diff options
author | Christian Claus <ch.claus@me.com> | 2018-03-28 06:02:04 +0200 |
---|---|---|
committer | Elias Nahum <nahumhbl@gmail.com> | 2018-03-28 07:02:04 +0300 |
commit | 257f74873297a6c6b4d14f2d21ffc3adad620c4c (patch) | |
tree | e4220b50c707759fb98bd2e49a765952bd705cc9 /app/command_mute.go | |
parent | 71c9dff7662868770f66ab876ad66b354133c2c1 (diff) | |
download | chat-257f74873297a6c6b4d14f2d21ffc3adad620c4c.tar.gz chat-257f74873297a6c6b4d14f2d21ffc3adad620c4c.tar.bz2 chat-257f74873297a6c6b4d14f2d21ffc3adad620c4c.zip |
[PLT-4340] Channel Mute and "/mute" command #7617 (#7713)
* Add command and store changes to allow mute toggling
* Change channel muting to use ChannelMember notification structure
* Suppress email and push notifications for a muted channel
* Make i18n keys issue-compliant
* Add notification-cache handling for channel-muting
* Add channel handle for channel-muting slash-command
* Add unit test for mute command
* Merge branch 'master' into PLT-4340
# Conflicts:
# app/notification.go
* Fix issue that command_mute responses will be overwritten
* Fix i18n key for channel muting
* Apply new Provider Interface to MuteCommand
* Migrate mute notification property to mark_unread
PLT-4340
* Make some i18n improvements for command_mute
PLT-4340
* Remove de.json translations
* Prevent push notifications when channel is muted
* Treat Group messages like Direct messages
* Fix unit test
* Send WS event when the channel member notify props changed
Diffstat (limited to 'app/command_mute.go')
-rw-r--r-- | app/command_mute.go | 88 |
1 files changed, 88 insertions, 0 deletions
diff --git a/app/command_mute.go b/app/command_mute.go new file mode 100644 index 000000000..072e79f92 --- /dev/null +++ b/app/command_mute.go @@ -0,0 +1,88 @@ +// Copyright (c) 2017-present Mattermost, Inc. All Rights Reserved. +// See License.txt for license information. + +package app + +import ( + "strings" + + "github.com/mattermost/mattermost-server/model" + goi18n "github.com/nicksnyder/go-i18n/i18n" +) + +type MuteProvider struct { +} + +const ( + CMD_MUTE = "mute" +) + +func init() { + RegisterCommandProvider(&MuteProvider{}) +} + +func (me *MuteProvider) GetTrigger() string { + return CMD_MUTE +} + +func (me *MuteProvider) GetCommand(a *App, T goi18n.TranslateFunc) *model.Command { + return &model.Command{ + Trigger: CMD_MUTE, + AutoComplete: true, + AutoCompleteDesc: T("api.command_mute.desc"), + AutoCompleteHint: T("api.command_mute.hint"), + DisplayName: T("api.command_mute.name"), + } +} + +func (me *MuteProvider) DoCommand(a *App, args *model.CommandArgs, message string) *model.CommandResponse { + var channel *model.Channel + var noChannelErr *model.AppError + + if channel, noChannelErr = a.GetChannel(args.ChannelId); noChannelErr != nil { + return &model.CommandResponse{Text: args.T("api.command_mute.error", map[string]interface{}{"Channel": channel.DisplayName}), ResponseType: model.COMMAND_RESPONSE_TYPE_EPHEMERAL} + } + + // Overwrite channel with channel-handle if set + if strings.HasPrefix(message, "~") { + splitMessage := strings.Split(message, " ") + chanHandle := strings.Split(splitMessage[0], "~")[1] + data := (<-a.Srv.Store.Channel().GetByName(channel.TeamId, chanHandle, true)).Data + + if data == nil { + return &model.CommandResponse{Text: args.T("api.command_mute.error", map[string]interface{}{"Channel": chanHandle}), ResponseType: model.COMMAND_RESPONSE_TYPE_EPHEMERAL} + } + + channel = data.(*model.Channel) + } + + channelMember := a.ToggleMuteChannel(channel.Id, args.UserId) + + // Invalidate cache to allow cache lookups while sending notifications + a.Srv.Store.Channel().InvalidateCacheForChannelMembersNotifyProps(channel.Id) + + // Direct and Group messages won't have a nice channel title, omit it + if channel.Type == model.CHANNEL_DIRECT || channel.Type == model.CHANNEL_GROUP { + if channelMember.NotifyProps[model.MARK_UNREAD_NOTIFY_PROP] == model.CHANNEL_NOTIFY_MENTION { + publishChannelMemberEvt(a, channelMember, args.UserId) + return &model.CommandResponse{Text: args.T("api.command_mute.success_mute_direct_msg"), ResponseType: model.COMMAND_RESPONSE_TYPE_EPHEMERAL} + } else { + publishChannelMemberEvt(a, channelMember, args.UserId) + return &model.CommandResponse{Text: args.T("api.command_mute.success_unmute_direct_msg"), ResponseType: model.COMMAND_RESPONSE_TYPE_EPHEMERAL} + } + } + + if channelMember.NotifyProps[model.MARK_UNREAD_NOTIFY_PROP] == model.CHANNEL_NOTIFY_MENTION { + publishChannelMemberEvt(a, channelMember, args.UserId) + return &model.CommandResponse{Text: args.T("api.command_mute.success_mute", map[string]interface{}{"Channel": channel.DisplayName}), ResponseType: model.COMMAND_RESPONSE_TYPE_EPHEMERAL} + } else { + publishChannelMemberEvt(a, channelMember, args.UserId) + return &model.CommandResponse{Text: args.T("api.command_mute.success_unmute", map[string]interface{}{"Channel": channel.DisplayName}), ResponseType: model.COMMAND_RESPONSE_TYPE_EPHEMERAL} + } +} + +func publishChannelMemberEvt(a *App, channelMember *model.ChannelMember, userId string) { + evt := model.NewWebSocketEvent(model.WEBSOCKET_EVENT_CHANNEL_MEMBER_UPDATED, "", "", userId, nil) + evt.Add("channelMember", channelMember.ToJson()) + a.Publish(evt) +} |