Added server parsing of wildcards

This commit is contained in:
nickago
2015-08-13 15:34:56 -07:00
parent d3093028cf
commit 72fc15ddf3

View File

@@ -5,9 +5,12 @@ package store
import (
"fmt"
"regexp"
"strconv"
"strings"
"github.com/mattermost/platform/model"
"github.com/mattermost/platform/utils"
"strings"
)
type SqlPostStore struct {
@@ -361,7 +364,7 @@ func (s SqlPostStore) getParentsPosts(channelId string, offset int, limit int) S
var posts []*model.Post
_, err := s.GetReplica().Select(&posts,
`SELECT
`SELECT
q2.*
FROM
Posts q2
@@ -369,7 +372,7 @@ func (s SqlPostStore) getParentsPosts(channelId string, offset int, limit int) S
(SELECT DISTINCT
q3.RootId
FROM
(SELECT
(SELECT
RootId
FROM
Posts
@@ -416,6 +419,12 @@ func (s SqlPostStore) Search(teamId string, userId string, terms string, isHasht
// cannot escape it so we replace it.
terms = strings.Replace(terms, "@", " ", -1)
// Parse text for wildcards
if wildcard, err := regexp.Compile("\\*($| )"); err == nil {
terms = wildcard.ReplaceAllLiteralString(terms, ":* ")
terms = strings.Replace(terms, " ", " ", -1)
}
var posts []*model.Post
if utils.Cfg.SqlSettings.DriverName == "postgres" {