Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(cli): cancel gov proposal by proposer before voting period ends #13010

Merged
merged 203 commits into from
Jan 20, 2023
Merged
Show file tree
Hide file tree
Changes from 2 commits
Commits
Show all changes
203 commits
Select commit Hold shift + click to select a range
d67504b
WIP : add the cancel gov proposal proto
gsk967 Aug 24, 2022
9c2deb8
WIP: add cancel-proposal tx to cli
gsk967 Aug 24, 2022
25b2f2c
feat: add minDeposits of proposal to community pool
gsk967 Aug 25, 2022
2f86e1b
Merge branch 'main' into sai/impl_11554
gsk967 Aug 25, 2022
8263f9d
Merge branch 'main' into sai/impl_11554
gsk967 Aug 25, 2022
146e4cf
chore: sort the proposal ids
Aug 25, 2022
f11cbe9
Merge branch 'main' into sai/impl_11554
gsk967 Aug 26, 2022
2b9c916
test: fix the test cases in gov submit proposal
gsk967 Aug 26, 2022
6b60745
test: fix++
gsk967 Aug 26, 2022
ce52eca
Merge branch 'main' into sai/impl_11554
gsk967 Aug 29, 2022
6cff9f1
Merge branch 'main' into sai/impl_11554
gsk967 Aug 29, 2022
c8cbda5
Merge branch 'main' into sai/impl_11554
gsk967 Sep 1, 2022
7b587ee
test: add test for cli tx cancel proposal
gsk967 Sep 1, 2022
4a9e6b4
Merge branch 'main' into sai/impl_11554
gsk967 Sep 1, 2022
4b1c0a8
Merge branch 'main' into sai/impl_11554
gsk967 Sep 1, 2022
3f18856
chore: update the changelog
gsk967 Sep 1, 2022
d5974bb
chore: fix the small issues
gsk967 Sep 1, 2022
02586b9
test: fix the tests and legacy build issue
gsk967 Sep 1, 2022
b1f0712
fix: fix++
gsk967 Sep 1, 2022
b829a1f
fix: fix the tests
gsk967 Sep 1, 2022
188026f
Merge branch 'main' into sai/impl_11554
anilcse Sep 1, 2022
09f70ed
Merge branch 'main' into sai/impl_11554
gsk967 Sep 2, 2022
77f84e1
Merge branch 'main' into sai/impl_11554
gsk967 Sep 2, 2022
0e7552d
chore: address the pr comments
gsk967 Sep 2, 2022
7abc4cd
Merge branch 'main' into sai/impl_11554
gsk967 Sep 2, 2022
122da82
Merge branch 'main' into sai/impl_11554
gsk967 Sep 2, 2022
da49b39
Merge branch 'main' into sai/impl_11554
gsk967 Sep 2, 2022
77a3534
chore: address the comment and done proto pretty
gsk967 Sep 2, 2022
d6f66b4
Merge branch 'main' into sai/impl_11554
gsk967 Sep 2, 2022
8513623
Merge branch 'main' into sai/impl_11554
gsk967 Sep 3, 2022
18943e9
Merge branch 'main' into sai/impl_11554
anilcse Sep 5, 2022
2e5d79d
Merge branch 'main' into sai/impl_11554
gsk967 Sep 5, 2022
16a49a0
Merge branch 'main' into sai/impl_11554
gsk967 Sep 5, 2022
cfaf946
chore: address the pr comments
gsk967 Sep 5, 2022
e7ce012
chore: small fix for test
gsk967 Sep 5, 2022
4e11b75
Merge branch 'main' into sai/impl_11554
gsk967 Sep 6, 2022
24573a8
Merge branch 'main' into sai/impl_11554
gsk967 Sep 6, 2022
b16103e
Merge branch 'main' into sai/impl_11554
gsk967 Sep 7, 2022
479e71c
Merge branch 'main' into sai/impl_11554
gsk967 Sep 7, 2022
4bd0c35
Merge branch 'main' into sai/impl_11554
gsk967 Sep 8, 2022
dfcc6ae
Merge branch 'main' into sai/impl_11554
gsk967 Sep 22, 2022
8ee3a5b
fix: fix the build issue
gsk967 Sep 22, 2022
8675495
Merge branch 'main' into sai/impl_11554
gsk967 Sep 23, 2022
f6fff38
Merge branch 'main' into sai/impl_11554
gsk967 Sep 26, 2022
9053320
Merge branch 'main' into sai/impl_11554
gsk967 Sep 26, 2022
b29dd21
Merge branch 'main' into sai/impl_11554
gsk967 Sep 29, 2022
3e98a31
Merge remote-tracking branch 'mine/sai/impl_11554' into sai/impl_11554
gsk967 Sep 29, 2022
c1ea79c
Merge branch 'main' into sai/impl_11554
gsk967 Sep 30, 2022
007fb50
Merge branch 'main' into sai/impl_11554
gsk967 Sep 30, 2022
4b3f56c
Merge branch 'main' into sai/impl_11554
gsk967 Oct 1, 2022
fb7ccdd
refactor: add `burn rate` of deposits for cancel proposal
gsk967 Oct 1, 2022
b321bb1
Merge branch 'main' into sai/impl_11554
gsk967 Oct 3, 2022
845bc11
test: fix the test on cancel gov proposal
gsk967 Oct 3, 2022
fa84c25
Merge remote-tracking branch 'mine/sai/impl_11554' into sai/impl_11554
gsk967 Oct 3, 2022
b94adcf
Merge branch 'main' into sai/impl_11554
gsk967 Oct 3, 2022
2f26729
Merge branch 'main' into sai/impl_11554
gsk967 Oct 4, 2022
a18e6da
Merge branch 'main' into sai/impl_11554
gsk967 Oct 6, 2022
85d8162
Merge remote-tracking branch 'mine/sai/impl_11554' into sai/impl_11554
gsk967 Oct 6, 2022
49b5283
Merge branch 'main' into sai/impl_11554
gsk967 Oct 7, 2022
ec1f7f0
Merge branch 'main' into sai/impl_11554
gsk967 Oct 8, 2022
75f9529
Merge branch 'main' into sai/impl_11554
gsk967 Oct 10, 2022
e439cd0
Merge branch 'main' into sai/impl_11554
gsk967 Oct 11, 2022
7441760
Merge branch 'main' into sai/impl_11554
gsk967 Oct 16, 2022
c0b215f
fix: fix the burn the deposits of proposal
gsk967 Oct 16, 2022
81f3c4c
fix: fix the bank tests
gsk967 Oct 16, 2022
94e312e
Merge branch 'main' into sai/impl_11554
gsk967 Oct 17, 2022
f466b0d
Merge branch 'main' into sai/impl_11554
gsk967 Oct 17, 2022
544c903
Merge branch 'main' into sai/impl_11554
gsk967 Oct 17, 2022
e4af3bb
Merge branch 'main' into sai/impl_11554
gsk967 Oct 17, 2022
ee0785b
docs: update the UPGRADING.md
gsk967 Oct 17, 2022
166596a
chore: address the pr comments
gsk967 Oct 18, 2022
0d9bfff
Merge branch 'main' into sai/impl_11554
gsk967 Oct 18, 2022
0bb9f6d
Merge branch 'main' into sai/impl_11554
gsk967 Oct 19, 2022
9ce6bcd
chore: address the pr comments
gsk967 Oct 19, 2022
2f58974
Merge branch 'main' into sai/impl_11554
gsk967 Oct 19, 2022
657779d
chore: address the pr comments
gsk967 Oct 20, 2022
c094141
Update UPGRADING.md
alexanderbez Oct 20, 2022
341ed7b
Update UPGRADING.md
alexanderbez Oct 20, 2022
aa097fa
Update proto/cosmos/gov/v1/gov.proto
alexanderbez Oct 20, 2022
e5a97ee
Update proto/cosmos/gov/v1/gov.proto
alexanderbez Oct 20, 2022
b21c2ce
Update proto/cosmos/gov/v1/gov.proto
alexanderbez Oct 20, 2022
51d50db
Merge branch 'main' into sai/impl_11554
gsk967 Oct 21, 2022
26be9f7
chore : address the pr comments and add delete votes for cancel-proposal
gsk967 Oct 21, 2022
adce771
Merge branch 'main' into sai/impl_11554
gsk967 Oct 21, 2022
3f27c14
Merge branch 'main' into sai/impl_11554
gsk967 Oct 22, 2022
def73ab
chore: address the pr comments
gsk967 Oct 22, 2022
6c23579
Merge branch 'main' into sai/impl_11554
gsk967 Oct 23, 2022
1ee4a16
Merge branch 'main' into sai/impl_11554
gsk967 Oct 23, 2022
dda44f4
Merge branch 'main' into sai/impl_11554
gsk967 Oct 24, 2022
23f1b96
remove the cancelProposalQueue for cancel proposal
gsk967 Oct 24, 2022
8058f67
chore: typo fix
gsk967 Oct 24, 2022
4ae93e7
Merge branch 'main' into sai/impl_11554
gsk967 Oct 25, 2022
dcb23ed
Merge branch 'main' into sai/impl_11554
gsk967 Oct 25, 2022
a6bb51c
Merge branch 'main' into sai/impl_11554
gsk967 Oct 25, 2022
8a95079
Merge branch 'main' into sai/impl_11554
gsk967 Oct 26, 2022
3d50206
chore: allow only action proposals for migration
gsk967 Oct 26, 2022
d9eb597
test: fix the keeper test of cancel proposal
gsk967 Oct 26, 2022
0a7a798
chore: address the pr comments
gsk967 Oct 26, 2022
108c14c
Merge branch 'main' into sai/impl_11554
gsk967 Oct 27, 2022
4b80a61
Merge branch 'main' into sai/impl_11554
gsk967 Oct 27, 2022
562c8c6
Merge branch 'main' into sai/impl_11554
gsk967 Oct 28, 2022
5ab7c2c
Merge branch 'main' into sai/impl_11554
gsk967 Oct 31, 2022
98fdfac
Merge branch 'main' into sai/impl_11554
gsk967 Nov 18, 2022
3e0b0c8
chore: update the proto files
gsk967 Nov 18, 2022
5c8640d
add 'proposal_cancel_dest' param
gsk967 Nov 18, 2022
cc93b40
chore: address the pr comments
gsk967 Nov 18, 2022
7dfbeb4
Merge branch 'main' into sai/impl_11554
gsk967 Nov 18, 2022
c58a0d3
chore: renamed 'proposal_cancel_burn_rate' to 'proposal_cancel_rate'
gsk967 Nov 18, 2022
7de7448
Merge remote-tracking branch 'mine/sai/impl_11554' into sai/impl_11554
gsk967 Nov 18, 2022
2e54e5d
Merge branch 'main' into sai/impl_11554
gsk967 Nov 18, 2022
0c77258
chore: small fix
gsk967 Nov 18, 2022
6ce31e8
Merge branch 'main' into sai/impl_11554
gsk967 Nov 18, 2022
753d1b1
chore: fix the lint
gsk967 Nov 18, 2022
9bfdca8
Merge remote-tracking branch 'mine/sai/impl_11554' into sai/impl_11554
gsk967 Nov 18, 2022
b82f898
Merge branch 'main' into sai/impl_11554
gsk967 Nov 19, 2022
9eebbcf
chore: fix the test cases
gsk967 Nov 19, 2022
d1043c2
Merge branch 'main' into sai/impl_11554
gsk967 Nov 21, 2022
f1134ba
Merge branch 'main' into sai/impl_11554
gsk967 Nov 21, 2022
983e518
chore: address the pr comments
gsk967 Nov 21, 2022
911438b
Merge branch 'main' into sai/impl_11554
gsk967 Nov 21, 2022
1df9399
Update proto/cosmos/gov/v1/gov.proto
robert-zaremba Nov 21, 2022
095e83b
chore: address the pr comments
gsk967 Nov 21, 2022
08ff0e0
Merge branch 'main' into sai/impl_11554
gsk967 Nov 21, 2022
b6099f1
Merge branch 'main' into sai/impl_11554
gsk967 Nov 21, 2022
cd87a02
chore: address the pr comments
gsk967 Nov 28, 2022
ce844f1
Merge main
gsk967 Nov 28, 2022
c868a05
chore: fix build issue and add test for balance check on cancel proposal
gsk967 Nov 28, 2022
7e6149c
Merge branch 'main' into sai/impl_11554
gsk967 Nov 28, 2022
ef389c4
Merge branch 'main' into sai/impl_11554
gsk967 Nov 29, 2022
d2ccc17
Merge branch 'main' into sai/impl_11554
gsk967 Nov 29, 2022
b8c49b1
Merge branch 'main' into sai/impl_11554
gsk967 Nov 29, 2022
af97dd6
Merge branch 'main' into sai/impl_11554
gsk967 Nov 29, 2022
ee06adb
chore: address pr comments
gsk967 Nov 29, 2022
71af716
Merge branch 'main' into sai/impl_11554
gsk967 Nov 29, 2022
c261149
Merge branch 'main' into sai/impl_11554
gsk967 Nov 30, 2022
b387f0b
Merge branch 'main' into sai/impl_11554
gsk967 Dec 1, 2022
861098e
Merge branch 'main' into sai/impl_11554
gsk967 Dec 1, 2022
91c049f
Merge branch 'main' into sai/impl_11554
gsk967 Dec 5, 2022
ec01f78
Merge branch 'main' into sai/impl_11554
gsk967 Dec 5, 2022
22b7cb5
Merge branch 'main' into sai/impl_11554
gsk967 Dec 6, 2022
77b6023
chore: address the pr comments
gsk967 Dec 12, 2022
e719121
Merge main
gsk967 Dec 12, 2022
c729d4a
fix: fix the test cases
gsk967 Dec 12, 2022
c3f3d28
chore: address the pr comments
gsk967 Dec 12, 2022
7a6bd8c
Merge branch 'main' into sai/impl_11554
gsk967 Dec 13, 2022
4fb2626
Merge branch 'main' into sai/impl_11554
gsk967 Dec 13, 2022
5e42633
Merge branch 'main' into sai/impl_11554
gsk967 Dec 16, 2022
ca981b9
Merge remote-tracking branch 'mine/sai/impl_11554' into sai/impl_11554
gsk967 Dec 16, 2022
f8fdd0e
test: add more tests for cancel proposal
gsk967 Dec 16, 2022
1a9a4d7
chore: removed extra test of cancelProposal on msg_server
gsk967 Dec 16, 2022
fb1bfd7
fix: fix the failing tests
gsk967 Dec 16, 2022
7cb39b3
Merge branch 'main' into sai/impl_11554
gsk967 Dec 28, 2022
cc03ded
chore: fix the test and proto-gen for gov
gsk967 Dec 28, 2022
c77ca59
fix: fix the lint
gsk967 Dec 28, 2022
7101f1e
Merge branch 'main' into sai/impl_11554
gsk967 Dec 28, 2022
594cb12
fix: fix the test
gsk967 Dec 28, 2022
a5a2b57
fix: fix the charging fees and remaining deposit calculations
gsk967 Dec 28, 2022
5c32186
chore: move the proposer address migration to v5
gsk967 Dec 28, 2022
bdbf3ae
fix: fix the rand genesis state test
gsk967 Dec 28, 2022
60582e8
Merge branch 'main' into sai/impl_11554
gsk967 Dec 29, 2022
51b15f2
Merge branch 'main' into sai/impl_11554
gsk967 Dec 29, 2022
0ffeb41
Merge branch 'main' into sai/impl_11554
gsk967 Dec 29, 2022
af9a31e
Merge branch 'main' into sai/impl_11554
gsk967 Dec 30, 2022
5e38073
Merge branch 'main' into sai/impl_11554
gsk967 Dec 30, 2022
94d391b
Merge branch 'main' into sai/impl_11554
gsk967 Dec 30, 2022
58ff8d4
chore: address the pr comments
gsk967 Dec 30, 2022
125360e
Merge branch 'main' into sai/impl_11554
gsk967 Dec 31, 2022
1d8f8a2
Merge branch 'main' into sai/impl_11554
gsk967 Jan 2, 2023
b8f1418
Merge branch 'main' into sai/impl_11554
gsk967 Jan 2, 2023
f35692f
Merge branch 'main' into sai/impl_11554
gsk967 Jan 3, 2023
d2cd3c1
fix: fix the failing simulations
gsk967 Jan 3, 2023
45facd6
fix: fix the lint
gsk967 Jan 3, 2023
62b55fe
Merge branch 'main' into sai/impl_11554
gsk967 Jan 4, 2023
1f65ca4
Merge branch 'main' into sai/impl_11554
gsk967 Jan 4, 2023
3f29399
Merge branch 'main' into sai/impl_11554
gsk967 Jan 5, 2023
72f234e
fix: fix the proto-gen
gsk967 Jan 5, 2023
be3376f
Merge branch 'main' into sai/impl_11554
gsk967 Jan 5, 2023
388e97f
test: add test for `ChargeDeposit`
gsk967 Jan 6, 2023
df188e1
Merge branch 'main' into sai/impl_11554
gsk967 Jan 6, 2023
da4951b
Merge branch 'main' into sai/impl_11554
gsk967 Jan 6, 2023
2c7763e
Merge branch 'main' into sai/impl_11554
gsk967 Jan 9, 2023
ded1144
fix: fix the tests
gsk967 Jan 9, 2023
348ef12
fix: fix the integration test of gov
gsk967 Jan 9, 2023
fd0ca71
Merge branch 'main' into sai/impl_11554
gsk967 Jan 9, 2023
9b07b78
Merge branch 'main' into sai/impl_11554
gsk967 Jan 9, 2023
e5cb7a1
Merge branch 'main' into sai/impl_11554
gsk967 Jan 10, 2023
bbc3e55
Merge branch 'main' into sai/impl_11554
tac0turtle Jan 10, 2023
3a93d23
Merge branch 'main' into sai/impl_11554
gsk967 Jan 10, 2023
6450f4f
Merge branch 'main' into sai/impl_11554
gsk967 Jan 10, 2023
256a8bb
Merge branch 'main' into sai/impl_11554
gsk967 Jan 11, 2023
682eba4
Merge branch 'main' into sai/impl_11554
gsk967 Jan 11, 2023
05a6073
Merge branch 'main' into sai/impl_11554
gsk967 Jan 12, 2023
3bce1e0
Merge branch 'main' into sai/impl_11554
gsk967 Jan 13, 2023
1550ef4
Merge branch 'main' into sai/impl_11554
gsk967 Jan 13, 2023
8afb906
Merge branch 'main' into sai/impl_11554
gsk967 Jan 14, 2023
6d50340
Merge branch 'main' into sai/impl_11554
gsk967 Jan 16, 2023
8b97d60
Merge branch 'main' into sai/impl_11554
gsk967 Jan 16, 2023
e93687a
Merge branch 'main' into sai/impl_11554
gsk967 Jan 16, 2023
b838c86
Merge branch 'main' into sai/impl_11554
gsk967 Jan 17, 2023
ccfbec2
Merge branch 'main' into sai/impl_11554
gsk967 Jan 18, 2023
45a1e95
Merge branch 'main' into sai/impl_11554
gsk967 Jan 20, 2023
90508cb
Merge branch 'main' into sai/impl_11554
tac0turtle Jan 20, 2023
127caff
Merge branch 'main' into sai/impl_11554
gsk967 Jan 20, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
315 changes: 199 additions & 116 deletions api/cosmos/gov/v1/gov.pulsar.go

Large diffs are not rendered by default.

1,069 changes: 1,007 additions & 62 deletions api/cosmos/gov/v1/tx.pulsar.go

Large diffs are not rendered by default.

42 changes: 42 additions & 0 deletions api/cosmos/gov/v1/tx_grpc.pb.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

6 changes: 6 additions & 0 deletions proto/cosmos/gov/v1/gov.proto
Original file line number Diff line number Diff line change
Expand Up @@ -56,6 +56,9 @@ message Proposal {

// metadata is any arbitrary metadata attached to the proposal.
string metadata = 10;

// proposer defines an address of creater of the proposal.
gsk967 marked this conversation as resolved.
Show resolved Hide resolved
string proposer = 11 [(cosmos_proto.scalar) = "cosmos.AddressString"];
alexanderbez marked this conversation as resolved.
Show resolved Hide resolved
}

// ProposalStatus enumerates the valid statuses of a proposal.
Expand All @@ -77,6 +80,9 @@ enum ProposalStatus {
// PROPOSAL_STATUS_FAILED defines a proposal status of a proposal that has
// failed.
PROPOSAL_STATUS_FAILED = 5;
// PROPOSAL_STATUS_CANCELED defines a proposal status of a proposal that has
// canceled.
PROPOSAL_STATUS_CANCELED = 6;
}

// TallyResult defines a standard tally for a governance proposal.
Expand Down
21 changes: 21 additions & 0 deletions proto/cosmos/gov/v1/tx.proto
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,11 @@ service Msg {
//
// Since: cosmos-sdk 0.47
rpc UpdateParams(MsgUpdateParams) returns (MsgUpdateParamsResponse);

// CancelProposal defines a method to cancel governance proposal
//
// Since: cosmos-sdk 0.47
rpc CancelProposal(MsgCancelProposal) returns (MsgCancelProposalResponse);
}

// MsgSubmitProposal defines an sdk.Msg type that supports submitting arbitrary
Expand Down Expand Up @@ -125,3 +130,19 @@ message MsgUpdateParams {
//
// Since: cosmos-sdk 0.47
message MsgUpdateParamsResponse {}

// MsgCancelProposal is the Msg/CancelProposal request type.
//
// Since: cosmos-sdk 0.47
message MsgCancelProposal{
option (cosmos.msg.v1.signer) = "depositor";

uint64 proposal_id = 1 [(gogoproto.jsontag) = "proposal_id"];
string proposer = 2 [(cosmos_proto.scalar) = "cosmos.AddressString"];
}

// MsgCancelProposalResponse defines the response structure for executing a
// MsgCancelProposal message.
//
// Since: cosmos-sdk 0.47
gsk967 marked this conversation as resolved.
Show resolved Hide resolved
message MsgCancelProposalResponse{}
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Perhaps we add a field stating the time and/or height at which it was cancelled?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We need to start adding relevant info (that isn't part of the initial message) to response objects.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@anilcse @alexanderbez

message MsgCancelProposalResponse{
   uint64 proposal_id  = 1;
   google.protobuf.Timestamp         canceled_time = 2 [(gogoproto.stdtime) = true];
   uint64 height = 3;

}

this fields are enough for response of cancel proposal ?

8 changes: 8 additions & 0 deletions x/gov/abci.go
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,14 @@ func EndBlocker(ctx sdk.Context, keeper *keeper.Keeper) {

logger := keeper.Logger(ctx)

// delete the canceled proposals from store and returns theirs deposits.
keeper.IterateCanceledProposalQueue(ctx, func(proposal v1.Proposal) (stop bool) {
keeper.DeleteProposal(ctx, proposal.Id)
Fixed Show fixed Hide fixed
Fixed Show fixed Hide fixed
Fixed Show fixed Hide fixed
Fixed Show fixed Hide fixed
gsk967 marked this conversation as resolved.
Show resolved Hide resolved
Fixed Show fixed Hide fixed
Fixed Show fixed Hide fixed
// send min deposit to community pool
keeper.RefundAndDeleteDeposits(ctx, proposal.Id) // refund deposit if proposal got removed without getting 100% of the proposal
return false
})
Fixed Show fixed Hide fixed

// delete dead proposals from store and returns theirs deposits.
// A proposal is dead when it's inactive and didn't get enough deposit on time to get into voting phase.
keeper.IterateInactiveProposalsQueue(ctx, ctx.BlockHeader().Time, func(proposal v1.Proposal) bool {
Expand Down
35 changes: 35 additions & 0 deletions x/gov/client/cli/tx.go
Original file line number Diff line number Diff line change
Expand Up @@ -70,6 +70,7 @@ func NewTxCmd(legacyPropCmds []*cobra.Command) *cobra.Command {
NewCmdVote(),
NewCmdWeightedVote(),
NewCmdSubmitProposal(),
NewCmdCancelProposal(),

// Deprecated
cmdSubmitLegacyProp,
Expand Down Expand Up @@ -135,6 +136,40 @@ Where proposal.json contains:
return cmd
}

// NewCmdCancelProposal implements submitting a cancel proposal transaction command.
func NewCmdCancelProposal() *cobra.Command {
cmd := &cobra.Command{
Use: "cancel-proposal [proposal-id]",
Short: "Cancel governance proposal by proposal before the voting period ends.",
Args: cobra.ExactArgs(1),
Example: fmt.Sprintf(`
$ %s tx gov cancel-proposal 1 --from mykey
`, version.AppName),
gsk967 marked this conversation as resolved.
Show resolved Hide resolved
RunE: func(cmd *cobra.Command, args []string) error {
clientCtx, err := client.GetClientTxContext(cmd)
if err != nil {
return err
}

// validate that the proposal id is a uint
amaury1093 marked this conversation as resolved.
Show resolved Hide resolved
proposalID, err := strconv.ParseUint(args[0], 10, 64)
if err != nil {
return fmt.Errorf("proposal-id %s not a valid uint, please input a valid proposal-id", args[0])
}

// Get depositor address
gsk967 marked this conversation as resolved.
Show resolved Hide resolved
from := clientCtx.GetFromAddress()

msg := v1.NewMsgCancelProposal(from, proposalID)

return tx.GenerateOrBroadcastTxCLI(clientCtx, cmd.Flags(), msg)
},
}

flags.AddTxFlagsToCmd(cmd)
return cmd
}

// NewCmdSubmitLegacyProposal implements submitting a proposal transaction command.
// Deprecated: please use NewCmdSubmitProposal instead.
func NewCmdSubmitLegacyProposal() *cobra.Command {
Expand Down
39 changes: 39 additions & 0 deletions x/gov/keeper/keeper.go
Original file line number Diff line number Diff line change
Expand Up @@ -146,6 +146,19 @@ func (keeper Keeper) RemoveFromActiveProposalQueue(ctx sdk.Context, proposalID u
store.Delete(types.ActiveProposalQueueKey(proposalID, endTime))
}

// InsertCanceledProposalQueue inserts a ProposalID into the cancel proposal queue
gsk967 marked this conversation as resolved.
Show resolved Hide resolved
func (Keeper Keeper) InsertCanceledProposalQueue(ctx sdk.Context, proposalID uint64) {
store := ctx.KVStore(Keeper.storeKey)
bz := types.GetProposalIDBytes(proposalID)
store.Set(types.CanceledProposalQueueKey(proposalID), bz)
}

// RemoveFromCanceledProposalQueue remove a proposalID from the Canceled Proposal Queue
gsk967 marked this conversation as resolved.
Show resolved Hide resolved
func (keeper Keeper) RemoveFromCanceledProposalQueue(ctx sdk.Context, proposalID uint64) {
store := ctx.KVStore(keeper.storeKey)
store.Delete(types.CanceledProposalQueueKey(proposalID))
}

// InsertInactiveProposalQueue Inserts a ProposalID into the inactive proposal queue at endTime
func (keeper Keeper) InsertInactiveProposalQueue(ctx sdk.Context, proposalID uint64, endTime time.Time) {
store := ctx.KVStore(keeper.storeKey)
Expand Down Expand Up @@ -199,6 +212,26 @@ func (keeper Keeper) IterateInactiveProposalsQueue(ctx sdk.Context, endTime time
}
}

// IterateCanceledProposalQueue iterates over the proposal in the canceled proposal queue
// and performs a callback function
func (keeper Keeper) IterateCanceledProposalQueue(ctx sdk.Context, cb func(proposal v1.Proposal) (stop bool)) {
gsk967 marked this conversation as resolved.
Show resolved Hide resolved
store := ctx.KVStore(keeper.storeKey)
iterator := sdk.KVStorePrefixIterator(store, types.CanceledProposalQueuePrefix)

defer iterator.Close()
for ; iterator.Valid(); iterator.Next() {
proposalID := types.GetProposalIDFromBytes(iterator.Key()[1:])
proposal, found := keeper.GetProposal(ctx, proposalID)
if !found {
panic(fmt.Sprintf("proposal %d does not exist", proposalID))
}

if cb(proposal) {
break
}
}
}

// ActiveProposalQueueIterator returns an sdk.Iterator for all the proposals in the Active Queue that expire by endTime
func (keeper Keeper) ActiveProposalQueueIterator(ctx sdk.Context, endTime time.Time) sdk.Iterator {
store := ctx.KVStore(keeper.storeKey)
Expand All @@ -211,6 +244,12 @@ func (keeper Keeper) InactiveProposalQueueIterator(ctx sdk.Context, endTime time
return store.Iterator(types.InactiveProposalQueuePrefix, sdk.PrefixEndBytes(types.InactiveProposalByTimeKey(endTime)))
}

// InactiveProposalQueueIterator returns an sdk.Iterator for all the proposals in the Inactive Queue that expire by endTime
func (keeper Keeper) CanceledProposalQueueIterator(ctx sdk.Context) sdk.Iterator {
store := ctx.KVStore(keeper.storeKey)
return store.Iterator(types.CanceledProposalQueuePrefix, nil)
}

// assertMetadataLength returns an error if given metadata length
// is greater than a pre-defined maxMetadataLen.
func (keeper Keeper) assertMetadataLength(metadata string) error {
Expand Down
32 changes: 30 additions & 2 deletions x/gov/keeper/msg_server.go
Original file line number Diff line number Diff line change
Expand Up @@ -37,11 +37,17 @@ func (k msgServer) SubmitProposal(goCtx context.Context, msg *v1.MsgSubmitPropos
return nil, err
}

proposer, err := sdk.AccAddressFromBech32(msg.GetProposer())
if err != nil {
return nil, err
}

proposalMsgs, err := msg.GetMsgs()
if err != nil {
return nil, err
}
proposal, err := k.Keeper.SubmitProposal(ctx, proposalMsgs, msg.Metadata)

proposal, err := k.Keeper.SubmitProposal(ctx, proposer, proposalMsgs, msg.Metadata)
if err != nil {
return nil, err
}
Expand All @@ -59,7 +65,6 @@ func (k msgServer) SubmitProposal(goCtx context.Context, msg *v1.MsgSubmitPropos

defer telemetry.IncrCounter(1, govtypes.ModuleName, "proposal")

proposer, _ := sdk.AccAddressFromBech32(msg.GetProposer())
votingStarted, err := k.Keeper.AddDeposit(ctx, proposal.Id, proposer, msg.GetInitialDeposit())
if err != nil {
return nil, err
Expand All @@ -86,6 +91,29 @@ func (k msgServer) SubmitProposal(goCtx context.Context, msg *v1.MsgSubmitPropos
}, nil
}

// CancelProposal implements v1.MsgServer
func (k msgServer) CancelProposal(goCtx context.Context, msg *v1.MsgCancelProposal) (*v1.MsgCancelProposalResponse, error) {
ctx := sdk.UnwrapSDKContext(goCtx)
_, err := sdk.AccAddressFromBech32(msg.Proposer)
if err != nil {
return nil, err
}
amaury1093 marked this conversation as resolved.
Show resolved Hide resolved

if err := k.Keeper.CancelProposal(ctx, msg.ProposalId, msg.Proposer); err != nil {
return nil, err
}

ctx.EventManager().EmitEvent(
sdk.NewEvent(
sdk.EventTypeMessage,
sdk.NewAttribute(sdk.AttributeKeyModule, govtypes.AttributeValueCategory),
sdk.NewAttribute(sdk.AttributeKeySender, msg.Proposer),
gsk967 marked this conversation as resolved.
Show resolved Hide resolved
),
)

return &v1.MsgCancelProposalResponse{}, nil
}

func (k msgServer) ExecLegacyContent(goCtx context.Context, msg *v1.MsgExecLegacyContent) (*v1.MsgExecLegacyContentResponse, error) {
ctx := sdk.UnwrapSDKContext(goCtx)

Expand Down
41 changes: 39 additions & 2 deletions x/gov/keeper/proposal.go
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ import (
)

// SubmitProposal creates a new proposal given an array of messages
func (keeper Keeper) SubmitProposal(ctx sdk.Context, messages []sdk.Msg, metadata string) (v1.Proposal, error) {
func (keeper Keeper) SubmitProposal(ctx sdk.Context, proposer sdk.AccAddress, messages []sdk.Msg, metadata string) (v1.Proposal, error) {
err := keeper.assertMetadataLength(metadata)
if err != nil {
return v1.Proposal{}, err
Expand Down Expand Up @@ -68,7 +68,7 @@ func (keeper Keeper) SubmitProposal(ctx sdk.Context, messages []sdk.Msg, metadat
submitTime := ctx.BlockHeader().Time
depositPeriod := keeper.GetParams(ctx).MaxDepositPeriod

proposal, err := v1.NewProposal(messages, proposalID, metadata, submitTime, submitTime.Add(*depositPeriod))
proposal, err := v1.NewProposal(messages, proposer, proposalID, metadata, submitTime, submitTime.Add(*depositPeriod))
if err != nil {
return v1.Proposal{}, err
}
Expand All @@ -91,6 +91,40 @@ func (keeper Keeper) SubmitProposal(ctx sdk.Context, messages []sdk.Msg, metadat
return proposal, nil
}

// CancelProposal will cancel proposal before the voting period ends
func (keeper Keeper) CancelProposal(ctx sdk.Context, proposalID uint64, proposer string) error {
proposal, ok := keeper.GetProposal(ctx, proposalID)
if !ok {
return sdkerrors.Wrapf(types.ErrProposalNotFound, "proposal is not found with % id", proposalID)
}

// Check creator of the proposal
if proposal.Proposer != proposer {
return sdkerrors.Wrapf(types.ErrInvalidProposer, "invalid proposer %s", proposer)
}

// Check if proposal is active or not
if (proposal.Status != v1.StatusDepositPeriod) && (proposal.Status != v1.StatusVotingPeriod) {
amaury1093 marked this conversation as resolved.
Show resolved Hide resolved
return sdkerrors.Wrapf(types.ErrInactiveProposal, "%d", proposalID)
}

// Check proposal voting period is ended.
if proposal.VotingEndTime != nil && proposal.VotingEndTime.Before(ctx.BlockTime()) {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

is there a case where proposal.VotingEndTime can be nil?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yes, if the proposal still in deposit period

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Let's add that note into the comment.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

up

// return sdkerrors.Wrap(errors.New("voting period is already ended for this proposal"))
// TODO: create error
return sdkerrors.Wrapf(types.ErrInactiveProposal, "voting period is already ended for this proposal %d", proposalID)
amaury1093 marked this conversation as resolved.
Show resolved Hide resolved
}

// update the status to StatusCanceled
proposal.Status = v1.StatusCanceled
// set to store
keeper.SetProposal(ctx, proposal)
// insert the proposal into cancel proposal queue
keeper.InsertCanceledProposalQueue(ctx, proposalID)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Am I right that if the proposer sends a tx that gets includes in block N, then the EnbBlocker of block N will run this and delete the canceled proposal. Which means that there's no way to query for a canceled proposal.

If that's correct, then why not just:

  • Remove StatusCanceled
  • Remove the CanceledProposalQueue
  • Directly burn/send deposits on CancelProposal msg execution, don't wait for EndBlocker

The only reason I see why we would want a CanceledProposalQueue is if we wanted to keep a canceled proposal in state (to be queryable) for X amount of blocks more.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I thought like if we do all the process inside msg execution then proposer has to wait for result, because we need do take care deposits and votes inside the process

Proposer doesn't need to wait for result if they use --broadcast-mode sync|async. And final execution time is the same whether it happens in DeliverTx or EndBlock.

One additional consideration is who pays for the gas of burning/returning deposits. Currently, in your design, the proposer pays little fees, just enough to write to the queue. In my proposed design, proposer would pay for the whole execution fee.

Copy link
Contributor

@amaury1093 amaury1093 Oct 21, 2022

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

IMO it boils down to a UX problem: if the proposer cancels a proposal, do we prefer:

  1. That the proposal still be queryable for a certain period of time? (with status canceled)
  2. Or it's fine that it immediately disappears from state?

IMO 2 is fine.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It will there until EndBlock execute the CanceledProposalQueue

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I also don't think we need the queue. Let's:

  • delete immediately
  • create an event that proposal was cancelled.


amaury1093 marked this conversation as resolved.
Show resolved Hide resolved
return nil
}

// GetProposal gets a proposal from store by ProposalID.
// Panics if can't unmarshal the proposal.
func (keeper Keeper) GetProposal(ctx sdk.Context, proposalID uint64) (v1.Proposal, bool) {
Expand Down Expand Up @@ -136,6 +170,9 @@ func (keeper Keeper) DeleteProposal(ctx sdk.Context, proposalID uint64) {
if proposal.VotingEndTime != nil {
keeper.RemoveFromActiveProposalQueue(ctx, proposalID, *proposal.VotingEndTime)
}
if proposal.Status == v1.StatusCanceled {
keeper.RemoveFromCanceledProposalQueue(ctx, proposalID)
}

store.Delete(types.ProposalKey(proposalID))
}
Expand Down
2 changes: 2 additions & 0 deletions x/gov/types/errors.go
Original file line number Diff line number Diff line change
Expand Up @@ -22,4 +22,6 @@ var (
ErrInvalidSignalMsg = sdkerrors.Register(ModuleName, 14, "signal message is invalid")
ErrMetadataTooLong = sdkerrors.Register(ModuleName, 15, "metadata too long")
ErrMinDepositTooSmall = sdkerrors.Register(ModuleName, 16, "minimum deposit is too small")
ErrProposalNotFound = sdkerrors.Register(ModuleName, 17, "proposal is not found")
gsk967 marked this conversation as resolved.
Show resolved Hide resolved
ErrInvalidProposer = sdkerrors.Register(ModuleName, 18, "invalid proposer")
)
Loading