A metadata quality assessment tool customized for Deutsche Digitale Bibliothek's requirements against the incomming metadata records. This is an extension of Metadata Quality Assessment Framework.
The software depends on the following technologies:
- MySQL
- SQLite3
- Java 11
- R
- Apache Solr
- PHP
The following installation instructions work in Ubuntu. These contain simplified steps, for further details please consult the official documentation of these tools.
sudo apt install jq wget curl
sudo apt install mysql-server
sudo service mysql start
sudo apt install sqlite3
sudo apt install openjdk-11-jre-headless
wget -qO- https://cloud.r-project.org/bin/linux/ubuntu/marutter_pubkey.asc | sudo gpg --dearmor -o /usr/share/keyrings/r-project.gpg
echo "deb [signed-by=/usr/share/keyrings/r-project.gpg] https://cloud.r-project.org/bin/linux/ubuntu jammy-cran40/" | sudo tee -a /etc/apt/sources.list.d/r-project.list
sudo apt update
sudo apt install --no-install-recommends r-base r-cran-tidyverse r-cran-stringr r-cran-gridextra
export SOLR_VERSION=9.1.1
cd /opt
curl -s -L https://archive.apache.org/dist/solr/solr/${SOLR_VERSION}/solr-${SOLR_VERSION}.tgz --output solr-${SOLR_VERSION}.tgz
tar zxf solr-${SOLR_VERSION}.tgz
rm solr-${SOLR_VERSION}.tgz
ln -s solr-${SOLR_VERSION} solr
run Apache Solr
/opt/solr/bin/solr start -m 2g
sudo apt install php php-http-request2 php-mysql php-sqlite3
Download and unzip the release package.
wget https://github.com/pkiraly/metadata-qa-ddb/releases/download/v1.0.0/metadata-qa-ddb-1.0.0-release.zip
unzip metadata-qa-ddb-1.0.0-release.zip
cd metadata-qa-ddb-1.0.0-release
Set the configuration file.
- Create a configuration file:
cp configuration.cnf.template configuration.cnf
- Edit the configuration file
INPUT_DIR=<path to input directory>
OUTPUT_DIR=<path to output directory>
# FTP user name and password for the DDB FTP server
MQAF_FTP_USER=<FTP user name>
MQAF_FTP_PW=<FTP password>
# MySQL database settings
MQAF_DB_HOST=localhost
MQAF_DB_PORT=3306
MQAF_DB_DATABASE=<MySQL database name>
MQAF_DB_USER=<MySQL user name>
MQAF_DB_PASSWORD=<MySQL password>
# the type of configuration when call 'mysql' command.
# valid values: LOCAL_FILE, TEMP_FILE or ENVIRONMENT_VARIABLES
MYSQL_CONFIG_TYPE=LOCAL_FILE
# Apache Solr settings
MQAF_SOLR_HOST=localhost
MQAF_DBSOLR_PORT=8983
# the prefix of the Solr core, default is 'qa_ddb'
# the cores will be names as [SOLR_CORE_PREFIX]_[METADATA_SCHEMA], e.g. qa_ddb_lido, qa_ddb_marc etc.
MQAF_SOLR_CORE_PREFIX=ddb_qa
# validation related settings
MQAF_VALIDATION_PARAMS=
With the MQAF_VALIDATION_PARAMS you can set individual parameters regarding to the running of the validation. For example to skip the image dimension check and content type check, you can add:
MQAF_VALIDATION_PARAMS="--skipDimension --skipContentType"
Log in to MySQL, create a database and a dedicated user:
CREATE DATABASE ddb;
CREATE USER '<user name>'@'localhost' IDENTIFIED BY '<password>';
GRANT ALL PRIVILEGES ON ddb.* TO '<user name>'@'localhost' WITH GRANT OPTION;
FLUSH PRIVILEGES;
create the database tables
scripts/create_database.mysql.sh
download files from FTP server
scripts/ingest/01_download_from_ftp.sh
unzip the downloaded zip files
scripts/ingest/02_extract_downloaded_files.sh
extract file info (path, size etc.) from the directory. The file paths contain semantic information about the data providers. The following data elements are extracted: file path, metadata schema, provider identifier, provider name, data set identifier, data set name, last modification date, file size. These data are saved into $OUTPUT_DIR/files.csv file.
scripts/ingest/03_extract_basic_info_from_downloaded_files.sh
import file info into MySQL (it first transforms CSV to SQL)
scripts/ingest/04_import_basic_info.mysql.sh
(optional) harvest Europeana-EDM records for each data sets
scripts/ingest/05_harvest_edm.mysql.sh
These commands will index the following fields into Apache Solr: identifier, provider identifier and title. The 'what to index?' question is answered by the schema's yaml definition file at the main/resources directory. The record ID and the container file is stored in MySQL. The record's full XML presentation is stored in a SQLite3 database. It is needed only for the display of records in the web user interface.
index DDB-EDM records
scripts/index/01_index_ddb-edm.sh
index MARC records
scripts/index/02_index_marc.sh
index DDB-DC records
scripts/index/03_index_ddb-dc.sh
index LIDO records
scripts/index/04_index_lido.sh
index METS-MODS records
scripts/index/05_index_mets-mods.sh
The quality assessment reads from the $INPUT_DIR
directory and writes the results to $OUTPUT_DIR
directory as CSV files, such as edm-ddb.csv
.
quality assessment of DDB-EDM records
scripts/process/01_process_ddb-edm.sh
quality assessment of MARC
scripts/process/02_process_marc.sh
quality assessment of DDB-DC
scripts/process/03_process_ddb-dc.sh
quality assessment of LIDO
scripts/process/04_process_lido.sh
quality assessment of METS-MODS
scripts/process/05_process_mets-mods.sh
import DDB-EDM
scripts/process/11_import_ddb-edm.mysql.sh
import MARC
scripts/process/11_import_marc.mysql.sh
import DDB-DC
scripts/process/11_import_dc.mysql.sh
import LIDO
scripts/process/11_import_lido.mysql.sh
import METS-MODS
scripts/process/11_import_mets-mods.mysql.sh
calculate aggregated results
scripts/process/12_calculate_aggregations.mysql.sh