Set up app key vaults for Business Central online
APPLIES TO: Business Central 2020 release wave 2 and later
Note
Azure Active Directory is now Microsoft Entra ID. Learn more
AppSource apps for Business Central can be developed to get secrets from Azure Keys Vaults. The app key vault feature is readily available for use on the service by all App Source apps. However, there are some onboarding tasks required.
Important
With Business Central online, App key vaults can only be used with AppSource apps. They're not supported with per-tenant extensions.
Tip
You must also specify secrets in a key vault if you deploy Business Central as part of the Embed App program. Especially if you must support the Outlook add-in, in which case you must specify secrets for TEMPORARYDOCUMENTSTORAGEACCOUNT and TEMPORARYDOCUMENTSTORAGEKEY.
For more information about developing extensions with key vaults, see Using Key Vault Secrets in Business Central Extensions.
Create the Azure Key Vault with secrets
In this task, you create a key vault in Azure, and add the secrets that you want to make available to your extensions. An extension can use up to two key vaults, so you can create more than one.
There are different ways to create an Azure key vault. For example, you can use the Azure portal, Azure CLI, and more.
The easiest way is to use the Azure portal. For instructions, see Quickstart: Set and retrieve a secret from Azure Key Vault using the Azure portal.
For using other methods, see Azure Key Vault Developer's Guide.
Provision the key reader application in your Microsoft Entra tenant
Your Business Central online solution is configured to use a Microsoft Entra application for reading key vault secrets. The application is called Dynamics 365 Business Central ISV Key Vault Reader. Microsoft manages the key vault reader application, however, there are a couple tasks that you have to do to enable it. First, the application must be provisioned on your Microsoft Entra tenant, as described here.
To provision the key vault reader application, use the Microsoft Entra ID PowerShell module.
Open Windows PowerShell as an administrator.
Install the Microsoft Entra ID PowerShell module.
Install-Module AzureAD
Import the Microsoft Entra ID module.
Import-Module AzureAD
Connect to your Business Central Microsoft Entra tenant.
Run the following command:
Connect-AzureAD
Provide your sign-in name and password when prompted.
Create a Microsoft Entra service principal using the following command:
New-AzureADServicePrincipal -AppId 7e97dcfb-bcdd-426e-8f0a-96439602627a
7e97dcfb-bcdd-426e-8f0a-96439602627a
is the Application (client) ID of Microsoft's centralized Microsoft Entra application.This step provisions the application in your Microsoft Entra tenant, where it now "lives" together with your key vaults.
Grant the key vault reader application permission to your key vaults
The next task is to grant the key vault reader application permission to read secrets from your key vaults. The steps in this task are done from the Azure portal.
- Open the key vault in the portal.
- Select Access policies, then Add Access Policy.
- Set Secret Permissions to Get.
- Choose Select principal, and then in the pane on the right, search for either the application (client) ID 7e97dcfb-bcdd-426e-8f0a-96439602627a or the display name Dynamics 365 Business Central ISV Key Vault Reader.
- Select Add, then Save.
Contact Microsoft to enable the App Key Vault feature
Send an email to bcappkeyvaultonboard@microsoft.com to start the onboarding process following this guideline:
If it's a new AppSource app, you should send the email after you publish the app on Partner Center. When the app is onboarded to the app key vault, you then need to publish a new version of the app to Partner Center.
If it's an existing AppSource app, you can send the email at any time, but it only takes effect when you publish a new version of the app to Partner Center.
The onboarding process involves a manual verification step that verifies that you own the Microsoft Entra tenant that contains the key vaults.
Provide the following information in the email:
- Your Microsoft Entra tenant ID. Obtain this information from the Azure portal by going to the Microsoft Entra ID Overview page.
- Your AppSource extensions, including names and App IDs, that should be enabled to read secrets from your key vaults. Note: It is important that all your AppSource extensions that need access to a key vault are included, as it is not enough to just set the key vault property in your
app.json
manifest files. - Confirmation that the app is already published on AppSource.
- Optionally, a screenshot from the Azure portal showing the key vault and its access policies. The screenshot can help Microsoft catch configuration mistakes early in the process.
Related information
Security considerations with app key vaults
Monitoring and troubleshooting app key vaults
Configuring Business Central Server