{
    "$id": "http://redfish.dmtf.org/schemas/v1/PrivilegeRegistry.v1_2_0.json",
    "$ref": "#/definitions/PrivilegeRegistry",
    "$schema": "http://redfish.dmtf.org/schemas/v1/redfish-schema-v1.json",
    "copyright": "Copyright 2014-2025 DMTF. For the full DMTF copyright policy, see http://www.dmtf.org/about/policies/copyright",
    "definitions": {
        "Actions": {
            "additionalProperties": false,
            "description": "The available actions for this resource.",
            "longDescription": "This type shall contain the available actions for this resource.",
            "patternProperties": {
                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
                    "description": "This property shall specify a valid odata or Redfish property.",
                    "type": [
                        "array",
                        "boolean",
                        "integer",
                        "number",
                        "null",
                        "object",
                        "string"
                    ]
                }
            },
            "properties": {
                "Oem": {
                    "$ref": "#/definitions/OemActions",
                    "description": "The available OEM-specific actions for this resource.",
                    "longDescription": "This property shall contain the available OEM-specific actions for this resource.",
                    "versionAdded": "v1_1_0"
                }
            },
            "type": "object"
        },
        "Mapping": {
            "additionalProperties": false,
            "description": "The mapping between a resource type and the relevant privileges that accesses the resource.",
            "longDescription": "This type shall describe a mapping between a resource type and the relevant privileges that accesses the resource.",
            "patternProperties": {
                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
                    "description": "This property shall specify a valid odata or Redfish property.",
                    "type": [
                        "array",
                        "boolean",
                        "integer",
                        "number",
                        "null",
                        "object",
                        "string"
                    ]
                }
            },
            "properties": {
                "Entity": {
                    "description": "The resource name, such as `Manager`.",
                    "longDescription": "This property shall contain the resource name, such as `Manager`.",
                    "readonly": true,
                    "type": "string"
                },
                "OperationMap": {
                    "$ref": "#/definitions/OperationMap",
                    "description": "List mapping between HTTP methods and privilege required for the resource.",
                    "longDescription": "This property shall list the mapping between HTTP methods and the privilege required for the resource."
                },
                "PropertyOverrides": {
                    "description": "The privilege overrides of properties within a resource.",
                    "items": {
                        "$ref": "#/definitions/Target_PrivilegeMap"
                    },
                    "longDescription": "This property shall contain the privilege overrides of properties, such as the `Password` property in the `ManagerAccount` resource.",
                    "type": "array"
                },
                "ResourceURIOverrides": {
                    "description": "The privilege overrides of resource URIs.",
                    "items": {
                        "$ref": "#/definitions/Target_PrivilegeMap"
                    },
                    "longDescription": "This property shall contain the privilege overrides of resource URIs.  The target lists the resource URI and the new privileges.",
                    "type": "array"
                },
                "SubordinateOverrides": {
                    "description": "The privilege overrides of the subordinate resource.",
                    "items": {
                        "$ref": "#/definitions/Target_PrivilegeMap"
                    },
                    "longDescription": "This property shall contain the privilege overrides of the subordinate resource.  The target lists are identified by resource type.",
                    "type": "array"
                }
            },
            "type": "object"
        },
        "OemActions": {
            "additionalProperties": true,
            "description": "The available OEM-specific actions for this resource.",
            "longDescription": "This type shall contain the available OEM-specific actions for this resource.",
            "patternProperties": {
                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
                    "description": "This property shall specify a valid odata or Redfish property.",
                    "type": [
                        "array",
                        "boolean",
                        "integer",
                        "number",
                        "null",
                        "object",
                        "string"
                    ]
                }
            },
            "properties": {},
            "type": "object"
        },
        "OperationMap": {
            "additionalProperties": false,
            "description": "The specific privileges required to complete a set of HTTP operations.",
            "longDescription": "This type shall describe the specific privileges required to complete a set of HTTP operations.",
            "patternProperties": {
                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
                    "description": "This property shall specify a valid odata or Redfish property.",
                    "type": [
                        "array",
                        "boolean",
                        "integer",
                        "number",
                        "null",
                        "object",
                        "string"
                    ]
                }
            },
            "properties": {
                "DELETE": {
                    "description": "The privilege required to complete an HTTP `DELETE` operation.",
                    "items": {
                        "$ref": "#/definitions/OperationPrivilege"
                    },
                    "longDescription": "This property shall contain the privilege required to complete an HTTP `DELETE` operation.",
                    "type": "array"
                },
                "GET": {
                    "description": "The privilege required to complete an HTTP `GET` operation.",
                    "items": {
                        "$ref": "#/definitions/OperationPrivilege"
                    },
                    "longDescription": "This property shall contain the privilege required to complete an HTTP `GET` operation.",
                    "type": "array"
                },
                "HEAD": {
                    "description": "The privilege required to complete an HTTP `HEAD` operation.",
                    "items": {
                        "$ref": "#/definitions/OperationPrivilege"
                    },
                    "longDescription": "This property shall contain the privilege required to complete an HTTP `HEAD` operation.",
                    "type": "array"
                },
                "PATCH": {
                    "description": "The privilege required to complete an HTTP `PATCH` operation.",
                    "items": {
                        "$ref": "#/definitions/OperationPrivilege"
                    },
                    "longDescription": "This property shall contain the privilege required to complete an HTTP `PATCH` operation.",
                    "type": "array"
                },
                "POST": {
                    "description": "The privilege required to complete an HTTP `POST` operation.",
                    "items": {
                        "$ref": "#/definitions/OperationPrivilege"
                    },
                    "longDescription": "This property shall contain the privilege required to complete an HTTP `POST` operation.",
                    "type": "array"
                },
                "PUT": {
                    "description": "The privilege required to complete an HTTP `PUT` operation.",
                    "items": {
                        "$ref": "#/definitions/OperationPrivilege"
                    },
                    "longDescription": "This property shall contain the privilege required to complete an HTTP `PUT` operation.",
                    "type": "array"
                }
            },
            "type": "object"
        },
        "OperationPrivilege": {
            "additionalProperties": false,
            "description": "The privileges for a specific HTTP operation.",
            "longDescription": "This type shall describe the privileges required to complete a specific HTTP operation.",
            "patternProperties": {
                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
                    "description": "This property shall specify a valid odata or Redfish property.",
                    "type": [
                        "array",
                        "boolean",
                        "integer",
                        "number",
                        "null",
                        "object",
                        "string"
                    ]
                }
            },
            "properties": {
                "Privilege": {
                    "description": "An array of privileges that are required to complete a specific HTTP operation on a resource.",
                    "items": {
                        "type": "string"
                    },
                    "longDescription": "This array shall contain an array of privileges that are required to complete a specific HTTP operation on a resource.  This set of strings match zero or more strings in the `PrivilegesUsed` and `OEMPrivilegesUsed` properties.",
                    "readonly": true,
                    "type": "array"
                }
            },
            "type": "object"
        },
        "PrivilegeRegistry": {
            "additionalProperties": false,
            "description": "The `PrivilegeRegistry` schema describes the operation-to-privilege mappings.",
            "longDescription": "This resource shall contain operation-to-privilege mappings.",
            "patternProperties": {
                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
                    "description": "This property shall specify a valid odata or Redfish property.",
                    "type": [
                        "array",
                        "boolean",
                        "integer",
                        "number",
                        "null",
                        "object",
                        "string"
                    ]
                }
            },
            "properties": {
                "@odata.type": {
                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/type"
                },
                "Actions": {
                    "$ref": "#/definitions/Actions",
                    "description": "The available actions for this resource.",
                    "longDescription": "This property shall contain the available actions for this resource.",
                    "versionAdded": "v1_1_0"
                },
                "Description": {
                    "anyOf": [
                        {
                            "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Description"
                        },
                        {
                            "type": "null"
                        }
                    ],
                    "readonly": true
                },
                "Id": {
                    "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Id",
                    "readonly": true
                },
                "Mappings": {
                    "description": "The mappings between entities and the relevant privileges that access those entities.",
                    "items": {
                        "$ref": "#/definitions/Mapping"
                    },
                    "longDescription": "This property shall describe the mappings between entities and the relevant privileges that access those entities.",
                    "type": "array"
                },
                "Name": {
                    "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Name",
                    "readonly": true
                },
                "OEMPrivilegeDescriptions": {
                    "description": "The descriptions of the OEM privileges used in this mapping.",
                    "items": {
                        "type": "string"
                    },
                    "longDescription": "This property shall contain an array of the descriptions of the values of the `OEMPrivilegesUsed` property.  The order of this array shall match the order of the `OEMPrivilegesUsed` property.",
                    "readonly": true,
                    "type": "array",
                    "versionAdded": "v1_2_0"
                },
                "OEMPrivilegesUsed": {
                    "description": "The set of OEM privileges used in this mapping.",
                    "items": {
                        "type": "string"
                    },
                    "longDescription": "This property shall contain an array of OEM privileges used in this mapping.",
                    "readonly": true,
                    "type": "array"
                },
                "Oem": {
                    "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Oem",
                    "description": "The OEM extension property.",
                    "longDescription": "This property shall contain the OEM extensions.  All values for properties that this object contains shall conform to the Redfish Specification-described requirements."
                },
                "PrivilegesUsed": {
                    "description": "The set of Redfish standard privileges used in this mapping.",
                    "items": {
                        "$ref": "http://redfish.dmtf.org/schemas/v1/Privileges.json#/definitions/PrivilegeType"
                    },
                    "longDescription": "This property shall contain an array of Redfish standard privileges used in this mapping.",
                    "readonly": true,
                    "type": "array"
                }
            },
            "required": [
                "@odata.type",
                "Id",
                "Name"
            ],
            "type": "object"
        },
        "Target_PrivilegeMap": {
            "additionalProperties": false,
            "description": "This type describes a mapping between one or more targets and the HTTP operations associated with them.",
            "longDescription": "This type shall describe a mapping between one or more targets and the HTTP operations associated with them.",
            "patternProperties": {
                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
                    "description": "This property shall specify a valid odata or Redfish property.",
                    "type": [
                        "array",
                        "boolean",
                        "integer",
                        "number",
                        "null",
                        "object",
                        "string"
                    ]
                }
            },
            "properties": {
                "OperationMap": {
                    "$ref": "#/definitions/OperationMap",
                    "description": "The mapping between the HTTP operation and the privilege required to complete the operation.",
                    "longDescription": "This property shall contain the mapping between the HTTP operation and the privilege required to complete the operation."
                },
                "Targets": {
                    "description": "The set of URIs, resource types, or properties.",
                    "items": {
                        "type": [
                            "string",
                            "null"
                        ]
                    },
                    "longDescription": "This property shall contain the array of URIs, resource types, or properties.  For example, `/redfish/v1/Systems/1`, `Manager`, or `Password`.  When the `Targets` property is not present, no override is specified.",
                    "readonly": true,
                    "type": "array"
                }
            },
            "type": "object"
        }
    },
    "language": "en",
    "owningEntity": "DMTF",
    "release": "2025.3",
    "title": "#PrivilegeRegistry.v1_2_0.PrivilegeRegistry"
}