Skip to main content

Generate a self-hosted backlog snapshot and dashboard for maintainers.

Project description

Backlog Atlas

PyPI Python versions Publish to PyPI License

Backlog Atlas generates a self-hosted backlog snapshot and static dashboard for GitHub repository maintainers.

It keeps GitHub Issues as the source of truth, derives backlog state from open issues and linked pull requests, and publishes the result to a dedicated backlog-atlas branch. The generated branch is machine-owned and can be served directly with GitHub Pages.

This repo's backlog dashboard: https://omry.github.io/backlog-atlas/

Documentation

  • User Guide — install Backlog Atlas on a repository, enable the web UI, run updates, and uninstall.
  • Maintainer Guide — local development, testing, packaging, and release prep for this package.
  • Design Note — how snapshots, diffs, and the update log fit together.
  • Changelog — user-facing release notes.
  • Standalone TODO — temporary publication checklist.

What It Produces

The backlog-atlas branch contains:

  • backlog.json — structured backlog data plus the recent activity tail used by the web UI.
  • updates.jsonl — append-only structured activity history.
  • last_snapshot.json — internal diff state for the next run.
  • index.html — the static dashboard.

The dashboard can also load a generated atlas.json manifest next to index.html and federate multiple public backlog.json files in the browser. Author the multi-repo source as YAML, then compile it to the browser manifest.

The default branch only needs the installed workflow, manifest, and config:

  • .github/workflows/update-backlog-atlas.yml
  • .github/backlog-atlas/manifest.json
  • .github/backlog-atlas/config.yaml — editable repository configuration

Quick Start

pip install backlog-atlas
cd /path/to/target-repo
backlog-atlas install --dry-run
backlog-atlas install

The dry run previews the files and install source before anything is written. Install is safe to rerun: it first removes old Backlog Atlas hooks/manifests and preserves config and generated dashboard history. When the previous install manifest lists bundled wheels, it writes a temporary cleanup workflow that removes those old wheels only after the new install lands. The manifest is the cleanup source of truth: it records installed files and which ones are removed only by clean uninstall. Review and push the install commit that Backlog Atlas creates, then enable GitHub Pages from the backlog-atlas branch. See the User Guide for the full local and remote install flows.

CLI

# install the workflow and manifest in a repository
backlog-atlas install [flags]

# remove installed hooks/manifests; --clean also removes config and branch
backlog-atlas uninstall [flags]

# write the static web UI files for preview or packaging
backlog-atlas dump-web --output PATH

# compile YAML multi-repo config into atlas.json for the browser UI
backlog-atlas dump-atlas --config atlas.yaml --output PATH

# manage repos tracked by .github/backlog-atlas/atlas.yaml
backlog-atlas atlas list
backlog-atlas atlas add owner/name [--backlog-url URL]
backlog-atlas atlas remove owner/name

# refresh backlog data; normally run by the installed GitHub Action
backlog-atlas update [flags]

# explain how one issue is classified by the active config
backlog-atlas classify ISSUE_NUMBER [--repo URL]

Development Checks

Maintainers can install local check tools with:

python -m pip install -e ".[dev]"
python -m black --check backlog_atlas tests tools
python -m pyflakes backlog_atlas tests tools
python -m mypy
python -m pytest

See the Maintainer Guide for the full development workflow.

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 Distribution

backlog_atlas-0.13.tar.gz (62.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

backlog_atlas-0.13-py3-none-any.whl (51.8 kB view details)

Uploaded Python 3

File details

Details for the file backlog_atlas-0.13.tar.gz.

File metadata

  • Download URL: backlog_atlas-0.13.tar.gz
  • Upload date:
  • Size: 62.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for backlog_atlas-0.13.tar.gz
Algorithm Hash digest
SHA256 9929e3d19d170432b6201ed281dce93e3bbd673a994b4c0023868cdd25995e7f
MD5 c71c2f7e3815a3ba020e84011a58980d
BLAKE2b-256 24cad2b4105e2f6f626e5342c2b032afc98b059e6a4616af7da335ce366b4c00

See more details on using hashes here.

Provenance

The following attestation bundles were made for backlog_atlas-0.13.tar.gz:

Publisher: publish.yml on omry/backlog-atlas

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file backlog_atlas-0.13-py3-none-any.whl.

File metadata

  • Download URL: backlog_atlas-0.13-py3-none-any.whl
  • Upload date:
  • Size: 51.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for backlog_atlas-0.13-py3-none-any.whl
Algorithm Hash digest
SHA256 ce215d9c002c03f56b67248ad625e663fb6d50d49d17b8af87f49fde8dd7f74e
MD5 e3655996fc18106c4b7e3feef4788d54
BLAKE2b-256 af86072817786b209d88cea716bf3d3bac8b78a08c2c14bb20059a5664c015bb

See more details on using hashes here.

Provenance

The following attestation bundles were made for backlog_atlas-0.13-py3-none-any.whl:

Publisher: publish.yml on omry/backlog-atlas

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page