This composition of applications provides a solution for hosting material science data for projects in the material digital initiative to participate in a decentralized linked data space with a central data portal instance. It also features an ontology agnostic transformation pipeline and a triple store integration.
- Central Component is a CKAN instance as data management system, with default views for pdf, images, text, csv, html, markdown.
- A apche jena fuseki triple store at a sublocation /fuseki
- A plugin to create accompanying named graphs in jena fuseki for semantic data contained in ckan datasets including sparql endpoint publication and a user-friendly sparql query interface known as sparklis
- a pipeline for transforming complex csv data common in the domain to csvw metadata
- A rule based mapping pipeline to combine rdf containing data with knowledge graphs to represent material data, its measurement routine and the processing. A tutorial and the steps involved can be found here.
Before you begin, make sure you have the following installed:
- Docker
- Docker Compose
-
Clone this repository to your local machine and init submoduls:
git clone https://github.com/materialdigital/pmd-ckan.git git submodule update --init
-
Navigate to the pmd-ckan directory:
cd ckan-docker-compose
-
create a .env file, use (example.env)[config/example.env] as a template
all variables starting with CKANEXT__ will be translated to the ckan.ini removing CKANINI__, replacing "__" with "." and putting the name to lowercase examples: CKANINI__CSVTOCSVW__FORMATS -> csvtocsvw.formats CKANINI__CSVTOCSVW__SSL_VERIFY -> csvtocsvw.ssl_verify
-
replace all values in <> braces or are comented to be changed
-
make changes according to your ssl or proxy configuration in config/nginx/default.template
-
Run the docker compose stack, it will pull and build the necessary containers
docker-compose up
-
After first successful startup, login into ckan with the admin password you defined in your .env
-
create an API token for the supervisor background tasks at /user/<ckan_admin_user>/api-tokens, and paste it into your .env file at BACKGROUNDJOBS_API_TOKEN
-
restart the docker compose stack in detached mode
docker-compose down docker-compose up -d
-
create a api token for the supervisor background tasks at /user/<ckan_admin_user>/api-tokens, and paste it into your .env file at BACKGROUNDJOBS_API_TOKEN
-
restart the dockercompose stack in detached mode
docker-compose down
docker-compose up -d
The authors would like to thank the Federal Government and the Heads of Government of the Länder for their funding and support within the framework of the Platform Material Digital consortium. Funded by the German Federal Ministry of Education and Research (BMBF) through the MaterialDigital Call in Project KupferDigital - project id 13XP5119.