| @@ -19,7 +19,7 @@ import ( | |||||
| // Test that go1.2 tag above is included in builds. main.go refers to this definition. | // Test that go1.2 tag above is included in builds. main.go refers to this definition. | ||||
| const go12tag = true | const go12tag = true | ||||
| const APP_VER = "0.1.7.0325" | |||||
| const APP_VER = "0.1.8.0325" | |||||
| func init() { | func init() { | ||||
| base.AppVer = APP_VER | base.AppVer = APP_VER | ||||
| @@ -59,7 +59,6 @@ func CreateIssue(userId, repoId, milestoneId, assigneeId int64, name, labels, co | |||||
| Content: content, | Content: content, | ||||
| } | } | ||||
| _, err = orm.Insert(issue) | _, err = orm.Insert(issue) | ||||
| // TODO: newIssueAction | |||||
| return issue, err | return issue, err | ||||
| } | } | ||||
| @@ -6,6 +6,7 @@ package mailer | |||||
| import ( | import ( | ||||
| "encoding/hex" | "encoding/hex" | ||||
| "errors" | |||||
| "fmt" | "fmt" | ||||
| "github.com/gogits/gogs/models" | "github.com/gogits/gogs/models" | ||||
| @@ -15,12 +16,17 @@ import ( | |||||
| ) | ) | ||||
| // Create New mail message use MailFrom and MailUser | // Create New mail message use MailFrom and MailUser | ||||
| func NewMailMessage(To []string, subject, body string) Message { | |||||
| msg := NewHtmlMessage(To, base.MailService.User, subject, body) | |||||
| func NewMailMessageFrom(To []string, from, subject, body string) Message { | |||||
| msg := NewHtmlMessage(To, from, subject, body) | |||||
| msg.User = base.MailService.User | msg.User = base.MailService.User | ||||
| return msg | return msg | ||||
| } | } | ||||
| // Create New mail message use MailFrom and MailUser | |||||
| func NewMailMessage(To []string, subject, body string) Message { | |||||
| return NewMailMessageFrom(To, base.MailService.User, subject, body) | |||||
| } | |||||
| func GetMailTmplData(user *models.User) map[interface{}]interface{} { | func GetMailTmplData(user *models.User) map[interface{}]interface{} { | ||||
| data := make(map[interface{}]interface{}, 10) | data := make(map[interface{}]interface{}, 10) | ||||
| data["AppName"] = base.AppName | data["AppName"] = base.AppName | ||||
| @@ -84,3 +90,33 @@ func SendActiveMail(r *middleware.Render, user *models.User) { | |||||
| SendAsync(&msg) | SendAsync(&msg) | ||||
| } | } | ||||
| // SendNotifyMail sends mail notification of all watchers. | |||||
| func SendNotifyMail(userId, repoId int64, userName, repoName, subject, content string) error { | |||||
| watches, err := models.GetWatches(repoId) | |||||
| if err != nil { | |||||
| return errors.New("mail.NotifyWatchers(get watches): " + err.Error()) | |||||
| } | |||||
| tos := make([]string, 0, len(watches)) | |||||
| for i := range watches { | |||||
| uid := watches[i].UserId | |||||
| if userId == uid { | |||||
| continue | |||||
| } | |||||
| u, err := models.GetUserById(uid) | |||||
| if err != nil { | |||||
| return errors.New("mail.NotifyWatchers(get user): " + err.Error()) | |||||
| } | |||||
| tos = append(tos, u.Email) | |||||
| } | |||||
| if len(tos) == 0 { | |||||
| return nil | |||||
| } | |||||
| msg := NewMailMessageFrom(tos, userName, subject, content) | |||||
| msg.Info = fmt.Sprintf("Subject: %s, send notify emails", subject) | |||||
| SendAsync(&msg) | |||||
| return nil | |||||
| } | |||||
| @@ -33,7 +33,7 @@ func (m Message) Content() string { | |||||
| } | } | ||||
| // create mail content | // create mail content | ||||
| content := "From: " + m.User + "<" + m.From + | |||||
| content := "From: " + m.From + "<" + m.User + | |||||
| ">\r\nSubject: " + m.Subject + "\r\nContent-Type: " + contentType + "\r\n\r\n" + m.Body | ">\r\nSubject: " + m.Subject + "\r\nContent-Type: " + contentType + "\r\n\r\n" + m.Body | ||||
| return content | return content | ||||
| } | } | ||||
| @@ -13,6 +13,7 @@ import ( | |||||
| "github.com/gogits/gogs/modules/auth" | "github.com/gogits/gogs/modules/auth" | ||||
| "github.com/gogits/gogs/modules/base" | "github.com/gogits/gogs/modules/base" | ||||
| "github.com/gogits/gogs/modules/log" | "github.com/gogits/gogs/modules/log" | ||||
| "github.com/gogits/gogs/modules/mailer" | |||||
| "github.com/gogits/gogs/modules/middleware" | "github.com/gogits/gogs/modules/middleware" | ||||
| ) | ) | ||||
| @@ -86,6 +87,14 @@ func CreateIssue(ctx *middleware.Context, params martini.Params, form auth.Creat | |||||
| return | return | ||||
| } | } | ||||
| // Mail watchers. | |||||
| if base.Service.NotifyMail { | |||||
| if err = mailer.SendNotifyMail(ctx.User.Id, ctx.Repo.Repository.Id, ctx.User.Name, ctx.Repo.Repository.Name, issue.Name, issue.Content); err != nil { | |||||
| ctx.Handle(200, "issue.CreateIssue", err) | |||||
| return | |||||
| } | |||||
| } | |||||
| log.Trace("%d Issue created: %d", ctx.Repo.Repository.Id, issue.Id) | log.Trace("%d Issue created: %d", ctx.Repo.Repository.Id, issue.Id) | ||||
| ctx.Redirect(fmt.Sprintf("/%s/%s/issues/%d", params["username"], params["reponame"], issue.Index)) | ctx.Redirect(fmt.Sprintf("/%s/%s/issues/%d", params["username"], params["reponame"], issue.Index)) | ||||
| } | } | ||||