Skip to content

Latest commit

 

History

History
205 lines (171 loc) · 12.7 KB

README.md

File metadata and controls

205 lines (171 loc) · 12.7 KB

O'FAIRe: Ontology FAIRness evaluator


O'FAIRe is a open source FAIRness assessment methodology and tool for ontologies, vocabularies and semantic resources developped within D2KAB and FooSIN projects. O'FAIRe comes as web service (implemented in Java) which executes tests automatically evaluating how a semantic resource stored within an ontology repositry responds to a set of FAIRness assessment questions.

We implemented O’FAIRe as a Web service working with any OntoPortal installations respecting the Metadata for Ontology Description and Publication Ontology (MOD1.4) metadata profile to harmonize metadata. We deployed it in AgroPortal and the SIFR BioPortal and designed specific user interfaces.

image

The documentation illustrates the web service with examples from AgroPortal. http://services.agroportal.lirmm.fr/ofaire/
The service can be deployed anywhere on Tomcat and can request any ontology repository based on the OntoPortal technology (however the scores will be function of the amount of metadata fields available).

Credits

Emna Amdouni (@eamdouniGIT), Syphax Bouazzouni (@syphax-bouazzouni) and Clement Jonquet (@jonquet) from LIRMM (University of Montpellier) and MISTEA (INRAE Montpellier). Your suggestions and comments are welcome. Thank you!

Cite us

E. Amdouni, S. Bouazzouni, C. Jonquet. O'FAIRe: Ontology FAIRness Evaluator in the AgroPortal semantic resource repository. International conference ESWC 2022. available on HAL (https://hal.archives-ouvertes.fr/lirmm-03630543/).

Main features

  • Assess each aspects of the 15 FAIR principles with 62 questions specific for ontologies and semantic reosurces.
  • Compute the FAIR score of one ontology or a list of ontologies.
  • Compute the average, min, median and max FAIR score of a list of ontologies.

General Usage

The Web service is requested with a simple HTTP GET witht he following base URL: http://services.agroportal.lirmm.fr/ofaire. For examples:

http://services.agroportal.lirmm.fr/ofaire?ontologies=AGRO

or

http://services.agroportal.lirmm.fr/ofaire?ontologies=ATOL,EOL,AHOL&combined

Web Service request mode

This web service can be used in three disctinct mode:

  • Requestiong the by default ontology repository on which the service is deployed with no specific parameters (examples above).
  • Requesting an external ontology repositrory independant of where O'FAIRe is deployed using the url and apikey parameters. For instance, with the NCI Thesaurus in the NCBO BioPortal:

http://services.agroportal.lirmm.fr/ofaire?url=https://data.bioontology.org&ontologies=NCIT&apikey={your API-KEY on the NCBO BioPortal}

  • Requesting an ontology repository pre-registered in O'FAIRe and for which FAIRness scores will be precomputed and cached), using the portal parameter. For instance, with the MDRFRE ontlogy in the SIFR BioPortal:

http://services.agroportal.lirmm.fr/ofaire?portal=bioportal&ontologies=MDRFRE

Web Service request parameters

Parameter Possible Values Description Mandatory
url a valid endpoint URL Specifies the repository web service API endpoint URL where the semantic resource is hosted e.g., https://data.bioontology.org/ or http://ecoportal.lifewatch.eu:8080/ no (but require apikey too if used)
apikey user apikey Specifies the user API-KEY to query the ontology repository where the semantic resource is stored. mandatory with url parameter and possible with the 2 other modes (it is preferred to provide a user API-KEY, but O'FAIRe will be default uses is own one)
portal agroportal , bioportal, stageportal (test environnement) Specifies the ontology repository pre-registered in O'FAIRe where the semantic resource is stored no
ontologies all or comma-separated list of acronyms (EX: EPHY,FCU) Specifies one or several semantic resources to process. Acronyms must be the ones provided by the requested ontology repository. yes
combined no value If present, in addition of the list of FAIR scores for each ontologies requested, O'FAIRe will also compute metrics for the group of ontologies requested (average, min, max and median no
sync no value If present, forces not to use the cache and recompute the FAIR scores. no

Web Service response

O'FAIRe returns a JSON with the following skeleton :

{
 "ontologies": { 
   "FCU": { // ontology acronym
     "Findable": { // FAIR principal
       "F1": { // Subprincipal
         "label": "Ontologies and ontology metadata are assigned a globally unique and persistent identifier. ",
         "results": {
          "F1Q1": {
                "question": "Does an ontology have a \"local\" identifier i.e., a globally unique and potentially persistent identifier assigned by the developer                               (or developing organization)?",
                "score": 9,
                "explanation": "Present and valid ontology URI.", //Score explanation
                "properties": {//List of properties used in the test with there values
                             "owl:ontologyIRI": "http://ontology.inrae.fr/frenchcropusage"
                },
                "maxCredits": 9,
                "points": [ //Array of possible scores and explanation for this question
                       {
                         "explanation": "Ontology URI is not present.",
                         "score": 0
                       },
                       {
                       "explanation": "Present but invalid ontology URI.",
                       "score": 3
                       },
                       {
                       "explanation": "Present and valid ontology URI.",
                       "score": 9
                       }
              ]
           },
           "F1Q2": {...},
           "F1Q3": {...},
           "F1Q4": {...},
           "F1Q5": {...},
           "F1Q6": {...},
           "F1Q7": {...},
         },
         "score": 12, // Subprincipal FAIR score
         "normalizedScore": 29, // Creiterion normalized FAIR score
         "maxCredits": 41, // Subprincipal theoretical max score 
         "portalMaxCredits": 35 // Subprincipal max points calculable with this version of API
       },
       "F2": {...},
       "F3": {...},
       "F4": {...},
       "score": 41, // Principle FAIR score
       "normalizedScore": 36, // Principle normalized FAIR score
       "maxCredits": 113, // Principle theoretical max score 
       "portalMaxCredits": 86 // Principle max points calculable with this version of API
     },
     "Accessible": {...},
     "Reusable": {...},
     "score": 248.46, // Ontology FAIR score
     "normalizedScore": 51,  // Ontology normalized FAIR score
     "maxCredits": 478, // Ontology theoretical max score 
     "executionTime": 90 // Ontology max points calculable with this version of API
   }
 },
 "status": { // operation meta-data
   "request": "http://service.agroportal.lirmm.fr?portal=stageportal&ontologies=FCU", // original request
   "success": true,
   "executionTime": 959,
   "endpoint": "http://data.agroportal.lirmm.fr",
   "useCache": true
 }
}

Each score in the result set comes with:

  • maxCredits, the maximum score for this principle or sub-principles as defined by O'FAIRe methodology;
  • portalMaxCredits, the maximum score that can be obtained in AgroPortal with urrent O'FAIRe implementation;
    portalMaxCredits = maxCredits => Some FAIRness assessment questions have not been (or cannot be) fully implemented.
  • normalizedScore, the score normalized betweem 0 and 100.
    normalizedScore = (score / maxCredits) * 100

O'FAIRe methodology and configuration

  • O'FAIRe is based on a FAIRness assessment grid defined in "FAIR or FAIRer? An integrated quantitative FAIRness assessment grid for semantic resources and ontologies".

  • O’FAIRe implementation relies on the ontology metadata description as returned by the ontology repository. For instance, the following call returns the description for the latest version of the Agronomy Ontology in JSON-LD: http://data.agroportal.lirmm.fr/ontologies/AGRO/latest_submission?display=all

  • O'FAIRe (v1) implements 62 FAIRness assessment questions, that project the FAIR principles for semantic resources. The questions are defined here: FAIR-Questions. To implemement each questions, we developped a set of Java functions to test how a semantic resources respond to the quesitons. We use most of the time metadata property values but alos sometimes relies directly on the features of the ontology repository.

Configuration files include:

  • questions.config.json defining the FAIRness assement questions with their possible credits, metadata property used (if any) and possible explanations.
  • properties.config.json defining the correspondences betweem MOD1.4 properties and AgroPortal's metadata model as well as the type (String or Array) and the object in AgroPortal where the proprety is available.
  • metadata.voc.config.json defining a list of standards metadata vocabularies (e.g., OWL,DC,RDFS), used in I2Q7.
  • catalogs.config.json defining a list of open ontology repositories and libraries, used in F4Q1 and F4Q2.

Latest results on AgroPortal ontology corpus

The latest results obtained over AgroPortal semantic resources is here : FAIR-Results

Local installation

O'FAIRe is open source and can be modified and/or installed locally:

1- Prerequisites

  • Tomcat server >= 7 running
  • Java >= 8

2- Clone this projet

      git clone [email protected]:agroportal/fairness.git

3- Configuration

Portal configuration is required by the portal parameter. File is available in config/portals/{portal_name}/config.properties:

    name=BioPortal #The name of the portal
    url=http://data.bioportal.lirmm.fr #A valid endpoint URL
    apikey=<your_api_key> #The API-KEY of an user on this repository 
    adminApikey= <your_admin_apikey> #The API-KEY of an admin user on this repository used for creating the cache
    cacheFilePath=<your_path> #The path where to save the cache 
    cacheEnabled=true # enable or disable the cache globaly

Change the apikey, adminApikey and cacheFilePath in config.properties.example with the corresponding infos , and rename it to config.properties

4- Build the project

5- Deploy the war file in the Tomcat server

Simply drop the war file into the $CATALINA_HOME\webapps directory of any Tomcat instance. If the instance is running, the deployment will start instantly as Tomcat unpacks the archive and configures its context path. If the instance is not running, then the server will deploy the project the next time it is started.

6- Create the SERVER_DEFAULT_PORTAL env variable

Add the SERVER_DEFAULT_PORTAL env variable, by adding this line export SERVER_DEFAULT_PORTAL='{portal_name}’ to this file /usr/share/tomcat/conf/conf.d/java_opts.conf

7- (Optional) Create a cron job to daily update cache files

The following command programs an update of the cache every day at midnight

  0 0 * * * /srv/ontoportal/tomcat/fairness/current/cron/cache_rest.sh /usr/share/tomcat/webapps/fairness-assessment

To add this job to the local system, execute the command crontab -e , it opens a text file, press "i" to go to insert mode, copy the above command. Then press "Esc" and type ":wq" to save and exit.