system_users

system_users

This is a very simple role meant to make playbooks that manage users a little bit cleaner by allowing you to avoid manually running the user, groups and authorized_key modules yourself. Instead, you just need to pass word system_users_users, system_users_groups and system_users_authorized_keys into each list and this role will run those modules for you.

WARNING:

This role is pretty dumb and passes much of the role values to the appropriate modules as dicts, which is something that Ansible doesn't like for security reasons. For that reason, it is recommended that you disable INJECT_FACTS_AS_VARS in Ansible. There are security benefits to disabling this value beyond this specific role.

Requirements

None.

Role Variables

See defaults/main.yml for the most up-to-date values.

They're repeated here for convenience, and since there's so few of them:

Variable Name Description Default Value
system_users_users This is a list of user dicts to be passed to ansible.builtin.user. See module documentation for more information. []
system_users_groups This is a list of group dicts to be passed to ansible.builtin.group. See module documentation for more information. []
system_users_authorized_keys This is a list of group dicts to be passed to ansible.posix.authorized_key. See module documentation for more information. []
system_users_private_keys The private keys provided in this list will be added to the provided users' directories. Each entry in this list can contain the key(s) ['user', 'group', 'key', 'dest', 'overwrite']. Further information on the use of each key is provided in defaults/main.yml []

Dependencies

None.

Example Playbook

Including an example of how to use your role (for instance, with variables passed in as parameters) is always nice for users too:

- hosts: servers
  roles:
     - role: dudefellah.system_users
       system_users_groups:
         - name: bob
           gid: 1001
       system_users_users:
         - name: bob
           group: bob
       system_users_authorized_keys:
         - user: bob
           key: "{{ lookup('file', 'my-key-path') }}"

License

GPLv2+

Author Information

Dan - github.com/dudefellah

About

This is a very simple role to manage multiple users.

Install
ansible-galaxy install dudefellah/ansible-role-system_users
GitHub repository
License
Unknown
Downloads
40460
Owner