cd78f72f33
Complete rename of all technical identifiers across the codebase: Package names (11 packages): - @planarchy/* → @capakraken/* in all package.json, tsconfig, imports Import statements: 277 files, 548 occurrences replaced Database & Docker: - PostgreSQL user/db: planarchy → capakraken - Docker volumes: planarchy_pgdata → capakraken_pgdata - Connection strings updated in docker-compose, .env, CI CI/CD: - GitHub Actions workflow: all filter commands updated - Test database credentials updated Infrastructure: - Redis channel: planarchy:sse → capakraken:sse - Logger service name: planarchy-api → capakraken-api - Anonymization seed updated - Start/stop/restart scripts updated Test data: - Seed emails: @planarchy.dev → @capakraken.dev - E2E test credentials: all 11 spec files updated - Email defaults: @planarchy.app → @capakraken.app - localStorage keys: planarchy_* → capakraken_* Documentation: 30+ .md files updated Verification: - pnpm install: workspace resolution works - TypeScript: only pre-existing TS2589 (no new errors) - Engine: 310/310 tests pass - Staffing: 37/37 tests pass Co-Authored-By: claude-flow <ruv@ruv.net>
77 lines
1.8 KiB
TypeScript
77 lines
1.8 KiB
TypeScript
import { NextResponse } from "next/server";
|
|
import { prisma } from "@capakraken/db";
|
|
import { createConnection } from "net";
|
|
|
|
export const dynamic = "force-dynamic";
|
|
export const runtime = "nodejs";
|
|
|
|
const REDIS_URL = process.env["REDIS_URL"] ?? "redis://localhost:6380";
|
|
|
|
async function checkPostgres(): Promise<"ok" | "error"> {
|
|
try {
|
|
await prisma.$queryRaw`SELECT 1`;
|
|
return "ok";
|
|
} catch {
|
|
return "error";
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Lightweight Redis PING check using a raw TCP socket.
|
|
* Avoids importing ioredis (which is only a dependency of @capakraken/api).
|
|
*/
|
|
async function checkRedis(): Promise<"ok" | "error"> {
|
|
return new Promise((resolve) => {
|
|
try {
|
|
const url = new URL(REDIS_URL);
|
|
const host = url.hostname || "localhost";
|
|
const port = parseInt(url.port || "6379", 10);
|
|
const timeout = 3000;
|
|
|
|
const socket = createConnection({ host, port }, () => {
|
|
// Send Redis PING command using RESP protocol
|
|
socket.write("*1\r\n$4\r\nPING\r\n");
|
|
});
|
|
|
|
socket.setTimeout(timeout);
|
|
|
|
socket.on("data", (data) => {
|
|
const response = data.toString();
|
|
socket.destroy();
|
|
// Redis responds with +PONG\r\n
|
|
resolve(response.includes("PONG") ? "ok" : "error");
|
|
});
|
|
|
|
socket.on("timeout", () => {
|
|
socket.destroy();
|
|
resolve("error");
|
|
});
|
|
|
|
socket.on("error", () => {
|
|
socket.destroy();
|
|
resolve("error");
|
|
});
|
|
} catch {
|
|
resolve("error");
|
|
}
|
|
});
|
|
}
|
|
|
|
export async function GET() {
|
|
const [postgres, redis] = await Promise.all([
|
|
checkPostgres(),
|
|
checkRedis(),
|
|
]);
|
|
|
|
const allHealthy = postgres === "ok" && redis === "ok";
|
|
|
|
return NextResponse.json(
|
|
{
|
|
status: allHealthy ? "ready" : "not_ready",
|
|
postgres,
|
|
redis,
|
|
},
|
|
{ status: allHealthy ? 200 : 503 },
|
|
);
|
|
}
|