2010-10-26 18:18:46 +01:00
|
|
|
#!/usr/bin/env python
|
2012-11-07 13:14:25 +00:00
|
|
|
# vim:fileencoding=UTF-8:ts=4:sw=4:sta:et:sts=4:ai
|
2010-10-26 18:18:46 +01:00
|
|
|
|
2010-11-11 22:11:36 +00:00
|
|
|
# eReaderPDB2PML_plugin.py
|
2010-10-26 18:18:46 +01:00
|
|
|
# Released under the terms of the GNU General Public Licence, version 3 or
|
|
|
|
# later. <http://www.gnu.org/licenses/>
|
|
|
|
#
|
|
|
|
# All credit given to The Dark Reverser for the original standalone script.
|
|
|
|
# I had the much easier job of converting it to Calibre a plugin.
|
|
|
|
#
|
|
|
|
# This plugin is meant to convert secure Ereader files (PDB) to unsecured PMLZ files.
|
|
|
|
# Calibre can then convert it to whatever format you desire.
|
|
|
|
# It is meant to function without having to install any dependencies...
|
2010-12-30 22:41:07 +00:00
|
|
|
# other than having Calibre installed, of course.
|
2010-10-26 18:18:46 +01:00
|
|
|
#
|
|
|
|
# Installation:
|
|
|
|
# Go to Calibre's Preferences page... click on the Plugins button. Use the file
|
|
|
|
# dialog button to select the plugin's zip file (eReaderPDB2PML_vXX_plugin.zip) and
|
|
|
|
# click the 'Add' button. You're done.
|
|
|
|
#
|
|
|
|
# Configuration:
|
|
|
|
# Highlight the plugin (eReader PDB 2 PML) and click the
|
|
|
|
# "Customize Plugin" button on Calibre's Preferences->Plugins page.
|
|
|
|
# Enter your name and the last 8 digits of the credit card number separated by
|
|
|
|
# a comma: Your Name,12341234
|
|
|
|
#
|
|
|
|
# If you've purchased books with more than one credit card, separate the info with
|
|
|
|
# a colon: Your Name,12341234:Other Name,23452345
|
|
|
|
# NOTE: Do NOT put quotes around your name like you do with the original script!!
|
|
|
|
#
|
|
|
|
# Revision history:
|
2010-11-11 22:11:36 +00:00
|
|
|
# 0.0.1 - Initial release
|
|
|
|
# 0.0.2 - updated to distinguish it from earlier non-openssl version
|
2010-12-30 22:41:07 +00:00
|
|
|
# 0.0.3 - removed added psyco code as it is not supported under Calibre's Python 2.7
|
2011-06-16 06:59:20 +01:00
|
|
|
# 0.0.4 - minor typos fixed
|
|
|
|
# 0.0.5 - updated to the new calibre plugin interface
|
2012-11-07 13:14:25 +00:00
|
|
|
# 0.0.6 - unknown changes
|
|
|
|
# 0.0.7 - improved config dialog processing and fix possible output/unicode problem
|
2010-10-26 18:18:46 +01:00
|
|
|
|
|
|
|
import sys, os
|
|
|
|
|
|
|
|
from calibre.customize import FileTypePlugin
|
2011-06-16 06:59:20 +01:00
|
|
|
from calibre.ptempfile import PersistentTemporaryDirectory
|
|
|
|
from calibre.constants import iswindows, isosx
|
2010-10-26 18:18:46 +01:00
|
|
|
|
|
|
|
class eRdrDeDRM(FileTypePlugin):
|
|
|
|
name = 'eReader PDB 2 PML' # Name of the plugin
|
|
|
|
description = 'Removes DRM from secure pdb files. \
|
|
|
|
Credit given to The Dark Reverser for the original standalone script.'
|
|
|
|
supported_platforms = ['linux', 'osx', 'windows'] # Platforms this plugin will run on
|
|
|
|
author = 'DiapDealer' # The author of this plugin
|
2012-11-07 13:14:25 +00:00
|
|
|
version = (0, 0, 7) # The version number of this plugin
|
2010-10-26 18:18:46 +01:00
|
|
|
file_types = set(['pdb']) # The file types that this plugin will be applied to
|
|
|
|
on_import = True # Run this plugin during the import
|
2011-06-16 06:59:20 +01:00
|
|
|
minimum_calibre_version = (0, 7, 55)
|
2010-10-26 18:18:46 +01:00
|
|
|
|
|
|
|
def run(self, path_to_ebook):
|
2012-11-07 13:14:25 +00:00
|
|
|
from calibre_plugins.erdrpdb2pml import erdr2pml, outputfix
|
|
|
|
|
|
|
|
if sys.stdout.encoding == None:
|
|
|
|
sys.stdout = outputfix.getwriter('utf-8')(sys.stdout)
|
|
|
|
else:
|
|
|
|
sys.stdout = outputfix.getwriter(sys.stdout.encoding)(sys.stdout)
|
|
|
|
if sys.stderr.encoding == None:
|
|
|
|
sys.stderr = outputfix.getwriter('utf-8')(sys.stderr)
|
|
|
|
else:
|
|
|
|
sys.stderr = outputfix.getwriter(sys.stderr.encoding)(sys.stderr)
|
2010-10-26 18:18:46 +01:00
|
|
|
|
|
|
|
global bookname, erdr2pml
|
|
|
|
|
|
|
|
infile = path_to_ebook
|
|
|
|
bookname = os.path.splitext(os.path.basename(infile))[0]
|
|
|
|
outdir = PersistentTemporaryDirectory()
|
|
|
|
pmlzfile = self.temporary_file(bookname + '.pmlz')
|
|
|
|
|
|
|
|
if self.site_customization:
|
|
|
|
keydata = self.site_customization
|
|
|
|
ar = keydata.split(':')
|
|
|
|
for i in ar:
|
|
|
|
try:
|
|
|
|
name, cc = i.split(',')
|
2012-11-07 13:14:25 +00:00
|
|
|
#remove spaces at start or end of name, and anywhere in CC
|
|
|
|
name = name.strip()
|
|
|
|
cc = cc.replace(" ","")
|
2010-10-26 18:18:46 +01:00
|
|
|
except ValueError:
|
|
|
|
print ' Error parsing user supplied data.'
|
|
|
|
return path_to_ebook
|
2012-11-07 13:14:25 +00:00
|
|
|
|
2010-10-26 18:18:46 +01:00
|
|
|
try:
|
|
|
|
print "Processing..."
|
|
|
|
import time
|
|
|
|
start_time = time.time()
|
|
|
|
pmlfilepath = self.convertEreaderToPml(infile, name, cc, outdir)
|
|
|
|
|
|
|
|
if pmlfilepath and pmlfilepath != 1:
|
|
|
|
import zipfile
|
|
|
|
print " Creating PMLZ file"
|
|
|
|
myZipFile = zipfile.ZipFile(pmlzfile.name,'w',zipfile.ZIP_STORED, False)
|
|
|
|
list = os.listdir(outdir)
|
|
|
|
for file in list:
|
|
|
|
localname = file
|
|
|
|
filePath = os.path.join(outdir,file)
|
|
|
|
if os.path.isfile(filePath):
|
|
|
|
myZipFile.write(filePath, localname)
|
|
|
|
elif os.path.isdir(filePath):
|
|
|
|
imageList = os.listdir(filePath)
|
|
|
|
localimgdir = os.path.basename(filePath)
|
|
|
|
for image in imageList:
|
|
|
|
localname = os.path.join(localimgdir,image)
|
|
|
|
imagePath = os.path.join(filePath,image)
|
|
|
|
if os.path.isfile(imagePath):
|
|
|
|
myZipFile.write(imagePath, localname)
|
|
|
|
myZipFile.close()
|
|
|
|
end_time = time.time()
|
|
|
|
search_time = end_time - start_time
|
|
|
|
print 'elapsed time: %.2f seconds' % (search_time, )
|
|
|
|
print "done"
|
|
|
|
return pmlzfile.name
|
|
|
|
else:
|
|
|
|
raise ValueError('Error Creating PML file.')
|
|
|
|
except ValueError, e:
|
|
|
|
print "Error: %s" % e
|
|
|
|
pass
|
|
|
|
raise Exception('Couldn\'t decrypt pdb file.')
|
|
|
|
else:
|
|
|
|
raise Exception('No name and CC# provided.')
|
|
|
|
|
|
|
|
def convertEreaderToPml(self, infile, name, cc, outdir):
|
|
|
|
|
|
|
|
print " Decoding File"
|
|
|
|
sect = erdr2pml.Sectionizer(infile, 'PNRdPPrs')
|
2011-10-28 07:24:15 +01:00
|
|
|
er = erdr2pml.EreaderProcessor(sect, name, cc)
|
2010-10-26 18:18:46 +01:00
|
|
|
|
|
|
|
if er.getNumImages() > 0:
|
|
|
|
print " Extracting images"
|
|
|
|
#imagedir = bookname + '_img/'
|
|
|
|
imagedir = 'images/'
|
|
|
|
imagedirpath = os.path.join(outdir,imagedir)
|
|
|
|
if not os.path.exists(imagedirpath):
|
|
|
|
os.makedirs(imagedirpath)
|
|
|
|
for i in xrange(er.getNumImages()):
|
|
|
|
name, contents = er.getImage(i)
|
|
|
|
file(os.path.join(imagedirpath, name), 'wb').write(contents)
|
|
|
|
|
|
|
|
print " Extracting pml"
|
|
|
|
pml_string = er.getText()
|
|
|
|
pmlfilename = bookname + ".pml"
|
|
|
|
try:
|
|
|
|
file(os.path.join(outdir, pmlfilename),'wb').write(erdr2pml.cleanPML(pml_string))
|
|
|
|
return os.path.join(outdir, pmlfilename)
|
|
|
|
except:
|
|
|
|
return 1
|
|
|
|
|
|
|
|
def customization_help(self, gui=False):
|
|
|
|
return 'Enter Account Name & Last 8 digits of Credit Card number (separate with a comma)'
|