Default value

Default value keyword

Edit on GitHub

You can specify a default value for an item using the default keyword. When a data doesn’t have a corresponding value, the value of this keyword will be used instead to do the validation checks. This keyword is not mandatory, and the value of this keyword can be anything.

This keyword can alter the input data, defining the missing properties on objects, as shown in this PHP example. You can disable it by setting the allowDefaults option to false.

The default value will be set only when is part of the property schema ($ref won’t work).

{
    "type": "object",
    "properties": {
        "prop1": {
            "type": "string",
            "default": "test"
        }
    }
}
Input Status
{"prop1": "string"} valid
{} valid - the default value for prop1 is not required
{"prop1": 5} invalid - not a string
{
    "type": "object",
    "properties": {
        "prop1": {
            "$ref": "#/$defs/str"
        }
    },
    "$defs": {
        "str": {
            "type": "string",
            "default": "test"
        }
    }
}

PHP Example

Consider the following schema

{
  "$id": "http://example.com/schema.json",
  
  "type": "object",
  "properties": {
    "name": {
      "type": "string"
    },
    "age": {
      "$comment": "value is null <=> age not disclosed",
      "type": ["integer", "null"],
      "default": null
    }
  },
  "required": ["name"]
}

As you can see, the name is required, but the age isn’t. If not present, the age should be considered not disclosed (value is null).

Our PHP code is something like this:

$data = (object)['name' => 'Opis', 'age' => 18];

$result = $validator->validate($data, "http://example.com/schema.json");
if ($result->isValid()) {
    inset_into_db($data->name, $data->age);
}

What happens when age property is missing?

$data = (object)['name' => 'Opis'];

The age property is automatically added to the object with the default value. In this way you avoid the double check, so you don’t have to do:

$data->age ?? null

You might think that this isn’t something that saved precious time. Well… what if we had another property, let’s say address, that contains an object?

Instead of editing the same object in two or more files, you edit just the value of the default keyword.

{
  "type": "object",
  "properties": {
    "address": {
      "type": "object",
      "properties": {
        "country": {},
        "county": {},
        "city": {},
        "street": {},
        "street2": {}
      },
      "default": {
        "country": null,
        "county": null,
        "city": null,
        "street": "",
        "street2": ""
      }
    }
  }
}

Now in php you have to do something like this

$data->address ?? (object) [
    'country' => null,
    'county' => null,
    'city' => null,
    'street' => '',
    'street2' => '',
];

The fun begins when you have to add the zip property to the address: add it into the schema document, then find where you have to change in PHP files just to add the same object. We hate that, that’s way we set the object’s missing properties to default values (if default keyword is present).

If you don’t want this behavior just disable it by setting the allowDefaults option to false.

On this page