Review OpenAPI (Swagger) specification files for compliance with the OpenAPI 3.1 standard, security scheme design, naming conventions, schema quality, and API design best practices. Use when a user asks to review an API spec, check an OpenAPI file, audit a Swagger definition, validate an OAS document, or improve API design. Accepts YAML or JSON files, file paths, or inline spec content.
Resources
1Install
npx skillscat add theepan/ai-agent-skills/openapi-review Install via the SkillsCat registry.
OpenAPI Specification Review
Review OpenAPI specification files systematically for standards compliance,
security, API design best practices, and documentation quality.
Input Handling
Determine the input type and gather the specification accordingly:
- Direct content -- Spec provided inline in the conversation. Review as-is.
- File path(s) -- Read the specified
.yaml,.yml, or.jsonfiles. - Directory path -- Find all OpenAPI spec files recursively. If multiple
specs are found, ask the user which to review. - URL -- If given a URL, ask the user to provide the file content directly.
Before starting the review phases, determine:
- Format: YAML or JSON
- Version: OpenAPI 2.0 (Swagger), 3.0.x, or 3.1.x
- Structure: Single document or multi-file with
$refto external files
If the spec uses OpenAPI 2.0 or 3.0.x, note version-specific differences and
recommend migration paths to 3.1.x where beneficial.
Review Process
Read references/openapi-checklist.md before
starting the review.
Execute these phases in order. For each finding, assign a severity.
Phase 1: Structural Compliance
Verify the spec conforms to the OpenAPI 3.1 specification structure:
- Required fields --
openapiversion string,info.title,info.version, and at least one ofpaths,components, orwebhooks $refresolution -- All$refpointers resolve to valid targets.
No circular references that would prevent schema validation- Path templating -- Path parameters match
{paramName}syntax and have
corresponding parameter definitions. No duplicate paths after template
resolution - Parameter uniqueness -- Parameters are unique by the combination of
nameandin(location) within each operation - operationId uniqueness -- Every
operationIdis unique across the
entire spec - Parameter schema -- Parameters use
schemafor simple values orcontentfor complex serialization, never both - Media types -- Request/response
contentkeys are valid media types
(e.g.,application/json, not invented types) - Status codes -- Response status codes are valid HTTP codes or
default.
Range codes (2XX,4XX) used correctly
Phase 2: Security Review
Check security definitions and their application:
- Schemes defined -- At least one security scheme exists in
components/securitySchemes - Global or per-operation security -- Security is applied globally or on
every operation. Flag any operation missing security that does not
explicitly opt out with an empty array[] - OAuth2 flows -- OAuth2 schemes have valid flow configurations with
proper authorization and token URLs. Scopes are defined and used
consistently - API key placement -- API keys use
headerorcookie, notquery
(query params appear in logs and browser history) - HTTPS enforced -- All
servers[].urlvalues usehttps://. Flag anyhttp://URL that is notlocalhostor127.0.0.1 - Sensitive data exposure -- Sensitive identifiers (passwords, tokens,
secrets) are not in path or query parameters. Use headers or request body
instead - CORS considerations -- If the API is consumed by browsers, note if
security-relevant headers are missing from response definitions
Phase 3: API Design Best Practices
Evaluate the API design for RESTful conventions and consistency:
- Resource naming -- Paths use plural nouns (
/users, not/user), no
verbs in paths (/users, not/getUsers), lowercase with hyphens for
multi-word segments (/user-profiles, not/userProfiles) - Naming consistency -- Property names follow a single convention
throughout (camelCase or snake_case, not mixed). Flag inconsistencies - HTTP method usage -- GET for retrieval (no request body), POST for
creation, PUT for full replacement, PATCH for partial update, DELETE for
removal. Flag misuse (e.g., POST for retrieval) - Pagination -- List endpoints (GET returning arrays) include pagination
parameters (limit,offsetorcursor) and response metadata - Status codes -- Appropriate codes per method: 201 for POST creation,
204 for DELETE with no body, 404 documented for resource endpoints, 409
for conflict scenarios - Versioning -- Consistent versioning strategy (URL path
/v1/, header,
or query param). Flag mixed approaches - Component reuse -- Shared schemas, parameters, and responses defined in
componentsand referenced via$ref. Flag inline duplication of
identical or near-identical schemas - operationId conventions -- operationIds are descriptive and follow a
consistent pattern (e.g.,listUsers,getUserById,createUser) - Descriptions -- All operations, parameters, and schemas have
meaningfuldescriptionfields. Flag missing descriptions on public-facing
endpoints
Phase 4: Schema and Documentation Quality
Assess schema completeness and documentation:
- Schema completeness -- Schemas define
type, useformatwhere
appropriate (e.g.,date-time,email,uri,uuid), setrequired
arrays for mandatory properties, defineenumfor fixed value sets, and
provideexampleorexamplesvalues - Discriminator usage -- Polymorphic schemas (
oneOf,anyOf) usediscriminatorwith a validpropertyNameand optionalmapping - Request/response examples -- Operations include
exampleorexamplesin media type objects. Examples are realistic and consistent
with schema constraints - Error responses -- 4xx and 5xx responses are defined with consistent
error schemas (e.g.,title,status,detailfollowing RFC 9457
Problem Details). At minimum, 400, 401, 404, and 500 are documented - Deprecated operations -- Deprecated operations are marked with
deprecated: trueand their description states the replacement
endpoint or migration path - External documentation -- Complex or domain-specific operations link
to external docs viaexternalDocswhere helpful additionalProperties-- Object schemas explicitly setadditionalPropertiestotrueorfalserather than relying on
default behavior, especially for schemas used in request validation- String constraints -- String properties define
minLength,maxLength, orpatternwhere appropriate to communicate validation
rules to consumers
Severity Levels
Assign one severity to each finding:
| Severity | Label | Meaning |
|---|---|---|
| S1 | CRITICAL | Spec is invalid, security scheme is missing or broken, or will cause code generation failures. Fix immediately. |
| S2 | HIGH | Likely to cause integration issues, security weakness, or incorrect client behavior. Fix before publishing. |
| S3 | MEDIUM | Design inconsistency, missing documentation, or deviation from best practices. Should be addressed. |
| S4 | LOW | Style suggestion, minor naming improvement, or optional enhancement. Address at discretion. |
Output Format
Structure the review as follows:
Summary
Provide a 2-3 sentence overview: what API the spec describes, overall quality
assessment, and the most important finding.
Findings
List each finding with this structure:
[S{n}] {Category}: {Brief title}
- Location: JSON Pointer path (e.g.,
#/paths/~1users/get/responses) or
object name - Issue: What is wrong and why it matters
- Suggestion: Concrete fix, with a YAML or JSON snippet when helpful
Order findings by severity (S1 first), then by location within each severity.
Positive Observations
Note 1-3 things the spec does well. Good component reuse, thorough examples,
or consistent naming deserve acknowledgment.
Summary Table
End with a count table:
| Severity | Count |
|---|---|
| S1 CRITICAL | n |
| S2 HIGH | n |
| S3 MEDIUM | n |
| S4 LOW | n |
Guidelines
- Be specific. Reference exact paths, property names, and operationIds.
- Provide concrete fix suggestions with YAML or JSON snippets demonstrating
the improvement. - When the spec uses OpenAPI 3.0.x, note 3.1.x features that would improve
it (e.g.,nulltype support, JSON Schema alignment) but focus the review
on the version actually used. - Do not flag valid style choices that are internally consistent (e.g.,
camelCase vs snake_case is fine if used consistently throughout). - For large specs (>100 paths), divide the review into logical sections
(by tag or resource group) and provide a consolidated summary. - When uncertain about API domain intent, state the assumption explicitly
rather than making a silent judgment.