ogCore - Documentación Técnica y Funcional

Equipo OpenGnsys

Octubre 2025

1 ogCore - Documentación Técnica y Funcional

1.1 Tabla de Contenidos

  1. Introducción
  2. Descripción del Proyecto
  3. Arquitectura del Sistema
  4. Tecnologías Utilizadas
  5. Requisitos del Sistema
  6. Instalación y Configuración
  7. Componentes del Sistema
  8. API RESTful
  9. Seguridad y Autenticación
  10. Servicios Principales
  11. Comandos de Consola
  12. Migraciones de Datos
  13. Testing
  14. Despliegue
  15. Mantenimiento y Operaciones
  16. Integración con Otros Servicios
  17. Roadmap y Changelog
  18. Contribución
  19. Soporte y Contacto

1.2 1. Introducción

ogCore es el servicio central de OpenGnsys, una plataforma de código abierto diseñada para la gestión centralizada de aulas de informática, laboratorios y entornos educativos. Este servicio proporciona una API RESTful robusta que permite administrar de manera eficiente clientes (equipos), imágenes de sistemas operativos, perfiles de hardware y software, tareas programadas, y mucho más.

1.2.1 1.1 Propósito del Sistema

El propósito principal de ogCore es:

1.2.2 1.2 Alcance

ogCore gestiona: - Clientes (equipos físicos) - Imágenes de sistemas operativos - Repositorios de imágenes - Perfiles de hardware y software - Unidades organizativas (aulas, grupos) - Redes y subredes - Plantillas PXE - Menús de arranque - Comandos y tareas programadas - Trazas de ejecución - Calendarios remotos - Integración con sistemas externos (UDS, ogRepository, ogDhcp, ogBoot)


1.3 2. Descripción del Proyecto

1.3.1 2.1 ¿Qué es ogCore?

ogCore es el núcleo central de OpenGnsys desarrollado con tecnologías modernas de PHP. Actúa como backend que expone una API RESTful completa, permitiendo la gestión de todos los aspectos relacionados con la administración de aulas informáticas.

1.3.2 2.2 Características Principales

1.3.3 2.3 Versión Actual


1.4 3. Arquitectura del Sistema

1.4.1 3.1 Arquitectura General

ogCore sigue una arquitectura de microservicios basada en el patrón API-First:

+-------------------------------------------------------------+
|                      Frontend (Web UI)                      |
+---------------------------+----------------------------------+
                            |
                            | HTTP/REST
                            |
+---------------------------v---------------------------------+
|                     ogCore API (Symfony)                    |
|  +------------------------------------------------------+   |
|  |  Controllers | States | DTOs | Validators | Filters  |   |
|  +------------------------------------------------------+   |
|  +------------------------------------------------------+   |
|  |              Business Logic (Services)               |   |
|  +------------------------------------------------------+   |
|  +------------------------------------------------------+   |
|  |        Entities | Repositories | Doctrine ORM        |   |
|  +------------------------------------------------------+   |
+---------------------------+----------------+----------------+
                            |                |
         +------------------v--+    +--------v--------+
         |   MariaDB           |    |   Mercure       |
         |   Database          |    |  (WebSocket)    |
         +---------------------+    +-----------------+

+-------------------------------------------------------------+
|              Servicios Externos Integrados                  |
+--------------+--------------+--------------+----------------+
| ogRepository |   ogDhcp     |   ogBoot     |   UDS/Git      |
+--------------+--------------+--------------+----------------+

1.4.2 3.2 Capas de la Aplicación

1.4.2.1 3.2.1 Capa de Presentación (API)

1.4.2.2 3.2.2 Capa de Negocio

1.4.2.3 3.2.3 Capa de Datos

1.4.2.4 3.2.4 Capa de Infraestructura

1.4.3 3.3 Patrones de Diseño Utilizados

  1. Repository Pattern: Para abstracción de acceso a datos
  2. DTO Pattern: Para transferencia de datos entre capas
  3. Factory Pattern: Para creación de entidades complejas
  4. Event-Driven Architecture: Para notificaciones y reactividad
  5. State Pattern: Para gestión de estados de procesamiento
  6. Service Layer: Para encapsulación de lógica de negocio

1.5 4. Tecnologías Utilizadas

1.5.1 4.1 Backend

Tecnología Versión Propósito
PHP 8.3 Lenguaje de programación principal
Symfony 6.4 Framework web principal
Doctrine ORM 2.19 Mapeo objeto-relacional
API Platform 3.2 Creación de APIs REST
Lexik JWT 3.0 Autenticación JWT
Gesdinet JWT Refresh Token 1.3 Refresh tokens
Stof Doctrine Extensions 1.10 Extensiones de Doctrine (timestampable, etc.)
Ramsey UUID 2.0 Generación de UUIDs

1.5.2 4.2 Base de Datos

Tecnología Versión Propósito
MariaDB 10.11 Sistema de gestión de base de datos
Doctrine DBAL 3.x Capa de abstracción de base de datos
Doctrine Migrations 3.3 Gestión de migraciones

1.5.3 4.3 Infraestructura

Tecnología Versión Propósito
Docker Latest Contenedorización
Docker Compose Latest Orquestación de contenedores
Nginx Latest Servidor web / Reverse proxy
PHP-FPM 8.3 Procesador FastCGI
Mercure 0.3.9 Hub de notificaciones en tiempo real

1.5.4 4.4 Testing

Tecnología Versión Propósito
PHPUnit 9.5 Framework de testing
Symfony PHPUnit Bridge 7.0 Integración con Symfony
DAMA Doctrine Test Bundle 8.1 Transacciones de prueba
Zenstruck Foundry 1.37 Factories para testing

1.5.5 4.5 Desarrollo

Tecnología Versión Propósito
Symfony Maker Bundle 1.59 Generación de código
Symfony Web Profiler 6.4 Debugging y profiling
Monolog 3.x Logging
PHPStan Latest Análisis estático

1.6 5. Requisitos del Sistema

1.6.1 5.1 Requisitos de Hardware (Producción)

1.6.2 5.2 Requisitos de Software

1.6.3 5.3 Puertos Requeridos

Puerto Servicio Propósito
8080 Nginx/HTTP API y documentación
3306 MariaDB Base de datos
9000 PHP-FPM Procesador PHP
3000 Mercure WebSocket/SSE

1.7 6. Instalación y Configuración

1.7.1 6.1 Instalación con Docker

1.7.1.1 6.1.1 Clonar el Repositorio

git clone <url-del-repositorio> ogcore
cd ogcore

1.7.1.2 6.1.2 Verificar Puertos Disponibles

Asegúrate de que los puertos 8080 y 3306 no estén en uso:

sudo lsof -i :8080
sudo lsof -i :3306

1.7.1.3 6.1.3 Desplegar Contenedores

docker compose up --build -d

1.7.1.4 6.1.4 Verificar Contenedores

docker ps

Deberías ver tres contenedores activos: - ogcore-nginx - ogcore-php - ogcore-database

1.7.1.5 6.1.5 Instalar Dependencias

docker exec ogcore-php composer install

1.7.1.6 6.1.6 Generar Claves JWT

docker exec ogcore-php php bin/console lexik:jwt:generate-keypair --overwrite

1.7.1.7 6.1.7 Inicializar Base de Datos

# Ejecutar migraciones
docker exec ogcore-php php bin/console doctrine:migrations:migrate --no-interaction

# Cargar datos iniciales (fixtures)
docker exec ogcore-php php bin/console doctrine:fixtures:load --no-interaction

# Cargar grupos de usuarios por defecto
docker exec ogcore-php php bin/console app:load-default-user-groups

# Cargar comandos por defecto
docker exec ogcore-php php bin/console app:load-default-commands

1.7.1.8 6.1.8 Acceder a la Aplicación

Abre tu navegador y accede a:

http://127.0.0.1:8080/docs

Deberías ver la documentación Swagger de la API de ogCore.

1.7.2 6.2 Configuración

1.7.2.1 6.2.1 Variables de Entorno

El archivo .env contiene las variables de configuración principales:

# Entorno
APP_ENV=dev
APP_SECRET=<tu-secreto>

# Base de datos
DATABASE_URL="mysql://user:password@ogcore-database:3306/ogcore"

# JWT
JWT_SECRET_KEY=%kernel.project_dir%/config/jwt/private.pem
JWT_PUBLIC_KEY=%kernel.project_dir%/config/jwt/public.pem
JWT_PASSPHRASE=<tu-passphrase>

# Mercure
MERCURE_URL=http://mercure:3000/.well-known/mercure
MERCURE_PUBLIC_URL=http://127.0.0.1:8080/.well-known/mercure
MERCURE_JWT_SECRET=<tu-secreto-mercure>

# Servicios externos
REMOTE_PC_URL=<url-uds>
REMOTE_PC_AUTH_LOGIN=<login>
REMOTE_PC_AUTH_USERNAME=<username>
REMOTE_PC_AUTH_PASSWORD=<password>

# SSL/TLS
SSL_ENABLED=false

1.7.2.2 6.2.2 Configuración de CORS

Edita config/packages/nelmio_cors.yaml para configurar CORS según tus necesidades.

1.7.2.3 6.2.3 Configuración de API Platform

La configuración de API Platform se encuentra en config/packages/api_platform.yaml.

1.7.3 6.3 Instalación en Producción

Para entornos de producción, utiliza el archivo docker-compose-deploy.yml:

docker compose -f docker-compose-deploy.yml up -d

Asegúrate de: - Cambiar todas las contraseñas por defecto - Configurar SSL/TLS - Configurar backups automáticos de base de datos - Configurar monitoreo y alertas - Revisar los límites de recursos de Docker


1.8 7. Componentes del Sistema

1.8.1 7.1 Controllers (Controladores)

El sistema cuenta con 102 controladores organizados por dominio:

1.8.1.1 Controladores principales:

1.8.2 7.2 States (Procesadores de Estado)

Los States implementan el patrón State de API Platform:

1.8.2.1 States principales (55 procesadores):

1.8.3 7.3 DTOs (Data Transfer Objects)

93 DTOs para transferencia de datos:

1.8.3.1 Tipos de DTOs:

1.8.4 7.4 Validators (Validadores)

18 validadores personalizados para: - Validación de IPs y MACs - Validación de rangos DHCP - Validación de particiones - Validación de imágenes - Validación de comandos - Validación de usuarios

1.8.5 7.5 EventSubscribers (Suscriptores de Eventos)

8 suscriptores para: - Publicación en Mercure al cambiar estados - Limpieza de recursos - Validaciones pre/post persistencia - Logging de eventos

1.8.6 7.6 Factories (Fábricas)

24 factories para testing con Foundry: - Creación de entidades para tests - Datos de prueba realistas - Estados predefinidos


1.9 8. API RESTful

1.9.1 8.1 Documentación

La API está completamente documentada con OpenAPI 3.0 y accesible en:

http://127.0.0.1:8080/docs

1.9.2 8.2 Formato de Respuestas

1.9.2.1 Formato estándar (JSON-LD):

{
  "@context": "/contexts/Client",
  "@id": "/clients/123e4567-e89b-12d3-a456-426614174000",
  "@type": "Client",
  "id": "123e4567-e89b-12d3-a456-426614174000",
  "name": "PC-01",
  "mac": "00:11:22:33:44:55",
  "ip": "192.168.1.100",
  "status": "active"
}

1.9.2.2 Formato alternativo (JSON):

{
  "id": "123e4567-e89b-12d3-a456-426614174000",
  "name": "PC-01",
  "mac": "00:11:22:33:44:55",
  "ip": "192.168.1.100",
  "status": "active"
}

1.9.3 8.3 Paginación

Todas las colecciones soportan paginación:

GET /clients?page=1&itemsPerPage=30

Respuesta:

{
  "@context": "/contexts/Client",
  "@id": "/clients",
  "@type": "hydra:Collection",
  "hydra:member": [...],
  "hydra:totalItems": 150,
  "hydra:view": {
    "@id": "/clients?page=1",
    "@type": "hydra:PartialCollectionView",
    "hydra:first": "/clients?page=1",
    "hydra:last": "/clients?page=5",
    "hydra:next": "/clients?page=2"
  }
}

1.9.4 8.4 Filtrado

Soporta filtros avanzados:

GET /clients?status=active
GET /clients?organizationalUnit.name=Aula1
GET /traces?client.id=123&status=pending

1.9.5 8.5 Ordenamiento

GET /clients?order[name]=asc
GET /traces?order[createdAt]=desc

1.9.6 8.6 Endpoints Principales

1.9.6.1 9.6.1 Autenticación

POST /auth/login
POST /auth/refresh

1.9.6.2 9.6.2 Clientes

GET    /clients
POST   /clients
GET    /clients/{id}
PUT    /clients/{id}
PATCH  /clients/{id}
DELETE /clients/{id}
POST   /clients/batch
POST   /clients/{id}/power-on
POST   /clients/{id}/power-off
POST   /clients/{id}/reboot

1.9.6.3 9.6.3 Imágenes

GET    /images
POST   /images
GET    /images/{id}
PUT    /images/{id}
DELETE /images/{id}
POST   /images/{id}/deploy
POST   /images/{id}/create
POST   /images/{id}/backup

1.9.6.4 9.6.4 Comandos y Tareas

GET    /commands
POST   /commands
GET    /command-tasks
POST   /command-tasks
PUT    /command-tasks/{id}
DELETE /command-tasks/{id}

1.9.6.5 9.6.5 Trazas

GET    /traces
GET    /traces/{id}
PUT    /traces/{id}
PATCH  /traces/{id}/complete
PATCH  /traces/{id}/cancel

1.9.7 8.7 Códigos de Estado HTTP

Código Significado
200 OK - Operación exitosa
201 Created - Recurso creado
204 No Content - Eliminación exitosa
400 Bad Request - Datos inválidos
401 Unauthorized - No autenticado
403 Forbidden - Sin permisos
404 Not Found - Recurso no encontrado
409 Conflict - Conflicto (cliente ocupado, constraint violation)
422 Unprocessable Entity - Validación fallida
500 Internal Server Error - Error del servidor

1.10 9. Seguridad y Autenticación

1.10.1 9.1 Sistema de Autenticación JWT

ogCore utiliza JSON Web Tokens (JWT) para autenticación:

1.10.1.1 10.1.1 Obtener Token

POST /auth/login
Content-Type: application/json

{
  "username": "admin",
  "password": "password"
}

Respuesta:

{
  "token": "eyJ0eXAiOiJKV1QiLCJhbGc...",
  "refresh_token": "def50200a54b7b..."
}

1.10.1.2 10.1.2 Usar Token

Incluir el token en el header Authorization:

GET /clients
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGc...

1.10.1.3 10.1.3 Refresh Token

POST /auth/refresh
Content-Type: application/json

{
  "refresh_token": "def50200a54b7b..."
}

1.10.2 9.2 Control de Acceso

1.10.2.1 Rutas Públicas:

1.10.2.2 Rutas Protegidas:

1.10.3 9.3 Roles de Usuario

Los roles se gestionan en la entidad User:

$user->setRoles(['ROLE_USER']);
$user->setRoles(['ROLE_ADMIN']);

1.10.4 9.4 Seguridad de Contraseñas

1.10.5 9.5 CORS (Cross-Origin Resource Sharing)

Configurado en nelmio_cors.yaml para permitir acceso desde frontend.

1.10.6 9.6 SSL/TLS

Para producción, habilitar SSL:

SSL_ENABLED=true

Configurar certificados en /certs/.


1.11 10. Servicios Principales

1.11.1 10.1 CreatePartitionService

Propósito: Crear y actualizar particiones de clientes.

Funcionalidad: - Recibe información de particiones del agente - Crea/actualiza particiones en base de datos - Detecta tipo de firmware (BIOS/UEFI) - Calcula códigos de partición

1.11.2 10.2 CreateTraceService

Propósito: Crear trazas de ejecución para tareas programadas.

Funcionalidad: - Genera trazas para cada combinación cliente-comando - Gestiona comandos agrupados - Establece estado inicial y fecha de ejecución

1.11.3 10.3 ChangeClientNetworkSettingsService

Propósito: Cambiar configuración de red de clientes.

Funcionalidad: - Actualiza subnet, IP, configuración de red - Sincroniza con servicios externos (DHCP)

1.11.4 10.4 ExternalGitRepositoryService

Propósito: Gestión de repositorios Git para imágenes.

Funcionalidad: - Backup de imágenes a Git - Versionado de imágenes - Sincronización con repositorios remotos

1.11.5 10.5 StatusService (OgBoot/OgDhcp/OgRepository)

Propósito: Verificar estado de servicios externos.

Funcionalidad: - Health checks de servicios - Manejo de errores de conexión - Logging de estado

1.11.6 10.6 UDSClient

Propósito: Integración con UDS (Universal Desktop Services).

Funcionalidad: - Autenticación con UDS - Obtención de service pools - Cálculo de asientos disponibles - Gestión de calendarios remotos

1.11.7 10.7 Trace/CreateService

Propósito: Servicio especializado para creación de trazas.

Funcionalidad: - Validación de parámetros de entrada - Creación de trazas individuales o masivas

1.11.8 10.8 Utils/GetPartitionCodeService

Propósito: Obtener código de partición según tipo y filesystem.

1.11.9 10.9 Utils/SimplifyOgLiveFilenameService

Propósito: Simplificar nombres de archivos OgLive para mostrar al usuario.

1.11.10 10.10 Utils/GetIpAddressAndNetmaskFromCIDRService

Propósito: Convertir notación CIDR a IP y máscara de red.


1.12 11. Comandos de Consola

ogCore incluye 18 comandos de consola para tareas administrativas:

1.12.1 11.1 Comandos de Inicialización

1.12.1.1 12.1.1 Cargar Grupos de Usuario por Defecto

php bin/console app:load-default-user-groups

Crea los grupos de usuarios predeterminados del sistema.

1.12.1.2 12.1.2 Cargar Comandos por Defecto

php bin/console app:load-default-commands

Carga los comandos básicos del sistema.

1.12.1.3 12.1.3 Cargar Usuario Admin

php bin/console app:load-default-user-admin

Crea el usuario administrador por defecto.

1.12.1.4 12.1.4 Cargar Menú por Defecto

php bin/console app:load-default-menu

Carga menús de arranque predeterminados.

1.12.1.5 12.1.5 Cargar Tipos de Hardware

php bin/console app:load-hardware-types

Inicializa la tabla de tipos de hardware.

1.12.1.6 12.1.6 Cargar Unidad Organizativa por Defecto

php bin/console app:load-organizational-unit-default

Crea la unidad organizativa raíz.

1.12.2 11.2 Comandos de Operación

1.12.2.1 12.2.1 Verificar Disponibilidad de Clientes

php bin/console app:check-client-availability

Ejecución: Cada 1 minuto (cron)

Verifica el estado de conectividad de los clientes y actualiza su estado si no responden en un tiempo determinado.

1.12.2.2 12.2.2 Ejecutar Trazas Pendientes

php bin/console app:execute-pending-traces

Ejecución: Cada 1 minuto (cron)

Procesa las trazas en estado PENDING y las ejecuta en los clientes correspondientes.

1.12.2.3 12.2.3 Ejecutar Tareas Programadas

php bin/console app:run-scheduled-command-tasks

Ejecución: Cada 1 minuto (cron)

Ejecuta tareas programadas que han llegado a su hora de ejecución.

1.12.3 11.3 Comandos de Migración

Comandos para migrar datos desde OpenGnsys 1.1:

1.12.3.1 12.3.1 Migrar Unidades Organizativas

php bin/console opengnsys:migration:organizational-unit

1.12.3.2 12.3.2 Migrar Perfiles de Hardware

php bin/console opengnsys:migration:hardware-profile

1.12.3.3 12.3.3 Migrar Clientes

php bin/console opengnsys:migration:clients

1.12.3.4 12.3.4 Migrar Sistemas Operativos

php bin/console opengnsys:migration:os

1.12.3.5 12.3.5 Migrar Imágenes

php bin/console opengnsys:migration:image

1.12.3.6 12.3.6 Migrar Perfiles de Software

php bin/console opengnsys:migration:software-profile

1.12.3.7 12.3.7 Migrar Particiones de Clientes

php bin/console opengnsys:migration:partition-client

1.12.4 11.4 Comandos de Desarrollo

1.12.4.1 12.4.1 Crear Repositorios de Imágenes

php bin/console app:create-image-repositories

Crea repositorios de imágenes para desarrollo/testing.

1.12.4.2 12.4.2 Cargar Trazas de Ejemplo

php bin/console app:charge-example-trace

Carga trazas de ejemplo para testing.

1.12.5 11.5 Configuración de Cron

Agregar al crontab:

* * * * * docker exec ogcore-php php bin/console app:check-client-availability
* * * * * docker exec ogcore-php php bin/console app:execute-pending-traces
* * * * * docker exec ogcore-php php bin/console app:run-scheduled-command-tasks

1.13 12. Migraciones de Datos

1.13.1 12.1 Sistema de Migraciones de Doctrine

ogCore utiliza Doctrine Migrations para gestionar cambios en el esquema de base de datos.

1.13.1.1 13.1.1 Crear una Migración

docker exec ogcore-php php bin/console make:migration

1.13.1.2 13.1.2 Ejecutar Migraciones

docker exec ogcore-php php bin/console doctrine:migrations:migrate

1.13.1.3 13.1.3 Ver Estado de Migraciones

docker exec ogcore-php php bin/console doctrine:migrations:status

1.13.1.4 13.1.4 Revertir Migración

docker exec ogcore-php php bin/console doctrine:migrations:migrate prev

1.13.2 12.2 Migración desde OpenGnsys 1.1

Para migrar datos desde una instalación de OpenGnsys 1.1:

1.13.2.1 13.2.1 Crear Base de Datos Temporal

docker exec ogcore-php php bin/console doctrine:database:create --connection=og_1

1.13.2.2 13.2.2 Cargar Dump de OpenGnsys 1.1

docker exec -i ogcore-database mysql -u user -p ogcore_old_og < dump_og_1.1.sql

1.13.2.3 13.2.3 Ejecutar Migraciones

Ejecutar los comandos de migración en orden:

docker exec ogcore-php php bin/console opengnsys:migration:organizational-unit
docker exec ogcore-php php bin/console opengnsys:migration:hardware-profile
docker exec ogcore-php php bin/console opengnsys:migration:clients
docker exec ogcore-php php bin/console opengnsys:migration:os
docker exec ogcore-php php bin/console opengnsys:migration:image
docker exec ogcore-php php bin/console opengnsys:migration:software-profile

1.13.3 12.3 Backup y Restauración

1.13.3.1 13.3.1 Backup de Base de Datos

docker exec ogcore-database mysqldump -u user -p ogcore > backup_$(date +%Y%m%d).sql

1.13.3.2 13.3.2 Restaurar Base de Datos

docker exec -i ogcore-database mysql -u user -p ogcore < backup_20251008.sql

1.14 13. Testing

1.14.1 13.1 Framework de Testing

ogCore utiliza PHPUnit con integración de Symfony y Doctrine.

1.14.2 13.2 Ejecutar Tests

1.14.2.1 14.2.1 Todos los Tests

docker compose exec php bin/phpunit

1.14.2.2 14.2.2 Tests Específicos

docker compose exec php bin/phpunit tests/Functional/ClientTest.php

1.14.2.3 14.2.3 Tests con Coverage

docker compose exec php bin/phpunit --coverage-html coverage/

1.14.3 13.3 Tipos de Tests

1.14.3.1 14.3.1 Tests Funcionales

Ubicación: tests/Functional/

20 archivos de tests funcionales que prueban: - Endpoints de API - Flujos completos - Integraciones

Ejemplo:

public function testCreateClient(): void
{
    $client = static::createClient();
    $client->request('POST', '/clients', [
        'json' => [
            'name' => 'Test Client',
            'mac' => '00:11:22:33:44:55',
            'ip' => '192.168.1.100'
        ]
    ]);
    
    $this->assertResponseStatusCodeSame(201);
}

1.14.4 13.4 Factories para Testing

Se utilizan Zenstruck Foundry factories (24 factories) para crear datos de prueba:

ClientFactory::createOne([
    'name' => 'Test PC',
    'status' => 'active'
]);

1.14.5 13.5 Base de Datos de Testing

Los tests utilizan DAMA Doctrine Test Bundle para: - Ejecutar cada test en una transacción - Rollback automático después de cada test - Aislamiento completo entre tests


1.15 14. Despliegue

1.15.1 14.1 Despliegue con Docker Compose

1.15.1.1 15.1.1 Desarrollo

docker compose up -d

1.15.1.2 15.1.2 Producción

docker compose -f docker-compose-deploy.yml up -d

1.15.2 14.2 Despliegue con Jenkins

El proyecto incluye Jenkinsfile para CI/CD.

1.15.2.1 Pipeline stages:

  1. Checkout: Clonar repositorio
  2. Build: Construir imagen Docker
  3. Test: Ejecutar tests
  4. Package: Crear paquete Debian
  5. Deploy: Desplegar en servidor

1.15.3 14.3 Paquete Debian

El proyecto puede empaquetarse como .deb:

./package.sh

Estructura del paquete en debian/: - Control files - Postinst/preinst scripts - Systemd service file - Configuración

1.15.4 14.4 Configuración de Producción

1.15.4.1 15.4.1 Variables de Entorno

Crear .env.local con configuración de producción:

APP_ENV=prod
APP_DEBUG=0
DATABASE_URL="mysql://user:pass@localhost:3306/ogcore"
# ... más configuración

1.15.4.2 15.4.2 Optimizaciones

# Limpiar caché
docker exec ogcore-php php bin/console cache:clear --env=prod

# Calentar caché
docker exec ogcore-php php bin/console cache:warmup --env=prod

# Optimizar autoloader
docker exec ogcore-php composer dump-autoload --optimize --classmap-authoritative

1.15.5 14.5 Monitoreo

1.15.5.1 15.5.1 Logs

Logs ubicados en var/log/: - dev.log / prod.log: Logs de aplicación - nginx/access.log: Accesos a nginx - nginx/error.log: Errores de nginx

1.15.5.2 15.5.2 Syslog

Los logs también se envían a syslog para centralización.

1.15.6 14.6 Escalabilidad

Para escalar horizontalmente:

  1. Base de datos: Usar MariaDB con replicación master-slave
  2. PHP: Aumentar réplicas de contenedor PHP
  3. Load Balancer: Usar nginx como balanceador de carga
  4. Caché: Implementar Redis para sesiones y caché
  5. Mercure: Escalar hub de Mercure

1.16 15. Mantenimiento y Operaciones

1.16.1 15.1 Reiniciar Base de Datos

docker exec ogcore-php php bin/console doctrine:database:drop --force
docker exec ogcore-php php bin/console doctrine:database:create
docker exec ogcore-php php bin/console doctrine:migrations:migrate --no-interaction
docker exec ogcore-php php bin/console doctrine:fixtures:load --no-interaction

1.16.2 15.2 Limpiar Caché

docker exec ogcore-php php bin/console cache:clear
docker exec ogcore-php php bin/console cache:warmup

1.16.3 15.3 Actualizar Dependencias

docker exec ogcore-php composer update

1.16.4 15.4 Regenerar Claves JWT

docker exec ogcore-php php bin/console lexik:jwt:generate-keypair --overwrite

1.16.5 15.5 Backups Automáticos

Script ejemplo para backup automático:

#!/bin/bash
DATE=$(date +%Y%m%d_%H%M%S)
BACKUP_DIR="/backups"

# Backup de base de datos
docker exec ogcore-database mysqldump -u user -p password ogcore > $BACKUP_DIR/db_$DATE.sql

# Backup de archivos
tar -czf $BACKUP_DIR/files_$DATE.tar.gz /var/www/html/ogcore/var

# Limpiar backups antiguos (>30 días)
find $BACKUP_DIR -name "*.sql" -mtime +30 -delete
find $BACKUP_DIR -name "*.tar.gz" -mtime +30 -delete

1.16.6 15.6 Monitoreo de Salud

1.16.6.1 Health Check Endpoint

GET /health

1.16.6.2 Verificar Estado de Servicios

# PHP
docker exec ogcore-php php -v

# Nginx
docker exec ogcore-nginx nginx -t

# MariaDB
docker exec ogcore-database mysqladmin -u user -p status

1.16.7 15.7 Rotación de Logs

Configurar logrotate:

/var/www/html/ogcore/var/log/*.log {
    daily
    rotate 14
    compress
    delaycompress
    notifempty
    create 0640 www-data www-data
    sharedscripts
}

1.17 16. Integración con Otros Servicios

1.17.1 16.1 ogRepository

Propósito: Gestión de repositorios de imágenes.

Endpoints integrados: - Crear imagen - Desplegar imagen - Backup imagen - Eliminar imagen - Convertir a imagen virtual - Importar imagen externa - Verificar integridad - Imagen global

Webhook: /og-repository/webhook

1.17.2 16.2 ogDhcp

Propósito: Gestión de DHCP dinámico.

Funcionalidades: - Agregar clientes a DHCP - Eliminar clientes de DHCP - Actualizar configuración - Gestión de subredes

1.17.3 16.3 ogBoot

Propósito: Gestión de archivos de arranque PXE.

Funcionalidades: - Crear archivos de arranque - Actualizar plantillas PXE - Eliminar configuraciones - Sincronización de menús

1.17.4 16.4 ogAgent

Propósito: Agente instalado en clientes para ejecutar comandos.

Operaciones: - Power on/off/reboot - Crear/desplegar imágenes - Particionar discos - Ejecutar scripts - Obtener inventario hardware - Verificar tamaño de particiones - Kill jobs

1.17.5 16.5 UDS (Universal Desktop Services)

Propósito: Integración con sistema de escritorios remotos.

Funcionalidades: - Autenticación - Obtener service pools - Calcular disponibilidad - Gestión de reservas

1.17.6 16.6 Git (Versionado de Imágenes)

Propósito: Versionado de imágenes con Git.

Funcionalidades: - Backup a repositorio Git - Versionado automático - Recuperación de versiones - Sincronización

1.17.7 16.7 Mercure (Notificaciones en Tiempo Real)

Propósito: Notificaciones push en tiempo real.

Eventos publicados: - Cambio de estado de clientes - Actualización de trazas - Cambios en comandos - Alertas y notificaciones

Suscripción del cliente:

const eventSource = new EventSource('http://localhost:8080/.well-known/mercure?topic=/clients/{id}');
eventSource.onmessage = event => {
    const data = JSON.parse(event.data);
    console.log('Client updated:', data);
};

1.18 17. Roadmap y Changelog

1.18.1 17.1 Versión Actual: 0.5.0

1.18.2 17.2 Últimas Características (v0.25.1 - Octubre 2025)

1.18.3 17.3 Próximas Características (Roadmap)

1.18.3.1 v0.6.0 (Q4 2025)

1.18.3.2 v0.7.0 (Q1 2026)

1.18.3.3 v1.0.0 (Q2 2026)

1.18.4 17.4 Changelog Resumido

Ver CHANGELOG.md para el historial completo de cambios.

Versiones destacadas:


1.19 18. Contribución

1.19.1 18.1 Guía de Contribución

Para contribuir al proyecto:

  1. Fork el repositorio
  2. Crea una rama para tu feature: git checkout -b feature/nueva-funcionalidad
  3. Commit tus cambios: git commit -am 'Añade nueva funcionalidad'
  4. Push a la rama: git push origin feature/nueva-funcionalidad
  5. Crea un Pull Request

1.19.2 18.2 Estándares de Código

1.19.3 18.3 Proceso de Revisión

  1. CI/CD ejecuta tests automáticamente
  2. Revisión de código por maintainers
  3. Aprobación requerida antes de merge
  4. Merge a rama develop
  5. Release periódicos a main

1.19.4 18.4 Reportar Bugs

Usar el sistema de Issues del repositorio:

Template de Bug:

**Descripción del bug**
Descripción clara y concisa del bug.

**Pasos para reproducir**
1. Ir a '...'
2. Hacer clic en '...'
3. Ver error

**Comportamiento esperado**
Lo que esperabas que sucediera.

**Screenshots**
Si aplica, añadir screenshots.

**Entorno**
- OS: [ej. Ubuntu 22.04]
- Versión: [ej. 0.5.0]
- Browser: [ej. Firefox 118]

1.20 19. Soporte y Contacto

1.20.1 19.1 Documentación Adicional

1.20.2 19.2 Recursos

1.20.3 19.3 Equipo de Desarrollo

Proyecto desarrollado por el equipo de OpenGnsys en colaboración con universidades participantes.

1.20.4 19.4 Licencia

Proyecto propietario. Ver archivo LICENSE para más información.


1.21 Apéndices

1.21.1 Apéndice A: Glosario de Términos

1.21.2 Apéndice B: Puertos y Servicios

Puerto Servicio Protocolo Descripción
8080 nginx HTTP API y docs
3306 MariaDB MySQL Base de datos
9000 PHP-FPM FastCGI Procesador PHP
3000 Mercure HTTP/SSE Notificaciones

1.21.3 Apéndice C: Estructura de Directorios

ogcore/
|-- bin/              # Ejecutables (console, phpunit)
|-- config/           # Configuración de Symfony
|   |-- api_platform/ # Configuración de entidades API
|   |-- packages/     # Configuración de bundles
|   +-- routes/       # Rutas
|-- migrations/       # Migraciones de base de datos
|-- public/           # Punto de entrada web
|-- src/              # Código fuente
|   |-- Command/      # Comandos de consola
|   |-- Controller/   # Controladores
|   |-- Dto/          # Data Transfer Objects
|   |-- Entity/       # Entidades Doctrine
|   |-- EventListener/# Event Listeners
|   |-- EventSubscriber/ # Event Subscribers
|   |-- Factory/      # Factories para testing
|   |-- Filter/       # Filtros de API Platform
|   |-- Repository/   # Repositorios Doctrine
|   |-- Security/     # Seguridad y autenticación
|   |-- Service/      # Servicios de negocio
|   |-- State/        # States de API Platform
|   +-- Validator/    # Validadores personalizados
|-- tests/            # Tests
|-- translations/     # Traducciones
|-- var/              # Archivos variables (cache, logs)
+-- vendor/           # Dependencias

1.21.4 Apéndice D: Variables de Entorno Completas

Ver archivo .env para todas las variables de entorno disponibles.


Fecha de actualización: Octubre 2025
Versión del documento: 1.0
Mantenedor: Equipo OpenGnsys