mirror of https://github.com/evilhero/mylar
691 lines
26 KiB
Python
691 lines
26 KiB
Python
#!/usr/bin/env python
|
|
# -*- coding: utf-8 -*-
|
|
|
|
# This file is part of Mylar.
|
|
#
|
|
# Mylar 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.
|
|
#
|
|
# Mylar 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 Mylar. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
import mylar
|
|
from mylar import db, mb, importer, search, process, versioncheck, logger, webserve, helpers
|
|
import simplejson as simplejson
|
|
import json
|
|
import cherrypy
|
|
import random
|
|
import os
|
|
import urllib2
|
|
import cache
|
|
import imghdr
|
|
from operator import itemgetter
|
|
from cherrypy.lib.static import serve_file, serve_download
|
|
import datetime
|
|
|
|
cmd_list = ['getIndex', 'getComic', 'getUpcoming', 'getWanted', 'getHistory',
|
|
'getLogs', 'clearLogs','findComic', 'addComic', 'delComic',
|
|
'pauseComic', 'resumeComic', 'refreshComic', 'addIssue',
|
|
'queueIssue', 'unqueueIssue', 'forceSearch', 'forceProcess',
|
|
'getVersion', 'checkGithub','shutdown', 'restart', 'update',
|
|
'getComicInfo', 'getIssueInfo', 'getArt', 'downloadIssue',
|
|
'downloadNZB', 'getReadList', 'getStoryArc', 'addStoryArc']
|
|
|
|
|
|
class Api(object):
|
|
|
|
def __init__(self):
|
|
self.apikey = None
|
|
self.cmd = None
|
|
self.id = None
|
|
self.img = None
|
|
self.file = None
|
|
self.filename = None
|
|
self.kwargs = None
|
|
self.data = None
|
|
self.callback = None
|
|
self.apitype = None
|
|
self.comicrn = False
|
|
|
|
def checkParams(self, *args, **kwargs):
|
|
|
|
if 'apikey' not in kwargs:
|
|
self.data = self._error_with_message('Missing api key')
|
|
return
|
|
|
|
if 'cmd' not in kwargs:
|
|
self.data = self._error_with_message('Missing parameter: cmd')
|
|
return
|
|
|
|
if not mylar.CONFIG.API_ENABLED:
|
|
if kwargs['apikey'] != mylar.DOWNLOAD_APIKEY:
|
|
self.data = self._error_with_message('API not enabled')
|
|
return
|
|
|
|
if kwargs['apikey'] != mylar.CONFIG.API_KEY and all([kwargs['apikey'] != mylar.DOWNLOAD_APIKEY, mylar.DOWNLOAD_APIKEY != None]):
|
|
self.data = self._error_with_message('Incorrect API key')
|
|
return
|
|
else:
|
|
if kwargs['apikey'] == mylar.CONFIG.API_KEY:
|
|
self.apitype = 'normal'
|
|
elif kwargs['apikey'] == mylar.DOWNLOAD_APIKEY:
|
|
self.apitype = 'download'
|
|
logger.fdebug('Matched to key. Api set to : ' + self.apitype + ' mode.')
|
|
self.apikey = kwargs.pop('apikey')
|
|
|
|
if not([mylar.CONFIG.API_KEY, mylar.DOWNLOAD_APIKEY]):
|
|
self.data = self._error_with_message('API key not generated')
|
|
return
|
|
|
|
if self.apitype:
|
|
if self.apitype == 'normal' and len(mylar.CONFIG.API_KEY) != 32:
|
|
self.data = self._error_with_message('API key not generated correctly')
|
|
return
|
|
if self.apitype == 'download' and len(mylar.DOWNLOAD_APIKEY) != 32:
|
|
self.data = self._error_with_message('Download API key not generated correctly')
|
|
return
|
|
else:
|
|
self.data = self._error_with_message('API key not generated correctly')
|
|
return
|
|
|
|
if kwargs['cmd'] not in cmd_list:
|
|
self.data = self._error_with_message('Unknown command: %s' % kwargs['cmd'])
|
|
return
|
|
else:
|
|
self.cmd = kwargs.pop('cmd')
|
|
|
|
self.kwargs = kwargs
|
|
self.data = 'OK'
|
|
|
|
def fetchData(self):
|
|
|
|
if self.data == 'OK':
|
|
logger.fdebug('Recieved API command: ' + self.cmd)
|
|
methodToCall = getattr(self, "_" + self.cmd)
|
|
result = methodToCall(**self.kwargs)
|
|
if 'callback' not in self.kwargs:
|
|
if self.img:
|
|
return serve_file(path=self.img, content_type='image/jpeg')
|
|
if self.file and self.filename:
|
|
return serve_download(path=self.file, name=self.filename)
|
|
if isinstance(self.data, basestring):
|
|
return self.data
|
|
else:
|
|
if self.comicrn is True:
|
|
return self.data
|
|
else:
|
|
cherrypy.response.headers['Content-Type'] = "application/json"
|
|
return simplejson.dumps(self.data)
|
|
else:
|
|
self.callback = self.kwargs['callback']
|
|
self.data = simplejson.dumps(self.data)
|
|
self.data = self.callback + '(' + self.data + ');'
|
|
cherrypy.response.headers['Content-Type'] = "application/javascript"
|
|
return self.data
|
|
else:
|
|
return self.data
|
|
|
|
def _dic_from_query(self, query):
|
|
myDB = db.DBConnection()
|
|
rows = myDB.select(query)
|
|
|
|
rows_as_dic = []
|
|
|
|
for row in rows:
|
|
row_as_dic = dict(zip(row.keys(), row))
|
|
rows_as_dic.append(row_as_dic)
|
|
|
|
return rows_as_dic
|
|
|
|
def _error_with_message(self, message):
|
|
error = {'error': {'message': message} }
|
|
cherrypy.response.headers['Content-Type'] = "application/json"
|
|
return simplejson.dumps(error)
|
|
|
|
def _getIndex(self, **kwargs):
|
|
self.data = self._dic_from_query('SELECT * from comics order by ComicSortName COLLATE NOCASE')
|
|
return
|
|
|
|
def _getReadList(self, **kwargs):
|
|
self.data = self._dic_from_query('SELECT * from readlist order by IssueDate ASC')
|
|
return
|
|
|
|
def _getComic(self, **kwargs):
|
|
if 'id' not in kwargs:
|
|
self.data = self._error_with_message('Missing parameter: id')
|
|
return
|
|
else:
|
|
self.id = kwargs['id']
|
|
|
|
comic = self._dic_from_query('SELECT * from comics WHERE ComicID="' + self.id + '"')
|
|
issues = self._dic_from_query('SELECT * from issues WHERE ComicID="' + self.id + '"order by Int_IssueNumber DESC')
|
|
if mylar.CONFIG.ANNUALS_ON:
|
|
annuals = self._dic_from_query('SELECT * FROM annuals WHERE ComicID="' + self.id + '"')
|
|
else:
|
|
annuals = None
|
|
|
|
self.data = {'comic': comic, 'issues': issues, 'annuals': annuals}
|
|
return
|
|
|
|
def _getHistory(self, **kwargs):
|
|
self.data = self._dic_from_query('SELECT * from snatched order by DateAdded DESC')
|
|
return
|
|
|
|
def _getUpcoming(self, **kwargs):
|
|
if 'include_downloaded_issues' in kwargs and kwargs['include_downloaded_issues'].upper() == 'Y':
|
|
select_status_clause = "w.STATUS IN ('Wanted', 'Snatched', 'Downloaded')"
|
|
else:
|
|
select_status_clause = "w.STATUS = 'Wanted'"
|
|
|
|
# Days in a new year that precede the first Sunday will look to the previous Sunday for week and year.
|
|
today = datetime.date.today()
|
|
if today.strftime('%U') == '00':
|
|
weekday = 0 if today.isoweekday() == 7 else today.isoweekday()
|
|
sunday = today - datetime.timedelta(days=weekday)
|
|
week = sunday.strftime('%U')
|
|
year = sunday.strftime('%Y')
|
|
else:
|
|
week = today.strftime('%U')
|
|
year = today.strftime('%Y')
|
|
|
|
self.data = self._dic_from_query(
|
|
"SELECT w.COMIC AS ComicName, w.ISSUE AS IssueNumber, w.ComicID, w.IssueID, w.SHIPDATE AS IssueDate, w.STATUS AS Status, c.ComicName AS DisplayComicName \
|
|
FROM weekly w JOIN comics c ON w.ComicID = c.ComicID WHERE w.COMIC IS NOT NULL AND w.ISSUE IS NOT NULL AND \
|
|
SUBSTR('0' || w.weeknumber, -2) = '" + week + "' AND w.year = '" + year + "' AND " + select_status_clause + " ORDER BY c.ComicSortName")
|
|
return
|
|
|
|
def _getWanted(self, **kwargs):
|
|
self.data = self._dic_from_query("SELECT * from issues WHERE Status='Wanted'")
|
|
return
|
|
|
|
def _getLogs(self, **kwargs):
|
|
self.data = mylar.LOG_LIST
|
|
return
|
|
|
|
def _clearLogs(self, **kwargs):
|
|
mylar.LOG_LIST = []
|
|
self.data = 'Cleared log'
|
|
return
|
|
|
|
def _delComic(self, **kwargs):
|
|
if 'id' not in kwargs:
|
|
self.data = self._error_with_message('Missing parameter: id')
|
|
return
|
|
else:
|
|
self.id = kwargs['id']
|
|
|
|
myDB = db.DBConnection()
|
|
myDB.action('DELETE from comics WHERE ComicID="' + self.id + '"')
|
|
myDB.action('DELETE from issues WHERE ComicID="' + self.id + '"')
|
|
myDB.action('DELETE from upcoming WHERE ComicID="' + self.id + '"')
|
|
|
|
def _pauseComic(self, **kwargs):
|
|
if 'id' not in kwargs:
|
|
self.data = self._error_with_message('Missing parameter: id')
|
|
return
|
|
else:
|
|
self.id = kwargs['id']
|
|
|
|
myDB = db.DBConnection()
|
|
controlValueDict = {'ComicID': self.id}
|
|
newValueDict = {'Status': 'Paused'}
|
|
myDB.upsert("comics", newValueDict, controlValueDict)
|
|
|
|
def _resumeComic(self, **kwargs):
|
|
if 'id' not in kwargs:
|
|
self.data = self._error_with_message('Missing parameter: id')
|
|
return
|
|
else:
|
|
self.id = kwargs['id']
|
|
|
|
myDB = db.DBConnection()
|
|
controlValueDict = {'ComicID': self.id}
|
|
newValueDict = {'Status': 'Active'}
|
|
myDB.upsert("comics", newValueDict, controlValueDict)
|
|
|
|
def _refreshComic(self, **kwargs):
|
|
if 'id' not in kwargs:
|
|
self.data = self._error_with_message('Missing parameter: id')
|
|
return
|
|
else:
|
|
self.id = kwargs['id']
|
|
|
|
try:
|
|
importer.addComictoDB(self.id)
|
|
except Exception, e:
|
|
self.data = e
|
|
|
|
return
|
|
|
|
def _addComic(self, **kwargs):
|
|
if 'id' not in kwargs:
|
|
self.data = self._error_with_message('Missing parameter: id')
|
|
return
|
|
else:
|
|
self.id = kwargs['id']
|
|
|
|
try:
|
|
importer.addComictoDB(self.id)
|
|
except Exception, e:
|
|
self.data = e
|
|
|
|
return
|
|
|
|
def _queueIssue(self, **kwargs):
|
|
if 'id' not in kwargs:
|
|
self.data = self._error_with_message('Missing parameter: id')
|
|
return
|
|
else:
|
|
self.id = kwargs['id']
|
|
|
|
myDB = db.DBConnection()
|
|
controlValueDict = {'IssueID': self.id}
|
|
newValueDict = {'Status': 'Wanted'}
|
|
myDB.upsert("issues", newValueDict, controlValueDict)
|
|
search.searchforissue(self.id)
|
|
|
|
def _unqueueIssue(self, **kwargs):
|
|
if 'id' not in kwargs:
|
|
self.data = self._error_with_message('Missing parameter: id')
|
|
return
|
|
else:
|
|
self.id = kwargs['id']
|
|
|
|
myDB = db.DBConnection()
|
|
controlValueDict = {'IssueID': self.id}
|
|
newValueDict = {'Status': 'Skipped'}
|
|
myDB.upsert("issues", newValueDict, controlValueDict)
|
|
|
|
def _forceSearch(self, **kwargs):
|
|
search.searchforissue()
|
|
|
|
def _forceProcess(self, **kwargs):
|
|
if 'nzb_name' not in kwargs:
|
|
self.data = self._error_with_message('Missing parameter: nzb_name')
|
|
return
|
|
else:
|
|
self.nzb_name = kwargs['nzb_name']
|
|
|
|
if 'nzb_folder' not in kwargs:
|
|
self.data = self._error_with_message('Missing parameter: nzb_folder')
|
|
return
|
|
else:
|
|
self.nzb_folder = kwargs['nzb_folder']
|
|
|
|
if 'failed' not in kwargs:
|
|
failed = False
|
|
else:
|
|
failed = kwargs['failed']
|
|
|
|
|
|
if 'apc_version' not in kwargs:
|
|
fp = process.Process(self.nzb_name, self.nzb_folder, failed=failed)
|
|
self.data = fp.post_process()
|
|
else:
|
|
logger.info('[API] Api Call from ComicRN detected - initiating script post-processing.')
|
|
fp = webserve.WebInterface()
|
|
self.data = fp.post_process(self.nzb_name, self.nzb_folder, failed=failed, apc_version=kwargs['apc_version'], comicrn_version=kwargs['comicrn_version'])
|
|
self.comicrn = True
|
|
return
|
|
|
|
def _getVersion(self, **kwargs):
|
|
self.data = {
|
|
'git_path': mylar.CONFIG.GIT_PATH,
|
|
'install_type': mylar.INSTALL_TYPE,
|
|
'current_version': mylar.CURRENT_VERSION,
|
|
'latest_version': mylar.LATEST_VERSION,
|
|
'commits_behind': mylar.COMMITS_BEHIND,
|
|
}
|
|
|
|
def _checkGithub(self, **kwargs):
|
|
versioncheck.checkGithub()
|
|
self._getVersion()
|
|
|
|
def _shutdown(self, **kwargs):
|
|
mylar.SIGNAL = 'shutdown'
|
|
|
|
def _restart(self, **kwargs):
|
|
mylar.SIGNAL = 'restart'
|
|
|
|
def _update(self, **kwargs):
|
|
mylar.SIGNAL = 'update'
|
|
|
|
def _getArtistArt(self, **kwargs):
|
|
if 'id' not in kwargs:
|
|
self.data = self._error_with_message('Missing parameter: id')
|
|
return
|
|
else:
|
|
self.id = kwargs['id']
|
|
|
|
self.data = cache.getArtwork(ComicID=self.id)
|
|
|
|
def _getIssueArt(self, **kwargs):
|
|
if 'id' not in kwargs:
|
|
self.data = self._error_with_message('Missing parameter: id')
|
|
return
|
|
else:
|
|
self.id = kwargs['id']
|
|
|
|
self.data = cache.getArtwork(IssueID=self.id)
|
|
|
|
def _getComicInfo(self, **kwargs):
|
|
if 'id' not in kwargs:
|
|
self.data = self._error_with_message('Missing parameter: id')
|
|
return
|
|
else:
|
|
self.id = kwargs['id']
|
|
|
|
self.data = cache.getInfo(ComicID=self.id)
|
|
|
|
def _getIssueInfo(self, **kwargs):
|
|
if 'id' not in kwargs:
|
|
self.data = self._error_with_message('Missing parameter: id')
|
|
return
|
|
else:
|
|
self.id = kwargs['id']
|
|
|
|
self.data = cache.getInfo(IssueID=self.id)
|
|
|
|
def _getArt(self, **kwargs):
|
|
if 'id' not in kwargs:
|
|
self.data = self._error_with_message('Missing parameter: id')
|
|
return
|
|
else:
|
|
self.id = kwargs['id']
|
|
|
|
img = None
|
|
image_path = os.path.join(mylar.CONFIG.CACHE_DIR, str(self.id) + '.jpg')
|
|
|
|
# Checks if its a valid path and file
|
|
if os.path.isfile(image_path):
|
|
# check if its a valid img
|
|
if imghdr.what(image_path):
|
|
self.img = image_path
|
|
return
|
|
else:
|
|
# If we cant find the image, lets check the db for a url.
|
|
comic = self._dic_from_query('SELECT * from comics WHERE ComicID="' + self.id + '"')
|
|
|
|
# Try every img url in the db
|
|
try:
|
|
img = urllib2.urlopen(comic[0]['ComicImageURL']).read()
|
|
except:
|
|
try:
|
|
img = urllib2.urlopen(comic[0]['ComicImageALTURL']).read()
|
|
except:
|
|
pass
|
|
|
|
if img:
|
|
# verify the img stream
|
|
if imghdr.what(None, img):
|
|
with open(image_path, 'wb') as f:
|
|
f.write(img)
|
|
self.img = image_path
|
|
return
|
|
else:
|
|
self.data = self._error_with_message('Failed return a image')
|
|
else:
|
|
self.data = self._error_with_message('Failed to return a image')
|
|
|
|
def _findComic(self, name, issue=None, type_=None, mode=None, explisit=None, serinfo=None):
|
|
# set defaults
|
|
if type_ is None:
|
|
type_ = 'comic'
|
|
if mode is None:
|
|
mode = 'series'
|
|
|
|
# Dont do shit if name is missing
|
|
if len(name) == 0:
|
|
self.data = self._error_with_message('Missing a Comic name')
|
|
return
|
|
|
|
if type_ == 'comic' and mode == 'series':
|
|
searchresults, explisit = mb.findComic(name, mode, issue=issue)
|
|
elif type_ == 'comic' and mode == 'pullseries':
|
|
pass
|
|
elif type_ == 'comic' and mode == 'want':
|
|
searchresults, explisit = mb.findComic(name, mode, issue)
|
|
elif type_ == 'story_arc':
|
|
searchresults, explisit = mb.findComic(name, mode, issue=None, explisit='explisit', type='story_arc')
|
|
|
|
searchresults = sorted(searchresults, key=itemgetter('comicyear', 'issues'), reverse=True)
|
|
self.data = searchresults
|
|
|
|
def _downloadIssue(self, id):
|
|
if not id:
|
|
self.data = self._error_with_message('You need to provide a issueid')
|
|
return
|
|
|
|
self.id = id
|
|
# Fetch a list of dicts from issues table
|
|
i = self._dic_from_query('SELECT * from issues WHERE issueID="' + self.id + '"')
|
|
|
|
if not len(i):
|
|
self.data = self._error_with_message('Couldnt find a issue with issueID %s' % self.id)
|
|
return
|
|
|
|
# issueid is unique so it should one dict in the list
|
|
issue = i[0]
|
|
|
|
issuelocation = issue.get('Location', None)
|
|
|
|
# Check the issue is downloaded
|
|
if issuelocation is not None:
|
|
# Find the comic location
|
|
comic = self._dic_from_query('SELECT * from comics WHERE comicID="' + issue['ComicID'] + '"')[0]
|
|
comiclocation = comic.get('ComicLocation')
|
|
f = os.path.join(comiclocation, issuelocation)
|
|
if not os.path.isfile(f):
|
|
if mylar.CONFIG.MULTIPLE_DEST_DIRS is not None and mylar.CONFIG.MULTIPLE_DEST_DIRS != 'None':
|
|
pathdir = os.path.join(mylar.CONFIG.MULTIPLE_DEST_DIRS, os.path.basename(comiclocation))
|
|
f = os.path.join(pathdir, issuelocation)
|
|
self.file = f
|
|
self.filename = issuelocation
|
|
else:
|
|
self.file = f
|
|
self.filename = issuelocation
|
|
else:
|
|
self.data = self._error_with_message('You need to download that issue first')
|
|
return
|
|
|
|
def _downloadNZB(self, nzbname):
|
|
if not nzbname:
|
|
self.data = self._error_with_message('You need to provide a nzbname')
|
|
return
|
|
|
|
self.nzbname = nzbname
|
|
f = os.path.join(mylar.CONFIG.CACHE_DIR, nzbname)
|
|
if os.path.isfile(f):
|
|
self.file = f
|
|
self.filename = nzbname
|
|
else:
|
|
self.data = self._error_with_message('NZBname does not exist within the cache directory. Unable to retrieve.')
|
|
return
|
|
|
|
def _getStoryArc(self, **kwargs):
|
|
if not 'id' in kwargs:
|
|
if 'customOnly' in kwargs and kwargs['customOnly']:
|
|
self.data = self._dic_from_query('SELECT StoryArcID, StoryArc, MAX(ReadingOrder) AS HighestOrder from storyarcs WHERE StoryArcID LIKE "C%" GROUP BY StoryArcID ORDER BY StoryArc')
|
|
else:
|
|
self.data = self._dic_from_query('SELECT StoryArcID, StoryArc, MAX(ReadingOrder) AS HighestOrder from storyarcs GROUP BY StoryArcID ORDER BY StoryArc')
|
|
else:
|
|
self.id = kwargs['id']
|
|
self.data = self._dic_from_query('SELECT StoryArc, ReadingOrder, ComicID, ComicName, IssueNumber, IssueID, \
|
|
IssueDate, IssueName, IssuePublisher from storyarcs WHERE StoryArcID="' + self.id + '" ORDER BY ReadingOrder')
|
|
return
|
|
|
|
def _addStoryArc(self, **kwargs):
|
|
issuecount = 0
|
|
if not 'id' in kwargs:
|
|
self.id = 'C%04d' % random.randint(1, 9999)
|
|
if not 'storyarcname' in kwargs:
|
|
self.data = self._error_with_message('You need to provide either id or storyarcname')
|
|
return
|
|
else:
|
|
storyarcname = kwargs.pop('storyarcname')
|
|
else:
|
|
self.id = kwargs.pop('id')
|
|
arc = self._dic_from_query('SELECT * from storyarcs WHERE StoryArcID="' + self.id + '" ORDER by ReadingOrder')
|
|
storyarcname = arc[0]['StoryArc']
|
|
issuecount = len(arc)
|
|
if not 'issues' in kwargs and not 'arclist' in kwargs:
|
|
self.data = self._error_with_message('No issues specified')
|
|
return
|
|
else:
|
|
arclist = ""
|
|
if 'issues' in kwargs:
|
|
issuelist = kwargs.pop('issues').split(",")
|
|
index = 0
|
|
for issue in issuelist:
|
|
arclist += "%s,%s" % (issue, issuecount + 1)
|
|
index += 1
|
|
issuecount += 1
|
|
if index < len(issuelist):
|
|
arclist += "|"
|
|
if 'arclist' in kwargs:
|
|
cvlist = kwargs.pop('arclist')
|
|
issuelist = cvlist.split("|")
|
|
index = 0
|
|
for issue in issuelist:
|
|
arclist += "%s,%s" % (issue.split(",")[0],issuecount + 1)
|
|
index += 1
|
|
issuecount += 1
|
|
if index < len(issuelist):
|
|
arclist += "|"
|
|
wi = webserve.WebInterface()
|
|
logger.info("arclist: %s - arcid: %s - storyarcname: %s - storyarcissues: %s" % (arclist, self.id, storyarcname, issuecount))
|
|
wi.addStoryArc_thread(arcid=self.id, storyarcname=storyarcname, storyarcissues=issuecount, arclist=arclist, **kwargs)
|
|
return
|
|
|
|
class REST(object):
|
|
|
|
def __init__(self):
|
|
pass
|
|
|
|
class verify_api(object):
|
|
def __init__(self):
|
|
pass
|
|
|
|
def validate(self):
|
|
logger.info('attempting to validate...')
|
|
req = cherrypy.request.headers
|
|
logger.info('thekey: %s' % req)
|
|
logger.info('url: %s' % cherrypy.url())
|
|
logger.info('mylar.apikey: %s [%s]' % (mylar.CONFIG.API_KEY, type(mylar.CONFIG.API_KEY)))
|
|
logger.info('submitted.apikey: %s [%s]' % (req['Api-Key'], type(req['Api-Key'])))
|
|
if 'Api-Key' not in req or req['Api-Key'] != str(mylar.CONFIG.API_KEY): #str(mylar.API_KEY) or mylar.API_KEY not in cherrypy.url():
|
|
logger.info('wrong APIKEY')
|
|
return 'api-key provided was either not present in auth header, or was incorrect.'
|
|
else:
|
|
return True
|
|
|
|
class Watchlist(object):
|
|
exposed = True
|
|
def __init__(self):
|
|
pass
|
|
|
|
def GET(self):
|
|
va = REST.verify_api()
|
|
vchk = va.validate()
|
|
if vchk is not True:
|
|
return('api-key provided was either not present in auth header, or was incorrect.')
|
|
#rows_as_dic = []
|
|
|
|
#for row in rows:
|
|
# row_as_dic = dict(zip(row.keys(), row))
|
|
# rows_as_dic.append(row_as_dic)
|
|
|
|
#return rows_as_dic
|
|
some = helpers.havetotals()
|
|
return simplejson.dumps(some)
|
|
|
|
class Comics(object):
|
|
exposed = True
|
|
def __init__(self):
|
|
pass
|
|
|
|
def _dic_from_query(self, query):
|
|
myDB = db.DBConnection()
|
|
rows = myDB.select(query)
|
|
|
|
rows_as_dic = []
|
|
|
|
for row in rows:
|
|
row_as_dic = dict(zip(row.keys(), row))
|
|
rows_as_dic.append(row_as_dic)
|
|
|
|
return rows_as_dic
|
|
|
|
def GET(self):
|
|
va = REST.verify_api()
|
|
vchk = va.validate()
|
|
if vchk is not True:
|
|
return('api-key provided was either not present in auth header, or was incorrect.')
|
|
#req = cherrypy.request.headers
|
|
#logger.info('thekey: %s' % req)
|
|
#if 'api-key' not in req or req['api-key'] != 'hello':
|
|
# logger.info('wrong APIKEY')
|
|
# return('api-key provided was either not present in auth header, or was incorrect.')
|
|
|
|
self.comics = self._dic_from_query('SELECT * from comics order by ComicSortName COLLATE NOCASE')
|
|
return('Here are all the comics we have: %s' % self.comics)
|
|
|
|
@cherrypy.popargs('comic_id','issuemode','issue_id')
|
|
class Comic(object):
|
|
exposed = True
|
|
|
|
def __init__(self):
|
|
pass
|
|
|
|
def _dic_from_query(self, query):
|
|
myDB = db.DBConnection()
|
|
rows = myDB.select(query)
|
|
|
|
rows_as_dic = []
|
|
|
|
for row in rows:
|
|
row_as_dic = dict(zip(row.keys(), row))
|
|
rows_as_dic.append(row_as_dic)
|
|
|
|
return rows_as_dic
|
|
|
|
def GET(self, comic_id=None, issuemode=None, issue_id=None):
|
|
va = REST.verify_api()
|
|
vchk = va.validate()
|
|
if vchk is not True:
|
|
return('api-key provided was either not present in auth header, or was incorrect.')
|
|
|
|
#req = cherrypy.request.headers
|
|
#logger.info('thekey: %s' % req)
|
|
#if 'api-key' not in req or req['api-key'] != 'hello':
|
|
# logger.info('wrong APIKEY')
|
|
# return('api-key provided was either not present in auth header, or was incorrect.')
|
|
|
|
self.comics = self._dic_from_query('SELECT * from comics order by ComicSortName COLLATE NOCASE')
|
|
|
|
if comic_id is None:
|
|
return('No valid ComicID entered')
|
|
else:
|
|
if issuemode is None:
|
|
match = [c for c in self.comics if comic_id == c['ComicID']]
|
|
if match:
|
|
return json.dumps(match,ensure_ascii=False)
|
|
else:
|
|
return('No Comic with the ID %s :-(' % comic_id)
|
|
elif issuemode == 'issues':
|
|
self.issues = self._dic_from_query('SELECT * from issues where comicid="' + comic_id + '"')
|
|
return json.dumps(self.issues, ensure_ascii=False)
|
|
elif issuemode == 'issue' and issue_id is not None:
|
|
self.issues = self._dic_from_query('SELECT * from issues where comicid="' + comic_id + '" and issueid="' + issue_id + '"')
|
|
return json.dumps(self.issues, ensure_ascii=False)
|
|
else:
|
|
return('Nothing to do.')
|
|
|