Interface MultiTenantHandler
- All Superinterfaces:
Handler<RoutingContext>
A handler which selectively executes another handler if a precondition is met.
There are cases where applications are build as multi tenant, in this cases one of the
common tasks is to configure different authentication mechanisms for each tenant.
This handler will allow registering any other handler and will only execute it if
the precondition is met. There are 2 way of defining a precondition:
- A http header value for example
X-Tenant
- A custom extractor function that can return a String from the context
- Author:
- Paulo Lopes
-
Field Summary
Fields -
Method Summary
Modifier and TypeMethodDescriptionaddDefaultHandler(Handler<RoutingContext> handler) Add a default handler for the case when no tenant was matched.addTenantHandler(String tenant, Handler<RoutingContext> handler) Add a handler for a given tenant to this handler.static MultiTenantHandlerCreate a MultiTenant handler that will extract the tenant id from a given header name.static MultiTenantHandlercreate(Function<RoutingContext, String> tenantExtractor) Create a MultiTenant handler using a custom tenant extraction function.static MultiTenantHandlercreate(Function<RoutingContext, String> tenantExtractor, String contextKey) Create a MultiTenant handler using a custom tenant extraction function.removeTenant(String tenant) Remove a handler for a given tenant from this handler.
-
Field Details
-
TENANT
-
-
Method Details
-
create
Create a MultiTenant handler that will extract the tenant id from a given header name.- Parameters:
header- the header to lookup (e.g.: "X-Tenant")- Returns:
- the new handler.
-
create
Create a MultiTenant handler using a custom tenant extraction function.- Parameters:
tenantExtractor- the function that extracts the tenant id from the request- Returns:
- the new handler.
-
create
static MultiTenantHandler create(Function<RoutingContext, String> tenantExtractor, String contextKey) Create a MultiTenant handler using a custom tenant extraction function.- Parameters:
tenantExtractor- the function that extracts the tenant id from the requestcontextKey- the custom key to store the tenant id in the context- Returns:
- the new handler.
-
addTenantHandler
Add a handler for a given tenant to this handler. Both tenant and handler cannot be null.- Parameters:
tenant- the tenant idhandler- the handler to register.- Returns:
- a fluent reference to self.
- Throws:
IllegalStateException- In case a handler is already present for that tenant.
-
removeTenant
Remove a handler for a given tenant from this handler. Tenant cannot be null.- Parameters:
tenant- the tenant id- Returns:
- a fluent reference to self.
-
addDefaultHandler
Add a default handler for the case when no tenant was matched. The handler cannot be null.- Parameters:
handler- the handler to register.- Returns:
- a fluent reference to self.
-