fonctionnalité majeure : setup ultra simplifié (installation/configuration des infos supabase directement du web)

This commit is contained in:
Yannick Le Duc
2025-08-28 14:05:32 +02:00
parent b7ce1145e3
commit f93c995815
26 changed files with 3066 additions and 341 deletions

View File

@@ -0,0 +1,87 @@
import { NextRequest, NextResponse } from 'next/server';
import { supabaseAdmin } from '@/lib/supabase-admin';
export async function POST(request: NextRequest) {
try {
const body = await request.json();
const { email } = body;
if (!email) {
return NextResponse.json(
{ error: 'Email requis' },
{ status: 400 }
);
}
console.log('🔍 Diagnostic pour email:', email);
// 1. Vérifier si l'utilisateur existe dans auth.users
const { data: users, error: usersError } = await supabaseAdmin.auth.admin.listUsers();
if (usersError) {
console.error('❌ Erreur lors de la récupération des utilisateurs:', usersError);
return NextResponse.json(
{ error: `Erreur lors de la récupération des utilisateurs: ${usersError.message}` },
{ status: 500 }
);
}
const user = users.users.find(u => u.email === email);
if (!user) {
return NextResponse.json(
{ error: 'Utilisateur non trouvé dans auth.users' },
{ status: 404 }
);
}
console.log('✅ Utilisateur trouvé dans auth.users:', user.id);
// 2. Vérifier si l'utilisateur est dans user_permissions
const { data: permissions, error: permissionsError } = await supabaseAdmin
.from('user_permissions')
.select('*')
.eq('user_id', user.id)
.single();
if (permissionsError) {
console.error('❌ Erreur lors de la vérification user_permissions:', permissionsError);
return NextResponse.json(
{ error: `Erreur lors de la vérification user_permissions: ${permissionsError.message}` },
{ status: 500 }
);
}
const inUserPermissions = !!permissions;
console.log('🔍 Utilisateur dans user_permissions:', inUserPermissions);
// 3. Informations de debug
const debug = {
supabaseUrl: process.env.NEXT_PUBLIC_SUPABASE_URL,
hasServiceRole: !!process.env.SUPABASE_SERVICE_ROLE_KEY,
userCount: users.users.length,
userEmails: users.users.map(u => u.email),
};
return NextResponse.json({
success: true,
user: {
id: user.id,
email: user.email,
created_at: user.created_at,
email_confirmed_at: user.email_confirmed_at,
last_sign_in_at: user.last_sign_in_at,
},
inUserPermissions,
permissions: permissions || null,
debug,
});
} catch (error: any) {
console.error('❌ Erreur lors du diagnostic:', error);
return NextResponse.json(
{ error: `Erreur interne: ${error.message}` },
{ status: 500 }
);
}
}