api-documenter
SKILL.md
API Documentation
Generate and maintain API documentation from code and OpenAPI specs.
OpenAPI Spec Validation
# Validate an OpenAPI spec
npx @apidevtools/swagger-cli validate openapi.yaml
# Bundle split spec files into one
npx @apidevtools/swagger-cli bundle openapi.yaml -o openapi-bundled.yaml
Interactive Docs
Swagger UI
# Serve Swagger UI locally
npx @redocly/cli preview openapi.yaml
# Or with Docker
docker run -p 8080:8080 -e SWAGGER_JSON=/spec/openapi.yaml -v $(pwd):/spec swaggerapi/swagger-ui
Redoc
# Generate static HTML docs
npx @redocly/cli build-docs openapi.yaml -o docs.html
# Preview with hot reload
npx @redocly/cli preview-docs openapi.yaml
Generate OpenAPI from Code
Express/Node.js with swagger-jsdoc
# Install
npm install swagger-jsdoc swagger-ui-express
# Generate spec from JSDoc annotations
node -e "
const swaggerJsdoc = require('swagger-jsdoc');
const spec = swaggerJsdoc({
definition: { openapi: '3.1.0', info: { title: 'My API', version: '1.0.0' } },
apis: ['./src/routes/*.ts'],
});
console.log(JSON.stringify(spec, null, 2));
" > openapi.json
FastAPI (Python — auto-generates)
# FastAPI generates OpenAPI automatically at /docs
# Export the spec:
curl -s http://localhost:8000/openapi.json | jq . > openapi.json
TypeDoc (TypeScript Documentation)
# Generate docs from TypeScript
npx typedoc --entryPoints src/index.ts --out docs/api
# JSON output
npx typedoc --json docs/api.json --entryPoints src/index.ts
# With README
npx typedoc --entryPoints src/index.ts --out docs/api --readme README.md
JSDoc Extraction
# Generate HTML docs from JSDoc comments
npx jsdoc src/ -r -d docs/
# With custom template
npx jsdoc src/ -r -d docs/ -t node_modules/clean-jsdoc-theme
SDK Generation from OpenAPI
# Generate TypeScript client
npx openapi-typescript openapi.yaml -o src/api-types.ts
# Generate full SDK with openapi-generator
npx @openapitools/openapi-generator-cli generate \
-i openapi.yaml \
-g typescript-fetch \
-o src/generated/api
# Python client
npx @openapitools/openapi-generator-cli generate \
-i openapi.yaml \
-g python \
-o generated/python-client
Linting OpenAPI Specs
# Redocly lint
npx @redocly/cli lint openapi.yaml
# Spectral (custom rules)
npx @stoplight/spectral-cli lint openapi.yaml
Notes
- Write the OpenAPI spec first (design-first), then implement. It's faster than code-first for teams.
- Keep specs in version control alongside the code.
- Validate specs in CI — broken docs are worse than no docs.
- SDK generation saves client teams significant time. Regenerate on every API change.
- Use
$refto split large specs into manageable files.
Weekly Installs
1
Repository
thinkfleetai/th…t-engineFirst Seen
Mar 1, 2026
Security Audits
Installed on
amp1
cline1
opencode1
cursor1
kimi-cli1
codex1