- Add user CRUD: list, create (via Better Auth), update role/status, remove from port - Add role CRUD: create, update permissions, delete with system role protection - Full permissions matrix UI with accordion groups and per-action checkboxes - Validators, services, API routes, and UI components following existing patterns Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
36 lines
1.1 KiB
TypeScript
36 lines
1.1 KiB
TypeScript
import { z } from 'zod';
|
|
|
|
const permissionGroupSchema = z.record(z.string(), z.boolean());
|
|
|
|
const rolePermissionsSchema = z.object({
|
|
clients: permissionGroupSchema,
|
|
interests: permissionGroupSchema,
|
|
berths: permissionGroupSchema,
|
|
documents: permissionGroupSchema,
|
|
expenses: permissionGroupSchema,
|
|
invoices: permissionGroupSchema,
|
|
files: permissionGroupSchema,
|
|
email: permissionGroupSchema,
|
|
reminders: permissionGroupSchema,
|
|
calendar: permissionGroupSchema,
|
|
reports: permissionGroupSchema,
|
|
document_templates: permissionGroupSchema,
|
|
admin: permissionGroupSchema,
|
|
});
|
|
|
|
export const createRoleSchema = z.object({
|
|
name: z.string().min(1).max(100),
|
|
description: z.string().max(500).optional(),
|
|
permissions: rolePermissionsSchema,
|
|
});
|
|
|
|
export type CreateRoleInput = z.infer<typeof createRoleSchema>;
|
|
|
|
export const updateRoleSchema = z.object({
|
|
name: z.string().min(1).max(100).optional(),
|
|
description: z.string().max(500).nullable().optional(),
|
|
permissions: rolePermissionsSchema.optional(),
|
|
});
|
|
|
|
export type UpdateRoleInput = z.infer<typeof updateRoleSchema>;
|