a75303f857
- lib/db.ts entfernt, mysql2-Abhängigkeit gestrichen - lib/phpdb.ts: HTTP-Client für alle DB-Operationen via DB4js_all.php - Alle API-Routen und Server Actions auf phpdb.ts umgestellt - compose.yml / docker-compose.prod.yml: MySQL/phpMyAdmin-Container entfernt - app/api/DB4js_all.php/route.ts: Proxy für Statistik-AJAX-Calls - Statistik-Grafik liest ab 2026 live aus logbuch statt StatistikJahre - PHP 7.3-Kompatibilität: str_contains → strpos Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
52 lines
1.9 KiB
TypeScript
52 lines
1.9 KiB
TypeScript
import { NextRequest, NextResponse } from 'next/server';
|
|
import { getSession } from '@/lib/session';
|
|
import { triggerBackup } from '@/lib/backup';
|
|
import * as phpdb from '@/lib/phpdb';
|
|
|
|
export async function GET(request: NextRequest) {
|
|
const session = await getSession();
|
|
if (!session) return NextResponse.json({ error: 'Nicht angemeldet' }, { status: 401 });
|
|
|
|
const { searchParams } = new URL(request.url);
|
|
const kuppel = searchParams.get('kuppel') || 'West';
|
|
const limit = Math.min(parseInt(searchParams.get('limit') || '10') || 10, 500);
|
|
const offset = Math.max(0, parseInt(searchParams.get('offset') || '0') || 0);
|
|
const month = searchParams.get('month') || '';
|
|
const order = searchParams.get('order') === 'asc' ? 'asc' : 'desc';
|
|
const search = (searchParams.get('search') || '').trim();
|
|
|
|
try {
|
|
const result = await phpdb.listLogbuch({ kuppel, limit, offset, month, search, order });
|
|
return NextResponse.json(result);
|
|
} catch (error) {
|
|
console.error('GET /api/logbuch:', error);
|
|
return NextResponse.json({ error: 'Datenbankfehler' }, { status: 500 });
|
|
}
|
|
}
|
|
|
|
export async function POST(request: NextRequest) {
|
|
const session = await getSession();
|
|
if (!session) return NextResponse.json({ error: 'Nicht angemeldet' }, { status: 401 });
|
|
|
|
try {
|
|
const body = await request.json();
|
|
const { Kuppel, ArtFuehrung, SonderName, Beginn, Ende, Besucher, beoIds, objekte, Bemerkungen, Wetter } = body;
|
|
|
|
const result = await phpdb.createLogbuch({
|
|
Kuppel, ArtFuehrung, SonderName, Beginn, Ende,
|
|
Besucher: Besucher ?? 0,
|
|
beoIds: beoIds ?? [],
|
|
objekte: objekte ?? [],
|
|
Bemerkungen: Bemerkungen ?? null,
|
|
Wetter: Wetter ?? null,
|
|
created_by: session.beoId,
|
|
});
|
|
|
|
triggerBackup();
|
|
return NextResponse.json(result, { status: 201 });
|
|
} catch (error) {
|
|
console.error('POST /api/logbuch:', error);
|
|
return NextResponse.json({ error: 'Datenbankfehler' }, { status: 500 });
|
|
}
|
|
}
|