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

Uploaded Python 3

File details

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

File metadata

  • Download URL: git_surgeon_cli-0.0.1.post2.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.post2.tar.gz
Algorithm Hash digest
SHA256 017958e617e1d663b21569232a54e83adb4f36816db00157aeec18668b9545e4
MD5 687ffd0a3d3c6e8b5166c6f56ff01557
BLAKE2b-256 7da5dfb8d4e58f7839998a6c7ea5ea48053b73ab5eb650f87a5ff244d4271caa

See more details on using hashes here.

File details

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

File metadata

  • Download URL: git_surgeon_cli-0.0.1.post2-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.post2-py3-none-any.whl
Algorithm Hash digest
SHA256 46f6d02afff73cec13eb1520fa7f3e31e8548df6a648ba69e589ceacb20d9168
MD5 3bf991c7f0f46f60e4a238839db12a1e
BLAKE2b-256 a1a84f7b2114289380ff5847e966b593619eb3f2438cbf6950aa306899b42aa5

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