Merge pull request #996 from andycheng123/fix/general-order-executor

fix/general-order-executor: do not check for base balance for futures
This commit is contained in:
Andy Cheng 2022-10-18 19:14:18 +08:00 committed by GitHub
commit 7dd951e39c
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -230,6 +230,7 @@ func (e *GeneralOrderExecutor) reduceQuantityAndSubmitOrder(ctx context.Context,
var err error var err error
for i := 0; i < submitOrderRetryLimit; i++ { for i := 0; i < submitOrderRetryLimit; i++ {
q := submitOrder.Quantity.Mul(fixedpoint.One.Sub(quantityReduceDelta)) q := submitOrder.Quantity.Mul(fixedpoint.One.Sub(quantityReduceDelta))
if !e.session.Futures {
if submitOrder.Side == types.SideTypeSell { if submitOrder.Side == types.SideTypeSell {
if baseBalance, ok := e.session.GetAccount().Balance(e.position.Market.BaseCurrency); ok { if baseBalance, ok := e.session.GetAccount().Balance(e.position.Market.BaseCurrency); ok {
q = fixedpoint.Min(q, baseBalance.Available) q = fixedpoint.Min(q, baseBalance.Available)
@ -239,6 +240,7 @@ func (e *GeneralOrderExecutor) reduceQuantityAndSubmitOrder(ctx context.Context,
q = fixedpoint.Min(q, quoteBalance.Available.Div(price)) q = fixedpoint.Min(q, quoteBalance.Available.Div(price))
} }
} }
}
log.Warnf("retrying order, adjusting order quantity: %v -> %v", submitOrder.Quantity, q) log.Warnf("retrying order, adjusting order quantity: %v -> %v", submitOrder.Quantity, q)
submitOrder.Quantity = q submitOrder.Quantity = q