Show HN: CommitGate – Automatically scan your commit for vulnerabilities
CommitGate is an AI-powered Git pre-commit security gate that automatically scans staged diffs on every git commit, blocking secrets or risky code before they enter history. It combines a Gitleaks deterministic scan with an LLM semantic reviewer, supports multiple AI providers, and optionally sends audit logs to Splunk.
Notifications You must be signed in to change notification settings
Fork 0
Star 6
BranchesTags
Open more actions menu
Folders and files
NameName
Last commit message
Last commit date
Latest commit
History
74 Commits
74 Commits
.github/ISSUE_TEMPLATE
.github/ISSUE_TEMPLATE
assets
assets
commitgate
commitgate
docs
docs
tests
tests
.env.example
.env.example
.gitignore
.gitignore
CONTRIBUTING.md
CONTRIBUTING.md
LICENSE
LICENSE
README.md
README.md
architecture_diagram.png
architecture_diagram.png
pyproject.toml
pyproject.toml
Repository files navigation
An AI-powered security gate for Git. Every time you run git commit, CommitGate scans the staged diff for potential vulnerabilities and blocks the commit before secrets or risky code ever reach your history.
It runs two scanners over your staged changes and merges their findings:
Layer Tool Catches
Deterministic Gitleaks Known secret shapes — API keys, tokens, passwords matching standard patterns
Semantic AI reviewer (OpenAI-compatible — DeepSeek, OpenAI, Gemini, or Groq) What regex misses — internal URLs, non-standard credentials, eval/os.system, data-leaking logic
Findings from both layers are merged, deduplicated, and fed into a decision engine that rules allow / warn / block. A Rich terminal report explains why.
Demo
CommitGate blocking a vulnerable commit before it reaches Git history.
Table of Contents
Setup
Usage
How it works
Splunk Setup
Module map
Data Privacy
License
Setup
- Install prerequisites
Install these on your machine before installing CommitGate:
Python ≥ 3.10
Git
Gitleaks — an external binary that must be installed separately (it is not pulled in by pip):
Windows: winget install gitleaks
macOS: brew install gitleaks
Linux: download the release binary and place it on your PATH
Confirm it's on your PATH before continuing:
gitleaks version
AI API key — required for the AI reviewer (pick one provider; you'll add the key to your .env in step 3):
Groq — free tier available, recommended for getting started
DeepSeek — low cost
OpenAI
Gemini
- Install CommitGate
pip install git+https://github.com/ductrl/CommitGate.git
- Configure environment variables
Create a .env file in the root of your project (not CommitGate's repo):
Required — AI reviewer (one key for whichever provider you set in commitgate.yaml)
AI_KEY=your-api-key-here
Free option: get a Groq key at https://console.groq.com, then set provider: groq in commitgate.yaml
Optional — AI review timeout in seconds (default: 20)
COMMITGATE_AI_TIMEOUT=20
Optional — Splunk audit logging (see Splunk Setup below)
SPLUNK_HEC_TOKEN=your-hec-token-here
SPLUNK_HEC_URL=https://prd-p-yourinstance.splunkcloud.com:8088/services/collector/event
SPLUNK_VERIFY_SSL=false # required for Splunk Cloud free trial
.env should be gitignored — your keys should never enter source or git history.
- Initialize CommitGate
Run this inside the repo you want to protect:
commitgate init
This does two things at once:
Creates a commitgate.yaml config file in the repo root
Writes .git/hooks/pre-commit so commitgate scan fires automatically on every commit
The generated commitgate.yaml looks like this — edit it to match your needs:
ai: enabled: true # set to false to run gitleaks only (no API key needed)
Options: openai, deepseek, gemini, groq
Tip: groq offers a free API key — get one at https://console.groq.com
provider: deepseek timeout: 20 # seconds before AI review is abandoned (fail closed → warn) policy: block_severity: high # findings at this severity or above stop the commit, available options: low / medium / high / critical reporting: show_suggestions: true # include AI fix suggestions in the terminal report
Commit commitgate.yaml so your whole team shares the same gate policy — it contains no secrets.
Usage
commitgate init # create commitgate.yaml + install pre-commit hook commitgate scan # scan staged files (runs automatically via hook) commitgate install-hook # install pre-commit hook only (no config file) commitgate version # print version SKIP=all git commit ... # bypass CommitGate for a single commit
Once the hook is installed, just commit normally. CommitGate intercepts the commit, scans the diff, and either lets it through or blocks it with a report.
Decision outcomes
Outcome Meaning Exit code
allow No findings, or all below warn threshold 0 — commit proceeds
warn Medium-severity findings 0 — commit proceeds, warnings printed
block High or critical findings 1 — commit stopped
Manual scan (without committing)
git add commitgate scan git restore --staged
How it works
git commit └─ .git/hooks/pre-commit → commitgate scan ├─ gitleaks_runner scan staged diff for known secret patterns ├─ ai_reviewer LLM semantic review for issues regex can't catch ├─ decision_engine merge findings → allow / warn / block ├─ report_generator Rich terminal output ├─ splunk_logger audit event to Splunk HEC (optional) └─ exit code block → non-zero (stops commit) · allow/warn → 0
Splunk Setup (optional)
CommitGate can send an audit event to Splunk after every scan, giving you a searchable history of every commit decision.
- Create a Splunk account
Sign up at splunk.com. Start a Splunk Cloud free trial from your account dashboard.
- Enable HTTP Event Collector (HEC)
In your Splunk UI:
Settings → Data Inputs → HTTP Event Collector
Click Global Settings → set All Tokens to Enabled → Save
- Create a HEC token
Still on the HTTP Event Collector page → New Token
Name: commitgate-audit
Click Next → Source type: type commitgate:audit and select New
Index: main → Review → Submit
Copy the token shown on the confirmation screen
- Add to your .env
SPLUNK_HEC_TOKEN=your-token-here SPLUNK_HEC_URL=https://prd-p-yourinstance.splunkcloud.com:8088/services/collector/event SPLUNK_VERIFY_SSL=false
Why SPLUNK_VERIFY_SSL=false? Splunk Cloud free trial issues certificates missing the Authority Key Identifier extension required by Python 3.10+, making SSL verification impossible on the free plan. Paid Splunk accounts use properly signed certificates and do not need this setting.
- Verify the connection
Stage any file and run a manual scan:
git add commitgate scan git restore --staged
If the audit event reaches Splunk you'll see no yellow "Splunk audit log failed" warning in the output.
- View events in Splunk
Search & Reporting → run:
sourcetype="commitgate:audit"
Each commitgate scan appears as one event with action, reason, findings_count, and the full findings list.
Splunk dashboard
Build a CommitGate Security Gate dashboard with these searches:
Panel Type Search
Decisions over time Line chart sourcetype="commitgate:audit" action!="allow" | timechart count by action
Blocks today Single value sourcetype="commitgate:audit" action=block | stats count as Blocked
Top triggered categories Bar chart sourcetype="commitgate:audit" | stats count by findings{}.category | sort -count
Findings by severity Pie chart sourcetype="commitgate:audit" | stats count by findings{}.severity
Recent blocked commits Table sourcetype="commitgate:audit" | table _time reason findings_count | sort -_time
Module map
Module Role
cli.py Typer commands: scan, install-hook, init, version
git_utils.py Staged files/diff, is-git-repo, hook install
gitleaks_runner.py Run gitleaks binary, parse findings into dicts
ai_reviewer.py LLM semantic review (OpenAI-compatible — provider set in commitgate.yaml), returns (findings, ok)
decision_engine.py Merge findings → allow / warn / block (reads commitgate.yaml thresholds)
report_generator.py Format findings for Rich terminal output
splunk_logger.py POST audit event to Splunk HEC after every scan
config.py Generate and load commitgate.yaml, merge with built-in defaults
See docs/architecture.md for the full architecture and CONTRIBUTING.md for the branch/PR workflow.
Data Privacy
When ai.enabled: true, CommitGate sends your staged code diffs to an external AI provider (whichever you configure in commitgate.yaml). Do not use the AI reviewer on confidential or proprietary code without your organization's authorization. Set ai.enabled: false to run gitleaks only — no data leaves your machine.
Supported providers: Groq, DeepSeek, OpenAI, Gemini. Local LLM support (Ollama) and self-hosted Splunk are on the roadmap so CommitGate can operate fully air-gapped.
License
MIT © 2026 Mike Ly
CommitGate is free to use, modify, and distribute under the terms of the MIT License.
About
An AI-powered Git pre-commit security gate
Topics
python
git
cli
security
ai
devtools
developer-tools
devsecops
gitleaks
Resources
Readme
License
MIT license
Contributing
Contributing
Uh oh!
There was an error while loading. Please reload this page.
Activity
Stars
6 stars
Watchers
0 watching
Forks
0 forks
Report repository
Releases
No releases published
Packages 0
Uh oh!
There was an error while loading. Please reload this page.
Contributors
Uh oh!
There was an error while loading. Please reload this page.
Languages
Python 100.0%