forked from osmosis-labs/osmosis
-
Notifications
You must be signed in to change notification settings - Fork 0
/
query.go
144 lines (119 loc) · 3.31 KB
/
query.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
package cli
import (
"fmt"
"strings"
"github.com/spf13/cobra"
"github.com/MonOsmosis/osmosis/v10/x/txfees/types"
"github.com/cosmos/cosmos-sdk/client"
"github.com/cosmos/cosmos-sdk/client/flags"
"github.com/cosmos/cosmos-sdk/version"
)
// GetQueryCmd returns the cli query commands for this module.
func GetQueryCmd() *cobra.Command {
// Group queries under a subcommand
cmd := &cobra.Command{
Use: types.ModuleName,
Short: fmt.Sprintf("Querying commands for the %s module", types.ModuleName),
DisableFlagParsing: true,
SuggestionsMinimumDistance: 2,
RunE: client.ValidateCmd,
}
cmd.AddCommand(
GetCmdFeeTokens(),
GetCmdDenomPoolID(),
GetCmdBaseDenom(),
)
return cmd
}
// GetCmdFeeTokens takes the pool id and returns the matching gauge ids and durations.
func GetCmdFeeTokens() *cobra.Command {
cmd := &cobra.Command{
Use: "fee-tokens",
Short: "Query the list of non-basedenom fee tokens and their associated pool ids",
Long: strings.TrimSpace(
fmt.Sprintf(`Query the list of non-basedenom fee tokens and their associated pool ids
Example:
$ %s query txfees fee-tokens
`,
version.AppName,
),
),
Args: cobra.ExactArgs(0),
RunE: func(cmd *cobra.Command, args []string) error {
clientCtx, err := client.GetClientQueryContext(cmd)
if err != nil {
return err
}
queryClient := types.NewQueryClient(clientCtx)
res, err := queryClient.FeeTokens(cmd.Context(), &types.QueryFeeTokensRequest{})
if err != nil {
return err
}
return clientCtx.PrintProto(res)
},
}
flags.AddQueryFlagsToCmd(cmd)
return cmd
}
// GetCmdDenomPoolID takes the pool id and returns the matching gauge ids and durations.
func GetCmdDenomPoolID() *cobra.Command {
cmd := &cobra.Command{
Use: "denom-pool-id",
Short: "Query the pool id associated with a specific whitelisted fee token",
Long: strings.TrimSpace(
fmt.Sprintf(`Query the pool id associated with a specific fee token
Example:
$ %s query txfees denom-pool-id [denom]
`,
version.AppName,
),
),
Args: cobra.ExactArgs(1),
RunE: func(cmd *cobra.Command, args []string) error {
clientCtx, err := client.GetClientQueryContext(cmd)
if err != nil {
return err
}
queryClient := types.NewQueryClient(clientCtx)
res, err := queryClient.DenomPoolId(cmd.Context(), &types.QueryDenomPoolIdRequest{
Denom: args[0],
})
if err != nil {
return err
}
return clientCtx.PrintProto(res)
},
}
flags.AddQueryFlagsToCmd(cmd)
return cmd
}
// GetCmdBaseDenom takes the pool id and returns the matching gauge ids and weights.
func GetCmdBaseDenom() *cobra.Command {
cmd := &cobra.Command{
Use: "base-denom",
Short: "Query the base fee denom",
Long: strings.TrimSpace(
fmt.Sprintf(`Query the base fee denom.
Example:
$ %s query txfees base-denom
`,
version.AppName,
),
),
Args: cobra.ExactArgs(0),
RunE: func(cmd *cobra.Command, args []string) error {
clientCtx, err := client.GetClientQueryContext(cmd)
if err != nil {
return err
}
queryClient := types.NewQueryClient(clientCtx)
res, err := queryClient.BaseDenom(cmd.Context(), &types.QueryBaseDenomRequest{})
if err != nil {
return err
}
return clientCtx.PrintProto(res)
},
}
flags.AddQueryFlagsToCmd(cmd)
return cmd
}