GitHub repository with the Mule project can be found at the end of the post.
data:image/s3,"s3://crabby-images/71baa/71baa4dce8ba0b6405d1e844128427f526abf0a0" alt=""
Mule 4 has a Cryptography module which includes these 3 different strategies:
PGP
XML
JCE
In this article, we will see the PGP technique.
PGP
Pretty Good Privacy (PGP) is a cryptographic way that allows secure communication between two entities. It uses the public and private key concepts to encrypt the data as shown in the below diagram.
data:image/s3,"s3://crabby-images/d9e58/d9e581e9f179996592e8304a86181b56affa707e" alt=""
Prerequisites
1. Install the Crypto Module from Exchange, located in the Mule palette.
Note: Here is the reference documentation on how to install new modules to your Mule Project: Adding Modules to Your Project.
data:image/s3,"s3://crabby-images/e3a64/e3a64016597d8d98217a1c375452582be1e74502" alt=""
2. Create private and public keys
Please follow the below steps to generate a public/private key pair:
data:image/s3,"s3://crabby-images/31dba/31dba50e9d9287d1ce50ff84dd569f245f93364d" alt=""
Once the keys are generated, export them to the file system.
data:image/s3,"s3://crabby-images/1c14c/1c14c24a5a8e45316865c6bc6f298b001d31cc44" alt=""
The generated files are of ASC format, which is not supported by Mule yet, so we need to dearmor the keys first. Run the following command: "./gpg --dearmor <PATH_TO_YOUR_ASC_FILE>" for each of the keys. This command will create new files alongside the ASC files that will have .gpg appended to their filename which are supported in Mule.
data:image/s3,"s3://crabby-images/c38b3/c38b346823993f03b2e90ea89d0075c5811e5bba" alt=""
This is what you will get after following the previous steps:
Public/Private keys
Fingerprint
Passphrase
KeyId
Mule Code Implementation
We will limit our scope to PGP encrypt/decrypt operation in this article.
Global configurations
Create 2 global configurations:
Encryption – Configure public key, keyId, and fingerprint.
Decryption – Configure private key, keyId, and fingerprint.
data:image/s3,"s3://crabby-images/15931/15931d40e1bed38eba080ac478993e187240a5f9" alt=""
Usage
1. Encryption/Decryption of entire payload
Encryption:
data:image/s3,"s3://crabby-images/d9dfc/d9dfc2d8740896634c7203dd183079dae5bd0efd" alt=""
Output:
data:image/s3,"s3://crabby-images/92451/92451c3a5e45b3070d6953806d62e578a4062f1b" alt=""
Decryption:
data:image/s3,"s3://crabby-images/aa313/aa313875321cb2e259d0b27a6d4c8507e718f736" alt=""
Output:
data:image/s3,"s3://crabby-images/cb680/cb680afcb5625af12435be64f501987266a79592" alt=""
2. Encryption/Decryption at field level
This is a very common non-functional requirement where sensitive fields should be encrypted.
For this, we can still reuse the pgp-encryption-flow and pgp-decryption-flow flows. The only change would be the way we refer to these flows from the main flow, and for that, the DataWeave lookup function is very useful.
Encryption:
data:image/s3,"s3://crabby-images/a9aec/a9aecdf85c16cabe823962f7242424a5884f9299" alt=""
Output:
data:image/s3,"s3://crabby-images/4985f/4985fb9b814355fe965904272389085b9712902e" alt=""
Decryption:
data:image/s3,"s3://crabby-images/2a66a/2a66a67aec5de842107ed21753da7970fab97952" alt=""
Output:
data:image/s3,"s3://crabby-images/a0755/a0755330a3e411817fa440bcadb2e18233b4d6d9" alt=""
Conclusion
So far we learned Mule code implementation for PGP. You can set this Mule code as a common service that will help to achieve the encryption/decryption non-functional requirement in many APIs.
Here are the 2 ways to set up this Mule code as a common service:
Externalize the flow and publish it on the Anypoint Exchange.
Create a common API, which will encrypt/decrypt the payload.
Awesome post, Vikalp! Looking forward to part 2 :)