Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Voice] - support for the whole API #27

Merged
merged 53 commits into from
May 10, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
53 commits
Select commit Hold shift + click to select a range
48d409a
feat(Voice): WiP
650elx Feb 14, 2024
b5a4a19
feat(Voice): region handling
650elx Feb 15, 2024
4ba5eea
feat(Voice): WiP
650elx Feb 15, 2024
d9d8ed2
test(Voice): e2e for updating call
650elx Feb 15, 2024
f541175
feat(Voice): naming aligned
650elx Feb 15, 2024
df58658
feat(Voice): Price DTO added
650elx Feb 15, 2024
c6d93db
feat(Voice): better naming
650elx Feb 16, 2024
efbcd6c
feat(Voice): Manage call endpoint added
650elx Feb 19, 2024
9e05762
feat(Voice): bring back regions enum
650elx Feb 19, 2024
be0b34d
feat(Voice): Destination dataclass added
650elx Feb 19, 2024
4a12fd5
feat(CI): Voice related env vars added
650elx Feb 19, 2024
7ede865
feat(Voice): apps and conferences WiP
650elx Feb 29, 2024
31c65d3
feat(Voice): WiP
650elx Mar 1, 2024
cdfc926
style(pep8): redundant empty line removed
650elx Mar 1, 2024
20917c5
fix(CI): typo
650elx Mar 1, 2024
ea22a2b
fix(style): redundant white line removed
650elx Mar 1, 2024
6aa94e0
feat(Voice): ConferenceDTMFOptionsMode added
650elx Mar 7, 2024
9d9cd2a
feat(Voice): align naming to other SDKs
650elx Mar 7, 2024
f9694b2
feat(Voice): missing DTO property added
650elx Mar 7, 2024
16aa654
fix(Verification): typo
650elx Mar 7, 2024
9030475
test(Voice): enable update call e2e tests
650elx Mar 7, 2024
b78427b
test(Voice): async tests added to callouts
650elx Mar 7, 2024
10dc71f
fix(Voice): missing env variable definition
650elx Mar 11, 2024
bf1b61a
feat(Voice): SVAML support
650elx Mar 11, 2024
cd91ca4
test(Voice): use SVAML DTOs
650elx Mar 11, 2024
082d2ba
feat(Voice): SVAML WiP
650elx Mar 12, 2024
7d8fb98
feat(Voice): additional conference call method
650elx Mar 13, 2024
6afa46f
feat(Voice): Literal type for domain arg
650elx Mar 13, 2024
324ddfb
feat(Voice): rename model
650elx Mar 13, 2024
29997e9
feat(Voice): DTO adapted to the facade changes
650elx Mar 14, 2024
90a9537
fix: typo
650elx Mar 15, 2024
24b0351
fix: naming convetion
650elx Mar 18, 2024
3d6b44c
feat(Voice): represent timestamps as datetime
650elx Mar 19, 2024
05b6ac2
feat(Voice): timestamp format compatible with older versions of Python
650elx Mar 19, 2024
c8a47d0
feat(SVAML): __all__ added
650elx Mar 20, 2024
69b2096
feat(Voice): type hint for Destination type added
650elx Mar 20, 2024
c344d7a
feat(Voice): mode type hints added
650elx Mar 20, 2024
e0d0a98
feat(SVAML): Indications enum added
650elx Mar 20, 2024
5a0d073
fix(Voice): missing property transformation
650elx Mar 20, 2024
96dfa8a
fix(Voice): better Enum naming
650elx Mar 20, 2024
e12a149
fix: remove redundant property
650elx Mar 20, 2024
164eb95
fix(SVAML): missing transformations added
650elx Mar 20, 2024
a0dbff0
feat(SVAML): missing transformation added
650elx Apr 5, 2024
0cba99c
feat(Voice): domain type hint added
650elx Apr 5, 2024
9def0cc
feat(Voice): missing transformation added
650elx Apr 5, 2024
b41187d
feat(Voice): timestamp validation added
650elx May 10, 2024
cac25fe
feat(Voice): type hits for instructions added
650elx May 10, 2024
e7d795f
fix(Voice): missing type added
650elx May 10, 2024
3a3e3c6
fix(Voice): response handling improved
650elx May 10, 2024
d74934d
fix(Voice): wrong type
650elx May 10, 2024
01a2d10
feat(Voice): capability enum added
650elx May 10, 2024
73d7ea2
feat(Voice): more comples type hint added
650elx May 10, 2024
9acaf65
feat(Voice): better type annotation
650elx May 10, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
13 changes: 9 additions & 4 deletions .github/workflows/run-tests.yml
Original file line number Diff line number Diff line change
Expand Up @@ -24,10 +24,15 @@ env:
APPLICATION_SECRET: ${{ secrets.APPLICATION_SECRET }}
APPLICATION_KEY: ${{ secrets.APPLICATION_KEY }}
VERIFICATION_ID: ${{ secrets.VERIFICATION_ID }}
VERIFICATION_ORIGIN: ${{ secrets.VERIFICATION_ORIGIN}}
VERIFICATION_REQUEST_SIGNATURE_TIMESTAMP: ${{ secrets.VERIFICATION_REQUEST_SIGNATURE_TIMESTAMP}}
VERIFICATION_REQUEST_WITH_EMPTY_BODY_SIGNATURE: ${{ secrets.VERIFICATION_REQUEST_WITH_EMPTY_BODY_SIGNATURE}}
VERIFICATION_REQUEST_SIGNATURE: ${{ secrets.VERIFICATION_REQUEST_SIGNATURE}}
VERIFICATION_ORIGIN: ${{ secrets.VERIFICATION_ORIGIN }}
VERIFICATION_REQUEST_SIGNATURE_TIMESTAMP: ${{ secrets.VERIFICATION_REQUEST_SIGNATURE_TIMESTAMP }}
VERIFICATION_REQUEST_WITH_EMPTY_BODY_SIGNATURE: ${{ secrets.VERIFICATION_REQUEST_WITH_EMPTY_BODY_SIGNATURE }}
VERIFICATION_REQUEST_SIGNATURE: ${{ secrets.VERIFICATION_REQUEST_SIGNATURE }}
VOICE_ORIGIN: ${{ secrets.VOICE_ORIGIN }}
VOICE_ORIGIN_PHONE_NUMBER: ${{ secrets.VOICE_ORIGIN_PHONE_NUMBER }}
VOICE_CALL_ID: ${{ secrets.VOICE_CALL_ID }}
CONFERENCE_ID: ${{ secrets.CONFERENCE_ID }}
CONFERENCE_CALL_ID: ${{ secrets.CONFERENCE_CALL_ID }}

jobs:
build:
Expand Down
4 changes: 3 additions & 1 deletion sinch/core/clients/sinch_client_async.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,8 @@
from sinch.domains.numbers import NumbersAsync
from sinch.domains.conversation import ConversationAsync
from sinch.domains.sms import SMSAsync
from sinch.domains.verification import Verification as VerificationAsync
from sinch.domains.verification import VerificationAsync
from sinch.domains.voice import VoiceAsync


class ClientAsync(ClientBase):
Expand Down Expand Up @@ -42,3 +43,4 @@ def __init__(
self.conversation = ConversationAsync(self)
self.sms = SMSAsync(self)
self.verification = VerificationAsync(self)
self.voice = VoiceAsync(self)
2 changes: 2 additions & 0 deletions sinch/core/clients/sinch_client_base.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@
from sinch.domains.numbers import NumbersBase
from sinch.domains.conversation import ConversationBase
from sinch.domains.sms import SMSBase
from sinch.domains.voice import VoiceBase


class ClientBase(ABC):
Expand All @@ -17,6 +18,7 @@ class ClientBase(ABC):
numbers = NumbersBase
conversation = ConversationBase
sms = SMSBase
voice = VoiceBase

@abstractmethod
def __init__(
Expand Down
23 changes: 23 additions & 0 deletions sinch/core/clients/sinch_client_configuration.py
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,9 @@ def __init__(
self.auth_origin = "auth.sinch.com"
self.numbers_origin = "numbers.api.sinch.com"
self.verification_origin = "verification.api.sinch.com"
self.voice_applications_origin = "callingapi.sinch.com"
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think it's not used, and overrieded below, but it would be a dot after calling

Suggested change
self.voice_applications_origin = "callingapi.sinch.com"
self.voice_applications_origin = "calling.api.sinch.com"

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

https://developers.sinch.com/docs/voice/api-reference/voice/tag/Applications/
I think there is a separate endpoint for Applications:
url = "https://callingapi.sinch.com/v1/configuration/numbers"

self._voice_domain = "{}.api.sinch.com"
self._voice_region = None
self._conversation_region = "eu"
self._conversation_domain = ".conversation.api.sinch.com"
self._sms_region = "us"
Expand All @@ -45,6 +48,7 @@ def __init__(
self._set_conversation_origin()
self._set_sms_origin()
self._set_templates_origin()
self._set_voice_origin()

if logger_name:
self.logger = logging.getLogger(logger_name)
Expand All @@ -53,6 +57,25 @@ def __init__(
else:
self.logger = logging.getLogger("Sinch")

def _set_voice_origin(self):
if not self._voice_region:
self.voice_origin = self._voice_domain.format("calling")
else:
self.voice_origin = self._voice_domain.format("calling-" + self._voice_region)

def _set_voice_region(self, region):
self._voice_region = region
self._set_voice_origin()

def _get_voice_region(self):
return self._voice_region

voice_region = property(
_get_voice_region,
_set_voice_region,
doc="Voice Region"
)

def _set_sms_origin(self):
self.sms_origin = self._sms_domain.format(self._sms_region)

Expand Down
2 changes: 2 additions & 0 deletions sinch/core/clients/sinch_client_sync.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@
from sinch.domains.conversation import Conversation
from sinch.domains.sms import SMS
from sinch.domains.verification import Verification
from sinch.domains.voice import Voice


class Client(ClientBase):
Expand Down Expand Up @@ -42,3 +43,4 @@ def __init__(
self.conversation = Conversation(self)
self.sms = SMS(self)
self.verification = Verification(self)
self.voice = Voice(self)
12 changes: 12 additions & 0 deletions sinch/core/deserializers.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
from datetime import datetime


def timestamp_to_datetime_in_utc_deserializer(timestamp: str):
"""
Older Python versions (like 3.9) do not support "Z" as a TZ information.
One needs to use '+00:00' to represent UTC tz.
"""
if timestamp.endswith("Z"):
timestamp = timestamp[:-1]

return datetime.fromisoformat(timestamp + "+00:00")
Loading
Loading