calibre-web/cps/book_formats.py

120 lines
3.7 KiB
Python
Raw Normal View History

#!/usr/bin/env python
# -*- coding: utf-8 -*-
import logging
import uploader
import os
from flask_babel import gettext as _
__author__ = 'lemmsh'
2016-06-05 09:42:18 -07:00
logger = logging.getLogger("book_formats")
try:
from wand.image import Image
from wand import version as ImageVersion
use_generic_pdf_cover = False
except ImportError as e:
2016-06-05 12:28:30 -07:00
logger.warning('cannot import Image, generating pdf covers for pdf uploads will not work: %s', e)
use_generic_pdf_cover = True
2016-06-05 09:42:18 -07:00
try:
from PyPDF2 import PdfFileReader
from PyPDF2 import __version__ as PyPdfVersion
2016-06-05 09:42:18 -07:00
use_pdf_meta = True
except ImportError as e:
2016-06-05 12:28:30 -07:00
logger.warning('cannot import PyPDF2, extracting pdf metadata will not work: %s', e)
2016-06-05 09:42:18 -07:00
use_pdf_meta = False
2016-06-05 12:28:30 -07:00
try:
import epub
use_epub_meta = True
except ImportError as e:
2016-08-07 09:46:38 -07:00
logger.warning('cannot import epub, extracting epub metadata will not work: %s', e)
2016-06-05 12:28:30 -07:00
use_epub_meta = False
2016-06-18 06:50:32 -07:00
try:
import fb2
use_fb2_meta = True
except ImportError as e:
2016-08-07 09:46:38 -07:00
logger.warning('cannot import fb2, extracting fb2 metadata will not work: %s', e)
2016-06-18 06:50:32 -07:00
use_fb2_meta = False
2016-06-05 12:28:30 -07:00
def process(tmp_file_path, original_file_name, original_file_extension):
2016-06-05 12:28:30 -07:00
try:
if ".PDF" == original_file_extension.upper():
return pdf_meta(tmp_file_path, original_file_name, original_file_extension)
if ".EPUB" == original_file_extension.upper() and use_epub_meta is True:
2016-06-05 12:28:30 -07:00
return epub.get_epub_info(tmp_file_path, original_file_name, original_file_extension)
if ".FB2" == original_file_extension.upper() and use_fb2_meta is True:
return fb2.get_fb2_info(tmp_file_path, original_file_extension)
except Exception as e:
2016-06-05 12:28:30 -07:00
logger.warning('cannot parse metadata, using default: %s', e)
return default_meta(tmp_file_path, original_file_name, original_file_extension)
2016-06-05 09:52:28 -07:00
def default_meta(tmp_file_path, original_file_name, original_file_extension):
return uploader.BookMeta(
file_path=tmp_file_path,
extension=original_file_extension,
title=original_file_name,
author=u"Unknown",
cover=None,
description="",
tags="",
series="",
2017-03-02 03:59:35 -08:00
series_id="",
comments="",
2017-03-02 06:57:02 -08:00
languages="")
def pdf_meta(tmp_file_path, original_file_name, original_file_extension):
2016-06-05 09:42:18 -07:00
if use_pdf_meta:
2016-06-05 09:42:18 -07:00
pdf = PdfFileReader(open(tmp_file_path, 'rb'))
doc_info = pdf.getDocumentInfo()
else:
doc_info = None
if doc_info is not None:
author = doc_info.author if doc_info.author is not None else u"Unknown"
2016-08-07 14:32:55 -07:00
title = doc_info.title if doc_info.title is not None else original_file_name
subject = doc_info.subject
else:
author = u"Unknown"
title = original_file_name
subject = ""
return uploader.BookMeta(
file_path=tmp_file_path,
extension=original_file_extension,
title=title,
author=author,
cover=pdf_preview(tmp_file_path, original_file_name),
description=subject,
tags="",
series="",
2017-03-02 03:59:35 -08:00
series_id="",
comments="",
2017-03-02 06:57:02 -08:00
languages="")
def pdf_preview(tmp_file_path, tmp_dir):
if use_generic_pdf_cover:
return None
else:
cover_file_name = os.path.splitext(tmp_file_path)[0] + ".cover.jpg"
with Image(filename=tmp_file_path + "[0]", resolution=150) as img:
img.compression_quality = 88
img.save(filename=os.path.join(tmp_dir, cover_file_name))
return cover_file_name
def get_versions():
if not use_generic_pdf_cover:
IVersion=ImageVersion.MAGICK_VERSION
else:
IVersion=_(u'not installed')
if use_pdf_meta:
PVersion=PyPdfVersion
else:
PVersion=_(u'not installed')
return {'ImageVersion':IVersion,'PyPdfVersion':PVersion}