One universal AI/vibe-coding repo safety skill with OSS guardrails, Python 3.12, uv/uvx, secret scanning, SAST, GitHub read guard, MCP safety, and incident cleanup.
Project description
AI Repo Safety Skill
Package links:
- skill: https://skills.sh/letya999/ai-repo-safety-skill
- PyPI: https://pypi.org/project/ai-repo-safety/
- npm: https://www.npmjs.com/package/ai-repo-safety
One powerful public skill + asset repository for hardening AI/vibe-coded projects before commit, before push, and before publishing on GitHub.
The project is designed for Python 3.12, uv, and uvx, and works on Windows, macOS, and Linux. It uses only free / open-source / community tools by default.
What this gives you
- one installable skill:
SKILL.md - one Python CLI:
ai-repo-safety - safe repo bootstrap before the first commit
- secret file denylist
- Gitleaks / TruffleHog / detect-secrets integration
- Opengrep-first SAST profile, without Semgrep as a default dependency
- Python hardening via Bandit, Ruff, pip-audit, pytest, pydantic-settings examples
- GitHub public repo hardening workflows
- GitHub read guard for commits, PRs, branches, issues, and merge request aliases
- MCP config safety checks
- lightweight STRIDE threat model templates
- incident cleanup templates
- cross-platform tool doctor and install plan
Note: Earlier versions of this README referenced
skill/ai-repo-safety/SKILL.md. The skill ships as a singleSKILL.mdat the repository root, and agents are expected to install it into their config directory via the skills CLI.
Install the skill (AI agents)
Install to all detected agents in one command:
npx skills add letya999/ai-repo-safety-skill
Or install to a specific agent:
npx skills add letya999/ai-repo-safety-skill -a claude-code
Branch and release model: the default branch is
dev. Releases are tagged fromdev(e.g.v0.1.4) and published to PyPI and npm via Trusted Publishing on tag push. Theai-repo-safety verify-release --version X.Y.Zcommand checks that a release is ready before you push the tag.
Install the CLI
Package pages:
Via uv/uvx (recommended):
uv tool install ai-repo-safety
ai-repo-safety doctor
Or run without installing:
uvx ai-repo-safety doctor
uvx ai-repo-safety init --target . --python auto --github auto
uvx ai-repo-safety scan --target .
Via pip:
pip install ai-repo-safety
ai-repo-safety doctor
Via npm (delegates to Python under the hood):
npm install -g ai-repo-safety
ai-repo-safety doctor
Skill install layout
The skill lives here:
SKILL.md
The skill is ready to be executed via uv run universally on Windows, macOS, and Linux without the need for OS-specific shell wrappers.
Commands
# Read-only environment check.
ai-repo-safety doctor
# Plan-only bootstrap. By default does not install tools, hooks,
# or call the GitHub API. Use --apply --yes and the matching
# opt-in flag to perform a specific mutation.
ai-repo-safety init --target . --python auto --github auto
ai-repo-safety setup --target . # plan only
ai-repo-safety setup --target . --apply --run-hooks --yes
# Local hook install. Refuses to overwrite an unmanaged existing
# hook unless --overwrite (or --chain to append) is passed.
ai-repo-safety install-hooks --target .
ai-repo-safety install-hooks --target . --chain
ai-repo-safety install-hooks --target . --overwrite
# Scans.
ai-repo-safety scan --target .
ai-repo-safety scan --target . --strict
ai-repo-safety prepush --target .
# GitHub read guard. Always pass an explicit --reason.
ai-repo-safety github-guard validate --target . --repo owner/repo --resource pulls --reason "review current PRs"
ai-repo-safety github-guard read --target . --repo owner/repo --resource pulls --reason "review current PRs"
ai-repo-safety github-guard check-text --target . --file suspicious_issue.md
# Threat model and incident templates.
ai-repo-safety threat-model --target .
ai-repo-safety incident --target . --type secret-leak
# Pre-release verification.
ai-repo-safety verify-release --version 0.1.4 --target .
AI Assistant Integrations
To ensure your AI assistants (like Claude Code, Codex, OpenCode, and Cursor) follow these repository safety rules, you can integrate this skill using the following steps:
1. Installing via skills CLI
If you use a skills manager or custom CLI tool for orchestrating agent abilities, install the skill directly:
skills add git+https://github.com/letya999/ai-repo-safety-skill
This will place the SKILL.md and related guardrails into your agent workspace.
2. Integration with AI Assistants & IDEs
Claude Code (by Anthropic)
Claude Code automatically scans and respects repository instructions. To make it aware of this safety skill:
- Place AGENTS.md in the root of your project directory.
- When starting a session, Claude Code reads root markdown instructions (like
AGENTS.md) and strictly adheres to the forbidden actions and GitHub read guard policies. - You can also reference the CLI directly in your prompt to enforce checks, e.g.,
claude "run ai-repo-safety scan before committing".
Codex CLI & OpenCode
For CLI-based agents:
- Inject the rules by importing the skill or placing the
SKILL.mdin your agent's config folder. - The agent will read
SKILL.mdas part of its system instructions, preventing it from performing directgit pushor reading raw GitHub API responses without usingai-repo-safety github-guard.
Cursor (IDE)
Cursor uses .cursorrules to guide its Chat and Composer features:
- Create a
.cursorrulesfile in the root of your repository (if it doesn't exist yet). - Copy the content of AGENTS.md into your
.cursorrulesfile or append a reference:Always follow the repository safety guardrails defined in AGENTS.md. Never run forbidden actions (like git push, public PR creation) without user confirmation.
- Cursor's AI will automatically prioritize these instructions during code generation and terminal executions.
Tool philosophy
Default tools are free / OSS / community:
pre-commitgitleakstrufflehogdetect-secretsopengrepbanditruffpip-auditosv-scannercyclonedx-pyRenovateOpenSSF Scorecard- optional
CodeQLfor public/open-source GitHub repos
Semgrep is not the default. The SAST profile is Opengrep-first. Existing Semgrep-compatible rules can be adapted by the agent when compatible.
Tool installation policy
The CLI checks whether Git, Python, uv, uvx, GitHub CLI, and scanners are available.
When tools are missing, the agent can automatically install all required Python and System binaries by running:
uv run ai-repo-safety install-missing
This command uses uv tool for Python tools (like bandit, pip-audit) and leverages the native package manager (winget, brew, npm) or direct downloads to globally install system binaries (like Gitleaks, OSV-Scanner, TruffleHog, Opengrep, GitHub CLI) across Windows, macOS, and Linux.
GitHub read guard
Agents often ingest too much GitHub context: commits, PRs, branches, issues, comments, and public issue bodies with prompt injection. This project includes a read guard:
ai-repo-safety github-guard read --repo owner/repo --resource issues --reason "triage current issues"
It enforces policy from .repo-safety.json:
- only allowed repositories by default
- explicit reason required
- max items
- max body characters
- secret redaction
- prompt-injection pattern detection
- aliases for
mrs/merge_requests-> GitHub pulls
Agents should use this wrapper instead of direct gh api, gh pr view, gh issue view, or raw GitHub web reads when reading GitHub context into an AI session.
Important limits
This project gives strong local deterministic gates, but it cannot magically intercept every external AI tool. The included AGENTS.md and hook templates force agents to use the guardrails, but each client has different hook/plugin support.
The safe default is: if the agent cannot enforce a guardrail in its runtime, it must run the CLI guard before the risky action.
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file ai_repo_safety-0.1.4.tar.gz.
File metadata
- Download URL: ai_repo_safety-0.1.4.tar.gz
- Upload date:
- Size: 57.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
7db1b31735e7c8b0538a9a506ba1f55b7f6c6ff73add121370068711d089c69f
|
|
| MD5 |
585faa7babae9203d99cdcac756a3b6b
|
|
| BLAKE2b-256 |
995610b92d9c6d9f30a7becbd9af1e718eaf011fd45194171786cfdd41c9b85f
|
Provenance
The following attestation bundles were made for ai_repo_safety-0.1.4.tar.gz:
Publisher:
publish-pypi.yml on letya999/ai-repo-safety-skill
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
ai_repo_safety-0.1.4.tar.gz -
Subject digest:
7db1b31735e7c8b0538a9a506ba1f55b7f6c6ff73add121370068711d089c69f - Sigstore transparency entry: 1825140644
- Sigstore integration time:
-
Permalink:
letya999/ai-repo-safety-skill@b6c0ddb3a71d513450d252670cc5e3662388ea19 -
Branch / Tag:
refs/tags/v0.1.4 - Owner: https://github.com/letya999
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-pypi.yml@b6c0ddb3a71d513450d252670cc5e3662388ea19 -
Trigger Event:
push
-
Statement type:
File details
Details for the file ai_repo_safety-0.1.4-py3-none-any.whl.
File metadata
- Download URL: ai_repo_safety-0.1.4-py3-none-any.whl
- Upload date:
- Size: 64.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0ec83d3112f849256cfdda1878cfca113d85332e772f67f8c7b2b244ba12cc2c
|
|
| MD5 |
e4347e0c5931eb8d3453fd650d3746ef
|
|
| BLAKE2b-256 |
de64f10be5c4d6529e90de43b0369d142b3f49ca8b2c051c4ce12dab339a1922
|
Provenance
The following attestation bundles were made for ai_repo_safety-0.1.4-py3-none-any.whl:
Publisher:
publish-pypi.yml on letya999/ai-repo-safety-skill
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
ai_repo_safety-0.1.4-py3-none-any.whl -
Subject digest:
0ec83d3112f849256cfdda1878cfca113d85332e772f67f8c7b2b244ba12cc2c - Sigstore transparency entry: 1825140668
- Sigstore integration time:
-
Permalink:
letya999/ai-repo-safety-skill@b6c0ddb3a71d513450d252670cc5e3662388ea19 -
Branch / Tag:
refs/tags/v0.1.4 - Owner: https://github.com/letya999
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-pypi.yml@b6c0ddb3a71d513450d252670cc5e3662388ea19 -
Trigger Event:
push
-
Statement type: