mirror of
https://github.com/craigerl/aprsd.git
synced 2024-09-28 16:16:51 -04:00
Hemna
1a1fcba1c4
This patch adds a new optional feature called Watch list. Aprsd will filter IN all aprs packets from a list of callsigns. APRSD will keep track of the last time a callsign has been seen. When the configured timeout value has been reached, the next time a callsign is seen, APRSD will send the next packet from that callsign through the new notification plugins list. The new BaseNotifyPlugin is the default core APRSD notify based plugin. When it gets a packet it will construct a reply message to be sent to the configured alert callsign to alert them that the seen callsign is now on the APRS network. This basically acts as a notification that your watched callsign list is available on APRS. The new configuration options: aprsd: watch_list: # The callsign to send a message to once a watch list callsign # is now seen on APRS-IS alert_callsign: NOCALL # The time in seconds to wait for notification. # The default is 12 hours. alert_time_seconds: 43200 # The list of callsigns to watch for callsigns: - WB4BOR - KFART # Enable/disable this feature enabled: false # The list of notify based plugins to load for # processing a new seen packet from a callsign. enabled_plugins: - aprsd.plugins.notify.BaseNotifyPlugin This patch also adds a new section in the Admin UI for showing the watch list and the age of the last seen packet for each callsing since APRSD startup.
99 lines
3.9 KiB
Python
99 lines
3.9 KiB
Python
import logging
|
|
import re
|
|
import time
|
|
|
|
from aprsd import email, messaging, plugin, trace
|
|
|
|
LOG = logging.getLogger("APRSD")
|
|
|
|
|
|
class EmailPlugin(plugin.APRSDMessagePluginBase):
|
|
"""Email Plugin."""
|
|
|
|
version = "1.0"
|
|
command_regex = "^-.*"
|
|
command_name = "email"
|
|
|
|
# message_number:time combos so we don't resend the same email in
|
|
# five mins {int:int}
|
|
email_sent_dict = {}
|
|
|
|
@trace.trace
|
|
def command(self, packet):
|
|
LOG.info("Email COMMAND")
|
|
|
|
fromcall = packet.get("from")
|
|
message = packet.get("message_text", None)
|
|
ack = packet.get("msgNo", "0")
|
|
|
|
reply = None
|
|
if not self.config["aprsd"]["email"].get("enabled", False):
|
|
LOG.debug("Email is not enabled in config file ignoring.")
|
|
return "Email not enabled."
|
|
|
|
searchstring = "^" + self.config["ham"]["callsign"] + ".*"
|
|
# only I can do email
|
|
if re.search(searchstring, fromcall):
|
|
# digits only, first one is number of emails to resend
|
|
r = re.search("^-([0-9])[0-9]*$", message)
|
|
if r is not None:
|
|
LOG.debug("RESEND EMAIL")
|
|
email.resend_email(r.group(1), fromcall)
|
|
reply = messaging.NULL_MESSAGE
|
|
# -user@address.com body of email
|
|
elif re.search(r"^-([A-Za-z0-9_\-\.@]+) (.*)", message):
|
|
# (same search again)
|
|
a = re.search(r"^-([A-Za-z0-9_\-\.@]+) (.*)", message)
|
|
if a is not None:
|
|
to_addr = a.group(1)
|
|
content = a.group(2)
|
|
|
|
email_address = email.get_email_from_shortcut(to_addr)
|
|
if not email_address:
|
|
reply = "Bad email address"
|
|
return reply
|
|
|
|
# send recipient link to aprs.fi map
|
|
if content == "mapme":
|
|
content = "Click for my location: http://aprs.fi/{}".format(
|
|
self.config["ham"]["callsign"],
|
|
)
|
|
too_soon = 0
|
|
now = time.time()
|
|
# see if we sent this msg number recently
|
|
if ack in self.email_sent_dict:
|
|
# BUG(hemna) - when we get a 2 different email command
|
|
# with the same ack #, we don't send it.
|
|
timedelta = now - self.email_sent_dict[ack]
|
|
if timedelta < 300: # five minutes
|
|
too_soon = 1
|
|
if not too_soon or ack == 0:
|
|
LOG.info("Send email '{}'".format(content))
|
|
send_result = email.send_email(to_addr, content)
|
|
reply = messaging.NULL_MESSAGE
|
|
if send_result != 0:
|
|
reply = "-{} failed".format(to_addr)
|
|
# messaging.send_message(fromcall, "-" + to_addr + " failed")
|
|
else:
|
|
# clear email sent dictionary if somehow goes over 100
|
|
if len(self.email_sent_dict) > 98:
|
|
LOG.debug(
|
|
"DEBUG: email_sent_dict is big ("
|
|
+ str(len(self.email_sent_dict))
|
|
+ ") clearing out.",
|
|
)
|
|
self.email_sent_dict.clear()
|
|
self.email_sent_dict[ack] = now
|
|
else:
|
|
reply = messaging.NULL_MESSAGE
|
|
LOG.info(
|
|
"Email for message number "
|
|
+ ack
|
|
+ " recently sent, not sending again.",
|
|
)
|
|
else:
|
|
reply = "Bad email address"
|
|
# messaging.send_message(fromcall, "Bad email address")
|
|
|
|
return reply
|