TypeError: строковые индексы должны быть целыми числами при использовании Google login с помощью django-allauth

Я сталкиваюсь со следующей ошибкой при попытке реализовать вход в Google с помощью django-allauth в моем проекте Django:

social_login = adapter.complete_login(request, app, token, response=response)
File "/.venv/lib/python3.8/site-packages/allauth/socialaccount/providers/google/views.py", line 43, in complete_login
   response["id_token"],
TypeError: string indices must be integers

Прямо сейчас я использую django-allauth версии 0.54.0 и django 2.2.28

У меня есть следующий класс GoogleLogin, настроенный для обработки аутентификации Google OAuth2:

class GoogleLogin(SocialLoginView):
    authentication_classes = [] 
    permission_classes = [] 
    adapter_class = GoogleOAuth2Adapter
    client_class = OAuth2Client
    callback_url = "https://developers.google.com/oauthplayground"

Интерфейс отправляет мне только access_token В GoogleOAuth2Adapter реализован метод complete_login для декодирования id_token из ответа Google:

class GoogleOAuth2Adapter(OAuth2Adapter):
    provider_id = GoogleProvider.id
    access_token_url = ACCESS_TOKEN_URL
    authorize_url = AUTHORIZE_URL
    id_token_issuer = ID_TOKEN_ISSUER

    def complete_login(self, request, app, token, response, **kwargs):
        try:
            print(response)
            identity_data = jwt.decode(
                response["id_token"],
                # Since the token was received by direct communication
                # protected by TLS between this library and Google, we
                # are allowed to skip checking the token signature
                # according to the OpenID Connect Core 1.0
                # specification.
                # https://openid.net/specs/openid-connect-core-1_0.html#IDTokenValidation
                options={
                    "verify_signature": False,
                    "verify_iss": True,
                    "verify_aud": True,
                    "verify_exp": True,
                },
                issuer=self.id_token_issuer,
                audience=app.client_id,
            )
        except jwt.PyJWTError as e:
            raise OAuth2Error("Invalid id_token") from e
        login = self.get_provider().sociallogin_from_response(request, identity_data)
        return login


oauth2_login = OAuth2LoginView.adapter_view(GoogleOAuth2Adapter)
oauth2_callback = OAuth2CallbackView.adapter_view(GoogleOAuth2Adapter)
Вернуться на верх