diff options
author | Anton Tananaev <anton.tananaev@gmail.com> | 2019-04-20 10:35:57 -0700 |
---|---|---|
committer | GitHub <noreply@github.com> | 2019-04-20 10:35:57 -0700 |
commit | 24be0a7aa9ee04da30f2da81c0ba5d21e2353f5d (patch) | |
tree | 9e58528210035fa75755002d566658a36669b09f /src/main/java/org | |
parent | 2c6dc2ea108e8f35ad8324e6a6149010b8e258ef (diff) | |
parent | 25cbe0ed501319dbb23cc260817a797df5be9fb6 (diff) | |
download | traccar-server-24be0a7aa9ee04da30f2da81c0ba5d21e2353f5d.tar.gz traccar-server-24be0a7aa9ee04da30f2da81c0ba5d21e2353f5d.tar.bz2 traccar-server-24be0a7aa9ee04da30f2da81c0ba5d21e2353f5d.zip |
Merge pull request #4284 from he-leon/master
Added Telegram support
Diffstat (limited to 'src/main/java/org')
-rw-r--r-- | src/main/java/org/traccar/notification/NotificatorManager.java | 4 | ||||
-rw-r--r-- | src/main/java/org/traccar/notificators/NotificatorTelegram.java | 79 |
2 files changed, 83 insertions, 0 deletions
diff --git a/src/main/java/org/traccar/notification/NotificatorManager.java b/src/main/java/org/traccar/notification/NotificatorManager.java index a4080a38d..191748379 100644 --- a/src/main/java/org/traccar/notification/NotificatorManager.java +++ b/src/main/java/org/traccar/notification/NotificatorManager.java @@ -31,6 +31,7 @@ import org.traccar.notificators.NotificatorNull; import org.traccar.notificators.Notificator; import org.traccar.notificators.NotificatorSms; import org.traccar.notificators.NotificatorWeb; +import org.traccar.notificators.NotificatorTelegram; public final class NotificatorManager { @@ -57,6 +58,9 @@ public final class NotificatorManager { case "firebase": defaultNotificator = NotificatorFirebase.class.getCanonicalName(); break; + case "telegram": + defaultNotificator = NotificatorTelegram.class.getCanonicalName(); + break; default: break; } diff --git a/src/main/java/org/traccar/notificators/NotificatorTelegram.java b/src/main/java/org/traccar/notificators/NotificatorTelegram.java new file mode 100644 index 000000000..34e9f9c9d --- /dev/null +++ b/src/main/java/org/traccar/notificators/NotificatorTelegram.java @@ -0,0 +1,79 @@ +/* + * 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.notification.NotificationFormatter; + +import javax.ws.rs.client.Entity; +import javax.ws.rs.client.InvocationCallback; + +public class NotificatorTelegram extends Notificator { + + private static final Logger LOGGER = LoggerFactory.getLogger(NotificatorTelegram.class); + + private String urlString = "https://api.telegram.org/bot%s/sendMessage"; + private String apikey; + private String chatid; + + public static class Message { + @JsonProperty("chat_id") + private String chatid; + @JsonProperty("text") + private String text; + @JsonProperty("parse_mode") + private String parsemode; + + } + + public NotificatorTelegram() { + apikey = Context.getConfig().getString("notificator.Telegram.apikey"); + chatid = Context.getConfig().getString("notificator.Telegram.chatid"); + } + + @Override + public void sendSync(long userId, Event event, Position position) { + + Message message = new Message(); + message.chatid = chatid; + message.parsemode = "html"; + message.text = NotificationFormatter.formatShortMessage(userId, event, position); + + urlString = String.format(urlString, apikey); + Context.getClient().target(urlString).request() + .async().post(Entity.json(message), new InvocationCallback<Object>() { + @Override + public void completed(Object o) { + } + + @Override + public void failed(Throwable throwable) { + LOGGER.warn("Telegram API error", throwable); + } + }); + } + + @Override + public void sendAsync(long userId, Event event, Position position) { + sendSync(userId, event, position); + } + +} |