diff options
author | Martin Willi <martin@revosec.ch> | 2015-03-09 12:06:38 +0100 |
---|---|---|
committer | Martin Willi <martin@revosec.ch> | 2015-03-18 13:59:14 +0100 |
commit | 90c5b48c96d7d34fbc446660449892f3bd3b9040 (patch) | |
tree | f9ab6632ee59aaea0540d5f76f65f94f71087bce /src | |
parent | 288b6541739bb2e6ff766fbb8e7a803b3caf1f12 (diff) | |
download | strongswan-90c5b48c96d7d34fbc446660449892f3bd3b9040.tar.bz2 strongswan-90c5b48c96d7d34fbc446660449892f3bd3b9040.tar.xz |
vici: Catch Python GeneratorExit to properly cancel streamed event iteration
Diffstat (limited to 'src')
-rw-r--r-- | src/libcharon/plugins/vici/README.md | 5 | ||||
-rw-r--r-- | src/libcharon/plugins/vici/python/vici/session.py | 8 |
2 files changed, 12 insertions, 1 deletions
diff --git a/src/libcharon/plugins/vici/README.md b/src/libcharon/plugins/vici/README.md index 655f74911..0ce4271b0 100644 --- a/src/libcharon/plugins/vici/README.md +++ b/src/libcharon/plugins/vici/README.md @@ -909,6 +909,11 @@ event: for key in conn: print key +Please note that if the returned generator is not iterated completely, it must +be closed using _close()_. This is implicitly done when breaking from a loop, +but an explicit call may be required when directly iterating the generator with +_next()_. + ## Sorting in dictionaries ## In VICI, in some message trees the order of objects in dictionary matters. In diff --git a/src/libcharon/plugins/vici/python/vici/session.py b/src/libcharon/plugins/vici/python/vici/session.py index 65b89b5ba..da79ecd64 100644 --- a/src/libcharon/plugins/vici/python/vici/session.py +++ b/src/libcharon/plugins/vici/python/vici/session.py @@ -281,10 +281,16 @@ class SessionHandler(object): # issue command, and read any event messages packet = Packet.request(command, message) self.transport.send(packet) + exited = False while True: response = Packet.parse(self.transport.receive()) if response.response_type == Packet.EVENT: - yield Message.deserialize(response.payload) + if not exited: + try: + yield Message.deserialize(response.payload) + except GeneratorExit: + exited = True + pass else: break |