MinimalApiBuilder 5.0.0-beta.1
See the version list below for details.
dotnet add package MinimalApiBuilder --version 5.0.0-beta.1
NuGet\Install-Package MinimalApiBuilder -Version 5.0.0-beta.1
<PackageReference Include="MinimalApiBuilder" Version="5.0.0-beta.1" />
paket add MinimalApiBuilder --version 5.0.0-beta.1
#r "nuget: MinimalApiBuilder, 5.0.0-beta.1"
// Install MinimalApiBuilder as a Cake Addin #addin nuget:?package=MinimalApiBuilder&version=5.0.0-beta.1&prerelease // Install MinimalApiBuilder as a Cake Tool #tool nuget:?package=MinimalApiBuilder&version=5.0.0-beta.1&prerelease
MinimalApiBuilder
Reflectionless, source-generated, thin abstraction layer over the ASP.NET Core Minimal APIs interface.
How to Use
Based on the Vertical Slice Architecture with Feature
folder.
There is one class for every API endpoint. A basic example looks like the following:
using Microsoft.AspNetCore.Mvc;
using MinimalApiBuilder;
public partial class BasicEndpoint : MinimalApiBuilderEndpoint
{
private static string Handle([FromServices] BasicEndpoint endpoint)
{
return "Hello, World!";
}
}
The endpoint class must be partial
, inherit from MinimalApiBuilderEndpoint
,
and have a static
Handle
or HandleAsync
method with the containing type passed
from dependency injection.
The endpoint is mapped through the typical IEndpointRouteBuilder
Map<Verb>
extension methods:
app.MapGet<BasicEndpoint>("/hello");
The above is functionally equivalent to:
app.MapGet("/hello", static () => "Hello, World!");
This library depends on FluentValidation >= 11
. An endpoint
can have a validated request object:
public struct BasicRequest
{
public required string Name { get; init; }
}
public partial class BasicRequestEndpoint : MinimalApiBuilderEndpoint
{
private static string Handle([FromServices] BasicRequestEndpoint endpoint,
[AsParameters] BasicRequest request)
{
return $"Hello, {request.Name}!";
}
}
public class BasicRequestValidator : AbstractValidator<BasicRequest>
{
public BasicRequestValidator()
{
RuleFor(static request => request.Name).MinimumLength(2);
}
}
app.MapGet<BasicRequestEndpoint>("/hello/{name}");
The incremental generator will generate code to validate the request object before the handler is called and return
a 400 Bad Request
response if the validation fails. In Program.cs
the below
builder.Services.AddMinimalApiBuilderEndpoints();
needs to be added to register the necessary types with dependency injection.
Configuration
Users can add configuration through entries in .editorconfig
or with MSBuild properties.
The following options are available:
minimalapibuilder_assign_name_to_endpoint
(true
| false
)
If true
, the generator will add a unique public const string Name
field
to the endpoint classes and call
the WithName
extension method when mapping them.
minimalapibuilder_assign_name_to_endpoint = true
<PropertyGroup>
<minimalapibuilder_assign_name_to_endpoint>true</minimalapibuilder_assign_name_to_endpoint>
</PropertyGroup>
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net7.0 is compatible. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
-
net7.0
- FluentValidation (>= 11.0.0)
-
net8.0
- FluentValidation (>= 11.0.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
5.0.0-beta.10 | 111 | 1/25/2024 |
5.0.0-beta.9 | 75 | 1/22/2024 |
5.0.0-beta.8 | 109 | 1/3/2024 |
5.0.0-beta.7 | 105 | 12/29/2023 |
5.0.0-beta.6 | 85 | 12/18/2023 |
5.0.0-beta.5 | 98 | 12/15/2023 |
5.0.0-beta.4 | 105 | 11/27/2023 |
5.0.0-beta.3 | 96 | 11/23/2023 |
5.0.0-beta.2 | 83 | 11/23/2023 |
5.0.0-beta.1 | 112 | 11/21/2023 |
4.0.0 | 263 | 11/12/2023 |
3.1.0 | 128 | 11/8/2023 |
3.0.1 | 121 | 11/6/2023 |
3.0.0 | 210 | 11/6/2023 |
2.0.0 | 152 | 10/30/2023 |
1.4.0 | 148 | 10/27/2023 |
1.3.3 | 284 | 5/11/2023 |
1.3.2 | 151 | 5/8/2023 |
1.3.1 | 151 | 5/8/2023 |
1.3.0 | 148 | 5/8/2023 |
1.2.0 | 154 | 5/6/2023 |
1.1.0 | 178 | 5/1/2023 |
1.0.1 | 349 | 2/10/2023 |
1.0.0 | 372 | 1/5/2023 |
0.1.0-beta.12 | 114 | 1/5/2023 |
0.1.0-beta.11 | 112 | 1/5/2023 |
0.1.0-beta.10 | 106 | 1/5/2023 |
0.1.0-beta.9 | 124 | 1/5/2023 |
0.1.0-beta.8 | 124 | 1/5/2023 |
0.1.0-beta.7 | 120 | 1/4/2023 |
0.1.0-beta.6 | 114 | 1/4/2023 |
0.1.0-beta.5 | 113 | 1/4/2023 |
0.1.0-beta.4 | 117 | 1/4/2023 |
0.1.0-beta.3 | 116 | 1/4/2023 |
0.1.0-beta.2 | 118 | 12/31/2022 |
0.1.0-beta.1 | 118 | 12/30/2022 |