diff options
Diffstat (limited to 'bin')
| -rw-r--r-- | bin/awsutil.py | 29 | ||||
| -rw-r--r-- | bin/openshift-ansible-bin.spec | 4 | ||||
| -rw-r--r-- | bin/openshift_ansible.conf.example | 6 | ||||
| -rwxr-xr-x | bin/opssh | 32 | ||||
| -rwxr-xr-x | bin/oscp | 25 | ||||
| -rwxr-xr-x | bin/ossh | 23 | 
6 files changed, 101 insertions, 18 deletions
| diff --git a/bin/awsutil.py b/bin/awsutil.py index 37259b946..78421e5f5 100644 --- a/bin/awsutil.py +++ b/bin/awsutil.py @@ -6,27 +6,30 @@ import json  import re  class AwsUtil(object): -    def __init__(self): -        self.host_type_aliases = { -                'legacy-openshift-broker': ['broker', 'ex-srv'], -                         'openshift-node': ['node', 'ex-node'], -                   'openshift-messagebus': ['msg'], -            'openshift-customer-database': ['mongo'], -                'openshift-website-proxy': ['proxy'], -            'openshift-community-website': ['drupal'], -                         'package-mirror': ['mirror'], -        } +    def __init__(self, inventory_path=None, host_type_aliases={}): +        self.host_type_aliases = host_type_aliases +        self.file_path = os.path.join(os.path.dirname(os.path.realpath(__file__))) + +        if inventory_path is None: +            inventory_path = os.path.realpath(os.path.join(self.file_path, \ +                                              '..','inventory','multi_ec2.py')) + +        if not os.path.isfile(inventory_path): +            raise Exception("Inventory file not found [%s]" % inventory_path) +        self.inventory_path = inventory_path +        self.setup_host_type_alias_lookup() + +    def setup_host_type_alias_lookup(self):          self.alias_lookup = {}          for key, values in self.host_type_aliases.iteritems():              for value in values:                  self.alias_lookup[value] = key -        self.file_path = os.path.join(os.path.dirname(os.path.realpath(__file__))) -        self.multi_ec2_path = os.path.realpath(os.path.join(self.file_path, '..','inventory','multi_ec2.py')) +      def get_inventory(self,args=[]): -        cmd = [self.multi_ec2_path] +        cmd = [self.inventory_path]          if args:              cmd.extend(args) diff --git a/bin/openshift-ansible-bin.spec b/bin/openshift-ansible-bin.spec index 86b1d4fdf..1bd486bff 100644 --- a/bin/openshift-ansible-bin.spec +++ b/bin/openshift-ansible-bin.spec @@ -21,15 +21,19 @@ Scripts to make it nicer when working with hosts that are defined only by metada  mkdir -p %{buildroot}%{_bindir}  mkdir -p %{buildroot}%{python_sitelib}/openshift_ansible  mkdir -p %{buildroot}/etc/bash_completion.d +mkdir -p %{buildroot}/etc/openshift_ansible  cp -p ossh oscp opssh %{buildroot}%{_bindir}  cp -p awsutil.py %{buildroot}%{python_sitelib}/openshift_ansible  cp -p ossh_bash_completion %{buildroot}/etc/bash_completion.d +cp -p openshift_ansible.conf.example %{buildroot}/etc/openshift_ansible/openshift_ansible.conf +  %files  %{_bindir}/*  %{python_sitelib}/openshift_ansible/  /etc/bash_completion.d/* +%config(noreplace) /etc/openshift_ansible/  %changelog  * Tue Mar 24 2015 Thomas Wiest <twiest@redhat.com> 0.0.1-1 diff --git a/bin/openshift_ansible.conf.example b/bin/openshift_ansible.conf.example new file mode 100644 index 000000000..e891b855a --- /dev/null +++ b/bin/openshift_ansible.conf.example @@ -0,0 +1,6 @@ +#[main] +#inventory = /usr/share/ansible/inventory/multi_ec2.py + +#[host_type_aliases] +#host-type-one = aliasa,aliasb +#host-type-two = aliasfortwo @@ -10,16 +10,30 @@ import re  import tempfile  import time  import subprocess +import ConfigParser -DEFAULT_PSSH_PAR=200 +DEFAULT_PSSH_PAR = 200  PSSH = '/usr/bin/pssh' +CONFIG_MAIN_SECTION = 'main' +CONFIG_HOST_TYPE_ALIAS_SECTION = 'host_type_aliases' +CONFIG_INVENTORY_OPTION = 'inventory' +  class Opssh(object):      def __init__(self): +        self.inventory = None +        self.host_type_aliases = {}          self.file_path = os.path.join(os.path.dirname(os.path.realpath(__file__))) -        self.aws = awsutil.AwsUtil() + +        # Default the config path to /etc +        self.config_path = os.path.join(os.path.sep, 'etc',  \ +                                        'openshift_ansible', \ +                                        'openshift_ansible.conf')          self.parse_cli_args() +        self.parse_config_file() + +        self.aws = awsutil.AwsUtil(self.inventory, self.host_type_aliases)          if self.args.list_host_types:              self.aws.print_host_types() @@ -66,6 +80,20 @@ class Opssh(object):          return None +    def parse_config_file(self): +        if os.path.isfile(self.config_path): +            config = ConfigParser.ConfigParser() +            config.read(self.config_path) + +            if config.has_section(CONFIG_MAIN_SECTION) and \ +               config.has_option(CONFIG_MAIN_SECTION, CONFIG_INVENTORY_OPTION): +                self.inventory = config.get(CONFIG_MAIN_SECTION, CONFIG_INVENTORY_OPTION) + +            self.host_type_aliases = {} +            if config.has_section(CONFIG_HOST_TYPE_ALIAS_SECTION): +                for alias in config.options(CONFIG_HOST_TYPE_ALIAS_SECTION): +                    value = config.get(CONFIG_HOST_TYPE_ALIAS_SECTION, alias).split(',') +                    self.host_type_aliases[alias] = value      def parse_cli_args(self):          """Setup the command line parser with the options we want @@ -7,16 +7,28 @@ import traceback  import sys  import os  import re +import ConfigParser + +CONFIG_MAIN_SECTION = 'main' +CONFIG_INVENTORY_OPTION = 'inventory'  class Oscp(object):      def __init__(self): +        self.inventory = None          self.file_path = os.path.join(os.path.dirname(os.path.realpath(__file__))) + +        # Default the config path to /etc +        self.config_path = os.path.join(os.path.sep, 'etc',  \ +                                        'openshift_ansible', \ +                                        'openshift_ansible.conf') +          self.parse_cli_args() +        self.parse_config_file()          # parse host and user          self.process_host() -        self.aws = awsutil.AwsUtil() +        self.aws = awsutil.AwsUtil(self.inventory)          # get a dict of host inventory          if self.args.list: @@ -38,9 +50,18 @@ class Oscp(object):          else:              self.scp() +    def parse_config_file(self): +        if os.path.isfile(self.config_path): +            config = ConfigParser.ConfigParser() +            config.read(self.config_path) + +            if config.has_section(CONFIG_MAIN_SECTION) and \ +               config.has_option(CONFIG_MAIN_SECTION, CONFIG_INVENTORY_OPTION): +                self.inventory = config.get(CONFIG_MAIN_SECTION, CONFIG_INVENTORY_OPTION) +      def parse_cli_args(self):          parser = argparse.ArgumentParser(description='Openshift Online SSH Tool.') -        parser.add_argument('-e', '--env',  +        parser.add_argument('-e', '--env',                            action="store", help="Environment where this server exists.")          parser.add_argument('-d', '--debug', default=False,                            action="store_true", help="debug mode") @@ -7,13 +7,25 @@ import traceback  import sys  import os  import re +import ConfigParser + +CONFIG_MAIN_SECTION = 'main' +CONFIG_INVENTORY_OPTION = 'inventory'  class Ossh(object):      def __init__(self): +        self.inventory = None          self.file_path = os.path.join(os.path.dirname(os.path.realpath(__file__))) + +        # Default the config path to /etc +        self.config_path = os.path.join(os.path.sep, 'etc',  \ +                                        'openshift_ansible', \ +                                        'openshift_ansible.conf') +          self.parse_cli_args() +        self.parse_config_file() -        self.aws = awsutil.AwsUtil() +        self.aws = awsutil.AwsUtil(self.inventory)          # get a dict of host inventory          if self.args.list: @@ -37,6 +49,15 @@ class Ossh(object):          else:              self.ssh() +    def parse_config_file(self): +        if os.path.isfile(self.config_path): +            config = ConfigParser.ConfigParser() +            config.read(self.config_path) + +            if config.has_section(CONFIG_MAIN_SECTION) and \ +               config.has_option(CONFIG_MAIN_SECTION, CONFIG_INVENTORY_OPTION): +                self.inventory = config.get(CONFIG_MAIN_SECTION, CONFIG_INVENTORY_OPTION) +      def parse_cli_args(self):          parser = argparse.ArgumentParser(description='Openshift Online SSH Tool.')          parser.add_argument('-e', '--env', action="store", | 
