diff options
Diffstat (limited to 'vcl/source')
-rw-r--r-- | vcl/source/pdf/PDFEncryptor.cxx | 25 |
1 files changed, 5 insertions, 20 deletions
diff --git a/vcl/source/pdf/PDFEncryptor.cxx b/vcl/source/pdf/PDFEncryptor.cxx index a5425f014ae0..315a2c6e27cc 100644 --- a/vcl/source/pdf/PDFEncryptor.cxx +++ b/vcl/source/pdf/PDFEncryptor.cxx @@ -289,28 +289,13 @@ bool computeUDictionaryValue(EncryptionHashTransporter* i_pTransporter, sal_Int32 computeAccessPermissions(const vcl::PDFEncryptionProperties& i_rProperties, sal_Int32& o_rKeyLength, sal_Int32& o_rRC4KeyLength) { - /* - 2) compute the access permissions, in numerical form + o_rKeyLength = SECUR_128BIT_KEY; - the default value depends on the revision 2 (40 bit) or 3 (128 bit security): - - for 40 bit security the unused bit must be set to 1, since they are not used - - for 128 bit security the same bit must be preset to 0 and set later if needed - according to the table 3.15, pdf v 1.4 */ - sal_Int32 nAccessPermissions = 0xfffff0c0; + // for this value see PDF spec v 1.4, algorithm 3.1 step 4, where n is 16, + // thus maximum permitted value is 16 + o_rRC4KeyLength = 16; - o_rKeyLength = SECUR_128BIT_KEY; - o_rRC4KeyLength = 16; // for this value see PDF spec v 1.4, algorithm 3.1 step 4, where n is 16, - // thus maximum permitted value is 16 - - nAccessPermissions |= (i_rProperties.CanPrintTheDocument) ? 1 << 2 : 0; - nAccessPermissions |= (i_rProperties.CanModifyTheContent) ? 1 << 3 : 0; - nAccessPermissions |= (i_rProperties.CanCopyOrExtract) ? 1 << 4 : 0; - nAccessPermissions |= (i_rProperties.CanAddOrModify) ? 1 << 5 : 0; - nAccessPermissions |= (i_rProperties.CanFillInteractive) ? 1 << 8 : 0; - nAccessPermissions |= (i_rProperties.CanExtractForAccessibility) ? 1 << 9 : 0; - nAccessPermissions |= (i_rProperties.CanAssemble) ? 1 << 10 : 0; - nAccessPermissions |= (i_rProperties.CanPrintFull) ? 1 << 11 : 0; - return nAccessPermissions; + return i_rProperties.getAccessPermissions(); } } // end anonymous namespace |