mirror of
https://github.com/marcogll/AnchorOS.git
synced 2026-03-15 10:24:26 +00:00
6.7 KiB
6.7 KiB
Sistema de Kiosko - AnchorOS
Resumen
El sistema de kiosko permite a los clientes interactuar con el salón mediante pantallas táctiles en la entrada, facilitando la confirmación de citas y la creación de reservas walk-in sin necesidad de personal.
Características
1. Confirmación de Citas
- Los clientes pueden confirmar su llegada ingresando el código de 6 caracteres (short_id) de su cita
- Verificación de estado de la cita (pending → confirmed)
- Visualización de detalles limitados (sin PII)
2. Reservas Walk-in
- Creación de reservas inmediatas para clientes sin cita previa
- Asignación automática de recursos con prioridad
- Selección de servicios disponibles
- Registro de datos básicos del cliente
3. Asignación de Recursos con Prioridad
- Prioridad 1 (Alta): Estaciones (stations)
- Prioridad 2 (Media): Salas (rooms)
- Prioridad 3 (Baja): Equipo (equipment)
Arquitectura
Base de Datos
Nueva Tabla: kiosks
CREATE TABLE kiosks (
id UUID PRIMARY KEY,
location_id UUID REFERENCES locations(id),
device_name VARCHAR(100) UNIQUE,
display_name VARCHAR(100),
API key VARCHAR(64) UNIQUE,
ip_address INET,
is_active BOOLEAN DEFAULT true,
created_at TIMESTAMPTZ,
updated_at TIMESTAMPTZ
);
Nuevo Rol: 'kiosk'
Agregado al enum user_role para manejar permisos específicos.
API Routes
Autenticación
POST /api/kiosk/authenticate- Valida API key y devuelve información del kiosko
Bookings
GET /api/kiosk/bookings?short_id={id}- Busca booking por short_idGET /api/kiosk/bookings?date={date}- Lista bookings de una fechaPOST /api/kiosk/bookings- Crea nuevo bookingPOST /api/kiosk/bookings/{shortId}/confirm- Confirma booking (pending → confirmed)
Recursos
GET /api/kiosk/resources/available?start_time={...}&end_time={...}- Lista recursos disponibles con prioridad
Walk-in
POST /api/kiosk/walkin- Crea reserva walk-in inmediata
Componentes UI
BookingConfirmation- Flujo para confirmar citas existentesWalkInFlow- Flujo completo para crear reservas walk-inResourceAssignment- Muestra recursos disponibles con prioridad
Seguridad
Autenticación
- Basada en API key (64 caracteres aleatorios)
- Validación en cada request vía header
x-kiosk-api-key
Permisos RLS
El Kiosko PUEDE:
- Ver bookings de su location (solo: short_id, start_time, status)
- Crear bookings walk-in (clientes sin pre-reserva)
- Confirmar bookings existentes (solo cambiar status → confirmed)
- Ver/consultar resources disponibles de su location
- Ver services activos
- Ver datos básicos de su location
El Kiosko NO PUEDE:
- Ver datos sensibles del cliente (PII)
- Ver bookings de otras locations
- Modificar bookings existentes (solo status → confirmed)
- Cancelar bookings
- Ver datos de otros kioskos
Instalación
1. Ejecutar Migración SQL
# En Supabase SQL Editor o via CLI
psql -h <your-host> -U <your-user> -d <your-db> -f supabase/migrations/20260116000000_add_kiosk_system.sql
2. Configurar Variables de Entorno
NEXT_PUBLIC_KIOSK_API_KEY=your-kiosk-api-key-here
3. Crear Kioskos
SELECT create_kiosk(
'<location-id>',
'kiosk-entrance-1',
'Kiosko Entrada Principal',
'192.168.1.100'::INET
);
IMPORTANTE: Guarda la API key generada de forma segura. Solo se muestra una vez.
Uso
Iniciar Kiosko
- Navega a
/kiosk/{locationId}en tu navegador - El kiosko se autentica automáticamente usando la API key configurada
- Verás la pantalla principal con dos opciones:
- Confirmar Cita - Para clientes con cita previa
- Reserva Inmediata - Para clientes sin cita (walk-in)
Flujo de Confirmación de Cita
- El cliente ingresa el código de 6 caracteres de su cita
- El sistema busca el booking
- Si existe y está en estado
pending, muestra los detalles - El cliente confirma su llegada
- El status cambia a
confirmed - Se muestra confirmación visual
Flujo de Walk-in
- Seleccionar servicio disponible
- Ingresar datos del cliente (nombre, email, teléfono opcional)
- Verificar disponibilidad de recursos
- Confirmar reserva
- El sistema asigna automáticamente:
- Artista disponible (prioridad: staff → manager → artist)
- Recurso disponible con mayor prioridad
- Se muestra código de reserva (short_id)
Prioridad de Asignación de Recursos
La función get_available_resources_with_priority() ordena recursos por:
- Tipo (station > room > equipment)
- Nombre (alfabético)
Esto asegura que los kioskos siempre asignen la mejor opción disponible.
API Key Management
Generar Nueva API Key
-- Para un kiosko existente (no soportado directamente)
-- Debes crear un nuevo kiosko y borrar el antiguo
DELETE FROM kiosks WHERE id = '<old-kiosk-id>';
SELECT create_kiosk(
'<location-id>',
'kiosk-new',
'Nuevo Kiosko',
NULL
);
Validar API Key en Frontend
const response = await fetch('/api/kiosk/authenticate', {
method: 'POST',
headers: { 'Content-Type': 'application/json' },
body: JSON.stringify({
api_key: process.env.NEXT_PUBLIC_KIOSK_API_KEY
})
})
Monitoreo y Auditoría
Audit Logs
Todas las acciones del kiosko se registran en audit_logs con:
performed_by_role = 'kiosk'entity_type = 'bookings'u otrosaction = 'create' | 'update' | 'status_change'
Consultas Útiles
-- Ver kioskos activos
SELECT device_name, display_name, ip_address, location_id
FROM kiosks
WHERE is_active = true;
-- Ver bookings creados por kiosko hoy
SELECT * FROM bookings
WHERE DATE(created_at) = CURRENT_DATE
AND metadata @> '{"source": "kiosk"}';
-- Ver confirmaciones de kiosko
SELECT * FROM audit_logs
WHERE performed_by_role = 'kiosk'
AND action = 'status_change'
AND created_at >= NOW() - INTERVAL '1 hour';
Troubleshooting
Error: "Invalid API key"
- Verifica que la API key esté configurada en
.env - Verifica que el kiosko exista y esté activo en la base de datos
- Revisa los logs del servidor
Error: "No resources available"
- Verifica que hay recursos activos en la location
- Revisa los horarios de los bookings existentes
- Asegúrate de que el service_id es válido
Error: "Booking not found in kiosk location"
- Verifica que el short_id es correcto
- Confirma que el booking pertenece a la location del kiosko
Mejoras Futuras
- Soporte para múltiples idiomas
- Integración con pagos en el kiosko
- Sistema de notificaciones al confirmar cita
- Modo mantenimiento para kioskos individuales
- Reportes de uso de kioskos
- Soporte para escanear QR codes en lugar de ingresar short_id
- Sincronización offline
- Soporte para devices móviles (tablets)