summaryrefslogtreecommitdiffstats
path: root/app/post.go
diff options
context:
space:
mode:
authorCharles Birk <charles@cryptolab.net>2018-09-17 10:15:28 -0400
committerJoram Wilander <jwawilander@gmail.com>2018-09-17 10:15:28 -0400
commita755bcdde63b2f27866d49be97bb82e4cdb0e893 (patch)
tree96d89780b184a17da7b66acd1049a5c40b919301 /app/post.go
parent7226ea7dfbf21860a5eb2fe0997a8363df4a4dd6 (diff)
downloadchat-a755bcdde63b2f27866d49be97bb82e4cdb0e893.tar.gz
chat-a755bcdde63b2f27866d49be97bb82e4cdb0e893.tar.bz2
chat-a755bcdde63b2f27866d49be97bb82e4cdb0e893.zip
[MM-11860]: Expose slack attachment parsing functions in the model package (#9351)
Refactored parseSlackAttachment functions from https://github.com/mattermost/mattermost-server/blob/master/app/post.go#L312 into model/slack_attachments.go so that plugins have access to them.
Diffstat (limited to 'app/post.go')
-rw-r--r--app/post.go27
1 files changed, 1 insertions, 26 deletions
diff --git a/app/post.go b/app/post.go
index 114029f44..a36e9709f 100644
--- a/app/post.go
+++ b/app/post.go
@@ -13,7 +13,6 @@ import (
"net/http"
"net/url"
"path"
- "regexp"
"strings"
"github.com/dyatlov/go-opengraph/opengraph"
@@ -25,8 +24,6 @@ import (
"golang.org/x/net/html/charset"
)
-var linkWithTextRegex = regexp.MustCompile(`<([^<\|]+)\|([^>]+)>`)
-
func (a *App) CreatePostAsUser(post *model.Post) (*model.Post, *model.AppError) {
// Check that channel has not been deleted
var channel *model.Channel
@@ -308,28 +305,6 @@ func (a *App) handlePostEvents(post *model.Post, user *model.User, channel *mode
return nil
}
-// This method only parses and processes the attachments,
-// all else should be set in the post which is passed
-func parseSlackAttachment(post *model.Post, attachments []*model.SlackAttachment) {
- post.Type = model.POST_SLACK_ATTACHMENT
-
- for _, attachment := range attachments {
- attachment.Text = parseSlackLinksToMarkdown(attachment.Text)
- attachment.Pretext = parseSlackLinksToMarkdown(attachment.Pretext)
-
- for _, field := range attachment.Fields {
- if value, ok := field.Value.(string); ok {
- field.Value = parseSlackLinksToMarkdown(value)
- }
- }
- }
- post.AddProp("attachments", attachments)
-}
-
-func parseSlackLinksToMarkdown(text string) string {
- return linkWithTextRegex.ReplaceAllString(text, "[${2}](${1})")
-}
-
func (a *App) SendEphemeralPost(userId string, post *model.Post) *model.Post {
post.Type = model.POST_EPHEMERAL
@@ -931,7 +906,7 @@ func (a *App) DoPostAction(postId, actionId, userId, selectedOption string) *mod
if response.EphemeralText != "" {
ephemeralPost := &model.Post{}
- ephemeralPost.Message = parseSlackLinksToMarkdown(response.EphemeralText)
+ ephemeralPost.Message = model.ParseSlackLinksToMarkdown(response.EphemeralText)
ephemeralPost.ChannelId = post.ChannelId
ephemeralPost.RootId = post.RootId
if ephemeralPost.RootId == "" {