Foxit PDF SDK
|
Public Types | |
enum | ModifyFlag { e_ModifyPermission = 0x01, e_ModifyUserPassword = 0x02, e_ModifyOwnerPassword = 0x04 } |
(Only for AES-256) Enumeration for modify flag used to decide which security data or password will be modified during encryption process More... | |
![]() | |
enum | CipherType { e_CipherNone = 0, e_CipherRC4 = 1, e_CipherAES = 2 } |
Enumeration for Encryption Algorithm. More... | |
Public Member Functions | |
StdSecurityHandler () | |
Constructor. | |
StdSecurityHandler (const foxit::pdf::SecurityHandler &other) | |
Constructor, with parent class object. More... | |
bool | Initialize (const StdEncryptData &encrypt_data, const String &user_password, const String &owner_password) |
(Not support AES-256) Initialize current standard security handler. More... | |
bool | InitializeW (const StdEncryptData &encrypt_data, const WString &user_password, const WString &owner_password) |
(Only for AES-256) Initialize current standard security handler. More... | |
void | SetAES256ModifyFlags (uint32 modify_flags) |
(Only for AES-256) Set modify flags to decide which security data or password will be modified during encryption process. More... | |
![]() | |
SecurityHandler () | |
Constructor. | |
SecurityHandler (const SecurityHandler &other) | |
Constructor, with another security handler object. More... | |
virtual | ~SecurityHandler () |
Destructor. | |
virtual PDFDoc::EncryptType | GetSecurityType () |
Get the encryption type of current security handler. More... | |
bool | IsEmpty () const |
Check whether current object is empty or not. More... | |
bool | operator != (const SecurityHandler &other) |
Not equal operator. More... | |
SecurityHandler & | operator= (const SecurityHandler &other) |
Assign operator. More... | |
bool | operator== (const SecurityHandler &other) |
Equal operator. More... | |
![]() | |
FS_HANDLE | Handle () const |
Get the handle of current object. More... | |
This class represents a standard security handler, used for password encryption.
(Only for AES-256) Enumeration for modify flag used to decide which security data or password will be modified during encryption process
Values of this enumeration can be used alone or in combination.
Enumerator | |
---|---|
e_ModifyPermission | If set, user permissions and "is encrypt metadata" values (which are defined in StdEncryptData) will be modified during encryption process. |
e_ModifyUserPassword | If set, user password and owner password will be modified during encryption process. |
e_ModifyOwnerPassword | If set, only owner password will be modified during encryption process. |
|
explicit |
Constructor, with parent class object.
[in] | other | Parent class object. |
bool foxit::pdf::StdSecurityHandler::Initialize | ( | const StdEncryptData & | encrypt_data, |
const String & | user_password, | ||
const String & | owner_password | ||
) |
(Not support AES-256) Initialize current standard security handler.
[in] | user_password | A user password, which is used to open the PDF document. This can be empty when parameter owner_password is not empty. |
[in] | owner_password | An owner password, which is used to take ownership of the PDF document. This can be empty when parameter user_password is not empty. |
[in] | encrypt_data | A standard encrypt data object. In the encryption data, cipher type should not be SecurityHandler::e_CipherNone, or SecurityHandler::e_CipherAES with key length 32 (that means not support AES-256). Please refer to comment of class StdEncryptData to ensure the validation of each member. |
bool foxit::pdf::StdSecurityHandler::InitializeW | ( | const StdEncryptData & | encrypt_data, |
const WString & | user_password, | ||
const WString & | owner_password | ||
) |
(Only for AES-256) Initialize current standard security handler.
[in] | user_password | A user password, which is used to open the PDF document. This can be empty when parameter owner_password is not empty. |
[in] | owner_password | An owner password, which is used to take ownership of the PDF document. This can be empty when parameter user_password is not empty. |
[in] | encrypt_data | A standard encrypt data object. In the encryption data, cipher type should be SecurityHandler::e_CipherAES and key length should be 32. |
void foxit::pdf::StdSecurityHandler::SetAES256ModifyFlags | ( | uint32 | modify_flags | ) |
(Only for AES-256) Set modify flags to decide which security data or password will be modified during encryption process.
Modify flags are useful only when a PDF document has been encrypted by AES-256 and current StdSecurityHandler object is to be used to modify some security data or password for this PDF document. For other case, these modify flags will be ignored during encryption process. Security data and passwords are set through function StdSecurityHandler::InitializeW. If this function has not been called by current StdSecurityHandler object, that means to modify all the security data and password by default.
[in] | modify_flags | Modify flags used to decide which security data or password will be modified during encryption process. Please refer to values starting from StdSecurityHandler::e_ModifyPermission and this should be one or combination of these values. |