2
from flexget.plugin import register_plugin, get_plugin_by_name, PluginError
3
from flexget.utils.log import log_once
5
log = logging.getLogger('imdb')
8
class FilterImdb(object):
10
This plugin allows filtering based on IMDB score, votes and genres etc.
14
Note: All parameters are optional. Some are mutually exclusive.
21
# reject if genre contains any of these
26
# reject if language contain any of these
30
# accept only this language
34
# accept movies with any of these actors
39
# reject movie if it has any of these actors
44
# accept all movies by these directors
48
# reject movies by these directors
52
# reject movies/TV shows with any of these ratings
58
# accept movies/TV shows with only these ratings
66
"""Validate given configuration"""
67
from flexget import validator
68
imdb = validator.factory('dict')
69
imdb.accept('integer', key='min_year')
70
imdb.accept('integer', key='max_year')
71
imdb.accept('integer', key='min_votes')
72
imdb.accept('number', key='min_score')
73
imdb.accept('list', key='reject_genres').accept('text')
74
imdb.accept('list', key='reject_languages').accept('text')
75
imdb.accept('list', key='accept_languages').accept('text')
76
imdb.accept('list', key='reject_actors').accept('text')
77
imdb.accept('list', key='accept_actors').accept('text')
78
imdb.accept('list', key='reject_directors').accept('text')
79
imdb.accept('list', key='accept_directors').accept('text')
80
imdb.accept('list', key='reject_mpaa_ratings').accept('text')
81
imdb.accept('list', key='accept_mpaa_ratings').accept('text')
84
def on_feed_filter(self, feed):
85
config = feed.config['imdb']
87
lookup = get_plugin_by_name('imdb_lookup').instance.lookup
89
for entry in feed.entries:
94
except PluginError, e:
95
# logs skip message once trough log_once (info) and then only when ran from cmd line (w/o --cron)
96
msg = 'Skipping %s because of an error: %s' % (entry['title'], e.value)
97
if not log_once(msg, logger=log):
98
feed.verbose_progress(msg, log)
100
if entry["imdb_mpaa_rating"] == '':
101
entry["imdb_mpaa_rating"] = "NONE"
102
# Check defined conditions, TODO: rewrite into functions?
104
if 'min_score' in config:
105
if entry['imdb_score'] < config['min_score']:
106
reasons.append('min_score (%s < %s)' % (entry['imdb_score'], config['min_score']))
107
if 'min_votes' in config:
108
if entry['imdb_votes'] < config['min_votes']:
109
reasons.append('min_votes (%s < %s)' % (entry['imdb_votes'], config['min_votes']))
110
if 'min_year' in config:
111
if entry['imdb_year'] < config['min_year']:
112
reasons.append('min_year (%s < %s)' % (entry['imdb_year'], config['min_year']))
113
if 'max_year' in config:
114
if entry['imdb_year'] == 0 or entry['imdb_year'] > config['max_year']:
115
reasons.append('max_year (%s > %s)' % (entry['imdb_year'], config['max_year']))
116
if 'reject_genres' in config:
117
rejected = config['reject_genres']
118
for genre in entry['imdb_genres']:
119
if genre in rejected:
120
reasons.append('reject_genres')
123
if 'reject_languages' in config:
124
rejected = config['reject_languages']
125
for language in entry['imdb_languages']:
126
if language in rejected:
127
reasons.append('reject_languages')
130
if 'accept_languages' in config:
131
accepted = config['accept_languages']
132
for language in entry['imdb_languages']:
133
if language not in accepted:
134
reasons.append('accept_languages')
137
if 'reject_actors' in config:
138
rejected = config['reject_actors']
139
for actor_id, actor_name in entry['imdb_actors'].iteritems():
140
if actor_id in rejected or actor_name in rejected:
141
reasons.append('reject_actors %s' % actor_name or actor_id)
144
# Accept if actors contains an accepted actor, but don't reject otherwise
145
if 'accept_actors' in config:
146
accepted = config['accept_actors']
147
for actor_id, actor_name in entry['imdb_actors'].iteritems():
148
if actor_id in accepted or actor_name in accepted:
149
log.debug("Accepting because of accept_actors %s" % actor_name or actor_id)
153
if 'reject_directors' in config:
154
rejected = config['reject_directors']
155
for director_id, director_name in entry['imdb_directors'].iteritems():
156
if director_id in rejected or director_name in rejected:
157
reasons.append('reject_directors %s' % director_name or director_id)
160
# Accept if the director is in the accept list, but do not reject if the director is unknown
161
if 'accept_directors' in config:
162
accepted = config['accept_directors']
163
for director_id, director_name in entry['imdb_directors'].iteritems():
164
if director_id in accepted or director_name in accepted:
165
log.debug("Accepting because of accept_directors %s" % director_name or director_id)
169
if 'reject_mpaa_ratings' in config:
170
rejected = config['reject_mpaa_ratings']
171
if entry["imdb_mpaa_rating"] in rejected:
172
reasons.append('reject_mpaa_ratings %s' % entry["imdb_mpaa_rating"])
174
if 'accept_mpaa_ratings' in config:
175
accepted = config['accept_mpaa_ratings']
176
if entry["imdb_mpaa_rating"] not in accepted:
177
reasons.append("accept_mpaa_ratings %s" % entry["imdb_mpaa_rating"])
179
if reasons and not force_accept:
180
msg = 'Skipping %s because of rule(s) %s' % \
181
(entry.get('imdb_name', None) or entry['title'], ', '.join(reasons))
182
if feed.manager.options.debug:
185
if feed.manager.options.quiet:
190
log.debug('Accepting %s' % (entry['title']))
193
register_plugin(FilterImdb, 'imdb')