mirror of
https://github.com/xcat2/confluent.git
synced 2025-01-28 11:57:37 +00:00
Restore error handling to SNMP
Properly carry and reconstitute exceptions used to drive the specific errors.
This commit is contained in:
parent
374b87e2d7
commit
1aea406852
@ -25,9 +25,10 @@ def deserialize_exc(msg):
|
||||
return Exception(excd[1])
|
||||
if excd[0] not in globals():
|
||||
return Exception('Cannot deserialize: {0}'.format(repr(excd)))
|
||||
if not issubclass(excd[0], ConfluentException):
|
||||
classn = globals()[excd[0]]
|
||||
if not issubclass(classn, ConfluentException):
|
||||
return Exception('Cannot deserialize: {0}'.format(repr(excd)))
|
||||
return globals(excd[0])(*excd[1])
|
||||
return classn(*excd[1])
|
||||
|
||||
class ConfluentException(Exception):
|
||||
apierrorcode = 500
|
||||
|
@ -184,10 +184,16 @@ def _offload_map_switch(switch, password, user):
|
||||
while evtid in _offloadevts:
|
||||
evtid = random.randint(0, 4294967295)
|
||||
_offloadevts[evtid] = eventlet.Event()
|
||||
_offloader.stdin.write(msgpack.packb((evtid, switch, password, user), use_bin_type=False))
|
||||
_offloader.stdin.write(msgpack.packb((evtid, switch, password, user),
|
||||
use_bin_type=True))
|
||||
_offloader.stdin.flush()
|
||||
result = _offloadevts[evtid].wait()
|
||||
del _offloadevts[evtid]
|
||||
if len(result) == 2:
|
||||
if result[0] == 1:
|
||||
raise exc.deserialize_exc(result[1])
|
||||
elif result[0] == 2:
|
||||
raise Exception(result[1])
|
||||
return result
|
||||
|
||||
|
||||
@ -206,7 +212,7 @@ def _start_offloader():
|
||||
|
||||
|
||||
def _recv_offload():
|
||||
upacker = msgpack.Unpacker(raw=False)
|
||||
upacker = msgpack.Unpacker(encoding='utf8')
|
||||
instream = _offloader.stdout.fileno()
|
||||
while True:
|
||||
select.select([_offloader.stdout], [], [])
|
||||
@ -311,17 +317,24 @@ def _map_switch_backend(args):
|
||||
def _snmp_map_switch_relay(rqid, switch, password, user):
|
||||
try:
|
||||
res = _snmp_map_switch(switch, password, user)
|
||||
payload = msgpack.packb((rqid,) + res, use_bin_type=True)
|
||||
try:
|
||||
sys.stdout.buffer.write(msgpack.packb((rqid,) + res,
|
||||
use_bin_type=False))
|
||||
sys.stdout.buffer.write(payload)
|
||||
except AttributeError:
|
||||
sys.stdout.write(msgpack.packb((rqid,) + res,
|
||||
use_bin_type=False))
|
||||
sys.stdout.write(payload)
|
||||
except exc.ConfluentException as e:
|
||||
nestedexc = e.serialize()
|
||||
payload = msgpack.packb((rqid, 1, nestedexc), use_bin_type=True)
|
||||
try:
|
||||
sys.stdout.buffer.write(payload)
|
||||
except AttributeError:
|
||||
sys.stdout.write(payload)
|
||||
except Exception as e:
|
||||
payload = msgpack.packb((rqid, 2, str(e)), use_bin_type=True)
|
||||
try:
|
||||
sys.stdout.buffer.write(msgpack.packb(str(e)))
|
||||
sys.stdout.buffer.write(payload)
|
||||
except AttributeError:
|
||||
sys.stdout.write(msgpack.packb(str(e)))
|
||||
sys.stdout.write(payload)
|
||||
finally:
|
||||
sys.stdout.flush()
|
||||
|
||||
@ -651,7 +664,7 @@ def rescan(cfg):
|
||||
|
||||
if __name__ == '__main__':
|
||||
if len(sys.argv) > 1 and sys.argv[1] == '-o':
|
||||
upacker = msgpack.Unpacker(raw=False)
|
||||
upacker = msgpack.Unpacker(encoding='utf8')
|
||||
currfl = fcntl.fcntl(sys.stdin.fileno(), fcntl.F_GETFL)
|
||||
fcntl.fcntl(sys.stdin.fileno(), fcntl.F_SETFL, currfl | os.O_NONBLOCK)
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user