diff options
Diffstat (limited to 'roles')
| -rw-r--r-- | roles/copr_cli/README.md | 38 | ||||
| -rw-r--r-- | roles/copr_cli/defaults/main.yml | 2 | ||||
| -rw-r--r-- | roles/copr_cli/handlers/main.yml | 2 | ||||
| -rw-r--r-- | roles/copr_cli/meta/main.yml | 14 | ||||
| -rw-r--r-- | roles/copr_cli/tasks/main.yml | 4 | ||||
| -rw-r--r-- | roles/copr_cli/vars/main.yml | 2 | ||||
| -rwxr-xr-x | roles/openshift_facts/library/openshift_facts.py | 68 | ||||
| -rw-r--r-- | roles/openshift_facts/tasks/main.yml | 3 | ||||
| -rw-r--r-- | roles/rhel_subscribe/tasks/main.yml | 11 | ||||
| -rw-r--r-- | roles/tito/README.md | 38 | ||||
| -rw-r--r-- | roles/tito/defaults/main.yml | 2 | ||||
| -rw-r--r-- | roles/tito/handlers/main.yml | 2 | ||||
| -rw-r--r-- | roles/tito/meta/main.yml | 14 | ||||
| -rw-r--r-- | roles/tito/tasks/main.yml | 4 | ||||
| -rw-r--r-- | roles/tito/vars/main.yml | 2 | 
15 files changed, 181 insertions, 25 deletions
| diff --git a/roles/copr_cli/README.md b/roles/copr_cli/README.md new file mode 100644 index 000000000..edc68454e --- /dev/null +++ b/roles/copr_cli/README.md @@ -0,0 +1,38 @@ +Role Name +========= + +This role manages Copr CLI. + +https://apps.fedoraproject.org/packages/copr-cli/ + +Requirements +------------ + +None + +Role Variables +-------------- + +None + +Dependencies +------------ + +None + +Example Playbook +---------------- + +    - hosts: servers +      roles: +      - role: copr_cli + +License +------- + +Apache License, Version 2.0 + +Author Information +------------------ + +Thomas Wiest diff --git a/roles/copr_cli/defaults/main.yml b/roles/copr_cli/defaults/main.yml new file mode 100644 index 000000000..3b8adf910 --- /dev/null +++ b/roles/copr_cli/defaults/main.yml @@ -0,0 +1,2 @@ +--- +# defaults file for copr_cli diff --git a/roles/copr_cli/handlers/main.yml b/roles/copr_cli/handlers/main.yml new file mode 100644 index 000000000..c3dec5a4c --- /dev/null +++ b/roles/copr_cli/handlers/main.yml @@ -0,0 +1,2 @@ +--- +# handlers file for copr_cli diff --git a/roles/copr_cli/meta/main.yml b/roles/copr_cli/meta/main.yml new file mode 100644 index 000000000..f050281fd --- /dev/null +++ b/roles/copr_cli/meta/main.yml @@ -0,0 +1,14 @@ +--- +galaxy_info: +  author: Thomas Wiest +  description: Manages Copr CLI +  company: Red Hat +  license: Apache License, Version 2.0 +  min_ansible_version: 1.2 +  platforms: +  - name: EL +    versions: +    - 7 +  categories: +  - packaging +dependencies: [] diff --git a/roles/copr_cli/tasks/main.yml b/roles/copr_cli/tasks/main.yml new file mode 100644 index 000000000..f7ef1c26e --- /dev/null +++ b/roles/copr_cli/tasks/main.yml @@ -0,0 +1,4 @@ +--- +- yum: +    name: copr-cli +    state: present diff --git a/roles/copr_cli/vars/main.yml b/roles/copr_cli/vars/main.yml new file mode 100644 index 000000000..1522c94d9 --- /dev/null +++ b/roles/copr_cli/vars/main.yml @@ -0,0 +1,2 @@ +--- +# vars file for copr_cli diff --git a/roles/openshift_facts/library/openshift_facts.py b/roles/openshift_facts/library/openshift_facts.py index 2e1075aca..091ba4e2b 100755 --- a/roles/openshift_facts/library/openshift_facts.py +++ b/roles/openshift_facts/library/openshift_facts.py @@ -24,8 +24,23 @@ import StringIO  import yaml  from distutils.util import strtobool  from distutils.version import LooseVersion -from netaddr import IPNetwork +import struct +import socket +def first_ip(network): +    """ Return the first IPv4 address in network + +        Args: +            network (str): network in CIDR format +        Returns: +            str: first IPv4 address +    """ +    atoi = lambda addr: struct.unpack("!I", socket.inet_aton(addr))[0] +    itoa = lambda addr: socket.inet_ntoa(struct.pack("!I", addr)) + +    (address, netmask) = network.split('/') +    netmask_i = (0xffffffff << (32 - atoi(netmask))) & 0xffffffff +    return itoa((atoi(address) & netmask_i) + 1)  def hostname_valid(hostname):      """ Test if specified hostname should be considered valid @@ -525,7 +540,7 @@ def set_aggregate_facts(facts):                           'kubernetes.default.svc', 'kubernetes.default.svc.' + cluster_domain]              all_hostnames.update(svc_names)              internal_hostnames.update(svc_names) -            first_svc_ip = str(IPNetwork(facts['master']['portal_net'])[1]) +            first_svc_ip = first_ip(facts['master']['portal_net'])              all_hostnames.add(first_svc_ip)              internal_hostnames.add(first_svc_ip) @@ -543,8 +558,10 @@ def set_etcd_facts_if_unset(facts):      If anything goes wrong parsing these, the fact will not be set.      """ -    if 'etcd' in facts: -        if 'master' in facts and facts['master']['embedded_etcd']: +    if 'master' in facts and facts['master']['embedded_etcd']: +        etcd_facts = facts['etcd'] if 'etcd' in facts else dict() + +        if 'etcd_data_dir' not in etcd_facts:              try:                  # Parse master config to find actual etcd data dir:                  master_cfg_path = os.path.join(facts['common']['config_base'], @@ -553,28 +570,37 @@ def set_etcd_facts_if_unset(facts):                  config = yaml.safe_load(master_cfg_f.read())                  master_cfg_f.close() -                facts['etcd']['etcd_data_dir'] = \ +                etcd_facts['etcd_data_dir'] = \                      config['etcdConfig']['storageDirectory'] + +                facts['etcd'] = etcd_facts +              # We don't want exceptions bubbling up here:              # pylint: disable=broad-except              except Exception:                  pass -        else: -            # Read ETCD_DATA_DIR from /etc/etcd/etcd.conf: -            try: -                # Add a fake section for parsing: -                ini_str = '[root]\n' + open('/etc/etcd/etcd.conf', 'r').read() -                ini_fp = StringIO.StringIO(ini_str) -                config = ConfigParser.RawConfigParser() -                config.readfp(ini_fp) -                etcd_data_dir = config.get('root', 'ETCD_DATA_DIR') -                if etcd_data_dir.startswith('"') and etcd_data_dir.endswith('"'): -                    etcd_data_dir = etcd_data_dir[1:-1] -                facts['etcd']['etcd_data_dir'] = etcd_data_dir -            # We don't want exceptions bubbling up here: -            # pylint: disable=broad-except -            except Exception: -                pass +    else: +        etcd_facts = facts['etcd'] if 'etcd' in facts else dict() + +        # Read ETCD_DATA_DIR from /etc/etcd/etcd.conf: +        try: +            # Add a fake section for parsing: +            ini_str = '[root]\n' + open('/etc/etcd/etcd.conf', 'r').read() +            ini_fp = StringIO.StringIO(ini_str) +            config = ConfigParser.RawConfigParser() +            config.readfp(ini_fp) +            etcd_data_dir = config.get('root', 'ETCD_DATA_DIR') +            if etcd_data_dir.startswith('"') and etcd_data_dir.endswith('"'): +                etcd_data_dir = etcd_data_dir[1:-1] + +            etcd_facts['etcd_data_dir'] = etcd_data_dir +            facts['etcd'] = etcd_facts + +        # We don't want exceptions bubbling up here: +        # pylint: disable=broad-except +        except Exception: +            pass +      return facts  def set_deployment_facts_if_unset(facts): diff --git a/roles/openshift_facts/tasks/main.yml b/roles/openshift_facts/tasks/main.yml index a28aa7ba2..913f0dc78 100644 --- a/roles/openshift_facts/tasks/main.yml +++ b/roles/openshift_facts/tasks/main.yml @@ -6,10 +6,9 @@      - ansible_version | version_compare('1.9.0', 'ne')      - ansible_version | version_compare('1.9.0.1', 'ne') -- name: Ensure python-netaddr and PyYaml are installed +- name: Ensure PyYaml is installed    yum: pkg={{ item }} state=installed    with_items: -    - python-netaddr      - PyYAML  - name: Gather Cluster facts diff --git a/roles/rhel_subscribe/tasks/main.yml b/roles/rhel_subscribe/tasks/main.yml index 8fb2fc042..30c0920a1 100644 --- a/roles/rhel_subscribe/tasks/main.yml +++ b/roles/rhel_subscribe/tasks/main.yml @@ -6,19 +6,26 @@  - set_fact:      rhel_subscription_user: "{{ lookup('oo_option', 'rhel_subscription_user') | default(rhsub_user, True) | default(omit, True) }}"      rhel_subscription_pass: "{{ lookup('oo_option', 'rhel_subscription_pass') | default(rhsub_pass, True) | default(omit, True) }}" +    rhel_subscription_server: "{{ lookup('oo_option', 'rhel_subscription_server') | default(rhsub_server) }}"  - fail:      msg: "This role is only supported for Red Hat hosts"    when: ansible_distribution != 'RedHat'  - fail: -    msg: Either rsub_user or the rhel_subscription_user env variable are required for this role. +    msg: Either rhsub_user or the rhel_subscription_user env variable are required for this role.    when: rhel_subscription_user is not defined  - fail: -    msg: Either rsub_pass or the rhel_subscription_pass env variable are required for this role. +    msg: Either rhsub_pass or the rhel_subscription_pass env variable are required for this role.    when: rhel_subscription_pass is not defined +- name: Satellite preparation +  command: "rpm -Uvh http://{{ rhel_subscription_server }}/pub/katello-ca-consumer-latest.noarch.rpm" +  args: +    creates: /etc/rhsm/ca/katello-server-ca.pem +  when: rhel_subscription_server is defined and rhel_subscription_server +  - name: RedHat subscriptions    redhat_subscription:      username: "{{ rhel_subscription_user }}" diff --git a/roles/tito/README.md b/roles/tito/README.md new file mode 100644 index 000000000..c4e2856dc --- /dev/null +++ b/roles/tito/README.md @@ -0,0 +1,38 @@ +Role Name +========= + +This role manages Tito. + +https://github.com/dgoodwin/tito + +Requirements +------------ + +None + +Role Variables +-------------- + +None + +Dependencies +------------ + +None + +Example Playbook +---------------- + +    - hosts: servers +      roles: +      - role: tito + +License +------- + +Apache License, Version 2.0 + +Author Information +------------------ + +Thomas Wiest diff --git a/roles/tito/defaults/main.yml b/roles/tito/defaults/main.yml new file mode 100644 index 000000000..dd7cd269e --- /dev/null +++ b/roles/tito/defaults/main.yml @@ -0,0 +1,2 @@ +--- +# defaults file for tito diff --git a/roles/tito/handlers/main.yml b/roles/tito/handlers/main.yml new file mode 100644 index 000000000..e9ce609d5 --- /dev/null +++ b/roles/tito/handlers/main.yml @@ -0,0 +1,2 @@ +--- +# handlers file for tito diff --git a/roles/tito/meta/main.yml b/roles/tito/meta/main.yml new file mode 100644 index 000000000..fb121c08e --- /dev/null +++ b/roles/tito/meta/main.yml @@ -0,0 +1,14 @@ +--- +galaxy_info: +  author: Thomas Wiest +  description: Manages Tito +  company: Red Hat +  license: Apache License, Version 2.0 +  min_ansible_version: 1.2 +  platforms: +  - name: EL +    versions: +    - 7 +  categories: +  - packaging +dependencies: [] diff --git a/roles/tito/tasks/main.yml b/roles/tito/tasks/main.yml new file mode 100644 index 000000000..f7b4ef363 --- /dev/null +++ b/roles/tito/tasks/main.yml @@ -0,0 +1,4 @@ +--- +- yum: +    name: tito +    state: present diff --git a/roles/tito/vars/main.yml b/roles/tito/vars/main.yml new file mode 100644 index 000000000..8a1aafc41 --- /dev/null +++ b/roles/tito/vars/main.yml @@ -0,0 +1,2 @@ +--- +# vars file for tito | 
