2012-11-02 13:54:17 -07:00
|
|
|
"""
|
2015-02-12 14:57:46 -08:00
|
|
|
A python class to encapsulate the ComicBookInfo data
|
2012-11-02 13:54:17 -07:00
|
|
|
"""
|
|
|
|
|
2012-11-06 12:56:30 -08:00
|
|
|
"""
|
2014-03-23 10:30:23 -07:00
|
|
|
Copyright 2012-2014 Anthony Beville
|
2012-11-06 12:56:30 -08:00
|
|
|
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
you may not use this file except in compliance with the License.
|
|
|
|
You may obtain a copy of the License at
|
|
|
|
|
2015-02-12 14:57:46 -08:00
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
2012-11-06 12:56:30 -08:00
|
|
|
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
See the License for the specific language governing permissions and
|
|
|
|
limitations under the License.
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
2012-11-02 13:54:17 -07:00
|
|
|
import json
|
|
|
|
from datetime import datetime
|
|
|
|
import zipfile
|
|
|
|
|
|
|
|
from genericmetadata import GenericMetadata
|
|
|
|
import utils
|
2013-01-16 15:29:32 -08:00
|
|
|
import ctversion
|
2012-11-02 13:54:17 -07:00
|
|
|
|
|
|
|
|
2015-02-13 15:08:07 -08:00
|
|
|
class ComicBookInfo:
|
2015-02-12 14:57:46 -08:00
|
|
|
|
2015-02-13 15:08:07 -08:00
|
|
|
def metadataFromString(self, string):
|
2015-02-12 14:57:46 -08:00
|
|
|
|
2015-02-13 15:08:07 -08:00
|
|
|
cbi_container = json.loads(unicode(string, 'utf-8'))
|
2015-02-12 14:57:46 -08:00
|
|
|
|
|
|
|
metadata = GenericMetadata()
|
|
|
|
|
|
|
|
cbi = cbi_container[ 'ComicBookInfo/1.0' ]
|
|
|
|
|
|
|
|
#helper func
|
|
|
|
# If item is not in CBI, return None
|
2015-02-13 15:08:07 -08:00
|
|
|
def xlate(cbi_entry):
|
2015-02-12 14:57:46 -08:00
|
|
|
if cbi_entry in cbi:
|
|
|
|
return cbi[cbi_entry]
|
|
|
|
else:
|
|
|
|
return None
|
|
|
|
|
2015-02-13 15:08:07 -08:00
|
|
|
metadata.series = xlate('series')
|
|
|
|
metadata.title = xlate('title')
|
|
|
|
metadata.issue = xlate('issue')
|
|
|
|
metadata.publisher = xlate('publisher')
|
|
|
|
metadata.month = xlate('publicationMonth')
|
|
|
|
metadata.year = xlate('publicationYear')
|
|
|
|
metadata.issueCount = xlate('numberOfIssues')
|
|
|
|
metadata.comments = xlate('comments')
|
|
|
|
metadata.credits = xlate('credits')
|
|
|
|
metadata.genre = xlate('genre')
|
|
|
|
metadata.volume = xlate('volume')
|
|
|
|
metadata.volumeCount = xlate('numberOfVolumes')
|
|
|
|
metadata.language = xlate('language')
|
|
|
|
metadata.country = xlate('country')
|
|
|
|
metadata.criticalRating = xlate('rating')
|
|
|
|
metadata.tags = xlate('tags')
|
2015-02-12 14:57:46 -08:00
|
|
|
|
|
|
|
# make sure credits and tags are at least empty lists and not None
|
|
|
|
if metadata.credits is None:
|
|
|
|
metadata.credits = []
|
|
|
|
if metadata.tags is None:
|
|
|
|
metadata.tags = []
|
|
|
|
|
|
|
|
#need to massage the language string to be ISO
|
|
|
|
if metadata.language is not None:
|
|
|
|
# reverse look-up
|
|
|
|
pattern = metadata.language
|
|
|
|
metadata.language = None
|
|
|
|
for key in utils.getLanguageDict():
|
|
|
|
if utils.getLanguageDict()[ key ] == pattern.encode('utf-8'):
|
|
|
|
metadata.language = key
|
|
|
|
break
|
|
|
|
|
|
|
|
metadata.isEmpty = False
|
|
|
|
|
|
|
|
return metadata
|
|
|
|
|
2015-02-13 15:08:07 -08:00
|
|
|
def stringFromMetadata(self, metadata):
|
2015-02-12 14:57:46 -08:00
|
|
|
|
2015-02-13 15:08:07 -08:00
|
|
|
cbi_container = self.createJSONDictionary(metadata)
|
|
|
|
return json.dumps(cbi_container)
|
2015-02-12 14:57:46 -08:00
|
|
|
|
|
|
|
#verify that the string actually contains CBI data in JSON format
|
2015-02-13 15:08:07 -08:00
|
|
|
def validateString(self, string):
|
2015-02-12 14:57:46 -08:00
|
|
|
|
|
|
|
try:
|
2015-02-13 15:08:07 -08:00
|
|
|
cbi_container = json.loads(string)
|
2015-02-12 14:57:46 -08:00
|
|
|
except:
|
|
|
|
return False
|
|
|
|
|
2015-02-13 15:08:07 -08:00
|
|
|
return ('ComicBookInfo/1.0' in cbi_container)
|
2015-02-12 14:57:46 -08:00
|
|
|
|
|
|
|
|
2015-02-13 15:08:07 -08:00
|
|
|
def createJSONDictionary(self, metadata):
|
2015-02-12 14:57:46 -08:00
|
|
|
|
|
|
|
# Create the dictionary that we will convert to JSON text
|
|
|
|
cbi = dict()
|
|
|
|
cbi_container = {'appID' : 'ComicTagger/' + ctversion.version,
|
|
|
|
'lastModified' : str(datetime.now()),
|
|
|
|
'ComicBookInfo/1.0' : cbi }
|
|
|
|
|
|
|
|
#helper func
|
2015-02-13 15:08:07 -08:00
|
|
|
def assign(cbi_entry, md_entry):
|
2015-02-12 14:57:46 -08:00
|
|
|
if md_entry is not None:
|
|
|
|
cbi[cbi_entry] = md_entry
|
|
|
|
|
|
|
|
#helper func
|
|
|
|
def toInt(s):
|
|
|
|
i = None
|
|
|
|
if type(s) in [ str, unicode, int ]:
|
|
|
|
try:
|
|
|
|
i = int(s)
|
|
|
|
except ValueError:
|
|
|
|
pass
|
|
|
|
return i
|
|
|
|
|
2015-02-13 15:08:07 -08:00
|
|
|
assign('series', metadata.series)
|
|
|
|
assign('title', metadata.title)
|
|
|
|
assign('issue', metadata.issue)
|
|
|
|
assign('publisher', metadata.publisher)
|
|
|
|
assign('publicationMonth', toInt(metadata.month))
|
|
|
|
assign('publicationYear', toInt(metadata.year))
|
|
|
|
assign('numberOfIssues', toInt(metadata.issueCount))
|
|
|
|
assign('comments', metadata.comments)
|
|
|
|
assign('genre', metadata.genre)
|
|
|
|
assign('volume', toInt(metadata.volume))
|
|
|
|
assign('numberOfVolumes', toInt(metadata.volumeCount))
|
|
|
|
assign('language', utils.getLanguageFromISO(metadata.language))
|
|
|
|
assign('country', metadata.country)
|
|
|
|
assign('rating', metadata.criticalRating)
|
|
|
|
assign('credits', metadata.credits)
|
|
|
|
assign('tags', metadata.tags)
|
2015-02-12 14:57:46 -08:00
|
|
|
|
|
|
|
return cbi_container
|
|
|
|
|
|
|
|
|
2015-02-13 15:08:07 -08:00
|
|
|
def writeToExternalFile(self, filename, metadata):
|
2015-02-12 14:57:46 -08:00
|
|
|
|
|
|
|
cbi_container = self.createJSONDictionary(metadata)
|
|
|
|
|
|
|
|
f = open(filename, 'w')
|
|
|
|
f.write(json.dumps(cbi_container, indent=4))
|
|
|
|
f.close
|