Source code for scap.cmd

# -*- coding: utf-8 -*-
"""
    scap.cmd
    ~~~~~~~~~~~
    command execution

    Copyright © 2014-2017 Wikimedia Foundation and Contributors.

    This file is part of Scap.

    Scap is free software: you can redistribute it and/or modify
    it under the terms of the GNU General Public License as published by
    the Free Software Foundation, version 3.

    This program is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    GNU General Public License for more details.

    You should have received a copy of the GNU General Public License
    along with this program.  If not, see <http://www.gnu.org/licenses/>.
"""


[docs]class Command(object): """ Command is used to store a parameterized shell command for reuse by cluster_ssh and other utilities. The idea is that we store the command, along with any arguments that need to be filled in, then we can call the command later just like a normal python function, which returns the shell command to be ran. Usage Example:: import scap.cmd as cmd ssh = cmd.Command('/usr/bin/ssh', cmd.arg('user', '-oUser={}')) sudo = cmd.Command('sudo', cmd.arg('user', '-u {}'), '-n', '--') ssh('some.host', sudo('remote_cmd', 'some', 'args', user='sudo_user'), user='ssh_user') # result: ['/usr/bin/ssh', '-oUser=ssh_user', 'some.host', 'sudo', '-u sudo_user', '-n', '--', 'remote_cmd', 'some', 'args'] """
[docs] def __init__(self, *cmds): self.cmds = cmds
[docs] def __call__(self, *args, **values): result = [] parts = self.cmds + args for cmd in parts: rendered = cmd if callable(cmd): rendered = cmd(**values) if rendered: if isinstance(rendered, str): result.append(rendered) else: result.extend(rendered) return result
[docs]class arg(object): """ Represent a named parameter that will be passed to an instance of Command. For example, ``arg('user', '-u {}')`` creates an arg called 'user' which will evaluate to ``"-u luser"`` when the command is evaluated with ``some_command(user='luser')`` :param name: The name of the parameter, used to specify it's value later when the command is evaluated. :param cmd: string, the argument text format string. """
[docs] def __init__(self, name, cmd): self.name = name self.cmd = cmd self._required = False
[docs] def required(self, required=True): """Mark this argument as required""" self._required = required return self
[docs] def __call__(self, **values): if self.name in values and values[self.name]: val = values[self.name] return self.cmd.format(val) return ""