Create & Init Project...
This commit is contained in:
202
app/tool/saga/service/notification/notification.go
Normal file
202
app/tool/saga/service/notification/notification.go
Normal file
@ -0,0 +1,202 @@
|
||||
package notification
|
||||
|
||||
import (
|
||||
"context"
|
||||
"fmt"
|
||||
"runtime/debug"
|
||||
"strconv"
|
||||
"strings"
|
||||
|
||||
"go-common/app/tool/saga/dao"
|
||||
"go-common/app/tool/saga/model"
|
||||
"go-common/app/tool/saga/service/mail"
|
||||
"go-common/app/tool/saga/service/wechat"
|
||||
"go-common/library/log"
|
||||
)
|
||||
|
||||
// WechatAuthor send wechat message to original author
|
||||
func WechatAuthor(dao *dao.Dao, authorName string, url, sourceBranch, targetBranch string, comment string) (err error) {
|
||||
defer func() {
|
||||
if x := recover(); x != nil {
|
||||
log.Error("wechatAuthor: %+v %s", x, debug.Stack())
|
||||
}
|
||||
}()
|
||||
var (
|
||||
subject = fmt.Sprintf("[SAGA] MR ( %s ) merge 通知", sourceBranch)
|
||||
data = fmt.Sprintf("MR : %s \n ( %s -> %s ) 状态 %s", url, sourceBranch, targetBranch, comment)
|
||||
wct = wechat.New(dao)
|
||||
ctx = context.Background()
|
||||
)
|
||||
|
||||
return wct.PushMsg(ctx, []string{authorName}, fmt.Sprintf("%s\n\n%s", subject, data))
|
||||
}
|
||||
|
||||
// MailPipeline ...
|
||||
func MailPipeline(event *model.HookPipeline) (err error) {
|
||||
var (
|
||||
author = event.User.UserName
|
||||
branch = event.ObjectAttributes.Ref
|
||||
commit = event.ObjectAttributes.Sha
|
||||
title = ""
|
||||
url = ""
|
||||
status = "失败"
|
||||
)
|
||||
if event.Commit != nil {
|
||||
commitIndex := strings.LastIndex(event.Commit.URL, "commit")
|
||||
url = event.Commit.URL[:commitIndex] + "pipelines/" + strconv.FormatInt(event.ObjectAttributes.ID, 10)
|
||||
}
|
||||
|
||||
if strings.Contains(event.Commit.Message, "\n") {
|
||||
title = event.Commit.Message[:strings.Index(event.Commit.Message, "\n")]
|
||||
} else {
|
||||
title = event.Commit.Message
|
||||
}
|
||||
|
||||
if event.ObjectAttributes.Status == model.PipelineSuccess {
|
||||
status = "成功"
|
||||
}
|
||||
|
||||
subject := fmt.Sprintf("[SAGA] Pipeline ( %s ) %s 通知", branch, status)
|
||||
data := fmt.Sprintf("Pipeline : %s \nCommit : %s\nCommitID : %s\n状态: 运行%s !", url, title, commit, status)
|
||||
addr := &model.MailAddress{
|
||||
Address: author + "@bilibili.com",
|
||||
Name: author,
|
||||
}
|
||||
|
||||
if err = mail.SendMail2(addr, subject, data); err != nil {
|
||||
log.Error("%+v", err)
|
||||
}
|
||||
return
|
||||
}
|
||||
|
||||
// WechatPipeline ...
|
||||
func WechatPipeline(dao *dao.Dao, event *model.HookPipeline) (err error) {
|
||||
var (
|
||||
wct = wechat.New(dao)
|
||||
ctx = context.Background()
|
||||
author = event.User.UserName
|
||||
branch = event.ObjectAttributes.Ref
|
||||
commit = event.ObjectAttributes.Sha
|
||||
title = ""
|
||||
url = ""
|
||||
status = "失败"
|
||||
)
|
||||
if event.Commit != nil {
|
||||
commitIndex := strings.LastIndex(event.Commit.URL, "commit")
|
||||
url = event.Commit.URL[:commitIndex] + "pipelines/" + strconv.FormatInt(event.ObjectAttributes.ID, 10)
|
||||
}
|
||||
|
||||
if strings.Contains(event.Commit.Message, "\n") {
|
||||
title = event.Commit.Message[:strings.Index(event.Commit.Message, "\n")]
|
||||
} else {
|
||||
title = event.Commit.Message
|
||||
}
|
||||
|
||||
if event.ObjectAttributes.Status == model.PipelineSuccess {
|
||||
status = "成功"
|
||||
}
|
||||
|
||||
subject := fmt.Sprintf("[SAGA] Pipeline ( %s ) %s 通知", branch, status)
|
||||
data := fmt.Sprintf("Pipeline : %s \nCommit : %s\nCommitID : %s\n状态: 运行%s !", url, title, commit, status)
|
||||
|
||||
if err = wct.PushMsg(ctx, []string{author}, fmt.Sprintf("%s\n\n%s", subject, data)); err != nil {
|
||||
log.Error("%+v", err)
|
||||
}
|
||||
return
|
||||
}
|
||||
|
||||
// MailPlusOne ...
|
||||
func MailPlusOne(author, reviewer, url, commit, sourceBranch, targetBranch string) (err error) {
|
||||
var (
|
||||
subject = fmt.Sprintf("[SAGA] MR ( %s ) review 通知", sourceBranch)
|
||||
data = fmt.Sprintf("MR : %s \n ( %s -> %s ) commitID ( %s ) 已被 ( %s ) review!", url, sourceBranch, targetBranch, commit, reviewer)
|
||||
addr = &model.MailAddress{
|
||||
Address: author + "@bilibili.com",
|
||||
Name: author,
|
||||
}
|
||||
)
|
||||
if err = mail.SendMail2(addr, subject, data); err != nil {
|
||||
log.Error("%+v", err)
|
||||
}
|
||||
return
|
||||
}
|
||||
|
||||
// WechatPlusOne ...
|
||||
func WechatPlusOne(dao *dao.Dao, author, reviewer, url, commit, sourceBranch, targetBranch string) (err error) {
|
||||
defer func() {
|
||||
if x := recover(); x != nil {
|
||||
log.Error("wechatPlusOne: %+v %s", x, debug.Stack())
|
||||
}
|
||||
}()
|
||||
var (
|
||||
subject = fmt.Sprintf("[SAGA] MR ( %s ) review 通知", sourceBranch)
|
||||
data = fmt.Sprintf("MR : %s \n ( %s -> %s ) commitID ( %s ) 已被 ( %s ) review!", url, sourceBranch, targetBranch, commit, reviewer)
|
||||
wct = wechat.New(dao)
|
||||
ctx = context.Background()
|
||||
)
|
||||
|
||||
if err = wct.PushMsg(ctx, []string{author}, fmt.Sprintf("%s\n\n%s", subject, data)); err != nil {
|
||||
log.Error("%+v", err)
|
||||
}
|
||||
return
|
||||
}
|
||||
|
||||
// func notifyAssign(assign string, authorName string, url, sourceBranch, targetBranch string) (err error) {
|
||||
// var (
|
||||
// subject = fmt.Sprintf("[SAGA] MR ( %s ) assign 通知", sourceBranch)
|
||||
// data = fmt.Sprintf("MR : %s \n ( %s -> %s ) 开发者 ( %s ) 已指派给您 !", url, sourceBranch, targetBranch, authorName)
|
||||
// addr = &model.MailAddress{
|
||||
// Address: assign + "@bilibili.com",
|
||||
// Name: assign,
|
||||
// }
|
||||
// )
|
||||
// if err = mail.SendMail2(addr, subject, data); err != nil {
|
||||
// log.Error("%+v", err)
|
||||
// }
|
||||
// return
|
||||
// }
|
||||
|
||||
// func wechatAssign(dao *dao.Dao, assign string, authorName string, url, sourceBranch, targetBranch string) (err error) {
|
||||
// var (
|
||||
// subject = fmt.Sprintf("[SAGA] MR ( %s ) assign 通知", sourceBranch)
|
||||
// data = fmt.Sprintf("MR : %s \n ( %s -> %s ) 开发者 ( %s ) 已指派给您 !", url, sourceBranch, targetBranch, authorName)
|
||||
// wct = wechat.New(dao)
|
||||
// ctx = context.Background()
|
||||
// )
|
||||
|
||||
// if err = wct.PushMsg(ctx, []string{assign}, fmt.Sprintf("%s\n\n%s", subject, data)); err != nil {
|
||||
// log.Error("wechatAssign failed, err (%s)", err.Error())
|
||||
// }
|
||||
// return
|
||||
// }
|
||||
|
||||
// func notifyReviewer(reviewers []string, authorName, url, sourceBranch, targetBranch string) (err error) {
|
||||
// var (
|
||||
// subject = fmt.Sprintf("[SAGA] MR ( %s ) review 请求", sourceBranch)
|
||||
// data = fmt.Sprintf("MR : %s \n ( %s -> %s ) 开发者 ( %s ) 需要您的 review !\n请在 review 后留言 +1 !", url, sourceBranch, targetBranch, authorName)
|
||||
// )
|
||||
// for _, reviewer := range reviewers {
|
||||
// addr := &model.MailAddress{
|
||||
// Address: reviewer + "@bilibili.com",
|
||||
// Name: reviewer,
|
||||
// }
|
||||
// if err = mail.SendMail2(addr, subject, data); err != nil {
|
||||
// log.Error("%+v", err)
|
||||
// }
|
||||
// }
|
||||
// return
|
||||
// }
|
||||
|
||||
// func wechatReviewer(dao *dao.Dao, reviewers []string, authorName, url, sourceBranch, targetBranch string) (err error) {
|
||||
// var (
|
||||
// subject = fmt.Sprintf("[SAGA] MR ( %s ) review 请求", sourceBranch)
|
||||
// data = fmt.Sprintf("MR : %s \n ( %s -> %s ) 开发者 ( %s ) 需要您的 review !\n请在 review 后留言 +1 !", url, sourceBranch, targetBranch, authorName)
|
||||
// wct = wechat.New(dao)
|
||||
// ctx = context.Background()
|
||||
// )
|
||||
|
||||
// if err = wct.PushMsg(ctx, reviewers, fmt.Sprintf("%s\n\n%s", subject, data)); err != nil {
|
||||
// log.Error("%+v", err)
|
||||
// }
|
||||
// return
|
||||
// }
|
Reference in New Issue
Block a user