/ansible-role-satellite_smart_proxies

This role allows to create, delete and modify Satellite Smart Proxy associations

GNU General Public License v2.0GPL-2.0

ansible-lint Publish to Ansible Galaxy markdown link check markdownlint pyspelling pre-commit Renovate enabled

satellite_smart_proxies

This role allows to create, delete and modify Satellite Smart Proxy associations. It does not install Red Hat Satellite Capsule servers. It allows managing the Smart Proxy functionality of the Satellite's builtin Capsule or any other installed Capsule.

This is useful if you want to assign or remove your Satellite/Capsule to/from a Organization or to/from a Location.

It makes use of the Red Hat certified collection redhat.satellite, specifically of the module redhat.satellite.smart_proxy.

To use the certified collection redhat.satellite you need to be a Red Hat subscriber. If you don't own any subscriptions, you can make use of Red Hat's Developer Subscription which is provided at no cost by Red Hat.

You can also make use of the upstream collection theforeman.foreman, but you'd need to change the module names from redhat.satellite to theforeman.foreman - but I have not tested this.

This role supports all available module options of redhat.satellite.smart_proxy at the time of this writing (23.03.2024).

Requirements

This role requires the collection redhat.satellite. It is specified via collections/requirements.yml.

Role Variables

variable default required description
sat_smart_proxies unset true Smart Proxies to create/update/delete
satellite_username unset true1 Username to authenticate with against the Satellite API
satellite_password unset true1 Password of the user to authenticate with against the Satellite API
satellite_server_url unset true1 URL to the Satellite API (including http/s://)
satellite_validate_certs true false Whether to validate certificates when connecting to the Satellite API
sat_quiet_assert true false Whether to quiet assert

Variable sat_smart_proxies

An extended example of only the sat_smart_proxies variable is illustrated down below:

---
sat_smart_proxies:
  - name: 'satellite.example.com
    url: 'https://satellite.example.com:9090'
    locations:
      - 'loc-default'
      - 'loc-special'
    organizations:
      - 'org-default'
      - 'org-special'

  - name: 'capsule.example.com
    url: 'https://capsule.example.com:9090'
    locations:
      - 'loc-default'
      - 'loc-special'
    organizations:
      - 'org-default'
      - 'org-special'
    lifecycle_environments:
      - 'lce-default-dev'
      - 'lce-default-prod'
    download_policy: 'on_demand'
...

The only required attributes are name and url. Everything else can be mixed and matched. A validation of the attributes is only performed on name and url.

Dependencies

None

Example Playbook

---
- name: 'Configure Smart Proxy functionality'
  hosts: 'all'
  gather_facts: false
  roles:
    - role: 'satellite_smart_proxies'
      vars:
        satellite_server_url: 'https://satellite.example.com'
        satellite_username: 'steffen'
        satellite_password: !vault |
          $ANSIBLE_VAULT;1.1;AES256
          [..]
        satellite_validate_certs: true
        sat_quiet_assert: false
        sat_smart_proxies:
          - name: 'satellite.example.com
            url: 'https://satellite.example.com:9090'
            locations:
              - 'loc-default'
              - 'loc-special'
            organizations:
              - 'org-default'
              - 'org-special'

          - name: 'capsule.example.com
            url: 'https://capsule.example.com:9090'
            locations:
              - 'loc-default'
              - 'loc-special'
            organizations:
              - 'org-default'
              - 'org-special'
            lifecycle_environments:
              - 'lce-default-dev'
              - 'lce-default-prod'
            download_policy: 'on_demand'
...

License

GPL-2.0-or-later

Footnotes

  1. This role also supports passing the Satellite URL, username and password via environment variables. Please check vars/main.yml for the exact variables to use. 2 3