#include <SecurityHandler.h>
|
enum | Permission {
e_owner = 1,
e_doc_open,
e_doc_modify,
e_print,
e_print_high,
e_extract_content,
e_mod_annot,
e_fill_forms,
e_access_support,
e_assemble_doc
} |
|
enum | AlgorithmType { e_RC4_40 = 1,
e_RC4_128,
e_AES,
e_AES_256
} |
|
enum | OverloadedFunction {
has_CloneProc = 0x01,
has_AuthProc = 0x02,
has_AuthFailedProc = 0x04,
has_GetAuthDataProc = 0x08,
has_EditSecurDataProc = 0x10,
has_FillEncDictProc = 0x20
} |
|
Standard Security Handler is a standard password-based security handler.
Definition at line 22 of file SecurityHandler.h.
The algorithm to be used in encrypting and decrypting the document.
Enumerator |
---|
e_RC4_40 |
40-bit RC4 algorithm.
|
e_RC4_128 |
128-bit RC4 algorithm.
|
e_AES |
Use Crypt filters with 128-bit AES (Advanced Encryption Standard) algorithm.
|
e_AES_256 |
Use Crypt filters with 256-bit AES (Advanced Encryption Standard) algorithm.
|
Definition at line 101 of file SecurityHandler.h.
Enumerator |
---|
has_CloneProc |
|
has_AuthProc |
|
has_AuthFailedProc |
|
has_GetAuthDataProc |
|
has_EditSecurDataProc |
|
has_FillEncDictProc |
|
Definition at line 405 of file SecurityHandler.h.
Enumerator |
---|
e_owner |
the user has 'owner' rights (e.g. rights to change the document's security settings).
|
e_doc_open |
open and decrypt the document.
|
e_doc_modify |
edit the document more than adding or modifying text notes.
|
e_print |
print the document.
|
e_print_high |
high resolution print.
|
e_extract_content |
enable content extraction
|
e_mod_annot |
allow modifications to annotations
|
e_fill_forms |
allow changes to fill in forms
|
e_access_support |
content access for the visually impaired.
|
e_assemble_doc |
allow document assembly
|
Definition at line 26 of file SecurityHandler.h.
pdftron::SDF::SecurityHandler::SecurityHandler |
( |
AlgorithmType |
crypt_type | ) |
|
Create a Standard Security Handler.
- Parameters
-
crypt_type | The encryption algorithm identifier. |
pdftron::SDF::SecurityHandler::SecurityHandler |
( |
const char * |
name, |
|
|
int |
key_len, |
|
|
int |
enc_code |
|
) |
| |
Create a Standard Security Handler.
- Parameters
-
name | The name of the Standard Security Handler. |
key_len | The bit length of the encryption key (40 or 128 bit). |
enc_code | The encryption algorithm identifier. The number corresponds to the V entry in encryption dictionary. Currently allowed values are (see Table 3.18 in PDF Reference Manual v1.6 for more details):
- 1 : Encryption using 40-bit RC4 algorithm.
- 2 : Encryption using 128-bit RC4 algorithm. Available in PDF 1.4 and above.
- 3 : This algorithm was deprecated by PDF standard and is not supported.
- 4 : Encryption using Crypt filters and 128-bit AES (Advanced Encryption Standard) algorithm. Available in PDF 1.6 and above.
|
values for key_len and enc_code are 128 and 2 respectively.
pdftron::SDF::SecurityHandler::SecurityHandler |
( |
| ) |
|
pdftron::SDF::SecurityHandler::SecurityHandler |
( |
const SecurityHandler & |
s | ) |
|
virtual pdftron::SDF::SecurityHandler::~SecurityHandler |
( |
| ) |
|
|
virtual |
virtual bool pdftron::SDF::SecurityHandler::Authorize |
( |
Permission |
p | ) |
|
|
virtual |
The method is called when a user tries to set security for an encrypted document and when a user tries to open a file. It must decide, based on the contents of the authorization data structure, whether or not the user is permitted to open the file, and what permissions the user has for this file.
- Note
- - This callback must not obtain the authorization data (e.g. by displaying a user interface into which a user can type a password). This is handled by the security handler's GetAuthorizationData(), which must be called before this callback. Instead, Authorize() should work with authorization data it has access to.
- Parameters
-
p | - permission to authorize |
virtual void pdftron::SDF::SecurityHandler::AuthorizeFailed |
( |
| ) |
|
|
virtual |
A callback method indicating repeated failed authorization. Override this callback in order to provide a UI feedback for failed authorization. Default implementation returns immediately.
void pdftron::SDF::SecurityHandler::ChangeMasterPassword |
( |
const char * |
password, |
|
|
size_t |
pwd_length |
|
) |
| |
Set the new master password to a binary string
- Parameters
-
password | the new user password |
void pdftron::SDF::SecurityHandler::ChangeMasterPassword |
( |
const pdftron::UString & |
password | ) |
|
Sets the new master/owner password.
- Parameters
-
password | The new master/owner password. |
void pdftron::SDF::SecurityHandler::ChangeMasterPassword |
( |
const std::vector< pdftron::UInt8 > & |
password_buf | ) |
|
Sets the new master/owner password.
- Parameters
-
password_buf | The new master/owner password. |
void pdftron::SDF::SecurityHandler::ChangeMasterPasswordASCII |
( |
const char * |
password | ) |
|
Set the new master password to an ASCII text string
- Parameters
-
password | the new master/owner password |
void pdftron::SDF::SecurityHandler::ChangeRevisionNumber |
( |
int |
rev_num | ) |
|
Change the revision number and the encryption algorithm of the standard security handler.
- Parameters
-
rev_num | the new revision number of the standard security algorithm. Currently allowed values for the revision number are (see Table 3.18 in PDF Reference Manual v1.6 for more details):
- 2 : Encryption using 40-bit RC4 algorithm.
- 3 : Encryption using 128-bit RC4 algorithm. Available in PDF 1.4 and above.
- 4 : Encryption using Crypt filters and 128-bit AES (Advanced Encryption Standard) algorithm. Available in PDF 1.6 and above.
|
void pdftron::SDF::SecurityHandler::ChangeUserPassword |
( |
const char * |
password, |
|
|
size_t |
pwd_length |
|
) |
| |
Set the new user password to a binary string
- Parameters
-
password | the new user password |
void pdftron::SDF::SecurityHandler::ChangeUserPassword |
( |
const pdftron::UString & |
password | ) |
|
Sets the new user password.
- Parameters
-
password | The new user password. |
void pdftron::SDF::SecurityHandler::ChangeUserPassword |
( |
const std::vector< pdftron::UInt8 > & |
password_buf | ) |
|
Sets the new user password.
- Parameters
-
password_buf | The new user password. |
void pdftron::SDF::SecurityHandler::ChangeUserPasswordASCII |
( |
const char * |
password | ) |
|
Set the new user password to an ASCII text string
- Parameters
-
password | the new user password |
virtual SecurityHandler* pdftron::SDF::SecurityHandler::Clone |
( |
TRN_SecurityHandler |
base | ) |
const |
|
virtual |
virtual bool pdftron::SDF::SecurityHandler::EditSecurityData |
( |
SDFDoc & |
doc | ) |
|
|
virtual |
Called when the security handler should activate a dialog box with the current security settings that may be modified.
- Returns
- true if the operation was successful false otherwise.
virtual Obj pdftron::SDF::SecurityHandler::FillEncryptDict |
( |
class SDFDoc & |
doc | ) |
|
|
virtual |
Called when an encrypted document is saved. Fills the document's Encryption dictionary with whatever information the security handler wants to store in the document.
The sequence of events during creation of the encrypt_dict is as follows:
- encrypt_dict is created (if it does not exist)
- Filter attribute is added to the dictionary
- call this method to allow the security handler to add its own attributes
- call the GetCryptKey to get the algorithm version, key, and key length
- checks if the V attribute has been added to the dictionary and, if not, then sets V to the algorithm version
- set the Length attribute if V is 2 or greater
- add the encrypt_dict to the document
- Parameters
-
doc | - The document to save. |
- Returns
- - encrypt_dict
- Warning
- - Unlike all other strings and streams, direct object elements of the encrypt_dict are not encrypted automatically. If you want them encrypted, you must encrypt them before inserting them into the dictionary.
virtual bool pdftron::SDF::SecurityHandler::GetAuthorizationData |
( |
Permission |
req_opr | ) |
|
|
virtual |
This method is invoked in case Authorize() failed. The callback must determine the user's authorization properties for the document by obtaining authorization data (e.g. a password through a GUI dialog).
The authorization data is subsequently used by the security handler's Authorize() to determine whether or not the user is authorized to open the file.
- Returns
- false if the operation was canceled, true otherwise.
- Parameters
-
req_opr | - the permission for which authorization data is requested. |
- Returns
- The derived class or NULL for standard security handler.
int pdftron::SDF::SecurityHandler::GetEncryptionAlgorithmID |
( |
| ) |
const |
- Returns
- The encryption algorithm identifier. A code specifying the algorithm to be used in encrypting and decrypting the document. Returned number corresponds to V entry in encryption dictionary. Currently allowed values are from 0-4. See PDF Reference Manual for more details.
const char* pdftron::SDF::SecurityHandler::GetHandlerDocName |
( |
| ) |
const |
- Returns
- The name of the security handler as it appears in the serialized file as the value of /Filter key in /Encrypt dictionary.
int pdftron::SDF::SecurityHandler::GetKeyLength |
( |
| ) |
const |
- Returns
- The length of the encryption key in bytes.
- Note
- The returned key length is given in bytes.
const char* pdftron::SDF::SecurityHandler::GetMasterPassword |
( |
| ) |
|
- Returns
- Current master (owner) password.
size_t pdftron::SDF::SecurityHandler::GetMasterPasswordSize |
( |
| ) |
const |
- Returns
- Length of the current owner password string. This has to be used when password is a non-ASCII string that may contain '\0' bytes.
bool pdftron::SDF::SecurityHandler::GetPermission |
( |
Permission |
p | ) |
|
- Returns
- true if the SecurityHandler permits the specified action (Permission p) on the document, or false if the permission was not granted.
- Parameters
-
p | A Permission to be granted. |
- Note
- in order to check for permission the method will repeatedly (up to three times) attempt to GetAuthorizationData() and Authorize() permission. If the permission is not granted AuthorizeFailed() callback will be called. This callback method allows derived class to provide UI feedback for failed authorization.
int pdftron::SDF::SecurityHandler::GetRevisionNumber |
( |
| ) |
|
- Returns
- the revision number of the standard security algorithm.
const char* pdftron::SDF::SecurityHandler::GetUserPassword |
( |
| ) |
|
- Returns
- Current user password.
size_t pdftron::SDF::SecurityHandler::GetUserPasswordSize |
( |
| ) |
const |
- Returns
- Length of the current user password string. This has to be used when password is a non-ASCII string that may contain '\0' bytes.
void pdftron::SDF::SecurityHandler::InitPassword |
( |
const char * |
password, |
|
|
size_t |
pwd_length |
|
) |
| |
void pdftron::SDF::SecurityHandler::InitPassword |
( |
const pdftron::UString & |
password | ) |
|
void pdftron::SDF::SecurityHandler::InitPassword |
( |
const std::vector< pdftron::UInt8 > & |
password_buf | ) |
|
void pdftron::SDF::SecurityHandler::InitPasswordASCII |
( |
const char * |
password | ) |
|
bool pdftron::SDF::SecurityHandler::IsAES |
( |
| ) |
const |
- Returns
- true is this security handler uses 128 bit AES (Advanced Encryption Standard) algorithm to encrypt strings or streams.
bool pdftron::SDF::SecurityHandler::IsAES |
( |
Obj |
stream | ) |
const |
The following function can be used to verify whether a given stream is encrypted using AES.
- Returns
- true if the given stream is encrypted using AES encryption.
- Parameters
-
stream | A pointer to an SDF::Stream object |
bool pdftron::SDF::SecurityHandler::IsMasterPasswordRequired |
( |
| ) |
|
bool pdftron::SDF::SecurityHandler::IsModified |
( |
| ) |
const |
bool pdftron::SDF::SecurityHandler::IsRC4 |
( |
| ) |
const |
- Returns
- true is this security handler uses RC4 algorithm to encrypt strings or streams.
bool pdftron::SDF::SecurityHandler::IsUserPasswordRequired |
( |
| ) |
|
bool pdftron::SDF::SecurityHandler::IsValid |
( |
| ) |
const |
pdftron::SDF::SecurityHandler::operator bool |
( |
| ) |
|
|
inline |
- Returns
- true if the object is not null, false otherwise.
Definition at line 299 of file SecurityHandler.h.
void pdftron::SDF::SecurityHandler::SetDerived |
( |
UInt32 |
overloaded_funct | ) |
|
This method informs base security handler which methods are overridden in the derived class. The only place this method needs to be invoked is in Create(name, key_len, enc_code) static factory method in the derived class.
- Parameters
-
overloaded_funct | A flag that specifies which functions are overloaded in the derived class. For example: SetDerived(SecurityHandler::has_Clone + SecurityHandler::has_FillEncDictProc); |
void pdftron::SDF::SecurityHandler::SetEncryptMetadata |
( |
bool |
encrypt_metadata | ) |
|
Indicates whether the document-level metadata stream is to be encrypted.
- Parameters
-
encrypt_metadata | true if metadata stream should be encrypted, false otherwise. |
- Note
- EncryptMetadata flag affects only Crypt filters available in PDF 1.5 (Acrobat 6) and later. By default, metadata stream will be encrypted.
void pdftron::SDF::SecurityHandler::SetModified |
( |
bool |
is_modified = true | ) |
|
The method allows derived classes to set SecurityHandler is modified flag. This method should be called whenever there are changes (e.g. a password change) to the SecurityHandler
- Parameters
-
void pdftron::SDF::SecurityHandler::SetPermission |
( |
Permission |
perm, |
|
|
bool |
value |
|
) |
| |
Set the permission setting of the StdSecurityHandler.
- Parameters
-
perm | indicates a permission to set or clear. It can be any of the following values: |
e_print // print the document. e_doc_modify // edit the document more than adding or modifying text notes. e_extract_content // enable content extraction e_mod_annot // allow modifications to annotations e_fill_forms // allow changes to fill in forms e_access_support // content access for the visually impaired. e_assemble_doc // allow document assembly e_print_high // high resolution print.
- Parameters
-
value | true if the permission/s should be granted, false otherwise. |
The documentation for this class was generated from the following file: