Skip to main content

Surgical git history rewriting: author rewrite, message scrub, sensitive data removal, and more.

Project description

🔪 git-surgeon

Surgical git history rewriting: a modular CLI toolkit wrapping git-filter-repo.

Rewrite authors, scrub sensitive data, clean commit messages, flatten merges, and filter commits, all in a single pass with automatic backup & undo.

Features

Feature Description
Message Scrub Find-and-replace text in commit messages (literal or regex)
Blob Scrub Remove secrets, emails, keys from file contents across all history
Merge Flatten Linearize history by converting merge commits to single-parent
Commit Filter Remove or keep commits matching specific criteria
Backup & Undo Automatic git bundle backup + git-surgeon undo to restore
Dry Run Preview every change before touching the repo
Interactive Wizard Run git-surgeon with no args for guided setup
Config Persistence Operations saved to .git-surgeon/config.toml (auto-gitignored)

Quick Start

pip install git-surgeon-cli

or

uv add git-surgeon-cli

Requires Python ≥3.13 and git on PATH.

cd /path/to/your/repo

# Option A: Interactive wizard
git-surgeon

# Option B: CLI commands
git-surgeon init
git-surgeon rewrite-authors --name "Jane" --email "jane@example.com" --default --save
git-surgeon scrub --find "secret-api-key" --replace "***REMOVED***"
git-surgeon run          # creates backup, rewrites history
git-surgeon undo         # restore if needed

Architecture

graph TD
    classDef cli fill:#e1f5fe,stroke:#0288d1,stroke-width:2px,color:#000;
    classDef core fill:#fff3e0,stroke:#f57c00,stroke-width:2px,color:#000;
    classDef ops fill:#e8f5e9,stroke:#388e3c,stroke-width:2px,color:#000;
    classDef ext fill:#eceff1,stroke:#607d8b,stroke-width:2px,color:#000;

    U([User Input]) --> CLI[CLI & Wizard]:::cli
    CLI --> Core[Engine Orchestrator]:::core
    Core <--> Ops[Pluggable Operations]:::ops
    Core --> GFR[git-filter-repo]:::ext
    GFR --> Git[Git Repository]:::ext

For a detailed breakdown of the system architecture and data flow, see the Architecture Documentation.

Documentation

For full guides on usage, configuration, internals, and operations, please visit the Documentation Index or build the docs using MkDocs.

WIP

Safety

Every git-surgeon run automatically creates a git bundle backup at .git-surgeon/backup.bundle before touching history.
Run git-surgeon undo to fully restore.
Use --dry-run on any command to preview without modifying anything.

License

Apache License 2.0. See LICENSE for details.

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

git_surgeon_cli-0.0.1.post1.tar.gz (48.4 kB view details)

Uploaded Source

Built Distribution

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

git_surgeon_cli-0.0.1.post1-py3-none-any.whl (44.8 kB view details)

Uploaded Python 3

File details

Details for the file git_surgeon_cli-0.0.1.post1.tar.gz.

File metadata

  • Download URL: git_surgeon_cli-0.0.1.post1.tar.gz
  • Upload date:
  • Size: 48.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.7 {"installer":{"name":"uv","version":"0.11.7","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":null,"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for git_surgeon_cli-0.0.1.post1.tar.gz
Algorithm Hash digest
SHA256 58b33a5dfe5065639f20f9b292fbae0d78eebdf232a5cd27b6db7154a077db40
MD5 693e9b3b954e42019df015003b0f45f8
BLAKE2b-256 1b10640b38924d4cd5b341436f3493a1e8b41be7ec1e460d8f20a1299d719993

See more details on using hashes here.

File details

Details for the file git_surgeon_cli-0.0.1.post1-py3-none-any.whl.

File metadata

  • Download URL: git_surgeon_cli-0.0.1.post1-py3-none-any.whl
  • Upload date:
  • Size: 44.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.7 {"installer":{"name":"uv","version":"0.11.7","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":null,"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for git_surgeon_cli-0.0.1.post1-py3-none-any.whl
Algorithm Hash digest
SHA256 d65424ef6287750121d8835c28b85a8f46edd63c4fb97f5150a31e0f650c649f
MD5 4cdb3a85808612a44834c20d9d620dca
BLAKE2b-256 268b48cb710659db6100d8b7ca8361fe249ab0e0522b81dbe8f014c001d7a3ea

See more details on using hashes here.

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