Microsoft Double Key Encryption (DKE) Resources
CCKM provides support for Double Key Encryption (DKE) for Microsoft 365. With DKE, two keys are used to access content (such as files or documents) that is protected with the sensitivity labels that you apply when using any one of the supported Microsoft Office apps. You hold one key in CCKM, which you maintain full control over using Microsoft’s Double Key Encryption service. The other is securely stored within Microsoft Azure. To decrypt and gain access to the protected content, both keys are required. Since Microsoft holds only one of the keys, this solution ensures that Microsoft cannot independently access this content. Only your authorized users can access the protected content.
Only your highly confidential data should be protected by DKE, which is typically a small percentage of your organization’s overall data. For more information about DKE, guidance on what type of content to protect, the supported office applications, and other information, refer to Double Key Encryption.
DKE encryption workflow
- User adds a DKE label to a document. The Microsoft Office client connects to Azure RMS (Protection Service). - Note - For detailed information on DKE labeling requirements, see DKE labeling requirements for Office apps. - To learn about the minimum supported versions for sensitivity labels, see Minimum versions for sensitivity labels in Office apps. 
- User certificate, API templates, and Azure RMS key are sent to the Microsoft Office client. 
- Microsoft Office client requests CCKM for the DKE public key associated with the applied label. 
- CCKM verifies the request. After authorization succeeds, CCKM sends the DKE public key to the Microsoft Office client. 
- Microsoft Office client encrypts the document content with the content key. 
- Microsoft Office client encrypts the part of the metadata that controls access to the content with the DKE public key. 
- Microsoft Office client encrypts the encrypted metadata with the Azure RMS key. 
The content is protected with the double-encrypted content key, RMS key and DKE public key. The following illustration shows the DKE encryption workflow:

DKE decryption workflow
- User opens a document which has a DKE label. The Microsoft Office client first sends the double-encrypted metadata to Azure RMS (Protection Service). 
- Azure RMS (Protection Service) decrypts the double-encrypted metadata using the Azure RMS key and returns the simple-encrypted metadata. 
- Microsoft Office client sends the simple-encrypted metadata to CCKM and requests CCKM to decrypt it. 
- CCKM verifies the request and goes through the authorization process. When authorization passes successfully, CCKM decrypts the simple-encrypted metadata and returns the decrypted metadata to the Microsoft Office client. 
- Microsoft Office client uses the content key to decrypt the document. The user can view the document content. 
The following illustration shows the DKE decryption workflow:

The following are the high-level steps to configure DKE within Microsoft and CipherTrust Manager/CCKM:
Prerequisites
In preparation for deploying DKE, ensure that the following prerequisites are met:
- Ensure CipherTrust Manager/CCKM is installed and running. In addition, ensure to activate and install the CCKM license. Refer to the CipherTrust Manager Deployment Guide and Licensing for details. 
- The NTP server is added. Refer to Add an NTP Server for details. 
- Install a third-party CA certificate on the web interface. - Note - We recommend obtaining a CA-signed certificate for the web interface from trusted CAs that are part of the Microsoft Trusted Root Program. For more information, refer to Microsoft Trusted Root Program participants. 
- Ensure the following. - If you have a load balancer that terminates the TLS connection and has mTLS disabled, the load balancer has a valid TLS certificate signed by a trusted CA. 
- If you have a load balancer that doesn't terminate the TLS connection or you don't have a load balancer in front of CipherTrust Manager, CipherTrust Manager has a valid TLS certificate signed by a trusted CA. 
- Additional DNS record is configured with - dke.prefix and pointing to the same IP Address of the CipherTrust Manager or SSL Passthrough Load Balancer.
- Subject Alternative Name (SAN) in the TLS certificate includes - dke.prefixed DNS name, along with other DNS names associated with CipherTrust Manager or SSL Passthrough Load Balancer.
 
- Microsoft 365 E5 License: Windows clients must have a Microsoft 365 E5 license. Refer to information about system and licensing requirements for DKE for more information these licensing requirements. - Note - CCKM supports built-in sensitivity labeling with Office apps. CCKM does not support Azure Information Protection unified labeling client, which is to be deprecated in the future. 
- User Presence in Azure Directory: Users who have to create and share documents or files protected by DKE must be part of the Azure Active Directory (Azure AD) associated with the organization's tenant. - Note - DKE is tested on the Windows and iOS devices. It is not tested on macOS and Android devices. 
- To configure the B2B cross-tenant access settings, refer to Configure cross-tenant access settings for B2B collaboration. 
 
You can now Configure DKE on CCKM.
Configure DKE on CCKM
To configure DKE on CCKM, do the following:
- From the CCKM GUI or API, create a DKE endpoint. Refer to Creating Microsoft DKE Endpoints for details on how to create a DKE endpoint from the CCKM GUI or Creating Microsoft DKE Endpoints using the CCKM API. - Note - Only Azure AD users are currently supported. The email addresses included in the API call must be associated with a user Azure AD. The email address parameter an optional field applicable only if authorization_type is set to email. - If you specify one or more email addresses in a DKE endpoint, this field is validated against the User Principal Name (UPN) claim in the JWT received during the decrypt operation. The UPN is the unique sign-in identifier for each user in Microsoft Entra ID. For guest access, where the UPN claim might not be present in the token, the 'email' claim in the token is used instead. 
- A Microsoft Office 365 client user and email (if configured in CipherTrust Manager) must match. 
- The Issuer field must be specific to the tenant configured in the Microsoft Azure Portal. 
- The web interface port within CipherTrust Manager can be changed from the default port of 443 to another port. If you plan to change the default port for the CipherTrust Manager web interface, ensure to change it BEFORE configuring the Microsoft DKE service on CCKM. Also reflect this port change when creating a DKE endpoint on CCKM as part of the prerequisites for deploying DKE. Changing the default port AFTER configuring Microsoft DKE is not supported. 
 
Register DKE Service
After creating a DKE endpoint, register your DKE service from the Microsoft Azure portal.
Note
- When registering your DKE service, ensure that Application ID URI matches the FQDN of the CipherTrust Manager. In the case where you are using a load balancer in front of the CipherTrust Manager, ensure that Application ID URI matches the FQDN of the load balancer. You can only register one DKE service per one instance of CipherTrust Manager. 
- Also, ensure that the publisher domain on the Branding and Properties page is set to the domain in which CipherTrust Manager is deployed. For example, if CipherTrust Manager is - test.thalescpl.io, then ensure that the publisher domain includes- thalescpl.io.
Single Tenant Application
When to Use the Single Tenant Application
Single tenant applications are only available in the tenant they were registered in, also known as their home tenant. DKE-labeled data will only be used within home tenant, configured with one CCKM environment.
For more details, refer to Tenancy in Microsoft Entra ID.
Register a Single Tenant Application
To register a single tenant application.
- Sign in to the Microsoft Azure portal. 
- Under Azure services, click App registrations. 
- Click New registration. 
- Enter Name, like SingleTenantApplication. 
- Select Accounts in any organizational directory (Any Microsoft Entra ID tenant - Single Tenant) as the account type. 
- Under Redirect URI: - Select Web as the platform. 
- Enter the URI of CipherTrust Manager, like - https://dke.thalescpl.io.
 
- Click Register. 
Copy the Application (client) ID and Directory (tenant) ID.
Now configure the single tenant application that includes the following.
- Adding a Certificate or Secret. - Note - It is optional to add a certificate or secret. 
- You will get the credentials after adding a certificate or secret. You will need the credentials during the role-based authentication. 
 
- Note - It is optional to add the owner. 
Authenticate Tokens and ID Tokens
To authenticate the tokens and ID tokens.
- Go to the left pane, click Manage > Authentication. 
- Enable Access tokens 
- Enable ID Tokens. 
- Click Save. 
Adding a Certificate or Secret
To add a certificate or secret.
- Go to the left pane, click Manage > Certificates & secrets. 
- Click New client secret. The Add a client secret wizard is displayed. 
- Enter Description. 
- (Optional) Select the desired Expires (Expiry days) from the drop-down list. 
- Click Add. 
Copy the Value and Secret ID of the secret. You will need the Value and Secret ID to add an Azure connection on CCKM.
Adding an API Permission
For role-based authorization, the User.Read.All and RoleManagement.Read.Directory permissions are required to retrieve user details and their assigned roles.
To add an API permission.
- Go to the left pane, click Manage > API permissions. 
- Click Add a permission. The Request API permissions wizard is displayed. 
- Click Microsoft Graph. 
- Click Application permissions. 
- Add the - User.Read.Alland- RoleManagement.Read.Directorypermissions.- To add the - User.Read.Allpermission.- In the Select permissions search box, search for User. 
- Expand User from the result. 
- Select User.Read.All from the User list. 
 - To add the - RoleManagement.Read.Directorypermission.- In the Select permissions search box, search for RoleManagement. 
- Expand RoleManagement from the result. 
- Select RoleManagement.Read.Directory from the RoleManagement list. 
 
- Click Add permissions. 
- Click Grant admin consent for {tenant}. The Grant admin consent confirmation dialog box is displayed. 
- Click Yes. 
Note
If you do not have the admin rights, please ask your admin to grant the admin consent. You need to share the consent grant URI to your admin, like https://login.microsoftonline.com/{organization}/adminconsent?client_id={client-id}. In the URI, the {organization} is Directory (tenant) ID and {client-id} is Application (client) ID that you copied during the registration.
Exposing an API
Exposing an API includes adding the Application ID URI, adding a scope, and authorizing the client applications.
Adding the application ID URI.
- Go to the left pane, click Manage > Expose an API. 
- Click Add. The Edit application ID URI is displayed. 
- Enter Application ID URI, the URI of the CipherTrust Manager. 
- Click Save. 
Adding a scope.
- Click Add a scope. The Add a scope wizard is displayed. 
- Enter Scope name, like "user_impersonation". 
- Select the Consent as Admins and users. 
- Enter Admin consent display name. 
- Enter Admin consent description. 
- (Optional) Enter User consent display name. 
- (Optional) Enter User consent description. 
- (Optional) Enable State. 
- Click Add scope. 
Authorizing the client applications.
You need to authorize the Microsoft Office and Azure Information Protection applications. Perform the below steps for both the applications.
- Click Add a client application. The Add a client application wizard is displayed. 
- Enter Client ID. - Note - The Client ID of Microsoft Office and Azure Information Protection applications are - d3590ed6-52b3-4102-aeff-aad2292ab01cand- c00e9d32-3c8d-4a7d-832b-029040e7db99, respectively.
- Enable Authorized scopes. 
- Click Add application. 
Adding the Owner
To add the owner.
- Go to the left pane, click Manage > Owners. 
- Click Add owners. 
- Search and select the desired owner. 
- Click Select. 
Multitenant Application
When to Use the Multitenant Application
Multitenant applications are available to the users in both their home tenant and other tenants. Multitenant application can be used for the following.
- Cross-tenant access for B2B collaboration. 
- Sharing one DKE endpoint across multiple Azure tenants. 
- Using one CCKM environment for supporting DKE in multiple Azure tenants. For example Managed Service Providers need to create a multitenant application when their customers share one CCKM environment. 
For more details, refer to Tenancy in Microsoft Entra ID.
Register a Multitenant Application
Note
To trust the multitenant application, the admin of other tenant needs to add this application to their enterprise applications. The the admin of other tenant should enter and accept the consent grant URI, like https://login.microsoftonline.com/{organization}/adminconsent?client_id={client-id}.
Here, the {organization} is the Directory (tenant) ID of the other tenant and {client-id} is the Application (client) ID of the home tenant.
To create a multitenant application.
- Sign in to the Microsoft Azure portal. 
- Go to the left pane, click Authentication. 
- Click App registrations. 
- Click New registration. 
- Enter Name, like MultiTenantApplication. 
- Select Accounts in any organizational directory (Any Microsoft Entra ID tenant - Multitenant) as the account type. 
- Under Redirect URI: - Select Web as the platform 
- Enter the URI of CipherTrust Manager, like - https://dke.thalescpl.io.
 
- Click Register. 
Copy the Application (client) ID and Directory (tenant) ID.
Now configure the multitenant application that includes the following.
- Adding a Certificate or Secret. - Note - It is optional to add a certificate or secret. 
- You will get the credentials after adding a certificate or secret. You will need the credentials during the role-based authentication. 
 
- Note - It is optional to add the owner. 
Authenticate Tokens and ID Tokens
To authenticate the tokens and ID tokens.
- Go to the left pane, click Manage > Authentication. 
- Enable Access tokens 
- Enable ID Tokens. 
- Click Save. 
Adding a Certificate or Secret
To add a certificate or secret.
- Go to the left pane, click Manage > Certificates & secrets. 
- Click New client secret. The Add a client secret wizard is displayed. 
- Enter Description. 
- (Optional) Select the desired Expires (Expiry days) from the drop-down list. 
- Click Add. 
Copy the Value and Secret ID of the secret. You will need the Value and Secret ID to add an Azure connection on CCKM.
Adding an API Permission
For role-based authorization, the User.Read.All and RoleManagement.Read.Directory permissions are required to retrieve user details and their assigned roles.
To add an API permission.
- Go to the left pane, click Manage > API permissions. 
- Click Add a permission. The Request API permissions wizard is displayed. 
- Click Microsoft Graph. 
- Click Application permissions. 
- Add the - User.Read.Alland- RoleManagement.Read.Directorypermissions.- To add the - User.Read.Allpermission.- In the Select permissions search box, search for User. 
- Expand User from the result. 
- Select User.Read.All from the User list. 
 - To add the - RoleManagement.Read.Directorypermission.- In the Select permissions search box, search for RoleManagement. 
- Expand RoleManagement from the result. 
- Select RoleManagement.Read.Directory from the RoleManagement list. 
 
- Click Add permissions. 
- Click Grant admin consent for {tenant}. The Grant admin consent confirmation dialog box is displayed. 
- Click Yes. 
Note
If you do not have the admin rights, please ask your admin to grant the admin consent. You need to share the consent grant URI to your admin, like https://login.microsoftonline.com/{organization}/adminconsent?client_id={client-id}. In the URI, the {organization} is Directory (tenant) ID and {client-id} is Application (client) ID that you copied during the registration.
Exposing an API
Exposing an API includes adding the Application ID URI, adding a scope, and authorizing the client applications.
Adding the application ID URI.
- Go to the left pane, click Manage > Expose an API. 
- Click Add. The Edit application ID URI is displayed. 
- Enter Application ID URI, the URI of the CipherTrust Manager. 
- Click Save. 
Adding a scope.
- Click Add a scope. The Add a scope wizard is displayed. 
- Enter Scope name, like "user_impersonation". 
- Select the Consent as Admins and users. 
- Enter Admin consent display name. 
- Enter Admin consent description. 
- (Optional) Enter User consent display name. 
- (Optional) Enter User consent description. 
- (Optional) Enable State. 
- Click Add scope. 
Authorizing the client applications.
You need to authorize the Microsoft Office and Azure Information Protection applications. Perform the below steps for both the applications.
- Click Add a client application. The Add a client application wizard is displayed. 
- Enter Client ID. - Note - The Client ID of Microsoft Office and Azure Information Protection applications are - d3590ed6-52b3-4102-aeff-aad2292ab01cand- c00e9d32-3c8d-4a7d-832b-029040e7db99, respectively.
- Enable Authorized scopes. 
- Click Add application. 
Adding the Owner
To add the owner.
- Go to the left pane, click Manage > Owners. 
- Click Add owners. 
- Search and select the desired owner. 
- Click Select. 
Create the DKE sensitivity label and label policy
After successfully registering the DKE service, create the DKE sensitivity label from the Microsoft Compliance portal. To use the senstivity level, you need to publish it by creating a new label policy.
Create DKE Sensitivity Label
To create a DKE sensitivity label.
- Sign in to the Microsoft Compliance portal. 
- Go to the left pane, under the Solutions section, click lnformation protection > Labels. 
- Click Create a Label. The Label details tab of the New sensitivity label screen is displayed. 
Label details
- Enter Name. 
- Enter Display name. 
- (Optional) Select a Label Priority from the drop-down list. 
- Enter Description for users. 
- Click Next. The Scope tab is displayed. 
Scope
- Ensure that Files, Emails, and Schematized data assets (preview) are enabled. 
- Click Next. The Items tab is displayed. 
Items
- Enable Control access. 
- Enable Apply content marking. 
- Click Next. Within the Items tab, the Access control section is displayed. 
- Select Configure access control settings. 
- Select Assign permissions now from the Assign permissions now or let users decide? drop-down list. 
- Select Never from the User access to content expires drop-down list. 
- Select Never from the Allow offline access drop-down list. - Note - For labels that are configured to have Offline Access set to Never, the decrypt requests will be sent to the CipherTrust Manager. Otherwise, if labels are configured to have Offline Access set to Always, the decrypt requests will not be sent to the CipherTrust Manager. 
- Under Assign permissions to specific users and groups, click Assign permissions. The Assign permissions wizard is displayed. 
- Click Add all users and groups in your organization. 
- (Applicable to multitenant only) Add the email addresses or domains of the other tenants. - Click Add specific email addresses or domain. 
- Enter email addresses or domains. 
- Click Add. 
 
- Click Save. 
- Enable Use Double Key Encryption. 
- Enter DKE Endpoint URL. You can copy the desired DKE Endpoint URL from CCKM. Refer to the Viewing DKE endpoints section. 
- Click Next. The Content marking section is displayed. 
- (Optional) Enable Content marking. 
- Click Next. The Auto-labeling for files and emails section is displayed. 
- Click Next. The Groups & sites tab is displayed. 
Groups & sites
Click Next. The Schematized data assets (preview) tab is displayed.
Schematized data assets (preview)
Click Next. The Finish tab is displayed.
Finish
- Click Create Label. 
- Click Done. 
Create Policy
After creating the sensitivity label, the Publish Label wizard is displayed. Click Create new label policy to create a new label policy. Alternatively, you can also create a new label policy from the lnformation protection > Label policies section. The Labels to publish tab of the Create Policy screen is displayed.
Labels to publish
- Click Choose sensitivity labels to publish. The Sensitivity labels to publish wizard is displayed. 
- Select the Label that you have created above, from the list. 
- Click Add. 
- Click Next. The Admin units tab is displayed. 
Admin units
Click Next. The Users and groups tab is displayed.
Users and groups
- Enable Users and groups. 
- Click Next. The Settings tab is displayed. 
Settings
- Click Next. Within the Settings tab, the Documents section is displayed. 
- Select the label that you created above as the Default label. 
- Click Next. The Emails section is displayed. 
- Select the label that you created above as the Default label. 
- Click Next. The Meetings section is displayed. 
- Click Next. The Fabric and Power BI section is displayed. 
- Click Next. The Name tab is displayed. 
Name
- Enter the Name of the label policy. 
- (Optional) Enter Description. 
- Click Next. The Finish tab is displayed. 
Finish
- Click Submit. 
- Click Done. 
The new label policy is created. After a label is published by the defining policy, it can take up to 24 hours for a label to be made available (after the label policy is published) for use in a Microsoft 365 Apps, such as Word or PowerPoint.
Note
Microsoft DKE supports guest accounts for external users to open the encrypted documents. For more details, refer to Guest accounts for external users to open encrypted documents.