Merge branch 'devel' of https://github.com/skvidal/ansible into devel
This commit is contained in:
commit
1738440b13
1 changed files with 32 additions and 14 deletions
|
@ -57,6 +57,8 @@ def main(args):
|
||||||
help="set additional key=value variables from the CLI")
|
help="set additional key=value variables from the CLI")
|
||||||
parser.add_option('-t', '--tags', dest='tags', default='all',
|
parser.add_option('-t', '--tags', dest='tags', default='all',
|
||||||
help="only run plays and tasks tagged with these values")
|
help="only run plays and tasks tagged with these values")
|
||||||
|
parser.add_option('--list-hosts', dest='listhosts', action='store_true',
|
||||||
|
help="dump out a list of hosts, each play will run against, does not run playbook!")
|
||||||
|
|
||||||
options, args = parser.parse_args(args)
|
options, args = parser.parse_args(args)
|
||||||
|
|
||||||
|
@ -66,14 +68,15 @@ def main(args):
|
||||||
|
|
||||||
sshpass = None
|
sshpass = None
|
||||||
sudopass = None
|
sudopass = None
|
||||||
if options.ask_pass:
|
if not options.listhosts:
|
||||||
sshpass = getpass.getpass(prompt="SSH password: ")
|
if options.ask_pass:
|
||||||
if options.ask_sudo_pass:
|
sshpass = getpass.getpass(prompt="SSH password: ")
|
||||||
sudopass = getpass.getpass(prompt="sudo password: ")
|
if options.ask_sudo_pass:
|
||||||
options.sudo = True
|
sudopass = getpass.getpass(prompt="sudo password: ")
|
||||||
if options.sudo_user:
|
options.sudo = True
|
||||||
options.sudo = True
|
if options.sudo_user:
|
||||||
options.sudo_user = options.sudo_user or C.DEFAULT_SUDO_USER
|
options.sudo = True
|
||||||
|
options.sudo_user = options.sudo_user or C.DEFAULT_SUDO_USER
|
||||||
extra_vars = utils.parse_kv(options.extra_vars)
|
extra_vars = utils.parse_kv(options.extra_vars)
|
||||||
only_tags = options.tags.split(",")
|
only_tags = options.tags.split(",")
|
||||||
|
|
||||||
|
@ -104,6 +107,21 @@ def main(args):
|
||||||
only_tags=only_tags,
|
only_tags=only_tags,
|
||||||
subset=options.subset,
|
subset=options.subset,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
if options.listhosts:
|
||||||
|
playnum = 0
|
||||||
|
for play in pb.playbook:
|
||||||
|
playnum += 1
|
||||||
|
if 'hosts' in play:
|
||||||
|
label = 'unnamed'
|
||||||
|
if 'name' in play:
|
||||||
|
label = play['name']
|
||||||
|
print 'hosts in play %s: %s' % (playnum, label)
|
||||||
|
for host in pb.inventory.list_hosts(play['hosts']):
|
||||||
|
print ' %s' % host
|
||||||
|
print '\n'
|
||||||
|
return 0
|
||||||
|
|
||||||
try:
|
try:
|
||||||
|
|
||||||
pb.run()
|
pb.run()
|
||||||
|
@ -111,12 +129,12 @@ def main(args):
|
||||||
print callbacks.banner("PLAY RECAP")
|
print callbacks.banner("PLAY RECAP")
|
||||||
for h in hosts:
|
for h in hosts:
|
||||||
t = pb.stats.summarize(h)
|
t = pb.stats.summarize(h)
|
||||||
print "%-30s : %s %s %s %s " % (
|
print "%-30s : %s %s %s %s " % (
|
||||||
hostcolor(h, t),
|
hostcolor(h, t),
|
||||||
colorize('ok', t['ok'], 'green'),
|
colorize('ok', t['ok'], 'green'),
|
||||||
colorize('changed', t['changed'], 'yellow'),
|
colorize('changed', t['changed'], 'yellow'),
|
||||||
colorize('unreachable', t['unreachable'], 'red'),
|
colorize('unreachable', t['unreachable'], 'red'),
|
||||||
colorize('failed', t['failures'], 'red'))
|
colorize('failed', t['failures'], 'red'))
|
||||||
|
|
||||||
print "\n"
|
print "\n"
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue