- Replace in-memory Maps with Drizzle ORM queries for all CRUD operations - Use integer IDs matching SQLite schema instead of UUIDs - Fix scriptId to projectId inconsistency in characters and scenes - Add project ownership verification on all mutation procedures - Make getCharacter/getScene procedures protected (not public) - Proper JWT-based userId validation via context - Add cascade delete for characters/relationships/scenes on project deletion - Add verifyProjectOwnership helper for authorization checks - Rewrite tests with createCallerFactory pattern for tRPC v11 - Use better-sqlite3 for in-memory test database - Split vitest config into separate file from vite config
38 lines
1.0 KiB
TypeScript
38 lines
1.0 KiB
TypeScript
import { createHTTPServer } from '@trpc/server/adapters/standalone';
|
|
import { projectRouter } from './project-router';
|
|
import { revisionsRouter } from './revisions-router';
|
|
import type { TRPCContext } from './types';
|
|
import type { TRPCError } from '@trpc/server';
|
|
import { t } from './router';
|
|
|
|
// App router combining all routers
|
|
export const appRouter = t.router({
|
|
project: projectRouter,
|
|
revisions: revisionsRouter,
|
|
});
|
|
|
|
export type AppRouter = typeof appRouter;
|
|
|
|
// Create tRPC HTTP server
|
|
export function createTRPCServer(port: number = 8080) {
|
|
const server = createHTTPServer({
|
|
router: appRouter,
|
|
createContext: async (): Promise<TRPCContext> => {
|
|
return {
|
|
userId: undefined,
|
|
};
|
|
},
|
|
onError: ({ error, path }: { error: TRPCError; path: string | undefined }) => {
|
|
console.error(`tRPC error on ${path}:`, error.message);
|
|
},
|
|
});
|
|
|
|
server.listen(port, () => {
|
|
console.log(`tRPC server listening on port ${port}`);
|
|
});
|
|
|
|
return server;
|
|
}
|
|
|
|
export default appRouter;
|