This repository has been archived on 2026-02-15. You can view files and clone it. You cannot open issues or pull requests or push a commit.
Files
breakpilot-pwa/backend/deadline_api.py
BreakPilot Dev 19855efacc
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
feat: BreakPilot PWA - Full codebase (clean push without large binaries)
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.
2026-02-11 13:25:58 +01:00

80 lines
2.1 KiB
Python

"""
Deadline API - Proxy zu Go Consent Service für Consent-Deadlines und Account-Sperrung
"""
from fastapi import APIRouter, HTTPException, Header
from typing import Optional
import httpx
router = APIRouter(prefix="/v1", tags=["Deadlines"])
CONSENT_SERVICE_URL = "http://localhost:8081"
async def proxy_request(
method: str,
path: str,
authorization: Optional[str] = None,
json_data: dict = None
):
"""Proxy request to Go consent service."""
headers = {}
if authorization:
headers["Authorization"] = authorization
async with httpx.AsyncClient() as client:
try:
response = await client.request(
method,
f"{CONSENT_SERVICE_URL}{path}",
headers=headers,
json=json_data,
timeout=30.0
)
if response.status_code >= 400:
raise HTTPException(
status_code=response.status_code,
detail=response.json().get("error", "Request failed")
)
return response.json()
except httpx.RequestError as e:
raise HTTPException(status_code=503, detail=f"Consent service unavailable: {str(e)}")
@router.get("/consent/deadlines")
async def get_pending_deadlines(
authorization: Optional[str] = Header(None)
):
"""Holt alle ausstehenden Consent-Deadlines des Benutzers."""
return await proxy_request(
"GET",
"/api/v1/consent/deadlines",
authorization=authorization
)
@router.get("/account/suspension-status")
async def get_suspension_status(
authorization: Optional[str] = Header(None)
):
"""Gibt den Sperrstatus des Accounts zurück."""
return await proxy_request(
"GET",
"/api/v1/account/suspension-status",
authorization=authorization
)
@router.post("/admin/deadlines/process")
async def process_deadlines(
authorization: Optional[str] = Header(None)
):
"""Löst die Deadline-Verarbeitung manuell aus (nur Admin)."""
return await proxy_request(
"POST",
"/api/v1/admin/deadlines/process",
authorization=authorization
)