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: Elastic-2.0 Python 3.11+

Website | PyPI | Paper (arXiv) | Wiki


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 arXiv | Zenodo | DOI: 10.5281/zenodo.18787663


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

Elastic License 2.0. See LICENSE.

Copyright (c) 2026 Varun Pratap Bhardwaj / Qualixar.


Citation

@article{bhardwaj2026skillfortify,
  author    = {Bhardwaj, Varun Pratap},
  title     = {Formal Analysis and Supply Chain Security for Agentic AI Skills},
  journal   = {arXiv preprint arXiv:2603.00195},
  year      = {2026},
  doi       = {10.5281/zenodo.18787663},
  url       = {https://arxiv.org/abs/2603.00195}
}

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.4.0.tar.gz (1.5 MB view details)

Uploaded Source

Built Distribution

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

skillfortify-0.4.0-py3-none-any.whl (207.3 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: skillfortify-0.4.0.tar.gz
  • Upload date:
  • Size: 1.5 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.3

File hashes

Hashes for skillfortify-0.4.0.tar.gz
Algorithm Hash digest
SHA256 0f6e576cde5ace5f844533746a80c1ddd3dac6b3498603da882106f379e2f612
MD5 1ee93867288ae1c7f42cd8f03323c8c6
BLAKE2b-256 484ba99f9960c6e38b17c9694c6ed5b19ef2fc8c71d5259fc7d6f19366ee3426

See more details on using hashes here.

File details

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

File metadata

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

File hashes

Hashes for skillfortify-0.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 b41f6e7897c0d71e9eeb300b504c9d87a6b388cd9b7fbd4dcd5490573b8772e4
MD5 1bcf79502ee49cfc11f31de5ef5583e9
BLAKE2b-256 0c3ea6235fbc0196ff3bf6383b42182a8bad318cbf805c979e7b2e2257070634

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