Tool to which you pass basic information of a project or a research article (such as the datasets, software, people who have been involved, bibliography...) and generates two files with structured information with the intention of easing the readability for machines and people. One file is a webpage with all the relevant information and the other one is a Research Object.
Project description
ya2ro
Example
Ya2ro generates Research Objects (ROs) like the following: https://w3id.org/dgarijo/ro/sepln2022. Given a few ROs, ya2ro
can also create a landing page:
https://oeg-upm.github.io/ya2ro/output/landing_page.html
Requirements
The latest version of ya2ro works in Python 3.10.
Installation
To run ya2ro, please follow the next steps:
Install from PyPI
pip install ya2ro
Install from GitHub
git clone https://github.com/oeg-upm/ya2ro
cd ya2ro
pip install -e .
Installing through Docker
We provide a Dockerfile with ya2ro already installed. To run through Docker, you may build the Dockerfile provided in the repository by running:
docker build -t ya2ro .
Then, to run your image just type:
docker run -it ya2ro /bin/bash
And you will be ready to use ya2ro (see section below). If you want to have access to the results we recommend mounting a volume. For example, the following command will mount the current directory as the out
folder in the Docker image:
docker run -it --rm -v $PWD/:/out ya2ro /bin/bash
If you move any files produced by ya2ro into /out
, then you will be able to see them in your current directory.
Usage
Configure
Before running ya2ro, you must configure it appropriately. Please add your GitHub personal token in ya2ro properties file. This needed if you want ya2ro
to extract your software metadata automatically. The file can be found at:
--> ~/ya2ro/src/ya2ro/resources/properties.yaml <--
Add a line like the following:
# Add here your GitHub personal access token
GITHUB_PERSONAL_ACCESS_TOKEN: xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
ya2ro will work if this is not configured, but is highly recommended to apply this setting, as the GitHub API has restricted access.
Test ya2ro installation
ya2ro --help
If everything goes fine, you should see:
ad888888b,
d8" "88
a8P
8b d8 ,adPPYYba, ,d8P" 8b,dPPYba, ,adPPYba,
`8b d8' "" `Y8 a8P" 88P' "Y8 a8" "8a
`8b d8' ,adPPPPP88 a8P' 88 8b d8
`8b,d8' 88, ,88 d8" 88 "8a, ,a8"
Y88' `"8bbdP"Y8 88888888888 88 `"YbbdP"'
d8'
d8'
_________________________________________________________
usage: ya2ro [-h] (-i YAML_PATH | -l YA2RO_PREV_OUTPUT) [-o OUTPUT_DIR] [-p PROPERTIES_FILE] [-ns]
Human and machine readable input as a yaml file and create RO-Object in jsonld and/or HTML view. Run 'ya2ro -configure GITHUB_PERSONAL_ACCESS_TOKEN' this the first time to configure ya2ro
properly
options:
-h, --help show this help message and exit
-i YAML_PATH, --input YAML_PATH
Path of the required yaml input. Follow the documentation or the example given to see the structure of the file.
-l YA2RO_PREV_OUTPUT, --landing_page YA2RO_PREV_OUTPUT
Path of a previous output folder using the ya2ro tool. This flag will make a landing page to make all the resources accessible.
-o OUTPUT_DIR, --output_directory OUTPUT_DIR
Output directory.
-p PROPERTIES_FILE, --properties_file PROPERTIES_FILE
Properties file name.
-ns, --no_somef Disable SOMEF for a faster execution (software cards will not work).
How to use
The first thing to do is create some input for ya2ro. To create valid a yaml you should follow the documentation bellow.
Create a yaml from scratch or use one of the supplied templates. Currently ya2ro supports two formats:
- paper
- project
Please find a template for each type under the directory templates. Once you have a valid yaml (project or paper) is time to run ya2ro.
Create machine and human readable content
It is possible to process batches of yamls at the same time, to do that just specify as input a folder with all the yamls inside.
Simple execution
ya2ro -i templates
ya2ro -i templates/project_template.yaml
With optional arguments
ya2ro -input templates --output_directory out --properties_file custom_properties.yaml
ya2ro -i templates -o out -p custom_properties.yaml
Faster execution?
Use the flag --no_somef or -ns for disabling SOMEF which is the most time consuming process.
ya2ro -i templates -ns
WARNING: Software cards will no longer work on github links. Therefore you will need to manually insert the software data in the yaml file.
Create landing page
ya2ro offers the option to create a landing page where all the resources produced are easily accessible. Just indicate the folder where this resources are, for example:
ya2ro -l output
Documentation
Please have a look at our documentation to know which metadata fields are supported by ya2ro
.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file ya2ro-0.0.4.tar.gz
.
File metadata
- Download URL: ya2ro-0.0.4.tar.gz
- Upload date:
- Size: 149.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0858030511cd124220fae18c9b2c30b0e71dcbe7133f47912ce1a7464c74ab43 |
|
MD5 | aa0242a069a0fcfaf3a5bd44524dc5f4 |
|
BLAKE2b-256 | bdfa1629bd77740843bb95cea7611db6416a2bfdebfaa306e9ca013c830492cf |
File details
Details for the file ya2ro-0.0.4-py3-none-any.whl
.
File metadata
- Download URL: ya2ro-0.0.4-py3-none-any.whl
- Upload date:
- Size: 151.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | b585338fb0a5c48a20e1a284ea864d7e3defdfdc3a6d15a08a0b3ea6df8d2fb0 |
|
MD5 | 1ac6bec23e3fed2737851fc8c97c934b |
|
BLAKE2b-256 | dc1b7a89bdf54ee1c56d3a1b265743ed712712e9d5259b480ebdec78454e9c40 |