D7net
Home
Console
Upload
information
Create File
Create Folder
About
Tools
:
/
opt
/
saltstack
/
salt
/
lib
/
python3.10
/
site-packages
/
salt
/
proxy
/
Filename :
ssh_sample.py
back
Copy
""" This is a simple proxy-minion designed to connect to and communicate with a server that exposes functionality via SSH. This can be used as an option when the device does not provide an api over HTTP and doesn't have the python stack to run a minion. """ import logging import salt.utils.json import salt.utils.vt_helper from salt.utils.vt import TerminalException # This must be present or the Salt loader won't load this module __proxyenabled__ = ["ssh_sample"] log = logging.getLogger(__file__) # This does nothing, it's here just as an example and to provide a log # entry when the module is loaded. def __virtual__(): """ Only return if all the modules are available """ log.info("ssh_sample proxy __virtual__() called...") return True def init(opts): """ Required. Can be used to initialize the server connection. """ try: __context__["server"] = salt.utils.vt_helper.SSHConnection( host=__opts__["proxy"]["host"], username=__opts__["proxy"]["username"], password=__opts__["proxy"]["password"], ) out, err = __context__["server"].sendline("help") __context__["initialized"] = True except TerminalException as e: log.error(e) return False def initialized(): """ Since grains are loaded in many different places and some of those places occur before the proxy can be initialized, return whether our init() function has been called """ return __context__.get("initialized", False) def grains(): """ Get the grains from the proxied device """ if not __context__.get("grains_cache", {}): cmd = "info" # Send the command to execute out, err = __context__["server"].sendline(cmd) # "scrape" the output and return the right fields as a dict __context__["grains_cache"] = parse(out) return __context__["grains_cache"] def grains_refresh(): """ Refresh the grains from the proxied device """ __context__["grains_cache"] = None return grains() def fns(): """ Method called by grains module. """ return { "details": ( "This key is here because a function in " "grains/ssh_sample.py called fns() here in the proxymodule." ) } def ping(): """ Required. Ping the device on the other end of the connection """ try: out, err = __context__["server"].sendline("help") return True except TerminalException as e: log.error(e) return False def shutdown(opts): """ Disconnect """ __context__["server"].close_connection() def parse(out): """ Extract json from out. Parameter out: Type string. The data returned by the ssh command. """ jsonret = [] in_json = False for ln_ in out.split("\n"): if "{" in ln_: in_json = True if in_json: jsonret.append(ln_) if "}" in ln_: in_json = False return salt.utils.json.loads("\n".join(jsonret)) def package_list(): """ List "packages" by executing a command via ssh This function is called in response to the salt command .. code-block:: bash salt target_minion pkg.list_pkgs """ # Send the command to execute out, err = __context__["server"].sendline("pkg_list\n") # "scrape" the output and return the right fields as a dict return parse(out) def package_install(name, **kwargs): """ Install a "package" on the ssh server """ cmd = "pkg_install " + name if kwargs.get("version", False): cmd += " " + kwargs["version"] # Send the command to execute out, err = __context__["server"].sendline(cmd) # "scrape" the output and return the right fields as a dict return parse(out) def package_remove(name): """ Remove a "package" on the ssh server """ cmd = "pkg_remove " + name # Send the command to execute out, err = __context__["server"].sendline(cmd) # "scrape" the output and return the right fields as a dict return parse(out) def service_list(): """ Start a "service" on the ssh server .. versionadded:: 2015.8.2 """ cmd = "ps" # Send the command to execute out, err = __context__["server"].sendline(cmd) # "scrape" the output and return the right fields as a dict return parse(out) def service_start(name): """ Start a "service" on the ssh server .. versionadded:: 2015.8.2 """ cmd = "start " + name # Send the command to execute out, err = __context__["server"].sendline(cmd) # "scrape" the output and return the right fields as a dict return parse(out) def service_stop(name): """ Stop a "service" on the ssh server .. versionadded:: 2015.8.2 """ cmd = "stop " + name # Send the command to execute out, err = __context__["server"].sendline(cmd) # "scrape" the output and return the right fields as a dict return parse(out) def service_restart(name): """ Restart a "service" on the ssh server .. versionadded:: 2015.8.2 """ cmd = "restart " + name # Send the command to execute out, err = __context__["server"].sendline(cmd) # "scrape" the output and return the right fields as a dict return parse(out)