@vocab
to handle uniform namespacesJSON-LD provides JSON-LD contexts which enable JSON documents to use simple, locally-meaningful names, while still enabling the messages to be meaningful beyond the initial exchange partners. A JSON-LD message can be meaningful to anyone anywhere, even when mixed with other data.
The JSON-LD context has many more capabilities than this section will highlight. Here, we focus only on the use of contexts to define aliases, to enable the use of namespaces and short local terms.
Although you may not want to use colon-separated qualified names in your JSON data, it’s easier to explain starting with that style. This example uses NIEM names with the standard prefixes for the NIEM namespaces:
{
"nc:PersonAgeMeasure": {
"nc:MeasureIntegerValue": 14,
"nc:TimeUnitCode": "ANN"
},
"j:PersonHairColorCode": "BRO",
"nc:PersonName": {
"nc:PersonGivenName": "Mortimer",
"nc:PersonSurName": "Smith",
"nc:PersonNameSuffixText": "Sr",
"nc:PersonPreferredName": "Morty"
}
}
This may be interpreted against the following JSON-LD context:
{
"nc": "http://release.niem.gov/niem/niem-core/4.0/#",
"j": "http://release.niem.gov/niem/domains/jxdm/6.0/#"
}
This example and expanded and compacted version can be seen at the JSON-LD Playground.
The page on JSON-LD processing discusses expansion and compaction, two of the standard JSON-LD processing algorithms that can transform JSON-LD data in useful ways.
When compacted with an empty context, the structure of the data, and the complete URIs for keys are plainly visible:
{
"http://release.niem.gov/niem/domains/jxdm/6.0/#PersonHairColorCode": "BRO",
"http://release.niem.gov/niem/niem-core/4.0/#PersonAgeMeasure": {
"http://release.niem.gov/niem/niem-core/4.0/#MeasureIntegerValue": 14,
"http://release.niem.gov/niem/niem-core/4.0/#TimeUnitCode": "ANN"
},
"http://release.niem.gov/niem/niem-core/4.0/#PersonName": {
"http://release.niem.gov/niem/niem-core/4.0/#PersonGivenName": "Mortimer",
"http://release.niem.gov/niem/niem-core/4.0/#PersonNameSuffixText": "Sr",
"http://release.niem.gov/niem/niem-core/4.0/#PersonPreferredName": "Morty",
"http://release.niem.gov/niem/niem-core/4.0/#PersonSurName": "Smith"
}
}
This example can be seen at the JSON-LD Playground.
Again, expanded and otherwise processed data shows the fundamental meaning of data in a universally-understandable way. It’s likely that exchanges will instead utilize shorter, locally-preferred terminology.
The above data can be compacted against another JSON-LD context:
{
"nc": "http://release.niem.gov/niem/niem-core/4.0/#",
"j": "http://release.niem.gov/niem/domains/jxdm/6.0/#",
"age": "nc:PersonAgeMeasure",
"value": "nc:MeasureIntegerValue",
"units": "nc:TimeUnitCode",
"hairColor": "j:PersonHairColorCode",
"name": "nc:PersonName",
"given": "nc:PersonGivenName",
"surname": "nc:PersonSurName",
"suffix": "nc:PersonNameSuffixText",
"nickname": "nc:PersonPreferredName"
}
This yields the JSON-LD data that uses only short, local terms:
{
"age": {
"value": 14,
"units": "ANN"
},
"hairColor": "BRO",
"name": {
"given": "Mortimer",
"surname": "Smith",
"suffix": "Sr",
"nickname": "Morty"
}
}
This example can be seen at the JSON-LD Playground.
When interpreted against the right JSON-LD contexts, both JSON documents evaluate to the same expanded data.
Developers of exchanges may use contexts to greatly simplify their JSON files, while maintaining the meaning of the data across all users and communities.
JSON-LD contexts can define universal identifiers for keys several different ways. This section highlights a few. The context can do much more than define key URIs; techniques are detailed in the JSON-LD specification’s sections on contexts and advanced concepts.
Contexts use Internationalized Resource Identifiers (IRIs) to uniquely identify resources.
The use of contexts to define prefixes is described by the JSON-LD specification’s section on compact IRIs, which is JSON-LD’s name for colon-separated qualified names.
The proper value to use for a prefix defined in a context can be identified by
the NIEM Naming and Design Rules, section 5.6.1, Resource IRIs for XML Schema components and information items,
which describes the mapping from an XML qualified name to a URI. In short, any
namespace that does not end in an octothorp/hash/pound sign (
) has a
#
character appended to it. So, since the namespace URI for the NIEM
Core namespace (nc) is #
http://release.niem.gov/niem/niem-core/4.0/
, it would
be defined in the following part of a context:
{
"nc": "http://release.niem.gov/niem/niem-core/4.0/#"
}
With this context, a value nc:PersonAgeMeasure
becomes, after processing, the
IRI http://release.niem.gov/niem/niem-core/4.0/#PersonAgeMeasure
.
Within a context, a local name, like age
can be aliased to an IRI. Either of
the two following contexts would suffice:
{
"nc": "http://release.niem.gov/niem/niem-core/4.0/#",
"age": "nc:PersonAgeMeasure"
}
{
"age": "http://release.niem.gov/niem/niem-core/4.0/#PersonAgeMeasure"
}
@vocab
to handle uniform namespacesIf much of your data is from a single namespace, the @vocab
directive within a
context will map otherwise-undefined local names to a single namespace, as if
each was given an assigned prefix.
The context, …
{
"@vocab": "http://release.niem.gov/niem/niem-core/4.0/#",
"j": "http://release.niem.gov/niem/domains/jxdm/6.0/#"
}
… used to process the following instance, results in the same data as the above example.
{
"PersonAgeMeasure": {
"MeasureIntegerValue": 14,
"TimeUnitCode": "ANN"
},
"j:PersonHairColorCode": "BRO",
"PersonName": {
"PersonGivenName": "Mortimer",
"PersonSurName": "Smith",
"PersonNameSuffixText": "Sr",
"PersonPreferredName": "Morty"
}
}
This example is available at the JSON-LD Playground.
The JSON-LD specification describes how to attach a JSON-LD context to a JSON file, so that the file may be properly processed as JSON-LD. Examples provided on this website mostly maintain separate contexts from the JSON files.
@context
Any JSON object may carry a key
, which indicates a context
that is active at the scope of that object, and within to nested objects.@context
A key
may have, as a value, a JSON object, which acts as a
context.@context
{
"@context" : {
"nc": "http://release.niem.gov/niem/niem-core/4.0/#"
},
"nc:PersonPreferredName": "Morty"
}
A key
may have, as a value, a URI, which is a name for a
JSON-LD context object.@context
{
"@context" : "https://example.org/my/context.json",
"nc:PersonPreferredName": "Morty"
}
A method for attaching a JSON context to a plain JSON object via an HTTP Link
header is described by
the JSON-LD specification, section 4.9, Interpreting JSON as JSON-LD. In
short, a plain JSON file that is passed via HTTP can be accompanied by a
separate JSON-LD context document. The URI of the JSON-LD context document is
passed via an HTTP Link header, using the link relation
http://www.w3.org/ns/json-ld#context
.
The JSON-LD specification recommends that JSON-LD contexts be cached by systems that use them, reducing security risks and load times:
JSON-LD contexts that are loaded from the Web over non-secure connections, such as HTTP, run the risk of being altered by an attacker such that they may modify the JSON-LD active context in a way that could compromise security. It is advised that any application that depends on a remote context for mission critical purposes vet and cache the remote context before allowing the system to use it.
A best practice for using JSON-LD contexts with NIEM is to treat contexts as part of an information exchange specification, and inspect them, vet them, and cache them for use, rather than relying on any kind of run-time network resolution of contexts.