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
backlog-atlas atlas install --delivery pr|push
backlog-atlas atlas install --local --checkout-root PATH

# 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.15.tar.gz (68.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.15-py3-none-any.whl (55.5 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: backlog_atlas-0.15.tar.gz
  • Upload date:
  • Size: 68.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.15.tar.gz
Algorithm Hash digest
SHA256 a995234de70f700a51615d252afb348d1858bffd7797440752dd6bfb507ba294
MD5 27b0db72365f3d112dd215ce771ed31c
BLAKE2b-256 f45b77d6ed47a3a0bf413302bd70f427391eb65bc18a53ce209c4f07b9d6447a

See more details on using hashes here.

Provenance

The following attestation bundles were made for backlog_atlas-0.15.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.15-py3-none-any.whl.

File metadata

  • Download URL: backlog_atlas-0.15-py3-none-any.whl
  • Upload date:
  • Size: 55.5 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.15-py3-none-any.whl
Algorithm Hash digest
SHA256 ef551eae20cb5e7064b917c5c07df90f499fc0408a4fd7534c7780829bf32219
MD5 955b5945833f02860a33a25626324569
BLAKE2b-256 94a96b5232c51296ab30c6be35f7704e896f55a4b5c03532b42a447f0d60d752

See more details on using hashes here.

Provenance

The following attestation bundles were made for backlog_atlas-0.15-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