Skip to main content

Big Data Bag Utilities

Project description

bdbag

Build Status Coverage Status PyPi Version PyPi Downloads PyPi Wheel Anaconda-Server Badge Anaconda-Server Badge Python Versions License

Big Data Bag Utilities

The bdbag utilities are a collection of software programs for working with BagIt packages that conform to the BDBag and Bagit/RO profiles.

The bdbag profiles specify the use of the fetch.txt file, require serialization, and specify what manifests must be provided with a bdbag.

The bdbag utilities incorporate functions from various other Python-based bagit components (such as the Bagit-Python bag creation utility and the Bagit-Profiles-Validator utility) and wraps them in a single, easy to use software package with additional features.

Enhanced bag support includes:

  • Update-in-place functionality for existing bags.
  • Automatic archiving and extraction of bags using ZIP, TAR, and TGZ formats.
  • Automatic generation of file manifest entries and fetch.txt for remote files via configuration file.
  • Automatic file retrieval based on the contents of a bag's fetch.txt file with multiple protocol support. Transport handlers for http(s),ftp,s3,gs, and globus are provided, along with an extensibility mechanism for adding externally developed transports.
  • Built-in bagit-profile validation.
  • Built-in support for creation of bags with Bagit/RO profile compatibility.

An experimental Graphical User Interface (GUI) for bdbag can be found here.

Technical Papers

"I'll take that to go: Big data bags and minimal identifiers for exchange of large, complex datasets" explains the motivation for BDBags and the related Minid construct, provides details on design and implementation, and gives examples of use.

"Reproducible big data science: A case study in continuous FAIRness" presents a data analysis use case in which BDBags and Minids are used to capture a transcription factor binding site analysis.

Dependencies

  • Python 2.7 is the minimum Python version required.
  • The code and dependencies are also compatible with Python 3, versions 3.5 through 3.9.

Installation

The latest bdbag release is available on PyPi and can be installed using pip:

pip install bdbag

Note that the above command will install bdbag with only the minimal dependencies required to run. If you wish to install bdbag with the extra fetch transport handler support provided by boto (for AWS S3) and globus (for Globus Transfer) packages, use the following command:

pip install bdbag[boto,globus]

Installation from Source

You can use pip to install bdbag directly from GitHub:

sudo pip install git+https://github.com/fair-research/bdbag

or:

pip install --user git+https://github.com/fair-research/bdbag

You can also download the current bdbag source code from GitHub or alternatively clone the source from GitHub if you have git installed:

git clone https://github.com/fair-research/bdbag

From the root of the bdbag source code directory execute the following command:

sudo pip install .

or:

pip install --user .

Note that if you want to install the extra dependencies from a local source directory you would use the following command:

pip install .[boto,globus]

Testing

The unit tests can be run by invoking the following command from the root of the bdbag source code directory:

python setup.py test

Usage

This software can be used from the command-line environment by running the bdbag script. For detailed usage instructions, see the CLI Guide.

Configuration

Some components of the bdbag software can be configured via JSON-formatted configuration files. See the Configuration Guide for further details.

Application Programming Interface

It is also possible to use bdbag from within other Python programs via an API. See the API Guide for further details.

Utilities

A CLI utility module is provided for various ancillary tasks commonly involved with authoring bdbags. See the Utility Guide for further details.

Change Log

The change log is located here.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

bdbag-1.6.1.tar.gz (1.3 MB view details)

Uploaded Source

Built Distribution

bdbag-1.6.1-py2.py3-none-any.whl (69.4 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file bdbag-1.6.1.tar.gz.

File metadata

  • Download URL: bdbag-1.6.1.tar.gz
  • Upload date:
  • Size: 1.3 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.7.0 requests/2.25.1 setuptools/53.0.0 requests-toolbelt/0.9.1 tqdm/4.56.2 CPython/3.7.7

File hashes

Hashes for bdbag-1.6.1.tar.gz
Algorithm Hash digest
SHA256 96188cf4e0bdff6c62e697dd8e41696c1b1a4202f21329b57f38a789b05397e7
MD5 7f60e383dbc79137c78c31e4b7942387
BLAKE2b-256 3f150cf73ac159c3ac0f33a6a927bbc4b214dceba50736a2cc71477848b15c08

See more details on using hashes here.

File details

Details for the file bdbag-1.6.1-py2.py3-none-any.whl.

File metadata

  • Download URL: bdbag-1.6.1-py2.py3-none-any.whl
  • Upload date:
  • Size: 69.4 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.7.0 requests/2.25.1 setuptools/53.0.0 requests-toolbelt/0.9.1 tqdm/4.56.2 CPython/3.7.7

File hashes

Hashes for bdbag-1.6.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 258b9a9b79f18f77a71f8c485e210737753d2afd6a99416d4d0682b48b08ba30
MD5 1436d47c0f02991b6b31c06564cc6e63
BLAKE2b-256 061ae04f3498d663be77f8a9240ee64289e7ec5a8580089c2ede64a04449f8b9

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page