Skip to main content

SkillFortify — Supply chain security scanner for AI agent skills. Supports 22 frameworks.

Project description

SkillFortify

Supply chain security scanner for AI agent skills -- supports 22 frameworks.

PyPI version Tests License: MIT Python 3.11+


One Command. Every Framework.

pip install skillfortify
skillfortify scan                # Auto-discovers all AI tools on your system
skillfortify scan ./my-project   # Scan a specific project
skillfortify dashboard           # Generate HTML security report

SkillFortify formally analyzes agent skill safety using sound static analysis. If SkillFortify reports no violations, the capability bounds in the formal model are assured. Unlike heuristic scanners where absence of findings does not mean absence of risk, SkillFortify provides mathematically grounded security guarantees.


Supported Frameworks (22)

# Framework Detection
1 Claude Code Skills .claude/ directory
2 MCP Servers mcp.json, mcp_config.json, deep server scan
3 OpenClaw Skills .claw/ directory
4 LangChain Tools langchain imports, BaseTool, @tool
5 CrewAI Tools crew.yaml, crewai imports
6 AutoGen Tools autogen imports, register_for_llm
7 OpenAI Agents SDK openai-agents configurations
8 Google ADK google-adk configurations
9 Dify Dify workflow and plugin definitions
10 Composio Composio tool integrations
11 Semantic Kernel Microsoft Semantic Kernel plugins
12 LlamaIndex LlamaIndex tool abstractions
13 n8n n8n workflow node definitions
14 Flowise Flowise chatflow configurations
15 Mastra Mastra agent tool definitions
16 PydanticAI PydanticAI tool decorators
17 Agno Agno agent configurations
18 CAMEL-AI CAMEL-AI tool integrations
19 MetaGPT MetaGPT action and tool definitions
20 Haystack Haystack component definitions
21 Anthropic Agent SDK Anthropic agent tool configurations
22 Custom Skills User-defined skill manifests (YAML/JSON)

All frameworks are parsed into a unified representation for consistent analysis, trust scoring, and SBOM generation.


Quick Start

Install

pip install skillfortify                 # Core scanner
pip install skillfortify[registry]       # + marketplace scanning
pip install skillfortify[all]            # Everything

System-Wide Scan

Run skillfortify scan with no arguments to automatically discover every AI agent tool installed on your system -- Claude Code, Cursor, VS Code extensions, Windsurf, and more:

skillfortify scan
Discovering AI tools on this system...
  Found: Claude Code skills       (12 skills in ~/.claude/skills/)
  Found: MCP servers              (8 servers in ~/.cursor/mcp.json)
  Found: VS Code MCP configs      (3 servers in ~/.vscode/mcp.json)
  Found: Windsurf MCP configs     (2 servers)

Scanning 25 skills across 4 locations...

+----------------------+--------+-----------+----------+--------------+
|       Skill          | Source |  Status   | Findings | Max Severity |
+----------------------+--------+-----------+----------+--------------+
| deploy-automation    | Claude |   SAFE    |        0 | -            |
| data-export          | Claude |  UNSAFE   |        2 | HIGH         |
| postgres-server      | MCP    |   SAFE    |        0 | -            |
| file-manager         | MCP    |  WARNING  |        1 | MEDIUM       |
+----------------------+--------+-----------+----------+--------------+
25 skills scanned | 22 safe | 2 unsafe | 1 warning | 5 total findings

Project Scan

skillfortify scan ./my-agent-project
skillfortify scan ./my-agent-project --format json
skillfortify scan ./my-agent-project --severity-threshold high

HTML Dashboard

Generate a standalone HTML security report with interactive filtering, a capabilities matrix, and severity breakdown:

skillfortify dashboard
skillfortify dashboard --output security-report.html

Open the generated file in any browser -- no server or dependencies required.


Features

  • Formal threat model (DY-Skill) -- mathematically grounded attack taxonomy for the agent skill supply chain
  • Sound static analysis -- formal capability verification, not heuristic pattern matching
  • Capability-based access control -- POLA compliance checks for every skill
  • Agent Dependency Graph -- constraint-based resolution with conflict detection
  • Lockfile generation -- deterministic skill-lock.json for reproducible agent configurations
  • Trust score algebra -- multi-signal trust with propagation through dependency chains
  • ASBOM generation -- CycloneDX 1.6 Agent Skill Bill of Materials for compliance reporting
  • Registry scanning -- scan MCP registries, PyPI, and npm for known vulnerabilities
  • HTML dashboard -- standalone interactive security report
  • System auto-discovery -- finds every AI tool on your machine automatically
  • 22 framework support -- broadest coverage of any agent security scanner

CLI Commands

Command Description
skillfortify scan [path] Discover and analyze skills. No path = system-wide scan
skillfortify verify <skill> Deep formal verification of a single skill file
skillfortify lock <path> Generate deterministic skill-lock.json lockfile
skillfortify trust <skill> Compute multi-signal trust score with graduated levels
skillfortify sbom <path> Generate CycloneDX 1.6 ASBOM for compliance
skillfortify frameworks List all 22 supported frameworks and detection methods
skillfortify dashboard Generate standalone HTML security report
skillfortify registry-scan <source> Scan MCP, PyPI, or npm registries for threats

Exit Codes

Code Meaning
0 All checks passed
1 Security findings detected
2 No skills found or parse error

Benchmark Results

Evaluated on SkillFortifyBench -- 540 agent skills (clean and malicious samples from documented real-world incidents):

Metric Value
Precision 100% (zero false positives)
Recall 94.12%
F1 Score 96.95%
Average scan time 2.55 ms per skill

Trust Levels

Graduated trust levels inspired by the SLSA framework:

Level Threshold Meaning
FORMALLY_VERIFIED >= 0.75 Highest assurance. Formal analysis passed, strong provenance
COMMUNITY_VERIFIED >= 0.50 Community reviewed, usage history, behavioral checks passed
SIGNED >= 0.25 Basic provenance. Author signed, limited verification
UNSIGNED < 0.25 No verification. Treat with extreme caution

CI/CD Integration

GitHub Actions

name: Skill Security Scan
on: [push, pull_request]

jobs:
  skillfortify-scan:
    runs-on: ubuntu-latest
    steps:
      - uses: actions/checkout@v4
      - uses: actions/setup-python@v5
        with:
          python-version: "3.11"
      - run: pip install skillfortify
      - run: skillfortify scan . --format json
      - run: skillfortify lock . --output /tmp/fresh-lock.json

Requirements

  • Python 3.11 or later
  • No external services required -- runs entirely offline
  • Works on Linux, macOS, and Windows

Academic Paper

"Formal Analysis and Supply Chain Security for Agentic AI Skills"

Backed by peer-reviewed research with five formal theorems and full proofs, formalizing the agent skill supply chain threat model, capability verification, trust algebra, and dependency resolution.

Read the paper on Zenodo | DOI: 10.5281/zenodo.18787663

Part of the AgentAssert suite (arXiv:2602.22302) -- formal foundations for trustworthy AI agents.


Contributing

Contributions welcome. See CONTRIBUTING.md for setup instructions, coding standards, and submission guidelines.


Author

Varun Pratap Bhardwaj -- Solution Architect with 15+ years in enterprise technology. Dual qualifications in technology and law (LL.B.), with a focus on formal methods for AI safety.


License

MIT License. See LICENSE for details.


Citation

@software{bhardwaj2026skillfortify,
  author    = {Bhardwaj, Varun Pratap},
  title     = {SkillFortify: Formal Analysis and Supply Chain Security
               for Agentic AI Skills},
  year      = {2026},
  doi       = {10.5281/zenodo.18787663},
  publisher = {Zenodo},
  url       = {https://doi.org/10.5281/zenodo.18787663}
}

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

skillfortify-0.3.1.tar.gz (314.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

skillfortify-0.3.1-py3-none-any.whl (202.0 kB view details)

Uploaded Python 3

File details

Details for the file skillfortify-0.3.1.tar.gz.

File metadata

  • Download URL: skillfortify-0.3.1.tar.gz
  • Upload date:
  • Size: 314.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.12

File hashes

Hashes for skillfortify-0.3.1.tar.gz
Algorithm Hash digest
SHA256 ec4cec40f0f2ed3e27bb1db6d00d9eb9d65ba7f362518f7437ef45bfec7ab0c8
MD5 0b343985415dcf78c8d25488296b1f1b
BLAKE2b-256 8b3db728ddb768dcf42da88c60bb9761dc64d6ad5c503d184b66d50c1c0dfe5d

See more details on using hashes here.

File details

Details for the file skillfortify-0.3.1-py3-none-any.whl.

File metadata

  • Download URL: skillfortify-0.3.1-py3-none-any.whl
  • Upload date:
  • Size: 202.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.12

File hashes

Hashes for skillfortify-0.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 f9640931b8e09bf040e17d9078a2768b2616fd3f9e56a4ae2ad0138838edad96
MD5 0b166b72cb95493a93f698958f54d321
BLAKE2b-256 4a20131aa83a51ab2274b97cf749873d173628cf8c4171c7e1af8459266197f4

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