Copyright (C) 2019 Johns Hopkins University
This software is distributed under the terms of the Apache License, Version 2.0. See the file "LICENSE" for more information.
FOLIO compatible A-Z Database module.
Provides PostgreSQL based storage to implement an A-Z Database module. Written in Java, using the raml-module-builder and uses Maven as its build system.
- Java 8 JDK
- Maven 3.3.9
- Postgres 9.6.1 (running and listening on localhost:5432, logged in user must have admin rights)
Download and Install Intellij
brew install maven
brew install jetty
brew install jenv
You will need a JDK that includes tools.jar since this project uses the AspectJ maven plugin.
You can download Amazon's JDK at 
https://docs.aws.amazon.com/corretto/latest/corretto-8-ug/macos-install.html
jenv add /Library/Java/JavaVirtualMachines/amazon-corretto-8.jdk/Contents/Home/
jenv global 1.8
If you haven't already, enable the maven and export plugins:
jenv enable-plugin maven
jenv enable-plugin export
Update bash settings
java -jar target/mod-oriole-fat.jar
Postgres setup
exec java "$JAVA_OPTS" -jar ${VERTICLE_HOME}/module.jar "$@"
Main class: org.folio.rest.RestLauncher
Project Arguments: run org.folio.rest.RestVerticle db_connection=/Users/amanda/oriole/mod-oriole-archive/postgres-conf.idea.json
Working Dir: /[your path to]/mod-oriole
Use classpath of module: mod-oriole
JDK: Default 1.8
Be sure to include submodules since there are some common RAML definitions that are shared between FOLIO projects via Git submodules:
git clone --recurse-submodules -j8 git@github.com:jhu-sheridan-libraries/mod-oriole.git
- Follow the steps here: https://wiki.library.jhu.edu/display/ULCSS/Docker+-+software+containerization+platform
run mvn install
from the root directory.
The above command will compile, test and create a fat-jar file in the target
directory.
To just run tests,
mvn test
To run the fat jar file directly, with embedded postresql:
java -jar target/mod-oriole-fat.jar embed_postgres=true
First set up PostgreSQL and create database and role.
On Mac, start psql client:
psql postgres
Create role and database
CREATE ROLE folio WITH PASSWORD 'folio' LOGIN SUPERUSER;
CREATE DATABASE folio WITH OWNER folio;
Create a postgres-conf.json file, and use it as the connection conf.
cat > /tmp/postgres-conf.json <<END
{
"host": "localhost",
"port": 5432,
"username": "folio",
"password": "folio",
"database": "folio"
}
END
Start the fat jar with the db_connection option.
java -jar target/mod-oriole-fat.jar db_connection=/tmp/postgres-conf.json
Try the following and you should get a 401 response.
curl -D - -w '\n' -H "X-Okapi-Tenant: test" http://localhost:8081/oriole-libraries
The output would be like:
HTTP/1.1 500 Internal Server Error
Content-Type: text/plain
host: localhost:8081
user-agent: curl/7.54.0
accept: */*
x-okapi-tenant: test
Transfer-Encoding: chunked
This is because the module hasn't been initialized. Keep reading for more command line options.
The following examples are for interactions with the API when using the far jar file.
First you need to initialize the module. This will create a database table for this module and the tenant. Future CRUD operations from the same tenant will be based on that database table.
curl -X "POST" "http://localhost:8081/_/tenant" \
-H 'X-Okapi-Tenant: diku' \
-H 'Content-Type: application/json' \
-H 'Accept: application/json' \
-d $'{
"module_to": "mod-oriole-1.0"
}'
The output is like the following:
HTTP/1.1 201 Created
Content-Type: application/json
host: localhost:8081
user-agent: curl/7.54.0
accept: */*
x-okapi-tenant: diku
content-length: 31
Transfer-Encoding: chunked
"[ ]"
To fetch the resources, use this command:
curl "http://localhost:8081/oriole/resources" \
-H 'X-Okapi-Tenant: diku' \
-H 'Accept: application/json'
The results would be:
HTTP/1.1 200 OK
Transfer-Encoding: chunked
Content-Type: application/json
x-okapi-tenant: diku
accept: application/json
host: localhost:8081
Connection: close
{
"resources" : [ ],
"totalRecords" : 0,
"resultInfo" : {
"totalRecords" : 0,
"facets" : [ ],
"diagnostics" : [ ]
}
}
Note that it returns a 200 response, instead of the 500 error earlier in the Getting Started section. This is because the database table has been created for this tenant and this module. There are no records found because we haven't post any resources in the database yet.
To create a new resource, use this command:
curl -X "POST" "http://localhost:8081/oriole/resources" \
-H 'X-Okapi-Tenant: diku' \
-H 'Content-Type: application/json' \
-H 'Accept: application/json' \
-d $'{
"id": "c7b8911a-6983-11ea-bc55-0242ac130003",
"title": "PubMed",
"description": "PubMed lists journal articles and more back to 1947. It indexes about 5,400 journals and covers the areas of medicine, nursing, dentistry, veterinary medicine, health care systems, preclinical sciences, and related areas. PubMed also links to online books and to most of the other NCBI databases. PubMed is a free database developed by the National Library of Medicine (NLM) and the National Center for Biotechnology Information (NCBI), both at the National Institutes of Health (NIH) in Bethesda, MD.",
"url": "https://www.ncbi.nlm.nih.gov/pubmed/"
}'
The response should be a HTTP 201 response:
HTTP/1.1 201 Created
Transfer-Encoding: chunked
Content-Type: application/json
Location: /oriole/resources/c7b8911a-6983-11ea-bc55-0242ac130003
x-okapi-tenant: diku
accept: application/json
host: localhost:8081
content-length: 651
Connection: close
{
"id" : "c7b8911a-6983-11ea-bc55-0242ac130003",
"altId" : "JHU00002",
"url" : "https://www.ncbi.nlm.nih.gov/pubmed/",
"title" : "PubMed",
"description" : "PubMed lists journal articles and more back to 1947. It indexes about 5,400 journals and covers the areas of medicine, nursing, dentistry, veterinary medicine, health care systems, preclinical sciences, and related areas. PubMed also links to online books and to most of the other NCBI databases. PubMed is a free database developed by the National Library of Medicine (NLM) and the National Center for Biotechnology Information (NCBI), both at the National Institutes of Health (NIH) in Bethesda, MD.",
"identifier" : [ ],
"terms" : [ ],
"accessRestrictions" : [ ],
"availability" : [ ]
}
Try fetch again, and this time there should be one record found.
$ curl -D - -w '\n' -H "X-Okapi-Tenant: diku" -H "Accept: application/json" http://localhost:8081/oriole/resources
HTTP/1.1 200 OK
Transfer-Encoding: chunked
Content-Type: application/json
x-okapi-tenant: diku
accept: application/json
host: localhost:8081
user-agent: Paw/3.1.10 (Macintosh; OS X/10.15.3) GCDHTTPRequest
Connection: close
{
"resources" : [ {
"id" : "c7b8911a-6983-11ea-bc55-0242ac130003",
"altId" : "JHU00002",
"url" : "https://www.ncbi.nlm.nih.gov/pubmed/",
"title" : "PubMed",
"description" : "PubMed lists journal articles and more back to 1947. It indexes about 5,400 journals and covers the areas of medicine, nursing, dentistry, veterinary medicine, health care systems, preclinical sciences, and related areas. PubMed also links to online books and to most of the other NCBI databases. PubMed is a free database developed by the National Library of Medicine (NLM) and the National Center for Biotechnology Information (NCBI), both at the National Institutes of Health (NIH) in Bethesda, MD.",
"identifier" : [ ],
"terms" : [ ],
"accessRestrictions" : [ ],
"availability" : [ ]
} ],
"totalRecords" : 1,
"resultInfo" : {
"totalRecords" : 1,
"facets" : [ ],
"diagnostics" : [ ]
}
}
To fetch the resource by the ID (which is required to be a UUID), use the following:
curl "http://localhost:8081/oriole/resources/c7b8911a-6983-11ea-bc55-0242ac130003" \
-H 'X-Okapi-Tenant: diku' \
-H 'Accept: application/json'
The response would be like:
HTTP/1.1 200 OK
Transfer-Encoding: chunked
Content-Type: application/json
x-okapi-tenant: diku
accept: application/json
host: localhost:8081
Connection: close
{
"id" : "c7b8911a-6983-11ea-bc55-0242ac130003",
"altId" : "JHU00002",
"url" : "https://www.ncbi.nlm.nih.gov/pubmed/",
"title" : "PubMed",
"description" : "PubMed lists journal articles and more back to 1947. It indexes about 5,400 journals and covers the areas of medicine, nursing, dentistry, veterinary medicine, health care systems, preclinical sciences, and related areas. PubMed also links to online books and to most of the other NCBI databases. PubMed is a free database developed by the National Library of Medicine (NLM) and the National Center for Biotechnology Information (NCBI), both at the National Institutes of Health (NIH) in Bethesda, MD.",
"identifier" : [ ],
"terms" : [ ],
"keywords" : "c7b8911a-6983-11ea-bc55-0242ac130003 https://www.ncbi.nlm.nih.gov/pubmed/ JHU00002 PubMed PubMed lists journal articles and more back to 1947. It indexes about 5,400 journals and covers the areas of medicine, nursing, dentistry, veterinary medicine, health care systems, preclinical sciences, and related areas. PubMed also links to online books and to most of the other NCBI databases. PubMed is a free database developed by the National Library of Medicine (NLM) and the National Center for Biotechnology Information (NCBI), both at the National Institutes of Health (NIH) in Bethesda, MD.",
"accessRestrictions" : [ ],
"availability" : [ ]
}
Update the resource with this command:
curl -X "PUT" "http://localhost:8081/oriole/resources/c7b8911a-6983-11ea-bc55-0242ac130003" \
-H 'X-Okapi-Tenant: diku' \
-H 'Content-Type: application/json' \
-H 'Accept: application/json' \
-d $'{
"id": "c7b8911a-6983-11ea-bc55-0242ac130003",
"title": "PubMed",
"description": "short description...",
"url": "https://www.ncbi.nlm.nih.gov/pubmed/"
}'
The response would look like:
HTTP/1.1 204 No Content
x-okapi-tenant: diku
accept: application/json
host: localhost:8081
Connection: close
curl -X "DELETE" "http://localhost:8081/oriole/resources/c7b8911a-6983-11ea-bc55-0242ac130003" \
-H 'X-Okapi-Tenant: diku' \
-H 'Accept: application/json'
It returns a HTTP 204 response
HTTP/1.1 204 No Content
x-okapi-tenant: diku
accept: application/json
host: localhost:8081
Connection: close
See wiki page: Package and publish docker images
First start vagrant
vagrant up
Logon to the vagrant virtual box
vagrant ssh
Register the module
curl -w '\n' -D - -X POST -H "Content-type: application/json" -d @/vagrant/target/ModuleDescriptor.json http://localhost:9130/_/proxy/modules
Deploy it
curl -w '\n' -D - -s -X POST -H "Content-type: application/json" -d @/vagrant/target/DeploymentDescriptor.json http://localhost:9130/_/discovery/modules
Start the fat jar
cd /vagrant; java -jar /vagrant/target/mod-oriole-fat.jar db_connection=/vagrant/postgres-conf.json
Enable for a tenent
curl -w '\n' -X POST -D - -H "Content-type: application/json" -d@/vagrant/target/EnableModule.json http://localhost:9130/_/proxy/tenants/diku/modules
We need to run the following step manually.
curl -D - -w '\n' -H "X-Okapi-Tenant: diku" -H "Content-Type: application/json" -X POST -d '{"module_to": "mod-oriole-1.0-SNAPSHOT"}' http://localhost:8081/_/tenant
Add permissions
python3 scripts/add-permissions.py
Install the api-console command line tool using npm:
$ npm i -g api-console-cli
Generate the console for Oriole and EzProxy
$ api-console build -t "RAML 1.0" ./ramls/oriole.raml -o api-console/oriole
$ api-console build -t "RAML 1.0" ./ramls/ezprozy.raml -o api-console/ezproxy