Better output messages for failed kindlegen conversions (fix #191)

This commit is contained in:
OzzieIsaacs 2017-05-19 21:30:39 +02:00
parent 38fa9ce206
commit 5f4d839895

View File

@ -52,6 +52,9 @@ except Exception as e:
global_task = None global_task = None
updater_thread = None updater_thread = None
RET_SUCCESS = 1
RET_FAIL = 0
def update_download(book_id, user_id): def update_download(book_id, user_id):
check = ub.session.query(ub.Downloads).filter(ub.Downloads.user_id == user_id).filter(ub.Downloads.book_id == check = ub.session.query(ub.Downloads).filter(ub.Downloads.user_id == user_id).filter(ub.Downloads.book_id ==
book_id).first() book_id).first()
@ -63,6 +66,7 @@ def update_download(book_id, user_id):
def make_mobi(book_id, calibrepath): def make_mobi(book_id, calibrepath):
error_message = None
vendorpath = os.path.join(os.path.normpath(os.path.dirname(os.path.realpath(__file__)) + vendorpath = os.path.join(os.path.normpath(os.path.dirname(os.path.realpath(__file__)) +
os.sep + "../vendor" + os.sep)) os.sep + "../vendor" + os.sep))
if sys.platform == "win32": if sys.platform == "win32":
@ -70,13 +74,15 @@ def make_mobi(book_id, calibrepath):
else: else:
kindlegen = (os.path.join(vendorpath, u"kindlegen")).encode(sys.getfilesystemencoding()) kindlegen = (os.path.join(vendorpath, u"kindlegen")).encode(sys.getfilesystemencoding())
if not os.path.exists(kindlegen): if not os.path.exists(kindlegen):
app.logger.error("make_mobi: kindlegen binary not found in: %s" % kindlegen) error_message = _(u"kindlegen binary %(kindlepath)s not found", kindlepath=kindlegen)
return None app.logger.error("make_mobi: " + error_message)
return error_message, RET_FAIL
book = db.session.query(db.Books).filter(db.Books.id == book_id).first() book = db.session.query(db.Books).filter(db.Books.id == book_id).first()
data = db.session.query(db.Data).filter(db.Data.book == book.id).filter(db.Data.format == 'EPUB').first() data = db.session.query(db.Data).filter(db.Data.book == book.id).filter(db.Data.format == 'EPUB').first()
if not data: if not data:
app.logger.error("make_mobi: epub format not found for book id: %d" % book_id) error_message = _(u"epub format not found for book id: %(book)d", book=book_id)
return None app.logger.error("make_mobi: " + error_message)
return error_message, RET_FAIL
file_path = os.path.join(calibrepath, book.path, data.name) file_path = os.path.join(calibrepath, book.path, data.name)
if os.path.exists(file_path + u".epub"): if os.path.exists(file_path + u".epub"):
@ -88,6 +94,15 @@ def make_mobi(book_id, calibrepath):
if nextline == '' and p.poll() is not None: if nextline == '' and p.poll() is not None:
break break
if nextline != "\r\n": if nextline != "\r\n":
# Format of error message (kindlegen translates its output texts):
# Error(prcgen):E23006: Language not recognized in metadata.The dc:Language field is mandatory.Aborting.
conv_error=re.search(".*\(.*\):(E\d+):\s(.*)",nextline)
# If error occoures, log in every case
if conv_error:
error_message = _(u"Kindlegen failed with Error %(error)s. Message: %(message)s",
error=conv_error.group(1), message=conv_error.group(2).decode('utf-8'))
app.logger.info("make_mobi: " + error_message)
app.logger.info(nextline.strip('\r\n'))
app.logger.debug(nextline.strip('\r\n')) app.logger.debug(nextline.strip('\r\n'))
check = p.returncode check = p.returncode
@ -99,13 +114,13 @@ def make_mobi(book_id, calibrepath):
uncompressed_size=os.path.getsize(file_path + ".mobi") uncompressed_size=os.path.getsize(file_path + ".mobi")
)) ))
db.session.commit() db.session.commit()
return file_path + ".mobi" return file_path + ".mobi", RET_SUCCESS
else: else:
app.logger.error("make_mobi: kindlegen failed with error while converting book") app.logger.error("make_mobi: kindlegen failed with error while converting book")
return None return error_message, RET_FAIL
else: else:
app.logger.error("make_mobie: epub not found: %s.epub" % file_path) app.logger.error("make_mobi: epub not found: %s.epub" % file_path)
return None return None, RET_FAIL
class StderrLogger(object): class StderrLogger(object):
@ -204,13 +219,11 @@ def send_mail(book_id, kindle_mail, calibrepath):
if 'mobi' in formats: if 'mobi' in formats:
msg.attach(get_attachment(formats['mobi'])) msg.attach(get_attachment(formats['mobi']))
elif 'epub' in formats: elif 'epub' in formats:
filepath = make_mobi(book.id, calibrepath) data, resultCode = make_mobi(book.id, calibrepath)
if filepath is not None: if resultCode == RET_SUCCESS:
msg.attach(get_attachment(filepath)) msg.attach(get_attachment(data))
elif filepath is None: else:
return _("Could not convert epub to mobi") return data #_("Could not convert epub to mobi")
elif 'pdf' in formats:
msg.attach(get_attachment(formats['pdf']))
elif 'pdf' in formats: elif 'pdf' in formats:
msg.attach(get_attachment(formats['pdf'])) msg.attach(get_attachment(formats['pdf']))
else: else: