Software requirements:
- Same requirements as in README.md
- Elasticsearch 2+
For the BrAPI server requirements, please consult the Elixir EXCELERATE BrAPI recommendations.
The config
folder contains general configuration about the whole ETL process:
config/extract-brapi.json
: BrAPI extraction configuration describing all the BrAPI entities, entity links and the REST calls to perform in order to extract all BrAPI data from an endpoint.config/transform-elasticsearch.json
: Elasticsearch document transform configuration describing how documents can be generated from BrAPI entities and how the ETL process should validate the documents data.config/elasticsearch/*.json
: Elasticsearch document mappings describing how Elasticsearch should index the JSON documents.config/load-elasticsearch.json
: Elasticsearch indexing configuration containing the default HTTP gateway access and how the document index should be configured at creation.
The sources
folder contains source-specific configurations.
Here is an example of configuration for the VIB endpoint:
{
"@context": {
"schema": "http://schema.org/",
"brapi": "https://brapi.org/rdf/"
},
"@type": "schema:DataCatalog",
"@id": "http://pippa.psb.ugent.be",
"schema:identifier": "VIB",
"schema:name": "VIB PIPPA",
"brapi:endpointUrl": "https://pippa.psb.ugent.be/pippa_experiments/brapi/v1/"
}
This configuration file uses the JSON-LD format with the schema.org and brapi.org properties. The following properties should be modified for each data source:
"@id"
: The URI identifying this data source (we use the institute/information system web page most of the time)"schema:identifier"
: A short text identifier for the data source"schema:name"
: The full display name for this data source"brapi:endpointUrl"
: The URL of the BrAPI endpoint to harvest
To get help on the usage of the command line interface, you can run the following:
$ python3 main.py --help
usage: main.py [-h] [--data-dir DATA_DIR] [--verbose]
{extract,transform,trans,load} ...
ETL: BrAPI to Elasticsearch. BrAPI to RDF.
positional arguments:
{extract,transform,trans,load}
Actions
extract Extract data from BrAPI endpoints
transform (trans) Transform BrAPI data
load Load data
optional arguments:
-h, --help show this help message and exit
--data-dir DATA_DIR Working directory for ETL data (default is './data')
--verbose, -v Verbose mode
To extract BrAPI data for a data source, simply run:
python3 main.py extract --data-dir {datadir} {datasource.json}
Where {datasource.json}
is the path to the data source configuration file (ex: sources/VIB.json
).
The harvested BrAPI data will then be available in the data directory {datadir}/json/{datasource}/*.json
.
Some example command run:
# Extracting VIB to ./data/json/NIB
$ python3 main.py extract sources/VIB.json
# Extracting VIB and NIB to /tmp/data/json/VIB and /tmp/data/json/NIB
$ python3 main.py extract --data-dir /tmp/data sources/VIB.json sources/NIB.json
To transform BrAPI data to Elasticsearch documents, simply run:
python3 main.py transform elasticsearch --data-dir {datadir} --document-types {documenttypes} {datasource.json}
Where {datasource.json}
is the path to the data source configuration file (ex: sources/VIB.json
) and {documenttypes}
the list of document type to generate (ex: study,datadiscovery
).
The generated Elasicsearch documents will then be available in the data directory {datadir}/json-bulk/{datasource}/*.json
.
Some example command run:
# Transform BrAPI VIB to Elasticsearch documents in ./data/json-bulk/NIB
$ python3 main.py transform elasticsearch sources/VIB.json
# Transform BrAPI VIB and NIB to Elasticsearch documents in /tmp/data/json-bulk/VIB and /tmp/data/json-bulk/NIB
$ python3 main.py trans es --data-dir /tmp/data sources/VIB.json sources/NIB.json
Transformation templating documentation : see test_templating.py
To load/index Elasticsearch documents, simply run:
python3 main.py load elasticsearch --data-dir {datadir} --document-types {documenttypes} {datasource.json}
Where {datasource.json}
is the path to the data source configuration file (ex: sources/VIB.json
) and {documenttypes}
the list of document type to index (ex: study,datadiscovery
).
Some example command run:
# Load BrAPI VIB to Elasticsearch documents
$ python3 main.py load elasticsearch sources/VIB.json
# Load BrAPI VIB and NIB to Elasticsearch documents (from /tmp/data)
$ python3 main.py load es --data-dir /tmp/data sources/VIB.json sources/NIB.json