CLI tool and SDK for interacting with the Cirro platform
Project description
Cirro Client
A Python 3.9+ library for the Cirro platform.
Installation
You can install Cirro using pip:
pip install cirro
or you can install the main branch of the repo by running:
pip install git+https://github.com/CirroBio/Cirro-client.git
Authentication
Upon first use, the Cirro client will ask you what Cirro instance to use and if you would like to save your login information. It will then give you a link to authenticate through the web browser.
You can change your Cirro instance by running cirro configure
and selecting the desired instance.
If you need to change your credentials after this point, and you've opted to save your login, please see the clearing saved login section.
Command Line Usage
Downloading a dataset:
Usage: cirro download [OPTIONS]
Download dataset files
Options:
--project TEXT Name or ID of the project
--dataset TEXT ID of the dataset
--data-directory TEXT Directory to store the files
-i, --interactive Gather arguments interactively
--help Show this message and exit.
Uploading a dataset:
Usage: cirro upload [OPTIONS]
Upload and create a dataset
Options:
--name TEXT Name of the dataset
--description TEXT Description of the dataset (optional)
--project TEXT Name or ID of the project
--process TEXT Name or ID of the ingest process
--data-directory TEXT Directory you wish to upload
-i, --interactive Gather arguments interactively
--help Show this message and exit.
Listing datasets:
Usage: cirro list-datasets [OPTIONS]
List available datasets
Options:
--project TEXT ID of the project
-i, --interactive Gather arguments interactively
--help Show this message and exit.
Interactive Commands
When running a command, you can specify the --interactive
flag to gather the command arguments interactively.
Example:
$ cirro upload --interactive
? What project is this dataset associated with? Test project
? Enter the full path of the data directory /shared/biodata/test
? Please confirm that you wish to upload 20 files (0.630 GB) Yes
? What type of files? Illumina Sequencing Run
? What is the name of this dataset? test
? Enter a description of the dataset (optional)
Python Usage
See the following set of Jupyter notebooks that contain examples on the following topics:
Jupyter Notebook | Topic |
---|---|
Introduction | Installing and authenticating |
Uploading a dataset | Uploading data |
Downloading a dataset | Downloading data |
Interacting with a dataset | Calling data and reading into tables |
Analyzing a dataset | Running analysis pipelines |
Using references | Managing reference data |
Advanced usage | Advanced operations |
R Usage
Jupyter Notebook | Topic |
---|---|
Downloading a dataset in R | Reading data with R |
Advanced Usage
View the API documentation for this library here.
Supported environment variables
Name | Description | Default |
---|---|---|
CIRRO_HOME | Local configuration directory | ~/.cirro |
CIRRO_BASE_URL | Base URL of the data portal |
Configuration
The cirro configure
command creates a file in CIRRO_HOME
called config.ini
.
You can set the base_url
property in the config file rather than using the environment variable.
The transfer_max_retries
configuration property specifies the maximum number of times to attempt uploading a file to Cirro in the event of a transfer failure.
When uploading files to Cirro, network issues or temporary outages can occasionally cause a transfer to fail.
It will pause for an increasing amount of time for each retry attempt.
The enable_additional_checksums
property manages the utilization of SHA-256 hashing for enhanced data integrity.
This feature computes the SHA-256 hash of a file during the upload process, and subsequently cross-validates it with the server upon completion.
When retrieving files, it ensures that the hash received matches the server's stored hash.
The default hashing algorithm for files is MD5. In many cases, MD5 is sufficient to ensure data integrity upon upload.
[General]
base_url = cirro.bio
transfer_max_retries = 15
enable_additional_checksums = true
Clearing saved login
You can clear your saved login information by removing the ~/.cirro/token.dat
file from your system or
by running cirro configure
and selecting No when it asks if you'd like to save your login information.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file cirro-1.2.7.tar.gz
.
File metadata
- Download URL: cirro-1.2.7.tar.gz
- Upload date:
- Size: 42.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.4 CPython/3.12.7 Linux/6.5.0-1025-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | d0d2755a5ae25f8079a13f921cfabe3d7405ae9c21fb7b00aaa61daf9d4d9400 |
|
MD5 | 95ce9e6c309e3d2e282ae85ccd0f80ba |
|
BLAKE2b-256 | 14101ccc43f29c8a913845a2e52a7daf773219fdcc7d23e77d6b95960885be7c |
File details
Details for the file cirro-1.2.7-py3-none-any.whl
.
File metadata
- Download URL: cirro-1.2.7-py3-none-any.whl
- Upload date:
- Size: 59.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.4 CPython/3.12.7 Linux/6.5.0-1025-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 44ed2bf60d38ac41973101addd8eb384a3bf187e9416444870625b5ed092cfce |
|
MD5 | ed247139eefe6f3461ce0449fd74995c |
|
BLAKE2b-256 | c92bdd0fb4f50b6f53b1f77b7c630413abba801e86ab28ed496e13c147011ace |