Skip to content

Commit

Permalink
bail link processing if the regex is non-terminal
Browse files Browse the repository at this point in the history
  • Loading branch information
mickmister committed Jul 20, 2021
1 parent 9f8f884 commit e4d873a
Show file tree
Hide file tree
Showing 2 changed files with 52 additions and 0 deletions.
6 changes: 6 additions & 0 deletions server/autolink/autolink.go
Original file line number Diff line number Diff line change
Expand Up @@ -108,6 +108,12 @@ func (l Autolink) Replace(message string) string {
if submatch == nil {
break
}

// The beginning of the submatch is equal to the end of the submatch here. The regex pattern is non-terminal.
if len(submatch) > 1 && submatch[0] == submatch[1] {
break
}

out = append(out, in[:submatch[0]]...)
out = l.re.Expand(out, []byte(l.template), in, submatch)
in = in[submatch[1]:]
Expand Down
46 changes: 46 additions & 0 deletions server/autolink/autolink_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ package autolink_test
import (
"fmt"
"testing"
"time"

"github.com/mattermost/mattermost-server/v5/model"
"github.com/mattermost/mattermost-server/v5/plugin/plugintest"
Expand Down Expand Up @@ -320,3 +321,48 @@ func TestEquals(t *testing.T) {
})
}
}

func TestWildcard(t *testing.T) {
for _, tc := range []struct {
Name string
Link autolink.Autolink
}{
{
Name: ".*",
Link: autolink.Autolink{
Pattern: ".*",
Template: "My template",
},
},
{
Name: ".*.",
Link: autolink.Autolink{
Pattern: ".*.",
Template: "My template",
},
},
} {
p := setupTestPlugin(t, tc.Link)

message := "Your message"

var post *model.Post
done := make(chan bool)
go func() {
post, _ = p.MessageWillBePosted(nil, &model.Post{
Message: message,
})

done <- true
}()

select {
case <-done:
case <-time.After(1 * time.Millisecond):
panic("wildcard regex timed out")
}

assert.NotNil(t, post, "post is nil")
assert.Equal(t, "My template", post.Message)
}
}

0 comments on commit e4d873a

Please sign in to comment.