Reference

Type-specific keywords

The type keyword is fundamental to JSON Schema. It specifies the data type for a schema.

At its core, JSON Schema defines the following basic types:

These types have analogs in most programming languages, though they may go by different names.

Language-specific info:
Python
Ruby
Perl
Objective-C
Swift

The following table maps from the names of JSON types to their analogous types in Python:

JSON Python
string string *1
number int/float *2
object dict
array list
boolean bool
null None

Footnotes

[#1] Since JSON strings always support unicode, they are analogous to unicode on Python 2.x and str on Python 3.x.

[#2] JSON does not have separate types for integer and floating-point.

The type keyword may either be a string or an array:

  • If it's a string, it is the name of one of the basic types above.
  • If it is an array, it must be an array of strings, where each string is the name of one of the basic types, and each element is unique. In this case, the JSON snippet is valid if it matches any of the given types.

Here is a simple example of using the type keyword:

Copy icon
 logo-white schema
{ "type": "number" }
Copy icon
data
42
Checkmark iconcompliant to schema
Copy icon
data
42.0
Checkmark iconcompliant to schema
Copy icon
data
"42"
Error iconnot compliant to schema

In the following example, we accept strings and numbers, but not structured data types:

Copy icon
 logo-white schema
{ "type": ["number", "string"] }
Copy icon
data
42
Checkmark iconcompliant to schema
Copy icon
data
"Life, the universe, and everything"
Checkmark iconcompliant to schema
Copy icon
data
["Life", "the universe", "and everything"]
Error iconnot compliant to schema

For each of these types, there are keywords that only apply to those types. For example, numeric types have a way of specifying a numeric range, that would not be applicable to other types. In this reference, these validation keywords are described along with each of their corresponding types in the following chapters.

Format

The format keyword conveys semantic information for values that may be difficult or impossible to describe using JSON Schema. Typically, this semantic information is described by other documents. The JSON Schema Validation specification defines several formats, but this keyword also allows schema authors to define their own formats.

For example, because JSON doesn't have a "DateTime" type, dates need to be encoded as strings. format allows the schema author to indicate that the string value should be interpreted as a date. By default, format is just an annotation and does not affect validation.

Optionally, validator implementations can provide a configuration option to enable format to function as an assertion rather than just an annotation. That means that validation fails when, for example, a value with a date format isn't in a form that can be parsed as a date. This allows values to be constrained beyond what other tools in JSON Schema, including Regular Expressions, can do.

Implementations may provide validation for only a subset of the built-in formats or do partial validation for a given format. For example, some implementations may consider a string an email if it contains an @, while others might perform additional checks for other aspects of a well-formed email address.

The JSON Schema specification has a bias toward networking-related formats due to its roots in web technologies. However, custom formats may also be used if the parties exchanging the JSON documents share information about the custom format types. A JSON Schema validator will ignore any format type it does not understand.

Built-in Formats

It should be noted that format is not limited to a specific set of valid values or types. Users may define their own custom keywords including ones that work with JSON data types other than string, such as number. Below, we cover the formats specified in the JSON Schema specification.

Dates and Times

Dates and times are represented in RFC 3339, section 5.6. RFC 3339 is a specification from the Internet Engineering Task Force (IETF).

  • "date-time": Date and time together, for example, 2018-11-13T20:20:39+00:00.
  • "time":
    info yellowNew in draft 7
    Time, for example, 20:20:39+00:00.
  • "date":
    info yellowNew in draft 7
    Date, for example, 2018-11-13.
  • "duration":
    info yellowNew in draft 2019-09
    A duration as defined by the ISO 8601 ABNF for "duration". For example, P3D expresses a duration of 3 days.

Email Addresses

  • "email": Internet email address, see RFC 5321, section 4.1.2.
  • "idn-email":
    info yellowNew in draft 7
    The internationalized form of an Internet email address, see RFC 6531.

Hostnames

IP Addresses

Resource Identifiers

  • "uuid":
    info yellowNew in draft 2019-09
    A Universally Unique Identifier as defined by RFC 4122. Example: 3e4666bf-d5e5-4aa7-b8ce-cefe41c7568a.
  • "uri": A universal resource identifier (URI), according to RFC3986.
  • "uri-reference":
    info yellowNew in draft 6
    A URI Reference (either a URI or a relative-reference), according to RFC3986, section 4.1.
  • "iri":
    info yellowNew in draft 7
    The internationalized equivalent of a "uri", according to RFC3987.
  • "iri-reference":
    info yellowNew in draft 7
    The internationalized equivalent of a "uri-reference", according to RFC3987.

URI Template

  • "uri-template":
    info yellowNew in draft 6
    A URI Template (of any level) according to RFC6570. If you don't already know what a URI Template is, you probably don't need this value.

JSON Pointer

  • "json-pointer":
    info yellowNew in draft 6
    A JSON Pointer, according to RFC6901. There is more discussion on using JSON Pointer within JSON Schema in Structuring a complex schema. Note that this should be used only when the entire string contains only JSON Pointer content, e.g., /foo/bar. JSON Pointer URI fragments, e.g., #/foo/bar/ should use "uri-reference".
  • "relative-json-pointer":
    info yellowNew in draft 7
    A relative JSON pointer.

Regular Expressions

  • "regex":
    info yellowNew in draft 7
    A regular expression that should be valid according to the ECMA 262 dialect. Be careful, in practice, JSON Schema validators are only required to accept the safe subset of regular expressions described elsewhere in this document.

Need Help?

Did you find these docs helpful?

Help us make our docs great!

At JSON Schema, we value docs contributions as much as every other type of contribution!

Still Need Help?

Learning JSON Schema is often confusing, but don't worry, we are here to help!.