AArkhipenko.Core
7.0.0
dotnet add package AArkhipenko.Core --version 7.0.0
NuGet\Install-Package AArkhipenko.Core -Version 7.0.0
<PackageReference Include="AArkhipenko.Core" Version="7.0.0" />
<PackageVersion Include="AArkhipenko.Core" Version="7.0.0" />
<PackageReference Include="AArkhipenko.Core" />
paket add AArkhipenko.Core --version 7.0.0
#r "nuget: AArkhipenko.Core, 7.0.0"
#addin nuget:?package=AArkhipenko.Core&version=7.0.0
#tool nuget:?package=AArkhipenko.Core&version=7.0.0
AArkhipenko.Core
Nuget-проект с базовым функционалом
Базовые исключения
- Ошибка задания параметров запроса BadRequestException
- Не найдена сущность NotFoundException
- Ошибка авторизации AuthorizationException
Методы расширения
Все методы расширения находятся здесь
ИД запроса
На каждый запрос к АПИ добавляет в заголовки Request-Chain-Id с ИД запроса
Такой подход позволяет:
- находить в логах данные только по одному запросу
- отслеживать цепочку вызовов в микросервисной системе
Подключение:
var builder = WebApplication.CreateBuilder(args);
builder.Services.AddControllers();
...
var app = builder.Build();
// Использование прослойки, которая добавляет в заголовки ИД запроса
app.UseRequestChainMiddleware();
...
app.MapControllers();
app.Run();
Контроль состояния программы
Добавление АПИ контроля состояния программы Запрос http://localhost:5066/check вернет информацию о состоянии программы Healthy
Подключение:
var builder = WebApplication.CreateBuilder(args);
builder.Services.AddControllers();
// Добавление АПИ контроля состояния программы
builder.Services.AddCustomHealthCheck();
...
var app = builder.Build();
// Использование прослойки контроля состояния программы
app.UseCustomHealthCheck();
...
app.MapControllers();
app.Run();
Версионирование АПИ
В АПИ добавляется информация о версии, что позволяет группировать АПИ по версиям
Подключение:
var builder = WebApplication.CreateBuilder(args);
builder.Services.AddControllers();
// Добавление версионирования
builder.Services.AddVersioning();
...
var app = builder.Build();
...
app.MapControllers();
app.Run();
Единая обработка исключений
Добавление прослойки обработки исключений на самом нижнем уровне
Такой подход позволяет:
- реагировать на все исключения в одном месте
- возращать информацию о исключениях в одном виде
- менять http статус ответа в зависимости от типа исключения
Подключение:
var builder = WebApplication.CreateBuilder(args);
builder.Services.AddControllers();
...
var app = builder.Build();
// Использование простойки, которая обрабатывает исключения
app.UseExceptionMiddleware();
...
app.MapControllers();
app.Run();
Логирование
Nuget-пакет имеет дополнительный функционал, который позволяет расширить логирования
Возможности:
- обогащение лога информацией о начале и завершении выполнении метода
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 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. |
-
net7.0
- Asp.Versioning.Mvc.ApiExplorer (>= 7.1.0)
- Microsoft.AspNetCore.Http.Abstractions (>= 2.3.0)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 8.0.2)
- Microsoft.Extensions.Diagnostics.HealthChecks (>= 7.0.20)
NuGet packages (4)
Showing the top 4 NuGet packages that depend on AArkhipenko.Core:
Package | Downloads |
---|---|
AArkhipenko.Keycloak
Package Description |
|
AArkhipenko.Logging
Package Description |
|
AArkhipenko.Swagger
Package Description |
|
AArkhipenko.UserHelper
Package Description |
GitHub repositories
This package is not used by any popular GitHub repositories.