Skip to content

jmchilton/bdbag

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

bdbag

Build Status

Big Data Bag Utilities

The bdbag utilities are a collection of software programs for working with BagIt packages that conform to the Bagit 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.

These utilities combine various other components such as the Bagit-Python bag creation utility and the Bagit-Profiles-Validator utility into a single, easy to use software package.

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 remote file manifest entries and fetch.txt via configuration file.
  • Automatic file retrieval based on the contents of a bag's fetch.txt file with multiple protocol support.
  • Built-in 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.3 through 3.6.

Installation

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

pip install bdbag

Installation from Source

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:

python setup.py install --user

Note that if you want to make bdbag available to all users on the system, you should run the following command:

python setup.py install

If you are on a Unix-based system (including MacOSX) you should execute the above command as root or use sudo.

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

Configuration

See the Configuration guide.

Usage

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

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.

About

Big Data Bag Utilities

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Python 100.0%