RESTful HTTP-API for the B2STAGE service inside the EUDAT project
This is a reference page to quick start your knowledge of the project.
The quickest way to deploy or develop the current project state is to test online our prototype. Also see the dedicated instructions. Please feel free to report or comment to help us improve!
If you feel comfortable with a terminal shell you could spin your first instace easily. Please head to the pre-requisites page first, to make sure your current machine is qualified to host the project.
NOTE: DO NOT run this instructions as administrator. Please make sure you are not the root
user (e.g. with the whoami
command); this behaviour is not allowed by the rapydo
framework.
Here’s step-by-step tutorial to work with the HTTP API project:
################
# get the code
git clone https://github.com/EUDAT-B2STAGE/http-api.git latest
cd latest
################
# install the corrensponding rapydo framework version
sudo pip3 install rapydo-controller
rapydo --project b2stage install --git 0.6.7
# build and run
rapydo --project b2stage init
rapydo --project b2stage start
################
# only required in debug mode
rapydo --project b2stage shell backend --command 'restapi launch'
If everything worked so far you may now try a test against your own server:
# from another shell
$ curl -i localhost:8080/api/status
HTTP/1.0 200 OK
Content-Type: application/json
Access-Control-Allow-Origin: *
Content-Length: 185
Server: Werkzeug/0.12.2 Python/3.6.3
Date: Tue, 05 Dec 2017 15:56:40 GMT
{
"Meta": {
"data_type": "<class 'str'>",
"elements": 1,
"errors": 0,
"status": 200
},
"Response": {
"data": "Server is alive!",
"errors": null
}
}
The key difference to switch from debug to production mode
for the previuos commands is by passing the dedicated option to rapydo
, e.g. rapydo --mode production start
.
To ensure the option is always activated you can save it in a .projectrc
file:
# setup a rc file to save your preferred rapydo options
echo "project: b2stage" > .projectrc
echo "mode: production" >> .projectrc
echo "hostname: yourdomain.com" >> .projectrc # set a domain if you have one
You can override any of the project configuration variables, e.g. to set an external B2SAFE instance by including a project_configuration section into your .projectrc file.
project: b2stage
mode: production
hostname: yourdomain.com
project_configuration:
variables:
env:
IRODS_HOST: your.b2safe.host
You can now start your HTTP api server in production mode.
# remove containers in debug mode
rapydo remove
rapydo start # in production, thanks to the projectrc setup
# Hint: double check open ports 80 and 443 from the outside world
# issues a valid free SSL certificate with "Let's Encrypt"
rapydo ssl-certificate
# check your server is alive and running on HTTPS protocol
curl -i https://YOURDOMAIN.com/api/status
# check your swagger configuration with a browser
open http://petstore.swagger.io/?url=https://YOURDOMAIN.com/api/specs&docExpansion=none
Certificates issued using “Let’s encrypt” lasts 90 days. To make sure your certificate is always up-to-date you can setup a cron job to run every week.
# edit crontab
$ crontab -e
# add this line
30 0 * * 1 cd /path/to/httpapi/code && rapydo ssl-certificate
# runs every Monday at 00:30 AM
# to check later on about cron jobs executions:
less /var/log/cron
We implemented on the rapydo
cli tool all needed Docker (or Docker compose) typical actions to manage running containers: rapydo status
, rapydo stop
, rapydo remove
.
To get a list of all available commands you can use one of the following:
rapydo
rapydo --help
rapydo -h
Finally to dig more into details you may now head back to the index to read the other parts of the documentation.