Saltar a contenido

Multi-tenant

EUDIStack es una plataforma multi-tenant: cada organización cliente opera como un tenant aislado con su propia configuración, branding, credenciales criptográficas y recursos dedicados.

El aislamiento multi-tenant permite que múltiples organizaciones compartan la misma infraestructura EUDIStack sin mezclar datos, identidades ni configuraciones.


Arquitectura multi-tenant

Los componentes frontend y backend distinguen automáticamente el tenant a partir del dominio utilizado en cada request.

flowchart LR
    A[Wallet / Client Application]

    A --> B[sandbox-stg.eudistack.net]
    A --> C[dome-stg.eudistack.net]

    B --> D[Shared Issuer Backend]
    C --> D

    D --> E[(Tenant: sandbox)]
    D --> F[(Tenant: dome)]

Identificación del tenant

El tenant se resuelve automáticamente a partir del subdominio de la petición. Tu integración no necesita pasar el tenant explícitamente en headers ni parámetros.

Ejemplos de resolución de tenant
URL Tenant resuelto
sandbox-stg.eudistack.net sandbox
dome-stg.eudistack.net dome
kpmg-stg.eudistack.net kpmg

Aislamiento por recurso

Tabla de aislamiento
Recurso Aislamiento
Base de datos Schema dedicado en PostgreSQL (schema-per-tenant).
Frontends (Wallet, Portal) Despliegue/distribución dedicada con branding propio.
Backends (Issuer, Verifier, EBW) Compartidos, distinguen tenant por Host header.
Claves criptográficas Independientes por tenant.
Status Lists URLs propias por tenant.

Implicaciones para integradores

Lo que debes tener en cuenta
  • Cross-tenant no es posible: una credencial emitida en tenant A no la puede recibir un wallet del tenant B (mismo origen requerido).
  • Una integración por tenant: si trabajas con varios tenants, configura un cliente por cada uno.
  • Branding: cada tenant ve su logo, paleta y nombres en wallet, portales y emails. La identidad es transparente para tu integración.
  • Seguridad: los backends compartidos nunca mezclan datos entre tenants y todas las operaciones se ejecutan dentro del contexto resuelto desde el dominio de entrada.