Copyright © 2025 World Wide Web Consortium. W3C® liability, trademark and permissive document license rules apply.
This document defines the Core of the SHACL Shapes Constraint Language. SHACL is a language for validating RDF graphs against a set of conditions. These conditions are provided as shapes and other constructs expressed in the form of an RDF graph. RDF graphs that are used in this manner are called "shapes graphs" in SHACL and the RDF graphs that are validated against a shapes graph are called "data graphs". As SHACL shape graphs are used to validate that data graphs satisfy a set of conditions they can also be viewed as a description of the data graphs that do satisfy these conditions. Such descriptions may be used for a variety of purposes beside validation, including user interface building, code generation and data integration.
This section describes the status of this document at the time of its publication. A list of current W3C publications and the latest revision of this technical report can be found in the W3C standards and drafts index.
This document was published by the Data Shapes Working Group as a Working Draft using the Recommendation track.
Publication as a Working Draft does not imply endorsement by W3C and its Members.
This is a draft document and may be updated, replaced, or obsoleted by other documents at any time. It is inappropriate to cite this document as other than a work in progress.
This document was produced by a group operating under the W3C Patent Policy. W3C maintains a public list of any patent disclosures made in connection with the deliverables of the group; that page also includes instructions for disclosing a patent. An individual who has actual knowledge of a patent that the individual believes contains Essential Claim(s) must disclose the information in accordance with section 6 of the W3C Patent Policy.
This document is governed by the 03 November 2023 W3C Process Document.
The introduction includes a Terminology section.
The syntax of SHACL is RDF. The examples in this document use Turtle [rdf12-turtle] and (in one instance) JSON-LD [json-ld]. Other RDF serializations such as RDF/XML may be used in practice. The reader should be familiar with basic RDF concepts [rdf12-concepts] such as triples.
This document specifies the Core of SHACL (Shapes Constraint Language), a language for describing and validating RDF graphs. This section introduces SHACL with an overview of the key terminology and an example to illustrate basic concepts.
Throughout this document, the following terminology is used.
Terminology that is linked to portions of RDF 1.2 Concepts and Abstract Syntax is used in SHACL as defined there. Terminology that is linked to portions of SPARQL 1.2 Query Language is used in SHACL as defined there. A single linkage is sufficient to provide a definition for all occurences of a particular term in this document.
Definitions are complete within this document, i.e., if there is no rule to make some situation true in this document then the situation is false.
n has a value v
						for property p in an RDF graph if there is an RDF triple in the graph
						with subject n, predicate p, and object v.
						The phrase "Every value of P in graph G ..." means "Every object of a triple in G with predicate P ...".
						(In this document, the verbs specify or declare are sometimes used to express the fact that an RDF term has values for a given predicate in a graph.)
						n has value v for SPARQL property path expression
						p in an RDF graph G if there is a solution mapping in the result of the SPARQL query
						SELECT ?s ?o WHERE { ?s p' ?o } on G that binds ?s to
						n and ?o to v, where	p' is SPARQL surface syntax for p.
					G is an IRI or a blank node
						that is either rdf:nil	(provided that rdf:nil has no value
						for either rdf:first or rdf:rest), or has exactly one value
						for the property rdf:first in G and exactly one value
						for the property rdf:rest in G that is also a SHACL list in G,
						and the list does not have itself as a value of the property path rdf:rest+ in G.
						rdf:nil in an RDF
						graph G consist of its value for rdf:first in G followed by
						the members in G of its value for rdf:rest in G.
						The SHACL list rdf:nil has no members in any RDF graph.
					Sub in an RDF graph is a SHACL subclass of another node Super
						in the graph if there is a sequence of triples in the graph each with predicate rdfs:subClassOf such that the subject of the first triple is Sub,
						the object of the last triple is Super, and the object of each triple except the last is the subject of the next.
						If Sub is a SHACL subclass of Super in an RDF graph then Super
						is a SHACL superclass of Sub in the graph.
					n in an RDF graph G is a SHACL instance of a SHACL class C in G
						if one of the SHACL types of n in G is C.
					n in a graph sourceGraph,
						the deep copy of n in a graph targetGraph
						is n in targetGraph plus, if n is a blank node,
						any triples from sourceGraph that can be reached by transitively traversing 
						the blank nodes that appear in the object position of a triple that can be reached
						starting with n as the subject. This is similar to
						the Concise Bounded Description, but without reification.
					Within this document, the following namespace prefix definitions are used:
| Prefix | Namespace | 
|---|---|
| owl: | http://www.w3.org/2002/07/owl# | 
| rdf: | http://www.w3.org/1999/02/22-rdf-syntax-ns# | 
| rdfs: | http://www.w3.org/2000/01/rdf-schema# | 
| sh: | http://www.w3.org/ns/shacl# | 
| xsd: | http://www.w3.org/2001/XMLSchema# | 
| ex: | http://example.com/ns# | 
Within this document, the following JSON-LD context is used:
{
  "@context": {
    "owl": "http://www.w3.org/2002/07/owl#",
    "rdf": "http://www.w3.org/1999/02/22-rdf-syntax-ns#",
    "rdfs": "http://www.w3.org/2000/01/rdf-schema#",
    "sh": "http://www.w3.org/ns/shacl#",
    "xsd": "http://www.w3.org/2001/XMLSchema#",
    "ex": "http://example.com/ns#"
  }
}
					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 document, color-coded boxes containing RDF graphs in Turtle and JSON-LD will appear. These fragments of Turtle documents use the prefix bindings given above. The JSON-LD document fragments use the context given above. Only the Turtle documents may highlight certain parts.
Grey boxes such as this include syntax rules that apply to the shapes graph.
					true denotes the RDF term "true"^^xsd:boolean.
					false denotes the RDF term "false"^^xsd:boolean.
				
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 key words MAY, MUST, MUST NOT, and SHOULD in this document are to be interpreted as described in BCP 14 [RFC2119] [RFC8174] when, and only when, they appear in all capitals, as shown here.
This document defines the SHACL Core language, also referred to as just SHACL. This specification describes conformance criteria for:
This document includes syntactic rules that shapes and other nodes need to fulfill in the shapes graph. These rules are typically of the form A shape must have... or The values of X are literals or All objects of triples with predicate P must be IRIs. The complete list of these rules can be found in the appendix. Nodes that violate any of these rules are called ill-formed. Nodes that violate none of these rules are called well-formed. A shapes graph is ill-formed if it contains at least one ill-formed node.
This section is non-normative.
					The following example data graph contains three SHACL instances of the class ex:Person.
				
					We can use the shape declaration above to illustrate some of the key terminology used by SHACL.
					The target for the shape ex:PersonShape is the set of all SHACL instances of the class ex:Person.
					This is specified using the property sh:targetClass.
					During the validation, these target nodes become focus nodes for the shape.
					The shape ex:PersonShape is a node shape, which means that it applies to the focus nodes.
					It declares constraints on the focus nodes, for example using the parameters sh:closed and sh:ignoredProperties.
					The node shape also declares two other constraints with the property sh:property,
					and each of these is backed by a property shape. 
					These property shapes declare additional constraints using parameters such as sh:datatype and sh:maxCount.
				
					Some of the property shapes specify parameters from multiple constraint components in order to
					restrict multiple aspects of the property values.
					For example, in the property shape for ex:ssn, parameters from three constraint components are used.
					The parameters of these constraint components are sh:datatype, sh:pattern and sh:maxCount.
					For each focus node the property values of ex:ssn will be validated against all three components.
				
SHACL validation based on the provided data graph and shapes graph would produce the following validation report. See the section Validation Report for details on the format.
{
	"@type": "sh:ValidationReport",
	"sh:conforms": {
		"@type": "xsd:boolean",
		"@value": "false"
	},
	"sh:result": [
		{
			"@type": "sh:ValidationResult",
			"sh:focusNode": {
				"@id": "ex:Alice"
			},
			"sh:resultPath": {
				"@id": "ex:ssn"
			},
			"sh:resultSeverity": {
				"@id": "sh:Violation"
			},
			"sh:sourceConstraintComponent": {
				"@id": "sh:PatternConstraintComponent"
			},
			"sh:sourceShape": {
				"@id": "_:b1"
			},
			"sh:value": "987-65-432A"
		},
		{
			"@type": "sh:ValidationResult",
			"sh:focusNode": {
				"@id": "ex:Bob"
			},
			"sh:resultPath": {
				"@id": "ex:ssn"
			},
			"sh:resultSeverity": {
				"@id": "sh:Violation"
			},
			"sh:sourceConstraintComponent": {
				"@id": "sh:MaxCountConstraintComponent"
			},
			"sh:sourceShape": {
				"@id": "_:b1"
			}
		},
		{
			"@type": "sh:ValidationResult",
			"sh:focusNode": {
				"@id": "ex:Calvin"
			},
			"sh:resultPath": {
				"@id": "ex:worksFor"
			},
			"sh:resultSeverity": {
				"@id": "sh:Violation"
			},
			"sh:sourceConstraintComponent": {
				"@id": "sh:ClassConstraintComponent"
			},
			"sh:sourceShape": {
				"@id": "_:b2"
			},
			"sh:value": {
				"@id": "ex:UntypedCompany"
			}
		},
		{
			"@type": "sh:ValidationResult",
			"sh:focusNode": {
				"@id": "ex:Calvin"
			},
			"sh:resultPath": {
				"@id": "ex:birthDate"
			},
			"sh:resultSeverity": {
				"@id": "sh:Violation"
			},
			"sh:sourceConstraintComponent": {
				"@id": "sh:ClosedConstraintComponent"
			},
			"sh:sourceShape": {
				"@id": "sh:PersonShape"
			},
			"sh:value": {
				"@type": "xsd:date",
				"@value": "1971-07-07"
			}
		}
	]
}
					The validation results are enclosed in a validation report.
					The first validation result is produced because ex:Alice has a value for ex:ssn
					that does not match the regular expression specified by the property sh:pattern.
					The second validation result is produced because ex:Bob has more than the permitted number of values
					for the property ex:ssn as specified by the sh:maxCount of 1.
					The third validation result is produced because ex:Calvin has a value for ex:worksFor
					that does not have an rdf:type triple that makes it a SHACL instance of ex:Company.
					The forth validation result is produced because the shape ex:PersonShape has the	property sh:closed set to true
					but ex:Calvin uses the property ex:birthDate which is neither one of the predicates from any of the 
					property shapes of the shape, nor one of the properties listed using sh:ignoredProperties.
				
SHACL uses the RDF and RDFS vocabularies, but full RDFS inferencing is not required.
					However, SHACL processors MAY operate on RDF graphs that include entailments [sparql12-entailment] -
					either pre-computed before being submitted to a SHACL processor or performed on the fly as
					part of SHACL processing (without modifying either data graph or shapes graph).
					To support processing of entailments, SHACL includes the property
					sh:entailment to indicate what inferencing is required
					by a given shapes graph.
				
					The values of the property sh:entailment are IRIs.
					Common values for this property are covered by [sparql12-entailment].
				
					SHACL implementations MAY, but are not required to, support entailment regimes.
					If a shapes graph contains any triple with the predicate sh:entailment and object E
					and the SHACL processor does not support E as an entailment regime for the given data graph
					then the processor MUST signal a failure.
					Otherwise, the SHACL processor MUST provide the entailments for all of the values of sh:entailment in the shapes graph,
					and any inferred triples MUST be returned by all queries against the data graph during the validation process.
				
The following introduction is non-normative.
				The following informal diagram provides an overview of some of the key classes in the SHACL vocabulary.
				Each box represents a class.
				The content of the boxes under the class name lists some of the properties that instances of these classes may have, together with their value types.
				The arrows indicate rdfs:subClassOf triples.
			
 
				The Turtle serialization of the SHACL vocabulary contains the complete SHACL vocabulary.
s
					that fulfills at least one of the following conditions in the shapes graph:
					s is a SHACL instance of sh:NodeShape or sh:PropertyShape.
						s is subject of a triple that has sh:targetClass, sh:targetNode,
							sh:targetObjectsOf or sh:targetSubjectsOf as predicate.
						s is subject of a triple that has a parameter as predicate.
						s is a value of a shape-expecting, non-list-taking parameter such as sh:node,
							or a member of a SHACL list that is a value of a shape-expecting and list-taking parameter such as sh:or.
						
					Note that the definition above does not include all of the syntax rules of well-formed shapes.
					Those are found throughout the document and summarized in Appendix A. Summary of SHACL Syntax Rules.
					For example, shapes that have literals as values for sh:targetClass are ill-formed.
				
Informally, a shape determines how to validate a focus node based on the values of properties and other characteristics of the focus node. For example, shapes can declare the condition that a focus node be an IRI or that a focus node has a particular value for a property and also a minimum number of values for the property.
The SHACL Core language defines two types of shapes:
					sh:Shape is the SHACL superclass of those two shape types in the SHACL vocabulary.
					Its subclasses sh:NodeShape and sh:PropertyShape can be used as SHACL type of node and property shapes, respectively.
				
Shapes can declare constraints using the parameters of constraint components.
A constraint component is an IRI. Each constraint component has one or more mandatory parameters, each of which is a property. Each constraint component has zero or more optional parameters, each of which is a property. The parameters of a constraint component are its mandatory parameters plus its optional parameters.
						For example, the component sh:MinCountConstraintComponent declares the parameter sh:minCount to represent the restriction
						that a node has at least a minimum number of values for a	particular property.
					
						For a constraint component C with mandatory parameters p1, ... pn,
						a shape s in a shapes graph SG declares a constraint
						that has kind C with mandatory parameter values <p1,v1>, ... <pn,vn>
						in SG when s has vi as a value for pi in SG.
						For constraint components with optional parameters, the constraint declaration consists of the values that the shape has for all mandatory and optional parameters of that component.
					
						Some constraint components declare only a single parameter.
						For example sh:ClassConstraintComponent has the single parameter sh:class.
						These parameters may be used multiple times in the same shape,
						and each value of such a parameter declares an individual constraint. 
						The interpretation of such declarations is conjunction, i.e. all constraints apply.
						The following example specifies that the values of ex:customer have to be SHACL instances of both
						ex:Customer and ex:Person.
					
{
	"@id": "ex:InvoiceShape",
	"@type": "sh:NodeShape",
	"sh:property": {
		"sh:class": [
			{
				"@id": "ex:Customer"
			},
			{
				"@id": "ex:Person"
			}
		],
		"sh:path": {
			"@id": "ex:customer"
		}
	}
}
						Some constraint components such as sh:PatternConstraintComponent declare more than one parameter.
						Shapes that have more than one value for any of the parameters of such components are ill-formed.
					
One way to bypass this syntax rule is to spread the constraints across multiple (property) shapes, as illustrated in the following example.
{
	"@id": "ex:MultiplePatternsShape",
	"@type": "sh:NodeShape",
	"sh:property": [
		{
			"sh:flags": "i",
			"sh:path": {
				"@id": "ex:name"
			},
			"sh:pattern": "^Start"
		},
		{
			"sh:path": {
				"@id": "ex:name"
			},
			"sh:pattern": "End$"
		}
	]
}shape ex:MultiplePatternsShape {
	ex:name pattern="^Start" flags="i" .
	ex:name pattern="End$" .
}Constraint components are associated with validators, which provide instructions (for example expressed via SPARQL queries) on how the parameters are used to validate data. Validating an RDF term against a shape involves validating the term against each constraint where the shape has values for all mandatory parameters of the component of the constraint, using the validators associated with the respective component.
The list of constraint components included in SHACL Core is described in section 4. SHACL-SPARQL can be used to declare additional constraint components based on SPARQL.
An RDF term that is validated against a shape using the triples from a data graph is called a focus node.
The remainder of this section is informative.
The set of focus nodes for a shape may be identified as follows:
sh:node)
						Target declarations of a shape in a shapes graph are
						triples with the shape as the subject and certain properties described in this document
						(e.g., sh:targetClass) as predicates.
						Target declarations can be used to produce focus nodes for a shape.
						The target of a target declaration is the set of RDF terms produced
						by applying the rules described in the remainder of this section to the data graph. 
						The target of a shape is the union of all RDF terms produced by the individual
						targets that are declared by the shape in the shapes graph.
					
SHACL Core includes the following kinds of targets: node targets, class-based targets (including implicit class-based targets), subjects-of targets, and objects-of targets.
The remainder of this introduction is informative.
						RDF terms produced by targets are not required to exist as nodes in the data graph.
						Targets of a shape are ignored whenever a focus node is provided directly as input to the validation process for that shape.
						This includes the cases where the shape is a value of one of the
						shape-expecting constraint parameters (such as sh:node) and
						a focus node is determined during the validation of the corresponding constraint component (such as sh:NodeConstraintComponent).
						In such cases, the provided focus node does not need to be in the target of the shape.
					
							A node target is specified using the sh:targetNode predicate.
							Each value of sh:targetNode in a shape is a well-formed node expression.
						
s is a shape in a shapes graph SG and s has
							value expr for sh:targetNode in SG,
							then the output nodes of expr are targets
							for the data graph DG as focus graph.
						The remainder of this section is informative.
							With the example data below, only ex:Alice is the target of the provided shape:
						
{
	"@id": "ex:PersonShape",
	"@type": "sh:NodeShape",
	"sh:targetNode": {
		"@id": "ex:Alice"
	}
}shape ex:PersonShape {
	targetNode=ex:Alice .
}{
	"@graph": [
		{
			"@id": "ex:Alice",
			"@type": "ex:Person"
		},
		{
			"@id": "ex:Bob",
			"@type": "ex:Person"
		}
	]
}
							A class target is specified with the sh:targetClass predicate.
							Each value of sh:targetClass in a shape is an IRI.
						
s is a shape in a shapes graph SG and s has value c for
							sh:targetClass in SG then the set of SHACL instances of c in a data graph
							DG is a target from DG for s in SG.
						The remainder of this section is informative.
{
	"@id": "ex:PersonShape",
	"@type": "sh:NodeShape",
	"sh:targetClass": {
		"@id": "ex:Person"
	}
}shape ex:PersonShape -> ex:Person {
}{
	"@graph": [
		{
			"@id": "ex:Alice",
			"@type": "ex:Person"
		},
		{
			"@id": "ex:Bob",
			"@type": "ex:Person"
		},
		{
			"@id": "ex:NewYork",
			"@type": "ex:Place"
		}
	]
}
							In this example, only ex:Alice and ex:Bob are focus nodes.
							Note that, according to the SHACL instance definition, all the rdfs:subClassOf declarations needed to walk the class hierarchy need to exist in the data graph.
							However, the ex:Person a rdfs:Class triple is not required to exist in either graphs.
						
							In the following example, the selected focus node is only ex:Who.
						
{
	"@graph": [
		{
			"@id": "ex:Doctor",
			"rdfs:subClassOf": {
				"@id": "ex:Person"
			}
		},
		{
			"@id": "ex:House",
			"@type": "ex:Nephrologist"
		},
		{
			"@id": "ex:Who",
			"@type": "ex:Doctor"
		}
	]
}Informally, if a shape is also declared to be a class in the shapes graph then all SHACL instances of this class are a target for the shape.
							If s is a SHACL instance of sh:NodeShape or sh:PropertyShape
							in an RDF graph G and s is also a SHACL instance of
							rdfs:Class in G and s is not an IRI then s is an ill-formed shape in G.
						
s is a SHACL instance of sh:NodeShape or sh:PropertyShape
							in a shapes graph SG and s is also a SHACL instance of rdfs:Class
							in SG then the set of SHACL instances of s in a data graph DG is a target from DG for s in SG.
						
							The SHACL namespace includes a dedicated class sh:ShapeClass that can serve as a syntactic shortcut for the implicit class targets pattern.
						
sh:ShapeClass is an rdfs:subClassOf of both sh:NodeShape and rdfs:Class.
							If s is a SHACL instance of sh:ShapeClass in a shapes graph SG
							then the set of SHACL instances of s in a data graph DG is a target from DG for s in SG.
						
							Please keep in mind that sh:ShapeClass may not be understood to be a subclass of rdfs:Class by some SHACL-unaware implementations.
							It is therefore recommended (but not required) that graphs that use sh:ShapeClass include an owl:imports sh: statement.
						
The remainder of this section is informative.
							In the following example, ex:Alice is a focus node, because it is a SHACL instance of
							ex:Person which is both a class and a shape in the shapes graph.
						
{
	"@id": "ex:Person",
	"@type": [
		"rdfs:Class",
		"sh:NodeShape"
	]
}shapeClass ex:Person {
}{
	"@graph": [
		{
			"@id": "ex:Alice",
			"@type": "ex:Person"
		},
		{
			"@id": "ex:NewYork",
			"@type": "ex:Place"
		}
	]
}
							In the following variation of the example above, ex:Person is declared as an instance of sh:ShapeClass,
							with the same interpretation.
						
{
	"@id": "ex:Person",
	"@type": "sh:ShapeClass"
}
							A subjects-of target is specified with the predicate sh:targetSubjectsOf.
							The values of sh:targetSubjectsOf in a shape are IRIs.
						
s is a shape in a shapes graph SG and s has value
							p for sh:targetSubjectsOf in SG then the set of nodes in a
							data graph DG that are subjects of triples in DG with predicate
							p is a target from DG for s in SG.
						The remainder of this section is informative.
{
	"@id": "ex:TargetSubjectsOfExampleShape",
	"@type": "sh:NodeShape",
	"sh:targetSubjectsOf": {
		"@id": "ex:knows"
	}
}shape ex:TargetSubjectsOfExampleShape {
	targetSubjectsOf=ex:knows .
}{
	"@graph": [
		{
			"@id": "ex:Alice",
			"ex:knows": {
				"@id": "ex:Bob"
			}
		},
		{
			"@id": "ex:Bob",
			"ex:livesIn": {
				"@id": "ex:NewYork"
			}
		}
	]
}
							In the example above, only ex:Alice is validated against the given shape,
							because it is the subject of a triple that has ex:knows as its predicate.
						
							An objects-of target is specified with the predicate sh:targetObjectsOf.
							The values of sh:targetObjectsOf in a shape are IRIs.
						
s is a shape in a shapes graph SG and s has value
							p for sh:targetObjectsOf in SG then the set of nodes in a
							data graph DG that are objects of triples in DG with predicate
							p is a target from DG for s in SG.
						The remainder of this section is informative.
{
	"@id": "ex:TargetObjectsOfExampleShape",
	"@type": "sh:NodeShape",
	"sh:targetObjectsOf": {
		"@id": "ex:knows"
	}
}shape ex:TargetObjectsOfExampleShape {
	targetObjectsOf=ex:knows .
}{
	"@graph": [
		{
			"@id": "ex:Alice",
			"ex:knows": {
				"@id": "ex:Bob"
			}
		},
		{
			"@id": "ex:Bob",
			"ex:livesIn": {
				"@id": "ex:NewYork"
			}
		}
	]
}
							In the example above, only ex:Bob is validated against the given shape,
							because it is the object of a triple that has ex:knows as its predicate.
						
						Shapes can specify one value for the property sh:severity in the shapes graph.
						Each value of sh:severity is an IRI.
					
						The values of sh:severity are called severities.
						SHACL includes the three IRIs listed in the table below to represent severities.
						These are declared in the SHACL vocabulary as SHACL instances of sh:Severity.
					
| Severity | Description | 
|---|---|
| sh:Trace | A trace message that is not a violation. | 
| sh:Debug | A debug message that is not a violation. | 
| sh:Info | A non-critical constraint violation indicating an informative message. | 
| sh:Warning | A non-critical constraint violation indicating a warning. | 
| sh:Violation | A constraint violation. | 
						Validation engines MAY treat sh:Info and sh:Warning as non-violating based on
						options passed to the engine. By default, they are treated as violations.
					
						In addition to declaring severities per shape, the property sh:severity can also be used
						on a reifier for a triple where the shape is the subject and one of the parameters
						of the constraint is the predicate.
					
						
						Let T be the set of triples that represent a constraint in a shape.
						A shapes graph can specify at most one value for the property sh:severity
						in the reifiers of the triples in T.
					
The remainder of this section is informative.
						The specific values of sh:severity have no impact on the validation,
						but MAY be used by user interface tools to categorize validation results.
						The values of sh:severity are used by SHACL processors to populate the sh:resultSeverity field of
						validation results, see section on severity in validation results.
						Any IRI can be used as a severity.
					
						For every shape and constraint, sh:Violation is the default if sh:severity is unspecified.
						The following example illustrates this.
					
{
	"@id": "ex:MyShape",
	"@type": "sh:NodeShape",
	"sh:property": [
		{
			"sh:datatype": {
				"@id": "xsd:string"
			},
			"sh:minCount": {
				"@type": "xsd:integer",
				"@value": "1"
			},
			"sh:path": {
				"@id": "ex:myProperty"
			},
			"sh:severity": {
				"@id": "sh:Warning"
			}
		},
		{
			"sh:maxLength": {
				"@type": "xsd:integer",
				"@value": "10"
			},
			"sh:message": [
				{
					"@language": "en",
					"@value": "Too many characters"
				},
				{
					"@language": "de",
					"@value": "Zu viele Zeichen"
				}
			],
			"sh:path": {
				"@id": "ex:myProperty"
			}
		}
	],
	"sh:targetNode": {
		"@id": "ex:MyInstance"
	}
}shape ex:MyShape {
	targetNode=ex:MyInstance .
	ex:myProperty xsd:string [1..*] severity=Warning .
	ex:myProperty maxLength=10 message="Too many characters"@en message="Zu viele Zeichen"@de .
}{
	"@id": "ex:MyInstance",
	"ex:myProperty": {
		"@type": "xsd:anyURI",
		"@value": "http://toomanycharacters"
	}
}{
	"@type": "sh:ValidationReport",
	"sh:conforms": {
		"@type": "xsd:boolean",
		"@value": "false"
	},
	"sh:result": [
		{
			"@type": "sh:ValidationResult",
			"sh:focusNode": {
				"@id": "ex:MyInstance"
			},
			"sh:resultPath": {
				"@id": "ex:myProperty"
			},
			"sh:resultSeverity": {
				"@id": "sh:Warning"
			},
			"sh:sourceConstraintComponent": {
				"@id": "sh:DatatypeConstraintComponent"
			},
			"sh:sourceShape": {
				"@id": "_:b1"
			},
			"sh:value": {
				"@type": "xsd:anyURI",
				"@value": "http://toomanycharacters"
			}
		},
		{
			"@type": "sh:ValidationResult",
			"sh:focusNode": {
				"@id": "ex:MyInstance"
			},
			"sh:resultMessage": [
				{
					"@language": "en",
					"@value": "Too many characters"
				},
				{
					"@language": "de",
					"@value": "Zu viele Zeichen"
				}
			],
			"sh:resultPath": {
				"@id": "ex:myProperty"
			},
			"sh:resultSeverity": {
				"@id": "sh:Violation"
			},
			"sh:sourceConstraintComponent": {
				"@id": "sh:MaxLengthConstraintComponent"
			},
			"sh:sourceShape": {
				"@id": "_:b2"
			},
			"sh:value": {
				"@type": "xsd:anyURI",
				"@value": "http://toomanycharacters"
			}
		}
	]
}The following example is a variation of the shapes graph above, but using reification to specify the severity of individual constraints:
						Shapes can have values for the property sh:message.
						The values of sh:message are either xsd:string literals or literals with a language tag.
						A subject should not have more than one value for sh:message with the same language tag.
					
						If a shape has at least one value for sh:message in the shapes graph, then
						all validation results produced as a result of the shape will have exactly these messages
						as their value of sh:resultMessage, i.e. the values will be copied from the shapes graph
						into the results graph.
					
						In addition to declaring messages per shape, the property sh:message can also be used
						on a reifier for a triple where the shape is the subject and one of the parameters
						of the constraint is the predicate.
					
						
						Let T be the set of triples that represent a constraint in a shape.
						A shapes graph can specify at most one value for the property sh:message
						in the reifiers of the triples in T.
					
The remainder of this section is informative.
						See the section on sh:resultMessage in the validation results
						on further details on how the values of sh:resultMessage are populated.
					
The example from the previous section uses this mechanism to supply the second validation result with two messages. The following example is a variation where the message is declared using reification.
						Shapes can have at most one value for the property sh:deactivated.
						The value of sh:deactivated is a node expression
						that must have either true or false as the (only) output node.
					
						Let expr be the value of sh:deactivated in a shape.
						If evalExpr(expr, data graph, focus node, {}) produces true as its only
						output node, the shape is called deactivated.
						All RDF terms conform to a deactivated shape.
					
In addition to deactivating all constraints for a shape, it is also possible to deactivate individual constraints. This is done using reification.
						A triple that has a shape as subject,
						a parameter (such as sh:minCount) as predicate can have at most one
						reifier with a value for the property sh:deactivated.
					
						Let expr be the value of sh:deactivated in a reifier on a triple
						that has shape subject and a parameter as predicate.
						If evalExpr(expr, data graph, focus node, {}) produces true as its only
						output node, the constraints that use the triple are called deactivated constraints.
						Deactivated constraints do not produce any validation results.
					
The remainder of this section is informative.
						In SHACL Core, the only valid values for sh:deactivated are the 
						constant literal node expressions
						true and false.
					
						Use cases of this feature include shape reuse and debugging.
						In scenarios where shapes from other graphs or files are imported into a given shapes graph,
						sh:deactivated can be set to true in the local shapes graph for imported shapes
						to exclude shapes that do not apply in the current application context.
						This makes it possible to reuse SHACL graphs developed by others even if you disagree with certain assumptions made by the original authors.
						If a shape author anticipates that a shape may need to be disabled or modified by others, it is a good practice to use IRIs instead of blank nodes
						for the actual shapes.  For example, a property shape for the property ex:name at the shape ex:PersonShape may have the IRI ex:PersonShape-name.
						Another typical use case of sh:deactivated is during the development and testing of shapes, to (temporarily) disable certain shapes.
					
						The following example illustrates the use of sh:deactivated to deactivate a shape.
						In cases where shapes are imported from other graphs, the sh:deactivated true triple would be in the importing graph.
					
{
	"@graph": [
		{
			"@id": "ex:PersonShape",
			"@type": "sh:NodeShape",
			"sh:property": {
				"@id": "ex:PersonShape-name"
			},
			"sh:targetClass": {
				"@id": "ex:Person"
			}
		},
		{
			"@id": "ex:PersonShape-name",
			"@type": "sh:PropertyShape",
			"sh:deactivated": {
				"@type": "xsd:boolean",
				"@value": "true"
			},
			"sh:minCount": {
				"@type": "xsd:integer",
				"@value": "1"
			},
			"sh:path": {
				"@id": "ex:name"
			}
		}
	]
}
							With the following data, no constraint violation will be reported even though the instance does not have any value for ex:name. 
						
{
	"@id": "ex:JohnDoe",
	"@type": "ex:Person"
}
						The following variation uses reification to deactivate just the sh:minCount
						constraint without affecting other constraints at the same property shape.
					
					A node shape is a shape in the shapes graph that
					is not the subject of a triple with sh:path as its predicate.
					It is recommended, but not required, for a node shape to be declared as a SHACL instance of sh:NodeShape.
					SHACL instances of sh:NodeShape cannot have a value for the property sh:path.
				
Informally, node shapes specify constraints that need to be met with respect to focus nodes. In contrast to property shapes they primarily apply to the focus node itself, not to its property values.
					A property shape is a shape in the shapes graph
					that is the subject of a triple that has sh:path as its predicate.
					A shape has at most one value for sh:path.
					The value of sh:path in a property shape is a well-formed
					SHACL property path.
					
					It is recommended, but not required, for a property shape to be declared as a SHACL instance of sh:PropertyShape.
					SHACL instances of sh:PropertyShape have one value for the property sh:path.
					
					A property shape has at most one value for the property sh:values and this value is a well-formed node expression.
					A property shape has at most one value for the property sh:defaultValue and this value is a well-formed node expression.
					A property shape can only have values for sh:values and/or sh:defaultValue when its value for sh:path is a Predicate Path.
				
					Informally, property shapes specify constraints that need to be met with respect to nodes that can be reached from the
					focus node by 
					(a) directly following a given property (specified as an IRI using sh:path),
					(b) directly following any other SHACL property path (specified using sh:path), 
					(c) evaluating the node expression specified using sh:values, or,
					(d) if no other values exist, evaluating the node expression specified using sh:defaultValue.
				
					Note that support for sh:values and sh:defaultValue is not required by SHACL Core,
					but is necessary for extensions such as [shacl12-sparql].
				
Note that the definitions of well-formed property shapes and node shapes make these two sets of nodes disjoint.
The following example illustrates some syntax variations of property shapes.
{
	"@graph": [
		{
			"@id": "ex:ExampleNodeShapeWithPropertyShapes",
			"@type": "sh:NodeShape",
			"sh:property": [
				{
					"sh:description": "We need at least one email value",
					"sh:minCount": {
						"@type": "xsd:integer",
						"@value": "1"
					},
					"sh:name": "e-mail",
					"sh:path": {
						"@id": "ex:email"
					}
				},
				{
					"sh:description": "We need at least one email for everyone you know",
					"sh:minCount": {
						"@type": "xsd:integer",
						"@value": "1"
					},
					"sh:name": "Friend's e-mail",
					"sh:path": {
						"@list": [
							{
								"@id": "ex:knows"
							},
							{
								"@id": "ex:email"
							}
						]
					}
				}
			]
		},
		{
			"@id": "ex:ExamplePropertyShape",
			"@type": "sh:PropertyShape",
			"sh:description": "We need at least one email value",
			"sh:minCount": {
				"@type": "xsd:integer",
				"@value": "1"
			},
			"sh:path": {
				"@id": "ex:email"
			}
		}
	]
}
				Property paths can be used at sh:path to derive the value nodes of a property shape.
			
				SHACL includes RDF terms to represent the following subset of SPARQL property paths:
				PredicatePath, InversePath, SequencePath, AlternativePath,
				ZeroOrMorePath, OneOrMorePath and ZeroOrOnePath.
			
				The following sub-sections provide syntax rules of well-formed SHACL property paths
				together with mapping rules to SPARQL 1.2 property paths.
				These rules define the path mapping path(p,G) in an RDF graph G of an RDF term p that is a SHACL property path in G.
				Two SHACL property paths are considered equivalent paths when they map to the exact same SPARQL property paths.
			
				A node in an RDF graph is a well-formed SHACL property path p if it satisfies exactly one of the syntax rules in the following sub-sections.
				A node p is not a well-formed SHACL property path if p is a blank node and any path mappings of p directly or transitively reference p.
			
The following example illustrates some valid SHACL property paths, together with their SPARQL 1.2 equivalents.
{
	"@graph": [
		{
			"@id": "ex:SomeClass-alternativePathExample",
			"sh:path": {
				"sh:alternativePath": {
					"@list": [
						{
							"@id": "ex:father"
						},
						{
							"@id": "ex:mother"
						}
					]
				}
			}
		},
		{
			"@id": "ex:SomeClass-complexPathExample",
			"sh:path": {
				"@list": [
					{
						"@id": "rdf:type"
					},
					{
						"sh:zeroOrMorePath": {
							"@id": "rdfs:subClassOf"
						}
					}
				]
			}
		},
		{
			"@id": "ex:SomeClass-inversePathExample",
			"sh:path": {
				"sh:inversePath": {
					"@id": "ex:parent"
				}
			}
		},
		{
			"@id": "ex:SomeClass-predicateExample",
			"sh:path": {
				"@id": "ex:parent"
			}
		},
		{
			"@id": "ex:SomeClass-sequencePathExample",
			"sh:path": {
				"@list": [
					{
						"@id": "ex:parent"
					},
					{
						"@id": "ex:firstName"
					}
				]
			}
		}
	]
}A predicate path is an IRI.
					If p is a predicate path, then path(p,G) is
					a SPARQL PredicatePath with p as iri.
				
A sequence path is a blank node that is a SHACL list with at least two members and each member is a well-formed SHACL property path.
					If p is a sequence path in G with list members
					v1, v2, ..., vn,
					then path(p,G) is a SPARQL SequencePath of
					path(v1,G) as elt1, and the results of the path mapping
					of the list node of v2 as elt2.
				
					Informal note: the nodes in such a SHACL list should not have values for
					other properties beside rdf:first and rdf:rest.
				
					An alternative path is a blank node that is the subject of exactly one triple in G.
					This triple has sh:alternativePath as predicate, L as object,
					and L is a SHACL list with at least two members
					and each member of L is a well-formed SHACL property path.
				
					If p is an alternative path in G,
					then, for the members of its SHACL list L:
					v1, v2, ..., vn,
					path(p,G) is a SPARQL AlternativePath with
					path(v1,G) as elt1 followed by an AlternativePath
					for v2 as elt2, ..., up to path(vn,G).
				
					An inverse path is a blank node that is the subject of exactly one triple in G.
					This triple has sh:inversePath as predicate, and the object v is a well-formed SHACL property path.
				
					If p is an inverse path in G, then path(p,G) is a
					SPARQL InversePath with path(v,G) as its elt.
				
					A zero-or-more path is a blank node that is the subject of exactly one triple in G.
					This triple has sh:zeroOrMorePath as predicate, and the object v is a well-formed SHACL property path.
				
					If p is a zero-or-more path in G, then path(p,G) is a
					SPARQL ZeroOrMorePath with path(v,G) as its elt.
				
					A one-or-more path is a blank node that is the subject of exactly one triple in G.
					This triple has sh:oneOrMorePath as predicate, and the object v is a well-formed SHACL property path.
				
					If p is a one-or-more path in G, then path(p,G) is a
					SPARQL OneOrMorePath with path(v,G) as its elt.
				
					A zero-or-one path is a blank node that is the subject of exactly one triple in G.
					This triple has sh:zeroOrOnePath as predicate, and the object v is a well-formed SHACL property path.
				
					If p is a zero-or-one path in G, then path(p,G) is a
					SPARQL ZeroOrOnePath with path(v,G) as its elt.
				
This section introduces the concept of node expressions. SHACL Core supports node expressions in the following features:
sh:values and sh:defaultValue to derive the value nodes of a property shape.sh:targetNode to dynamically compute the targets of a shape.sh:nodeByExpression to validate nodes against a dynamically computed set of node shapes.sh:expression to validate nodes against a condition.sh:deactivated to deactivate certain shapes under specific conditions.Readers who are only interested in SHACL Core can typically skip this section. Given that Core only supports constant IRIs and literals as node expressions, the use cases of node expressions are identical to traditional use of SHACL Core.
evalExpr(expr, focusGraph, focusNode, scope) -> outputNodes
				where
				expr is a node expression in a shapes graph.
					During evaluation, the engine can access triples related to expr in the shapes graph.focusGraph is a graph, called the focus graph. This is the default query graph for the evaluation of the node expression.focusNode is a node, called the input focus node. This variable may have no value.scope is a map from variable names to individual nodes.
					The empty map is written as {}.
					The SHACL Core specification only exactly defines the node expression functions based on the next two subsections. Other specifications such as [shacl12-sparql] introduce additional functions, using blank nodes. Therefore node expressions serve as an extension point of SHACL. TODO: Add link to shacl12-node-expr once that is stable.
					A node expression that is a IRI is called an IRI expression with the function name
					sh:IRIExpression.
				
A node in an RDF graph is a well-formed IRI expression if it is an IRI.
						The output nodes of an IRI expression are the list consisting of exactly the node expression itself:
						
						
						evalExpr(expr, focusGraph, focusNode, scope) -> [expr]
					
					A node expression that is a literal is called a literal expression with the function name
					sh:LiteralExpression.
				
A node in an RDF graph is a well-formed literal expression if it is a literal.
						The output nodes of a literal expression are the list consisting of exactly the node expression itself:
						
						
						evalExpr(expr, focusGraph, focusNode, scope) -> [expr]
					
Validation takes a data graph and a shapes graph as input and produces a validation report containing the results of the validation. Conformance checking is a simplified version of validation, producing a boolean result. A system that is capable of performing validation is called a processor, and the verb processing is sometimes used to refer to the validation process.
SHACL defines an RDF Validation Report Vocabulary that can be used by processors that produce validation reports as RDF results graphs. This specification uses the SHACL results vocabulary for the normative definitions of the validators associated with the constraint components. Only SHACL implementations that can produce all of the mandatory properties of the Validation Report Vocabulary are standards-compliant.
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.
The remainder of this section is informative.
					Shapes graphs can be reusable validation modules that can be cross-referenced with the predicate owl:imports.
					As a pre-validation step, SHACL processors SHOULD extend the originally provided shapes graph by transitively following and importing all referenced shapes graphs
					through the owl:imports predicate.
					The resulting graph forms the input shapes graph for validation and MUST NOT be further modified during the validation process.
				
					In addition to shape declarations, the shapes graph may contain additional information for the SHACL processor such as sh:entailment statements.
				
Any RDF graph can be a data graph.
The remainder of this section is informative.
A data graph is one of the inputs to the SHACL processor for validation. SHACL processors treat it as a general RDF graph and makes no assumption about its nature. For example, it can be an in-memory graph or a named graph from an RDF dataset or a SPARQL endpoint.
SHACL can be used with RDF graphs that are obtained by any means, e.g. from the file system, HTTP requests, or RDF datasets. SHACL makes no assumptions about whether a graph contains triples that are entailed from the graph under any RDF entailment regime.
					The data graph is expected to include all the ontology axioms related to the data and especially all the
					rdfs:subClassOf triples in order for SHACL to correctly identify class targets and validate Core SHACL constraints.
				
					owl:imports in the data graph is not enacted, in order to avoid uncontrolled increase of validation work. If you want to validate 
					several related ontologies, pass all of them to the SHACL processor (together or one by one), do not rely on owl:imports links.
				
					A data graph can include triples used to suggest one or more graphs to a SHACL processor with the predicate sh:shapesGraph.
					Every value of sh:shapesGraph is an IRI representing a graph that SHOULD be included into the shapes graph used to validate the data graph.
				
					In the following example, a SHACL processor SHOULD use the union of ex:graph-shapes1 and ex:graph-shapes2 graphs (and their owl:imports) as the shapes graph when validating the given graph.
				
{
	"@id": "http://example.com/myDataGraph",
	"sh:shapesGraph": [
		{
			"@id": "ex:graph-shapes1"
		},
		{
			"@id": "ex:graph-shapes2"
		}
	]
}Validation is a mapping from some input to validation results, as defined in the following paragraphs.
Validation of a data graph against a shapes graph: Given a data graph and a shapes graph, the validation results are the union of results of the validation of the data graph against all shapes in the shapes graph.
Validation of a data graph against a shape: Given a data graph and a shape in the shapes graph, the validation results are the union of the results of the validation of all focus nodes that are in the target of the shape in the data graph.
Validation of a focus node against a shape: Given a focus node in the data graph and a shape in the shapes graph, the validation results are the union of the results of the validation of the focus node against all constraints declared by the shape, unless the shape has been deactivated, in which case the validation results are empty.
					Validation of a focus node against a constraint:
					Given a focus node in the data graph and a constraint of kind C in the shapes graph,
					the validation results are defined by the validators of the constraint component C.
					These validators typically take as input the focus node, the specific values of the parameters of C
					of the constraint in the shapes graph, and the value nodes of the shape that declares the constraint.
				
During validation, the data graph and the shapes graph MUST remain immutable, i.e. both graphs at the end of the validation MUST be identical to the graph at the beginning of validation. SHACL processors MUST NOT change the graphs that they use to construct the shapes graph or the data graph, even if these graphs are part of an RDF store that allows changes to its stored graphs. SHACL processors MAY store the graphs that they create, such as a graph containing validation results, and this operation MAY change existing graphs in an RDF store, but not any of the graphs that were used to construct the shapes graph or the data graph. SHACL processing is thus idempotent.
Validation and conformance checking can result in a failure. For example, a particular SHACL processor might allow recursive shapes but report a failure if it detects a loop within the data. Failures can also be reported due to resource exhaustion. Failures are signalled through implementation-specific channels.
If the shapes graph contains ill-formed nodes, then the result of the validation process is undefined. A SHACL processor SHOULD produce a failure in this case. See also 5.6.1.3 Syntax Checking of Shapes Graph (sh:shapesGraphWellFormed).
The following properties are the so-called shape-expecting constraint parameters in SHACL Core:
The following properties are the so-called list-taking constraint parameters in SHACL Core:
						A shape s1 in an RDF graph G refers to shape s2
						in G if it	has s2 as value for some non-list-taking,
						shape-expecting parameter of some constraint component or s2 as a member of
						the value for some list-taking, shape-expecting parameter of some constraint component.
						A shape in an RDF graph G is a recursive shape in G if it is related to
						itself by the transitive closure of the refers relationship in G.
					
The validation with recursive shapes is not defined in SHACL and is left to SHACL processor implementations. For example, SHACL processors may support recursion scenarios or produce a failure when they detect recursion.
The remainder of this section is informative.
The recursion policy above has been selected to support a large variety of implementation strategies. By leaving recursion undefined, implementations may chose to not support recursion so that they can issue a static set of SPARQL queries (against SPARQL end points) without having to support cycles. The Working Group is aware that other implementations may support recursion and that some shapes graphs may rely on these specific characteristics. The expectation is that future work, for example in W3C Community Groups, will lead to the definition of specific dialects of SHACL where recursion is well-defined.
A focus node conforms to a shape if and only if the set of result of the validation of the focus node against the shape does not contain any results with a severity level representing a violation and no failure has been reported by it.
					Conformance checking produces true if and only if a given focus node
					conforms to a given shape, and false otherwise.
				
					Note that all shape-expecting constraint parameters of SHACL Core
					rely on conformance checking.
					In these cases, the validation results used to determine the outcome of conformance checking are
					separated from those of the surrounding validation process and typically do not end up in the same validation report
					(except perhaps as values of sh:detail).
				
The validation report is the result of the validation process that reports the conformance and the set of all validation results. The validation report is described with the SHACL Validation Report Vocabulary as defined in this section. This vocabulary defines the RDF properties to represent structural information that may provide guidance on how to identify or fix violations in the data graph.
SHACL-compliant processors MUST be capable of returning a validation report with all required validation results described in this specification. SHACL-compliant processors MAY support optional arguments that make it possible to limit the number of returned results. This flexibility is for example needed in some large-scale dataset validation use cases.
The following graph represents an example of a validation report for the validation of a data graph that conforms to a shapes graph.
{
	"@id": "_:b1",
	"@type": "sh:ValidationReport",
	"sh:conforms": {
		"@type": "xsd:boolean",
		"@value": "true"
	}
}
					The following graph represents an example of a validation report for the validation of a data graph that does not conform to a shapes graph.
					Note that the specific value of sh:resultMessage is not mandated by SHACL and considered implementation-specific.
				
{
	"@type": "sh:ValidationReport",
	"sh:conforms": {
		"@type": "xsd:boolean",
		"@value": "false"
	},
	"sh:result": {
		"@type": "sh:ValidationResult",
		"sh:focusNode": {
			"@id": "ex:Bob"
		},
		"sh:resultMessage": "ex:age expects a literal of datatype xsd:integer.",
		"sh:resultPath": {
			"@id": "ex:age"
		},
		"sh:resultSeverity": {
			"@id": "sh:Violation"
		},
		"sh:sourceConstraintComponent": {
			"@id": "sh:DatatypeConstraintComponent"
		},
		"sh:sourceShape": {
			"@id": "ex:PersonShape-age"
		},
		"sh:value": "twenty two"
	}
}
						The result of a validation process is an RDF graph with exactly one SHACL instance of sh:ValidationReport.
						The RDF graph MAY contain additional information such as provenance metadata.
					
							Each SHACL instance of sh:ValidationReport in the results graph has exactly one value for the property sh:conforms and the value is of datatype xsd:boolean.
							It represents the outcome of the conformance checking.
							The value of sh:conforms is true if and only if the validation did not produce any validation results with a severity level representing a violation, and false otherwise.
						
							For every validation result that is produced by a validation process
							(except those mentioned in the context of conformance checking),
							the SHACL instance of sh:ValidationReport in the results graph has a value for the property sh:result.
							Each value of sh:result is a SHACL instance of the class sh:ValidationResult.
						
							SHACL validation engines are not strictly required to check whether the shapes graph is well-formed.
							Implementations that do perform such checks (e.g., when the shapes graph is installed in the system,
							or before or during the validation) SHOULD use the property sh:shapesGraphWellFormed to inform the
							consumer of the validation report about this fact.
							If a SHACL instance of sh:ValidationReport in the results graph has true as the value
							for sh:shapesGraphWellFormed then the processor was certain that the shapes graph that was used for the
							validation process has passed all SHACL syntax rules (as summarized in A. Summary of SHACL Syntax Rules) during the validation process.
						
						SHACL defines sh:ValidationResult as a subclass of sh:AbstractResult to report individual SHACL validation results.
						SHACL implementations may use other SHACL subclasses of sh:AbstractResult, for example,
						to report successfully completed constraint checks or accumulated results.
					
						All the properties described in the remaining sub-sections of this section can be specified in a sh:ValidationResult.
						The properties sh:focusNode, sh:resultSeverity and sh:sourceConstraintComponent
						are the only properties that are mandatory for all validation results.
					
							Each validation result has exactly one value for the property sh:focusNode
							that is equal to the focus node that has caused the result.
							This is the focus node that was validated when the validation result was produced.
						
							Validation results may have a value for the property sh:resultPath pointing at a well-formed SHACL property path.
							For results produced by a property shape, this SHACL property path is equivalent to the value of sh:path of the shape,
							unless stated otherwise. 
							If the sh:path p is a blank node, then the sh:resultPath is a deep copy of p in the results graph.
						
							Validation results may include, as a value of the property sh:value,
							at most one RDF term that has caused the result.
							The textual definitions of the validators of the SHACL Core components specify how this
							value is constructed - often they are the value nodes that have violated a constraint.
						
							Validation results may include, as the only value of the property sh:sourceShape,
							the shape that the given sh:focusNode was validated against.
						
							Validation results have exactly one value for the property sh:sourceConstraintComponent
							and this value is the IRI of the constraint component that caused the result.
							For example, results produced due to a violation of a constraint based on a value of sh:minCount
							would have the source constraint component sh:MinCountConstraintComponent.
						
							The property sh:detail may link a (parent) result with one or more SHACL instances of
							sh:AbstractResult that can provide further details about the cause of the (parent) result.
							Depending on the capabilities of the SHACL processor, this may for example include violations of
							constraints that have been evaluated as part of conformance checking via sh:node.
						
							Validation results may have values for the property sh:resultMessage,
							for example to communicate additional textual details to humans.
							While sh:resultMessage may have multiple values, there should not be two values with the same language tag.
							These values are produced by a validation engine based on the values of sh:message of the constraints
							in the shapes graph, see Declaring Messages for a Shape.
							Messages declared using reification have precedence over those declared at the surrounding shape.
							In cases where a constraint does not have any values for sh:message in the shapes graph the
							SHACL processor MAY automatically generate other values for sh:resultMessage.
						
							Each validation result has exactly one value for the property sh:resultSeverity, and this value is an IRI.
							The value is determined by the following rules (in order):
						
sh:severity at a reifier of any of the triples containing the parameters of the constraint that caused the resultsh:severity of the shape in the shapes graph that caused the resultsh:Violation if no sh:severity has been specified for the shape or constraint.The validators of most constraint components use the concept of value nodes, which is defined by the following two sub-sections.
For node shapes the value nodes are the individual focus nodes, forming a set with exactly one member.
						For property shapes with a value for sh:path p the
						set of value nodes is produced by the following steps:
					
p.
						e is the value of sh:values at the property shape,
							then add the output nodes of evalExpr(e, data graph, focus node, {}).
						d is the value of sh:defaultValue at the property shape,
							then add the output nodes of evalExpr(d, data graph, focus node, {}).
						This section defines the built-in SHACL Core constraint components that MUST be supported by all SHACL Core processors. The definition of each constraint component contains its IRI as well as a table of its parameters. Unless stated otherwise, all these parameters are mandatory parameters. Shapes that violate any of the syntax rules enumerated in those parameter tables are ill-formed.
				Each constraint component also includes a textual definition, which describes the validator associated with the component.
				These textual definitions refer to the values of the parameters in the constraint by variables of the form
				$paramName where paramName is the part of the parameter's IRI after the sh: namespace.
				For example, the textual definition of sh:ClassConstraintComponent refers to the value of
				sh:class using the variable $class.
				In SHACL Core, the term parameter value means the value of a parameter,
				i.e. the object of the triple in the shapes graph where the subject is the shape
				and the predicate is the parameter (such as sh:class).
			
				At the time of writing, the intent of the WG is to define a dialect of SHACL outside of SHACL Core in which the term
				parameter value also allows node expressions.
				Note that not all constraint components use the term parameter value but instead refer to the term value.
				For example, the values of sh:node cannot ever be node expressions, because this would complicate
				the handling of blank nodes.
				TODO: Add link to Node Expression spec in case it's ready, or clarify the sentences above otherwise.
			
Note that these validators define the only validation results that are being produced by the component. Furthermore, the validators always produce new result nodes, i.e. when the textual definition states that "...there is a validation result..." then this refers to a distinct new node in a results graph.
The remainder of this section is informative.
The choice of constraint components that were included into the SHACL Core was made based on the requirements collected by the [shacl-ucr] document. Special attention was paid to the balance between trying to cover as many common use cases as possible and keeping the size of the Core language manageable. Not all use cases can be expressed by the Core language alone. Instead, SHACL-SPARQL provides an extension mechanism, described in the second part of this specification. It is expected that additional reusable libraries of constraint components will be maintained by third parties.
				Unless stated otherwise, the Core constraint components can be used both in property shapes and node shapes.
				Some constraint parameters have syntax rules attached to them that would make node shapes that use these parameters ill-formed.
				Examples of this include sh:minCount which is only supported for property shapes.
			
The constraint components in this section have in common that they can be used to restrict the type of value nodes. Note that it is possible to represent multiple value type alternatives using sh:or.
						The condition specified by sh:class is that each value node is a SHACL instance of the given type(s).
					
						Constraint Component IRI: sh:ClassConstraintComponent
					
| Property | Summary and Syntax Rules | 
|---|---|
| sh:class | The type of all value nodes.
								The values of sh:classin a shape are either IRIs
								or blank nodes that are well-formed SHACL lists where all members are IRIs. | 
$class be a parameter value for sh:class.
							Let classes be a set of IRIs so that
							when $class is an IRI then the set only consists of exactly that IRI,
							and when $class is a blank node SHACL list then the set consists of
							exactly the members of the list.classes in the data graph,
							there is a validation result with the value node as sh:value.
						The remainder of this section is informative.
						Note that multiple values for sh:class are interpreted as a conjunction,
						i.e., the values need to be SHACL instances of all of them.
						Use lists for union semantics.
					
{
	"@id": "ex:ClassExampleShape",
	"@type": "sh:NodeShape",
	"sh:property": {
		"sh:class": {
			"@id": "ex:PostalAddress"
		},
		"sh:path": {
			"@id": "ex:address"
		}
	},
	"sh:targetNode": [
		{
			"@id": "ex:Bob"
		},
		{
			"@id": "ex:Alice"
		},
		{
			"@id": "ex:Carol"
		}
	]
}shape ex:ClassExampleShape {
	targetNode=ex:Bob targetNode=ex:Alice targetNode=ex:Carol .
	ex:address ex:PostalAddress .
}{
	"@graph": [
		{
			"@id": "ex:Alice",
			"@type": "ex:Person"
		},
		{
			"@id": "ex:Bob",
			"ex:address": {
				"@type": "ex:PostalAddress",
				"ex:city": {
					"@id": "ex:Berlin"
				}
			}
		},
		{
			"@id": "ex:Carol",
			"ex:address": {
				"ex:city": {
					"@id": "ex:Cairo"
				}
			}
		}
	]
}
						The following example illustrates the list-based syntax for sh:class,
						meaning that the values of the property ex:pet must be either cats or dogs.
					
						sh:datatype specifies a condition to be satisfied with regards to the datatype of each value node.
					
						Constraint Component IRI: sh:DatatypeConstraintComponent
					
| Property | Summary and Syntax Rules | 
|---|---|
| sh:datatype | The allowed datatype(s) of all value nodes (e.g., xsd:integer).
								A shape has at most one value forsh:datatype.
								The value ofsh:datatypein a shape is either an IRI
								or a blank node that is a well-formed SHACL list where all members are IRIs. | 
$datatype be a parameter value for sh:datatype.
							Let datatypes be a set of IRIs so that
							when $datatype is an IRI then the set only consists of exactly that IRI,
							and when $datatype is a blank node SHACL list then the set consists of
							exactly the members of the list.datatypes,
							there is a validation result with the value node as sh:value.The remainder of this section is informative.
						The values of sh:datatype are typically datatypes, such as xsd:string.
					
{
	"@id": "ex:DatatypeExampleShape",
	"@type": "sh:NodeShape",
	"sh:property": {
		"sh:datatype": {
			"@id": "xsd:integer"
		},
		"sh:path": {
			"@id": "ex:age"
		}
	},
	"sh:targetNode": [
		{
			"@id": "ex:Alice"
		},
		{
			"@id": "ex:Bob"
		},
		{
			"@id": "ex:Carol"
		}
	]
}shape ex:DatatypeExampleShape {
	targetNode=ex:Alice targetNode=ex:Bob targetNode=ex:Carol .
	ex:age xsd:integer .
}{
	"@graph": [
		{
			"@id": "ex:Alice",
			"ex:age": {
				"@type": "xsd:integer",
				"@value": "23"
			}
		},
		{
			"@id": "ex:Bob",
			"ex:age": "twenty two"
		},
		{
			"@id": "ex:Carol",
			"ex:age": {
				"@type": "xsd:int",
				"@value": "23"
			}
		}
	]
}
						The following example illustrates the list-based syntax, meaning that all values of
						rdfs:label must be either xsd:string or rdf:langString.
						Note that using rdf:langString as value of sh:datatype can be used to test if value nodes have a language tag.
					
						sh:nodeKind specifies a condition to be satisfied by the RDF node kind of each value node.
					
						Constraint Component IRI: sh:NodeKindConstraintComponent
					
| Property | Summary and Syntax Rules | 
|---|---|
| sh:nodeKind | The node kind (IRI, blank node, literal or combinations of these) of all value nodes.
								The values of sh:nodeKindin a shape are one of the following six instances of the classsh:NodeKind:sh:BlankNode,sh:IRI,sh:Literalsh:BlankNodeOrIRI,sh:BlankNodeOrLiteralandsh:IRIOrLiteral.
								A shape has at most one value forsh:nodeKind. | 
$nodeKind be a parameter value for sh:nodeKind.
							For each value node
							that does not match $nodeKind,
							there is a validation result with the value node as sh:value.
							Any IRI matches only sh:IRI, sh:BlankNodeOrIRI and sh:IRIOrLiteral.
							Any blank node matches only sh:BlankNode, sh:BlankNodeOrIRI and sh:BlankNodeOrLiteral.
							Any literal matches only sh:Literal, sh:BlankNodeOrLiteral and sh:IRIOrLiteral.
						The remainder of this section is informative.
						The following example states that all values of ex:knows need to be IRIs, at any subject.
					
{
	"@id": "ex:NodeKindExampleShape",
	"@type": "sh:NodeShape",
	"sh:nodeKind": {
		"@id": "sh:IRI"
	},
	"sh:targetObjectsOf": {
		"@id": "ex:knows"
	}
}shape ex:NodeKindExampleShape {
	targetObjectsOf=ex:knows nodeKind=IRI .
}{
	"@graph": [
		{
			"@id": "ex:Alice",
			"ex:knows": "Bob"
		},
		{
			"@id": "ex:Bob",
			"ex:knows": {
				"@id": "ex:Alice"
			}
		}
	]
}The following constraint components represent restrictions on the number of value nodes for the given focus node.
						sh:minCount specifies the minimum number of value nodes that satisfy the condition.
						If the minimum cardinality value is 0 then this constraint is always satisfied and so may be omitted.
					
						Constraint Component IRI: sh:MinCountConstraintComponent
					
| Property | Summary and Syntax Rules | 
|---|---|
| sh:minCount | The minimum cardinality.
								Node shapes cannot have any value for sh:minCount.
								A property shape has at most one value forsh:minCount.
								The values ofsh:minCountin a property shape are literals with datatypexsd:integer. | 
$minCount be a parameter value for sh:minCount.
							If the number of value nodes is less than $minCount,
							there is a validation result.
						The remainder of this section is informative.
{
	"@id": "ex:MinCountExampleShape",
	"@type": "sh:PropertyShape",
	"sh:minCount": {
		"@type": "xsd:integer",
		"@value": "1"
	},
	"sh:path": {
		"@id": "ex:name"
	},
	"sh:targetNode": [
		{
			"@id": "ex:Alice"
		},
		{
			"@id": "ex:Bob"
		}
	]
}{
	"@graph": [
		{
			"@id": "ex:Alice",
			"ex:name": "Alice"
		},
		{
			"@id": "ex:Bob",
			"ex:givenName": {
				"@language": "en",
				"@value": "Bob"
			}
		}
	]
}
						sh:maxCount specifies the maximum number of value nodes that satisfy the condition.
					
						Constraint Component IRI: sh:MaxCountConstraintComponent
					
| Property | Summary and Syntax Rules | 
|---|---|
| sh:maxCount | The maximum cardinality.
								Node shapes cannot have any value for sh:maxCount.
								A property shape has at most one value forsh:maxCount.
								The values ofsh:maxCountin a property shape are literals with datatypexsd:integer. | 
$maxCount be a parameter value for sh:maxCount.
							If the number of value nodes is greater than $maxCount,
							there is a validation result.
						The remainder of this section is informative.
{
	"@id": "ex:MaxCountExampleShape",
	"@type": "sh:NodeShape",
	"sh:property": {
		"sh:maxCount": {
			"@type": "xsd:integer",
			"@value": "1"
		},
		"sh:path": {
			"@id": "ex:birthDate"
		}
	},
	"sh:targetNode": {
		"@id": "ex:Bob"
	}
}shape ex:MaxCountExampleShape {
	targetNode=ex:Bob .
	ex:birthDate [0..1] .
}{
	"@id": "ex:Bob",
	"ex:birthDate": "May 5th 1990"
}
					The following constraint components specify value range conditions to be satisfied by value nodes that are comparable
					via operators such as <, <=, > and >=.
					The following example illustrates a typical use case of these constraint components.
				
{
	"@id": "ex:NumericRangeExampleShape",
	"@type": "sh:NodeShape",
	"sh:property": {
		"sh:maxInclusive": {
			"@type": "xsd:integer",
			"@value": "150"
		},
		"sh:minInclusive": {
			"@type": "xsd:integer",
			"@value": "0"
		},
		"sh:path": {
			"@id": "ex:age"
		}
	},
	"sh:targetNode": [
		{
			"@id": "ex:Bob"
		},
		{
			"@id": "ex:Alice"
		},
		{
			"@id": "ex:Ted"
		}
	]
}shape ex:NumericRangeExampleShape {
	targetNode=ex:Bob targetNode=ex:Alice targetNode=ex:Ted .
	ex:age minInclusive=0 maxInclusive=150 .
}{
	"@graph": [
		{
			"@id": "ex:Alice",
			"ex:age": {
				"@type": "xsd:integer",
				"@value": "220"
			}
		},
		{
			"@id": "ex:Bob",
			"ex:age": {
				"@type": "xsd:integer",
				"@value": "23"
			}
		},
		{
			"@id": "ex:Ted",
			"ex:age": "twenty one"
		}
	]
}
						Constraint Component IRI: sh:MinExclusiveConstraintComponent
					
| Property | Summary and Syntax Rules | 
|---|---|
| sh:minExclusive | The minimum exclusive value.
								The values of sh:minExclusivein a shape are literals.
								A shape has at most one value forsh:minExclusive. | 
$minExclusive be a parameter value for sh:minExclusive.
							For each value node v
							where the SPARQL expression $minExclusive < v does not return true,
							there is a validation result with v as sh:value. 
						The remainder of this section is informative.
There is a validation result if the value node cannot be compared to the specified range, for example when someone compares a string with an integer.
						Constraint Component IRI: sh:MinInclusiveConstraintComponent
					
| Property | Summary and Syntax Rules | 
|---|---|
| sh:minInclusive | The minimum inclusive value.
								The values of sh:minInclusivein a shape are literals.
								A shape has at most one value forsh:minInclusive. | 
$minInclusive be a parameter value for sh:minInclusive.
							For each value node v
							where the SPARQL expression $minInclusive <= v does not return true,
							there is a validation result with v as sh:value. 
						
						Constraint Component IRI: sh:MaxExclusiveConstraintComponent
					
| Property | Summary and Syntax Rules | 
|---|---|
| sh:maxExclusive | The maximum exclusive value.
								The values of sh:maxExclusivein a shape are literals.
								A shape has at most one value forsh:maxExclusive. | 
$maxExclusive be a parameter value for sh:maxExclusive.
							For each value node v
							where the SPARQL expression $maxExclusive > v does not return true,
							there is a validation result with v as sh:value. 
						
						Constraint Component IRI: sh:MaxInclusiveConstraintComponent
					
| Property | Summary and Syntax Rules | 
|---|---|
| sh:maxInclusive | The maximum inclusive value.
								The values of sh:maxInclusivein a shape are literals.
								A shape has at most one value forsh:maxInclusive. | 
$maxInclusive be a parameter value for sh:maxInclusive.
							For each value node v
							where the SPARQL expression $maxInclusive >= v does not return true,
							there is a validation result with v as sh:value. 
						The constraint components in this section have in common that they specify conditions on the string representation of value nodes.
						sh:minLength specifies the minimum string length of each value node that satisfies the condition.
						This can be applied to any literals and IRIs, but not to blank nodes.
					
						Constraint Component IRI: sh:MinLengthConstraintComponent
					
| Property | Summary and Syntax Rules | 
|---|---|
| sh:minLength | The minimum length.
								The values of sh:minLengthin a shape are literals with datatypexsd:integer.
								A shape has at most one value forsh:minLength. | 
$minLength be a parameter value for sh:minLength.
							For each value node v
							where the length (as defined by the SPARQL STRLEN function)
							of the string representation of v (as defined by the SPARQL str function)
							is less than $minLength, or where v is a blank node,
							there is a validation result with v as sh:value.
						The remainder of this section is informative.
						Note that if the value of sh:minLength is 0 then there is no restriction on the
						string length but the constraint is still violated if the value node is a blank node.
					
						sh:maxLength specifies the maximum string length of each value node that satisfies the condition.
						This can be applied to any literals and IRIs, but not to blank nodes.
					
						Constraint Component IRI: sh:MaxLengthConstraintComponent
					
| Property | Summary and Syntax Rules | 
|---|---|
| sh:maxLength | The maximum length.
								The values of sh:maxLengthin a shape are literals with datatypexsd:integer.
								A shape has at most one value forsh:maxLength. | 
$maxLength be a parameter value for sh:maxLength.
							For each value node v
							where the length (as defined by the SPARQL STRLEN function)
							of the string representation of v (as defined by the SPARQL str function)
							is greater than $maxLength, or where v is a blank node,
							there is a validation result with v as sh:value.
						The remainder of this section is informative.
{
	"@id": "ex:PasswordExampleShape",
	"@type": "sh:NodeShape",
	"sh:property": {
		"sh:maxLength": {
			"@type": "xsd:integer",
			"@value": "10"
		},
		"sh:minLength": {
			"@type": "xsd:integer",
			"@value": "8"
		},
		"sh:path": {
			"@id": "ex:password"
		}
	},
	"sh:targetNode": [
		{
			"@id": "ex:Bob"
		},
		{
			"@id": "ex:Alice"
		}
	]
}shape ex:PasswordExampleShape {
	targetNode=ex:Bob targetNode=ex:Alice .
	ex:password minLength=8 maxLength=10 .
}{
	"@graph": [
		{
			"@id": "ex:Alice",
			"ex:password": "1234567890ABC"
		},
		{
			"@id": "ex:Bob",
			"ex:password": "123456789"
		}
	]
}
						sh:pattern specifies a regular expression that each value node matches to satisfy the condition.
					
						Constraint Component IRI: sh:PatternConstraintComponent
					
| Property | Summary and Syntax Rules | 
|---|---|
| sh:pattern | A regular expression that all value nodes need to match.
								The values of sh:patternin a shape are literals with datatypexsd:string.
								The values ofsh:patternin a shape are valid pattern arguments for the SPARQL REGEX function. | 
| sh:flags | An optional string of flags, interpreted as in SPARQL 1.2 REGEX.
								The values of sh:flagsin a shape are literals with datatypexsd:string. | 
$pattern be a parameter value for sh:pattern.
							Let $flags be a parameter value for sh:flags.
							For each value node
							that is a blank node or
							where the string representation (as defined by the SPARQL str function)
							does not match the regular expression $pattern (as defined by the SPARQL REGEX function),
							there is a validation result with the value node as sh:value.
							If $flags has a value then the matching MUST follow the definition of the 3-argument variant of the SPARQL REGEX function, using $flags as third argument.
						The remainder of this section is informative.
{
	"@id": "ex:PatternExampleShape",
	"@type": "sh:NodeShape",
	"sh:property": {
		"sh:flags": "i",
		"sh:path": {
			"@id": "ex:bCode"
		},
		"sh:pattern": "^B"
	},
	"sh:targetNode": [
		{
			"@id": "ex:Bob"
		},
		{
			"@id": "ex:Alice"
		},
		{
			"@id": "ex:Carol"
		}
	]
}shape ex:PatternExampleShape {
	targetNode=ex:Bob targetNode=ex:Alice targetNode=ex:Carol .
	ex:bCode pattern="^B" flags="i" .
}{
	"@graph": [
		{
			"@id": "ex:Alice",
			"ex:bCode": "B102"
		},
		{
			"@id": "ex:Bob",
			"ex:bCode": "b101"
		},
		{
			"@id": "ex:Carol",
			"ex:bCode": "C103"
		}
	]
}This feature is "at risk" pending a WG resolution on this (and similar) convenience features. The WG is not sure yet where to draw the lines between features that should go into Core versus some other document. Originally discussed as Issue 177.
						When set to true, sh:singleLine specifies that the value nodes must not contain line breaks.
						In addition to constraint validation, this information can be exploited by user interface builders to select between (single-lined) text fields and (multi-lined) text areas.
					
						Constraint Component IRI: sh:SingleLineConstraintComponent
					
| Property | Summary and Syntax Rules | 
|---|---|
| sh:singleLine | trueto activate this constraint.
								The values ofsh:singleLinein a shape are literals with datatypexsd:boolean.
								A shape has at most one value forsh:singleLine. | 
$singleLine be a parameter value for sh:singleLine.
							If $singleLine is true, then, for each value node that is a literal where the lexical form matches the
							regular expression (as defined by the SPARQL REGEX function) [\f\r\n\v], there is a validation result.
						The remainder of this section is informative.
							In this example, the valid target nodes of the shape can only contain single-lined values for rdfs:label.
							The values of rdfs:comment are explicitly allowed to contain line breaks, indicating to form builders that
							those values should be edited in a multi-line (text area) input widget.
						
{
	"@id": "ex:SingleLineExampleShape",
	"@type": "sh:NodeShape",
	"sh:property": [
		{
			"@type": "sh:PropertyShape",
			"sh:datatype": {
				"@id": "xsd:string"
			},
			"sh:path": {
				"@id": "rdfs:label"
			},
			"sh:singleLine": {
				"@type": "xsd:boolean",
				"@value": "true"
			}
		},
		{
			"@type": "sh:PropertyShape",
			"sh:or": {
				"@list": [
					{
						"sh:datatype": {
							"@id": "xsd:string"
						}
					},
					{
						"sh:datatype": {
							"@id": "rdf:langString"
						}
					}
				]
			},
			"sh:path": {
				"@id": "rdfs:comment"
			},
			"sh:singleLine": {
				"@type": "xsd:boolean",
				"@value": "false"
			}
		}
	]
}
						The condition specified by sh:languageIn is that the allowed language tags for each value node are limited by a given list of language tags.
					
						Constraint Component IRI: sh:LanguageInConstraintComponent
					
| Property | Summary and Syntax Rules | 
|---|---|
| sh:languageIn | A list of basic language ranges as per [BCP47].
								Each value of sh:languageInin a shape is a SHACL list.
								Each member of such a list is a literal with datatypexsd:string.
								A shape has at most one value forsh:languageIn. | 
$languageIn be a value of sh:languageIn.
							For each value node
							that is either not a literal or that does not have a language tag
							matching any of the basic language ranges that are the members of $languageIn
							following the filtering schema defined by the SPARQL langMatches function,
							there is a validation result with the value node as sh:value.
						The remainder of this section is informative.
						The following example shape states that all values of ex:prefLabel
						can be either in English or Māori.
					
{
	"@id": "ex:NewZealandLanguagesShape",
	"@type": "sh:NodeShape",
	"sh:property": {
		"sh:languageIn": {
			"@list": [
				"en",
				"mi"
			]
		},
		"sh:path": {
			"@id": "ex:prefLabel"
		}
	},
	"sh:targetNode": [
		{
			"@id": "ex:Mountain"
		},
		{
			"@id": "ex:Berg"
		}
	]
}shape ex:NewZealandLanguagesShape {
	targetNode=ex:Mountain targetNode=ex:Berg .
	ex:prefLabel languageIn=["en" "mi"] .
}
							From the example instances, ex:Berg will lead to constraint violations for all
							of its labels.
						
{
	"@graph": [
		{
			"@id": "ex:Berg",
			"ex:prefLabel": [
				"Berg",
				{
					"@language": "de",
					"@value": "Berg"
				},
				{
					"@id": "ex:BergLabel"
				}
			]
		},
		{
			"@id": "ex:Mountain",
			"ex:prefLabel": [
				{
					"@language": "en",
					"@value": "Mountain"
				},
				{
					"@language": "en-nz",
					"@value": "Hill"
				},
				{
					"@language": "mi",
					"@value": "Maunga"
				}
			]
		}
	]
}
						The property sh:uniqueLang can be set to true to specify that no pair of value nodes may use the same language tag.
					
						Constraint Component IRI: sh:UniqueLangConstraintComponent
					
| Property | Summary and Syntax Rules | 
|---|---|
| sh:uniqueLang | trueto activate this constraint.
								The values ofsh:uniqueLangin a shape are literals with datatypexsd:boolean.
								A property shape has at most one value forsh:uniqueLang.
								Node shapes cannot have any value forsh:uniqueLang. | 
$uniqueLang be a parameter value for sh:uniqueLang.
							If $uniqueLang is true
							then for each non-empty language tag that is used by at least two value nodes,
							there is a validation result. 
						The remainder of this section is informative.
{
	"@id": "ex:UniqueLangExampleShape",
	"@type": "sh:NodeShape",
	"sh:property": {
		"sh:path": {
			"@id": "ex:label"
		},
		"sh:uniqueLang": {
			"@type": "xsd:boolean",
			"@value": "true"
		}
	},
	"sh:targetNode": [
		{
			"@id": "ex:Alice"
		},
		{
			"@id": "ex:Bob"
		}
	]
}shape ex:UniqueLangExampleShape {
	targetNode=ex:Alice targetNode=ex:Bob .
	ex:label uniqueLang=true .
}{
	"@graph": [
		{
			"@id": "ex:Alice",
			"ex:label": [
				"Alice",
				{
					"@language": "en",
					"@value": "Alice"
				},
				{
					"@language": "fr",
					"@value": "Alice"
				}
			]
		},
		{
			"@id": "ex:Bob",
			"ex:label": [
				{
					"@language": "en",
					"@value": "Bob"
				},
				{
					"@language": "en",
					"@value": "Bobby"
				}
			]
		}
	]
}The constraint components in this section apply to value nodes that are SHACL lists. They specify conditions on the structure, length, and members of SHACL lists.
						sh:memberShape specifies that all members of SHACL list value nodes must conform to the given node shape.
					
						Constraint Component IRI: sh:MemberShapeConstraintComponent
					
| Property | Summary and Syntax Rules | 
|---|---|
| sh:memberShape | The shape that all members of the SHACL list must conform to.
								The value of sh:memberShapemust be a well-formed node shape. | 
$memberShape be a parameter value for sh:memberShape.
							Each value node v must be a SHACL list - if v is not a SHACL list there is a validation result.
							If any member m of the SHACL list v does not conform to $memberShape, there is a validation result.
						The remainder of this section is informative.
						Each member m of a value node v that does not conform to the $memberShape should be reported as a separate sh:detail in the validation result for v.
						If v is not a valid SHACL list, this should be reported as a top-level validation result and validation of individual members should not be attempted.
					
						Examples of how to generate sh:details in validation results can be found in the test cases for sh:memberShape in the SHACL test suite: memberShape-001.ttl.
					
						In the following example, all values of the property ex:speakerOrder must be SHACL lists with members that are IRIs.
					
{
	"@id": "ex:AgendaShape",
	"@type": "sh:NodeShape",
	"sh:property": {
		"sh:memberShape": {
			"sh:nodeKind": {
				"@id": "sh:IRI"
			}
		},
		"sh:path": {
			"@id": "ex:speakerOrder"
		}
	},
	"sh:targetClass": {
		"@id": "ex:Agenda"
	}
}{
	"@graph": [
		{
			"@id": "ex:agenda1",
			"@type": "ex:Agenda",
			"ex:speakerOrder": {
				"@list": [
					{
						"@id": "ex:Alice"
					},
					{
						"@id": "ex:Bob"
					},
					{
						"@id": "ex:Charlie"
					}
				]
			}
		},
		{
			"@id": "ex:agenda2",
			"@type": "ex:Agenda",
			"ex:speakerOrder": {
				"@list": [
					{
						"@id": "ex:Alice"
					},
					{
						"@id": "ex:Bob"
					},
					"Charlie"
				]
			}
		}
	]
}
						sh:minListLength specifies the minimum number of members that SHACL list value nodes must have.
					
						Constraint Component IRI: sh:MinListLengthConstraintComponent
					
| Property | Summary and Syntax Rules | 
|---|---|
| sh:minListLength | The minimum number of members in the SHACL list.
								The values of sh:minListLengthin a shape are literals with datatypexsd:integer.
								The values ofsh:minListLengthin a shape are integers greater than or equal to 0. | 
$minListLength be a parameter value for sh:minListLength.
							Each value node v must be a SHACL list - if v is not a SHACL list there is a validation result.
							If the number of members in a list v is less than $minListLength,
							there is a validation result.
						The remainder of this section is informative.
						In the following example, all values of the property ex:skills must be SHACL lists with at least 1 member.
						Additional test cases for sh:minListLength can be found in the SHACL test suite: minListLength-001.ttl.
					
{
	"@id": "ex:PersonShape",
	"@type": "sh:NodeShape",
	"sh:property": {
		"sh:minListLength": {
			"@type": "xsd:integer",
			"@value": "1"
		},
		"sh:path": {
			"@id": "ex:skills"
		}
	},
	"sh:targetClass": {
		"@id": "ex:Person"
	}
}{
	"@graph": [
		{
			"@id": "ex:person1",
			"@type": "ex:Person",
			"ex:skills": {
				"@list": [
					"programming",
					"design"
				]
			}
		},
		{
			"@id": "ex:person2",
			"@type": "ex:Person",
			"ex:skills": {
				"@list": []
			}
		}
	]
}
						sh:maxListLength specifies the maximum number of members that SHACL list value nodes must have.
					
						Constraint Component IRI: sh:MaxListLengthConstraintComponent
					
| Property | Summary and Syntax Rules | 
|---|---|
| sh:maxListLength | The maximum number of members in the SHACL list.
								The values of sh:maxListLengthin a shape are literals with datatypexsd:integer.
								The values ofsh:maxListLengthin a shape are integers greater than or equal to 0. | 
$maxListLength be a parameter value for sh:maxListLength.
							Each value node v must be a SHACL list - if v is not a SHACL list there is a validation result.
							If the number of members in the list v is greater than $maxListLength,
							there is a validation result.
						The remainder of this section is informative.
						In the following example, all values of the property ex:hobbies must be SHACL lists with at most 2 members.
						Additional test cases for sh:maxListLength can be found in the SHACL test suite: maxListLength-001.ttl.
					
{
	"@id": "ex:PersonShape",
	"@type": "sh:NodeShape",
	"sh:property": {
		"sh:maxListLength": {
			"@type": "xsd:integer",
			"@value": "2"
		},
		"sh:path": {
			"@id": "ex:hobbies"
		}
	},
	"sh:targetClass": {
		"@id": "ex:Person"
	}
}{
	"@graph": [
		{
			"@id": "ex:person1",
			"@type": "ex:Person",
			"ex:hobbies": {
				"@list": [
					"reading",
					"writing"
				]
			}
		},
		{
			"@id": "ex:person2",
			"@type": "ex:Person",
			"ex:hobbies": {
				"@list": [
					"reading",
					"writing",
					"swimming"
				]
			}
		}
	]
}
						sh:uniqueMembers specifies whether SHACL list value nodes must have unique members.
					
						Constraint Component IRI: sh:UniqueMembersConstraintComponent
					
| Property | Summary and Syntax Rules | 
|---|---|
| sh:uniqueMembers | A boolean that specifies whether the members of the SHACL list must be unique.
								The values of sh:uniqueMembersin a shape are literals with datatypexsd:boolean. | 
$uniqueMembers be a parameter value for sh:uniqueMembers.
							Each value node v must be a SHACL list - if v is not a SHACL list there is a validation result.
							If $uniqueMembers is true and the list v has duplicate members,
							there is a validation result.
						The remainder of this section is informative.
				
						Each duplicate member m of a list v should be reported as a separate sh:detail in the validation result for v. If the list v is not a valid SHACL list, this should be reported as a top-level validation result and validation of unique membership should not be attempted.
					
						Examples of how to generate sh:details in validation results can be found in the test cases for sh:uniqueMembers in the SHACL test suite: uniqueMembers-001.ttl.
					
						In the following example, all values of the property ex:preferences must be SHACL lists with members that have unique values within each SHACL list.
					
{
	"@id": "ex:PersonShape",
	"@type": "sh:NodeShape",
	"sh:property": {
		"sh:uniqueMembers": {
			"@type": "xsd:boolean",
			"@value": "true"
		},
		"sh:path": {
			"@id": "ex:preferences"
		}
	},
	"sh:targetClass": {
		"@id": "ex:Person"
	}
}{
	"@graph": [
		{
			"@id": "ex:person1",
			"@type": "ex:Person",
			"ex:preferences": {
				"@list": [
					"coffee",
					"tea"
				]
			}
		},
		{
			"@id": "ex:person2",
			"@type": "ex:Person",
			"ex:preferences": {
				"@list": [
					"coffee",
					"tea",
					"coffee",
					"tea",
					"tea"
				]
			}
		}
	]
}The constraint components in this section specify conditions on the sets of value nodes in relation to other properties. These constraint components can only be used by property shapes.
						sh:equals specifies the condition that the set of all value nodes is equal to the set of objects of the triples that have the focus node as subject and the value of sh:equals as predicate.
					
						Constraint Component IRI: sh:EqualsConstraintComponent
					
| Property | Summary and Syntax Rules | 
|---|---|
| sh:equals | The property to compare with.
								The values of sh:equalsin a shape are IRIs. | 
$equals be a value of sh:equals.
							For each value node 
							that does not exist as a value of the property $equals at the focus node,
							there is a validation result with the value node as sh:value.
							For each value of the property $equals at the focus node
							that is not one of the value nodes,
							there is a validation result with the value as sh:value.
						The remainder of this section is informative.
						The following example illustrates the use of sh:equals in a shape to specify
						that certain focus nodes need to have the same set of values for ex:firstName and ex:givenName.
					
{
	"@id": "ex:EqualExampleShape",
	"@type": "sh:NodeShape",
	"sh:property": {
		"sh:equals": {
			"@id": "ex:givenName"
		},
		"sh:path": {
			"@id": "ex:firstName"
		}
	},
	"sh:targetNode": {
		"@id": "ex:Bob"
	}
}shape ex:EqualExampleShape {
	targetNode=ex:Bob .
	ex:firstName equals=ex:givenName .
}{
	"@id": "ex:Bob",
	"ex:firstName": "Bob",
	"ex:givenName": "Bob"
}
						sh:disjoint specifies the condition that the set of value nodes
						is disjoint with the set of objects of the triples
						that have the focus node as subject
						and the value of sh:disjoint as predicate.
					
						Constraint Component IRI: sh:DisjointConstraintComponent
					
| Property | Summary and Syntax Rules | 
|---|---|
| sh:disjoint | The property to compare the values with.
								The values of sh:disjointin a shape are IRIs. | 
$disjoint be a parameter value of sh:disjoint.
							For each value node
							that also exists as a value of the property $disjoint at the focus node,
							there is a validation result with the value node as sh:value. 
						The remainder of this section is informative.
						The following example illustrates the use of sh:disjoint in a shape to specify
						that certain focus nodes cannot share any values for ex:prefLabel and ex:altLabel.
					
{
	"@id": "ex:DisjointExampleShape",
	"@type": "sh:NodeShape",
	"sh:property": {
		"sh:disjoint": {
			"@id": "ex:altLabel"
		},
		"sh:path": {
			"@id": "ex:prefLabel"
		}
	},
	"sh:targetNode": [
		{
			"@id": "ex:USA"
		},
		{
			"@id": "ex:Germany"
		}
	]
}shape ex:DisjointExampleShape {
	targetNode=ex:USA targetNode=ex:Germany .
	ex:prefLabel disjoint=ex:altLabel .
}{
	"@graph": [
		{
			"@id": "ex:Germany",
			"ex:altLabel": "Germany",
			"ex:prefLabel": "Germany"
		},
		{
			"@id": "ex:USA",
			"ex:altLabel": "United States",
			"ex:prefLabel": "USA"
		}
	]
}
						sh:lessThan specifies the condition that each value node is smaller than all the objects of the triples that have the focus node as subject and the value of sh:lessThan as predicate.
					
						Constraint Component IRI: sh:LessThanConstraintComponent
					
| Property | Summary and Syntax Rules | 
|---|---|
| sh:lessThan | The property to compare the values with.
								The values of sh:lessThanin a shape are IRIs.
								Node shapes cannot have any value forsh:lessThan. | 
$lessThan be a value of sh:lessThan.
							For each pair of value nodes and the values of the property $lessThan at the given focus node
							where the first value is not less than the second value (based on SPARQL's < operator)
							or where the two values cannot be compared,
							there is a validation result with the value node as sh:value. 
						The remainder of this section is informative.
						The following example illustrates the use of sh:lessThan in a shape to specify
						that all values of ex:startDate are "before" the values of ex:endDate.
					
{
	"@id": "ex:LessThanExampleShape",
	"@type": "sh:NodeShape",
	"sh:property": {
		"sh:lessThan": {
			"@id": "ex:endDate"
		},
		"sh:path": {
			"@id": "ex:startDate"
		}
	}
}shape ex:LessThanExampleShape {
	ex:startDate lessThan=ex:endDate .
}
						sh:lessThanOrEquals specifies the condition that each value node is smaller than or equal to all the objects of the triples that have the focus node as subject and the value of sh:lessThanOrEquals as predicate.
					
						Constraint Component IRI: sh:LessThanOrEqualsConstraintComponent
					
| Property | Summary and Syntax Rules | 
|---|---|
| sh:lessThanOrEquals | The property to compare the values with.
								The values of sh:lessThanOrEqualsin a shape are IRIs.
								Node shapes cannot have any value forsh:lessThanOrEquals. | 
$lessThanOrEquals be a value of sh:lessThanOrEquals.
							For each pair of value nodes and the values of the property $lessThanOrEquals at the given focus node
							where the first value is not less than or equal to the second value (based on SPARQL's <= operator)
							or where the two values cannot be compared,
							there is a validation result with the value node as sh:value. 
						The constraint components in this section implement the common logical operators and, or and not, as well as a variation of exclusive or.
						sh:not specifies the condition that each value node cannot conform to a given shape.
						This is comparable to negation and the logical "not" operator.
					
						Constraint Component IRI: sh:NotConstraintComponent
					
| Property | Summary and Syntax Rules | 
|---|---|
| sh:not | The shape to negate.
								The values of sh:notin a shape must be well-formed shapes. | 
$not be a value of sh:not.
							For each value node v:
							A failure MUST be reported if the conformance checking of v against
							the shape $not produces a failure.
							Otherwise, if v conforms to the shape $not,
							there is validation result with v as sh:value.
						The remainder of this section is informative.
						The following example illustrates the use of sh:not in a shape to specify the condition
						that certain focus nodes cannot have any value of ex:property.
					
{
	"@id": "ex:NotExampleShape",
	"@type": "sh:NodeShape",
	"sh:not": {
		"@type": "sh:PropertyShape",
		"sh:minCount": {
			"@type": "xsd:integer",
			"@value": "1"
		},
		"sh:path": {
			"@id": "ex:property"
		}
	},
	"sh:targetNode": {
		"@id": "ex:InvalidInstance1"
	}
}{
	"@id": "ex:InvalidInstance1",
	"ex:property": "Some value"
}
						sh:and specifies the condition that each value node conforms to all provided shapes.
						This is comparable to conjunction and the logical "and" operator.
					
						Constraint Component IRI: sh:AndConstraintComponent
					
| Property | Summary and Syntax Rules | 
|---|---|
| sh:and | A SHACL list of shapes to validate the value nodes against.
								Each value of sh:andin a shape is a SHACL list.
								Each member of such list must be a well-formed shape. | 
$and be a value of sh:and.
							For each value node v:
							A failure MUST be produced if the conformance checking of v against any of the members of $and produces a failure.
							Otherwise, if v does not conform to each member of $and,
							there is a validation result with v as sh:value.
						The remainder of this section is informative.
						Note that although sh:and has a SHACL list of shapes as its value,
						the order of those shapes does not impact the validation results.
						For implementations that use shortcut evaluation semantics, the order may impact the efficiency of validation.
						It is recommended to put earlier in the list constraints that are easier to evaluate, or are more likely to fail.
					
						The following example illustrates the use of sh:and in a shape to specify the condition
						that certain focus nodes have exactly one value of ex:property.
						This is achieved via the conjunction of a separate named shape (ex:SuperShape) which specifies
						the minimum count, and a property shape that additionally specifies the maximum count.
						As shown here, sh:and can be used to implement a specialization mechanism between shapes.
					
{
	"@graph": [
		{
			"@id": "ex:ExampleAndShape",
			"@type": "sh:NodeShape",
			"sh:and": {
				"@list": [
					{
						"@id": "ex:SuperShape"
					},
					{
						"sh:maxCount": {
							"@type": "xsd:integer",
							"@value": "1"
						},
						"sh:path": {
							"@id": "ex:property"
						}
					}
				]
			},
			"sh:targetNode": [
				{
					"@id": "ex:ValidInstance"
				},
				{
					"@id": "ex:InvalidInstance"
				}
			]
		},
		{
			"@id": "ex:SuperShape",
			"@type": "sh:NodeShape",
			"sh:property": {
				"sh:minCount": {
					"@type": "xsd:integer",
					"@value": "1"
				},
				"sh:path": {
					"@id": "ex:property"
				}
			}
		}
	]
}{
	"@graph": [
		{
			"@id": "ex:InvalidInstance",
			"ex:property": [
				"One",
				"Two"
			]
		},
		{
			"@id": "ex:ValidInstance",
			"ex:property": "One"
		}
	]
}
						sh:or specifies the condition that each value node conforms to at least one of the provided shapes.
						This is comparable to disjunction and the logical "or" operator.
					
						Constraint Component IRI: sh:OrConstraintComponent
					
| Property | Summary and Syntax Rules | 
|---|---|
| sh:or | A SHACL list of shapes to validate the value nodes against.
								Each value of sh:orin a shape is a SHACL list.
								Each member of such list must be a well-formed shape. | 
$or be a value of sh:or.
							For each value node v:
							A failure MUST be produced if the conformance checking of v against any of the members produces a failure.
							Otherwise, if v conforms to none of the members of $or
							there is a validation result with v as sh:value.
						The remainder of this section is informative.
						Note that although sh:or has a SHACL list of shapes as its value,
						the order of those shapes does not impact the validation results.
						For implementations that use shortcut evaluation semantics, the order may impact the efficiency of validation.
						It is recommended to put earlier in the list constraints that are easier to evaluate, or are more likely to succeed.
					
						The following example illustrates the use of sh:or in a shape to specify the condition
						that certain focus nodes have at least one value of ex:firstName
						or at least one value of ex:givenName.
					
{
	"@id": "ex:OrConstraintExampleShape",
	"@type": "sh:NodeShape",
	"sh:or": {
		"@list": [
			{
				"sh:minCount": {
					"@type": "xsd:integer",
					"@value": "1"
				},
				"sh:path": {
					"@id": "ex:firstName"
				}
			},
			{
				"sh:minCount": {
					"@type": "xsd:integer",
					"@value": "1"
				},
				"sh:path": {
					"@id": "ex:givenName"
				}
			}
		]
	},
	"sh:targetNode": {
		"@id": "ex:Bob"
	}
}{
	"@id": "ex:Bob",
	"ex:firstName": "Robert"
}
						The next example shows how sh:or can be used in a property shape to state that the values of
						the given property ex:address may be either literals with datatype xsd:string
						or SHACL instances of the class ex:Address.
					
{
	"@id": "ex:PersonAddressShape",
	"@type": "sh:NodeShape",
	"sh:property": {
		"sh:or": {
			"@list": [
				{
					"sh:datatype": {
						"@id": "xsd:string"
					}
				},
				{
					"sh:class": {
						"@id": "ex:Address"
					}
				}
			]
		},
		"sh:path": {
			"@id": "ex:address"
		}
	},
	"sh:targetClass": {
		"@id": "ex:Person"
	}
}shape ex:PersonAddressShape -> ex:Person {
	ex:address xsd:string|ex:Address .
}{
	"@id": "ex:Bob",
	"ex:address": "123 Prinzengasse, Vaduz, Liechtenstein"
}Note that all constraints in SHACL get ANDed for execution. Consider the following example:
{
	"@id": "ex:shapeRoot",
	"@type": "sh:NodeShape",
	"sh:or": [
		{
			"@list": [
				{
					"@id": "ex:shapeA"
				},
				{
					"@id": "ex:shapeB"
				}
			]
		},
		{
			"@list": [
				{
					"@id": "ex:shapeC"
				},
				{
					"@id": "ex:shapeD"
				}
			]
		}
	]
}
						The correct interpretation is (shapeA OR shapeB) AND (shapeC OR shapeD).
						The target nodes need to conform to shapeA or shapeB, and then also shapeC or shapeD.
					
						sh:xone specifies the condition that each value node conforms to exactly one of the provided shapes.
					
						Constraint Component IRI: sh:XoneConstraintComponent
					
| Property | Summary and Syntax Rules | 
|---|---|
| sh:xone | A SHACL list of shapes to validate the value nodes against.
								Each value of sh:xonein a shape is a SHACL list.
								Each member of such list must be a well-formed shape. | 
$xone be a value of sh:xone.
							For each value node v
							let N be the number of the shapes that are members of $xone 
							where v conforms to the shape.
							A failure MUST be produced if the conformance checking of v against any of the members produces a failure.
							Otherwise, if N is not exactly 1,
							there is a validation result with v as sh:value.
						The remainder of this section is informative.
						Note that although sh:xone has a SHACL list of shapes as its value,
						the order of those shapes does not impact the validation results.
					
						The following example illustrates the use of sh:xone in a shape to specify the condition
						that certain focus nodes must either have a value for ex:fullName or values for
						ex:firstName and ex:lastName, but not both.
					
{
	"@id": "ex:XoneConstraintExampleShape",
	"@type": "sh:NodeShape",
	"sh:targetClass": {
		"@id": "ex:Person"
	},
	"sh:xone": {
		"@list": [
			{
				"sh:property": {
					"sh:minCount": {
						"@type": "xsd:integer",
						"@value": "1"
					},
					"sh:path": {
						"@id": "ex:fullName"
					}
				}
			},
			{
				"sh:property": [
					{
						"sh:minCount": {
							"@type": "xsd:integer",
							"@value": "1"
						},
						"sh:path": {
							"@id": "ex:firstName"
						}
					},
					{
						"sh:minCount": {
							"@type": "xsd:integer",
							"@value": "1"
						},
						"sh:path": {
							"@id": "ex:lastName"
						}
					}
				]
			}
		]
	}
}{
	"@graph": [
		{
			"@id": "ex:Bob",
			"@type": "ex:Person",
			"ex:firstName": "Robert",
			"ex:lastName": "Coin"
		},
		{
			"@id": "ex:Carla",
			"@type": "ex:Person",
			"ex:fullName": "Carla Miller"
		},
		{
			"@id": "ex:Dory",
			"@type": "ex:Person",
			"ex:firstName": "Dory",
			"ex:fullName": "Dory Dunce",
			"ex:lastName": "Dunce"
		}
	]
}The constraint components in this section can be used to specify complex conditions by validating the value nodes against certain shapes.
						sh:node specifies the condition that each value node conforms to the given node shape.
					
						Constraint Component IRI: sh:NodeConstraintComponent
					
| Property | Summary and Syntax Rules | 
|---|---|
| sh:node | The node shape that all value nodes need to conform to.
								The values of sh:nodein a shape must be well-formed node shapes. | 
$node be a value of sh:node.
							For each value node v:
							A failure MUST be produced if the conformance checking of v against $node produces a failure.
							Otherwise, if v does not conform to $node,
							there is a validation result with v as sh:value.
						The remainder of this section is informative.
						In the following example, all values of the property ex:address must fulfill the
						constraints expressed by the shape ex:AddressShape.
					
{
	"@graph": [
		{
			"@id": "ex:AddressShape",
			"@type": "sh:NodeShape",
			"sh:property": {
				"sh:datatype": {
					"@id": "xsd:string"
				},
				"sh:maxCount": {
					"@type": "xsd:integer",
					"@value": "1"
				},
				"sh:path": {
					"@id": "ex:postalCode"
				}
			}
		},
		{
			"@id": "ex:PersonShape",
			"@type": "sh:NodeShape",
			"sh:property": {
				"sh:minCount": {
					"@type": "xsd:integer",
					"@value": "1"
				},
				"sh:node": {
					"@id": "ex:AddressShape"
				},
				"sh:path": {
					"@id": "ex:address"
				}
			},
			"sh:targetClass": {
				"@id": "ex:Person"
			}
		}
	]
}shape ex:AddressShape {
	ex:postalCode xsd:string [0..1] .
}
shape ex:PersonShape -> ex:Person {
	ex:address [1..*] @ex:AddressShape .
}{
	"@graph": [
		{
			"@id": "ex:Bob",
			"@type": "ex:Person",
			"ex:address": {
				"@id": "ex:BobsAddress"
			}
		},
		{
			"@id": "ex:BobsAddress",
			"ex:postalCode": "1234"
		},
		{
			"@id": "ex:Reto",
			"@type": "ex:Person",
			"ex:address": {
				"@id": "ex:RetosAddress"
			}
		},
		{
			"@id": "ex:RetosAddress",
			"ex:postalCode": {
				"@type": "xsd:integer",
				"@value": "5678"
			}
		}
	]
}{
	"@type": "sh:ValidationReport",
	"sh:conforms": {
		"@type": "xsd:boolean",
		"@value": "false"
	},
	"sh:result": {
		"@type": "sh:ValidationResult",
		"sh:focusNode": {
			"@id": "ex:Reto"
		},
		"sh:resultMessage": "Value does not conform to shape ex:AddressShape.",
		"sh:resultPath": {
			"@id": "ex:address"
		},
		"sh:resultSeverity": {
			"@id": "sh:Violation"
		},
		"sh:sourceConstraintComponent": {
			"@id": "sh:NodeConstraintComponent"
		},
		"sh:sourceShape": {
			"@id": "_:b1"
		},
		"sh:value": {
			"@id": "ex:RetosAddress"
		}
	}
}
						sh:property can be used to specify that each value node has a given property shape.
					
						Constraint Component IRI: sh:PropertyConstraintComponent
					
| Property | Summary and Syntax Rules | 
|---|---|
| sh:property | A property shape that all value nodes need to have.
								Each value of sh:propertyin a shape must be a well-formed property shape. | 
$property be a value of sh:property.
							For each value node v:
							A failure MUST be produced if the validation of v as focus node against the property shape $property produces a failure.
							Otherwise, the validation results are the results of validating v as focus node against the property shape $property.
						The remainder of this section is informative.
						Note that there is an important difference between sh:property and sh:node:
						If a value node is violating the constraint, then there is only a single validation result for sh:node for this value node,
						with sh:NodeConstraintComponent as its sh:sourceConstraintComponent.
						On the other hand side, there may be any number of validation results for sh:property, and these
						will have the individual constraint components of the constraints in the property shape as their values of sh:sourceConstraintComponent.
					
						Like with all other validation results, each time a property shape is reached via sh:property,
						a validation engine MUST produce fresh validation result nodes.
						This includes cases where the same focus node is validated against the same property shape
						although it is reached via different paths in the shapes graph.
					
						sh:qualifiedValueShape specifies the condition that a specified number of value nodes conforms to the given shape.
						Each sh:qualifiedValueShape can have: one value for sh:qualifiedMinCount, one value for sh:qualifiedMaxCount or, one value for each, at the same subject.
					
| Property | Summary and Syntax Rules | 
|---|---|
| sh:qualifiedValueShape | The shape that the specified number of value nodes needs to conform to.
								The values of sh:qualifiedValueShapein a shape must be well-formed shapes.
								Node shapes cannot have any value forsh:qualifiedValueShape.
								This is a mandatory parameter ofsh:QualifiedMinCountConstraintComponentandsh:QualifiedMaxCountConstraintComponent. | 
| sh:qualifiedValueShapesDisjoint | This is an optional parameter of sh:QualifiedMinCountConstraintComponentandsh:QualifiedMaxCountConstraintComponent.
								If set totruethen (for the counting) the value nodes must not conform to any of the sibling shapes.
								The values ofsh:qualifiedValueShapesDisjointin a shape are literals with datatypexsd:boolean. | 
| sh:qualifiedMinCount | The minimum number of value nodes that conform to the shape.
								The values of sh:qualifiedMinCountin a shape are literals with datatypexsd:integer.
								This is a mandatory parameter ofsh:QualifiedMinCountConstraintComponent. | 
| sh:qualifiedMaxCount | The maximum number of value nodes that can conform to the shape.
								The values of sh:qualifiedMaxCountin a shape are literals with datatypexsd:integer.
								This is a mandatory parameter ofsh:QualifiedMaxCountConstraintComponent. | 
Q be a shape in shapes graph G that declares a qualified cardinality constraint
							(by having values for sh:qualifiedValueShape and at least one of sh:qualifiedMinCount or sh:qualifiedMaxCount).
							Let ps be the set of shapes in G that have Q as a value of sh:property.
							If Q has true as a value for sh:qualifiedValueShapesDisjoint then
							the set of sibling shapes for Q is defined as the set of all values of the
							SPARQL property path sh:property/sh:qualifiedValueShape for any shape in ps
							minus the value of sh:qualifiedValueShape of Q itself.
							The set of sibling shapes is empty otherwise.
						$qualifiedValueShape be a value of sh:qualifiedValueShape.
							Let $qualifiedMinCount be a parameter value for sh:qualifiedMinCount.
							Let C be the number of value nodes v where
							v conforms to $qualifiedValueShape
							and where v does not conform to any of the sibling shapes for the current shape,
							i.e. the shape that v is validated against and which has $qualifiedValueShape as its value for sh:qualifiedValueShape.
							A failure MUST be produced if any of the said conformance checks produces a failure.
							Otherwise, there is a validation result if C is less than $qualifiedMinCount.
							The constraint component for sh:qualifiedMinCount is sh:QualifiedMinCountConstraintComponent.
						$qualifiedMaxCount be a parameter value for sh:qualifiedMaxCount.
							Let C be as defined for sh:qualifiedMinCount above.
							A failure MUST be produced if any of the said conformance checks produces a failure.
							Otherwise, there is a validation result if C is greater than $qualifiedMaxCount.
							The constraint component for sh:qualifiedMaxCount is sh:QualifiedMaxCountConstraintComponent.
						The remainder of this section is informative.
						In the following example shape can be used to specify the condition that the property ex:parent has exactly two values,
						and at least one of them is female.
					
{
	"@id": "ex:QualifiedValueShapeExampleShape",
	"@type": "sh:NodeShape",
	"sh:property": {
		"sh:maxCount": {
			"@type": "xsd:integer",
			"@value": "2"
		},
		"sh:minCount": {
			"@type": "xsd:integer",
			"@value": "2"
		},
		"sh:path": {
			"@id": "ex:parent"
		},
		"sh:qualifiedMinCount": {
			"@type": "xsd:integer",
			"@value": "1"
		},
		"sh:qualifiedValueShape": {
			"sh:hasValue": {
				"@id": "ex:female"
			},
			"sh:path": {
				"@id": "ex:gender"
			}
		}
	},
	"sh:targetNode": {
		"@id": "ex:QualifiedValueShapeExampleValidResource"
	}
}{
	"@graph": [
		{
			"@id": "ex:Jane",
			"ex:gender": {
				"@id": "ex:female"
			}
		},
		{
			"@id": "ex:John",
			"ex:gender": {
				"@id": "ex:male"
			}
		},
		{
			"@id": "ex:QualifiedValueShapeExampleValidResource",
			"ex:parent": [
				{
					"@id": "ex:John"
				},
				{
					"@id": "ex:Jane"
				}
			]
		}
	]
}
						The following example illustrates the use of sh:qualifiedValueShapesDisjoint
						to express that a hand must have at most 5 values of ex:digit (expressed using sh:maxCount),
						and exactly one of them must be an instance of ex:Thumb while exactly 4 of them must be an instance of ex:Finger
						but thumbs and fingers must be disjoint.
						In other words, on a hand, none of the fingers can also be counted as the thumb. 
					
{
	"@id": "ex:HandShape",
	"@type": "sh:NodeShape",
	"sh:property": [
		{
			"sh:maxCount": {
				"@type": "xsd:integer",
				"@value": "5"
			},
			"sh:path": {
				"@id": "ex:digit"
			}
		},
		{
			"sh:path": {
				"@id": "ex:digit"
			},
			"sh:qualifiedMaxCount": {
				"@type": "xsd:integer",
				"@value": "1"
			},
			"sh:qualifiedMinCount": {
				"@type": "xsd:integer",
				"@value": "1"
			},
			"sh:qualifiedValueShape": {
				"sh:class": {
					"@id": "ex:Thumb"
				}
			},
			"sh:qualifiedValueShapesDisjoint": {
				"@type": "xsd:boolean",
				"@value": "true"
			}
		},
		{
			"sh:path": {
				"@id": "ex:digit"
			},
			"sh:qualifiedMaxCount": {
				"@type": "xsd:integer",
				"@value": "4"
			},
			"sh:qualifiedMinCount": {
				"@type": "xsd:integer",
				"@value": "4"
			},
			"sh:qualifiedValueShape": {
				"sh:class": {
					"@id": "ex:Finger"
				}
			},
			"sh:qualifiedValueShapesDisjoint": {
				"@type": "xsd:boolean",
				"@value": "true"
			}
		}
	],
	"sh:targetClass": {
		"@id": "ex:Hand"
	}
}
						sh:reifierShape can be used to link a property shape with one or more node shapes.
						Any reifier must conform to these node shapes.
					
						Constraint Component IRI: sh:ReifierShapeConstraintComponent
					
| Property | Summary and Syntax Rules | 
|---|---|
| sh:reifierShape | The node shape that a reifier for this triple must conform to.
								
									The values of sh:reifierShapemust be well-formed node shapes.
									If a value forsh:reifierShapeis given,sh:pathvalues are constrained to IRIs. | 
| sh:reificationRequired | This is an optional parameter of sh:ReifierShapeConstraintComponent.
								If set totrue, there must be at least one reification value for the focus node/path combination in the data graph.
								The values ofsh:reificationRequiredin a shape are literals with datatypexsd:boolean. | 
t be the triple term (focus node,  $path, value node).
							For each reifier for the triple term t, a failure MUST be produced if validating the reifier against the node shape $reifierShape with the reifier as focus node produces a failure.
							For each reifier t that does not conform to $reifierShape, there is a validation result with t as sh:value.
						$reificationRequired is set to true and there is no reified statement for the triple term t in the data graph, there is a validation result with t as sh:value.
						{
	"@graph": [
		{
			"@id": "ex:PersonShape",
			"@type": "sh:NodeShape",
			"sh:property": {
				"@id": "ex:PersonShape-age"
			},
			"sh:targetClass": {
				"@id": "ex:Person"
			}
		},
		{
			"@id": "ex:PersonShape-age",
			"@type": "sh:PropertyShape",
			"sh:datatype": {
				"@id": "xsd:integer"
			},
			"sh:maxCount": {
				"@type": "xsd:integer",
				"@value": "1"
			},
			"sh:path": {
				"@id": "ex:age"
			},
			"sh:reificationRequired": {
				"@type": "xsd:boolean",
				"@value": "true"
			},
			"sh:reifierShape": {
				"@id": "ex:ProvenanceShape"
			}
		},
		{
			"@id": "ex:ProvenanceShape",
			"@type": "sh:NodeShape",
			"sh:property": [
				{
					"sh:datatype": {
						"@id": "xsd:date"
					},
					"sh:maxCount": {
						"@type": "xsd:integer",
						"@value": "1"
					},
					"sh:path": {
						"@id": "ex:date"
					}
				},
				{
					"sh:maxCount": {
						"@type": "xsd:integer",
						"@value": "1"
					},
					"sh:nodeKind": {
						"@id": "sh:IRI"
					},
					"sh:path": {
						"@id": "ex:author"
					}
				}
			]
		}
	]
}{
	"@id": "Bob",
	"ex:age": {
		"@type": "xsd:integer",
		"@value": "23",
		"@annotation": {
			"ex:author": {
				"@id": "ex:Claire"
			},
			"ex:date": {
				"@type": "xsd:date",
				"@value": "2019-12-05"
			}
		}
	}
}
						sh:nodeByExpression specifies the condition that each value node conforms to the
						node shapes produced by a node expression.
						The evaluation of these node expressions is repeated for all value nodes of the shape
						as the focus node.
					
						Constraint Component IRI: sh:NodeByExpressionConstraintComponent
					
| Property | Summary and Syntax Rules | 
|---|---|
| sh:nodeByExpression | The node shapes that all value nodes need to conform to.
								The values of sh:nodeByExpressionin a shape must be well-formed node expressions. | 
$expr be a value of sh:nodeByExpression.
For each value node v: perform a conformance check of
v against each output node of evalExpr(expr,
data graph, v, {}) s. A failure
MUST be produced if the conformance check of v against
s produces a failure. Otherwise, if v does
not conform to s, there is a validation result
with v as sh:value and a deep copy of
s as sh:sourceConstraint.
						The remainder of this section is informative.
						sh:nodeByExpression functions similarly to sh:node, but instead of referencing a fixed node shape,
						a referenced node expression is used to dynamically compute the set of node shapes to which each value node must conform.
					
						There are three key differences between sh:nodeByExpression and sh:node:
						
sh:nodeByExpression references a node expression instead of a fixed node shape as sh:node does.
							sh:nodeByExpression cannot reference a node shape that is a blank node as a value like sh:node can,
								as a blank node would be interpreted as a node expression.
							sh:nodeByExpression additionally include a value for sh:sourceConstraint.
							
						Note that sh:node and sh:nodeByExpression exhibit the same behavior when given a value that is an IRI of a node shape.
						In this case, sh:node directly validates against the specified node shape, whereas sh:nodeByExpression interprets the IRI
						as an IRI expression that evaluates to a set containing the same node shape.
					
						In the following example, all values of the property ex:address must fulfill the
						constraints expressed by the shape ex:AddressShape.
					
{
	"@graph": [
		{
			"@id": "ex:AddressShape",
			"@type": "sh:NodeShape",
			"sh:property": {
				"sh:datatype": {
					"@id": "xsd:string"
				},
				"sh:maxCount": {
					"@type": "xsd:integer",
					"@value": "1"
				},
				"sh:path": {
					"@id": "ex:postalCode"
				}
			}
		},
		{
			"@id": "ex:PersonShape",
			"@type": "sh:NodeShape",
			"sh:property": {
				"sh:minCount": {
					"@type": "xsd:integer",
					"@value": "1"
				},
				"sh:nodeByExpression": {
					"@id": "ex:AddressShape"
				},
				"sh:path": {
					"@id": "ex:address"
				}
			},
			"sh:targetClass": {
				"@id": "ex:Person"
			}
		}
	]
}{
	"@graph": [
		{
			"@id": "ex:Bob",
			"@type": "ex:Person",
			"ex:address": {
				"@id": "ex:BobsAddress"
			}
		},
		{
			"@id": "ex:BobsAddress",
			"ex:postalCode": "1234"
		},
		{
			"@id": "ex:Reto",
			"@type": "ex:Person",
			"ex:address": {
				"@id": "ex:RetosAddress"
			}
		},
		{
			"@id": "ex:RetosAddress",
			"ex:postalCode": {
				"@type": "xsd:integer",
				"@value": "5678"
			}
		}
	]
}{
	"@type": "sh:ValidationReport",
	"sh:conforms": {
		"@type": "xsd:boolean",
		"@value": "false"
	},
	"sh:result": {
		"@type": "sh:ValidationResult",
		"sh:focusNode": {
			"@id": "ex:Reto"
		},
		"sh:resultMessage": "Value does not conform to shape ex:AddressShape.",
		"sh:resultPath": {
			"@id": "ex:address"
		},
		"sh:resultSeverity": {
			"@id": "sh:Violation"
		},
		"sh:sourceConstraint": {
			"@id": "ex:AddressShape"
		},
		"sh:sourceConstraintComponent": {
			"@id": "sh:NodeByExpressionConstraintComponent"
		},
		"sh:sourceShape": {
			"@id": "_:b66_b1"
		},
		"sh:value": {
			"@id": "ex:RetosAddress"
		}
	}
}This section enumerates Core constraint components that do not fit into the other categories.
						The RDF data model offers a huge amount of flexibility.
						Any node can in principle have values for any property.
						However, in some cases it makes sense to specify conditions on which properties can be applied to nodes.
						The SHACL Core language includes a property called sh:closed that can be used to
						specify the condition that each value node has values only for those properties that have been explicitly enumerated via the
						property shapes specified for the shape via sh:property.
					
						Constraint Component IRI: sh:ClosedConstraintComponent
					
| Property | Summary and Syntax Rules | 
|---|---|
| sh:closed | Set to trueto close the shape.
								The values ofsh:closedin a shape are literals with datatypexsd:booleanor the IRIsh:ByTypes. | 
| sh:ignoredProperties | Optional SHACL list of properties that are also permitted in addition to those explicitly enumerated via sh:property.
								The values ofsh:ignoredPropertiesin a shape must be SHACL lists.
								Each member of such a list must be a IRI. | 
$closed be a parameter value for sh:closed.
							Let $ignoredProperties be a value for sh:ignoredProperties.
							$closed is true or sh:ByTypes and P
							is the set of properties defined below,
							then there is a validation result for each triple that has a value node as its
							subject and a predicate that is not in P.
							If $ignoredProperties has a value then the properties enumerated as members of this SHACL list
							are also permitted for the value node.
							The validation result MUST have the predicate of the triple as its sh:resultPath,
							and the object of the triple as its sh:value.
							$closed is true, then P is the set of IRI properties
							that can be reached from the current shape via the SPARQL path sh:property/sh:path.
							$closed is sh:ByTypes, then P is the set of IRI properties
							that can be reached from the value node via the following algorithm, plus rdf:type:
							function collectProperties(S)
    add all IRI properties that can be reached from S via the SPARQL path
            sh:property/sh:path
    if S is a SHACL instance of rdfs:Class in the shapes graph {
        for each triple in the shapes graph matching (S rdfs:subClassOf ?o)
            collectProperties(?o)
        for each triple in the shapes graph matching (?s sh:targetClass S)
            collectProperties(?s)
    }
    if S is a SHACL instance of sh:NodeShape in the shapes graph
        for each triple in the shapes graph matching (S sh:node ?o)
            collectProperties(?o)
for each rdf:type T of the value node in the data graph
    collectProperties(T)S twice.
						The remainder of this section is informative.
						The following example illustrates the use of sh:closed in a shape to specify the condition
						that certain focus nodes only have values for ex:firstName and ex:lastName.
						The "ignored" property rdf:type would also be allowed.
					
{
	"@id": "ex:ClosedShapeExampleShape",
	"@type": "sh:NodeShape",
	"sh:closed": {
		"@type": "xsd:boolean",
		"@value": "true"
	},
	"sh:ignoredProperties": {
		"@list": [
			{
				"@id": "rdf:type"
			}
		]
	},
	"sh:property": [
		{
			"sh:path": {
				"@id": "ex:firstName"
			}
		},
		{
			"sh:path": {
				"@id": "ex:lastName"
			}
		}
	],
	"sh:targetNode": [
		{
			"@id": "ex:Alice"
		},
		{
			"@id": "ex:Bob"
		}
	]
}shape ex:ClosedShapeExampleShape {
	targetNode=ex:Alice targetNode=ex:Bob closed=true ignoredProperties=[rdf:type] .
	ex:firstName .
	ex:lastName .
}{
	"@graph": [
		{
			"@id": "ex:Alice",
			"ex:firstName": "Alice"
		},
		{
			"@id": "ex:Bob",
			"ex:firstName": "Bob",
			"ex:middleInitial": "J"
		}
	]
}
						The use case for sh:closed sh:ByTypes includes properties that are declared
						in superclasses of the types of the current value node (via rdfs:subClassOf),
						as well as other shapes that are linked to those types via sh:targetClass and
						the shapes that can be reached from one node shape to the other via sh:node.
						Examples for sh:ByTypes can be found in the test case library:
						closed-003.ttl,
						closed-004.ttl.
					
						sh:hasValue specifies the condition that at least one value node is equal to the given RDF term.
					
						Constraint Component IRI: sh:HasValueConstraintComponent
					
| Property | Summary and Syntax Rules | 
|---|---|
| sh:hasValue | A specific required value. | 
$hasValue be a parameter value for sh:hasValue.
							If the RDF term $hasValue is not among the value nodes,
							there is a validation result. 
						The remainder of this section is informative.
{
	"@id": "ex:StanfordGraduate",
	"@type": "sh:NodeShape",
	"sh:property": {
		"sh:hasValue": {
			"@id": "ex:Stanford"
		},
		"sh:path": {
			"@id": "ex:alumniOf"
		}
	},
	"sh:targetNode": {
		"@id": "ex:Alice"
	}
}shape ex:StanfordGraduate {
	targetNode=ex:Alice .
	ex:alumniOf hasValue=ex:Stanford .
}{
	"@id": "ex:Alice",
	"ex:alumniOf": [
		{
			"@id": "ex:Harvard"
		},
		{
			"@id": "ex:Stanford"
		}
	]
}
						sh:in specifies the condition that each value node is a member of a provided SHACL list.
					
						Constraint Component IRI: sh:InConstraintComponent
					
| Property | Summary and Syntax Rules | 
|---|---|
| sh:in | A SHACL list that has the allowed values as members.
								Each value of sh:inin a shape is a SHACL list.
								A shape has at most one value forsh:in. | 
$in be a value of sh:in.
							For each value node
							that is not a member of $in,
							there is a validation result with the value node as sh:value.
						The remainder of this section is informative.
						Note that matching of literals needs to be exact, e.g. "04"^^xsd:byte does not match "4"^^xsd:integer.
					
{
	"@id": "ex:InExampleShape",
	"@type": "sh:NodeShape",
	"sh:property": {
		"sh:in": {
			"@list": [
				{
					"@id": "ex:Pink"
				},
				{
					"@id": "ex:Purple"
				}
			]
		},
		"sh:path": {
			"@id": "ex:color"
		}
	},
	"sh:targetNode": {
		"@id": "ex:RainbowPony"
	}
}shape ex:InExampleShape {
	targetNode=ex:RainbowPony .
	ex:color in=[ex:Pink ex:Purple] .
}{
	"@id": "ex:RainbowPony",
	"ex:color": {
		"@id": "ex:Pink"
	}
}
						Based on node expressions, this section introduces a constraint component called
						expression constraints.
						Expression constraints can be used in any shape to declare the condition that the
						node expression specified via sh:expression has true as its only output node.
						The evaluation of these node expressions is repeated for all value nodes of the shape
						as the focus node.
					
						Constraint Component IRI: sh:ExpressionConstraintComponent
					
| Property | Summary and Syntax Rules | 
|---|---|
| sh:expression | The node expression that must return true.
								The values ofsh:expressionat a
								shape must be well-formed node expressions. | 
$expr be a value of sh:expression.
							For each value node v 
							where evalExpr(expr, data graph, v, {})
							does not return the list consisting of exactly true as its output nodes,
							there is a validation result that has v as its sh:value
							and a deep copy of $expr in the results graph as its sh:sourceConstraint.
							If the $expr has values for sh:message in the shapes graph,
							then these values become the (only) values for sh:resultMessage in the
							validation result.
						This section is non-normative.
While the previous sections introduced properties that represent validation conditions, this section covers properties that are ignored by SHACL processors. The use of these so-called non-validating properties is entirely optional and is not subject to formal interpretation contracts. They MAY be used for purposes such as form building or predictable printing of RDF files.
					Property shapes may have one or more values for sh:name
					to provide human-readable labels for the property in the target where it appears.
					If present, tools SHOULD prefer such locally specified labels
					over globally specified labels at the rdf:Property itself.
					For example, if a form displays a node that is in the target of a given property shape
					with an sh:name, then the tool SHOULD use the provided name.
					Similarly, property shapes may have values for sh:description
					to provide descriptions of the property in the given context.
					Both sh:name and sh:description may have
					multiple values, but should only have one value per language tag.
				
					Property shapes may have one value for the property sh:order
					to indicate the relative order of the property shape for purposes such as form building.
					The values of sh:order are decimals.
					sh:order is not used for validation purposes
					and may be used with any type of subjects.
					If present at property shapes, the recommended use of sh:order is to sort the
					property shapes in an ascending order, for example so that properties with smaller order are
					placed above or to the start (left in left-to-right languages) of properties with larger order.
				
					Property shapes may link to a SHACL instance of the class sh:PropertyGroup
					using the property sh:group to indicate that
					the shape belongs to a group of related property shapes.
					Each group may have additional triples that serve application purposes,
					such as an rdfs:label for form building.
					Groups may also have an sh:order property to indicate
					the relative ordering of groups within the same form.
				
The following example illustrates the use of these various features together.
{
	"@graph": [
		{
			"@id": "ex:AddressGroup",
			"@type": "sh:PropertyGroup",
			"rdfs:label": "Address",
			"sh:order": {
				"@type": "xsd:integer",
				"@value": "1"
			}
		},
		{
			"@id": "ex:NameGroup",
			"@type": "sh:PropertyGroup",
			"rdfs:label": "Name",
			"sh:order": {
				"@type": "xsd:integer",
				"@value": "0"
			}
		},
		{
			"@id": "ex:PersonFormShape",
			"@type": "sh:NodeShape",
			"sh:property": [
				{
					"sh:description": "The person's given name(s)",
					"sh:group": {
						"@id": "ex:NameGroup"
					},
					"sh:name": "first name",
					"sh:order": {
						"@type": "xsd:integer",
						"@value": "0"
					},
					"sh:path": {
						"@id": "ex:firstName"
					}
				},
				{
					"sh:description": "The person's last name",
					"sh:group": {
						"@id": "ex:NameGroup"
					},
					"sh:name": "last name",
					"sh:order": {
						"@type": "xsd:integer",
						"@value": "1"
					},
					"sh:path": {
						"@id": "ex:lastName"
					}
				},
				{
					"sh:description": "The street address including number",
					"sh:group": {
						"@id": "ex:AddressGroup"
					},
					"sh:name": "street address",
					"sh:order": {
						"@type": "xsd:integer",
						"@value": "11"
					},
					"sh:path": {
						"@id": "ex:streetAddress"
					}
				},
				{
					"sh:description": "The city or town of the address",
					"sh:group": {
						"@id": "ex:AddressGroup"
					},
					"sh:name": "locality",
					"sh:order": {
						"@type": "xsd:integer",
						"@value": "12"
					},
					"sh:path": {
						"@id": "ex:locality"
					}
				},
				{
					"sh:description": "The postal code of the locality",
					"sh:group": {
						"@id": "ex:AddressGroup"
					},
					"sh:name": [
						"postal code",
						{
							"@language": "en-us",
							"@value": "zip code"
						}
					],
					"sh:order": {
						"@type": "xsd:integer",
						"@value": "13"
					},
					"sh:path": {
						"@id": "ex:postalCode"
					}
				}
			]
		}
	]
}A form building application MAY use the information above to display information as follows:
| first name: | John | 
| last name: | Doe | 
| street address: | 123 Silverado Ave | 
| locality: | Cupertino | 
| zip code: | 54321 | 
					Note that the same information would be generated by the following example,
					which changes the order of the triples but not the sh:order values:
				
{
	"@graph": [
		{
			"@id": "ex:AddressGroup",
			"@type": "sh:PropertyGroup",
			"rdfs:label": "Address",
			"sh:order": {
				"@type": "xsd:integer",
				"@value": "1"
			}
		},
		{
			"@id": "ex:NameGroup",
			"@type": "sh:PropertyGroup",
			"rdfs:label": "Name",
			"sh:order": {
				"@type": "xsd:integer",
				"@value": "0"
			}
		},
		{
			"@id": "ex:PersonFormShape",
			"@type": "sh:NodeShape",
			"sh:property": [
				{
					"sh:description": "The person's last name",
					"sh:group": {
						"@id": "ex:NameGroup"
					},
					"sh:name": "last name",
					"sh:order": {
						"@type": "xsd:integer",
						"@value": "1"
					},
					"sh:path": {
						"@id": "ex:lastName"
					}
				},
				{
					"sh:description": "The person's given name(s)",
					"sh:group": {
						"@id": "ex:NameGroup"
					},
					"sh:name": "first name",
					"sh:order": {
						"@type": "xsd:integer",
						"@value": "0"
					},
					"sh:path": {
						"@id": "ex:firstName"
					}
				},
				{
					"sh:description": "The postal code of the locality",
					"sh:group": {
						"@id": "ex:AddressGroup"
					},
					"sh:name": [
						"postal code",
						{
							"@language": "en-us",
							"@value": "zip code"
						}
					],
					"sh:order": {
						"@type": "xsd:integer",
						"@value": "13"
					},
					"sh:path": {
						"@id": "ex:postalCode"
					}
				},
				{
					"sh:description": "The street address including number",
					"sh:group": {
						"@id": "ex:AddressGroup"
					},
					"sh:name": "street address",
					"sh:order": {
						"@type": "xsd:integer",
						"@value": "11"
					},
					"sh:path": {
						"@id": "ex:streetAddress"
					}
				},
				{
					"sh:description": "The city or town of the address",
					"sh:group": {
						"@id": "ex:AddressGroup"
					},
					"sh:name": "locality",
					"sh:order": {
						"@type": "xsd:integer",
						"@value": "12"
					},
					"sh:path": {
						"@id": "ex:locality"
					}
				}
			]
		}
	]
}This section enumerates all normative syntax rules of SHACL. This section is automatically generated from other parts of this spec and hyperlinks are provided back into the prose if the context of the rule in unclear. Nodes that violate these rules in a shapes graph are ill-formed.
| Syntax Rule Id | Syntax Rule Text | 
|---|---|
| SHACL-list | A SHACL list in an RDF graph Gis an IRI or a blank node
						that is eitherrdf:nil(provided thatrdf:nilhas no value
						for eitherrdf:firstorrdf:rest), or has exactly one value
						for the propertyrdf:firstinGand exactly one value
						for the propertyrdf:restinGthat is also a SHACL list inG,
						and the list does not have itself as a value of the property pathrdf:rest+inG. | 
| entailment-nodeKind | The values of the property sh:entailmentare IRIs. | 
| shape | A shape is an IRI or blank node sthat fulfills at least one of the following conditions in the shapes graph:
 | 
| multiple-parameters | Some constraint components such as sh:PatternConstraintComponentdeclare more than one parameter.
						Shapes that have more than one value for any of the parameters of such components are ill-formed. | 
| targetNode-nodeKind | Each value of sh:targetNodein a shape is a well-formed node expression. | 
| targetClass-nodeKind | Each value of sh:targetClassin a shape is an IRI. | 
| implicit-targetClass-nodeKind | If sis a SHACL instance ofsh:NodeShapeorsh:PropertyShapein an RDF graphGandsis also a SHACL instance ofrdfs:ClassinGandsis not an IRI thensis an ill-formed shape inG. | 
| targetSubjectsOf-nodeKind | The values of sh:targetSubjectsOfin a shape are IRIs. | 
| targetObjectsOf-nodeKind | The values of sh:targetObjectsOfin a shape are IRIs. | 
| severity-maxCount | Shapes can specify one value for the property sh:severityin the shapes graph. | 
| severity-nodeKind | Each value of sh:severityis an IRI. | 
| severity-reifier-maxCount | Let Tbe the set of triples that represent a constraint in a shape.
						A shapes graph can specify at most one value for the propertysh:severityin the reifiers of the triples inT. | 
| message-datatype | The values of sh:messageare eitherxsd:stringliterals or literals with a language tag. | 
| message-reifier-maxCount | Let Tbe the set of triples that represent a constraint in a shape.
						A shapes graph can specify at most one value for the propertysh:messagein the reifiers of the triples inT. | 
| deactivated-maxCount | Shapes can have at most one value for the property sh:deactivated. | 
| deactivated-datatype | The value of sh:deactivatedis a node expression
						that must have eithertrueorfalseas the (only) output node. | 
| deactivated-reified-maxCount | A triple that has a shape as subject,
						a parameter (such as sh:minCount) as predicate can have at most one
						reifier with a value for the propertysh:deactivated. | 
| NodeShape-path-maxCount | SHACL instances of sh:NodeShapecannot have a value for the propertysh:path. | 
| PropertyShape | A property shape is a shape in the shapes graph
					that is the subject of a triple that has sh:pathas its predicate. | 
| path-maxCount | A shape has at most one value for sh:path. | 
| path-node | The value of sh:pathin a property shape is a well-formed
					SHACL property path. | 
| PropertyShape-path-minCount | SHACL instances of sh:PropertyShapehave one value for the propertysh:path. | 
| path-values | A property shape has at most one value for the property sh:valuesand this value is a well-formed node expression. | 
| path-defaultValue | A property shape has at most one value for the property sh:defaultValueand this value is a well-formed node expression. | 
| path-values-iri | A property shape can only have values for sh:valuesand/orsh:defaultValuewhen its value forsh:pathis a Predicate Path. | 
| path-metarule | A node in an RDF graph is a well-formed SHACL property path pif it satisfies exactly one of the syntax rules in the following sub-sections. | 
| path-non-recursive | A node pis not a well-formed SHACL property path ifpis a blank node and any path mappings ofpdirectly or transitively referencep. | 
| path-sequence | A sequence path is a blank node that is a SHACL list with at least two members and each member is a well-formed SHACL property path. | 
| path-alternative | An alternative path is a blank node that is the subject of exactly one triple in G.
					This triple hassh:alternativePathas predicate,Las object,
					andLis a SHACL list with at least two members
					and each member ofLis a well-formed SHACL property path. | 
| path-inverse | An inverse path is a blank node that is the subject of exactly one triple in G.
					This triple hassh:inversePathas predicate, and the objectvis a well-formed SHACL property path. | 
| path-zero-or-more | A zero-or-more path is a blank node that is the subject of exactly one triple in G.
					This triple hassh:zeroOrMorePathas predicate, and the objectvis a well-formed SHACL property path. | 
| path-one-or-more | A one-or-more path is a blank node that is the subject of exactly one triple in G.
					This triple hassh:oneOrMorePathas predicate, and the objectvis a well-formed SHACL property path. | 
| path-zero-or-one | A zero-or-one path is a blank node that is the subject of exactly one triple in G.
					This triple hassh:zeroOrOnePathas predicate, and the objectvis a well-formed SHACL property path. | 
| IRIExpression-syntax | A node in an RDF graph is a well-formed IRI expression if it is an IRI. | 
| LiteralExpression-syntax | A node in an RDF graph is a well-formed literal expression if it is a literal. | 
| shapesGraph-nodeKind | Every value of sh:shapesGraphis an IRI | 
| class-nodeKind | The values of sh:classin a shape are either IRIs
								or blank nodes that are well-formed SHACL lists where all members are IRIs. | 
| datatype-maxCount | A shape has at most one value for sh:datatype. | 
| datatype-nodeKind | The value of sh:datatypein a shape is either an IRI
								or a blank node that is a well-formed SHACL list where all members are IRIs. | 
| nodeKind-in | The values of sh:nodeKindin a shape are one of the following six instances of the classsh:NodeKind:sh:BlankNode,sh:IRI,sh:Literalsh:BlankNodeOrIRI,sh:BlankNodeOrLiteralandsh:IRIOrLiteral. | 
| nodeKind-maxCount | A shape has at most one value for sh:nodeKind. | 
| minCount-scope | Node shapes cannot have any value for sh:minCount. | 
| minCount-maxCount | A property shape has at most one value for sh:minCount. | 
| minCount-datatype | The values of sh:minCountin a property shape are literals with datatypexsd:integer. | 
| maxCount-scope | Node shapes cannot have any value for sh:maxCount. | 
| maxCount-maxCount | A property shape has at most one value for sh:maxCount. | 
| maxCount-datatype | The values of sh:maxCountin a property shape are literals with datatypexsd:integer. | 
| minExclusive-nodeKind | The values of sh:minExclusivein a shape are literals. | 
| minExclusive-maxCount | A shape has at most one value for sh:minExclusive. | 
| minInclusive-nodeKind | The values of sh:minInclusivein a shape are literals. | 
| minInclusive-maxCount | A shape has at most one value for sh:minInclusive. | 
| maxExclusive-nodeKind | The values of sh:maxExclusivein a shape are literals. | 
| maxExclusive-maxCount | A shape has at most one value for sh:maxExclusive. | 
| maxInclusive-nodeKind | The values of sh:maxInclusivein a shape are literals. | 
| maxInclusive-maxCount | A shape has at most one value for sh:maxInclusive. | 
| minLength-datatype | The values of sh:minLengthin a shape are literals with datatypexsd:integer. | 
| minLength-maxCount | A shape has at most one value for sh:minLength. | 
| maxLength-datatype | The values of sh:maxLengthin a shape are literals with datatypexsd:integer. | 
| maxLength-maxCount | A shape has at most one value for sh:maxLength. | 
| pattern-datatype | The values of sh:patternin a shape are literals with datatypexsd:string. | 
| pattern-regex | The values of sh:patternin a shape are valid pattern arguments for the SPARQL REGEX function. | 
| flags-datatype | The values of sh:flagsin a shape are literals with datatypexsd:string. | 
| singleLine-datatype | The values of sh:singleLinein a shape are literals with datatypexsd:boolean. | 
| singleLine-maxCount | A shape has at most one value for sh:singleLine. | 
| languageIn-node | Each value of sh:languageInin a shape is a SHACL list. | 
| languageIn-members-datatype | Each member of such a list is a literal with datatype xsd:string. | 
| languageIn-maxCount | A shape has at most one value for sh:languageIn. | 
| uniqueLang-datatype | The values of sh:uniqueLangin a shape are literals with datatypexsd:boolean. | 
| uniqueLang-maxCount | A property shape has at most one value for sh:uniqueLang. | 
| uniqueLang-scope | Node shapes cannot have any value for sh:uniqueLang. | 
| memberShape-node | The value of sh:memberShapemust be a well-formed node shape. | 
| minListLength-datatype | The values of sh:minListLengthin a shape are literals with datatypexsd:integer. | 
| minListLength-minInclusive | The values of sh:minListLengthin a shape are integers greater than or equal to 0. | 
| maxListLength-datatype | The values of sh:maxListLengthin a shape are literals with datatypexsd:integer. | 
| maxListLength-minInclusive | The values of sh:maxListLengthin a shape are integers greater than or equal to 0. | 
| uniqueMembers-datatype | The values of sh:uniqueMembersin a shape are literals with datatypexsd:boolean. | 
| equals-nodeKind | The values of sh:equalsin a shape are IRIs. | 
| disjoint-nodeKind | The values of sh:disjointin a shape are IRIs. | 
| lessThan-nodeKind | The values of sh:lessThanin a shape are IRIs. | 
| lessThan-scope | Node shapes cannot have any value for sh:lessThan. | 
| lessThanOrEquals-nodeKind | The values of sh:lessThanOrEqualsin a shape are IRIs. | 
| lessThanOrEquals-scope | Node shapes cannot have any value for sh:lessThanOrEquals. | 
| not-node | The values of sh:notin a shape must be well-formed shapes. | 
| and-node | Each value of sh:andin a shape is a SHACL list. | 
| and-members-node | Each member of such list must be a well-formed shape. | 
| or-node | Each value of sh:orin a shape is a SHACL list. | 
| or-members-node | Each member of such list must be a well-formed shape. | 
| xone-node | Each value of sh:xonein a shape is a SHACL list. | 
| xone-members-node | Each member of such list must be a well-formed shape. | 
| node-node | The values of sh:nodein a shape must be well-formed node shapes. | 
| property-node | Each value of sh:propertyin a shape must be a well-formed property shape. | 
| qualifiedValueShape-node | The values of sh:qualifiedValueShapein a shape must be well-formed shapes. | 
| qualifiedValueShape-scope | Node shapes cannot have any value for sh:qualifiedValueShape. | 
| qualifiedValueShapesDisjoint-datatype | The values of sh:qualifiedValueShapesDisjointin a shape are literals with datatypexsd:boolean. | 
| qualifiedMinCount-datatype | The values of sh:qualifiedMinCountin a shape are literals with datatypexsd:integer. | 
| qualifiedMaxCount-datatype | The values of sh:qualifiedMaxCountin a shape are literals with datatypexsd:integer. | 
| reifierShape-node | The values of sh:reifierShapemust be well-formed node shapes.
									If a value forsh:reifierShapeis given,sh:pathvalues are constrained to IRIs. | 
| reificationRequired-datatype | The values of sh:reificationRequiredin a shape are literals with datatypexsd:boolean. | 
| nodeByExpression-scope | The values of sh:nodeByExpressionin a shape must be well-formed node expressions. | 
| closed-datatype | The values of sh:closedin a shape are literals with datatypexsd:booleanor the IRIsh:ByTypes. | 
| ignoredProperties-node | The values of sh:ignoredPropertiesin a shape must be SHACL lists. | 
| ignoredProperties-members-nodeKind | Each member of such a list must be a IRI. | 
| in-node | Each value of sh:inin a shape is a SHACL list. | 
| in-maxCount | A shape has at most one value for sh:in. | 
| expression-scope | The values of sh:expressionat a
								shape must be well-formed node expressions. | 
This section is non-normative.
The SHACL 1.2 SHACL-SHACL Note [shacl12-shacl-shacl] describes a SHACL graph that can be used to validate other SHACL Shapes graphs and thus may enforce many of the syntactic constraints related to RDF data aiming to conform to SHACL Core in this specification.
This shapes graph is available as an RDF resource at http://www.w3.org/ns/shacl-shacl, as indicated in the Note.
TODO: Replace the hyperlink to the NOTE with a reference once that has been created.
This section enumerates all normative validators of SHACL Core. This section is automatically generated from other parts of this spec and hyperlinks are provided back into the prose if the context of the validator in unclear.
| Validators by Constraint Component | 
|---|
| sh:ClassConstraintComponent: 
							Let $classbe a parameter value forsh:class.
							Letclassesbe a set of IRIs so that
							when$classis an IRI then the set only consists of exactly that IRI,
							and when$classis a blank node SHACL list then the set consists of
							exactly the members of the list.For each value node that is either a literal, or a non-literal that is not a SHACL instance of any of the classesin the data graph,
							there is a validation result with the value node assh:value. | 
| sh:DatatypeConstraintComponent: 
							Let $datatypebe a parameter value forsh:datatype.
							Letdatatypesbe a set of IRIs so that
							when$datatypeis an IRI then the set only consists of exactly that IRI,
							and when$datatypeis a blank node SHACL list then the set consists of
							exactly the members of the list.For each value node that is not a literal, or is a literal with a datatype that matches none of the datatypes,
							there is a validation result with the value node assh:value.The datatype of a literal is determined following the datatype function of SPARQL 1.2. A literal matches a datatype if the literal's datatype has the same IRI and, for the datatypes supported by SPARQL 1.2, is not an ill-typed literal. | 
| sh:NodeKindConstraintComponent: 
							Let $nodeKindbe a parameter value forsh:nodeKind.
							For each value node
							that does not match$nodeKind,
							there is a validation result with the value node assh:value.
							Any IRI matches onlysh:IRI,sh:BlankNodeOrIRIandsh:IRIOrLiteral.
							Any blank node matches onlysh:BlankNode,sh:BlankNodeOrIRIandsh:BlankNodeOrLiteral.
							Any literal matches onlysh:Literal,sh:BlankNodeOrLiteralandsh:IRIOrLiteral. | 
| sh:MinCountConstraintComponent: 
							Let $minCountbe a parameter value forsh:minCount.
							If the number of value nodes is less than$minCount,
							there is a validation result. | 
| sh:MaxCountConstraintComponent: 
							Let $maxCountbe a parameter value forsh:maxCount.
							If the number of value nodes is greater than$maxCount,
							there is a validation result. | 
| sh:MinExclusiveConstraintComponent: 
							Let $minExclusivebe a parameter value forsh:minExclusive.
							For each value nodevwhere the SPARQL expression$minExclusive < vdoes not returntrue,
							there is a validation result withvassh:value. | 
| sh:MinInclusiveConstraintComponent: 
							Let $minInclusivebe a parameter value forsh:minInclusive.
							For each value nodevwhere the SPARQL expression$minInclusive <= vdoes not returntrue,
							there is a validation result withvassh:value. | 
| sh:MaxExclusiveConstraintComponent: 
							Let $maxExclusivebe a parameter value forsh:maxExclusive.
							For each value nodevwhere the SPARQL expression$maxExclusive > vdoes not returntrue,
							there is a validation result withvassh:value. | 
| sh:MaxInclusiveConstraintComponent: 
							Let $maxInclusivebe a parameter value forsh:maxInclusive.
							For each value nodevwhere the SPARQL expression$maxInclusive >= vdoes not returntrue,
							there is a validation result withvassh:value. | 
| sh:MinLengthConstraintComponent: 
							Let $minLengthbe a parameter value forsh:minLength.
							For each value nodevwhere the length (as defined by the SPARQL STRLEN function)
							of the string representation ofv(as defined by the SPARQL str function)
							is less than$minLength, or wherevis a blank node,
							there is a validation result withvassh:value. | 
| sh:MaxLengthConstraintComponent: 
							Let $maxLengthbe a parameter value forsh:maxLength.
							For each value nodevwhere the length (as defined by the SPARQL STRLEN function)
							of the string representation ofv(as defined by the SPARQL str function)
							is greater than$maxLength, or wherevis a blank node,
							there is a validation result withvassh:value. | 
| sh:PatternConstraintComponent: 
							Let $patternbe a parameter value forsh:pattern.
							Let$flagsbe a parameter value forsh:flags.
							For each value node
							that is a blank node or
							where the string representation (as defined by the SPARQL str function)
							does not match the regular expression$pattern(as defined by the SPARQL REGEX function),
							there is a validation result with the value node assh:value.
							If$flagshas a value then the matching MUST follow the definition of the 3-argument variant of the SPARQL REGEX function, using$flagsas third argument. | 
| sh:SingleLineConstraintComponent: 
							Let $singleLinebe a parameter value forsh:singleLine.
							If$singleLineistrue, then, for each value node that is a literal where the lexical form matches the
							regular expression (as defined by the SPARQL REGEX function)[\f\r\n\v], there is a validation result. | 
| sh:LanguageInConstraintComponent: 
							Let $languageInbe a value ofsh:languageIn.
							For each value node
							that is either not a literal or that does not have a language tag
							matching any of the basic language ranges that are the members of$languageInfollowing the filtering schema defined by the SPARQL langMatches function,
							there is a validation result with the value node assh:value. | 
| sh:UniqueLangConstraintComponent: 
							Let $uniqueLangbe a parameter value forsh:uniqueLang.
							If$uniqueLangistruethen for each non-empty language tag that is used by at least two value nodes,
							there is a validation result. | 
| sh:MemberShapeConstraintComponent: 
							Let $memberShapebe a parameter value forsh:memberShape.
							Each value nodevmust be a SHACL list - ifvis not a SHACL list there is a validation result.
							If any membermof the SHACL listvdoes not conform to$memberShape, there is a validation result. | 
| sh:MinListLengthConstraintComponent: 
							Let $minListLengthbe a parameter value forsh:minListLength.
							Each value nodevmust be a SHACL list - ifvis not a SHACL list there is a validation result.
							If the number of members in a listvis less than$minListLength,
							there is a validation result. | 
| sh:MaxListLengthConstraintComponent: 
							Let $maxListLengthbe a parameter value forsh:maxListLength.
							Each value nodevmust be a SHACL list - ifvis not a SHACL list there is a validation result.
							If the number of members in the listvis greater than$maxListLength,
							there is a validation result. | 
| sh:UniqueMembersConstraintComponent: 
							Let $uniqueMembersbe a parameter value forsh:uniqueMembers.
							Each value nodevmust be a SHACL list - ifvis not a SHACL list there is a validation result.
							If$uniqueMembersistrueand the listvhas duplicate members,
							there is a validation result. | 
| sh:EqualsConstraintComponent: 
							Let $equalsbe a value ofsh:equals.
							For each value node 
							that does not exist as a value of the property$equalsat the focus node,
							there is a validation result with the value node assh:value.
							For each value of the property$equalsat the focus node
							that is not one of the value nodes,
							there is a validation result with the value assh:value. | 
| sh:DisjointConstraintComponent: 
							Let $disjointbe a parameter value ofsh:disjoint.
							For each value node
							that also exists as a value of the property$disjointat the focus node,
							there is a validation result with the value node assh:value. | 
| sh:LessThanConstraintComponent: 
							Let $lessThanbe a value ofsh:lessThan.
							For each pair of value nodes and the values of the property$lessThanat the given focus node
							where the first value is not less than the second value (based on SPARQL's<operator)
							or where the two values cannot be compared,
							there is a validation result with the value node assh:value. | 
| sh:LessThanOrEqualsConstraintComponent: 
							Let $lessThanOrEqualsbe a value ofsh:lessThanOrEquals.
							For each pair of value nodes and the values of the property$lessThanOrEqualsat the given focus node
							where the first value is not less than or equal to the second value (based on SPARQL's<=operator)
							or where the two values cannot be compared,
							there is a validation result with the value node assh:value. | 
| sh:NotConstraintComponent: 
							Let $notbe a value ofsh:not.
							For each value nodev:
							A failure MUST be reported if the conformance checking ofvagainst
							the shape$notproduces a failure.
							Otherwise, ifvconforms to the shape$not,
							there is validation result withvassh:value. | 
| sh:AndConstraintComponent: 
							Let $andbe a value ofsh:and.
							For each value nodev:
							A failure MUST be produced if the conformance checking ofvagainst any of the members of$andproduces a failure.
							Otherwise, ifvdoes not conform to each member of$and,
							there is a validation result withvassh:value. | 
| sh:OrConstraintComponent: 
							Let $orbe a value ofsh:or.
							For each value nodev:
							A failure MUST be produced if the conformance checking ofvagainst any of the members produces a failure.
							Otherwise, ifvconforms to none of the members of$orthere is a validation result withvassh:value. | 
| sh:XoneConstraintComponent: 
							Let $xonebe a value ofsh:xone.
							For each value nodevletNbe the number of the shapes that are members of$xonewherevconforms to the shape.
							A failure MUST be produced if the conformance checking ofvagainst any of the members produces a failure.
							Otherwise, ifNis not exactly1,
							there is a validation result withvassh:value. | 
| sh:NodeConstraintComponent: 
							Let $nodebe a value ofsh:node.
							For each value nodev:
							A failure MUST be produced if the conformance checking ofvagainst$nodeproduces a failure.
							Otherwise, ifvdoes not conform to$node,
							there is a validation result withvassh:value. | 
| sh:PropertyConstraintComponent: 
							Let $propertybe a value ofsh:property.
							For each value nodev:
							A failure MUST be produced if the validation ofvas focus node against the property shape$propertyproduces a failure.
							Otherwise, the validation results are the results of validatingvas focus node against the property shape$property. | 
| sh:QualifiedMinCountConstraintComponent: 
							Let $qualifiedValueShapebe a value ofsh:qualifiedValueShape.
							Let$qualifiedMinCountbe a parameter value forsh:qualifiedMinCount.
							LetCbe the number of value nodesvwherevconforms to$qualifiedValueShapeand wherevdoes not conform to any of the sibling shapes for the current shape,
							i.e. the shape thatvis validated against and which has$qualifiedValueShapeas its value forsh:qualifiedValueShape.
							A failure MUST be produced if any of the said conformance checks produces a failure.
							Otherwise, there is a validation result ifCis less than$qualifiedMinCount.
							The constraint component forsh:qualifiedMinCountissh:QualifiedMinCountConstraintComponent. | 
| sh:QualifiedMaxCountConstraintComponent: 
							Let $qualifiedMaxCountbe a parameter value forsh:qualifiedMaxCount.
							LetCbe as defined forsh:qualifiedMinCountabove.
							A failure MUST be produced if any of the said conformance checks produces a failure.
							Otherwise, there is a validation result ifCis greater than$qualifiedMaxCount.
							The constraint component forsh:qualifiedMaxCountissh:QualifiedMaxCountConstraintComponent. | 
| sh:ReifierShapeConstraintComponent: 
							Let tbe the triple term (focus node,$path, value node).
							For each reifier for the triple termt, a failure MUST be produced if validating the reifier against the node shape$reifierShapewith the reifier as focus node produces a failure.
							For each reifiertthat does not conform to$reifierShape, there is a validation result withtassh:value. | 
| sh:ReificationRequiredConstraintComponent: 
							If $reificationRequiredis set totrueand there is no reified statement for the triple termtin the data graph, there is a validation result withtassh:value. | 
| sh:NodeByExpressionConstraintComponent: 
Let $exprbe a value ofsh:nodeByExpression.
For each value nodev: perform a conformance check ofvagainst each output node ofevalExpr(expr,
data graph, v, {})s. A failure
MUST be produced if the conformance check ofvagainstsproduces a failure. Otherwise, ifvdoes
not conform tos, there is a validation result
withvassh:valueand a deep copy ofsassh:sourceConstraint. | 
| sh:ClosedConstraintComponent: 
							Let $closedbe a parameter value forsh:closed.
							Let$ignoredPropertiesbe a value forsh:ignoredProperties.If $closedistrueorsh:ByTypesandPis the set of properties defined below,
							then there is a validation result for each triple that has a value node as its
							subject and a predicate that is not inP.
							If$ignoredPropertieshas a value then the properties enumerated as members of this SHACL list
							are also permitted for the value node.
							The validation result MUST have the predicate of the triple as itssh:resultPath,
							and the object of the triple as itssh:value.If $closedistrue, thenPis the set of IRI properties
							that can be reached from the current shape via the SPARQL pathsh:property/sh:path.If $closedissh:ByTypes, thenPis the set of IRI properties
							that can be reached from the value node via the following algorithm, plusrdf:type:Stwice. | 
| sh:HasValueConstraintComponent: 
							Let $hasValuebe a parameter value forsh:hasValue.
							If the RDF term$hasValueis not among the value nodes,
							there is a validation result. | 
| sh:InConstraintComponent: 
							Let $inbe a value ofsh:in.
							For each value node
							that is not a member of$in,
							there is a validation result with the value node assh:value. | 
| sh:ExpressionConstraintComponent: 
							Let $exprbe a value ofsh:expression.
							For each value nodevwhereevalExpr(expr, data graph, v, {})does not return the list consisting of exactlytrueas its output nodes,
							there is a validation result that hasvas itssh:valueand a deep copy of$exprin the results graph as itssh:sourceConstraint.
							If the$exprhas values forsh:messagein the shapes graph,
							then these values become the (only) values forsh:resultMessagein the
							validation result. | 
This section is non-normative.
				Like most RDF-based technologies, SHACL processors may operate on graphs that are combined
				from various sources.  Some applications may have an open "linked data" architecture and dynamically
				assemble RDF triples from sources that are outside of 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 lead to misleading results.
				Protection against this (and the following) scenario can be achieved by only using trusted
				and verified RDF sources and eliminating the possibility that graphs are dynamically added via
				owl:imports and sh:shapesGraph.
			
This section is non-normative.
The original 1.0 version of SHACL was produced by the RDF Data Shapes Working Group. See its SHACL 1.0 Acknowledgements section.
This section is non-normative.
The detailed list of changes and their diffs can be found in the Git repository.
This section is non-normative.
sh:targetNode, sh:deactivated and sh:defaultValue, and introduced sh:values to support node expressions.sh:singleLine, see Issue 177sh:ShapeClass for implicit class targets; see Issue 212sh:expression; see Issue 357sh:nodeByExpression, see Issue 408sh:ByTypes for sh:closed; see Issue 172sh:class and sh:datatype can now also be lists, indicating a union of choices; see Issue 160Referenced in:
Referenced in:
Referenced in:
Referenced in:
Referenced in:
Referenced in:
Referenced in:
Referenced in:
Referenced in:
Referenced in:
Referenced in:
Referenced in:
Referenced in:
Referenced in:
Referenced in:
Referenced in:
Referenced in:
Referenced in:
Referenced in:
Referenced in:
Referenced in:
Referenced in:
Referenced in:
Referenced in:
Referenced in:
Referenced in:
Referenced in:
Referenced in:
Referenced in:
Referenced in:
Referenced in:
Referenced in:
Referenced in:
Referenced in:
Referenced in: