Files
openmonetis/app/api/health/route.ts
Felipe Coutinho 97662d5d34 feat(api): update health endpoint for OpenSheets Companion compatibility
- Add app name and version to health response
- Rename 'service' to 'name' for better semantics
- Rename 'error' to 'message' for consistency
- Update documentation to reflect companion app usage
2026-01-23 12:12:40 +00:00

45 lines
1.2 KiB
TypeScript

import { NextResponse } from "next/server";
import { db } from "@/lib/db";
const APP_VERSION = "1.0.0";
/**
* Health check endpoint para Docker, monitoring e OpenSheets Companion
* GET /api/health
*
* Retorna status 200 se a aplicação está saudável
* Verifica conexão com banco de dados
* Usado pelo app Android para validar URL do servidor
*/
export async function GET() {
try {
// Tenta fazer uma query simples no banco para verificar conexão
// Isso garante que o app está conectado ao banco antes de considerar "healthy"
await db.execute("SELECT 1");
return NextResponse.json(
{
status: "ok",
name: "OpenSheets",
version: APP_VERSION,
timestamp: new Date().toISOString(),
},
{ status: 200 }
);
} catch (error) {
// Se houver erro na conexão com banco, retorna status 503 (Service Unavailable)
console.error("Health check failed:", error);
return NextResponse.json(
{
status: "error",
name: "OpenSheets",
version: APP_VERSION,
timestamp: new Date().toISOString(),
message: error instanceof Error ? error.message : "Database connection failed",
},
{ status: 503 }
);
}
}