Module supertokens_python.ingredients.smsdelivery.types
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 abc import ABC, abstractmethod
from typing import Any, Callable, Dict, Generic, TypeVar, Union
from twilio.rest import Client  # type: ignore
_T = TypeVar("_T")
class SMSDeliveryInterface(ABC, Generic[_T]):
    @abstractmethod
    async def send_sms(self, template_vars: _T, user_context: Dict[str, Any]) -> None:
        pass
class SMSDeliveryConfig(ABC, Generic[_T]):
    def __init__(
        self,
        service: Union[SMSDeliveryInterface[_T], None] = None,
        override: Union[
            Callable[[SMSDeliveryInterface[_T]], SMSDeliveryInterface[_T]], None
        ] = None,
    ) -> None:
        self.service = service
        self.override = override
class SMSDeliveryConfigWithService(ABC, Generic[_T]):
    def __init__(
        self,
        service: SMSDeliveryInterface[_T],
        override: Union[
            Callable[[SMSDeliveryInterface[_T]], SMSDeliveryInterface[_T]], None
        ] = None,
    ) -> None:
        self.service = service
        self.override = override
class TwilioSettings:
    def __init__(
        self,
        account_sid: str,
        auth_token: str,
        from_: Union[str, None] = None,
        messaging_service_sid: Union[str, None] = None,
        opts: Union[Dict[str, Any], None] = None,
    ) -> None:
        """
        Note: `self.otps` can be used to override values passed to the Twilio Client.
        Read docs from `twilio.rest.Client.__init__` to discover possible args.
        For example, `opts = {"region": "...", "user_agent_extensions": ["..."], }`
        """
        self.account_sid = account_sid
        self.auth_token = auth_token
        self.from_ = from_
        self.messaging_service_sid = messaging_service_sid
        self.opts = opts
class SMSContent:
    def __init__(self, body: str, to_phone: str) -> None:
        self.body = body
        self.to_phone = to_phone
class TwilioServiceInterface(ABC, Generic[_T]):
    def __init__(self, twilio_client: Client) -> None:  # type: ignore
        self.twilio_client = twilio_client  # type: ignore
    @abstractmethod
    async def send_raw_sms(
        self,
        content: SMSContent,
        user_context: Dict[str, Any],
        from_: Union[str, None] = None,
        messaging_service_sid: Union[str, None] = None,
    ) -> None:
        pass
    @abstractmethod
    async def get_content(
        self, template_vars: _T, user_context: Dict[str, Any]
    ) -> SMSContent:
        passClasses
- class SMSContent (body: str, to_phone: str)
- 
Expand source codeclass SMSContent: def __init__(self, body: str, to_phone: str) -> None: self.body = body self.to_phone = to_phone
- class SMSDeliveryConfig (service: Optional[SMSDeliveryInterface[~_T]] = None, override: Optional[Callable[[SMSDeliveryInterface[~_T]], SMSDeliveryInterface[~_T]]] = None)
- 
Helper class that provides a standard way to create an ABC using inheritance. Expand source codeclass SMSDeliveryConfig(ABC, Generic[_T]): def __init__( self, service: Union[SMSDeliveryInterface[_T], None] = None, override: Union[ Callable[[SMSDeliveryInterface[_T]], SMSDeliveryInterface[_T]], None ] = None, ) -> None: self.service = service self.override = overrideAncestors- abc.ABC
- typing.Generic
 
- class SMSDeliveryConfigWithService (service: SMSDeliveryInterface[~_T], override: Optional[Callable[[SMSDeliveryInterface[~_T]], SMSDeliveryInterface[~_T]]] = None)
- 
Helper class that provides a standard way to create an ABC using inheritance. Expand source codeclass SMSDeliveryConfigWithService(ABC, Generic[_T]): def __init__( self, service: SMSDeliveryInterface[_T], override: Union[ Callable[[SMSDeliveryInterface[_T]], SMSDeliveryInterface[_T]], None ] = None, ) -> None: self.service = service self.override = overrideAncestors- abc.ABC
- typing.Generic
 
- class SMSDeliveryInterface
- 
Helper class that provides a standard way to create an ABC using inheritance. Expand source codeclass SMSDeliveryInterface(ABC, Generic[_T]): @abstractmethod async def send_sms(self, template_vars: _T, user_context: Dict[str, Any]) -> None: passAncestors- abc.ABC
- typing.Generic
 Subclasses- BackwardCompatibilityService
- SuperTokensSMSService
- TwilioService
- BackwardCompatibilityService
- SuperTokensSMSService
- TwilioService
 Methods- async def send_sms(self, template_vars: ~_T, user_context: Dict[str, Any]) ‑> None
- 
Expand source code@abstractmethod async def send_sms(self, template_vars: _T, user_context: Dict[str, Any]) -> None: pass
 
- class TwilioServiceInterface (twilio_client: twilio.rest.Client)
- 
Helper class that provides a standard way to create an ABC using inheritance. Expand source codeclass TwilioServiceInterface(ABC, Generic[_T]): def __init__(self, twilio_client: Client) -> None: # type: ignore self.twilio_client = twilio_client # type: ignore @abstractmethod async def send_raw_sms( self, content: SMSContent, user_context: Dict[str, Any], from_: Union[str, None] = None, messaging_service_sid: Union[str, None] = None, ) -> None: pass @abstractmethod async def get_content( self, template_vars: _T, user_context: Dict[str, Any] ) -> SMSContent: passAncestors- abc.ABC
- typing.Generic
 SubclassesMethods- async def get_content(self, template_vars: ~_T, user_context: Dict[str, Any]) ‑> SMSContent
- 
Expand source code@abstractmethod async def get_content( self, template_vars: _T, user_context: Dict[str, Any] ) -> SMSContent: pass
- async def send_raw_sms(self, content: SMSContent, user_context: Dict[str, Any], from_: Optional[str] = None, messaging_service_sid: Optional[str] = None) ‑> None
- 
Expand source code@abstractmethod async def send_raw_sms( self, content: SMSContent, user_context: Dict[str, Any], from_: Union[str, None] = None, messaging_service_sid: Union[str, None] = None, ) -> None: pass
 
- class TwilioSettings (account_sid: str, auth_token: str, from_: Optional[str] = None, messaging_service_sid: Optional[str] = None, opts: Optional[Dict[str, Any]] = None)
- 
Note: self.otpscan be used to override values passed to the Twilio Client. Read docs fromtwilio.rest.Client.__init__to discover possible args.For example, opts = {"region": "...", "user_agent_extensions": ["..."], }Expand source codeclass TwilioSettings: def __init__( self, account_sid: str, auth_token: str, from_: Union[str, None] = None, messaging_service_sid: Union[str, None] = None, opts: Union[Dict[str, Any], None] = None, ) -> None: """ Note: `self.otps` can be used to override values passed to the Twilio Client. Read docs from `twilio.rest.Client.__init__` to discover possible args. For example, `opts = {"region": "...", "user_agent_extensions": ["..."], }` """ self.account_sid = account_sid self.auth_token = auth_token self.from_ = from_ self.messaging_service_sid = messaging_service_sid self.opts = opts