mirror of
https://github.com/marcogll/AnchorOS.git
synced 2026-03-15 18:24:31 +00:00
🚀 FASE 4 COMPLETADO: Comentarios auditables + Calendario funcional + Gestión staff/recursos
✅ COMENTARIOS AUDITABLES IMPLEMENTADOS: - 80+ archivos con JSDoc completo para auditoría manual - APIs críticas con validaciones business/security/performance - Componentes con reglas de negocio documentadas - Funciones core con edge cases y validaciones ✅ CALENDARIO MULTI-COLUMNA FUNCIONAL (95%): - Drag & drop con reprogramación automática - Filtros por sucursal/staff, tiempo real - Indicadores de conflictos y disponibilidad - APIs completas con validaciones de colisión ✅ GESTIÓN OPERATIVA COMPLETA: - CRUD staff: APIs + componente con validaciones - CRUD recursos: APIs + componente con disponibilidad - Autenticación completa con middleware seguro - Auditoría completa en todas las operaciones ✅ DOCUMENTACIÓN ACTUALIZADA: - TASKS.md: FASE 4 95% completado - README.md: Estado actual y funcionalidades - API.md: 40+ endpoints documentados ✅ SEGURIDAD Y VALIDACIONES: - RLS policies documentadas en comentarios - Business rules validadas manualmente - Performance optimizations anotadas - Error handling completo Próximos: Nómina/POS/CRM avanzado (FASE 4 final)
This commit is contained in:
68
scripts/check-staff-records.js
Normal file
68
scripts/check-staff-records.js
Normal file
@@ -0,0 +1,68 @@
|
||||
/**
|
||||
* Check Staff Records Script
|
||||
*
|
||||
* This script checks which staff records exist for the admin user
|
||||
*/
|
||||
|
||||
const { createClient } = require('@supabase/supabase-js');
|
||||
require('dotenv').config();
|
||||
|
||||
const SUPABASE_URL = process.env.SUPABASE_URL;
|
||||
const SUPABASE_SERVICE_ROLE_KEY = process.env.SUPABASE_SERVICE_ROLE_KEY;
|
||||
|
||||
const supabase = createClient(SUPABASE_URL, SUPABASE_SERVICE_ROLE_KEY);
|
||||
|
||||
async function checkStaffRecords() {
|
||||
console.log('🔍 Checking staff records...\n');
|
||||
|
||||
try {
|
||||
// 1. Get admin user from auth.users
|
||||
const { data: { users }, error: usersError } = await supabase.auth.admin.listUsers();
|
||||
|
||||
if (usersError) {
|
||||
console.error('❌ Error fetching auth.users:', usersError);
|
||||
return;
|
||||
}
|
||||
|
||||
const adminUser = users.find(u => u.email === 'marco.gallegos@anchor23.mx');
|
||||
|
||||
if (!adminUser) {
|
||||
console.error('❌ No admin user found in auth.users');
|
||||
return;
|
||||
}
|
||||
|
||||
console.log('✅ Found admin user in auth.users:');
|
||||
console.log(` Email: ${adminUser.email}`);
|
||||
console.log(` ID: ${adminUser.id}\n`);
|
||||
|
||||
// 2. Check which staff records exist with this user_id
|
||||
const { data: staffRecords, error: staffError } = await supabase
|
||||
.from('staff')
|
||||
.select('*')
|
||||
.eq('user_id', adminUser.id);
|
||||
|
||||
if (staffError) {
|
||||
console.error('❌ Error fetching staff records:', staffError);
|
||||
return;
|
||||
}
|
||||
|
||||
if (staffRecords.length > 0) {
|
||||
console.log(`✅ Found ${staffRecords.length} staff records with user_id = ${adminUser.id}:`);
|
||||
staffRecords.forEach((staff, index) => {
|
||||
console.log(` ${index + 1}. ${staff.display_name} (${staff.role})`);
|
||||
console.log(` Location ID: ${staff.location_id}`);
|
||||
console.log(` Active: ${staff.is_active}`);
|
||||
});
|
||||
console.log('\n✅ Admin user already has valid staff records!');
|
||||
console.log(' No fix needed.\n');
|
||||
} else {
|
||||
console.log('❌ No staff records found with user_id = ${adminUser.id}');
|
||||
console.log(' This is the problem - admin user has no staff record!\n');
|
||||
}
|
||||
|
||||
} catch (error) {
|
||||
console.error('❌ Unexpected error:', error);
|
||||
}
|
||||
}
|
||||
|
||||
checkStaffRecords();
|
||||
Reference in New Issue
Block a user