1{
2    "$id": "http://redfish.dmtf.org/schemas/v1/ResourceBlock.v1_4_3.json",
3    "$ref": "#/definitions/ResourceBlock",
4    "$schema": "http://redfish.dmtf.org/schemas/v1/redfish-schema-v1.json",
5    "copyright": "Copyright 2014-2024 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                "Oem": {
27                    "$ref": "#/definitions/OemActions",
28                    "description": "The available OEM-specific actions for this resource.",
29                    "longDescription": "This property shall contain the available OEM-specific actions for this resource."
30                }
31            },
32            "type": "object"
33        },
34        "CompositionState": {
35            "enum": [
36                "Composing",
37                "ComposedAndAvailable",
38                "Composed",
39                "Unused",
40                "Failed",
41                "Unavailable"
42            ],
43            "enumDescriptions": {
44                "Composed": "Final successful state of a resource block that has participated in composition.",
45                "ComposedAndAvailable": "The resource block is currently participating in one or more compositions, and is available to use in more compositions.",
46                "Composing": "Intermediate state indicating composition is in progress.",
47                "Failed": "The final composition resulted in failure and manual intervention might be required to fix it.",
48                "Unavailable": "The resource block has been made unavailable by the service, such as due to maintenance being performed on the resource block.",
49                "Unused": "The resource block is free and can participate in composition."
50            },
51            "enumVersionAdded": {
52                "ComposedAndAvailable": "v1_1_0",
53                "Unavailable": "v1_2_0"
54            },
55            "type": "string"
56        },
57        "CompositionStatus": {
58            "additionalProperties": false,
59            "description": "Composition status of the resource block.",
60            "longDescription": "This type shall contain properties that describe the high level composition status of the resource block.",
61            "patternProperties": {
62                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
63                    "description": "This property shall specify a valid odata or Redfish property.",
64                    "type": [
65                        "array",
66                        "boolean",
67                        "integer",
68                        "number",
69                        "null",
70                        "object",
71                        "string"
72                    ]
73                }
74            },
75            "properties": {
76                "CompositionState": {
77                    "anyOf": [
78                        {
79                            "$ref": "#/definitions/CompositionState"
80                        },
81                        {
82                            "type": "null"
83                        }
84                    ],
85                    "description": "The current state of the resource block from a composition perspective.",
86                    "longDescription": "This property shall contain an enumerated value that describes the composition state of the resource block.",
87                    "readonly": true
88                },
89                "MaxCompositions": {
90                    "description": "The maximum number of compositions in which this resource block can participate simultaneously.",
91                    "longDescription": "This property shall contain a number indicating the maximum number of compositions in which this resource block can participate simultaneously.  Services can have additional constraints that prevent this value from being achieved, such as due to system topology and current composed resource utilization.  If `SharingCapable` is `false`, this value shall be set to `1`.  The service shall support this property if SharingCapable supported.",
92                    "minimum": 1,
93                    "readonly": true,
94                    "type": [
95                        "integer",
96                        "null"
97                    ],
98                    "versionAdded": "v1_1_0"
99                },
100                "NumberOfCompositions": {
101                    "description": "The number of compositions in which this resource block is currently participating.",
102                    "longDescription": "This property shall contain the number of compositions in which this resource block is currently participating.",
103                    "minimum": 0,
104                    "readonly": true,
105                    "type": [
106                        "integer",
107                        "null"
108                    ],
109                    "versionAdded": "v1_1_0"
110                },
111                "Reserved": {
112                    "description": "An indication of whether any client has reserved the resource block.",
113                    "longDescription": "This property shall indicate whether any client has reserved the resource block.  A client sets this property after the resource block is identified as composed.  It shall provide a way for multiple clients to negotiate the ownership of the resource block.",
114                    "readonly": false,
115                    "type": [
116                        "boolean",
117                        "null"
118                    ]
119                },
120                "SharingCapable": {
121                    "description": "An indication of whether this resource block can participate in multiple compositions simultaneously.",
122                    "longDescription": "This property shall indicate whether this resource block can participate in multiple compositions simultaneously.  If this property is not provided, it shall be assumed that this resource block is not capable of being shared.",
123                    "readonly": true,
124                    "type": [
125                        "boolean",
126                        "null"
127                    ],
128                    "versionAdded": "v1_1_0"
129                },
130                "SharingEnabled": {
131                    "description": "An indication of whether this resource block is allowed to participate in multiple compositions simultaneously.",
132                    "longDescription": "This property shall indicate whether this resource block can participate in multiple compositions simultaneously.  The service shall reject modifications of this property with the HTTP `400 Bad Request` status code if this resource block is already being used as part of a composed resource.  If `false`, the service shall not use the `ComposedAndAvailable` state for this resource block.",
133                    "readonly": false,
134                    "type": [
135                        "boolean",
136                        "null"
137                    ],
138                    "versionAdded": "v1_1_0"
139                }
140            },
141            "required": [
142                "CompositionState"
143            ],
144            "type": "object"
145        },
146        "Links": {
147            "additionalProperties": false,
148            "description": "The links to other resources that are related to this resource.",
149            "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.",
150            "patternProperties": {
151                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
152                    "description": "This property shall specify a valid odata or Redfish property.",
153                    "type": [
154                        "array",
155                        "boolean",
156                        "integer",
157                        "number",
158                        "null",
159                        "object",
160                        "string"
161                    ]
162                }
163            },
164            "properties": {
165                "Chassis": {
166                    "description": "An array of links to the chassis in which this resource block is contained.",
167                    "items": {
168                        "$ref": "http://redfish.dmtf.org/schemas/v1/Chassis.json#/definitions/Chassis"
169                    },
170                    "longDescription": "This property shall contain an array of links to resources of type `Chassis` that represent the physical containers associated with this resource block.",
171                    "readonly": true,
172                    "type": "array"
173                },
174                "Chassis@odata.count": {
175                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/count"
176                },
177                "ComputerSystems": {
178                    "description": "An array of links to the computer systems that are composed from this resource block.",
179                    "items": {
180                        "$ref": "http://redfish.dmtf.org/schemas/v1/ComputerSystem.json#/definitions/ComputerSystem"
181                    },
182                    "longDescription": "This property shall contain an array of links to resources of type `ComputerSystem` that represent the computer systems composed from this resource block.",
183                    "readonly": true,
184                    "type": "array"
185                },
186                "ComputerSystems@odata.count": {
187                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/count"
188                },
189                "ConsumingResourceBlocks": {
190                    "description": "An array of links to resource blocks that depend on this resource block.",
191                    "items": {
192                        "$ref": "http://redfish.dmtf.org/schemas/v1/ResourceBlock.json#/definitions/ResourceBlock"
193                    },
194                    "longDescription": "This property shall contain an array of links to resources of type `ResourceBlock` that represent the resource blocks that depend on this resource block as a component.",
195                    "readonly": true,
196                    "type": "array",
197                    "versionAdded": "v1_4_0"
198                },
199                "ConsumingResourceBlocks@odata.count": {
200                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/count"
201                },
202                "Oem": {
203                    "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Oem",
204                    "description": "The OEM extension property.",
205                    "longDescription": "This property shall contain the OEM extensions.  All values for properties contained in this object shall conform to the Redfish Specification-described requirements."
206                },
207                "SupplyingResourceBlocks": {
208                    "description": "An array of links to resource blocks that this resource block depends on.",
209                    "items": {
210                        "$ref": "http://redfish.dmtf.org/schemas/v1/ResourceBlock.json#/definitions/ResourceBlock"
211                    },
212                    "longDescription": "This property shall contain an array of links to resources of type `ResourceBlock` that represent the resource blocks that this resource block depends on as components.",
213                    "readonly": true,
214                    "type": "array",
215                    "versionAdded": "v1_4_0"
216                },
217                "SupplyingResourceBlocks@odata.count": {
218                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/count"
219                },
220                "Zones": {
221                    "description": "An array of links to the zones in which this resource block is bound.",
222                    "items": {
223                        "$ref": "http://redfish.dmtf.org/schemas/v1/Zone.json#/definitions/Zone"
224                    },
225                    "longDescription": "This property shall contain an array of links to resources of type `Zone` that represent the binding constraints associated with this resource block.",
226                    "readonly": true,
227                    "type": "array"
228                },
229                "Zones@odata.count": {
230                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/count"
231                }
232            },
233            "type": "object"
234        },
235        "OemActions": {
236            "additionalProperties": true,
237            "description": "The available OEM-specific actions for this resource.",
238            "longDescription": "This type shall contain the available OEM-specific actions for this resource.",
239            "patternProperties": {
240                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
241                    "description": "This property shall specify a valid odata or Redfish property.",
242                    "type": [
243                        "array",
244                        "boolean",
245                        "integer",
246                        "number",
247                        "null",
248                        "object",
249                        "string"
250                    ]
251                }
252            },
253            "properties": {},
254            "type": "object"
255        },
256        "PoolType": {
257            "enum": [
258                "Free",
259                "Active",
260                "Unassigned"
261            ],
262            "enumDescriptions": {
263                "Active": "This resource block is in the active pool and is contributing to at least one composed resource as a result of a composition request.",
264                "Free": "This resource block is in the free pool and is not contributing to any composed resources.",
265                "Unassigned": "This resource block is not assigned to any pools."
266            },
267            "type": "string"
268        },
269        "ResourceBlock": {
270            "additionalProperties": false,
271            "description": "The `ResourceBlock` schema contains definitions of a resource block, its components, and affinity to composed devices.",
272            "longDescription": "This resource shall represent a resource block for a Redfish implementation.",
273            "patternProperties": {
274                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
275                    "description": "This property shall specify a valid odata or Redfish property.",
276                    "type": [
277                        "array",
278                        "boolean",
279                        "integer",
280                        "number",
281                        "null",
282                        "object",
283                        "string"
284                    ]
285                }
286            },
287            "properties": {
288                "@odata.context": {
289                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/context"
290                },
291                "@odata.etag": {
292                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/etag"
293                },
294                "@odata.id": {
295                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/id"
296                },
297                "@odata.type": {
298                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/type"
299                },
300                "Actions": {
301                    "$ref": "#/definitions/Actions",
302                    "description": "The available actions for this resource.",
303                    "longDescription": "This property shall contain the available actions for this resource."
304                },
305                "Client": {
306                    "description": "The client to which this resource block is assigned.",
307                    "longDescription": "This property shall contain the client to which this resource block is assigned.",
308                    "readonly": false,
309                    "type": [
310                        "string",
311                        "null"
312                    ],
313                    "versionAdded": "v1_4_0"
314                },
315                "CompositionStatus": {
316                    "$ref": "#/definitions/CompositionStatus",
317                    "description": "The composition status details for this resource block.",
318                    "longDescription": "This property shall contain composition status information about this resource block."
319                },
320                "ComputerSystems": {
321                    "description": "An array of links to the computer systems available in this resource block.",
322                    "items": {
323                        "$ref": "http://redfish.dmtf.org/schemas/v1/ComputerSystem.json#/definitions/ComputerSystem"
324                    },
325                    "longDescription": "This property shall contain an array of links to resources of type `ComputerSystem` that this resource block contains.",
326                    "readonly": true,
327                    "type": "array",
328                    "uriSegment": "Systems"
329                },
330                "ComputerSystems@odata.count": {
331                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/count"
332                },
333                "Description": {
334                    "anyOf": [
335                        {
336                            "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Description"
337                        },
338                        {
339                            "type": "null"
340                        }
341                    ],
342                    "readonly": true
343                },
344                "Drives": {
345                    "description": "An array of links to the drives available in this resource block.",
346                    "items": {
347                        "$ref": "http://redfish.dmtf.org/schemas/v1/Drive.json#/definitions/Drive"
348                    },
349                    "longDescription": "This property shall contain an array of links to resources of type `Drive` that this resource block contains.",
350                    "readonly": true,
351                    "type": "array",
352                    "versionAdded": "v1_3_0"
353                },
354                "Drives@odata.count": {
355                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/count"
356                },
357                "EthernetInterfaces": {
358                    "description": "An array of links to the Ethernet interfaces available in this resource block.",
359                    "items": {
360                        "$ref": "http://redfish.dmtf.org/schemas/v1/EthernetInterface.json#/definitions/EthernetInterface"
361                    },
362                    "longDescription": "This property shall contain an array of links to resources of type `EthernetInterface` that this resource block contains.",
363                    "readonly": true,
364                    "type": "array"
365                },
366                "EthernetInterfaces@odata.count": {
367                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/count"
368                },
369                "Id": {
370                    "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Id",
371                    "readonly": true
372                },
373                "Links": {
374                    "$ref": "#/definitions/Links",
375                    "description": "The links to other resources that are related to this resource.",
376                    "longDescription": "This property shall contain links to resources that are related to but are not contained by, or subordinate to, this resource."
377                },
378                "Memory": {
379                    "description": "An array of links to the memory available in this resource block.",
380                    "items": {
381                        "$ref": "http://redfish.dmtf.org/schemas/v1/Memory.json#/definitions/Memory"
382                    },
383                    "longDescription": "This property shall contain an array of links to resources of type `Memory` that this resource block contains.",
384                    "readonly": true,
385                    "type": "array"
386                },
387                "Memory@odata.count": {
388                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/count"
389                },
390                "Name": {
391                    "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Name",
392                    "readonly": true
393                },
394                "NetworkInterfaces": {
395                    "description": "An array of links to the Network Interfaces available in this resource block.",
396                    "items": {
397                        "$ref": "http://redfish.dmtf.org/schemas/v1/NetworkInterface.json#/definitions/NetworkInterface"
398                    },
399                    "longDescription": "This property shall contain an array of links to resources of type `NetworkInterface` that this resource block contains.",
400                    "readonly": true,
401                    "type": "array"
402                },
403                "NetworkInterfaces@odata.count": {
404                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/count"
405                },
406                "Oem": {
407                    "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Oem",
408                    "description": "The OEM extension property.",
409                    "longDescription": "This property shall contain the OEM extensions.  All values for properties that this object contains shall conform to the Redfish Specification-described requirements."
410                },
411                "Pool": {
412                    "anyOf": [
413                        {
414                            "$ref": "#/definitions/PoolType"
415                        },
416                        {
417                            "type": "null"
418                        }
419                    ],
420                    "description": "The pool to which this resource block belongs.",
421                    "longDescription": "This property shall contain the pool to which this resource block belongs.  If this resource block is not assigned to a client, this property shall contain the value `Unassigned`.  If this resource block is assigned to a client, this property shall not contain the value `Unassigned`.",
422                    "readonly": false,
423                    "versionAdded": "v1_4_0"
424                },
425                "Processors": {
426                    "description": "An array of links to the processors available in this resource block.",
427                    "items": {
428                        "$ref": "http://redfish.dmtf.org/schemas/v1/Processor.json#/definitions/Processor"
429                    },
430                    "longDescription": "This property shall contain an array of links to resources of type `Processor` that this resource block contains.",
431                    "readonly": true,
432                    "type": "array"
433                },
434                "Processors@odata.count": {
435                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/count"
436                },
437                "ResourceBlockType": {
438                    "description": "The types of resources available on this resource block.",
439                    "items": {
440                        "$ref": "#/definitions/ResourceBlockType"
441                    },
442                    "longDescription": "This property shall contain an array of enumerated values that describe the type of resources available.",
443                    "readonly": true,
444                    "type": "array"
445                },
446                "SimpleStorage": {
447                    "description": "An array of links to the simple storage available in this resource block.",
448                    "items": {
449                        "$ref": "http://redfish.dmtf.org/schemas/v1/SimpleStorage.json#/definitions/SimpleStorage"
450                    },
451                    "longDescription": "This property shall contain an array of links to resources of type `SimpleStorage` that this resource block contains.",
452                    "readonly": true,
453                    "type": "array"
454                },
455                "SimpleStorage@odata.count": {
456                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/count"
457                },
458                "Status": {
459                    "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Status",
460                    "description": "The status and health of the resource and its subordinate or dependent resources.",
461                    "longDescription": "This property shall contain any status or health properties of the resource."
462                },
463                "Storage": {
464                    "description": "An array of links to the storage available in this resource block.",
465                    "items": {
466                        "$ref": "http://redfish.dmtf.org/schemas/v1/Storage.json#/definitions/Storage"
467                    },
468                    "longDescription": "This property shall contain an array of links to resources of type `Storage` that this resource block contains.",
469                    "readonly": true,
470                    "type": "array"
471                },
472                "Storage@odata.count": {
473                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/count"
474                }
475            },
476            "required": [
477                "CompositionStatus",
478                "ResourceBlockType",
479                "@odata.id",
480                "@odata.type",
481                "Id",
482                "Name"
483            ],
484            "type": "object"
485        },
486        "ResourceBlockLimits": {
487            "additionalProperties": false,
488            "description": "This type specifies the allowable quantities of types of resource blocks for a composition request.",
489            "longDescription": "This object shall specify the allowable quantities of types of resource blocks for a given composition request.",
490            "patternProperties": {
491                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
492                    "description": "This property shall specify a valid odata or Redfish property.",
493                    "type": [
494                        "array",
495                        "boolean",
496                        "integer",
497                        "number",
498                        "null",
499                        "object",
500                        "string"
501                    ]
502                }
503            },
504            "properties": {
505                "MaxCompute": {
506                    "description": "The maximum number of resource blocks of type `Compute` allowed for the composition request.",
507                    "longDescription": "This property shall contain an integer that specifies the maximum number of resource blocks of type `Compute` allowed for the composition request.",
508                    "minimum": 1,
509                    "readonly": true,
510                    "type": [
511                        "integer",
512                        "null"
513                    ],
514                    "versionAdded": "v1_3_0"
515                },
516                "MaxComputerSystem": {
517                    "description": "The maximum number of resource blocks of type `ComputerSystem` allowed for the composition request.",
518                    "longDescription": "This property shall contain an integer that specifies the maximum number of resource blocks of type `ComputerSystem` allowed for the composition request.",
519                    "minimum": 1,
520                    "readonly": true,
521                    "type": [
522                        "integer",
523                        "null"
524                    ],
525                    "versionAdded": "v1_3_0"
526                },
527                "MaxExpansion": {
528                    "description": "The maximum number of resource blocks of type `Expansion` allowed for the composition request.",
529                    "longDescription": "This property shall contain an integer that specifies the maximum number of resource blocks of type `Expansion` allowed for the composition request.",
530                    "minimum": 1,
531                    "readonly": true,
532                    "type": [
533                        "integer",
534                        "null"
535                    ],
536                    "versionAdded": "v1_3_0"
537                },
538                "MaxMemory": {
539                    "description": "The maximum number of resource blocks of type `Memory` allowed for the composition request.",
540                    "longDescription": "This property shall contain an integer that specifies the maximum number of resource blocks of type `Memory` allowed for the composition request.",
541                    "minimum": 1,
542                    "readonly": true,
543                    "type": [
544                        "integer",
545                        "null"
546                    ],
547                    "versionAdded": "v1_3_0"
548                },
549                "MaxNetwork": {
550                    "description": "The maximum number of resource blocks of type `Network` allowed for the composition request.",
551                    "longDescription": "This property shall contain an integer that specifies the maximum number of resource blocks of type `Network` allowed for the composition request.",
552                    "minimum": 1,
553                    "readonly": true,
554                    "type": [
555                        "integer",
556                        "null"
557                    ],
558                    "versionAdded": "v1_3_0"
559                },
560                "MaxProcessor": {
561                    "description": "The maximum number of resource blocks of type `Processor` allowed for the composition request.",
562                    "longDescription": "This property shall contain an integer that specifies the maximum number of resource blocks of type `Processor` allowed for the composition request.",
563                    "minimum": 1,
564                    "readonly": true,
565                    "type": [
566                        "integer",
567                        "null"
568                    ],
569                    "versionAdded": "v1_3_0"
570                },
571                "MaxStorage": {
572                    "description": "The maximum number of resource blocks of type `Storage` allowed for the composition request.",
573                    "longDescription": "This property shall contain an integer that specifies the maximum number of resource blocks of type `Storage` allowed for the composition request.",
574                    "minimum": 1,
575                    "readonly": true,
576                    "type": [
577                        "integer",
578                        "null"
579                    ],
580                    "versionAdded": "v1_3_0"
581                },
582                "MinCompute": {
583                    "description": "The minimum number of resource blocks of type `Compute` required for the composition request.",
584                    "longDescription": "This property shall contain an integer that specifies the minimum number of resource blocks of type `Compute` required for the composition request.",
585                    "minimum": 0,
586                    "readonly": true,
587                    "type": [
588                        "integer",
589                        "null"
590                    ],
591                    "versionAdded": "v1_3_0"
592                },
593                "MinComputerSystem": {
594                    "description": "The minimum number of resource blocks of type `ComputerSystem` required for the composition request.",
595                    "longDescription": "This property shall contain an integer that specifies the minimum number of resource blocks of type `ComputerSystem` required for the composition request.",
596                    "minimum": 0,
597                    "readonly": true,
598                    "type": [
599                        "integer",
600                        "null"
601                    ],
602                    "versionAdded": "v1_3_0"
603                },
604                "MinExpansion": {
605                    "description": "The minimum number of resource blocks of type `Expansion` required for the composition request.",
606                    "longDescription": "This property shall contain an integer that specifies the minimum number of resource blocks of type `Expansion` required for the composition request.",
607                    "minimum": 0,
608                    "readonly": true,
609                    "type": [
610                        "integer",
611                        "null"
612                    ],
613                    "versionAdded": "v1_3_0"
614                },
615                "MinMemory": {
616                    "description": "The minimum number of resource blocks of type `Memory` required for the composition request.",
617                    "longDescription": "This property shall contain an integer that specifies the minimum number of resource blocks of type `Memory` required for the composition request.",
618                    "minimum": 0,
619                    "readonly": true,
620                    "type": [
621                        "integer",
622                        "null"
623                    ],
624                    "versionAdded": "v1_3_0"
625                },
626                "MinNetwork": {
627                    "description": "The minimum number of resource blocks of type `Network` required for the composition request.",
628                    "longDescription": "This property shall contain an integer that specifies the minimum number of resource blocks of type `Network` required for the composition request.",
629                    "minimum": 0,
630                    "readonly": true,
631                    "type": [
632                        "integer",
633                        "null"
634                    ],
635                    "versionAdded": "v1_3_0"
636                },
637                "MinProcessor": {
638                    "description": "The minimum number of resource blocks of type `Processor` required for the composition request.",
639                    "longDescription": "This property shall contain an integer that specifies the minimum number of resource blocks of type `Processor` required for the composition request.",
640                    "minimum": 0,
641                    "readonly": true,
642                    "type": [
643                        "integer",
644                        "null"
645                    ],
646                    "versionAdded": "v1_3_0"
647                },
648                "MinStorage": {
649                    "description": "The minimum number of resource blocks of type `Storage` required for the composition request.",
650                    "longDescription": "This property shall contain an integer that specifies the minimum number of resource blocks of type `Storage` required for the composition request.",
651                    "minimum": 0,
652                    "readonly": true,
653                    "type": [
654                        "integer",
655                        "null"
656                    ],
657                    "versionAdded": "v1_3_0"
658                }
659            },
660            "type": "object"
661        },
662        "ResourceBlockType": {
663            "enum": [
664                "Compute",
665                "Processor",
666                "Memory",
667                "Network",
668                "Storage",
669                "ComputerSystem",
670                "Expansion",
671                "IndependentResource"
672            ],
673            "enumDescriptions": {
674                "Compute": "This resource block contains resources of type `Processor` and `Memory` in a manner that creates a compute complex.",
675                "ComputerSystem": "This resource block contains resources of type `ComputerSystem`.",
676                "Expansion": "This resource block is capable of changing over time based on its configuration.  Different types of devices within this resource block can be added and removed over time.",
677                "IndependentResource": "This resource block is capable of being consumed as a standalone component.  This resource block can represent things such as a software platform on one or more computer systems or an appliance that provides composable resources and other services and can be managed independently of the Redfish service.",
678                "Memory": "This resource block contains resources of type `Memory`.",
679                "Network": "This resource block contains network resources, such as resources of type `EthernetInterface` and `NetworkInterface`.",
680                "Processor": "This resource block contains resources of type `Processor`.",
681                "Storage": "This resource block contains storage resources, such as resources of type `Storage` and `SimpleStorage`."
682            },
683            "enumVersionAdded": {
684                "Expansion": "v1_2_0",
685                "IndependentResource": "v1_4_0"
686            },
687            "type": "string"
688        }
689    },
690    "language": "en",
691    "owningEntity": "DMTF",
692    "release": "2020.4",
693    "title": "#ResourceBlock.v1_4_3.ResourceBlock"
694}