diff options
author | Kenny Woodson <kwoodson@redhat.com> | 2015-01-30 16:29:56 -0500 |
---|---|---|
committer | Kenny Woodson <kwoodson@redhat.com> | 2015-01-30 16:29:56 -0500 |
commit | d3dee2db1c87b074075b3bbcbe8931862ee7eca3 (patch) | |
tree | 5d1a0f38b7da189a2581376058082b71f12ddb2e | |
parent | 0457b96cd5b5252010208ee8f74d0a3da49573b2 (diff) | |
download | openshift-d3dee2db1c87b074075b3bbcbe8931862ee7eca3.tar.gz openshift-d3dee2db1c87b074075b3bbcbe8931862ee7eca3.tar.bz2 openshift-d3dee2db1c87b074075b3bbcbe8931862ee7eca3.tar.xz openshift-d3dee2db1c87b074075b3bbcbe8931862ee7eca3.zip |
Adding ossh.py
-rw-r--r-- | bin/ansibleutil.py | 20 | ||||
-rwxr-xr-x | bin/ossh.py | 45 |
2 files changed, 64 insertions, 1 deletions
diff --git a/bin/ansibleutil.py b/bin/ansibleutil.py index 7ba2c461e..a16a4dca9 100644 --- a/bin/ansibleutil.py +++ b/bin/ansibleutil.py @@ -22,7 +22,9 @@ class AnsibleUtil(object): if p.returncode != 0: raise RuntimeError(err) - return json.loads(out) + with open('/tmp/ans.out','w') as fd: + fd.writelines(out) + return json.loads(out.strip()) def get_environments(self): pattern = re.compile(r'^tag_environment_(.*)') @@ -47,3 +49,19 @@ class AnsibleUtil(object): groups.append(m.group(1)) return groups + + def get_host_address(self): + pattern = re.compile(r'^tag_Name_(.*)') + inv = self.get_inventory() + + inst_names = {} + for key in inv.keys(): + m = pattern.match(key) + if m: inst_names[m.group(1)] = inv[key] + + + return inst_names + + + + diff --git a/bin/ossh.py b/bin/ossh.py new file mode 100755 index 000000000..2a24e807d --- /dev/null +++ b/bin/ossh.py @@ -0,0 +1,45 @@ +#!/usr/bin/env python + +import argparse +import ansibleutil +import sys +import os + + +# use dynamic inventory +# list instances +# symlinked to ~/bin +# list instances that match pattern +# python! + + +class Ossh(object): + def __init__(self): + self.file_path = os.path.join(os.path.dirname(os.path.realpath(__file__))) + self.parse_cli_args() + self.ansible = ansibleutil.AnsibleUtil() + + self.list_hosts() + + def parse_cli_args(self): + parser = argparse.ArgumentParser(description='Openshift Online SSH Tool.') + parser.add_argument('-l', '--list', default=True, + action="store_true", help="list out hosts") + + self.args = parser.parse_args() + + def list_hosts(self): + # TODO: perform a numerical sort on these hosts + # and display them + print self.ansible.get_host_address() + + def ssh(self): + pass + +def main(): + ossh = Ossh() + + +if __name__ == '__main__': + main() + |