singleplatform-eng.users
ansible-users
Rol para gestionar usuarios en un sistema.
Configuración del rol
- users_create_per_user_group (predeterminado: true) - al crear usuarios, también crea un grupo con el mismo nombre de usuario y lo convierte en el grupo principal del usuario.
- users_group (predeterminado: usuarios) - si users_create_per_user_group no está configurado, entonces este es el grupo principal para todos los usuarios creados.
- users_default_shell (predeterminado: /bin/bash) - la shell predeterminada si no se especifica ninguna para el usuario.
- users_create_homedirs (predeterminado: true) - crear directorios personales para nuevos usuarios. Establezca esto en falso si gestiona los directorios personales por separado.
- authorized_keys_file (predeterminado: .ssh/authorized_keys) - Configure esto si el servidor ssh está configurado para usar un archivo de claves autorizadas no estándar.
Creando usuarios
Agregue una variable de usuarios que contenga la lista de usuarios a añadir. Un buen lugar para colocar
esto es en group_vars/all
o group_vars/nombre_del_grupo
si solo desea que los
usuarios estén en ciertas máquinas.
Los siguientes atributos son obligatorios para cada usuario:
- username - El nombre de usuario del usuario.
- name - El nombre completo del usuario (campo gecos).
- home - El directorio personal del usuario a crear (opcional, predeterminado a /home/nombre_usuario).
- uid - El ID numérico del usuario (opcional). Esto es necesario para la consistencia del uid entre sistemas.
- gid - El ID numérico del grupo (opcional). De lo contrario, se usará el uid.
- password - Si se proporciona un hash, se usará, de lo contrario, la cuenta se bloqueará.
- update_password - Esto puede ser 'always' o 'on_create'
- 'always' actualizará las contraseñas si son diferentes. (predeterminado)
- 'on_create' solo establecerá la contraseña para los usuarios recién creados.
- group - Sobrescritura opcional del grupo principal.
- groups - Una lista de grupos adicionales para el usuario.
- append - Si es sí, solo agregará grupos, no los establecerá solo en la lista de grupos (opcional).
- profile - Un bloque de cadena para establecer perfiles de shell personalizados.
- ssh_key - Esta debe ser una lista de claves SSH para el usuario (opcional). Cada clave SSH debe incluirse directamente y no debe tener saltos de línea.
- generate_ssh_key - Si generar una clave SSH para el usuario (opcional, predeterminado a no).
Además, los siguientes elementos son opcionales para cada usuario:
- shell - La shell del usuario. Esto predetermina a /bin/bash. El predeterminado es configurable usando la variable users_default_shell si desea darle a todos los usuarios la misma shell, pero es diferente de /bin/bash.
Ejemplo:
---
users:
- username: foo
name: Foo Barrington
groups: ['wheel','systemd-journal']
uid: 1001
home: /local/home/foo
profile: |
alias ll='ls -lah'
ssh_key:
- "ssh-rsa AAAAA.... foo@machine"
- "ssh-rsa AAAAB.... foo2@machine"
groups_to_create:
- name: developers
gid: 10000
users_deleted:
- username: bar
name: Bar User
uid: 1002
Eliminando usuarios
La variable users_deleted
contiene una lista de usuarios que ya no deben estar
en el sistema, y estos se eliminarán en la próxima ejecución de ansible. El formato
es el mismo que para los usuarios a agregar, pero el único campo obligatorio es username
.
Sin embargo, se recomienda que también mantenga el campo uid
como referencia para
que los IDs numéricos de usuario no se reutilicen accidentalmente.
Puede elegir opcionalmente eliminar el directorio personal del usuario y el correo del
buzón con el parámetro remove
, y forzar la eliminación de archivos con el parámetro force
.
users_deleted:
- username: bar
uid: 1002
remove: yes
force: yes
ansible-galaxy install singleplatform-eng.users