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

or

uv add git-surgeon

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.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-py3-none-any.whl (44.7 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: git_surgeon_cli-0.0.1.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.tar.gz
Algorithm Hash digest
SHA256 9ab4ffe5442f9ede3be7d6e2450c4238a8fe61475b681f446a36772cb81ecca4
MD5 18d3b618e73bb1cbf979dabe07abf4ee
BLAKE2b-256 f466c70705920ca59345f45946e2c0aa01378e07ffbbec15e281e2b27c6d4552

See more details on using hashes here.

File details

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

File metadata

  • Download URL: git_surgeon_cli-0.0.1-py3-none-any.whl
  • Upload date:
  • Size: 44.7 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-py3-none-any.whl
Algorithm Hash digest
SHA256 5959b51fba6dd7becc0ad21d7e8f182ddfa7106ceacc3b2f8c2eb182074b69f9
MD5 d20d61311050cee5f461a4f9202b67d4
BLAKE2b-256 c06b00cd9abd8d4f9eb4b57d4a33470f7129c29e5a16c49e12eca93e1b9b59c3

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