According to https://github.com/dotnet/runtime/issues/65396, using a new JsonSerializerOptions every time JsonSerializer is invoked is a suboptimal pattern. Fix this by caching JsonSerializerOptions instances.
29 lines
1.1 KiB
C#
29 lines
1.1 KiB
C#
namespace Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator.Services;
|
|
|
|
public class OrderApiClient : IOrderApiClient
|
|
{
|
|
private readonly HttpClient _apiClient;
|
|
private readonly ILogger<OrderApiClient> _logger;
|
|
private readonly UrlsConfig _urls;
|
|
|
|
public OrderApiClient(HttpClient httpClient, ILogger<OrderApiClient> logger, IOptions<UrlsConfig> config)
|
|
{
|
|
_apiClient = httpClient;
|
|
_logger = logger;
|
|
_urls = config.Value;
|
|
}
|
|
|
|
public async Task<OrderData> GetOrderDraftFromBasketAsync(BasketData basket)
|
|
{
|
|
var url = $"{_urls.Orders}{UrlsConfig.OrdersOperations.GetOrderDraft()}";
|
|
var content = new StringContent(JsonSerializer.Serialize(basket), System.Text.Encoding.UTF8, "application/json");
|
|
var response = await _apiClient.PostAsync(url, content);
|
|
|
|
response.EnsureSuccessStatusCode();
|
|
|
|
var ordersDraftResponse = await response.Content.ReadAsStringAsync();
|
|
|
|
return JsonSerializer.Deserialize<OrderData>(ordersDraftResponse, JsonHelper.CaseInsensitiveOptions);
|
|
}
|
|
}
|