CLI tool for uploading data to a centralised data platform.
There are currently two different deployments of the tool both published to PyPi:
- hca-util -- for uploading data to the HCA data platform
- covid-util -- for uploading data to the European COVID-19 data platform
Depending on which installation you use, replace XXX-util
with either hca-util
or covid-util
. Note that each tool deployment uses its own separate data storage and access credentials.
Users need to have
- Basic command-line knowledge
- Python3.x installed on their machine
- Credentials to access data in the S3 bucket (access and secret keys)
Get XXX-util
from PyPi.
$ pip install XXX-util
Display help
$ XXX-util -h
usage: XXX-util [-h] [--profile PROFILE]
{config,create,select,dir,clear,list,upload,download,delete}
In the above, optional arguments are between []
and choices between {}
.
The basic usage is as follows:
$ XXX-util cmd ARG1 ARG2 -o1 -o2
Use the tool by specifying a command (cmd
- see list below) to run, any mandatory (positional) arguments (e.g. ARG1
and ARG2
- see positional args for each command), and any optional arguments (e.g. -o1
and o2
- see options for each command).
help for a specific command:
$ XXX-util <command> -h
Some commands or options/flags are restricted to authorised users (for e.g. admin) only.
Configure AWS credentials
$ XXX-util config ACCESS_KEY SECRET_KEY
positional arguments:
ACCESS_KEY AWS Access Key ID
SECRET_KEY AWS Secret Access Key
By default, this tool looks for and uses the profile name XXX-util, if it exists, or it can be set by the config
command.
Running a command with the --profile
argument uses the specified profile instead of the default XXX-util profile.
Create an upload area (authorised users only)
$ XXX-util create NAME [-p {u,ud,ux,udx}]
positional arguments:
NAME name for the new area
optional arguments:
-n name optional project name for new area
-p {u,ud,ux,udx} allowed actions (permissions) on new area. u for
upload, x for delete and d for download. Default is ux
Select or show the active upload area
$ XXX-util select AREA
positional arguments:
AREA area uuid. If not present then selected area is shown
List contents of selected area
$ XXX-util list [-b]
optional arguments:
-b list all areas in bucket **(authorised users only)**
Upload files to the selected area
$ XXX-util upload (-a | -f file [file ...]) [-o]
optional arguments:
-a upload all files from current user directory
-f file [file ...] upload specified file(s)
-o overwrite files with same names
Download files from the selected area
$ XXX-util download (-a | -f file [file ...])
optional arguments:
-a download all files from selected area
-f file [file ...] download specified file(s) only
Delete files from the selected area
$ XXX-util delete (-a | -f file [file ...] | -d)
optional arguments:
-a delete all files from selected area
-f file [file ...] delete specified file(s) only
-d delete area and contents **(authorised users only)**
Download dependencies
pip install -r requirements.txt
Run
python3 -m util
Run tests
nosetests