mirror of
https://github.com/SickGear/SickGear.git
synced 2024-11-24 13:55:16 +00:00
32987134ba
Cleanup most init warnings. Cleanup some vars, pythonic instead of js. Some typos and python var/func names for Scheduler. Remove legacy handlers deprecated in 2020. Remove some legacy tagged stuff. Cleanup ConfigParser and 23.py Change cleanup vendored scandir. Remove redundant pkg_resources.py in favour of the vendor folder. Remove backports. Remove trakt checker. Change remove redundant WindowsSelectorEventLoopPolicy from webserveInit. Cleanup varnames and providers Various minor tidy ups to remove ide warnings.
223 lines
8.7 KiB
Python
223 lines
8.7 KiB
Python
#
|
|
# This file is part of SickGear.
|
|
#
|
|
# SickGear is free software: you can redistribute it and/or modify
|
|
# 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.
|
|
#
|
|
# SickGear is distributed in the hope that it will be useful,
|
|
# 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
|
|
# along with SickGear. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
from __future__ import with_statement
|
|
|
|
import traceback
|
|
|
|
# noinspection PyPep8Naming
|
|
from exceptions_helper import ex
|
|
|
|
from . import db, generic_queue, logger, helpers, ui
|
|
|
|
# noinspection PyUnreachableCode
|
|
if False:
|
|
from six import integer_types
|
|
from typing import AnyStr, Dict, List, Optional
|
|
from .tv import TVShow
|
|
from lib.tvinfo_base import CastList
|
|
|
|
|
|
class PeopleQueue(generic_queue.GenericQueue):
|
|
def __init__(self):
|
|
generic_queue.GenericQueue.__init__(self, cache_db_tables=['people_queue'])
|
|
self.queue_name = 'PEOPLEQUEUE' # type: AnyStr
|
|
|
|
def load_queue(self):
|
|
try:
|
|
my_db = db.DBConnection('cache.db')
|
|
queue_sql = my_db.select('SELECT * FROM people_queue')
|
|
for q in queue_sql:
|
|
if PeopleQueueActions.SHOWCAST == q['action_id']:
|
|
try:
|
|
show_obj = helpers.find_show_by_id({q['indexer']: q['indexer_id']})
|
|
except (BaseException, Exception):
|
|
continue
|
|
if not show_obj:
|
|
continue
|
|
self.add_cast_update(show_obj=show_obj, show_info_cast=None, uid=q['uid'], force=bool(q['forced']),
|
|
scheduled_update=bool(q['scheduled']), add_to_db=False)
|
|
except (BaseException, Exception) as e:
|
|
logger.error('Exception loading queue %s: %s' % (self.__class__.__name__, ex(e)))
|
|
try:
|
|
my_db = db.DBConnection()
|
|
if not my_db.has_flag('cast_loaded'):
|
|
import sickgear
|
|
[self.add_cast_update(s, show_info_cast=None, scheduled_update=True)
|
|
for s in sickgear.showList if not s.cast_list]
|
|
my_db.set_flag('cast_loaded')
|
|
except (BaseException, Exception):
|
|
pass
|
|
|
|
def _clear_sql(self):
|
|
return [
|
|
['DELETE FROM people_queue']
|
|
]
|
|
|
|
def _get_item_sql(self, item):
|
|
# type: (PeopleQueueItem) -> List[List]
|
|
return [
|
|
['INSERT OR IGNORE INTO people_queue (indexer, indexer_id, action_id, forced, scheduled, uid)'
|
|
' VALUES (?,?,?,?,?,?)',
|
|
[item.show_obj.tvid, item.show_obj.prodid, item.action_id, int(item.force), int(item.scheduled_update),
|
|
item.uid]]
|
|
]
|
|
|
|
def _delete_item_from_db_sql(self, item):
|
|
# type: (PeopleQueueItem) -> List[List]
|
|
return [
|
|
['DELETE FROM people_queue WHERE uid = ?', [item.uid]]
|
|
]
|
|
|
|
def queue_data(self):
|
|
# type: (...) -> Dict[AnyStr, List[AnyStr, Dict]]
|
|
data = {'main_cast': []}
|
|
with self.lock:
|
|
for cur_item in [self.currentItem] + self.queue: # type: PeopleQueueItem
|
|
if not cur_item or not cur_item.show_obj:
|
|
continue
|
|
result_item = {'name': cur_item.show_obj.name, 'tvid_prodid': cur_item.show_obj.tvid_prodid,
|
|
'uid': cur_item.uid, 'forced': cur_item.force}
|
|
if isinstance(cur_item, CastQueueItem):
|
|
data['main_cast'].append(result_item)
|
|
return data
|
|
|
|
def show_in_queue(self, show_obj, check_inprogress=False):
|
|
# type: (TVShow, Optional[bool]) -> bool
|
|
with self.lock:
|
|
return any(1 for q in ((self.currentItem and [self.currentItem]) or []) + self.queue
|
|
if show_obj == q.show_obj and (True, q.inProgress)[check_inprogress])
|
|
|
|
def abort_cast_update(self, show_obj):
|
|
# type: (TVShow) -> None
|
|
if show_obj:
|
|
with self.lock:
|
|
to_remove = []
|
|
for c in ((self.currentItem and [self.currentItem]) or []) + self.queue:
|
|
if show_obj == c.show_obj:
|
|
try:
|
|
to_remove.append(c.uid)
|
|
except (BaseException, Exception):
|
|
pass
|
|
try:
|
|
c.stop.set()
|
|
except (BaseException, Exception):
|
|
pass
|
|
|
|
if to_remove:
|
|
try:
|
|
self.remove_from_queue(to_remove)
|
|
except (BaseException, Exception):
|
|
pass
|
|
|
|
def add_cast_update(self, show_obj, show_info_cast, uid=None, add_to_db=True, force=False, scheduled_update=False,
|
|
switch=False):
|
|
# type: (TVShow, Optional[CastList], AnyStr, bool, bool, bool, bool) -> CastQueueItem
|
|
"""
|
|
|
|
:param show_obj: TV Show object
|
|
:param show_info_cast: TV Info object
|
|
:param uid: unique id
|
|
:param add_to_db: add to queue db table
|
|
:param force:
|
|
:param scheduled_update: suppresses ui notifications
|
|
:param switch: part of id switch
|
|
"""
|
|
with self.lock:
|
|
if not self.show_in_queue(show_obj):
|
|
cast_item = CastQueueItem(show_obj=show_obj, show_info_cast=show_info_cast, uid=uid, force=force,
|
|
scheduled_update=scheduled_update, switch=switch)
|
|
self.add_item(cast_item, add_to_db=add_to_db)
|
|
return cast_item
|
|
|
|
|
|
class PeopleQueueActions(object):
|
|
SHOWCAST = 1
|
|
|
|
names = {
|
|
SHOWCAST: 'Show Cast',
|
|
}
|
|
|
|
|
|
class PeopleQueueItem(generic_queue.QueueItem):
|
|
def __init__(self, action_id, show_obj, uid=None, force=False, **kwargs):
|
|
# type: (integer_types, TVShow, AnyStr, bool, Dict) -> None
|
|
"""
|
|
|
|
:param action_id:
|
|
:param show_obj: show object
|
|
"""
|
|
generic_queue.QueueItem.__init__(self, PeopleQueueActions.names[action_id], action_id, uid=uid)
|
|
self.show_obj = show_obj # type: TVShow
|
|
self.force = force # type: bool
|
|
|
|
def finish(self):
|
|
self.show_obj = None
|
|
super(PeopleQueueItem, self).finish()
|
|
|
|
|
|
class CastQueueItem(PeopleQueueItem):
|
|
def __init__(self, show_obj, show_info_cast=None, uid=None, force=False, scheduled_update=False, switch=False,
|
|
**kwargs):
|
|
# type: (TVShow, CastList, AnyStr, bool, bool, bool, Dict) -> None
|
|
"""
|
|
|
|
:param show_obj: show obj
|
|
:param show_info_cast: show info cast list
|
|
:param scheduled_update: suppresses ui notifications
|
|
:param switch: part of id switch
|
|
"""
|
|
PeopleQueueItem.__init__(self, PeopleQueueActions.SHOWCAST, show_obj, uid=uid, force=force, **kwargs)
|
|
self.show_info_cast = show_info_cast # type: Optional[CastList]
|
|
self.scheduled_update = scheduled_update # type: bool
|
|
self.switch = switch # type: bool
|
|
|
|
def run(self):
|
|
|
|
PeopleQueueItem.run(self)
|
|
|
|
if self.show_obj:
|
|
logger.log('Starting cast update for show %s' % self.show_obj.unique_name)
|
|
old_cast = self.show_obj.cast_list_id()
|
|
if not self.scheduled_update and not self.switch:
|
|
ui.notifications.message('Starting cast update for show %s' % self.show_obj.unique_name)
|
|
try:
|
|
self.show_obj.load_cast_from_tvinfo(self.show_info_cast, force=self.force, stop_event=self.stop)
|
|
update_success = True
|
|
except (BaseException, Exception) as e:
|
|
update_success = False
|
|
logger.error('Exception in cast update queue: %s' % ex(e))
|
|
logger.debug('Traceback: %s' % traceback.format_exc())
|
|
|
|
if update_success and (old_cast != self.show_obj.cast_list_id()):
|
|
logger.debug('Update show nfo with new cast data')
|
|
self.show_obj.write_show_nfo(force=True)
|
|
|
|
logger.log('Finished cast update for show %s' % self.show_obj.unique_name)
|
|
if not self.scheduled_update and not self.switch:
|
|
ui.notifications.message('Finished cast update for show %s' % self.show_obj.unique_name)
|
|
|
|
self.finish()
|
|
|
|
def finish(self):
|
|
self.show_info_cast = None
|
|
super(CastQueueItem, self).finish()
|
|
|
|
def __str__(self):
|
|
return '<Cast Queue Item (%s)%s>' % (self.show_obj.unique_name, ('', ' - forced')[self.force])
|
|
|
|
def __repr__(self):
|
|
return self.__str__()
|