Blame README-host.md

Packit Service 0a38ef
Host module
Packit Service 0a38ef
===========
Packit Service 0a38ef
Packit Service 0a38ef
Description
Packit Service 0a38ef
-----------
Packit Service 0a38ef
Packit Service 0a38ef
The host module allows to ensure presence, absence and disablement of hosts.
Packit Service 0a38ef
Packit Service 0a38ef
The host module is as compatible as possible to the Ansible upstream `ipa_host` module, but additionally offers to disable hosts.
Packit Service 0a38ef
Packit Service 0a38ef
Packit Service 0a38ef
Features
Packit Service 0a38ef
--------
Packit Service 0a38ef
* Host management
Packit Service 0a38ef
Packit Service 0a38ef
Packit Service 0a38ef
Supported FreeIPA Versions
Packit Service 0a38ef
--------------------------
Packit Service 0a38ef
Packit Service 0a38ef
FreeIPA versions 4.4.0 and up are supported by the ipahost module.
Packit Service 0a38ef
Packit Service 0a38ef
Packit Service 0a38ef
Requirements
Packit Service 0a38ef
------------
Packit Service 0a38ef
Packit Service 0a38ef
**Controller**
Packit Service 0a38ef
* Ansible version: 2.8+
Packit Service 0a38ef
Packit Service 0a38ef
**Node**
Packit Service 0a38ef
* Supported FreeIPA version (see above)
Packit Service 0a38ef
Packit Service 0a38ef
Packit Service 0a38ef
Usage
Packit Service 0a38ef
=====
Packit Service 0a38ef
Packit Service 0a38ef
Example inventory file
Packit Service 0a38ef
Packit Service 0a38ef
```ini
Packit Service 0a38ef
[ipaserver]
Packit Service 0a38ef
ipaserver.test.local
Packit Service 0a38ef
```
Packit Service 0a38ef
Packit Service 0a38ef
Packit Service 0a38ef
Example playbook to ensure host presence:
Packit Service 0a38ef
Packit Service 0a38ef
```yaml
Packit Service 0a38ef
---
Packit Service 0a38ef
- name: Playbook to handle hosts
Packit Service 0a38ef
  hosts: ipaserver
Packit Service 0a38ef
  become: true
Packit Service 0a38ef
Packit Service 0a38ef
  tasks:
Packit Service 0a38ef
  # Ensure host is present
Packit Service 0a38ef
  - ipahost:
Packit Service 0a38ef
      ipaadmin_password: SomeADMINpassword
Packit Service 0a38ef
      name: host01.example.com
Packit Service 0a38ef
      description: Example host
Packit Service 0a38ef
      ip_address: 192.168.0.123
Packit Service 0a38ef
      locality: Lab
Packit Service 0a38ef
      ns_host_location: Lab
Packit Service 0a38ef
      ns_os_version: CentOS 7
Packit Service 0a38ef
      ns_hardware_platform: Lenovo T61
Packit Service 0a38ef
      mac_address:
Packit Service 0a38ef
      - "08:00:27:E3:B1:2D"
Packit Service 0a38ef
      - "52:54:00:BD:97:1E"
Packit Service 0a38ef
      state: present
Packit Service 0a38ef
```
Packit Service 0a38ef
Compared to `ipa host-add` command no IP address conflict check is done as the ipahost module supports to have several IPv4 and IPv6 addresses for a host.
Packit Service 0a38ef
Packit Service 0a38ef
Packit Service 0a38ef
Example playbook to ensure host presence with several IP addresses:
Packit Service 0a38ef
Packit Service 0a38ef
```yaml
Packit Service 0a38ef
---
Packit Service 0a38ef
- name: Playbook to handle hosts
Packit Service 0a38ef
  hosts: ipaserver
Packit Service 0a38ef
  become: true
Packit Service 0a38ef
Packit Service 0a38ef
  tasks:
Packit Service 0a38ef
  # Ensure host is present
Packit Service 0a38ef
  - ipahost:
Packit Service 0a38ef
      ipaadmin_password: SomeADMINpassword
Packit Service 0a38ef
      name: host01.example.com
Packit Service 0a38ef
      description: Example host
Packit Service 0a38ef
      ip_address:
Packit Service 0a38ef
      - 192.168.0.123
Packit Service 0a38ef
      - 192.168.0.124
Packit Service 0a38ef
      - fe80::20c:29ff:fe02:a1b3
Packit Service 0a38ef
      - fe80::20c:29ff:fe02:a1b4
Packit Service 0a38ef
      locality: Lab
Packit Service 0a38ef
      ns_host_location: Lab
Packit Service 0a38ef
      ns_os_version: CentOS 7
Packit Service 0a38ef
      ns_hardware_platform: Lenovo T61
Packit Service 0a38ef
      mac_address:
Packit Service 0a38ef
      - "08:00:27:E3:B1:2D"
Packit Service 0a38ef
      - "52:54:00:BD:97:1E"
Packit Service 0a38ef
      state: present
Packit Service 0a38ef
```
Packit Service 0a38ef
Packit Service 0a38ef
Packit Service 0a38ef
Example playbook to ensure IP addresses are present for a host:
Packit Service 0a38ef
Packit Service 0a38ef
```yaml
Packit Service 0a38ef
---
Packit Service 0a38ef
- name: Playbook to handle hosts
Packit Service 0a38ef
  hosts: ipaserver
Packit Service 0a38ef
  become: true
Packit Service 0a38ef
Packit Service 0a38ef
  tasks:
Packit Service 0a38ef
  # Ensure host is present
Packit Service 0a38ef
  - ipahost:
Packit Service 0a38ef
      ipaadmin_password: SomeADMINpassword
Packit Service 0a38ef
      name: host01.example.com
Packit Service 0a38ef
      ip_address:
Packit Service 0a38ef
      - 192.168.0.124
Packit Service 0a38ef
      - fe80::20c:29ff:fe02:a1b4
Packit Service 0a38ef
      action: member
Packit Service 0a38ef
      state: present
Packit Service 0a38ef
```
Packit Service 0a38ef
Packit Service 0a38ef
Packit Service 0a38ef
Example playbook to ensure IP addresses are absent for a host:
Packit Service 0a38ef
Packit Service 0a38ef
```yaml
Packit Service 0a38ef
---
Packit Service 0a38ef
- name: Playbook to handle hosts
Packit Service 0a38ef
  hosts: ipaserver
Packit Service 0a38ef
  become: true
Packit Service 0a38ef
Packit Service 0a38ef
  tasks:
Packit Service 0a38ef
  # Ensure host is present
Packit Service 0a38ef
  - ipahost:
Packit Service 0a38ef
      ipaadmin_password: SomeADMINpassword
Packit Service 0a38ef
      name: host01.example.com
Packit Service 0a38ef
      ip_address:
Packit Service 0a38ef
      - 192.168.0.124
Packit Service 0a38ef
      - fe80::20c:29ff:fe02:a1b4
Packit Service 0a38ef
      action: member
Packit Service 0a38ef
      state: absent
Packit Service 0a38ef
```
Packit Service 0a38ef
Packit Service 0a38ef
Packit Service 0a38ef
Example playbook to ensure host presence without DNS:
Packit Service 0a38ef
Packit Service 0a38ef
```yaml
Packit Service 0a38ef
---
Packit Service 0a38ef
- name: Playbook to handle hosts
Packit Service 0a38ef
  hosts: ipaserver
Packit Service 0a38ef
  become: true
Packit Service 0a38ef
Packit Service 0a38ef
  tasks:
Packit Service 0a38ef
  # Ensure host is present without DNS
Packit Service 0a38ef
  - ipahost:
Packit Service 0a38ef
      ipaadmin_password: SomeADMINpassword
Packit Service 0a38ef
      name: host02.example.com
Packit Service 0a38ef
      description: Example host
Packit Service 0a38ef
      force: yes
Packit Service 0a38ef
```
Packit Service 0a38ef
Packit Service 0a38ef
Packit Service 0a38ef
Example playbook to ensure host presence with a random password:
Packit Service 0a38ef
Packit Service 0a38ef
```yaml
Packit Service 0a38ef
---
Packit Service 0a38ef
- name: Ensure host with random password
Packit Service 0a38ef
  hosts: ipaserver
Packit Service 0a38ef
  become: true
Packit Service 0a38ef
Packit Service 0a38ef
  tasks:
Packit Service 0a38ef
  - name: Host host01.example.com present with random password
Packit Service 0a38ef
    ipahost:
Packit Service 0a38ef
      ipaadmin_password: SomeADMINpassword
Packit Service 0a38ef
      name: host01.example.com
Packit Service 0a38ef
      random: yes
Packit Service 0a38ef
      force: yes
Packit Service 0a38ef
      update_password: on_create
Packit Service 0a38ef
    register: ipahost
Packit Service 0a38ef
Packit Service 0a38ef
  - name: Print generated random password
Packit Service 0a38ef
    debug:
Packit Service 0a38ef
      var: ipahost.host.randompassword
Packit Service 0a38ef
```
Packit Service 0a38ef
Please remember that a new random password will be generated for an existing but not enrolled host if `update_password` is not limited to `on_create`. For an already enrolled host the task will fail with `update_password` default setting `always`.
Packit Service 0a38ef
Packit Service 0a38ef
Example playbook to ensure presence of several hosts with a random password:
Packit Service 0a38ef
Packit Service 0a38ef
```yaml
Packit Service 0a38ef
---
Packit Service 0a38ef
- name: Ensure hosts with random password
Packit Service 0a38ef
  hosts: ipaserver
Packit Service 0a38ef
  become: true
Packit Service 0a38ef
Packit Service 0a38ef
  tasks:
Packit Service 0a38ef
  - name: Hosts host01.example.com and host01.example.com present with random passwords
Packit Service 0a38ef
    ipahost:
Packit Service 0a38ef
      ipaadmin_password: SomeADMINpassword
Packit Service 0a38ef
      hosts:
Packit Service 0a38ef
      - name: host01.example.com
Packit Service 0a38ef
        random: yes
Packit Service 0a38ef
        force: yes
Packit Service 0a38ef
        update_password: on_create
Packit Service 0a38ef
      - name: host02.example.com
Packit Service 0a38ef
        random: yes
Packit Service 0a38ef
        force: yes
Packit Service 0a38ef
        update_password: on_create
Packit Service 0a38ef
    register: ipahost
Packit Service 0a38ef
Packit Service 0a38ef
  - name: Print generated random password for host01.example.com
Packit Service 0a38ef
    debug:
Packit Service 0a38ef
      var: ipahost.host["host01.example.com"].randompassword
Packit Service 0a38ef
Packit Service 0a38ef
  - name: Print generated random password for host02.example.com
Packit Service 0a38ef
    debug:
Packit Service 0a38ef
      var: ipahost.host["host02.example.com"].randompassword
Packit Service 0a38ef
```
Packit Service 0a38ef
Please remember that a new random password will be generated for an existing but not enrolled host if `update_password` is not limited to `on_create`. For an already enrolled host the task will fail with `update_password` default setting `always`.
Packit Service 0a38ef
Packit Service 0a38ef
Packit Service 0a38ef
Example playbook to ensure presence of host member principal:
Packit Service 0a38ef
Packit Service 0a38ef
```yaml
Packit Service 0a38ef
---
Packit Service 0a38ef
- name: Host present with principal
Packit Service 0a38ef
  hosts: ipaserver
Packit Service 0a38ef
  become: true
Packit Service 0a38ef
Packit Service 0a38ef
  tasks:
Packit Service 0a38ef
  - name: Host host01.example.com present with principals host/testhost01.example.com and host/myhost01.example.com
Packit Service 0a38ef
    ipahost:
Packit Service 0a38ef
      ipaadmin_password: SomeADMINpassword
Packit Service 0a38ef
      name: host01.example.com
Packit Service 0a38ef
      principal:
Packit Service 0a38ef
      - host/testhost01.example.com
Packit Service 0a38ef
      - host/myhost01.example.com
Packit Service 0a38ef
      action: member
Packit Service 0a38ef
```
Packit Service 0a38ef
Packit Service 0a38ef
Packit Service 0a38ef
Example playbook to ensure presence of host member certificate:
Packit Service 0a38ef
Packit Service 0a38ef
```yaml
Packit Service 0a38ef
- name: Host present with certificate
Packit Service 0a38ef
  hosts: ipaserver
Packit Service 0a38ef
  become: true
Packit Service 0a38ef
Packit Service 0a38ef
  tasks:
Packit Service 0a38ef
  - name: Host host01.example.com present with certificate
Packit Service 0a38ef
    ipahost:
Packit Service 0a38ef
      ipaadmin_password: SomeADMINpassword
Packit Service 0a38ef
      name: host01.example.com
Packit Service 0a38ef
      certificate:
Packit Service 0a38ef
      - MIIC/zCCAeegAwIBAg...
Packit Service 0a38ef
      action: member
Packit Service 0a38ef
```
Packit Service 0a38ef
Packit Service 0a38ef
Packit Service 0a38ef
Example playbook to ensure presence of member managedby_host for serveral hosts:
Packit Service 0a38ef
Packit Service 0a38ef
```yaml
Packit Service 0a38ef
---
Packit Service 0a38ef
- name: Host present with managedby_host
Packit Service 0a38ef
  hosts: ipaserver
Packit Service 0a38ef
  become: true
Packit Service 0a38ef
Packit Service 0a38ef
  tasks:
Packit Service 0a38ef
    ipahost:
Packit Service 0a38ef
      ipaadmin_password: SomeADMINpassword
Packit Service 0a38ef
      hosts:
Packit Service 0a38ef
      - name: host01.exmaple.com
Packit Service 0a38ef
        managedby_host: server.exmaple.com
Packit Service 0a38ef
      - name: host02.exmaple.com
Packit Service 0a38ef
        managedby_host: server.exmaple.com
Packit Service 0a38ef
      action: member
Packit Service 0a38ef
```
Packit Service 0a38ef
Packit Service 0a38ef
Packit Service 0a38ef
Example playbook to disable a host:
Packit Service 0a38ef
Packit Service 0a38ef
```yaml
Packit Service 0a38ef
---
Packit Service 0a38ef
- name: Playbook to handle hosts
Packit Service 0a38ef
  hosts: ipaserver
Packit Service 0a38ef
  become: true
Packit Service 0a38ef
Packit Service 0a38ef
  tasks:
Packit Service 0a38ef
  # Ensure host is disabled
Packit Service 0a38ef
  - ipahost:
Packit Service 0a38ef
      ipaadmin_password: SomeADMINpassword
Packit Service 0a38ef
      name: host01.example.com
Packit Service 0a38ef
      update_dns: yes
Packit Service 0a38ef
      state: disabled
Packit Service 0a38ef
```
Packit Service 0a38ef
`update_dns` controls if the DNS entries will be updated in this case. For `state` present it is controlling the update of the DNS SSHFP records, but not the the other DNS records.
Packit Service 0a38ef
Packit Service 0a38ef
Packit Service 0a38ef
Example playbook to ensure a host is absent:
Packit Service 0a38ef
Packit Service 0a38ef
```yaml
Packit Service 0a38ef
---
Packit Service 0a38ef
- name: Playbook to handle hosts
Packit Service 0a38ef
  hosts: ipaserver
Packit Service 0a38ef
  become: true
Packit Service 0a38ef
Packit Service 0a38ef
  tasks:
Packit Service 0a38ef
  # Ensure host is absent
Packit Service 0a38ef
  - ipahost:
Packit Service 0a38ef
      ipaadmin_password: password1
Packit Service 0a38ef
      name: host01.example.com
Packit Service 0a38ef
      state: absent
Packit Service 0a38ef
```
Packit Service 0a38ef
Packit Service 0a38ef
Packit Service 0a38ef
Variables
Packit Service 0a38ef
=========
Packit Service 0a38ef
Packit Service 0a38ef
ipahost
Packit Service 0a38ef
-------
Packit Service 0a38ef
Packit Service 0a38ef
Variable | Description | Required
Packit Service 0a38ef
-------- | ----------- | --------
Packit Service 0a38ef
`ipaadmin_principal` | The admin principal is a string and defaults to `admin` | no
Packit Service 0a38ef
`ipaadmin_password` | The admin password is a string and is required if there is no admin ticket available on the node | no
Packit Service 0a38ef
`name` \| `fqdn` | The list of host name strings. `name` with *host variables* or `hosts` containing *host variables* need to be used. | no
Packit Service 0a38ef
**Host variables** | Only used with `name` variable in the first level. | no
Packit Service 0a38ef
`hosts` | The list of host dicts. Each `hosts` dict entry can contain **host variables**.
There is one required option in the `hosts` dict:| no
Packit Service 0a38ef
  | `name` \| `fqdn` - The user name string of the entry. | yes
Packit Service 0a38ef
  | **Host variables** | no
Packit Service 0a38ef
`update_password` |  Set password for a host in present state only on creation or always. It can be one of `always` or `on_create` and defaults to `always`. | no
Packit Service 0a38ef
`action` | Work on host or member level. It can be on of `member` or `host` and defaults to `host`. | no
Packit Service 0a38ef
`state` | The state to ensure. It can be one of `present`, `absent` or `disabled`, default: `present`. | yes
Packit Service 0a38ef
Packit Service 0a38ef
Packit Service 0a38ef
**Host Variables:**
Packit Service 0a38ef
Packit Service 0a38ef
Variable | Description | Required
Packit Service 0a38ef
-------- | ----------- | --------
Packit Service 0a38ef
`description` | The host description. | no
Packit Service 0a38ef
`locality` | Host locality (e.g. "Baltimore, MD"). | no
Packit Service 0a38ef
`location` \| `ns_host_location` | Host location (e.g. "Lab 2"). | no
Packit Service 0a38ef
`platform` \| `ns_hardware_platform` | Host hardware platform (e.g. "Lenovo T61"). | no
Packit Service 0a38ef
`os` \| `ns_os_version` | Host operating system and version (e.g. "Fedora 9"). | no
Packit Service 0a38ef
`password` \| `user_password` \| `userpassword` | Password used in bulk enrollment for absent or not enrolled hosts. | no
Packit Service 0a38ef
`random` \| `random_password` |  Initiate the generation of a random password to be used in bulk enrollment for absent or not enrolled hosts. | no
Packit Service 0a38ef
`certificate` \| `usercertificate` | List of base-64 encoded host certificates | no
Packit Service 0a38ef
`managedby` \| `principalname` \| `krbprincipalname` | List of hosts that can manage this host | no
Packit Service 0a38ef
`principal` \| `principalname` \| `krbprincipalname` | List of principal aliases for this host | no
Packit Service 0a38ef
`allow_create_keytab_user` \| `ipaallowedtoperform_write_keys_user` | Users allowed to create a keytab of this host. | no
Packit Service 0a38ef
`allow_create_keytab_group` \| `ipaallowedtoperform_write_keys_group` | Groups allowed to create a keytab of this host. | no
Packit Service 0a38ef
`allow_create_keytab_host` \| `ipaallowedtoperform_write_keys_host` | Hosts allowed to create a keytab of this host. | no
Packit Service 0a38ef
`allow_create_keytab_hostgroup` \| `ipaallowedtoperform_write_keys_hostgroup` | Host groups allowed to create a keytab of this host. | no
Packit Service 0a38ef
`allow_retrieve_keytab_user` \| `ipaallowedtoperform_read_keys_user` | Users allowed to retieve a keytab of this host. | no
Packit Service 0a38ef
`allow_retrieve_keytab_group` \| `ipaallowedtoperform_read_keys_group` | Groups allowed to retieve a keytab of this host. | no
Packit Service 0a38ef
`allow_retrieve_keytab_host` \| `ipaallowedtoperform_read_keys_host` | Hosts allowed to retieve a keytab of this host. | no
Packit Service 0a38ef
`allow_retrieve_keytab_hostgroup` \| `ipaallowedtoperform_read_keys_hostgroup` | Host groups allowed to retieve a keytab of this host. | no
Packit Service 0a38ef
`mac_address` \| `macaddress` | List of hardware MAC addresses. | no
Packit Service 0a38ef
`sshpubkey` \| `ipasshpubkey` | List of SSH public keys | no
Packit Service 0a38ef
`userclass` \| `class` | Host category (semantics placed on this attribute are for local interpretation) | no
Packit Service a166ed
`auth_ind` \| `krbprincipalauthind` | Defines an allow list for Authentication Indicators. Use 'otp' to allow OTP-based 2FA authentications. Use 'radius' to allow RADIUS-based 2FA authentications. Use empty string to reset auth_ind to the initial value. Other values may be used for custom configurations. choices: ["radius", "otp", "pkinit", "hardened", ""] | no
Packit Service 0a38ef
`requires_pre_auth` \| `ipakrbrequirespreauth` | Pre-authentication is required for the service (bool) | no
Packit Service 0a38ef
`ok_as_delegate` \| `ipakrbokasdelegate` | Client credentials may be delegated to the service (bool) | no
Packit Service 0a38ef
`ok_to_auth_as_delegate` \| `ipakrboktoauthasdelegate` | The service is allowed to authenticate on behalf of a client (bool) | no
Packit Service 0a38ef
`force` | Force host name even if not in DNS. | no
Packit Service 0a38ef
`reverse` | Reverse DNS detection. | no
Packit Service 0a38ef
`ip_address` \| `ipaddress` | The host IP address list. It can contain IPv4 and IPv6 addresses. No conflict check for IP addresses is done. | no
Packit Service 0a38ef
`update_dns` | For existing hosts: DNS SSHFP records are updated with `state` present and all DNS entries for a host removed with `state` absent. | no
Packit Service 0a38ef
Packit Service 0a38ef
Packit Service 0a38ef
Return Values
Packit Service 0a38ef
=============
Packit Service 0a38ef
Packit Service 0a38ef
ipahost
Packit Service 0a38ef
-------
Packit Service 0a38ef
Packit Service 0a38ef
There are only return values if one or more random passwords have been generated.
Packit Service 0a38ef
Packit Service 0a38ef
Variable | Description | Returned When
Packit Service 0a38ef
-------- | ----------- | -------------
Packit Service 0a38ef
`host` | Host dict with random password. (dict) 
Options: | If random is yes and host did not exist or update_password is yes
Packit Service 0a38ef
  | `randompassword` - The generated random password | If only one host is handled by the module
Packit Service 0a38ef
  | `name` - The host name of the host that got a new random password. (dict) 
Options:
  `randompassword` - The generated random password | If several hosts are handled by the module
Packit Service 0a38ef
Packit Service 0a38ef
Packit Service 0a38ef
Authors
Packit Service 0a38ef
=======
Packit Service 0a38ef
Packit Service 0a38ef
Thomas Woerner