Initial: RAPPORT-HOST Iteration 1 (proprietär)
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>
This commit is contained in:
@@ -0,0 +1,21 @@
|
||||
// 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);
|
||||
}
|
||||
Reference in New Issue
Block a user