diff options
| author | luisgulo <luisgulo@gmail.com> | 2025-10-24 18:01:10 +0200 |
|---|---|---|
| committer | luisgulo <luisgulo@gmail.com> | 2025-10-24 18:01:10 +0200 |
| commit | 533e79ba959143f0459431a486bfb85c56c72ddc (patch) | |
| tree | 91974de1bbbdc4c51c76ed591fc5c6e02a3342b6 /core/modules/users.sh | |
| parent | 45019c81cfd0fc1d18dce18cdfd5f127c6d61073 (diff) | |
Releasing code version 1.8.0
Diffstat (limited to 'core/modules/users.sh')
| -rw-r--r-- | core/modules/users.sh | 106 |
1 files changed, 106 insertions, 0 deletions
diff --git a/core/modules/users.sh b/core/modules/users.sh new file mode 100644 index 0000000..e7306e2 --- /dev/null +++ b/core/modules/users.sh @@ -0,0 +1,106 @@ +#!/usr/bin/env bash +# Module: users +# Description: Gestiona usuarios del sistema (crear, modificar, eliminar) +# Author: Luis GuLo +# Version: 1.4.0 +# Dependencies: id, useradd, usermod, userdel, groupadd, sudo + +users_task() { + local host="$1"; shift + declare -A args; for arg in "$@"; do key="${arg%%=*}"; value="${arg#*=}"; args["$key"]="$value"; done + + local username="${args[username]}" + local home="${args[home]:-/home/$username}" + local shell="${args[shell]:-/bin/bash}" + local groups="${args[groups]:-}" + local state="${args[state]:-create}" + local become="${args[become]}" + local prefix="" + [ "$become" = "true" ] && prefix="sudo" + + # 🌐 Cargar traducciones + local lang="${shflow_vars[language]:-es}" + local trfile="$(dirname "${BASH_SOURCE[0]}")/users.tr.${lang}" + declare -A tr + if [[ -f "$trfile" ]]; then + while IFS='=' read -r k v; do tr["$k"]="$v"; done < "$trfile" + fi + + # 🛡️ Validación + if [[ "$become" != "true" && "$EUID" -ne 0 ]]; then + echo "${tr[priv_required]:-❌ [users] Se requieren privilegios para gestionar usuarios. Usa 'become: true'.}" + return 1 + fi + + if [[ -z "$username" ]]; then + echo "${tr[missing_username]:-❌ [users] Falta el parámetro obligatorio 'username'}" + return 1 + fi + + case "$state" in + create) + echo "${tr[enter_create]:-🔧 [users] Entrando en create}" + if id "$username" &>/dev/null; then + echo "$(render_msg "${tr[exists]}" "username=$username")" + return 0 + fi + if [[ -n "$groups" && "$groups" != "$username" ]]; then + if ! getent group "$groups" &>/dev/null; then + echo "$(render_msg "${tr[group_create]}" "groups=$groups")" + $prefix groupadd "$groups" + fi + fi + local cmd="$prefix useradd -m \"$username\" -s \"$shell\" -d \"$home\"" + [[ -n "$groups" ]] && cmd="$cmd -G \"$groups\"" + eval "$cmd" && echo "$(render_msg "${tr[created]}" "username=$username")" + ;; + modify) + echo "${tr[enter_modify]:-🔧 [users] Entrando en modify}" + if ! id "$username" &>/dev/null; then + echo "$(render_msg "${tr[not_exists]}" "username=$username")" + return 1 + fi + local cmd="$prefix usermod \"$username\"" + [[ -n "$shell" ]] && cmd="$cmd -s \"$shell\"" + [[ -n "$home" ]] && cmd="$cmd -d \"$home\"" + [[ -n "$groups" ]] && cmd="$cmd -G \"$groups\"" + eval "$cmd" && echo "$(render_msg "${tr[modified]}" "username=$username")" + ;; + absent) + echo "${tr[enter_absent]:-🔧 [users] Entrando en absent}" + if ! id "$username" &>/dev/null; then + echo "$(render_msg "${tr[already_deleted]}" "username=$username")" + return 0 + fi + eval "$prefix userdel -r \"$username\"" && echo "$(render_msg "${tr[deleted]}" "username=$username")" + ;; + *) + echo "$(render_msg "${tr[unsupported_state]}" "state=$state")" + return 1 + ;; + esac +} + +check_dependencies_users() { + local lang="${shflow_vars[language]:-es}" + local trfile="$(dirname "${BASH_SOURCE[0]}")/users.tr.${lang}" + declare -A tr + if [[ -f "$trfile" ]]; then + while IFS='=' read -r k v; do tr["$k"]="$v"; done < "$trfile" + fi + + local missing=() + for cmd in id sudo; do + if ! command -v "$cmd" >/dev/null 2>&1; then + missing+=("$cmd") + fi + done + + if [[ ${#missing[@]} -gt 0 ]]; then + echo "$(render_msg "${tr[missing_deps]}" "cmds=${missing[*]}")" + return 1 + fi + + echo "${tr[deps_ok]:-✅ [users] Todas las dependencias están presentes}" + return 0 +} |
