eQuantic.Core.Api 1.7.15

There is a newer version of this package available.
See the version list below for details.
dotnet add package eQuantic.Core.Api --version 1.7.15                
NuGet\Install-Package eQuantic.Core.Api -Version 1.7.15                
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="eQuantic.Core.Api" Version="1.7.15" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add eQuantic.Core.Api --version 1.7.15                
#r "nuget: eQuantic.Core.Api, 1.7.15"                
#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.
// Install eQuantic.Core.Api as a Cake Addin
#addin nuget:?package=eQuantic.Core.Api&version=1.7.15

// Install eQuantic.Core.Api as a Cake Tool
#tool nuget:?package=eQuantic.Core.Api&version=1.7.15                

eQuantic.Core.Api Library

The eQuantic Core API provides all the implementation needed to publish standard APIs.

To install eQuantic.Core.Api, run the following command in the Package Manager Console

Install-Package eQuantic.Core.Api

Example of implementation

The data entities

[Table("orders")]
public class OrderData : EntityDataBase
{
    [Key]
    public string Id { get; set; } = string.Empty;
    public DateTime Date { get; set; }
    
    public virtual ICollection<OrderItemData> Items { get; set; } = new HashSet<OrderItemData>();
}

[Table("orderItems")]
public class OrderItemData : EntityDataBase, IWithReferenceId<OrderItemData, int>
{
    [Key]
    public int Id { get; set; }
    public int OrderId { get; set; }
    
    [ForeignKey(nameof(OrderId))]
    public virtual OrderData? Order { get; set; }
    
    [Required]
    [MaxLength(200)]
    public string Name { get; set; } = string.Empty;
}

The models

public class Order
{
    public string Id { get; set; } = string.Empty;
    public DateTime Date { get; set; }
}

public class OrderItem
{
    public int Id { get; set; }
    public int OrderId { get; set; }
    public string Name { get; set; } = string.Empty;
}

The request models

public class OrderRequest
{
    public DateTime? Date { get; set; }
}

public class OrderItemRequest
{
    public string? Name { get; set; }
}

The mappers

public class OrderMapper : IMapper<OrderData, Order>, IMapper<OrderRequest, OrderData>
{
    public Order? Map(OrderData? source)
    {
        return Map(source, new Order());
    }

    public Order? Map(OrderData? source, Order? destination)
    {
        if (source == null)
        {
            return null;
        }

        if (destination == null)
        {
            return Map(source);
        }

        destination.Id = source.Id;
        destination.Date = source.Date;

        return destination;
    }

    public OrderData? Map(OrderRequest? source)
    {
        return Map(source, new OrderData());
    }

    public OrderData? Map(OrderRequest? source, OrderData? destination)
    {
        if (source == null)
        {
            return null;
        }

        if (destination == null)
        {
            return Map(source);
        }
        
        destination.Date = source.Date ?? DateTime.UtcNow;

        return destination;
    }
}

The services

public interface IOrderService : IApplicationService
{
    
}

[MapCrudEndpoints]
public class OrderService : IOrderService
{
    private readonly IMapperFactory _mapperFactory;
    private readonly ILogger<ExampleService> _logger;
    private readonly IAsyncQueryableRepository<IQueryableUnitOfWork, OrderData, int> _repository;
    
    public OrderService(
        IApplicationContext<int> applicationContext,
        IQueryableUnitOfWork unitOfWork, 
        IMapperFactory mapperFactory, 
        ILogger<OrderService> logger)
    {
        _mapperFactory = mapperFactory;
        _logger = logger;
        _repository = unitOfWork.GetAsyncQueryableRepository<IQueryableUnitOfWork, OrderData, int>();
    }
    
    public async Task<Order?> GetByIdAsync(int orderId, CancellationToken cancellationToken = default)
    {
        var item = await _repository.GetAsync(orderId, cancellationToken: cancellationToken);

        if (item == null)
        {
            var ex = new EntityNotFoundException<int>(orderId);
            _logger.LogError(ex, "{ServiceName} - GetById: Entity of {EntityName} not found", GetType().Name,
                nameof(OrderData));
            throw ex;
        }

        var mapper = _mapperFactory.GetMapper<OrderData, Order>()!;
        var result = mapper.Map(item);
        
        return result;
    }
}

The Program.cs

var builder = WebApplication.CreateBuilder(args);
var assembly = typeof(Program).Assembly;

builder.Services.AddDbContext<ExampleDbContext>(opt =>
    opt.UseInMemoryDatabase("ExampleDb"));
        
builder.Services.AddQueryableRepositories<ExampleUnitOfWork>(opt =>
{
    opt.FromAssembly(assembly)
        .AddLifetime(ServiceLifetime.Scoped);
});

builder.Services
    .AddMappers(opt => opt.FromAssembly(assembly))
    .AddTransient<IExampleService, ExampleService>()
    .AddControllers()
    .AddJsonOptions(options =>
    {
        options.JsonSerializerOptions.Converters.Add(new JsonStringEnumConverter());
        options.JsonSerializerOptions.PropertyNamingPolicy = JsonNamingPolicy.CamelCase;
    })
    .AddFilterModelBinder()
    .AddSortModelBinder();

builder.Services
    .AddEndpointsApiExplorer()
    .AddApiDocumentation(opt => opt.WithTitle("Example API"));

var app = builder.Build();

if (app.Environment.IsDevelopment())
{
    app.UseApiDocumentation();
}

app.UseHttpsRedirection();
app.UseRouting();
app.MapControllers();
app.MapGet("orders/{id}", GetById);

app.Run();
return;

async Task<Results<Ok<Order>, NotFound>> GetById(
    [FromRoute] int id, 
    [FromServices] IOrderService service, 
    CancellationToken cancellationToken)
{
    var item = await service.GetByIdAsync(id, cancellationToken);
    if (item == null)
        return TypedResults.NotFound();

    return TypedResults.Ok(item);
}

Product Compatible and additional computed target framework versions.
.NET net6.0 is compatible.  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 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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (1)

Showing the top 1 NuGet packages that depend on eQuantic.Core.Api:

Package Downloads
eQuantic.Core.Api.Crud

eQuantic API CRUD Library

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
1.7.17 79 1/21/2025
1.7.16 174 1/10/2025
1.7.15 47 1/8/2025
1.7.14 154 12/27/2024
1.7.13 259 11/20/2024
1.7.12 134 11/20/2024
1.7.11 89 11/19/2024
1.7.10 197 11/9/2024
1.7.9 206 10/11/2024
1.7.8 165 10/4/2024
1.7.7 118 10/4/2024
1.7.6 126 10/3/2024
1.7.5 294 9/4/2024
1.7.4 169 9/1/2024
1.7.3 155 8/25/2024
1.7.2 208 7/29/2024
1.7.1 103 7/28/2024
1.7.0 98 7/28/2024
1.6.25 104 7/27/2024
1.6.24 183 7/22/2024
1.6.23 246 6/23/2024
1.6.22 108 6/23/2024
1.6.21 117 6/22/2024
1.6.20 111 6/21/2024
1.6.19 265 5/18/2024
1.6.18 250 5/4/2024
1.6.17 331 4/11/2024
1.6.16 149 4/11/2024
1.6.15 129 4/9/2024
1.6.14 147 4/4/2024
1.6.13 154 4/2/2024
1.6.12 177 3/21/2024
1.6.11 127 3/21/2024
1.6.10 157 3/18/2024
1.6.9 143 3/10/2024
1.6.8 147 2/18/2024
1.6.7 132 2/17/2024
1.6.6 145 2/14/2024
1.6.5 141 2/13/2024
1.6.4 134 2/12/2024
1.6.3 138 2/10/2024
1.6.2 129 2/10/2024
1.6.1 153 1/22/2024
1.6.0 216 12/21/2023
1.5.2 168 12/10/2023
1.5.1 169 12/5/2023
1.5.0 164 12/5/2023
1.4.0 148 12/3/2023
1.3.3 200 11/18/2023
1.3.2 167 11/18/2023
1.3.1 172 11/15/2023
1.3.0 122 11/15/2023
1.2.3 162 11/2/2023
1.2.2 126 11/2/2023
1.2.1 216 10/21/2023
1.2.0 126 10/21/2023
1.1.6 167 10/9/2023
1.1.5 167 10/7/2023
1.1.4 176 10/2/2023
1.1.3 144 10/1/2023
1.1.2 178 9/25/2023
1.1.1 140 9/24/2023
1.1.0 213 9/4/2023
1.0.14 274 8/13/2023
1.0.13 189 8/13/2023
1.0.12 177 8/13/2023
1.0.11 178 8/13/2023
1.0.10 174 8/8/2023
1.0.9 217 8/3/2023
1.0.8 187 7/30/2023
1.0.7 191 7/22/2023
1.0.6 185 7/21/2023
1.0.5 188 7/21/2023
1.0.4 184 7/20/2023
1.0.3 171 7/20/2023
1.0.2 197 7/19/2023
1.0.0.1 184 7/5/2023
1.0.0 161 7/5/2023

Common API implementations