diff options
author | Anton Tananaev <anton.tananaev@gmail.com> | 2018-09-23 15:09:57 +1200 |
---|---|---|
committer | Anton Tananaev <anton.tananaev@gmail.com> | 2018-09-23 15:09:57 +1200 |
commit | 517382ccc972d6d1ba2b5fd2d912cc6e5ac83902 (patch) | |
tree | 4e1985b73c1e4e501e2786dbc9e57cf02bc878a4 /src | |
parent | a7296d99876000e65bef9b9df708f57ebabbe894 (diff) | |
download | traccar-server-517382ccc972d6d1ba2b5fd2d912cc6e5ac83902.tar.gz traccar-server-517382ccc972d6d1ba2b5fd2d912cc6e5ac83902.tar.bz2 traccar-server-517382ccc972d6d1ba2b5fd2d912cc6e5ac83902.zip |
Implement push notifications
Diffstat (limited to 'src')
-rw-r--r-- | src/org/traccar/notification/NotificatorManager.java | 4 | ||||
-rw-r--r-- | src/org/traccar/notificators/NotificatorFirebase.java | 85 |
2 files changed, 89 insertions, 0 deletions
diff --git a/src/org/traccar/notification/NotificatorManager.java b/src/org/traccar/notification/NotificatorManager.java index 7e8a9dd0e..41678d65c 100644 --- a/src/org/traccar/notification/NotificatorManager.java +++ b/src/org/traccar/notification/NotificatorManager.java @@ -35,6 +35,7 @@ public final class NotificatorManager { private static final String DEFAULT_WEB_NOTIFICATOR = "org.traccar.notificators.NotificatorWeb"; private static final String DEFAULT_MAIL_NOTIFICATOR = "org.traccar.notificators.NotificatorMail"; private static final String DEFAULT_SMS_NOTIFICATOR = "org.traccar.notificators.NotificatorSms"; + private static final String DEFAULT_FIREBASE_NOTIFICATOR = "org.traccar.notificators.NotificatorFirebase"; private final Map<String, Notificator> notificators = new HashMap<>(); private static final Notificator NULL_NOTIFICATOR = new NotificatorNull(); @@ -53,6 +54,9 @@ public final class NotificatorManager { case "sms": defaultNotificator = DEFAULT_SMS_NOTIFICATOR; break; + case "firebase": + defaultNotificator = DEFAULT_FIREBASE_NOTIFICATOR; + break; default: break; } diff --git a/src/org/traccar/notificators/NotificatorFirebase.java b/src/org/traccar/notificators/NotificatorFirebase.java new file mode 100644 index 000000000..a01726889 --- /dev/null +++ b/src/org/traccar/notificators/NotificatorFirebase.java @@ -0,0 +1,85 @@ +/* + * Copyright 2018 Anton Tananaev (anton@traccar.org) + * Copyright 2018 Andrey Kunitsyn (andrey@traccar.org) + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +package org.traccar.notificators; + +import com.fasterxml.jackson.annotation.JsonProperty; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; +import org.traccar.Context; +import org.traccar.model.Event; +import org.traccar.model.Position; +import org.traccar.model.User; +import org.traccar.notification.NotificationFormatter; + +import javax.ws.rs.client.Entity; +import javax.ws.rs.client.InvocationCallback; + +public class NotificatorFirebase extends Notificator { + + private static final Logger LOGGER = LoggerFactory.getLogger(NotificatorFirebase.class); + + private static final String URL = "https://fcm.googleapis.com/fcm/send"; + + private String key; + + public static class Notification { + public String body; + } + + public static class Message { + @JsonProperty("registration_ids") + public String[] tokens; + public Notification notification; + } + + public NotificatorFirebase() { + key = Context.getConfig().getString("notificator.firebase.key"); + } + + @Override + public void sendSync(long userId, Event event, Position position) { + final User user = Context.getPermissionsManager().getUser(userId); + if (user.getAttributes().containsKey("notificationTokens")) { + + Notification notification = new Notification(); + notification.body = NotificationFormatter.formatShortMessage(userId, event, position).trim(); + + Message message = new Message(); + message.tokens = user.getString("notificationTokens").split("[, ]"); + message.notification = notification; + + Context.getClient().target(URL).request() + .header("Authorization", "key=" + key) + .async().post(Entity.json(message), new InvocationCallback<Object>() { + @Override + public void completed(Object o) { + } + + @Override + public void failed(Throwable throwable) { + LOGGER.warn("Firebase notification error", throwable); + } + }); + } + } + + @Override + public void sendAsync(long userId, Event event, Position position) { + sendSync(userId, event, position); + } + +} |