Server IP : 85.214.239.14 / Your IP : 3.139.235.100 Web Server : Apache/2.4.62 (Debian) System : Linux h2886529.stratoserver.net 4.9.0 #1 SMP Tue Jan 9 19:45:01 MSK 2024 x86_64 User : www-data ( 33) PHP Version : 7.4.18 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare, MySQL : OFF | cURL : OFF | WGET : ON | Perl : ON | Python : ON | Sudo : ON | Pkexec : OFF Directory : /lib/python3/dist-packages/ansible_collections/openstack/cloud/plugins/modules/ |
Upload File : |
#!/usr/bin/python # Copyright (c) 2015 Hewlett-Packard Development Company, L.P. # GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt) DOCUMENTATION = ''' --- module: identity_user short_description: Manage OpenStack Identity Users author: OpenStack Ansible SIG description: - Manage OpenStack Identity users. Users can be created, updated or deleted using this module. A user will be updated if I(name) matches an existing user and I(state) is present. The value for I(name) cannot be updated without deleting and re-creating the user. options: name: description: - Username for the user required: true type: str password: description: - Password for the user type: str update_password: required: false choices: ['always', 'on_create'] default: on_create description: - C(always) will attempt to update password. C(on_create) will only set the password for newly created users. type: str email: description: - Email address for the user type: str description: description: - Description about the user type: str default_project: description: - Project name or ID that the user should be associated with by default type: str domain: description: - Domain to create the user in if the cloud supports domains type: str enabled: description: - Is the user enabled type: bool default: 'yes' state: description: - Should the resource be present or absent. choices: [present, absent] default: present type: str requirements: - "python >= 3.6" - "openstacksdk" extends_documentation_fragment: - openstack.cloud.openstack ''' EXAMPLES = ''' # Create a user - openstack.cloud.identity_user: cloud: mycloud state: present name: demouser password: secret email: demo@example.com domain: default default_project: demo # Delete a user - openstack.cloud.identity_user: cloud: mycloud state: absent name: demouser # Create a user but don't update password if user exists - openstack.cloud.identity_user: cloud: mycloud state: present name: demouser password: secret update_password: on_create email: demo@example.com domain: default default_project: demo # Create a user without password - openstack.cloud.identity_user: cloud: mycloud state: present name: demouser email: demo@example.com domain: default default_project: demo ''' RETURN = ''' user: description: Dictionary describing the user. returned: On success when I(state) is 'present' type: dict contains: default_project_id: description: User default project ID. Only present with Keystone >= v3. returned: success type: str sample: "4427115787be45f08f0ec22a03bfc735" description: description: The description of this user returned: success type: str sample: "a user" domain_id: description: User domain ID. Only present with Keystone >= v3. returned: success type: str sample: "default" email: description: User email address returned: success type: str sample: "demo@example.com" id: description: User ID returned: success type: str sample: "f59382db809c43139982ca4189404650" enabled: description: Indicates whether the user is enabled type: bool name: description: Unique user name, within the owning domain returned: success type: str sample: "demouser" username: description: Username with Identity API v2 (OpenStack Pike or earlier) else Null returned: success type: str ''' from ansible_collections.openstack.cloud.plugins.module_utils.openstack import OpenStackModule class IdentityUserModule(OpenStackModule): argument_spec = dict( name=dict(required=True), password=dict(required=False, default=None, no_log=True), email=dict(required=False, default=None), default_project=dict(required=False, default=None), description=dict(type='str'), domain=dict(required=False, default=None), enabled=dict(default=True, type='bool'), state=dict(default='present', choices=['absent', 'present']), update_password=dict(default='on_create', choices=['always', 'on_create']), ) module_kwargs = dict() def _needs_update(self, params_dict, user): for k in params_dict: # We don't get password back in the user object, so assume any supplied # password is a change. if k == 'password': return True if k == 'default_project': if user['default_project_id'] != params_dict['default_project']: return True else: continue if user[k] != params_dict[k]: return True return False def _get_domain_id(self, domain): dom_obj = self.conn.identity.find_domain(domain) if dom_obj is None: # Ok, let's hope the user is non-admin and passing a sane id return domain return dom_obj.id def _get_default_project_id(self, default_project, domain_id): project = self.conn.identity.find_project(default_project, domain_id=domain_id) if not project: self.fail_json(msg='Default project %s is not valid' % default_project) return project['id'] def run(self): name = self.params['name'] password = self.params.get('password') email = self.params['email'] default_project = self.params['default_project'] domain = self.params['domain'] enabled = self.params['enabled'] state = self.params['state'] update_password = self.params['update_password'] description = self.params['description'] if domain: domain_id = self._get_domain_id(domain) user = self.conn.get_user(name, domain_id=domain_id) else: domain_id = None user = self.conn.get_user(name) changed = False if state == 'present': user_args = { 'name': name, 'email': email, 'domain_id': domain_id, 'description': description, 'enabled': enabled, } if default_project: default_project_id = self._get_default_project_id( default_project, domain_id) user_args['default_project'] = default_project_id user_args = {k: v for k, v in user_args.items() if v is not None} changed = False if user is None: if password: user_args['password'] = password user = self.conn.create_user(**user_args) changed = True else: if update_password == 'always': if not password: self.fail_json(msg="update_password is always but a password value is missing") user_args['password'] = password if self._needs_update(user_args, user): user = self.conn.update_user(user['id'], **user_args) changed = True self.exit_json(changed=changed, user=user) elif state == 'absent' and user is not None: self.conn.identity.delete_user(user['id']) changed = True self.exit_json(changed=changed) def main(): module = IdentityUserModule() module() if __name__ == '__main__': main()