diff options
author | Ruzette Tanyag <ruzette@users.noreply.github.com> | 2017-02-14 10:28:08 -0500 |
---|---|---|
committer | Harrison Healey <harrisonmhealey@gmail.com> | 2017-02-14 10:28:08 -0500 |
commit | 28aa7cdbf2357bda51ba740fd4d7af48b36b96b4 (patch) | |
tree | 0a7daa93b5fa594b113f905506ed6ee6940e789b /api4/channel.go | |
parent | 9dabd10da975a47155641351bbf61b6fb203b4ca (diff) | |
download | chat-28aa7cdbf2357bda51ba740fd4d7af48b36b96b4.tar.gz chat-28aa7cdbf2357bda51ba740fd4d7af48b36b96b4.tar.bz2 chat-28aa7cdbf2357bda51ba740fd4d7af48b36b96b4.zip |
Implement GET channels endpoints for APIv4 (#5363)
* implement get channels endpoints and updated drivers and unittests
* removed channel deletion on tear down, removed manage permission on get channels endpoints, and updated utils to add constant channel length
* added constants for user, team and channel length, updated context to use the model functions
* make sure team name length should be less than the minimum length and revert underscore to team name validity
* changed post test condition from notfound to unauthorized
Diffstat (limited to 'api4/channel.go')
-rw-r--r-- | api4/channel.go | 70 |
1 files changed, 70 insertions, 0 deletions
diff --git a/api4/channel.go b/api4/channel.go index 09ed4b571..938511c14 100644 --- a/api4/channel.go +++ b/api4/channel.go @@ -18,6 +18,10 @@ func InitChannel() { BaseRoutes.Channels.Handle("", ApiSessionRequired(createChannel)).Methods("POST") BaseRoutes.Channels.Handle("/direct", ApiSessionRequired(createDirectChannel)).Methods("POST") + BaseRoutes.Channel.Handle("", ApiSessionRequired(getChannel)).Methods("GET") + BaseRoutes.ChannelByName.Handle("", ApiSessionRequired(getChannelByName)).Methods("GET") + BaseRoutes.ChannelByNameForTeamName.Handle("", ApiSessionRequired(getChannelByNameForTeamName)).Methods("GET") + BaseRoutes.ChannelMembers.Handle("", ApiSessionRequired(getChannelMembers)).Methods("GET") BaseRoutes.ChannelMembersForUser.Handle("", ApiSessionRequired(getChannelMembersForUser)).Methods("GET") BaseRoutes.ChannelMember.Handle("", ApiSessionRequired(getChannelMember)).Methods("GET") @@ -88,6 +92,72 @@ func createDirectChannel(c *Context, w http.ResponseWriter, r *http.Request) { } } +func getChannel(c *Context, w http.ResponseWriter, r *http.Request) { + c.RequireChannelId() + if c.Err != nil { + return + } + + if !app.SessionHasPermissionToChannel(c.Session, c.Params.ChannelId, model.PERMISSION_READ_CHANNEL) { + c.SetPermissionError(model.PERMISSION_READ_CHANNEL) + return + } + + if channel, err := app.GetChannel(c.Params.ChannelId); err != nil { + c.Err = err + return + } else { + w.Write([]byte(channel.ToJson())) + return + } +} + +func getChannelByName(c *Context, w http.ResponseWriter, r *http.Request) { + c.RequireTeamId().RequireChannelName() + if c.Err != nil { + return + } + + var channel *model.Channel + var err *model.AppError + + if channel, err = app.GetChannelByName(c.Params.ChannelName, c.Params.TeamId); err != nil { + c.Err = err + return + } + + if !app.SessionHasPermissionToChannel(c.Session, channel.Id, model.PERMISSION_READ_CHANNEL) { + c.SetPermissionError(model.PERMISSION_READ_CHANNEL) + return + } + + w.Write([]byte(channel.ToJson())) + return +} + +func getChannelByNameForTeamName(c *Context, w http.ResponseWriter, r *http.Request) { + c.RequireTeamName().RequireChannelName() + if c.Err != nil { + return + } + + var channel *model.Channel + var err *model.AppError + + if channel, err = app.GetChannelByNameForTeamName(c.Params.ChannelName, c.Params.TeamName); err != nil { + c.Err = err + return + } + + if !app.SessionHasPermissionToChannel(c.Session, channel.Id, model.PERMISSION_READ_CHANNEL) { + c.SetPermissionError(model.PERMISSION_READ_CHANNEL) + return + } + + w.Write([]byte(channel.ToJson())) + return +} + func getChannelMembers(c *Context, w http.ResponseWriter, r *http.Request) { c.RequireChannelId() if c.Err != nil { |