Module supertokens_python.recipe.emailverification.interfaces
Expand source code
# Copyright (c) 2021, VRAI Labs and/or its affiliates. All rights reserved.
#
# 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 abc import ABC, abstractmethod
from typing import TYPE_CHECKING, Any, Dict, Union
from supertokens_python.ingredients.emaildelivery import \
EmailDeliveryIngredient
from supertokens_python.types import APIResponse
if TYPE_CHECKING:
from supertokens_python.framework import BaseRequest, BaseResponse
from .types import User
from .utils import EmailVerificationConfig
class CreateEmailVerificationTokenOkResult:
def __init__(self, token: str):
self.token = token
class CreateEmailVerificationTokenEmailAlreadyVerifiedError:
pass
class VerifyEmailUsingTokenOkResult:
def __init__(self, user: User):
self.user = user
class VerifyEmailUsingTokenInvalidTokenError:
pass
class RevokeEmailVerificationTokensOkResult:
pass
class UnverifyEmailOkResult:
pass
class RecipeInterface(ABC):
def __init__(self):
pass
@abstractmethod
async def create_email_verification_token(self, user_id: str, email: str, user_context: Dict[str, Any]) -> Union[CreateEmailVerificationTokenOkResult, CreateEmailVerificationTokenEmailAlreadyVerifiedError]:
pass
@abstractmethod
async def verify_email_using_token(self, token: str, user_context: Dict[str, Any]) -> Union[VerifyEmailUsingTokenOkResult, VerifyEmailUsingTokenInvalidTokenError]:
pass
@abstractmethod
async def is_email_verified(self, user_id: str, email: str, user_context: Dict[str, Any]) -> bool:
pass
@abstractmethod
async def revoke_email_verification_tokens(self, user_id: str, email: str, user_context: Dict[str, Any]) -> RevokeEmailVerificationTokensOkResult:
pass
@abstractmethod
async def unverify_email(self, user_id: str, email: str, user_context: Dict[str, Any]) -> UnverifyEmailOkResult:
pass
class APIOptions:
def __init__(self, request: BaseRequest, response: BaseResponse, recipe_id: str,
config: EmailVerificationConfig, recipe_implementation: RecipeInterface,
email_delivery: EmailDeliveryIngredient[TypeEmailVerificationEmailDeliveryInput]):
self.request = request
self.response = response
self.recipe_id = recipe_id
self.config = config
self.recipe_implementation = recipe_implementation
self.email_delivery = email_delivery
class EmailVerifyPostOkResult(APIResponse):
def __init__(self, user: User):
self.user = user
self.status = "OK"
def to_json(self) -> Dict[str, Any]:
return {
'status': self.status,
'user': {
'id': self.user.user_id,
'email': self.user.email
}
}
class EmailVerifyPostInvalidTokenError(APIResponse):
def __init__(self):
self.status = "EMAIL_VERIFICATION_INVALID_TOKEN_ERROR"
def to_json(self) -> Dict[str, Any]:
return {
'status': self.status
}
class IsEmailVerifiedGetOkResult(APIResponse):
def __init__(self, is_verified: bool):
self.status = 'OK'
self.is_verified = is_verified
def to_json(self) -> Dict[str, Any]:
return {
'status': self.status,
'isVerified': self.is_verified
}
class GenerateEmailVerifyTokenPostOkResult(
APIResponse):
def __init__(self):
self.status = 'OK'
def to_json(self) -> Dict[str, Any]:
return {
'status': self.status
}
class GenerateEmailVerifyTokenPostEmailAlreadyVerifiedError(
APIResponse):
def __init__(self):
self.status = 'EMAIL_ALREADY_VERIFIED_ERROR'
def to_json(self) -> Dict[str, Any]:
return {
'status': self.status
}
class TypeEmailVerificationEmailDeliveryInputUser:
def __init__(self, user_id: str, email: str):
self.id = user_id
self.email = email
class TypeEmailVerificationEmailDeliveryInput:
def __init__(
self,
user: TypeEmailVerificationEmailDeliveryInputUser,
email_verify_link: str,
user_context: Dict[str, Any],
) -> None:
self.user = user
self.email_verify_link = email_verify_link
self.user_context = user_context
class APIInterface(ABC):
def __init__(self):
self.disable_email_verify_post = False
self.disable_is_email_verified_get = False
self.disable_generate_email_verify_token_post = False
@abstractmethod
async def email_verify_post(self, token: str, api_options: APIOptions, user_context: Dict[str, Any]) -> Union[EmailVerifyPostOkResult, EmailVerifyPostInvalidTokenError]:
pass
@abstractmethod
async def is_email_verified_get(self, api_options: APIOptions, user_context: Dict[str, Any]) -> IsEmailVerifiedGetOkResult:
pass
@abstractmethod
async def generate_email_verify_token_post(self, api_options: APIOptions,
user_context: Dict[str, Any]) -> Union[GenerateEmailVerifyTokenPostOkResult, GenerateEmailVerifyTokenPostEmailAlreadyVerifiedError]:
pass
Classes
class APIInterface
-
Helper class that provides a standard way to create an ABC using inheritance.
Expand source code
class APIInterface(ABC): def __init__(self): self.disable_email_verify_post = False self.disable_is_email_verified_get = False self.disable_generate_email_verify_token_post = False @abstractmethod async def email_verify_post(self, token: str, api_options: APIOptions, user_context: Dict[str, Any]) -> Union[EmailVerifyPostOkResult, EmailVerifyPostInvalidTokenError]: pass @abstractmethod async def is_email_verified_get(self, api_options: APIOptions, user_context: Dict[str, Any]) -> IsEmailVerifiedGetOkResult: pass @abstractmethod async def generate_email_verify_token_post(self, api_options: APIOptions, user_context: Dict[str, Any]) -> Union[GenerateEmailVerifyTokenPostOkResult, GenerateEmailVerifyTokenPostEmailAlreadyVerifiedError]: pass
Ancestors
- abc.ABC
Subclasses
Methods
async def email_verify_post(self, token: str, api_options: APIOptions, user_context: Dict[str, Any]) ‑> Union[EmailVerifyPostOkResult, EmailVerifyPostInvalidTokenError]
-
Expand source code
@abstractmethod async def email_verify_post(self, token: str, api_options: APIOptions, user_context: Dict[str, Any]) -> Union[EmailVerifyPostOkResult, EmailVerifyPostInvalidTokenError]: pass
async def generate_email_verify_token_post(self, api_options: APIOptions, user_context: Dict[str, Any]) ‑> Union[GenerateEmailVerifyTokenPostOkResult, GenerateEmailVerifyTokenPostEmailAlreadyVerifiedError]
-
Expand source code
@abstractmethod async def generate_email_verify_token_post(self, api_options: APIOptions, user_context: Dict[str, Any]) -> Union[GenerateEmailVerifyTokenPostOkResult, GenerateEmailVerifyTokenPostEmailAlreadyVerifiedError]: pass
async def is_email_verified_get(self, api_options: APIOptions, user_context: Dict[str, Any]) ‑> IsEmailVerifiedGetOkResult
-
Expand source code
@abstractmethod async def is_email_verified_get(self, api_options: APIOptions, user_context: Dict[str, Any]) -> IsEmailVerifiedGetOkResult: pass
class APIOptions (request: BaseRequest, response: BaseResponse, recipe_id: str, config: EmailVerificationConfig, recipe_implementation: RecipeInterface, email_delivery: EmailDeliveryIngredient[TypeEmailVerificationEmailDeliveryInput])
-
Expand source code
class APIOptions: def __init__(self, request: BaseRequest, response: BaseResponse, recipe_id: str, config: EmailVerificationConfig, recipe_implementation: RecipeInterface, email_delivery: EmailDeliveryIngredient[TypeEmailVerificationEmailDeliveryInput]): self.request = request self.response = response self.recipe_id = recipe_id self.config = config self.recipe_implementation = recipe_implementation self.email_delivery = email_delivery
class CreateEmailVerificationTokenEmailAlreadyVerifiedError
-
Expand source code
class CreateEmailVerificationTokenEmailAlreadyVerifiedError: pass
class CreateEmailVerificationTokenOkResult (token: str)
-
Expand source code
class CreateEmailVerificationTokenOkResult: def __init__(self, token: str): self.token = token
class EmailVerifyPostInvalidTokenError
-
Helper class that provides a standard way to create an ABC using inheritance.
Expand source code
class EmailVerifyPostInvalidTokenError(APIResponse): def __init__(self): self.status = "EMAIL_VERIFICATION_INVALID_TOKEN_ERROR" def to_json(self) -> Dict[str, Any]: return { 'status': self.status }
Ancestors
- APIResponse
- abc.ABC
Methods
def to_json(self) ‑> Dict[str, Any]
-
Expand source code
def to_json(self) -> Dict[str, Any]: return { 'status': self.status }
class EmailVerifyPostOkResult (user: User)
-
Helper class that provides a standard way to create an ABC using inheritance.
Expand source code
class EmailVerifyPostOkResult(APIResponse): def __init__(self, user: User): self.user = user self.status = "OK" def to_json(self) -> Dict[str, Any]: return { 'status': self.status, 'user': { 'id': self.user.user_id, 'email': self.user.email } }
Ancestors
- APIResponse
- abc.ABC
Methods
def to_json(self) ‑> Dict[str, Any]
-
Expand source code
def to_json(self) -> Dict[str, Any]: return { 'status': self.status, 'user': { 'id': self.user.user_id, 'email': self.user.email } }
class GenerateEmailVerifyTokenPostEmailAlreadyVerifiedError
-
Helper class that provides a standard way to create an ABC using inheritance.
Expand source code
class GenerateEmailVerifyTokenPostEmailAlreadyVerifiedError( APIResponse): def __init__(self): self.status = 'EMAIL_ALREADY_VERIFIED_ERROR' def to_json(self) -> Dict[str, Any]: return { 'status': self.status }
Ancestors
- APIResponse
- abc.ABC
Methods
def to_json(self) ‑> Dict[str, Any]
-
Expand source code
def to_json(self) -> Dict[str, Any]: return { 'status': self.status }
class GenerateEmailVerifyTokenPostOkResult
-
Helper class that provides a standard way to create an ABC using inheritance.
Expand source code
class GenerateEmailVerifyTokenPostOkResult( APIResponse): def __init__(self): self.status = 'OK' def to_json(self) -> Dict[str, Any]: return { 'status': self.status }
Ancestors
- APIResponse
- abc.ABC
Methods
def to_json(self) ‑> Dict[str, Any]
-
Expand source code
def to_json(self) -> Dict[str, Any]: return { 'status': self.status }
class IsEmailVerifiedGetOkResult (is_verified: bool)
-
Helper class that provides a standard way to create an ABC using inheritance.
Expand source code
class IsEmailVerifiedGetOkResult(APIResponse): def __init__(self, is_verified: bool): self.status = 'OK' self.is_verified = is_verified def to_json(self) -> Dict[str, Any]: return { 'status': self.status, 'isVerified': self.is_verified }
Ancestors
- APIResponse
- abc.ABC
Methods
def to_json(self) ‑> Dict[str, Any]
-
Expand source code
def to_json(self) -> Dict[str, Any]: return { 'status': self.status, 'isVerified': self.is_verified }
class RecipeInterface
-
Helper class that provides a standard way to create an ABC using inheritance.
Expand source code
class RecipeInterface(ABC): def __init__(self): pass @abstractmethod async def create_email_verification_token(self, user_id: str, email: str, user_context: Dict[str, Any]) -> Union[CreateEmailVerificationTokenOkResult, CreateEmailVerificationTokenEmailAlreadyVerifiedError]: pass @abstractmethod async def verify_email_using_token(self, token: str, user_context: Dict[str, Any]) -> Union[VerifyEmailUsingTokenOkResult, VerifyEmailUsingTokenInvalidTokenError]: pass @abstractmethod async def is_email_verified(self, user_id: str, email: str, user_context: Dict[str, Any]) -> bool: pass @abstractmethod async def revoke_email_verification_tokens(self, user_id: str, email: str, user_context: Dict[str, Any]) -> RevokeEmailVerificationTokensOkResult: pass @abstractmethod async def unverify_email(self, user_id: str, email: str, user_context: Dict[str, Any]) -> UnverifyEmailOkResult: pass
Ancestors
- abc.ABC
Subclasses
Methods
async def create_email_verification_token(self, user_id: str, email: str, user_context: Dict[str, Any]) ‑> Union[CreateEmailVerificationTokenOkResult, CreateEmailVerificationTokenEmailAlreadyVerifiedError]
-
Expand source code
@abstractmethod async def create_email_verification_token(self, user_id: str, email: str, user_context: Dict[str, Any]) -> Union[CreateEmailVerificationTokenOkResult, CreateEmailVerificationTokenEmailAlreadyVerifiedError]: pass
async def is_email_verified(self, user_id: str, email: str, user_context: Dict[str, Any]) ‑> bool
-
Expand source code
@abstractmethod async def is_email_verified(self, user_id: str, email: str, user_context: Dict[str, Any]) -> bool: pass
async def revoke_email_verification_tokens(self, user_id: str, email: str, user_context: Dict[str, Any]) ‑> RevokeEmailVerificationTokensOkResult
-
Expand source code
@abstractmethod async def revoke_email_verification_tokens(self, user_id: str, email: str, user_context: Dict[str, Any]) -> RevokeEmailVerificationTokensOkResult: pass
async def unverify_email(self, user_id: str, email: str, user_context: Dict[str, Any]) ‑> UnverifyEmailOkResult
-
Expand source code
@abstractmethod async def unverify_email(self, user_id: str, email: str, user_context: Dict[str, Any]) -> UnverifyEmailOkResult: pass
async def verify_email_using_token(self, token: str, user_context: Dict[str, Any]) ‑> Union[VerifyEmailUsingTokenOkResult, VerifyEmailUsingTokenInvalidTokenError]
-
Expand source code
@abstractmethod async def verify_email_using_token(self, token: str, user_context: Dict[str, Any]) -> Union[VerifyEmailUsingTokenOkResult, VerifyEmailUsingTokenInvalidTokenError]: pass
class RevokeEmailVerificationTokensOkResult
-
Expand source code
class RevokeEmailVerificationTokensOkResult: pass
class TypeEmailVerificationEmailDeliveryInput (user: TypeEmailVerificationEmailDeliveryInputUser, email_verify_link: str, user_context: Dict[str, Any])
-
Expand source code
class TypeEmailVerificationEmailDeliveryInput: def __init__( self, user: TypeEmailVerificationEmailDeliveryInputUser, email_verify_link: str, user_context: Dict[str, Any], ) -> None: self.user = user self.email_verify_link = email_verify_link self.user_context = user_context
class TypeEmailVerificationEmailDeliveryInputUser (user_id: str, email: str)
-
Expand source code
class TypeEmailVerificationEmailDeliveryInputUser: def __init__(self, user_id: str, email: str): self.id = user_id self.email = email
class UnverifyEmailOkResult
-
Expand source code
class UnverifyEmailOkResult: pass
class VerifyEmailUsingTokenInvalidTokenError
-
Expand source code
class VerifyEmailUsingTokenInvalidTokenError: pass
class VerifyEmailUsingTokenOkResult (user: User)
-
Expand source code
class VerifyEmailUsingTokenOkResult: def __init__(self, user: User): self.user = user