feat(db): mesh data model — meshes, members, invites, audit log

- pgSchema "mesh" with 4 tables isolating the peer mesh domain
- Enums: visibility, transport, tier, role
- audit_log is metadata-only (E2E encryption enforced at broker/client)
- Cascade on mesh delete, soft-delete via archivedAt/revokedAt

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
This commit is contained in:
Alejandro Gutiérrez
2026-04-04 21:19:32 +01:00
commit d3163a5bff
1384 changed files with 314925 additions and 0 deletions

View File

@@ -0,0 +1,2 @@
export * from "./pagination";
export * from "./sort";

View File

@@ -0,0 +1,15 @@
import * as z from "zod";
export const offsetPaginationSchema = z.object({
page: z.coerce.number().int().default(1),
perPage: z.coerce.number().int().default(10),
});
export type OffsetPaginationPayload = z.infer<typeof offsetPaginationSchema>;
export const cursorPaginationSchema = z.object({
cursor: z.string().optional(),
limit: z.coerce.number().int().default(10),
});
export type CursorPaginationPayload = z.infer<typeof cursorPaginationSchema>;

View File

@@ -0,0 +1,8 @@
import * as z from "zod";
export const sortSchema = z.object({
id: z.string(),
desc: z.boolean().optional().default(false),
});
export type SortPayload = z.infer<typeof sortSchema>;