Schema: - 8 neue Profile-Felder fuer DiGA-Demographics (birthYear/gender/maritalStatus/ profession/bundesland/city + 2 consent-stamps demographicsConsentAt/ demographicsWithdrawnAt) - 4 Pro-Trial-Felder (proTrialStartedAt/ExpiresAt/Source/UsedAt) — Free-User bekommen 1 Woche Pro als Reward fuer DiGA-Daten-Pflege (siehe project_demographic_pro_trial_reward.md) - lyra_voice_id (Legend-only Voice-Picker) - diga_banner_dismissed_at (server-side persistence ueber Re-Install) - last_install_at (Streak-Logic survives Re-Install) - Migration 20260507_profile_demographics_and_trial: alle Felder optional, keine Backfill-Logik notwendig Endpoints (alle auth-protected, scope=me): - GET /api/profile/me/sos-insights - GET /api/profile/me/cooldown-history - GET /api/profile/me/approved-domains - POST /api/profile/me/install-event (track app re-installs) - POST /api/profile/me/diga-banner-dismiss - PATCH /api/profile/me/demographics (consent-stamp + re-grant-after-withdrawal in tx) - DELETE /api/profile/me/demographics (DSGVO right-to-be-forgotten) Plugin: - pro-trial-expiry-cron: 6h-Interval, conservative-fallback (revoke nur wenn kein stripeSubId), 60s initial-delay damit Server-boot nicht blockiert wird Tests: - vitest config + erste Test-Files (test-infrastructure setup) Memory: - feedback_demographics_user_initiated.md (Lyra darf NIE extrahieren) - project_demographic_pro_trial_reward.md (Pro-Trial-Reward-Mechanik) - project_profile_page_design.md (UI-Showpiece, eigene/fremde-Ansicht streng getrennt) Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
26 lines
777 B
TypeScript
26 lines
777 B
TypeScript
/**
|
|
* DELETE /api/profile/me/demographics
|
|
*
|
|
* DSGVO-Withdrawal — nullt alle 6 Demographic-Felder.
|
|
*
|
|
* Wichtig:
|
|
* - `demographicsConsentAt` BLEIBT erhalten (Audit-Trail dass User mal
|
|
* eingewilligt hat).
|
|
* - `demographicsWithdrawnAt` wird gesetzt (zweiter Audit-Marker).
|
|
* - Pro-Trial bleibt aktiv falls bereits getriggert (no-penalty-policy,
|
|
* siehe memory/project_demographic_pro_trial_reward.md).
|
|
*/
|
|
import { withdrawDemographics } from "../../../db/profile";
|
|
import { requireUser } from "../../../utils/auth";
|
|
|
|
export default defineEventHandler(async (event) => {
|
|
const user = await requireUser(event);
|
|
|
|
await withdrawDemographics(user.id);
|
|
|
|
console.log(`[demographics-withdraw] user=${user.id}`);
|
|
|
|
setResponseStatus(event, 204);
|
|
return null;
|
|
});
|