Skip to content

Commit

Permalink
feat: Add support for []string and []int in draft-proposal prom…
Browse files Browse the repository at this point in the history
…pt. (#14483)

(cherry picked from commit 701aaa8)

# Conflicts:
#	CHANGELOG.md
#	x/gov/types/metadata.go
  • Loading branch information
julienrbrt authored and mergify[bot] committed Jan 5, 2023
1 parent a1a6258 commit 53dd164
Show file tree
Hide file tree
Showing 9 changed files with 121 additions and 35 deletions.
14 changes: 14 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -129,7 +129,21 @@ Ref: https://keepachangelog.com/en/1.0.0/

### Improvements

<<<<<<< HEAD
* (config) [#13894](https://github.com/cosmos/cosmos-sdk/pull/13894) Support state streaming configuration in `app.toml` template and default configuration.
=======
* (x/group, x/gov) [#14483](https://github.com/cosmos/cosmos-sdk/pull/14483) Add support for `[]string` and `[]int` in `draft-proposal` prompt.
* (protobuf) [#14476](https://github.com/cosmos/cosmos-sdk/pull/14476) Clean up protobuf annotations `{accepts,implements}_interface`.
* (module) [#14415](https://github.com/cosmos/cosmos-sdk/pull/14415) Loosen assertions in SetOrderBeginBlockers() and SetOrderEndBlockers()
* (context)[#14384](https://github.com/cosmos/cosmos-sdk/pull/14384) refactor(context): Pass EventManager to the context as an interface.
* (types) [#14354](https://github.com/cosmos/cosmos-sdk/pull/14354) - improve performance on Context.KVStore and Context.TransientStore by 40%
* (crypto/keyring) [#14151](https://github.com/cosmos/cosmos-sdk/pull/14151) Move keys presentation from `crypto/keyring` to `client/keys`
* (types) [#14163](https://github.com/cosmos/cosmos-sdk/pull/14163) Refactor `(coins Coins) Validate()` to avoid unnecessary map.
* (signing) [#14087](https://github.com/cosmos/cosmos-sdk/pull/14087) Add SignModeHandlerWithContext interface with a new `GetSignBytesWithContext` to get the sign bytes using `context.Context` as an argument to access state.
* (server) [#14062](https://github.com/cosmos/cosmos-sdk/pull/14062) Remove rosetta from server start.
* [13882] (https://github.com/cosmos/cosmos-sdk/pull/13882) Add tx `encode` and `decode` endpoints to amino tx service.
> Note: These endpoints encodes and decodes only amino txs.
>>>>>>> 701aaa8c3 (feat: Add support for `[]string` and `[]int` in `draft-proposal` prompt. (#14483))
* (x/nft) [#13836](https://github.com/cosmos/cosmos-sdk/pull/13836) Remove the validation for `classID` and `nftID` from the NFT module.
* [#13789](https://github.com/cosmos/cosmos-sdk/pull/13789) Add tx `encode` and `decode` endpoints to tx service.
> Note: These endpoints will only encode and decode proto messages, Amino encoding and decoding is not supported.
Expand Down
2 changes: 1 addition & 1 deletion x/auth/module.go
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@ import (
)

// ConsensusVersion defines the current x/auth module consensus version.
const ConsensusVersion = 5
const ConsensusVersion = 4

var (
_ module.AppModule = AppModule{}
Expand Down
25 changes: 20 additions & 5 deletions x/gov/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -1464,7 +1464,9 @@ Example Output:
],
"votingStartTime": "2022-03-28T14:25:26.644857113Z",
"votingEndTime": "2022-03-30T14:25:26.644857113Z",
"metadata": "AQ=="
"metadata": "AQ==",
"title": "Proposal Title",
"summary": "Proposal Summary"
},
{
"id": "2",
Expand All @@ -1486,7 +1488,9 @@ Example Output:
"amount": "10"
}
],
"metadata": "AQ=="
"metadata": "AQ==",
"title": "Proposal Title",
"summary": "Proposal Summary"
}
],
"pagination": {
Expand Down Expand Up @@ -2009,7 +2013,9 @@ Example Output:
],
"voting_start_time": "2022-03-28T14:25:26.644857113Z",
"voting_end_time": "2022-03-30T14:25:26.644857113Z",
"metadata": "AQ=="
"metadata": "AQ==",
"title": "Proposal Title",
"summary": "Proposal Summary"
}
}
```
Expand Down Expand Up @@ -2134,7 +2140,9 @@ Example Output:
],
"voting_start_time": "2022-03-28T14:25:26.644857113Z",
"voting_end_time": "2022-03-30T14:25:26.644857113Z",
"metadata": "AQ=="
"metadata": "AQ==",
"title": "Proposal Title",
"summary": "Proposal Summary"
},
{
"id": "2",
Expand Down Expand Up @@ -2168,7 +2176,9 @@ Example Output:
],
"voting_start_time": null,
"voting_end_time": null,
"metadata": "AQ=="
"metadata": "AQ==",
"title": "Proposal Title",
"summary": "Proposal Summary"
}
],
"pagination": {
Expand Down Expand Up @@ -2598,6 +2608,11 @@ Location: off-chain as json object stored on IPFS (mirrors [group proposal](../g
}
```

:::note
The `authors` field is an array of strings, this is to allow for multiple authors to be listed in the metadata.
In v0.46, the `authors` field is a comma-separated string. Frontends are encouraged to support both formats for backwards compatibility.
:::

### Vote

Location: on-chain as json within 255 character limit (mirrors [group vote](../group/README.md#metadata))
Expand Down
29 changes: 23 additions & 6 deletions x/gov/client/cli/prompt.go
Original file line number Diff line number Diff line change
Expand Up @@ -63,10 +63,15 @@ func Prompt[T any](data T, namePrefix string) (T, error) {
}

for i := 0; i < v.NumField(); i++ {
if v.Field(i).Kind() == reflect.Struct || v.Field(i).Kind() == reflect.Slice {
// if the field is a struct skip
// in a future we can add a recursive call to Prompt
// if the field is a struct skip or not slice of string or int then skip
switch v.Field(i).Kind() {
case reflect.Struct:
// TODO(@julienrbrt) in the future we can add a recursive call to Prompt
continue
case reflect.Slice:
if v.Field(i).Type().Elem().Kind() != reflect.String && v.Field(i).Type().Elem().Kind() != reflect.Int {
continue
}
}

// create prompts
Expand Down Expand Up @@ -117,9 +122,20 @@ func Prompt[T any](data T, namePrefix string) (T, error) {
// of which on 64-bit machines, which are most common,
// int==int64
v.Field(i).SetInt(resultInt)
case reflect.Slice:
switch v.Field(i).Type().Elem().Kind() {
case reflect.String:
v.Field(i).Set(reflect.ValueOf([]string{result}))
case reflect.Int:
resultInt, err := strconv.ParseInt(result, 10, 0)
if err != nil {
return data, fmt.Errorf("invalid value for int: %w", err)
}

v.Field(i).Set(reflect.ValueOf([]int{int(resultInt)}))
}
default:
// skip other types
// possibly in the future we can add more types (like slices)
// skip any other types
continue
}
}
Expand Down Expand Up @@ -172,6 +188,7 @@ func (p *proposalType) Prompt(cdc codec.Codec) (*proposal, types.ProposalMetadat
return nil, metadata, fmt.Errorf("failed to marshal proposal message: %w", err)
}
proposal.Messages = append(proposal.Messages, message)

return proposal, metadata, nil
}

Expand Down Expand Up @@ -256,7 +273,7 @@ func NewCmdDraftProposal() *cobra.Command {
return err
}

fmt.Printf("Your draft proposal has successfully been generated.\nProposals should contain off-chain metadata, please upload the metadata JSON to IPFS.\nThen, replace the generated metadata field with the IPFS CID.\n")
fmt.Printf("The draft proposal has successfully been generated.\nProposals should contain off-chain metadata, please upload the metadata JSON to IPFS.\nThen, replace the generated metadata field with the IPFS CID.\n")

return nil
},
Expand Down
9 changes: 9 additions & 0 deletions x/gov/types/metadata.go
Original file line number Diff line number Diff line change
Expand Up @@ -3,10 +3,19 @@ package types
// ProposalMetadata is the metadata of a proposal
// This metadata is supposed to live off-chain when submitted in a proposal
type ProposalMetadata struct {
<<<<<<< HEAD
Title string `json:"title"`
Authors string `json:"authors"`
Summary string `json:"summary"`
Details string `json:"details"`
ProposalForumUrl string `json:"proposal_forum_url"` // named 'Url' instead of 'URL' for avoiding the camel case split
VoteOptionContext string `json:"vote_option_context"`
=======
Title string `json:"title"`
Authors []string `json:"authors"`
Summary string `json:"summary"`
Details string `json:"details"`
ProposalForumUrl string `json:"proposal_forum_url"` //nolint:revive // named 'Url' instead of 'URL' for avoiding the camel case split
VoteOptionContext string `json:"vote_option_context"`
>>>>>>> 701aaa8c3 (feat: Add support for `[]string` and `[]int` in `draft-proposal` prompt. (#14483))
}
57 changes: 36 additions & 21 deletions x/group/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -848,6 +848,8 @@ proposal:
no_count: "0"
veto_count: "0"
yes_count: "0"
summary: "Summary"
title: "Title"
```

##### proposals-by-group-policy
Expand Down Expand Up @@ -897,6 +899,8 @@ proposals:
no_count: "0"
veto_count: "0"
yes_count: "0"
summary: "Summary"
title: "Title"
```

##### vote
Expand Down Expand Up @@ -988,7 +992,7 @@ The `tx` commands allow users to interact with the `group` module.
simd tx group --help
```

##### create-group
#### create-group

The `create-group` command allows users to create a group which is an aggregation of member accounts with associated weights and
an administrator account.
Expand All @@ -1003,7 +1007,7 @@ Example:
simd tx group create-group cosmos1.. "AQ==" members.json
```

##### update-group-admin
#### update-group-admin

The `update-group-admin` command allows users to update a group's admin.

Expand All @@ -1017,7 +1021,7 @@ Example:
simd tx group update-group-admin cosmos1.. 1 cosmos1..
```

##### update-group-members
#### update-group-members

The `update-group-members` command allows users to update a group's members.

Expand All @@ -1031,7 +1035,7 @@ Example:
simd tx group update-group-members cosmos1.. 1 members.json
```

##### update-group-metadata
#### update-group-metadata

The `update-group-metadata` command allows users to update a group's metadata.

Expand All @@ -1045,7 +1049,7 @@ Example:
simd tx group update-group-metadata cosmos1.. 1 "AQ=="
```

##### create-group-policy
#### create-group-policy

The `create-group-policy` command allows users to create a group policy which is an account associated with a group and a decision policy.

Expand All @@ -1059,7 +1063,7 @@ Example:
simd tx group create-group-policy cosmos1.. 1 "AQ==" '{"@type":"/cosmos.group.v1.ThresholdDecisionPolicy", "threshold":"1", "windows": {"voting_period": "120h", "min_execution_period": "0s"}}'
```

##### create-group-with-policy
#### create-group-with-policy

The `create-group-with-policy` command allows users to create a group which is an aggregation of member accounts with associated weights and an administrator account with decision policy. If the `--group-policy-as-admin` flag is set to `true`, the group policy address becomes the group and group policy admin.

Expand All @@ -1073,7 +1077,7 @@ Example:
simd tx group create-group-with-policy cosmos1.. "AQ==" "AQ==" members.json '{"@type":"/cosmos.group.v1.ThresholdDecisionPolicy", "threshold":"1", "windows": {"voting_period": "120h", "min_execution_period": "0s"}}'
```

##### update-group-policy-admin
#### update-group-policy-admin

The `update-group-policy-admin` command allows users to update a group policy admin.

Expand All @@ -1087,7 +1091,7 @@ Example:
simd tx group update-group-policy-admin cosmos1.. cosmos1.. cosmos1..
```

##### update-group-policy-metadata
#### update-group-policy-metadata

The `update-group-policy-metadata` command allows users to update a group policy metadata.

Expand All @@ -1101,7 +1105,7 @@ Example:
simd tx group update-group-policy-metadata cosmos1.. cosmos1.. "AQ=="
```

##### update-group-policy-decision-policy
#### update-group-policy-decision-policy

The `update-group-policy-decision-policy` command allows users to update a group policy's decision policy.

Expand All @@ -1115,7 +1119,7 @@ Example:
simd tx group update-group-policy-decision-policy cosmos1.. cosmos1.. '{"@type":"/cosmos.group.v1.ThresholdDecisionPolicy", "threshold":"2", "windows": {"voting_period": "120h", "min_execution_period": "0s"}}'
```

##### create-proposal
#### create-proposal

The `create-proposal` command allows users to submit a new proposal.

Expand All @@ -1129,7 +1133,7 @@ Example:
simd tx group create-proposal cosmos1.. cosmos1.. msg_tx.json "AQ=="
```

##### withdraw-proposal
#### withdraw-proposal

The `withdraw-proposal` command allows users to withdraw a proposal.

Expand All @@ -1143,7 +1147,7 @@ Example:
simd tx group withdraw-proposal 1 cosmos1..
```

##### vote
#### vote

The `vote` command allows users to vote on a proposal.

Expand All @@ -1157,7 +1161,7 @@ Example:
simd tx group vote 1 cosmos1.. CHOICE_YES "AQ=="
```

##### exec
#### exec

The `exec` command allows users to execute a proposal.

Expand All @@ -1171,7 +1175,7 @@ Example:
simd tx group exec 1
```

##### leave-group
#### leave-group

The `leave-group` command allows group member to leave the group.

Expand Down Expand Up @@ -1452,9 +1456,11 @@ Example Output:
"voting_period": "432000s"
},
"executorResult": "EXECUTOR_RESULT_NOT_RUN",
"msgs": [
"messages": [
{"@type":"/cosmos.bank.v1beta1.MsgSend","amount":[{"denom":"stake","amount":"100000000"}],"fromAddress":"cosmos1..","toAddress":"cosmos1.."}
]
],
"title": "Title",
"summary": "Summary",
}
}
```
Expand Down Expand Up @@ -1501,9 +1507,11 @@ Example Output:
"voting_period": "432000s"
},
"executorResult": "EXECUTOR_RESULT_NOT_RUN",
"msgs": [
"messages": [
{"@type":"/cosmos.bank.v1beta1.MsgSend","amount":[{"denom":"stake","amount":"100000000"}],"fromAddress":"cosmos1..","toAddress":"cosmos1.."}
]
],
"title": "Title",
"summary": "Summary",
}
],
"pagination": {
Expand Down Expand Up @@ -1911,7 +1919,7 @@ Example Output:
"voting_period": "432000s"
},
"executor_result": "EXECUTOR_RESULT_NOT_RUN",
"msgs": [
"messages": [
{
"@type": "/cosmos.bank.v1beta1.MsgSend",
"from_address": "cosmos1..",
Expand All @@ -1923,7 +1931,9 @@ Example Output:
}
]
}
]
],
"title": "Title",
"summary": "Summary",
}
}
```
Expand Down Expand Up @@ -1970,7 +1980,7 @@ Example Output:
"voting_period": "432000s"
},
"executor_result": "EXECUTOR_RESULT_NOT_RUN",
"msgs": [
"messages": [
{
"@type": "/cosmos.bank.v1beta1.MsgSend",
"from_address": "cosmos1..",
Expand Down Expand Up @@ -2107,6 +2117,11 @@ Location: off-chain as json object stored on IPFS (mirrors [gov proposal](../gov
}
```
:::note
The `authors` field is an array of strings, this is to allow for multiple authors to be listed in the metadata.
In v0.46, the `authors` field is a comma-separated string. Frontends are encouraged to support both formats for backwards compatibility.
:::
### Vote
Location: on-chain as json within 255 character limit (mirrors [gov vote](../gov/README.md#metadata))
Expand Down
Loading

0 comments on commit 53dd164

Please sign in to comment.