Improve webhooks (#8583)
* Improve webhooks Signed-off-by: jolheiser <john.olheiser@gmail.com> * Update MSTeams and ReviewPayload comment Signed-off-by: jolheiser <john.olheiser@gmail.com> * Add repo.FullName to comments Signed-off-by: jolheiser <john.olheiser@gmail.com>
This commit is contained in:
parent
05e437f8fd
commit
0a004a69cd
|
@ -183,22 +183,36 @@ func getDingtalkIssuesPayload(p *api.IssuePayload) (*DingtalkPayload, error) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func getDingtalkIssueCommentPayload(p *api.IssueCommentPayload) (*DingtalkPayload, error) {
|
func getDingtalkIssueCommentPayload(p *api.IssueCommentPayload) (*DingtalkPayload, error) {
|
||||||
title := fmt.Sprintf("#%d %s", p.Issue.Index, p.Issue.Title)
|
title := fmt.Sprintf("#%d: %s", p.Issue.Index, p.Issue.Title)
|
||||||
url := fmt.Sprintf("%s/issues/%d#%s", p.Repository.HTMLURL, p.Issue.Index, CommentHashTag(p.Comment.ID))
|
url := fmt.Sprintf("%s/issues/%d#%s", p.Repository.HTMLURL, p.Issue.Index, CommentHashTag(p.Comment.ID))
|
||||||
var content string
|
var content string
|
||||||
switch p.Action {
|
switch p.Action {
|
||||||
case api.HookIssueCommentCreated:
|
case api.HookIssueCommentCreated:
|
||||||
title = "New comment: " + title
|
if p.IsPull {
|
||||||
|
title = "New comment on pull request " + title
|
||||||
|
} else {
|
||||||
|
title = "New comment on issue " + title
|
||||||
|
}
|
||||||
content = p.Comment.Body
|
content = p.Comment.Body
|
||||||
case api.HookIssueCommentEdited:
|
case api.HookIssueCommentEdited:
|
||||||
title = "Comment edited: " + title
|
if p.IsPull {
|
||||||
|
title = "Comment edited on pull request " + title
|
||||||
|
} else {
|
||||||
|
title = "Comment edited on issue " + title
|
||||||
|
}
|
||||||
content = p.Comment.Body
|
content = p.Comment.Body
|
||||||
case api.HookIssueCommentDeleted:
|
case api.HookIssueCommentDeleted:
|
||||||
title = "Comment deleted: " + title
|
if p.IsPull {
|
||||||
|
title = "Comment deleted on pull request " + title
|
||||||
|
} else {
|
||||||
|
title = "Comment deleted on issue " + title
|
||||||
|
}
|
||||||
url = fmt.Sprintf("%s/issues/%d", p.Repository.HTMLURL, p.Issue.Index)
|
url = fmt.Sprintf("%s/issues/%d", p.Repository.HTMLURL, p.Issue.Index)
|
||||||
content = p.Comment.Body
|
content = p.Comment.Body
|
||||||
}
|
}
|
||||||
|
|
||||||
|
title = fmt.Sprintf("[%s] %s", p.Repository.FullName, title)
|
||||||
|
|
||||||
return &DingtalkPayload{
|
return &DingtalkPayload{
|
||||||
MsgType: "actionCard",
|
MsgType: "actionCard",
|
||||||
ActionCard: dingtalk.ActionCard{
|
ActionCard: dingtalk.ActionCard{
|
||||||
|
@ -282,7 +296,7 @@ func getDingtalkPullRequestApprovalPayload(p *api.PullRequestPayload, event Hook
|
||||||
}
|
}
|
||||||
|
|
||||||
title = fmt.Sprintf("[%s] Pull request review %s : #%d %s", p.Repository.FullName, action, p.Index, p.PullRequest.Title)
|
title = fmt.Sprintf("[%s] Pull request review %s : #%d %s", p.Repository.FullName, action, p.Index, p.PullRequest.Title)
|
||||||
text = p.PullRequest.Body
|
text = p.Review.Content
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -75,9 +75,14 @@ func color(clr string) int {
|
||||||
}
|
}
|
||||||
|
|
||||||
var (
|
var (
|
||||||
successColor = color("1ac600")
|
greenColor = color("1ac600")
|
||||||
warnColor = color("ffd930")
|
greenColorLight = color("bfe5bf")
|
||||||
failedColor = color("ff3232")
|
yellowColor = color("ffd930")
|
||||||
|
greyColor = color("4f545c")
|
||||||
|
purpleColor = color("7289da")
|
||||||
|
orangeColor = color("eb6420")
|
||||||
|
orangeColorLight = color("e68d60")
|
||||||
|
redColor = color("ff3232")
|
||||||
)
|
)
|
||||||
|
|
||||||
// SetSecret sets the discord secret
|
// SetSecret sets the discord secret
|
||||||
|
@ -104,7 +109,7 @@ func getDiscordCreatePayload(p *api.CreatePayload, meta *DiscordMeta) (*DiscordP
|
||||||
{
|
{
|
||||||
Title: title,
|
Title: title,
|
||||||
URL: p.Repo.HTMLURL + "/src/" + refName,
|
URL: p.Repo.HTMLURL + "/src/" + refName,
|
||||||
Color: successColor,
|
Color: greenColor,
|
||||||
Author: DiscordEmbedAuthor{
|
Author: DiscordEmbedAuthor{
|
||||||
Name: p.Sender.UserName,
|
Name: p.Sender.UserName,
|
||||||
URL: setting.AppURL + p.Sender.UserName,
|
URL: setting.AppURL + p.Sender.UserName,
|
||||||
|
@ -127,7 +132,7 @@ func getDiscordDeletePayload(p *api.DeletePayload, meta *DiscordMeta) (*DiscordP
|
||||||
{
|
{
|
||||||
Title: title,
|
Title: title,
|
||||||
URL: p.Repo.HTMLURL + "/src/" + refName,
|
URL: p.Repo.HTMLURL + "/src/" + refName,
|
||||||
Color: warnColor,
|
Color: redColor,
|
||||||
Author: DiscordEmbedAuthor{
|
Author: DiscordEmbedAuthor{
|
||||||
Name: p.Sender.UserName,
|
Name: p.Sender.UserName,
|
||||||
URL: setting.AppURL + p.Sender.UserName,
|
URL: setting.AppURL + p.Sender.UserName,
|
||||||
|
@ -149,7 +154,7 @@ func getDiscordForkPayload(p *api.ForkPayload, meta *DiscordMeta) (*DiscordPaylo
|
||||||
{
|
{
|
||||||
Title: title,
|
Title: title,
|
||||||
URL: p.Repo.HTMLURL,
|
URL: p.Repo.HTMLURL,
|
||||||
Color: successColor,
|
Color: greenColor,
|
||||||
Author: DiscordEmbedAuthor{
|
Author: DiscordEmbedAuthor{
|
||||||
Name: p.Sender.UserName,
|
Name: p.Sender.UserName,
|
||||||
URL: setting.AppURL + p.Sender.UserName,
|
URL: setting.AppURL + p.Sender.UserName,
|
||||||
|
@ -199,7 +204,7 @@ func getDiscordPushPayload(p *api.PushPayload, meta *DiscordMeta) (*DiscordPaylo
|
||||||
Title: title,
|
Title: title,
|
||||||
Description: text,
|
Description: text,
|
||||||
URL: titleLink,
|
URL: titleLink,
|
||||||
Color: successColor,
|
Color: greenColor,
|
||||||
Author: DiscordEmbedAuthor{
|
Author: DiscordEmbedAuthor{
|
||||||
Name: p.Sender.UserName,
|
Name: p.Sender.UserName,
|
||||||
URL: setting.AppURL + p.Sender.UserName,
|
URL: setting.AppURL + p.Sender.UserName,
|
||||||
|
@ -218,48 +223,48 @@ func getDiscordIssuesPayload(p *api.IssuePayload, meta *DiscordMeta) (*DiscordPa
|
||||||
case api.HookIssueOpened:
|
case api.HookIssueOpened:
|
||||||
title = fmt.Sprintf("[%s] Issue opened: #%d %s", p.Repository.FullName, p.Index, p.Issue.Title)
|
title = fmt.Sprintf("[%s] Issue opened: #%d %s", p.Repository.FullName, p.Index, p.Issue.Title)
|
||||||
text = p.Issue.Body
|
text = p.Issue.Body
|
||||||
color = warnColor
|
color = orangeColor
|
||||||
case api.HookIssueClosed:
|
case api.HookIssueClosed:
|
||||||
title = fmt.Sprintf("[%s] Issue closed: #%d %s", p.Repository.FullName, p.Index, p.Issue.Title)
|
title = fmt.Sprintf("[%s] Issue closed: #%d %s", p.Repository.FullName, p.Index, p.Issue.Title)
|
||||||
color = failedColor
|
color = redColor
|
||||||
text = p.Issue.Body
|
text = p.Issue.Body
|
||||||
case api.HookIssueReOpened:
|
case api.HookIssueReOpened:
|
||||||
title = fmt.Sprintf("[%s] Issue re-opened: #%d %s", p.Repository.FullName, p.Index, p.Issue.Title)
|
title = fmt.Sprintf("[%s] Issue re-opened: #%d %s", p.Repository.FullName, p.Index, p.Issue.Title)
|
||||||
text = p.Issue.Body
|
text = p.Issue.Body
|
||||||
color = warnColor
|
color = yellowColor
|
||||||
case api.HookIssueEdited:
|
case api.HookIssueEdited:
|
||||||
title = fmt.Sprintf("[%s] Issue edited: #%d %s", p.Repository.FullName, p.Index, p.Issue.Title)
|
title = fmt.Sprintf("[%s] Issue edited: #%d %s", p.Repository.FullName, p.Index, p.Issue.Title)
|
||||||
text = p.Issue.Body
|
text = p.Issue.Body
|
||||||
color = warnColor
|
color = yellowColor
|
||||||
case api.HookIssueAssigned:
|
case api.HookIssueAssigned:
|
||||||
title = fmt.Sprintf("[%s] Issue assigned to %s: #%d %s", p.Repository.FullName,
|
title = fmt.Sprintf("[%s] Issue assigned to %s: #%d %s", p.Repository.FullName,
|
||||||
p.Issue.Assignee.UserName, p.Index, p.Issue.Title)
|
p.Issue.Assignee.UserName, p.Index, p.Issue.Title)
|
||||||
text = p.Issue.Body
|
text = p.Issue.Body
|
||||||
color = successColor
|
color = greenColor
|
||||||
case api.HookIssueUnassigned:
|
case api.HookIssueUnassigned:
|
||||||
title = fmt.Sprintf("[%s] Issue unassigned: #%d %s", p.Repository.FullName, p.Index, p.Issue.Title)
|
title = fmt.Sprintf("[%s] Issue unassigned: #%d %s", p.Repository.FullName, p.Index, p.Issue.Title)
|
||||||
text = p.Issue.Body
|
text = p.Issue.Body
|
||||||
color = warnColor
|
color = yellowColor
|
||||||
case api.HookIssueLabelUpdated:
|
case api.HookIssueLabelUpdated:
|
||||||
title = fmt.Sprintf("[%s] Issue labels updated: #%d %s", p.Repository.FullName, p.Index, p.Issue.Title)
|
title = fmt.Sprintf("[%s] Issue labels updated: #%d %s", p.Repository.FullName, p.Index, p.Issue.Title)
|
||||||
text = p.Issue.Body
|
text = p.Issue.Body
|
||||||
color = warnColor
|
color = yellowColor
|
||||||
case api.HookIssueLabelCleared:
|
case api.HookIssueLabelCleared:
|
||||||
title = fmt.Sprintf("[%s] Issue labels cleared: #%d %s", p.Repository.FullName, p.Index, p.Issue.Title)
|
title = fmt.Sprintf("[%s] Issue labels cleared: #%d %s", p.Repository.FullName, p.Index, p.Issue.Title)
|
||||||
text = p.Issue.Body
|
text = p.Issue.Body
|
||||||
color = warnColor
|
color = yellowColor
|
||||||
case api.HookIssueSynchronized:
|
case api.HookIssueSynchronized:
|
||||||
title = fmt.Sprintf("[%s] Issue synchronized: #%d %s", p.Repository.FullName, p.Index, p.Issue.Title)
|
title = fmt.Sprintf("[%s] Issue synchronized: #%d %s", p.Repository.FullName, p.Index, p.Issue.Title)
|
||||||
text = p.Issue.Body
|
text = p.Issue.Body
|
||||||
color = warnColor
|
color = yellowColor
|
||||||
case api.HookIssueMilestoned:
|
case api.HookIssueMilestoned:
|
||||||
title = fmt.Sprintf("[%s] Issue milestone: #%d %s", p.Repository.FullName, p.Index, p.Issue.Title)
|
title = fmt.Sprintf("[%s] Issue milestone: #%d %s", p.Repository.FullName, p.Index, p.Issue.Title)
|
||||||
text = p.Issue.Body
|
text = p.Issue.Body
|
||||||
color = warnColor
|
color = yellowColor
|
||||||
case api.HookIssueDemilestoned:
|
case api.HookIssueDemilestoned:
|
||||||
title = fmt.Sprintf("[%s] Issue clear milestone: #%d %s", p.Repository.FullName, p.Index, p.Issue.Title)
|
title = fmt.Sprintf("[%s] Issue clear milestone: #%d %s", p.Repository.FullName, p.Index, p.Issue.Title)
|
||||||
text = p.Issue.Body
|
text = p.Issue.Body
|
||||||
color = warnColor
|
color = yellowColor
|
||||||
}
|
}
|
||||||
|
|
||||||
return &DiscordPayload{
|
return &DiscordPayload{
|
||||||
|
@ -282,26 +287,41 @@ func getDiscordIssuesPayload(p *api.IssuePayload, meta *DiscordMeta) (*DiscordPa
|
||||||
}
|
}
|
||||||
|
|
||||||
func getDiscordIssueCommentPayload(p *api.IssueCommentPayload, discord *DiscordMeta) (*DiscordPayload, error) {
|
func getDiscordIssueCommentPayload(p *api.IssueCommentPayload, discord *DiscordMeta) (*DiscordPayload, error) {
|
||||||
title := fmt.Sprintf("#%d %s", p.Issue.Index, p.Issue.Title)
|
title := fmt.Sprintf("#%d: %s", p.Issue.Index, p.Issue.Title)
|
||||||
url := fmt.Sprintf("%s/issues/%d#%s", p.Repository.HTMLURL, p.Issue.Index, CommentHashTag(p.Comment.ID))
|
url := fmt.Sprintf("%s/issues/%d#%s", p.Repository.HTMLURL, p.Issue.Index, CommentHashTag(p.Comment.ID))
|
||||||
content := ""
|
content := ""
|
||||||
var color int
|
var color int
|
||||||
switch p.Action {
|
switch p.Action {
|
||||||
case api.HookIssueCommentCreated:
|
case api.HookIssueCommentCreated:
|
||||||
title = "New comment: " + title
|
if p.IsPull {
|
||||||
|
title = "New comment on pull request " + title
|
||||||
|
color = greenColorLight
|
||||||
|
} else {
|
||||||
|
title = "New comment on issue " + title
|
||||||
|
color = orangeColorLight
|
||||||
|
}
|
||||||
content = p.Comment.Body
|
content = p.Comment.Body
|
||||||
color = successColor
|
|
||||||
case api.HookIssueCommentEdited:
|
case api.HookIssueCommentEdited:
|
||||||
title = "Comment edited: " + title
|
if p.IsPull {
|
||||||
|
title = "Comment edited on pull request " + title
|
||||||
|
} else {
|
||||||
|
title = "Comment edited on issue " + title
|
||||||
|
}
|
||||||
content = p.Comment.Body
|
content = p.Comment.Body
|
||||||
color = warnColor
|
color = yellowColor
|
||||||
case api.HookIssueCommentDeleted:
|
case api.HookIssueCommentDeleted:
|
||||||
title = "Comment deleted: " + title
|
if p.IsPull {
|
||||||
|
title = "Comment deleted on pull request " + title
|
||||||
|
} else {
|
||||||
|
title = "Comment deleted on issue " + title
|
||||||
|
}
|
||||||
url = fmt.Sprintf("%s/issues/%d", p.Repository.HTMLURL, p.Issue.Index)
|
url = fmt.Sprintf("%s/issues/%d", p.Repository.HTMLURL, p.Issue.Index)
|
||||||
content = p.Comment.Body
|
content = p.Comment.Body
|
||||||
color = warnColor
|
color = redColor
|
||||||
}
|
}
|
||||||
|
|
||||||
|
title = fmt.Sprintf("[%s] %s", p.Repository.FullName, title)
|
||||||
|
|
||||||
return &DiscordPayload{
|
return &DiscordPayload{
|
||||||
Username: discord.Username,
|
Username: discord.Username,
|
||||||
AvatarURL: discord.IconURL,
|
AvatarURL: discord.IconURL,
|
||||||
|
@ -328,24 +348,24 @@ func getDiscordPullRequestPayload(p *api.PullRequestPayload, meta *DiscordMeta)
|
||||||
case api.HookIssueOpened:
|
case api.HookIssueOpened:
|
||||||
title = fmt.Sprintf("[%s] Pull request opened: #%d %s", p.Repository.FullName, p.Index, p.PullRequest.Title)
|
title = fmt.Sprintf("[%s] Pull request opened: #%d %s", p.Repository.FullName, p.Index, p.PullRequest.Title)
|
||||||
text = p.PullRequest.Body
|
text = p.PullRequest.Body
|
||||||
color = warnColor
|
color = greenColor
|
||||||
case api.HookIssueClosed:
|
case api.HookIssueClosed:
|
||||||
if p.PullRequest.HasMerged {
|
if p.PullRequest.HasMerged {
|
||||||
title = fmt.Sprintf("[%s] Pull request merged: #%d %s", p.Repository.FullName, p.Index, p.PullRequest.Title)
|
title = fmt.Sprintf("[%s] Pull request merged: #%d %s", p.Repository.FullName, p.Index, p.PullRequest.Title)
|
||||||
color = successColor
|
color = purpleColor
|
||||||
} else {
|
} else {
|
||||||
title = fmt.Sprintf("[%s] Pull request closed: #%d %s", p.Repository.FullName, p.Index, p.PullRequest.Title)
|
title = fmt.Sprintf("[%s] Pull request closed: #%d %s", p.Repository.FullName, p.Index, p.PullRequest.Title)
|
||||||
color = failedColor
|
color = redColor
|
||||||
}
|
}
|
||||||
text = p.PullRequest.Body
|
text = p.PullRequest.Body
|
||||||
case api.HookIssueReOpened:
|
case api.HookIssueReOpened:
|
||||||
title = fmt.Sprintf("[%s] Pull request re-opened: #%d %s", p.Repository.FullName, p.Index, p.PullRequest.Title)
|
title = fmt.Sprintf("[%s] Pull request re-opened: #%d %s", p.Repository.FullName, p.Index, p.PullRequest.Title)
|
||||||
text = p.PullRequest.Body
|
text = p.PullRequest.Body
|
||||||
color = warnColor
|
color = yellowColor
|
||||||
case api.HookIssueEdited:
|
case api.HookIssueEdited:
|
||||||
title = fmt.Sprintf("[%s] Pull request edited: #%d %s", p.Repository.FullName, p.Index, p.PullRequest.Title)
|
title = fmt.Sprintf("[%s] Pull request edited: #%d %s", p.Repository.FullName, p.Index, p.PullRequest.Title)
|
||||||
text = p.PullRequest.Body
|
text = p.PullRequest.Body
|
||||||
color = warnColor
|
color = yellowColor
|
||||||
case api.HookIssueAssigned:
|
case api.HookIssueAssigned:
|
||||||
list := make([]string, len(p.PullRequest.Assignees))
|
list := make([]string, len(p.PullRequest.Assignees))
|
||||||
for i, user := range p.PullRequest.Assignees {
|
for i, user := range p.PullRequest.Assignees {
|
||||||
|
@ -355,31 +375,31 @@ func getDiscordPullRequestPayload(p *api.PullRequestPayload, meta *DiscordMeta)
|
||||||
strings.Join(list, ", "),
|
strings.Join(list, ", "),
|
||||||
p.Index, p.PullRequest.Title)
|
p.Index, p.PullRequest.Title)
|
||||||
text = p.PullRequest.Body
|
text = p.PullRequest.Body
|
||||||
color = successColor
|
color = greenColor
|
||||||
case api.HookIssueUnassigned:
|
case api.HookIssueUnassigned:
|
||||||
title = fmt.Sprintf("[%s] Pull request unassigned: #%d %s", p.Repository.FullName, p.Index, p.PullRequest.Title)
|
title = fmt.Sprintf("[%s] Pull request unassigned: #%d %s", p.Repository.FullName, p.Index, p.PullRequest.Title)
|
||||||
text = p.PullRequest.Body
|
text = p.PullRequest.Body
|
||||||
color = warnColor
|
color = yellowColor
|
||||||
case api.HookIssueLabelUpdated:
|
case api.HookIssueLabelUpdated:
|
||||||
title = fmt.Sprintf("[%s] Pull request labels updated: #%d %s", p.Repository.FullName, p.Index, p.PullRequest.Title)
|
title = fmt.Sprintf("[%s] Pull request labels updated: #%d %s", p.Repository.FullName, p.Index, p.PullRequest.Title)
|
||||||
text = p.PullRequest.Body
|
text = p.PullRequest.Body
|
||||||
color = warnColor
|
color = yellowColor
|
||||||
case api.HookIssueLabelCleared:
|
case api.HookIssueLabelCleared:
|
||||||
title = fmt.Sprintf("[%s] Pull request labels cleared: #%d %s", p.Repository.FullName, p.Index, p.PullRequest.Title)
|
title = fmt.Sprintf("[%s] Pull request labels cleared: #%d %s", p.Repository.FullName, p.Index, p.PullRequest.Title)
|
||||||
text = p.PullRequest.Body
|
text = p.PullRequest.Body
|
||||||
color = warnColor
|
color = yellowColor
|
||||||
case api.HookIssueSynchronized:
|
case api.HookIssueSynchronized:
|
||||||
title = fmt.Sprintf("[%s] Pull request synchronized: #%d %s", p.Repository.FullName, p.Index, p.PullRequest.Title)
|
title = fmt.Sprintf("[%s] Pull request synchronized: #%d %s", p.Repository.FullName, p.Index, p.PullRequest.Title)
|
||||||
text = p.PullRequest.Body
|
text = p.PullRequest.Body
|
||||||
color = warnColor
|
color = yellowColor
|
||||||
case api.HookIssueMilestoned:
|
case api.HookIssueMilestoned:
|
||||||
title = fmt.Sprintf("[%s] Pull request milestone: #%d %s", p.Repository.FullName, p.Index, p.PullRequest.Title)
|
title = fmt.Sprintf("[%s] Pull request milestone: #%d %s", p.Repository.FullName, p.Index, p.PullRequest.Title)
|
||||||
text = p.PullRequest.Body
|
text = p.PullRequest.Body
|
||||||
color = warnColor
|
color = yellowColor
|
||||||
case api.HookIssueDemilestoned:
|
case api.HookIssueDemilestoned:
|
||||||
title = fmt.Sprintf("[%s] Pull request clear milestone: #%d %s", p.Repository.FullName, p.Index, p.PullRequest.Title)
|
title = fmt.Sprintf("[%s] Pull request clear milestone: #%d %s", p.Repository.FullName, p.Index, p.PullRequest.Title)
|
||||||
text = p.PullRequest.Body
|
text = p.PullRequest.Body
|
||||||
color = warnColor
|
color = yellowColor
|
||||||
}
|
}
|
||||||
|
|
||||||
return &DiscordPayload{
|
return &DiscordPayload{
|
||||||
|
@ -412,17 +432,17 @@ func getDiscordPullRequestApprovalPayload(p *api.PullRequestPayload, meta *Disco
|
||||||
}
|
}
|
||||||
|
|
||||||
title = fmt.Sprintf("[%s] Pull request review %s: #%d %s", p.Repository.FullName, action, p.Index, p.PullRequest.Title)
|
title = fmt.Sprintf("[%s] Pull request review %s: #%d %s", p.Repository.FullName, action, p.Index, p.PullRequest.Title)
|
||||||
text = p.PullRequest.Body
|
text = p.Review.Content
|
||||||
|
|
||||||
switch event {
|
switch event {
|
||||||
case HookEventPullRequestApproved:
|
case HookEventPullRequestApproved:
|
||||||
color = successColor
|
color = greenColor
|
||||||
case HookEventPullRequestRejected:
|
case HookEventPullRequestRejected:
|
||||||
color = failedColor
|
color = redColor
|
||||||
case HookEventPullRequestComment:
|
case HookEventPullRequestComment:
|
||||||
fallthrough
|
color = greyColor
|
||||||
default:
|
default:
|
||||||
color = warnColor
|
color = yellowColor
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -452,10 +472,10 @@ func getDiscordRepositoryPayload(p *api.RepositoryPayload, meta *DiscordMeta) (*
|
||||||
case api.HookRepoCreated:
|
case api.HookRepoCreated:
|
||||||
title = fmt.Sprintf("[%s] Repository created", p.Repository.FullName)
|
title = fmt.Sprintf("[%s] Repository created", p.Repository.FullName)
|
||||||
url = p.Repository.HTMLURL
|
url = p.Repository.HTMLURL
|
||||||
color = successColor
|
color = greenColor
|
||||||
case api.HookRepoDeleted:
|
case api.HookRepoDeleted:
|
||||||
title = fmt.Sprintf("[%s] Repository deleted", p.Repository.FullName)
|
title = fmt.Sprintf("[%s] Repository deleted", p.Repository.FullName)
|
||||||
color = warnColor
|
color = redColor
|
||||||
}
|
}
|
||||||
|
|
||||||
return &DiscordPayload{
|
return &DiscordPayload{
|
||||||
|
@ -483,15 +503,15 @@ func getDiscordReleasePayload(p *api.ReleasePayload, meta *DiscordMeta) (*Discor
|
||||||
case api.HookReleasePublished:
|
case api.HookReleasePublished:
|
||||||
title = fmt.Sprintf("[%s] Release created", p.Release.TagName)
|
title = fmt.Sprintf("[%s] Release created", p.Release.TagName)
|
||||||
url = p.Release.URL
|
url = p.Release.URL
|
||||||
color = successColor
|
color = greenColor
|
||||||
case api.HookReleaseUpdated:
|
case api.HookReleaseUpdated:
|
||||||
title = fmt.Sprintf("[%s] Release updated", p.Release.TagName)
|
title = fmt.Sprintf("[%s] Release updated", p.Release.TagName)
|
||||||
url = p.Release.URL
|
url = p.Release.URL
|
||||||
color = successColor
|
color = yellowColor
|
||||||
case api.HookReleaseDeleted:
|
case api.HookReleaseDeleted:
|
||||||
title = fmt.Sprintf("[%s] Release deleted", p.Release.TagName)
|
title = fmt.Sprintf("[%s] Release deleted", p.Release.TagName)
|
||||||
url = p.Release.URL
|
url = p.Release.URL
|
||||||
color = successColor
|
color = redColor
|
||||||
}
|
}
|
||||||
|
|
||||||
return &DiscordPayload{
|
return &DiscordPayload{
|
||||||
|
|
|
@ -74,7 +74,7 @@ func getMSTeamsCreatePayload(p *api.CreatePayload) (*MSTeamsPayload, error) {
|
||||||
return &MSTeamsPayload{
|
return &MSTeamsPayload{
|
||||||
Type: "MessageCard",
|
Type: "MessageCard",
|
||||||
Context: "https://schema.org/extensions",
|
Context: "https://schema.org/extensions",
|
||||||
ThemeColor: fmt.Sprintf("%x", successColor),
|
ThemeColor: fmt.Sprintf("%x", greenColor),
|
||||||
Title: title,
|
Title: title,
|
||||||
Summary: title,
|
Summary: title,
|
||||||
Sections: []MSTeamsSection{
|
Sections: []MSTeamsSection{
|
||||||
|
@ -117,7 +117,7 @@ func getMSTeamsDeletePayload(p *api.DeletePayload) (*MSTeamsPayload, error) {
|
||||||
return &MSTeamsPayload{
|
return &MSTeamsPayload{
|
||||||
Type: "MessageCard",
|
Type: "MessageCard",
|
||||||
Context: "https://schema.org/extensions",
|
Context: "https://schema.org/extensions",
|
||||||
ThemeColor: fmt.Sprintf("%x", warnColor),
|
ThemeColor: fmt.Sprintf("%x", yellowColor),
|
||||||
Title: title,
|
Title: title,
|
||||||
Summary: title,
|
Summary: title,
|
||||||
Sections: []MSTeamsSection{
|
Sections: []MSTeamsSection{
|
||||||
|
@ -159,7 +159,7 @@ func getMSTeamsForkPayload(p *api.ForkPayload) (*MSTeamsPayload, error) {
|
||||||
return &MSTeamsPayload{
|
return &MSTeamsPayload{
|
||||||
Type: "MessageCard",
|
Type: "MessageCard",
|
||||||
Context: "https://schema.org/extensions",
|
Context: "https://schema.org/extensions",
|
||||||
ThemeColor: fmt.Sprintf("%x", successColor),
|
ThemeColor: fmt.Sprintf("%x", greenColor),
|
||||||
Title: title,
|
Title: title,
|
||||||
Summary: title,
|
Summary: title,
|
||||||
Sections: []MSTeamsSection{
|
Sections: []MSTeamsSection{
|
||||||
|
@ -228,7 +228,7 @@ func getMSTeamsPushPayload(p *api.PushPayload) (*MSTeamsPayload, error) {
|
||||||
return &MSTeamsPayload{
|
return &MSTeamsPayload{
|
||||||
Type: "MessageCard",
|
Type: "MessageCard",
|
||||||
Context: "https://schema.org/extensions",
|
Context: "https://schema.org/extensions",
|
||||||
ThemeColor: fmt.Sprintf("%x", successColor),
|
ThemeColor: fmt.Sprintf("%x", greenColor),
|
||||||
Title: title,
|
Title: title,
|
||||||
Summary: title,
|
Summary: title,
|
||||||
Sections: []MSTeamsSection{
|
Sections: []MSTeamsSection{
|
||||||
|
@ -272,48 +272,48 @@ func getMSTeamsIssuesPayload(p *api.IssuePayload) (*MSTeamsPayload, error) {
|
||||||
case api.HookIssueOpened:
|
case api.HookIssueOpened:
|
||||||
title = fmt.Sprintf("[%s] Issue opened: #%d %s", p.Repository.FullName, p.Index, p.Issue.Title)
|
title = fmt.Sprintf("[%s] Issue opened: #%d %s", p.Repository.FullName, p.Index, p.Issue.Title)
|
||||||
text = p.Issue.Body
|
text = p.Issue.Body
|
||||||
color = warnColor
|
color = orangeColor
|
||||||
case api.HookIssueClosed:
|
case api.HookIssueClosed:
|
||||||
title = fmt.Sprintf("[%s] Issue closed: #%d %s", p.Repository.FullName, p.Index, p.Issue.Title)
|
title = fmt.Sprintf("[%s] Issue closed: #%d %s", p.Repository.FullName, p.Index, p.Issue.Title)
|
||||||
color = failedColor
|
color = redColor
|
||||||
text = p.Issue.Body
|
text = p.Issue.Body
|
||||||
case api.HookIssueReOpened:
|
case api.HookIssueReOpened:
|
||||||
title = fmt.Sprintf("[%s] Issue re-opened: #%d %s", p.Repository.FullName, p.Index, p.Issue.Title)
|
title = fmt.Sprintf("[%s] Issue re-opened: #%d %s", p.Repository.FullName, p.Index, p.Issue.Title)
|
||||||
text = p.Issue.Body
|
text = p.Issue.Body
|
||||||
color = warnColor
|
color = yellowColor
|
||||||
case api.HookIssueEdited:
|
case api.HookIssueEdited:
|
||||||
title = fmt.Sprintf("[%s] Issue edited: #%d %s", p.Repository.FullName, p.Index, p.Issue.Title)
|
title = fmt.Sprintf("[%s] Issue edited: #%d %s", p.Repository.FullName, p.Index, p.Issue.Title)
|
||||||
text = p.Issue.Body
|
text = p.Issue.Body
|
||||||
color = warnColor
|
color = yellowColor
|
||||||
case api.HookIssueAssigned:
|
case api.HookIssueAssigned:
|
||||||
title = fmt.Sprintf("[%s] Issue assigned to %s: #%d %s", p.Repository.FullName,
|
title = fmt.Sprintf("[%s] Issue assigned to %s: #%d %s", p.Repository.FullName,
|
||||||
p.Issue.Assignee.UserName, p.Index, p.Issue.Title)
|
p.Issue.Assignee.UserName, p.Index, p.Issue.Title)
|
||||||
text = p.Issue.Body
|
text = p.Issue.Body
|
||||||
color = successColor
|
color = greenColor
|
||||||
case api.HookIssueUnassigned:
|
case api.HookIssueUnassigned:
|
||||||
title = fmt.Sprintf("[%s] Issue unassigned: #%d %s", p.Repository.FullName, p.Index, p.Issue.Title)
|
title = fmt.Sprintf("[%s] Issue unassigned: #%d %s", p.Repository.FullName, p.Index, p.Issue.Title)
|
||||||
text = p.Issue.Body
|
text = p.Issue.Body
|
||||||
color = warnColor
|
color = yellowColor
|
||||||
case api.HookIssueLabelUpdated:
|
case api.HookIssueLabelUpdated:
|
||||||
title = fmt.Sprintf("[%s] Issue labels updated: #%d %s", p.Repository.FullName, p.Index, p.Issue.Title)
|
title = fmt.Sprintf("[%s] Issue labels updated: #%d %s", p.Repository.FullName, p.Index, p.Issue.Title)
|
||||||
text = p.Issue.Body
|
text = p.Issue.Body
|
||||||
color = warnColor
|
color = yellowColor
|
||||||
case api.HookIssueLabelCleared:
|
case api.HookIssueLabelCleared:
|
||||||
title = fmt.Sprintf("[%s] Issue labels cleared: #%d %s", p.Repository.FullName, p.Index, p.Issue.Title)
|
title = fmt.Sprintf("[%s] Issue labels cleared: #%d %s", p.Repository.FullName, p.Index, p.Issue.Title)
|
||||||
text = p.Issue.Body
|
text = p.Issue.Body
|
||||||
color = warnColor
|
color = yellowColor
|
||||||
case api.HookIssueSynchronized:
|
case api.HookIssueSynchronized:
|
||||||
title = fmt.Sprintf("[%s] Issue synchronized: #%d %s", p.Repository.FullName, p.Index, p.Issue.Title)
|
title = fmt.Sprintf("[%s] Issue synchronized: #%d %s", p.Repository.FullName, p.Index, p.Issue.Title)
|
||||||
text = p.Issue.Body
|
text = p.Issue.Body
|
||||||
color = warnColor
|
color = yellowColor
|
||||||
case api.HookIssueMilestoned:
|
case api.HookIssueMilestoned:
|
||||||
title = fmt.Sprintf("[%s] Issue milestone: #%d %s", p.Repository.FullName, p.Index, p.Issue.Title)
|
title = fmt.Sprintf("[%s] Issue milestone: #%d %s", p.Repository.FullName, p.Index, p.Issue.Title)
|
||||||
text = p.Issue.Body
|
text = p.Issue.Body
|
||||||
color = warnColor
|
color = yellowColor
|
||||||
case api.HookIssueDemilestoned:
|
case api.HookIssueDemilestoned:
|
||||||
title = fmt.Sprintf("[%s] Issue clear milestone: #%d %s", p.Repository.FullName, p.Index, p.Issue.Title)
|
title = fmt.Sprintf("[%s] Issue clear milestone: #%d %s", p.Repository.FullName, p.Index, p.Issue.Title)
|
||||||
text = p.Issue.Body
|
text = p.Issue.Body
|
||||||
color = warnColor
|
color = yellowColor
|
||||||
}
|
}
|
||||||
|
|
||||||
return &MSTeamsPayload{
|
return &MSTeamsPayload{
|
||||||
|
@ -356,26 +356,41 @@ func getMSTeamsIssuesPayload(p *api.IssuePayload) (*MSTeamsPayload, error) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func getMSTeamsIssueCommentPayload(p *api.IssueCommentPayload) (*MSTeamsPayload, error) {
|
func getMSTeamsIssueCommentPayload(p *api.IssueCommentPayload) (*MSTeamsPayload, error) {
|
||||||
title := fmt.Sprintf("#%d %s", p.Issue.Index, p.Issue.Title)
|
title := fmt.Sprintf("#%d: %s", p.Issue.Index, p.Issue.Title)
|
||||||
url := fmt.Sprintf("%s/issues/%d#%s", p.Repository.HTMLURL, p.Issue.Index, CommentHashTag(p.Comment.ID))
|
url := fmt.Sprintf("%s/issues/%d#%s", p.Repository.HTMLURL, p.Issue.Index, CommentHashTag(p.Comment.ID))
|
||||||
content := ""
|
content := ""
|
||||||
var color int
|
var color int
|
||||||
switch p.Action {
|
switch p.Action {
|
||||||
case api.HookIssueCommentCreated:
|
case api.HookIssueCommentCreated:
|
||||||
title = "New comment: " + title
|
if p.IsPull {
|
||||||
|
title = "New comment on pull request " + title
|
||||||
|
color = greenColorLight
|
||||||
|
} else {
|
||||||
|
title = "New comment on issue " + title
|
||||||
|
color = orangeColorLight
|
||||||
|
}
|
||||||
content = p.Comment.Body
|
content = p.Comment.Body
|
||||||
color = successColor
|
|
||||||
case api.HookIssueCommentEdited:
|
case api.HookIssueCommentEdited:
|
||||||
title = "Comment edited: " + title
|
if p.IsPull {
|
||||||
|
title = "Comment edited on pull request " + title
|
||||||
|
} else {
|
||||||
|
title = "Comment edited on issue " + title
|
||||||
|
}
|
||||||
content = p.Comment.Body
|
content = p.Comment.Body
|
||||||
color = warnColor
|
color = yellowColor
|
||||||
case api.HookIssueCommentDeleted:
|
case api.HookIssueCommentDeleted:
|
||||||
title = "Comment deleted: " + title
|
if p.IsPull {
|
||||||
|
title = "Comment deleted on pull request " + title
|
||||||
|
} else {
|
||||||
|
title = "Comment deleted on issue " + title
|
||||||
|
}
|
||||||
url = fmt.Sprintf("%s/issues/%d", p.Repository.HTMLURL, p.Issue.Index)
|
url = fmt.Sprintf("%s/issues/%d", p.Repository.HTMLURL, p.Issue.Index)
|
||||||
content = p.Comment.Body
|
content = p.Comment.Body
|
||||||
color = warnColor
|
color = redColor
|
||||||
}
|
}
|
||||||
|
|
||||||
|
title = fmt.Sprintf("[%s] %s", p.Repository.FullName, title)
|
||||||
|
|
||||||
return &MSTeamsPayload{
|
return &MSTeamsPayload{
|
||||||
Type: "MessageCard",
|
Type: "MessageCard",
|
||||||
Context: "https://schema.org/extensions",
|
Context: "https://schema.org/extensions",
|
||||||
|
@ -422,24 +437,24 @@ func getMSTeamsPullRequestPayload(p *api.PullRequestPayload) (*MSTeamsPayload, e
|
||||||
case api.HookIssueOpened:
|
case api.HookIssueOpened:
|
||||||
title = fmt.Sprintf("[%s] Pull request opened: #%d %s", p.Repository.FullName, p.Index, p.PullRequest.Title)
|
title = fmt.Sprintf("[%s] Pull request opened: #%d %s", p.Repository.FullName, p.Index, p.PullRequest.Title)
|
||||||
text = p.PullRequest.Body
|
text = p.PullRequest.Body
|
||||||
color = warnColor
|
color = greenColor
|
||||||
case api.HookIssueClosed:
|
case api.HookIssueClosed:
|
||||||
if p.PullRequest.HasMerged {
|
if p.PullRequest.HasMerged {
|
||||||
title = fmt.Sprintf("[%s] Pull request merged: #%d %s", p.Repository.FullName, p.Index, p.PullRequest.Title)
|
title = fmt.Sprintf("[%s] Pull request merged: #%d %s", p.Repository.FullName, p.Index, p.PullRequest.Title)
|
||||||
color = successColor
|
color = purpleColor
|
||||||
} else {
|
} else {
|
||||||
title = fmt.Sprintf("[%s] Pull request closed: #%d %s", p.Repository.FullName, p.Index, p.PullRequest.Title)
|
title = fmt.Sprintf("[%s] Pull request closed: #%d %s", p.Repository.FullName, p.Index, p.PullRequest.Title)
|
||||||
color = failedColor
|
color = redColor
|
||||||
}
|
}
|
||||||
text = p.PullRequest.Body
|
text = p.PullRequest.Body
|
||||||
case api.HookIssueReOpened:
|
case api.HookIssueReOpened:
|
||||||
title = fmt.Sprintf("[%s] Pull request re-opened: #%d %s", p.Repository.FullName, p.Index, p.PullRequest.Title)
|
title = fmt.Sprintf("[%s] Pull request re-opened: #%d %s", p.Repository.FullName, p.Index, p.PullRequest.Title)
|
||||||
text = p.PullRequest.Body
|
text = p.PullRequest.Body
|
||||||
color = warnColor
|
color = yellowColor
|
||||||
case api.HookIssueEdited:
|
case api.HookIssueEdited:
|
||||||
title = fmt.Sprintf("[%s] Pull request edited: #%d %s", p.Repository.FullName, p.Index, p.PullRequest.Title)
|
title = fmt.Sprintf("[%s] Pull request edited: #%d %s", p.Repository.FullName, p.Index, p.PullRequest.Title)
|
||||||
text = p.PullRequest.Body
|
text = p.PullRequest.Body
|
||||||
color = warnColor
|
color = yellowColor
|
||||||
case api.HookIssueAssigned:
|
case api.HookIssueAssigned:
|
||||||
list := make([]string, len(p.PullRequest.Assignees))
|
list := make([]string, len(p.PullRequest.Assignees))
|
||||||
for i, user := range p.PullRequest.Assignees {
|
for i, user := range p.PullRequest.Assignees {
|
||||||
|
@ -449,31 +464,31 @@ func getMSTeamsPullRequestPayload(p *api.PullRequestPayload) (*MSTeamsPayload, e
|
||||||
strings.Join(list, ", "),
|
strings.Join(list, ", "),
|
||||||
p.Index, p.PullRequest.Title)
|
p.Index, p.PullRequest.Title)
|
||||||
text = p.PullRequest.Body
|
text = p.PullRequest.Body
|
||||||
color = successColor
|
color = greenColor
|
||||||
case api.HookIssueUnassigned:
|
case api.HookIssueUnassigned:
|
||||||
title = fmt.Sprintf("[%s] Pull request unassigned: #%d %s", p.Repository.FullName, p.Index, p.PullRequest.Title)
|
title = fmt.Sprintf("[%s] Pull request unassigned: #%d %s", p.Repository.FullName, p.Index, p.PullRequest.Title)
|
||||||
text = p.PullRequest.Body
|
text = p.PullRequest.Body
|
||||||
color = warnColor
|
color = yellowColor
|
||||||
case api.HookIssueLabelUpdated:
|
case api.HookIssueLabelUpdated:
|
||||||
title = fmt.Sprintf("[%s] Pull request labels updated: #%d %s", p.Repository.FullName, p.Index, p.PullRequest.Title)
|
title = fmt.Sprintf("[%s] Pull request labels updated: #%d %s", p.Repository.FullName, p.Index, p.PullRequest.Title)
|
||||||
text = p.PullRequest.Body
|
text = p.PullRequest.Body
|
||||||
color = warnColor
|
color = yellowColor
|
||||||
case api.HookIssueLabelCleared:
|
case api.HookIssueLabelCleared:
|
||||||
title = fmt.Sprintf("[%s] Pull request labels cleared: #%d %s", p.Repository.FullName, p.Index, p.PullRequest.Title)
|
title = fmt.Sprintf("[%s] Pull request labels cleared: #%d %s", p.Repository.FullName, p.Index, p.PullRequest.Title)
|
||||||
text = p.PullRequest.Body
|
text = p.PullRequest.Body
|
||||||
color = warnColor
|
color = yellowColor
|
||||||
case api.HookIssueSynchronized:
|
case api.HookIssueSynchronized:
|
||||||
title = fmt.Sprintf("[%s] Pull request synchronized: #%d %s", p.Repository.FullName, p.Index, p.PullRequest.Title)
|
title = fmt.Sprintf("[%s] Pull request synchronized: #%d %s", p.Repository.FullName, p.Index, p.PullRequest.Title)
|
||||||
text = p.PullRequest.Body
|
text = p.PullRequest.Body
|
||||||
color = warnColor
|
color = yellowColor
|
||||||
case api.HookIssueMilestoned:
|
case api.HookIssueMilestoned:
|
||||||
title = fmt.Sprintf("[%s] Pull request milestone: #%d %s", p.Repository.FullName, p.Index, p.PullRequest.Title)
|
title = fmt.Sprintf("[%s] Pull request milestone: #%d %s", p.Repository.FullName, p.Index, p.PullRequest.Title)
|
||||||
text = p.PullRequest.Body
|
text = p.PullRequest.Body
|
||||||
color = warnColor
|
color = yellowColor
|
||||||
case api.HookIssueDemilestoned:
|
case api.HookIssueDemilestoned:
|
||||||
title = fmt.Sprintf("[%s] Pull request clear milestone: #%d %s", p.Repository.FullName, p.Index, p.PullRequest.Title)
|
title = fmt.Sprintf("[%s] Pull request clear milestone: #%d %s", p.Repository.FullName, p.Index, p.PullRequest.Title)
|
||||||
text = p.PullRequest.Body
|
text = p.PullRequest.Body
|
||||||
color = warnColor
|
color = yellowColor
|
||||||
}
|
}
|
||||||
|
|
||||||
return &MSTeamsPayload{
|
return &MSTeamsPayload{
|
||||||
|
@ -526,8 +541,18 @@ func getMSTeamsPullRequestApprovalPayload(p *api.PullRequestPayload, event HookE
|
||||||
}
|
}
|
||||||
|
|
||||||
title = fmt.Sprintf("[%s] Pull request review %s: #%d %s", p.Repository.FullName, action, p.Index, p.PullRequest.Title)
|
title = fmt.Sprintf("[%s] Pull request review %s: #%d %s", p.Repository.FullName, action, p.Index, p.PullRequest.Title)
|
||||||
text = p.PullRequest.Body
|
text = p.Review.Content
|
||||||
color = warnColor
|
|
||||||
|
switch event {
|
||||||
|
case HookEventPullRequestApproved:
|
||||||
|
color = greenColor
|
||||||
|
case HookEventPullRequestRejected:
|
||||||
|
color = redColor
|
||||||
|
case HookEventPullRequestComment:
|
||||||
|
color = greyColor
|
||||||
|
default:
|
||||||
|
color = yellowColor
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return &MSTeamsPayload{
|
return &MSTeamsPayload{
|
||||||
|
@ -576,10 +601,10 @@ func getMSTeamsRepositoryPayload(p *api.RepositoryPayload) (*MSTeamsPayload, err
|
||||||
case api.HookRepoCreated:
|
case api.HookRepoCreated:
|
||||||
title = fmt.Sprintf("[%s] Repository created", p.Repository.FullName)
|
title = fmt.Sprintf("[%s] Repository created", p.Repository.FullName)
|
||||||
url = p.Repository.HTMLURL
|
url = p.Repository.HTMLURL
|
||||||
color = successColor
|
color = greenColor
|
||||||
case api.HookRepoDeleted:
|
case api.HookRepoDeleted:
|
||||||
title = fmt.Sprintf("[%s] Repository deleted", p.Repository.FullName)
|
title = fmt.Sprintf("[%s] Repository deleted", p.Repository.FullName)
|
||||||
color = warnColor
|
color = yellowColor
|
||||||
}
|
}
|
||||||
|
|
||||||
return &MSTeamsPayload{
|
return &MSTeamsPayload{
|
||||||
|
@ -623,15 +648,15 @@ func getMSTeamsReleasePayload(p *api.ReleasePayload) (*MSTeamsPayload, error) {
|
||||||
case api.HookReleasePublished:
|
case api.HookReleasePublished:
|
||||||
title = fmt.Sprintf("[%s] Release created", p.Release.TagName)
|
title = fmt.Sprintf("[%s] Release created", p.Release.TagName)
|
||||||
url = p.Release.URL
|
url = p.Release.URL
|
||||||
color = successColor
|
color = greenColor
|
||||||
case api.HookReleaseUpdated:
|
case api.HookReleaseUpdated:
|
||||||
title = fmt.Sprintf("[%s] Release updated", p.Release.TagName)
|
title = fmt.Sprintf("[%s] Release updated", p.Release.TagName)
|
||||||
url = p.Release.URL
|
url = p.Release.URL
|
||||||
color = successColor
|
color = greenColor
|
||||||
case api.HookReleaseDeleted:
|
case api.HookReleaseDeleted:
|
||||||
title = fmt.Sprintf("[%s] Release deleted", p.Release.TagName)
|
title = fmt.Sprintf("[%s] Release deleted", p.Release.TagName)
|
||||||
url = p.Release.URL
|
url = p.Release.URL
|
||||||
color = successColor
|
color = greenColor
|
||||||
}
|
}
|
||||||
|
|
||||||
return &MSTeamsPayload{
|
return &MSTeamsPayload{
|
||||||
|
|
|
@ -236,6 +236,7 @@ type IssueCommentPayload struct {
|
||||||
Changes *ChangesPayload `json:"changes,omitempty"`
|
Changes *ChangesPayload `json:"changes,omitempty"`
|
||||||
Repository *Repository `json:"repository"`
|
Repository *Repository `json:"repository"`
|
||||||
Sender *User `json:"sender"`
|
Sender *User `json:"sender"`
|
||||||
|
IsPull bool `json:"is_pull"`
|
||||||
}
|
}
|
||||||
|
|
||||||
// SetSecret modifies the secret of the IssueCommentPayload
|
// SetSecret modifies the secret of the IssueCommentPayload
|
||||||
|
@ -419,6 +420,7 @@ type PullRequestPayload struct {
|
||||||
PullRequest *PullRequest `json:"pull_request"`
|
PullRequest *PullRequest `json:"pull_request"`
|
||||||
Repository *Repository `json:"repository"`
|
Repository *Repository `json:"repository"`
|
||||||
Sender *User `json:"sender"`
|
Sender *User `json:"sender"`
|
||||||
|
Review *ReviewPayload `json:"review"`
|
||||||
}
|
}
|
||||||
|
|
||||||
// SetSecret modifies the secret of the PullRequestPayload.
|
// SetSecret modifies the secret of the PullRequestPayload.
|
||||||
|
@ -431,6 +433,12 @@ func (p *PullRequestPayload) JSONPayload() ([]byte, error) {
|
||||||
return json.MarshalIndent(p, "", " ")
|
return json.MarshalIndent(p, "", " ")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// ReviewPayload FIXME
|
||||||
|
type ReviewPayload struct {
|
||||||
|
Type string `json:"type"`
|
||||||
|
Content string `json:"content"`
|
||||||
|
}
|
||||||
|
|
||||||
//__________ .__ __
|
//__________ .__ __
|
||||||
//\______ \ ____ ______ ____ _____|__|/ |_ ___________ ___.__.
|
//\______ \ ____ ______ ____ _____|__|/ |_ ___________ ___.__.
|
||||||
// | _// __ \\____ \ / _ \/ ___/ \ __\/ _ \_ __ < | |
|
// | _// __ \\____ \ / _ \/ ___/ \ __\/ _ \_ __ < | |
|
||||||
|
|
|
@ -38,6 +38,7 @@ func CreateIssueComment(doer *models.User, repo *models.Repository, issue *model
|
||||||
Comment: comment.APIFormat(),
|
Comment: comment.APIFormat(),
|
||||||
Repository: repo.APIFormat(mode),
|
Repository: repo.APIFormat(mode),
|
||||||
Sender: doer.APIFormat(),
|
Sender: doer.APIFormat(),
|
||||||
|
IsPull: issue.IsPull,
|
||||||
}); err != nil {
|
}); err != nil {
|
||||||
log.Error("PrepareWebhooks [comment_id: %d]: %v", comment.ID, err)
|
log.Error("PrepareWebhooks [comment_id: %d]: %v", comment.ID, err)
|
||||||
} else {
|
} else {
|
||||||
|
@ -128,6 +129,7 @@ func UpdateComment(c *models.Comment, doer *models.User, oldContent string) erro
|
||||||
},
|
},
|
||||||
Repository: c.Issue.Repo.APIFormat(mode),
|
Repository: c.Issue.Repo.APIFormat(mode),
|
||||||
Sender: doer.APIFormat(),
|
Sender: doer.APIFormat(),
|
||||||
|
IsPull: c.Issue.IsPull,
|
||||||
}); err != nil {
|
}); err != nil {
|
||||||
log.Error("PrepareWebhooks [comment_id: %d]: %v", c.ID, err)
|
log.Error("PrepareWebhooks [comment_id: %d]: %v", c.ID, err)
|
||||||
} else {
|
} else {
|
||||||
|
@ -162,6 +164,7 @@ func DeleteComment(comment *models.Comment, doer *models.User) error {
|
||||||
Comment: comment.APIFormat(),
|
Comment: comment.APIFormat(),
|
||||||
Repository: comment.Issue.Repo.APIFormat(mode),
|
Repository: comment.Issue.Repo.APIFormat(mode),
|
||||||
Sender: doer.APIFormat(),
|
Sender: doer.APIFormat(),
|
||||||
|
IsPull: comment.Issue.IsPull,
|
||||||
}); err != nil {
|
}); err != nil {
|
||||||
log.Error("PrepareWebhooks [comment_id: %d]: %v", comment.ID, err)
|
log.Error("PrepareWebhooks [comment_id: %d]: %v", comment.ID, err)
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -55,13 +55,16 @@ func reviewHook(review *models.Review) error {
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
if err := models.PrepareWebhooks(review.Issue.Repo, reviewHookType, &api.PullRequestPayload{
|
if err := models.PrepareWebhooks(review.Issue.Repo, reviewHookType, &api.PullRequestPayload{
|
||||||
Action: api.HookIssueSynchronized,
|
Action: api.HookIssueSynchronized,
|
||||||
Index: review.Issue.Index,
|
Index: review.Issue.Index,
|
||||||
PullRequest: pr.APIFormat(),
|
PullRequest: pr.APIFormat(),
|
||||||
Repository: review.Issue.Repo.APIFormat(mode),
|
Repository: review.Issue.Repo.APIFormat(mode),
|
||||||
Sender: review.Reviewer.APIFormat(),
|
Sender: review.Reviewer.APIFormat(),
|
||||||
|
Review: &api.ReviewPayload{
|
||||||
|
Type: string(reviewHookType),
|
||||||
|
Content: review.Content,
|
||||||
|
},
|
||||||
}); err != nil {
|
}); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user