- Añadir variable global DEVELOPER_DIR=${HOME}/.developer a base.lib - Eliminar definición redundante en cversadm_token.sh y usar la variable global - Actualizar todas las referencias a la variable en las funciones del script - Centralizar definición de la ruta para uso consistente en todo el proyecto 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
250 lines
No EOL
6.6 KiB
Bash
Executable file
250 lines
No EOL
6.6 KiB
Bash
Executable file
#!/bin/bash
|
|
#
|
|
# Script: cversadm_token.sh
|
|
# Description: Administrador de tokens para plataformas de control de versiones
|
|
# Modified: 2025/03/15
|
|
# [Author] Cortana Rosero One <cortana@rosero.one>
|
|
# [Generated] Created by Claude Code (claude-3-7-sonnet-20250219)
|
|
#
|
|
# Derechos de Autor (C) [2025] [Mauro Rosero P. <mauro@roser.one>]
|
|
#
|
|
# Este programa es software libre: usted puede redistribuirlo y/o modificarlo
|
|
# bajo los términos de la Licencia Pública Affero General de GNU tal como
|
|
# lo publica la Free Software Foundation, ya sea la versión 3 de la licencia,
|
|
# o (a su elección) cualquier versión posterior.
|
|
#
|
|
# Este programa se distribuye con la esperanza de que sea útil,
|
|
# pero SIN NINGUNA GARANTÍA; sin siquiera la garantía implícita de
|
|
# COMERCIABILIDAD o IDONEIDAD PARA UN PROPÓSITO PARTICULAR. Consulte la
|
|
# Licencia Pública Affero General de GNU para obtener más detalles.
|
|
#
|
|
# Debería haber recibido una copia de la Licencia Pública Affero General
|
|
# junto con este programa. Si no la recibió, consulte <https://www.gnu.org/licenses/>.
|
|
|
|
# Configuración inicial
|
|
# Usar DEVELOPER_DIR de base.lib
|
|
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
|
|
|
|
# Leer DEVSPATH desde el archivo de configuración o usar "devs" por defecto
|
|
if [ -f "$SCRIPT_DIR/config/devspath.dat" ]; then
|
|
DEVSPATH=$(cat "$SCRIPT_DIR/config/devspath.dat")
|
|
else
|
|
DEVSPATH="devs"
|
|
fi
|
|
|
|
BIN_HOME="$HOME/$DEVSPATH"
|
|
BIN_BASE="bin"
|
|
BIN_LIBS="lib"
|
|
BIN_MESG="msg"
|
|
|
|
# Definir variables necesarias para uso en funciones
|
|
head_error="ERROR"
|
|
head_exit="Salir"
|
|
head_key_end="END"
|
|
|
|
# Importar bibliotecas necesarias
|
|
source "${BIN_HOME}/${BIN_BASE}/${BIN_LIBS}/base.lib"
|
|
source "${BIN_HOME}/${BIN_BASE}/${BIN_LIBS}/console.lib"
|
|
|
|
# CHECK SHELL LANGUAGE
|
|
BIN_LANG=${LANG:0:2}
|
|
|
|
# Cargar mensajes en el idioma del sistema o español por defecto
|
|
load_messages "${BIN_HOME}/${BIN_BASE}" "${BIN_MESG}" "${BIN_LANG}" "head"
|
|
load_messages "${BIN_HOME}/${BIN_BASE}" "${BIN_MESG}" "${BIN_LANG}" "developers"
|
|
|
|
# Variables globales
|
|
title="${head_000} ${head_002}"
|
|
apps_title="${cvmsg_000}"
|
|
|
|
# Función para verificar si SOPS está instalado
|
|
check_sops_installed() {
|
|
if ! command -v sops &> /dev/null; then
|
|
# Mostrar el error usando dialog con mensaje desde developers.es
|
|
dialog_error_box "${head_error}" "${cvmsg_013}. ${cvmsg_014}"
|
|
clear
|
|
exit 1
|
|
fi
|
|
}
|
|
|
|
# Función para asegurar que el directorio .developer existe
|
|
ensure_developers_dir() {
|
|
if [ ! -d "$DEVELOPER_DIR" ]; then
|
|
mkdir -p "$DEVELOPER_DIR"
|
|
chmod 700 "$DEVELOPER_DIR"
|
|
echo "${cvmsg_008} $DEVELOPER_DIR"
|
|
fi
|
|
}
|
|
|
|
# Función para seleccionar la plataforma de control de versiones usando menu_actions
|
|
select_platform() {
|
|
# Preparar opciones para menu_actions
|
|
local menu_options="1:${cvmsg_010}
|
|
2:${cvmsg_011}
|
|
3:${cvmsg_012}
|
|
|
|
|
|
|
|
"
|
|
|
|
# Usar menu_actions en lugar de dialog_input_menu
|
|
local selection=$(menu_actions "${cvmsg_002}" "$menu_options" 9)
|
|
|
|
# Verificar si hubo cancelación o error
|
|
if [ "$selection" = "${head_key_end}" ]; then
|
|
return 1
|
|
fi
|
|
|
|
# Interpretar la selección
|
|
case $selection in
|
|
1) echo "github" ;;
|
|
2) echo "gitlab" ;;
|
|
3) echo "forgejo" ;;
|
|
*) return 1 ;;
|
|
esac
|
|
|
|
return 0
|
|
}
|
|
|
|
# Función para solicitar y validar el token
|
|
request_token() {
|
|
local platform=$1
|
|
local platform_name=""
|
|
local token=""
|
|
|
|
case $platform in
|
|
"github") platform_name="${cvmsg_010}" ;;
|
|
"gitlab") platform_name="${cvmsg_011}" ;;
|
|
"forgejo") platform_name="${cvmsg_012}" ;;
|
|
esac
|
|
|
|
# Bucle para validación de token usando dialog directamente
|
|
while true; do
|
|
# Usar dialog directamente en lugar de dialog_input_pass
|
|
token=$(dialog --backtitle "$title" --stdout --title "${cvmsg_003}" \
|
|
--passwordbox "${cvmsg_004} $platform_name\n${cvmsg_005}" 8 60)
|
|
|
|
# Verificar si el usuario canceló
|
|
if [ $? -ne 0 ]; then
|
|
clear
|
|
return 1
|
|
fi
|
|
|
|
# Validar token
|
|
if [ -z "$token" ]; then
|
|
dialog --backtitle "$title" --title "${head_error}" --msgbox "${cvmsg_015}" 7 60
|
|
continue
|
|
fi
|
|
|
|
# Verificar longitud (debería tener al menos 30 caracteres)
|
|
if [ ${#token} -lt 30 ]; then
|
|
dialog --backtitle "$title" --title "${head_error}" --msgbox "${cvmsg_016}" 7 60
|
|
continue
|
|
fi
|
|
|
|
# Verificar formato (debería contener caracteres alfanuméricos y algunos especiales)
|
|
if ! [[ "$token" =~ ^[A-Za-z0-9\#\-\_\.]+$ ]]; then
|
|
dialog --backtitle "$title" --title "${head_warning}" --msgbox "${cvmsg_017}" 7 60
|
|
fi
|
|
|
|
# Token válido
|
|
break
|
|
done
|
|
|
|
echo "$token"
|
|
return 0
|
|
}
|
|
|
|
# Función para guardar el token encriptado con SOPS
|
|
save_token() {
|
|
local platform=$1
|
|
local token=$2
|
|
local filename="${DEVELOPER_DIR}/${platform}.sops.yaml"
|
|
local token_file="/tmp/vcs_token_$$"
|
|
|
|
# Convertir token a base64 para mayor seguridad
|
|
local token_base64=$(echo -n "$token" | base64)
|
|
|
|
# Crear archivo temporal con el token en base64
|
|
echo "token: $token_base64" > "$token_file"
|
|
|
|
# Encriptar el archivo con SOPS
|
|
sops --encrypt "$token_file" > "$filename"
|
|
local result=$?
|
|
|
|
# Eliminar archivo temporal
|
|
rm -f "$token_file"
|
|
|
|
# Establecer permisos adecuados (solo lectura para el propietario)
|
|
if [ $result -eq 0 ]; then
|
|
chmod 600 "$filename"
|
|
fi
|
|
|
|
return $result
|
|
}
|
|
|
|
# Verificar si dialog está instalado
|
|
check_dialog_installed() {
|
|
if ! command -v dialog &> /dev/null; then
|
|
echo "${head_001}"
|
|
exit 1
|
|
fi
|
|
}
|
|
|
|
# Función principal
|
|
main() {
|
|
# Verificar requisitos
|
|
check_dialog_installed
|
|
check_sops_installed
|
|
ensure_developers_dir
|
|
|
|
# Asegurar que head_000 y head_002 estén definidos para el título
|
|
if [ -z "$head_000" ] || [ -z "$head_002" ]; then
|
|
head_000="MRDevs"
|
|
head_002="Tools"
|
|
fi
|
|
|
|
# Mostrar título inicial
|
|
display_text_header
|
|
|
|
# Seleccionar plataforma
|
|
platform=$(select_platform)
|
|
if [ $? -ne 0 ]; then
|
|
clear
|
|
exit 0
|
|
fi
|
|
|
|
# Solicitar token
|
|
token=$(request_token "$platform")
|
|
if [ $? -ne 0 ]; then
|
|
clear
|
|
exit 0
|
|
fi
|
|
|
|
# Guardar token
|
|
save_token "$platform" "$token"
|
|
if [ $? -eq 0 ]; then
|
|
local platform_name=""
|
|
case $platform in
|
|
"github") platform_name="${cvmsg_010}" ;;
|
|
"gitlab") platform_name="${cvmsg_011}" ;;
|
|
"forgejo") platform_name="${cvmsg_012}" ;;
|
|
esac
|
|
|
|
dialog_error_box "${cvmsg_009}" "${cvmsg_006} $platform_name"
|
|
else
|
|
local platform_name=""
|
|
case $platform in
|
|
"github") platform_name="${cvmsg_010}" ;;
|
|
"gitlab") platform_name="${cvmsg_011}" ;;
|
|
"forgejo") platform_name="${cvmsg_012}" ;;
|
|
esac
|
|
|
|
dialog_error_box "${head_error}" "${cvmsg_007} $platform_name"
|
|
fi
|
|
|
|
clear
|
|
}
|
|
|
|
# Ejecutar función principal
|
|
main |