Forms crypto engine
Describes the Optimizely Forms includes an encryption feature that lets you secure a form's submitted data and explains how to customize it.
Note
Optimizely Forms is only supported by MVC-based websites and HTML5-compliant browsers.
Optimizely Forms encryption components are as follows:
-
ICrypto
– Interface representing the mechanism (symmetric or asymmetric) used to encrypt plain text or decrypt cipher text. -
SymmetricCryptoBase
– Base class for symmetric crypto that uses symmetric algorithms to encrypt a plain text or decrypt a cipher text. This class follows a standard, so (in most cases) third parties need only to override how the key is initialized for the symmetric algorithm by using the functionSetKey(byte[] keyBytes)
. -
AesCrypto
– Specific symmetric crypto that usesAesManaged
as the symmetric algorithm for data encryption and decryption. This is the defaultSymmetricCrypto
used by Optimizely Forms. -
RsaCrypto
– Asymmetric crypto that uses (an asymmetric algorithm) to encrypt a plain text or decrypt a cipher text. This class follows a standard, so (in most cases) third parties need only to override how the key is initialized by using the functionÂSetKey(object input)
. -
IFormCryptoEngine
– Interface that supports encrypting and decrypting of form submission data. -
FormCryptoEngineBase
– The base class of the forms crypto engine is provided by Optimizely Forms. This class inheritsIFormCryptoEngine
. The default implementation includes RSA crypto (asymmetric) and AES crypto (symmetric), giving more data security options. This class is the most important, and in most cases, overriding exposed APIs of this class is enough to customize the data encryption and decryption following to be in line with their contexts. To do that, you initially need to create a class (for example,MyOwnFormCryptoEngine
) inheritingFormCryptoEngineBase
and then override the functions below.Initialize
– To initialize the engine's required parameters. The crypto keys (mentioned above) can be set up here by calling their set up functions.EncryptSubmission(Submission submission)
– To encrypt submission data. The default implementation of this function first uses AES crypto to encrypt data and then uses RSA crypto to encrypt the AES crypto key. Encrypted data, including submission data and the key of AES crypto, is returned as the final result. The engine sets up a random key for AES crypto by using the functionGenerateRandomSymmetricKey
below, which significantly improves data security.GenerateRandomSymmetricKey()
– This abstract function generates a random symmetric key AES crypto uses to encrypt data. It can be used if you want to use only one key for AES crypto encryption activities.DecryptSubmission(Submission submission)
– To decrypt encrypted submission data. By default, Optimizely Forms does not implement this function.
-
CryptoEngineFactory
– Factory to initialize the forms crypto engine based on a setting in theForms.config
file. After customizingFormCryptoEngineBase
with your class (for example,MyOwnFormCryptoEngine
), you can replace theAzureKeyVault
-related engine provided by Optimizely Forms with your engine. See the example below:
type="EPiServer.Forms.Core.Data.Internal.DdsEncryptedPermanentStorage, EPiServer.Forms.Core"
cryptoEngineType="full class name of MyOwnFormCryptoEngine, Your namespace"
Customize the AzureKeyVaultCryptoEngine
EPiServer.Forms
exposes the APIs necessary to customize the encryption feature with AzureKeyVault
. The default implementation of the forms crypto engine is provided in a separate package, EPiServer.Forms.Crypto.AzureKeyVault.
AzureKeyVaultCryptoEngine
 uses a symmetric algorithm for data encryption and decryption. The encryption key is stored in AzureKeyVault
, a service that enables users to store and use cryptographic keys within the Microsoft Azure environment. For details about AzureKeyVault
, see Encrypt form submission data.
DecryptedCSVDataExporter
– Exporter, which supports decrypted form data for users with correct access rights.
Updated 10 months ago