Я пытаюсь аутентифицировать пользователя с помощью Twitch Auth, используя Django и реагировать.Я могу авторизовать пользователя и сохранить его данные в админке Django из бэкэнда, но не знаю, как это сделать с реагированием.
Что я пробовал до сих пор:
Следуя документам отсюда: https://django -allauth.readthedocs.io / en / latest / installation.html
Я настроил все как:
settings.py:
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'rest_framework',
'rest_framework.authtoken',
'rest_auth',
'django.contrib.sites',
'allauth',
'allauth.account',
'allauth.socialaccount',
'allauth.socialaccount.providers.twitch',
'django_extensions',
'users.apps.UsersConfig',
]
SITE_ID = 1
MIDDLEWARE = [
'django.middleware.security.SecurityMiddleware',
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.common.CommonMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
'django.middleware.clickjacking.XFrameOptionsMiddleware',
]
ROOT_URLCONF = app-name.urls'
TEMPLATES = [
{
'BACKEND': 'django.template.backends.django.DjangoTemplates',
'DIRS': [],
'APP_DIRS': True,
'OPTIONS': {
'context_processors': [
'django.template.context_processors.debug',
'django.template.context_processors.request',
'django.contrib.auth.context_processors.auth',
'django.contrib.messages.context_processors.messages',
],
},
},
]
WSGI_APPLICATION = 'sphinx.wsgi.application'
REST_FRAMEWORK = {
'DEFAULT_AUTHENTICATION_CLASSES': [
'rest_framework.authentication.TokenAuthentication',
],
}
Я также зарегистрировал социальное приложение в админке Django.
Когда я нажал:
http://localhost:8000/accounts/twitch/login/
Он переходит на страницу авторизации дергаться, котораякогда я нажимаю «Авторизовать», сохраняются данные пользователя в админке Django, перенаправляет меня обратно на URL:
http://localhost:8000/accounts/profile/
Проблема в том, что мне нужно убедиться, что страница LOGIN_REDIRECT_URL '/ account / profile /' имеетнекоторая аутентификация, поэтому только авторизованный пользователь может получить к ней доступ и отобразить имя пользователя этого пользователя.
Как аутентифицировать пользователя?Например, как я могу отправить access_token внешнему пользователю и проверить пользователя?