Skip to main content

Sync local planning files to GitHub Issues.

Project description

Planhub

Planhub is a CLI app that syncs local planning artifacts (plans, issues, milestones written as .md files) to GitHub Issues via the API.

Goals

  • Keep planning artifacts in git and reviewable.
  • Generate/update GitHub issues and milestones from local files.
  • Make planning conversational: we can edit .md files and sync later.

How It Works

Planhub keeps planning data next to the code it describes. Each repository gets a .plan/ folder containing milestones and issues as Markdown files with YAML front matter. You edit these files like normal docs, then planhub sync maps them to GitHub issues and milestones.

Installation

Global install from PyPI (recommended for CLI usage). pipx gives you a clean CLI install without polluting your system Python, and puts planhub on your PATH:

pipx install planhub

Project-local install with uv (inside your repo). This keeps the tool in a virtual environment for that repo:

uv venv
uv pip install planhub

First Run (Required)

Run planhub setup immediately after installation to create the global config at ~/.planhub/config.yaml (created only if missing):

planhub setup

Without this setup step, sync defaults and other CLI behavior may be missing.

Commands

  • planhub init
    • Creates the standard .plan/ structure in the current repo.
    • Use --dry-run to preview the folders that would be created.
  • planhub setup
    • Creates the global config file at ~/.planhub/config.yaml (if missing).
    • Use --dry-run to preview what would be created.
  • planhub issue <title>
    • Creates a new GitHub issue with the given title.
    • Requires credentials and a GitHub remote.origin.url.
  • planhub sync
    • Reads .plan/ files and creates or updates GitHub issues and milestones.
    • Imports existing GitHub issues into .plan/ when credentials and a GitHub remote.origin.url are available.
    • Prints explicit operation counts for import/create/update/archive/delete.
    • Writes the GitHub number back into each file after creation.
    • GitHub is the source of truth for issue state during sync.
    • For existing issues, sync does not push local state or state_reason to GitHub; it reconciles those fields from the GitHub response.
    • Sync runs in three phases: parse files, build a sync plan, then apply it.
    • Use --dry-run to validate files without writing changes.
    • Use --verbose for path-level planned changes, or --compact for concise output. CLI flags override config.
    • Creating issues or milestones also requires credentials and a GitHub remote.origin.url.
    • Closed synced root issues are archived under .plan/archive/issues by default (or deleted when sync.closed_issues.policy: delete is configured).
    • Milestone issues remain inside their milestone folder. When milestone.md has state: "closed", sync moves the whole milestone directory to .plan/archive/milestones. If set back to state: "open", sync moves that directory back under .plan/milestones.

Credentials

Planhub can reuse your GitHub CLI session or a token stored in the environment. The simplest path is to authenticate once with gh, and the CLI will fetch a token automatically.

gh auth login

Alternatively, create a personal access token and export it:

  1. GitHub → Settings → Developer settings → Personal access tokens.
  2. Create a fine-grained token for the target repo(s).
  3. Grant Issues: Read (and Write if you will push updates later).
export GITHUB_TOKEN=ghp_your_token_here

Suggested Data Repo Layout

.plan/
  issues/
    20260127-backlog-issue.md
  milestones/
    stage-1/
      milestone.md
      issues/
        issue-001.md
      assets/
        diagram.png

Front Matter Tips

  • milestone can be a title or a number; use milestone: null to clear it.
  • Use labels: [] or assignees: [] to remove them on GitHub.
  • state_reason requires state: "closed".

Config

  • ~/.planhub/config.yaml and .plan/config.yaml are layered (repo overrides global).
  • Set sync.behavior.verbosity to compact (default) or verbose.

Development

Setup

Install development dependencies:

uv sync --dev

Pre-commit Hooks

This project uses pre-commit to run code quality checks before commits. Install the hooks:

uv run pre-commit install

The hooks will automatically run on git commit. They check for:

  • Code formatting and linting (ruff)
  • Trailing whitespace and end-of-file fixes
  • YAML, JSON, and TOML syntax
  • Merge conflicts and other common issues

To run hooks manually:

uv run pre-commit run --all-files

Version Bumping

This project includes a grow.py script for bumping versions and creating releases:

./grow.py

The script will:

  1. Read the current version from pyproject.toml
  2. Show commits since the last tag
  3. Prompt for the new version
  4. Update the version in pyproject.toml
  5. Create a commit with a changelog of commits since the last release
  6. Create an annotated tag with the new version
  7. Optionally push commits and tags to the remote repository

The changelog commit includes all commit messages since the last tag, making it easy to see what changed in each release on GitHub.

Next Steps

  • Implement the parsing + GitHub sync logic.
  • Add CI to validate file formats.

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

planhub-0.3.2.tar.gz (101.1 kB view details)

Uploaded Source

Built Distribution

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

planhub-0.3.2-py3-none-any.whl (39.2 kB view details)

Uploaded Python 3

File details

Details for the file planhub-0.3.2.tar.gz.

File metadata

  • Download URL: planhub-0.3.2.tar.gz
  • Upload date:
  • Size: 101.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for planhub-0.3.2.tar.gz
Algorithm Hash digest
SHA256 101da3f23eec212833962cf6322a982b53a4081d330976eedb2f71c975306ccd
MD5 f804d3c6f1d0a461b0f60a3dcc08b2d8
BLAKE2b-256 b703d30ed1075361530e6251043aef90a8da6a1018adc7ed31d8e373a98eb0ec

See more details on using hashes here.

Provenance

The following attestation bundles were made for planhub-0.3.2.tar.gz:

Publisher: release.yml on koradon/planhub

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

File details

Details for the file planhub-0.3.2-py3-none-any.whl.

File metadata

  • Download URL: planhub-0.3.2-py3-none-any.whl
  • Upload date:
  • Size: 39.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for planhub-0.3.2-py3-none-any.whl
Algorithm Hash digest
SHA256 774c44f1e5b67cddf16bae88705ef9e6d6a39fea0ce025485200e8ebd6266fa3
MD5 eed0556926474b1015df08adef6c1831
BLAKE2b-256 3ec640cad35e4df293ffc685cabf6d825ef9d2f8d5135f47a5ab0603491492a8

See more details on using hashes here.

Provenance

The following attestation bundles were made for planhub-0.3.2-py3-none-any.whl:

Publisher: release.yml on koradon/planhub

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