From dad0ec7b235ed5d91704d6182f51e91674978ee3 Mon Sep 17 00:00:00 2001 From: Victor Lee Date: Thu, 21 Nov 2024 19:28:01 -0800 Subject: [PATCH] removed order fetch after submission (#853) --- .../API/Exchanges/Coinbase/ExchangeCoinbaseAPI.cs | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) diff --git a/src/ExchangeSharp/API/Exchanges/Coinbase/ExchangeCoinbaseAPI.cs b/src/ExchangeSharp/API/Exchanges/Coinbase/ExchangeCoinbaseAPI.cs index b9f55f5e..857c74a3 100644 --- a/src/ExchangeSharp/API/Exchanges/Coinbase/ExchangeCoinbaseAPI.cs +++ b/src/ExchangeSharp/API/Exchanges/Coinbase/ExchangeCoinbaseAPI.cs @@ -14,6 +14,7 @@ The above copyright notice and this permission notice shall be included in all c using Newtonsoft.Json.Linq; using System; using System.Collections.Generic; +using System.Diagnostics; using System.Linq; using System.Threading.Tasks; @@ -450,10 +451,13 @@ protected override async Task OnPlaceOrderAsync(ExchangeOrd try { - JToken result = await MakeJsonRequestAsync($"/orders", payload: payload, requestMethod: "POST" ); - // The Post doesn't return with any status, just a new OrderId. To get the Order Details we have to reQuery. - return await OnGetOrderDetailsAsync(result[ORDERID].ToStringInvariant()); - } + JToken jtokenResult = await MakeJsonRequestAsync($"/orders", payload: payload, requestMethod: "POST" ); + var orderResult = ParseOrder(jtokenResult["success_response"]); + Debug.Assert(jtokenResult.Value("success") == true); + // the jtokenResult doesn't have the order status inside the "success_response" portion, but rather outside of it, so need to set it manually + orderResult.Result = ExchangeAPIOrderResult.PendingOpen; + return orderResult; + } catch (Exception ex) // All fails come back with an exception. { Logger.Error(ex, "Failed to place coinbase error");