2014-03-10 01:18:05 -04:00
|
|
|
# Author: Dieter Blomme <dieterblomme@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 sickbeard
|
|
|
|
from sickbeard import logger
|
2014-12-06 01:51:24 -05:00
|
|
|
from sickbeard.exceptions import ex
|
2014-11-28 17:07:26 -05:00
|
|
|
from lib.trakt import TraktAPI
|
|
|
|
from lib.trakt.exceptions import traktException, traktServerBusy, traktAuthException
|
|
|
|
|
2014-03-10 01:18:05 -04:00
|
|
|
class TraktNotifier:
|
|
|
|
"""
|
|
|
|
A "notifier" for trakt.tv which keeps track of what has and hasn't been added to your library.
|
|
|
|
"""
|
|
|
|
|
|
|
|
def notify_snatch(self, ep_name):
|
|
|
|
pass
|
|
|
|
|
|
|
|
def notify_download(self, ep_name):
|
|
|
|
pass
|
2014-03-25 01:57:24 -04:00
|
|
|
|
2014-03-10 01:18:05 -04:00
|
|
|
def notify_subtitle_download(self, ep_name, lang):
|
|
|
|
pass
|
2014-11-24 05:59:39 -05:00
|
|
|
|
2014-07-03 17:04:26 -04:00
|
|
|
def notify_git_update(self, new_version):
|
2014-07-03 02:43:48 -04:00
|
|
|
pass
|
2014-03-10 01:18:05 -04:00
|
|
|
|
|
|
|
def update_library(self, ep_obj):
|
|
|
|
"""
|
|
|
|
Sends a request to trakt indicating that the given episode is part of our library.
|
|
|
|
|
|
|
|
ep_obj: The TVEpisode object to add to trakt
|
|
|
|
"""
|
2014-03-25 01:57:24 -04:00
|
|
|
|
2014-11-24 05:59:39 -05:00
|
|
|
trakt_id = sickbeard.indexerApi(ep_obj.show.indexer).config['trakt_id']
|
2014-11-29 06:09:49 -05:00
|
|
|
trakt_api = TraktAPI(sickbeard.TRAKT_API, sickbeard.TRAKT_USERNAME, sickbeard.TRAKT_PASSWORD)
|
2014-03-25 01:57:24 -04:00
|
|
|
|
2014-11-24 05:59:39 -05:00
|
|
|
if sickbeard.USE_TRAKT:
|
2014-11-28 17:07:26 -05:00
|
|
|
try:
|
|
|
|
# URL parameters
|
2014-11-24 05:59:39 -05:00
|
|
|
data = {
|
2014-11-28 17:07:26 -05:00
|
|
|
'title': ep_obj.show.name,
|
|
|
|
'year': ep_obj.show.startyear,
|
|
|
|
'episodes': [{
|
|
|
|
'season': ep_obj.season,
|
|
|
|
'episode': ep_obj.episode
|
|
|
|
}]
|
2014-11-24 05:59:39 -05:00
|
|
|
}
|
2014-08-18 19:53:10 -04:00
|
|
|
|
2014-11-24 05:59:39 -05:00
|
|
|
if trakt_id == 'tvdb_id':
|
2014-11-28 17:07:26 -05:00
|
|
|
data[trakt_id] = ep_obj.show.indexerid
|
|
|
|
|
|
|
|
# update library
|
|
|
|
trakt_api.traktRequest("show/episode/library/%APIKEY%", data)
|
|
|
|
|
|
|
|
# remove from watchlist
|
|
|
|
if sickbeard.TRAKT_REMOVE_WATCHLIST:
|
|
|
|
trakt_api.traktRequest("show/episode/unwatchlist/%APIKEY%", data)
|
|
|
|
|
|
|
|
if sickbeard.TRAKT_REMOVE_SERIESLIST:
|
|
|
|
data = {
|
|
|
|
'shows': [
|
|
|
|
{
|
|
|
|
'title': ep_obj.show.name,
|
|
|
|
'year': ep_obj.show.startyear
|
2014-11-24 05:59:39 -05:00
|
|
|
}
|
2014-11-28 17:07:26 -05:00
|
|
|
]
|
|
|
|
}
|
|
|
|
|
|
|
|
if trakt_id == 'tvdb_id':
|
2014-11-29 05:24:30 -05:00
|
|
|
data['shows'][0][trakt_id] = ep_obj.show.indexerid
|
2014-11-28 17:07:26 -05:00
|
|
|
|
|
|
|
trakt_api.traktRequest("show/unwatchlist/%APIKEY%", data)
|
|
|
|
|
|
|
|
# Remove all episodes from episode watchlist
|
|
|
|
# Start by getting all episodes in the watchlist
|
|
|
|
watchlist = trakt_api.traktRequest("user/watchlist/episodes.json/%APIKEY%/%USER%")
|
2014-11-24 05:59:39 -05:00
|
|
|
|
2014-11-28 17:07:26 -05:00
|
|
|
# Convert watchlist to only contain current show
|
|
|
|
if watchlist:
|
|
|
|
for show in watchlist:
|
|
|
|
if show[trakt_id] == ep_obj.show.indexerid:
|
|
|
|
data_show = {
|
|
|
|
'title': show['title'],
|
|
|
|
trakt_id: show[trakt_id],
|
|
|
|
'episodes': []
|
|
|
|
}
|
2014-11-24 05:59:39 -05:00
|
|
|
|
2014-11-28 17:07:26 -05:00
|
|
|
# Add series and episode (number) to the array
|
|
|
|
for episodes in show['episodes']:
|
|
|
|
ep = {'season': episodes['season'], 'episode': episodes['number']}
|
|
|
|
data_show['episodes'].append(ep)
|
|
|
|
|
|
|
|
trakt_api.traktRequest("show/episode/unwatchlist/%APIKEY%", data_show)
|
|
|
|
except (traktException, traktAuthException, traktServerBusy) as e:
|
2014-12-06 01:51:24 -05:00
|
|
|
logger.log(u"Could not connect to Trakt service: %s" % ex(e), logger.WARNING)
|
2014-08-18 19:53:10 -04:00
|
|
|
|
2014-03-10 01:18:05 -04:00
|
|
|
def test_notify(self, api, username, password):
|
|
|
|
"""
|
|
|
|
Sends a test notification to trakt with the given authentication info and returns a boolean
|
|
|
|
representing success.
|
|
|
|
|
|
|
|
api: The api string to use
|
|
|
|
username: The username to use
|
|
|
|
password: The password to use
|
|
|
|
|
|
|
|
Returns: True if the request succeeded, False otherwise
|
|
|
|
"""
|
2014-03-25 01:57:24 -04:00
|
|
|
|
2014-11-29 06:09:49 -05:00
|
|
|
trakt_api = TraktAPI(sickbeard.TRAKT_API, sickbeard.TRAKT_USERNAME, sickbeard.TRAKT_PASSWORD)
|
2014-11-28 17:13:06 -05:00
|
|
|
|
2014-11-28 17:07:26 -05:00
|
|
|
try:
|
|
|
|
if trakt_api.validateAccount():
|
|
|
|
return True
|
|
|
|
except (traktException, traktAuthException, traktServerBusy) as e:
|
2014-12-06 01:51:24 -05:00
|
|
|
logger.log(u"Could not connect to Trakt service: %s" % ex(e), logger.WARNING)
|
2014-03-10 01:18:05 -04:00
|
|
|
|
|
|
|
notifier = TraktNotifier
|