D7net
Home
Console
Upload
information
Create File
Create Folder
About
Tools
:
/
opt
/
saltstack
/
salt
/
lib
/
python3.10
/
site-packages
/
salt
/
modules
/
Filename :
varnish.py
back
Copy
""" Support for Varnish .. versionadded:: 2014.7.0 .. note:: These functions are designed to work with all implementations of Varnish from 3.x onwards """ import logging import re import salt.utils.path log = logging.getLogger(__name__) # Define the module's virtual name __virtualname__ = "varnish" def __virtual__(): """ Only load the module if varnish is installed """ if salt.utils.path.which("varnishd") and salt.utils.path.which("varnishadm"): return __virtualname__ return ( False, "The varnish execution module failed to load: either varnishd or varnishadm is" " not in the path.", ) def _run_varnishadm(cmd, params=(), **kwargs): """ Execute varnishadm command return the output of the command cmd The command to run in varnishadm params Any additional args to add to the command line kwargs Additional options to pass to the salt cmd.run_all function """ cmd = ["varnishadm", cmd] cmd.extend([param for param in params if param is not None]) log.debug("Executing: %s", " ".join(cmd)) return __salt__["cmd.run_all"](cmd, python_shell=False, **kwargs) def version(): """ Return server version from varnishd -V CLI Example: .. code-block:: bash salt '*' varnish.version """ cmd = ["varnishd", "-V"] out = __salt__["cmd.run"](cmd, python_shell=False) ret = re.search(r"\(varnish-([^\)]+)\)", out).group(1) return ret def ban(ban_expression): """ Add ban to the varnish cache CLI Example: .. code-block:: bash salt '*' varnish.ban ban_expression """ return _run_varnishadm("ban", [ban_expression])["retcode"] == 0 def ban_list(): """ List varnish cache current bans CLI Example: .. code-block:: bash salt '*' varnish.ban_list """ ret = _run_varnishadm("ban.list") if ret["retcode"]: return False else: return ret["stdout"].split("\n")[1:] def purge(): """ Purge the varnish cache CLI Example: .. code-block:: bash salt '*' varnish.purge """ return ban("req.url ~ .") def param_set(param, value): """ Set a param in varnish cache CLI Example: .. code-block:: bash salt '*' varnish.param_set param value """ return _run_varnishadm("param.set", [param, str(value)])["retcode"] == 0 def param_show(param=None): """ Show params of varnish cache CLI Example: .. code-block:: bash salt '*' varnish.param_show param """ ret = _run_varnishadm("param.show", [param]) if ret["retcode"]: return False else: result = {} for line in ret["stdout"].split("\n"): m = re.search(r"^(\w+)\s+(.*)$", line) result[m.group(1)] = m.group(2) if param: # When we ask to varnishadm for a specific param, it gives full # info on what that parameter is, so we just process the first # line and we get out of the loop break return result