A Clojure library for validating xAPI Profiles, according to the xAPI Profile specification.
Add the following to the :deps
map in your deps.edn
file:
com.yetanalytics/project-pan {:mvn/version "0.5.3"
:exclusions [org.clojure/clojure
org.clojure/clojurescript]}
To use the library to validate a whole Profile, call validate-profile
in the pan
namespace. This method takes in an entire Profile as an EDN data structure and prints either a success message on success (obviously) or an error message on failure.
Similarly, to validate a collection of Profiles, call validate-profile-coll
on them. Each Profile in the collection will be able to reference Concepts, Templates, and Patterns from the other Profiles.
Arguments may be supplied for different levels of validation strictness, which are listed as follows:
:syntax?
- Basic validation; check only the types of properties and simple syntax of all Profile objects. Default true
.:ids?
- Validate the correctness of all object and versioning IDs (the id
and inScheme
properties). Validate that all IDs are distinct and that all inScheme
values correspond to valid Profile version IDs. If multiple Profiles are involved, all IDs are checked that they are distinct among all Profiles (not just the Profile it is a part of).*:multi-version?
- A flag for the :ids?
keyword arg; if false
then ID validation will check that all objects have the same inScheme
value. If true
, then in addition to the usual ID checking, validation that Template and Pattern IDs change when their properties (other than inScheme
, prefLabel
, and scopeNote
) change is active. Default false
.:relations?
- Validate that all relations between Profile objects are valid. These relations are given by IRIs and include the following:
recommendedActivityTypes
property for Activity ExtensionsrecommendedVerbs
property for Context and Result ExtensionsobjectStatementRefTemplate
property and the contextStatementRefTemplate
properties for Statement Templates.sequence
, alternates
, optional
, oneOrMore
and zeroOrMore
properties for Patterns.:concept-rels?
, :template-rels?
, :pattern-rels?
- Similar to :relations?
, except that each only validates relations specific to Concept, Statement Template, and Pattern properties, respectively. Each are default false
, and are overridden when :relations?
are true
.:contexts?
- Validate that all instances of @context
resolve to valid JSON-LD contexts and that they allow all properties to expand out to absolute IRIs during JSON-LD processing. The @context
property is always found in the Profile metadata and in Activity Definitions, though they can also be found in Extensions for said Activity Definitions.Other keyword arguments include:
:external-profiles
- Extra Profiles from which to reference Concepts, Statement Templates, and Patterns from. Unlike the Profiles passed into validate-profile-coll
, these Profiles are not validated (though will be treated as part of the same scope in terms of ID distinctiveness validation).:external-contexts
- Extra @context
values (other than the xAPI Profile and Activity contexts) that @context
IRIs in profile
can reference during context validation. During multi-profile validation, all Profiles refer to the same global :external-contexts
map. Default {}
.:result
- This value affects the format of the result type.
:print
prints an Expound-generated error string to standard output.:string
returns the aforementioned error string (or a vector of them, in the case of validate-profile-coll
).:type-string
returns a {:type string}
map, where :type
is a keyword and string
is an error message specific to that type of error. :type
can be one of the following:
:syntax-errors
for basic validation errors:id-errors
for ID errors:in-scheme-errors
for inScheme errors:concept-edge-errors
for errors between Concept relations:template-edge-errors
for errors between Template relations:pattern-edge-errors
for errors between Pattern relations:pattern-cycle-errors
for cycles in the Pattern relation graph:context-errors
for errors relating to JSON-LD context:type-path-string
returns a {:type {path string}}
map, where path
is the assoc-in
vector needed to retrieve the erroneous value, and string
is an error message specific to that error location.:spec-error-data
- Return a {:type spec-error-data}
map, with each value being the map generated by Clojure spec. Default.:error-msg-opts
- Takes an opt map that affects how error messages are formed and printed. Currently only takes :print-objects?
, which when true
(default) displays the entire object in error messages, and if false
only displays IDs.The validate-object
function is provided in order to provide a way to validate individual Concepts, Templates, and Patterns without having to go deeper than the top level API. The :type
and :result
keyword args are used to fix the expected spec and to affect the function result, respectively; more details can be found in the docstring.
The get-external-iris
function is provided in the API in order to retrieve IRI values that refer to external objects, JSON-LD contexts, etc. (i.e. objects that do not exist in the Profile). This allows the user to more easily retrieve external Profiles and contexts in their application from the Internet or their data store.
The json-profile->edn
function is provided in the API to provide for convenient coercion of JSON profile strings into an EDN format that Pan recognizes.
Besides validating whole Profiles, you can also use library methods and specs to validate parts of Profiles, such as individual Concepts, Templates and Patterns).
schema
values are given by IRIs that link out to external JSON Schemas.@context
values need to be given by external links.Copyright © 2019-2022 Yet Analytics, Inc.
Project Pan is licensed under the Apache License, Version 2.0. See LICENSE for the full license text
Can you improve this documentation? These fine people already did:
kelvinqian00, Kelvin Qian, Kelvin, Shelly Blake-Plock & Milt RederEdit on GitHub
cljdoc is a website building & hosting documentation for Clojure/Script libraries
× close