summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--app/notification.go19
-rw-r--r--model/client.go1
2 files changed, 15 insertions, 5 deletions
diff --git a/app/notification.go b/app/notification.go
index e9e76de45..ae365b417 100644
--- a/app/notification.go
+++ b/app/notification.go
@@ -514,7 +514,7 @@ func sendPushNotification(post *model.Post, user *model.User, channel *model.Cha
for _, session := range sessions {
tmpMessage := *model.PushNotificationFromJson(strings.NewReader(msg.ToJson()))
tmpMessage.SetDeviceIdAndPlatform(session.DeviceId)
- go sendToPushProxy(tmpMessage)
+ go sendToPushProxy(tmpMessage, session)
if einterfaces.GetMetricsInterface() != nil {
einterfaces.GetMetricsInterface().IncrementPostSentPush()
@@ -546,13 +546,13 @@ func ClearPushNotification(userId string, channelId string) *model.AppError {
for _, session := range sessions {
tmpMessage := *model.PushNotificationFromJson(strings.NewReader(msg.ToJson()))
tmpMessage.SetDeviceIdAndPlatform(session.DeviceId)
- go sendToPushProxy(tmpMessage)
+ go sendToPushProxy(tmpMessage, session)
}
return nil
}
-func sendToPushProxy(msg model.PushNotification) *model.AppError {
+func sendToPushProxy(msg model.PushNotification, session *model.Session) *model.AppError {
msg.ServerId = utils.CfgDiagnosticId
tr := &http.Transport{
@@ -565,8 +565,17 @@ func sendToPushProxy(msg model.PushNotification) *model.AppError {
if resp, err := httpClient.Do(request); err != nil {
return model.NewLocAppError("sendToPushProxy", "api.post.send_notifications_and_forget.push_notification.error", map[string]interface{}{"DeviceId": msg.DeviceId, "Error": err.Error()}, "")
} else {
- ioutil.ReadAll(resp.Body)
- resp.Body.Close()
+ m := model.MapFromJson(resp.Body)
+ if resp.Body != nil {
+ ioutil.ReadAll(resp.Body)
+ resp.Body.Close()
+ }
+
+ if m[model.STATUS] == model.STATUS_REMOVE {
+ l4g.Info("Device was reported as removed for UserId=%v SessionId=%v removing push for this session", session.UserId, session.Id)
+ AttachDeviceId(session.Id, "", session.ExpiresAt)
+ ClearSessionCacheForUser(session.UserId)
+ }
}
return nil
diff --git a/model/client.go b/model/client.go
index 15cdd1a97..26efa62b4 100644
--- a/model/client.go
+++ b/model/client.go
@@ -35,6 +35,7 @@ const (
STATUS = "status"
STATUS_OK = "OK"
STATUS_FAIL = "FAIL"
+ STATUS_REMOVE = "REMOVE"
CLIENT_DIR = "webapp/dist"