-
Notifications
You must be signed in to change notification settings - Fork 140
/
Copy pathhsm-config.html.md.erb
366 lines (280 loc) · 13.6 KB
/
hsm-config.html.md.erb
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
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
---
title: Preparing CredHub HSMs for Configuration
owner: CredHub
---
This topic describes how to prepare a Hardware Security Module (HSM) to store CredHub encryption keys. Storing CredHub encryption keys in an HSM is more secure than storing them internally.
## <a id='overview'></a> Overview
SafeNet Luna HSM is the only HSM option that you can use as a CredHub encryption provider. The Amazon Web Services (AWS) [CloudHSM Classic](https://aws.amazon.com/cloudhsm/faqs-classic/) service uses SafeNet Luna HSMs. For more information about SafeNet Luna HSM, see the [SafeNet Luna Network HSMs](https://safenet.gemalto.com/data-encryption/hardware-security-modules-hsms/safenet-network-hsm/) product page.
When configuring <%= vars.ops_manager_full %>, BOSH CredHub uses a single HSM to store encryption keys. In <%= vars.app_runtime_full %> (<%= vars.app_runtime_abbr %>), you can configure multiple HSMs for runtime CredHub to use as encryption providers.
To configure BOSH CredHub, see _Step 3: Configure Director_ in the [BOSH Director configuration topic for your IaaS](deploy-bosh-om.html#contents).
<p class="note"><strong>Note:</strong> You can configure multiple HSMs for BOSH CredHub using the <%= vars.ops_manager %> API. For more information, see the <a href="https://docs.pivotal.io/platform/opsman-api/#updating-director-and-iaas-properties-experimental"><%= vars.ops_manager %> API documentation</a>.</p>
Configure runtime CredHub with one or more HSMs to securely manage service broker credentials. To configure runtime CredHub, see [Step 1: Configure the <%= vars.app_runtime_abbr %> Tile](../opsguide/secure-si-creds.html#pas-config) in _Securing Service Instance Credentials with Runtime CredHub_.
## <a id='checklist'></a> Preparation Checklist
As you follow these procedures, you should collect or create these resources:
* The name of your encryption key
* Your HSM certificate
* Your HSM partition name and password
* Your client certificate and private key
* Your HSM partition serial numbers
## <a id="initialize-and-configure"></a> Initialize and Configure New HSMs
The procedures in these sections describe how to initialize and configure new HSMs.
### <a id='initialize-and-set-policies'></a> Initialize HSM and Set Policies
To initialize a new HSM and set its policies:
1. Run:
```
ssh -i path/to/ssh-key.pem manager@HSM-IP-ADDRESS
```
Where `HSM-IP-ADDRESS` is the IP address of your HSM.
1. Initialize the HSM and create an admin password when prompted by running:
```
lunash:> hsm init -label LABEL
```
Where `LABEL` is the label you want to give the HSM.
<br>
<br>
Initialize all HSMs into the same cloning domain to guarantee high availability for your <%= vars.platform_name %> deployment.
1. Log in to the HSM using the password you just created by running:
```
lunash:> hsm login
```
1. Confirm that only FIPS algorithms are enabled. Run:
```
lunash:> hsm changePolicy -policy 12 -value 0
```
1. To confirm that `Allow cloning` and `Allow network replication` policy values are set to `On` on the HSM, run:
```
hsm showPolicies
```
If these values are not set to `On`, change them by running:
```
lunash:> hsm changePolicy -policy POLICY-CODE -value 1
```
Where `POLICY-CODE` is the numerical code of the `Allow cloning` or `Allow network replication` policy.
1. Validate that the `SO can reset partition PIN` is set correctly. If it is set to `Off`, consecutive failed login attempts permanently erase the partition once the failure count hits the configured threshold. If it is set to `On`, the partition locks once the threshold is met. An HSM admin must unlock the partition, but no data is lost. To set the policy to `On`, run:
```
lunash:> hsm changePolicy -policy 15 -value 1
```
### <a id="retrieve-hsm-certificate"></a> Retrieve HSM Certificate
To retrieve your HSM certificate:
1. Run:
```
scp -i path/to/ssh-key.pem \
manager@HSM-IP-ADDRESS:server.pem \
HSM-IP-ADDRESS.pem
```
Where `HSM-IP-ADDRESS` is the IP address of your HSM.
BOSH CredHub uses this certificate to validate the identity of the HSM when connecting to it.
### <a id="create-an-hsm-partition"></a> Create an HSM Partition
To create an HSM partition to hold the encryption keys:
1. Run:
```
lunash:> partition create -partition PARTITION-NAME -domain CLONING-DOMAIN
```
Where:
* `PARTITION-NAME` is the name you give the partition.
* `CLONING-DOMAIN` is the cloning domain of the HSM.
1. When prompted to do so, create a password for the partition. The partition password must be the same for all partitions in the highly available partition group.
1. To retrieve the partition serial number, run:
```
lunash:> partition show -partition PARTITION-NAME
```
Where `PARTITION-NAME` is the name of the partition you created.
1. Record the `Partition SN` shown in the output of the command you ran in the previous step.
## <a id='create-register-hsm'></a> Create and Register HSM Clients
Clients that communicate with the HSM must provide a client certificate to establish a client-authenticated session. You must set up each client's certificate on the HSM and assign access rights for your partition.
### <a id='network-trust-link'></a> Establish a Network Trust Link Between Client and HSMs
To establish a network trust link between a client and your HSMs:
1. Create a certificate for the client by running:
```
openssl req \
-x509 \
-newkey rsa:4096 \
-days NUMBER-OF-DAYS \
-sha256 \
-nodes \
-subj "/CN=CLIENT-HOSTNAME-OR-IP" \
-keyout CLIENT-HOSTNAME-OR-IP.pem \
-out CLIENT-HOSTNAME-OR-IP.pem
```
Where:
* `NUMBER-OF-DAYS` is the number of days you want the network trust link to be valid.
* `CLIENT-HOSTNAME-OR-IP` is the hostname or IP address of the client.
1. Copy the client certificate to your HSM by running:
```
scp -i path/to/ssh-key.pem \
CLIENT-HOSTNAME-OR-IP.pem \
manager@HSM-IP:CLIENT-HOSTNAME-OR-IP.pem
```
Where `CLIENT-HOSTNAME-OR-IP` is the hostname or IP address of the client.
### <a id='register'></a> Register HSM Client Host and Partitions
To register a client host and partitions for your HSM:
1. Create a client by running:
```
lunash:> client register -client CLIENT-NAME -hostname CLIENT-HOSTNAME
```
Where:
* `CLIENT-NAME` is the name of the client.
* `CLIENT-HOSTNAME` is the hostname of your planned CredHub instances.
If you are only planning to run one CredHub instance, you can also register a client with the planned CredHub IP
address by running:
```
lunash:> client register -client CLIENT-NAME -ip CLIENT-IP-ADDRESS
```
Where:
<ul>
<li><code>CLIENT-NAME</code> is the name of the client.</li>
<li><code>CLIENT-IP-ADDRESS</code> is the IP address of your planned CredHub instance.</li>
</ul>
1. Assign the partition created in the previous section to the client by running:
```
lunash:> client assignPartition -client CLIENT-NAME -partition PARTITION-NAME
```
Where:
* `CLIENT-NAME` is the name of the client.
* `PARTITION-NAME` is the name of the partition you created.
## <a id="hsm-encryption-keys"></a> Set, Review, and Delete HSM Encryption Keys
You can set which key is used for encryption operations by defining the encryption key name in the **Director Config** pane of the BOSH Director tile for BOSH Credhub, the **CredHub** pane of the <%= vars.app_runtime_abbr %> tile for runtime CredHub, or the <%= vars.ops_manager %> API. If a key already exists on the HSM, CredHub uses it by default. If a key does not exist on the HSM, CredHub creates one automatically in the referenced partition.
### <a id='review-stored-keys'></a> Review Stored Keys on a Partition
When you generate a new key, you should review the list of keys on each HSM to validate that key replication is occurring. If new keys do not propagate among the HSMs, you could get locked out of HSMs.
To review stored keys on a partition:
1. Run:
```
lunash:> partition showContents -partition PARTITION-NAME
```
Where `PARTITION-NAME` is the name of your partition.
### <a id='delete-key'></a> Delete Key
<%= vars.ops_manager %> places extra safeguards around the `/api/v0/staged/director/properties` endpoint to ensure that you cannot accidentally delete active CredHub encryption keys through the <%= vars.ops_manager %> API:
* You must always have an active key.
* You cannot delete keys that are currently active. You can only delete keys after they have been deactivated.
To delete an active CredHub key, you must first deactivate it and activate a new or existing key.
To delete the currently active key:
1. Deactivate the currently active key by running:
```
curl "https://OPS-MANAGER-FQDN/api/v0/staged/director/properties" \
-X PUT \
-H "Content-Type: application/json" \
-d '{
"director-configuration": {
"encryption": {
"keys": [
{
"provider_name": "hsm",
"encryption_key_name": "KEY-TO-DEACTIVATE",
"active": "false"
},
{
"provider_name": "hsm",
"encryption_key_name": "OTHER-KEY",
"active": "false"
}
]
}
}
}'
```
Where:
* `OPS-MANAGER-FQDN` is the fully-qualified domain name (FQDN) of your Ops Manager instance.
* `KEY-TO-DEACTIVATE` is the name of the encryption key you want to deactivate.
* `OTHER-KEY` is any other key you may have stored in CredHub.
1. Activate either a new or existing key.
* To activate a new key:
1. Upload a new key by running:
```
curl "https://OPS-MANAGER-FQDN/api/v0/staged/director/properties" \
-X POST \
-H "Content-Type: application/json" \
-d '{
"director-configuration": {
"encryption": {
"keys": [
{
"provider_name": "hsm",
"encryption_key_name": "KEY-TO-UPLOAD"
}
]
}
}
}'
```
Where:
* `OPS-MANAGER-FQDN` is the FQDN of your Ops Manager instance.
* `KEY-TO-UPLOAD` is the name of the encryption key you want to upload.
1. Activate the key by running:
```
curl "https://OPS-MANAGER-FQDN/api/v0/staged/director/properties" \
-X PUT \
-H "Content-Type: application/json" \
-d '{
"director-configuration": {
"encryption": {
"keys": [
{
"provider_name": "hsm",
"encryption_key_name": "DEACTIVATED-KEY",
"active": "false"
},
{
"provider_name": "hsm",
"encryption_key_name": "UPLOADED-KEY",
"active": "true"
}
]
}
}
}'
```
Where:
* `OPS-MANAGER-FQDN` is the FQDN of your Ops Manager instance.
* `DEACTIVATED-KEY` is the key you deactivated.
* `UPLOADED-KEY` is the name of the encryption key you uploaded in the previous step.
* To activate an existing key, run:
```
curl "https://OPS-MANAGER-FQDN/api/v0/staged/director/properties" \
-X PUT \
-H "Content-Type: application/json" \
-d '{
"director-configuration": {
"encryption": {
"keys": [
{
"provider_name": "hsm",
"encryption_key_name": "DEACTIVATED-KEY",
"active": "false"
},
{
"provider_name": "hsm",
"encryption_key_name": "KEY-TO-ACTIVATE",
"active": "true"
}
]
}
}
}'
```
Where:
* `OPS-MANAGER-FQDN` is the FQDN of your Ops Manager instance.
* `DEACTIVATED-KEY` is the key you want to deactivate.
* `KEY-TO-ACTIVATE` is the name of the encryption key you want to activate.
1. To delete the key you deactivated, you must run a `PUT` request with the key you want to delete omitted from your `keys` array. Run:
```
curl "https://OPS-MANAGER-FQDN/api/v0/staged/director/properties" \
-X PUT \
-H "Content-Type: application/json" \
-d '{
"director-configuration": {
"encryption": {
"keys": [
{
"provider_name": "hsm",
"encryption_key_name": "ACTIVATED-KEY",
"active": "false"
}
]
}
}
}'
```
Where:
* `OPS-MANAGER-FQDN` is the FQDN of your Ops Manager instance.
* `ACTIVATED-KEY` is the name of the encryption key you activated in the previous step.
For information about running commands with the <%= vars.ops_manager %> API, see [Run API Commands](ops-man-api.html#run-commands) in _Using the <%= vars.ops_manager %> API_.