We’ve added the following AES-256 Encrypt and Decrypt Pascal Script functions in v2020.2.29.0:
- Function psSimpleDecryptFile(Source, Destination, Key: String; IVAtBeginning: Boolean): Boolean;
- Function psSimpleEncryptFile(Source, Destination, Key: String; IVAtBeginning: Boolean): Boolean;
psSimpleEncryptFile and psSimpleDecryptFile can be used to cypher/decypher any file content using AES-256 as encryption standard. The code uses a safe block chaining mode like CFB and PKCS7 padding. If ‘IVAtBeginning‘ is TRUE, a random Initialization Vector will be computed, and stored at the beginning of the output binary buffer. It will generate the binary key using SHA-256 over the supplied ‘Key’ string, and will use AES-NI hardware instructions if your CPU supports it.
Some screenshots to get you started. Let’s begin with the encryption script. Source will be the directory of files you want to Encrypt. As Destination you’ll need to add a Pascal Script.
The Script itself, don’t forget to adjust the ctOut path and the ctKey Const:
Const
ctOut = 'C:\Test\Out\Encrypted\';
ctKey = '*-+Key0123456789';
Begin
// ... add your code here
If psSimpleEncryptFile(psFilePath+psFilename, ctOut+psFileName, ctKey, True) then
Begin
psExitCode:= 1;
psLogWrite(1, '', 'Encryption Successful: ' + psFilename + psFilePath);
End
Else
Begin
psExitCode:= 0;
psLogWrite(1, '', 'Encryption Error: ' + psFilePath + psFilename);
End;
End.
In case you want to Decrypt Files, Source will be the directory containg the encrypted files (AES-256). As Destination you’ll need to add a different Pascal Script. Same here, don’t forget to adjust the ctOut path and the ctKey Const.
Const
ctOut = 'C:\Test\Out\Encrypted\Decrypted\';
ctKey = '*-+Key0123456789';
Begin
psExitCode:= 1;
// ... add your code here
If psSimpleDecryptFile(psFilePath+psFilename, ctOut+psFileName, ctKey, True) then
Begin
psExitCode:= 1;
psLogWrite(1, '', 'Decryption Successful: ' + psFilename);
End
Else
Begin
psExitCode:= 0;
psLogWrite(1, '', 'Decryption Error: ' + psFilename);
End;
End.
If you need any help, please let us know.
Regards,
Limagito Team