Gitleaks Secret Scanner
A powerful, intelligent, and safe wrapper for the Gitleaks engine.
This tool solves the main challenge of using Gitleaks in a team environment: the setup. It automatically downloads the correct Gitleaks binary for any operating system and architecture, making it incredibly easy to scan for secrets in local pre-commit hooks and CI/CD pipelines without manual intervention.
Why Use This Package?
While Gitleaks is a phenomenal tool, this package provides a seamless bridge to the Node.js ecosystem, offering several key advantages that go beyond a simple wrapper.
🚀 1. Effortless, Zero-Configuration Setup
The biggest advantage. You no longer need to manually download Gitleaks binaries or write complex scripts to manage different versions for macOS, Windows, and Linux developers on your team. This package handles everything automatically.
🧠 2. Truly Accurate & Performant CI/CD Scanning
This is not a simple git diff | gitleaks
pipe. The --diff-mode ci
is far more intelligent, providing a fast and robust way to secure your merge/pull requests. It's built on a "scan final state" philosophy that delivers accuracy and confidence.
Here’s how it works and why it’s better:
Focuses on the Merge Outcome Instead of analyzing every intermediate commit,
ci
mode identifies all files changed in the pull request and scans their final content. This answers the most important question: "Will this merge introduce a secret into the target branch?" This approach correctly passes the build if a secret is added and then removed within the same PR.Comprehensive File Analysis If you modify a file that already contains a secret,
ci
mode will find it. By scanning the entire content of any changed file (not just the changed lines), it helps you clean up existing security debt and prevents you from unknowingly propagating old vulnerabilities.High Performance The scan is surgical and fast. It gets a simple list of changed files from
git
and runs a targeted Gitleaks scan only on them. This is highly efficient, even for large pull requests with extensive commit histories.Rich, Actionable Context Findings are automatically enriched with author, email, and commit data using
git blame
. This makes it trivial to identify the source of a leak and take immediate action, directly from the console output or the HTML report.
🔒 3. Safe and Powerful Local Scanning
This tool uses advanced, non-invasive strategies to scan your uncommitted work safely and effectively.
- For staged changes (
staged
mode): It uses a safe "Virtual Commit" strategy with low-level Git commands to create a temporary, in-memory commit. This provides a full, rich report with commit data without ever changing your branch history or staging area. - For all changes (
all
mode): It performs a comprehensive three-part scan that covers staged, unstaged, and new untracked files, ensuring no secret can be missed.
📄 4. Rich, User-Friendly Reports
The console output and generated HTML reports are populated with the rich contextual data captured by the advanced scanning methods, making it easy to find and fix issues quickly.
Key Features
- Auto-Installation: Automatically downloads and caches the appropriate Gitleaks binary for your OS and architecture.
- Full History Auditing: A dedicated
--diff-mode history
for performing a complete scan of your entire repository. - Accurate CI/CD Mode: Intelligently scans pull requests, reporting only on newly introduced secrets.
- Advanced Local Scans: Uses safe, non-invasive methods to provide rich reports for staged and uncommitted work.
- Rich HTML Reports: Generates a clean, comprehensive HTML report from scan results with full commit context.
- Professional CLI: Correctly handles pass-through flags like
--no-banner
and--help
.
Quick Start & Usage
One-Off Scan with NPX
The easiest way to try it out without installation:
# Scan all of your uncommitted changes (staged, unstaged, and new untracked files)
npx gitleaks-secret-scanner --diff-mode all --html-report
Project Installation (Recommended)
For use in npm scripts
or with tools like Husky, install it as a development dependency.
npm install gitleaks-secret-scanner --save-dev
Then, add scripts to your package.json
:
"scripts": {
"scan:staged": "gitleaks-secret-scanner",
"scan:all": "gitleaks-secret-scanner --diff-mode all",
"scan:history": "gitleaks-secret-scanner --diff-mode history"
}
Command-Line Options
For a comprehensive menu showing both wrapper commands and the most common Gitleaks flags, run:
gitleaks-secret-scanner --options
For the complete, native help menu from the Gitleaks binary itself, run:
gitleaks-secret-scanner --help
Wrapper-Specific Options:
| Flag | Description |
| :--- | :--- |
| --diff-mode <mode>
| Sets the scan scope. Modes: staged
(default), all
, ci
, history
. |
| --html-report [path]
| Generates a user-friendly HTML report. Defaults to gitleaks-report.html
. |
| --depth <number>
| Used with --diff-mode history
to limit the scan to the last <number>
of commits. |
CI/CD Integration Guide
The following examples show how to configure your CI pipeline for different use cases.
GitHub Actions Example
This workflow runs a fast, targeted scan on every pull request.
# .github/workflows/secret-detection.yml
name: 'Secret Detection Scan'
on:
pull_request:
branches: [ main ]
jobs:
gitleaks-scan:
runs-on: ubuntu-latest
steps:
- name: 'Check out repository'
uses: actions/checkout@v4
with:
fetch-depth: 0
- name: 'Run Gitleaks Secret Scanner for Pull Request'
run: npx gitleaks-secret-scanner@latest --diff-mode ci --html-report scan-report-mr.html
env:
BASE_SHA: ${{ github.event.pull_request.base.sha }}
HEAD_SHA: ${{ github.event.pull_request.head.sha }}
- name: 'Upload HTML Report Artifact'
if: always()
uses: actions/upload-artifact@v4
with:
name: gitleaks-scan-report
path: scan-report-mr.html
GitLab CI Example
This example demonstrates how to set up two separate jobs: one for merge requests and one for a scheduled weekly audit of recent history.
# .gitlab-ci.yml
stages:
- security
secret-scan-mr:
stage: security
image: node:lts-bullseye
variables:
BASE_SHA: ${CI_MERGE_REQUEST_DIFF_BASE_SHA}
HEAD_SHA: ${CI_COMMIT_SHA}
script:
- npm install -g gitleaks-secret-scanner
- gitleaks-secret-scanner --diff-mode ci --html-report scan-report-mr.html
artifacts:
when: always
paths: [scan-report-mr.html]
expire_in: 1 week
rules:
- if: '$CI_PIPELINE_SOURCE == "merge_request_event"'
secret-scan-weekly:
stage: security
image: node:lts-bullseye
script:
- npm install -g gitleaks-secret-scanner
- gitleaks-secret-scanner --diff-mode history --html-report scan-report-weekly.html
artifacts:
when: always
paths: [scan-report-weekly.html]
expire_in: 1 week
rules:
- if: '$CI_PIPELINE_SOURCE == "schedule"'
Known Issues
- CLI Argument Parsing: The current argument parser is intentionally permissive to allow all native Gitleaks flags to be passed through. As a result, it does not throw an error for unknown or misspelled flags (e.g.,
gitleaks-secret-scanner --verrbose
). This behavior is scheduled to be improved in a future release with a more intelligent "typo-check" mechanism.
License and Attribution
This package is licensed under the MIT License. It is a wrapper around the Gitleaks engine, which is developed by Zachary Rice and is also licensed under the MIT License.