blob: 675e331d15f00ec3ceb368e74a16bc177dd7bab3 [file] [log] [blame]
Marri Devender Raod45d2d02019-01-21 10:11:34 -06001{
Gunnar Mills10f270b2021-05-19 15:34:06 -05002 "$id": "http://redfish.dmtf.org/schemas/v1/Certificate.v1_3_0.json",
Marri Devender Raod45d2d02019-01-21 10:11:34 -06003 "$ref": "#/definitions/Certificate",
4 "$schema": "http://redfish.dmtf.org/schemas/v1/redfish-schema-v1.json",
Gunnar Mills10f270b2021-05-19 15:34:06 -05005 "copyright": "Copyright 2014-2021 DMTF. For the full DMTF copyright policy, see http://www.dmtf.org/about/policies/copyright",
Marri Devender Raod45d2d02019-01-21 10:11:34 -06006 "definitions": {
7 "Actions": {
8 "additionalProperties": false,
Gunnar Mills844b4152020-06-22 12:44:09 -05009 "description": "The available actions for this resource.",
10 "longDescription": "This type shall contain the available actions for this resource.",
Marri Devender Raod45d2d02019-01-21 10:11:34 -060011 "patternProperties": {
Ed Tanouscb103132019-10-08 11:34:22 -070012 "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
Marri Devender Raod45d2d02019-01-21 10:11:34 -060013 "description": "This property shall specify a valid odata or Redfish property.",
14 "type": [
15 "array",
16 "boolean",
17 "integer",
18 "number",
19 "null",
20 "object",
21 "string"
22 ]
23 }
24 },
25 "properties": {
Ed Tanouscb103132019-10-08 11:34:22 -070026 "#Certificate.Rekey": {
27 "$ref": "#/definitions/Rekey"
28 },
29 "#Certificate.Renew": {
30 "$ref": "#/definitions/Renew"
31 },
Marri Devender Raod45d2d02019-01-21 10:11:34 -060032 "Oem": {
33 "$ref": "#/definitions/OemActions",
Gunnar Mills844b4152020-06-22 12:44:09 -050034 "description": "The available OEM-specific actions for this resource.",
35 "longDescription": "This property shall contain the available OEM-specific actions for this resource."
Marri Devender Raod45d2d02019-01-21 10:11:34 -060036 }
37 },
38 "type": "object"
39 },
40 "Certificate": {
41 "additionalProperties": false,
Ed Tanouscb103132019-10-08 11:34:22 -070042 "description": "The Certificate schema describes a certificate that proves the identify of a component, account, or service.",
Gunnar Mills844b4152020-06-22 12:44:09 -050043 "longDescription": "This resource shall represent a certificate for a Redfish implementation.",
Marri Devender Raod45d2d02019-01-21 10:11:34 -060044 "patternProperties": {
Ed Tanouscb103132019-10-08 11:34:22 -070045 "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
Marri Devender Raod45d2d02019-01-21 10:11:34 -060046 "description": "This property shall specify a valid odata or Redfish property.",
47 "type": [
48 "array",
49 "boolean",
50 "integer",
51 "number",
52 "null",
53 "object",
54 "string"
55 ]
56 }
57 },
58 "properties": {
59 "@odata.context": {
Ed Tanouscb103132019-10-08 11:34:22 -070060 "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/context"
Marri Devender Raod45d2d02019-01-21 10:11:34 -060061 },
62 "@odata.etag": {
Ed Tanouscb103132019-10-08 11:34:22 -070063 "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/etag"
Marri Devender Raod45d2d02019-01-21 10:11:34 -060064 },
65 "@odata.id": {
Ed Tanouscb103132019-10-08 11:34:22 -070066 "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/id"
Marri Devender Raod45d2d02019-01-21 10:11:34 -060067 },
68 "@odata.type": {
Ed Tanouscb103132019-10-08 11:34:22 -070069 "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/type"
Marri Devender Raod45d2d02019-01-21 10:11:34 -060070 },
71 "Actions": {
72 "$ref": "#/definitions/Actions",
Gunnar Mills844b4152020-06-22 12:44:09 -050073 "description": "The available actions for this resource.",
74 "longDescription": "This property shall contain the available actions for this resource."
Marri Devender Raod45d2d02019-01-21 10:11:34 -060075 },
76 "CertificateString": {
77 "description": "The string for the certificate.",
Ed Tanouscb103132019-10-08 11:34:22 -070078 "longDescription": "This property shall contain the certificate, and the format shall follow the requirements specified by the CertificateType property value. If the certificate contains any private keys, they shall be removed from the string in responses. If the service does not know the private key for the certificate and is needed to use the certificate, the client shall provide the private key as part of the string in the POST request.",
Marri Devender Raod45d2d02019-01-21 10:11:34 -060079 "readonly": true,
80 "type": [
81 "string",
82 "null"
83 ]
84 },
85 "CertificateType": {
86 "anyOf": [
87 {
88 "$ref": "http://redfish.dmtf.org/schemas/v1/Certificate.json#/definitions/CertificateType"
89 },
90 {
91 "type": "null"
92 }
93 ],
94 "description": "The format of the certificate.",
95 "longDescription": "This property shall contain the format type for the certificate.",
96 "readonly": true
97 },
98 "Description": {
99 "anyOf": [
100 {
101 "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Description"
102 },
103 {
104 "type": "null"
105 }
106 ],
107 "readonly": true
108 },
Gunnar Mills10f270b2021-05-19 15:34:06 -0500109 "Fingerprint": {
110 "description": "The fingerprint of the certificate.",
111 "longDescription": "The value of this property shall be a string containing the ASCII representation of the fingerprint of the certificate. The hash algorithm used to generate this fingerprint shall be specified by the FingerprintHashAlgorithm property.",
112 "pattern": "^([0-9A-Fa-f]{2}:){0,}([0-9A-Fa-f]{2})$",
113 "readonly": true,
114 "type": "string",
115 "versionAdded": "v1_3_0"
116 },
117 "FingerprintHashAlgorithm": {
118 "description": "The hash algorithm for the fingerprint of the certificate.",
119 "longDescription": "The value of this property shall be a string containing the hash algorithm used for generating the Fingerprint property. The value shall be one of the strings in the 'Algorithm Name' field of the 'TPM_ALG_ID Constants' table within the 'Trusted Computing Group Algorithm Registry'.",
120 "readonly": true,
121 "type": "string",
122 "versionAdded": "v1_3_0"
123 },
Marri Devender Raod45d2d02019-01-21 10:11:34 -0600124 "Id": {
125 "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Id",
126 "readonly": true
127 },
128 "Issuer": {
129 "$ref": "#/definitions/Identifier",
130 "description": "The issuer of the certificate.",
Ed Tanouscb103132019-10-08 11:34:22 -0700131 "longDescription": "This property shall contain an object containing information about the issuer of the certificate."
Marri Devender Raod45d2d02019-01-21 10:11:34 -0600132 },
133 "KeyUsage": {
Ed Tanouscb103132019-10-08 11:34:22 -0700134 "description": "The key usage extension, which defines the purpose of the public keys in this certificate.",
Marri Devender Raod45d2d02019-01-21 10:11:34 -0600135 "items": {
136 "anyOf": [
137 {
138 "$ref": "http://redfish.dmtf.org/schemas/v1/Certificate.json#/definitions/KeyUsage"
139 },
140 {
141 "type": "null"
142 }
143 ]
144 },
Ed Tanouscb103132019-10-08 11:34:22 -0700145 "longDescription": "This property shall contain the key usage extension, which defines the purpose of the public keys in this certificate.",
Marri Devender Raod45d2d02019-01-21 10:11:34 -0600146 "readonly": true,
147 "type": "array"
148 },
149 "Name": {
150 "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Name",
151 "readonly": true
152 },
153 "Oem": {
154 "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Oem",
Ed Tanouscb103132019-10-08 11:34:22 -0700155 "description": "The OEM extension property.",
156 "longDescription": "This property shall contain the OEM extensions. All values for properties that this object contains shall conform to the Redfish Specification-described requirements."
Marri Devender Raod45d2d02019-01-21 10:11:34 -0600157 },
Gunnar Mills10f270b2021-05-19 15:34:06 -0500158 "SerialNumber": {
159 "description": "The serial number of the certificate.",
160 "longDescription": "The value of this property shall be a string containing the ASCII representation of the serial number of the certificate, as defined by the RFC5280 'serialNumber' field.",
161 "pattern": "^([0-9A-Fa-f]{2}:){0,}([0-9A-Fa-f]{2})$",
162 "readonly": true,
163 "type": "string",
164 "versionAdded": "v1_3_0"
165 },
166 "SignatureAlgorithm": {
167 "description": "The algorithm used for creating the signature of the certificate.",
168 "longDescription": "The value of this property shall be a string containing the algorithm used for generating the signature of the certificate, as defined by the RFC5280 'signatureAlgorithm' field. The value shall be a string representing the ASN.1 OID of the signature algorithm as defined in, but not limited to, RFC3279, RFC4055, or RFC4491.",
169 "readonly": true,
170 "type": "string",
171 "versionAdded": "v1_3_0"
172 },
Marri Devender Raod45d2d02019-01-21 10:11:34 -0600173 "Subject": {
174 "$ref": "#/definitions/Identifier",
175 "description": "The subject of the certificate.",
Ed Tanouscb103132019-10-08 11:34:22 -0700176 "longDescription": "This property shall contain an object containing information about the subject of the certificate."
Marri Devender Raod45d2d02019-01-21 10:11:34 -0600177 },
Gunnar Millsa778c022020-05-12 12:20:36 -0500178 "UefiSignatureOwner": {
179 "description": "The UEFI signature owner for this certificate.",
Gunnar Mills10f270b2021-05-19 15:34:06 -0500180 "longDescription": "The value of this property shall contain the GUID of the UEFI signature owner for this certificate as defined by the UEFI Specification. This property shall only be present for certificates managed by UEFI.",
Gunnar Millsa778c022020-05-12 12:20:36 -0500181 "pattern": "([0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12})",
182 "readonly": true,
183 "type": [
184 "string",
185 "null"
186 ],
187 "versionAdded": "v1_2_0"
188 },
Marri Devender Raod45d2d02019-01-21 10:11:34 -0600189 "ValidNotAfter": {
190 "description": "The date when the certificate is no longer valid.",
191 "format": "date-time",
Ed Tanouscb103132019-10-08 11:34:22 -0700192 "longDescription": "This property shall contain the date when the certificate validity period ends.",
Marri Devender Raod45d2d02019-01-21 10:11:34 -0600193 "readonly": true,
194 "type": "string"
195 },
196 "ValidNotBefore": {
197 "description": "The date when the certificate becomes valid.",
198 "format": "date-time",
Ed Tanouscb103132019-10-08 11:34:22 -0700199 "longDescription": "This property shall contain the date when the certificate validity period begins.",
Marri Devender Raod45d2d02019-01-21 10:11:34 -0600200 "readonly": true,
201 "type": "string"
202 }
203 },
204 "required": [
205 "@odata.id",
206 "@odata.type",
207 "Id",
208 "Name"
209 ],
210 "requiredOnCreate": [
211 "CertificateString",
212 "CertificateType"
213 ],
214 "type": "object"
215 },
216 "Identifier": {
217 "additionalProperties": false,
218 "description": "The identifier information about a certificate.",
Ed Tanouscb103132019-10-08 11:34:22 -0700219 "longDescription": "This type shall contain the properties that identifies the issuer or subject of a certificate.",
Marri Devender Raod45d2d02019-01-21 10:11:34 -0600220 "patternProperties": {
Ed Tanouscb103132019-10-08 11:34:22 -0700221 "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
Marri Devender Raod45d2d02019-01-21 10:11:34 -0600222 "description": "This property shall specify a valid odata or Redfish property.",
223 "type": [
224 "array",
225 "boolean",
226 "integer",
227 "number",
228 "null",
229 "object",
230 "string"
231 ]
232 }
233 },
234 "properties": {
235 "City": {
236 "description": "The city or locality of the organization of the entity.",
237 "longDescription": "This property shall contain the city or locality of the organization of the entity.",
238 "readonly": true,
239 "type": "string"
240 },
241 "CommonName": {
242 "description": "The fully qualified domain name of the entity.",
243 "longDescription": "This property shall contain the fully qualified domain name of the entity.",
244 "readonly": true,
245 "type": "string"
246 },
247 "Country": {
248 "description": "The country of the organization of the entity.",
Ed Tanouscb103132019-10-08 11:34:22 -0700249 "longDescription": "This property shall contain the two-letter ISO code for the country of the organization of the entity.",
Marri Devender Raod45d2d02019-01-21 10:11:34 -0600250 "readonly": true,
251 "type": "string"
252 },
253 "Email": {
254 "description": "The email address of the contact within the organization of the entity.",
255 "longDescription": "This property shall contain the email address of the contact within the organization of the entity.",
256 "readonly": true,
257 "type": [
258 "string",
259 "null"
260 ]
261 },
262 "Organization": {
263 "description": "The name of the organization of the entity.",
264 "longDescription": "This property shall contain the name of the organization of the entity.",
265 "readonly": true,
266 "type": "string"
267 },
268 "OrganizationalUnit": {
269 "description": "The name of the unit or division of the organization of the entity.",
270 "longDescription": "This property shall contain the name of the unit or division of the organization of the entity.",
271 "readonly": true,
272 "type": "string"
273 },
274 "State": {
275 "description": "The state, province, or region of the organization of the entity.",
276 "longDescription": "This property shall contain the state, province, or region of the organization of the entity.",
277 "readonly": true,
278 "type": "string"
279 }
280 },
281 "type": "object"
282 },
283 "OemActions": {
284 "additionalProperties": true,
Gunnar Mills844b4152020-06-22 12:44:09 -0500285 "description": "The available OEM-specific actions for this resource.",
286 "longDescription": "This type shall contain the available OEM-specific actions for this resource.",
Marri Devender Raod45d2d02019-01-21 10:11:34 -0600287 "patternProperties": {
Ed Tanouscb103132019-10-08 11:34:22 -0700288 "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
Marri Devender Raod45d2d02019-01-21 10:11:34 -0600289 "description": "This property shall specify a valid odata or Redfish property.",
290 "type": [
291 "array",
292 "boolean",
293 "integer",
294 "number",
295 "null",
296 "object",
297 "string"
298 ]
299 }
300 },
301 "properties": {},
302 "type": "object"
Ed Tanouscb103132019-10-08 11:34:22 -0700303 },
304 "Rekey": {
305 "actionResponse": {
306 "$ref": "#/definitions/RekeyResponse"
307 },
308 "additionalProperties": false,
309 "description": "This action generates a new key-pair for a certificate and produces a certificate signing request.",
Gunnar Mills262d7d42021-01-20 16:28:41 -0600310 "longDescription": "This action shall use the certificate data to generate a new key-pair for a certificate. The response shall contain a signing request that a certificate authority (CA) will sign. The service should retain the private key that generated this request for installation of the certificate. The private key should not be part of the response. The private key should not be part of the response.",
Ed Tanouscb103132019-10-08 11:34:22 -0700311 "parameters": {
312 "ChallengePassword": {
313 "description": "The challenge password to apply to the certificate for revocation requests.",
314 "longDescription": "This property shall contain the challenge password to apply to the certificate for revocation requests as defined by the RFC2985 'challengePassword' attribute.",
315 "type": "string"
316 },
317 "KeyBitLength": {
318 "description": "The length of the key, in bits, if needed based on the KeyPairAlgorithm parameter value.",
319 "longDescription": "This parameter shall contain the length of the key, in bits, if needed based on the KeyPairAlgorithm parameter value.",
320 "type": "integer"
321 },
322 "KeyCurveId": {
323 "description": "The curve ID to use with the key, if needed based on the KeyPairAlgorithm parameter value.",
324 "longDescription": "This parameter shall contain the curve ID to use with the key, if needed based on the KeyPairAlgorithm parameter value. The allowable values for this parameter shall be the strings in the 'Name' field of the 'TPM_ECC_CURVE Constants' table within the 'Trusted Computing Group Algorithm Registry'.",
325 "type": "string"
326 },
327 "KeyPairAlgorithm": {
328 "description": "The type of key-pair for use with signing algorithms.",
329 "longDescription": "This parameter shall contain the type of key-pair for use with signing algorithms. The allowable values for this parameter shall be the strings in the 'Algorithm Name' field of the 'TPM_ALG_ID Constants' table within the 'Trusted Computing Group Algorithm Registry'.",
330 "type": "string"
331 }
332 },
333 "patternProperties": {
334 "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
335 "description": "This property shall specify a valid odata or Redfish property.",
336 "type": [
337 "array",
338 "boolean",
339 "integer",
340 "number",
341 "null",
342 "object",
343 "string"
344 ]
345 }
346 },
347 "properties": {
348 "target": {
349 "description": "Link to invoke action",
350 "format": "uri-reference",
351 "type": "string"
352 },
353 "title": {
354 "description": "Friendly action name",
355 "type": "string"
356 }
357 },
358 "type": "object",
359 "versionAdded": "v1_1_0"
360 },
361 "RekeyResponse": {
362 "additionalProperties": false,
363 "description": "The response body for the Rekey action.",
364 "longDescription": "This type shall contain the properties found in the response body for the Rekey action.",
365 "patternProperties": {
366 "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
367 "description": "This property shall specify a valid odata or Redfish property.",
368 "type": [
369 "array",
370 "boolean",
371 "integer",
372 "number",
373 "null",
374 "object",
375 "string"
376 ]
377 }
378 },
379 "properties": {
380 "CSRString": {
381 "description": "The string for the certificate signing request.",
382 "longDescription": "This property shall contain the certificate signing request as a PEM-encoded string, containing structures specified by RFC2986. The private key should not be part of the string.",
383 "readonly": true,
384 "type": "string",
385 "versionAdded": "v1_1_0"
386 },
387 "Certificate": {
388 "$ref": "http://redfish.dmtf.org/schemas/v1/Certificate.json#/definitions/Certificate",
389 "description": "The link to the certificate being rekeyed.",
Gunnar Mills844b4152020-06-22 12:44:09 -0500390 "longDescription": "This property shall contain a link to a resource of type Certificate that is replaced after the certificate authority (CA) signs the certificate.",
Ed Tanouscb103132019-10-08 11:34:22 -0700391 "readonly": true,
392 "versionAdded": "v1_1_0"
393 }
394 },
395 "required": [
396 "Certificate",
397 "CSRString"
398 ],
399 "type": "object"
400 },
401 "Renew": {
402 "actionResponse": {
403 "$ref": "#/definitions/RenewResponse"
404 },
405 "additionalProperties": false,
406 "description": "This action generates a certificate signing request by using the existing information and key-pair of the certificate.",
Gunnar Mills262d7d42021-01-20 16:28:41 -0600407 "longDescription": "This action shall generate a certificate signing request using the existing information and key-pair of the certificate. The response shall contain a signing request that a certificate authority (CA) will sign. The service should retain the private key that this request generates for when the certificate is installed. The private key should not be part of the response.",
Ed Tanouscb103132019-10-08 11:34:22 -0700408 "parameters": {
409 "ChallengePassword": {
410 "description": "The challenge password to apply to the certificate for revocation requests.",
411 "longDescription": "This property shall contain the challenge password to apply to the certificate for revocation requests as defined by the RFC2985 'challengePassword' attribute.",
412 "type": "string"
413 }
414 },
415 "patternProperties": {
416 "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
417 "description": "This property shall specify a valid odata or Redfish property.",
418 "type": [
419 "array",
420 "boolean",
421 "integer",
422 "number",
423 "null",
424 "object",
425 "string"
426 ]
427 }
428 },
429 "properties": {
430 "target": {
431 "description": "Link to invoke action",
432 "format": "uri-reference",
433 "type": "string"
434 },
435 "title": {
436 "description": "Friendly action name",
437 "type": "string"
438 }
439 },
440 "type": "object",
441 "versionAdded": "v1_1_0"
442 },
443 "RenewResponse": {
444 "additionalProperties": false,
445 "description": "The response body for the Renew action.",
446 "longDescription": "This type shall contain the properties found in the response body for the Renew action.",
447 "patternProperties": {
448 "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
449 "description": "This property shall specify a valid odata or Redfish property.",
450 "type": [
451 "array",
452 "boolean",
453 "integer",
454 "number",
455 "null",
456 "object",
457 "string"
458 ]
459 }
460 },
461 "properties": {
462 "CSRString": {
463 "description": "The string for the certificate signing request.",
464 "longDescription": "This property shall contain the certificate signing request as a PEM-encoded string, containing structures specified by RFC2986. The private key should not be part of the string.",
465 "readonly": true,
466 "type": "string",
467 "versionAdded": "v1_1_0"
468 },
469 "Certificate": {
470 "$ref": "http://redfish.dmtf.org/schemas/v1/Certificate.json#/definitions/Certificate",
471 "description": "The link to the certificate being renewed.",
Gunnar Mills844b4152020-06-22 12:44:09 -0500472 "longDescription": "This property shall contain a link to a resource of type Certificate that is replaced after the certificate authority (CA) signs the certificate.",
Ed Tanouscb103132019-10-08 11:34:22 -0700473 "readonly": true,
474 "versionAdded": "v1_1_0"
475 }
476 },
477 "required": [
478 "Certificate",
479 "CSRString"
480 ],
481 "type": "object"
Marri Devender Raod45d2d02019-01-21 10:11:34 -0600482 }
483 },
484 "owningEntity": "DMTF",
Gunnar Mills10f270b2021-05-19 15:34:06 -0500485 "release": "2021.1",
486 "title": "#Certificate.v1_3_0.Certificate"
Marri Devender Raod45d2d02019-01-21 10:11:34 -0600487}