Οργανισμοί & Workspaces
Επισκόπηση
Το qr3.app χρησιμοποιεί μια ιεραρχία δύο επιπέδων:
Organization (Firma/Agentur) └── Workspace 1 (Kunde A) └── Workspace 2 (Kunde B) └── Workspace 3 (Internes Team)- Οργανισμός — το ανώτατο επίπεδο, συνδεδεμένο με έναν λογαριασμό Stripe και ένα πρόγραμμα
- Workspace — απομονωμένη περιοχή για QR-Codes, σαρώσεις και API-Keys
Organizations API
GET /v1/organizations
Επιστρέφει τον οργανισμό στον οποίο ανήκει το τρέχον API-Key.
curl https://qr3.app/v1/organizations \ -H "Authorization: Bearer qr3_sk_..."POST /v1/organizations
Δημιουργεί έναν νέο οργανισμό.
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]" }'Πεδία:
| Πεδίο | Τύπος | Υποχρεωτικό | Περιγραφή |
|---|---|---|---|
name | string | ✅ | Όνομα εμφάνισης (μέγ. 255 χαρακτήρες) |
slug | string | ✅ | Φιλικό προς URL, μοναδικό (ελάχ. 2, μέγ. 63 χαρακτήρες, μόνο a-z0-9-) |
billing_email | string | — | E-mail τιμολόγησης |
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 του οργανισμού. Όλοι οι σχετικοί Workspaces και τα QR-Codes διατηρούνται, αλλά δεν είναι πλέον προσβάσιμα.
Workspaces API
GET /v1/workspaces
Λίστα όλων των Workspaces του οργανισμού.
curl https://qr3.app/v1/workspaces \ -H "Authorization: Bearer qr3_sk_..."POST /v1/workspaces
Δημιουργία νέου Workspace.
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 }'Πεδία:
| Πεδίο | Τύπος | Προεπιλογή | Περιγραφή |
|---|---|---|---|
name | string | — | Όνομα εμφάνισης (Υποχρεωτικό) |
slug | string | — | Φιλικό προς URL, μοναδικό ανά Org (Υποχρεωτικό) |
default_locale | string | de | Προεπιλεγμένη γλώσσα |
approval_required | boolean | false | Ενεργοποίηση ροής εργασίας έγκρισης |
primary_color | string | — | Χρώμα επωνυμίας (#RRGGBB) |
Όρια προγραμμάτων:
| Πρόγραμμα | Μέγ. Workspaces |
|---|---|
| Free | 1 |
| Pro | 3 |
| Business | 10 |
| Agency | Απεριόριστα |
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
Αρχειοθετεί τον Workspace. Δεν μπορεί να εφαρμοστεί στον τρέχοντα Workspace.
Audit Logs
GET /v1/audit-logs
Αρχείο καταγραφής όλων των αλλαγών στον Workspace.
curl "https://qr3.app/v1/audit-logs?resource_type=codes&limit=50" \ -H "Authorization: Bearer qr3_sk_..."Παράμετροι Query:
| Παράμετρος | Τύπος | Περιγραφή |
|---|---|---|
resource_type | string | Φιλτράρισμα ανά πόρο: codes, api_keys, webhooks, workspaces |
resource_id | string | Φιλτράρισμα ανά συγκεκριμένο ID πόρου |
action | string | Φιλτράρισμα ανά ενέργεια (π.χ. codes.created) |
cursor | string | Κέρσορας σελιδοποίησης (Pagination-Cursor) |
limit | integer | Μέγ. 100 (Προεπιλογή: 50) |
Παράδειγμα απάντησης (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" } ]}