6.9 KiB
title | author | description | monikerRange | ms.author | ms.custom | ms.date | no-loc | uid | |||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Use web API conventions | pranavkm | Learn about web API conventions in ASP.NET Core. | >= aspnetcore-2.2 | scaddie | mvc | 12/05/2019 |
|
web-api/advanced/conventions |
Use web API conventions
By Pranav Krishnamoorthy and Scott Addie
ASP.NET Core 2.2 and later includes a way to extract common API documentation and apply it to multiple actions, controllers, or all controllers within an assembly. Web API conventions are a substitute for decorating individual actions with [ProducesResponseType]
.
A convention allows you to:
- Define the most common return types and status codes returned from a specific type of action.
- Identify actions that deviate from the defined standard.
ASP.NET Core MVC 2.2 and later includes a set of default conventions in xref:Microsoft.AspNetCore.Mvc.DefaultApiConventions?displayProperty=fullName. The conventions are based on the controller (ValuesController.cs) provided in the ASP.NET Core API project template. If your actions follow the patterns in the template, you should be successful using the default conventions. If the default conventions don't meet your needs, see Create web API conventions.
At runtime, xref:Microsoft.AspNetCore.Mvc.ApiExplorer understands conventions. ApiExplorer
is MVC's abstraction to communicate with OpenAPI (also known as Swagger) document generators. Attributes from the applied convention are associated with an action and are included in the action's OpenAPI documentation. API analyzers also understand conventions. If your action is unconventional (for example, it returns a status code that isn't documented by the applied convention), a warning encourages you to document the status code.
View or download sample code (how to download)
Apply web API conventions
Conventions don't compose; each action may be associated with exactly one convention. More specific conventions take precedence over less specific conventions. The selection is non-deterministic when two or more conventions of the same priority apply to an action. The following options exist to apply a convention to an action, from the most specific to the least specific:
-
Microsoft.AspNetCore.Mvc.ApiConventionMethodAttribute
— Applies to individual actions and specifies the convention type and the convention method that applies.In the following example, the default convention type's
Microsoft.AspNetCore.Mvc.DefaultApiConventions.Put
convention method is applied to theUpdate
action:The
Microsoft.AspNetCore.Mvc.DefaultApiConventions.Put
convention method applies the following attributes to the action:[ProducesDefaultResponseType] [ProducesResponseType(StatusCodes.Status204NoContent)] [ProducesResponseType(StatusCodes.Status404NotFound)] [ProducesResponseType(StatusCodes.Status400BadRequest)]
For more information on
[ProducesDefaultResponseType]
, see Default Response. -
Microsoft.AspNetCore.Mvc.ApiConventionTypeAttribute
applied to a controller — Applies the specified convention type to all actions on the controller. A convention method is marked with hints that determine the actions to which the convention method applies. For more information on hints, see Create web API conventions).In the following example, the default set of conventions is applied to all actions in ContactsConventionController:
-
Microsoft.AspNetCore.Mvc.ApiConventionTypeAttribute
applied to an assembly — Applies the specified convention type to all controllers in the current assembly. As a recommendation, apply assembly-level attributes in the Startup.cs file.In the following example, the default set of conventions is applied to all controllers in the assembly:
Create web API conventions
If the default API conventions don't meet your needs, create your own conventions. A convention is:
- A static type with methods.
- Capable of defining response types and naming requirements on actions.
Response types
These methods are annotated with [ProducesResponseType]
or [ProducesDefaultResponseType]
attributes. For example:
public static class MyAppConventions
{
[ProducesResponseType(StatusCodes.Status200OK)]
[ProducesResponseType(StatusCodes.Status404NotFound)]
public static void Find(int id)
{
}
}
If more specific metadata attributes are absent, applying this convention to an assembly enforces that:
- The convention method applies to any action named
Find
. - A parameter named
id
is present on theFind
action.
Naming requirements
The [ApiConventionNameMatch]
and [ApiConventionTypeMatch]
attributes can be applied to the convention method that determines the actions to which they apply. For example:
[ProducesResponseType(StatusCodes.Status200OK)]
[ProducesResponseType(StatusCodes.Status404NotFound)]
[ApiConventionNameMatch(ApiConventionNameMatchBehavior.Prefix)]
public static void Find(
[ApiConventionNameMatch(ApiConventionNameMatchBehavior.Suffix)]
int id)
{ }
In the preceding example:
- The
Microsoft.AspNetCore.Mvc.ApiExplorer.ApiConventionNameMatchBehavior.Prefix
option applied to the method indicates that the convention matches any action prefixed with "Find". Examples of matching actions includeFind
,FindPet
, andFindById
. - The
Microsoft.AspNetCore.Mvc.ApiExplorer.ApiConventionNameMatchBehavior.Suffix
applied to the parameter indicates that the convention matches methods with exactly one parameter ending in the suffix identifier. Examples include parameters such asid
orpetId
.ApiConventionTypeMatch
can be similarly applied to types to constrain the parameter type. Aparams[]
argument indicates remaining parameters that don't need to be explicitly matched.