From 9ab9b3772f4872af17908cad0756472ea627f2bb Mon Sep 17 00:00:00 2001 From: Robin Munn Date: Wed, 4 Dec 2024 12:49:48 +0700 Subject: [PATCH] Project managers invited by email can create projects (#1300) If someone is promoted to manager by other means, they can create projects without needing a draft project approved by an admin. Sending an email invitation to a new user and giving them the project-manager role right off the bat should have the same effect. --- backend/LexBoxApi/Controllers/UserController.cs | 2 +- backend/LexBoxApi/Services/EmailService.cs | 8 ++++---- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/backend/LexBoxApi/Controllers/UserController.cs b/backend/LexBoxApi/Controllers/UserController.cs index ac48f3f52..912ceb0d1 100644 --- a/backend/LexBoxApi/Controllers/UserController.cs +++ b/backend/LexBoxApi/Controllers/UserController.cs @@ -184,7 +184,7 @@ private User CreateUserEntity(RegisterAccountInput input, LexAuthUser? jwtUser, EmailVerified = jwtUser?.Email == input.Email, CreatedById = creatorId, Locked = false, - CanCreateProjects = false + CanCreateProjects = jwtUser?.Email == input.Email && jwtUser.CanCreateProjects == true, }; UpdateUserMemberships(jwtUser, userEntity); return userEntity; diff --git a/backend/LexBoxApi/Services/EmailService.cs b/backend/LexBoxApi/Services/EmailService.cs index 6a7215c9f..914e5f148 100644 --- a/backend/LexBoxApi/Services/EmailService.cs +++ b/backend/LexBoxApi/Services/EmailService.cs @@ -103,7 +103,7 @@ public async Task SendCreateAccountWithOrgEmail( string? language = null) { language ??= User.DefaultLocalizationCode; - var authUser = CreateUserForInvite(emailAddress, language); + var authUser = CreateUserForInvite(emailAddress, language, canCreateProjects: orgRole == OrgRole.Admin); authUser.Orgs = [new AuthUserOrg(orgRole, orgId)]; await SendInvitationEmail(authUser, emailAddress, managerName, orgName, language, isProjectInvitation: false); @@ -124,12 +124,12 @@ public async Task SendCreateAccountWithProjectEmail( string? language = null) { language ??= User.DefaultLocalizationCode; - var authUser = CreateUserForInvite(emailAddress, language); + var authUser = CreateUserForInvite(emailAddress, language, canCreateProjects: role == ProjectRole.Manager); authUser.Projects = [new AuthUserProject(role, projectId)]; await SendInvitationEmail(authUser, emailAddress, managerName, projectName, language, isProjectInvitation: true); } - private LexAuthUser CreateUserForInvite(string emailAddress, string? language) + private LexAuthUser CreateUserForInvite(string emailAddress, string? language, bool canCreateProjects = false) { language ??= User.DefaultLocalizationCode; return new LexAuthUser @@ -141,7 +141,7 @@ private LexAuthUser CreateUserForInvite(string emailAddress, string? language) EmailVerificationRequired = null, Role = UserRole.user, UpdatedDate = DateTimeOffset.Now.ToUnixTimeSeconds(), - CanCreateProjects = null, + CanCreateProjects = canCreateProjects ? true : null, Locale = language, Locked = null, Projects = [],