feat: add auto-cli customization options (#11763)

* feat(cli/v2): add command & flag proto options

* WIP

* docs

* update

* change name to use

* update use

* rename to autocli

* updates

* switch to (hopefully) more intuitive design

* docs

* updates

* updates

* add flag_options example
This commit is contained in:
Aaron Craelius 2022-09-12 11:51:08 -04:00 committed by GitHub
parent 97a77a47dc
commit b41fd3fbf5
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 5129 additions and 1 deletions

File diff suppressed because it is too large Load Diff

View File

@ -0,0 +1,28 @@
tx:
service: cosmos.bank.v1beta1.Msg
rpc_command_options:
- rpc_method: Send
use: send [from_key_or_address] [to_address] [amount...]
positional_args:
- proto_field: from_address
- proto_field: to_address
- proto_field: amount
varargs: true
query:
service: cosmos.bank.v1beta1.Query
rpc_command_options:
- rpc_method: Balance
use: balance [address] [denom]
positional_args:
- proto_field: address
- proto_field: denom
- rpc_method: SupplyOf
# this is a contrived example of how to customize flag options
# we would likely prefer positional args here, but this demonstrates usage
use: supply-of --denom [denom]
flag_options:
# flag_options is a map of proto field names to customization options
denom:
shorthand: d
usage: the denom to query

View File

@ -0,0 +1,129 @@
syntax = "proto3";
package cosmos.autocli.v1;
import "google/protobuf/descriptor.proto";
option go_package = "github.com/cosmos/cosmos-sdk/api/cosmos/base/cli/v1;cliv1";
// ModuleOptions describes the CLI options for a Cosmos SDK module.
message ModuleOptions {
// tx describes the tx command for the module.
ServiceCommandDescriptor tx = 1;
// query describes the tx command for the module.
ServiceCommandDescriptor query = 2;
}
// ServiceCommandDescriptor describes a CLI command based on a protobuf service.
message ServiceCommandDescriptor {
// service is the fully qualified name of the protobuf service to build
// the command from. It can be left empty if sub_commands are used instead
// which may be the case if a module provides multiple tx and/or query services.
string service = 1;
// rpc_command_options are options for commands generated from rpc methods.
// If no options are specified for a given rpc method on the service, a
// command will be generated for that method with the default options.
repeated RpcCommandOptions rpc_command_options = 2;
// sub_commands is a map of optional sub-commands for this command based on
// different protobuf services. The map key is used as the name of the
// sub-command.
map<string, ServiceCommandDescriptor> sub_commands = 3;
}
// RpcCommandOptions specifies options for commands generated from protobuf
// rpc methods.
message RpcCommandOptions {
// rpc_method is short name of the protobuf rpc method that this command is
// generated from.
string rpc_method = 1;
// use is the one-line usage method. It also allows specifying an alternate
// name for the command as the first word of the usage text.
//
// By default the name of an rpc command is the kebab-case short name of the
// rpc method.
string use = 2;
// long is the long message shown in the 'help <this-command>' output.
string long = 3;
// short is the short description shown in the 'help' output.
string short = 4;
// example is examples of how to use the command.
string example = 5;
// alias is an array of aliases that can be used instead of the first word in Use.
repeated string alias = 6;
// suggest_for is an array of command names for which this command will be suggested -
// similar to aliases but only suggests.
repeated string suggest_for = 7;
// deprecated defines, if this command is deprecated and should print this string when used.
string deprecated = 8;
// version defines the version for this command. If this value is non-empty and the command does not
// define a "version" flag, a "version" boolean flag will be added to the command and, if specified,
// will print content of the "Version" variable. A shorthand "v" flag will also be added if the
// command does not define one.
string version = 9;
// flag_options are options for flags generated from rpc request fields.
// By default all request fields are configured as flags. They can
// also be configured as positional args instead using positional_args.
map<string, FlagOptions> flag_options = 10;
// positional_args specifies positional arguments for the command.
repeated PositionalArgDescriptor positional_args = 11;
// skip specifies whether to skip this rpc method when generating commands.
bool skip = 12;
}
// FlagOptions are options for flags generated from rpc request fields.
// By default, all request fields are configured as flags based on the
// kebab-case name of the field. Fields can be turned into positional arguments
// instead by using RpcCommandOptions.positional_args.
message FlagOptions {
// name is an alternate name to use for the field flag.
string name = 1;
// shorthand is a one-letter abbreviated flag.
string shorthand = 2;
// usage is the help message.
string usage = 3;
// default_value is the default value as text.
string default_value = 4;
// default value is the default value as text if the flag is used without any value.
string no_opt_default_value = 5;
// deprecated is the usage text to show if this flag is deprecated.
string deprecated = 6;
// shorthand_deprecated is the usage text to show if the shorthand of this flag is deprecated.
string shorthand_deprecated = 7;
// hidden hides the flag from help/usage text
bool hidden = 8;
}
// PositionalArgDescriptor describes a positional argument.
message PositionalArgDescriptor {
// proto_field specifies the proto field to use as the positional arg. Any
// fields used as positional args will not have a flag generated.
string proto_field = 1;
// varargs makes a positional parameter a varargs parameter. This can only be
// applied to last positional parameter and the proto_field must a repeated
// field.
bool varargs = 2;
}

View File

@ -11,7 +11,7 @@ cd proto
proto_dirs=$(find ./cosmos -path -prune -o -name '*.proto' -print0 | xargs -0 -n1 dirname | sort | uniq)
for dir in $proto_dirs; do
for file in $(find "${dir}" -maxdepth 1 -name '*.proto'); do
if grep "option go_package" $file &> /dev/null ; then
if grep "option go_package.*(?!cosmos-sdk/api)" $file &> /dev/null ; then
buf generate --template buf.gen.gogo.yaml $file
fi
done