Organizații și Spații de lucru
Prezentare generală
qr3.app utilizează o ierarhie pe două niveluri:
Organization (Firma/Agentur) └── Workspace 1 (Kunde A) └── Workspace 2 (Kunde B) └── Workspace 3 (Internes Team)- Organizație — nivelul superior, asociat unui cont Stripe și unui abonament
- Workspace — zonă izolată pentru coduri QR, scanări și chei API
API Organizații
GET /v1/organizations
Returnează organizația de care aparține cheia API curentă.
curl https://qr3.app/v1/organizations \ -H "Authorization: Bearer qr3_sk_..."POST /v1/organizations
Creează o organizație nouă.
curl -X POST https://qr3.app/v1/organizations \ -H "Authorization: Bearer qr3_sk_..." \ -H "Content-Type: application/json" \ -d '{ "name": "Digital Heroes GmbH", "slug": "digital-heroes", "billing_email": "[email protected]" }'Câmpuri:
| Câmp | Tip | Obligatoriu | Descriere |
|---|---|---|---|
name | string | ✅ | Nume afișat (max. 255 caractere) |
slug | string | ✅ | Prietenos cu URL-ul, unic (min. 2, max. 63 caractere, doar a-z0-9-) |
billing_email | string | — | E-mail de facturare |
PATCH /v1/organizations/:id
curl -X PATCH https://qr3.app/v1/organizations/org_a1b2c3 \ -H "Authorization: Bearer qr3_sk_..." \ -H "Content-Type: application/json" \DELETE /v1/organizations/:id
Ștergere logică (Soft-Delete) a organizației. Toate spațiile de lucru (Workspaces) și codurile QR asociate sunt păstrate, dar nu mai pot fi accesate.
API Workspaces
GET /v1/workspaces
Listează toate spațiile de lucru (Workspaces) ale organizației.
curl https://qr3.app/v1/workspaces \ -H "Authorization: Bearer qr3_sk_..."POST /v1/workspaces
Creează un Workspace nou.
curl -X POST https://qr3.app/v1/workspaces \ -H "Authorization: Bearer qr3_sk_..." \ -H "Content-Type: application/json" \ -d '{ "name": "Kunde Bäckerei Schmidt", "slug": "baeckerei-schmidt", "default_locale": "de", "primary_color": "#8B4513", "approval_required": false }'Câmpuri:
| Câmp | Tip | Implicit | Descriere |
|---|---|---|---|
name | string | — | Nume afișat (obligatoriu) |
slug | string | — | Prietenos cu URL-ul, unic per organizație (obligatoriu) |
default_locale | string | de | Limba implicită |
approval_required | boolean | false | Activează fluxul de lucru pentru aprobare |
primary_color | string | — | Culoare de branding (#RRGGBB) |
Limite abonament:
| Abonament | Max. Workspaces |
|---|---|
| Free | 1 |
| Pro | 3 |
| Business | 10 |
| Agency | Nelimitat |
PATCH /v1/workspaces/:id
curl -X PATCH https://qr3.app/v1/workspaces/ws_xyz789 \ -H "Authorization: Bearer qr3_sk_..." \ -H "Content-Type: application/json" \ -d '{ "name": "Neuer Name", "approval_required": true, "custom_domain": "qr.baeckerei-schmidt.de" }'DELETE /v1/workspaces/:id
Arhivează Workspace-ul. Nu poate fi aplicat propriului Workspace.
Audit Logs
GET /v1/audit-logs
Jurnal trasabil al tuturor modificărilor din Workspace.
curl "https://qr3.app/v1/audit-logs?resource_type=codes&limit=50" \ -H "Authorization: Bearer qr3_sk_..."Parametri Query:
| Parametru | Tip | Descriere |
|---|---|---|
resource_type | string | Filtrare după resursă: codes, api_keys, webhooks, workspaces |
resource_id | string | Filtrare după ID-ul specific al resursei |
action | string | Filtrare după acțiune (de ex. codes.created) |
cursor | string | Cursor de paginare |
limit | integer | Max. 100 (implicit: 50) |
Exemplu de răspuns:
{ "data": [ { "id": "aud_a1b2c3", "actor_type": "api", "action": "codes.created", "resource_type": "codes", "resource_id": "qr_xyz123", "changes": {}, "created_at": "2026-03-15T10:00:00.000Z" } ]}