2014-03-10 01:18:05 -04:00
|
|
|
# Author: Marvin Pinto <me@marvinp.ca>
|
|
|
|
# Author: Dennis Lutter <lad1337@gmail.com>
|
|
|
|
# URL: http://code.google.com/p/sickbeard/
|
|
|
|
#
|
2014-05-23 08:37:22 -04:00
|
|
|
# This file is part of SickRage.
|
2014-03-10 01:18:05 -04:00
|
|
|
#
|
2014-05-23 08:37:22 -04:00
|
|
|
# SickRage is free software: you can redistribute it and/or modify
|
2014-03-10 01:18:05 -04:00
|
|
|
# it under the terms of the GNU General Public License as published by
|
|
|
|
# the Free Software Foundation, either version 3 of the License, or
|
|
|
|
# (at your option) any later version.
|
|
|
|
#
|
2014-05-23 08:37:22 -04:00
|
|
|
# SickRage is distributed in the hope that it will be useful,
|
2014-03-10 01:18:05 -04:00
|
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
# GNU General Public License for more details.
|
|
|
|
#
|
|
|
|
# You should have received a copy of the GNU General Public License
|
2014-05-23 08:37:22 -04:00
|
|
|
# along with SickRage. If not, see <http://www.gnu.org/licenses/>.
|
2014-03-10 01:18:05 -04:00
|
|
|
|
|
|
|
import urllib, urllib2
|
|
|
|
import time
|
|
|
|
|
|
|
|
import sickbeard
|
|
|
|
|
|
|
|
from sickbeard import logger
|
2014-07-03 17:04:26 -04:00
|
|
|
from sickbeard.common import notifyStrings, NOTIFY_SNATCH, NOTIFY_DOWNLOAD, NOTIFY_SUBTITLE_DOWNLOAD, NOTIFY_GIT_UPDATE, NOTIFY_GIT_UPDATE_TEXT
|
2014-03-10 01:18:05 -04:00
|
|
|
from sickbeard.exceptions import ex
|
|
|
|
|
|
|
|
API_URL = "https://boxcar.io/devices/providers/fWc4sgSmpcN6JujtBmR6/notifications"
|
|
|
|
|
|
|
|
|
2014-03-25 01:57:24 -04:00
|
|
|
class BoxcarNotifier:
|
2014-05-28 20:30:38 -04:00
|
|
|
def test_notify(self, boxcar_username):
|
|
|
|
return self._notify("This is a test notification from Sick Beard", "Test", boxcar_username, force=True)
|
2014-03-10 01:18:05 -04:00
|
|
|
|
|
|
|
def _sendBoxcar(self, msg, title, email, subscribe=False):
|
|
|
|
"""
|
|
|
|
Sends a boxcar notification to the address provided
|
|
|
|
|
|
|
|
msg: The message to send (unicode)
|
|
|
|
title: The title of the message
|
|
|
|
email: The email address to send the message to (or to subscribe with)
|
|
|
|
subscribe: If true then instead of sending a message this function will send a subscription notification (optional, default is False)
|
|
|
|
|
|
|
|
returns: True if the message succeeded, False otherwise
|
|
|
|
"""
|
2014-03-25 01:57:24 -04:00
|
|
|
|
2014-03-10 01:18:05 -04:00
|
|
|
# build up the URL and parameters
|
|
|
|
msg = msg.strip()
|
|
|
|
curUrl = API_URL
|
|
|
|
|
|
|
|
# if this is a subscription notification then act accordingly
|
|
|
|
if subscribe:
|
|
|
|
data = urllib.urlencode({'email': email})
|
2014-03-20 14:03:22 -04:00
|
|
|
curUrl = curUrl + "/subscribe"
|
2014-03-25 01:57:24 -04:00
|
|
|
|
2014-03-10 01:18:05 -04:00
|
|
|
# for normal requests we need all these parameters
|
|
|
|
else:
|
|
|
|
data = urllib.urlencode({
|
|
|
|
'email': email,
|
|
|
|
'notification[from_screen_name]': title,
|
|
|
|
'notification[message]': msg.encode('utf-8'),
|
|
|
|
'notification[from_remote_service_id]': int(time.time())
|
2014-03-25 01:57:24 -04:00
|
|
|
})
|
2014-03-10 01:18:05 -04:00
|
|
|
|
|
|
|
|
|
|
|
# send the request to boxcar
|
|
|
|
try:
|
|
|
|
req = urllib2.Request(curUrl)
|
|
|
|
handle = urllib2.urlopen(req, data)
|
|
|
|
handle.close()
|
2014-03-25 01:57:24 -04:00
|
|
|
|
2014-05-26 02:29:22 -04:00
|
|
|
except urllib2.HTTPError, e:
|
2014-03-10 01:18:05 -04:00
|
|
|
# if we get an error back that doesn't have an error code then who knows what's really happening
|
|
|
|
if not hasattr(e, 'code'):
|
2014-05-28 20:30:38 -04:00
|
|
|
logger.log("Boxcar notification failed. Error code: " + ex(e), logger.ERROR)
|
2014-03-10 01:18:05 -04:00
|
|
|
return False
|
|
|
|
else:
|
|
|
|
logger.log("Boxcar notification failed. Error code: " + str(e.code), logger.WARNING)
|
|
|
|
|
|
|
|
# HTTP status 404 if the provided email address isn't a Boxcar user.
|
|
|
|
if e.code == 404:
|
|
|
|
logger.log("Username is wrong/not a boxcar email. Boxcar will send an email to it", logger.WARNING)
|
|
|
|
return False
|
2014-03-25 01:57:24 -04:00
|
|
|
|
2014-03-10 01:18:05 -04:00
|
|
|
# For HTTP status code 401's, it is because you are passing in either an invalid token, or the user has not added your service.
|
|
|
|
elif e.code == 401:
|
2014-03-25 01:57:24 -04:00
|
|
|
|
2014-03-10 01:18:05 -04:00
|
|
|
# If the user has already added your service, we'll return an HTTP status code of 401.
|
|
|
|
if subscribe:
|
|
|
|
logger.log("Already subscribed to service", logger.ERROR)
|
|
|
|
# i dont know if this is true or false ... its neither but i also dont know how we got here in the first place
|
|
|
|
return False
|
2014-03-25 01:57:24 -04:00
|
|
|
|
2014-03-10 01:18:05 -04:00
|
|
|
#HTTP status 401 if the user doesn't have the service added
|
|
|
|
else:
|
|
|
|
subscribeNote = self._sendBoxcar(msg, title, email, True)
|
|
|
|
if subscribeNote:
|
|
|
|
logger.log("Subscription send", logger.DEBUG)
|
|
|
|
return True
|
|
|
|
else:
|
|
|
|
logger.log("Subscription could not be send", logger.ERROR)
|
|
|
|
return False
|
2014-03-25 01:57:24 -04:00
|
|
|
|
2014-03-10 01:18:05 -04:00
|
|
|
# If you receive an HTTP status code of 400, it is because you failed to send the proper parameters
|
|
|
|
elif e.code == 400:
|
2014-05-28 20:30:38 -04:00
|
|
|
logger.log("Wrong data sent to boxcar", logger.ERROR)
|
2014-03-10 01:18:05 -04:00
|
|
|
return False
|
|
|
|
|
2014-05-28 20:30:38 -04:00
|
|
|
logger.log("Boxcar notification successful.", logger.MESSAGE)
|
2014-03-10 01:18:05 -04:00
|
|
|
return True
|
|
|
|
|
|
|
|
def notify_snatch(self, ep_name, title=notifyStrings[NOTIFY_SNATCH]):
|
|
|
|
if sickbeard.BOXCAR_NOTIFY_ONSNATCH:
|
|
|
|
self._notifyBoxcar(title, ep_name)
|
2014-03-25 01:57:24 -04:00
|
|
|
|
2014-03-10 01:18:05 -04:00
|
|
|
|
|
|
|
def notify_download(self, ep_name, title=notifyStrings[NOTIFY_DOWNLOAD]):
|
|
|
|
if sickbeard.BOXCAR_NOTIFY_ONDOWNLOAD:
|
|
|
|
self._notifyBoxcar(title, ep_name)
|
|
|
|
|
|
|
|
def notify_subtitle_download(self, ep_name, lang, title=notifyStrings[NOTIFY_SUBTITLE_DOWNLOAD]):
|
|
|
|
if sickbeard.BOXCAR_NOTIFY_ONSUBTITLEDOWNLOAD:
|
|
|
|
self._notifyBoxcar(title, ep_name + ": " + lang)
|
2014-07-03 02:43:48 -04:00
|
|
|
|
2014-07-03 17:04:26 -04:00
|
|
|
def notify_git_update(self, new_version = "??"):
|
2014-07-03 02:43:48 -04:00
|
|
|
if sickbeard.USE_BOXCAR:
|
2014-07-03 17:04:26 -04:00
|
|
|
update_text=notifyStrings[NOTIFY_GIT_UPDATE_TEXT]
|
|
|
|
title=notifyStrings[NOTIFY_GIT_UPDATE]
|
2014-07-03 02:43:48 -04:00
|
|
|
self._notifyBoxcar(title, update_text + new_version)
|
2014-03-10 01:18:05 -04:00
|
|
|
|
|
|
|
def _notifyBoxcar(self, title, message, username=None, force=False):
|
|
|
|
"""
|
|
|
|
Sends a boxcar notification based on the provided info or SB config
|
|
|
|
|
|
|
|
title: The title of the notification to send
|
|
|
|
message: The message string to send
|
|
|
|
username: The username to send the notification to (optional, defaults to the username in the config)
|
|
|
|
force: If True then the notification will be sent even if Boxcar is disabled in the config
|
|
|
|
"""
|
|
|
|
|
|
|
|
if not sickbeard.USE_BOXCAR and not force:
|
|
|
|
logger.log("Notification for Boxcar not enabled, skipping this notification", logger.DEBUG)
|
|
|
|
return False
|
|
|
|
|
|
|
|
# if no username was given then use the one from the config
|
|
|
|
if not username:
|
|
|
|
username = sickbeard.BOXCAR_USERNAME
|
|
|
|
|
|
|
|
logger.log("Sending notification for " + message, logger.DEBUG)
|
|
|
|
|
2014-05-28 20:30:38 -04:00
|
|
|
return self._sendBoxcar(message, title, username)
|
2014-03-10 01:18:05 -04:00
|
|
|
|
2014-03-25 01:57:24 -04:00
|
|
|
|
2014-03-10 01:18:05 -04:00
|
|
|
notifier = BoxcarNotifier
|