cacher

S3-backed CI cache helper. A single static Go binary.

What it is

cacher is the build that the typical "check S3, fall back to upstream, upload for next time" shell loop should have been. It downloads, uploads, lists, and invalidates cached artifacts in any S3-compatible bucket — single files, docker images (via streamed save | zstd | s3), and whole directory trees keyed by lockfile hash. Built for builds.sr.ht; works anywhere you can run a binary and reach an S3 endpoint.

Download

Pre-built binaries for v0.1.2. The shipping URL is stable; the SHA-256s below are specific to this build — paste them into your pin if you care.

PlatformBinarySHA-256
linux/amd64 cacher-linux-amd64 95d02052b4125a4f4edaea4a0d7119aa589e01dbc4baa8778cfd2faf3ecec932
linux/arm64 cacher-linux-arm64 685df53170294c766cbcfbb2a5f0c1647c6cf8e6af4beac83c47007088dfaa51
darwin/amd64 cacher-darwin-amd64 6b6c3d97455b118eddcd7e41ad40e8b847af14448ee0d62229f2dd5f34f5d2d6
darwin/arm64 cacher-darwin-arm64 9ab5cb841bcb9de64445f3315b76c8d8f788fe26befe0d09e1e133cbf9717e26

All four hashes plus filenames are also available in a single checksums.txt for piping into sha256sum -c:

wget https://bigbes.pages.srht.bigb.es/ci-cacher/cacher-linux-amd64 \
  -O ~/.local/bin/cacher
chmod +x ~/.local/bin/cacher
wget -qO- https://bigbes.pages.srht.bigb.es/ci-cacher/checksums.txt \
  | sha256sum -c --ignore-missing

The loop it replaces

# before — install awscli, write ~/.aws/config, then in every task:
if aws s3api head-object --bucket "$B" --key "$K" >/dev/null 2>&1; then
  aws s3 cp "s3://$B/$K" "$out"
else
  curl -sSL "$url" -o "$out"
  aws s3 cp "$out" "s3://$B/$K"
fi
# after — one binary, one config, one command:
cacher download "$key" "$out" --url "$url"

Commands

Run cacher --help for the full surface. Read the README for usage patterns, Garage compatibility notes, and exit-code semantics.

Why

The shell version this replaced repeated five things in every CI task: install AWS CLI v2 (≈50 MB per build), write a Garage-tuned ~/.aws/config, compute cache keys from file content with sha256sum | cut, branch HIT/MISS by hand, and for docker images pipe docker save | zstd | aws s3 cp - (and the inverse). cacher collapses all of that into one fetched binary plus a config file. The directory caching is the genuinely new capability — the shell version only ever handled single files.

Changelog

All notable changes to this project will be documented in this file. The format is based on Keep a Changelog and this project adheres to Semantic Versioning.

Unreleased

0.1.2 — 2026-05-26

Changed

0.1.1 — 2026-05-26

Added

Changed

0.1.0 — 2026-05-26

First public release. Replaces the s3_cache_or_curl / s3_cache_docker_image shell helpers in tarantool-protobuf/.builds/lib/ci-lib.sh with a single static Go binary.

Added

Fixed

This build

Version
v0.1.2
Built
2026-05-26T05:51:47Z
Source
git.srht.bigb.es/~bigbes/ci-cacher
License
BSD-2-Clause