forked from robotechredmond/Azure-PowerShell-Snippets
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathAzure RM - Key Vault with Service Principal cert-based auth using Enterprise CA certs.ps1
160 lines (107 loc) · 4.25 KB
/
Azure RM - Key Vault with Service Principal cert-based auth using Enterprise CA certs.ps1
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
# Select certificate generated from Enterprise PKI
# Cert must have minimum RSA 2048-bit key length for Public Key
$cert =
( Get-ChildItem Cert:\CurrentUser\My |
Out-GridView `
-Title "Select a certificate ..." `
-PassThru
)
# If not using Enterprise PKI, create self-signed certificate instead
if (!$cert) {
$cert = New-SelfSignedCertificate `
-CertStoreLocation Cert:\CurrentUser\My `
-Subject "CN=examplesp" `
-KeySpec KeyExchange `
-HashAlgorithm SHA256
}
# Get certificate thumbprint
$certThumbprint = $cert.Thumbprint
# Get public key and properties from selected cert
$keyValue = [System.Convert]::ToBase64String($cert.GetRawCertData())
$keyId = [guid]::NewGuid()
$startDate = $cert.NotBefore
$endDate = $cert.NotAfter
# Create a Key Credential object for selected cert
Import-Module `
-Name AzureRM.Resources
$keyCredential =
New-Object -TypeName Microsoft.Azure.Commands.Resources.Models.ActiveDirectory.PSADKeyCredential
$keyCredential.StartDate = $startDate
$keyCredential.EndDate = $endDate
$keyCredential.KeyId = $keyId
$keyCredential.CertValue = $keyValue
# Define Azure AD App values for new Service Principal
$adAppName =
Read-Host -Prompt “Enter unique Azure AD App name”
$adAppHomePage =
Read-Host -Prompt “Enter unique Azure AD App Homepage URI”
$adAppIdentifierUri =
Read-Host -Prompt “Enter unique Azure AD App Identifier URI”
# Login to Azure as user credentials with Azure Subscription Owner and Azure AD Global Admin access
Login-AzureRmAccount
# If more than 1 Azure subscription is present, select Azure subscription
$subscriptionId =
( Get-AzureRmSubscription |
Out-GridView `
-Title "Select an Azure Subscription ..." `
-PassThru
).SubscriptionId
Select-AzureRmSubscription `
-SubscriptionId $subscriptionId
# Create Azure AD App object for new Service Principal
$adApp =
New-AzureRmADApplication `
-DisplayName $adAppName `
-HomePage $adAppHomePage `
-IdentifierUris $adAppIdentifierUri `
-KeyCredentials $keyCredential
Write-Output “New Azure AD App Id: $($adApp.ApplicationId)”
# Create Service Principal
New-AzureRmADServicePrincipal `
-ApplicationId $adApp.ApplicationId
# Select Azure Resource Group in which to create Key Vault
$rgName =
(Get-AzureRmResourceGroup |
Out-GridView `
-Title "Select an Azure Resource Group ..." `
-PassThru).ResourceGroupName
$rg =
Get-AzureRmResourceGroup `
-Name $rgName
# Create New Key Vault
$vaultName = 'MyDemoVault01'
$vaultSKU = 'Premium'
New-AzureRmKeyVault `
-VaultName $vaultName `
-ResourceGroupName $rgName `
-Location $rg.Location `
-SKU $vaultSKU
# Show current properties of Key Vault
$vault =
Get-AzureRmKeyVault `
-VaultName $vaultName `
-ResourceGroupName $rgName
$vault | Format-List
# Assign Key Vault access to new Service Principal
Set-AzureRmKeyVaultAccessPolicy `
-VaultName $vaultName `
-ServicePrincipalName $adApp.ApplicationId `
-PermissionsToKeys create,get,list,wrapKey,unwrapKey
# Optional: Set Azure Key Vault Access Policy for ARM Template Deployments
Set-AzureRmKeyVaultAccessPolicy `
-VaultName $vaultName `
-EnabledForTemplateDeployment
# Optional: Set Azure Key Vault Access Policy for ARM Compute xRP Deployments
Set-AzureRmKeyVaultAccessPolicy `
-VaultName $vaultName `
-EnabledForDeployment
# Optional: If demo'ing Azure RBAC delegation, assign RBAC role to new Service Principal and test authenticating to Azure
New-AzureRmRoleAssignment `
-RoleDefinitionName Owner `
-ServicePrincipalName $adApp.ApplicationId
$tenantId = (Get-AzureRmContext).Tenant.TenantId
Login-AzureRmAccount `
-ServicePrincipal `
-TenantId $tenantId `
-ApplicationId $adApp.ApplicationId `
-CertificateThumbprint $certThumbprint