Convert FastAPI apps into Agent Skills (CLI + SKILL.md)
Project description
fastapi-to-skill
Convert any FastAPI app into a CLI + SKILL.md for AI agents — in one command.
pip install fastapi-to-skill
fastapi-to-skill generate main:app
The Problem
A year ago, APIs served frontends. Developers read docs, learned the UI, wrote integration code.
Now APIs serve AI agents. And agents don't read docs — they read skill files.
If your product has no SKILL.md, agents can't discover it, can't use it, and will use a competitor that does have one.
The new distribution channel is not the App Store. It's the agent skill registry.
The Solution
fastapi-to-skill takes your existing FastAPI app and generates everything an AI agent needs to use your API:
| Output | What it is |
|---|---|
cli.py |
Standalone Typer CLI — one command per endpoint, no deps on this tool |
SKILL.md |
Agent Skills file — works in Claude Code and any Agent Skills-compatible platform |
No MCP server. No AI costs. No infrastructure. Just files.
Why FastAPI?
FastAPI auto-generates an OpenAPI spec from your Python type hints. You write:
@app.post("/tasks")
def create_task(task: Task) -> TaskOut:
...
FastAPI gives you a full API contract for free — endpoints, parameters, request bodies, types, auth schemes. Always in sync with your code. No manual YAML.
fastapi-to-skill reads that spec with one call to app.openapi() and turns it into agent-ready tools. The whole pipeline is: your type hints → OpenAPI spec → CLI + SKILL.md.
Big thanks to @sebastianramirez for building FastAPI + Typer — an ecosystem where this kind of tooling is possible in a weekend.
Quick Start
Install
pip install fastapi-to-skill
# or for global CLI tools (recommended)
pipx install fastapi-to-skill
Generate from a FastAPI app
# main.py
from fastapi import FastAPI
from pydantic import BaseModel
app = FastAPI(title="Task Manager API")
class Task(BaseModel):
title: str
done: bool = False
@app.post("/tasks")
def create_task(task: Task):
...
@app.get("/tasks/{task_id}")
def get_task(task_id: int):
...
fastapi-to-skill generate main:app
Output (folder name is derived from your API title):
skills/task-manager-api/
├── cli.py ← standalone CLI
└── SKILL.md ← agent skill file
Use the generated CLI
cd skills/task-manager-api/
pip install typer httpx rich
# Run without a command — shows SKILL.md (AI-friendly)
python cli.py
# List all commands
python cli.py --help
# See body schema for any command
python cli.py create-task --help
# Body fields:
# title: string (required)
# done: boolean default: False
# Call the API
python cli.py create-task --body '{"title": "Ship the feature"}'
python cli.py get-task 1
python cli.py list-tasks --done false
# Search commands by keyword
python cli.py search "task"
Other options
# Preview without writing files
fastapi-to-skill generate main:app --dry-run
# Validate spec only
fastapi-to-skill generate main:app --validate
# Override base URL
fastapi-to-skill generate main:app --base-url https://api.myapp.com
Authentication
Set your credentials via environment variables before calling any command:
# API key
export MYAPI_API_KEY="sk-your-key"
# Bearer token
export MYAPI_TOKEN="your-token"
# Custom base URL
export MYAPI_BASE_URL="https://api.myapp.com"
The env var prefix is derived from your API title automatically.
How the SKILL.md works
When an AI agent encounters your CLI, it runs:
task-manager-api # reads SKILL.md, understands the API
task-manager-api --help # sees all available commands
task-manager-api create-task --help # sees body schema
No human needed. The agent discovers capabilities, reads the contract, and starts calling commands.
The SKILL.md follows the Agent Skills open standard — compatible with Claude Code and any platform that supports it.
License
MIT
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 fastapi_to_skill-0.1.7.tar.gz.
File metadata
- Download URL: fastapi_to_skill-0.1.7.tar.gz
- Upload date:
- Size: 3.3 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
21b25da8a6a291481a7bb22e419f15e710ebff25d08bca480a6297c8388b31fc
|
|
| MD5 |
d9be98c5c1f66ed14e1272377ca38f87
|
|
| BLAKE2b-256 |
53ea0f6876646230059bf7ba8ed3cdd429f46c2470e95b7195e79f3bbb90bd9e
|
File details
Details for the file fastapi_to_skill-0.1.7-py3-none-any.whl.
File metadata
- Download URL: fastapi_to_skill-0.1.7-py3-none-any.whl
- Upload date:
- Size: 17.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
be7ee282e030315035f29123de636cd53f433a569325eec26802bbd67aaf9c80
|
|
| MD5 |
ddb19920de5c85e8fc2d9608f9e163f5
|
|
| BLAKE2b-256 |
353c7eedf7cc3c40f86476349bb12609749fed5644b9ec9e4c00b3ce742ec94b
|