Alor.OpenAPI
2.0.1
dotnet add package Alor.OpenAPI --version 2.0.1
NuGet\Install-Package Alor.OpenAPI -Version 2.0.1
<PackageReference Include="Alor.OpenAPI" Version="2.0.1" />
<PackageVersion Include="Alor.OpenAPI" Version="2.0.1" />
<PackageReference Include="Alor.OpenAPI" />
paket add Alor.OpenAPI --version 2.0.1
#r "nuget: Alor.OpenAPI, 2.0.1"
#:package Alor.OpenAPI@2.0.1
#addin nuget:?package=Alor.OpenAPI&version=2.0.1
#tool nuget:?package=Alor.OpenAPI&version=2.0.1
Alor OpenAPI SDK
Описание
Alor OpenAPI SDK — это библиотека, написанная на .NET 8, реализующая все методы из спецификации Swagger, за исключением методов со статусом deprecated. SDK упрощает взаимодействие с API, предоставляя удобный интерфейс для работы с различными ресурсами и методами.
Основные возможности
- Полная реализация актуальных методов API Warp OpenAPI.
- Простая интеграция в .NET проекты (в том числе через DI).
- Поддержка работы с веб-сокетами для получения рыночных данных в реальном времени (включая торговлю).
- Готовые примеры использования для быстрого старта.
- Встроенные тесты для проверки корректности работы.
Структура проекта
- WarpOpenAPIv2.yml — спецификация Swagger для генерации методов API.
- Sample Project/ — пример использования SDK в реальном проекте.
- Sample DI Project/ — пример интеграции SDK в реальном проекте через механизм DI.
- Alor.OpenAPI.Tests/ — модульные тесты, демонстрирующие корректность работы методов.
Установка из репозитория
- Убедитесь, что у вас установлен .NET SDK версии 8 или выше.
- Клонируйте репозиторий или загрузите архив с исходным кодом.
- Соберите проект с помощью команды:
dotnet build "Alor OpenAPI SDK.sln"
Установка через NuGet
SDK доступен в официальном NuGet-репозитории.
Установка через .NET CLI
dotnet add package Alor.OpenAPI
Установка через Package Manager Console в Visual Studio
Install-Package Alor.OpenAPI
После установки библиотека будет доступна в вашем проекте, и вы сможете использовать все предоставляемые методы. Для подключения добавьте в проект зависимость Alor.OpenAPI.
Быстрый старт
Пример минимального кода для начала работы с SDK:
using Alor.OpenAPI.Core;
using Alor.OpenAPI.Enums;
using Alor.OpenAPI.Models.Simple;
class Program
{
static async Task Main(string[] args)
{
// Загрузка токена
var token = await File.ReadAllTextAsync("../../tokens/tokenAlorDev.txt");
// Создание клиента
var client = await AlorOpenApiClient.CreateAsync(
Configuration.Dev,
token,
AlorOpenApiLogLevel.Information
);
// Получение списка инструментов
var instruments = await client.Instruments.MdV2SecuritiesGetSimpleAsync(exchange: Exchange.MOEX);
Console.WriteLine($"Получено {instruments.Count()} инструментов.");
// Подписка на данные стаканов
var orderbookSubscriptions = await client.WsPoolManager.Subscriptions.OrderBookGetAndSubscribeSimpleAsync(
data => Console.WriteLine($"Обновление стакана: {data}"),
instruments.Take(5).Select(x=> x.Symbol),
Exchange.MOEX
);
}
}
Полный пример
Полный пример использования SDK доступен в папке Sample Project. Он включает:
- Настройку клиента и загрузку токенов.
- Создание пула соединений для работы с веб-сокетами.
- Подписку на обновления стаканов и позиций.
- Использование таймеров для автоматической переподписки.
🚀 Интеграция с Dependency Injection (.NET)
SDK поддерживает удобную регистрацию и асинхронную инициализацию клиентов через DI разными способами.
1. Регистрация одного клиента в коде
using Alor.OpenAPI.DI;
var options = new OpenApiClientOptions
{
RefreshToken = "your-refresh-token",
Contour = "Prod"
};
services.AddOpenApiClient(options);
Используй этот способ, если задаёшь параметры клиента вручную.
2. Регистрация одного клиента через конфиг
appsettings.json
"Alor": {
"Contour": "Dev",
"RefreshToken": "your-refresh-token"
}
Program.cs
services.AddOpenApiClient(builder.Configuration.GetSection("Alor"));
Для работы с конфиг-секциями требуется установить NuGet:
Microsoft.Extensions.Configuration.Binder
dotnet add package Microsoft.Extensions.Configuration.Binder
Это нужно для корректного маппинга секций конфига в объект
OpenApiClientOptions.
3. Регистрация нескольких клиентов (multi-client, через конфиг)
appsettings.json
"AlorClients": {
"Profile1": { "Contour": "Prod", "RefreshToken": "token-pf1" },
"Profile2": { "Contour": "Dev", "RefreshToken": "token-pf2" }
}
Program.cs
var section = builder.Configuration.GetSection("AlorClients");
services.AddOpenApiClientsFromConfiguration(section);
Все параметры берутся только из json, делегаты при таком подходе НЕ задаются.
4. Получение клиента по имени
public class MyService
{
public MyService(IOpenApiClientProvider provider)
{
var profileClient1 = provider.Get("Profile1");
// ...
}
}
5. Использование клиента в сервисах/контроллерах
public class MyController : ControllerBase
{
private readonly IAlorOpenApiClient _client;
public MyController(IAlorOpenApiClient client)
{
_client = client;
}
public async Task<IActionResult> GetInstruments()
{
var result = await _client.Instruments.MdV2SecuritiesGetSimpleAsync("MOEX");
return Ok(result);
}
}
6. Динамическая установка обработчиков (делегатов) событий websocket
Важно: Делегаты нельзя передать через JSON или IConfiguration!
Если DI-клиент создаётся через конфиг, обработчики назначаются позже — например, в контроллере, сервисе или любом другом месте, где получаешь клиента через DI.
public class MyService
{
public MyService(IAlorOpenApiClient client)
{
// Назначаем обработчик в рантайме
client.SetWsResponseMessageHandler(msg => Console.WriteLine($"WS: {msg}"));
client.SetWsResponseCommandMessageHandler(cmd => Console.WriteLine($"CMD: {cmd}"));
}
}
Такой способ нужен, если требуется реагировать на сообщения WebSocket в бизнес-логике.
Это лучший подход для DI, так как делегаты — это исполняемый код, их невозможно описать в конфиге.
7. Регистрация нескольких клиентов вручную в коде (с любыми параметрами и делегатами)
var profileOptions1 = new OpenApiClientOptions
{
RefreshToken = "token-profile1",
Contour = "Prod",
WsResponseMessageHandler = msg => Console.WriteLine($"PF1: {msg}")
// другие параметры...
};
var profileOptions2 = new OpenApiClientOptions
{
RefreshToken = "token-profile2",
Contour = "Dev",
WsResponseCommandMessageHandler = cmd => Console.WriteLine($"PF2: {cmd}")
// другие параметры...
};
services.AddOpenApiClient("Profile1", profileOptions1);
services.AddOpenApiClient("Profile2", profileOptions2);
Такой способ позволяет задать любые runtime-параметры и делегаты для каждого клиента вручную.
📝 Примечания
- Клиент создаётся асинхронно “в фоне” (через HostedService), не блокируя запуск приложения.
- Несколько клиентов легко регистрируются и доступны по имени.
- Все DI-компоненты покрыты unit-тестами (
Alor.OpenAPI.Tests). - Если обработчики-делегаты нужны — назначай их прямо в месте получения клиента через DI.
Полный пример c DI
Полный пример использования SDK в режиме DI доступен в папке Sample DI Project. Он включает:
- Настройку клиента всемии способами, рассмотренными выше и загрузку токенов.
- Создание контроллера, который работает с клиентами, зарегистрированными в контейнере DI разными способами.
Тестирование
Для запуска тестов выполните команду:
dotnet test "Alor OpenAPI SDK.sln"
Все тесты находятся в папке Alor.OpenAPI.Tests и покрывают основные методы SDK.
Документация API
Подробную документацию по API можно найти по ссылке.
Поддержка
Проект открыт для замечаний и предложений. Для получения поддержки по работе SDK создайте или дополните существующий Issue, в котором подробно опишите Ваш вопрос.
| Product | Versions 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. |
-
net8.0
- App.Metrics (>= 4.3.0)
- App.Metrics.Reporting.Console (>= 4.3.0)
- Microsoft.Extensions.Configuration.Binder (>= 9.0.6)
- Microsoft.Extensions.Hosting.Abstractions (>= 9.0.6)
- Microsoft.Extensions.Logging (>= 9.0.6)
- Polly (>= 8.6.1)
- Serilog (>= 4.3.0)
- Serilog.Sinks.Async (>= 2.1.0)
- Serilog.Sinks.Console (>= 6.0.0)
- Serilog.Sinks.File (>= 7.0.0)
- SpanJson (>= 4.2.1)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.