Conway.Endpoints
                             
                            
                                0.3.0
                            
                        
                    dotnet add package Conway.Endpoints --version 0.3.0
NuGet\Install-Package Conway.Endpoints -Version 0.3.0
<PackageReference Include="Conway.Endpoints" Version="0.3.0" />
<PackageVersion Include="Conway.Endpoints" Version="0.3.0" />
<PackageReference Include="Conway.Endpoints" />
paket add Conway.Endpoints --version 0.3.0
#r "nuget: Conway.Endpoints, 0.3.0"
#:package Conway.Endpoints@0.3.0
#addin nuget:?package=Conway.Endpoints&version=0.3.0
#tool nuget:?package=Conway.Endpoints&version=0.3.0
Conway Endpoints
Endpoints is a small library/pattern for defining a single endpoint in Asp.Net Core.
Traditionally, controllers define endpoints through actions (any public method in a Controller class); when there are a small number of endpoints, this works great, but as the number of actions increases, controllers become hard to maintain and test.
Endpoint solves this problem by only having one endpoint per class, which adheres to the single responsibility principle. As a side-effect, you'll have more files to manage, but we see this as an opportunity to organize your code, thus allowing you more visibility into the application's structure.
Getting Started
There are 3 use cases for Endpoint:
- An endpoint where we know the incoming type and the outgoing type. 
- An endpoint without any incoming type and an outgoing type of - IActionResult
- An endpoint where we know the incoming type and an outgoing type of - IActionResult
1. Defining the incoming type and the outgoing type
When the incoming and outgoing types are known.
For example, user details are posted to an endpoint and the endpointed returns the saved user to the caller.
public class KnownIncomingAndOutgoingTypesEndpoint : EndpointBase<UserDetailsRequest, UserDetailsResponse> 
{
    /// <summary>
    /// Save the user details
    /// </summary>
    /// <param name="request"></param>
    /// <returns>Saved user.</returns>
    [HttpPost("api/user/save")]
    public override async Task<ActionResult<UserDetailsResponse>> HandleAsync(UserDetailsRequest request)
    {
        return new UserDetailsResponse
        {
            UserId = 2,
            FirstName = request.FirstName,
            LastName = request.LastName,
            MiddleName = request.MiddleName
        };
    }
}
2. When there is no incoming type
Sometimes requests don't have any data incoming data, it's a simple call to an endpoint. It might be a trigger or request static data, in this case, we don't need an incoming type.
public class OutgoingTypeOnlyEndpoint : EndpointBase
{
    /// <summary>
    /// Gets the weather for today.
    /// </summary>
    /// <returns></returns>
    [HttpGet("api/us/states")]
    public override async Task<IActionResult> HandleAsync()
    {
      var json =  new JsonResult(new[]
        {
            "Alabama",
            "Alaska",
            "Arizona",
            "Arkansas",
            "California",
            "Colorado",
            "Delaware",
            "Florida"
        });
      return json;
    }
}
3. When defining an incoming type with the greatest flexibly for the outgoing type
We don't always know our return type. For example, we might return an array of items under normal circumstances, however, in the event of an error we might return a different type. IActionResult allow us this flexibly.
public class KnownIncomingTypeAndFlexibleOutgoingTypeEndpoint : EndpointBase<SearchRequest>
{
    /// <summary>
    /// Search for most common pets
    /// </summary>
    /// <param name="request">The search term</param>
    /// <returns>Returns results, if no search term is provided an error is returned.</returns>
    [HttpPost("api/search")]
    public override async Task<IActionResult> HandleAsync(SearchRequest request)
    {
        if (!string.IsNullOrEmpty(request.Term))
        {
            //Most common Pets
            var results = new[] {"Cat", "Dog", "Fish", "Chickens", "Hamsters"};
            return new ActionResult<object>(new
            {
                Results = results
            }).Result;
        }
        return new JsonResult(new
        {
            Error = "The search term is missing. Please resubmit with search term",
            ErrorCode = 101
        });
    }
}
This project was inspired by Ardalis's Endpoint project.
| Product | Versions Compatible and additional computed target framework versions. | 
|---|---|
| .NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. 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 was computed. 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. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. | 
| .NET Core | netcoreapp3.1 is compatible. | 
- 
                                                    .NETCoreApp 3.1- Microsoft.AspNetCore.Mvc (>= 2.2.0)
- Microsoft.AspNetCore.Mvc.Core (>= 2.2.5)
 
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 | 
|---|---|---|
| 0.3.0 | 705 | 8/5/2020 |