Skip to main content

Unified storage interface.

Project description

fw-storage

Unified file storage interface tuned for simple filtering, memory-efficiency and performance to support processing large datasets in Flywheel imports and exports.

Supported storage backends:

  • fs:// - Local file-system
  • s3:// - Amazon S3
  • gs:// - Google Cloud Storage
  • az:// - Azure Blob Storage

Installation

Add as a poetry dependency to your project:

poetry add fw-storage

The local file-system storage backend has no extra package dependencies. To use any other backend, though, fw-storage needs to be installed with extras. For example, in order to access S3:

poetry add fw-storage --extras s3

Alternatively, install with all extras to get everything:

poetry add fw-storage --extras all

Usage

from fw_storage import get_storage

# instantiate storage with URL
fs = get_storage("fs:///tmp")

# set objects from bytes, filepaths or open files
fs.set("test/file1.dat", b"content")
fs.set("test/file2.dat", "/tmp/test/file1.dat")
fs.set("test/file3.dat", open("/tmp/test/file2.dat"))

# list objects, filtering with expressions
files = list(fs.ls("test", include=["size<1kB"], exclude=["path!~file3"]))
len(files) == 2

# get object info with path, size, created and modified
info = fs.stat("test/file1.dat")
info.size == 7

# read object contents
file = fs.get("test/file1.dat")
file.read() == b"content"

# remove one or more objects
fs.rm("test", recurse=True)

Configuration

Credentials for cloud storage providers are loaded using the vendor SDKs to support every standard config file location and environment variable recommended by the provider:

Storage Config docs
s3:// https://boto3.amazonaws.com/v1/documentation/api/latest/guide/credentials.html
gs:// https://google-auth.readthedocs.io/en/latest/reference/google.auth.html
az:// https://docs.microsoft.com/en-us/python/api/azure-identity/azure.identity.defaultazurecredential

In addition, az:// can be configured with the envvar AZ_ACCESS_KEY.

Development

Install the project using poetry and enable pre-commit:

poetry install -E all
pre-commit install

License

MIT

Project details


Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

fw_storage-1.5.5-py3-none-any.whl (30.9 kB view details)

Uploaded Python 3

File details

Details for the file fw_storage-1.5.5-py3-none-any.whl.

File metadata

  • Download URL: fw_storage-1.5.5-py3-none-any.whl
  • Upload date:
  • Size: 30.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.2.2 CPython/3.10.7 Linux/5.4.202+

File hashes

Hashes for fw_storage-1.5.5-py3-none-any.whl
Algorithm Hash digest
SHA256 bda327d18fad6644ee36a5000ae90bc369e748b6887ea6ddb16093efaea6d043
MD5 8df887cf675da03d969771c122e500ee
BLAKE2b-256 9dd9be78361e5c04cfa1e9b3ee44f8b67ea87909c25b05530e8bea8ddcd45fc4

See more details on using hashes here.

Provenance

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