1. Control-Bibliothek: 130 Controls in 10 Domaenen (payment_controls_v1.json) - PAY (20): Transaction Flow, Idempotenz, State Machine - LOG (15): Audit Trail, PAN-Maskierung, Event-Typen - CRYPTO (15): Secrets, HSM, P2PE, TLS - API (15): Auth, RBAC, Rate Limiting, Injection - TERM (15): ZVT/OPI, Heartbeat, Offline-Queue - FW (10): Firmware Signing, Secure Boot, Tamper Detection - REP (10): Reconciliation, Tagesabschluss, GoBD - ACC (10): MFA, Session, Least Privilege - ERR (10): Recovery, Circuit Breaker, Offline-Modus - BLD (10): CI/CD, SBOM, Container Scanning 2. Backend: DB Migration 024, Go Handler (5 Endpoints), Routes 3. Frontend: /sdk/payment-compliance mit Control-Browser + Assessment-Wizard Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
49 lines
1.6 KiB
TypeScript
49 lines
1.6 KiB
TypeScript
import { NextRequest, NextResponse } from 'next/server'
|
|
|
|
const SDK_URL = process.env.SDK_URL || 'http://ai-compliance-sdk:8090'
|
|
|
|
export async function GET(request: NextRequest) {
|
|
try {
|
|
const { searchParams } = new URL(request.url)
|
|
const endpoint = searchParams.get('endpoint') || 'controls'
|
|
const tenantId = request.headers.get('x-tenant-id') || '9282a473-5c95-4b3a-bf78-0ecc0ec71d3e'
|
|
|
|
let path: string
|
|
switch (endpoint) {
|
|
case 'controls':
|
|
const domain = searchParams.get('domain') || ''
|
|
path = `/sdk/v1/payment-compliance/controls${domain ? `?domain=${domain}` : ''}`
|
|
break
|
|
case 'assessments':
|
|
path = '/sdk/v1/payment-compliance/assessments'
|
|
break
|
|
default:
|
|
path = '/sdk/v1/payment-compliance/controls'
|
|
}
|
|
|
|
const resp = await fetch(`${SDK_URL}${path}`, {
|
|
headers: { 'X-Tenant-ID': tenantId },
|
|
})
|
|
const data = await resp.json()
|
|
return NextResponse.json(data)
|
|
} catch (err) {
|
|
return NextResponse.json({ error: 'Failed to fetch' }, { status: 500 })
|
|
}
|
|
}
|
|
|
|
export async function POST(request: NextRequest) {
|
|
try {
|
|
const tenantId = request.headers.get('x-tenant-id') || '9282a473-5c95-4b3a-bf78-0ecc0ec71d3e'
|
|
const body = await request.json()
|
|
const resp = await fetch(`${SDK_URL}/sdk/v1/payment-compliance/assessments`, {
|
|
method: 'POST',
|
|
headers: { 'Content-Type': 'application/json', 'X-Tenant-ID': tenantId },
|
|
body: JSON.stringify(body),
|
|
})
|
|
const data = await resp.json()
|
|
return NextResponse.json(data, { status: resp.status })
|
|
} catch (err) {
|
|
return NextResponse.json({ error: 'Failed to create' }, { status: 500 })
|
|
}
|
|
}
|