Szervezetek és munkaterületek
Áttekintés
A qr3.app kétszintű hierarchiát használ:
Organization (Firma/Agentur) └── Workspace 1 (Kunde A) └── Workspace 2 (Kunde B) └── Workspace 3 (Internes Team)- Szervezet (Organization) — a legfelső szint, amely egy Stripe-fiókhoz és díjcsomaghoz (Plan) kapcsolódik
- Munkaterület (Workspace) — izolált terület a QR-kódok, beolvasások (scans) és API-kulcsok számára
Organizations API
GET /v1/organizations
Visszaadja azt a szervezetet, amelyhez az aktuális API-kulcs tartozik.
curl https://qr3.app/v1/organizations \ -H "Authorization: Bearer qr3_sk_..."POST /v1/organizations
Létrehoz egy új szervezetet.
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]" }'Mezők:
| Mező | Típus | Kötelező | Leírás |
|---|---|---|---|
name | string | ✅ | Megjelenítendő név (max. 255 karakter) |
slug | string | ✅ | URL-barát, egyedi (min. 2, max. 63 karakter, csak a-z0-9-) |
billing_email | string | — | Számlázási e-mail-cím |
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
A szervezet szoft törlése (soft-delete). Minden kapcsolódó Workspace és QR-kód megmarad, de többé nem lesznek hozzáférhetők.
Workspaces API
GET /v1/workspaces
A szervezet összes Workspace-ének kilistázása.
curl https://qr3.app/v1/workspaces \ -H "Authorization: Bearer qr3_sk_..."POST /v1/workspaces
Új Workspace létrehozása.
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 }'Mezők:
| Mező | Típus | Alapértelmezett | Leírás |
|---|---|---|---|
name | string | — | Megjelenítendő név (kötelező) |
slug | string | — | URL-barát, szervezetenként egyedi (kötelező) |
default_locale | string | de | Alapértelmezett nyelv |
approval_required | boolean | false | Jóváhagyási munkafolyamat aktiválása |
primary_color | string | — | Arculati szín (#RRGGBB) |
Díjcsomag-korlátok:
| Díjcsomag | Max. Workspace-ek száma |
|---|---|
| Free | 1 |
| Pro | 3 |
| Business | 10 |
| Agency | Korlátlan |
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
Archiválja a Workspace-t. Nem alkalmazható a saját Workspace-re.
Audit-Logs
GET /v1/audit-logs
A Workspace-ben történt összes változás nyomon követhető naplója.
curl "https://qr3.app/v1/audit-logs?resource_type=codes&limit=50" \ -H "Authorization: Bearer qr3_sk_..."Query-paraméterek:
| Paraméter | Típus | Leírás |
|---|---|---|
resource_type | string | Szűrés erőforrás szerint: codes, api_keys, webhooks, workspaces |
resource_id | string | Szűrés konkrét erőforrás-ID szerint |
action | string | Szűrés művelet szerint (pl. codes.created) |
cursor | string | Lapozási kurzor (Pagination-Cursor) |
limit | integer | Max. 100 (Alapértelmezett: 50) |
Példa válasz:
{ "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" } ]}