community.general.ipa_role module – Manage FreeIPA role
Note
This module is part of the community.general collection (version 10.7.5).
You might already have this collection installed if you are using the ansible package.
It is not included in ansible-core.
To check whether it is installed, run ansible-galaxy collection list.
To install it, use: ansible-galaxy collection install community.general.
To use it in a playbook, specify: community.general.ipa_role.
Synopsis
- Add, modify and delete a role within FreeIPA server using FreeIPA API. 
Parameters
| Parameter | Comments | 
|---|---|
| Role name. Can not be changed as it is the unique identifier. | |
| A description of this role-group. | |
| List of group names assign to this role. If an empty list is passed all assigned groups are unassigned from the role. If option is omitted groups are not checked nor changed. If option is passed all assigned groups that are not passed are unassigned from the role. | |
| List of host names to assign. If an empty list is passed all assigned hosts are unassigned from the role. If option is omitted hosts are not checked nor changed. If option is passed all assigned hosts that are not passed are unassigned from the role. | |
| List of host group names to assign. If an empty list is passed all assigned host groups are removed from the role. If option is omitted host groups are not checked nor changed. If option is passed all assigned hostgroups that are not passed are unassigned from the role. | |
| IP or hostname of IPA server. If the value is not specified in the task, the value of environment variable  If both the environment variable  The relevant entry needed in FreeIPA is the  If neither the DNS entry, nor the environment  Default:  | |
| Password of administrative user. If the value is not specified in the task, the value of environment variable  Note that if the  If the environment variable  If the environment variable  If GSSAPI is not available, the usage of  | |
| Port of FreeIPA / IPA server. If the value is not specified in the task, the value of environment variable  If both the environment variable  Default:  | |
| Protocol used by IPA server. If the value is not specified in the task, the value of environment variable  If both the environment variable  Choices: 
 | |
| Specifies idle timeout (in seconds) for the connection. For bulk operations, you may want to increase this in order to avoid timeout from IPA server. If the value is not specified in the task, the value of environment variable  If both the environment variable  Default:  | |
| Administrative account used on IPA server. If the value is not specified in the task, the value of environment variable  If both the environment variable  Default:  | |
| List of privileges granted to the role. If an empty list is passed all assigned privileges are removed. If option is omitted privileges are not checked nor changed. If option is passed all assigned privileges that are not passed are removed. | |
| List of service names to assign. If an empty list is passed all assigned services are removed from the role. If option is omitted services are not checked nor changed. If option is passed all assigned services that are not passed are removed from the role. | |
| State to ensure. Choices: 
 | |
| List of user names to assign. If an empty list is passed all assigned users are removed from the role. If option is omitted users are not checked nor changed. | |
| This only applies if  If set to  This should only set to  Choices: 
 | 
Attributes
| Attribute | Support | Description | 
|---|---|---|
| Support: full | Can run in  | |
| Support: none | Will return details on what has changed (or possibly needs changing in  | 
Notes
Note
- This module uses JSON-RPC over HTTP(S) to communicate with the FreeIPA server. If you need to enroll the managed node into FreeIPA realm, you might want to consider using the collection freeipa.ansible_freeipa, but shell access to one node from the realm is required to manage the deployment. 
Examples
- name: Ensure role is present
  community.general.ipa_role:
    name: dba
    description: Database Administrators
    state: present
    user:
      - pinky
      - brain
    ipa_host: ipa.example.com
    ipa_user: admin
    ipa_pass: topsecret
- name: Ensure role with certain details
  community.general.ipa_role:
    name: another-role
    description: Just another role
    group:
      - editors
    host:
      - host01.example.com
    hostgroup:
      - hostgroup01
    privilege:
      - Group Administrators
      - User Administrators
    service:
      - service01
- name: Ensure role is absent
  community.general.ipa_role:
    name: dba
    state: absent
    ipa_host: ipa.example.com
    ipa_user: admin
    ipa_pass: topsecret
Return Values
Common return values are documented here, the following are the fields unique to this module:
| Key | Description | 
|---|---|
| Role as returned by IPA API. Returned: always | 
