From 0187e702eae59fd5435ea2b061d1087a3882eb09 Mon Sep 17 00:00:00 2001 From: =Corey Hulen Date: Tue, 13 Oct 2015 09:47:31 -0700 Subject: PLT-602 combining welcome and verify email --- api/templates/welcome_body.html | 11 +++++++++++ api/user.go | 13 ++++++++----- 2 files changed, 19 insertions(+), 5 deletions(-) (limited to 'api') diff --git a/api/templates/welcome_body.html b/api/templates/welcome_body.html index 94b597cbb..b7cb3704d 100644 --- a/api/templates/welcome_body.html +++ b/api/templates/welcome_body.html @@ -15,6 +15,17 @@ + {{if .Props.VerifyUrl }} + + + + {{end}}
+

You've been invited

+

Please verify your email address by clicking below.

+

+ Verify Email +

+

You can sign-in to your new team from the web address:

diff --git a/api/user.go b/api/user.go index faf828cf9..146ede015 100644 --- a/api/user.go +++ b/api/user.go @@ -198,13 +198,12 @@ func CreateUser(c *Context, team *model.Team, user *model.User) *model.User { l4g.Error("Encountered an issue joining default channels user_id=%s, team_id=%s, err=%v", ruser.Id, ruser.TeamId, err) } - fireAndForgetWelcomeEmail(ruser.Email, team.DisplayName, c.GetSiteURL(), c.GetTeamURLFromTeam(team)) + fireAndForgetWelcomeEmail(result.Data.(*model.User).Id, ruser.Email, team.Name, team.DisplayName, c.GetSiteURL(), c.GetTeamURLFromTeam(team), user.EmailVerified) + if user.EmailVerified { if cresult := <-Srv.Store.User().VerifyEmail(ruser.Id); cresult.Err != nil { l4g.Error("Failed to set email verified err=%v", cresult.Err) } - } else { - FireAndForgetVerifyEmail(result.Data.(*model.User).Id, ruser.Email, team.Name, team.DisplayName, c.GetSiteURL(), c.GetTeamURLFromTeam(team)) } ruser.Sanitize(map[string]bool{}) @@ -218,7 +217,7 @@ func CreateUser(c *Context, team *model.Team, user *model.User) *model.User { } } -func fireAndForgetWelcomeEmail(email, teamDisplayName, siteURL, teamURL string) { +func fireAndForgetWelcomeEmail(userId, email, teamName, teamDisplayName, siteURL, teamURL string, verified bool) { go func() { subjectPage := NewServerTemplatePage("welcome_subject") @@ -227,10 +226,14 @@ func fireAndForgetWelcomeEmail(email, teamDisplayName, siteURL, teamURL string) bodyPage.Props["SiteURL"] = siteURL bodyPage.Props["TeamURL"] = teamURL + if !verified { + link := fmt.Sprintf("%s/verify_email?uid=%s&hid=%s&teamname=%s&email=%s", siteURL, userId, model.HashPassword(userId), teamName, email) + bodyPage.Props["VerifyUrl"] = link + } + if err := utils.SendMail(email, subjectPage.Render(), bodyPage.Render()); err != nil { l4g.Error("Failed to send welcome email successfully err=%v", err) } - }() } -- cgit v1.2.3-1-g7c22