D7net
Home
Console
Upload
information
Create File
Create Folder
About
Tools
:
/
proc
/
self
/
root
/
opt
/
saltstack
/
salt
/
lib
/
python3.10
/
site-packages
/
salt
/
runners
/
Filename :
reactor.py
back
Copy
""" A convenience system to manage reactors Beginning in the 2017.7 release, the reactor runner requires that the reactor system is running. This is accomplished one of two ways, either by having reactors configured or by including ``reactor`` in the engine configuration for the Salt master. .. code-block:: yaml engines: - reactor """ import logging import salt.config import salt.syspaths import salt.utils.event import salt.utils.master import salt.utils.process import salt.utils.reactor from salt.exceptions import CommandExecutionError log = logging.getLogger(__name__) __func_alias__ = { "list_": "list", } def _reactor_system_available(): """ Helper to see if the reactor system is available """ if __opts__.get("engines", {}): if any([True for engine in __opts__["engines"] if "reactor" in engine]): return True elif __opts__.get("reactor", {}) and __opts__["reactor"]: return True return False def list_(saltenv="base", test=None): """ List currently configured reactors CLI Example: .. code-block:: bash salt-run reactor.list """ if not _reactor_system_available(): raise CommandExecutionError("Reactor system is not running.") with salt.utils.event.get_event( "master", __opts__["sock_dir"], opts=__opts__, listen=True, ) as sevent: master_key = salt.utils.master.get_master_key("root", __opts__) __jid_event__.fire_event({"key": master_key}, "salt/reactors/manage/list") results = sevent.get_event(wait=30, tag="salt/reactors/manage/list-results") reactors = results.get("reactors") return reactors def add(event, reactors, saltenv="base", test=None): """ Add a new reactor CLI Example: .. code-block:: bash salt-run reactor.add 'salt/cloud/*/destroyed' reactors='/srv/reactor/destroy/*.sls' """ if not _reactor_system_available(): raise CommandExecutionError("Reactor system is not running.") if isinstance(reactors, str): reactors = [reactors] with salt.utils.event.get_event( "master", __opts__["sock_dir"], opts=__opts__, listen=True, ) as sevent: master_key = salt.utils.master.get_master_key("root", __opts__) __jid_event__.fire_event( {"event": event, "reactors": reactors, "key": master_key}, "salt/reactors/manage/add", ) res = sevent.get_event(wait=30, tag="salt/reactors/manage/add-complete") return res.get("result") def delete(event, saltenv="base", test=None): """ Delete a reactor CLI Example: .. code-block:: bash salt-run reactor.delete 'salt/cloud/*/destroyed' """ if not _reactor_system_available(): raise CommandExecutionError("Reactor system is not running.") with salt.utils.event.get_event( "master", __opts__["sock_dir"], opts=__opts__, listen=True, ) as sevent: master_key = salt.utils.master.get_master_key("root", __opts__) __jid_event__.fire_event( {"event": event, "key": master_key}, "salt/reactors/manage/delete" ) res = sevent.get_event(wait=30, tag="salt/reactors/manage/delete-complete") return res.get("result") def is_leader(): """ Return whether the running reactor is acting as a leader (responding to events). CLI Example: .. code-block:: bash salt-run reactor.is_leader """ if not _reactor_system_available(): raise CommandExecutionError("Reactor system is not running.") with salt.utils.event.get_event( "master", __opts__["sock_dir"], opts=__opts__, listen=True, ) as sevent: master_key = salt.utils.master.get_master_key("root", __opts__) __jid_event__.fire_event({"key": master_key}, "salt/reactors/manage/is_leader") res = sevent.get_event(wait=30, tag="salt/reactors/manage/leader/value") return res["result"] def set_leader(value=True): """ Set the current reactor to act as a leader (responding to events). Defaults to True CLI Example: .. code-block:: bash salt-run reactor.set_leader True """ if not _reactor_system_available(): raise CommandExecutionError("Reactor system is not running.") with salt.utils.event.get_event( "master", __opts__["sock_dir"], opts=__opts__, listen=True, ) as sevent: master_key = salt.utils.master.get_master_key("root", __opts__) __jid_event__.fire_event( {"id": __opts__["id"], "value": value, "key": master_key}, "salt/reactors/manage/set_leader", ) res = sevent.get_event(wait=30, tag="salt/reactors/manage/leader/value") return res["result"]