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:
        pass

Classes

class SMSContent (body: str, to_phone: str)
Expand source code
class 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 code
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

Ancestors

  • 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 code
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

Ancestors

  • abc.ABC
  • typing.Generic
class SMSDeliveryInterface

Helper class that provides a standard way to create an ABC using inheritance.

Expand source code
class SMSDeliveryInterface(ABC, Generic[_T]):
    @abstractmethod
    async def send_sms(self, template_vars: _T, user_context: Dict[str, Any]) -> None:
        pass

Ancestors

  • abc.ABC
  • typing.Generic

Subclasses

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 code
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:
        pass

Ancestors

  • abc.ABC
  • typing.Generic

Subclasses

Methods

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.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": ["..."], }

Expand source code
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