Some checks failed
Tests / Go Tests (push) Has been cancelled
Tests / Python Tests (push) Has been cancelled
Tests / Integration Tests (push) Has been cancelled
Tests / Go Lint (push) Has been cancelled
Tests / Python Lint (push) Has been cancelled
Tests / Security Scan (push) Has been cancelled
Tests / All Checks Passed (push) Has been cancelled
Security Scanning / Secret Scanning (push) Has been cancelled
Security Scanning / Dependency Vulnerability Scan (push) Has been cancelled
Security Scanning / Go Security Scan (push) Has been cancelled
Security Scanning / Python Security Scan (push) Has been cancelled
Security Scanning / Node.js Security Scan (push) Has been cancelled
Security Scanning / Docker Image Security (push) Has been cancelled
Security Scanning / Security Summary (push) Has been cancelled
CI/CD Pipeline / Go Tests (push) Has been cancelled
CI/CD Pipeline / Python Tests (push) Has been cancelled
CI/CD Pipeline / Website Tests (push) Has been cancelled
CI/CD Pipeline / Linting (push) Has been cancelled
CI/CD Pipeline / Security Scan (push) Has been cancelled
CI/CD Pipeline / Docker Build & Push (push) Has been cancelled
CI/CD Pipeline / Integration Tests (push) Has been cancelled
CI/CD Pipeline / Deploy to Staging (push) Has been cancelled
CI/CD Pipeline / Deploy to Production (push) Has been cancelled
CI/CD Pipeline / CI Summary (push) Has been cancelled
ci/woodpecker/manual/build-ci-image Pipeline was successful
ci/woodpecker/manual/main Pipeline failed
All services: admin-v2, studio-v2, website, ai-compliance-sdk, consent-service, klausur-service, voice-service, and infrastructure. Large PDFs and compiled binaries excluded via .gitignore.
68 lines
1.8 KiB
TypeScript
68 lines
1.8 KiB
TypeScript
/**
|
|
* Content API Route
|
|
*
|
|
* GET: Laedt aktuellen Website-Content
|
|
* POST: Speichert geaenderten Content (Admin only)
|
|
*/
|
|
|
|
import { NextRequest, NextResponse } from 'next/server'
|
|
import { getContent, saveContent, WebsiteContent } from '@/lib/content'
|
|
|
|
// GET - Content laden
|
|
export async function GET() {
|
|
try {
|
|
const content = getContent()
|
|
return NextResponse.json(content)
|
|
} catch (error) {
|
|
console.error('Error loading content:', error)
|
|
return NextResponse.json(
|
|
{ error: 'Failed to load content' },
|
|
{ status: 500 }
|
|
)
|
|
}
|
|
}
|
|
|
|
// POST - Content speichern
|
|
export async function POST(request: NextRequest) {
|
|
try {
|
|
// Einfache Admin-Pruefung via Header oder Query
|
|
// In Produktion: JWT/Session-basierte Auth
|
|
const adminKey = request.headers.get('x-admin-key')
|
|
const expectedKey = process.env.ADMIN_API_KEY || 'breakpilot-admin-2024'
|
|
|
|
if (adminKey !== expectedKey) {
|
|
return NextResponse.json(
|
|
{ error: 'Unauthorized' },
|
|
{ status: 401 }
|
|
)
|
|
}
|
|
|
|
const content: WebsiteContent = await request.json()
|
|
|
|
// Validierung
|
|
if (!content.hero || !content.features || !content.faq || !content.pricing) {
|
|
return NextResponse.json(
|
|
{ error: 'Invalid content structure' },
|
|
{ status: 400 }
|
|
)
|
|
}
|
|
|
|
const result = saveContent(content)
|
|
|
|
if (result.success) {
|
|
return NextResponse.json({ success: true, message: 'Content saved' })
|
|
} else {
|
|
return NextResponse.json(
|
|
{ error: result.error || 'Failed to save content' },
|
|
{ status: 500 }
|
|
)
|
|
}
|
|
} catch (error) {
|
|
console.error('Error saving content:', error)
|
|
return NextResponse.json(
|
|
{ error: error instanceof Error ? error.message : 'Failed to save content' },
|
|
{ status: 500 }
|
|
)
|
|
}
|
|
}
|