SeoPatterns 1.0.1.1

dotnet add package SeoPatterns --version 1.0.1.1
                    
NuGet\Install-Package SeoPatterns -Version 1.0.1.1
                    
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="SeoPatterns" Version="1.0.1.1" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="SeoPatterns" Version="1.0.1.1" />
                    
Directory.Packages.props
<PackageReference Include="SeoPatterns" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add SeoPatterns --version 1.0.1.1
                    
#r "nuget: SeoPatterns, 1.0.1.1"
                    
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package SeoPatterns@1.0.1.1
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=SeoPatterns&version=1.0.1.1
                    
Install as a Cake Addin
#tool nuget:?package=SeoPatterns&version=1.0.1.1
                    
Install as a Cake Tool

NuGet Package: Business Layer Separation

This library allows you to separate your business layer from your controllers.

  1. Create two concrete classes per endpoint in your controller:
  • One implementing SeoPatterns.IBizReq<TResponse>
  • Another implementing SeoPatterns.IBizHandle<TRequest, TResponse>
  1. Register dependencies using the following line:
  • builder.Services.AddBizExec(Assembly.GetExecutingAssembly()); with "using SeoPatterns;"
  • This will register IBizExec and all your IBizHandle classes.
  1. In your controller, inject IBizExec and use it in your endpoint.
  • Create an IBizReq instance by passing all required inputs.
  • Call IBizExec.Process(IBizReq).
  • This will invoke the corresponding business layer (IBizHandle).
  1. Use one BusinessHandler per endpoint.
  • Consider adding a "Features" folder.
  • Inside this folder, create a subfolder for each endpoint, containing its IBizReq and IBizHandle.
  • This makes it easier to manage your business logic.

Many developers create a single large business or service layer that handles logic for all endpoints, which can be difficult to maintain and violates the Single Responsibility Principle. This approach keeps your code modular and maintainable.

=============================================================================

In your Program.cs or StartUp.cs where you register all your dependencies

using SeoPatterns;

builder.Services.AddBizExec(Assembly.GetExecutingAssembly());

=============================================================================

using SeoPatterns;

public class TestController : ControllerBase
{
        private readonly IBizExec _exec;

        public TestController(IBizExec exec)
        {
            _exec = exec;
        }

        [HttpPost()]
        public async Task<ActionResult> Sample([FromBody] SampleInput input)
        {
            if (request == null) return BadRequest("Invalid data");

            var result = await _exec.Process(new SampleBusinessRequest(input));

            return result.Success ? Ok() : StatusCode(result.StatusCode, result);
        }
}

=============================================================================

using SeoPatterns;

/// <summary>
/// The generic type 'TResponse' represents the return type of IBizHandle. You can use any object type you need (e.g., ServiceResult).
/// You can create as many properties as required.
/// The goal is to pass the input object from the controller endpoint through the constructor of this class and assign it to the internal properties.
/// These inputs will then be exposed to IBizHandle, where your business logic will be applied.
/// </summary>
public class SampleBusinessRequest : IBizReq<ServiceResult>
{
    public SampleInput SampleInput { get; set; }

    public SampleBusinessRequest(SampleInput input)
    {
        SampleInput = input;
    }
}

=============================================================================

using SeoPatterns;

/// <summary>
/// The IBizHandle<TRequest, TResponse> interface represents the business layer.
/// The input objects from the controller are exposed through the 'request' object.
/// </summary>
public class SampleBusinessHandler : IBizHandle<SampleBusinessRequest, ServiceResult>
{
    public async Task<ServiceResult> Process(SampleBusinessRequest request, CancellationToken cancellationToken)
    {
        // Your business logic

        return ServiceResult.Ok();
    }
}
Product Compatible and additional computed target framework versions.
.NET 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.  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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

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
1.0.1.1 95 4/25/2025
1.0.1 470 3/24/2025
1.0.0 94 3/22/2025

Initial Release