Source code for platypush.plugins.shell

import subprocess

from platypush.plugins import Plugin, action


[docs]class ShellPlugin(Plugin): """ Plugin to run custom shell commands. """
[docs] @action def exec(self, cmd, background=False, ignore_errors=False): """ Execute a command. :param cmd: Command to execute :type cmd: str :param background: If set to True, execute the process in the background, otherwise wait for the process termination and return its output (deafult: False). :param ignore_errors: If set, then any errors in the command execution will be ignored. Otherwise a RuntimeError will be thrown (default value: False) :returns: A response object where the ``output`` field will contain the command output as a string, and the ``errors`` field will contain whatever was sent to stderr. """ if background: subprocess.Popen(cmd, shell=True) try: return subprocess.check_output( cmd, stderr=subprocess.STDOUT, shell=True).decode('utf-8') except subprocess.CalledProcessError as e: if ignore_errors: self.logger.warning('Command {} failed with error: {}'.format( cmd, e.output.decode('utf-8'))) else: raise RuntimeError(e.output.decode('utf-8'))
# vim:sw=4:ts=4:et: