Salta ai contenuti

Organizzazioni e Workspace

Panoramica

qr3.app utilizza una gerarchia a due livelli:

Organization (Firma/Agentur)
└── Workspace 1 (Kunde A)
└── Workspace 2 (Kunde B)
└── Workspace 3 (Internes Team)
  • Organizzazione — livello superiore, associato a un account Stripe e a un piano
  • Workspace — area isolata per codici QR, scansioni e API-Key

API Organizations

GET /v1/organizations

Restituisce l’organizzazione a cui appartiene l’API-Key corrente.

Terminal window
curl https://qr3.app/v1/organizations \
-H "Authorization: Bearer qr3_sk_..."

POST /v1/organizations

Crea una nuova organizzazione.

Terminal window
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]"
}'

Campi:

CampoTipoObbligatorioDescrizione
namestringNome visualizzato (max. 255 caratteri)
slugstringURL-friendly, univoco (min. 2, max. 63 caratteri, solo a-z0-9-)
billing_emailstringE-mail di fatturazione

PATCH /v1/organizations/:id

Terminal window
curl -X PATCH https://qr3.app/v1/organizations/org_a1b2c3 \
-H "Authorization: Bearer qr3_sk_..." \
-H "Content-Type: application/json" \
-d '{ "name": "Digital Heroes AG", "billing_email": "[email protected]" }'

DELETE /v1/organizations/:id

Eliminazione logica (soft-delete) dell’organizzazione. Tutti i workspace e i codici QR associati vengono conservati, ma non sono più accessibili.


API Workspaces

GET /v1/workspaces

Elenca tutti i workspace dell’organizzazione.

Terminal window
curl https://qr3.app/v1/workspaces \
-H "Authorization: Bearer qr3_sk_..."

POST /v1/workspaces

Crea un nuovo workspace.

Terminal window
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
}'

Campi:

CampoTipoPredefinitoDescrizione
namestringNome visualizzato (obbligatorio)
slugstringURL-friendly, univoco per organizzazione (obbligatorio)
default_localestringdeLingua predefinita
approval_requiredbooleanfalseAttiva flusso di approvazione
primary_colorstringColore del brand (#RRGGBB)

Limiti del piano:

PianoMax. workspace
Free1
Pro3
Business10
AgencyIllimitati

PATCH /v1/workspaces/:id

Terminal window
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

Archivia il workspace. Non può essere applicato al proprio workspace.


Audit Log

GET /v1/audit-logs

Registro tracciabile di tutte le modifiche nel workspace.

Terminal window
curl "https://qr3.app/v1/audit-logs?resource_type=codes&limit=50" \
-H "Authorization: Bearer qr3_sk_..."

Parametri di query:

ParametroTipoDescrizione
resource_typestringFiltra per risorsa: codes, api_keys, webhooks, workspaces
resource_idstringFiltra per ID risorsa specifico
actionstringFiltra per azione (es. codes.created)
cursorstringCursore di paginazione
limitintegerMax. 100 (predefinito: 50)

Esempio di risposta:

{
"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"
}
]
}