diff options
author | Joey Lee <jayd005@gmail.com> | 2017-11-18 03:17:59 +1100 |
---|---|---|
committer | Harrison Healey <harrisonmhealey@gmail.com> | 2017-11-17 11:17:59 -0500 |
commit | 3836f9992056410e00041004132f5d53b4e43300 (patch) | |
tree | a75570472e9000c7cde74454af7fa186dcab2062 /model/slack_attachment.go | |
parent | 065d8e97313b9c8ffad37862665186668c88499f (diff) | |
download | chat-3836f9992056410e00041004132f5d53b4e43300.tar.gz chat-3836f9992056410e00041004132f5d53b4e43300.tar.bz2 chat-3836f9992056410e00041004132f5d53b4e43300.zip |
PLT-7824 Added support for mentions with <@userid> and <!here> (#7615) (#7737)
Diffstat (limited to 'model/slack_attachment.go')
-rw-r--r-- | model/slack_attachment.go | 25 |
1 files changed, 2 insertions, 23 deletions
diff --git a/model/slack_attachment.go b/model/slack_attachment.go index fe3958316..197d3f0f9 100644 --- a/model/slack_attachment.go +++ b/model/slack_attachment.go @@ -5,7 +5,6 @@ package model import ( "fmt" - "strings" ) type SlackAttachment struct { @@ -34,23 +33,7 @@ type SlackAttachmentField struct { Short bool `json:"short"` } -// To mention @channel via a webhook in Slack, the message should contain -// <!channel>, as explained at the bottom of this article: -// https://get.slack.help/hc/en-us/articles/202009646-Making-announcements -func ExpandAnnouncement(text string) string { - c1 := "<!channel>" - c2 := "@channel" - if strings.Contains(text, c1) { - return strings.Replace(text, c1, c2, -1) - } - return text -} - -// Expand announcements in incoming webhooks from Slack. Those announcements -// can be found in the text attribute, or in the pretext, text, title and value -// attributes of the attachment structure. The Slack attachment structure is -// documented here: https://api.slack.com/docs/attachments -func ProcessSlackAttachments(a []*SlackAttachment) []*SlackAttachment { +func StringifySlackFieldValue(a []*SlackAttachment) []*SlackAttachment { var nonNilAttachments []*SlackAttachment for _, attachment := range a { if attachment == nil { @@ -58,10 +41,6 @@ func ProcessSlackAttachments(a []*SlackAttachment) []*SlackAttachment { } nonNilAttachments = append(nonNilAttachments, attachment) - attachment.Pretext = ExpandAnnouncement(attachment.Pretext) - attachment.Text = ExpandAnnouncement(attachment.Text) - attachment.Title = ExpandAnnouncement(attachment.Title) - var nonNilFields []*SlackAttachmentField for _, field := range attachment.Fields { if field == nil { @@ -71,7 +50,7 @@ func ProcessSlackAttachments(a []*SlackAttachment) []*SlackAttachment { if field.Value != nil { // Ensure the value is set to a string if it is set - field.Value = ExpandAnnouncement(fmt.Sprintf("%v", field.Value)) + field.Value = fmt.Sprintf("%v", field.Value) } } attachment.Fields = nonNilFields |