Created
December 31, 2017 07:30
-
-
Save vladwa/bc49621782736a825844ee4c2a7dacae to your computer and use it in GitHub Desktop.
Python code to execute command as a sudo user over ssh connection on a remote server using "paramiko" module. On The code snippet establishes connection and executes the command and return the status and output of the executed command.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
import logging | |
import paramiko | |
class SSH: | |
def __init__(self): | |
pass | |
def get_ssh_connection(self, ssh_machine, ssh_username, ssh_password): | |
"""Establishes a ssh connection to execute command. | |
:param ssh_machine: IP of the machine to which SSH connection to be established. | |
:param ssh_username: User Name of the machine to which SSH connection to be established.. | |
:param ssh_password: Password of the machine to which SSH connection to be established.. | |
returns connection Object | |
""" | |
client = paramiko.SSHClient() | |
client.set_missing_host_key_policy(paramiko.AutoAddPolicy()) | |
client.connect(hostname=ssh_machine, username=ssh_username, password=ssh_password, timeout=10) | |
return client | |
def run_sudo_command(self, ssh_username="root", ssh_password="abc123", ssh_machine="localhost", command="ls", | |
jobid="None"): | |
"""Executes a command over a established SSH connectio. | |
:param ssh_machine: IP of the machine to which SSH connection to be established. | |
:param ssh_username: User Name of the machine to which SSH connection to be established.. | |
:param ssh_password: Password of the machine to which SSH connection to be established.. | |
returns status of the command executed and Output of the command. | |
""" | |
conn = self.get_ssh_connection(ssh_machine=ssh_machine, ssh_username=ssh_username, ssh_password=ssh_password) | |
command = "sudo -S -p '' %s" % command | |
logging.info("Job[%s]: Executing: %s" % (jobid, command)) | |
stdin, stdout, stderr = conn.exec_command(command=command) | |
stdin.write(ssh_password + "\n") | |
stdin.flush() | |
stdoutput = [line for line in stdout] | |
stderroutput = [line for line in stderr] | |
for output in stdoutput: | |
logging.info("Job[%s]: %s" % (jobid, output.strip())) | |
# Check exit code. | |
logging.debug("Job[%s]:stdout: %s" % (jobid, stdoutput)) | |
logging.debug("Job[%s]:stderror: %s" % (jobid, stderroutput)) | |
logging.info("Job[%s]:Command status: %s" % (jobid, stdout.channel.recv_exit_status())) | |
if not stdout.channel.recv_exit_status(): | |
logging.info("Job[%s]: Command executed." % jobid) | |
conn.close() | |
if not stdoutput: | |
stdoutput = True | |
return True, stdoutput | |
else: | |
logging.error("Job[%s]: Command failed." % jobid) | |
for output in stderroutput: | |
logging.error("Job[%s]: %s" % (jobid, output)) | |
conn.close() | |
return False, stderroutput |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment