Merge PR #5942: Tx Client Migration: x/gov

This commit is contained in:
Aaron Craelius 2020-04-14 15:05:14 -04:00 committed by GitHub
parent e8cedf243f
commit 58a6c4c007
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
30 changed files with 649 additions and 215 deletions

View File

@ -9,7 +9,7 @@ import (
"github.com/cosmos/cosmos-sdk/x/auth/vesting"
"github.com/cosmos/cosmos-sdk/x/evidence"
eviexported "github.com/cosmos/cosmos-sdk/x/evidence/exported"
"github.com/cosmos/cosmos-sdk/x/gov"
gov "github.com/cosmos/cosmos-sdk/x/gov/types"
"github.com/cosmos/cosmos-sdk/x/supply"
supplyexported "github.com/cosmos/cosmos-sdk/x/supply/exported"
)

View File

@ -965,100 +965,100 @@ func init() {
func init() { proto.RegisterFile("codec/std/codec.proto", fileDescriptor_daf09dc2dfa19bb4) }
var fileDescriptor_daf09dc2dfa19bb4 = []byte{
// 1479 bytes of a gzipped FileDescriptorProto
0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xb4, 0x58, 0xcd, 0x6f, 0xd4, 0x46,
0x1b, 0xf7, 0xc2, 0x92, 0x84, 0x49, 0x80, 0x30, 0x2f, 0xbc, 0x59, 0xe5, 0x85, 0x4d, 0x08, 0xbc,
0xa8, 0x05, 0x65, 0xcd, 0x47, 0x5b, 0x60, 0xd5, 0x0a, 0xf2, 0x01, 0x5a, 0xaa, 0xa6, 0x45, 0x0e,
0xa4, 0x6a, 0x45, 0x6b, 0xcd, 0x7a, 0x06, 0x67, 0x9a, 0xb5, 0xc7, 0xf5, 0x8c, 0x37, 0x9b, 0x43,
0xef, 0x6d, 0xa5, 0x4a, 0x55, 0xfb, 0x0f, 0xa0, 0xf6, 0xd8, 0x2b, 0xc7, 0x9e, 0x2b, 0xc4, 0x89,
0x63, 0x4f, 0xa8, 0x82, 0x4b, 0xd5, 0xbf, 0xa2, 0x9a, 0x0f, 0x7b, 0xed, 0x5d, 0xef, 0x86, 0x1e,
0x7a, 0x89, 0x3c, 0xf3, 0x3c, 0xbf, 0xdf, 0xf3, 0xf3, 0xcc, 0xf3, 0xe1, 0x0d, 0x38, 0xe9, 0x31,
0x4c, 0x3c, 0x9b, 0x0b, 0x6c, 0xab, 0xa7, 0x46, 0x14, 0x33, 0xc1, 0xe0, 0x9c, 0xc7, 0x78, 0xc0,
0xb8, 0xcb, 0xf1, 0x4e, 0x43, 0xef, 0x73, 0x81, 0x1b, 0xdd, 0xcb, 0xf3, 0x17, 0xc5, 0x36, 0x8d,
0xb1, 0x1b, 0xa1, 0x58, 0xec, 0xd9, 0xca, 0xd7, 0xd6, 0xae, 0xcb, 0xf9, 0x85, 0x66, 0x99, 0x3f,
0x3f, 0xec, 0xec, 0x33, 0x9f, 0xf5, 0x9f, 0x8c, 0x5f, 0xad, 0x67, 0xa3, 0x44, 0x6c, 0xdb, 0x62,
0x2f, 0x22, 0x5c, 0xff, 0x35, 0x96, 0x45, 0x63, 0xe9, 0x12, 0x2e, 0x68, 0xe8, 0x97, 0x78, 0xd4,
0x7a, 0x76, 0x1b, 0x85, 0x3b, 0x25, 0x96, 0xf9, 0x9e, 0xed, 0xc5, 0x94, 0x53, 0x5e, 0xce, 0x8b,
0x29, 0x17, 0x31, 0x6d, 0x27, 0x82, 0xb2, 0xb0, 0x1c, 0xcd, 0x93, 0x28, 0xea, 0xec, 0x95, 0xd8,
0x4e, 0xf5, 0x6c, 0xd2, 0xa5, 0x98, 0x84, 0x1e, 0x29, 0xb1, 0xce, 0xf5, 0x6c, 0x9f, 0x75, 0xcb,
0x61, 0xbc, 0x83, 0xf8, 0x76, 0xf9, 0x8b, 0xfc, 0xaf, 0x67, 0x73, 0x81, 0x76, 0xca, 0x8d, 0x67,
0x7b, 0x76, 0x84, 0x62, 0x14, 0xa4, 0xef, 0x12, 0xc5, 0x2c, 0x62, 0x1c, 0x75, 0x06, 0x19, 0x92,
0xc8, 0x8f, 0x11, 0x2e, 0x51, 0xb5, 0xf4, 0x6b, 0x15, 0x4c, 0xae, 0x78, 0x1e, 0x4b, 0x42, 0x01,
0xef, 0x80, 0x99, 0x36, 0xe2, 0xc4, 0x45, 0x7a, 0x5d, 0xab, 0x2c, 0x56, 0xde, 0x98, 0xbe, 0x72,
0xa6, 0x91, 0xbb, 0xf4, 0x5e, 0x43, 0x9e, 0x7b, 0xa3, 0x7b, 0xb9, 0xb1, 0x8a, 0x38, 0x31, 0xc0,
0x96, 0xe5, 0x4c, 0xb7, 0xfb, 0x4b, 0xd8, 0x05, 0xf3, 0x1e, 0x0b, 0x05, 0x0d, 0x13, 0x96, 0x70,
0xd7, 0xdc, 0x51, 0xc6, 0x7a, 0x40, 0xb1, 0xbe, 0x53, 0xc6, 0xaa, 0x3d, 0x25, 0xfb, 0x5a, 0x86,
0xdf, 0xd2, 0x9b, 0xfd, 0x50, 0x35, 0x6f, 0x84, 0x0d, 0x06, 0x60, 0x0e, 0x93, 0x0e, 0xda, 0x23,
0x78, 0x28, 0xe8, 0x41, 0x15, 0xf4, 0xea, 0xf8, 0xa0, 0xeb, 0x1a, 0x3c, 0x14, 0xf1, 0x24, 0x2e,
0x33, 0xc0, 0x08, 0xd4, 0x22, 0x12, 0x53, 0x86, 0xa9, 0x37, 0x14, 0xaf, 0xaa, 0xe2, 0xbd, 0x35,
0x3e, 0xde, 0x3d, 0x83, 0x1e, 0x0a, 0xf8, 0xdf, 0xa8, 0xd4, 0x02, 0x3f, 0x04, 0x47, 0x03, 0x86,
0x93, 0x4e, 0xff, 0x8a, 0x0e, 0xa9, 0x38, 0xff, 0x2f, 0xc6, 0xd1, 0x09, 0x2a, 0x23, 0x6c, 0x28,
0xef, 0x3e, 0xf1, 0x91, 0x20, 0xbf, 0xd1, 0xbc, 0xf1, 0xec, 0xc9, 0xf2, 0xdb, 0x17, 0x7c, 0x2a,
0xb6, 0x93, 0x76, 0xc3, 0x63, 0x81, 0x29, 0xd3, 0xb4, 0x74, 0x39, 0xde, 0xb1, 0x4d, 0xa1, 0x91,
0x5e, 0xc4, 0x62, 0x41, 0x70, 0xc3, 0x40, 0x57, 0x0f, 0x81, 0x83, 0x3c, 0x09, 0x96, 0xbe, 0xad,
0x80, 0x89, 0x4d, 0x15, 0x0e, 0x5e, 0x07, 0x13, 0x3a, 0xb0, 0xc9, 0x9b, 0xfa, 0x28, 0x51, 0xda,
0xbf, 0x65, 0x39, 0xc6, 0xbf, 0x79, 0xf3, 0xcf, 0xc7, 0x0b, 0x95, 0x67, 0x4f, 0x96, 0xaf, 0xed,
0x27, 0xc5, 0x54, 0x5e, 0x26, 0x46, 0x33, 0xdd, 0x4d, 0xc5, 0xfc, 0x54, 0x01, 0x53, 0xb7, 0x4d,
0x01, 0xc2, 0x0f, 0xc0, 0x0c, 0xf9, 0x32, 0xa1, 0x5d, 0xe6, 0x21, 0x59, 0xca, 0x46, 0xd4, 0xf9,
0xa2, 0xa8, 0xb4, 0x5c, 0xa5, 0xac, 0xdb, 0x39, 0xef, 0x96, 0xe5, 0x14, 0xd0, 0xcd, 0x15, 0x23,
0xf1, 0xc6, 0x3e, 0x0a, 0xb3, 0xfa, 0xcf, 0x34, 0xa6, 0x82, 0x52, 0x91, 0xbf, 0x54, 0xc0, 0xf1,
0x0d, 0xee, 0x6f, 0x26, 0xed, 0x80, 0x8a, 0x4c, 0xed, 0x06, 0xa8, 0xca, 0x0a, 0x32, 0x2a, 0xed,
0xd1, 0x2a, 0x87, 0xa0, 0xb2, 0x0e, 0x57, 0xa7, 0x9e, 0xbe, 0x58, 0xb0, 0x9e, 0xbf, 0x58, 0xa8,
0x38, 0x8a, 0x06, 0xbe, 0x07, 0xa6, 0x52, 0x90, 0xa9, 0xb7, 0x42, 0x15, 0xe7, 0x5b, 0x77, 0x26,
0xd0, 0xc9, 0x20, 0xcd, 0xa9, 0xaf, 0x1f, 0x2f, 0x58, 0xf2, 0x8d, 0x97, 0x7e, 0xce, 0xab, 0xbd,
0x67, 0xba, 0x0b, 0x6c, 0x15, 0xd4, 0x5e, 0x28, 0xaa, 0xf5, 0x59, 0xb7, 0x20, 0x34, 0x45, 0x95,
0x0a, 0x6d, 0x82, 0x49, 0x59, 0xce, 0x24, 0xeb, 0x0b, 0x8b, 0x23, 0x75, 0xae, 0x69, 0x3f, 0x27,
0x05, 0xe4, 0x54, 0xfe, 0x58, 0x01, 0x53, 0x99, 0xb8, 0x9b, 0x05, 0x71, 0x67, 0x4a, 0xc5, 0x8d,
0xd5, 0x74, 0xeb, 0x1f, 0x6b, 0x5a, 0xad, 0x4a, 0x8a, 0xbe, 0xb2, 0xaa, 0x52, 0xf5, 0xb8, 0x0a,
0x26, 0x8d, 0x03, 0xbc, 0x06, 0xaa, 0x82, 0xf4, 0xc4, 0x58, 0x51, 0xf7, 0x49, 0x2f, 0x3b, 0xac,
0x96, 0xe5, 0x28, 0x00, 0x7c, 0x08, 0x66, 0x55, 0x87, 0x27, 0x82, 0xc4, 0xae, 0xb7, 0x8d, 0x42,
0x3f, 0xbd, 0xd1, 0x81, 0x24, 0xd1, 0x73, 0x40, 0xbd, 0x5c, 0xea, 0xbf, 0xa6, 0xdc, 0x73, 0x94,
0xc7, 0xa2, 0xa2, 0x09, 0x7e, 0x06, 0x66, 0x39, 0x7b, 0x24, 0x76, 0x51, 0x4c, 0x5c, 0x33, 0x23,
0x4c, 0xab, 0xbc, 0x54, 0x64, 0x37, 0x46, 0x55, 0xbe, 0x06, 0xf0, 0x40, 0x6f, 0xe5, 0xe9, 0x79,
0xd1, 0x04, 0x23, 0x30, 0xe7, 0xa1, 0xd0, 0x23, 0x1d, 0x77, 0x28, 0x4a, 0xb5, 0x6c, 0x0a, 0xe4,
0xa2, 0xac, 0x29, 0xdc, 0xe8, 0x58, 0x27, 0xbd, 0x32, 0x07, 0xd8, 0x01, 0x27, 0x3c, 0x16, 0x04,
0x49, 0x48, 0xc5, 0x9e, 0x1b, 0x31, 0xd6, 0x71, 0x79, 0x44, 0x42, 0x6c, 0xfa, 0xe4, 0xf5, 0x62,
0xb8, 0xfc, 0xa8, 0xd7, 0xb7, 0x69, 0x90, 0xf7, 0x18, 0xeb, 0x6c, 0x4a, 0x5c, 0x2e, 0x20, 0xf4,
0x86, 0xac, 0xcd, 0xeb, 0xa6, 0x2b, 0x5c, 0xda, 0xa7, 0x2b, 0x64, 0x73, 0x3f, 0x4b, 0x18, 0xd3,
0x0c, 0x7e, 0xa8, 0x80, 0xe9, 0xfb, 0x31, 0x0a, 0x39, 0xf2, 0xa4, 0x08, 0xb8, 0x52, 0xc8, 0xdd,
0x85, 0xf2, 0xc9, 0xbb, 0x29, 0xf0, 0xfd, 0x9e, 0xca, 0xdc, 0x99, 0x34, 0x73, 0xff, 0x92, 0xe9,
0x97, 0x56, 0x54, 0x35, 0xe0, 0x3e, 0xaf, 0x1d, 0x58, 0x3c, 0x38, 0x36, 0x75, 0x37, 0x08, 0xe7,
0xc8, 0x27, 0x26, 0x75, 0x15, 0xa6, 0x59, 0x95, 0x15, 0xb5, 0xf4, 0xdb, 0x0c, 0x98, 0x34, 0x56,
0xd8, 0x04, 0x53, 0x01, 0xf7, 0x5d, 0x2e, 0xcf, 0x50, 0x8b, 0x3a, 0x5d, 0x14, 0x25, 0x3f, 0xb2,
0xd2, 0x72, 0x27, 0x21, 0x6e, 0x59, 0xce, 0x64, 0xa0, 0x1f, 0xe1, 0xfb, 0xe0, 0xa8, 0xc4, 0x06,
0x49, 0x47, 0x50, 0xcd, 0xa0, 0x13, 0x77, 0x69, 0x24, 0xc3, 0x86, 0x74, 0x35, 0x34, 0x33, 0x41,
0x6e, 0x0d, 0x3f, 0x07, 0x27, 0x24, 0x57, 0x97, 0xc4, 0xf4, 0xd1, 0x9e, 0x4b, 0xc3, 0x2e, 0x8a,
0x29, 0xca, 0xe6, 0xfa, 0x40, 0x07, 0xd2, 0x9f, 0x77, 0x86, 0x73, 0x4b, 0x41, 0xee, 0xa6, 0x08,
0x79, 0x93, 0xc1, 0xd0, 0x2e, 0x0c, 0x41, 0x4d, 0xbf, 0xa7, 0x70, 0x77, 0xa9, 0xd8, 0xc6, 0x31,
0xda, 0x75, 0x11, 0xc6, 0x31, 0xe1, 0xdc, 0xa4, 0xea, 0xd5, 0xf1, 0xb9, 0xa3, 0xde, 0x5f, 0x7c,
0x6c, 0xb0, 0x2b, 0x1a, 0x2a, 0xf3, 0x34, 0x28, 0x33, 0xc0, 0xaf, 0xc0, 0x69, 0x19, 0x2f, 0x8b,
0x85, 0x49, 0x87, 0xf8, 0x48, 0xb0, 0xd8, 0x8d, 0xc9, 0x2e, 0x8a, 0x5f, 0x33, 0x61, 0x37, 0xb8,
0x9f, 0x12, 0xaf, 0xa7, 0x04, 0x8e, 0xc2, 0xb7, 0x2c, 0x67, 0x3e, 0x18, 0x69, 0x85, 0xdf, 0x54,
0xc0, 0x99, 0x42, 0xfc, 0x2e, 0xea, 0x50, 0xac, 0xe2, 0xcb, 0x34, 0xa7, 0x9c, 0xcb, 0x91, 0x39,
0xa1, 0x34, 0xbc, 0xfb, 0xda, 0x1a, 0xb6, 0x52, 0x92, 0xb5, 0x8c, 0xa3, 0x65, 0x39, 0xf5, 0x60,
0xac, 0x07, 0xdc, 0x01, 0x73, 0x52, 0xca, 0xa3, 0x24, 0xc4, 0x6e, 0xb1, 0x76, 0x6b, 0x93, 0x4a,
0xc0, 0x95, 0x7d, 0x05, 0xdc, 0x49, 0x42, 0x5c, 0x28, 0xde, 0x96, 0xe5, 0xc8, 0x7c, 0x19, 0xda,
0x87, 0x0f, 0xc1, 0x7f, 0xd4, 0x3d, 0xab, 0xc9, 0xe4, 0x66, 0x33, 0x72, 0x6a, 0x38, 0x8d, 0x8a,
0xc5, 0x32, 0x38, 0x75, 0x5b, 0x96, 0x73, 0x3c, 0x18, 0x9a, 0xe2, 0x45, 0xf6, 0xf4, 0x63, 0xbc,
0x76, 0xf8, 0x75, 0xd9, 0x73, 0xed, 0xa6, 0xcf, 0x9e, 0x0d, 0xb6, 0x1b, 0xba, 0x16, 0xbb, 0x4c,
0x90, 0x1a, 0x50, 0x94, 0xa7, 0x46, 0x4d, 0xde, 0x2d, 0x26, 0x88, 0x29, 0x45, 0xf9, 0x08, 0x57,
0xc1, 0xb4, 0x84, 0x62, 0x12, 0x31, 0x4e, 0x45, 0x6d, 0xba, 0xac, 0xbd, 0xf4, 0xd1, 0xeb, 0xda,
0xad, 0x65, 0x39, 0x20, 0xc8, 0x56, 0x70, 0x1d, 0xc8, 0x95, 0x9b, 0x84, 0x5f, 0x20, 0xda, 0xa9,
0xcd, 0x28, 0x8a, 0xb3, 0x03, 0xdf, 0x78, 0xe6, 0x67, 0x8c, 0xe1, 0x79, 0xa0, 0x5c, 0x5b, 0x96,
0x73, 0x38, 0x48, 0x17, 0xd0, 0xd5, 0x85, 0xec, 0xc5, 0x04, 0x09, 0xd2, 0x4f, 0xbb, 0xda, 0x11,
0xc5, 0x77, 0x71, 0x80, 0x4f, 0xff, 0xf0, 0x31, 0x74, 0x6b, 0x0a, 0x93, 0xa5, 0x90, 0xa9, 0xe4,
0x81, 0x5d, 0xf8, 0x09, 0x90, 0xbb, 0x2e, 0xc1, 0x54, 0xe4, 0xe8, 0x8f, 0x2a, 0xfa, 0x37, 0xc7,
0xd1, 0xdf, 0xc6, 0x54, 0xe4, 0xc9, 0x67, 0x83, 0x81, 0x3d, 0x78, 0x17, 0xcc, 0xe8, 0x53, 0x54,
0xc5, 0x44, 0x6a, 0xc7, 0x14, 0xe9, 0xb9, 0x71, 0xa4, 0xa6, 0xf0, 0xe4, 0x65, 0x4c, 0x07, 0xfd,
0x65, 0x7a, 0x0c, 0x6d, 0xe2, 0xd3, 0xd0, 0x8d, 0x49, 0x46, 0x39, 0xbb, 0xff, 0x31, 0xac, 0x4a,
0x8c, 0x93, 0x41, 0xcc, 0x31, 0x0c, 0xec, 0xc2, 0x8f, 0x74, 0xf3, 0x4d, 0xc2, 0x8c, 0xfa, 0x78,
0xd9, 0x07, 0x70, 0x91, 0xfa, 0x41, 0x98, 0x63, 0x3d, 0x12, 0xe4, 0x37, 0x9a, 0x17, 0x9e, 0x3d,
0x59, 0x3e, 0x3f, 0x76, 0xce, 0xe9, 0x09, 0x27, 0x15, 0x9a, 0xe9, 0xf6, 0x5d, 0x05, 0x4c, 0x6e,
0x52, 0x3f, 0x5c, 0x67, 0x1e, 0xbc, 0x53, 0x98, 0x6c, 0xe7, 0x46, 0x4e, 0x36, 0xe3, 0xff, 0x6f,
0x8c, 0xb7, 0xd5, 0x5b, 0x4f, 0x5f, 0xd6, 0x2b, 0xcf, 0x5f, 0xd6, 0x2b, 0x7f, 0xbc, 0xac, 0x57,
0xbe, 0x7f, 0x55, 0xb7, 0x9e, 0xbf, 0xaa, 0x5b, 0xbf, 0xbf, 0xaa, 0x5b, 0x9f, 0x8e, 0x7f, 0xb1,
0xec, 0x7f, 0x21, 0xed, 0x09, 0xf5, 0xa3, 0xf9, 0xea, 0xdf, 0x01, 0x00, 0x00, 0xff, 0xff, 0xb6,
0xc7, 0x0e, 0x8b, 0x1f, 0x11, 0x00, 0x00,
// 1477 bytes of a gzipped FileDescriptorProto
0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xb4, 0x58, 0xdf, 0x6f, 0x14, 0x45,
0x1c, 0xdf, 0x83, 0xa3, 0x2d, 0xd3, 0x02, 0x65, 0x04, 0x7b, 0xa9, 0x70, 0x2d, 0x05, 0x89, 0x42,
0x7a, 0x27, 0xa0, 0x42, 0x2f, 0x1a, 0xe8, 0xb5, 0x90, 0xc3, 0x58, 0x25, 0x5b, 0xa8, 0xd1, 0xa0,
0x9b, 0xb9, 0x9d, 0x61, 0x3b, 0xf6, 0x76, 0x67, 0xdd, 0x99, 0xbd, 0x5e, 0x1f, 0x7c, 0x57, 0x13,
0x13, 0xa3, 0xff, 0x00, 0xea, 0xa3, 0xaf, 0x3c, 0xfa, 0x6c, 0x08, 0x4f, 0x3c, 0xfa, 0x44, 0x0c,
0xbc, 0x18, 0xff, 0x0a, 0x33, 0x3f, 0x76, 0x6f, 0xf7, 0x6e, 0xef, 0x8a, 0x0f, 0xbe, 0x34, 0x3b,
0xf3, 0xfd, 0x7e, 0x3e, 0xdf, 0xcf, 0xce, 0x7c, 0x7f, 0xec, 0x15, 0x9c, 0x74, 0x19, 0x26, 0x6e,
0x9d, 0x0b, 0x5c, 0x57, 0x4f, 0xb5, 0x30, 0x62, 0x82, 0xc1, 0x39, 0x97, 0x71, 0x9f, 0x71, 0x87,
0xe3, 0x9d, 0x9a, 0xde, 0xe7, 0x02, 0xd7, 0xba, 0x97, 0xe6, 0x2f, 0x8a, 0x6d, 0x1a, 0x61, 0x27,
0x44, 0x91, 0xd8, 0xab, 0x2b, 0xdf, 0xba, 0x76, 0x5d, 0xce, 0x2e, 0x34, 0xcb, 0xfc, 0xf9, 0x61,
0x67, 0x8f, 0x79, 0xac, 0xff, 0x64, 0xfc, 0x2a, 0xbd, 0x3a, 0x8a, 0xc5, 0x76, 0x5d, 0xec, 0x85,
0x84, 0xeb, 0xbf, 0xc6, 0xb2, 0x68, 0x2c, 0x5d, 0xc2, 0x05, 0x0d, 0xbc, 0x02, 0x8f, 0x4a, 0xaf,
0xde, 0x46, 0xc1, 0x4e, 0x81, 0x65, 0xbe, 0x57, 0x77, 0x23, 0xca, 0x29, 0x2f, 0xe6, 0xc5, 0x94,
0x8b, 0x88, 0xb6, 0x63, 0x41, 0x59, 0x50, 0x8c, 0xe6, 0x71, 0x18, 0x76, 0xf6, 0x0a, 0x6c, 0xa7,
0x7a, 0x75, 0xd2, 0xa5, 0x98, 0x04, 0x2e, 0x29, 0xb0, 0xce, 0xf5, 0xea, 0x1e, 0xeb, 0x16, 0xc3,
0x78, 0x07, 0xf1, 0xed, 0xe2, 0x17, 0x79, 0xad, 0x57, 0xe7, 0x02, 0xed, 0x14, 0x1b, 0xcf, 0xf6,
0xea, 0x21, 0x8a, 0x90, 0x9f, 0xbc, 0x4b, 0x18, 0xb1, 0x90, 0x71, 0xd4, 0x19, 0x64, 0x88, 0x43,
0x2f, 0x42, 0xb8, 0x40, 0xd5, 0xd2, 0xef, 0x65, 0x30, 0xb9, 0xea, 0xba, 0x2c, 0x0e, 0x04, 0xbc,
0x05, 0x66, 0xda, 0x88, 0x13, 0x07, 0xe9, 0x75, 0xa5, 0xb4, 0x58, 0x7a, 0x63, 0xfa, 0xf2, 0x99,
0x5a, 0xe6, 0xd2, 0x7b, 0x35, 0x79, 0xee, 0xb5, 0xee, 0xa5, 0x5a, 0x13, 0x71, 0x62, 0x80, 0x2d,
0xcb, 0x9e, 0x6e, 0xf7, 0x97, 0xb0, 0x0b, 0xe6, 0x5d, 0x16, 0x08, 0x1a, 0xc4, 0x2c, 0xe6, 0x8e,
0xb9, 0xa3, 0x94, 0xf5, 0x80, 0x62, 0x7d, 0xb7, 0x88, 0x55, 0x7b, 0x4a, 0xf6, 0xb5, 0x14, 0xbf,
0xa5, 0x37, 0xfb, 0xa1, 0x2a, 0xee, 0x08, 0x1b, 0xf4, 0xc1, 0x1c, 0x26, 0x1d, 0xb4, 0x47, 0xf0,
0x50, 0xd0, 0x83, 0x2a, 0xe8, 0x95, 0xf1, 0x41, 0xd7, 0x35, 0x78, 0x28, 0xe2, 0x49, 0x5c, 0x64,
0x80, 0x21, 0xa8, 0x84, 0x24, 0xa2, 0x0c, 0x53, 0x77, 0x28, 0x5e, 0x59, 0xc5, 0x7b, 0x7b, 0x7c,
0xbc, 0x3b, 0x06, 0x3d, 0x14, 0xf0, 0xd5, 0xb0, 0xd0, 0x02, 0x3f, 0x02, 0x47, 0x7d, 0x86, 0xe3,
0x4e, 0xff, 0x8a, 0x0e, 0xa9, 0x38, 0xaf, 0xe7, 0xe3, 0xe8, 0x04, 0x95, 0x11, 0x36, 0x94, 0x77,
0x9f, 0xf8, 0x88, 0x9f, 0xdd, 0x68, 0xac, 0x3c, 0x79, 0xb4, 0xfc, 0xce, 0x05, 0x8f, 0x8a, 0xed,
0xb8, 0x5d, 0x73, 0x99, 0x6f, 0xca, 0x34, 0x29, 0x5d, 0x8e, 0x77, 0xea, 0xa6, 0xd0, 0x48, 0x2f,
0x64, 0x91, 0x20, 0xb8, 0x66, 0xa0, 0xcd, 0x43, 0xe0, 0x20, 0x8f, 0xfd, 0xa5, 0xef, 0x4a, 0x60,
0x62, 0x53, 0x85, 0x83, 0xd7, 0xc0, 0x84, 0x0e, 0x6c, 0xf2, 0xa6, 0x3a, 0x4a, 0x94, 0xf6, 0x6f,
0x59, 0xb6, 0xf1, 0x6f, 0x5c, 0xff, 0xfb, 0xe1, 0x42, 0xe9, 0xc9, 0xa3, 0xe5, 0xab, 0xfb, 0x49,
0x31, 0x95, 0x97, 0x8a, 0xd1, 0x4c, 0xb7, 0x13, 0x31, 0xbf, 0x94, 0xc0, 0xd4, 0x4d, 0x53, 0x80,
0xf0, 0x43, 0x30, 0x43, 0xbe, 0x8a, 0x69, 0x97, 0xb9, 0x48, 0x96, 0xb2, 0x11, 0x75, 0x3e, 0x2f,
0x2a, 0x29, 0x57, 0x29, 0xeb, 0x66, 0xc6, 0xbb, 0x65, 0xd9, 0x39, 0x74, 0x63, 0xd5, 0x48, 0x5c,
0xd9, 0x47, 0x61, 0x5a, 0xff, 0xa9, 0xc6, 0x44, 0x50, 0x22, 0xf2, 0xb7, 0x12, 0x38, 0xbe, 0xc1,
0xbd, 0xcd, 0xb8, 0xed, 0x53, 0x91, 0xaa, 0xdd, 0x00, 0x65, 0x59, 0x41, 0x46, 0x65, 0x7d, 0xb4,
0xca, 0x21, 0xa8, 0xac, 0xc3, 0xe6, 0xd4, 0xe3, 0x67, 0x0b, 0xd6, 0xd3, 0x67, 0x0b, 0x25, 0x5b,
0xd1, 0xc0, 0xf7, 0xc1, 0x54, 0x02, 0x32, 0xf5, 0x96, 0xab, 0xe2, 0x6c, 0xeb, 0x4e, 0x05, 0xda,
0x29, 0xa4, 0x31, 0xf5, 0xcd, 0xc3, 0x05, 0x4b, 0xbe, 0xf1, 0xd2, 0xaf, 0x59, 0xb5, 0x77, 0x4c,
0x77, 0x81, 0xad, 0x9c, 0xda, 0x0b, 0x79, 0xb5, 0x1e, 0xeb, 0xe6, 0x84, 0x26, 0xa8, 0x42, 0xa1,
0x0d, 0x30, 0x29, 0xcb, 0x99, 0xa4, 0x7d, 0x61, 0x71, 0xa4, 0xce, 0x35, 0xed, 0x67, 0x27, 0x80,
0x8c, 0xca, 0x9f, 0x4a, 0x60, 0x2a, 0x15, 0x77, 0x3d, 0x27, 0xee, 0x4c, 0xa1, 0xb8, 0xb1, 0x9a,
0x6e, 0xfc, 0x67, 0x4d, 0xcd, 0xb2, 0xa4, 0xe8, 0x2b, 0x2b, 0x2b, 0x55, 0x3f, 0x97, 0xc1, 0xa4,
0x71, 0x80, 0x57, 0x41, 0x59, 0x90, 0x9e, 0x18, 0x2b, 0xea, 0x2e, 0xe9, 0xa5, 0x87, 0xd5, 0xb2,
0x6c, 0x05, 0x80, 0xf7, 0xc1, 0xac, 0xea, 0xf0, 0x44, 0x90, 0xc8, 0x71, 0xb7, 0x51, 0xe0, 0x25,
0x37, 0x3a, 0x90, 0x24, 0x7a, 0x0e, 0xa8, 0x97, 0x4b, 0xfc, 0xd7, 0x94, 0x7b, 0x86, 0xf2, 0x58,
0x98, 0x37, 0xc1, 0xcf, 0xc1, 0x2c, 0x67, 0x0f, 0xc4, 0x2e, 0x8a, 0x88, 0x63, 0x66, 0x84, 0x69,
0x95, 0x6f, 0xe5, 0xd9, 0x8d, 0x51, 0x95, 0xaf, 0x01, 0xdc, 0xd3, 0x5b, 0x59, 0x7a, 0x9e, 0x37,
0xc1, 0x10, 0xcc, 0xb9, 0x28, 0x70, 0x49, 0xc7, 0x19, 0x8a, 0x52, 0x2e, 0x9a, 0x02, 0x99, 0x28,
0x6b, 0x0a, 0x37, 0x3a, 0xd6, 0x49, 0xb7, 0xc8, 0x01, 0x76, 0xc0, 0x09, 0x97, 0xf9, 0x7e, 0x1c,
0x50, 0xb1, 0xe7, 0x84, 0x8c, 0x75, 0x1c, 0x1e, 0x92, 0x00, 0x9b, 0x3e, 0x79, 0x2d, 0x1f, 0x2e,
0x3b, 0xea, 0xf5, 0x6d, 0x1a, 0xe4, 0x1d, 0xc6, 0x3a, 0x9b, 0x12, 0x97, 0x09, 0x08, 0xdd, 0x21,
0x6b, 0x63, 0xc5, 0x74, 0x85, 0x4b, 0xfb, 0x35, 0xae, 0x74, 0xf0, 0xa7, 0x19, 0x63, 0xba, 0xc1,
0x8f, 0x25, 0x30, 0x7d, 0x37, 0x42, 0x01, 0x47, 0xae, 0x54, 0x01, 0x57, 0x73, 0xc9, 0xbb, 0x50,
0x3c, 0x7a, 0x37, 0x05, 0xbe, 0xdb, 0x53, 0xa9, 0x3b, 0x93, 0xa4, 0xee, 0x3f, 0x32, 0xff, 0x92,
0x92, 0x2a, 0xfb, 0xdc, 0xe3, 0x95, 0x03, 0x8b, 0x07, 0xc7, 0xe6, 0xee, 0x06, 0xe1, 0x1c, 0x79,
0xc4, 0xe4, 0xae, 0xc2, 0x34, 0xca, 0xb2, 0xa4, 0x96, 0xfe, 0x98, 0x01, 0x93, 0xc6, 0x0a, 0x1b,
0x60, 0xca, 0xe7, 0x9e, 0xc3, 0xe5, 0x21, 0x6a, 0x51, 0xa7, 0xf3, 0xa2, 0xe4, 0x57, 0x56, 0x52,
0xef, 0x24, 0xc0, 0x2d, 0xcb, 0x9e, 0xf4, 0xf5, 0x23, 0xfc, 0x00, 0x1c, 0x95, 0x58, 0x3f, 0xee,
0x08, 0xaa, 0x19, 0x74, 0xe6, 0x2e, 0x8d, 0x64, 0xd8, 0x90, 0xae, 0x86, 0x66, 0xc6, 0xcf, 0xac,
0xe1, 0x17, 0xe0, 0x84, 0xe4, 0xea, 0x92, 0x88, 0x3e, 0xd8, 0x73, 0x68, 0xd0, 0x45, 0x11, 0x45,
0xe9, 0x60, 0x1f, 0x68, 0x41, 0xfa, 0xfb, 0xce, 0x70, 0x6e, 0x29, 0xc8, 0xed, 0x04, 0x21, 0xaf,
0xd2, 0x1f, 0xda, 0x85, 0x01, 0xa8, 0xe8, 0xf7, 0x14, 0xce, 0x2e, 0x15, 0xdb, 0x38, 0x42, 0xbb,
0x0e, 0xc2, 0x38, 0x22, 0x9c, 0x9b, 0x5c, 0xbd, 0x32, 0x3e, 0x79, 0xd4, 0xfb, 0x8b, 0x4f, 0x0c,
0x76, 0x55, 0x43, 0x65, 0xa2, 0xfa, 0x45, 0x06, 0xf8, 0x35, 0x38, 0x2d, 0xe3, 0xa5, 0xb1, 0x30,
0xe9, 0x10, 0x0f, 0x09, 0x16, 0x39, 0x11, 0xd9, 0x45, 0xd1, 0x4b, 0x66, 0xec, 0x06, 0xf7, 0x12,
0xe2, 0xf5, 0x84, 0xc0, 0x56, 0xf8, 0x96, 0x65, 0xcf, 0xfb, 0x23, 0xad, 0xf0, 0xdb, 0x12, 0x38,
0x93, 0x8b, 0xdf, 0x45, 0x1d, 0x8a, 0x55, 0x7c, 0x99, 0xe7, 0x94, 0x73, 0x39, 0x33, 0x27, 0x94,
0x86, 0xf7, 0x5e, 0x5a, 0xc3, 0x56, 0x42, 0xb2, 0x96, 0x72, 0xb4, 0x2c, 0xbb, 0xea, 0x8f, 0xf5,
0x80, 0x3b, 0x60, 0x4e, 0x4a, 0x79, 0x10, 0x07, 0xd8, 0xc9, 0x17, 0x6f, 0x65, 0x52, 0x09, 0xb8,
0xbc, 0xaf, 0x80, 0x5b, 0x71, 0x80, 0x73, 0xd5, 0xdb, 0xb2, 0x6c, 0x99, 0x2f, 0x43, 0xfb, 0xf0,
0x3e, 0x78, 0x45, 0xdd, 0xb3, 0x1a, 0x4d, 0x4e, 0x3a, 0x24, 0xa7, 0x86, 0xd3, 0x28, 0x5f, 0x2c,
0x83, 0x63, 0xb7, 0x65, 0xd9, 0xc7, 0xfd, 0xa1, 0x31, 0x9e, 0x67, 0x4f, 0xbe, 0xc6, 0x2b, 0x87,
0x5f, 0x96, 0x3d, 0xd3, 0x6f, 0xfa, 0xec, 0xe9, 0x64, 0x5b, 0xd1, 0xb5, 0xd8, 0x65, 0x82, 0x54,
0x80, 0xa2, 0x3c, 0x35, 0x6a, 0xf4, 0x6e, 0x31, 0x41, 0x4c, 0x29, 0xca, 0x47, 0xd8, 0x04, 0xd3,
0x12, 0x8a, 0x49, 0xc8, 0x38, 0x15, 0x95, 0xe9, 0xa2, 0xf6, 0xd2, 0x47, 0xaf, 0x6b, 0xb7, 0x96,
0x65, 0x03, 0x3f, 0x5d, 0xc1, 0x75, 0x20, 0x57, 0x4e, 0x1c, 0x7c, 0x89, 0x68, 0xa7, 0x32, 0xa3,
0x28, 0xce, 0x0e, 0x7c, 0xe4, 0x99, 0xdf, 0x31, 0x86, 0xe7, 0x9e, 0x72, 0x6d, 0x59, 0xf6, 0x61,
0x3f, 0x59, 0x40, 0x47, 0x17, 0xb2, 0x1b, 0x11, 0x24, 0x48, 0x3f, 0xed, 0x2a, 0x47, 0x14, 0xdf,
0xc5, 0x01, 0x3e, 0xfd, 0xcb, 0xc7, 0xd0, 0xad, 0x29, 0x4c, 0x9a, 0x42, 0xa6, 0x92, 0x07, 0x76,
0xe1, 0xa7, 0x40, 0xee, 0x3a, 0x04, 0x53, 0x91, 0xa1, 0x3f, 0xaa, 0xe8, 0xdf, 0x1c, 0x47, 0x7f,
0x13, 0x53, 0x91, 0x25, 0x9f, 0xf5, 0x07, 0xf6, 0xe0, 0x6d, 0x30, 0xa3, 0x4f, 0x51, 0x15, 0x13,
0xa9, 0x1c, 0x53, 0xa4, 0xe7, 0xc6, 0x91, 0x9a, 0xc2, 0x93, 0x97, 0x31, 0xed, 0xf7, 0x97, 0xc9,
0x31, 0xb4, 0x89, 0x47, 0x03, 0x27, 0x22, 0x29, 0xe5, 0xec, 0xfe, 0xc7, 0xd0, 0x94, 0x18, 0x3b,
0x85, 0x98, 0x63, 0x18, 0xd8, 0x85, 0x1f, 0xeb, 0xe6, 0x1b, 0x07, 0x29, 0xf5, 0xf1, 0xa2, 0x2f,
0xe0, 0x3c, 0xf5, 0xbd, 0x20, 0xc3, 0x7a, 0xc4, 0xcf, 0x6e, 0x34, 0x2e, 0x3c, 0x79, 0xb4, 0x7c,
0x7e, 0xec, 0x9c, 0xd3, 0x13, 0x4e, 0x2a, 0x34, 0xd3, 0xed, 0xfb, 0x12, 0x98, 0xdc, 0xa4, 0x5e,
0xb0, 0xce, 0x5c, 0x78, 0x2b, 0x37, 0xd9, 0xce, 0x8d, 0x9c, 0x6c, 0xc6, 0xff, 0xff, 0x18, 0x6f,
0xcd, 0x1b, 0x8f, 0x9f, 0x57, 0x4b, 0x4f, 0x9f, 0x57, 0x4b, 0x7f, 0x3d, 0xaf, 0x96, 0x7e, 0x78,
0x51, 0xb5, 0x9e, 0xbe, 0xa8, 0x5a, 0x7f, 0xbe, 0xa8, 0x5a, 0x9f, 0x8d, 0x7f, 0xb1, 0xf4, 0x9f,
0x21, 0xed, 0x09, 0xf5, 0xab, 0xf9, 0xca, 0xbf, 0x01, 0x00, 0x00, 0xff, 0xff, 0x23, 0x3f, 0x73,
0xb2, 0x20, 0x11, 0x00, 0x00,
}
func (this *Supply) Equal(that interface{}) bool {
@ -1515,33 +1515,18 @@ func (this *Content) SetContent(value github_com_cosmos_cosmos_sdk_x_gov_types.C
case *types4.TextProposal:
this.Sum = &Content_Text{vt}
return nil
case types4.TextProposal:
this.Sum = &Content_Text{&vt}
return nil
case *proposal.ParameterChangeProposal:
this.Sum = &Content_ParameterChange{vt}
return nil
case proposal.ParameterChangeProposal:
this.Sum = &Content_ParameterChange{&vt}
return nil
case *types5.SoftwareUpgradeProposal:
this.Sum = &Content_SoftwareUpgrade{vt}
return nil
case types5.SoftwareUpgradeProposal:
this.Sum = &Content_SoftwareUpgrade{&vt}
return nil
case *types5.CancelSoftwareUpgradeProposal:
this.Sum = &Content_CancelSoftwareUpgrade{vt}
return nil
case types5.CancelSoftwareUpgradeProposal:
this.Sum = &Content_CancelSoftwareUpgrade{&vt}
return nil
case *types6.CommunityPoolSpendProposal:
this.Sum = &Content_CommunityPoolSpend{vt}
return nil
case types6.CommunityPoolSpendProposal:
this.Sum = &Content_CommunityPoolSpend{&vt}
return nil
}
return fmt.Errorf("can't encode value of type %T as message Content", value)
}

View File

@ -88,7 +88,7 @@ message Proposal {
// governance proposal.
message Content {
option (gogoproto.equal) = true;
option (cosmos_proto.interface_type) = "github.com/cosmos/cosmos-sdk/x/gov/types.Content";
option (cosmos_proto.interface_type) = "*github.com/cosmos/cosmos-sdk/x/gov/types.Content";
// sum defines a set of all acceptable concrete governance proposal Content types.
oneof sum {

View File

@ -5,12 +5,12 @@ import (
sdkerrors "github.com/cosmos/cosmos-sdk/types/errors"
"github.com/cosmos/cosmos-sdk/x/evidence"
eviexported "github.com/cosmos/cosmos-sdk/x/evidence/exported"
"github.com/cosmos/cosmos-sdk/x/gov"
gov "github.com/cosmos/cosmos-sdk/x/gov/types"
)
var (
_ eviexported.MsgSubmitEvidence = MsgSubmitEvidence{}
_ gov.MsgSubmitProposalI = MsgSubmitProposal{}
_ gov.MsgSubmitProposalI = &MsgSubmitProposal{}
)
// NewMsgSubmitEvidence returns a new MsgSubmitEvidence.
@ -47,13 +47,13 @@ func (msg MsgSubmitEvidence) GetEvidence() eviexported.Evidence { return msg.Evi
func (msg MsgSubmitEvidence) GetSubmitter() sdk.AccAddress { return msg.Submitter }
// NewMsgSubmitProposal returns a new MsgSubmitProposal.
func NewMsgSubmitProposal(c gov.Content, d sdk.Coins, p sdk.AccAddress) (MsgSubmitProposal, error) {
func NewMsgSubmitProposal(c gov.Content, d sdk.Coins, p sdk.AccAddress) (gov.MsgSubmitProposalI, error) {
content := &Content{}
if err := content.SetContent(c); err != nil {
return MsgSubmitProposal{}, err
return nil, err
}
return MsgSubmitProposal{
return &MsgSubmitProposal{
Content: content,
MsgSubmitProposalBase: gov.NewMsgSubmitProposalBase(d, p),
}, nil
@ -79,6 +79,13 @@ func (msg MsgSubmitProposal) ValidateBasic() error {
}
// nolint
func (msg MsgSubmitProposal) GetContent() gov.Content { return msg.Content.GetContent() }
func (msg MsgSubmitProposal) GetInitialDeposit() sdk.Coins { return msg.InitialDeposit }
func (msg MsgSubmitProposal) GetProposer() sdk.AccAddress { return msg.Proposer }
func (msg *MsgSubmitProposal) GetContent() gov.Content { return msg.Content.GetContent() }
func (msg *MsgSubmitProposal) SetContent(content gov.Content) error {
stdContent := &Content{}
err := stdContent.SetContent(content)
if err != nil {
return err
}
msg.Content = stdContent
return nil
}

View File

@ -4,12 +4,13 @@ import (
"testing"
"time"
gov "github.com/cosmos/cosmos-sdk/x/gov/types"
"github.com/stretchr/testify/require"
"github.com/cosmos/cosmos-sdk/codec/std"
sdk "github.com/cosmos/cosmos-sdk/types"
"github.com/cosmos/cosmos-sdk/x/evidence"
"github.com/cosmos/cosmos-sdk/x/gov"
)
func TestNewMsgSubmitEvidence(t *testing.T) {
@ -28,15 +29,45 @@ func TestNewMsgSubmitEvidence(t *testing.T) {
require.NoError(t, msg.ValidateBasic())
}
func TestNewNewMsgSubmitProposal(t *testing.T) {
type invalidProposal struct {
*gov.TextProposal
}
func TestMsgSubmitProposal(t *testing.T) {
p := sdk.AccAddress("foo")
d := sdk.NewCoins(sdk.NewInt64Coin("stake", 1000))
c := gov.TextProposal{Title: "title", Description: "description"}
c := gov.NewTextProposal("title", "description")
//
// test constructor
//
msg, err := std.NewMsgSubmitProposal(c, d, p)
require.NoError(t, err)
require.Equal(t, msg.GetContent(), &c)
require.Equal(t, msg.GetContent(), c)
require.Equal(t, msg.GetProposer(), p)
require.Equal(t, msg.GetInitialDeposit(), d)
require.NoError(t, msg.ValidateBasic())
_, err = std.NewMsgSubmitProposal(invalidProposal{}, d, p)
require.Error(t, err)
//
// test setter methods
//
msg = &std.MsgSubmitProposal{}
msg.SetProposer(p)
msg.SetInitialDeposit(d)
err = msg.SetContent(c)
require.NoError(t, err)
require.Equal(t, msg.GetContent(), c)
require.Equal(t, msg.GetProposer(), p)
require.Equal(t, msg.GetInitialDeposit(), d)
require.NoError(t, msg.ValidateBasic())
msg = &std.MsgSubmitProposal{}
err = msg.SetContent(invalidProposal{})
require.Error(t, err)
}

View File

@ -4,6 +4,7 @@
- 2020 March 06: Initial Draft
- 2020 March 12: API Updates
- 2020 April 13: Added details on interface `oneof` handling
## Status
@ -132,9 +133,42 @@ We then update `CLIContext` to have a new field: `Marshaler`.
Then, each module's client handler will at the minimum accept a `Marshaler` instead
of a concrete Amino codec and a `Generator` along with an `AccountRetriever` so
that account fields can be retrieved for signing. If the module needs to work with
any interface types, it will use the `Codec` interface defined by the module which
also extends `Marshaler`.
that account fields can be retrieved for signing.
#### Interface `oneof` Handling
If the module needs to work with any `sdk.Msg`s that use interface types, that
`sdk.Msg` should be implemented as an interface with getters and setters on the
module level and a no-arg constructor function should be passed around to
required CLI and REST client commands.
For example, in `x/gov`, `Content` is an interface type, so `MsgSubmitProposalI`
should also be an interface and implement setter methods:
```go
// x/gov/types/msgs.go
type MsgSubmitProposalI interface {
sdk.Msg
GetContent() Content
// SetContent returns an error if the underlying oneof does not support
// the concrete Content passed in
SetContent(Content) error
GetInitialDeposit() sdk.Coins
SetInitialDeposit(sdk.Coins)
GetProposer() sdk.AccAddress
SetProposer(sdk.AccAddress)
}
```
Note that the implementation of `MsgSubmitProposalI` can be simplified by
using an embedded base struct which implements most of that interface - in this
case `MsgSubmitProposalBase`.
A parameter `ctr func() MsgSubmitProposalI` would then be passed to CLI client
methods in order to construct a concrete instance.
## Future Improvements

View File

@ -103,7 +103,7 @@ func handleMsgFundCommunityPool(ctx sdk.Context, msg types.MsgFundCommunityPool,
func NewCommunityPoolSpendProposalHandler(k Keeper) govtypes.Handler {
return func(ctx sdk.Context, content govtypes.Content) error {
switch c := content.(type) {
case types.CommunityPoolSpendProposal:
case *types.CommunityPoolSpendProposal:
return keeper.HandleCommunityPoolSpendProposal(ctx, k, c)
default:

View File

@ -9,7 +9,7 @@ import (
)
// HandleCommunityPoolSpendProposal is a handler for executing a passed community spend proposal
func HandleCommunityPoolSpendProposal(ctx sdk.Context, k Keeper, p types.CommunityPoolSpendProposal) error {
func HandleCommunityPoolSpendProposal(ctx sdk.Context, k Keeper, p *types.CommunityPoolSpendProposal) error {
if k.blacklistedAddrs[p.Recipient.String()] {
return sdkerrors.Wrapf(sdkerrors.ErrUnauthorized, "%s is blacklisted from receiving external funds", p.Recipient)
}

View File

@ -24,7 +24,7 @@ var (
amount = sdk.NewCoins(sdk.NewCoin(sdk.DefaultBondDenom, sdk.NewInt(1)))
)
func testProposal(recipient sdk.AccAddress, amount sdk.Coins) types.CommunityPoolSpendProposal {
func testProposal(recipient sdk.AccAddress, amount sdk.Coins) *types.CommunityPoolSpendProposal {
return types.NewCommunityPoolSpendProposal("Test", "description", recipient, amount)
}

View File

@ -10,7 +10,7 @@ func RegisterCodec(cdc *codec.Codec) {
cdc.RegisterConcrete(MsgWithdrawDelegatorReward{}, "cosmos-sdk/MsgWithdrawDelegationReward", nil)
cdc.RegisterConcrete(MsgWithdrawValidatorCommission{}, "cosmos-sdk/MsgWithdrawValidatorCommission", nil)
cdc.RegisterConcrete(MsgSetWithdrawAddress{}, "cosmos-sdk/MsgModifyWithdrawAddress", nil)
cdc.RegisterConcrete(CommunityPoolSpendProposal{}, "cosmos-sdk/CommunityPoolSpendProposal", nil)
cdc.RegisterConcrete(&CommunityPoolSpendProposal{}, "cosmos-sdk/CommunityPoolSpendProposal", nil)
}
var (

View File

@ -14,32 +14,32 @@ const (
)
// Assert CommunityPoolSpendProposal implements govtypes.Content at compile-time
var _ govtypes.Content = CommunityPoolSpendProposal{}
var _ govtypes.Content = &CommunityPoolSpendProposal{}
func init() {
govtypes.RegisterProposalType(ProposalTypeCommunityPoolSpend)
govtypes.RegisterProposalTypeCodec(CommunityPoolSpendProposal{}, "cosmos-sdk/CommunityPoolSpendProposal")
govtypes.RegisterProposalTypeCodec(&CommunityPoolSpendProposal{}, "cosmos-sdk/CommunityPoolSpendProposal")
}
// NewCommunityPoolSpendProposal creates a new community pool spned proposal.
func NewCommunityPoolSpendProposal(title, description string, recipient sdk.AccAddress, amount sdk.Coins) CommunityPoolSpendProposal {
return CommunityPoolSpendProposal{title, description, recipient, amount}
func NewCommunityPoolSpendProposal(title, description string, recipient sdk.AccAddress, amount sdk.Coins) *CommunityPoolSpendProposal {
return &CommunityPoolSpendProposal{title, description, recipient, amount}
}
// GetTitle returns the title of a community pool spend proposal.
func (csp CommunityPoolSpendProposal) GetTitle() string { return csp.Title }
func (csp *CommunityPoolSpendProposal) GetTitle() string { return csp.Title }
// GetDescription returns the description of a community pool spend proposal.
func (csp CommunityPoolSpendProposal) GetDescription() string { return csp.Description }
func (csp *CommunityPoolSpendProposal) GetDescription() string { return csp.Description }
// GetDescription returns the routing key of a community pool spend proposal.
func (csp CommunityPoolSpendProposal) ProposalRoute() string { return RouterKey }
func (csp *CommunityPoolSpendProposal) ProposalRoute() string { return RouterKey }
// ProposalType returns the type of a community pool spend proposal.
func (csp CommunityPoolSpendProposal) ProposalType() string { return ProposalTypeCommunityPoolSpend }
func (csp *CommunityPoolSpendProposal) ProposalType() string { return ProposalTypeCommunityPoolSpend }
// ValidateBasic runs basic stateless validity checks
func (csp CommunityPoolSpendProposal) ValidateBasic() error {
func (csp *CommunityPoolSpendProposal) ValidateBasic() error {
err := govtypes.ValidateAbstract(csp)
if err != nil {
return err

View File

@ -4,10 +4,11 @@ import (
"testing"
"time"
codecstd "github.com/cosmos/cosmos-sdk/codec/std"
"github.com/stretchr/testify/require"
abci "github.com/tendermint/tendermint/abci/types"
codecstd "github.com/cosmos/cosmos-sdk/codec/std"
"github.com/cosmos/cosmos-sdk/simapp"
sdk "github.com/cosmos/cosmos-sdk/types"
"github.com/cosmos/cosmos-sdk/x/gov"

View File

@ -82,8 +82,8 @@ var (
SplitInactiveProposalQueueKey = types.SplitInactiveProposalQueueKey
SplitKeyDeposit = types.SplitKeyDeposit
SplitKeyVote = types.SplitKeyVote
NewMsgSubmitProposalBase = types.NewMsgSubmitProposalBase
NewMsgSubmitProposal = types.NewMsgSubmitProposal
NewMsgSubmitProposalBase = types.NewMsgSubmitProposalBase
NewMsgDeposit = types.NewMsgDeposit
NewMsgVote = types.NewMsgVote
ParamKeyTable = types.ParamKeyTable

View File

@ -11,6 +11,7 @@ import (
"github.com/cosmos/cosmos-sdk/client"
"github.com/cosmos/cosmos-sdk/client/context"
"github.com/cosmos/cosmos-sdk/client/flags"
"github.com/cosmos/cosmos-sdk/client/tx"
"github.com/cosmos/cosmos-sdk/codec"
sdk "github.com/cosmos/cosmos-sdk/types"
"github.com/cosmos/cosmos-sdk/version"
@ -49,6 +50,209 @@ var ProposalFlags = []string{
FlagDeposit,
}
// NewTxCmd returns the transaction commands for this module
// governance ModuleClient is slightly different from other ModuleClients in that
// it contains a slice of "proposal" child commands. These commands are respective
// to proposal type handlers that are implemented in other modules but are mounted
// under the governance CLI (eg. parameter change proposals).
func NewTxCmd(
cdc codec.Marshaler,
txg tx.Generator,
ar tx.AccountRetriever,
newMsgFn func() types.MsgSubmitProposalI,
pcmds []*cobra.Command) *cobra.Command {
govTxCmd := &cobra.Command{
Use: types.ModuleName,
Short: "Governance transactions subcommands",
DisableFlagParsing: true,
SuggestionsMinimumDistance: 2,
RunE: client.ValidateCmd,
}
cmdSubmitProp := NewCmdSubmitProposal(cdc, txg, ar, newMsgFn)
for _, pcmd := range pcmds {
cmdSubmitProp.AddCommand(flags.PostCommands(pcmd)[0])
}
govTxCmd.AddCommand(flags.PostCommands(
NewCmdDeposit(cdc, txg, ar),
NewCmdVote(cdc, txg, ar),
cmdSubmitProp,
)...)
return govTxCmd
}
// NewCmdSubmitProposal implements submitting a proposal transaction command.
func NewCmdSubmitProposal(
cdc codec.Marshaler,
txg tx.Generator,
ar tx.AccountRetriever,
newMsgFn func() types.MsgSubmitProposalI) *cobra.Command {
cmd := &cobra.Command{
Use: "submit-proposal",
Short: "Submit a proposal along with an initial deposit",
Long: strings.TrimSpace(
fmt.Sprintf(`Submit a proposal along with an initial deposit.
Proposal title, description, type and deposit can be given directly or through a proposal JSON file.
Example:
$ %s tx gov submit-proposal --proposal="path/to/proposal.json" --from mykey
Where proposal.json contains:
{
"title": "Test Proposal",
"description": "My awesome proposal",
"type": "Text",
"deposit": "10test"
}
Which is equivalent to:
$ %s tx gov submit-proposal --title="Test Proposal" --description="My awesome proposal" --type="Text" --deposit="10test" --from mykey
`,
version.ClientName, version.ClientName,
),
),
RunE: func(cmd *cobra.Command, args []string) error {
inBuf := bufio.NewReader(cmd.InOrStdin())
cliCtx := context.NewCLIContextWithInput(inBuf).WithMarshaler(cdc)
txf := tx.NewFactoryFromCLI(inBuf).WithTxGenerator(txg).WithAccountRetriever(ar)
proposal, err := parseSubmitProposalFlags()
if err != nil {
return err
}
amount, err := sdk.ParseCoins(proposal.Deposit)
if err != nil {
return err
}
content := types.ContentFromProposalType(proposal.Title, proposal.Description, proposal.Type)
msg := newMsgFn()
err = msg.SetContent(content)
if err != nil {
return err
}
msg.SetInitialDeposit(amount)
msg.SetProposer(cliCtx.FromAddress)
if err = msg.ValidateBasic(); err != nil {
return err
}
return tx.GenerateOrBroadcastTx(cliCtx, txf, msg)
},
}
cmd.Flags().String(FlagTitle, "", "title of proposal")
cmd.Flags().String(FlagDescription, "", "description of proposal")
cmd.Flags().String(flagProposalType, "", "proposalType of proposal, types: text/parameter_change/software_upgrade")
cmd.Flags().String(FlagDeposit, "", "deposit of proposal")
cmd.Flags().String(FlagProposal, "", "proposal file path (if this path is given, other proposal flags are ignored)")
return cmd
}
// NewCmdDeposit implements depositing tokens for an active proposal.
func NewCmdDeposit(cdc codec.Marshaler, txg tx.Generator, ar tx.AccountRetriever) *cobra.Command {
return &cobra.Command{
Use: "deposit [proposal-id] [deposit]",
Args: cobra.ExactArgs(2),
Short: "Deposit tokens for an active proposal",
Long: strings.TrimSpace(
fmt.Sprintf(`Submit a deposit for an active proposal. You can
find the proposal-id by running "%s query gov proposals".
Example:
$ %s tx gov deposit 1 10stake --from mykey
`,
version.ClientName, version.ClientName,
),
),
RunE: func(cmd *cobra.Command, args []string) error {
inBuf := bufio.NewReader(cmd.InOrStdin())
cliCtx := context.NewCLIContextWithInput(inBuf).WithMarshaler(cdc)
txf := tx.NewFactoryFromCLI(inBuf).WithTxGenerator(txg).WithAccountRetriever(ar)
// validate that the proposal id is a uint
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
from := cliCtx.GetFromAddress()
// Get amount of coins
amount, err := sdk.ParseCoins(args[1])
if err != nil {
return err
}
msg := types.NewMsgDeposit(from, proposalID, amount)
err = msg.ValidateBasic()
if err != nil {
return err
}
return tx.GenerateOrBroadcastTx(cliCtx, txf, msg)
},
}
}
// NewCmdVote implements creating a new vote command.
func NewCmdVote(cdc codec.Marshaler, txg tx.Generator, ar tx.AccountRetriever) *cobra.Command {
return &cobra.Command{
Use: "vote [proposal-id] [option]",
Args: cobra.ExactArgs(2),
Short: "Vote for an active proposal, options: yes/no/no_with_veto/abstain",
Long: strings.TrimSpace(
fmt.Sprintf(`Submit a vote for an active proposal. You can
find the proposal-id by running "%s query gov proposals".
Example:
$ %s tx gov vote 1 yes --from mykey
`,
version.ClientName, version.ClientName,
),
),
RunE: func(cmd *cobra.Command, args []string) error {
inBuf := bufio.NewReader(cmd.InOrStdin())
cliCtx := context.NewCLIContextWithInput(inBuf).WithMarshaler(cdc)
txf := tx.NewFactoryFromCLI(inBuf).WithTxGenerator(txg).WithAccountRetriever(ar)
// Get voting address
from := cliCtx.GetFromAddress()
// validate that the proposal id is a uint
proposalID, err := strconv.ParseUint(args[0], 10, 64)
if err != nil {
return fmt.Errorf("proposal-id %s not a valid int, please input a valid proposal-id", args[0])
}
// Find out which vote option user chose
byteVoteOption, err := types.VoteOptionFromString(govutils.NormalizeVoteOption(args[1]))
if err != nil {
return err
}
// Build vote message and run basic validation
msg := types.NewMsgVote(from, proposalID, byteVoteOption)
err = msg.ValidateBasic()
if err != nil {
return err
}
return tx.GenerateOrBroadcastTx(cliCtx, txf, msg)
},
}
}
// GetTxCmd returns the transaction commands for this module
// governance ModuleClient is slightly different from other ModuleClients in that
// it contains a slice of "proposal" child commands. These commands are respective

View File

@ -3,6 +3,11 @@ package rest
import (
"net/http"
"github.com/cosmos/cosmos-sdk/codec"
"github.com/cosmos/cosmos-sdk/client/tx"
"github.com/cosmos/cosmos-sdk/x/gov/types"
"github.com/gorilla/mux"
"github.com/cosmos/cosmos-sdk/client/context"
@ -28,6 +33,11 @@ type ProposalRESTHandler struct {
Handler func(http.ResponseWriter, *http.Request)
}
func RegisterHandlers(cliCtx context.CLIContext, m codec.Marshaler, txg tx.Generator, r *mux.Router, msgSubmitProposalCtr func() types.MsgSubmitProposalI, phs []ProposalRESTHandler) {
registerQueryRoutes(cliCtx, r)
registerTxHandlers(cliCtx, m, txg, r, msgSubmitProposalCtr, phs)
}
// RegisterRoutes - Central function to define routes that get registered by the main application
func RegisterRoutes(cliCtx context.CLIContext, r *mux.Router, phs []ProposalRESTHandler) {
registerQueryRoutes(cliCtx, r)

View File

@ -4,9 +4,12 @@ import (
"fmt"
"net/http"
"github.com/cosmos/cosmos-sdk/codec"
"github.com/gorilla/mux"
"github.com/cosmos/cosmos-sdk/client/context"
"github.com/cosmos/cosmos-sdk/client/tx"
sdk "github.com/cosmos/cosmos-sdk/types"
"github.com/cosmos/cosmos-sdk/types/rest"
authclient "github.com/cosmos/cosmos-sdk/x/auth/client"
@ -14,6 +17,128 @@ import (
"github.com/cosmos/cosmos-sdk/x/gov/types"
)
func registerTxHandlers(cliCtx context.CLIContext, m codec.Marshaler, txg tx.Generator, r *mux.Router, newMsgFn func() types.MsgSubmitProposalI, phs []ProposalRESTHandler) {
propSubRtr := r.PathPrefix("/gov/proposals").Subrouter()
for _, ph := range phs {
propSubRtr.HandleFunc(fmt.Sprintf("/%s", ph.SubRoute), ph.Handler).Methods("POST")
}
cliCtx = cliCtx.WithMarshaler(m)
r.HandleFunc("/gov/proposals", newPostProposalHandlerFn(cliCtx, m, txg, newMsgFn)).Methods("POST")
r.HandleFunc(fmt.Sprintf("/gov/proposals/{%s}/deposits", RestProposalID), newDepositHandlerFn(cliCtx, txg)).Methods("POST")
r.HandleFunc(fmt.Sprintf("/gov/proposals/{%s}/votes", RestProposalID), newVoteHandlerFn(cliCtx, txg)).Methods("POST")
}
func newPostProposalHandlerFn(cliCtx context.CLIContext, m codec.Marshaler, txg tx.Generator, newMsgFn func() types.MsgSubmitProposalI) http.HandlerFunc {
return func(w http.ResponseWriter, r *http.Request) {
var req PostProposalReq
if !rest.ReadRESTReq(w, r, cliCtx.Codec, &req) {
return
}
req.BaseReq = req.BaseReq.Sanitize()
if !req.BaseReq.ValidateBasic(w) {
return
}
proposalType := gcutils.NormalizeProposalType(req.ProposalType)
content := types.ContentFromProposalType(req.Title, req.Description, proposalType)
msg := newMsgFn()
err := msg.SetContent(content)
if rest.CheckBadRequestError(w, err) {
return
}
msg.SetInitialDeposit(req.InitialDeposit)
msg.SetProposer(req.Proposer)
if rest.CheckBadRequestError(w, msg.ValidateBasic()) {
return
}
tx.WriteGeneratedTxResponse(cliCtx, w, txg, req.BaseReq, msg)
}
}
func newDepositHandlerFn(cliCtx context.CLIContext, txg tx.Generator) http.HandlerFunc {
return func(w http.ResponseWriter, r *http.Request) {
vars := mux.Vars(r)
strProposalID := vars[RestProposalID]
if len(strProposalID) == 0 {
rest.WriteErrorResponse(w, http.StatusBadRequest, "proposalId required but not specified")
return
}
proposalID, ok := rest.ParseUint64OrReturnBadRequest(w, strProposalID)
if !ok {
return
}
var req DepositReq
if !rest.ReadRESTReq(w, r, cliCtx.Codec, &req) {
return
}
req.BaseReq = req.BaseReq.Sanitize()
if !req.BaseReq.ValidateBasic(w) {
return
}
// create the message
msg := types.NewMsgDeposit(req.Depositor, proposalID, req.Amount)
if rest.CheckBadRequestError(w, msg.ValidateBasic()) {
return
}
tx.WriteGeneratedTxResponse(cliCtx, w, txg, req.BaseReq, msg)
}
}
func newVoteHandlerFn(cliCtx context.CLIContext, txg tx.Generator) http.HandlerFunc {
return func(w http.ResponseWriter, r *http.Request) {
vars := mux.Vars(r)
strProposalID := vars[RestProposalID]
if len(strProposalID) == 0 {
rest.WriteErrorResponse(w, http.StatusBadRequest, "proposalId required but not specified")
return
}
proposalID, ok := rest.ParseUint64OrReturnBadRequest(w, strProposalID)
if !ok {
return
}
var req VoteReq
if !rest.ReadRESTReq(w, r, cliCtx.Codec, &req) {
return
}
req.BaseReq = req.BaseReq.Sanitize()
if !req.BaseReq.ValidateBasic(w) {
return
}
voteOption, err := types.VoteOptionFromString(gcutils.NormalizeVoteOption(req.Option))
if rest.CheckBadRequestError(w, err) {
return
}
// create the message
msg := types.NewMsgVote(req.Voter, proposalID, voteOption)
if rest.CheckBadRequestError(w, msg.ValidateBasic()) {
return
}
tx.WriteGeneratedTxResponse(cliCtx, w, txg, req.BaseReq, msg)
}
}
// ---------------------------------------------------------------------------
// Deprecated
//
// TODO: Remove once client-side Protobuf migration has been completed.
// ---------------------------------------------------------------------------
func registerTxRoutes(cliCtx context.CLIContext, r *mux.Router, phs []ProposalRESTHandler) {
propSubRtr := r.PathPrefix("/gov/proposals").Subrouter()
for _, ph := range phs {

View File

@ -66,14 +66,14 @@ func TestSubmitProposal(t *testing.T) {
content types.Content
expectedErr error
}{
{types.TextProposal{Title: "title", Description: "description"}, nil},
{&types.TextProposal{Title: "title", Description: "description"}, nil},
// Keeper does not check the validity of title and description, no error
{types.TextProposal{Title: "", Description: "description"}, nil},
{types.TextProposal{Title: strings.Repeat("1234567890", 100), Description: "description"}, nil},
{types.TextProposal{Title: "title", Description: ""}, nil},
{types.TextProposal{Title: "title", Description: strings.Repeat("1234567890", 1000)}, nil},
{&types.TextProposal{Title: "", Description: "description"}, nil},
{&types.TextProposal{Title: strings.Repeat("1234567890", 100), Description: "description"}, nil},
{&types.TextProposal{Title: "title", Description: ""}, nil},
{&types.TextProposal{Title: "title", Description: strings.Repeat("1234567890", 1000)}, nil},
// error only when invalid route
{invalidProposalRoute{}, types.ErrNoProposalHandlerExists},
{&invalidProposalRoute{}, types.ErrNoProposalHandlerExists},
}
for i, tc := range testCases {

View File

@ -5,6 +5,8 @@ import (
"math/rand"
"time"
"github.com/cosmos/cosmos-sdk/codec/std"
"github.com/cosmos/cosmos-sdk/baseapp"
"github.com/cosmos/cosmos-sdk/codec"
"github.com/cosmos/cosmos-sdk/simapp/helpers"
@ -125,7 +127,10 @@ func SimulateSubmitProposal(
return simtypes.NoOpMsg(types.ModuleName), nil, err
}
msg := types.NewMsgSubmitProposal(content, deposit, simAccount.Address)
msg, err := std.NewMsgSubmitProposal(content, deposit, simAccount.Address)
if err != nil {
return simtypes.NoOpMsg(types.ModuleName), nil, err
}
account := ak.GetAccount(ctx, simAccount.Address)
spendable := bk.SpendableCoins(ctx, account.GetAddress())

View File

@ -17,10 +17,10 @@ type Codec interface {
func RegisterCodec(cdc *codec.Codec) {
cdc.RegisterInterface((*Content)(nil), nil)
cdc.RegisterConcrete(MsgSubmitProposalBase{}, "cosmos-sdk/MsgSubmitProposalBase", nil)
cdc.RegisterConcrete(MsgSubmitProposal{}, "cosmos-sdk/MsgSubmitProposal", nil)
cdc.RegisterConcrete(&MsgSubmitProposal{}, "cosmos-sdk/MsgSubmitProposal", nil)
cdc.RegisterConcrete(MsgDeposit{}, "cosmos-sdk/MsgDeposit", nil)
cdc.RegisterConcrete(MsgVote{}, "cosmos-sdk/MsgVote", nil)
cdc.RegisterConcrete(TextProposal{}, "cosmos-sdk/TextProposal", nil)
cdc.RegisterConcrete(&TextProposal{}, "cosmos-sdk/TextProposal", nil)
}
// RegisterProposalTypeCodec registers an external proposal content type defined

View File

@ -23,8 +23,13 @@ type MsgSubmitProposalI interface {
sdk.Msg
GetContent() Content
SetContent(Content) error
GetInitialDeposit() sdk.Coins
SetInitialDeposit(sdk.Coins)
GetProposer() sdk.AccAddress
SetProposer(sdk.AccAddress)
}
// NewMsgSubmitProposalBase creates a new MsgSubmitProposalBase.
@ -35,6 +40,18 @@ func NewMsgSubmitProposalBase(initialDeposit sdk.Coins, proposer sdk.AccAddress)
}
}
func (msg *MsgSubmitProposalBase) GetInitialDeposit() sdk.Coins { return msg.InitialDeposit }
func (msg *MsgSubmitProposalBase) GetProposer() sdk.AccAddress { return msg.Proposer }
func (msg *MsgSubmitProposalBase) SetInitialDeposit(coins sdk.Coins) {
msg.InitialDeposit = coins
}
func (msg *MsgSubmitProposalBase) SetProposer(address sdk.AccAddress) {
msg.Proposer = address
}
// Route implements Msg
func (msg MsgSubmitProposalBase) Route() string { return RouterKey }
@ -172,6 +189,8 @@ type MsgSubmitProposal struct {
Proposer sdk.AccAddress `json:"proposer" yaml:"proposer"` // Address of the proposer
}
var _ MsgSubmitProposalI = &MsgSubmitProposal{}
// NewMsgSubmitProposal returns a (deprecated) MsgSubmitProposal message.
//
// TODO: Remove once client-side Protobuf migration has been completed.
@ -213,3 +232,16 @@ func (msg MsgSubmitProposal) Type() string { return TypeMsgSubmi
func (msg MsgSubmitProposal) GetContent() Content { return msg.Content }
func (msg MsgSubmitProposal) GetInitialDeposit() sdk.Coins { return msg.InitialDeposit }
func (msg MsgSubmitProposal) GetProposer() sdk.AccAddress { return msg.Proposer }
func (msg *MsgSubmitProposal) SetContent(content Content) error {
msg.Content = content
return nil
}
func (msg *MsgSubmitProposal) SetInitialDeposit(deposit sdk.Coins) {
msg.InitialDeposit = deposit
}
func (msg *MsgSubmitProposal) SetProposer(proposer sdk.AccAddress) {
msg.Proposer = proposer
}

View File

@ -195,27 +195,27 @@ const (
)
// Implements Content Interface
var _ Content = TextProposal{}
var _ Content = &TextProposal{}
// NewTextProposal creates a text proposal Content
func NewTextProposal(title, description string) Content {
return TextProposal{title, description}
return &TextProposal{title, description}
}
// GetTitle returns the proposal title
func (tp TextProposal) GetTitle() string { return tp.Title }
func (tp *TextProposal) GetTitle() string { return tp.Title }
// GetDescription returns the proposal description
func (tp TextProposal) GetDescription() string { return tp.Description }
func (tp *TextProposal) GetDescription() string { return tp.Description }
// ProposalRoute returns the proposal router key
func (tp TextProposal) ProposalRoute() string { return RouterKey }
func (tp *TextProposal) ProposalRoute() string { return RouterKey }
// ProposalType is "Text"
func (tp TextProposal) ProposalType() string { return ProposalTypeText }
func (tp *TextProposal) ProposalType() string { return ProposalTypeText }
// ValidateBasic validates the content's title and description of the proposal
func (tp TextProposal) ValidateBasic() error { return ValidateAbstract(tp) }
func (tp *TextProposal) ValidateBasic() error { return ValidateAbstract(tp) }
// String implements Stringer interface
func (tp TextProposal) String() string {

View File

@ -14,7 +14,7 @@ import (
func NewParamChangeProposalHandler(k keeper.Keeper) govtypes.Handler {
return func(ctx sdk.Context, content govtypes.Content) error {
switch c := content.(type) {
case proposal.ParameterChangeProposal:
case *proposal.ParameterChangeProposal:
return handleParameterChangeProposal(ctx, k, c)
default:
@ -23,7 +23,7 @@ func NewParamChangeProposalHandler(k keeper.Keeper) govtypes.Handler {
}
}
func handleParameterChangeProposal(ctx sdk.Context, k keeper.Keeper, p proposal.ParameterChangeProposal) error {
func handleParameterChangeProposal(ctx sdk.Context, k keeper.Keeper, p *proposal.ParameterChangeProposal) error {
for _, c := range p.Changes {
ss, ok := k.GetSubspace(c.Subspace)
if !ok {

View File

@ -51,7 +51,7 @@ func (tp *testParams) ParamSetPairs() types.ParamSetPairs {
}
}
func testProposal(changes ...proposal.ParamChange) proposal.ParameterChangeProposal {
func testProposal(changes ...proposal.ParamChange) *proposal.ParameterChangeProposal {
return proposal.NewParameterChangeProposal(
"Test",
"description",

View File

@ -28,5 +28,5 @@ func init() {
// RegisterCodec registers all necessary param module types with a given codec.
func RegisterCodec(cdc *codec.Codec) {
cdc.RegisterConcrete(ParameterChangeProposal{}, "cosmos-sdk/ParameterChangeProposal", nil)
cdc.RegisterConcrete(&ParameterChangeProposal{}, "cosmos-sdk/ParameterChangeProposal", nil)
}

View File

@ -15,31 +15,31 @@ const (
)
// Assert ParameterChangeProposal implements govtypes.Content at compile-time
var _ govtypes.Content = ParameterChangeProposal{}
var _ govtypes.Content = &ParameterChangeProposal{}
func init() {
govtypes.RegisterProposalType(ProposalTypeChange)
govtypes.RegisterProposalTypeCodec(ParameterChangeProposal{}, "cosmos-sdk/ParameterChangeProposal")
govtypes.RegisterProposalTypeCodec(&ParameterChangeProposal{}, "cosmos-sdk/ParameterChangeProposal")
}
func NewParameterChangeProposal(title, description string, changes []ParamChange) ParameterChangeProposal {
return ParameterChangeProposal{title, description, changes}
func NewParameterChangeProposal(title, description string, changes []ParamChange) *ParameterChangeProposal {
return &ParameterChangeProposal{title, description, changes}
}
// GetTitle returns the title of a parameter change proposal.
func (pcp ParameterChangeProposal) GetTitle() string { return pcp.Title }
func (pcp *ParameterChangeProposal) GetTitle() string { return pcp.Title }
// GetDescription returns the description of a parameter change proposal.
func (pcp ParameterChangeProposal) GetDescription() string { return pcp.Description }
func (pcp *ParameterChangeProposal) GetDescription() string { return pcp.Description }
// ProposalRoute returns the routing key of a parameter change proposal.
func (pcp ParameterChangeProposal) ProposalRoute() string { return RouterKey }
func (pcp *ParameterChangeProposal) ProposalRoute() string { return RouterKey }
// ProposalType returns the type of a parameter change proposal.
func (pcp ParameterChangeProposal) ProposalType() string { return ProposalTypeChange }
func (pcp *ParameterChangeProposal) ProposalType() string { return ProposalTypeChange }
// ValidateBasic validates the parameter change proposal
func (pcp ParameterChangeProposal) ValidateBasic() error {
func (pcp *ParameterChangeProposal) ValidateBasic() error {
err := govtypes.ValidateAbstract(pcp)
if err != nil {
return err

View File

@ -61,28 +61,28 @@ func setupTest(height int64, skip map[int64]bool) TestSuite {
func TestRequireName(t *testing.T) {
s := setupTest(10, map[int64]bool{})
err := s.handler(s.ctx, upgrade.SoftwareUpgradeProposal{Title: "prop", Plan: upgrade.Plan{}})
err := s.handler(s.ctx, &upgrade.SoftwareUpgradeProposal{Title: "prop", Plan: upgrade.Plan{}})
require.NotNil(t, err)
require.True(t, errors.Is(sdkerrors.ErrInvalidRequest, err), err)
}
func TestRequireFutureTime(t *testing.T) {
s := setupTest(10, map[int64]bool{})
err := s.handler(s.ctx, upgrade.SoftwareUpgradeProposal{Title: "prop", Plan: upgrade.Plan{Name: "test", Time: s.ctx.BlockHeader().Time}})
err := s.handler(s.ctx, &upgrade.SoftwareUpgradeProposal{Title: "prop", Plan: upgrade.Plan{Name: "test", Time: s.ctx.BlockHeader().Time}})
require.NotNil(t, err)
require.True(t, errors.Is(sdkerrors.ErrInvalidRequest, err), err)
}
func TestRequireFutureBlock(t *testing.T) {
s := setupTest(10, map[int64]bool{})
err := s.handler(s.ctx, upgrade.SoftwareUpgradeProposal{Title: "prop", Plan: upgrade.Plan{Name: "test", Height: s.ctx.BlockHeight()}})
err := s.handler(s.ctx, &upgrade.SoftwareUpgradeProposal{Title: "prop", Plan: upgrade.Plan{Name: "test", Height: s.ctx.BlockHeight()}})
require.NotNil(t, err)
require.True(t, errors.Is(sdkerrors.ErrInvalidRequest, err), err)
}
func TestCantSetBothTimeAndHeight(t *testing.T) {
s := setupTest(10, map[int64]bool{})
err := s.handler(s.ctx, upgrade.SoftwareUpgradeProposal{Title: "prop", Plan: upgrade.Plan{Name: "test", Time: time.Now(), Height: s.ctx.BlockHeight() + 1}})
err := s.handler(s.ctx, &upgrade.SoftwareUpgradeProposal{Title: "prop", Plan: upgrade.Plan{Name: "test", Time: time.Now(), Height: s.ctx.BlockHeight() + 1}})
require.NotNil(t, err)
require.True(t, errors.Is(sdkerrors.ErrInvalidRequest, err), err)
}
@ -90,7 +90,7 @@ func TestCantSetBothTimeAndHeight(t *testing.T) {
func TestDoTimeUpgrade(t *testing.T) {
s := setupTest(10, map[int64]bool{})
t.Log("Verify can schedule an upgrade")
err := s.handler(s.ctx, upgrade.SoftwareUpgradeProposal{Title: "prop", Plan: upgrade.Plan{Name: "test", Time: time.Now()}})
err := s.handler(s.ctx, &upgrade.SoftwareUpgradeProposal{Title: "prop", Plan: upgrade.Plan{Name: "test", Time: time.Now()}})
require.Nil(t, err)
VerifyDoUpgrade(t)
@ -99,7 +99,7 @@ func TestDoTimeUpgrade(t *testing.T) {
func TestDoHeightUpgrade(t *testing.T) {
s := setupTest(10, map[int64]bool{})
t.Log("Verify can schedule an upgrade")
err := s.handler(s.ctx, upgrade.SoftwareUpgradeProposal{Title: "prop", Plan: upgrade.Plan{Name: "test", Height: s.ctx.BlockHeight() + 1}})
err := s.handler(s.ctx, &upgrade.SoftwareUpgradeProposal{Title: "prop", Plan: upgrade.Plan{Name: "test", Height: s.ctx.BlockHeight() + 1}})
require.Nil(t, err)
VerifyDoUpgrade(t)
@ -108,9 +108,9 @@ func TestDoHeightUpgrade(t *testing.T) {
func TestCanOverwriteScheduleUpgrade(t *testing.T) {
s := setupTest(10, map[int64]bool{})
t.Log("Can overwrite plan")
err := s.handler(s.ctx, upgrade.SoftwareUpgradeProposal{Title: "prop", Plan: upgrade.Plan{Name: "bad_test", Height: s.ctx.BlockHeight() + 10}})
err := s.handler(s.ctx, &upgrade.SoftwareUpgradeProposal{Title: "prop", Plan: upgrade.Plan{Name: "bad_test", Height: s.ctx.BlockHeight() + 10}})
require.Nil(t, err)
err = s.handler(s.ctx, upgrade.SoftwareUpgradeProposal{Title: "prop", Plan: upgrade.Plan{Name: "test", Height: s.ctx.BlockHeight() + 1}})
err = s.handler(s.ctx, &upgrade.SoftwareUpgradeProposal{Title: "prop", Plan: upgrade.Plan{Name: "test", Height: s.ctx.BlockHeight() + 1}})
require.Nil(t, err)
VerifyDoUpgrade(t)
@ -164,7 +164,7 @@ func TestHaltIfTooNew(t *testing.T) {
require.Equal(t, 0, called)
t.Log("Verify we panic if we have a registered handler ahead of time")
err := s.handler(s.ctx, upgrade.SoftwareUpgradeProposal{Title: "prop", Plan: upgrade.Plan{Name: "future", Height: s.ctx.BlockHeight() + 3}})
err := s.handler(s.ctx, &upgrade.SoftwareUpgradeProposal{Title: "prop", Plan: upgrade.Plan{Name: "future", Height: s.ctx.BlockHeight() + 3}})
require.NoError(t, err)
require.Panics(t, func() {
s.module.BeginBlock(newCtx, req)
@ -193,10 +193,10 @@ func VerifyCleared(t *testing.T, newCtx sdk.Context) {
func TestCanClear(t *testing.T) {
s := setupTest(10, map[int64]bool{})
t.Log("Verify upgrade is scheduled")
err := s.handler(s.ctx, upgrade.SoftwareUpgradeProposal{Title: "prop", Plan: upgrade.Plan{Name: "test", Time: time.Now()}})
err := s.handler(s.ctx, &upgrade.SoftwareUpgradeProposal{Title: "prop", Plan: upgrade.Plan{Name: "test", Time: time.Now()}})
require.Nil(t, err)
err = s.handler(s.ctx, upgrade.CancelSoftwareUpgradeProposal{Title: "cancel"})
err = s.handler(s.ctx, &upgrade.CancelSoftwareUpgradeProposal{Title: "cancel"})
require.Nil(t, err)
VerifyCleared(t, s.ctx)
@ -204,11 +204,11 @@ func TestCanClear(t *testing.T) {
func TestCantApplySameUpgradeTwice(t *testing.T) {
s := setupTest(10, map[int64]bool{})
err := s.handler(s.ctx, upgrade.SoftwareUpgradeProposal{Title: "prop", Plan: upgrade.Plan{Name: "test", Time: time.Now()}})
err := s.handler(s.ctx, &upgrade.SoftwareUpgradeProposal{Title: "prop", Plan: upgrade.Plan{Name: "test", Time: time.Now()}})
require.Nil(t, err)
VerifyDoUpgrade(t)
t.Log("Verify an executed upgrade \"test\" can't be rescheduled")
err = s.handler(s.ctx, upgrade.SoftwareUpgradeProposal{Title: "prop", Plan: upgrade.Plan{Name: "test", Time: time.Now()}})
err = s.handler(s.ctx, &upgrade.SoftwareUpgradeProposal{Title: "prop", Plan: upgrade.Plan{Name: "test", Time: time.Now()}})
require.NotNil(t, err)
require.True(t, errors.Is(sdkerrors.ErrInvalidRequest, err), err)
}
@ -279,7 +279,7 @@ func TestSkipUpgradeSkippingAll(t *testing.T) {
newCtx := s.ctx
req := abci.RequestBeginBlock{Header: newCtx.BlockHeader()}
err := s.handler(s.ctx, upgrade.SoftwareUpgradeProposal{Title: "prop", Plan: upgrade.Plan{Name: "test", Height: skipOne}})
err := s.handler(s.ctx, &upgrade.SoftwareUpgradeProposal{Title: "prop", Plan: upgrade.Plan{Name: "test", Height: skipOne}})
require.NoError(t, err)
t.Log("Verify if skip upgrade flag clears upgrade plan in both cases")
@ -291,7 +291,7 @@ func TestSkipUpgradeSkippingAll(t *testing.T) {
})
t.Log("Verify a second proposal also is being cleared")
err = s.handler(s.ctx, upgrade.SoftwareUpgradeProposal{Title: "prop2", Plan: upgrade.Plan{Name: "test2", Height: skipTwo}})
err = s.handler(s.ctx, &upgrade.SoftwareUpgradeProposal{Title: "prop2", Plan: upgrade.Plan{Name: "test2", Height: skipTwo}})
require.NoError(t, err)
newCtx = newCtx.WithBlockHeight(skipTwo)
@ -316,7 +316,7 @@ func TestUpgradeSkippingOne(t *testing.T) {
newCtx := s.ctx
req := abci.RequestBeginBlock{Header: newCtx.BlockHeader()}
err := s.handler(s.ctx, upgrade.SoftwareUpgradeProposal{Title: "prop", Plan: upgrade.Plan{Name: "test", Height: skipOne}})
err := s.handler(s.ctx, &upgrade.SoftwareUpgradeProposal{Title: "prop", Plan: upgrade.Plan{Name: "test", Height: skipOne}})
require.Nil(t, err)
t.Log("Verify if skip upgrade flag clears upgrade plan in one case and does upgrade on another")
@ -329,7 +329,7 @@ func TestUpgradeSkippingOne(t *testing.T) {
})
t.Log("Verify the second proposal is not skipped")
err = s.handler(s.ctx, upgrade.SoftwareUpgradeProposal{Title: "prop2", Plan: upgrade.Plan{Name: "test2", Height: skipTwo}})
err = s.handler(s.ctx, &upgrade.SoftwareUpgradeProposal{Title: "prop2", Plan: upgrade.Plan{Name: "test2", Height: skipTwo}})
require.Nil(t, err)
// Setting block height of proposal test2
newCtx = newCtx.WithBlockHeight(skipTwo)
@ -351,7 +351,7 @@ func TestUpgradeSkippingOnlyTwo(t *testing.T) {
newCtx := s.ctx
req := abci.RequestBeginBlock{Header: newCtx.BlockHeader()}
err := s.handler(s.ctx, upgrade.SoftwareUpgradeProposal{Title: "prop", Plan: upgrade.Plan{Name: "test", Height: skipOne}})
err := s.handler(s.ctx, &upgrade.SoftwareUpgradeProposal{Title: "prop", Plan: upgrade.Plan{Name: "test", Height: skipOne}})
require.Nil(t, err)
t.Log("Verify if skip upgrade flag clears upgrade plan in both cases and does third upgrade")
@ -364,7 +364,7 @@ func TestUpgradeSkippingOnlyTwo(t *testing.T) {
})
// A new proposal with height in skipUpgradeHeights
err = s.handler(s.ctx, upgrade.SoftwareUpgradeProposal{Title: "prop2", Plan: upgrade.Plan{Name: "test2", Height: skipTwo}})
err = s.handler(s.ctx, &upgrade.SoftwareUpgradeProposal{Title: "prop2", Plan: upgrade.Plan{Name: "test2", Height: skipTwo}})
require.Nil(t, err)
// Setting block height of proposal test2
newCtx = newCtx.WithBlockHeight(skipTwo)
@ -373,7 +373,7 @@ func TestUpgradeSkippingOnlyTwo(t *testing.T) {
})
t.Log("Verify a new proposal is not skipped")
err = s.handler(s.ctx, upgrade.SoftwareUpgradeProposal{Title: "prop3", Plan: upgrade.Plan{Name: "test3", Height: skipThree}})
err = s.handler(s.ctx, &upgrade.SoftwareUpgradeProposal{Title: "prop3", Plan: upgrade.Plan{Name: "test3", Height: skipThree}})
require.Nil(t, err)
newCtx = newCtx.WithBlockHeight(skipThree)
VerifyDoUpgradeWithCtx(t, newCtx, "test3")
@ -388,7 +388,7 @@ func TestUpgradeWithoutSkip(t *testing.T) {
s := setupTest(10, map[int64]bool{})
newCtx := s.ctx.WithBlockHeight(s.ctx.BlockHeight() + 1).WithBlockTime(time.Now())
req := abci.RequestBeginBlock{Header: newCtx.BlockHeader()}
err := s.handler(s.ctx, upgrade.SoftwareUpgradeProposal{Title: "prop", Plan: upgrade.Plan{Name: "test", Height: s.ctx.BlockHeight() + 1}})
err := s.handler(s.ctx, &upgrade.SoftwareUpgradeProposal{Title: "prop", Plan: upgrade.Plan{Name: "test", Height: s.ctx.BlockHeight() + 1}})
require.Nil(t, err)
t.Log("Verify if upgrade happens without skip upgrade")
require.Panics(t, func() {

View File

@ -12,10 +12,10 @@ import (
func NewSoftwareUpgradeProposalHandler(k Keeper) govtypes.Handler {
return func(ctx sdk.Context, content govtypes.Content) error {
switch c := content.(type) {
case SoftwareUpgradeProposal:
case *SoftwareUpgradeProposal:
return handleSoftwareUpgradeProposal(ctx, k, c)
case CancelSoftwareUpgradeProposal:
case *CancelSoftwareUpgradeProposal:
return handleCancelSoftwareUpgradeProposal(ctx, k, c)
default:
@ -24,11 +24,11 @@ func NewSoftwareUpgradeProposalHandler(k Keeper) govtypes.Handler {
}
}
func handleSoftwareUpgradeProposal(ctx sdk.Context, k Keeper, p SoftwareUpgradeProposal) error {
func handleSoftwareUpgradeProposal(ctx sdk.Context, k Keeper, p *SoftwareUpgradeProposal) error {
return k.ScheduleUpgrade(ctx, p.Plan)
}
func handleCancelSoftwareUpgradeProposal(ctx sdk.Context, k Keeper, p CancelSoftwareUpgradeProposal) error {
func handleCancelSoftwareUpgradeProposal(ctx sdk.Context, k Keeper, _ *CancelSoftwareUpgradeProposal) error {
k.ClearUpgradePlan(ctx)
return nil
}

View File

@ -7,6 +7,6 @@ import (
// RegisterCodec registers concrete types on the Amino codec
func RegisterCodec(cdc *codec.Codec) {
cdc.RegisterConcrete(Plan{}, "cosmos-sdk/Plan", nil)
cdc.RegisterConcrete(SoftwareUpgradeProposal{}, "cosmos-sdk/SoftwareUpgradeProposal", nil)
cdc.RegisterConcrete(CancelSoftwareUpgradeProposal{}, "cosmos-sdk/CancelSoftwareUpgradeProposal", nil)
cdc.RegisterConcrete(&SoftwareUpgradeProposal{}, "cosmos-sdk/SoftwareUpgradeProposal", nil)
cdc.RegisterConcrete(&CancelSoftwareUpgradeProposal{}, "cosmos-sdk/CancelSoftwareUpgradeProposal", nil)
}

View File

@ -3,7 +3,7 @@ package types
import (
"fmt"
"github.com/cosmos/cosmos-sdk/x/gov"
gov "github.com/cosmos/cosmos-sdk/x/gov/types"
)
const (
@ -12,25 +12,25 @@ const (
)
func NewSoftwareUpgradeProposal(title, description string, plan Plan) gov.Content {
return SoftwareUpgradeProposal{title, description, plan}
return &SoftwareUpgradeProposal{title, description, plan}
}
// Implements Proposal Interface
var _ gov.Content = SoftwareUpgradeProposal{}
var _ gov.Content = &SoftwareUpgradeProposal{}
func init() {
gov.RegisterProposalType(ProposalTypeSoftwareUpgrade)
gov.RegisterProposalTypeCodec(SoftwareUpgradeProposal{}, "cosmos-sdk/SoftwareUpgradeProposal")
gov.RegisterProposalTypeCodec(&SoftwareUpgradeProposal{}, "cosmos-sdk/SoftwareUpgradeProposal")
gov.RegisterProposalType(ProposalTypeCancelSoftwareUpgrade)
gov.RegisterProposalTypeCodec(CancelSoftwareUpgradeProposal{}, "cosmos-sdk/CancelSoftwareUpgradeProposal")
gov.RegisterProposalTypeCodec(&CancelSoftwareUpgradeProposal{}, "cosmos-sdk/CancelSoftwareUpgradeProposal")
}
// nolint
func (sup SoftwareUpgradeProposal) GetTitle() string { return sup.Title }
func (sup SoftwareUpgradeProposal) GetDescription() string { return sup.Description }
func (sup SoftwareUpgradeProposal) ProposalRoute() string { return RouterKey }
func (sup SoftwareUpgradeProposal) ProposalType() string { return ProposalTypeSoftwareUpgrade }
func (sup SoftwareUpgradeProposal) ValidateBasic() error {
func (sup *SoftwareUpgradeProposal) GetTitle() string { return sup.Title }
func (sup *SoftwareUpgradeProposal) GetDescription() string { return sup.Description }
func (sup *SoftwareUpgradeProposal) ProposalRoute() string { return RouterKey }
func (sup *SoftwareUpgradeProposal) ProposalType() string { return ProposalTypeSoftwareUpgrade }
func (sup *SoftwareUpgradeProposal) ValidateBasic() error {
if err := sup.Plan.ValidateBasic(); err != nil {
return err
}
@ -45,20 +45,20 @@ func (sup SoftwareUpgradeProposal) String() string {
}
func NewCancelSoftwareUpgradeProposal(title, description string) gov.Content {
return CancelSoftwareUpgradeProposal{title, description}
return &CancelSoftwareUpgradeProposal{title, description}
}
// Implements Proposal Interface
var _ gov.Content = CancelSoftwareUpgradeProposal{}
var _ gov.Content = &CancelSoftwareUpgradeProposal{}
// nolint
func (sup CancelSoftwareUpgradeProposal) GetTitle() string { return sup.Title }
func (sup CancelSoftwareUpgradeProposal) GetDescription() string { return sup.Description }
func (sup CancelSoftwareUpgradeProposal) ProposalRoute() string { return RouterKey }
func (sup CancelSoftwareUpgradeProposal) ProposalType() string {
func (sup *CancelSoftwareUpgradeProposal) GetTitle() string { return sup.Title }
func (sup *CancelSoftwareUpgradeProposal) GetDescription() string { return sup.Description }
func (sup *CancelSoftwareUpgradeProposal) ProposalRoute() string { return RouterKey }
func (sup *CancelSoftwareUpgradeProposal) ProposalType() string {
return ProposalTypeCancelSoftwareUpgrade
}
func (sup CancelSoftwareUpgradeProposal) ValidateBasic() error {
func (sup *CancelSoftwareUpgradeProposal) ValidateBasic() error {
return gov.ValidateAbstract(sup)
}

View File

@ -7,7 +7,7 @@ import (
"github.com/stretchr/testify/require"
"github.com/cosmos/cosmos-sdk/codec"
"github.com/cosmos/cosmos-sdk/x/gov"
gov "github.com/cosmos/cosmos-sdk/x/gov/types"
)
type ProposalWrapper struct {