From 3c23eac92f66af07eb4a5e52404a4382dbf58cb0 Mon Sep 17 00:00:00 2001 From: Ilias Asqiriba Date: Wed, 5 Jun 2024 22:22:04 +0200 Subject: [PATCH 1/2] ALlow to obtain polling ID without automatically contacting auth endpoint --- tgtg/__init__.py | 60 ++++++++++++++++++++++++++---------------------- 1 file changed, 32 insertions(+), 28 deletions(-) diff --git a/tgtg/__init__.py b/tgtg/__init__.py index e63839c..9d296c3 100644 --- a/tgtg/__init__.py +++ b/tgtg/__init__.py @@ -152,36 +152,40 @@ def login(self): if self._already_logged: self._refresh_token() else: - response = self.session.post( - self._get_url(AUTH_BY_EMAIL_ENDPOINT), - headers=self._headers, - json={ - "device_type": self.device_type, - "email": self.email, - }, - proxies=self.proxies, - timeout=self.timeout, - ) - if response.status_code == HTTPStatus.OK: - first_login_response = response.json() - if first_login_response["state"] == "TERMS": - raise TgtgPollingError( - f"This email {self.email} is not linked to a tgtg account. " - "Please signup with this email first." - ) - elif first_login_response["state"] == "WAIT": - self.start_polling(first_login_response["polling_id"]) - else: - raise TgtgLoginError(response.status_code, response.content) + polling_id = self.request_polling_id() + self.complete_login_with_polling_id(polling_id) + + def request_polling_id(self): + response = self.session.post( + self._get_url(AUTH_BY_EMAIL_ENDPOINT), + headers=self._headers, + json={ + "device_type": self.device_type, + "email": self.email, + }, + proxies=self.proxies, + timeout=self.timeout, + ) + if response.status_code == HTTPStatus.OK: + first_login_response = response.json() + if first_login_response["state"] == "TERMS": + raise TgtgPollingError( + f"This email {self.email} is not linked to a tgtg account. " + "Please signup with this email first." + ) + elif first_login_response["state"] == "WAIT": + return first_login_response["polling_id"] else: - if response.status_code == HTTPStatus.TOO_MANY_REQUESTS: - raise TgtgAPIError( - response.status_code, "Too many requests. Try again later." - ) - else: - raise TgtgLoginError(response.status_code, response.content) + raise TgtgLoginError(response.status_code, response.content) + else: + if response.status_code == HTTPStatus.TOO_MANY_REQUESTS: + raise TgtgAPIError( + response.status_code, "Too many requests. Try again later." + ) + else: + raise TgtgLoginError(response.status_code, response.content) - def start_polling(self, polling_id): + def complete_login_with_polling_id(self, polling_id): for _ in range(MAX_POLLING_TRIES): response = self.session.post( self._get_url(AUTH_POLLING_ENDPOINT), From c22e1f3deb7e708ed601ffb3cb6ccb0b7e120efa Mon Sep 17 00:00:00 2001 From: SuperLanceur Date: Sun, 1 Sep 2024 03:02:48 +0200 Subject: [PATCH 2/2] Updated README with how to use the polling-free login flow --- README.md | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/README.md b/README.md index 1e530b2..37f630f 100644 --- a/README.md +++ b/README.md @@ -57,6 +57,17 @@ print(credentials) } ``` +#### No polling +You can avoid the polling mechanism by providing the polling_id directly + +```python +client = TgtgClient(email="") +polling_id = client.request_polling_id() +# You now click in the link you received by email +client.complete_login_with_polling_id(cached_polling_id) +credentials = client.get_credentials() +``` + ### Build the client from tokens ```python