Organizaciones y Workspaces
Vista general
qr3.app utiliza una jerarquía de dos niveles:
Organization (Firma/Agentur) └── Workspace 1 (Kunde A) └── Workspace 2 (Kunde B) └── Workspace 3 (Internes Team)- Organización — nivel superior, asociada a una cuenta de Stripe y a un plan
- Workspace — área aislada para códigos QR, escaneos y API-Keys
API de Organizaciones
GET /v1/organizations
Devuelve la organización a la que pertenece la API-Key actual.
curl https://qr3.app/v1/organizations \ -H "Authorization: Bearer qr3_sk_..."POST /v1/organizations
Crea una nueva organización.
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]" }'Campos:
| Campo | Tipo | Obligatorio | Descripción |
|---|---|---|---|
name | string | ✅ | Nombre para mostrar (máx. 255 caracteres) |
slug | string | ✅ | Amigable para URL, único (mín. 2, máx. 63 caracteres, solo a-z0-9-) |
billing_email | string | — | Correo electrónico de facturación |
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
Eliminación lógica (soft-delete) de la organización. Todos los workspaces y códigos QR asociados se conservan, pero ya no son accesibles.
API de Workspaces
GET /v1/workspaces
Listar todos los workspaces de la organización.
curl https://qr3.app/v1/workspaces \ -H "Authorization: Bearer qr3_sk_..."POST /v1/workspaces
Crear un nuevo 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 }'Campos:
| Campo | Tipo | Por defecto | Descripción |
|---|---|---|---|
name | string | — | Nombre para mostrar (obligatorio) |
slug | string | — | Amigable para URL, único por organización (obligatorio) |
default_locale | string | de | Idioma predeterminado |
approval_required | boolean | false | Activar flujo de trabajo de aprobación |
primary_color | string | — | Color de marca (#RRGGBB) |
Límites del plan:
| Plan | Máx. Workspaces |
|---|---|
| Free | 1 |
| Pro | 3 |
| Business | 10 |
| Agency | Ilimitado |
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
Archiva el workspace. No se puede aplicar al propio workspace.
Registros de auditoría
GET /v1/audit-logs
Registro de auditoría de todos los cambios en el workspace.
curl "https://qr3.app/v1/audit-logs?resource_type=codes&limit=50" \ -H "Authorization: Bearer qr3_sk_..."Parámetros de consulta:
| Parámetro | Tipo | Descripción |
|---|---|---|
resource_type | string | Filtrar por recurso: codes, api_keys, webhooks, workspaces |
resource_id | string | Filtrar por ID de recurso específico |
action | string | Filtrar por acción (p. ej., codes.created) |
cursor | string | Cursor de paginación |
limit | integer | Máx. 100 (por defecto: 50) |
Ejemplo de respuesta:
{ "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" } ]}