summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJoram Wilander <jwawilander@gmail.com>2016-06-06 14:29:10 -0400
committerJoram Wilander <jwawilander@gmail.com>2016-06-06 14:29:10 -0400
commitc0d1b8fbb9a141b942d73ad4869e612cdf01bbcd (patch)
tree2c1fe6dfa35bc4d9e913c3eb9aaf74e3b3a1fac6
parenteabd67e4cbc845a2f591fdcf525696c0c2505d0b (diff)
downloadchat-c0d1b8fbb9a141b942d73ad4869e612cdf01bbcd.tar.gz
chat-c0d1b8fbb9a141b942d73ad4869e612cdf01bbcd.tar.bz2
chat-c0d1b8fbb9a141b942d73ad4869e612cdf01bbcd.zip
System messages trigger notifications when user is mentioned (#3235)
-rw-r--r--api/post.go47
-rw-r--r--i18n/en.json4
-rw-r--r--webapp/stores/notification_store.jsx10
3 files changed, 36 insertions, 25 deletions
diff --git a/api/post.go b/api/post.go
index 3acbaff40..408e96377 100644
--- a/api/post.go
+++ b/api/post.go
@@ -470,28 +470,6 @@ func handleWebhookEvents(c *Context, post *model.Post, team *model.Team, channel
}
func sendNotifications(c *Context, post *model.Post, team *model.Team, channel *model.Channel, profileMap map[string]*model.User, members []model.ChannelMember) {
- message := model.NewMessage(c.TeamId, post.ChannelId, post.UserId, model.ACTION_POSTED)
- message.Add("post", post.ToJson())
- message.Add("channel_type", channel.Type)
- message.Add("team_id", team.Id)
-
- if len(post.Filenames) != 0 {
- message.Add("otherFile", "true")
-
- for _, filename := range post.Filenames {
- ext := filepath.Ext(filename)
- if model.IsFileExtImage(ext) {
- message.Add("image", "true")
- break
- }
- }
- }
-
- if post.IsSystemMessage() {
- go Publish(message)
- return
- }
-
if _, ok := profileMap[post.UserId]; !ok {
l4g.Error(utils.T("api.post.send_notifications_and_forget.user_id.error"), post.UserId)
return
@@ -547,7 +525,9 @@ func sendNotifications(c *Context, post *model.Post, team *model.Team, channel *
keywordMap["@channel"] = append(keywordMap["@channel"], profile.Id)
}
- if profile.NotifyProps["push"] == model.USER_NOTIFY_ALL && (post.UserId != profile.Id || post.Props["from_webhook"] == "true") {
+ if profile.NotifyProps["push"] == model.USER_NOTIFY_ALL &&
+ (post.UserId != profile.Id || post.Props["from_webhook"] == "true") &&
+ !post.IsSystemMessage() {
alwaysNotifyUserIds = append(alwaysNotifyUserIds, profile.Id)
}
}
@@ -605,7 +585,9 @@ func sendNotifications(c *Context, post *model.Post, team *model.Team, channel *
mentionedUsersList := make([]string, 0, len(mentionedUserIds))
senderName := ""
- if profile, ok := profileMap[post.UserId]; ok {
+ if post.IsSystemMessage() {
+ senderName = c.T("system.message.name")
+ } else if profile, ok := profileMap[post.UserId]; ok {
senderName = profile.Username
}
@@ -647,7 +629,24 @@ func sendNotifications(c *Context, post *model.Post, team *model.Team, channel *
}
}
+ message := model.NewMessage(c.TeamId, post.ChannelId, post.UserId, model.ACTION_POSTED)
+ message.Add("post", post.ToJson())
+ message.Add("channel_type", channel.Type)
+ message.Add("channel_display_name", channel.DisplayName)
message.Add("sender_name", senderName)
+ message.Add("team_id", team.Id)
+
+ if len(post.Filenames) != 0 {
+ message.Add("otherFile", "true")
+
+ for _, filename := range post.Filenames {
+ ext := filepath.Ext(filename)
+ if model.IsFileExtImage(ext) {
+ message.Add("image", "true")
+ break
+ }
+ }
+ }
if len(mentionedUsersList) != 0 {
message.Add("mentions", model.ArrayToJson(mentionedUsersList))
diff --git a/i18n/en.json b/i18n/en.json
index 80e885343..f88e00d29 100644
--- a/i18n/en.json
+++ b/i18n/en.json
@@ -48,6 +48,10 @@
"translation": "September"
},
{
+ "id": "system.message.name",
+ "translation": "System"
+ },
+ {
"id": "api.general.init.debug",
"translation": "Initializing general api routes"
},
diff --git a/webapp/stores/notification_store.jsx b/webapp/stores/notification_store.jsx
index 5935b876b..78f8e56c8 100644
--- a/webapp/stores/notification_store.jsx
+++ b/webapp/stores/notification_store.jsx
@@ -27,7 +27,11 @@ class NotificationStoreClass extends EventEmitter {
handleRecievedPost(post, msgProps) {
// Send desktop notification
- if ((UserStore.getCurrentId() !== post.user_id || post.props.from_webhook === 'true') && !PostUtils.isSystemMessage(post)) {
+ if ((UserStore.getCurrentId() !== post.user_id || post.props.from_webhook === 'true')) {
+ if (PostUtils.isSystemMessage(post) && post.type !== 'system_join_leave') {
+ return;
+ }
+
let mentions = [];
if (msgProps.mentions) {
mentions = JSON.parse(msgProps.mentions);
@@ -52,6 +56,8 @@ class NotificationStoreClass extends EventEmitter {
let username = Utils.localizeMessage('channel_loader.someone', 'Someone');
if (post.props.override_username && global.window.mm_config.EnablePostUsernameOverride === 'true') {
username = post.props.override_username;
+ } else if (msgProps.sender_name) {
+ username = msgProps.sender_name;
} else if (UserStore.hasProfile(post.user_id)) {
username = UserStore.getProfile(post.user_id).username;
}
@@ -59,6 +65,8 @@ class NotificationStoreClass extends EventEmitter {
let title = Utils.localizeMessage('channel_loader.posted', 'Posted');
if (channel) {
title = channel.display_name;
+ } else if (msgProps.channel_display_name) {
+ title = msgProps.channel_display_name;
}
let notifyText = post.message.replace(/\n+/g, ' ');