Schema Validation

    While ArangoDB is schema-less, it allows to enforce certain document structures on collection level. The desired structure can be described in the popular JSON Schema format (draft-4, without remote schema support). The level of validation and a custom error message can be configured. The system attributes , _id, _rev, _from and _to are ignored by the schema validation.

    Also see .

    Schema validation can be managed via the JavaScript API, typically using arangosh, as well as via the HTTP interface.

    • The attribute must contain the JSON Schema description.
    • level controls when the validation will be applied.
    • message sets the message that will be used when validation fails.

    To remove an existing schema from a collection, a schema value of either null or {} (empty object) can be stored:

    1. /* Remove the schema of an existing collection */
    2. db.schemaCollection.properties({ "schema": null });

    JSON Schema Rule

    The rule must be a valid JSON Schema object as outlined in the . See Understanding JSON Schema for a user guide on how to write JSON Schema descriptions.

    System attributes are invisible to the schema validation, i.e. _key, and _id (in edge collections additionally _from and _to) do not need to be specified in the schema. You may set additionalProperties: false to only allow attributes described by the schema. System attributes will not fall under this restriction.

    The level controls when the validation is triggered:

    • new: Only newly inserted documents are validated.
    • moderate: New and modified documents must pass validation, except for modified documents where the OLD value did not pass validation already. This level is useful if you have documents which do not match your target structure, but you want to stop the insertion of more invalid documents and prohibit that valid documents are changed to invalid documents.
    • strict: All new and modified document must strictly pass validation. No exceptions are made (default).

    Error message

    If the schema validation for a document fails, then a generic error is raised. The schema validation cannot pin-point which part of a rule made it fail, also see Known Issues. You may customize the error message via the attribute to provide a summary of what is expected or point out common mistakes.

    The schema validation is executed for data-modification operations according to the levels described above. That means that it can slow down document write operations, with more complex schemas typically taking more time for the validation than very simple schemas.