Securing your data in Watson OpenScale
To securely manage you data when you use Watson OpenScale, know exactly what data is stored and encrypted. Additionally, know how to delete any stored personal data. Data encryption by using customer-managed keys is supported by using Key Protect with Watson OpenScale.
What is Bring Your Own Key (BYOK)?
Bring your own key (BYOK) or bring your own encryption (BYOE) refers to the infrastructure and method by which cloud service clients can manage their own encryption software and keys. This infrastructure adds a layer of security that protects both data at rest and data in motion.
How your data is stored and encrypted
IBM Key Protect for IBM Cloud helps secure your sensitive data from unauthorized access or inadvertent employee release, meeting compliance-auditing standards. It provides mandatory control of user access requests to encryption keys and manages the entire lifecycle of keys from creation through application use, key archival, and key destruction. Offered as a Platform as a Service on the IBM Cloud™, Key Protect provisions and stores cryptographic keys that use FIPS 140-2 Level 3 certified (Federal Information Processing Standard) hardware security module (HSM) devices that are located within secure IBM data centers.
Protecting your sensitive data
You can add a higher level of encryption protection and control to your data at rest (when it is stored) and data in motion (when it is transported). Enable high encryption protection through integration with IBM® Key Protect for IBM Cloud™.
The data that you store in IBM Cloud is encrypted at rest by using a randomly generated key. If you need to control the encryption keys, you can integrate Key Protect. This process is commonly referred to as Bring your own keys (BYOK). With Key Protect you can create, import, and manage encryption keys. You can assign access policies to the keys, assign users or service IDs to the keys, or give the key access only to a specific service. The first 20 keys are offered at no cost.
About customer-managed keys
Watson OpenScale uses envelope encryption to implement customer-managed keys. Envelope encryption describes encrypting one encryption key with another encryption key. The key used to encrypt the actual data is known as a data encryption key (DEK). The DEK itself is never stored but is wrapped by a second key that is known as the key encryption key (KEK) to create a wrapped DEK. To decrypt data, the wrapped DEK is unwrapped to get the DEK. This process is possible only by accessing the KEK, which in this case is your root key that is stored in Key Protect.
Key Protect keys are secured by FIPS 140-2 Level 3 certified cloud-based hardware security modules (HSMs).
Enabling customer-managed keys
Integrating Key Protect with Watson Premium services involves the following steps in the IBM Cloud console.
- Create an instance of Key Protect.
- Add a root key to the Key Protect instance.
- Grant Key Protect access to all instances of your Watson service.
- Encrypt the Watson service data.
Working with customer-managed keys
You can integrate Watson OpenScale with IBM Key Protect for IBM Cloud by using the API by making user_preferences
calls. The following parameters apply:
- HTTP method: PUT
- URL: https://aiopenscale.cloud.ibm.com/openscale/{service-instance-id}/v2/user_preferences/user_root_key_crn
- Payload: {"user_root_key_crn": crn_from_step_1}
Case 1: Key Protect during initial set up
-
Provision a Watson OpenScale instance.
-
After you provision an instance, but before you do any other configuration, you must complete the following steps:
- Provision an instance of IBM Key Protect for IBM Cloud and obtain the instance
CRN
value. - Make an API call to Watson OpenScale /v2/user_preferences, and specify the
{"user_root_key_crn": crn_from_step_1}
variable.
- Provision an instance of IBM Key Protect for IBM Cloud and obtain the instance
-
Create a DataMart, for which a database configuration is created.
-
The configuration service makes an API call to IBM Key Protect for IBM Cloud specified by the
user_root_key_crn
property. The service returns a new encryption key in both a wrapped and unwrapped form. Use the unwrapped key form to encrypt the database password. The wrapped key form is persisted in instance properties. To decrypt a database password, use the wrapped key form to get the unwrapped key form either from cache or through API call to IBM Key Protect for IBM Cloud. Then, decryption is done by using the unwrapped key.
Case 2: Key Protect after set-up
- Provision a Watson OpenScale instance.
- After you provision an instance, initialize the system either by running the auto setup or by performing a manual configuration. In this scenario, the database configuration is created with a password that is not encrypted with the user's key protect root key.
- After configuration, you must provision an instance of IBM Key Protect for IBM Cloud and get the instance Cloud Reseource Name
CRN
value used as a unique ID for the resource. - Make an API call to Watson OpenScale /v2/user_preferences, and specify the
{"user_root_key_crn": crn_from_step_1}
variable. When you specify theuser_root_key_crn
variable, all instance secrets are automatically re-encrypted by using IBM Key Protect for IBM Cloud. If you delete theuser_root_key_crn
variable, all instance secrets are automatically re-encrypted by using global key. The actual re-encryption is the same as in the previous case, Case 1.
Deleting Watson OpenScale instances
The Watson OpenScale data retention policy describes how long your data is stored after you delete the service. The data retention policy is included in the Watson OpenScale service description, which you can find in the IBM Cloud Terms and Notices.
For more information, see the following topics:
-
IBM Key Protect for IBM Cloud helps you provision encrypted keys for apps across IBM Cloud services. This tutorial shows you how to create and add existing cryptographic keys by using the Key Protect dashboard, so you can manage data encryption from one central location.
-
IBM Key Protect for IBM Cloud integrates with a number of IBM Cloud services to enable encryption with customer-managed keys for those services. Encryption with customer-managed encryption keys is sometimes called Bring Your Own Key (BYOK).
-
Integrating with IBM Cloud Object Storage.
IBM Key Protect for IBM Cloud and IBM® Cloud Object Storage work together to help you own the security of your at-rest data. Learn how to add advanced encryption to your IBM® Cloud Object Storage resources by using the IBM Key Protect service.
-
You can create an instance of IBM Key Protect for IBM Cloud by using the IBM Cloud console or the IBM Cloud CLI.
Parent topic: Information security