Full CRM rebuild with Next.js 15, TypeScript, Tailwind, Drizzle ORM, PostgreSQL, Redis, BullMQ, MinIO, and Socket.io. Includes 461 source files covering clients, berths, interests/pipeline, documents/EOI, expenses/invoices, email, notifications, dashboard, admin, and client portal. CI/CD via Gitea Actions with Docker builds. Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
26 lines
763 B
TypeScript
26 lines
763 B
TypeScript
import { NextResponse } from 'next/server';
|
|
import { eq } from 'drizzle-orm';
|
|
|
|
import { withAuth } from '@/lib/api/helpers';
|
|
import { db } from '@/lib/db';
|
|
import { userPortRoles, userProfiles } from '@/lib/db/schema';
|
|
import { errorResponse } from '@/lib/errors';
|
|
|
|
export const GET = withAuth(async (_req, ctx) => {
|
|
try {
|
|
const rows = await db
|
|
.select({
|
|
id: userPortRoles.userId,
|
|
displayName: userProfiles.displayName,
|
|
})
|
|
.from(userPortRoles)
|
|
.innerJoin(userProfiles, eq(userPortRoles.userId, userProfiles.userId))
|
|
.where(eq(userPortRoles.portId, ctx.portId))
|
|
.orderBy(userProfiles.displayName);
|
|
|
|
return NextResponse.json({ data: rows });
|
|
} catch (error) {
|
|
return errorResponse(error);
|
|
}
|
|
});
|