The high level steps required to configure the Azure Keyvault Orchestrator extension are:
To provision access to the Keyvault instance, we will:
For the Orchestrator to be able to interact with the instance of Azure Keyvault, we will need to create an entity in Azure that will encapsulate the permissions we would like to grant it. In Azure, these intermediate entities are referred to as app registrations and they provision authority for external application access. To learn more about application and service principals, refer to this article.
In order to complete these steps, you must have the Owner role for the Azure subscription, at least temporarily. This is required to create an App Registration in Azure Active Directory.
-
Log into your azure portal
-
Navigate to Azure active directory in the portal.
-
Select "App registrations" from the menu.
-
Click "+ New registration"
-
Give it a name such as "keyfactor-akv" and leave the first radio button selected
-
Once the entity has been created, you should be directed to the overview view.
-
From here, copy the Directory (tenant) ID.
-
Click on the underlined link above. You should see the managed application details that look similar to the below screen shot.
-
Copy the Application (client) ID, Object ID.
-
Now we have a App registration and values for Directory (tenant) ID, Application (client) ID and Object ID. These will be used by the integration for authentication to Azure.
In order to be able to discover and create new Azure Keyvault certificate stores, the app principal that we created must be provided with the "Keyvault Administrator" role at the Resource Group level.1 If there are multiple resource groups that will contain Key Vaults to be managed, you should repeat for each.
Here are the steps for assigning this role.
-
Navigate to the Azure portal and select a resource group that will contain the Keyvaults we would like to manage.
-
Select "Access control (IAM)" from the left menu.
-
Click "Add", then "Add Role Assignment" to create a new role assignment
-
Search and Select the "Key Vault Administrator" role.
-
Search and Select the principal we created.
-
Click "Review and Assign" and save the role assignment.
If you only need to manage a single instance of a Key Vault, you can provision access to the specific instance without needing to provide the service principal the "Keyvault Administrator" role at the resource group level.
Follow the below steps in order to provide management access for our service principal to a specific instance of a Key Vault:
-
Navigate to the Azure Portal and then to your instance of the Azure Keyvault
-
Go to "Access control (IAM)" in the navigation menu for the Key vault.
-
Click on "Add role assignment"
-
Find the Keyvault Administrator role in the list. Select it and click "Next"
-
On the next screen, click "Select members" and then search for the service principal we created above.
-
Select the service principal, click "select", and then "Next"
-
On the final screen, you should see something similar to the following:
-
Click "Review + assign" to finish assigning the role of Keyvault Administrator for this Key Vault to our service principal account.
Access to an Azure Key Vault instance can be granted via Role Based Access Control (RBAC) or with class Azure Resource Access Policies. The below steps are for provisioning access to a single instance of a Key Vault using Access Policies. If you are using RBAC at the resource group level we recommend following RBAC (above). Alternatively, you will need to assign explicit permissions to the service principal for any Key Vault that is using Access Policy for Access Control if the Key Vault should be managed with Keyfactor.
Following the below steps will provide our service principal with the ability to manage keys in an existing vault, without providing it the elevated permissions required for discovering existing vaults or creating new ones. If you've completed the steps in the previous section for the resource group that contains the Key Vault(s) you would like to manage and the Key Vault(s) are using RBAC, the below steps are not necessary.
-
Navigate to the Azure Portal and then to your instance of the Azure Keyvault.
-
Go to "Access Policies" in the navigation menu for the Key vault.
-
Click "+ Add Access Policy"
-
In the first drop-down, you can select "Certificate Management". This will select all certificate management permissions.
-
Click "Select Principal" to open the search pane.
-
Find the Application Registration we created above, select it, and click "Select".
-
Leave "Authorized application" unselected.
-
Click "Add".
-
After you are redirected to the "Access policies" view, you should see the App Registration listed under "APPLICATION".
-
Click "Save" at the top of this view.
For authenticating to Azure via our App Registration, we will need to generate an access token.
- Navigate to the App Registration we created earlier, in Azure Active Directory.
- Select "Certificates & Secrets" from the left menu.
- Click "+ New client secret"
- Give it a description such as "Keyfactor access"
- Select a valid expiration
- Click "Add".
- Copy the "Value" of the secret before navigating away.
Now we have our App registration created in Azure, and we have the following values
- TenantId
- ApplicationId
- ObjectId
- ClientSecret
We will store these values securely in Keyfactor in subsequent steps.
In Keyfactor Command create a new Certificate Store Type similar to the one below:
- Name – Required. The display name of the new Certificate Store Type
- Short Name – Required. MUST be "AKV"
- Needs Server, Blueprint Allowed, Requires Store Password, Supports Entry Password – All unchecked as shown
- Supports Custom Alias – Optional. Not used.
- Use PowerShell – Unchecked
- Store PathType – Freeform (user will enter the the location of the store). Format => [VaultName].vault.azure.net. See "VaultName" under "Custom Parameters" below.
- Private Keys – Required (a certificate in a Azure Key Vault will contain a private key)
- PFX Password Style – Default
- Job Types – Inventory, Add and Remove are the job types implemented by this AnyAgent
- Custom Parameters :
- TenantID – Required . The ID of the Azure Active Directory (obtained from Properties menu of the subscription's Azure Active Directory – on this page it is called "Directory ID")
- ResourceGroupName – Required . The resource group name to which the Key Vault(s) belong. Can be found by clicking on the vault being managed and finding the "Resource group" at the top of the page.
- ApplicationId – Required . The ID of the API Application you are using to communicate with the Azure Key Vault (obtained from the App registration found under the App registrations menu of the subscription's Azure Active Directory)
- ClientSecret – Required . The secret value given to you when you created a key for the API application.
- SubscriptionId – Required . The ID of the subscription the Azure Key Vault(s) reside in (obtained from the Properties menu of the Subscription under the Subscriptions menu)
- APIObjectId – Required . The object ID of the API Application. This is found by searching for your app in "Enterprise Applications" (Object Id). This value may be different than the one found in "App Registrations". Use the Enterprise one.
- VaultName – Required . The name of the vault being managed.
Next to the parameters listbox in the Certificate Store Types dialog, click the <ADD> button. You should see the dialog below, with the values for TenantId filled in:
- Name – Required . For each parameter _ must _ match the name shown above.
- Display Name – Required. The label that will show when adding or editing a specific AKV certificate store.
- Type – Required. Will be "string" for all of the above.
- Required – Checked for all parameters above.
- Depends On Other – Unchecked for all parameters above.
- Default Value – Leave blank for all parameters above.
Open the Keyfactor Windows Agent Configuration Wizard and perform the tasks as illustrated below:
- Click <Next>
- If you have configured the agent service previously, you should be able to skip to just click <Next>. Otherwise, enter the service account Username and Password you wish to run the Keyfactor Windows Agent Service under, click <Update Windows Service Account> and click <Next>.
- If you have configured the agent service previously, you should be able to skip to just re-enter the password to the service account the agent service will run under, click <Validate Keyfactor Connection> and then <Next>.
- Select the agent you are adding capabilities for (in this case, Azure Key Vault, and also select the specific capabilities (Inventory and Management in this example). Click <Next>.
- For agent configuration purposes, this screen can be skipped by clicking <Next>.
- For each AnyAgent implementation, check Load assemblies containing extension modules from other location , browse to the location of the compiled AnyAgent dlls, and click <Validate Capabilities>. Once all AnyAgents have been validated, click <Apply Configuration>.
- If the Keyfactor Agent Configuration Wizard configured everything correctly, you should see the dialog above.
3. Create an AKV Certificate Store within Keyfactor Command
Navigate to Certificate Locations => Certificate Stores within Keyfactor Command to add an Azure Key Vault certificate store. Below are the values that should be entered.
- Category – Required. The Azure Key Vault category name must be selected.
- Container – Optional. Select a container if utilized.
- Client Machine – Required. The server name or IP Address where the agent is running.
- Store Path – Required. Format => [VaultName].vault.azure.net. See "VaultName" under "Custom Parameters" under _ 1. Create the New Certificate Store Type for the New AKV AnyAgent _.
- TenantID – Required . The ID of the Azure Active Directory (obtained from Properties menu of the subscription's Azure Active Directory – on this page it is called "Directory ID")
- ResourceGroupName – Required . The resource group name to which the Key Vault(s) belong. Can be found by clicking on the vault being managed and finding the "Resource group" at the top of the page.
- ApplicationId – Required . The ID of the API Application you are using to communicate with the Azure Key Vault (obtained from the App registration found under the App registrations menu of the subscription's Azure Active Directory)
- ClientSecret – Required . The secret value given to you when you created a key for the API application.
- SubscriptionId – Required . The ID of the subscription the Azure Key Vault(s) reside in (obtained from the Properties menu of the Subscription under the Subscriptions menu)
- APIObjectId – Required . The object ID of the API Application. This is found by searching for your app in "Enterprise Applications" (Object Id). This value may be different than the one found in "App Registrations". Use the Enterprise one.
- VaultName – Required . The name of the vault being managed.
- Create Certificate Store – Unchecked .
- Inventory Schedule – Set a schedule for running Inventory jobs or none, if you choose not to schedule Inventory at this time.
Talking Points
- While Azure Key Vault will automatically renew certs from DigiCert, GlobalSign, and D-Trust, they only send emails for certificates from other certificate providers
- You have the option to specify that the key pair be generated as non-exportable and generated inside an HSM. If you do this then you cannot distribute your certificate and private key to your app nodes as illustrated in the end-to-end flow example above.
- The Azure App Services platform periodically polls your key vault to check if there is an updated certificate. If it finds one it reads the new one and rebinds SSL/TLS for your app.
Packages
- GAC
- System.Net.Http
- System.Security.Cryptography.X509Certificates
- System.Threading.Tasks
- NuGet
- Microsoft.Azure.KeyVault v3.0.0 (https://github.com/Azure/AutoRest)
- Newtonsoft.Json.Linq v6.0.0 (Dependency from above)
- Microsoft.IdentityModel.Clients.ActiveDirectory v3.19.8 (https://aka.ms/adalnet)
- Microsoft.AspNet.WebApi.Client v5.2.3 (https://www.asp.net/web-api)
- Microsoft.Azure.Management.KeyVault v2.4.1 (https://github.com/Azure/azure-sdk-for-net)
- CSS
- CSS.CMS.Extensions.Agents;
- CSS.PlatformServices;
Footnotes
-
It is also possible to manage individual certificate stores without the need to provide resource group level authority. The steps to do assign permissions for an individual Azure Keyvault are described here for vaults using Access Policy based permissions and here for Individual Key Vaults using Role-Based Access Control (RBAC). ↩