Organizzazzjonijiet u Workspaces
Ħarsa ġenerali
qr3.app juża ġerarkija b’żewġ livelli:
Organization (Firma/Agentur) └── Workspace 1 (Kunde A) └── Workspace 2 (Kunde B) └── Workspace 3 (Internes Team)- Organizzazzjoni — l-ogħla livell, assoċjat ma’ kont u pjan ta’ Stripe
- Workspace — żona iżolata għal QR codes, skans u API keys
API tal-Organizzazzjonijiet
GET /v1/organizations
Irritorna l-organizzazzjoni li magħha huwa assoċjat l-API key attwali.
curl https://qr3.app/v1/organizations \ -H "Authorization: Bearer qr3_sk_..."POST /v1/organizations
Oħloq organizzazzjoni ġdida.
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]" }'Kampi:
| Kamp | Tip | Mandatorju | Deskrizzjoni |
|---|---|---|---|
name | string | ✅ | Isem għall-wiri (mass. 255 karattru) |
slug | string | ✅ | URL-friendly, uniku (min. 2, mass. 63 karattru, a-z0-9- biss) |
billing_email | string | — | Email tal-kontijiet |
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
Soft-delete tal-organizzazzjoni. Il-workspaces u l-QR codes kollha assoċjati jinżammu, iżda ma jibqgħux aċċessibbli.
API tal-Workspaces
GET /v1/workspaces
Elenka l-workspaces kollha tal-organizzazzjoni.
curl https://qr3.app/v1/workspaces \ -H "Authorization: Bearer qr3_sk_..."POST /v1/workspaces
Oħloq workspace ġdid.
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 }'Kampi:
| Kamp | Tip | Default | Deskrizzjoni |
|---|---|---|---|
name | string | — | Isem għall-wiri (mandatorju) |
slug | string | — | URL-friendly, uniku għal kull Org (mandatorju) |
default_locale | string | de | Lingwa default |
approval_required | boolean | false | Attiva l-workflow tal-approvazzjoni |
primary_color | string | — | Kulur tal-branding (#RRGGBB) |
Limiti tal-Pjan:
| Pjan | Mass. Workspaces |
|---|---|
| Free | 1 |
| Pro | 3 |
| Business | 10 |
| Agency | Bla limitu |
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
Archivja l-workspace. Ma jistax jiġi applikat għall-workspace tiegħek stess.
Audit Logs
GET /v1/audit-logs
Log traċċabbli tal-bidliet kollha fil-workspace.
curl "https://qr3.app/v1/audit-logs?resource_type=codes&limit=50" \ -H "Authorization: Bearer qr3_sk_..."Parametri tal-Query:
| Parametru | Tip | Deskrizzjoni |
|---|---|---|
resource_type | string | Iffiltra skont ir-riżorsa: codes, api_keys, webhooks, workspaces |
resource_id | string | Iffiltra skont ID speċifika tar-riżorsa |
action | string | Iffiltra skont l-azzjoni (eż. codes.created) |
cursor | string | Cursor tal-paginazzjoni |
limit | integer | Mass. 100 (Default: 50) |
Eżempju ta’ Response:
{ "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" } ]}