Schema of a JSON object in a request has no properties defined
Issue ID: v3-schema-request-object-without-properties
Average severity: Medium
Description
The schema for a JSON payload does not have any properties defined.
For more details, see the OpenAPI Specification.
Example
The following is an example of how this type of risk could look in your API definition. The method defines the schema
as the JSON payload NewPet
. However, the actual content of that JSON object is not defined:
{
"post": {
"description": "Creates a new pet in the store",
"operationId": "addPet",
"requestBody": {
"description": "Pet to add to the store",
"required": true,
"content": {
"application/json": {
"schema": {
"$ref": "#/components/schemas/NewPet"
}
}
}
}
},
// ...
"NewPet": {
"type": "object",
"description": "JSON defining a Pet object"
}
}
Possible exploit scenario
If you do not clearly define the schema and you leave properties of a JSON payload empty, you effectively allow attackers to pass in any data. This means that you are opening your backend to various attacks, such as SQL injection.
This also lets attackers to try various unexpected inputs. Unexpected inputs may cause the backend server to crash or behave in an unexpected way. This in turn may cause the server to potentially leak stack trace that can be used for further attacks, or even data.
If no restrictions to the set of properties in the JSON payload are enforced, the API might also accept more fields than expected. The received payloads could be blindly transformed into an object and stored, overwriting sensitive internal data.
Remediation
Make sure you define all properties of the accepted JSON payload and set additionalProperties
to false
to enforce limitations to what the schema accepts.
{
"post": {
"description": "Creates a new pet in the store",
"operationId": "addPet",
"parameters": [
{
"name": "pet",
"in": "body",
"description": "pet to add to the system",
"required": true,
"schema": {
"$ref": "#/components/schemas/NewPet"
}
}
]
},
// ...
"NewPet": {
"type": "object",
"additionalProperties": false,
"required": [
"name"
],
"properties": {
"name": {
"type": "string",
"description": "Pet name"
},
"tag": {
"type": "string",
"description": "Pet tag"
}
}
}
}