xref: /openbmc/bmcweb/features/redfish/schema/dmtf/json-schema/SimpleStorage.v1_3_2.json (revision f2a8e57ede74a8252100b2281e3f4d170aa69391)
1*f2a8e57eSGunnar Mills{
2*f2a8e57eSGunnar Mills    "$id": "http://redfish.dmtf.org/schemas/v1/SimpleStorage.v1_3_2.json",
3*f2a8e57eSGunnar Mills    "$ref": "#/definitions/SimpleStorage",
4*f2a8e57eSGunnar Mills    "$schema": "http://redfish.dmtf.org/schemas/v1/redfish-schema-v1.json",
5*f2a8e57eSGunnar Mills    "copyright": "Copyright 2014-2024 DMTF. For the full DMTF copyright policy, see http://www.dmtf.org/about/policies/copyright",
6*f2a8e57eSGunnar Mills    "definitions": {
7*f2a8e57eSGunnar Mills        "Actions": {
8*f2a8e57eSGunnar Mills            "additionalProperties": false,
9*f2a8e57eSGunnar Mills            "description": "The available actions for this resource.",
10*f2a8e57eSGunnar Mills            "longDescription": "This type shall contain the available actions for this resource.",
11*f2a8e57eSGunnar Mills            "patternProperties": {
12*f2a8e57eSGunnar Mills                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
13*f2a8e57eSGunnar Mills                    "description": "This property shall specify a valid odata or Redfish property.",
14*f2a8e57eSGunnar Mills                    "type": [
15*f2a8e57eSGunnar Mills                        "array",
16*f2a8e57eSGunnar Mills                        "boolean",
17*f2a8e57eSGunnar Mills                        "integer",
18*f2a8e57eSGunnar Mills                        "number",
19*f2a8e57eSGunnar Mills                        "null",
20*f2a8e57eSGunnar Mills                        "object",
21*f2a8e57eSGunnar Mills                        "string"
22*f2a8e57eSGunnar Mills                    ]
23*f2a8e57eSGunnar Mills                }
24*f2a8e57eSGunnar Mills            },
25*f2a8e57eSGunnar Mills            "properties": {
26*f2a8e57eSGunnar Mills                "Oem": {
27*f2a8e57eSGunnar Mills                    "$ref": "#/definitions/OemActions",
28*f2a8e57eSGunnar Mills                    "description": "The available OEM-specific actions for this resource.",
29*f2a8e57eSGunnar Mills                    "longDescription": "This property shall contain the available OEM-specific actions for this resource.",
30*f2a8e57eSGunnar Mills                    "versionAdded": "v1_2_0"
31*f2a8e57eSGunnar Mills                }
32*f2a8e57eSGunnar Mills            },
33*f2a8e57eSGunnar Mills            "type": "object"
34*f2a8e57eSGunnar Mills        },
35*f2a8e57eSGunnar Mills        "Device": {
36*f2a8e57eSGunnar Mills            "additionalProperties": false,
37*f2a8e57eSGunnar Mills            "description": "A storage device, such as a disk drive or optical media device.",
38*f2a8e57eSGunnar Mills            "longDescription": "This type shall describe a storage device visible to simple storage.",
39*f2a8e57eSGunnar Mills            "patternProperties": {
40*f2a8e57eSGunnar Mills                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
41*f2a8e57eSGunnar Mills                    "description": "This property shall specify a valid odata or Redfish property.",
42*f2a8e57eSGunnar Mills                    "type": [
43*f2a8e57eSGunnar Mills                        "array",
44*f2a8e57eSGunnar Mills                        "boolean",
45*f2a8e57eSGunnar Mills                        "integer",
46*f2a8e57eSGunnar Mills                        "number",
47*f2a8e57eSGunnar Mills                        "null",
48*f2a8e57eSGunnar Mills                        "object",
49*f2a8e57eSGunnar Mills                        "string"
50*f2a8e57eSGunnar Mills                    ]
51*f2a8e57eSGunnar Mills                }
52*f2a8e57eSGunnar Mills            },
53*f2a8e57eSGunnar Mills            "properties": {
54*f2a8e57eSGunnar Mills                "CapacityBytes": {
55*f2a8e57eSGunnar Mills                    "description": "The size, in bytes, of the storage device.",
56*f2a8e57eSGunnar Mills                    "longDescription": "This property shall represent the size, in bytes, of the storage device.",
57*f2a8e57eSGunnar Mills                    "minimum": 0,
58*f2a8e57eSGunnar Mills                    "readonly": true,
59*f2a8e57eSGunnar Mills                    "type": [
60*f2a8e57eSGunnar Mills                        "integer",
61*f2a8e57eSGunnar Mills                        "null"
62*f2a8e57eSGunnar Mills                    ],
63*f2a8e57eSGunnar Mills                    "units": "By",
64*f2a8e57eSGunnar Mills                    "versionAdded": "v1_1_0"
65*f2a8e57eSGunnar Mills                },
66*f2a8e57eSGunnar Mills                "Manufacturer": {
67*f2a8e57eSGunnar Mills                    "description": "The name of the manufacturer of this device.",
68*f2a8e57eSGunnar Mills                    "longDescription": "This property shall indicate the name of the manufacturer of this storage device.",
69*f2a8e57eSGunnar Mills                    "readonly": true,
70*f2a8e57eSGunnar Mills                    "type": [
71*f2a8e57eSGunnar Mills                        "string",
72*f2a8e57eSGunnar Mills                        "null"
73*f2a8e57eSGunnar Mills                    ]
74*f2a8e57eSGunnar Mills                },
75*f2a8e57eSGunnar Mills                "Model": {
76*f2a8e57eSGunnar Mills                    "description": "The product model number of this device.",
77*f2a8e57eSGunnar Mills                    "longDescription": "This property shall indicate the model information as provided by the manufacturer of this storage device.",
78*f2a8e57eSGunnar Mills                    "readonly": true,
79*f2a8e57eSGunnar Mills                    "type": [
80*f2a8e57eSGunnar Mills                        "string",
81*f2a8e57eSGunnar Mills                        "null"
82*f2a8e57eSGunnar Mills                    ]
83*f2a8e57eSGunnar Mills                },
84*f2a8e57eSGunnar Mills                "Name": {
85*f2a8e57eSGunnar Mills                    "description": "The name of the resource or array member.",
86*f2a8e57eSGunnar Mills                    "longDescription": "This object represents the name of this resource or array member.  The resource values shall conform with the Redfish Specification-described requirements.  This string value shall be of the 'Name' reserved word format.",
87*f2a8e57eSGunnar Mills                    "readonly": true,
88*f2a8e57eSGunnar Mills                    "type": "string"
89*f2a8e57eSGunnar Mills                },
90*f2a8e57eSGunnar Mills                "Oem": {
91*f2a8e57eSGunnar Mills                    "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Oem",
92*f2a8e57eSGunnar Mills                    "description": "The OEM extension property.",
93*f2a8e57eSGunnar Mills                    "longDescription": "This property shall contain the OEM extensions.  All values for properties contained in this object shall conform to the Redfish Specification-described requirements."
94*f2a8e57eSGunnar Mills                },
95*f2a8e57eSGunnar Mills                "Status": {
96*f2a8e57eSGunnar Mills                    "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Status",
97*f2a8e57eSGunnar Mills                    "description": "The status and health of the resource and its subordinate or dependent resources.",
98*f2a8e57eSGunnar Mills                    "longDescription": "This property shall contain any status or health properties of the resource."
99*f2a8e57eSGunnar Mills                }
100*f2a8e57eSGunnar Mills            },
101*f2a8e57eSGunnar Mills            "required": [
102*f2a8e57eSGunnar Mills                "Name"
103*f2a8e57eSGunnar Mills            ],
104*f2a8e57eSGunnar Mills            "type": "object"
105*f2a8e57eSGunnar Mills        },
106*f2a8e57eSGunnar Mills        "Links": {
107*f2a8e57eSGunnar Mills            "additionalProperties": false,
108*f2a8e57eSGunnar Mills            "description": "The links to other resources that are related to this resource.",
109*f2a8e57eSGunnar Mills            "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.",
110*f2a8e57eSGunnar Mills            "patternProperties": {
111*f2a8e57eSGunnar Mills                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
112*f2a8e57eSGunnar Mills                    "description": "This property shall specify a valid odata or Redfish property.",
113*f2a8e57eSGunnar Mills                    "type": [
114*f2a8e57eSGunnar Mills                        "array",
115*f2a8e57eSGunnar Mills                        "boolean",
116*f2a8e57eSGunnar Mills                        "integer",
117*f2a8e57eSGunnar Mills                        "number",
118*f2a8e57eSGunnar Mills                        "null",
119*f2a8e57eSGunnar Mills                        "object",
120*f2a8e57eSGunnar Mills                        "string"
121*f2a8e57eSGunnar Mills                    ]
122*f2a8e57eSGunnar Mills                }
123*f2a8e57eSGunnar Mills            },
124*f2a8e57eSGunnar Mills            "properties": {
125*f2a8e57eSGunnar Mills                "Chassis": {
126*f2a8e57eSGunnar Mills                    "$ref": "http://redfish.dmtf.org/schemas/v1/Chassis.json#/definitions/Chassis",
127*f2a8e57eSGunnar Mills                    "description": "The link to the chassis that contains this simple storage.",
128*f2a8e57eSGunnar Mills                    "longDescription": "This property shall contain a link to a resource of type `Chassis` that represents the physical container associated with this resource.",
129*f2a8e57eSGunnar Mills                    "readonly": true,
130*f2a8e57eSGunnar Mills                    "versionAdded": "v1_2_0"
131*f2a8e57eSGunnar Mills                },
132*f2a8e57eSGunnar Mills                "Oem": {
133*f2a8e57eSGunnar Mills                    "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Oem",
134*f2a8e57eSGunnar Mills                    "description": "The OEM extension property.",
135*f2a8e57eSGunnar Mills                    "longDescription": "This property shall contain the OEM extensions.  All values for properties contained in this object shall conform to the Redfish Specification-described requirements."
136*f2a8e57eSGunnar Mills                },
137*f2a8e57eSGunnar Mills                "Storage": {
138*f2a8e57eSGunnar Mills                    "$ref": "http://redfish.dmtf.org/schemas/v1/Storage.json#/definitions/Storage",
139*f2a8e57eSGunnar Mills                    "description": "The link to the storage instance that corresponds to this simple storage.",
140*f2a8e57eSGunnar Mills                    "longDescription": "This property shall contain a link to a resource of type `Storage` that represents the same storage subsystem as this resource.",
141*f2a8e57eSGunnar Mills                    "readonly": true,
142*f2a8e57eSGunnar Mills                    "versionAdded": "v1_3_0"
143*f2a8e57eSGunnar Mills                }
144*f2a8e57eSGunnar Mills            },
145*f2a8e57eSGunnar Mills            "type": "object"
146*f2a8e57eSGunnar Mills        },
147*f2a8e57eSGunnar Mills        "OemActions": {
148*f2a8e57eSGunnar Mills            "additionalProperties": true,
149*f2a8e57eSGunnar Mills            "description": "The available OEM-specific actions for this resource.",
150*f2a8e57eSGunnar Mills            "longDescription": "This type shall contain the available OEM-specific actions for this resource.",
151*f2a8e57eSGunnar Mills            "patternProperties": {
152*f2a8e57eSGunnar Mills                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
153*f2a8e57eSGunnar Mills                    "description": "This property shall specify a valid odata or Redfish property.",
154*f2a8e57eSGunnar Mills                    "type": [
155*f2a8e57eSGunnar Mills                        "array",
156*f2a8e57eSGunnar Mills                        "boolean",
157*f2a8e57eSGunnar Mills                        "integer",
158*f2a8e57eSGunnar Mills                        "number",
159*f2a8e57eSGunnar Mills                        "null",
160*f2a8e57eSGunnar Mills                        "object",
161*f2a8e57eSGunnar Mills                        "string"
162*f2a8e57eSGunnar Mills                    ]
163*f2a8e57eSGunnar Mills                }
164*f2a8e57eSGunnar Mills            },
165*f2a8e57eSGunnar Mills            "properties": {},
166*f2a8e57eSGunnar Mills            "type": "object"
167*f2a8e57eSGunnar Mills        },
168*f2a8e57eSGunnar Mills        "SimpleStorage": {
169*f2a8e57eSGunnar Mills            "additionalProperties": false,
170*f2a8e57eSGunnar Mills            "description": "The `SimpleStorage` schema represents the properties of a storage controller and its directly-attached devices.",
171*f2a8e57eSGunnar Mills            "longDescription": "This resource contains a storage controller and its directly-attached devices.",
172*f2a8e57eSGunnar Mills            "patternProperties": {
173*f2a8e57eSGunnar Mills                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
174*f2a8e57eSGunnar Mills                    "description": "This property shall specify a valid odata or Redfish property.",
175*f2a8e57eSGunnar Mills                    "type": [
176*f2a8e57eSGunnar Mills                        "array",
177*f2a8e57eSGunnar Mills                        "boolean",
178*f2a8e57eSGunnar Mills                        "integer",
179*f2a8e57eSGunnar Mills                        "number",
180*f2a8e57eSGunnar Mills                        "null",
181*f2a8e57eSGunnar Mills                        "object",
182*f2a8e57eSGunnar Mills                        "string"
183*f2a8e57eSGunnar Mills                    ]
184*f2a8e57eSGunnar Mills                }
185*f2a8e57eSGunnar Mills            },
186*f2a8e57eSGunnar Mills            "properties": {
187*f2a8e57eSGunnar Mills                "@odata.context": {
188*f2a8e57eSGunnar Mills                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/context"
189*f2a8e57eSGunnar Mills                },
190*f2a8e57eSGunnar Mills                "@odata.etag": {
191*f2a8e57eSGunnar Mills                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/etag"
192*f2a8e57eSGunnar Mills                },
193*f2a8e57eSGunnar Mills                "@odata.id": {
194*f2a8e57eSGunnar Mills                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/id"
195*f2a8e57eSGunnar Mills                },
196*f2a8e57eSGunnar Mills                "@odata.type": {
197*f2a8e57eSGunnar Mills                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/type"
198*f2a8e57eSGunnar Mills                },
199*f2a8e57eSGunnar Mills                "Actions": {
200*f2a8e57eSGunnar Mills                    "$ref": "#/definitions/Actions",
201*f2a8e57eSGunnar Mills                    "description": "The available actions for this resource.",
202*f2a8e57eSGunnar Mills                    "longDescription": "This property shall contain the available actions for this resource.",
203*f2a8e57eSGunnar Mills                    "versionAdded": "v1_2_0"
204*f2a8e57eSGunnar Mills                },
205*f2a8e57eSGunnar Mills                "Description": {
206*f2a8e57eSGunnar Mills                    "anyOf": [
207*f2a8e57eSGunnar Mills                        {
208*f2a8e57eSGunnar Mills                            "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Description"
209*f2a8e57eSGunnar Mills                        },
210*f2a8e57eSGunnar Mills                        {
211*f2a8e57eSGunnar Mills                            "type": "null"
212*f2a8e57eSGunnar Mills                        }
213*f2a8e57eSGunnar Mills                    ],
214*f2a8e57eSGunnar Mills                    "readonly": true
215*f2a8e57eSGunnar Mills                },
216*f2a8e57eSGunnar Mills                "Devices": {
217*f2a8e57eSGunnar Mills                    "description": "The storage devices.",
218*f2a8e57eSGunnar Mills                    "items": {
219*f2a8e57eSGunnar Mills                        "$ref": "#/definitions/Device"
220*f2a8e57eSGunnar Mills                    },
221*f2a8e57eSGunnar Mills                    "longDescription": "This property shall contain a list of storage devices related to this resource.",
222*f2a8e57eSGunnar Mills                    "type": "array"
223*f2a8e57eSGunnar Mills                },
224*f2a8e57eSGunnar Mills                "Id": {
225*f2a8e57eSGunnar Mills                    "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Id",
226*f2a8e57eSGunnar Mills                    "readonly": true
227*f2a8e57eSGunnar Mills                },
228*f2a8e57eSGunnar Mills                "Links": {
229*f2a8e57eSGunnar Mills                    "$ref": "#/definitions/Links",
230*f2a8e57eSGunnar Mills                    "description": "The links to other resources that are related to this resource.",
231*f2a8e57eSGunnar Mills                    "longDescription": "This property shall contain links to resources that are related to but are not contained by, or subordinate to, this resource.",
232*f2a8e57eSGunnar Mills                    "versionAdded": "v1_2_0"
233*f2a8e57eSGunnar Mills                },
234*f2a8e57eSGunnar Mills                "Name": {
235*f2a8e57eSGunnar Mills                    "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Name",
236*f2a8e57eSGunnar Mills                    "readonly": true
237*f2a8e57eSGunnar Mills                },
238*f2a8e57eSGunnar Mills                "Oem": {
239*f2a8e57eSGunnar Mills                    "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Oem",
240*f2a8e57eSGunnar Mills                    "description": "The OEM extension property.",
241*f2a8e57eSGunnar Mills                    "longDescription": "This property shall contain the OEM extensions.  All values for properties that this object contains shall conform to the Redfish Specification-described requirements."
242*f2a8e57eSGunnar Mills                },
243*f2a8e57eSGunnar Mills                "Status": {
244*f2a8e57eSGunnar Mills                    "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Status",
245*f2a8e57eSGunnar Mills                    "description": "The status and health of the resource and its subordinate or dependent resources.",
246*f2a8e57eSGunnar Mills                    "longDescription": "This property shall contain any status or health properties of the resource."
247*f2a8e57eSGunnar Mills                },
248*f2a8e57eSGunnar Mills                "UefiDevicePath": {
249*f2a8e57eSGunnar Mills                    "description": "The UEFI device path to access this storage controller.",
250*f2a8e57eSGunnar Mills                    "longDescription": "This property shall contain the UEFI device path that identifies and locates the specific storage controller.",
251*f2a8e57eSGunnar Mills                    "readonly": true,
252*f2a8e57eSGunnar Mills                    "type": [
253*f2a8e57eSGunnar Mills                        "string",
254*f2a8e57eSGunnar Mills                        "null"
255*f2a8e57eSGunnar Mills                    ]
256*f2a8e57eSGunnar Mills                }
257*f2a8e57eSGunnar Mills            },
258*f2a8e57eSGunnar Mills            "required": [
259*f2a8e57eSGunnar Mills                "@odata.id",
260*f2a8e57eSGunnar Mills                "@odata.type",
261*f2a8e57eSGunnar Mills                "Id",
262*f2a8e57eSGunnar Mills                "Name"
263*f2a8e57eSGunnar Mills            ],
264*f2a8e57eSGunnar Mills            "type": "object"
265*f2a8e57eSGunnar Mills        }
266*f2a8e57eSGunnar Mills    },
267*f2a8e57eSGunnar Mills    "language": "en",
268*f2a8e57eSGunnar Mills    "owningEntity": "DMTF",
269*f2a8e57eSGunnar Mills    "release": "2020.3",
270*f2a8e57eSGunnar Mills    "title": "#SimpleStorage.v1_3_2.SimpleStorage"
271*f2a8e57eSGunnar Mills}