aspnet-minimal-api-openapi

$npx mdskill add github/awesome-copilot/aspnet-minimal-api-openapi

Creates ASP.NET Minimal API endpoints with structured OpenAPI documentation for .NET 9+ applications.

  • Helps organize API endpoints into groups and manage cross-cutting concerns like validation and error handling.
  • Integrates with ASP.NET Minimal APIs, OpenAPI/Swagger, and uses C# features like records and nullable annotations.
  • Recommends best practices for request/response types, routing, and documentation based on .NET standards.
  • Presents results as well-structured code snippets with explicit DTOs and OpenAPI metadata for clarity.
SKILL.md
.github/skills/aspnet-minimal-api-openapiView on GitHub ↗
---
name: aspnet-minimal-api-openapi
description: 'Create ASP.NET Minimal API endpoints with proper OpenAPI documentation'
---

# ASP.NET Minimal API with OpenAPI

Your goal is to help me create well-structured ASP.NET Minimal API endpoints with correct types and comprehensive OpenAPI/Swagger documentation.

## API Organization

- Group related endpoints using `MapGroup()` extension
- Use endpoint filters for cross-cutting concerns
- Structure larger APIs with separate endpoint classes
- Consider using a feature-based folder structure for complex APIs

## Request and Response Types

- Define explicit request and response DTOs/models
- Create clear model classes with proper validation attributes
- Use record types for immutable request/response objects
- Use meaningful property names that align with API design standards
- Apply `[Required]` and other validation attributes to enforce constraints
- Use the ProblemDetailsService and StatusCodePages to get standard error responses

## Type Handling

- Use strongly-typed route parameters with explicit type binding
- Use `Results<T1, T2>` to represent multiple response types
- Return `TypedResults` instead of `Results` for strongly-typed responses
- Leverage C# 10+ features like nullable annotations and init-only properties

## OpenAPI Documentation

- Use the built-in OpenAPI document support added in .NET 9
- Define operation summary and description
- Add operationIds using the `WithName` extension method
- Add descriptions to properties and parameters with `[Description()]`
- Set proper content types for requests and responses
- Use document transformers to add elements like servers, tags, and security schemes
- Use schema transformers to apply customizations to OpenAPI schemas
More from github/awesome-copilot