summaryrefslogtreecommitdiffstats
path: root/app/command_remove.go
diff options
context:
space:
mode:
authorGeorge Goldberg <george@gberg.me>2018-10-01 13:51:12 +0100
committerGitHub <noreply@github.com>2018-10-01 13:51:12 +0100
commita0f75cadb2b0fa91f6e321b1b8b859519b2ec865 (patch)
tree49d6333eba0aa4cc02355a740c757500e9ee4798 /app/command_remove.go
parent71e3afaf63631583202f824424ced2e3aa02d140 (diff)
downloadchat-a0f75cadb2b0fa91f6e321b1b8b859519b2ec865.tar.gz
chat-a0f75cadb2b0fa91f6e321b1b8b859519b2ec865.tar.bz2
chat-a0f75cadb2b0fa91f6e321b1b8b859519b2ec865.zip
MM-12110: Don't /invite or /kick deactivated users. (#9494)
Diffstat (limited to 'app/command_remove.go')
-rw-r--r--app/command_remove.go57
1 files changed, 45 insertions, 12 deletions
diff --git a/app/command_remove.go b/app/command_remove.go
index 6a67996e9..f79ba5b51 100644
--- a/app/command_remove.go
+++ b/app/command_remove.go
@@ -67,24 +67,39 @@ func (me *KickProvider) DoCommand(a *App, args *model.CommandArgs, message strin
func doCommand(a *App, args *model.CommandArgs, message string) *model.CommandResponse {
channel, err := a.GetChannel(args.ChannelId)
if err != nil {
- return &model.CommandResponse{Text: args.T("api.command_channel_rename.channel.app_error"), ResponseType: model.COMMAND_RESPONSE_TYPE_EPHEMERAL}
+ return &model.CommandResponse{
+ Text: args.T("api.command_channel_remove.channel.app_error"),
+ ResponseType: model.COMMAND_RESPONSE_TYPE_EPHEMERAL,
+ }
}
switch channel.Type {
case model.CHANNEL_OPEN:
if !a.SessionHasPermissionToChannel(args.Session, args.ChannelId, model.PERMISSION_MANAGE_PUBLIC_CHANNEL_MEMBERS) {
- return &model.CommandResponse{Text: args.T("api.command_remove.permission.app_error"), ResponseType: model.COMMAND_RESPONSE_TYPE_EPHEMERAL}
+ return &model.CommandResponse{
+ Text: args.T("api.command_remove.permission.app_error"),
+ ResponseType: model.COMMAND_RESPONSE_TYPE_EPHEMERAL,
+ }
}
case model.CHANNEL_PRIVATE:
if !a.SessionHasPermissionToChannel(args.Session, args.ChannelId, model.PERMISSION_MANAGE_PRIVATE_CHANNEL_MEMBERS) {
- return &model.CommandResponse{Text: args.T("api.command_remove.permission.app_error"), ResponseType: model.COMMAND_RESPONSE_TYPE_EPHEMERAL}
+ return &model.CommandResponse{
+ Text: args.T("api.command_remove.permission.app_error"),
+ ResponseType: model.COMMAND_RESPONSE_TYPE_EPHEMERAL,
+ }
}
default:
- return &model.CommandResponse{Text: args.T("api.command_remove.direct_group.app_error"), ResponseType: model.COMMAND_RESPONSE_TYPE_EPHEMERAL}
+ return &model.CommandResponse{
+ Text: args.T("api.command_remove.direct_group.app_error"),
+ ResponseType: model.COMMAND_RESPONSE_TYPE_EPHEMERAL,
+ }
}
if len(message) == 0 {
- return &model.CommandResponse{Text: args.T("api.command_remove.message.app_error"), ResponseType: model.COMMAND_RESPONSE_TYPE_EPHEMERAL}
+ return &model.CommandResponse{
+ Text: args.T("api.command_remove.message.app_error"),
+ ResponseType: model.COMMAND_RESPONSE_TYPE_EPHEMERAL,
+ }
}
targetUsername := ""
@@ -92,22 +107,40 @@ func doCommand(a *App, args *model.CommandArgs, message string) *model.CommandRe
targetUsername = strings.SplitN(message, " ", 2)[0]
targetUsername = strings.TrimPrefix(targetUsername, "@")
- var userProfile *model.User
- if result := <-a.Srv.Store.User().GetByUsername(targetUsername); result.Err != nil {
+ result := <-a.Srv.Store.User().GetByUsername(targetUsername)
+ if result.Err != nil {
mlog.Error(result.Err.Error())
- return &model.CommandResponse{Text: args.T("api.command_remove.missing.app_error"), ResponseType: model.COMMAND_RESPONSE_TYPE_EPHEMERAL}
- } else {
- userProfile = result.Data.(*model.User)
+ return &model.CommandResponse{
+ Text: args.T("api.command_remove.missing.app_error"),
+ ResponseType: model.COMMAND_RESPONSE_TYPE_EPHEMERAL,
+ }
+ }
+ userProfile := result.Data.(*model.User)
+ if userProfile.DeleteAt != 0 {
+ return &model.CommandResponse{
+ Text: args.T("api.command_remove.missing.app_error"),
+ ResponseType: model.COMMAND_RESPONSE_TYPE_EPHEMERAL,
+ }
}
_, err = a.GetChannelMember(args.ChannelId, userProfile.Id)
if err != nil {
nameFormat := *a.Config().TeamSettings.TeammateNameDisplay
- return &model.CommandResponse{Text: args.T("api.command_remove.user_not_in_channel", map[string]interface{}{"Username": userProfile.GetDisplayName(nameFormat)}), ResponseType: model.COMMAND_RESPONSE_TYPE_EPHEMERAL}
+ return &model.CommandResponse{
+ Text: args.T("api.command_remove.user_not_in_channel", map[string]interface{}{
+ "Username": userProfile.GetDisplayName(nameFormat),
+ }),
+ ResponseType: model.COMMAND_RESPONSE_TYPE_EPHEMERAL,
+ }
}
if err = a.RemoveUserFromChannel(userProfile.Id, args.UserId, channel); err != nil {
- return &model.CommandResponse{Text: args.T(err.Id, map[string]interface{}{"Channel": model.DEFAULT_CHANNEL}), ResponseType: model.COMMAND_RESPONSE_TYPE_EPHEMERAL}
+ return &model.CommandResponse{
+ Text: args.T(err.Id, map[string]interface{}{
+ "Channel": model.DEFAULT_CHANNEL,
+ }),
+ ResponseType: model.COMMAND_RESPONSE_TYPE_EPHEMERAL,
+ }
}
return &model.CommandResponse{}