infinidat.infinibox.infini_export_client module – Create, Delete or Modify NFS Client(s) for existing exports on Infinibox
Note
This module is part of the infinidat.infinibox collection (version 1.6.3).
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 infinidat.infinibox.
You need further requirements to be able to use this module,
see Requirements for details.
To use it in a playbook, specify: infinidat.infinibox.infini_export_client.
New in infinidat.infinibox 2.3.0
Synopsis
- This module creates, deletes or modifys NFS client(s) for existing exports on Infinibox. 
Requirements
The below requirements are needed on the host that executes this module.
- infinisdk (https://infinisdk.readthedocs.io/en/latest/) 
- munch 
- python2 >= 2.7 or python3 >= 3.6 
Parameters
| Parameter | Comments | 
|---|---|
| Read Write or Read Only Access. Choices: 
 | |
| Client IP or Range. Ranges can be defined as follows 192.168.0.1-192.168.0.254. | |
| Name of the export. | |
| Don’t squash root user to anonymous. Will be set to “no” on creation if not specified explicitly. Choices: 
 | |
| Infinibox User password. | |
| Creates/Modifies client when present and removes when absent. Choices: 
 | |
| If True, persist API session to disk. Load the session on subsequent module calls. Persisted sessions are only usable for stay_logged_in_minutes. Choices: 
 | |
| Number of minutes for which a persisted session may be reused. After this time, the session data will be deleted. The time should be shorter than the IBOX session timeout time. Default:  | |
| Infinibox Hostname or IPv4 Address. | |
| Infinibox User username with sufficient priveledges ( see notes ). | 
Notes
Note
- This module requires infinisdk python library 
- You must set INFINIBOX_USER and INFINIBOX_PASSWORD environment variables if user and password arguments are not passed to the module directly 
- Ansible uses the infinisdk configuration file - ~/.infinidat/infinisdk.iniif no credentials are provided. See http://infinisdk.readthedocs.io/en/latest/getting_started.html
- All Infinidat modules support check mode (--check). However, a dryrun that creates resources may fail if the resource dependencies are not met for a task. For example, consider a task that creates a volume in a pool. If the pool does not exist, the volume creation task will fail. It will fail even if there was a previous task in the playbook that would have created the pool but did not because the pool creation was also part of the dry run. 
Examples
- name: Make sure nfs client 10.0.0.1 is configured for export. Allow root access
  infini_export_client:
    client: 10.0.0.1
    access_mode: RW
    no_root_squash: true
    export: /data
    state: present  # Default
    user: admin
    password: secret
    system: ibox001
- name: Add multiple clients with RO access. Squash root privileges
  infini_export_client:
    client: "{{ item }}"
    access_mode: RO
    no_root_squash: false
    export: /data
    user: admin
    password: secret
    system: ibox001
  with_items:
    - 10.0.0.2
    - 10.0.0.3
