From 5fa2e021c98e05a848c7cb7202f616955673d4f6 Mon Sep 17 00:00:00 2001 From: Nick Mango Date: Tue, 3 Dec 2024 18:42:31 +0300 Subject: [PATCH] [#3498] Bug/Email Template - Updated CLA Group update Signed-off-by: Nick Mango --- cla-backend-go/cla_manager/service.go | 115 +++++++++--------- .../emails/cla_manager_templates.go | 26 ++-- .../emails/cla_manager_templates_test.go | 13 +- cla-backend-go/emails/prefill.go | 2 + .../mocks/mock_repository.go | 15 +++ .../projects_cla_groups/repository.go | 21 ++++ cla-backend-go/v2/cla_manager/service.go | 2 +- 7 files changed, 108 insertions(+), 86 deletions(-) diff --git a/cla-backend-go/cla_manager/service.go b/cla-backend-go/cla_manager/service.go index 00961bae2..0eaa6a1dc 100644 --- a/cla-backend-go/cla_manager/service.go +++ b/cla-backend-go/cla_manager/service.go @@ -39,7 +39,7 @@ type IService interface { PendingRequest(companyID, claGroupID, requestID string) (*models.ClaManagerRequest, error) DeleteRequest(requestID string) error - AddClaManager(ctx context.Context, authUser *auth.User, companyID string, claGroupID string, LFID string, projectSFName string) (*models.Signature, error) + AddClaManager(ctx context.Context, authUser *auth.User, companyID string, claGroupID string, LFID string, projectSFID string) (*models.Signature, error) RemoveClaManager(ctx context.Context, authUser *auth.User, companyID string, claGroupID string, LFID string, projectSFName string) (*models.Signature, error) } @@ -193,7 +193,7 @@ func (s service) DeleteRequest(requestID string) error { } // AddClaManager Adds LFID to Signature Access Control list -func (s service) AddClaManager(ctx context.Context, authUser *auth.User, companyID string, claGroupID string, LFID string, projectSFName string) (*models.Signature, error) { +func (s service) AddClaManager(ctx context.Context, authUser *auth.User, companyID string, claGroupID string, LFID string, projectSFID string) (*models.Signature, error) { f := logrus.Fields{ "functionName": "v1.cla_manager.AddClaManager", @@ -201,9 +201,9 @@ func (s service) AddClaManager(ctx context.Context, authUser *auth.User, company "companyID": companyID, "claGroupID": claGroupID, "LFID": LFID, - "projectName": projectSFName, + "projectSFID": projectSFID, } - + var projectSFName string userModel, userErr := s.usersService.GetUserByLFUserName(LFID) if userErr != nil || userModel == nil { return nil, userErr @@ -218,11 +218,6 @@ func (s service) AddClaManager(ctx context.Context, authUser *auth.User, company return nil, projectErr } - // if projectSFName is empty, we can set clagroup project name. - if projectSFName == "" { - projectSFName = claGroupModel.ProjectName - } - // Look up signature ACL to ensure the user can add cla manager signed := true @@ -258,8 +253,9 @@ func (s service) AddClaManager(ctx context.Context, authUser *auth.User, company RecipientAddress: manager.LfEmail.String(), CompanyName: companyModel.CompanyName, }, - Name: userModel.Username, - Email: userModel.LfEmail.String(), + Name: userModel.Username, + Email: userModel.LfEmail.String(), + ProjectSFID: projectSFID, }, claGroupModel) } // Notify the added user @@ -267,7 +263,7 @@ func (s service) AddClaManager(ctx context.Context, authUser *auth.User, company RecipientName: userModel.Username, RecipientAddress: userModel.LfEmail.String(), CompanyName: companyModel.CompanyName, - }, claGroupModel) + }, claGroupModel, projectSFID) // Send an event s.eventsService.LogEventWithContext(ctx, &events.LogEventArgs{ @@ -317,7 +313,7 @@ func (s service) getCompanySignature(ctx context.Context, companyID string, claG } // RemoveClaManager removes lfid from signature acl with given company and project -func (s service) RemoveClaManager(ctx context.Context, authUser *auth.User, companyID string, claGroupID string, LFID string, projectSFName string) (*models.Signature, error) { +func (s service) RemoveClaManager(ctx context.Context, authUser *auth.User, companyID string, claGroupID string, LFID string, projectSFID string) (*models.Signature, error) { f := logrus.Fields{ "functionName": "v1.cla_manager.RemoveClaManager", @@ -327,6 +323,7 @@ func (s service) RemoveClaManager(ctx context.Context, authUser *auth.User, comp "companyID": companyID, } + var projectSFName string userModel, userErr := s.usersService.GetUserByLFUserName(LFID) if userErr != nil || userModel == nil { return nil, userErr @@ -341,11 +338,6 @@ func (s service) RemoveClaManager(ctx context.Context, authUser *auth.User, comp return nil, projectErr } - // if projectSFName is empty, we can set clagroup project name. - if projectSFName == "" { - projectSFName = claGroupModel.ProjectName - } - signed := true approved := true sigModel, sigErr := s.sigService.GetProjectCompanySignature(ctx, companyID, claGroupID, &signed, &approved, nil, aws.Int64(5)) @@ -420,50 +412,56 @@ func (s service) RemoveClaManager(ctx context.Context, authUser *auth.User, comp type ProjectDetails struct { ProjectName string - ProjectSFID string + ProjectSFID []string } -func (s service) getProjectDetails(ctx context.Context, claGroupModel *models.ClaGroup) ProjectDetails { - f := logrus.Fields{ - "functionName": "v1.cla_manager.getProjectDetails", - utils.XREQUESTID: ctx.Value(utils.XREQUESTID), - "claGroupID": claGroupModel.ProjectID, - } +// func (s service) getProjectDetails(ctx context.Context, claGroupModel *models.ClaGroup) ProjectDetails { +// f := logrus.Fields{ +// "functionName": "v1.cla_manager.getProjectDetails", +// utils.XREQUESTID: ctx.Value(utils.XREQUESTID), +// "claGroupID": claGroupModel.ProjectID, +// } +// projectSFIDs := make([]string, 0) - projectDetails := ProjectDetails{ - ProjectName: claGroupModel.ProjectName, - ProjectSFID: claGroupModel.ProjectExternalID, - } - signedAtFoundation := false +// projectDetails := ProjectDetails{ +// ProjectName: claGroupModel.ProjectName, +// } +// signedAtFoundation := false +// var err error - pcg, err := s.projectClaRepository.GetCLAGroup(ctx, claGroupModel.ProjectID) - if err != nil { - log.WithFields(f).Warnf("unable to fetch project cla group by project id: %s, error: %+v", claGroupModel.ProjectID, err) - } +// pcg, pcgErr := s.projectClaRepository.GetCLAGroup(ctx, claGroupModel.ProjectID) +// if pcgErr != nil { +// log.WithFields(f).WithError(err).Debug("unable too get pcg record") +// } - // check if cla group is signed at foundation level - if pcg != nil && pcg.FoundationSFID != "" { - signedAtFoundation, err = s.projectClaRepository.IsExistingFoundationLevelCLAGroup(ctx, pcg.FoundationSFID) - if err != nil { - log.WithFields(f).Warnf("unable to fetch foundation level cla group by foundation id: %s, error: %+v", pcg.FoundationSFID, err) - } +// signedAtFoundation, err = s.projectClaRepository.SignedAtFoundation(ctx, claGroupModel.ProjectID) +// if err != nil { +// log.WithFields(f).WithError(err).Debug("unable to get status of cla signed at foundation") +// } - if signedAtFoundation { - log.WithFields(f).Debugf("cla group is signed at foundation level...") - projectDetails.ProjectName = pcg.FoundationName - projectDetails.ProjectSFID = pcg.FoundationSFID - } - } +// if signedAtFoundation && pcg != nil && err != nil { +// log.WithFields(f).Debug("cla group is signed at foundation level...") +// projectDetails.ProjectName = pcg.FoundationName +// projectSFIDs = append(projectSFIDs, pcg.FoundationSFID) - return projectDetails -} +// } else { +// log.WithFields(f).Debug("cla group is signed at project level ...") + +// } -func (s service) sendClaManagerAddedEmailToUser(emailSvc emails.EmailTemplateService, emailParams emails.CommonEmailParams, claGroupModel *models.ClaGroup) { - projectDetails := s.getProjectDetails(context.Background(), claGroupModel) - projectName := projectDetails.ProjectName - projectSFID := projectDetails.ProjectSFID +// projectDetails.ProjectSFID = projectSFIDs + +// return projectDetails +// } + +func (s service) sendClaManagerAddedEmailToUser(emailSvc emails.EmailTemplateService, emailParams emails.CommonEmailParams, claGroupModel *models.ClaGroup, projectSFID string) { + f := logrus.Fields{ + "functionName": "sendClaManagerAddedEmailToUser", + "projectSFID": projectSFID, + } + log.WithFields(f).Info("Sending email to user") // subject string, body string, recipients []string - subject := fmt.Sprintf("EasyCLA: Added as CLA Manager for Project :%s", projectName) + subject := fmt.Sprintf("EasyCLA: Added as CLA Manager for Project :%s", claGroupModel.ProjectName) recipients := []string{emailParams.RecipientAddress} body, err := emails.RenderClaManagerAddedEToUserTemplate(emailSvc, claGroupModel.Version, projectSFID, emails.ClaManagerAddedEToUserTemplateParams{ CommonEmailParams: emailParams, @@ -553,10 +551,12 @@ func sendRemovedClaManagerEmailToRecipient(emailSvc emails.EmailTemplateService, body, err := emails.RenderRemovedCLAManagerTemplate( emailSvc, claGroupModel.Version, - claGroupModel.ProjectExternalID, emails.RemovedCLAManagerTemplateParams{ CommonEmailParams: emailParams, CLAManagers: emailCLAManagerParams, + CLAGroupTemplateParams: emails.CLAGroupTemplateParams{ + CLAGroupName: projectName, + }, }) if err != nil { @@ -573,14 +573,11 @@ func sendRemovedClaManagerEmailToRecipient(emailSvc emails.EmailTemplateService, } func (s service) sendClaManagerDeleteEmailToCLAManagers(emailSvc emails.EmailTemplateService, emailParams emails.ClaManagerDeletedToCLAManagersTemplateParams, claGroupModel *models.ClaGroup) { - projectDetails := s.getProjectDetails(context.Background(), claGroupModel) - projectName := projectDetails.ProjectName - projectSFID := projectDetails.ProjectSFID // subject string, body string, recipients []string - subject := fmt.Sprintf("EasyCLA: CLA Manager Removed Notice for %s", projectName) + subject := fmt.Sprintf("EasyCLA: CLA Manager Removed Notice for %s", claGroupModel.ProjectName) recipients := []string{emailParams.RecipientAddress} - body, err := emails.RenderClaManagerDeletedToCLAManagersTemplate(emailSvc, claGroupModel.Version, projectSFID, emailParams) + body, err := emails.RenderClaManagerDeletedToCLAManagersTemplate(emailSvc, claGroupModel.Version, claGroupModel.ProjectName) if err != nil { log.Warnf("email template render : %s failed : %v", emails.ClaManagerDeletedToCLAManagersTemplateName, err) diff --git a/cla-backend-go/emails/cla_manager_templates.go b/cla-backend-go/emails/cla_manager_templates.go index 085047ccd..ca66dbe06 100644 --- a/cla-backend-go/emails/cla_manager_templates.go +++ b/cla-backend-go/emails/cla_manager_templates.go @@ -16,8 +16,8 @@ const ( // RemovedCLAManagerTemplate includes the email template for email when user is removed as CLA Manager RemovedCLAManagerTemplate = `

Hello {{.RecipientName}},

-

This is a notification email from EasyCLA regarding the project {{.GetProjectNameOrFoundation}} and CLA Group {{.CLAGroupName}}.

-

You have been removed as a CLA Manager from {{.CompanyName}} for the project {{.Project.ExternalProjectName}}.

+

This is a notification email from EasyCLA regarding the CLA Group {{.CLAGroupName}}.

+

You have been removed as a CLA Manager from {{.CompanyName}} for the CLA Group {{.CLAGroupName}}.

If you have further questions about this, please contact one of the existing managers from {{.CompanyName}}: