Encryption of the Data at Rest
- Akash Kumar Jaiswal (Unlicensed)
- Rohan Dhanwade (Deactivated)
- Ashhad Alam
When any Template executes, all temporary files are stored in a repository folder. To prevent it from misuse, you may want to secure the folder. You can secure the repository folder by encrypting data in the folder.
To encrypt the data, you need to create and configure a Keystore.
Creating a Keystore using Keytool
- Open Command Prompt.
- Go to the directory where JRE is installed (for example, C:/Program Files/Java/jre8/bin).
- Run the following Keytool command to create a Keystore.
For Windows:
keytool.exe -genseckey -keystore <Keystore_path> -storetype <store_type> -storepass <Keystore_password> -keyalg AES -keysize 256 -alias <alias_name> -keypass <Key_password>
For example:
keytool.exe -genseckey -keystore <> -storetype JCEKS -storepass changeit -keyalg AES -keysize 256 -alias <> -keypass changeit
For Linux:
keytool -genseckey -keystore <Keystore_path> -storetype <store_type> -storepass <Keystore_password> -keyalg AES -keysize 256 -alias <alias_name> -keypass <Key_password>
For example:
keytool -genseckey -keystore <> -storetype JCEKS -storepass changeit -keyalg AES -keysize 256 -alias <> -keypass changeit
where,
<Keystore_path> is the location of the Keystore. If the Keystore does not exist, the tool will create a new store.
<store_type> is the type of store. Only JCEKS is supported.
<Keystore_password> is the password related to the Keystore.
<alias_name> is the name to be given to the newly created key.
<Key_password> is the password protecting the use of the key.
The Keystore is generated at the specified location and exit from the Command Prompt.
Configuring Keystore in Adeptia Connect
- Login to Adeptia Connect as an administrator.
- Click Accounts > Settings.
- Expand the Server Node Settings in the left panel.
- Select the server node.
- Click Edit.
- Expand Systems > Data Encryption at rest.
Set the value in the below parameters:
Property NameDescriptionabpm.security.data.encryption.rest.enable To enable or disable data encryption at rest. The possible value can be either Yes or No. abpm.security.data.encryption.rest.keystoreLocation Location of the Keystore that will be used for data encryption. abpm.security.data.encryption.rest.alias Alias name for the key. abpm.security.data.encryption.rest.keystorePasword Password of the Keystore. abpm.security.data.encryption.rest.keyPassword Password of the Key. - Click Save.
- To reload the configuration, click Reload Configuration link.
A confirmation message is displayed that the configuration has been reloaded. Restart Connect Kernel and Connect WebRunner.
However, after you enable the encryption, the data stored before you enabled the encryption remains in plaintext. Therefore, before enabling the encryption it is advisable to run the Encryption utility to encrypt the existing data present in the repository. If you do not encrypt the existing data, before enabling the encryption, repository data displayed on the GUIs may not be displayed correctly.
If due to any reason if you have not encrypted the existing data and have executed the transaction with encryption enabled, then in the repository folder the data will be a combination of plaintext and encrypted text. Therefore, you must encrypt plaintext separately. To do this:
- Move all the plaintext data in a separate folder.
- Encrypt the folder using the Encryption utility.
- After the records are encrypted successfully, copy the data of the encrypted folder in the repository.
After you have encrypted the data, enable the Encrypting data at rest feature. When the utility executes, you will have the encrypted data in the repository including the previous one.