diff options
author | Unknown <joe2010xtmf@163.com> | 2014-03-19 10:46:48 -0400 |
---|---|---|
committer | Unknown <joe2010xtmf@163.com> | 2014-03-19 10:46:48 -0400 |
commit | ddbd2ce152a7443076e3000fc1723f4589611ca8 (patch) | |
tree | 2fa8bca12ce6f44b928fa81d7a88acc4bf7655fb /modules/mailer/mail.go | |
parent | 3634d1ee326fd285935c0a5992575583ef6467d4 (diff) |
Add register mail tpl
Diffstat (limited to 'modules/mailer/mail.go')
-rw-r--r-- | modules/mailer/mail.go | 61 |
1 files changed, 59 insertions, 2 deletions
diff --git a/modules/mailer/mail.go b/modules/mailer/mail.go index cc4fd6d0..de4f24a4 100644 --- a/modules/mailer/mail.go +++ b/modules/mailer/mail.go @@ -5,8 +5,13 @@ package mailer import ( + "encoding/hex" + "fmt" + "github.com/gogits/gogs/models" "github.com/gogits/gogs/modules/base" + "github.com/gogits/gogs/modules/log" + "github.com/gogits/gogs/modules/middleware" ) // Create New mail message use MailFrom and MailUser @@ -22,10 +27,62 @@ func GetMailTmplData(user *models.User) map[interface{}]interface{} { data["AppVer"] = base.AppVer data["AppUrl"] = base.AppUrl data["AppLogo"] = base.AppLogo - data["ActiveCodeLives"] = base.Service.ActiveCodeLives - data["ResetPwdCodeLives"] = base.Service.ResetPwdCodeLives + data["ActiveCodeLives"] = base.Service.ActiveCodeLives / 60 + data["ResetPwdCodeLives"] = base.Service.ResetPwdCodeLives / 60 if user != nil { data["User"] = user } return data } + +// create a time limit code for user active +func CreateUserActiveCode(user *models.User, startInf interface{}) string { + hours := base.Service.ActiveCodeLives / 60 + data := base.ToStr(user.Id) + user.Email + user.LowerName + user.Passwd + user.Rands + code := base.CreateTimeLimitCode(data, hours, startInf) + + // add tail hex username + code += hex.EncodeToString([]byte(user.LowerName)) + return code +} + +// Send user register mail with active code +func SendRegisterMail(r *middleware.Render, user *models.User) { + code := CreateUserActiveCode(user, nil) + subject := "Register success, Welcome" + + data := GetMailTmplData(user) + data["Code"] = code + body, err := r.HTMLString("mail/auth/register_success", data) + if err != nil { + log.Error("mail.SendRegisterMail(fail to render): %v", err) + return + } + + msg := NewMailMessage([]string{user.Email}, subject, body) + msg.Info = fmt.Sprintf("UID: %d, send register mail", user.Id) + + // async send mail + SendAsync(msg) +} + +// Send email verify active email. +func SendActiveMail(r *middleware.Render, user *models.User) { + code := CreateUserActiveCode(user, nil) + + subject := "Verify your email address" + + data := GetMailTmplData(user) + data["Code"] = code + body, err := r.HTMLString("mail/auth/active_email.html", data) + if err != nil { + log.Error("mail.SendActiveMail(fail to render): %v", err) + return + } + + msg := NewMailMessage([]string{user.Email}, subject, body) + msg.Info = fmt.Sprintf("UID: %d, send email verify mail", user.Id) + + // async send mail + SendAsync(msg) +} |