mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-26 12:27:06 +00:00 
			
		
		
		
	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:
		| @@ -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 | ||||||
| 	} | 	} | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 John Olheiser
					John Olheiser