Organizacije in delovni prostori
Pregled
qr3.app uporablja dvostopenjsko hierarhijo:
Organization (Firma/Agentur) └── Workspace 1 (Kunde A) └── Workspace 2 (Kunde B) └── Workspace 3 (Internes Team)- Organizacija — najvišja raven, povezana z računom Stripe in paketom
- Delovni prostor — izolirano območje za QR-kode, skeniranja in API-ključe
API za organizacije
GET /v1/organizations
Vrne organizacijo, ki ji pripada trenutni API-ključ.
curl https://qr3.app/v1/organizations \ -H "Authorization: Bearer qr3_sk_..."POST /v1/organizations
Ustvari novo organizacijo.
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]" }'Polja:
| Polje | Tip | Obvezno | Opis |
|---|---|---|---|
name | string | ✅ | Prikazno ime (največ 255 znakov) |
slug | string | ✅ | URL-prijazen, edinstven (najmanj 2, največ 63 znakov, samo a-z0-9-) |
billing_email | string | — | E-pošta za izstavitev računov |
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
Mehki izbris (soft-delete) organizacije. Vsi pripadajoči delovni prostori in QR-kode se ohranijo, vendar niso več dostopni.
API za delovne prostore
GET /v1/workspaces
Seznam vseh delovnih prostorov v organizaciji.
curl https://qr3.app/v1/workspaces \ -H "Authorization: Bearer qr3_sk_..."POST /v1/workspaces
Ustvari nov delovni prostor.
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 }'Polja:
| Polje | Tip | Privzeto | Opis |
|---|---|---|---|
name | string | — | Prikazno ime (obvezno) |
slug | string | — | URL-prijazen, edinstven znotraj organizacije (obvezno) |
default_locale | string | de | Privzeti jezik |
approval_required | boolean | false | Omogoči potek dela za odobritev |
primary_color | string | — | Barva blagovne znamke (#RRGGBB) |
Omejitve paketov:
| Paket | Največ delovnih prostorov |
|---|---|
| Free | 1 |
| Pro | 3 |
| Business | 10 |
| Agency | Brez omejitev |
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
Arhivira delovni prostor. Ni mogoče uporabiti za lasten delovni prostor.
Revizijski dnevniki
GET /v1/audit-logs
Sledljiv dnevnik vseh sprememb v delovnem prostoru.
curl "https://qr3.app/v1/audit-logs?resource_type=codes&limit=50" \ -H "Authorization: Bearer qr3_sk_..."Parametri poizvedbe:
| Parameter | Tip | Opis |
|---|---|---|
resource_type | string | Filtriranje po viru: codes, api_keys, webhooks, workspaces |
resource_id | string | Filtriranje po določenem ID-ju vira |
action | string | Filtriranje po dejanju (npr. codes.created) |
cursor | string | Kazalec za strani (pagination cursor) |
limit | integer | Največ 100 (privzeto: 50) |
Primer odziva:
{ "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" } ]}