|
|
@ -21,8 +21,8 @@ if (typeof PDFJS === 'undefined') { |
|
|
|
typeof global !== 'undefined' ? global : this).PDFJS = {}; |
|
|
|
typeof global !== 'undefined' ? global : this).PDFJS = {}; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
PDFJS.version = '1.3.135'; |
|
|
|
PDFJS.version = '1.3.137'; |
|
|
|
PDFJS.build = 'b32cdf5'; |
|
|
|
PDFJS.build = 'b8e7efa'; |
|
|
|
|
|
|
|
|
|
|
|
(function pdfjsWrapper() { |
|
|
|
(function pdfjsWrapper() { |
|
|
|
// Use strict in our context only - users might not want it
|
|
|
|
// Use strict in our context only - users might not want it
|
|
|
@ -25684,6 +25684,7 @@ var utf8StringToString = sharedUtil.utf8StringToString; |
|
|
|
var warn = sharedUtil.warn; |
|
|
|
var warn = sharedUtil.warn; |
|
|
|
var Name = corePrimitives.Name; |
|
|
|
var Name = corePrimitives.Name; |
|
|
|
var isName = corePrimitives.isName; |
|
|
|
var isName = corePrimitives.isName; |
|
|
|
|
|
|
|
var isDict = corePrimitives.isDict; |
|
|
|
var DecryptStream = coreStream.DecryptStream; |
|
|
|
var DecryptStream = coreStream.DecryptStream; |
|
|
|
|
|
|
|
|
|
|
|
var ARCFourCipher = (function ARCFourCipherClosure() { |
|
|
|
var ARCFourCipher = (function ARCFourCipherClosure() { |
|
|
@ -27567,7 +27568,27 @@ var CipherTransformFactory = (function CipherTransformFactoryClosure() { |
|
|
|
error('unsupported encryption algorithm'); |
|
|
|
error('unsupported encryption algorithm'); |
|
|
|
} |
|
|
|
} |
|
|
|
this.algorithm = algorithm; |
|
|
|
this.algorithm = algorithm; |
|
|
|
var keyLength = dict.get('Length') || 40; |
|
|
|
var keyLength = dict.get('Length'); |
|
|
|
|
|
|
|
if (!keyLength) { |
|
|
|
|
|
|
|
// Spec asks to rely on encryption dictionary's Length entry, however
|
|
|
|
|
|
|
|
// some PDFs don't have it. Trying to recover.
|
|
|
|
|
|
|
|
if (algorithm <= 3) { |
|
|
|
|
|
|
|
// For 1 and 2 it's fixed to 40-bit, for 3 40-bit is a minimal value.
|
|
|
|
|
|
|
|
keyLength = 40; |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
// Trying to find default handler -- it usually has Length.
|
|
|
|
|
|
|
|
var cfDict = dict.get('CF'); |
|
|
|
|
|
|
|
var streamCryptoName = dict.get('StmF'); |
|
|
|
|
|
|
|
if (isDict(cfDict) && isName(streamCryptoName)) { |
|
|
|
|
|
|
|
var handlerDict = cfDict.get(streamCryptoName.name); |
|
|
|
|
|
|
|
keyLength = (handlerDict && handlerDict.get('Length')) || 128; |
|
|
|
|
|
|
|
if (keyLength < 40) { |
|
|
|
|
|
|
|
// Sometimes it's incorrect value of bits, generators specify bytes.
|
|
|
|
|
|
|
|
keyLength <<= 3; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
if (!isInt(keyLength) || |
|
|
|
if (!isInt(keyLength) || |
|
|
|
keyLength < 40 || (keyLength % 8) !== 0) { |
|
|
|
keyLength < 40 || (keyLength % 8) !== 0) { |
|
|
|
error('invalid key length'); |
|
|
|
error('invalid key length'); |
|
|
|