From 43e795448f62fa86f3dad7940fc2297c44a6ea9c Mon Sep 17 00:00:00 2001 From: Saturnino Abril Date: Tue, 4 Apr 2017 02:34:14 +0900 Subject: APIv4 post /teams/search (#5931) --- store/sql_team_store.go | 42 ++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 42 insertions(+) (limited to 'store/sql_team_store.go') diff --git a/store/sql_team_store.go b/store/sql_team_store.go index 7d843b030..39a39fa0b 100644 --- a/store/sql_team_store.go +++ b/store/sql_team_store.go @@ -257,6 +257,48 @@ func (s SqlTeamStore) SearchByName(name string) StoreChannel { return storeChannel } +func (s SqlTeamStore) SearchAll(term string) StoreChannel { + storeChannel := make(StoreChannel, 1) + + go func() { + result := StoreResult{} + + var teams []*model.Team + + if _, err := s.GetReplica().Select(&teams, "SELECT * FROM Teams WHERE Name LIKE :Term OR DisplayName LIKE :Term", map[string]interface{}{"Term": term + "%"}); err != nil { + result.Err = model.NewLocAppError("SqlTeamStore.SearchAll", "store.sql_team.search_all_team.app_error", nil, "term="+term+", "+err.Error()) + } + + result.Data = teams + + storeChannel <- result + close(storeChannel) + }() + + return storeChannel +} + +func (s SqlTeamStore) SearchOpen(term string) StoreChannel { + storeChannel := make(StoreChannel, 1) + + go func() { + result := StoreResult{} + + var teams []*model.Team + + if _, err := s.GetReplica().Select(&teams, "SELECT * FROM Teams WHERE Type = 'O' AND (Name LIKE :Term OR DisplayName LIKE :Term)", map[string]interface{}{"Term": term + "%"}); err != nil { + result.Err = model.NewLocAppError("SqlTeamStore.SearchOpen", "store.sql_team.search_open_team.app_error", nil, "term="+term+", "+err.Error()) + } + + result.Data = teams + + storeChannel <- result + close(storeChannel) + }() + + return storeChannel +} + func (s SqlTeamStore) GetAll() StoreChannel { storeChannel := make(StoreChannel, 1) -- cgit v1.2.3-1-g7c22