summaryrefslogtreecommitdiffstats
path: root/api
diff options
context:
space:
mode:
authorJoram Wilander <jwawilander@gmail.com>2017-03-28 08:07:15 -0400
committerGitHub <noreply@github.com>2017-03-28 08:07:15 -0400
commit060b9f92c382052276fa784065af6b18eda70669 (patch)
tree1d1703b1668b017e8461bdfaa07288ed9b3db4a0 /api
parentdaca0d93f621bcb1daae149c178af0631bcd120a (diff)
downloadchat-060b9f92c382052276fa784065af6b18eda70669.tar.gz
chat-060b9f92c382052276fa784065af6b18eda70669.tar.bz2
chat-060b9f92c382052276fa784065af6b18eda70669.zip
Remove API endpoints being deprecated in 3.8 (#5880)
Diffstat (limited to 'api')
-rw-r--r--api/deprecated.go142
-rw-r--r--api/deprecated_test.go80
2 files changed, 1 insertions, 221 deletions
diff --git a/api/deprecated.go b/api/deprecated.go
index 46f016420..eca6f78f8 100644
--- a/api/deprecated.go
+++ b/api/deprecated.go
@@ -4,152 +4,12 @@
package api
import (
- "net/http"
-
l4g "github.com/alecthomas/log4go"
- "github.com/gorilla/mux"
- "github.com/mattermost/platform/app"
- "github.com/mattermost/platform/model"
"github.com/mattermost/platform/utils"
)
// ONLY FOR APIs SCHEDULED TO BE DEPRECATED
func InitDeprecated() {
- l4g.Debug(utils.T("api.channel.init.debug"))
-
- /* start - SCHEDULED FOR DEPRECATION IN 3.7 */
- BaseRoutes.Channels.Handle("/more", ApiUserRequired(getMoreChannels)).Methods("GET")
- /* end - SCHEDULED FOR DEPRECATION IN 3.7 */
-
- /* start - SCHEDULED FOR DEPRECATION IN 3.8 */
- BaseRoutes.NeedChannel.Handle("/update_last_viewed_at", ApiUserRequired(updateLastViewedAt)).Methods("POST")
- BaseRoutes.NeedChannel.Handle("/set_last_viewed_at", ApiUserRequired(setLastViewedAt)).Methods("POST")
- BaseRoutes.Users.Handle("/status/set_active_channel", ApiUserRequired(setActiveChannel)).Methods("POST")
- /* end - SCHEDULED FOR DEPRECATION IN 3.8 */
-}
-
-func getMoreChannels(c *Context, w http.ResponseWriter, r *http.Request) {
-
- // user is already in the team
- if !app.SessionHasPermissionToTeam(c.Session, c.TeamId, model.PERMISSION_LIST_TEAM_CHANNELS) {
- c.SetPermissionError(model.PERMISSION_LIST_TEAM_CHANNELS)
- return
- }
-
- if result := <-app.Srv.Store.Channel().GetMoreChannels(c.TeamId, c.Session.UserId, 0, 100000); result.Err != nil {
- c.Err = result.Err
- return
- } else if HandleEtag(result.Data.(*model.ChannelList).Etag(), "Get More Channels (deprecated)", w, r) {
- return
- } else {
- data := result.Data.(*model.ChannelList)
- w.Header().Set(model.HEADER_ETAG_SERVER, data.Etag())
- w.Write([]byte(data.ToJson()))
- }
-}
-
-func updateLastViewedAt(c *Context, w http.ResponseWriter, r *http.Request) {
- params := mux.Vars(r)
- id := params["channel_id"]
-
- data := model.StringInterfaceFromJson(r.Body)
-
- var active bool
- var ok bool
- if active, ok = data["active"].(bool); !ok {
- active = true
- }
-
- doClearPush := false
- if *utils.Cfg.EmailSettings.SendPushNotifications && !c.Session.IsMobileApp() && active {
- if result := <-app.Srv.Store.User().GetUnreadCountForChannel(c.Session.UserId, id); result.Err != nil {
- l4g.Error(utils.T("api.channel.update_last_viewed_at.get_unread_count_for_channel.error"), c.Session.UserId, id, result.Err.Error())
- } else {
- if result.Data.(int64) > 0 {
- doClearPush = true
- }
- }
- }
-
- go func() {
- if err := app.SetActiveChannel(c.Session.UserId, id); err != nil {
- l4g.Error(err.Error())
- }
- }()
-
- app.Srv.Store.Channel().UpdateLastViewedAt([]string{id}, c.Session.UserId)
-
- // Must be after update so that unread count is correct
- if doClearPush {
- go app.ClearPushNotification(c.Session.UserId, id)
- }
-
- chanPref := model.Preference{
- UserId: c.Session.UserId,
- Category: c.TeamId,
- Name: model.PREFERENCE_NAME_LAST_CHANNEL,
- Value: id,
- }
-
- teamPref := model.Preference{
- UserId: c.Session.UserId,
- Category: model.PREFERENCE_CATEGORY_LAST,
- Name: model.PREFERENCE_NAME_LAST_TEAM,
- Value: c.TeamId,
- }
-
- app.Srv.Store.Preference().Save(&model.Preferences{teamPref, chanPref})
-
- result := make(map[string]string)
- result["id"] = id
- w.Write([]byte(model.MapToJson(result)))
-}
-
-func setLastViewedAt(c *Context, w http.ResponseWriter, r *http.Request) {
- params := mux.Vars(r)
- id := params["channel_id"]
-
- data := model.StringInterfaceFromJson(r.Body)
- newLastViewedAt := int64(data["last_viewed_at"].(float64))
-
- app.Srv.Store.Channel().SetLastViewedAt(id, c.Session.UserId, newLastViewedAt)
-
- chanPref := model.Preference{
- UserId: c.Session.UserId,
- Category: c.TeamId,
- Name: model.PREFERENCE_NAME_LAST_CHANNEL,
- Value: id,
- }
-
- teamPref := model.Preference{
- UserId: c.Session.UserId,
- Category: model.PREFERENCE_CATEGORY_LAST,
- Name: model.PREFERENCE_NAME_LAST_TEAM,
- Value: c.TeamId,
- }
-
- app.Srv.Store.Preference().Save(&model.Preferences{teamPref, chanPref})
-
- result := make(map[string]string)
- result["id"] = id
- w.Write([]byte(model.MapToJson(result)))
-}
-
-func setActiveChannel(c *Context, w http.ResponseWriter, r *http.Request) {
- data := model.MapFromJson(r.Body)
-
- var channelId string
- var ok bool
- if channelId, ok = data["channel_id"]; !ok || len(channelId) > 26 {
- c.SetInvalidParam("setActiveChannel", "channel_id")
- return
- }
-
- if err := app.SetActiveChannel(c.Session.UserId, channelId); err != nil {
- c.Err = err
- return
- }
-
- ReturnStatusOK(w)
+ l4g.Debug(utils.T("api.deprecated.init.debug"))
}
diff --git a/api/deprecated_test.go b/api/deprecated_test.go
index ee2ce0b2c..b3249a58d 100644
--- a/api/deprecated_test.go
+++ b/api/deprecated_test.go
@@ -2,83 +2,3 @@
// See License.txt for license information.
package api
-
-import (
- "testing"
-
- "github.com/mattermost/platform/model"
-)
-
-func TestGetMoreChannel(t *testing.T) {
- th := Setup().InitBasic()
- Client := th.BasicClient
- team := th.BasicTeam
-
- channel1 := &model.Channel{DisplayName: "A Test API Name", Name: "a" + model.NewId() + "a", Type: model.CHANNEL_OPEN, TeamId: team.Id}
- channel1 = Client.Must(Client.CreateChannel(channel1)).Data.(*model.Channel)
-
- channel2 := &model.Channel{DisplayName: "B Test API Name", Name: "a" + model.NewId() + "a", Type: model.CHANNEL_OPEN, TeamId: team.Id}
- channel2 = Client.Must(Client.CreateChannel(channel2)).Data.(*model.Channel)
-
- th.LoginBasic2()
-
- rget := Client.Must(Client.GetMoreChannels(""))
- channels := rget.Data.(*model.ChannelList)
-
- if (*channels)[0].DisplayName != channel1.DisplayName {
- t.Fatal("full name didn't match")
- }
-
- if (*channels)[1].DisplayName != channel2.DisplayName {
- t.Fatal("full name didn't match")
- }
-
- // test etag caching
- if cache_result, err := Client.GetMoreChannels(rget.Etag); err != nil {
- t.Fatal(err)
- } else if cache_result.Data.(*model.ChannelList) != nil {
- t.Log(cache_result.Data)
- t.Fatal("cache should be empty")
- }
-}
-
-/*
-func TestSetActiveChannel(t *testing.T) {
- th := Setup().InitBasic()
- Client := th.BasicClient
-
- if _, err := Client.SetActiveChannel(th.BasicChannel.Id); err != nil {
- t.Fatal(err)
- }
-
- status, _ := GetStatus(th.BasicUser.Id)
- if status.ActiveChannel != th.BasicChannel.Id {
- t.Fatal("active channel should be set")
- }
-
- if _, err := Client.SetActiveChannel(""); err != nil {
- t.Fatal(err)
- }
-
- status, _ = GetStatus(th.BasicUser.Id)
- if status.ActiveChannel != "" {
- t.Fatal("active channel should be blank")
- }
-
- if _, err := Client.SetActiveChannel("123456789012345678901234567890"); err == nil {
- t.Fatal("should have failed, id too long")
- }
-
- if _, err := Client.UpdateLastViewedAt(th.BasicChannel.Id, true); err != nil {
- t.Fatal(err)
- }
-
- time.Sleep(500 * time.Millisecond)
-
- status, _ = GetStatus(th.BasicUser.Id)
- need to check if offline to catch race
- if status.Status != model.STATUS_OFFLINE && status.ActiveChannel != th.BasicChannel.Id {
- t.Fatal("active channel should be set")
- }
-}
-*/