Module supertokens_python.recipe.multitenancy.asyncio
Expand source code
#
# This software is licensed under the Apache License, Version 2.0 (the
# "License") as published by the Apache Software Foundation.
#
# You may not use this file except in compliance with the License. You may
# obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations
# under the License.
from __future__ import annotations
from typing import Any, Dict, Union, Optional, TYPE_CHECKING
from ..interfaces import (
TenantConfig,
CreateOrUpdateTenantOkResult,
DeleteTenantOkResult,
GetTenantOkResult,
ListAllTenantsOkResult,
CreateOrUpdateThirdPartyConfigOkResult,
DeleteThirdPartyConfigOkResult,
AssociateUserToTenantOkResult,
AssociateUserToTenantUnknownUserIdError,
AssociateUserToTenantEmailAlreadyExistsError,
AssociateUserToTenantPhoneNumberAlreadyExistsError,
AssociateUserToTenantThirdPartyUserAlreadyExistsError,
DisassociateUserFromTenantOkResult,
)
from ..recipe import MultitenancyRecipe
if TYPE_CHECKING:
from ..interfaces import ProviderConfig
async def create_or_update_tenant(
tenant_id: str,
config: Optional[TenantConfig],
user_context: Optional[Dict[str, Any]] = None,
) -> CreateOrUpdateTenantOkResult:
if user_context is None:
user_context = {}
recipe = MultitenancyRecipe.get_instance()
return await recipe.recipe_implementation.create_or_update_tenant(
tenant_id, config, user_context
)
async def delete_tenant(
tenant_id: str, user_context: Optional[Dict[str, Any]] = None
) -> DeleteTenantOkResult:
if user_context is None:
user_context = {}
recipe = MultitenancyRecipe.get_instance()
return await recipe.recipe_implementation.delete_tenant(tenant_id, user_context)
async def get_tenant(
tenant_id: str, user_context: Optional[Dict[str, Any]] = None
) -> Optional[GetTenantOkResult]:
if user_context is None:
user_context = {}
recipe = MultitenancyRecipe.get_instance()
return await recipe.recipe_implementation.get_tenant(tenant_id, user_context)
async def list_all_tenants(
user_context: Optional[Dict[str, Any]] = None
) -> ListAllTenantsOkResult:
if user_context is None:
user_context = {}
recipe = MultitenancyRecipe.get_instance()
return await recipe.recipe_implementation.list_all_tenants(user_context)
async def create_or_update_third_party_config(
tenant_id: str,
config: ProviderConfig,
skip_validation: Optional[bool] = None,
user_context: Optional[Dict[str, Any]] = None,
) -> CreateOrUpdateThirdPartyConfigOkResult:
if user_context is None:
user_context = {}
recipe = MultitenancyRecipe.get_instance()
return await recipe.recipe_implementation.create_or_update_third_party_config(
tenant_id, config, skip_validation, user_context
)
async def delete_third_party_config(
tenant_id: str,
third_party_id: str,
user_context: Optional[Dict[str, Any]] = None,
) -> DeleteThirdPartyConfigOkResult:
if user_context is None:
user_context = {}
recipe = MultitenancyRecipe.get_instance()
return await recipe.recipe_implementation.delete_third_party_config(
tenant_id, third_party_id, user_context
)
async def associate_user_to_tenant(
tenant_id: str,
user_id: str,
user_context: Optional[Dict[str, Any]] = None,
) -> Union[
AssociateUserToTenantOkResult,
AssociateUserToTenantUnknownUserIdError,
AssociateUserToTenantEmailAlreadyExistsError,
AssociateUserToTenantPhoneNumberAlreadyExistsError,
AssociateUserToTenantThirdPartyUserAlreadyExistsError,
]:
if user_context is None:
user_context = {}
recipe = MultitenancyRecipe.get_instance()
return await recipe.recipe_implementation.associate_user_to_tenant(
tenant_id, user_id, user_context
)
async def dissociate_user_from_tenant(
tenant_id: str,
user_id: str,
user_context: Optional[Dict[str, Any]] = None,
) -> DisassociateUserFromTenantOkResult:
if user_context is None:
user_context = {}
recipe = MultitenancyRecipe.get_instance()
return await recipe.recipe_implementation.dissociate_user_from_tenant(
tenant_id, user_id, user_context
)
Functions
async def associate_user_to_tenant(tenant_id: str, user_id: str, user_context: Optional[Dict[str, Any]] = None) ‑> Union[AssociateUserToTenantOkResult, AssociateUserToTenantUnknownUserIdError, AssociateUserToTenantEmailAlreadyExistsError, AssociateUserToTenantPhoneNumberAlreadyExistsError, AssociateUserToTenantThirdPartyUserAlreadyExistsError]
-
Expand source code
async def associate_user_to_tenant( tenant_id: str, user_id: str, user_context: Optional[Dict[str, Any]] = None, ) -> Union[ AssociateUserToTenantOkResult, AssociateUserToTenantUnknownUserIdError, AssociateUserToTenantEmailAlreadyExistsError, AssociateUserToTenantPhoneNumberAlreadyExistsError, AssociateUserToTenantThirdPartyUserAlreadyExistsError, ]: if user_context is None: user_context = {} recipe = MultitenancyRecipe.get_instance() return await recipe.recipe_implementation.associate_user_to_tenant( tenant_id, user_id, user_context )
async def create_or_update_tenant(tenant_id: str, config: Optional[TenantConfig], user_context: Optional[Dict[str, Any]] = None) ‑> CreateOrUpdateTenantOkResult
-
Expand source code
async def create_or_update_tenant( tenant_id: str, config: Optional[TenantConfig], user_context: Optional[Dict[str, Any]] = None, ) -> CreateOrUpdateTenantOkResult: if user_context is None: user_context = {} recipe = MultitenancyRecipe.get_instance() return await recipe.recipe_implementation.create_or_update_tenant( tenant_id, config, user_context )
async def create_or_update_third_party_config(tenant_id: str, config: ProviderConfig, skip_validation: Optional[bool] = None, user_context: Optional[Dict[str, Any]] = None) ‑> CreateOrUpdateThirdPartyConfigOkResult
-
Expand source code
async def create_or_update_third_party_config( tenant_id: str, config: ProviderConfig, skip_validation: Optional[bool] = None, user_context: Optional[Dict[str, Any]] = None, ) -> CreateOrUpdateThirdPartyConfigOkResult: if user_context is None: user_context = {} recipe = MultitenancyRecipe.get_instance() return await recipe.recipe_implementation.create_or_update_third_party_config( tenant_id, config, skip_validation, user_context )
async def delete_tenant(tenant_id: str, user_context: Optional[Dict[str, Any]] = None) ‑> DeleteTenantOkResult
-
Expand source code
async def delete_tenant( tenant_id: str, user_context: Optional[Dict[str, Any]] = None ) -> DeleteTenantOkResult: if user_context is None: user_context = {} recipe = MultitenancyRecipe.get_instance() return await recipe.recipe_implementation.delete_tenant(tenant_id, user_context)
async def delete_third_party_config(tenant_id: str, third_party_id: str, user_context: Optional[Dict[str, Any]] = None) ‑> DeleteThirdPartyConfigOkResult
-
Expand source code
async def delete_third_party_config( tenant_id: str, third_party_id: str, user_context: Optional[Dict[str, Any]] = None, ) -> DeleteThirdPartyConfigOkResult: if user_context is None: user_context = {} recipe = MultitenancyRecipe.get_instance() return await recipe.recipe_implementation.delete_third_party_config( tenant_id, third_party_id, user_context )
async def dissociate_user_from_tenant(tenant_id: str, user_id: str, user_context: Optional[Dict[str, Any]] = None) ‑> DisassociateUserFromTenantOkResult
-
Expand source code
async def dissociate_user_from_tenant( tenant_id: str, user_id: str, user_context: Optional[Dict[str, Any]] = None, ) -> DisassociateUserFromTenantOkResult: if user_context is None: user_context = {} recipe = MultitenancyRecipe.get_instance() return await recipe.recipe_implementation.dissociate_user_from_tenant( tenant_id, user_id, user_context )
async def get_tenant(tenant_id: str, user_context: Optional[Dict[str, Any]] = None) ‑> Optional[GetTenantOkResult]
-
Expand source code
async def get_tenant( tenant_id: str, user_context: Optional[Dict[str, Any]] = None ) -> Optional[GetTenantOkResult]: if user_context is None: user_context = {} recipe = MultitenancyRecipe.get_instance() return await recipe.recipe_implementation.get_tenant(tenant_id, user_context)
async def list_all_tenants(user_context: Optional[Dict[str, Any]] = None) ‑> ListAllTenantsOkResult
-
Expand source code
async def list_all_tenants( user_context: Optional[Dict[str, Any]] = None ) -> ListAllTenantsOkResult: if user_context is None: user_context = {} recipe = MultitenancyRecipe.get_instance() return await recipe.recipe_implementation.list_all_tenants(user_context)