Events
Events are messages published on specific Redis channels. Modules must
subscribe to the channel they want to be notified from. Usually channel
address is under a module name, something like
module/<module_id>/event/<event_name>
.
Events should respect the following rules:
- use past tense inside the name, like
ldap-provider-changed
,user-domain-changed
,module-added
… - accept a parameter in JSON format
- the parameter should contain minimal required info about the event
- optionally, the parameter can contain extra data which can ease the event usage
Well known events:
user-domain-changed
: the user domain has become available, has been removed, or its configuration has changed. The JSON parameter format is{"node_id":INT,"domain":STRING}
. Thenode_id
attribute is optional.ldap-provider-changed
: an external LDAP account provider was removed or added to a user-domain. The JSON parameter format is{"domain":STRING,"key":STRING}
.module-domain-changed
: the relation between modules and user domains has been changed. The JSON parameter format is{"domains":[DOMAIN1, DOMAIN2 ...], "modules":[MODULE_ID1, MODULE_ID2...]}
and reflects the domains and modules affected by the latest change.
Cluster events
Events fired by the cluster
agent (i.e. channel is cluster/event/<event name>
):
module-added
: the event is fired at the end of the add-module process to inform other modules that a new module has been installed on the clustermodule-removed
: the event is fired at the end of the remove-module process to inform other modules that a module has been removed on the clusterleader-changed
: a node was promoted to leader. Thenode_id
attribute indicates the new leader, andendpoint
its public Wireguard VPN endpoint address
Node events
Events fired by the node
agent (i.e. channel is node/<node id>/event/<event name>
):
fqdn-changed
: the node FQDN has changed. Thehostname
anddomain
attribute describe the new FQDN, while thenode
attribute contains the node ID that originated the event
Signaling events
To signal an event, just PUBLISH a message to the channel. All events take a JSON object as a parameter.
Example:
redis-cli PUBLISH module/traefik1/event/test '{"field": "value"}'
Handling events
Events are handled like actions by the agent
service.
Modules can define their event handlers under a dedicated directory:
${AGENT_INSTALL_DIR}/events/
. The handler directory contains one or more
step scripts that must be executable files. For instance:
- rootfull module:
/var/lib/nethserver/mymodule/events/some-event-happened/10handler
. - rootless module:
/home/mymodule/.config/events/some-event-happened/10handler
Like actions, the event payload can be read by the step scripts from the standard input file descriptor.
The event handlers receive two additional environment variables:
AGENT_EVENT_SOURCE
the agent ID that originated the eventAGENT_EVENT_NAME
the name of the event (it is the name same of the directory where of the event handler)
Lines sent to standard error and standard output are relayed to the system log.
Similarly to actions, if an handler step exit code is non-zero, the handler execution is aborted. Subsequent steps are not executed and an error message is sent to the log.