Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

Table of Contents
stylecircle
typeflat

Die CoreOne Suite ist mandantenfähig. Die Mandantenfähigkeit kann auf verschiedene Varianten umgesetzt werden.

Image Removed

Logische Trennung

  • Datensätze pro Mandant
  • Die Daten werden in einer Datenbank gespeichert.
  • Jedes Objekt erhält eine Mandantenzuweisung
  • Die Daten sind logisch und nicht physisch getrennt

Es ergeben sich folgende Vorteile:

  • Es kann entschieden werden, welche Daten mit welchen Mandanten geteilt werden sollen
  • Es ist möglich ein Rollenmodel pro Mandant zu führen
  • Es können Mandanten übergreifende Rollen konfiguriert werden
  • Ein System für alle Mandanten
  • Lizenzierte Funktionen, Features und Module können allen Mandanten zur Verfügung gestellt werden
  • Es können SaaS-Funktionen genutzt werden wie zum Beispiel dynamisches Registrieren eines neuen Mandanten (IAMaaS).
  • Federation innerhalb der Mandanten ist möglich

Logische Trennung bis auf Datenbank Ebene

  • Eine dedizierte Datenbank pro Mandant

Es ergeben sich die folgenden Synergien und Vorteile:

  • Ein System für alle Mandanten
  • Lizenzierte Funktionen, Features und Module können allen Mandanten zur Verfügung gestellt werden
  • Es können SaaS-Funktionen genutzt werden wie zum Beispiel dynamisches Registrieren eines neuen Mandanten (IAMaaS).
  • Ausgewählte Daten / Stammdaten können über die Mandanten geteilt werden.
  • Federation innerhalb der Mandante ist möglich

Vollständige Trennung

  • Pro Mandant wird ein dediziertes System zur Verfügung gestellt.

Es ergeben sich die folgenden Synergien und Vorteile: 

...

Introduction

The CoreOne Suite offers various tools and patterns to cover a multi tenancy environment. Depending on the use case you can choose one deployment scenario or even combine some of them. Below you will find an overview of all possible deployments.

...

Logical Tenant Seperation

Each entity within the CoreOne Suite Meta Directory has a tenant_id associated with it that references the tenant entity. That entity itself has a parent_id and let’s you therefore create a logical tenant tree. By assigning each entity to a logical tenant you clearly associate each entity to said tenant. In many places that association will then be taken into account. To give an example we can look at the organizational tree and the employments. If you create a new employment, you first have to select the tenant that this employment belongs to. Dependend on the selected tenant, you then can only select organizational units that are associated to that tenant.

The following rules apply for this deployment scenario:

  • Each data record is associated to a tenant

  • There is one single database, the data storage is not separated for multiple tenants

  • The actual data is not physically divided, there is only one AppCustomer

Advantages

Disadvantages

The underlying hardware is the same for all tenants.

A misconfiguration of the security rules can lead to sharing data with other tenants.

Licencing is shared across all tenants.

SaaS functions can be used, such as dynamic registration of a new tenant (IAMaaS).

Selected data / master data can be shared across tenants.

All services are hosted for all tenants.

AppCustomer Seperation

The CoreOne Suite supports the creation of multiple AppCustomers. An AppCustomer is represented as a seperated schema within the same database. Therefore the underlying hardware can be shared but the data is stored in a dedicated schema and therefore logically seperated from other AppCustomers.

The following rules apply for this deployment scenario:

  • Data records are stored in the appropriate AppCustomer schemas

  • There is one single database, but data storage is seperated on schema level

  • The actual data is logically divided, there are multiple AppCustomers

Advantages

Disadvantages

The underlying hardware is the same for all tenants.

Additional complexity in the configuration.

Licencing is shared across all tenants.

Certain services have to be hosted for each AppCustomer (Portal, Auth).

SaaS functions can be used, such as dynamic registration of a new tenant (IAMaaS).

Selected data / master data can be shared across tenants.

Data is further divided. The risk of accidentally sharing data with other tenants is mitigated.

Physical Seperation

By actually installing the CoreOne Suite multiple times the data is completely separated.

Advantages

Disadvantages

The data is completely separated.

Additional complexity.

Licences have to be ordered for each installation.

No dynamic registration of new tenants.

Logical Security Seperation

With the Advanced Permission Management of the CoreOne Suite you can configure security roles that gives users access to only selected data. This allows you to configure a wide variety of use cases with endless complexity. You can configure use cases such as give users only access to data that is associated to an organizational unit below the Legal Entity that they are employed to.

Advantages

Disadvantages

The underlying hardware is the same for all tenants.

Additional complexity in the configuration.

Licencing is shared across all tenants.

The evaluation of the security roles can be slow depending on the use case and data amount.

SaaS functions can be used, such as dynamic registration of a new tenant (IAMaaS).

Selected data / master data can be shared across tenants.

Data is further divided. The risk of accidentally sharing data with other tenants is mitigated.

Complex use cases can be configured.

Combining

All the described deployment scenarios can be combined. This allows you to find the best combination for your use cases. It’s also possible to migrate from one deployment scenario to another. But be aware that even though this is possible, it’s not an easy task to do. So be sure to select the ideal scenario for your use case.

Things to consider

Authentication

Each App Customer and each separate instance has its own Identity Provider and therefore its own user base. Especially when using the system as an IdP, this has major implications as usually a relying party only has one IdP associated. Let’s assume you have an customer relationship portal where both employee as well as customers should have access to. You could seperate the customers in one AppCustomer and the employees into another AppCustomer, giving you a clear seperation of the data. For the customer relationship portal you are now facing the challenge, that the portal only has one IdP. So you need to either choose the customer AppCustomer and configure a federation for the employees or combine both user groups in one AppCustomer.