summaryrefslogtreecommitdiffstats
path: root/api/channel.go
diff options
context:
space:
mode:
authorCorey Hulen <corey@hulen.com>2015-10-07 09:30:01 -0700
committerCorey Hulen <corey@hulen.com>2015-10-07 09:30:01 -0700
commit3c859aebde2e9e11e8b1eeb4d8bb300400b4ad54 (patch)
treee392637ecffed4e761ad5c59e4d6472e998132e6 /api/channel.go
parent5ac1a58063b9302f2ed88af2bbed0be850aa1666 (diff)
parent1421e1ec4aa09c0e7094643d342d095cdd91d506 (diff)
downloadchat-3c859aebde2e9e11e8b1eeb4d8bb300400b4ad54.tar.gz
chat-3c859aebde2e9e11e8b1eeb4d8bb300400b4ad54.tar.bz2
chat-3c859aebde2e9e11e8b1eeb4d8bb300400b4ad54.zip
Merge pull request #961 from mattermost/plt-471
PLT-471 Fix user_added websocket event
Diffstat (limited to 'api/channel.go')
-rw-r--r--api/channel.go39
1 files changed, 23 insertions, 16 deletions
diff --git a/api/channel.go b/api/channel.go
index 5e13fa18a..0d22d7c00 100644
--- a/api/channel.go
+++ b/api/channel.go
@@ -472,6 +472,8 @@ func leaveChannel(c *Context, w http.ResponseWriter, r *http.Request) {
return
}
+ UpdateChannelAccessCacheAndForget(c.Session.TeamId, c.Session.UserId, channel.Id)
+
post := &model.Post{ChannelId: channel.Id, Message: fmt.Sprintf(
`%v has left the channel.`,
user.Username), Type: model.POST_JOIN_LEAVE}
@@ -706,20 +708,21 @@ func addChannelMember(c *Context, w http.ResponseWriter, r *http.Request) {
return
}
- post := &model.Post{ChannelId: id, Message: fmt.Sprintf(
- `%v added to the channel by %v`,
- nUser.Username, oUser.Username), Type: model.POST_JOIN_LEAVE}
- if _, err := CreatePost(c, post, false); err != nil {
- l4g.Error("Failed to post add message %v", err)
- c.Err = model.NewAppError("addChannelMember", "Failed to add member to channel", "")
- return
- }
-
c.LogAudit("name=" + channel.Name + " user_id=" + userId)
- message := model.NewMessage(c.Session.TeamId, "", userId, model.ACTION_USER_ADDED)
+ go func() {
+ post := &model.Post{ChannelId: id, Message: fmt.Sprintf(
+ `%v added to the channel by %v`,
+ nUser.Username, oUser.Username), Type: model.POST_JOIN_LEAVE}
+ if _, err := CreatePost(c, post, false); err != nil {
+ l4g.Error("Failed to post add member to channel message, err=%v", err)
+ }
- PublishAndForget(message)
+ UpdateChannelAccessCache(c.Session.TeamId, userId, channel.Id)
+ message := model.NewMessage(c.Session.TeamId, channel.Id, userId, model.ACTION_USER_ADDED)
+
+ PublishAndForget(message)
+ }()
<-Srv.Store.Channel().UpdateLastViewedAt(id, oUser.Id)
w.Write([]byte(cm.ToJson()))
@@ -773,13 +776,17 @@ func removeChannelMember(c *Context, w http.ResponseWriter, r *http.Request) {
return
}
- message := model.NewMessage(c.Session.TeamId, "", userId, model.ACTION_USER_REMOVED)
- message.Add("channel_id", id)
- message.Add("remover", c.Session.UserId)
- PublishAndForget(message)
-
c.LogAudit("name=" + channel.Name + " user_id=" + userId)
+ go func() {
+ UpdateChannelAccessCache(c.Session.TeamId, userId, id)
+
+ message := model.NewMessage(c.Session.TeamId, "", userId, model.ACTION_USER_REMOVED)
+ message.Add("channel_id", id)
+ message.Add("remover", c.Session.UserId)
+ PublishAndForget(message)
+ }()
+
result := make(map[string]string)
result["channel_id"] = channel.Id
result["removed_user_id"] = userId