aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorAnton Tananaev <anton.tananaev@gmail.com>2019-04-20 10:35:57 -0700
committerGitHub <noreply@github.com>2019-04-20 10:35:57 -0700
commit24be0a7aa9ee04da30f2da81c0ba5d21e2353f5d (patch)
tree9e58528210035fa75755002d566658a36669b09f /src
parent2c6dc2ea108e8f35ad8324e6a6149010b8e258ef (diff)
parent25cbe0ed501319dbb23cc260817a797df5be9fb6 (diff)
downloadtraccar-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')
-rw-r--r--src/main/java/org/traccar/notification/NotificatorManager.java4
-rw-r--r--src/main/java/org/traccar/notificators/NotificatorTelegram.java79
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);
+ }
+
+}