Add public Foerderantrag (funding application) pages to the website. Add website management section to admin-v2 with content and status APIs. Extend Header, LandingContent, and i18n with new navigation entries. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
53 lines
1.3 KiB
TypeScript
53 lines
1.3 KiB
TypeScript
/**
|
|
* Website Status API Route
|
|
*
|
|
* GET: Health-Check ob die Website (Port 3000) erreichbar ist
|
|
*/
|
|
|
|
import { NextResponse } from 'next/server'
|
|
|
|
const WEBSITE_URL = process.env.WEBSITE_URL || 'http://website:3000'
|
|
const WEBSITE_FALLBACK_URL = 'https://macmini:3000'
|
|
|
|
export async function GET() {
|
|
const start = Date.now()
|
|
|
|
try {
|
|
const controller = new AbortController()
|
|
const timeout = setTimeout(() => controller.abort(), 5000)
|
|
|
|
let response: Response | null = null
|
|
try {
|
|
response = await fetch(WEBSITE_URL, {
|
|
method: 'HEAD',
|
|
signal: controller.signal,
|
|
cache: 'no-store',
|
|
})
|
|
} catch {
|
|
// Docker-internal name failed, try fallback
|
|
response = await fetch(WEBSITE_FALLBACK_URL, {
|
|
method: 'HEAD',
|
|
signal: controller.signal,
|
|
cache: 'no-store',
|
|
})
|
|
} finally {
|
|
clearTimeout(timeout)
|
|
}
|
|
|
|
const responseTime = Date.now() - start
|
|
|
|
return NextResponse.json({
|
|
online: response.ok || response.status < 500,
|
|
responseTime,
|
|
statusCode: response.status,
|
|
})
|
|
} catch (error) {
|
|
const responseTime = Date.now() - start
|
|
return NextResponse.json({
|
|
online: false,
|
|
responseTime,
|
|
error: error instanceof Error ? error.message : 'Website nicht erreichbar',
|
|
})
|
|
}
|
|
}
|