S3 git filter for Peagen using s3fs
Project description
Swarmauri Git Filter S3FS
Git filter implementation for Peagen that streams artifacts to Amazon S3 (or
S3-compatible services) through s3fs. The filter registers as a
StorageAdapter named S3FSFilter and supports the full git clean/smudge
cycle by delegating reads and writes to the configured S3 bucket.
Features
- Implements :class:
~swarmauri_base.storage.StorageAdapterBaseand :class:~swarmauri_base.git_filters.GitFilterBaseto provide streaminguploadanddownloadoperations. - Recursively uploads local directories via
upload_dirand reconstructs prefixes back onto disk withdownload_prefix. - Lists existing objects under a prefix with
iter_prefixto back git history reconstruction. - Reads configuration from
peagen.toml([storage.filters.s3fs]) or theAWS_*environment variables when instantiated through :meth:S3FSFilter.from_uri.
Installation
Install the package with your preferred Python packaging tool:
pip install swarmauri_gitfilter_s3fs
poetry add swarmauri_gitfilter_s3fs
uv pip install swarmauri_gitfilter_s3fs
Configuration
Create the filter by supplying your bucket name and optional connection parameters:
bucket– Target bucket name (required).prefix– Optional key prefix to scope uploads.key/secret– Credentials for the S3 endpoint.SecretStrinstances are supported.endpoint_url– Custom S3-compatible endpoint (useful for MinIO or LocalStack).region_name– Region for the endpoint.
When using :meth:S3FSFilter.from_uri, the URI sets the bucket and
prefix while credentials are loaded from peagen.toml at
[storage.filters.s3fs] (key, secret, endpoint_url, and
region). Missing configuration falls back to
AWS_ACCESS_KEY_ID, AWS_SECRET_ACCESS_KEY, AWS_ENDPOINT_URL, and
AWS_REGION respectively.
Usage
The example below patches s3fs with an in-memory stub so it can run without
network access. The logic mirrors how S3FSFilter writes data to S3 and
returns the URI of the uploaded object.
from contextlib import nullcontext
from io import BytesIO
from unittest.mock import MagicMock, patch
from swarmauri_gitfilter_s3fs import S3FSFilter
with patch("swarmauri_gitfilter_s3fs.s3fs_filter.s3fs.S3FileSystem") as fs_cls:
fake_fs = MagicMock()
buffer = BytesIO()
fake_fs.open.return_value = nullcontext(buffer)
fs_cls.return_value = fake_fs
filt = S3FSFilter.from_uri("s3://demo-bucket/models")
location = filt.upload("artifacts/model.bin", BytesIO(b"model-weights"))
assert location == "s3://demo-bucket/models/artifacts/model.bin"
fake_fs.open.assert_called_with(
"demo-bucket/models/artifacts/model.bin",
"wb",
)
assert buffer.getvalue() == b"model-weights"
In a production workflow you do not need to patch s3fs – instantiate the
filter with your credentials and bucket, then use clean/smudge or
upload/download to move artifacts between git and S3.
Want to help?
If you want to contribute to swarmauri-sdk, read up on our guidelines for contributing that will help you get started.
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file swarmauri_gitfilter_s3fs-0.3.0.dev32.tar.gz.
File metadata
- Download URL: swarmauri_gitfilter_s3fs-0.3.0.dev32.tar.gz
- Upload date:
- Size: 8.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.10.3 {"installer":{"name":"uv","version":"0.10.3","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
19c8cf0e77e2ff0bcb2620cd16f7500a76aae29d4e8aa1e798ad51eafde01670
|
|
| MD5 |
24f3906239a240f3b2ceafc73c5614ae
|
|
| BLAKE2b-256 |
73d13523fc9f314c47048f1f1454ef83ba34ebc4ca7918cdbbc3e52824f1cedd
|
File details
Details for the file swarmauri_gitfilter_s3fs-0.3.0.dev32-py3-none-any.whl.
File metadata
- Download URL: swarmauri_gitfilter_s3fs-0.3.0.dev32-py3-none-any.whl
- Upload date:
- Size: 9.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.10.3 {"installer":{"name":"uv","version":"0.10.3","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9ddb0def03699f65a30651bc0ab1f27c7062fc571c2fc124ae336d8eaac01088
|
|
| MD5 |
95f947330fb47ddf60b5151f34439373
|
|
| BLAKE2b-256 |
8b0c8b4d7b989b0afc650225fbabbf4d3b80ad30d5064faac4f7afa4e0185b3d
|