From 2df818b9c680d9e6aec2cddb4c910ecf8341e3a9 Mon Sep 17 00:00:00 2001 From: George Goldberg Date: Tue, 10 Jul 2018 09:54:49 +0100 Subject: MM-11227: Fix group msg slash command. (#9070) --- app/channel.go | 24 ++++++++++++++++++++++++ 1 file changed, 24 insertions(+) (limited to 'app/channel.go') diff --git a/app/channel.go b/app/channel.go index eee27a6de..5607601c6 100644 --- a/app/channel.go +++ b/app/channel.go @@ -340,6 +340,30 @@ func (a *App) createGroupChannel(userIds []string, creatorId string) (*model.Cha } } +func (a *App) GetGroupChannel(userIds []string) (*model.Channel, *model.AppError) { + if len(userIds) > model.CHANNEL_GROUP_MAX_USERS || len(userIds) < model.CHANNEL_GROUP_MIN_USERS { + return nil, model.NewAppError("GetGroupChannel", "api.channel.create_group.bad_size.app_error", nil, "", http.StatusBadRequest) + } + + var users []*model.User + if result := <-a.Srv.Store.User().GetProfileByIds(userIds, true); result.Err != nil { + return nil, result.Err + } else { + users = result.Data.([]*model.User) + } + + if len(users) != len(userIds) { + return nil, model.NewAppError("GetGroupChannel", "api.channel.create_group.bad_user.app_error", nil, "user_ids="+model.ArrayToJson(userIds), http.StatusBadRequest) + } + + channel, err := a.GetChannelByName(model.GetGroupNameFromUserIds(userIds), "") + if err != nil { + return nil, err + } + + return channel, nil +} + func (a *App) UpdateChannel(channel *model.Channel) (*model.Channel, *model.AppError) { if result := <-a.Srv.Store.Channel().Update(channel); result.Err != nil { return nil, result.Err -- cgit v1.2.3-1-g7c22