Confiti.MoySklad.Remap.Sdk
0.21.1
dotnet add package Confiti.MoySklad.Remap.Sdk --version 0.21.1
NuGet\Install-Package Confiti.MoySklad.Remap.Sdk -Version 0.21.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="Confiti.MoySklad.Remap.Sdk" Version="0.21.1" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Confiti.MoySklad.Remap.Sdk --version 0.21.1
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: Confiti.MoySklad.Remap.Sdk, 0.21.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.
// Install Confiti.MoySklad.Remap.Sdk as a Cake Addin #addin nuget:?package=Confiti.MoySklad.Remap.Sdk&version=0.21.1 // Install Confiti.MoySklad.Remap.Sdk as a Cake Tool #tool nuget:?package=Confiti.MoySklad.Remap.Sdk&version=0.21.1
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
МойСклад C# API client
Реализация C# клиента для МойСклад API
Поддерживаемые API
- МойСклад Remap API v1.2
Начало работы c Remap API
Быстрый старт
var credentials = new MoySkladCredentials()
{
AccessToken = "your-access-token"
// или
Username = "your-username",
Password = "your-password",
};
var api = new MoySkladApi(credentials);
var response = await api.Assortment.GetAllAsync();
Пользовательский HttpClient
var httpClient = new HttpClient(new HttpClientHandler()
{
// gZip обязателен
AutomaticDecompression = DecompressionMethods.GZip
});
var credentials = new MoySkladCredentials()
{
AccessToken = "your-access-token"
};
var api = new MoySkladApi(credentials, httpClient);
Фильтрация
var query = new AssortmentApiParameterBuilder();
// фильтр '='
query.Parameter(p => p.Name).Should().Be("foo");
// вложенный фильтр '='
query.Parameter(p => p.Alcoholic.Type).Should().Be(123);
// множественный фильтр '='
query.Parameter(p => p.Archived).Should().Be(true).Or.Be(false);
// фильтр '~'
query.Parameter(p => p.Article).Should().Contains("foo");
// фильтр '~='
query.Parameter(p => p.Article).Should().StartsWith("foo");
// фильтр '>=' и '<='
query.Parameter(p => p.Updated).Should()
.BeGreaterOrEqualTo(DateTime.Parse("2020-07-10 12:00:00"))
.And
.BeLessOrEqualTo(DateTime.Parse("2020-07-12 12:00:00"));
// фильтр по пользовательскому полю
query.Parameter("your-custom-attribute-href").Should().Be(123);
var response = await api.Assortment.GetAllAsync(query);
Сортировка
query.Order().By(p => p.Name)
// пользовательское поле
.And.By("your-custom-property-name");
// по убыванию
query.Order().By(p => p.Name, OrderBy.Desc)
Limit и Offset
query.Limit(100);
query.Offset(50);
Контекстный поиск
query.Search("foo");
Группировка
query.GroupBy(GroupBy.Consignment);
Expand
query.Expand().With(p => p.Images)
.And.With(p => p.Product)
// вложенный
.And.With(p => p.SalePrices.Currency)
.And.With(p => p.BuyPrice.Currency)
.And.With(p => p.Product.SalePrices.Currency)
.And.With(p => p.Product.BuyPrice.Currency)
// пользовательское поле
.And.With("your-custom-property-name")
Загрузка картинок
var imagesResponse = await api.Product.Images.GetAllAsync(Guid.Parse("product-id"));
foreach (var image in imagesResponse.Payload.Rows)
{
var imageDataResponse = await api.Product.Images.DownloadAsync(image);
await using (imageDataResponse.Payload)
{
if (imageDataResponse.Payload is MemoryStream memoryStream)
{
var imageData = memoryStream.ToArray();
// обработать изображение
}
}
}
Получение метаданных
await api.Product.Metadata.GetAsync();
Обработка исключений
try
{
await _moySkladApi.Counterparty.GetAsync(counterpartyId);
}
catch (ApiException ex)
{
// обработать код ошибки
if (ex.ErrorCode == 404) { ... }
// обработать ошибки
foreach (var error in ex.Errors) { ... }
// полное описание ошибки
// cодержит все коды/описания по каждой ошибке из ex.Errors.
_logger.Log(ex.Message);
}
Сборка и запуск тестов
- В корневой папке в файле
build.ps1
укажитеAPI_LOGIN
иAPI_PASSWORD
build.ps1
# Enter your login and password
# $Env:API_LOGIN = "enter-your-api-login-here"
# $Env:API_PASSWORD = "enter-your-api-password-here"
- Запустите
build.ps1
Поддержка
Я открыт для любого сотрудничества и расширения функционала данного проекта. Pull requests приветствуются, однако сначала откройте issue для обсуждения.
Если вам понравился данный проект, воткните ⭐
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. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
-
.NETStandard 2.0
- Newtonsoft.Json (>= 12.0.3)
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.21.1 | 869 | 7/22/2024 |
0.21.0 | 119 | 7/22/2024 |
0.20.1 | 120 | 7/18/2024 |
0.20.0 | 126 | 6/17/2024 |
0.19.0 | 127 | 5/16/2024 |
0.18.0 | 733 | 10/19/2023 |
0.17.1 | 386 | 12/26/2022 |
0.17.0 | 364 | 11/13/2022 |
0.16.1 | 445 | 10/30/2022 |
0.15.2 | 441 | 8/16/2022 |
0.15.1 | 421 | 8/15/2022 |
0.15.0 | 417 | 8/14/2022 |
0.14.0 | 421 | 8/14/2022 |
0.13.1 | 492 | 4/11/2022 |
0.13.0 | 439 | 3/23/2022 |
0.12.0 | 438 | 3/23/2022 |
0.11.0 | 443 | 3/18/2022 |
0.9.1 | 405 | 9/4/2021 |
0.9.0 | 327 | 9/1/2021 |
0.8.0 | 361 | 6/25/2021 |
0.7.0 | 390 | 6/17/2021 |
0.6.0 | 389 | 6/13/2021 |
0.5.0 | 328 | 5/9/2021 |
0.4.2 | 321 | 4/15/2021 |
0.3.2 | 352 | 2/13/2021 |
0.3.1 | 341 | 2/12/2021 |
0.3.0 | 360 | 2/7/2021 |