Skip to content
This repository has been archived by the owner on Apr 12, 2023. It is now read-only.
/ adamant Public archive
forked from plasma-mds/adamant

Adamant is a JSON schema-based metadata creation tool for various research data management workflows.

License

Notifications You must be signed in to change notification settings

tomio13/adamant

 
 

Repository files navigation

drawing

Adamant is a JSON schema-based metadata creation tool presented in a user-friendly interface. Adamant aims to ease the integration of various research data management (RDM) workflows into the everyday research routine of especially small independent laboratories, which hopefully leads to the generation of research data that adhere to the FAIR (findable, accessible, interoperable, reusable) principles. As of now, Adamant supports the following features:

  • Rendering of interactive web-form based on a valid JSON schema
  • User-friendly editing process of the rendered web-form and the corresponding schema
  • Creating a valid JSON schema and web-form from scratch
  • Live validation for various field types
  • Quick re-use of existing schemas from a list
  • Downloadable JSON schema and its form data
  • API-based integration as various form submission functionalities

A live demo of Adamant (client only) is available at: https://plasma-mds.github.io/adamant/.

GitHub license DOI

Supported JSON schema keywords

Currently, Adamant supports the rendering and editing of JSON schemas with a specification version draft 4 and 7. The following table lists all the implemented JSON schema keywords in the current version of Adamant. Note that the id keyword only works with the JSON schema specification version draft 4, whereas $id is used for the newer specification drafts. Lastly, the contentEncoding keyword is intended to be used with the specification version draft 7 or newer.

Field Type Implemented Keywords Note
String title, id, $id, description, type, enum, contentEncoding, default, minLength, maxLength contentEncoding can only receive a string value of "base64"
Number title, id, $id, description, type, enum, default, minimum, maximum
Integer title, id, $id, description, type, enum, default, minimum, maximum
Boolean title, id, $id, description, type, default
Array title , id, $id, description, type, default, items, minItems, maxItems, uniqueItems
Object title, id, $id, description, type, properties, required

Development

Setting up Adamant on a local machine for development (Ubuntu 20.04.4 LTS):

  • $ git clone https://github.com/plasma-mds/adamant.git—clone the repository
  • $ cd adamant—go to adamant project directory
  • adamant$ npm install—install the dependencies for the client-side
  • adamant$ cd backend—go to backend directory
  • adamant/backend$ python3 -m venv venv—create a python virtual environment
  • adamant/backend$ source ./venv/bin/activate—activate the virtual environment
  • adamant/backend$ pip install -r requirements.txt—install the dependencies for the back-end
  • adamant/backend$ ./venv/bin/flask run --no-debugger—start the back-end
  • Start a new terminal
  • adamant$ npm start—on a new terminal, in the adamant project directory, start the front-end

By default, Adamant is accessible at http://localhost:3000.

Deployment

We recommend deploying Adamant with docker-compose, which can be done with ease:

  • $ git clone https://github.com/plasma-mds/adamant.git—clone the repository
  • $ cd adamant—go to adamant project directory
  • adamant$ docker−compose build—build the docker images for both back-end and front-end
  • adamant$ docker−compose up -d—start both client and server containers, i.e., the whole system

By default, the deployed system can be accessed at http://localhost:3000.

Grant information

The work was funded by the Federal Ministry of Education and Research (BMBF) under the grant mark 16QK03A. The responsibility for the content of this repository lies with the authors.

About

Adamant is a JSON schema-based metadata creation tool for various research data management workflows.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • JavaScript 96.0%
  • Python 3.3%
  • Other 0.7%