This document defines SHACL Profiling.
SHACL, the Shapes Constraint Language, is a language for describing the structure of RDF graphs. SHACL may be used for a variety of purposes such as validating, inferencing, modeling domains, generating ontologies to inform other agents, building user interfaces, generating code, and integrating data.
SHACL Profiling defines elements of the SHACL Shapes Constraint Language created to allow for profiles of SHACL and profiling with SHACL. This document's scope is limited to profiling of RDF graphs, including graphs containing SHACL Shapes.
This specification is published by the Data Shapes Working Group.The introduction provides background concepts of profiling and states this specification's scope. It also provides term definitions and describes document conventions.
Section 2 covers packaging of SHACL for management.
Sections 3 & 4 cover the two main modes of profiling with SHACL, building on packaging.
Profiling is the act of creating a "profile" of something.
Generically, in English, a "profile" of something is as follows:
The outline of a physical object or feature, or a representation of this
- Oxford English dictionary, use of the word "profile" since the 17th century
Within the world of data, a derived definition of "profile" consistent with the above is:
A summary or an extraction
In this definition, the essence of the English word is retained, since a summary or extraction of or from a data object may be an outline of it; for example, a 2D representation of a 3D spatial object. or a statistical summary of a dataset having lots of parts.
Warning: This background of profiling up to this point in the Introduction may be up-streamed to an updated version of [[[dx-prof]]].
By definition, SHACL constrains RDF data. Therefore, any data that is valid according to a shapes graph will be a profile of the data graph. If a shapes graph validates all elements of a data graph, the resulting valid data will be a "null" profile of the data graph, meaning it is identical to the original data graph.
[[[dx-prof]]] defines a profile in the context of a specification to be:
a specification that constrains, extends, combines, or provides guidance or explanation about the use of other specifications
If a shapes graph is taken to be a "specification," then not only is the data that is valid according to the shapes graph a profile of the validated data graph, but the shapes graph itself also serves as a profile of the data model used for the data graph.
Within this document, we describe how to package SHACL information for optimal profiling and we exemplify this with packaging of the SHACL shapes created for each of the SHACL Specifications.
With the above section's concepts in mind, this specification defines the following:
Terminology used throughout this specification is either defined here or taken from one of several sources. Those other sources are:
Terms taken from other sources are linked to their definitions in text.
The terms defined here are:
A profile of a specification in which implements some, and likely all, of the specification's rules, but definitely no additional rules.
The purpose of a null profile is to provide profiling artefacts, such as an executable validator, when the specification being profiled does not.
An RDF/OWL class or property defined by one of the SHACL specifications.
Warning: The definition of null profile may be up-streamed to an updated version of [[[dx-prof]]]. See Issue dx-prof/56.
All the defined terms used in this specification are listed in the index.
Within this specification, the following namespace prefix definitions are used:
| Prefix | Namespace |
|---|---|
dcterms: |
http://purl.org/dc/terms/ |
ex: |
http://example.com/ns# |
owl: |
http://www.w3.org/2002/07/owl# |
prof: |
http://www.w3.org/ns/dx/prof/ |
rdfs: |
http://www.w3.org/2000/01/rdf-schema# |
role: |
http://www.w3.org/ns/dx/prof/role/ |
sh: |
http://www.w3.org/ns/shacl# |
shpr: |
http://www.w3.org/ns/shpr# |
Within this specification, the following JSON-LD context is used:
{
"@context": {
"dcterms": "http://purl.org/dc/terms/",
"ex": "http://example.com/ns#",
"owl": "http://www.w3.org/2002/07/owl#",
"prof": "http://www.w3.org/ns/dx/prof/" ,
"rdfs": "http://www.w3.org/2000/01/rdf-schema#",
"role": "http://www.w3.org/ns/dx/prof/role/" ,
"sh": "http://www.w3.org/ns/shacl#",
"shpr": "http://www.w3.org/ns/shpr#"
}
}
Note that the URI of the graph defining the SHACL vocabulary itself is equivalent to
the namespace above, i.e., it includes the #.
References to the SHACL vocabulary, e.g., via owl:imports should include the #.
Throughout the specification, color-coded boxes containing RDF graphs in Turtle and JSON-LD will appear. The color and title of a box indicate whether it is a shapes graph, a data graph, or something else. The Turtle specification fragments use the prefix bindings given above. Only the Turtle specifications will have parts highlighted.
Conventions within figures are described by this key:
This document defines extensions to the data model of the SHACL Core specification [shacl12-core] for the purposes of profiling.
As well as sections marked as non-normative, all authoring guidelines, diagrams, examples, and notes in this specification are non-normative. Everything else in this specification is normative.
The syntactic rules specified here are given in English and use keywords MAY, MUST, MUST NOT, RECOMMENDED, SHOULD, and SHOULD NOT that are to be interpreted as described in BCP 14 [[RFC2119]] [[RFC8174]] when, and only when, they appear in all capitals, as shown here.
Conformance claims of data to this specification's rules can be tested by validation using the SHACL-SHACL Profiling validator in the SHACL-SHACL Annex of the SHACL Overview specification [shacl12-overview]
Packaging of SHACL is the presentation of SHACL elements in relation to container objects.
There are multiple reasons one might want to identify groups of SHACL elements and to know the relations between groups and individual SHACL elements. These reasons include wanting to understand the purpose(s) of a group, how a change in one group affects another group, and how to create a new group. Three Use Cases have been articulated for this:
Solutions to the Use Cases indicated above result in the following recommendations that build on well-established practice, such as the use of instances of sh:ShapesGraph to group SHACL elements:
sh:ShapesGraph SHOULD be used to group instances of SHACL elementssh:ShapesGraph that defines it with the rdfs:isDefinedBy predicatesh:ShapesGraph that uses a SHACL element, but does not define it, SHOULD indicate the SHACL element as a member with the rdfs:member predicatesh:ShapesGraph being used to group SHACL elements SHOULD indicate dependence on other groups of SHACL elements identified using instances of sh:ShapesGraph with the owl:imports predicateThe following subsections detail each of these recommendations.
Instances of sh:ShapesGraph SHOULD be used to group instances of SHACL element.
SHACL elements, like much other RDF definitional data, have often been grouped within instances of [[[owl2-rdf-based-semantics]]]'s
owl:Ontology class.
For example, the Open Geospatial Consortium's
GeoSPARQL 1.1 standard for spatial RDF data provides a
SHACL validator
containing 27 instances of sh:NodeShape and a similar number of instances of sh:PropertyShape within a Turtle
file. The file also contains an instance of owl:Ontology presenting metadata for the validating resource, such as its
modified date, a license for its use, and so on.
This recommendation supersedes that practice and recommends that sh:ShapesGraph, a specialised subclass
of owl:Ontology, be used to group SHACL elements. This is to avoid ambiguous grouping objects.
An instance of SHACL element SHOULD indicate the instance of sh:ShapesGraph that defines it with the rdfs:isDefinedBy predicate.
Common practice when placing SHACL elements into groups identified by use of an sh:ShapesGraph instance
has been to just contain the elements and the ontology instance in an RDF file. This is reasonable for data exchange
but, when exchanged files are stored in an RDF database, associations between an sh:ShapesGraph instance
and the SHACL elements defined within it may be lost. If loaded into a named graph,
the association might be kept with the named graph grouping the ontology and the SHACL elements but this is a non-semantic
association, i.e. one not seen directly in a graph.
This recommendation suggests that the creator of a SHACL element SHOULD indicate the group within which the SHACL element is defined. An example of such an assertion in RDF is as follows:
In Section 2.5 Syntactic Variations of Shapes and Classes of [[[shacl12-core]]], a warning is issued that while property shapes may be declared as blank nodes, it is preferable to declare them as IRIs as this enables better reuse across graphs. If including information about the shapes as per this section, IRIs SHOULD be used.
An instance of sh:ShapesGraph that uses a SHACL element, but does not define it, SHOULD indicate the SHACL element as a member with the rdfs:member predicate
When a SHACL element is used within a group of elements but not defined by it, it SHOULD NOT be indicated as being defined by that group, so the recommendation in the section above is irrelevant. Reuse of SHACL elements within groups that do not define them is expected and encouraged, according to Linked Data principles [[?LDP]].
An example of the use of the rdfs:member predicate to indicate inclusion of a SHACL element in a group
that does not define it, as well use of rdfs:isDefinedBy, as in the example above, is as follows:
Instances of sh:ShapesGraph being used to group SHACL elements SHOULD indicate dependence on other groups of SHACL elements identified using instances of sh:ShapesGraph with the owl:imports predicate.
It is established practice within SHACL validation tooling to import SHACL elements from one collection, such as a
file containing RDF data, into another via an owl:imports instruction. Many SHACL validation engines
do this, such as pySHACL [[?PYSH]], and this practice is recommended to indicate dependence from one collection/group
to another, even if no particular validation engine's actions are expected to arise from the assertion: it is
likely usefully informative for SHACL data management too.
An example of owl:imports is as per the example below.
Dependency implications can be drawn from the use of the four recommendations above which can be used to answer the three Use Cases indicated in the Motivation section.
TODO
It may be necessary to persist the result of a validation action performed
on a data graph by a
shapes graph in RDF. If so,
a data graph DG MAY be indicated as being conformant to the
shapes graph SG using the predicate
shpr:conformsTo. In this situation, DG will be inferred to be an instance of
sh:DataGraph and SG an instance of sh:ShapesGraph.
This section describes how existing profiles of SHACL 1.2 are made, gives examples of some and indicates how to create more profiles of SHACL.
See Annex A for a listing of profiles of SHACL known at the time of this specification's publication and for links to community managed profiles.
Profiles of SHACL should be declared using [[[dx-prof]]]. The declaration of the Core profile of SHACL 1.2 is as follows:
This declaration identifies the Core profile with the IRI <http://www.w3.org/ns/shacl/profile/core> and
indicates it is an instance of prof:Profile, that it is a profile of the original SHACL publication from
2015 and that it has two profile resources: a specification and a validator.
When described using terminology from [[[dx-prof]]], the online document form of each specification linked to above is just one of many resources that together make a profile of SHACL 1.2. The document plays the resource role of Specification — "Defining the profile in human-readable form" — and other resources play other roles. Of particular interest to SHACL users is the SHACL shapes graph for each profile that plays the role of Validation — "Supplies instructions about how to verify conformance of data to the profile". The various profiles of SHACL 1.2 may supply additional resources with other profile resource roles.
The shapes graph validation resources are given in SHACL 1.2 Overview's SHACL-SHACL appendix.
To validate RDF data against any of these Specification Profiles, or the Union Profile defined below, use the SHACL-SHACL shapes graphs listed in the SHACL 1.2 Overview's SHACL-SHACL appendix.
Describe how to pick and choose SHACL elements to support in your profile using Packaging of SHACL.
A profile of SHACL 1.2 for each of the specifications listed above is known at the time of this specification's publication. In addition, a union profile - all the specification profiles combined - is also known.
A computational effort-defined profile of SHACL and a SHACL UI implementation effort-defined profile of SHACL are also known.
These known profiles are listed in Appendix A and future profiles of SHACL are to be listed in the W3C SHACL community controlled repository at https://github.com/w3c/shacl-resources.
Here are some other profiles of SHACL that use different logic to scope their contents.
Additional profiles of SHACL 1.2 may be created using any criteria. For example, it may be desirable to have profiles of SHACL 1.2 Core that only implement shape types limited to particular computation complexities, much like the profiles of OWL [[[?owl2-profiles]]]. In this case, a profile definition could be made that uses the mechanisms given in the Packaging SHACL section above, to only include some of SHACL 1.2 Core's elements.
When making profiles of SHACL 1.2, it is important to identify and present the profile as per the currently known profiles of SHACL 1.2 — the Specification Profiles and the Union Profile — so they can be used effectively, including by others. Creators of profiles of SHACL 1.2 SHOULD:
This section describes how to create profiles of different kinds of things with SHACL.
General profiling terms and elements from [[[dx-prof]]] are used as well as more specialised SHACL profiling elements defined in the .
Aligning with [[[dx-prof]]], we take the term Specification to be synonymous with the term Standard.
SHACL is often used to test whether data matches a known Specification. If the SHACL used for such testing implements no rules other than those in the specification, the SHACL shapes graph creates a null profile of the specification.
If a Shapes Graph implements more/different rules than just those in the specification, then it is testing for a (non-null) profile of the specification.
If a Shapes Graph SG1 is profiling a specification S1 then, following
the characterisation of [[[dx-prof]]]:
However, SG1 is also playing the role of Validation,
so a more complete [[[dx-prof]]] characterisation of the situation would be:
This is an unexpected use of [[[dx-prof]]], where the profile is also playing a role usually performed by a part of, or one of, the resources of the profile, rather than having a single profile resource playing all roles, but it is legitimate, and will still achieve the PROF goal of allowing a conceptual profile to indicate a resource that performs a common profiling resource role — validation.
To indicate that a profile resource is using [[[shacl12-core]]] and available in Turtle, the following can also be added to the characterisation:
If SG1 is also considered the normative expression of the profile's requirements, as opposed to perhaps a
separate human language document containing them, then the prof:hasRole value of role:constraints
may also be applied to the resource.
If there is no separate human language document about the profile, then the prof:hasRole value of
role:specification may also be applied to the resource. This is not optimal, however, as
role:specification is specified to "[define] the profile in human-readable form" and while SHACL is
human-readable, natural language prose is expected.
What Use Cases does this reasoning address?
As per , we can indicate the validity of a data graph
according to a shapes graph with the predicate sh:conformsTo.
This predicate is a sub property of the [[DCTERMS]] predicate dcterms:conformsTo used in [[[dx-prof]]].
Following , if we have <DG1> sh:conformsTo <SG1>, which may
have been asserted after testing the conformance of the Data Graph to the Shapes Graph by validation
we can infer that:
Following the [[[dx-prof]]] axiom of dcterms:conformsTo owl:propertyChainAxiom ( dcterms:conformsTo prof:isProfileOf ) then, if given
and
we can conclude that
This reasoning allows for static conformance claims of data to profiles of specifications and specifications themselves to be made which will have utility for data whose conformance to these things must be known but which cannot be continuously validated.
Section content removed as duplicative of Profiling Specifications above.
SHACL is a language that can implement constraints and inference rules for RDF data. These two things are not the complete set of things that a profile designer may wish to do; for example, they may want to include documentation about why and how the profile was created, or provide new model elements (classes, predicates, etc.) within an extended schema.
Since SHACL cannot be used for all possible profile parts, profile designers need to look to specifications outside the SHACL family of specifications for guidance on a profile's total set of parts and how to relate them to one another. [[[dx-prof]]] is expected to be used for this.
Referencing [[[dx-prof]]]'s vocabulary of Resource Role Instances, it seems clear that SHACL graphs can perform the role of Validation within a profile and perhaps also the role of Specification, since SHACL can be used to declare Node and Property Shapes just as OWL can be used to declare Classes and Properties.
SHACL shapes naturally constrain models and data, therefore if used to indicate how a profile constrains a thing — a standard or another profile — they could perform the role of Constraints.
They could also perform the role of Mapping, if SHACL Rules are implemented to transform data from one model to another.
Profile hierarchies are arrangements in which a profile is a specialization of another, forming a chain where more specific profiles inherit constraints from broader ones. As per the rules of the [[[dx-prof]]], if
C is a profile of B and B is a profile of A, then data
wanting to be conformant to C can only be valid if it is also conformant to B and A.
Checking conformance of data to profiles means testing the data with a profile resource with the Validation role.
Incomplete
A null profile of a specification, created using SHACL, is a profile of that specification in which SHACL is used to implement some, and likely all the specification's rules, but no other rules, in SHACL.
The main purpose of creating a null profile of a specification using SHACL is to enable the testing of conformance to that specification by SHACL validation. This purpose exists because many RDF data models exist that have a model specification, perhaps an OWL model or only a natural-language document of a model, but do not provide a mechanism for data validation, such as a SHACL validator. Examples of such models are: [[[vocab-dcat-3]]], [[[schema-org]]], [[[vocab-data-cube]]], and many W3C standards.
While null profiles of specifications can be created using mechanism other than SHACL, here we focus only on the use of SHACL.
An example of a non-SHACL validator for RDF data that acts as a null profile is the W3C's [[[prov-constraints]]] which provides a list of constraints that apply to provenance data formulated according to [[[prov-o]]]. [[[prov-constraints]]] implements no constraints beyond those stated or implied in [[[prov-o]]] and the conceptual [[[prov-dm]]], however it does include tests for things that the models do not explicitly model but whose proper use requires, e.g., for ordering of temporal entities. Implementations of those constraints have been made as Python scripts that execute SPARQL queries, allowing for RDF data validation.
No universal and precise methodology can be given for creation of a null profile of a specification, because, by the task's very nature, the specification's rule(s) may be imprecisely defined, and thus the method used to characterize them in SHACL, which is precise, will vary just as the imprecise rule definition does.
See [[[#null-profile-examples]]] for examples of null profiles of other specifications.
This vocabulary is a specialised form of [[[dx-prof]]], which is a general purpose vocabulary for profiling, and SHACL.
Many elements in this vocabulary are taken unchanged from [[[shacl12-core]]] but are relisted here so their use can be exemplified.
This vocabulary has an RDF representation which is serialized in turtle at its namespace location:
| RDF Class: | sh:ShapesGraph |
|---|---|
| Is defined by: | [[[shacl12-core]]] |
| Sub-class of: | owl:Ontology |
| Definition: | A shapes graph is an RDF graph containing zero or more shapes that is passed into a SHACL validation process so that a data graph can be validated against the shapes. |
| See also: | SHACL 1.2 Core: Shapes Graph |
| Scope note: | For the purposes of SHACL profiling, this class is to be used to group SHACL elements together, as per Section [[[#rec-shapesgraph]]]. |
| RDF Property: | owl:imports |
|---|---|
| Is defined by: | [[[owl-ref]]] |
| Definition: | The property that is used for importing other ontologies into a given ontology. |
| Domain: | owl:Ontology |
| Range: | owl:Ontology |
| See also: | OWL Web Ontology Language Reference: importing an ontology |
| Scope note: | For the purposes of SHACL profiling, this predicate is to be used to indicate dependency between Shapes Graphs, as per Section [[[#rec-imports]]]. |
| RDF Property: | rdfs:member |
|---|---|
| Is defined by: | [[[rdf12-schema]]] |
| Definition: | A member of the subject resource. |
| Domain: | Resource |
| Range: | Resource |
| See also: | RDF 1.2 Schema: member |
| Scope note: | For the purposes of SHACL profiling, this predicate is to be used to associate a Shapes Graph with each Shape that it uses, whether defined by it or elsewhere, as per Section [[[#rec-member]]]. |
| RDF Class: | sh:DataGraph |
|---|---|
| Is defined by: | [[[shacl12-core]]] |
| Definition: | Any RDF graph can be a data graph. |
| Usage note: |
Use this class to represent RDF graphs that you wish to make conformance claims for.
For example, record graphs of RDF data as Data Graphs when testing their conformance
according to the GeoSPARQL 1.1 standard's Shapes
Graph (http://www.opengis.net/def/geosparql/validator).
|
| See also: | SHACL 1.2 Core: Data Graph |
| Scope note: | For the purposes of SHACL profiling, this class is to be used to represent RDF data that is to have SHACL-related claims made about it. |
| RDF Property: | sh:conformsTo |
|---|---|
| Is defined by: | [[[shacl12-core]]] |
| Sub-property of: | dcterms:conformsTo |
| Definition: | The subject is valid when validated according to the object. |
| Domain: | Data Graph |
| Range: | Shapes Graph |
| See also: | SHACL 1.2 Core: conforms to TODO |
| RDF Property: | sh:validationReport |
|---|---|
| Is defined by: | [[[shacl12-core]]] |
| Definition: | A Validation Report exists for the subject. |
| Domain: | Data Graph |
| Range: | Validation Report |
| See also: | SHACL 1.2 Core: has validation report TODO |
| RDF Class: | sh:ValidationReport |
|---|---|
| Is defined by: | [[[shacl12-core]]] |
| Definition: | A validation report is the result of a validation process that reports the conformance and the set of all validation results of a Data Graph with respect to a Shapes Graph. |
| See also: | SHACL 1.2 Core: Validation Report |
| RDF Property: | sh:usedShapesGraph |
|---|---|
| Is defined by: | [[[shacl12-core]]] |
| Definition: | The subject used the object when determining validity of a tested Data Graph. |
| Domain: | Validation Report |
| Usage note: | The version IRI of a Shapes Graph may also be used as an object for this property. |
| Range: | Shapes Graph |
| See also: | SHACL 1.2 Core: used shapes graph TODO |
| RDF Property: | sh:conforms |
|---|---|
| Is defined by: | [[[shacl12-core]]] |
| Definition: | Represents the outcome of the conformance checking the Validation Report is describing. |
| Domain: | Validation Report |
| Range: | boolean |
| RDF Class: | sh:Shape |
|---|---|
| Is defined by: | [[[shacl12-core]]] |
| Definition: | A shape is a collection of constraints that may be targeted for certain nodes. |
| See also: | SHACL 1.2 Core: Shapes |
| RDF Property: | rdfs:isDefinedBy |
|---|---|
| Is defined by: | [[[rdf12-schema]]] |
| Definition: | The subject used the object when determining validity of a tested Data Graph. |
| Domain: | Validation Report |
| Range: | Shapes Graph |
| See also: | RDF 1.2 Schema: isDefinedBy |
The rule 'conforms to' is a reasoning rule that allows for a Data Graph to be indicated as conforming
to a Shapes Graph if there is a Validation Report associated with the Data Graph
which indicates the Shapes Graph was used for validation and the sh:conforms property
indicates true.
This reasoning rule cannot be articulated as an OWL property chain axiom due to the test of the
sh:conforms property value, so it is presented here as both a [[[sparql12-query]]] rule and a [[[shacl12-rules]]] rule.
This appendix lists profiles of SHACL 1.2 known at the time of this specification's publication, formulated as per the section Profiling of SHACL. It also indicates where the W3C's SHACL community maintains an informal register of profiles of SHACL that can be added to after this document has been finalised
The definition of each of the 7 Specification Profiles in RDF are available here:
The Union Profile definition is available in RDF too:
The Union Profile of SHACL 1.2 is the conceptual whole of SHACL 1.2 which covers all aspects of the SHACL 1.2 series of Specifications. There is no single human-readable Union Profile specification document — you must read all the documents individually, as linked from the specification section — but there is a single validation resource: a shapes graph comprising all the individual profiles' validation shapes graphs.
The Union Profile shapes graph is given in the SHACL 1.2 Overview's SHACL-SHACL appendix.
The SHACL 1.2 UI profile of SHACL is a subset of the vocabulary elements of SHACL Core selected for their ease of implementation as user interface components as implemented for the SHACL 1.2 UI specification.
TODO
The CD1 ("Computationally-Defined #1") profile of SHACL is a subset of the vocabulary elements of SHACL Core, SPARQL and Node Expressions vocabulary elements selected for their computational simplicity.
The reason for defining this CD1 profile is twofold:
This profile is defined in the resource http://www.w3.org/ns/shacl/profile/cd1, a portion of which is as follows:
All the class and property elements of SHACL 1.2 are listed where ... many skipped members
is indicated above except for:
blah:BlahBlahblah:OtherBlahTODO
The Pretty Print profile of SHACL is a subset of the vocabulary elements of SHACL that are selected to ensure "pretty" - easy to read - error messages are generated by validation processes.
The Owl Consistent profile of SHACL is a subset of the vocabulary elements of SHACL that are selected to ensure shapes definitions do not violate OWL constraints on the classes and predicates they target.
This appendix contains examples of null profiles of other specifications.
This profile is a null profile of the [[[!w3c-basic-geo]]]. The purpose of this profile is to demonstrate what a null profile of a very simple RDF vocabulary looks like.
TODO - see file pos.ttl in repo
This profile is a null profile of [[[dx-prof]]].
The purposes of this profile are to both provide a SHACL-based validator for PROF data and to demonstrate what a slightly more complex null profile of a vocabulary looks like.
This null profile implements all the OWL rules of PROF as well as some rules stated in the PROF specification that are not implemented in the PROF ontology.
TODO
Like most RDF-based technologies, SHACL processors may operate on graphs that are assembled
from various sources. Some applications may have an open "linked data" ("LD") architecture and dynamically
assemble RDF triples from sources that are outside an organization's network of trust.
Since RDF allows anyone to add statements about any resource, triples may modify the originally
intended semantics of shape definitions or nodes in a data graph and thus feed
into misleading results.
Protection against this (and the following) scenario is achievable by using only trusted
and verified RDF sources and eliminating the possibility that graphs are dynamically added via
owl:imports and sh:shapesGraph.
When creating profiles of other specifications, profile creators need to ensure that their constraints do not violate those specification's rules. If any did so, and if only the profile's rules, but not the specification's rules, were used to check for data validity, by accident or by design, data could be wrongly calculated to be valid. This could lead to accidental data release or use, potentially introducing security issues.
Many people contributed to this specification, including members of the RDF Data Shapes Working Group.
TODO