diff options
author | Tomás Touceda <chiiph@leap.se> | 2013-06-28 14:55:33 -0300 |
---|---|---|
committer | Tomás Touceda <chiiph@leap.se> | 2013-06-28 14:55:33 -0300 |
commit | d071efe20a285e579111f568e2ff994a6171249f (patch) | |
tree | 824ea959c02c8ed3af36c0cec8421e0748d311cc /src/leap/common/events/README.rst | |
parent | b966eec96fd3621908baab8697de8e2ed61ba136 (diff) | |
parent | a0f78f9d708cc6fe686ee5860cdc34909391b14b (diff) |
Merge branch 'release-0.2.5'
Diffstat (limited to 'src/leap/common/events/README.rst')
-rw-r--r-- | src/leap/common/events/README.rst | 53 |
1 files changed, 53 insertions, 0 deletions
diff --git a/src/leap/common/events/README.rst b/src/leap/common/events/README.rst new file mode 100644 index 0000000..813be8b --- /dev/null +++ b/src/leap/common/events/README.rst @@ -0,0 +1,53 @@ +Events mechanism +================ + +The events mechanism allows for "components" to send signal events to each +other by means of a centralized server. Components can register with the +server to receive signals of certain types, and they can also send signals to +the server that will then redistribute these signals to registered components. + + +Listening daemons +----------------- + +Both components and the server listen for incoming messages by using a +listening daemon that runs in its own thread. The server daemon has to be +started explicitly, while components daemon will be started whenever a +component registers with the server to receive messages. + + +How to use it +------------- + +To start the events server: + +>>> from leap.common.events import server +>>> server.ensure_server(port=8090) + +To register a callback to be called when a given signal is raised: + +>>> from leap.common.events import ( +>>> register, +>>> events_pb2 as proto, +>>> ) +>>> +>>> def mycallback(sigreq): +>>> print str(sigreq) +>>> +>>> events.register(signal=proto.CLIENT_UID, callback=mycallback) + +To signal an event: + +>>> from leap.common.events import ( +>>> signal, +>>> events_pb2 as proto, +>>> ) +>>> signal(proto.CLIENT_UID) + +Adding events +------------- + +* Add the new event under enum ``Event`` in ``events.proto`` +* Compile the new protocolbuffers file:: + + make |