LDShapes is a software tool used to define rdf-based data structures and transform data from miscellaneous sources to RDF data based on and validated against that data structure. The tool has a primary goal of getting data from miscellaneous sources into any RDF-based collection management system such as Memorix. Since both Memorix and LDShapes use open standards to reason about and describe data, LDShapes could be used in other environments as well, such as generic triple stores and /or other collection management systems.
make sure you use node >= 10.13.0, except for v13
cd backend
$ npm install
cd ../
cd frontend
npm install
cd backend
# development
$ npm run start
# watch mode
$ npm run start:dev
# production mode
$ npm run start:prod
cd frontend
npm run serve
cd backend
# unit tests
$ npm run test
# e2e tests
$ npm run test:e2e
# test coverage
$ npm run test:cov
npm run build
npm run lint
The Shape creator uses a small configuration file (json) to fill lists and default prefixes.
This configuration file is located in "/resources" and named "config.json". If needed you can add (or remove) your own values to choose from.
Be carefull of which default prefixes you remove. Most are needed for a proper Shape when starting from scratch.
To transform your data to rdf, you need an rml mapping.
The mapping should be put in the /resources/mappings/
folder.
Example:
@prefix rr: <http://www.w3.org/ns/r2rml#> .
@prefix foaf: <http://xmlns.com/foaf/0.1/> .
@prefix ex: <http://example.com/> .
@prefix xsd: <http://www.w3.org/2001/XMLSchema#> .
@prefix rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#> .
@prefix rml: <http://semweb.mmlab.be/ns/rml#> .
@prefix ql: <http://semweb.mmlab.be/ns/ql#> .
@prefix fnml: <http://semweb.mmlab.be/ns/fnml#> .
@prefix schema: <http://schema.org/> .
@prefix fno: <http://w3id.org/function/ontology#> .
@base <http://example.com/base/> .
<TriplesMap1>
a rr:TriplesMap;
rml:logicalSource [
rml:source "<absolute-path-to-data-source>";
rml:referenceFormulation ql:JSONPath;
rml:iterator "$.persons[*]"
];
rr:subjectMap [
rml:reference "firstName";
rr:termType rr:IRI;
];
rr:predicateObjectMap [
rr:predicate rdf:type;
rr:object foaf:Person;
];
rr:predicateObjectMap [
rr:predicate foaf:givenName;
rr:objectMap [ rml:reference "firstName" ];
];
rr:predicateObjectMap [
rr:predicate foaf:familyName;
rr:objectMap [ rml:reference "lastName" ];
];
cd backend
npm run cli:dev -- transform --mapping <name> --output <name>
-m, --mapping <name> the mapping file in `/resources/mappings/`
-o, --output <name> the output file that will be placed in `/resources/rdf/`
Example:
cd backend
npm run cli:dev -- transform --mapping person-mapping.ttl --output persons.n3
cd backend
npm run cli:dev -- validate --rdf <name> --shape <name>
-r, --rdf <name> the name of the rdf file in `/resources/rdf/`
-s, --shape <name> the name of the shape file in `/resources/shapes/`
Example:
cd backend
npm run cli:dev -- validate --rdf persons.n3 --shape person-shape.ttl