Statistics
| Branch: | Tag: | Revision:

root / lib / errors.py @ 6b9b18a2

History | View | Annotate | Download (9.8 kB)

1 2f31098c Iustin Pop
#
2 a8083063 Iustin Pop
#
3 a8083063 Iustin Pop
4 4b63dc7a Iustin Pop
# Copyright (C) 2006, 2007, 2008, 2009, 2010 Google Inc.
5 a8083063 Iustin Pop
#
6 a8083063 Iustin Pop
# This program is free software; you can redistribute it and/or modify
7 a8083063 Iustin Pop
# it under the terms of the GNU General Public License as published by
8 a8083063 Iustin Pop
# the Free Software Foundation; either version 2 of the License, or
9 a8083063 Iustin Pop
# (at your option) any later version.
10 a8083063 Iustin Pop
#
11 a8083063 Iustin Pop
# This program is distributed in the hope that it will be useful, but
12 a8083063 Iustin Pop
# WITHOUT ANY WARRANTY; without even the implied warranty of
13 a8083063 Iustin Pop
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14 a8083063 Iustin Pop
# General Public License for more details.
15 a8083063 Iustin Pop
#
16 a8083063 Iustin Pop
# You should have received a copy of the GNU General Public License
17 a8083063 Iustin Pop
# along with this program; if not, write to the Free Software
18 a8083063 Iustin Pop
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
19 a8083063 Iustin Pop
# 02110-1301, USA.
20 a8083063 Iustin Pop
21 a8083063 Iustin Pop
22 a8083063 Iustin Pop
"""Ganeti exception handling"""
23 a8083063 Iustin Pop
24 a8083063 Iustin Pop
25 5c983ee5 Iustin Pop
# OpPrereqError failure types
26 5c983ee5 Iustin Pop
27 104f4ca1 Iustin Pop
# resolver errors
28 104f4ca1 Iustin Pop
ECODE_RESOLVER = "resolver_error"
29 5c983ee5 Iustin Pop
# not enough resources (iallocator failure, disk space, memory, etc.)
30 5c983ee5 Iustin Pop
ECODE_NORES = "insufficient_resources"
31 5c983ee5 Iustin Pop
# wrong arguments (at syntax level)
32 5c983ee5 Iustin Pop
ECODE_INVAL = "wrong_input"
33 5c983ee5 Iustin Pop
# wrong entity state
34 5c983ee5 Iustin Pop
ECODE_STATE = "wrong_state"
35 5c983ee5 Iustin Pop
# entity not found
36 5c983ee5 Iustin Pop
ECODE_NOENT = "unknown_entity"
37 5c983ee5 Iustin Pop
# entity already exists
38 5c983ee5 Iustin Pop
ECODE_EXISTS = "already_exists"
39 5c983ee5 Iustin Pop
# resource not unique (e.g. MAC or IP duplication)
40 5c983ee5 Iustin Pop
ECODE_NOTUNIQUE = "resource_not_unique"
41 5c983ee5 Iustin Pop
# internal cluster error
42 5c983ee5 Iustin Pop
ECODE_FAULT = "internal_error"
43 5c983ee5 Iustin Pop
# environment error (e.g. node disk error)
44 5c983ee5 Iustin Pop
ECODE_ENVIRON = "environment_error"
45 5c983ee5 Iustin Pop
46 df156277 Michael Hanselmann
#: List of all failure types
47 df156277 Michael Hanselmann
ECODE_ALL = frozenset([
48 df156277 Michael Hanselmann
  ECODE_RESOLVER,
49 df156277 Michael Hanselmann
  ECODE_NORES,
50 df156277 Michael Hanselmann
  ECODE_INVAL,
51 df156277 Michael Hanselmann
  ECODE_STATE,
52 df156277 Michael Hanselmann
  ECODE_NOENT,
53 df156277 Michael Hanselmann
  ECODE_EXISTS,
54 df156277 Michael Hanselmann
  ECODE_NOTUNIQUE,
55 df156277 Michael Hanselmann
  ECODE_FAULT,
56 df156277 Michael Hanselmann
  ECODE_ENVIRON,
57 df156277 Michael Hanselmann
  ])
58 df156277 Michael Hanselmann
59 5c983ee5 Iustin Pop
60 a8083063 Iustin Pop
class GenericError(Exception):
61 a8083063 Iustin Pop
  """Base exception for Ganeti.
62 a8083063 Iustin Pop

63 a8083063 Iustin Pop
  """
64 a8083063 Iustin Pop
  pass
65 a8083063 Iustin Pop
66 a8083063 Iustin Pop
67 a8083063 Iustin Pop
class LVMError(GenericError):
68 a8083063 Iustin Pop
  """LVM-related exception.
69 a8083063 Iustin Pop

70 a8083063 Iustin Pop
  This exception codifies problems with LVM setup.
71 a8083063 Iustin Pop

72 a8083063 Iustin Pop
  """
73 a8083063 Iustin Pop
  pass
74 a8083063 Iustin Pop
75 a8083063 Iustin Pop
76 a8083063 Iustin Pop
class LockError(GenericError):
77 a8083063 Iustin Pop
  """Lock error exception.
78 a8083063 Iustin Pop

79 a8083063 Iustin Pop
  This signifies problems in the locking subsystem.
80 a8083063 Iustin Pop

81 a8083063 Iustin Pop
  """
82 a8083063 Iustin Pop
  pass
83 a8083063 Iustin Pop
84 a8083063 Iustin Pop
85 a8083063 Iustin Pop
class HypervisorError(GenericError):
86 a8083063 Iustin Pop
  """Hypervisor-related exception.
87 a8083063 Iustin Pop

88 a8083063 Iustin Pop
  This is raised in case we can't communicate with the hypervisor
89 a8083063 Iustin Pop
  properly.
90 a8083063 Iustin Pop

91 a8083063 Iustin Pop
  """
92 a8083063 Iustin Pop
  pass
93 a8083063 Iustin Pop
94 a8083063 Iustin Pop
95 a8083063 Iustin Pop
class ProgrammerError(GenericError):
96 a8083063 Iustin Pop
  """Programming-related error.
97 a8083063 Iustin Pop

98 a8083063 Iustin Pop
  This is raised in cases we determine that the calling conventions
99 a8083063 Iustin Pop
  have been violated, meaning we got some desynchronisation between
100 a8083063 Iustin Pop
  parts of our code. It signifies a real programming bug.
101 a8083063 Iustin Pop

102 a8083063 Iustin Pop
  """
103 a8083063 Iustin Pop
  pass
104 a8083063 Iustin Pop
105 a8083063 Iustin Pop
106 a8083063 Iustin Pop
class BlockDeviceError(GenericError):
107 a8083063 Iustin Pop
  """Block-device related exception.
108 a8083063 Iustin Pop

109 a8083063 Iustin Pop
  This is raised in case we can't setup the instance's block devices
110 a8083063 Iustin Pop
  properly.
111 a8083063 Iustin Pop

112 a8083063 Iustin Pop
  """
113 a8083063 Iustin Pop
  pass
114 a8083063 Iustin Pop
115 a8083063 Iustin Pop
116 a8083063 Iustin Pop
class ConfigurationError(GenericError):
117 a8083063 Iustin Pop
  """Configuration related exception.
118 a8083063 Iustin Pop

119 a8083063 Iustin Pop
  Things like having an instance with a primary node that doesn't
120 a8083063 Iustin Pop
  exist in the config or such raise this exception.
121 a8083063 Iustin Pop

122 a8083063 Iustin Pop
  """
123 a8083063 Iustin Pop
  pass
124 a8083063 Iustin Pop
125 a8083063 Iustin Pop
126 4b63dc7a Iustin Pop
class ConfigVersionMismatch(ConfigurationError):
127 4b63dc7a Iustin Pop
  """Version mismatch in the configuration file.
128 4b63dc7a Iustin Pop

129 4b63dc7a Iustin Pop
  The error has two arguments: the expected and the actual found
130 4b63dc7a Iustin Pop
  version.
131 4b63dc7a Iustin Pop

132 4b63dc7a Iustin Pop
  """
133 4b63dc7a Iustin Pop
  pass
134 4b63dc7a Iustin Pop
135 4b63dc7a Iustin Pop
136 2c8a5690 Guido Trotter
class ReservationError(GenericError):
137 2c8a5690 Guido Trotter
  """Errors reserving a resource.
138 2c8a5690 Guido Trotter

139 2c8a5690 Guido Trotter
  """
140 2c8a5690 Guido Trotter
141 2c8a5690 Guido Trotter
142 a8083063 Iustin Pop
class RemoteError(GenericError):
143 a8083063 Iustin Pop
  """Programming-related error on remote call.
144 a8083063 Iustin Pop

145 a8083063 Iustin Pop
  This is raised when an unhandled error occurs in a call to a
146 a8083063 Iustin Pop
  remote node.  It usually signifies a real programming bug.
147 a8083063 Iustin Pop

148 a8083063 Iustin Pop
  """
149 a8083063 Iustin Pop
  pass
150 a8083063 Iustin Pop
151 a8083063 Iustin Pop
152 f4a2f532 Guido Trotter
class SignatureError(GenericError):
153 f4a2f532 Guido Trotter
  """Error authenticating a remote message.
154 f4a2f532 Guido Trotter

155 f4a2f532 Guido Trotter
  This is raised when the hmac signature on a message doesn't verify correctly
156 f4a2f532 Guido Trotter
  to the message itself. It can happen because of network unreliability or
157 f4a2f532 Guido Trotter
  because of spurious traffic.
158 f4a2f532 Guido Trotter

159 f4a2f532 Guido Trotter
  """
160 f4a2f532 Guido Trotter
  pass
161 f4a2f532 Guido Trotter
162 f4a2f532 Guido Trotter
163 a8083063 Iustin Pop
class ParameterError(GenericError):
164 a8083063 Iustin Pop
  """A passed parameter to a command is invalid.
165 a8083063 Iustin Pop

166 a8083063 Iustin Pop
  This is raised when the parameter passed to a request function is
167 a8083063 Iustin Pop
  invalid. Correct code should have verified this before passing the
168 a8083063 Iustin Pop
  request structure.
169 a8083063 Iustin Pop

170 a8083063 Iustin Pop
  The argument to this exception should be the parameter name.
171 a8083063 Iustin Pop

172 a8083063 Iustin Pop
  """
173 a8083063 Iustin Pop
  pass
174 a8083063 Iustin Pop
175 a8083063 Iustin Pop
176 a8083063 Iustin Pop
class OpPrereqError(GenericError):
177 a8083063 Iustin Pop
  """Prerequisites for the OpCode are not fulfilled.
178 a8083063 Iustin Pop

179 5c983ee5 Iustin Pop
  This exception will have either one or two arguments. For the
180 5c983ee5 Iustin Pop
  two-argument construction, the second argument should be one of the
181 5c983ee5 Iustin Pop
  ECODE_* codes.
182 5c983ee5 Iustin Pop

183 a8083063 Iustin Pop
  """
184 a8083063 Iustin Pop
185 098c0958 Michael Hanselmann
186 a8083063 Iustin Pop
class OpExecError(GenericError):
187 a8083063 Iustin Pop
  """Error during OpCode execution.
188 a8083063 Iustin Pop

189 a8083063 Iustin Pop
  """
190 a8083063 Iustin Pop
191 098c0958 Michael Hanselmann
192 a8083063 Iustin Pop
class OpCodeUnknown(GenericError):
193 a8083063 Iustin Pop
  """Unknown opcode submitted.
194 a8083063 Iustin Pop

195 a8083063 Iustin Pop
  This signifies a mismatch between the definitions on the client and
196 a8083063 Iustin Pop
  server side.
197 a8083063 Iustin Pop

198 a8083063 Iustin Pop
  """
199 a8083063 Iustin Pop
200 098c0958 Michael Hanselmann
201 685ee993 Iustin Pop
class JobLost(GenericError):
202 685ee993 Iustin Pop
  """Submitted job lost.
203 685ee993 Iustin Pop

204 685ee993 Iustin Pop
  The job was submitted but it cannot be found in the current job
205 685ee993 Iustin Pop
  list.
206 685ee993 Iustin Pop

207 685ee993 Iustin Pop
  """
208 685ee993 Iustin Pop
209 685ee993 Iustin Pop
210 3d6c5566 Guido Trotter
class JobFileCorrupted(GenericError):
211 3d6c5566 Guido Trotter
  """Job file could not be properly decoded/restored.
212 3d6c5566 Guido Trotter

213 3d6c5566 Guido Trotter
  """
214 3d6c5566 Guido Trotter
215 3d6c5566 Guido Trotter
216 89e1fc26 Iustin Pop
class ResolverError(GenericError):
217 89e1fc26 Iustin Pop
  """Host name cannot be resolved.
218 89e1fc26 Iustin Pop

219 89e1fc26 Iustin Pop
  This is not a normal situation for Ganeti, as we rely on having a
220 89e1fc26 Iustin Pop
  working resolver.
221 89e1fc26 Iustin Pop

222 89e1fc26 Iustin Pop
  The non-resolvable hostname is available as the first element of the
223 89e1fc26 Iustin Pop
  args tuple; the other two elements of the tuple are the first two
224 89e1fc26 Iustin Pop
  args of the socket.gaierror exception (error code and description).
225 89e1fc26 Iustin Pop

226 89e1fc26 Iustin Pop
  """
227 89e1fc26 Iustin Pop
228 89e1fc26 Iustin Pop
229 a8083063 Iustin Pop
class HooksFailure(GenericError):
230 a8083063 Iustin Pop
  """A generic hook failure.
231 a8083063 Iustin Pop

232 a8083063 Iustin Pop
  This signifies usually a setup misconfiguration.
233 a8083063 Iustin Pop

234 a8083063 Iustin Pop
  """
235 a8083063 Iustin Pop
236 098c0958 Michael Hanselmann
237 a8083063 Iustin Pop
class HooksAbort(HooksFailure):
238 a8083063 Iustin Pop
  """A required hook has failed.
239 a8083063 Iustin Pop

240 a8083063 Iustin Pop
  This caused an abort of the operation in the initial phase. This
241 a8083063 Iustin Pop
  exception always has an attribute args which is a list of tuples of:
242 a8083063 Iustin Pop
    - node: the source node on which this hooks has failed
243 a8083063 Iustin Pop
    - script: the name of the script which aborted the run
244 a8083063 Iustin Pop

245 a8083063 Iustin Pop
  """
246 a8083063 Iustin Pop
247 098c0958 Michael Hanselmann
248 a8083063 Iustin Pop
class UnitParseError(GenericError):
249 a8083063 Iustin Pop
  """Unable to parse size unit.
250 a8083063 Iustin Pop

251 a8083063 Iustin Pop
  """
252 a8083063 Iustin Pop
253 ac2d0fe4 Michael Hanselmann
254 31155d60 Balazs Lecz
class ParseError(GenericError):
255 31155d60 Balazs Lecz
  """Generic parse error.
256 31155d60 Balazs Lecz

257 31155d60 Balazs Lecz
  Raised when unable to parse user input.
258 31155d60 Balazs Lecz

259 31155d60 Balazs Lecz
  """
260 31155d60 Balazs Lecz
261 31155d60 Balazs Lecz
262 a5728081 Guido Trotter
class TypeEnforcementError(GenericError):
263 a5728081 Guido Trotter
  """Unable to enforce data type.
264 a5728081 Guido Trotter

265 a5728081 Guido Trotter
  """
266 a8083063 Iustin Pop
267 ac2d0fe4 Michael Hanselmann
268 a8083063 Iustin Pop
class SshKeyError(GenericError):
269 a8083063 Iustin Pop
  """Invalid SSH key.
270 b0059682 Guido Trotter

271 a8083063 Iustin Pop
  """
272 5c947f38 Iustin Pop
273 5c947f38 Iustin Pop
274 5c947f38 Iustin Pop
class TagError(GenericError):
275 5c947f38 Iustin Pop
  """Generic tag error.
276 5c947f38 Iustin Pop

277 5c947f38 Iustin Pop
  The argument to this exception will show the exact error.
278 5c947f38 Iustin Pop

279 5c947f38 Iustin Pop
  """
280 7bca53e4 Michael Hanselmann
281 7bca53e4 Michael Hanselmann
282 7bca53e4 Michael Hanselmann
class CommandError(GenericError):
283 7bca53e4 Michael Hanselmann
  """External command error.
284 7bca53e4 Michael Hanselmann

285 7bca53e4 Michael Hanselmann
  """
286 e50bdd68 Guido Trotter
287 e50bdd68 Guido Trotter
288 ac2d0fe4 Michael Hanselmann
class StorageError(GenericError):
289 ac2d0fe4 Michael Hanselmann
  """Storage-related exception.
290 ac2d0fe4 Michael Hanselmann

291 ac2d0fe4 Michael Hanselmann
  """
292 ac2d0fe4 Michael Hanselmann
293 589dee9a Guido Trotter
294 589dee9a Guido Trotter
class InotifyError(GenericError):
295 589dee9a Guido Trotter
  """Error raised when there is a failure setting up an inotify watcher.
296 589dee9a Guido Trotter

297 589dee9a Guido Trotter
  """
298 589dee9a Guido Trotter
299 ac2d0fe4 Michael Hanselmann
300 e50bdd68 Guido Trotter
class QuitGanetiException(Exception):
301 7e975535 Stephen Shirley
  """Signal Ganeti that it must quit.
302 e50bdd68 Guido Trotter

303 0623d351 Iustin Pop
  This is not necessarily an error (and thus not a subclass of
304 0623d351 Iustin Pop
  GenericError), but it's an exceptional circumstance and it is thus
305 0623d351 Iustin Pop
  treated. This instance should be instantiated with two values. The
306 0623d351 Iustin Pop
  first one will specify the return code to the caller, and the second
307 0623d351 Iustin Pop
  one will be the returned result (either as an error or as a normal
308 0623d351 Iustin Pop
  result). Usually only the leave cluster rpc call should return
309 0623d351 Iustin Pop
  status True (as there it's expected we quit), every other call will
310 0623d351 Iustin Pop
  return status False (as a critical error was encountered).
311 e50bdd68 Guido Trotter

312 c41eea6e Iustin Pop
  Examples::
313 c41eea6e Iustin Pop

314 e50bdd68 Guido Trotter
    # Return a result of "True" to the caller, but quit ganeti afterwards
315 0623d351 Iustin Pop
    raise QuitGanetiException(True, None)
316 e50bdd68 Guido Trotter
    # Send an error to the caller, and quit ganeti
317 0623d351 Iustin Pop
    raise QuitGanetiException(False, "Fatal safety violation, shutting down")
318 e50bdd68 Guido Trotter

319 e50bdd68 Guido Trotter
  """
320 e50bdd68 Guido Trotter
321 f1da30e6 Michael Hanselmann
322 d11bda8d Iustin Pop
class JobQueueError(GenericError):
323 f1da30e6 Michael Hanselmann
  """Job queue error.
324 f1da30e6 Michael Hanselmann

325 f1da30e6 Michael Hanselmann
  """
326 6797ec29 Iustin Pop
327 6797ec29 Iustin Pop
328 686d7433 Iustin Pop
class JobQueueDrainError(JobQueueError):
329 686d7433 Iustin Pop
  """Job queue is marked for drain error.
330 686d7433 Iustin Pop

331 686d7433 Iustin Pop
  This is raised when a job submission attempt is made but the queue
332 686d7433 Iustin Pop
  is marked for drain.
333 686d7433 Iustin Pop

334 686d7433 Iustin Pop
  """
335 686d7433 Iustin Pop
336 686d7433 Iustin Pop
337 f87b405e Michael Hanselmann
class JobQueueFull(JobQueueError):
338 f87b405e Michael Hanselmann
  """Job queue full error.
339 f87b405e Michael Hanselmann

340 f87b405e Michael Hanselmann
  Raised when job queue size reached its hard limit.
341 f87b405e Michael Hanselmann

342 f87b405e Michael Hanselmann
  """
343 f87b405e Michael Hanselmann
344 f87b405e Michael Hanselmann
345 b125e3b3 Guido Trotter
class ConfdRequestError(GenericError):
346 b125e3b3 Guido Trotter
  """A request error in Ganeti confd.
347 b125e3b3 Guido Trotter

348 b125e3b3 Guido Trotter
  Events that should make confd abort the current request and proceed serving
349 b125e3b3 Guido Trotter
  different ones.
350 b125e3b3 Guido Trotter

351 b125e3b3 Guido Trotter
  """
352 b125e3b3 Guido Trotter
353 b125e3b3 Guido Trotter
354 9748ab35 Guido Trotter
class ConfdMagicError(GenericError):
355 9748ab35 Guido Trotter
  """A magic fourcc error in Ganeti confd.
356 9748ab35 Guido Trotter

357 9748ab35 Guido Trotter
  Errors processing the fourcc in ganeti confd datagrams.
358 9748ab35 Guido Trotter

359 9748ab35 Guido Trotter
  """
360 9748ab35 Guido Trotter
361 9748ab35 Guido Trotter
362 e4ccf6cd Guido Trotter
class ConfdClientError(GenericError):
363 e4ccf6cd Guido Trotter
  """A magic fourcc error in Ganeti confd.
364 e4ccf6cd Guido Trotter

365 e4ccf6cd Guido Trotter
  Errors in the confd client library.
366 e4ccf6cd Guido Trotter

367 e4ccf6cd Guido Trotter
  """
368 e4ccf6cd Guido Trotter
369 e4ccf6cd Guido Trotter
370 c8eded0b Guido Trotter
class UdpDataSizeError(GenericError):
371 c8eded0b Guido Trotter
  """UDP payload too big.
372 c8eded0b Guido Trotter

373 c8eded0b Guido Trotter
  """
374 c8eded0b Guido Trotter
375 c8eded0b Guido Trotter
376 4c32a8bd Luca Bigliardi
class NoCtypesError(GenericError):
377 4c32a8bd Luca Bigliardi
  """python ctypes module is not found in the system.
378 4c32a8bd Luca Bigliardi

379 4c32a8bd Luca Bigliardi
  """
380 4c32a8bd Luca Bigliardi
381 4c32a8bd Luca Bigliardi
382 8b312c1d Manuel Franceschini
class IPAddressError(GenericError):
383 8b312c1d Manuel Franceschini
  """Generic IP address error.
384 8b312c1d Manuel Franceschini

385 8b312c1d Manuel Franceschini
  """
386 8b312c1d Manuel Franceschini
387 8b312c1d Manuel Franceschini
388 7a8bda3f Michael Hanselmann
class LuxiError(GenericError):
389 7a8bda3f Michael Hanselmann
  """LUXI error.
390 7a8bda3f Michael Hanselmann

391 7a8bda3f Michael Hanselmann
  """
392 7a8bda3f Michael Hanselmann
393 7a8bda3f Michael Hanselmann
394 6797ec29 Iustin Pop
# errors should be added above
395 6797ec29 Iustin Pop
396 6797ec29 Iustin Pop
397 6797ec29 Iustin Pop
def GetErrorClass(name):
398 6797ec29 Iustin Pop
  """Return the class of an exception.
399 6797ec29 Iustin Pop

400 6797ec29 Iustin Pop
  Given the class name, return the class itself.
401 6797ec29 Iustin Pop

402 6797ec29 Iustin Pop
  @type name: str
403 6797ec29 Iustin Pop
  @param name: the exception name
404 6797ec29 Iustin Pop
  @rtype: class
405 6797ec29 Iustin Pop
  @return: the actual class, or None if not found
406 6797ec29 Iustin Pop

407 6797ec29 Iustin Pop
  """
408 6797ec29 Iustin Pop
  item = globals().get(name, None)
409 6797ec29 Iustin Pop
  if item is not None:
410 6797ec29 Iustin Pop
    if not (isinstance(item, type(Exception)) and
411 6797ec29 Iustin Pop
            issubclass(item, GenericError)):
412 6797ec29 Iustin Pop
      item = None
413 6797ec29 Iustin Pop
  return item
414 6956e9cd Iustin Pop
415 6956e9cd Iustin Pop
416 6956e9cd Iustin Pop
def EncodeException(err):
417 6956e9cd Iustin Pop
  """Encodes an exception into a format that L{MaybeRaise} will recognise.
418 6956e9cd Iustin Pop

419 6956e9cd Iustin Pop
  The passed L{err} argument will be formatted as a tuple (exception
420 6956e9cd Iustin Pop
  name, arguments) that the MaybeRaise function will recognise.
421 6956e9cd Iustin Pop

422 6956e9cd Iustin Pop
  @type err: GenericError child
423 6956e9cd Iustin Pop
  @param err: usually a child of GenericError (but any exception
424 6956e9cd Iustin Pop
      will be accepted)
425 6956e9cd Iustin Pop
  @rtype: tuple
426 6956e9cd Iustin Pop
  @return: tuple of (exception name, exception arguments)
427 6956e9cd Iustin Pop

428 6956e9cd Iustin Pop
  """
429 6956e9cd Iustin Pop
  return (err.__class__.__name__, err.args)
430 6956e9cd Iustin Pop
431 6956e9cd Iustin Pop
432 84f790e6 Michael Hanselmann
def GetEncodedError(result):
433 84f790e6 Michael Hanselmann
  """If this looks like an encoded Ganeti exception, return it.
434 6956e9cd Iustin Pop

435 6956e9cd Iustin Pop
  This function tries to parse the passed argument and if it looks
436 84f790e6 Michael Hanselmann
  like an encoding done by EncodeException, it will return the class
437 84f790e6 Michael Hanselmann
  object and arguments.
438 6956e9cd Iustin Pop

439 6956e9cd Iustin Pop
  """
440 6956e9cd Iustin Pop
  tlt = (tuple, list)
441 6956e9cd Iustin Pop
  if (isinstance(result, tlt) and len(result) == 2 and
442 6956e9cd Iustin Pop
      isinstance(result[1], tlt)):
443 6956e9cd Iustin Pop
    # custom ganeti errors
444 84f790e6 Michael Hanselmann
    errcls = GetErrorClass(result[0])
445 84f790e6 Michael Hanselmann
    if errcls:
446 84f790e6 Michael Hanselmann
      return (errcls, tuple(result[1]))
447 84f790e6 Michael Hanselmann
448 84f790e6 Michael Hanselmann
  return None
449 84f790e6 Michael Hanselmann
450 84f790e6 Michael Hanselmann
451 84f790e6 Michael Hanselmann
def MaybeRaise(result):
452 84f790e6 Michael Hanselmann
  """If this looks like an encoded Ganeti exception, raise it.
453 84f790e6 Michael Hanselmann

454 84f790e6 Michael Hanselmann
  This function tries to parse the passed argument and if it looks
455 84f790e6 Michael Hanselmann
  like an encoding done by EncodeException, it will re-raise it.
456 84f790e6 Michael Hanselmann

457 84f790e6 Michael Hanselmann
  """
458 84f790e6 Michael Hanselmann
  error = GetEncodedError(result)
459 84f790e6 Michael Hanselmann
  if error:
460 84f790e6 Michael Hanselmann
    (errcls, args) = error
461 84f790e6 Michael Hanselmann
    raise errcls, args