mirror of
https://github.com/ansible-collections/community.general.git
synced 2024-09-14 20:13:21 +02:00
add support to prompt for ssh password on the cli
This commit is contained in:
parent
bd37864242
commit
08b45d6da1
2 changed files with 13 additions and 2 deletions
|
@ -24,6 +24,7 @@
|
||||||
from optparse import OptionParser
|
from optparse import OptionParser
|
||||||
import json
|
import json
|
||||||
import os
|
import os
|
||||||
|
import getpass
|
||||||
import ansible
|
import ansible
|
||||||
|
|
||||||
DEFAULT_HOST_LIST = '/etc/ansible/hosts'
|
DEFAULT_HOST_LIST = '/etc/ansible/hosts'
|
||||||
|
@ -41,6 +42,8 @@ class Cli(object):
|
||||||
|
|
||||||
def runner(self):
|
def runner(self):
|
||||||
parser = OptionParser()
|
parser = OptionParser()
|
||||||
|
parser.add_option("-P", "--askpass", default=False, action="store_true",
|
||||||
|
help="ask the user to input the ssh password for connecting")
|
||||||
parser.add_option("-H", "--host-list", dest="host_list",
|
parser.add_option("-H", "--host-list", dest="host_list",
|
||||||
help="path to hosts list", default=DEFAULT_HOST_LIST)
|
help="path to hosts list", default=DEFAULT_HOST_LIST)
|
||||||
parser.add_option("-L", "--library", dest="module_path",
|
parser.add_option("-L", "--library", dest="module_path",
|
||||||
|
@ -61,11 +64,16 @@ class Cli(object):
|
||||||
# TODO: more shell like splitting on module_args would
|
# TODO: more shell like splitting on module_args would
|
||||||
# be a good idea
|
# be a good idea
|
||||||
|
|
||||||
|
sshpass = None
|
||||||
|
if options.askpass:
|
||||||
|
sshpass = getpass.getpass(prompt="SSH password: ")
|
||||||
|
|
||||||
return ansible.Runner(
|
return ansible.Runner(
|
||||||
module_name=options.module_name,
|
module_name=options.module_name,
|
||||||
module_path=options.module_path,
|
module_path=options.module_path,
|
||||||
module_args=options.module_args.split(' '),
|
module_args=options.module_args.split(' '),
|
||||||
remote_user=options.remote_user,
|
remote_user=options.remote_user,
|
||||||
|
remote_pass=sshpass,
|
||||||
host_list=options.host_list,
|
host_list=options.host_list,
|
||||||
forks=options.forks,
|
forks=options.forks,
|
||||||
pattern=options.pattern,
|
pattern=options.pattern,
|
||||||
|
|
|
@ -36,6 +36,7 @@ DEFAULT_FORKS = 3
|
||||||
DEFAULT_MODULE_ARGS = ''
|
DEFAULT_MODULE_ARGS = ''
|
||||||
DEFAULT_TIMEOUT = 60
|
DEFAULT_TIMEOUT = 60
|
||||||
DEFAULT_REMOTE_USER = 'root'
|
DEFAULT_REMOTE_USER = 'root'
|
||||||
|
DEFAULT_REMOTE_PASS = None
|
||||||
|
|
||||||
def _executor_hook(x):
|
def _executor_hook(x):
|
||||||
''' callback used by multiprocessing pool '''
|
''' callback used by multiprocessing pool '''
|
||||||
|
@ -53,6 +54,7 @@ class Runner(object):
|
||||||
timeout=DEFAULT_TIMEOUT,
|
timeout=DEFAULT_TIMEOUT,
|
||||||
pattern=DEFAULT_PATTERN,
|
pattern=DEFAULT_PATTERN,
|
||||||
remote_user=DEFAULT_REMOTE_USER,
|
remote_user=DEFAULT_REMOTE_USER,
|
||||||
|
remote_pass=DEFAULT_REMOTE_PASS,
|
||||||
verbose=False):
|
verbose=False):
|
||||||
|
|
||||||
|
|
||||||
|
@ -69,6 +71,7 @@ class Runner(object):
|
||||||
self.timeout = timeout
|
self.timeout = timeout
|
||||||
self.verbose = verbose
|
self.verbose = verbose
|
||||||
self.remote_user = remote_user
|
self.remote_user = remote_user
|
||||||
|
self.remote_pass = remote_pass
|
||||||
|
|
||||||
def _parse_hosts(self, host_list):
|
def _parse_hosts(self, host_list):
|
||||||
''' parse the host inventory file if not sent as an array '''
|
''' parse the host inventory file if not sent as an array '''
|
||||||
|
@ -95,8 +98,8 @@ class Runner(object):
|
||||||
ssh = paramiko.SSHClient()
|
ssh = paramiko.SSHClient()
|
||||||
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
|
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
|
||||||
try:
|
try:
|
||||||
ssh.connect(host, username=self.remote_user,
|
ssh.connect(host, username=self.remote_user, allow_agent=True,
|
||||||
allow_agent=True, look_for_keys=True)
|
look_for_keys=True, password=self.remote_pass)
|
||||||
return [ True, ssh ]
|
return [ True, ssh ]
|
||||||
except:
|
except:
|
||||||
return [ False, traceback.format_exc() ]
|
return [ False, traceback.format_exc() ]
|
||||||
|
|
Loading…
Reference in a new issue