Skip to content

Latest commit

 

History

History
87 lines (64 loc) · 2.5 KB

README.md

File metadata and controls

87 lines (64 loc) · 2.5 KB

OCFL Tools

This repository provides a command line tool (ocfl) for working with OCFL-based repositories. It supports basic operations for creating, accessing, and updating objects in an OCFL storage root:

Usage: ocfl <command> [flags]

tools for working with OCFL repositories

Flags:
  -h, --help           Show context-sensitive help.
  -r, --root=STRING    The prefix/directory of the OCFL storage root used for the command ($OCFL_ROOT)
      --debug          enable debug log messages

Commands:
  init-root    Create a new OCFL storage root
  commit       Create or update an object in a storage root
  export       Export object contents to the local filesystem
  diff         Show changed files between versions of an object
  info         Show information about an object or the active storage root
  ls           List objects in a storage root or files in an object
  log          Show an object's revision log
  validate     Validate an object or all objects in the storage root
  version      Print ocfl-tools version information

Run "ocfl <command> --help" for more information on a command.

Usage

S3 Configuration

To access OCFL storage roots on S3, set --root or $OCFL_ROOT with the bucket and prefix:

# set root with flag
ocfl ls --root="s3://my-bucket/my-root"

# OR set root with environment variable
export OCFL_ROOT="s3://my-bucket/my-root"
ocfl ls

The S3 client is configurable using AWS configuration files (e.g., ~/.aws/credentials) and environment variables:

export AWS_ENDPOINT_URL="..."
export AWS_REGION="..."
export AWS_ACCESS_KEY_ID="..."
export AWS_SECRET_ACCESS_KEY="..."

Path-style S3 requests are enabled by setting OCFL_S3_PATHSTYLE=true.

Installation

The CLI is distributed in an Ubuntu-based docker image: docker.io/srerickson/ocfl-tools

# start container shell with mounted data volume
docker run -it -v /tmp:/data docker.io/srerickson/ocfl-tools
# run `ocfl`
ocfl --help

You can also build and install ocfl locally using Go (v1.23 or greater):

go install github.com/srerickson/ocfl-tools/cmd/ocfl@latest

Development

Testing with S3

To enable S3 tests, set $OCFL_TEST_S3:

# example using minio
export OCFL_TEST_S3="http://127.0.0.1:9000"
export AWS_SECRET_ACCESS_KEY=...
export AWS_ACCESS_KEY_ID=...
go test ./...