Files
omarchy_setup/.docs/AGENTS.md
google-labs-jules[bot] d85b81dd0e refactor(docs): Mover AGENTS.md a un directorio oculto (#16)
Se mueve el archivo `AGENTS.md` al nuevo directorio oculto `.docs` para organizar mejor los archivos de documentación interna del proyecto.

Se actualiza el enlace correspondiente en el archivo `Readme.md` para que apunte a la nueva ubicación del archivo.

Co-authored-by: google-labs-jules[bot] <161369871+google-labs-jules[bot]@users.noreply.github.com>
2025-11-19 17:16:54 -06:00

5.0 KiB

AGENTS.md - Guía para Contribuidores y Tareas Pendientes

Este documento está destinado a los desarrolladores (humanos o agentes de IA) que trabajan en el proyecto Omarchy Setup. Contiene un resumen del estado actual, una lista de tareas pendientes y directrices para el desarrollo futuro.

Análisis del Proyecto

El proyecto "Omarchy Setup" es un script de post-instalación para Arch Linux, diseñado con un enfoque en la modularidad y la facilidad de uso.

  • Orquestador Principal (omarchy-setup.sh): Actúa como el punto de entrada. Presenta un menú interactivo al usuario, gestiona las sesiones de sudo, y coordina la ejecución de los diferentes módulos.
  • Módulos (modules/): Cada archivo .sh en este directorio encapsula una funcionalidad específica (ej. instalar aplicaciones, configurar Docker, personalizar Zsh). Esta estructura facilita la adición o modificación de tareas sin afectar al resto del sistema.
  • Funciones Comunes (modules/common.sh): Centraliza el código repetitivo, como las funciones de logging, la instalación de paquetes (pacman y AUR), y la creación de backups. Esto promueve la reutilización de código y la consistencia.
  • Interactividad: El sistema está diseñado para ser interactivo, solicitando confirmación del usuario para acciones importantes, pero también soporta ejecuciones en segundo plano para tareas no interactivas.

Tareas Pendientes y Mejoras

A continuación se detallan las tareas prioritarias para mejorar la funcionalidad y robustez del proyecto.

1. Implementar un Sistema de Dependencias entre Módulos

  • Objetivo: Evitar fallos cuando un módulo requiere que otro se haya ejecutado previamente (por ejemplo, ssh-keyring.sh necesita que apps.sh instale gnome-keyring).
  • Acción Propuesta:
    1. En cada módulo, definir un array o variable que liste sus dependencias. Ejemplo en ssh-keyring.sh: MODULE_DEPS=("apps").
    2. En omarchy-setup.sh, antes de ejecutar un módulo, leer esta variable y comprobar si los módulos dependientes ya han sido ejecutados (se podría mantener un registro de módulos completados).
    3. Si una dependencia no se ha cumplido, informar al usuario y ofrecerle ejecutarla primero.

2. Crear un Archivo de Configuración Central (omarchy.conf)

  • Objetivo: Facilitar instalaciones desatendidas y permitir a los usuarios pre-configurar sus preferencias sin modificar los scripts.
  • Acción Propuesta:
    1. Crear un archivo omarchy.conf.example con pares clave-valor para las opciones personalizables (ej. INSTALL_DOCKER="true", ZEROTIER_NETWORK_ID="tu_id_de_red").
    2. En omarchy-setup.sh, comprobar si existe omarchy.conf y cargarlo.
    3. Modificar los módulos para que lean estas variables de configuración y actúen en consecuencia, saltándose las preguntas interactivas si la opción está definida.

3. Añadir Funcionalidad de Desinstalación / Reversión

  • Objetivo: Permitir a los usuarios deshacer los cambios realizados por un módulo de forma segura.
  • Acción Propuesta:
    1. Para cada módulo, crear una función uninstall_<nombre_modulo>.
    2. Esta función debe realizar la acción inversa a la instalación: eliminar paquetes, restaurar archivos de configuración a partir de los backups .bak y deshabilitar los servicios correspondientes.
    3. Añadir una nueva opción en el menú principal para acceder a un sub-menú de desinstalación.

4. Implementar Verificaciones Post-Instalación

  • Objetivo: Aumentar la fiabilidad del script confirmando que el software principal de cada módulo se ha instalado y funciona correctamente.
  • Acción Propuesta:
    1. Al final de cada módulo, añadir una pequeña función de verify_<nombre_modulo>.
    2. Esta función debería ejecutar un comando simple para comprobar el estado del software. Ejemplos:
      • Docker: docker --version y docker run hello-world.
      • Zsh: zsh --version y comprobar que oh-my-posh está en el $PATH.
      • ZeroTier: sudo zerotier-cli status.
    3. Informar al usuario si la verificación ha sido exitosa o ha fallado.

Directrices para Futuros Desarrollos

  • Modularidad: Toda nueva funcionalidad debe encapsularse en su propio módulo.
  • Idempotencia: Los scripts deben poder ejecutarse múltiples veces sin causar efectos secundarios negativos. Comprueba siempre si un paquete ya está instalado o si una configuración ya existe antes de aplicarla.
  • Lenguaje y Estilo: Todo el código y los comentarios deben estar en español para mantener la consistencia del proyecto.
  • Manejo de Errores: Utiliza las funciones log_error, log_warning y log_success de common.sh para proporcionar feedback claro al usuario. Si un comando crítico falla, el script debe salir de forma controlada.
  • Seguridad: No almacenes información sensible (contraseñas, claves de API) directamente en los scripts. Utiliza ficheros locales como .zshrc.local (que está en .gitignore) para estos casos.