diff --git a/allauth/socialaccount/providers/bitbucket_oauth2/views.py b/allauth/socialaccount/providers/bitbucket_oauth2/views.py index 6117906782..bf023fee4c 100644 --- a/allauth/socialaccount/providers/bitbucket_oauth2/views.py +++ b/allauth/socialaccount/providers/bitbucket_oauth2/views.py @@ -21,11 +21,12 @@ def complete_login(self, request, app, token, **kwargs): .get(self.profile_url, params={"access_token": token.token}) ) extra_data = resp.json() - if app_settings.QUERY_EMAIL and not extra_data.get("email"): - extra_data["email"] = self.get_email(token) + if app_settings.QUERY_EMAIL: + if email := self.get_email(token): + extra_data["email"] = email return self.get_provider().sociallogin_from_response(request, extra_data) - def get_email(self, token): + def get_email(self, token) -> str: """Fetches email address from email API endpoint""" resp = ( get_adapter() diff --git a/allauth/socialaccount/providers/github/views.py b/allauth/socialaccount/providers/github/views.py index b25e883c7c..d66bf7bb27 100644 --- a/allauth/socialaccount/providers/github/views.py +++ b/allauth/socialaccount/providers/github/views.py @@ -30,13 +30,12 @@ def complete_login(self, request, app, token, **kwargs): ) resp.raise_for_status() extra_data = resp.json() - if app_settings.QUERY_EMAIL and not extra_data.get("email"): - emails = self.get_emails(headers) - if emails: + if app_settings.QUERY_EMAIL: + if emails := self.get_emails(headers): extra_data["emails"] = emails return self.get_provider().sociallogin_from_response(request, extra_data) - def get_emails(self, headers): + def get_emails(self, headers) -> list | None: resp = ( get_adapter().get_requests_session().get(self.emails_url, headers=headers) )