fonctionnalité majeure : setup ultra simplifié (installation/configuration des infos supabase directement du web)
This commit is contained in:
92
src/app/api/fix-admin/route.ts
Normal file
92
src/app/api/fix-admin/route.ts
Normal file
@@ -0,0 +1,92 @@
|
||||
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('🔧 Réparation admin pour email:', email);
|
||||
|
||||
// 1. Récupérer l'utilisateur depuis 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é:', user.id, user.email);
|
||||
|
||||
// 2. Supprimer l'utilisateur de user_permissions s'il existe
|
||||
const { error: deleteError } = await supabaseAdmin
|
||||
.from('user_permissions')
|
||||
.delete()
|
||||
.eq('user_id', user.id);
|
||||
|
||||
if (deleteError) {
|
||||
console.warn('⚠️ Erreur lors de la suppression (peut être normal):', deleteError.message);
|
||||
} else {
|
||||
console.log('🗑️ Utilisateur supprimé de user_permissions');
|
||||
}
|
||||
|
||||
// 3. Réinsérer l'utilisateur dans user_permissions
|
||||
const { data: permissionsData, error: insertError } = await supabaseAdmin
|
||||
.from('user_permissions')
|
||||
.insert({
|
||||
user_id: user.id,
|
||||
is_admin: true,
|
||||
is_super_admin: true
|
||||
})
|
||||
.select()
|
||||
.single();
|
||||
|
||||
if (insertError) {
|
||||
console.error('❌ Erreur lors de l\'insertion dans user_permissions:', insertError);
|
||||
return NextResponse.json(
|
||||
{ error: `Erreur lors de l'insertion dans user_permissions: ${insertError.message}` },
|
||||
{ status: 500 }
|
||||
);
|
||||
}
|
||||
|
||||
console.log('✅ Utilisateur réinséré dans user_permissions:', permissionsData);
|
||||
|
||||
return NextResponse.json({
|
||||
success: true,
|
||||
message: 'Utilisateur admin réparé avec succès',
|
||||
permissions: permissionsData,
|
||||
user: {
|
||||
id: user.id,
|
||||
email: user.email,
|
||||
is_admin: true,
|
||||
is_super_admin: true
|
||||
}
|
||||
});
|
||||
|
||||
} catch (error: any) {
|
||||
console.error('❌ Erreur lors de la réparation:', error);
|
||||
return NextResponse.json(
|
||||
{ error: `Erreur interne: ${error.message}` },
|
||||
{ status: 500 }
|
||||
);
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user