Metadata-Version: 2.1
Name: morphic-util
Version: 0.0.8
Summary: CLI tool for uploading data to Morphic AWS S3 bucket
Home-page: https://github.com/ebi-ait/morphic-util
Author: hca-ingest-dev
Author-email: hca-ingest-dev@ebi.ac.uk
License: Apache License
Description: # morphic-util
        
        CLI tool for uploading data to the Morphic AWS S3 buckets.
        
        # Users
        
        ## Prerequisites
        
        Users need to have
        
        1. Basic command-line knowledge
        2. Python3.x installed on their machine
        3. AWS Cognito username and password
        
        ## Install
        
        The [morphic-util](https://pypi.org/project/morphic-util/) tool is available to install from PyPi.
        
        ```shell script
        $ pip install morphic-util
        ```
        
        ## Usage
        
        Display help and list of commands.
        
        ```shell script
        $ morphic-util -h
        usage: morphic-util [-h] [--version] [--profile PROFILE] {config,create,select,list,upload,download,delete} ...
        
        morphic-util
        
        optional arguments:
          -h, --help            show this help message and exit
          --version, -v         show program's version number and exit
        
        command:
          {config,create,select,list,upload,download,delete}
            config              configure AWS credentials
            create              create an upload area (authorised users only)
            select              select or show the active upload area
            list                list contents of the area
            upload              upload files to the area
            download            download files from the area
            delete              delete files from the area
        ```
        
        In the above, optional arguments are between `[]` and choices between `{}`.
        
        The basic usage is as follows:
        
        ```shell script
        $ morphic-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).
        
        ## Commands
        
        Help with specific command:
        
        ```shell script
        $ morphic-util <cmd> -h
        ```
        
        Some commands or options/flags are restricted to authorised users (admin) only.
        
        ## `config` command
        
        Configure AWS credentials
        
        ```shell script
        $ morphic-util config username password
        
        positional arguments:
          username         AWS Cognito username
          password         AWS Cognito password
        ```
        
        The tool uses the profile name _hca-util_ in local AWS config files.
        
        ## `create` command
        
        Create an upload area/ project folder **(authorised users only)**
        
        ```shell script
        $ morphic-util create NAME DPC [-p {u,ud,ux,udx}]
        
        positional arguments:
          NAME               name for the new area/ project folder
          DPC                center name of the submitter
        
        optional arguments:
          -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` command
        
        Show or select the active upload area/ project folder
        
        ```shell script
        $ morphic-util select AREA
        
        positional arguments:
          AREA                area name/ folder name. 
        ```
        
        If AREA is not specified, the selected area is shown.
        
        ## `list` command
        
        List contents of selected area
        
        ```shell script
        $ morphic-util list [-b]
        
        optional arguments:
          -b                 list all areas in bucket **(authorised users only)**
        ```
        
        ## `upload` command
        
        Upload files to the selected area
        
        ```shell script
        $ morphic-util upload PATH [PATH ...] [-o]
        
        positional arguments:
          PATH               valid file or directory
        
        optional arguments:
          -o                  overwrite files with same names
        ```
        
        ## `download` command
        
        Download files from the selected area **(authorised users only)**
        
        ```shell script
        $ morphic-util download (-a | -f file [file ...])
        
        optional arguments:
          -a                  download all files from selected area
          -f file [file ...]  download specified file(s) only
        ```
        
        ## `delete` command
        
        Delete files from the selected area
        
        ```shell script
        $ morphic-util delete [-a | -d] [PATH [PATH ...]]
        
        positional arguments:
          PATH               path to file or directory to delete
        
        optional arguments:
          -a                 delete all files from the area
          -d                 delete upload area and contents (authorised users only)
        ```
        
        # Developers
        
        Download dependencies
        
        ```
        pip install -r requirements.txt
        ```
        
        Run tests
        
        ```shell script
        nosetests
        ```
        
Platform: MacOS X
Platform: Posix
Classifier: License :: OSI Approved :: Apache Software License
Classifier: Operating System :: MacOS :: MacOS X
Classifier: Operating System :: POSIX
Classifier: Programming Language :: Python :: 3.6
Classifier: Programming Language :: Python :: 3.7
Requires-Python: >=3.6
Description-Content-Type: text/markdown
