This commit is contained in:
parent
1de1cb4086
commit
a01af1e3fa
10 changed files with 51 additions and 15 deletions
|
|
@ -18,14 +18,12 @@ class OAuthProvider(OAuth2Provider):
|
|||
account_class = OAuthAccount
|
||||
|
||||
def extract_uid(self, data):
|
||||
return str(data["username"])
|
||||
return str(data["preferred_username"])
|
||||
|
||||
def extract_common_fields(self, data):
|
||||
return dict(
|
||||
email=data.get("email"),
|
||||
username=data.get("username"),
|
||||
last_name=data.get("last_name"),
|
||||
first_name=data.get("first_name"),
|
||||
username=data.get("preferred_username"),
|
||||
)
|
||||
|
||||
def get_default_scope(self):
|
||||
|
|
|
|||
|
|
@ -2,7 +2,9 @@
|
|||
# Copyright (C) 2022 Amicale des élèves de l'ENS Paris-Saclay
|
||||
# SPDX-License-Identifier: GPL-3.0-or-later
|
||||
|
||||
from allauth.account.models import EmailAddress
|
||||
from allauth.socialaccount.signals import pre_social_login
|
||||
from django.conf import settings
|
||||
from django.dispatch import receiver
|
||||
|
||||
|
||||
|
|
@ -19,11 +21,19 @@ def sync_user_fields(sender, request, sociallogin, **kwargs):
|
|||
if email and user.email != email:
|
||||
user.email = email
|
||||
changed = True
|
||||
EmailAddress.objects.filter(user=user).update(email=email)
|
||||
|
||||
username = data.get("username")
|
||||
username = data.get("preferred_username")
|
||||
if username and user.username != username:
|
||||
user.username = username
|
||||
changed = True
|
||||
|
||||
admin_group = settings.OAUTH_ADMIN_GROUP
|
||||
if admin_group:
|
||||
is_admin = admin_group in data.get("groups", [])
|
||||
user.is_staff = is_admin
|
||||
user.is_superuser = is_admin
|
||||
changed = True
|
||||
|
||||
if changed:
|
||||
user.save()
|
||||
|
|
|
|||
|
|
@ -4,6 +4,7 @@
|
|||
|
||||
import requests
|
||||
from allauth.socialaccount import app_settings
|
||||
from django.core.exceptions import ImproperlyConfigured
|
||||
from allauth.socialaccount.providers.oauth2.views import (
|
||||
OAuth2Adapter,
|
||||
OAuth2CallbackView,
|
||||
|
|
@ -31,20 +32,27 @@ class OAuthAdapter(OAuth2Adapter):
|
|||
|
||||
@property
|
||||
def domain(self):
|
||||
return self.settings.get("DOMAIN", "")
|
||||
domain = self.settings.get("DOMAIN", "")
|
||||
if not domain:
|
||||
raise ImproperlyConfigured(
|
||||
"OAUTH_SERVER_URL is not configured. Set it in your .env file."
|
||||
)
|
||||
return domain
|
||||
|
||||
@property
|
||||
def access_token_url(self):
|
||||
return f"https://{self.domain}/o/token/"
|
||||
return f"https://{self.domain}/application/o/token/"
|
||||
|
||||
@property
|
||||
def authorize_url(self):
|
||||
return f"https://{self.domain}/o/authorize/"
|
||||
return f"https://{self.domain}/application/o/authorize/"
|
||||
|
||||
@property
|
||||
def profile_url(self):
|
||||
return f"https://{self.domain}/api/me/"
|
||||
return f"https://{self.domain}/application/o/userinfo/"
|
||||
|
||||
|
||||
OAuthProvider.oauth2_adapter_class = OAuthAdapter
|
||||
|
||||
oauth2_login = OAuth2LoginView.adapter_view(OAuthAdapter)
|
||||
oauth2_callback = OAuth2CallbackView.adapter_view(OAuthAdapter)
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue