GitHub release backed git filter for Peagen
Project description
Swarmauri Git Filter GitHub Release
Store artifacts in GitHub Releases.
Overview
swarmauri_gitfilter_gh_release provides the GithubReleaseFilter, a StorageAdapter and GitFilter hybrid that manages Peagen artifacts as assets attached to a GitHub Release. It:
- Connects to the configured organization, repository, and release tag using PyGithub.
- Creates the release on-demand if it does not already exist.
- Normalizes object keys with an optional prefix, exposing the release contents as a virtual directory via
root_uri. - Uploads and replaces release assets atomically, allowing you to store binary artifacts without worrying about duplicates.
- Supports directory workflows with
upload_dir,iter_prefix, anddownload_prefixhelpers for batch operations.
Authentication & configuration
The filter authenticates using a GitHub token sourced from your .peagen.toml or the GITHUB_TOKEN environment variable. The token needs permissions to read and write releases in the target repository.
Example .peagen.toml snippet:
[storage.filters.gh_release]
token = "$GITHUB_TOKEN"
You can also set the environment variable directly:
export GITHUB_TOKEN="ghp_..."
Installation
pip
pip install swarmauri_gitfilter_gh_release
uv
curl -Ls https://astral.sh/uv/install.sh | sh
uv pip install swarmauri_gitfilter_gh_release
Poetry
poetry add swarmauri_gitfilter_gh_release
Usage
from swarmauri_gitfilter_gh_release import GithubReleaseFilter
filt = GithubReleaseFilter.from_uri("ghrel://org/repo/tag/artifacts")
print(filt.root_uri)
The example above resolves the release (creating it if necessary) and prints the normalized root URI (ghrel://org/repo/tag/artifacts/).
Managing artifacts
GithubReleaseFilter mirrors GitHub release assets onto local paths. Each method accepts keys relative to the virtual root defined by the release tag and optional prefix:
upload(key, data)uploads a file-like object and replaces existing assets that share the same key.download(key)streams a release asset back as aBytesIOobject for inspection or local persistence.upload_dir(path, prefix="")walks a directory tree and pushes each file into the release using the provided prefix.iter_prefix(prefix)yields keys that start with the supplied prefix, allowing selective sync logic.download_prefix(prefix, dest_dir)restores a tree of assets into a target directory on disk.
Combine these helpers to move trained models, prompts, or configuration bundles between local development and persistent release storage while keeping file layouts consistent.
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_gh_release-0.3.0.dev43.tar.gz.
File metadata
- Download URL: swarmauri_gitfilter_gh_release-0.3.0.dev43.tar.gz
- Upload date:
- Size: 8.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.10.12 {"installer":{"name":"uv","version":"0.10.12","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 |
40e239956c6d0f2555d4b4cb18ca5807b420d878c05ef2886474e6dd8f323b9f
|
|
| MD5 |
3f5d50637514d9db36de15598ee3c25e
|
|
| BLAKE2b-256 |
28ba3ad666f9a0c78cfbd0a1d40760d76d2c1914fdf76bdfc5c85d9465af47ab
|
File details
Details for the file swarmauri_gitfilter_gh_release-0.3.0.dev43-py3-none-any.whl.
File metadata
- Download URL: swarmauri_gitfilter_gh_release-0.3.0.dev43-py3-none-any.whl
- Upload date:
- Size: 9.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.10.12 {"installer":{"name":"uv","version":"0.10.12","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 |
f53a4fe9143ebb973d2200a344d3d906c42156082be0ef15e66b494a5975a252
|
|
| MD5 |
07346dad5eb62da09d522daf89507208
|
|
| BLAKE2b-256 |
d6cd6b78b93b96a5562f5388b98154e24ea58ab4a74c4d62b14ba74f048628f5
|