From ae5be2122871fcf95ce5c8730084a8dac778011b Mon Sep 17 00:00:00 2001 From: Dzmitry Hil Date: Fri, 13 Dec 2024 09:34:38 +0300 Subject: [PATCH] Improve DEX place-order CLI --- x/dex/client/cli/tx.go | 48 +++++++++++++++++-------------------- x/dex/client/cli/tx_test.go | 12 +--------- 2 files changed, 23 insertions(+), 37 deletions(-) diff --git a/x/dex/client/cli/tx.go b/x/dex/client/cli/tx.go index 6a2adafea..da05fc3f0 100644 --- a/x/dex/client/cli/tx.go +++ b/x/dex/client/cli/tx.go @@ -27,10 +27,6 @@ const ( GoodTilBlockHeightFlag = "good-til-block-height" // GoodTilBlockTimeFlag is good til block time flag. GoodTilBlockTimeFlag = "good-til-block-time" - // OrderTypeLimit is limit order type. - OrderTypeLimit = "limit" - // OrderTypeMarket is limit order market. - OrderTypeMarket = "market" // TimeInForce is time-in-force flag. TimeInForce = "time-in-force" ) @@ -60,15 +56,19 @@ func GetTxCmd() *cobra.Command { func CmdPlaceOrder() *cobra.Command { availableTimeInForces := lo.Values(types.TimeInForce_name) sort.Strings(availableTimeInForces) + availableOrderTypes := lo.Values(types.OrderType_name) + sort.Strings(availableTimeInForces) + availableSides := lo.Values(types.Side_name) + sort.Strings(availableTimeInForces) cmd := &cobra.Command{ - Use: "place-order [type (limit,market)] [id] [base_denom] [quote_denom] [quantity] [side] --price 123e-2 --time-in-force=" + strings.Join(availableTimeInForces, ",") + " --good-til-block-height=123 --good-til-block-time=1727124446 --from [sender]", //nolint:lll // string example + Use: "place-order [type (" + strings.Join(availableOrderTypes, ",") + ")] [id] [base_denom] [quote_denom] [quantity] [side (" + strings.Join(availableSides, ",") + ")] --price 123e-2 --time-in-force=" + strings.Join(availableTimeInForces, ",") + " --good-til-block-height=123 --good-til-block-time=1727124446 --from [sender]", //nolint:lll // string example Args: cobra.ExactArgs(6), Short: "Place new order", Long: strings.TrimSpace( fmt.Sprintf(`Place new order. Example: -$ %s tx %s place-order id1 denom1 denom2 123e-2 10000 buy --from [sender] +$ %s tx %s cored tx dex place-order ORDER_TYPE_LIMIT "my-order-id1" denom1 denom2 1000 SIDE_SELL --price 12e-1 --time-in-force=TIME_IN_FORCE_GTC --from [sender] `, version.AppName, types.ModuleName, ), @@ -81,25 +81,8 @@ $ %s tx %s place-order id1 denom1 denom2 123e-2 10000 buy --from [sender] sender := clientCtx.GetFromAddress() - var orderType types.OrderType - timeInForceString, err := cmd.Flags().GetString(TimeInForce) - timeInForceInt, ok := types.TimeInForce_value[timeInForceString] + orderType, ok := types.OrderType_value[args[0]] if !ok { - return errors.Errorf( - "unknown TimeInForce '%s',available TimeInForces: %s", - timeInForceString, strings.Join(availableTimeInForces, ","), - ) - } - if err != nil { - return errors.WithStack(err) - } - timeInForce := types.TimeInForce(timeInForceInt) - switch args[0] { - case OrderTypeLimit: - orderType = types.ORDER_TYPE_LIMIT - case OrderTypeMarket: - orderType = types.ORDER_TYPE_MARKET - default: return errors.Errorf("unknown type '%s'", args[0]) } @@ -109,7 +92,7 @@ $ %s tx %s place-order id1 denom1 denom2 123e-2 10000 buy --from [sender] quantity, ok := sdkmath.NewIntFromString(args[4]) if !ok { - return sdkerrors.Wrap(err, "invalid quantity") + return errors.New("invalid quantity") } side, ok := types.Side_value[args[5]] @@ -144,9 +127,22 @@ $ %s tx %s place-order id1 denom1 denom2 123e-2 10000 buy --from [sender] goodTilBlockTime = lo.ToPtr(time.Unix(goodTilBlockTimeNum, 0)) } + timeInForceString, err := cmd.Flags().GetString(TimeInForce) + timeInForceInt, ok := types.TimeInForce_value[timeInForceString] + if !ok { + return errors.Errorf( + "unknown TimeInForce '%s',available TimeInForces: %s", + timeInForceString, strings.Join(availableTimeInForces, ","), + ) + } + if err != nil { + return errors.WithStack(err) + } + timeInForce := types.TimeInForce(timeInForceInt) + msg := &types.MsgPlaceOrder{ Sender: sender.String(), - Type: orderType, + Type: types.OrderType(orderType), ID: id, BaseDenom: baseDenom, QuoteDenom: quoteDenom, diff --git a/x/dex/client/cli/tx_test.go b/x/dex/client/cli/tx_test.go index d8de18207..facd4de3a 100644 --- a/x/dex/client/cli/tx_test.go +++ b/x/dex/client/cli/tx_test.go @@ -251,18 +251,8 @@ func placeOrder( testNetwork *network.Network, order types.Order, ) { - var orderType string - switch order.Type { - case types.ORDER_TYPE_LIMIT: - orderType = cli.OrderTypeLimit - case types.ORDER_TYPE_MARKET: - orderType = cli.OrderTypeMarket - default: - requireT.Fail(fmt.Sprintf("unknown type '%s'", order.Type)) - } - args := []string{ - orderType, + order.Type.String(), order.ID, order.BaseDenom, order.QuoteDenom,