-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathhummingbird_movies.py
66 lines (54 loc) · 1.85 KB
/
hummingbird_movies.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
from __future__ import unicode_literals, division, absolute_import
import logging
import re
import json
import urllib2
from requests import RequestException
from flexget import plugin
from flexget.entry import Entry
from flexget.event import event
from flexget.utils.cached_input import cached
log = logging.getLogger('hummingbird_movies')
class HummingbirdMovies(object):
"""Creates an entry for each item in your hummingbird.me list.
Syntax:
hummingbird_movies:
username: <value>
lists:
- <currently-watching|plan-to-watch|completed|on-hold|dropped>
- <currently-watching|plan-to-watch|completed|on-hold|dropped>
"""
schema = {
'type': 'object',
'properties': {
'username': {'type': 'string'},
'lists': {'type': 'array', 'items': {'type': 'string'}},
},
'required': ['username'],
'additionalProperties': False,
}
@cached('hummingbird_movies', persist='2 hours')
def on_task_input(self, task, config):
url = "http://hummingbird.me/api/v1/users/%s/library" % (config['username'])
try:
data = json.load(urllib2.urlopen(url))
except ValueError:
raise plugin.PluginError('Error getting list from hummingbird.')
if not data:
return
entries = []
chosen_lists = config['lists']
for item in data:
if item['status'] not in chosen_lists:
continue
if item['anime']['show_type'] != 'Movie':
continue
entry = Entry()
entry['title'] = item['anime']['title']
entry['url'] = ''
if entry.isvalid():
entries.append(entry)
return entries
@event('plugin.register')
def register_plugin():
plugin.register(HummingbirdMovies, 'hummingbird_movies', api_ver=2)