xref: /openbmc/bmcweb/redfish-core/schema/dmtf/json-schema/Storage.v1_20_0.json (revision 5ecf7b4e1bb6988dd3403fa80b723afbe2be30ae)
1{
2    "$id": "http://redfish.dmtf.org/schemas/v1/Storage.v1_20_0.json",
3    "$ref": "#/definitions/Storage",
4    "$schema": "http://redfish.dmtf.org/schemas/v1/redfish-schema-v1.json",
5    "copyright": "Copyright 2014-2025 DMTF. For the full DMTF copyright policy, see http://www.dmtf.org/about/policies/copyright",
6    "definitions": {
7        "Actions": {
8            "additionalProperties": false,
9            "description": "The available actions for this resource.",
10            "longDescription": "This type shall contain the available actions for this resource.",
11            "patternProperties": {
12                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
13                    "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": {
26                "#Storage.ImportForeignDrives": {
27                    "$ref": "#/definitions/ImportForeignDrives"
28                },
29                "#Storage.RekeyExternalKey": {
30                    "$ref": "#/definitions/RekeyExternalKey"
31                },
32                "#Storage.ResetToDefaults": {
33                    "$ref": "#/definitions/ResetToDefaults"
34                },
35                "#Storage.SetControllerPassword": {
36                    "$ref": "#/definitions/SetControllerPassword"
37                },
38                "#Storage.SetEncryptionKey": {
39                    "$ref": "#/definitions/SetEncryptionKey"
40                },
41                "Oem": {
42                    "$ref": "#/definitions/OemActions",
43                    "description": "The available OEM-specific actions for this resource.",
44                    "longDescription": "This property shall contain the available OEM-specific actions for this resource."
45                }
46            },
47            "type": "object"
48        },
49        "AutoVolumeCreate": {
50            "enum": [
51                "Disabled",
52                "NonRAID",
53                "RAID0",
54                "RAID1"
55            ],
56            "enumDescriptions": {
57                "Disabled": "Do not automatically create volumes.",
58                "NonRAID": "Automatically create non-RAID volumes.",
59                "RAID0": "Automatically create RAID0 volumes.",
60                "RAID1": "Automatically create RAID1 volumes."
61            },
62            "type": "string"
63        },
64        "CacheSummary": {
65            "additionalProperties": false,
66            "description": "This type describes the cache memory of the storage controller in general detail.",
67            "longDescription": "This type shall contain properties that describe the cache memory for a storage controller.",
68            "patternProperties": {
69                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
70                    "description": "This property shall specify a valid odata or Redfish property.",
71                    "type": [
72                        "array",
73                        "boolean",
74                        "integer",
75                        "number",
76                        "null",
77                        "object",
78                        "string"
79                    ]
80                }
81            },
82            "properties": {
83                "PersistentCacheSizeMiB": {
84                    "description": "The portion of the cache memory that is persistent, measured in MiB.",
85                    "longDescription": "This property shall contain the amount of cache memory that is persistent as measured in mebibytes.  This size shall be less than or equal to the `TotalCacheSizeMiB`.",
86                    "minimum": 0,
87                    "readonly": true,
88                    "type": [
89                        "integer",
90                        "null"
91                    ],
92                    "units": "MiBy",
93                    "versionAdded": "v1_5_0"
94                },
95                "Status": {
96                    "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Status",
97                    "description": "The status and health of the resource and its subordinate or dependent resources.",
98                    "longDescription": "This property shall contain any status or health properties of the resource.",
99                    "versionAdded": "v1_5_0"
100                },
101                "TotalCacheSizeMiB": {
102                    "description": "The total configured cache memory, measured in MiB.",
103                    "longDescription": "This property shall contain the amount of configured cache memory as measured in mebibytes.",
104                    "minimum": 0,
105                    "readonly": true,
106                    "type": [
107                        "integer",
108                        "null"
109                    ],
110                    "units": "MiBy",
111                    "versionAdded": "v1_5_0"
112                }
113            },
114            "required": [
115                "TotalCacheSizeMiB"
116            ],
117            "type": "object"
118        },
119        "ConfigLockOptions": {
120            "enum": [
121                "Unlocked",
122                "Locked",
123                "LockdownUnsupported",
124                "CommandUnsupported"
125            ],
126            "enumDescriptions": {
127                "CommandUnsupported": "The command is not supported, therefore lockdown does not apply.",
128                "LockdownUnsupported": "The command is supported but is not able to be locked.",
129                "Locked": "The command is supported and is currently locked.",
130                "Unlocked": "The command is supported, able to be locked, and is currently unlocked."
131            },
132            "type": "string"
133        },
134        "ConfigurationLock": {
135            "enum": [
136                "Enabled",
137                "Disabled",
138                "Partial"
139            ],
140            "enumDescriptions": {
141                "Disabled": "In-band configuration requests are not locked.",
142                "Enabled": "In-band configuration requests are locked as specified by `TargetConfigurationLockLevel`.",
143                "Partial": "Some in-band configuration requests are not locked while others are locked.  This value is used for status reporting to indicate that the storage subsystem is partially locked and client action is recommended."
144            },
145            "enumLongDescriptions": {
146                "Disabled": "This value shall indicate in-band configuration requests are not locked.",
147                "Enabled": "This value shall indicate in-band configuration requests are locked as specified by `TargetConfigurationLockLevel`.",
148                "Partial": "This value shall indicate some in-band configuration requests are not locked while others are locked."
149            },
150            "type": "string"
151        },
152        "EncryptionMode": {
153            "enum": [
154                "Disabled",
155                "UseExternalKey",
156                "UseLocalKey",
157                "PasswordOnly",
158                "PasswordWithExternalKey",
159                "PasswordWithLocalKey"
160            ],
161            "enumDescriptions": {
162                "Disabled": "Encryption is disabled on the storage subsystem.",
163                "PasswordOnly": "The storage subsystem uses a password, but no keys for encryption.",
164                "PasswordWithExternalKey": "The storage subsystem uses a password and one or more external keys for encryption.",
165                "PasswordWithLocalKey": "The storage subsystem uses a password and a local key for encryption.",
166                "UseExternalKey": "The storage subsystem uses one or more external keys for encryption.",
167                "UseLocalKey": "The storage subsystem uses a local key for encryption."
168            },
169            "enumVersionAdded": {
170                "PasswordOnly": "v1_17_0",
171                "PasswordWithExternalKey": "v1_17_0",
172                "PasswordWithLocalKey": "v1_17_0"
173            },
174            "type": "string"
175        },
176        "HotspareActivationPolicy": {
177            "enum": [
178                "OnDriveFailure",
179                "OnDrivePredictedFailure",
180                "OEM"
181            ],
182            "enumDescriptions": {
183                "OEM": "The hot spare drive will take over for the original drive in an algorithm custom to the OEM.",
184                "OnDriveFailure": "The hot spare drive will take over for the original drive when the original drive has been marked as failed by the storage domain.",
185                "OnDrivePredictedFailure": "The hot spare drive will take over for the original drive when the original drive has been predicted to fail in the future by the storage domain."
186            },
187            "type": "string"
188        },
189        "ImportForeignDrives": {
190            "additionalProperties": false,
191            "description": "This action imports encrypted foreign drives to a host-based storage controller by supplying encryption access credentials.",
192            "longDescription": "This action shall import encrypted foreign drives to a host-based storage controller by supplying encryption access credentials.  Upon successful completion, the `EncryptionStatus` property of the affected `Drive` shall change from `Foreign` to `Unlocked`.",
193            "parameters": {
194                "ControllerPassword": {
195                    "description": "The current controller password.  This parameter is not required if the controller does not currently have a password.",
196                    "longDescription": "This parameter shall contain the current controller password.  Services may reject the action request if this parameter is not provided or the value supplied does not match the current password.",
197                    "type": "string"
198                },
199                "DriveEncryptionKey": {
200                    "description": "The encryption key to unlock the drives.",
201                    "longDescription": "This parameter shall contain the encryption key to unlock the drives.",
202                    "requiredParameter": true,
203                    "type": "string"
204                },
205                "DriveEncryptionKeyIdentifier": {
206                    "description": "An encryption key identifier to filter the drives that are imported.  If not provided, the controller attempts to import all foreign drives.",
207                    "longDescription": "This parameter shall contain an encryption key identifier to filter the drives that are imported.  If this parameter is not provided, the service shall not perform filtering of foreign drives.",
208                    "type": "string"
209                }
210            },
211            "patternProperties": {
212                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
213                    "description": "This property shall specify a valid odata or Redfish property.",
214                    "type": [
215                        "array",
216                        "boolean",
217                        "integer",
218                        "number",
219                        "null",
220                        "object",
221                        "string"
222                    ]
223                }
224            },
225            "properties": {
226                "target": {
227                    "description": "Link to invoke action",
228                    "format": "uri-reference",
229                    "type": "string"
230                },
231                "title": {
232                    "description": "Friendly action name",
233                    "type": "string"
234                }
235            },
236            "type": "object",
237            "versionAdded": "v1_19_0"
238        },
239        "Links": {
240            "additionalProperties": false,
241            "description": "The links to other resources that are related to this resource.",
242            "longDescription": "This Redfish Specification-described type shall contain links to resources that are related to but are not contained by, or subordinate to, this resource.",
243            "patternProperties": {
244                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
245                    "description": "This property shall specify a valid odata or Redfish property.",
246                    "type": [
247                        "array",
248                        "boolean",
249                        "integer",
250                        "number",
251                        "null",
252                        "object",
253                        "string"
254                    ]
255                }
256            },
257            "properties": {
258                "BlockSecurityIDUnsupportedDrives": {
259                    "description": "The set of drives in this storage subsystem that do not support blocking of TCG-defined security ID (SID).",
260                    "items": {
261                        "$ref": "http://redfish.dmtf.org/schemas/v1/Drive.json#/definitions/Drive"
262                    },
263                    "longDescription": "This property shall contain an array of links to resources of type `Drive` that represent the drives in this storage subsystem that do not support the TCG-defined 'Block SID' command.  This property should only be present if at least one drive does not support the TCG-defined 'Block SID' command.",
264                    "readonly": true,
265                    "type": "array",
266                    "versionAdded": "v1_18_0"
267                },
268                "BlockSecurityIDUnsupportedDrives@odata.count": {
269                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/count"
270                },
271                "BlockSecurityIDUpdateUnsuccessfulDrives": {
272                    "description": "The set of drives in this storage subsystem for which the most recent attempt to block TCG-defined security ID (SID) failed.",
273                    "items": {
274                        "$ref": "http://redfish.dmtf.org/schemas/v1/Drive.json#/definitions/Drive"
275                    },
276                    "longDescription": "This property shall contain an array of links to resources of type `Drive` that represent the drives in this storage subsystem for which the most recent attempt to block TCG-defined security ID (SID) with the TCG-defined 'Block SID' command failed.  This property should only be present if the most recent attempt to block TCG-defined security ID (SID) with the TCG-defined 'Block SID' command failed for at least one drive.",
277                    "readonly": true,
278                    "type": "array",
279                    "versionAdded": "v1_18_0"
280                },
281                "BlockSecurityIDUpdateUnsuccessfulDrives@odata.count": {
282                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/count"
283                },
284                "Enclosures": {
285                    "description": "An array of links to the chassis to which this storage subsystem is attached.",
286                    "items": {
287                        "$ref": "http://redfish.dmtf.org/schemas/v1/Chassis.json#/definitions/Chassis"
288                    },
289                    "longDescription": "This property shall contain an array of links to resources of type `Chassis` that represent the physical containers attached to this resource.",
290                    "readonly": true,
291                    "type": "array"
292                },
293                "Enclosures@odata.count": {
294                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/count"
295                },
296                "HostingStorageSystems": {
297                    "description": "The storage systems that host this storage subsystem.",
298                    "items": {
299                        "$ref": "http://redfish.dmtf.org/schemas/v1/ComputerSystem.json#/definitions/ComputerSystem"
300                    },
301                    "longDescription": "This property shall contain an array of links to resources of type `ComputerSystem` that represent the storage systems that host this storage subsystem.  The members of this array shall be in the `StorageSystems` resource collection off the service root.",
302                    "readonly": true,
303                    "type": "array",
304                    "versionAdded": "v1_11_0"
305                },
306                "HostingStorageSystems@odata.count": {
307                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/count"
308                },
309                "NVMeoFDiscoverySubsystems": {
310                    "description": "An array of links to the discovery subsystems that discovered this subsystem in an NVMe-oF environment.",
311                    "items": {
312                        "$ref": "http://redfish.dmtf.org/schemas/v1/Storage.json#/definitions/Storage"
313                    },
314                    "longDescription": "This property shall contain an array of links to resources of type `Storage` that represent the discovery subsystems that discovered this subsystem in an NVMe-oF environment.",
315                    "readonly": true,
316                    "type": "array",
317                    "versionAdded": "v1_15_0"
318                },
319                "NVMeoFDiscoverySubsystems@odata.count": {
320                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/count"
321                },
322                "Oem": {
323                    "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Oem",
324                    "description": "The OEM extension property.",
325                    "longDescription": "This property shall contain the OEM extensions.  All values for properties contained in this object shall conform to the Redfish Specification-described requirements."
326                },
327                "SimpleStorage": {
328                    "$ref": "http://redfish.dmtf.org/schemas/v1/SimpleStorage.json#/definitions/SimpleStorage",
329                    "description": "The link to the simple storage instance that corresponds to this storage.",
330                    "longDescription": "This property shall contain a link to a resource of type `SimpleStorage` that represents the same storage subsystem as this resource.",
331                    "readonly": true,
332                    "versionAdded": "v1_9_0"
333                },
334                "StorageServices": {
335                    "description": "An array of links to the storage services that connect to this storage subsystem.",
336                    "items": {
337                        "$ref": "http://redfish.dmtf.org/schemas/swordfish/v1/StorageService.json#/definitions/StorageService"
338                    },
339                    "longDescription": "This property shall contain an array of links to resources of type `StorageService` with which this storage subsystem is associated.",
340                    "readonly": true,
341                    "type": "array",
342                    "versionAdded": "v1_9_0"
343                },
344                "StorageServices@odata.count": {
345                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/count"
346                },
347                "UnassignedVolumes": {
348                    "description": "The set of volumes in this storage subsystem that are not assigned to a physical function.",
349                    "items": {
350                        "$ref": "http://redfish.dmtf.org/schemas/swordfish/v1/Volume.json#/definitions/Volume"
351                    },
352                    "longDescription": "This property shall contain an array of links to resources of type `Volume` that represent the volumes in this storage subsystem that are not assigned to a physical function.  This property should only be present if the storage subsystem supports the use of multiple physical functions to parallelize data transfer.",
353                    "readonly": true,
354                    "type": "array",
355                    "versionAdded": "v1_20_0"
356                },
357                "UnassignedVolumes@odata.count": {
358                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/count"
359                }
360            },
361            "type": "object"
362        },
363        "MPF": {
364            "additionalProperties": false,
365            "description": "Multiple physical function-related properties for storage controllers in a storage subsystem.",
366            "longDescription": "This type shall contain multiple physical function-related properties for storage controllers in a storage subsystem.",
367            "patternProperties": {
368                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
369                    "description": "This property shall specify a valid odata or Redfish property.",
370                    "type": [
371                        "array",
372                        "boolean",
373                        "integer",
374                        "number",
375                        "null",
376                        "object",
377                        "string"
378                    ]
379                }
380            },
381            "properties": {
382                "ConfiguredPhysicalFunctions": {
383                    "description": "The current number of physical functions configured for the storage controller in this storage subsystem.",
384                    "longDescription": "This property shall contain the current number of physical functions configured for the storage controller in this storage subsystem.",
385                    "readonly": false,
386                    "type": [
387                        "integer",
388                        "null"
389                    ],
390                    "versionAdded": "v1_20_0"
391                },
392                "MaximumSupportedPhysicalFunctions": {
393                    "description": "The maximum number of physical functions supported by the storage controller in this storage subsystem.",
394                    "longDescription": "This property shall contain the maximum number of physical functions supported by the storage controller in this storage subsystem.",
395                    "readonly": true,
396                    "type": [
397                        "integer",
398                        "null"
399                    ],
400                    "versionAdded": "v1_20_0"
401                },
402                "VolumeAssignmentPolicy": {
403                    "anyOf": [
404                        {
405                            "$ref": "#/definitions/VolumeAssignmentPolicy"
406                        },
407                        {
408                            "type": "null"
409                        }
410                    ],
411                    "description": "The current volume assignment policy configured for the storage controller in this storage subsystem.",
412                    "longDescription": "This property shall contain the current volume assignment policy configured for the storage controller in this storage subsystem.",
413                    "readonly": false,
414                    "versionAdded": "v1_20_0"
415                }
416            },
417            "type": "object"
418        },
419        "NVMeConfigurationLockState": {
420            "additionalProperties": false,
421            "description": "The configurable features that are able to be locked on an NVMe subsystem and their current lock state.",
422            "longDescription": "This type shall contain the configurable features that are able to be locked on an NVMe subsystem and their current lock state.",
423            "patternProperties": {
424                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
425                    "description": "This property shall specify a valid odata or Redfish property.",
426                    "type": [
427                        "array",
428                        "boolean",
429                        "integer",
430                        "number",
431                        "null",
432                        "object",
433                        "string"
434                    ]
435                }
436            },
437            "properties": {
438                "FirmwareCommit": {
439                    "anyOf": [
440                        {
441                            "$ref": "#/definitions/ConfigLockOptions"
442                        },
443                        {
444                            "type": "null"
445                        }
446                    ],
447                    "description": "The lock state of the NVMe-defined Firmware Commit command.",
448                    "longDescription": "This property shall contain the lock state of the NVMe-defined Firmware Commit command.",
449                    "readonly": true,
450                    "versionAdded": "v1_17_0"
451                },
452                "FirmwareImageDownload": {
453                    "anyOf": [
454                        {
455                            "$ref": "#/definitions/ConfigLockOptions"
456                        },
457                        {
458                            "type": "null"
459                        }
460                    ],
461                    "description": "The lock state of the NVMe-defined Firmware Image Download command.",
462                    "longDescription": "This property shall contain the lock state of the NVMe-defined Firmware Image Download command.",
463                    "readonly": true,
464                    "versionAdded": "v1_17_0"
465                },
466                "Lockdown": {
467                    "anyOf": [
468                        {
469                            "$ref": "#/definitions/ConfigLockOptions"
470                        },
471                        {
472                            "type": "null"
473                        }
474                    ],
475                    "description": "The lock state of the NVMe-defined Lockdown command.",
476                    "longDescription": "This property shall contain the lock state of the NVMe-defined Lockdown command.",
477                    "readonly": true,
478                    "versionAdded": "v1_17_0"
479                },
480                "SecuritySend": {
481                    "anyOf": [
482                        {
483                            "$ref": "#/definitions/ConfigLockOptions"
484                        },
485                        {
486                            "type": "null"
487                        }
488                    ],
489                    "description": "The lock state of the NVMe-defined Security Send command.",
490                    "longDescription": "This property shall contain the lock state of the NVMe-defined Security Send command.",
491                    "readonly": true,
492                    "versionAdded": "v1_17_0"
493                },
494                "VPDWrite": {
495                    "anyOf": [
496                        {
497                            "$ref": "#/definitions/ConfigLockOptions"
498                        },
499                        {
500                            "type": "null"
501                        }
502                    ],
503                    "description": "The lock state of the NVMe-MI-defined VPD Write command.",
504                    "longDescription": "This property shall contain the lock state of the NVMe-MI-defined VPD Write command.",
505                    "readonly": true,
506                    "versionAdded": "v1_17_0"
507                }
508            },
509            "type": "object"
510        },
511        "NVMeSubsystemProperties": {
512            "additionalProperties": false,
513            "description": "Information specific to NVMe Subsystems.",
514            "longDescription": "This type shall contain information specific to NVMe Subsystems.",
515            "patternProperties": {
516                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
517                    "description": "This property shall specify a valid odata or Redfish property.",
518                    "type": [
519                        "array",
520                        "boolean",
521                        "integer",
522                        "number",
523                        "null",
524                        "object",
525                        "string"
526                    ]
527                }
528            },
529            "properties": {
530                "ConfigurationLockState": {
531                    "anyOf": [
532                        {
533                            "$ref": "#/definitions/NVMeConfigurationLockState"
534                        },
535                        {
536                            "type": "null"
537                        }
538                    ],
539                    "description": "The configurable features that are able to be locked from in-band usage on an NVMe subsystem and their current lock state.",
540                    "longDescription": "This property shall contain the configurable features that are able to be locked from in-band usage on an NVMe subsystem and their current lock state.",
541                    "versionAdded": "v1_17_0"
542                },
543                "MaxNamespacesSupported": {
544                    "description": "The maximum number of namespace attachments supported by this NVMe Subsystem.",
545                    "longDescription": "This property shall contain the maximum number of namespace attachments supported by this NVMe Subsystem.  If no maximum is specified, this property should not be implemented.",
546                    "readonly": true,
547                    "type": [
548                        "number",
549                        "null"
550                    ],
551                    "versionAdded": "v1_16_0"
552                },
553                "SharedNamespaceControllerAttachmentSupported": {
554                    "description": "Indicates whether the subsystem supports shared namespace controller attachment, allowing a shared namespace to be attached concurrently to two or more controllers in an NVMe Subsystem.",
555                    "longDescription": "This property shall indicate whether the subsystem supports shared namespace controller attachment, allowing a shared namespace to be attached concurrently to two or more controllers in an NVMe Subsystem.",
556                    "readonly": true,
557                    "type": [
558                        "boolean",
559                        "null"
560                    ],
561                    "versionAdded": "v1_16_0"
562                }
563            },
564            "type": "object"
565        },
566        "OemActions": {
567            "additionalProperties": true,
568            "description": "The available OEM-specific actions for this resource.",
569            "longDescription": "This type shall contain the available OEM-specific actions for this resource.",
570            "patternProperties": {
571                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
572                    "description": "This property shall specify a valid odata or Redfish property.",
573                    "type": [
574                        "array",
575                        "boolean",
576                        "integer",
577                        "number",
578                        "null",
579                        "object",
580                        "string"
581                    ]
582                }
583            },
584            "properties": {},
585            "type": "object"
586        },
587        "Rates": {
588            "additionalProperties": false,
589            "description": "This type describes the various controller rates used for processes such as volume rebuild or consistency checks.",
590            "longDescription": "This type shall contain all the rate settings available on the controller.",
591            "patternProperties": {
592                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
593                    "description": "This property shall specify a valid odata or Redfish property.",
594                    "type": [
595                        "array",
596                        "boolean",
597                        "integer",
598                        "number",
599                        "null",
600                        "object",
601                        "string"
602                    ]
603                }
604            },
605            "properties": {
606                "ConsistencyCheckRatePercent": {
607                    "description": "The percentage of controller resources used for performing a data consistency check on volumes.",
608                    "longDescription": "This property shall contain the percentage of controller resources used for checking data consistency on volumes.",
609                    "maximum": 100,
610                    "minimum": 0,
611                    "readonly": false,
612                    "type": [
613                        "integer",
614                        "null"
615                    ],
616                    "versionAdded": "v1_7_0"
617                },
618                "RebuildRatePercent": {
619                    "description": "The percentage of controller resources used for rebuilding/repairing volumes.",
620                    "longDescription": "This property shall contain the percentage of controller resources used for rebuilding volumes.",
621                    "maximum": 100,
622                    "minimum": 0,
623                    "readonly": false,
624                    "type": [
625                        "integer",
626                        "null"
627                    ],
628                    "versionAdded": "v1_7_0"
629                },
630                "TransformationRatePercent": {
631                    "description": "The percentage of controller resources used for transforming volumes from one configuration to another.",
632                    "longDescription": "This property shall contain the percentage of controller resources used for transforming volumes.",
633                    "maximum": 100,
634                    "minimum": 0,
635                    "readonly": false,
636                    "type": [
637                        "integer",
638                        "null"
639                    ],
640                    "versionAdded": "v1_7_0"
641                }
642            },
643            "type": "object"
644        },
645        "RekeyExternalKey": {
646            "additionalProperties": false,
647            "description": "This action causes the controllers of the storage subsystem to request new encryption keys managed by an external key service.",
648            "longDescription": "This action shall cause the controllers of the storage subsystem to request new encryption keys managed by an external key service.",
649            "parameters": {},
650            "patternProperties": {
651                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
652                    "description": "This property shall specify a valid odata or Redfish property.",
653                    "type": [
654                        "array",
655                        "boolean",
656                        "integer",
657                        "number",
658                        "null",
659                        "object",
660                        "string"
661                    ]
662                }
663            },
664            "properties": {
665                "target": {
666                    "description": "Link to invoke action",
667                    "format": "uri-reference",
668                    "type": "string"
669                },
670                "title": {
671                    "description": "Friendly action name",
672                    "type": "string"
673                }
674            },
675            "type": "object",
676            "versionAdded": "v1_16_0"
677        },
678        "ResetToDefaults": {
679            "additionalProperties": false,
680            "description": "The reset action resets the storage device to factory defaults.  This can cause the loss of data.",
681            "longDescription": "This action shall reset the storage device.  This action can impact other resources.",
682            "parameters": {
683                "ResetType": {
684                    "$ref": "#/definitions/ResetToDefaultsType",
685                    "description": "The type of reset to defaults.",
686                    "longDescription": "This parameter shall contain the type of reset to defaults.",
687                    "requiredParameter": true
688                }
689            },
690            "patternProperties": {
691                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
692                    "description": "This property shall specify a valid odata or Redfish property.",
693                    "type": [
694                        "array",
695                        "boolean",
696                        "integer",
697                        "number",
698                        "null",
699                        "object",
700                        "string"
701                    ]
702                }
703            },
704            "properties": {
705                "target": {
706                    "description": "Link to invoke action",
707                    "format": "uri-reference",
708                    "type": "string"
709                },
710                "title": {
711                    "description": "Friendly action name",
712                    "type": "string"
713                }
714            },
715            "type": "object",
716            "versionAdded": "v1_11_0"
717        },
718        "ResetToDefaultsType": {
719            "enum": [
720                "ResetAll",
721                "PreserveVolumes"
722            ],
723            "enumDescriptions": {
724                "PreserveVolumes": "Reset all settings to factory defaults but preserve the configured volumes on the controllers.",
725                "ResetAll": "Reset all settings to factory defaults and remove all volumes."
726            },
727            "type": "string"
728        },
729        "SetControllerPassword": {
730            "additionalProperties": false,
731            "description": "This action sets the controller boot password for a host-based storage controller.",
732            "longDescription": "This action shall set the controller boot password for a host-based storage controller.",
733            "parameters": {
734                "CurrentPassword": {
735                    "description": "The current controller password.  This parameter is not needed if the controller does not currently have a password.",
736                    "longDescription": "This parameter shall contain the current controller password.  Services may reject the action request if this parameter is not provided or the value supplied does not match the current password.",
737                    "type": "string"
738                },
739                "NewPassword": {
740                    "description": "The new password to set for the controller.",
741                    "longDescription": "This parameter shall contain the new password to set for the controller.",
742                    "requiredParameter": true,
743                    "type": "string"
744                },
745                "SecurityKey": {
746                    "description": "The security key for the controller.  This parameter is not needed if the controller does not have a security key.",
747                    "longDescription": "This parameter shall contain the controller security key.  Services may reject the action request if this parameter is not provided or the value provided does not match the security key for the controller.",
748                    "type": "string"
749                }
750            },
751            "patternProperties": {
752                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
753                    "description": "This property shall specify a valid odata or Redfish property.",
754                    "type": [
755                        "array",
756                        "boolean",
757                        "integer",
758                        "number",
759                        "null",
760                        "object",
761                        "string"
762                    ]
763                }
764            },
765            "properties": {
766                "target": {
767                    "description": "Link to invoke action",
768                    "format": "uri-reference",
769                    "type": "string"
770                },
771                "title": {
772                    "description": "Friendly action name",
773                    "type": "string"
774                }
775            },
776            "type": "object",
777            "versionAdded": "v1_17_0"
778        },
779        "SetEncryptionKey": {
780            "additionalProperties": false,
781            "description": "This action sets the local encryption key for the storage subsystem.",
782            "longDescription": "This action shall set the local encryption key for the storage subsystem.",
783            "parameters": {
784                "CurrentEncryptionKey": {
785                    "description": "The current local encryption key on the storage subsystem.  This parameter is not needed if the controller does not currently have an encryption key.",
786                    "longDescription": "This parameter shall contain the current local encryption key on the storage subsystem.  Services may reject the action request if this parameter is not provided or the value supplied does not match the current encryption key.",
787                    "type": "string",
788                    "versionAdded": "v1_14_0"
789                },
790                "EncryptionKey": {
791                    "description": "The local encryption key to set on the storage subsystem.",
792                    "longDescription": "This parameter shall contain the local encryption key to set on the storage subsystem.",
793                    "requiredParameter": true,
794                    "type": "string"
795                },
796                "EncryptionKeyIdentifier": {
797                    "description": "The local encryption key identifier used by the storage subsystem.",
798                    "longDescription": "This property shall contain the local encryption key identifier used by the storage subsystem.",
799                    "type": "string",
800                    "versionAdded": "v1_14_0"
801                }
802            },
803            "patternProperties": {
804                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
805                    "description": "This property shall specify a valid odata or Redfish property.",
806                    "type": [
807                        "array",
808                        "boolean",
809                        "integer",
810                        "number",
811                        "null",
812                        "object",
813                        "string"
814                    ]
815                }
816            },
817            "properties": {
818                "target": {
819                    "description": "Link to invoke action",
820                    "format": "uri-reference",
821                    "type": "string"
822                },
823                "title": {
824                    "description": "Friendly action name",
825                    "type": "string"
826                }
827            },
828            "type": "object"
829        },
830        "Storage": {
831            "additionalProperties": false,
832            "description": "The `Storage` schema defines a storage subsystem and its respective properties.  A storage subsystem represents a set of physical or virtual storage controllers and the resources, such as volumes, that can be accessed from that subsystem.",
833            "longDescription": "This resource shall represent a storage subsystem in the Redfish Specification.",
834            "patternProperties": {
835                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
836                    "description": "This property shall specify a valid odata or Redfish property.",
837                    "type": [
838                        "array",
839                        "boolean",
840                        "integer",
841                        "number",
842                        "null",
843                        "object",
844                        "string"
845                    ]
846                }
847            },
848            "properties": {
849                "@odata.context": {
850                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/context"
851                },
852                "@odata.etag": {
853                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/etag"
854                },
855                "@odata.id": {
856                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/id"
857                },
858                "@odata.type": {
859                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/type"
860                },
861                "Actions": {
862                    "$ref": "#/definitions/Actions",
863                    "description": "The available actions for this resource.",
864                    "longDescription": "This property shall contain the available actions for this resource."
865                },
866                "AutoVolumeCreate": {
867                    "anyOf": [
868                        {
869                            "$ref": "#/definitions/AutoVolumeCreate"
870                        },
871                        {
872                            "type": "null"
873                        }
874                    ],
875                    "description": "Indicates if this storage subsystem automatically creates new volumes for unassigned drives.",
876                    "longDescription": "This property shall indicate if volumes are created automatically for each unassigned drive attached to this storage subsystem.",
877                    "readonly": false,
878                    "versionAdded": "v1_15_0"
879                },
880                "BlockSecurityIDPolicy": {
881                    "description": "Indicates if the storage controller sends a command to block establishment of a TCG-defined security ID (SID) during each drive boot sequence for drives that support it.",
882                    "longDescription": "This property shall indicate if the storage controller sends the TCG-defined 'Block SID' command to block establishment of a TCG-defined security ID (SID) during each drive boot sequence for drives that support it.  The value `true` shall indicate the TCG-defined 'Block SID' command is sent to supporting drives during each drive boot sequence.",
883                    "readonly": false,
884                    "type": [
885                        "boolean",
886                        "null"
887                    ],
888                    "versionAdded": "v1_18_0"
889                },
890                "ConfigurationLock": {
891                    "anyOf": [
892                        {
893                            "$ref": "#/definitions/ConfigurationLock"
894                        },
895                        {
896                            "type": "null"
897                        }
898                    ],
899                    "description": "Indicates whether in-band configuration requests to the storage subsystem are locked.  Other properties, such as `ConfigurationLockState`, contain additional information regarding the status of the configuration lock.",
900                    "longDescription": "This property shall indicate whether configuration requests to the storage subsystem are locked.  Services shall reject modification requests that contain the value `Partial`.  Modifying the value of this property may affect the `ConfigurationLock` property in `Drive` resources referenced by the `Drives` property.",
901                    "readonly": false,
902                    "versionAdded": "v1_16_0"
903                },
904                "Connections": {
905                    "$ref": "http://redfish.dmtf.org/schemas/v1/ConnectionCollection.json#/definitions/ConnectionCollection",
906                    "description": "The collection of links to the connections that this storage subsystem contains.",
907                    "longDescription": "This property shall contain a link to a resource collection of type `ConnectionCollection`.  The members of this collection shall reference Connection resources subordinate to Fabric resources.",
908                    "readonly": true,
909                    "versionAdded": "v1_15_0"
910                },
911                "ConsistencyGroups": {
912                    "$ref": "http://redfish.dmtf.org/schemas/swordfish/v1/ConsistencyGroupCollection.json#/definitions/ConsistencyGroupCollection",
913                    "description": "The consistency groups, each of which contains a set of volumes that are treated by an application or set of applications as a single resource, that are managed by this storage subsystem.",
914                    "longDescription": "This property shall contain a link to a resource collection of type `ConsistencyGroupCollection`.  The property shall be used when groups of volumes are treated as a single resource by an application or set of applications.",
915                    "readonly": true,
916                    "versionAdded": "v1_8_0"
917                },
918                "Controllers": {
919                    "$ref": "http://redfish.dmtf.org/schemas/v1/StorageControllerCollection.json#/definitions/StorageControllerCollection",
920                    "description": "The set of controllers instantiated by this storage subsystem.",
921                    "longDescription": "This property shall contain a link to a resource collection of type `StorageControllerCollection` that contains the set of storage controllers allocated to this storage subsystem.",
922                    "readonly": true,
923                    "versionAdded": "v1_9_0"
924                },
925                "Description": {
926                    "anyOf": [
927                        {
928                            "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Description"
929                        },
930                        {
931                            "type": "null"
932                        }
933                    ],
934                    "readonly": true
935                },
936                "Drives": {
937                    "description": "The set of drives attached to the storage controllers that this resource represents.",
938                    "items": {
939                        "$ref": "http://redfish.dmtf.org/schemas/v1/Drive.json#/definitions/Drive"
940                    },
941                    "longDescription": "This property shall contain a set of the drives attached to the storage controllers that this resource represents.",
942                    "readonly": true,
943                    "type": "array"
944                },
945                "Drives@odata.count": {
946                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/count"
947                },
948                "EncryptionMode": {
949                    "anyOf": [
950                        {
951                            "$ref": "#/definitions/EncryptionMode"
952                        },
953                        {
954                            "type": "null"
955                        }
956                    ],
957                    "description": "The encryption mode of this storage subsystem.",
958                    "longDescription": "This property shall contain the encryption mode of this storage subsystem.",
959                    "readonly": false,
960                    "versionAdded": "v1_14_0"
961                },
962                "EndpointGroups": {
963                    "$ref": "http://redfish.dmtf.org/schemas/v1/EndpointGroupCollection.json#/definitions/EndpointGroupCollection",
964                    "description": "All of the endpoint groups, each of which contains a set of endpoints that are used for a common purpose such as an ACL or logical identification, that belong to this storage subsystem.",
965                    "longDescription": "This property shall contain a link to a resource collection of type `EndpointGroupCollection`.  This property shall be implemented when atomic control is needed to perform mapping, masking, and zoning operations.",
966                    "readonly": true,
967                    "versionAdded": "v1_8_0"
968                },
969                "FileSystems": {
970                    "$ref": "http://redfish.dmtf.org/schemas/swordfish/v1/FileSystemCollection.json#/definitions/FileSystemCollection",
971                    "description": "All file systems that are allocated by this storage subsystem.",
972                    "longDescription": "This property shall contain a link to a resource collection of type `FileSystemCollection`.  This property shall be used when file systems are shared or exported by the storage subsystem.",
973                    "readonly": true,
974                    "versionAdded": "v1_8_0"
975                },
976                "HotspareActivationPolicy": {
977                    "anyOf": [
978                        {
979                            "$ref": "#/definitions/HotspareActivationPolicy"
980                        },
981                        {
982                            "type": "null"
983                        }
984                    ],
985                    "description": "The policy under which hot spare drives in this storage domain will activate.",
986                    "longDescription": "This property shall contain the policy under which all drives operating as hot spares in this storage domain will activate.",
987                    "readonly": false,
988                    "versionAdded": "v1_14_0"
989                },
990                "Id": {
991                    "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Id",
992                    "readonly": true
993                },
994                "Identifiers": {
995                    "description": "The durable names for the storage subsystem.",
996                    "items": {
997                        "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Identifier"
998                    },
999                    "longDescription": "This property shall contain a list of all known durable names for the storage subsystem.",
1000                    "type": "array",
1001                    "versionAdded": "v1_9_0"
1002                },
1003                "Links": {
1004                    "$ref": "#/definitions/Links",
1005                    "description": "The links to other resources that are related to this resource.",
1006                    "longDescription": "This property shall contain links to resources that are related to but are not contained by, or subordinate to, this resource."
1007                },
1008                "LocalEncryptionKeyIdentifier": {
1009                    "description": "The local encryption key identifier used by the storage subsystem.",
1010                    "longDescription": "This property shall contain the local encryption key identifier used by the storage subsystem when `EncryptionMode` contains `UseLocalKey`.",
1011                    "readonly": true,
1012                    "type": [
1013                        "string",
1014                        "null"
1015                    ],
1016                    "versionAdded": "v1_14_0"
1017                },
1018                "MPF": {
1019                    "anyOf": [
1020                        {
1021                            "$ref": "#/definitions/MPF"
1022                        },
1023                        {
1024                            "type": "null"
1025                        }
1026                    ],
1027                    "description": "The multiple physical function-related properties for storage controllers in this storage subsystem.",
1028                    "longDescription": "This property shall contain multiple physical function-related properties for storage controllers in this storage subsystem.  This property should only be present if the storage subsystem supports the use of multiple physical functions to parallelize data transfer.",
1029                    "versionAdded": "v1_20_0"
1030                },
1031                "Metrics": {
1032                    "anyOf": [
1033                        {
1034                            "$ref": "http://redfish.dmtf.org/schemas/v1/StorageMetrics.json#/definitions/StorageMetrics"
1035                        },
1036                        {
1037                            "type": "null"
1038                        }
1039                    ],
1040                    "description": "The link to the metrics associated with this storage subsystem.",
1041                    "longDescription": "This property shall contain a link to a resource of type `StorageMetrics` that represents the metrics associated with this storage subsystem.",
1042                    "readonly": true,
1043                    "versionAdded": "v1_18_0"
1044                },
1045                "NVMeSubsystemProperties": {
1046                    "anyOf": [
1047                        {
1048                            "$ref": "#/definitions/NVMeSubsystemProperties"
1049                        },
1050                        {
1051                            "type": "null"
1052                        }
1053                    ],
1054                    "description": "Information specific to NVMe Subsystems.",
1055                    "longDescription": "This property shall contain information specific to NVMe Subsystems.  This property shall only be present if this resource represents an NVMe Subsystem.",
1056                    "versionAdded": "v1_16_0"
1057                },
1058                "Name": {
1059                    "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Name",
1060                    "readonly": true
1061                },
1062                "Oem": {
1063                    "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Oem",
1064                    "description": "The OEM extension property.",
1065                    "longDescription": "This property shall contain the OEM extensions.  All values for properties that this object contains shall conform to the Redfish Specification-described requirements."
1066                },
1067                "Redundancy": {
1068                    "autoExpand": true,
1069                    "description": "Redundancy information for the storage subsystem.",
1070                    "items": {
1071                        "$ref": "http://redfish.dmtf.org/schemas/v1/Redundancy.json#/definitions/Redundancy"
1072                    },
1073                    "longDescription": "This property shall contain redundancy information for the storage subsystem.",
1074                    "type": "array"
1075                },
1076                "Redundancy@odata.count": {
1077                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/count"
1078                },
1079                "Status": {
1080                    "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Status",
1081                    "description": "The status and health of the resource and its subordinate or dependent resources.",
1082                    "longDescription": "This property shall contain any status or health properties of the resource."
1083                },
1084                "StorageControllers": {
1085                    "autoExpand": true,
1086                    "deprecated": "This property has been deprecated in favor of `Controllers` to allow for storage controllers to be represented as their own resources.",
1087                    "description": "The set of storage controllers that this resource represents.",
1088                    "items": {
1089                        "$ref": "#/definitions/StorageController"
1090                    },
1091                    "longDescription": "This property shall contain a set of the storage controllers that this resource represents.",
1092                    "readonly": true,
1093                    "type": "array",
1094                    "versionDeprecated": "v1_13_0"
1095                },
1096                "StorageControllers@odata.count": {
1097                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/count"
1098                },
1099                "StorageGroups": {
1100                    "$ref": "http://redfish.dmtf.org/schemas/swordfish/v1/StorageGroupCollection.json#/definitions/StorageGroupCollection",
1101                    "deprecated": "This property was deprecated in favor of the `Connections` property.",
1102                    "description": "All of the storage groups, each of which contains a set of volumes and endpoints that are managed as a group for mapping and masking, that belong to this storage subsystem.",
1103                    "longDescription": "This property shall contain a link to a resource collection of type `StorageGroupsCollection`.  This property shall be used when implementing mapping and masking.",
1104                    "readonly": true,
1105                    "versionAdded": "v1_8_0",
1106                    "versionDeprecated": "v1_15_0"
1107                },
1108                "StoragePools": {
1109                    "$ref": "http://redfish.dmtf.org/schemas/swordfish/v1/StoragePoolCollection.json#/definitions/StoragePoolCollection",
1110                    "description": "The set of all storage pools that are allocated by this storage subsystem.  A storage pool is the set of storage capacity that can be used to produce volumes or other storage pools.",
1111                    "longDescription": "This property shall contain a link to a resource collection of type `StoragePoolCollection`.  This property shall be used when an abstraction of media, rather than references to individual media, are used as the storage data source.",
1112                    "readonly": true,
1113                    "versionAdded": "v1_8_0"
1114                },
1115                "TargetConfigurationLockLevel": {
1116                    "anyOf": [
1117                        {
1118                            "$ref": "#/definitions/TargetConfigurationLockLevel"
1119                        },
1120                        {
1121                            "type": "null"
1122                        }
1123                    ],
1124                    "description": "Indicates the target configuration lock level for the drive based upon the state of the `ConfigurationLock` property.  Other properties, such as `ConfigurationLockState`, contain additional information regarding the status of the configuration lock.",
1125                    "longDescription": "This property shall contain the target configuration lock level for the drive.  For NVMe subsystems, services shall implement the locking requirements specified by SNIA's Swordfish NVMe Model Overview and Mapping Guide.",
1126                    "readonly": false,
1127                    "versionAdded": "v1_17_0"
1128                },
1129                "Volumes": {
1130                    "$ref": "http://redfish.dmtf.org/schemas/swordfish/v1/VolumeCollection.json#/definitions/VolumeCollection",
1131                    "description": "The set of volumes that the storage controllers produce.",
1132                    "longDescription": "This property shall contain a link to a resource collection of type `VolumeCollection`.",
1133                    "readonly": true
1134                }
1135            },
1136            "required": [
1137                "@odata.id",
1138                "@odata.type",
1139                "Id",
1140                "Name"
1141            ],
1142            "type": "object"
1143        },
1144        "StorageController": {
1145            "additionalProperties": false,
1146            "description": "The StorageController schema describes a storage controller and its properties.  A storage controller represents a physical or virtual storage device that produces volumes.",
1147            "longDescription": "This resource shall represent a storage controller in the Redfish Specification.",
1148            "patternProperties": {
1149                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
1150                    "description": "This property shall specify a valid odata or Redfish property.",
1151                    "type": [
1152                        "array",
1153                        "boolean",
1154                        "integer",
1155                        "number",
1156                        "null",
1157                        "object",
1158                        "string"
1159                    ]
1160                }
1161            },
1162            "properties": {
1163                "@odata.id": {
1164                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/id"
1165                },
1166                "Actions": {
1167                    "$ref": "#/definitions/StorageControllerActions",
1168                    "description": "The available actions for this resource.",
1169                    "longDescription": "This property shall contain the available actions for this resource.",
1170                    "versionAdded": "v1_2_0"
1171                },
1172                "Assembly": {
1173                    "$ref": "http://redfish.dmtf.org/schemas/v1/Assembly.json#/definitions/Assembly",
1174                    "description": "The link to the assembly associated with this storage controller.",
1175                    "longDescription": "This property shall contain a link to a resource of type `Assembly`.",
1176                    "readonly": true,
1177                    "versionAdded": "v1_4_0"
1178                },
1179                "AssetTag": {
1180                    "description": "The user-assigned asset tag for this storage controller.",
1181                    "longDescription": "This property shall track the storage controller for inventory purposes.",
1182                    "readonly": false,
1183                    "type": [
1184                        "string",
1185                        "null"
1186                    ]
1187                },
1188                "CacheSummary": {
1189                    "$ref": "#/definitions/CacheSummary",
1190                    "description": "The cache memory of the storage controller in general detail.",
1191                    "longDescription": "This property shall contain properties that describe the cache memory for this resource.",
1192                    "versionAdded": "v1_5_0"
1193                },
1194                "Certificates": {
1195                    "$ref": "http://redfish.dmtf.org/schemas/v1/CertificateCollection.json#/definitions/CertificateCollection",
1196                    "description": "The link to a collection of certificates for device identity and attestation.",
1197                    "longDescription": "This property shall contain a link to a resource collection of type `CertificateCollection` that contains certificates for device identity and attestation.",
1198                    "readonly": true,
1199                    "versionAdded": "v1_10_0"
1200                },
1201                "ControllerRates": {
1202                    "$ref": "#/definitions/Rates",
1203                    "description": "This property describes the various controller rates used for processes such as volume rebuild or consistency checks.",
1204                    "longDescription": "This object shall contain all the rate settings available on the controller.",
1205                    "versionAdded": "v1_7_0"
1206                },
1207                "FirmwareVersion": {
1208                    "description": "The firmware version of this storage controller.",
1209                    "longDescription": "This property shall contain the firmware version as defined by the manufacturer for the associated storage controller.",
1210                    "readonly": true,
1211                    "type": [
1212                        "string",
1213                        "null"
1214                    ]
1215                },
1216                "Identifiers": {
1217                    "description": "The durable names for the storage controller.",
1218                    "items": {
1219                        "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Identifier"
1220                    },
1221                    "longDescription": "This property shall contain a list of all known durable names for the associated storage controller.",
1222                    "type": "array"
1223                },
1224                "Links": {
1225                    "$ref": "#/definitions/StorageControllerLinks",
1226                    "description": "The links to other resources that are related to this resource.",
1227                    "longDescription": "This property shall contain links to resources that are related to but are not contained by, or subordinate to, this resource.",
1228                    "versionAdded": "v1_1_0"
1229                },
1230                "Location": {
1231                    "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Location",
1232                    "description": "The location of the storage controller.",
1233                    "longDescription": "This property shall contain the location information of the associated storage controller.",
1234                    "versionAdded": "v1_4_0"
1235                },
1236                "Manufacturer": {
1237                    "description": "The manufacturer of this storage controller.",
1238                    "longDescription": "This property shall contain the name of the organization responsible for producing the storage controller.  This organization may be the entity from which the storage controller is purchased, but this is not necessarily true.",
1239                    "readonly": true,
1240                    "type": [
1241                        "string",
1242                        "null"
1243                    ]
1244                },
1245                "Measurements": {
1246                    "deprecated": "This property has been deprecated in favor of the `ComponentIntegrity` resource.",
1247                    "description": "An array of DSP0274-defined measurement blocks.",
1248                    "items": {
1249                        "$ref": "http://redfish.dmtf.org/schemas/v1/SoftwareInventory.json#/definitions/MeasurementBlock"
1250                    },
1251                    "longDescription": "This property shall contain an array of DSP0274-defined measurement blocks.",
1252                    "type": "array",
1253                    "versionAdded": "v1_10_0",
1254                    "versionDeprecated": "v1_12_0"
1255                },
1256                "MemberId": {
1257                    "description": "The unique identifier for the member within an array.",
1258                    "longDescription": "This property shall contain the unique identifier for this member within an array.  For services supporting Redfish v1.6 or higher, this value shall contain the zero-based array index.",
1259                    "readonly": true,
1260                    "type": "string"
1261                },
1262                "Model": {
1263                    "description": "The model number for the storage controller.",
1264                    "longDescription": "This property shall contain the name by which the manufacturer generally refers to the storage controller.",
1265                    "readonly": true,
1266                    "type": [
1267                        "string",
1268                        "null"
1269                    ]
1270                },
1271                "Name": {
1272                    "description": "The name of the storage controller.",
1273                    "longDescription": "This property shall contain the name of the storage controller.",
1274                    "readonly": true,
1275                    "type": [
1276                        "string",
1277                        "null"
1278                    ],
1279                    "versionAdded": "v1_3_0"
1280                },
1281                "Oem": {
1282                    "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Oem",
1283                    "description": "The OEM extension property.",
1284                    "longDescription": "This property shall contain the OEM extensions.  All values for properties that this object contains shall conform to the Redfish Specification-described requirements."
1285                },
1286                "PCIeInterface": {
1287                    "$ref": "http://redfish.dmtf.org/schemas/v1/PCIeDevice.json#/definitions/PCIeInterface",
1288                    "description": "The PCIe interface details for this controller.",
1289                    "longDescription": "This property shall contain details on the PCIe interface that connects this PCIe-based controller to its host.",
1290                    "versionAdded": "v1_5_0"
1291                },
1292                "PartNumber": {
1293                    "description": "The part number for this storage controller.",
1294                    "longDescription": "This property shall contain a part number assigned by the organization that is responsible for producing or manufacturing the storage controller.",
1295                    "readonly": true,
1296                    "type": [
1297                        "string",
1298                        "null"
1299                    ]
1300                },
1301                "Ports": {
1302                    "$ref": "http://redfish.dmtf.org/schemas/v1/PortCollection.json#/definitions/PortCollection",
1303                    "description": "The link to the collection of ports that exist on the storage controller.",
1304                    "longDescription": "This property shall contain a link to a resource collection of type `PortCollection`.",
1305                    "readonly": true,
1306                    "versionAdded": "v1_7_0"
1307                },
1308                "SKU": {
1309                    "description": "The SKU for this storage controller.",
1310                    "longDescription": "This property shall contain the stock-keeping unit number for this storage controller.",
1311                    "readonly": true,
1312                    "type": [
1313                        "string",
1314                        "null"
1315                    ]
1316                },
1317                "SerialNumber": {
1318                    "description": "The serial number for this storage controller.",
1319                    "longDescription": "This property shall contain a manufacturer-allocated number that identifies the storage controller.",
1320                    "readonly": true,
1321                    "type": [
1322                        "string",
1323                        "null"
1324                    ]
1325                },
1326                "SpeedGbps": {
1327                    "description": "The maximum speed of the storage controller's device interface.",
1328                    "longDescription": "This property shall represent the maximum supported speed of the storage bus interface, in Gbit/s.  The specified interface connects the controller to the storage devices, not the controller to a host.  For example, SAS bus not PCIe host bus.",
1329                    "minimum": 0,
1330                    "readonly": true,
1331                    "type": [
1332                        "number",
1333                        "null"
1334                    ],
1335                    "units": "Gbit/s"
1336                },
1337                "Status": {
1338                    "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Status",
1339                    "description": "The status and health of the resource and its subordinate or dependent resources.",
1340                    "longDescription": "This property shall contain any status or health properties of the resource."
1341                },
1342                "SupportedControllerProtocols": {
1343                    "description": "The supported set of protocols for communicating with this storage controller.",
1344                    "items": {
1345                        "$ref": "http://redfish.dmtf.org/schemas/v1/Protocol.json#/definitions/Protocol"
1346                    },
1347                    "longDescription": "This property shall contain the supported set of protocols for communicating with this storage controller.",
1348                    "readonly": true,
1349                    "type": "array"
1350                },
1351                "SupportedDeviceProtocols": {
1352                    "description": "The protocols that the storage controller can use to communicate with attached devices.",
1353                    "items": {
1354                        "$ref": "http://redfish.dmtf.org/schemas/v1/Protocol.json#/definitions/Protocol"
1355                    },
1356                    "longDescription": "This property shall contain the set of protocols this storage controller can use to communicate with attached devices.",
1357                    "readonly": true,
1358                    "type": "array"
1359                },
1360                "SupportedRAIDTypes": {
1361                    "description": "The set of RAID types supported by the storage controller.",
1362                    "items": {
1363                        "anyOf": [
1364                            {
1365                                "$ref": "http://redfish.dmtf.org/schemas/swordfish/v1/Volume.json#/definitions/RAIDType"
1366                            },
1367                            {
1368                                "type": "null"
1369                            }
1370                        ]
1371                    },
1372                    "longDescription": "This property shall contain an array of all the RAID types supported by this controller.",
1373                    "readonly": true,
1374                    "type": "array",
1375                    "versionAdded": "v1_6_0"
1376                }
1377            },
1378            "required": [
1379                "@odata.id",
1380                "MemberId"
1381            ],
1382            "type": "object"
1383        },
1384        "StorageControllerActions": {
1385            "additionalProperties": false,
1386            "description": "The available actions for this resource.",
1387            "longDescription": "This type shall contain the available actions for this resource.",
1388            "patternProperties": {
1389                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
1390                    "description": "This property shall specify a valid odata or Redfish property.",
1391                    "type": [
1392                        "array",
1393                        "boolean",
1394                        "integer",
1395                        "number",
1396                        "null",
1397                        "object",
1398                        "string"
1399                    ]
1400                }
1401            },
1402            "properties": {
1403                "Oem": {
1404                    "$ref": "#/definitions/StorageControllerOemActions",
1405                    "description": "The available OEM-specific actions for this resource.",
1406                    "longDescription": "This property shall contain the available OEM-specific actions for this resource.",
1407                    "versionAdded": "v1_2_0"
1408                }
1409            },
1410            "type": "object"
1411        },
1412        "StorageControllerLinks": {
1413            "additionalProperties": false,
1414            "description": "The links to other resources that are related to this resource.",
1415            "longDescription": "This Redfish Specification-described type shall contain links to resources that are related to but are not contained by, or subordinate to, this resource.",
1416            "patternProperties": {
1417                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
1418                    "description": "This property shall specify a valid odata or Redfish property.",
1419                    "type": [
1420                        "array",
1421                        "boolean",
1422                        "integer",
1423                        "number",
1424                        "null",
1425                        "object",
1426                        "string"
1427                    ]
1428                }
1429            },
1430            "properties": {
1431                "Endpoints": {
1432                    "description": "An array of links to the endpoints that connect to this controller.",
1433                    "items": {
1434                        "$ref": "http://redfish.dmtf.org/schemas/v1/Endpoint.json#/definitions/Endpoint"
1435                    },
1436                    "longDescription": "This property shall contain an array of links to resources of type `Endpoint` with which this controller is associated.",
1437                    "type": "array",
1438                    "versionAdded": "v1_1_0"
1439                },
1440                "Endpoints@odata.count": {
1441                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/count"
1442                },
1443                "Oem": {
1444                    "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Oem",
1445                    "description": "The OEM extension property.",
1446                    "longDescription": "This property shall contain the OEM extensions.  All values for properties contained in this object shall conform to the Redfish Specification-described requirements."
1447                },
1448                "PCIeFunctions": {
1449                    "description": "An array of links to the PCIe functions that the storage controller produces.",
1450                    "items": {
1451                        "$ref": "http://redfish.dmtf.org/schemas/v1/PCIeFunction.json#/definitions/PCIeFunction"
1452                    },
1453                    "longDescription": "This property shall contain an array of links to resources of type `PCIeFunction` that represent the PCIe functions associated with this resource.",
1454                    "type": "array",
1455                    "versionAdded": "v1_7_0"
1456                },
1457                "PCIeFunctions@odata.count": {
1458                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/count"
1459                },
1460                "StorageServices": {
1461                    "deprecated": "This property has been deprecated in favor of `StorageServices` within the `Links` property at the root level.",
1462                    "description": "An array of links to the storage services that connect to this controller.",
1463                    "items": {
1464                        "$ref": "http://redfish.dmtf.org/schemas/swordfish/v1/StorageService.json#/definitions/StorageService"
1465                    },
1466                    "longDescription": "This property shall contain an array of links to resources of type `StorageService` with which this controller is associated.",
1467                    "type": "array",
1468                    "versionAdded": "v1_4_0",
1469                    "versionDeprecated": "v1_9_0"
1470                },
1471                "StorageServices@odata.count": {
1472                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/count"
1473                }
1474            },
1475            "type": "object"
1476        },
1477        "StorageControllerOemActions": {
1478            "additionalProperties": true,
1479            "description": "The available OEM-specific actions for this resource.",
1480            "longDescription": "This type shall contain the available OEM-specific actions for this resource.",
1481            "patternProperties": {
1482                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
1483                    "description": "This property shall specify a valid odata or Redfish property.",
1484                    "type": [
1485                        "array",
1486                        "boolean",
1487                        "integer",
1488                        "number",
1489                        "null",
1490                        "object",
1491                        "string"
1492                    ]
1493                }
1494            },
1495            "properties": {},
1496            "type": "object"
1497        },
1498        "TargetConfigurationLockLevel": {
1499            "enum": [
1500                "Baseline"
1501            ],
1502            "enumDescriptions": {
1503                "Baseline": "The standard configuration lock level, corresponding to applying firmware, updating security keys, and modifying other hardware settings.  It does not include managing the volumes or data within the storage subsystem."
1504            },
1505            "type": "string"
1506        },
1507        "VolumeAssignmentPolicy": {
1508            "enum": [
1509                "Unassigned",
1510                "Supervisor",
1511                "WeightedRoundRobin"
1512            ],
1513            "enumDescriptions": {
1514                "Supervisor": "Newly created volumes are assigned to the supervisor function.",
1515                "Unassigned": "Newly created volumes are not assigned to physical functions, but are added to `UnassignedVolumes` in the `Links` property within this resource.",
1516                "WeightedRoundRobin": "Newly created volumes are assigned to the physical functions in a round-robin fashion."
1517            },
1518            "type": "string"
1519        }
1520    },
1521    "language": "en",
1522    "owningEntity": "DMTF",
1523    "release": "2025.3",
1524    "title": "#Storage.v1_20_0.Storage"
1525}