calibre-web/cps/metadata_provider/comicvine.py

66 lines
2.5 KiB
Python
Raw Normal View History

2021-07-05 18:55:54 +02:00
# -*- coding: utf-8 -*-
# This file is part of the Calibre-Web (https://github.com/janeczku/calibre-web)
# Copyright (C) 2021 OzzieIsaacs
#
# This program 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.
#
# This program 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 this program. If not, see <http://www.gnu.org/licenses/>.
2021-07-07 21:24:29 +02:00
# ComicVine api document: https://comicvine.gamespot.com/api/documentation
2021-07-05 18:55:54 +02:00
import requests
from cps.services.Metadata import Metadata
2021-07-06 20:24:27 +02:00
class ComicVine(Metadata):
__name__ = "ComicVine"
2021-07-08 19:14:38 +02:00
__id__ = "comicvine"
2021-07-05 18:55:54 +02:00
def search(self, query, generic_cover=""):
2021-07-07 21:10:38 +02:00
val = list()
2021-07-08 19:14:38 +02:00
apikey = "57558043c53943d5d1e96a9ad425b0eb85532ee6"
2021-07-05 18:55:54 +02:00
if self.active:
2021-07-06 20:24:27 +02:00
headers = {
'User-Agent': 'Not Evil Browser'
2021-07-06 20:24:27 +02:00
}
2021-07-07 21:10:38 +02:00
2021-07-06 20:24:27 +02:00
result = requests.get("https://comicvine.gamespot.com/api/search?api_key="
+ apikey + "&resources=issue&query=" + query + "&sort=name:desc&format=json", headers=headers)
2021-07-07 21:10:38 +02:00
for r in result.json()['results']:
seriesTitle = r['volume'].get('name', "")
if r.get('store_date'):
dateFomers = r.get('store_date')
else:
dateFomers = r.get('date_added')
v = dict()
v['id'] = r['id']
v['title'] = seriesTitle + " #" + r.get('issue_number', "0") + " - " + ( r.get('name', "") or "")
v['authors'] = r.get('authors', [])
v['description'] = r.get('description', "")
v['publisher'] = ""
v['publishedDate'] = dateFomers
v['tags'] = ["Comics", seriesTitle]
v['rating'] = 0
v['series'] = seriesTitle
v['cover'] = r['image'].get('original_url')
v['source'] = {
2021-07-08 19:14:38 +02:00
"id": self.__id__,
2021-07-07 21:10:38 +02:00
"description": "ComicVine Books",
"link": "https://comicvine.gamespot.com/"
}
2021-07-31 09:18:05 +02:00
v['url'] = r.get('site_detail_url', "")
2021-07-07 21:10:38 +02:00
val.append(v)
return val
2021-07-05 18:55:54 +02:00