azure.azcollection.azure_rm_roleassignment module – Manage Azure Role Assignment
Note
This module is part of the azure.azcollection collection (version 3.9.0).
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 azure.azcollection.
You need further requirements to be able to use this module,
see Requirements for details.
To use it in a playbook, specify: azure.azcollection.azure_rm_roleassignment.
New in azure.azcollection 0.1.2
Synopsis
- Create and delete instance of Azure Role Assignment. 
Requirements
The below requirements are needed on the host that executes this module.
- python >= 2.7 
- The host that executes this module must have the azure.azcollection collection installed via galaxy 
- All python packages listed in collection’s requirements.txt must be installed via pip on the host that executes modules from azure.azcollection 
- Full installation instructions may be found https://galaxy.ansible.com/azure/azcollection 
Parameters
| Parameter | Comments | 
|---|---|
| Active Directory username. Use when authenticating with an Active Directory user rather than service principal. | |
| Azure AD authority url. Use when authenticating with Username/password, and has your own ADFS authority. | |
| Selects an API profile to use when communicating with Azure services. Default value of  Default:  | |
| The object id of assignee. This maps to the ID inside the Active Directory. It can point to a user, service principal or security group. Required when creating role assignment. | |
| Controls the source of the credentials to use for authentication. Can also be set via the  When set to  When set to  When set to  When set to  When set to  The  Choices: 
 | |
| Controls the certificate validation behavior for Azure endpoints. By default, all modules will validate the server certificate, but when an HTTPS proxy is in use, or against Azure Stack, it may be necessary to disable this behavior by passing  Choices: 
 | |
| Azure client ID. Use when authenticating with a Service Principal or Managed Identity (msi). Can also be set via the  | |
| For cloud environments other than the US public cloud, the environment name (as defined by Azure Python SDK, eg,  Default:  | |
| Determines whether or not instance discovery is performed when attempting to authenticate. Setting this to true will completely disable both instance discovery and authority validation. This functionality is intended for use in scenarios where the metadata endpoint cannot be reached such as in private clouds or Azure Stack. The process of instance discovery entails retrieving authority metadata from https://login.microsoft.com/ to validate the authority. By setting this to **True**, the validation of the authority is disabled. As a result, it is crucial to ensure that the configured authority host is valid and trustworthy. Set via credential file profile or the  Choices: 
 | |
| Fully qualified id of assignment to delete or create. Mutually Exclusive with scope and name | |
| Parent argument. | |
| Parent argument. | |
| Unique name of role assignment. The role assignment name must be a GUID, sample as “3ce0cbb0-58c4-4e6d-a16d-99d86a78b3ca”. Mutually Exclusive with id | |
| Active Directory user password. Use when authenticating with an Active Directory user rather than service principal. | |
| Security profile found in ~/.azure/credentials file. | |
| The role definition id used in the role assignment. Required when creating role assignment. | |
| The scope of the role assignment to create. For example, use /subscriptions/{subscription-id}/ for subscription. /subscriptions/{subscription-id}/resourceGroups/{resource-group-name} for resource group. /subscriptions/{subscription-id}/resourceGroups/{resource-group-name}/providers/{resource-provider}/{resource-type}/{resource-name} for resource. Mutually Exclusive with id | |
| Azure client secret. Use when authenticating with a Service Principal. | |
| Assert the state of the role assignment. Use  If  Choices: 
 | |
| Your Azure subscription Id. | |
| Azure tenant ID. Use when authenticating with a Service Principal. | |
| The thumbprint of the private key specified in x509_certificate_path. Use when authenticating with a Service Principal. Required if x509_certificate_path is defined. | |
| Path to the X509 certificate used to create the service principal in PEM format. The certificate must be appended to the private key. Use when authenticating with a Service Principal. | 
Notes
Note
- For authentication with Azure you can pass parameters, set environment variables, use a profile stored in ~/.azure/credentials, or log in before you run your tasks or playbook with - az login.
- Authentication is also possible using a service principal or Active Directory user. 
- To authenticate via service principal, pass subscription_id, client_id, secret and tenant or set environment variables AZURE_SUBSCRIPTION_ID, AZURE_CLIENT_ID, AZURE_SECRET and AZURE_TENANT. 
- To authenticate via Active Directory user, pass ad_user and password, or set AZURE_AD_USER and AZURE_PASSWORD in the environment. 
- Alternatively, credentials can be stored in ~/.azure/credentials. This is an ini file containing a [default] section and the following keys: subscription_id, client_id, secret and tenant or subscription_id, ad_user and password. It is also possible to add additional profiles. Specify the profile by passing profile or setting AZURE_PROFILE in the environment. 
See Also
See also
- Sign in with Azure CLI
- How to authenticate using the - az logincommand.
Examples
- name: Create a role assignment
  azure_rm_roleassignment:
    scope: /subscriptions/xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx
    assignee_object_id: xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx
    role_definition_id:
      "/subscriptions/xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx/providers/Microsoft.Authorization/roleDefinitions/xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"
- name: Create a role assignment
  azure_rm_roleassignment:
    name: xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx
    scope: /subscriptions/xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx
    assignee_object_id: xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx
    role_definition_id:
      "/subscriptions/xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx/providers/Microsoft.Authorization/roleDefinitions/xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"
- name: Delete a role assignment
  azure_rm_roleassignment:
    name: xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx
    scope: /subscriptions/xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx
    state: absent
- name: Delete a role assignment
  azure_rm_roleassignment:
    id: /subscriptions/xxx-sub-guid-xxx/resourceGroups/rgname/providers/Microsoft.Authorization/roleAssignments/xxx-assign-guid-xxx"
    state: absent
- name: Delete a role assignment
  azure_rm_roleassignment:
    scope: /subscriptions/xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx
    assignee_object_id: xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx
    role_definition_id:
      "/subscriptions/xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx/providers/Microsoft.Authorization/roleDefinitions/xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"
    state: absent
Return Values
Common return values are documented here, the following are the fields unique to this module:
| Key | Description | 
|---|---|
| Principal Id of the role assignee. Returned: always Sample:  | |
| Id of current role assignment. Returned: always Sample:  | |
| Name of role assignment. Returned: always Sample:  | |
| Principal type of the role assigned to. Returned: always Sample:  | |
| Role definition id that was assigned to principal_id. Returned: always Sample:  | |
| The role assignment scope. Returned: always Sample:  | |
| Type of role assignment. Returned: always Sample:  | 
