Major changes: - Docker Compose: full Supabase stack (11 services) equivalent to supabase CLI - Fischerei module: 16 DB tables, waters/species/stocking/catch books/competitions - Sitzungsprotokolle module: meeting protocols, agenda items, task tracking - Verbandsverwaltung module: federation management, member clubs, contacts, fees - Per-account module activation via Modules page toggle - Site Builder: live CMS data in Puck blocks (courses, events, membership registration) - Public registration APIs: course signup, event registration, membership application - Document generation: PDF member cards, Excel reports, HTML labels - Landing page: real Com.BISS content (no filler text) - UX audit fixes: AccountNotFound component, shared status badges, confirm dialog, pagination, duplicate heading removal, emoji→badge replacement, a11y fixes - QA: healthcheck fix, API auth fix, enum mismatch fix, password required attribute
40 lines
1.1 KiB
TypeScript
40 lines
1.1 KiB
TypeScript
import { NextResponse } from 'next/server';
|
|
|
|
import { getSupabaseServerAdminClient } from '@kit/supabase/server-admin-client';
|
|
|
|
/**
|
|
* Healthcheck endpoint for the web app. If this endpoint returns a 200, the web app will be considered healthy.
|
|
* If this endpoint returns a 500, the web app will be considered unhealthy.
|
|
* This endpoint can be used by Docker to determine if the web app is healthy and should be restarted.
|
|
*/
|
|
export async function GET() {
|
|
const isDbHealthy = await getSupabaseHealthCheck();
|
|
|
|
return NextResponse.json({
|
|
services: {
|
|
database: isDbHealthy,
|
|
// add other services here
|
|
},
|
|
});
|
|
}
|
|
|
|
/**
|
|
* Quick check to see if the database is healthy by querying the config table
|
|
* @returns true if the database is healthy, false otherwise
|
|
*/
|
|
async function getSupabaseHealthCheck() {
|
|
try {
|
|
const client = getSupabaseServerAdminClient();
|
|
|
|
const { data, error } = await client
|
|
.from('config')
|
|
.select('billing_provider')
|
|
.limit(1)
|
|
.maybeSingle();
|
|
|
|
return !error;
|
|
} catch {
|
|
return false;
|
|
}
|
|
}
|