Blame koji-tags/library/koji_btype.py

6e61fb
#!/usr/bin/python
6e61fb
from ansible.module_utils.basic import AnsibleModule
6e61fb
from ansible.module_utils import common_koji
6e61fb
6e61fb
6e61fb
ANSIBLE_METADATA = {
6e61fb
    'metadata_version': '1.0',
6e61fb
    'status': ['preview'],
6e61fb
    'supported_by': 'community'
6e61fb
}
6e61fb
6e61fb
6e61fb
DOCUMENTATION = '''
6e61fb
---
6e61fb
module: koji_btype
6e61fb
6e61fb
short_description: Create and manage Koji build types
6e61fb
description:
6e61fb
   - Every build in Koji has a "type". This module allows you to define
6e61fb
     entirely new build types in Koji. These are typically in support of
6e61fb
     `content generators
6e61fb
     <https://docs.pagure.org/koji/content_generators/>`_.
6e61fb
   - Koji only supports adding new build types, not deleting them.
6e61fb
6e61fb
options:
6e61fb
   name:
6e61fb
     description:
6e61fb
       - The name of the Koji build type to create.
6e61fb
       - 'Example: "debian".'
6e61fb
     required: true
6e61fb
requirements:
6e61fb
  - "python >= 2.7"
6e61fb
  - "koji"
6e61fb
'''
6e61fb
6e61fb
EXAMPLES = '''
6e61fb
- name: create a debian btype in koji
6e61fb
  hosts: localhost
6e61fb
  tasks:
6e61fb
    - name: Create a koji debian btype
6e61fb
      koji_btype:
6e61fb
        name: debian
6e61fb
        state: present
6e61fb
'''
6e61fb
6e61fb
RETURN = ''' # '''
6e61fb
6e61fb
6e61fb
def run_module():
6e61fb
    module_args = dict(
6e61fb
        koji=dict(type='str', required=False),
6e61fb
        name=dict(type='str', required=True),
6e61fb
        state=dict(type='str', choices=[
6e61fb
                   'present', 'absent'], required=False, default='present'),
6e61fb
    )
6e61fb
    module = AnsibleModule(
6e61fb
        argument_spec=module_args,
6e61fb
        supports_check_mode=True
6e61fb
    )
6e61fb
6e61fb
    if not common_koji.HAS_KOJI:
6e61fb
        module.fail_json(msg='koji is required for this module')
6e61fb
6e61fb
    check_mode = module.check_mode
6e61fb
    params = module.params
6e61fb
    profile = params['koji']
6e61fb
    name = params['name']
6e61fb
    state = params['state']
6e61fb
6e61fb
    session = common_koji.get_session(profile)
6e61fb
6e61fb
    result = {'changed': False}
6e61fb
6e61fb
    if state == 'present':
6e61fb
        btype_data = session.listBTypes()
6e61fb
        btypes = [data['name'] for data in btype_data]
6e61fb
        if name not in btypes:
6e61fb
            result['changed'] = True
6e61fb
            if not check_mode:
6e61fb
                common_koji.ensure_logged_in(session)
6e61fb
                session.addBType(name)
6e61fb
    elif state == 'absent':
6e61fb
        module.fail_json(msg="Cannot remove Koji build types.",
6e61fb
                         changed=False, rc=1)
6e61fb
6e61fb
    module.exit_json(**result)
6e61fb
6e61fb
6e61fb
def main():
6e61fb
    run_module()
6e61fb
6e61fb
6e61fb
if __name__ == '__main__':
6e61fb
    main()