ipaconfig
Description
The config module allows the setting of global config parameters within IPA. If no parameters are specified it returns the list of all current parameters.
The config module is as compatible as possible to the Ansible upstream ipa_config module, but adds many additional parameters
Features
- IPA server configuration management
 
Supported FreeIPA Versions
FreeIPA versions 4.4.0 and up are supported by the ipaconfig module.
Some variables are only supported on newer versions of FreeIPA. Check Variables section for details.
Requirements
Controller
- Ansible version: 2.13+
 
Node
- Supported FreeIPA version (see above)
 
Usage
Example inventory file
[ipaserver]
ipaserver.test.local
Example playbook to read config options:
---
- name: Playbook to handle global config options
  hosts: ipaserver
  become: true
  tasks:
    - name: return current values of the global configuration options
      ipaconfig:
        ipaadmin_password: password
      register: result
    - name: display default login shell
      debug:
        msg: ''
    - name: ensure defaultloginshell and maxusernamelength are set as required
      ipaconfig:
        ipaadmin_password: password
        defaultshell: /bin/bash
        maxusername: 64
Example playbook to set global configuration options:
---
- name: Playbook to ensure some config options are set
  hosts: ipaserver
  become: true
  tasks:
    - name: set defaultlogin and maxusername
      ipaconfig:
        ipaadmin_password: password
        defaultlogin: /bin/bash
        maxusername: 64
Example playbook to enable SID and generate users and groups SIDs:
---
- name: Playbook to ensure SIDs are enabled and users and groups have SIDs
  hosts: ipaserver
  become: no
  gather_facts: no
  tasks:
    - name: Enable SID and generate users and groups SIDS
      ipaconfig:
        ipaadmin_password: SomeADMINpassword
        enable_sid: yes
        add_sids: yes
Example playbook to change IPA domain NetBIOS name:
---
- name: Playbook to change IPA domain netbios name
  hosts: ipaserver
  become: no
  gather_facts: no
  tasks:
    - name: Set IPA domain netbios name
      ipaconfig:
        ipaadmin_password: SomeADMINpassword
        enable_sid: yes
        netbios_name: IPADOM
Variables
General Variables:
| Variable | Description | Required | 
|---|---|---|
ipaadmin_principal | 
      The admin principal is a string and defaults to admin | 
      no | 
ipaadmin_password | 
      The admin password is a string and is required if there is no admin ticket available on the node | no | 
ipaapi_context | 
      The context in which the module will execute. Executing in a server context is preferred. If not provided context will be determined by the execution environment. Valid values are server and client. | 
      no | 
ipaapi_ldap_cache | 
      Use LDAP cache for IPA connection. The bool setting defaults to yes. (bool) | no | 
maxusername | ipamaxusernamelength | 
      Set the maximum username length (1 to 255) | no | 
maxhostname | ipamaxhostnamelength | 
      Set the maximum hostname length between 64-255. Only usable with IPA versions 4.8.0 and up. | no | 
homedirectory | ipahomesrootdir | 
      Set the default location of home directories | no | 
defaultshell | ipadefaultloginshell | 
      Set the default shell for new users | no | 
defaultgroup | ipadefaultprimarygroup | 
      Set the default group for new users | no | 
emaildomain| ipadefaultemaildomain | 
      Set the default e-mail domain | false | 
searchtimelimit | ipasearchtimelimit | 
      Set maximum amount of time (seconds) for a search -1 to 2147483647 (-1 or 0 is unlimited) | no | 
searchrecordslimit | ipasearchrecordslimit | 
      Set maximum number of records to search -1 to 2147483647 (-1 or 0 is unlimited) | no | 
usersearch | ipausersearchfields | 
      Set list of fields to search when searching for users | no | 
groupsearch | ipagroupsearchfields | 
      Set list of fields to search in when searching for groups | no | 
enable_migration | ipamigrationenabled | 
      Enable migration mode (choices: True, False ) | no | 
groupobjectclasses | ipagroupobjectclasses | 
      Set default group objectclasses (list) | no | 
userobjectclasses | ipauserobjectclasses | 
      Set default user objectclasses (list) | no | 
pwdexpnotify | ipapwdexpadvnotify | 
      Set number of days’s notice of impending password expiration (0 to 2147483647) | no | 
configstring | ipaconfigstring | 
      Set extra hashes to generate in password plug-in (choices:AllowNThash, KDC:Disable Last Success, KDC:Disable Lockout, KDC:Disable Default Preauth for SPNs). Use "" to clear this variable. | 
      no | 
selinuxusermaporder | ipaselinuxusermaporder | 
      Set ordered list in increasing priority of SELinux users | no | 
selinuxusermapdefault| ipaselinuxusermapdefault | 
      Set default SELinux user when no match is found in SELinux map rule | no | 
pac_type | ipakrbauthzdata | 
      set default types of PAC supported for services (choices: MS-PAC, PAD, nfs:NONE). Use "" to clear this variable. | 
      no | 
user_auth_type | ipauserauthtype | 
      set default types of supported user authentication (choices: password, radius, otp, pkinit, hardened, idp, disabled, ""). An additional check ensures that only types can be used that are supported by the IPA version. Use "" to clear this variable. | 
      no | 
domain_resolution_order | ipadomainresolutionorder | 
      Set list of domains used for short name qualification | no | 
ca_renewal_master_server | ipacarenewalmasterserver | 
      Renewal master for IPA certificate authority. | no | 
enable_sid | 
      New users and groups automatically get a SID assigned. Cannot be deactivated once activated. Requires IPA 4.9.8+. (bool) | no | 
netbios_name | 
      NetBIOS name of the IPA domain. Requires IPA 4.9.8+ and SID generation to be activated. | no | 
add_sids | 
      Add SIDs for existing users and groups. Requires IPA 4.9.8+ and SID generation to be activated. (bool) | no | 
Return Values
| Variable | Description | Returned When | 
|---|---|---|
config | 
      config dict  Fields:  | 
      No values to configure are specified | 
maxusername | 
      ||
maxhostname | 
      ||
homedirectory | 
      ||
defaultshell | 
      ||
defaultgroup | 
      ||
emaildomain | 
      ||
searchtimelimit | 
      ||
searchrecordslimit | 
      ||
usersearch | 
      ||
groupsearch | 
      ||
enable_migration | 
      ||
groupobjectclasses | 
      ||
userobjectclasses | 
      ||
pwdexpnotify | 
      ||
configstring | 
      ||
selinuxusermapdefault | 
      ||
selinuxusermaporder | 
      ||
pac_type | 
      ||
user_auth_type | 
      ||
domain_resolution_order | 
      ||
ca_renewal_master_server | 
      ||
enable_sid | 
      ||
netbios_name | 
      
All returned fields take the same form as their namesake input parameters
Authors
Chris Procter
