mirror of
https://github.com/marcogll/AnchorOS.git
synced 2026-03-15 16:24:30 +00:00
- Implement client authentication with Supabase magic links - Add Stripe payment integration for deposits - Complete The Boutique booking flow with payment processing - Implement Aperture backend with staff/resources management - Add comprehensive reports: sales, payments, payroll - Create permissions management system by roles - Configure kiosk system with enrollment - Add no-show logic and penalization system - Update project documentation and API docs - Enhance README with current project status
60 lines
1.9 KiB
TypeScript
60 lines
1.9 KiB
TypeScript
import { NextRequest, NextResponse } from 'next/server'
|
|
|
|
// Mock permissions data
|
|
const mockPermissions = [
|
|
{
|
|
id: 'admin',
|
|
name: 'Administrador',
|
|
permissions: [
|
|
{ id: 'view_reports', name: 'Ver reportes', enabled: true },
|
|
{ id: 'manage_staff', name: 'Gestionar staff', enabled: true },
|
|
{ id: 'manage_resources', name: 'Gestionar recursos', enabled: true },
|
|
{ id: 'view_payments', name: 'Ver pagos', enabled: true },
|
|
{ id: 'manage_permissions', name: 'Gestionar permisos', enabled: true }
|
|
]
|
|
},
|
|
{
|
|
id: 'manager',
|
|
name: 'Gerente',
|
|
permissions: [
|
|
{ id: 'view_reports', name: 'Ver reportes', enabled: true },
|
|
{ id: 'manage_staff', name: 'Gestionar staff', enabled: false },
|
|
{ id: 'manage_resources', name: 'Gestionar recursos', enabled: true },
|
|
{ id: 'view_payments', name: 'Ver pagos', enabled: true },
|
|
{ id: 'manage_permissions', name: 'Gestionar permisos', enabled: false }
|
|
]
|
|
},
|
|
{
|
|
id: 'staff',
|
|
name: 'Staff',
|
|
permissions: [
|
|
{ id: 'view_reports', name: 'Ver reportes', enabled: false },
|
|
{ id: 'manage_staff', name: 'Gestionar staff', enabled: false },
|
|
{ id: 'manage_resources', name: 'Gestionar recursos', enabled: false },
|
|
{ id: 'view_payments', name: 'Ver pagos', enabled: false },
|
|
{ id: 'manage_permissions', name: 'Gestionar permisos', enabled: false }
|
|
]
|
|
}
|
|
]
|
|
|
|
export async function GET() {
|
|
return NextResponse.json({
|
|
success: true,
|
|
permissions: mockPermissions
|
|
})
|
|
}
|
|
|
|
export async function POST(request: NextRequest) {
|
|
const { roleId, permId } = await request.json()
|
|
|
|
// Toggle permission
|
|
const role = mockPermissions.find(r => r.id === roleId)
|
|
if (role) {
|
|
const perm = role.permissions.find(p => p.id === permId)
|
|
if (perm) {
|
|
perm.enabled = !perm.enabled
|
|
}
|
|
}
|
|
|
|
return NextResponse.json({ success: true })
|
|
} |