This framework allow users to configure some data masking operations on Sandbox environments.
Mask SObject Framework is not an official Salesforce product, it has not been officially tested or documented by Salesforce.
The configuration is based on two objects:
- MaskSObject__c : object to mask with options such as the order sequence and the where clause
- MaskSObjectField___c : field to mask and the option of masking (erase, randomize ...)
To assign required pset run following command:
sfdx force:apex:execute -f scripts/assignPset.apex
If you want to insert demo data, please run following command:
sfdx force:apex:execute -f scripts/importDemo.apex
- With execute anonymous and the following code
- To run anonymisation on all objects
MaskSObjectUtils.executeBatch('%');
- To run on a particular SObject
MaskSObjectUtils.executeBatch('Contact');
- When creating / refreshing a sandbox:
WARNING: if you choose this option, you need a Partial Copy Sandbox or a Full Copy Sandbox and data configuration on Production.
- Manually using Launch Batch LWC
-
Randomize:
- Generate a X char String based on
Crypto.generateAesKey(128);
method where X is the number of characters of the input to anonymize.'SALESFORCE.COM FRANCE' => 'iih5e2UT0qGZ8fJaNCbTT'
- Generate a X char String based on
-
Random Luhn number
- Generate a number considered as valid by Luhn algorithm Luhn algorithm, the number of characters to generate is calculated from the original input field value.
-
Obfuscate:
- Replace and lowercase following chars (customizable in settings)
{'a', 'e', 'i', 'o', '1', '2', '5', '6'};
by'x'
'SALESFORCE.COM FRANCE' => 'sxlxsfxrcx.cxm frxncx'
- Replace and lowercase following chars (customizable in settings)
-
Erase:
-
'SALESFORCE.COM FRANCE' => ''
-
-
Replace:
- Actions Types:
- Hardcoded: You must insert an hardocoded value in Value__c field to replace the current field value with hardcoded one.
- Dictionary:
- You can choose different dictionary fields to replace the current value Firstname, Lastname, Fullname, Email, Company Name, Street.
- A random line from MaskSObjectDictionary.json file will be selected to fill the field.
Dictionary Firstname : 'Thomas' => 'Corie', Dictionary Fullname : 'John Doe' => 'Corie Joberne' ...
- Actions Types:
The data dictionary is stored in MaskSObjectDictionary.json StaticResource. You can edit this file and replace the current values with yours if you need more common names for a particular country for example.
Website used to generate the data https://www.mockaroo.com/
- Standard Email
- We mask only the part before the domain name
- We mask only the part before the domain name
- Standard Phone
- We mask only the part after the two first char
'0612345678' => '0600340078'
- We mask only the part after the two first char
You can customize some options by editing MaskSObjectSettings__mdt Default Custom Metadata
- Allow execution on prod : enable this option to be able to run the batch on PROD (otherwise soql query returns no rows)
- Configure the number of digits to preserve in standard Phone fields.
Checkout the repo and deploy it with sfdx:
sfdx force:source:deploy -p force-app
Use GitHub Salesforce Deploy Tool: