6290475ea3
Kommerzielle Hosting-/Abo-Plattform für Rapport-Instanzen. - React-Frontend (Vite/JSX): Landing, Register, Login, Plans, Dashboard - Node/Express-Backend: Auth (bcrypt+JWT), Stripe-Billing, Provisioning - HOST-Postgres-Schema: accounts, subscriptions, instances - Provisioning-Interface + Modell-A-Adapter (Studio im geteilten Stack) - MOCK-Modus: voller End-to-End-Flow ohne Stripe/Rapport-Stack testbar - Idempotentes Fulfillment (Upsert auf stripe_subscription_id) - docker-compose für lokale host-db; identisch auf Hetzner deploybar E2E lokal verifiziert: Register -> Checkout(mock) -> Instanz -> Idempotenz. Lizenz: proprietär (kein AGPL-Code eingebunden, nur Netzwerk-API zur Familie). Co-Authored-By: Claude Opus 4.8 <noreply@anthropic.com>
22 lines
770 B
JavaScript
22 lines
770 B
JavaScript
// Provisioning-Interface — entkoppelt "Abo bezahlt" von "wie entsteht die Instanz".
|
|
//
|
|
// Modell A (jetzt): ein Studio im geteilten Rapport-Stack -> studio-adapter.js
|
|
// Modell B (später): eigener Container pro Kunde -> container-adapter.js
|
|
//
|
|
// Beide implementieren dieselbe Signatur:
|
|
// provision({ account, plan }) -> { studioId, slug, instanceUrl }
|
|
// deprovision({ instance }) -> void
|
|
//
|
|
// Der Aufrufer (Billing-Webhook) kennt nur dieses Interface, nie die Details.
|
|
import * as studioAdapter from "./studio-adapter.js";
|
|
|
|
const adapter = studioAdapter; // Modell A. Später per Env umschaltbar.
|
|
|
|
export function provision(args) {
|
|
return adapter.provision(args);
|
|
}
|
|
|
|
export function deprovision(args) {
|
|
return adapter.deprovision(args);
|
|
}
|