From 764be940acfa1d1e69fd74d59a9ecfd30ff1d777 Mon Sep 17 00:00:00 2001 From: Mark Rawson Date: Tue, 17 Jun 2014 21:37:09 +0100 Subject: [PATCH 1/4] Add UI option to input users own Pushover API key --- .../default/config_notifications.tmpl | 10 ++++++++++ gui/slick/js/configNotifications.js | 3 ++- sickbeard/__init__.py | 6 ++++-- sickbeard/notifiers/pushover.py | 19 ++++++++++++------- sickbeard/webserve.py | 7 ++++--- 5 files changed, 32 insertions(+), 13 deletions(-) diff --git a/gui/slick/interfaces/default/config_notifications.tmpl b/gui/slick/interfaces/default/config_notifications.tmpl index a67adfbb..891caf60 100644 --- a/gui/slick/interfaces/default/config_notifications.tmpl +++ b/gui/slick/interfaces/default/config_notifications.tmpl @@ -745,6 +745,16 @@ User key of your Pushover account +
+ + +
Click below to test.
diff --git a/gui/slick/js/configNotifications.js b/gui/slick/js/configNotifications.js index 8a390d3c..df03d5d3 100644 --- a/gui/slick/js/configNotifications.js +++ b/gui/slick/js/configNotifications.js @@ -57,7 +57,8 @@ $(document).ready(function(){ $('#testPushover').click(function() { $('#testPushover-result').html(loading); var pushover_userkey = $("#pushover_userkey").val(); - $.get(sbRoot + "/home/testPushover", {'userKey': pushover_userkey}, + var pushover_apikey = $("#pushover_apikey").val(); + $.get(sbRoot + "/home/testPushover", {'userKey': pushover_userkey, 'apiKey': pushover_apikey}, function (data) { $('#testPushover-result').html(data); }); }); diff --git a/sickbeard/__init__.py b/sickbeard/__init__.py index 98c684d5..7576b5e9 100644 --- a/sickbeard/__init__.py +++ b/sickbeard/__init__.py @@ -313,6 +313,7 @@ PUSHOVER_NOTIFY_ONSNATCH = False PUSHOVER_NOTIFY_ONDOWNLOAD = False PUSHOVER_NOTIFY_ONSUBTITLEDOWNLOAD = False PUSHOVER_USERKEY = None +PUSHOVER_APIKEY = None USE_LIBNOTIFY = False LIBNOTIFY_NOTIFY_ONSNATCH = False @@ -463,7 +464,7 @@ def initialize(consoleLogging=True): EXTRA_SCRIPTS, USE_TWITTER, TWITTER_USERNAME, TWITTER_PASSWORD, TWITTER_PREFIX, DAILYSEARCH_FREQUENCY, \ USE_BOXCAR, BOXCAR_USERNAME, BOXCAR_PASSWORD, BOXCAR_NOTIFY_ONDOWNLOAD, BOXCAR_NOTIFY_ONSUBTITLEDOWNLOAD, BOXCAR_NOTIFY_ONSNATCH, \ USE_BOXCAR2, BOXCAR2_ACCESSTOKEN, BOXCAR2_NOTIFY_ONDOWNLOAD, BOXCAR2_NOTIFY_ONSUBTITLEDOWNLOAD, BOXCAR2_NOTIFY_ONSNATCH, \ - USE_PUSHOVER, PUSHOVER_USERKEY, PUSHOVER_NOTIFY_ONDOWNLOAD, PUSHOVER_NOTIFY_ONSUBTITLEDOWNLOAD, PUSHOVER_NOTIFY_ONSNATCH, \ + USE_PUSHOVER, PUSHOVER_USERKEY, PUSHOVER_APIKEY, PUSHOVER_NOTIFY_ONDOWNLOAD, PUSHOVER_NOTIFY_ONSUBTITLEDOWNLOAD, PUSHOVER_NOTIFY_ONSNATCH, \ USE_LIBNOTIFY, LIBNOTIFY_NOTIFY_ONSNATCH, LIBNOTIFY_NOTIFY_ONDOWNLOAD, LIBNOTIFY_NOTIFY_ONSUBTITLEDOWNLOAD, USE_NMJ, NMJ_HOST, NMJ_DATABASE, NMJ_MOUNT, USE_NMJv2, NMJv2_HOST, NMJv2_DATABASE, NMJv2_DBLOC, USE_SYNOINDEX, \ USE_SYNOLOGYNOTIFIER, SYNOLOGYNOTIFIER_NOTIFY_ONSNATCH, SYNOLOGYNOTIFIER_NOTIFY_ONDOWNLOAD, SYNOLOGYNOTIFIER_NOTIFY_ONSUBTITLEDOWNLOAD, \ USE_EMAIL, EMAIL_HOST, EMAIL_PORT, EMAIL_TLS, EMAIL_USER, EMAIL_PASSWORD, EMAIL_FROM, EMAIL_NOTIFY_ONSNATCH, EMAIL_NOTIFY_ONDOWNLOAD, EMAIL_NOTIFY_ONSUBTITLEDOWNLOAD, EMAIL_LIST, \ @@ -754,7 +755,7 @@ def initialize(consoleLogging=True): PUSHOVER_NOTIFY_ONSUBTITLEDOWNLOAD = bool( check_setting_int(CFG, 'Pushover', 'pushover_notify_onsubtitledownload', 0)) PUSHOVER_USERKEY = check_setting_str(CFG, 'Pushover', 'pushover_userkey', '') - + PUSHOVER_APIKEY = check_setting_str(CFG, 'Pushover', 'pushover_apikey', '') USE_LIBNOTIFY = bool(check_setting_int(CFG, 'Libnotify', 'use_libnotify', 0)) LIBNOTIFY_NOTIFY_ONSNATCH = bool(check_setting_int(CFG, 'Libnotify', 'libnotify_notify_onsnatch', 0)) LIBNOTIFY_NOTIFY_ONDOWNLOAD = bool(check_setting_int(CFG, 'Libnotify', 'libnotify_notify_ondownload', 0)) @@ -1650,6 +1651,7 @@ def save_config(): new_config['Pushover']['pushover_notify_ondownload'] = int(PUSHOVER_NOTIFY_ONDOWNLOAD) new_config['Pushover']['pushover_notify_onsubtitledownload'] = int(PUSHOVER_NOTIFY_ONSUBTITLEDOWNLOAD) new_config['Pushover']['pushover_userkey'] = PUSHOVER_USERKEY + new_config['Pushover']['pushover_apikey'] = PUSHOVER_APIKEY new_config['Libnotify'] = {} new_config['Libnotify']['use_libnotify'] = int(USE_LIBNOTIFY) diff --git a/sickbeard/notifiers/pushover.py b/sickbeard/notifiers/pushover.py index ac0aabad..c9ea69f2 100644 --- a/sickbeard/notifiers/pushover.py +++ b/sickbeard/notifiers/pushover.py @@ -32,10 +32,10 @@ API_KEY = "awKfdt263PLaEWV9RXuSn4c46qoAyA" class PushoverNotifier: - def test_notify(self, userKey=None): + def test_notify(self, userKey=None, apiKey=None): return self._notifyPushover("This is a test notification from SickRage", 'Test', userKey, force=True) - def _sendPushover(self, msg, title, userKey=None): + def _sendPushover(self, msg, title, userKey=None, apiKey=None): """ Sends a pushover notification to the address provided @@ -49,12 +49,17 @@ class PushoverNotifier: if not userKey: userKey = sickbeard.PUSHOVER_USERKEY + if not apiKey: + apiKey = sickbeard.PUSHOVER_APIKEY or API_KEY + + logger.log("Pushover API KEY in use: " + apiKey, logger.DEBUG) + # build up the URL and parameters msg = msg.strip() curUrl = API_URL data = urllib.urlencode({ - 'token': API_KEY, + 'token': apiKey, 'title': title, 'user': userKey, 'message': msg.encode('utf-8'), @@ -85,7 +90,7 @@ class PushoverNotifier: elif e.code == 401: #HTTP status 401 if the user doesn't have the service added - subscribeNote = self._sendPushover(msg, title, userKey) + subscribeNote = self._sendPushover(msg, title, userKey, apiKey) if subscribeNote: logger.log("Subscription send", logger.DEBUG) return True @@ -114,7 +119,7 @@ class PushoverNotifier: if sickbeard.PUSHOVER_NOTIFY_ONSUBTITLEDOWNLOAD: self._notifyPushover(title, ep_name + ": " + lang) - def _notifyPushover(self, title, message, userKey=None, force=False): + def _notifyPushover(self, title, message, userKey=None, apiKey=None, force=False): """ Sends a pushover notification based on the provided info or SB config @@ -130,8 +135,8 @@ class PushoverNotifier: logger.log("Sending notification for " + message, logger.DEBUG) - # self._sendPushover(message, title, userKey) - return self._sendPushover(message, title) + # self._sendPushover(message, title, userKey, apiKey) + return self._sendPushover(message, title, userKey, apiKey) notifier = PushoverNotifier diff --git a/sickbeard/webserve.py b/sickbeard/webserve.py index 626ee5f0..b574bdca 100644 --- a/sickbeard/webserve.py +++ b/sickbeard/webserve.py @@ -2123,7 +2123,7 @@ class ConfigNotifications(IndexHandler): use_boxcar2=None, boxcar2_notify_onsnatch=None, boxcar2_notify_ondownload=None, boxcar2_notify_onsubtitledownload=None, boxcar2_accesstoken=None, use_pushover=None, pushover_notify_onsnatch=None, pushover_notify_ondownload=None, - pushover_notify_onsubtitledownload=None, pushover_userkey=None, + pushover_notify_onsubtitledownload=None, pushover_userkey=None, pushover_apikey=None, use_libnotify=None, libnotify_notify_onsnatch=None, libnotify_notify_ondownload=None, libnotify_notify_onsubtitledownload=None, use_nmj=None, nmj_host=None, nmj_database=None, nmj_mount=None, use_synoindex=None, @@ -2208,6 +2208,7 @@ class ConfigNotifications(IndexHandler): sickbeard.PUSHOVER_NOTIFY_ONDOWNLOAD = config.checkbox_to_value(pushover_notify_ondownload) sickbeard.PUSHOVER_NOTIFY_ONSUBTITLEDOWNLOAD = config.checkbox_to_value(pushover_notify_onsubtitledownload) sickbeard.PUSHOVER_USERKEY = pushover_userkey + sickbeard.PUSHOVER_APIKEY = pushover_apikey sickbeard.USE_LIBNOTIFY = config.checkbox_to_value(use_libnotify) sickbeard.LIBNOTIFY_NOTIFY_ONSNATCH = config.checkbox_to_value(libnotify_notify_onsnatch) @@ -3058,10 +3059,10 @@ class Home(IndexHandler): return "Error sending Boxcar2 notification" - def testPushover(self, userKey=None): + def testPushover(self, userKey=None, apiKey=None): self.set_header('Cache-Control', "max-age=0,no-cache,no-store") - result = notifiers.pushover_notifier.test_notify(userKey) + result = notifiers.pushover_notifier.test_notify(userKey, apiKey) if result: return "Pushover notification succeeded. Check your Pushover clients to make sure it worked" else: From 3f78f88c78e9831241d0361a79761c5353ddc42a Mon Sep 17 00:00:00 2001 From: Mark Rawson Date: Wed, 18 Jun 2014 21:50:48 +0100 Subject: [PATCH 2/4] Add logging for pushover message limit error (429) --- sickbeard/notifiers/pushover.py | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/sickbeard/notifiers/pushover.py b/sickbeard/notifiers/pushover.py index c9ea69f2..f2302975 100644 --- a/sickbeard/notifiers/pushover.py +++ b/sickbeard/notifiers/pushover.py @@ -103,6 +103,11 @@ class PushoverNotifier: logger.log("Wrong data sent to pushover", logger.ERROR) return False + # If you receive a HTTP status code of 429, it is because the message limit has been reached (free limit is 7,500) + elif e.code == 429: + logger.log("Pushover API message limit reached - try a different API key", logger.ERROR) + return False + logger.log("Pushover notification successful.", logger.MESSAGE) return True From abb7c78dac165a4b4c2eb9ae4a5183ec63cd91f6 Mon Sep 17 00:00:00 2001 From: Mark Rawson Date: Thu, 19 Jun 2014 00:11:20 +0100 Subject: [PATCH 3/4] Pushover - remove hard-coded API key, add API register link to UI. --- gui/slick/interfaces/default/config_notifications.tmpl | 2 +- sickbeard/notifiers/pushover.py | 3 +-- 2 files changed, 2 insertions(+), 3 deletions(-) diff --git a/gui/slick/interfaces/default/config_notifications.tmpl b/gui/slick/interfaces/default/config_notifications.tmpl index 891caf60..e5d52633 100644 --- a/gui/slick/interfaces/default/config_notifications.tmpl +++ b/gui/slick/interfaces/default/config_notifications.tmpl @@ -752,7 +752,7 @@
Click below to test.
diff --git a/sickbeard/notifiers/pushover.py b/sickbeard/notifiers/pushover.py index f2302975..3c51ada7 100644 --- a/sickbeard/notifiers/pushover.py +++ b/sickbeard/notifiers/pushover.py @@ -28,12 +28,11 @@ from sickbeard.common import notifyStrings, NOTIFY_SNATCH, NOTIFY_DOWNLOAD, NOTI from sickbeard.exceptions import ex API_URL = "https://api.pushover.net/1/messages.json" -API_KEY = "awKfdt263PLaEWV9RXuSn4c46qoAyA" class PushoverNotifier: def test_notify(self, userKey=None, apiKey=None): - return self._notifyPushover("This is a test notification from SickRage", 'Test', userKey, force=True) + return self._notifyPushover("This is a test notification from SickRage", 'Test', userKey, apiKey, force=True) def _sendPushover(self, msg, title, userKey=None, apiKey=None): """ From e50ce507e50126086aa229ef762efa1fcf52e838 Mon Sep 17 00:00:00 2001 From: Mark Rawson Date: Thu, 19 Jun 2014 00:13:16 +0100 Subject: [PATCH 4/4] Bugfix - fix issue with Pushover test notifications, false-positive if api/user keys removed in UI but not yet saved --- sickbeard/notifiers/pushover.py | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/sickbeard/notifiers/pushover.py b/sickbeard/notifiers/pushover.py index 3c51ada7..3024f243 100644 --- a/sickbeard/notifiers/pushover.py +++ b/sickbeard/notifiers/pushover.py @@ -45,11 +45,11 @@ class PushoverNotifier: returns: True if the message succeeded, False otherwise """ - if not userKey: + if userKey == None: userKey = sickbeard.PUSHOVER_USERKEY - if not apiKey: - apiKey = sickbeard.PUSHOVER_APIKEY or API_KEY + if apiKey == None: + apiKey = sickbeard.PUSHOVER_APIKEY logger.log("Pushover API KEY in use: " + apiKey, logger.DEBUG)