layout | title | date_published | date_modified | author | maintainer |
---|---|---|---|---|---|
docpost |
Setting up Ocarina and OAuth |
2021-07-05 15:01:00 +0000 |
BioWilko |
BioWilko |
Read the instructions for how to register
Ocarina is a command line tool that is used to connect to Majora and perform actions with elevated privileges that are not possible on the website. It is not terribly difficult to use, but ideally you will have used a command line tool before.
You can install the latest version with the Python package manager. You will probably want to install it into a conda environment on the shared node.
conda create -n ocarina python=3.7
conda activate ocarina
pip install git+https://github.com/climb-covid/ocarina2.git
Please remember to check the ocarina changelog periodically and update your client as necessary.
Instructions to do this are located here. Only the first section is necessary to set up ocarina but must be done before moving to the next step.
Create a JSON file in your home directory named .ocarina
. Note the starting dot.
{"MAJORA_DOMAIN": "https://majora.covid19.climb.ac.uk/", "MAJORA_USER": "your-username", "MAJORA_TOKEN": "OAUTH", "CLIENT_ID": "your-client-id", "CLIENT_SECRET": "your-client-secret"}
Where:
MAJORA_DOMAIN
points to either the domain of the real, or test Majora. Do not miss the/
at the end of the URL.MAJORA_USER
is your username on the appropriate Majora instanceMAJORA_TOKEN
must be set toOAUTH
CLIENT_ID
is the ocarina Client ID registered with majora accessible at this majora pageCLIENT_SECRET
is the ocarina Secret ID registered with majora accessible at this majora page
OAuth has been the standard way to authenticate since September 2020.
OAuth tokens expire every 10 hours, instructions for refreshing tokens can be found in section 5 as well as how this can be automated
Generate a legacy API key if you haven't already.
Create a JSON file in your home directory named .ocarina
. Note the starting dot.
{"MAJORA_DOMAIN": "https://majora.covid19.climb.ac.uk/", "MAJORA_USER": "your-username", "MAJORA_TOKEN": "YOUR_API_KEY", "CLIENT_ID": "", "CLIENT_SECRET": ""}
Where:
MAJORA_DOMAIN
points to either the domain of the real, or test Majora. Do not miss the/
at the end of the URL.MAJORA_USER
is your username on the appropriate Majora instanceMAJORA_TOKEN
taken from this majora page
Some features (such as reading secure dataviews) are only available via OAuth authentification and will not work with the legacy API keys.
API keys expire every 3 days and must be renewed by following the legacy API key documentation
Activate your Ocarina conda environment
conda activate ocarina
Attempt to access a biosample with the following command
ocarina --oauth get biosample --central-sample-id *Insert COG ID here*
You should see a message asking you to 'request a grant'. Open the link (or copy it into your a browser on your local machine) to see an approval screen like this:
Then click "Authorize" to confirm that you have indeed requested an OAuth token and you should see a page which looks like this apart from the text boxes will be populated:
Now click the copy button next to the the upper text box to copy the callback URL.
Now paste the copied return URL into Ocarina which should now return your requested dataview.
Please note that this will not renew a legacy API key, that must be done by following the legacy API documentation
Now you have fully set up OAuth and Ocarina!
OAuth tokens expire after 10 hours after which you will have to generate a new token by following step 4 again. This can by avoided by refreshing your token with the command ocarina oauth refresh
.
Refreshing your OAuth token can be automated by using a cron job
scheduled to run at any interval < 10 hours for convenience, the example below will refresh your OAuth token every 6 hours.
To set this up first enter the commands below:
$ conda activate ocarina
$ which ocarina
/home/sam/miniconda3/envs/ocarina/bin/ocarina #This is my ocarina path make sure you use your own!
Then copy the resulting path.
Enter the command crontab -e
to edit your crontab and add the command below
0 0,6,12,18 * * * {YOUR_OCARINA_PATH} oauth refresh
Now you are ready to use Ocarina please see the following pages for more information: