Skip to content

Definition of the SpecIF JSON-schema and constraint checker

License

Notifications You must be signed in to change notification settings

GfSE/SpecIF-Schema

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 

Repository files navigation

SpecIF - Specification Integration Facility

SpecIF - JSON-schema and constraint checker

Definition of the SpecIF JSON-schema and constraint checker.

This repository is part of the SpecIF-initiative and included as submodule into the main repository https://github.com/GfSE/SpecIF. Take a look here or at https://specif.de for details.

Schema

The SpecIF schema is developed according to JSON-schema using this Github repository. It is hosted by

Sometimes the question is raised why there is a version v1.1 so shortly after v1.0. In fact there is no need for any additional feature. SpecIF v1.0 is particularly well suited to get acquainted with SpecIF concepts, as simple tasks allow a simple representation. If more advanced features such as multi-language support are needed, the SpecIF schema v1.0 would allow a more elaborate structure. While the learning is facilitated, the structural variance makes system implementation including transformations more complicated. Also, some development teams may decide to only implement certain structure variants, resulting in compatibility problems. For that reason the schema v1.1 has eliminated all structural variances. Now the data structure seems to be more complicated, because all features are always accounted for, but the structure is always the same: When a certain element may have several values, it is always a list, even if it has only one member.

Constraints

In addition to the schema, the following constraints apply for SpecIF v1.1:

  • An item's 'key' consisting of 'id' and 'revision' must be unique. By default of a revision, the id must be unique.
  • dataType 'xs:integer' or 'xs:double': If both exist, 'minInclusive' must be smaller or equal than 'maxInclusive'.
  • dataType: If present, the list of enumerated values must have at least one entry.
  • dataType except 'xs:string': If present, the list of enumerated values must have entries of type string.
  • dataType 'xs:string': If present, the list of enumerated values must have entries with multi-language texts each.
  • A propertyClass's 'dataType' must reference a member of dataTypes by key.
  • propertyClass: If present, the list of default values must not have more than one value, unless 'multiple' is true.
  • propertyClass: If present, the list of default values must have valid entries according to the referenced dataType (see below).
  • resourceClass not extending another: The list of propertyClasses must reference at least one a member of propertyClasses by key.
  • resourceClass extending another: If present, the list of propertyClasses must reference members of propertyClasses by key.
  • A resourceClass's 'extends' must reference a resourceClass by key.
  • statementClass: If present, a list of propertyClasses must reference members of propertyClasses by key.
  • A statementClass's 'subjectClasses': If present, the list must reference members of resourceClasses or statementClasses by key.
  • A statementClass's 'objectClasses': If present, the list must reference members of resourceClasses or statementClasses by key.
  • A statementClass's 'extends' must reference a statementClass by key.
  • A resource's 'class' must reference a member of resourceClasses by key.
  • A resource's 'properties' must have valid entries according to the referenced dataType (see below).
  • A statement's 'class' must reference a member of statementClasses by key.
  • A statement's 'subject' must reference a valid resource or statement.
  • A statement's 'subject' must have a class which is listed in the subjectClasses of the statement's class, if such subjectClasses are defined.
  • A statement's 'object' must reference a valid resource or statement.
  • A statement's 'object' must have a class which is listed in the objectClasses of the statement's class, if such objectClasses are defined.
  • A statement's 'subject' and 'object' may have the same id, but if so, the revisions must be different (because only one revision of an element can be valid at a time).
  • A statement's 'properties' must have valid entries according to the referenced dataType (see below).
  • A node's 'resource' must reference a member of resources by key.
  • The list of values must not have more than one item, unless 'multiple' of the propertyClass (or by default of the dataType) is true.
  • Underlying dataType defines enumerated values: If present, the list of values must have entries defined as id in the dataType's enumeration list.
  • Underlying dataType 'xs:string' without enumerated values: If present, the list of values must have multilanguage text items.
  • Underlying dataType except 'xs:string' without enumerated values: If present, the list of values must have string items.
  • Underlying dataType 'xs:boolean' without enumerated values: Each item of the value list must be either 'true' or 'false'.
  • Underlying dataType 'xs:dateTime' without enumerated values: Each item of the value list must be a date-time according to ISO 8601.
  • Underlying dataType 'xs:anyURI' without enumerated values: Each item of the value list must be a valid URI string according to according to RFC 3986.
  • Underlying dataType 'xs:integer' without enumerated values: Each item of the value list must be a valid integer number.
  • Underlying dataType 'xs:double' without enumerated values: Each item of the value list must be a valid number.
  • Underlying dataType 'xs:integer' or 'xs:double' without enumerated values: Each item of the value list must be larger or equal to the dataTypes 'minInclusive', if defined.
  • Underlying dataType 'xs:integer' or 'xs:double' without enumerated values: Each item of the value list must be smaller or equal to the dataTypes 'maxInclusive', if defined.
  • Underlying dataType 'xs:string' without enumerated values: Each multilanguage object of the value list must not be longer than 'maxLength', if defined.

Checking

A schema and constraint checker is available as JavaScript class using this Github repository. It is hosted by

Usage:

...
// Required: https://github.com/epoberezkin/ajv/releases/tag/4.8.0 or later 
let checker = new CCheck(),
    result;
// 1. Check the schema:
result = checker.checkSchema(<specif-data>, { schema: <specif-schema> });
if (result.status == 0) {
    // 2.  Further check the constraints:
    result = checker.checkConstraints(<specif-data>, { dontCheck: ['statement.subject','subject.object','text.length'] });
    if (result.status == 0) {
        // all is fine, continue processing:
        ...
    }
    else {
        // constraint checking has failed:
        ... process/show result
    };
}
else {
    // schema checking has failed:
    ... process/show result
};
...

The checking routines return an object similar to jqXHR, namely

{status:900,statusText:"<string>",responseType:"text",responseText:"<string>"}.

About

Definition of the SpecIF JSON-schema and constraint checker

Resources

License

Stars

Watchers

Forks

Packages

No packages published