From 5f32137f4d46a58dd86cd07c0ce27a83264991b4 Mon Sep 17 00:00:00 2001 From: Mael Pedretti Date: Tue, 30 Jan 2024 15:46:02 +0100 Subject: [PATCH 1/2] Added email on user when creating a new user --- AUTHORS.md | 1 + django_saml2_auth/user.py | 27 +++++++++++++++------------ 2 files changed, 16 insertions(+), 12 deletions(-) diff --git a/AUTHORS.md b/AUTHORS.md index b315885..82718eb 100644 --- a/AUTHORS.md +++ b/AUTHORS.md @@ -59,3 +59,4 @@ an issue. - [Santiago Gandolfo](https://github.com/santigandolfo) - [Greg Wong](https://github.com/gregorywong) - [Michael V. Battista](https://github.com/mvbattista) +- [Maƫl Pedretti](https://github.com/73VW) \ No newline at end of file diff --git a/django_saml2_auth/user.py b/django_saml2_auth/user.py index b35d66c..ac5ea04 100644 --- a/django_saml2_auth/user.py +++ b/django_saml2_auth/user.py @@ -22,17 +22,16 @@ requires_cryptography) from jwt.exceptions import PyJWTError +FIRST_NAME_FIELD_NAME = "first_name" +LAST_NAME_FIELD_NAME = "last_name" -def create_new_user(email: str, - first_name: Optional[str] = None, - last_name: Optional[str] = None, - **kwargs) -> User: + +def create_new_user(user_id: str, user: dict, **kwargs) -> User: """Create a new user with the given information Args: - email (str): Email - first_name (str): First name - last_name (str): Last name + user_id (str): User ID + user (dict): User informations Keyword Args: **kwargs: Additional keyword arguments @@ -52,12 +51,16 @@ def create_new_user(email: str, is_superuser = dictor(saml2_auth_settings, "NEW_USER_PROFILE.SUPERUSER_STATUS", default=False) user_groups = dictor(saml2_auth_settings, "NEW_USER_PROFILE.USER_GROUPS", default=[]) - if first_name and last_name: - kwargs['first_name'] = first_name - kwargs['last_name'] = last_name + for field in [ + FIRST_NAME_FIELD_NAME, + LAST_NAME_FIELD_NAME, + user_model.EMAIL_FIELD, + ]: + if field in user: + kwargs[field] = user[field] try: - user = user_model.objects.create_user(email, **kwargs) + user = user_model.objects.create_user(user_id, **kwargs) user.is_active = is_active user.is_staff = is_staff user.is_superuser = is_superuser @@ -119,7 +122,7 @@ def get_or_create_user(user: Dict[str, Any]) -> Tuple[bool, User]: "reason": "Cannot create user. Missing user_id.", "status_code": 400 }) - target_user = create_new_user(user_id, user["first_name"], user["last_name"]) + target_user = create_new_user(user_id, user) create_user_trigger = dictor(saml2_auth_settings, "TRIGGER.CREATE_USER") if create_user_trigger: From c5662f83788e96862b7989c0ef202aec30808b1c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ma=C3=ABl=20Pedretti?= <24651698+73VW@users.noreply.github.com> Date: Wed, 27 Mar 2024 07:42:37 +0100 Subject: [PATCH 2/2] Update django_saml2_auth/user.py Co-authored-by: Mostafa Moradian --- django_saml2_auth/user.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/django_saml2_auth/user.py b/django_saml2_auth/user.py index ac5ea04..dd2758d 100644 --- a/django_saml2_auth/user.py +++ b/django_saml2_auth/user.py @@ -31,7 +31,7 @@ def create_new_user(user_id: str, user: dict, **kwargs) -> User: Args: user_id (str): User ID - user (dict): User informations + user (dict): User information Keyword Args: **kwargs: Additional keyword arguments