diff --git a/docs/proto/proto-docs.md b/docs/proto/proto-docs.md index 2912e7ab..98496c37 100644 --- a/docs/proto/proto-docs.md +++ b/docs/proto/proto-docs.md @@ -1392,6 +1392,8 @@ Params | Field | Type | Label | Description | | ----- | ---- | ----- | ----------- | +| `title` | [string](#string) | | the title of the update proposal | +| `description` | [string](#string) | | the description of the proposal | | `authority` | [string](#string) | | | | `params` | [Params](#alliance.alliance.Params) | | | diff --git a/proto/alliance/alliance/gov.proto b/proto/alliance/alliance/gov.proto index 9317582c..f7af2bf8 100644 --- a/proto/alliance/alliance/gov.proto +++ b/proto/alliance/alliance/gov.proto @@ -3,93 +3,87 @@ package alliance.alliance; import "alliance/alliance/alliance.proto"; import "gogoproto/gogo.proto"; +import "google/protobuf/timestamp.proto"; import "google/protobuf/duration.proto"; option go_package = "github.com/terra-money/alliance/x/alliance/types"; message MsgCreateAllianceProposal { - option (gogoproto.equal) = false; - option (gogoproto.goproto_getters) = false; - - // the title of the update proposal - string title = 1; - // the description of the proposal - string description = 2; - // Denom of the asset. It could either be a native token or an IBC token - string denom = 3 [(gogoproto.moretags) = "yaml:\"denom\""]; - // The reward weight specifies the ratio of rewards that will be given to each alliance asset - // It does not need to sum to 1. rate = weight / total_weight - // Native asset is always assumed to have a weight of 1. - string reward_weight = 4 [ - (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Dec", - (gogoproto.nullable) = false - ]; - // A positive take rate is used for liquid staking derivatives. It defines an annualized reward rate that - // will be redirected to the distribution rewards pool - string take_rate = 5 [ - (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Dec", - (gogoproto.nullable) = false - ]; + option (gogoproto.equal) = false; - string reward_change_rate = 6 [ - (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Dec", - (gogoproto.nullable) = false - ]; + // the title of the update proposal + string title = 1; + // the description of the proposal + string description = 2; + // Denom of the asset. It could either be a native token or an IBC token + string denom = 3 [(gogoproto.moretags) = "yaml:\"denom\""]; + // The reward weight specifies the ratio of rewards that will be given to each alliance asset + // It does not need to sum to 1. rate = weight / total_weight + // Native asset is always assumed to have a weight of 1. + string reward_weight = 4 [ + (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Dec", + (gogoproto.nullable) = false + ]; + // A positive take rate is used for liquid staking derivatives. It defines an annualized reward rate that + // will be redirected to the distribution rewards pool + string take_rate = 5 [ + (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Dec", + (gogoproto.nullable) = false + ]; - google.protobuf.Duration reward_change_interval = 7 [ - (gogoproto.nullable) = false, - (gogoproto.stdduration) = true - ]; + string reward_change_rate = 6 [ + (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Dec", + (gogoproto.nullable) = false + ]; - // set a bound of weight range to limit how much reward weights can scale. - RewardWeightRange reward_weight_range = 8 [ - (gogoproto.nullable) = false - ]; + google.protobuf.Duration reward_change_interval = 7 [ + (gogoproto.nullable) = false, + (gogoproto.stdduration) = true + ]; + + // set a bound of weight range to limit how much reward weights can scale. + RewardWeightRange reward_weight_range = 8 [(gogoproto.nullable) = false]; } - -message MsgUpdateAllianceProposal { - option (gogoproto.equal) = false; - option (gogoproto.goproto_getters) = false; - // the title of the update proposal - string title = 1; - // the description of the proposal - string description = 2; - // Denom of the asset. It could either be a native token or an IBC token - string denom = 3 [(gogoproto.moretags) = "yaml:\"denom\""]; - // The reward weight specifies the ratio of rewards that will be given to each alliance asset - // It does not need to sum to 1. rate = weight / total_weight - // Native asset is always assumed to have a weight of 1. - string reward_weight = 4 [ - (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Dec", - (gogoproto.nullable) = false - ]; +message MsgUpdateAllianceProposal { + option (gogoproto.equal) = false; - string take_rate = 5 [ - (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Dec", - (gogoproto.nullable) = false - ]; + // the title of the update proposal + string title = 1; + // the description of the proposal + string description = 2; + // Denom of the asset. It could either be a native token or an IBC token + string denom = 3 [(gogoproto.moretags) = "yaml:\"denom\""]; + // The reward weight specifies the ratio of rewards that will be given to each alliance asset + // It does not need to sum to 1. rate = weight / total_weight + // Native asset is always assumed to have a weight of 1. + string reward_weight = 4 [ + (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Dec", + (gogoproto.nullable) = false + ]; - string reward_change_rate = 6 [ - (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Dec", - (gogoproto.nullable) = false - ]; + string take_rate = 5 [ + (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Dec", + (gogoproto.nullable) = false + ]; - google.protobuf.Duration reward_change_interval = 7 [ - (gogoproto.nullable) = false, - (gogoproto.stdduration) = true - ]; + string reward_change_rate = 6 [ + (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Dec", + (gogoproto.nullable) = false + ]; + google.protobuf.Duration reward_change_interval = 7 [ + (gogoproto.nullable) = false, + (gogoproto.stdduration) = true + ]; } message MsgDeleteAllianceProposal { - option (gogoproto.equal) = false; - option (gogoproto.goproto_getters) = false; - - // the title of the update proposal - string title = 1; - // the description of the proposal - string description = 2; - string denom = 3 [(gogoproto.moretags) = "yaml:\"denom\""]; -} - \ No newline at end of file + option (gogoproto.equal) = false; + + // the title of the update proposal + string title = 1; + // the description of the proposal + string description = 2; + string denom = 3 [(gogoproto.moretags) = "yaml:\"denom\""]; +} \ No newline at end of file diff --git a/proto/alliance/alliance/tx.proto b/proto/alliance/alliance/tx.proto index 01d18761..869cea55 100644 --- a/proto/alliance/alliance/tx.proto +++ b/proto/alliance/alliance/tx.proto @@ -84,9 +84,13 @@ message MsgClaimDelegationRewardsResponse {} message MsgUpdateParams { option (cosmos.msg.v1.signer) = "authority"; + // the title of the update proposal + string title = 1; + // the description of the proposal + string description = 2; - string authority = 1 [(cosmos_proto.scalar) = "cosmos.AddressString"]; - Params params = 2 [(gogoproto.nullable) = false]; + string authority = 3 [(cosmos_proto.scalar) = "cosmos.AddressString"]; + Params params = 4 [(gogoproto.nullable) = false]; } message MsgUpdateParamsResponse {} diff --git a/x/alliance/types/gov.go b/x/alliance/types/gov.go index 1f87dc94..52ad1de2 100644 --- a/x/alliance/types/gov.go +++ b/x/alliance/types/gov.go @@ -3,6 +3,7 @@ package types import ( "time" + sdkerrors "cosmossdk.io/errors" sdk "github.com/cosmos/cosmos-sdk/types" govtypes "github.com/cosmos/cosmos-sdk/x/gov/types/v1beta1" "google.golang.org/grpc/codes" @@ -10,23 +11,63 @@ import ( ) const ( - ProposalTypeCreateAlliance = "msg_create_alliance_proposal" - ProposalTypeUpdateAlliance = "msg_update_alliance_proposal" - ProposalTypeDeleteAlliance = "msg_delete_alliance_proposal" + ProposalTypeUpdateAllianceParams = "msg_update_alliance_params" + ProposalTypeCreateAlliance = "msg_create_alliance_proposal" + ProposalTypeUpdateAlliance = "msg_update_alliance_proposal" + ProposalTypeDeleteAlliance = "msg_delete_alliance_proposal" ) var ( + _ govtypes.Content = &MsgUpdateParams{} _ govtypes.Content = &MsgCreateAllianceProposal{} _ govtypes.Content = &MsgUpdateAllianceProposal{} _ govtypes.Content = &MsgDeleteAllianceProposal{} ) func init() { + govtypes.RegisterProposalType(ProposalTypeUpdateAllianceParams) govtypes.RegisterProposalType(ProposalTypeCreateAlliance) govtypes.RegisterProposalType(ProposalTypeUpdateAlliance) govtypes.RegisterProposalType(ProposalTypeDeleteAlliance) } +func NewMsgUpdateParams(title, description string, + rewardDelayTime, takeRateClaimInterval time.Duration, + lastTakeRateClaimTime time.Time) govtypes.Content { + return &MsgUpdateParams{ + Title: title, + Description: description, + Params: Params{ + RewardDelayTime: rewardDelayTime, + TakeRateClaimInterval: takeRateClaimInterval, + LastTakeRateClaimTime: lastTakeRateClaimTime, + }, + } +} +func (msg *MsgUpdateParams) ValidateBasic() error { + if _, err := sdk.AccAddressFromBech32(msg.Authority); err != nil { + return sdkerrors.Wrap(err, "invalid authority address") + } + if err := ValidatePositiveDuration(msg.Params.RewardDelayTime); err != nil { + return err + } + return ValidatePositiveDuration(msg.Params.TakeRateClaimInterval) +} + +func (msg MsgUpdateParams) GetSignBytes() []byte { + return sdk.MustSortJSON(ModuleCdc.MustMarshalJSON(&msg)) +} + +func (msg *MsgUpdateParams) GetSigners() []sdk.AccAddress { + signer, err := sdk.AccAddressFromBech32(msg.Authority) + if err != nil { + panic("Authority is not valid") + } + return []sdk.AccAddress{signer} +} +func (m *MsgUpdateParams) ProposalRoute() string { return RouterKey } +func (m *MsgUpdateParams) ProposalType() string { return ProposalTypeCreateAlliance } + func NewMsgCreateAllianceProposal(title, description, denom string, rewardWeight sdk.Dec, rewardWeightRange RewardWeightRange, takeRate sdk.Dec, rewardChangeRate sdk.Dec, rewardChangeInterval time.Duration) govtypes.Content { return &MsgCreateAllianceProposal{ Title: title, @@ -39,11 +80,8 @@ func NewMsgCreateAllianceProposal(title, description, denom string, rewardWeight RewardChangeInterval: rewardChangeInterval, } } -func (m *MsgCreateAllianceProposal) GetTitle() string { return m.Title } -func (m *MsgCreateAllianceProposal) GetDescription() string { return m.Description } -func (m *MsgCreateAllianceProposal) ProposalRoute() string { return RouterKey } -func (m *MsgCreateAllianceProposal) ProposalType() string { return ProposalTypeCreateAlliance } - +func (m *MsgCreateAllianceProposal) ProposalRoute() string { return RouterKey } +func (m *MsgCreateAllianceProposal) ProposalType() string { return ProposalTypeCreateAlliance } func (m *MsgCreateAllianceProposal) ValidateBasic() error { if m.Denom == "" { return status.Errorf(codes.InvalidArgument, "Alliance denom must have a value") @@ -96,11 +134,8 @@ func NewMsgUpdateAllianceProposal(title, description, denom string, rewardWeight RewardChangeInterval: rewardChangeInterval, } } -func (m *MsgUpdateAllianceProposal) GetTitle() string { return m.Title } -func (m *MsgUpdateAllianceProposal) GetDescription() string { return m.Description } -func (m *MsgUpdateAllianceProposal) ProposalRoute() string { return RouterKey } -func (m *MsgUpdateAllianceProposal) ProposalType() string { return ProposalTypeUpdateAlliance } - +func (m *MsgUpdateAllianceProposal) ProposalRoute() string { return RouterKey } +func (m *MsgUpdateAllianceProposal) ProposalType() string { return ProposalTypeUpdateAlliance } func (m *MsgUpdateAllianceProposal) ValidateBasic() error { if m.Denom == "" { return status.Errorf(codes.InvalidArgument, "Alliance denom must have a value") @@ -132,11 +167,8 @@ func NewMsgDeleteAllianceProposal(title, description, denom string) govtypes.Con Denom: denom, } } -func (m *MsgDeleteAllianceProposal) GetTitle() string { return m.Title } -func (m *MsgDeleteAllianceProposal) GetDescription() string { return m.Description } -func (m *MsgDeleteAllianceProposal) ProposalRoute() string { return RouterKey } -func (m *MsgDeleteAllianceProposal) ProposalType() string { return ProposalTypeDeleteAlliance } - +func (m *MsgDeleteAllianceProposal) ProposalRoute() string { return RouterKey } +func (m *MsgDeleteAllianceProposal) ProposalType() string { return ProposalTypeDeleteAlliance } func (m *MsgDeleteAllianceProposal) ValidateBasic() error { if m.Denom == "" { return status.Errorf(codes.InvalidArgument, "Alliance denom must have a value") diff --git a/x/alliance/types/gov.pb.go b/x/alliance/types/gov.pb.go index 21b3892b..b90b9f27 100644 --- a/x/alliance/types/gov.pb.go +++ b/x/alliance/types/gov.pb.go @@ -10,6 +10,7 @@ import ( proto "github.com/cosmos/gogoproto/proto" github_com_cosmos_gogoproto_types "github.com/cosmos/gogoproto/types" _ "google.golang.org/protobuf/types/known/durationpb" + _ "google.golang.org/protobuf/types/known/timestamppb" io "io" math "math" math_bits "math/bits" @@ -81,6 +82,41 @@ func (m *MsgCreateAllianceProposal) XXX_DiscardUnknown() { var xxx_messageInfo_MsgCreateAllianceProposal proto.InternalMessageInfo +func (m *MsgCreateAllianceProposal) GetTitle() string { + if m != nil { + return m.Title + } + return "" +} + +func (m *MsgCreateAllianceProposal) GetDescription() string { + if m != nil { + return m.Description + } + return "" +} + +func (m *MsgCreateAllianceProposal) GetDenom() string { + if m != nil { + return m.Denom + } + return "" +} + +func (m *MsgCreateAllianceProposal) GetRewardChangeInterval() time.Duration { + if m != nil { + return m.RewardChangeInterval + } + return 0 +} + +func (m *MsgCreateAllianceProposal) GetRewardWeightRange() RewardWeightRange { + if m != nil { + return m.RewardWeightRange + } + return RewardWeightRange{} +} + type MsgUpdateAllianceProposal struct { // the title of the update proposal Title string `protobuf:"bytes,1,opt,name=title,proto3" json:"title,omitempty"` @@ -130,6 +166,34 @@ func (m *MsgUpdateAllianceProposal) XXX_DiscardUnknown() { var xxx_messageInfo_MsgUpdateAllianceProposal proto.InternalMessageInfo +func (m *MsgUpdateAllianceProposal) GetTitle() string { + if m != nil { + return m.Title + } + return "" +} + +func (m *MsgUpdateAllianceProposal) GetDescription() string { + if m != nil { + return m.Description + } + return "" +} + +func (m *MsgUpdateAllianceProposal) GetDenom() string { + if m != nil { + return m.Denom + } + return "" +} + +func (m *MsgUpdateAllianceProposal) GetRewardChangeInterval() time.Duration { + if m != nil { + return m.RewardChangeInterval + } + return 0 +} + type MsgDeleteAllianceProposal struct { // the title of the update proposal Title string `protobuf:"bytes,1,opt,name=title,proto3" json:"title,omitempty"` @@ -171,6 +235,27 @@ func (m *MsgDeleteAllianceProposal) XXX_DiscardUnknown() { var xxx_messageInfo_MsgDeleteAllianceProposal proto.InternalMessageInfo +func (m *MsgDeleteAllianceProposal) GetTitle() string { + if m != nil { + return m.Title + } + return "" +} + +func (m *MsgDeleteAllianceProposal) GetDescription() string { + if m != nil { + return m.Description + } + return "" +} + +func (m *MsgDeleteAllianceProposal) GetDenom() string { + if m != nil { + return m.Denom + } + return "" +} + func init() { proto.RegisterType((*MsgCreateAllianceProposal)(nil), "alliance.alliance.MsgCreateAllianceProposal") proto.RegisterType((*MsgUpdateAllianceProposal)(nil), "alliance.alliance.MsgUpdateAllianceProposal") @@ -180,38 +265,38 @@ func init() { func init() { proto.RegisterFile("alliance/alliance/gov.proto", fileDescriptor_c66988d3be8665d9) } var fileDescriptor_c66988d3be8665d9 = []byte{ - // 483 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xec, 0x94, 0x31, 0x6f, 0xd3, 0x40, - 0x14, 0xc7, 0x6d, 0x9a, 0x94, 0xf4, 0x5a, 0xa4, 0xf6, 0x88, 0x90, 0x5b, 0x24, 0x3b, 0x8a, 0x50, - 0xd5, 0xa5, 0x67, 0x04, 0x5b, 0x37, 0xdc, 0x2c, 0x80, 0x90, 0x90, 0x11, 0x42, 0x54, 0x48, 0xd1, - 0xc5, 0x7e, 0x5c, 0xac, 0x9e, 0x7d, 0xd6, 0xf9, 0xd2, 0x92, 0x0f, 0x80, 0xc4, 0xc8, 0xc8, 0xd8, - 0x0f, 0xc2, 0x07, 0xe8, 0xd8, 0x11, 0x31, 0x84, 0x2a, 0x59, 0x98, 0xf9, 0x04, 0xe8, 0xce, 0x4e, - 0xe3, 0xd2, 0x2d, 0x03, 0x03, 0x62, 0xca, 0xbb, 0xf7, 0x7f, 0xf9, 0xdd, 0xe9, 0xff, 0x7f, 0x32, - 0xba, 0x4f, 0x39, 0x4f, 0x68, 0x16, 0x81, 0x7f, 0x55, 0x30, 0x71, 0x42, 0x72, 0x29, 0x94, 0xc0, - 0x5b, 0xf3, 0x1e, 0x99, 0x17, 0x3b, 0x9d, 0x9b, 0xf3, 0x57, 0x43, 0xe6, 0x4f, 0x3b, 0x6d, 0x26, - 0x98, 0x30, 0xa5, 0xaf, 0xab, 0xaa, 0xeb, 0x32, 0x21, 0x18, 0x07, 0xdf, 0x9c, 0x06, 0xa3, 0xf7, - 0x7e, 0x3c, 0x92, 0x54, 0x25, 0x22, 0x2b, 0xf5, 0xee, 0xd7, 0x06, 0xda, 0x7e, 0x51, 0xb0, 0x43, - 0x09, 0x54, 0xc1, 0x93, 0x8a, 0xf8, 0x52, 0x8a, 0x5c, 0x14, 0x94, 0xe3, 0x36, 0x6a, 0xaa, 0x44, - 0x71, 0x70, 0xec, 0x8e, 0xbd, 0xb7, 0x16, 0x96, 0x07, 0xdc, 0x41, 0xeb, 0x31, 0x14, 0x91, 0x4c, - 0x72, 0x0d, 0x72, 0x6e, 0x19, 0xad, 0xde, 0xc2, 0xbb, 0xa8, 0x19, 0x43, 0x26, 0x52, 0x67, 0x45, - 0x6b, 0xc1, 0xe6, 0xaf, 0x89, 0xb7, 0x31, 0xa6, 0x29, 0x3f, 0xe8, 0x9a, 0x76, 0x37, 0x2c, 0x65, - 0xfc, 0x0a, 0xdd, 0x91, 0x70, 0x4a, 0x65, 0xdc, 0x3f, 0x85, 0x84, 0x0d, 0x95, 0xd3, 0x30, 0xf3, - 0xe4, 0x7c, 0xe2, 0x59, 0xdf, 0x27, 0xde, 0x2e, 0x4b, 0xd4, 0x70, 0x34, 0x20, 0x91, 0x48, 0xfd, - 0x48, 0x14, 0xa9, 0x28, 0xaa, 0x9f, 0xfd, 0x22, 0x3e, 0xf6, 0xd5, 0x38, 0x87, 0x82, 0xf4, 0x20, - 0x0a, 0x37, 0x4a, 0xc8, 0x1b, 0xc3, 0xc0, 0xcf, 0xd1, 0x9a, 0xa2, 0xc7, 0xd0, 0x97, 0x54, 0x81, - 0xd3, 0x5c, 0x0a, 0xd8, 0xd2, 0x80, 0x90, 0x2a, 0xc0, 0xef, 0x10, 0xae, 0x5e, 0x18, 0x0d, 0x69, - 0xc6, 0x2a, 0xea, 0xea, 0x52, 0xd4, 0xcd, 0x92, 0x74, 0x68, 0x40, 0x86, 0xfe, 0x16, 0xdd, 0xbb, - 0x4e, 0x4f, 0x32, 0x05, 0xf2, 0x84, 0x72, 0xe7, 0x76, 0xc7, 0xde, 0x5b, 0x7f, 0xb4, 0x4d, 0xca, - 0xf8, 0xc8, 0x3c, 0x3e, 0xd2, 0xab, 0xe2, 0x0b, 0x5a, 0xfa, 0xf2, 0x2f, 0x3f, 0x3c, 0x3b, 0x6c, - 0xd7, 0xb1, 0x4f, 0x2b, 0x00, 0x3e, 0x42, 0x77, 0xaf, 0x59, 0xdb, 0x97, 0x5a, 0x76, 0x5a, 0x86, - 0xfb, 0x80, 0xdc, 0xd8, 0x30, 0x12, 0xd6, 0x3c, 0x0c, 0xf5, 0x6c, 0xd0, 0xd0, 0x57, 0x84, 0x5b, - 0xf2, 0x4f, 0xe1, 0xa0, 0xf5, 0xe9, 0xcc, 0xb3, 0x7e, 0x9e, 0x79, 0x56, 0xf7, 0x72, 0xc5, 0xac, - 0xcf, 0xeb, 0x3c, 0xfe, 0xbf, 0x3e, 0xff, 0xd2, 0xfa, 0xd4, 0x22, 0xfe, 0x68, 0x9b, 0x88, 0x7b, - 0xc0, 0xe1, 0xef, 0x47, 0xbc, 0x78, 0x47, 0xf0, 0xec, 0x7c, 0xea, 0xda, 0x17, 0x53, 0xd7, 0xbe, - 0x9c, 0xba, 0xf6, 0xe7, 0x99, 0x6b, 0x5d, 0xcc, 0x5c, 0xeb, 0xdb, 0xcc, 0xb5, 0x8e, 0x1e, 0xd6, - 0x0c, 0x54, 0x20, 0x25, 0xdd, 0x4f, 0x45, 0x06, 0xe3, 0xc5, 0x97, 0xf2, 0xc3, 0xa2, 0x34, 0x76, - 0x0e, 0x56, 0x8d, 0x21, 0x8f, 0x7f, 0x07, 0x00, 0x00, 0xff, 0xff, 0x42, 0x52, 0xc4, 0x1c, 0x86, - 0x05, 0x00, 0x00, + // 490 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xec, 0x94, 0x41, 0x6b, 0x13, 0x41, + 0x14, 0xc7, 0x77, 0x6d, 0x52, 0xd3, 0x69, 0x85, 0x76, 0x0c, 0xb2, 0xad, 0xb0, 0x1b, 0x82, 0x94, + 0x5e, 0x3a, 0x2b, 0x7a, 0xeb, 0xcd, 0x34, 0x17, 0x15, 0x41, 0x56, 0x44, 0x2c, 0x42, 0x98, 0xec, + 0x3e, 0x27, 0x4b, 0x77, 0x77, 0x96, 0x99, 0x49, 0x6b, 0x8e, 0x7e, 0x03, 0x8f, 0x1e, 0xfd, 0x18, + 0x7e, 0x84, 0x1e, 0x7b, 0x14, 0x91, 0x28, 0xc9, 0xc5, 0xb3, 0x9f, 0x40, 0x66, 0x76, 0xd2, 0x6e, + 0xdb, 0x5b, 0x0f, 0x1e, 0xa4, 0xa7, 0xbc, 0x79, 0xff, 0x7f, 0x7e, 0x33, 0xbc, 0xff, 0x63, 0xd1, + 0x7d, 0x9a, 0x65, 0x29, 0x2d, 0x62, 0x08, 0xcf, 0x0a, 0xc6, 0x8f, 0x48, 0x29, 0xb8, 0xe2, 0x78, + 0x63, 0xd1, 0x23, 0x8b, 0x62, 0xab, 0x73, 0xd5, 0x7f, 0x66, 0x32, 0x7f, 0xda, 0x6a, 0x33, 0xce, + 0xb8, 0x29, 0x43, 0x5d, 0xd9, 0x6e, 0xc0, 0x38, 0x67, 0x19, 0x84, 0xe6, 0x34, 0x1c, 0xbf, 0x0f, + 0x55, 0x9a, 0x83, 0x54, 0x34, 0x2f, 0xad, 0xc1, 0xbf, 0x6c, 0x48, 0xc6, 0x82, 0xaa, 0x94, 0x17, + 0x95, 0xde, 0xfd, 0xda, 0x40, 0x9b, 0x2f, 0x24, 0xdb, 0x17, 0x40, 0x15, 0x3c, 0xb1, 0x57, 0xbe, + 0x14, 0xbc, 0xe4, 0x92, 0x66, 0xb8, 0x8d, 0x9a, 0x2a, 0x55, 0x19, 0x78, 0x6e, 0xc7, 0xdd, 0x59, + 0x89, 0xaa, 0x03, 0xee, 0xa0, 0xd5, 0x04, 0x64, 0x2c, 0xd2, 0x52, 0x83, 0xbc, 0x5b, 0x46, 0xab, + 0xb7, 0xf0, 0x36, 0x6a, 0x26, 0x50, 0xf0, 0xdc, 0x5b, 0xd2, 0x5a, 0x6f, 0xfd, 0xcf, 0x34, 0x58, + 0x9b, 0xd0, 0x3c, 0xdb, 0xeb, 0x9a, 0x76, 0x37, 0xaa, 0x64, 0xfc, 0x0a, 0xdd, 0x11, 0x70, 0x4c, + 0x45, 0x32, 0x38, 0x86, 0x94, 0x8d, 0x94, 0xd7, 0x30, 0x7e, 0x72, 0x32, 0x0d, 0x9c, 0xef, 0xd3, + 0x60, 0x9b, 0xa5, 0x6a, 0x34, 0x1e, 0x92, 0x98, 0xe7, 0x61, 0xcc, 0x65, 0xce, 0xa5, 0xfd, 0xd9, + 0x95, 0xc9, 0x61, 0xa8, 0x26, 0x25, 0x48, 0xd2, 0x87, 0x38, 0x5a, 0xab, 0x20, 0x6f, 0x0c, 0x03, + 0x3f, 0x47, 0x2b, 0x8a, 0x1e, 0xc2, 0x40, 0x50, 0x05, 0x5e, 0xf3, 0x5a, 0xc0, 0x96, 0x06, 0x44, + 0x54, 0x01, 0x7e, 0x87, 0xb0, 0x7d, 0x61, 0x3c, 0xa2, 0x05, 0xb3, 0xd4, 0xe5, 0x6b, 0x51, 0xd7, + 0x2b, 0xd2, 0xbe, 0x01, 0x19, 0xfa, 0x5b, 0x74, 0xef, 0x22, 0x3d, 0x2d, 0x14, 0x88, 0x23, 0x9a, + 0x79, 0xb7, 0x3b, 0xee, 0xce, 0xea, 0xa3, 0x4d, 0x52, 0xc5, 0x47, 0x16, 0xf1, 0x91, 0xbe, 0x8d, + 0xaf, 0xd7, 0xd2, 0x97, 0x7f, 0xfe, 0x19, 0xb8, 0x51, 0xbb, 0x8e, 0x7d, 0x6a, 0x01, 0xf8, 0x00, + 0xdd, 0xbd, 0x30, 0xda, 0x81, 0xd0, 0xb2, 0xd7, 0x32, 0xdc, 0x07, 0xe4, 0xca, 0x0a, 0x92, 0xa8, + 0x36, 0xc3, 0x48, 0x7b, 0x7b, 0x0d, 0x7d, 0x45, 0xb4, 0x21, 0x2e, 0x0b, 0x7b, 0x8d, 0xdf, 0x5f, + 0x02, 0xa7, 0xfb, 0x63, 0xc9, 0xac, 0xce, 0xeb, 0x32, 0xb9, 0x59, 0x9d, 0xff, 0x69, 0x75, 0x6c, + 0xbc, 0x1f, 0x5d, 0x13, 0x6f, 0x1f, 0x32, 0xf8, 0xf7, 0xf1, 0x56, 0x6f, 0xe8, 0x3d, 0x3b, 0x99, + 0xf9, 0xee, 0xe9, 0xcc, 0x77, 0x7f, 0xcd, 0x7c, 0xf7, 0xd3, 0xdc, 0x77, 0x4e, 0xe7, 0xbe, 0xf3, + 0x6d, 0xee, 0x3b, 0x07, 0x0f, 0x6b, 0x83, 0x53, 0x20, 0x04, 0xdd, 0xcd, 0x79, 0x01, 0x93, 0xf3, + 0xcf, 0xe7, 0x87, 0xf3, 0xd2, 0x8c, 0x71, 0xb8, 0x6c, 0x06, 0xf1, 0xf8, 0x6f, 0x00, 0x00, 0x00, + 0xff, 0xff, 0x3b, 0x90, 0xf8, 0x2c, 0x9b, 0x05, 0x00, 0x00, } func (m *MsgCreateAllianceProposal) Marshal() (dAtA []byte, err error) { diff --git a/x/alliance/types/msg.go b/x/alliance/types/msg.go index b23a46e7..5ddf324f 100644 --- a/x/alliance/types/msg.go +++ b/x/alliance/types/msg.go @@ -22,7 +22,6 @@ var ( _ legacytx.LegacyMsg = &MsgRedelegate{} _ legacytx.LegacyMsg = &MsgUndelegate{} _ legacytx.LegacyMsg = &MsgClaimDelegationRewards{} - _ legacytx.LegacyMsg = &MsgUpdateParams{} _ legacytx.LegacyMsg = &MsgCreateAlliance{} _ legacytx.LegacyMsg = &MsgUpdateAlliance{} _ legacytx.LegacyMsg = &MsgDeleteAlliance{} @@ -33,7 +32,6 @@ var ( MsgUndelegateType = "msg_undelegate" MsgRedelegateType = "msg_redelegate" MsgClaimDelegationRewardsType = "claim_delegation_rewards" - MsgUpdateParamsType = "update_params" MsgCreateAllianceType = "create_alliance" MsgUpdateAllianceType = "update_alliance" MsgDeleteAllianceType = "delete_alliance" @@ -172,34 +170,6 @@ func (msg *MsgClaimDelegationRewards) GetSigners() []sdk.AccAddress { func (msg MsgClaimDelegationRewards) Type() string { return MsgClaimDelegationRewardsType } -func (msg *MsgUpdateParams) ValidateBasic() error { - if _, err := sdk.AccAddressFromBech32(msg.Authority); err != nil { - return sdkerrors.Wrap(err, "invalid authority address") - } - if err := ValidatePositiveDuration(msg.Params.RewardDelayTime); err != nil { - return err - } - return ValidatePositiveDuration(msg.Params.TakeRateClaimInterval) -} - -func (msg MsgUpdateParams) Route() string { - return sdk.MsgTypeURL(&msg) -} - -func (msg MsgUpdateParams) GetSignBytes() []byte { - return sdk.MustSortJSON(ModuleCdc.MustMarshalJSON(&msg)) -} - -func (msg *MsgUpdateParams) GetSigners() []sdk.AccAddress { - signer, err := sdk.AccAddressFromBech32(msg.Authority) - if err != nil { - panic("Authority is not valid") - } - return []sdk.AccAddress{signer} -} - -func (msg MsgUpdateParams) Type() string { return MsgUpdateParamsType } - func (msg *MsgCreateAlliance) ValidateBasic() error { if _, err := sdk.AccAddressFromBech32(msg.Authority); err != nil { return sdkerrors.Wrap(err, "invalid authority address") diff --git a/x/alliance/types/tx.pb.go b/x/alliance/types/tx.pb.go index 3417d71d..34a4b51a 100644 --- a/x/alliance/types/tx.pb.go +++ b/x/alliance/types/tx.pb.go @@ -338,8 +338,12 @@ func (m *MsgClaimDelegationRewardsResponse) XXX_DiscardUnknown() { var xxx_messageInfo_MsgClaimDelegationRewardsResponse proto.InternalMessageInfo type MsgUpdateParams struct { - Authority string `protobuf:"bytes,1,opt,name=authority,proto3" json:"authority,omitempty"` - Params Params `protobuf:"bytes,2,opt,name=params,proto3" json:"params"` + // the title of the update proposal + Title string `protobuf:"bytes,1,opt,name=title,proto3" json:"title,omitempty"` + // the description of the proposal + Description string `protobuf:"bytes,2,opt,name=description,proto3" json:"description,omitempty"` + Authority string `protobuf:"bytes,3,opt,name=authority,proto3" json:"authority,omitempty"` + Params Params `protobuf:"bytes,4,opt,name=params,proto3" json:"params"` } func (m *MsgUpdateParams) Reset() { *m = MsgUpdateParams{} } @@ -375,6 +379,20 @@ func (m *MsgUpdateParams) XXX_DiscardUnknown() { var xxx_messageInfo_MsgUpdateParams proto.InternalMessageInfo +func (m *MsgUpdateParams) GetTitle() string { + if m != nil { + return m.Title + } + return "" +} + +func (m *MsgUpdateParams) GetDescription() string { + if m != nil { + return m.Description + } + return "" +} + func (m *MsgUpdateParams) GetAuthority() string { if m != nil { return m.Authority @@ -752,66 +770,68 @@ func init() { func init() { proto.RegisterFile("alliance/alliance/tx.proto", fileDescriptor_caddd4794042022d) } var fileDescriptor_caddd4794042022d = []byte{ - // 941 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xec, 0x97, 0xcf, 0x6f, 0xe3, 0x44, - 0x14, 0xc7, 0xe3, 0xb6, 0x1b, 0xda, 0xd9, 0xee, 0xd2, 0xba, 0xed, 0x36, 0x35, 0x92, 0x13, 0x42, - 0x54, 0xaa, 0xd5, 0xd6, 0xa6, 0x0b, 0x02, 0xa9, 0xb7, 0x4d, 0xc3, 0x81, 0x1f, 0x91, 0x90, 0x2b, - 0x04, 0xac, 0x10, 0xd1, 0xc4, 0x1e, 0x1c, 0x6b, 0x6d, 0x4f, 0x34, 0x33, 0xc9, 0x6e, 0x24, 0x4e, - 0x70, 0xe1, 0x88, 0x38, 0x71, 0x41, 0x2c, 0xff, 0x01, 0x07, 0x4e, 0xfc, 0x05, 0x7b, 0x5c, 0x71, - 0x42, 0x1c, 0xb2, 0xa8, 0x3d, 0xc0, 0x99, 0x03, 0x67, 0x34, 0x9e, 0xb1, 0x63, 0x27, 0xf6, 0x26, - 0xbb, 0x42, 0xc0, 0x4a, 0x3d, 0xc5, 0xf6, 0x7b, 0xf3, 0x99, 0x37, 0xdf, 0xf7, 0xe6, 0xcd, 0x04, - 0x68, 0xd0, 0xf7, 0x3d, 0x18, 0xda, 0xc8, 0x4c, 0x1e, 0xd8, 0x3d, 0xa3, 0x4f, 0x30, 0xc3, 0xea, - 0x66, 0xfc, 0xc9, 0x88, 0x1f, 0xb4, 0x6d, 0x17, 0xbb, 0x38, 0xb2, 0x9a, 0xfc, 0x49, 0x38, 0x6a, - 0x7b, 0x36, 0xa6, 0x01, 0xa6, 0x1d, 0x61, 0x10, 0x2f, 0xd2, 0xb4, 0x2b, 0xde, 0xcc, 0x80, 0xba, - 0xe6, 0xf0, 0x88, 0xff, 0x48, 0x83, 0x2e, 0x0d, 0x5d, 0x48, 0x91, 0x39, 0x3c, 0xea, 0x22, 0x06, - 0x8f, 0x4c, 0x1b, 0x7b, 0x61, 0x6c, 0x9f, 0x0d, 0xac, 0x0f, 0x09, 0x0c, 0x62, 0x70, 0x6d, 0xd6, - 0x9e, 0x84, 0x2b, 0x09, 0x2e, 0xc6, 0xae, 0x8f, 0xcc, 0xe8, 0xad, 0x3b, 0xf8, 0xd4, 0x74, 0x06, - 0x04, 0x32, 0x0f, 0xcb, 0x19, 0xea, 0xdf, 0x2d, 0x81, 0xcb, 0x6d, 0xea, 0xb6, 0x90, 0x8f, 0x5c, - 0xc8, 0x90, 0xfa, 0x26, 0xd8, 0x74, 0xc4, 0x33, 0x26, 0x1d, 0xe8, 0x38, 0x04, 0x51, 0x5a, 0x51, - 0x6a, 0xca, 0xc1, 0x5a, 0xb3, 0xf2, 0xf3, 0x8f, 0x87, 0xdb, 0x72, 0x5d, 0xb7, 0x84, 0xe5, 0x94, - 0x11, 0x2f, 0x74, 0xad, 0x8d, 0x64, 0x88, 0xfc, 0xce, 0x31, 0x43, 0xe8, 0x7b, 0x4e, 0x06, 0xb3, - 0x34, 0x0f, 0x93, 0x0c, 0x89, 0x31, 0x5d, 0x50, 0x86, 0x01, 0x1e, 0x84, 0xac, 0xb2, 0x5c, 0x53, - 0x0e, 0x2e, 0xdf, 0xdc, 0x33, 0xe4, 0x40, 0x2e, 0x98, 0x21, 0x05, 0x33, 0x4e, 0xb0, 0x17, 0x36, - 0xcd, 0x07, 0xe3, 0x6a, 0xe9, 0xd7, 0x71, 0xf5, 0x65, 0xd7, 0x63, 0xbd, 0x41, 0xd7, 0xb0, 0x71, - 0x20, 0x93, 0x20, 0x7f, 0x0e, 0xa9, 0x73, 0xc7, 0x64, 0xa3, 0x3e, 0xa2, 0xd1, 0x00, 0x4b, 0x92, - 0x8f, 0xf5, 0x2f, 0xef, 0x57, 0x4b, 0x7f, 0xdc, 0xaf, 0x96, 0x3e, 0xff, 0xfd, 0x87, 0xeb, 0xb3, - 0x8b, 0xaf, 0xef, 0x80, 0xad, 0x94, 0x40, 0x16, 0xa2, 0x7d, 0x1c, 0x52, 0x54, 0xff, 0x7e, 0x09, - 0x5c, 0x69, 0x53, 0xf7, 0xfd, 0xd0, 0xb9, 0x90, 0xae, 0x48, 0xba, 0x5d, 0xb0, 0x93, 0x91, 0x28, - 0x11, 0xef, 0x2f, 0x21, 0x9e, 0x85, 0xfe, 0x69, 0xf1, 0xde, 0x05, 0x3b, 0x13, 0xf1, 0x28, 0xb1, - 0x17, 0x16, 0x70, 0x2b, 0x19, 0x76, 0x4a, 0xec, 0x5c, 0x9a, 0x43, 0x59, 0x42, 0x5b, 0x5e, 0x98, - 0xd6, 0xa2, 0x6c, 0x36, 0x23, 0x2b, 0xff, 0x71, 0x46, 0x26, 0xba, 0x27, 0x19, 0x79, 0xa4, 0x80, - 0xbd, 0x36, 0x75, 0x4f, 0x7c, 0xe8, 0x05, 0xb2, 0xd6, 0x3d, 0x1c, 0x5a, 0xe8, 0x2e, 0x24, 0x0e, - 0xfd, 0x9f, 0x95, 0xf6, 0x36, 0xb8, 0xe4, 0xa0, 0x10, 0x07, 0x22, 0x0d, 0x96, 0x78, 0x99, 0xbb, - 0xf4, 0x97, 0xc0, 0x8b, 0x85, 0x0b, 0x4c, 0x64, 0xf8, 0x5a, 0x01, 0xcf, 0xf3, 0x92, 0xed, 0x3b, - 0x90, 0xa1, 0xf7, 0xa2, 0x56, 0xab, 0xbe, 0x0e, 0xd6, 0xe0, 0x80, 0xf5, 0x30, 0xf1, 0xd8, 0x68, - 0xee, 0xa2, 0x27, 0xae, 0xea, 0x1b, 0xa0, 0x2c, 0x9a, 0x75, 0xb4, 0x44, 0x9e, 0xef, 0x99, 0xa3, - 0xc4, 0x10, 0x53, 0x34, 0x57, 0x78, 0xbe, 0x2d, 0xe9, 0x7e, 0x7c, 0x95, 0xaf, 0x60, 0x02, 0xaa, - 0xef, 0x81, 0xdd, 0xa9, 0x98, 0x92, 0x78, 0x7f, 0x5a, 0x01, 0x9b, 0x7c, 0x55, 0x04, 0x41, 0x86, - 0x6e, 0x49, 0xea, 0x53, 0x47, 0xbc, 0x1f, 0x0b, 0x2b, 0x72, 0xb2, 0xf1, 0xe7, 0xb8, 0xba, 0x3e, - 0x82, 0x81, 0x7f, 0x5c, 0x8f, 0x3e, 0xd7, 0xa5, 0xd4, 0xea, 0x29, 0xb8, 0x42, 0x22, 0xe1, 0x3a, - 0x77, 0x91, 0xe7, 0xf6, 0x98, 0xdc, 0x0f, 0x86, 0xac, 0xda, 0xfd, 0x05, 0xaa, 0xb6, 0x85, 0x6c, - 0x6b, 0x5d, 0x40, 0x3e, 0x88, 0x18, 0xea, 0x3b, 0x60, 0x8d, 0xc1, 0x3b, 0xa8, 0x43, 0x20, 0x43, - 0xd1, 0x0e, 0x79, 0x72, 0xe0, 0x2a, 0x07, 0x58, 0xbc, 0x9d, 0x7c, 0x0c, 0x54, 0x19, 0xa1, 0xdd, - 0x83, 0xa1, 0x2b, 0xa9, 0x97, 0x9e, 0x8a, 0xba, 0x21, 0x48, 0x27, 0x11, 0x28, 0xa2, 0x7f, 0x04, - 0xae, 0x65, 0xe9, 0x5e, 0xc8, 0x10, 0x19, 0x42, 0xbf, 0x52, 0x96, 0x99, 0x16, 0xa7, 0xae, 0x11, - 0x9f, 0xba, 0x46, 0x4b, 0x9e, 0xba, 0xcd, 0x55, 0x3e, 0xf9, 0x37, 0x8f, 0xaa, 0x8a, 0xb5, 0x9d, - 0xc6, 0xbe, 0x25, 0x01, 0xea, 0x6d, 0xb0, 0x95, 0x91, 0xb6, 0x43, 0xb8, 0xb9, 0xf2, 0x5c, 0xc4, - 0x6d, 0xe4, 0x54, 0x90, 0x95, 0xd2, 0xd0, 0xe2, 0xbe, 0xb2, 0x98, 0x36, 0xc9, 0xb4, 0x61, 0xa6, - 0xae, 0x5e, 0x10, 0x5b, 0x3e, 0x53, 0x3b, 0x49, 0x65, 0x8d, 0x97, 0xa3, 0xca, 0x12, 0x55, 0x77, - 0x51, 0x59, 0xcf, 0x7c, 0x65, 0x15, 0x64, 0x3f, 0x9b, 0xdf, 0x24, 0xfb, 0x5f, 0x28, 0x51, 0xf6, - 0x79, 0xa3, 0xfc, 0xf7, 0xb2, 0x5f, 0x10, 0x62, 0x36, 0x88, 0x38, 0xc4, 0x9b, 0xdf, 0x96, 0xc1, - 0x72, 0x9b, 0xba, 0xaa, 0x05, 0x56, 0x93, 0xdb, 0xab, 0x9e, 0xb3, 0x41, 0x52, 0x97, 0x37, 0x6d, - 0xff, 0xf1, 0xf6, 0x98, 0xad, 0x7e, 0x08, 0x40, 0xea, 0x6e, 0x52, 0xcb, 0x1f, 0x35, 0xf1, 0xd0, - 0x0e, 0xe6, 0x79, 0xa4, 0xc9, 0xa9, 0x2b, 0x63, 0x01, 0x79, 0xe2, 0x51, 0x44, 0x9e, 0xbd, 0x53, - 0xa9, 0x9f, 0x81, 0x6b, 0x05, 0xa7, 0xf7, 0x8d, 0x7c, 0x46, 0xbe, 0xb7, 0xf6, 0xda, 0x93, 0x78, - 0x27, 0xb3, 0x7f, 0x02, 0xd6, 0x33, 0x87, 0x66, 0xbd, 0x20, 0xee, 0x94, 0x8f, 0x76, 0x7d, 0xbe, - 0x4f, 0xc2, 0x77, 0xc0, 0xd5, 0xa9, 0x43, 0xae, 0x51, 0x10, 0x67, 0xc6, 0x4b, 0xbb, 0xb1, 0x88, - 0x57, 0x7a, 0x96, 0xa9, 0x86, 0xd7, 0x78, 0x5c, 0x8c, 0xf3, 0x66, 0xc9, 0xdf, 0x5c, 0x7c, 0x96, - 0xa9, 0x8d, 0xd5, 0x28, 0xae, 0xcb, 0xf9, 0xb3, 0xe4, 0xef, 0x8f, 0xe6, 0xdb, 0x0f, 0xce, 0x74, - 0xe5, 0xe1, 0x99, 0xae, 0xfc, 0x76, 0xa6, 0x2b, 0x5f, 0x9d, 0xeb, 0xa5, 0x87, 0xe7, 0x7a, 0xe9, - 0x97, 0x73, 0xbd, 0x74, 0xfb, 0x95, 0x54, 0x7b, 0x62, 0x88, 0x10, 0x78, 0x18, 0xe0, 0x10, 0x8d, - 0x26, 0xff, 0x21, 0xef, 0xa5, 0xfe, 0x07, 0xf3, 0x66, 0xd5, 0x2d, 0x47, 0xed, 0xe6, 0xd5, 0xbf, - 0x03, 0x00, 0x00, 0xff, 0xff, 0xed, 0xcc, 0xf1, 0x5b, 0x29, 0x0f, 0x00, 0x00, + // 964 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xec, 0x57, 0xcf, 0x6f, 0xe3, 0x44, + 0x14, 0x8e, 0xdb, 0x6e, 0x68, 0xa7, 0xdd, 0xa5, 0x75, 0xdb, 0x6d, 0x6a, 0x24, 0x27, 0x84, 0xaa, + 0x54, 0xab, 0xad, 0x4d, 0x17, 0x04, 0x52, 0x6f, 0x9b, 0x96, 0x03, 0x3f, 0x2a, 0x21, 0x57, 0x08, + 0x58, 0x21, 0xa2, 0x89, 0x3d, 0xb8, 0xd6, 0xda, 0x9e, 0x68, 0x66, 0x92, 0xdd, 0x48, 0x9c, 0xe0, + 0xc2, 0x91, 0x23, 0x17, 0xc4, 0xf2, 0x1f, 0x70, 0xe0, 0xc4, 0x5f, 0xb0, 0xe2, 0xb4, 0xe2, 0x84, + 0x38, 0x64, 0x51, 0x7b, 0x80, 0x33, 0x07, 0xce, 0x68, 0x3c, 0xe3, 0x89, 0x9d, 0xd8, 0x9b, 0x2c, + 0x42, 0xfc, 0x90, 0x7a, 0x8a, 0xc7, 0xef, 0xcd, 0xf7, 0xde, 0xfb, 0xde, 0xe7, 0x37, 0x13, 0x60, + 0xc0, 0x30, 0x0c, 0x60, 0xec, 0x22, 0x5b, 0x3d, 0xb0, 0xfb, 0x56, 0x97, 0x60, 0x86, 0xf5, 0xb5, + 0xf4, 0x95, 0x95, 0x3e, 0x18, 0x1b, 0x3e, 0xf6, 0x71, 0x62, 0xb5, 0xf9, 0x93, 0x70, 0x34, 0xb6, + 0x5d, 0x4c, 0x23, 0x4c, 0xdb, 0xc2, 0x20, 0x16, 0xd2, 0xb4, 0x25, 0x56, 0x76, 0x44, 0x7d, 0xbb, + 0x7f, 0xc0, 0x7f, 0xa4, 0xc1, 0x94, 0x86, 0x0e, 0xa4, 0xc8, 0xee, 0x1f, 0x74, 0x10, 0x83, 0x07, + 0xb6, 0x8b, 0x83, 0x38, 0xb5, 0x4f, 0x26, 0xd6, 0x85, 0x04, 0x46, 0x29, 0x70, 0x63, 0xd2, 0xae, + 0xd2, 0x95, 0x08, 0x3e, 0xc6, 0x7e, 0x88, 0xec, 0x64, 0xd5, 0xe9, 0x7d, 0x6c, 0x7b, 0x3d, 0x02, + 0x59, 0x80, 0x65, 0x84, 0xe6, 0xd7, 0x73, 0x60, 0xf9, 0x84, 0xfa, 0xc7, 0x28, 0x44, 0x3e, 0x64, + 0x48, 0x7f, 0x1d, 0xac, 0x79, 0xe2, 0x19, 0x93, 0x36, 0xf4, 0x3c, 0x82, 0x28, 0xad, 0x69, 0x0d, + 0x6d, 0x6f, 0xa9, 0x55, 0xfb, 0xf1, 0xbb, 0xfd, 0x0d, 0x59, 0xd7, 0x6d, 0x61, 0x39, 0x65, 0x24, + 0x88, 0x7d, 0x67, 0x55, 0x6d, 0x91, 0xef, 0x39, 0x4c, 0x1f, 0x86, 0x81, 0x97, 0x83, 0x99, 0x9b, + 0x06, 0xa3, 0xb6, 0xa4, 0x30, 0x1d, 0x50, 0x85, 0x11, 0xee, 0xc5, 0xac, 0x36, 0xdf, 0xd0, 0xf6, + 0x96, 0x6f, 0x6d, 0x5b, 0x72, 0x23, 0x27, 0xcc, 0x92, 0x84, 0x59, 0x47, 0x38, 0x88, 0x5b, 0xf6, + 0xc3, 0x61, 0xbd, 0xf2, 0xf3, 0xb0, 0xfe, 0xa2, 0x1f, 0xb0, 0xb3, 0x5e, 0xc7, 0x72, 0x71, 0x24, + 0x9b, 0x20, 0x7f, 0xf6, 0xa9, 0x77, 0xd7, 0x66, 0x83, 0x2e, 0xa2, 0xc9, 0x06, 0x47, 0x22, 0x1f, + 0x9a, 0x9f, 0x3f, 0xa8, 0x57, 0x7e, 0x7b, 0x50, 0xaf, 0x7c, 0xfa, 0xeb, 0xb7, 0x37, 0x26, 0x8b, + 0x6f, 0x6e, 0x82, 0xf5, 0x0c, 0x41, 0x0e, 0xa2, 0x5d, 0x1c, 0x53, 0xd4, 0xfc, 0x66, 0x0e, 0x5c, + 0x3d, 0xa1, 0xfe, 0xbb, 0xb1, 0x77, 0x49, 0x5d, 0x19, 0x75, 0x5b, 0x60, 0x33, 0x47, 0x91, 0x22, + 0xef, 0x0f, 0x41, 0x9e, 0x83, 0xfe, 0x6e, 0xf2, 0xde, 0x06, 0x9b, 0x23, 0xf2, 0x28, 0x71, 0x67, + 0x26, 0x70, 0x5d, 0x6d, 0x3b, 0x25, 0x6e, 0x21, 0x9a, 0x47, 0x99, 0x42, 0x9b, 0x9f, 0x19, 0xed, + 0x98, 0xb2, 0xc9, 0x8e, 0x2c, 0xfc, 0xcb, 0x1d, 0x19, 0xf1, 0xae, 0x3a, 0xf2, 0x58, 0x03, 0xdb, + 0x27, 0xd4, 0x3f, 0x0a, 0x61, 0x10, 0x49, 0xad, 0x07, 0x38, 0x76, 0xd0, 0x3d, 0x48, 0x3c, 0xfa, + 0x1f, 0x93, 0xf6, 0x06, 0xb8, 0xe2, 0xa1, 0x18, 0x47, 0xa2, 0x0d, 0x8e, 0x58, 0x4c, 0x2d, 0xfd, + 0x05, 0xf0, 0x7c, 0x69, 0x81, 0x8a, 0x86, 0x1f, 0x34, 0xf0, 0x2c, 0x97, 0x6c, 0xd7, 0x83, 0x0c, + 0xbd, 0x93, 0x8c, 0x5a, 0x1e, 0x8e, 0x05, 0x2c, 0x44, 0xa2, 0x60, 0x47, 0x2c, 0xf4, 0x06, 0x58, + 0xf6, 0x10, 0x75, 0x49, 0xd0, 0xe5, 0x38, 0xa2, 0x0a, 0x27, 0xfb, 0x4a, 0x7f, 0x15, 0x2c, 0xc1, + 0x1e, 0x3b, 0xc3, 0x24, 0x60, 0x83, 0xa9, 0x8a, 0x19, 0xb9, 0xea, 0xaf, 0x81, 0xaa, 0x18, 0xf2, + 0x4a, 0x27, 0x13, 0x47, 0x90, 0x25, 0x52, 0x6b, 0x2d, 0x70, 0x9d, 0x38, 0xd2, 0xfd, 0xf0, 0x1a, + 0xaf, 0x7c, 0x04, 0xd4, 0xdc, 0x06, 0x5b, 0x63, 0xb5, 0xa8, 0x3a, 0xbf, 0x5f, 0x00, 0x6b, 0x9c, + 0x0d, 0x82, 0x20, 0x43, 0xb7, 0x25, 0x6a, 0x3e, 0x63, 0x6d, 0xf6, 0x8c, 0x77, 0xd3, 0x86, 0x88, + 0x5e, 0xae, 0xfe, 0x3e, 0xac, 0xaf, 0x0c, 0x60, 0x14, 0x1e, 0x36, 0x93, 0xd7, 0x4d, 0xd9, 0x22, + 0xfd, 0x14, 0x5c, 0x25, 0x09, 0xe1, 0xed, 0x7b, 0x28, 0xf0, 0xcf, 0x98, 0x64, 0xc5, 0x92, 0x6a, + 0xdf, 0x9d, 0x41, 0xed, 0xc7, 0xc8, 0x75, 0x56, 0x04, 0xc8, 0x7b, 0x09, 0x86, 0xfe, 0x16, 0x58, + 0x62, 0xf0, 0x2e, 0x6a, 0x13, 0xc8, 0x50, 0xc2, 0xd8, 0xd3, 0x03, 0x2e, 0x72, 0x00, 0x87, 0x8f, + 0xa1, 0x0f, 0x81, 0x2e, 0x33, 0x74, 0xcf, 0x60, 0xec, 0x4b, 0xd4, 0x2b, 0x7f, 0x09, 0x75, 0x55, + 0x20, 0x1d, 0x25, 0x40, 0x09, 0xfa, 0x07, 0xe0, 0x7a, 0x1e, 0x3d, 0x88, 0x19, 0x22, 0x7d, 0x18, + 0xd6, 0xaa, 0xb2, 0xd3, 0xe2, 0xb4, 0xb6, 0xd2, 0xd3, 0xda, 0x3a, 0x96, 0xa7, 0x75, 0x6b, 0x91, + 0x07, 0xff, 0xf2, 0x71, 0x5d, 0x73, 0x36, 0xb2, 0xb0, 0x6f, 0x48, 0x00, 0xfd, 0x0e, 0x58, 0xcf, + 0x51, 0xdb, 0x26, 0xdc, 0x5c, 0x7b, 0x26, 0xc1, 0xdd, 0x29, 0x50, 0x90, 0x93, 0xe1, 0xd0, 0xe1, + 0xbe, 0x52, 0x4c, 0x6b, 0x64, 0xdc, 0x30, 0xa1, 0xab, 0xe7, 0xc4, 0xa8, 0xc8, 0x69, 0x47, 0x29, + 0x6b, 0x38, 0x9f, 0x28, 0x4b, 0xa8, 0xee, 0x52, 0x59, 0xff, 0x7b, 0x65, 0x95, 0x74, 0x3f, 0xdf, + 0x5f, 0xd5, 0xfd, 0xcf, 0xb4, 0xa4, 0xfb, 0x7c, 0xc0, 0xfe, 0x73, 0xdd, 0x2f, 0x49, 0x31, 0x9f, + 0x44, 0x9a, 0xe2, 0xad, 0xaf, 0xaa, 0x60, 0xfe, 0x84, 0xfa, 0xba, 0x03, 0x16, 0xd5, 0xad, 0xd7, + 0x2c, 0xf8, 0x40, 0x32, 0x97, 0x3e, 0x63, 0xf7, 0xc9, 0xf6, 0x14, 0x5b, 0x7f, 0x1f, 0x80, 0xcc, + 0x9d, 0xa6, 0x51, 0xbc, 0x6b, 0xe4, 0x61, 0xec, 0x4d, 0xf3, 0xc8, 0x22, 0x67, 0xae, 0x9a, 0x25, + 0xc8, 0x23, 0x8f, 0x32, 0xe4, 0xc9, 0xbb, 0x98, 0xfe, 0x09, 0xb8, 0x5e, 0x72, 0xea, 0xdf, 0x2c, + 0xc6, 0x28, 0xf6, 0x36, 0x5e, 0x79, 0x1a, 0x6f, 0x15, 0xfd, 0x23, 0xb0, 0x92, 0x3b, 0x6c, 0x9b, + 0x25, 0x79, 0x67, 0x7c, 0x8c, 0x1b, 0xd3, 0x7d, 0x14, 0xbe, 0x07, 0xae, 0x8d, 0x1d, 0x72, 0x3b, + 0x25, 0x79, 0xe6, 0xbc, 0x8c, 0x9b, 0xb3, 0x78, 0x65, 0xa3, 0x8c, 0x0d, 0xbc, 0x9d, 0x27, 0xe5, + 0x38, 0x2d, 0x4a, 0xf1, 0xc7, 0xc5, 0xa3, 0x8c, 0x7d, 0x58, 0x3b, 0xe5, 0xba, 0x9c, 0x1e, 0xa5, + 0xf8, 0xfb, 0x68, 0xbd, 0xf9, 0xf0, 0xdc, 0xd4, 0x1e, 0x9d, 0x9b, 0xda, 0x2f, 0xe7, 0xa6, 0xf6, + 0xc5, 0x85, 0x59, 0x79, 0x74, 0x61, 0x56, 0x7e, 0xba, 0x30, 0x2b, 0x77, 0x5e, 0xca, 0x8c, 0x27, + 0x86, 0x08, 0x81, 0xfb, 0x11, 0x8e, 0xd1, 0x60, 0xf4, 0xdf, 0xf3, 0x7e, 0xe6, 0xff, 0x33, 0x1f, + 0x56, 0x9d, 0x6a, 0x32, 0x6e, 0x5e, 0xfe, 0x33, 0x00, 0x00, 0xff, 0xff, 0x29, 0x84, 0x8a, 0xce, + 0x61, 0x0f, 0x00, 0x00, } // Reference imports to suppress errors if they are not otherwise used. @@ -1459,12 +1479,26 @@ func (m *MsgUpdateParams) MarshalToSizedBuffer(dAtA []byte) (int, error) { i = encodeVarintTx(dAtA, i, uint64(size)) } i-- - dAtA[i] = 0x12 + dAtA[i] = 0x22 if len(m.Authority) > 0 { i -= len(m.Authority) copy(dAtA[i:], m.Authority) i = encodeVarintTx(dAtA, i, uint64(len(m.Authority))) i-- + dAtA[i] = 0x1a + } + if len(m.Description) > 0 { + i -= len(m.Description) + copy(dAtA[i:], m.Description) + i = encodeVarintTx(dAtA, i, uint64(len(m.Description))) + i-- + dAtA[i] = 0x12 + } + if len(m.Title) > 0 { + i -= len(m.Title) + copy(dAtA[i:], m.Title) + i = encodeVarintTx(dAtA, i, uint64(len(m.Title))) + i-- dAtA[i] = 0xa } return len(dAtA) - i, nil @@ -1894,6 +1928,14 @@ func (m *MsgUpdateParams) Size() (n int) { } var l int _ = l + l = len(m.Title) + if l > 0 { + n += 1 + l + sovTx(uint64(l)) + } + l = len(m.Description) + if l > 0 { + n += 1 + l + sovTx(uint64(l)) + } l = len(m.Authority) if l > 0 { n += 1 + l + sovTx(uint64(l)) @@ -2863,6 +2905,70 @@ func (m *MsgUpdateParams) Unmarshal(dAtA []byte) error { } switch fieldNum { case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Title", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowTx + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthTx + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthTx + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Title = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Description", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowTx + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthTx + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthTx + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Description = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 3: if wireType != 2 { return fmt.Errorf("proto: wrong wireType = %d for field Authority", wireType) } @@ -2894,7 +3000,7 @@ func (m *MsgUpdateParams) Unmarshal(dAtA []byte) error { } m.Authority = string(dAtA[iNdEx:postIndex]) iNdEx = postIndex - case 2: + case 4: if wireType != 2 { return fmt.Errorf("proto: wrong wireType = %d for field Params", wireType) }