You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

wechatwork.go 6.0KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188
  1. // Copyright 2021 The Gitea Authors. All rights reserved.
  2. // Use of this source code is governed by a MIT-style
  3. // license that can be found in the LICENSE file.
  4. package webhook
  5. import (
  6. "fmt"
  7. "strings"
  8. "code.gitea.io/gitea/models"
  9. "code.gitea.io/gitea/modules/git"
  10. "code.gitea.io/gitea/modules/json"
  11. api "code.gitea.io/gitea/modules/structs"
  12. )
  13. type (
  14. // WechatworkPayload represents
  15. WechatworkPayload struct {
  16. Msgtype string `json:"msgtype"`
  17. Text struct {
  18. Content string `json:"content"`
  19. MentionedList []string `json:"mentioned_list"`
  20. MentionedMobileList []string `json:"mentioned_mobile_list"`
  21. } `json:"text"`
  22. Markdown struct {
  23. Content string `json:"content"`
  24. } `json:"markdown"`
  25. }
  26. )
  27. // SetSecret sets the Wechatwork secret
  28. func (f *WechatworkPayload) SetSecret(_ string) {}
  29. // JSONPayload Marshals the WechatworkPayload to json
  30. func (f *WechatworkPayload) JSONPayload() ([]byte, error) {
  31. data, err := json.MarshalIndent(f, "", " ")
  32. if err != nil {
  33. return []byte{}, err
  34. }
  35. return data, nil
  36. }
  37. func newWechatworkMarkdownPayload(title string) *WechatworkPayload {
  38. return &WechatworkPayload{
  39. Msgtype: "markdown",
  40. Markdown: struct {
  41. Content string `json:"content"`
  42. }{
  43. Content: title,
  44. },
  45. }
  46. }
  47. var (
  48. _ PayloadConvertor = &WechatworkPayload{}
  49. )
  50. // Create implements PayloadConvertor Create method
  51. func (f *WechatworkPayload) Create(p *api.CreatePayload) (api.Payloader, error) {
  52. // created tag/branch
  53. refName := git.RefEndName(p.Ref)
  54. title := fmt.Sprintf("[%s] %s %s created", p.Repo.FullName, p.RefType, refName)
  55. return newWechatworkMarkdownPayload(title), nil
  56. }
  57. // Delete implements PayloadConvertor Delete method
  58. func (f *WechatworkPayload) Delete(p *api.DeletePayload) (api.Payloader, error) {
  59. // created tag/branch
  60. refName := git.RefEndName(p.Ref)
  61. title := fmt.Sprintf("[%s] %s %s deleted", p.Repo.FullName, p.RefType, refName)
  62. return newWechatworkMarkdownPayload(title), nil
  63. }
  64. // Fork implements PayloadConvertor Fork method
  65. func (f *WechatworkPayload) Fork(p *api.ForkPayload) (api.Payloader, error) {
  66. title := fmt.Sprintf("%s is forked to %s", p.Forkee.FullName, p.Repo.FullName)
  67. return newWechatworkMarkdownPayload(title), nil
  68. }
  69. // Push implements PayloadConvertor Push method
  70. func (f *WechatworkPayload) Push(p *api.PushPayload) (api.Payloader, error) {
  71. var (
  72. branchName = git.RefEndName(p.Ref)
  73. commitDesc string
  74. )
  75. title := fmt.Sprintf("# %s:%s <font color=\"warning\"> %s </font>", p.Repo.FullName, branchName, commitDesc)
  76. var text string
  77. // for each commit, generate attachment text
  78. for i, commit := range p.Commits {
  79. var authorName string
  80. if commit.Author != nil {
  81. authorName = "Author:" + commit.Author.Name
  82. }
  83. message := strings.ReplaceAll(commit.Message, "\n\n", "\r\n")
  84. text += fmt.Sprintf(" > [%s](%s) \r\n ><font color=\"info\">%s</font> \n ><font color=\"warning\">%s</font>", commit.ID[:7], commit.URL,
  85. message, authorName)
  86. // add linebreak to each commit but the last
  87. if i < len(p.Commits)-1 {
  88. text += "\n"
  89. }
  90. }
  91. return newWechatworkMarkdownPayload(title + "\r\n\r\n" + text), nil
  92. }
  93. // Issue implements PayloadConvertor Issue method
  94. func (f *WechatworkPayload) Issue(p *api.IssuePayload) (api.Payloader, error) {
  95. text, issueTitle, attachmentText, _ := getIssuesPayloadInfo(p, noneLinkFormatter, true)
  96. var content string
  97. content += fmt.Sprintf(" ><font color=\"info\">%s</font>\n >%s \n ><font color=\"warning\"> %s</font>", text, attachmentText, issueTitle)
  98. return newWechatworkMarkdownPayload(content), nil
  99. }
  100. // IssueComment implements PayloadConvertor IssueComment method
  101. func (f *WechatworkPayload) IssueComment(p *api.IssueCommentPayload) (api.Payloader, error) {
  102. text, issueTitle, _ := getIssueCommentPayloadInfo(p, noneLinkFormatter, true)
  103. var content string
  104. content += fmt.Sprintf(" ><font color=\"info\">%s</font>\n >%s \n ><font color=\"warning\">%s</font>", text, p.Comment.Body, issueTitle)
  105. return newWechatworkMarkdownPayload(content), nil
  106. }
  107. // PullRequest implements PayloadConvertor PullRequest method
  108. func (f *WechatworkPayload) PullRequest(p *api.PullRequestPayload) (api.Payloader, error) {
  109. text, issueTitle, attachmentText, _ := getPullRequestPayloadInfo(p, noneLinkFormatter, true)
  110. pr := fmt.Sprintf("> <font color=\"info\"> %s </font> \r\n > <font color=\"comment\">%s </font> \r\n > <font color=\"comment\">%s </font> \r\n",
  111. text, issueTitle, attachmentText)
  112. return newWechatworkMarkdownPayload(pr), nil
  113. }
  114. // Review implements PayloadConvertor Review method
  115. func (f *WechatworkPayload) Review(p *api.PullRequestPayload, event models.HookEventType) (api.Payloader, error) {
  116. var text, title string
  117. switch p.Action {
  118. case api.HookIssueSynchronized:
  119. action, err := parseHookPullRequestEventType(event)
  120. if err != nil {
  121. return nil, err
  122. }
  123. title = fmt.Sprintf("[%s] Pull request review %s : #%d %s", p.Repository.FullName, action, p.Index, p.PullRequest.Title)
  124. text = p.Review.Content
  125. }
  126. return newWechatworkMarkdownPayload("# " + title + "\r\n\r\n >" + text), nil
  127. }
  128. // Repository implements PayloadConvertor Repository method
  129. func (f *WechatworkPayload) Repository(p *api.RepositoryPayload) (api.Payloader, error) {
  130. var title string
  131. switch p.Action {
  132. case api.HookRepoCreated:
  133. title = fmt.Sprintf("[%s] Repository created", p.Repository.FullName)
  134. return newWechatworkMarkdownPayload(title), nil
  135. case api.HookRepoDeleted:
  136. title = fmt.Sprintf("[%s] Repository deleted", p.Repository.FullName)
  137. return newWechatworkMarkdownPayload(title), nil
  138. }
  139. return nil, nil
  140. }
  141. // Release implements PayloadConvertor Release method
  142. func (f *WechatworkPayload) Release(p *api.ReleasePayload) (api.Payloader, error) {
  143. text, _ := getReleasePayloadInfo(p, noneLinkFormatter, true)
  144. return newWechatworkMarkdownPayload(text), nil
  145. }
  146. // GetWechatworkPayload GetWechatworkPayload converts a ding talk webhook into a WechatworkPayload
  147. func GetWechatworkPayload(p api.Payloader, event models.HookEventType, meta string) (api.Payloader, error) {
  148. return convertPayloader(new(WechatworkPayload), p, event)
  149. }