Files
AnchorOS/app/api/aperture/permissions/route.ts
Marco Gallegos 28e98a2a44 feat: Complete SalonOS implementation with authentication, payments, reports, and documentation
- 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
2026-01-16 17:35:29 -06:00

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 })
}