diff options
-rw-r--r-- | app/command_remove.go | 114 | ||||
-rw-r--r-- | i18n/en.json | 36 |
2 files changed, 150 insertions, 0 deletions
diff --git a/app/command_remove.go b/app/command_remove.go new file mode 100644 index 000000000..6047ff5be --- /dev/null +++ b/app/command_remove.go @@ -0,0 +1,114 @@ +// Copyright (c) 2017-present Mattermost, Inc. All Rights Reserved. +// See License.txt for license information. + +package app + +import ( + "strings" + + l4g "github.com/alecthomas/log4go" + goi18n "github.com/nicksnyder/go-i18n/i18n" + + "github.com/mattermost/mattermost-server/model" + "github.com/mattermost/mattermost-server/utils" +) + +type RemoveProvider struct { +} + +type KickProvider struct { +} + +const ( + CMD_REMOVE = "remove" + CMD_KICK = "kick" +) + +func init() { + RegisterCommandProvider(&RemoveProvider{}) + RegisterCommandProvider(&KickProvider{}) +} + +func (me *RemoveProvider) GetTrigger() string { + return CMD_REMOVE +} + +func (me *KickProvider) GetTrigger() string { + return CMD_KICK +} + +func (me *RemoveProvider) GetCommand(T goi18n.TranslateFunc) *model.Command { + return &model.Command{ + Trigger: CMD_REMOVE, + AutoComplete: true, + AutoCompleteDesc: T("api.command_remove.desc"), + AutoCompleteHint: T("api.command_remove.hint"), + DisplayName: T("api.command_remove.name"), + } +} + +func (me *KickProvider) GetCommand(T goi18n.TranslateFunc) *model.Command { + return &model.Command{ + Trigger: CMD_KICK, + AutoComplete: true, + AutoCompleteDesc: T("api.command_remove.desc"), + AutoCompleteHint: T("api.command_remove.hint"), + DisplayName: T("api.command_kick.name"), + } +} + +func (me *RemoveProvider) DoCommand(a *App, args *model.CommandArgs, message string) *model.CommandResponse { + return doCommand(a, args, message) +} + +func (me *KickProvider) DoCommand(a *App, args *model.CommandArgs, message string) *model.CommandResponse { + return doCommand(a, args, message) +} + +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} + } + + if channel.Type == model.CHANNEL_OPEN && !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} + } + + if channel.Type == model.CHANNEL_PRIVATE && !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} + } + + if channel.Type == model.CHANNEL_GROUP || channel.Type == model.CHANNEL_DIRECT { + 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} + } + + targetUsername := "" + + 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 { + l4g.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) + } + + _, err = a.GetChannelMember(args.ChannelId, userProfile.Id) + if err != nil { + nameFormat := *utils.Cfg.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} + } + + 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{} +} diff --git a/i18n/en.json b/i18n/en.json index 50073765f..53cbc6d99 100644 --- a/i18n/en.json +++ b/i18n/en.json @@ -563,6 +563,42 @@ "id": "api.command_channel_purpose.update_channel.app_error", "translation": "Error to update the current channel." }, + { + "id": "api.command_remove.message.app_error", + "translation": "A message must be provided with the /remove or /kick command." + }, + { + "id": "api.command_remove.missing.app_error", + "translation": "We couldn't find the user" + }, + { + "id": "api.command_remove.permission.app_error", + "translation": "You do not have the appropriate permissions to remove the member." + }, + { + "id": "api.command_remove.direct_group.app_error", + "translation": "You can't remove someone from a direct message channel." + }, + { + "id": "api.command_remove.name", + "translation": "remove" + }, + { + "id": "api.command_remove.hint", + "translation": "@[username]" + }, + { + "id": "api.command_remove.desc", + "translation": "Remove a member from the channel" + }, + { + "id": "api.command_remove.user_not_in_channel", + "translation": "{{.Username}} is not a member of this channel." + }, + { + "id": "api.command_kick.name", + "translation": "kick" + }, { "id": "api.command_channel_rename.channel.app_error", "translation": "Error to retrieve the current channel." |