Skip to content

Commit

Permalink
init commit
Browse files Browse the repository at this point in the history
  • Loading branch information
insumity committed Oct 3, 2024
1 parent c8d13f5 commit 47d7934
Show file tree
Hide file tree
Showing 9 changed files with 324 additions and 208 deletions.
2 changes: 2 additions & 0 deletions proto/interchain_security/ccv/provider/v1/query.proto
Original file line number Diff line number Diff line change
Expand Up @@ -194,6 +194,8 @@ message Chain {
// Corresponds to whether inactive validators are allowed to validate the consumer chain.
bool allow_inactive_vals = 12;
string consumer_id = 13;
// the reward denoms allowlisted by this consumer chain
AllowlistedRewardDenoms allowlisted_reward_denoms = 14;
}

message QueryValidatorConsumerAddrRequest {
Expand Down
16 changes: 10 additions & 6 deletions x/ccv/provider/client/cli/tx.go
Original file line number Diff line number Diff line change
Expand Up @@ -255,11 +255,12 @@ where create_consumer.json has the following structure:
"denylist": [],
"min_stake": "0",
"allow_inactive_vals": false
}
},
"allowlisted_reward_denoms": ["ibc/..", "ibc/..."]
}
Note that both 'chain_id' and 'metadata' are mandatory;
and both 'initialization_parameters' and 'power_shaping_parameters' are optional.
and 'initialization_parameters', 'power_shaping_parameters' and 'allowlisted_reward_denoms' are optional.
The parameters not provided are set to their zero value.
`, version.AppName)),
Args: cobra.ExactArgs(1),
Expand All @@ -286,7 +287,8 @@ The parameters not provided are set to their zero value.
return fmt.Errorf("consumer data unmarshalling failed: %w", err)
}

msg, err := types.NewMsgCreateConsumer(submitter, consCreate.ChainId, consCreate.Metadata, consCreate.InitializationParameters, consCreate.PowerShapingParameters)
msg, err := types.NewMsgCreateConsumer(submitter, consCreate.ChainId, consCreate.Metadata, consCreate.InitializationParameters,
consCreate.PowerShapingParameters, consCreate.AllowlistedRewardDenoms)
if err != nil {
return err
}
Expand Down Expand Up @@ -349,12 +351,13 @@ where update_consumer.json has the following structure:
"denylist": [],
"min_stake": "0",
"allow_inactive_vals": false
}
},
"allowlisted_reward_denoms": ["ibc/..", "ibc/..."]
}
Note that only 'consumer_id' is mandatory. The others are optional.
Not providing one of them will leave the existing values unchanged.
Providing one of 'metadata', 'initialization_parameters' or 'power_shaping_parameters',
Providing one of 'metadata', 'initialization_parameters', 'power_shaping_parameters', or 'allowlisted_reward_denoms'
will update all the containing fields.
If one of the fields is missing, it will be set to its zero value.
`, version.AppName)),
Expand Down Expand Up @@ -387,7 +390,8 @@ If one of the fields is missing, it will be set to its zero value.
return fmt.Errorf("consumer_id can't be empty")
}

msg, err := types.NewMsgUpdateConsumer(owner, consUpdate.ConsumerId, consUpdate.NewOwnerAddress, consUpdate.Metadata, consUpdate.InitializationParameters, consUpdate.PowerShapingParameters)
msg, err := types.NewMsgUpdateConsumer(owner, consUpdate.ConsumerId, consUpdate.NewOwnerAddress, consUpdate.Metadata,
consUpdate.InitializationParameters, consUpdate.PowerShapingParameters, consUpdate.AllowlistedRewardDenoms)
if err != nil {
return err
}
Expand Down
37 changes: 23 additions & 14 deletions x/ccv/provider/keeper/grpc_query.go
Original file line number Diff line number Diff line change
Expand Up @@ -114,22 +114,31 @@ func (k Keeper) GetConsumerChain(ctx sdk.Context, consumerId string) (types.Chai
strDenylist[i] = addr.String()
}

metadata, _ := k.GetConsumerMetadata(ctx, consumerId)
metadata, err := k.GetConsumerMetadata(ctx, consumerId)
if err != nil {
return types.Chain{}, fmt.Errorf("cannot find metadata (%s): %s", consumerId, err.Error())
}

allowlistedRewardDenoms, err := k.GetAllowlistedRewardDenoms(ctx, consumerId)
if err != nil {
return types.Chain{}, fmt.Errorf("cannot find allowlisted reward denoms (%s): %s", consumerId, err.Error())
}

return types.Chain{
ChainId: chainID,
ClientId: clientID,
Top_N: powerShapingParameters.Top_N,
MinPowerInTop_N: minPowerInTopN,
ValidatorSetCap: powerShapingParameters.ValidatorSetCap,
ValidatorsPowerCap: powerShapingParameters.ValidatorsPowerCap,
Allowlist: strAllowlist,
Denylist: strDenylist,
Phase: k.GetConsumerPhase(ctx, consumerId).String(),
Metadata: metadata,
AllowInactiveVals: powerShapingParameters.AllowInactiveVals,
MinStake: powerShapingParameters.MinStake,
ConsumerId: consumerId,
ChainId: chainID,
ClientId: clientID,
Top_N: powerShapingParameters.Top_N,
MinPowerInTop_N: minPowerInTopN,
ValidatorSetCap: powerShapingParameters.ValidatorSetCap,
ValidatorsPowerCap: powerShapingParameters.ValidatorsPowerCap,
Allowlist: strAllowlist,
Denylist: strDenylist,
Phase: k.GetConsumerPhase(ctx, consumerId).String(),
Metadata: metadata,
AllowInactiveVals: powerShapingParameters.AllowInactiveVals,
MinStake: powerShapingParameters.MinStake,
ConsumerId: consumerId,
AllowlistedRewardDenoms: &types.AllowlistedRewardDenoms{Denoms: allowlistedRewardDenoms},
}, nil
}

Expand Down
54 changes: 32 additions & 22 deletions x/ccv/provider/keeper/grpc_query_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -459,6 +459,12 @@ func TestGetConsumerChain(t *testing.T) {

metadataLists := []types.ConsumerMetadata{}

allowlistedRewardDenoms := []*types.AllowlistedRewardDenoms{
{}, // no denoms
{Denoms: []string{"ibc/1", "ibc/2"}},
{Denoms: []string{"ibc/3", "ibc/4", "ibc/5"}},
{Denoms: []string{"ibc/6"}}}

expectedGetAllOrder := []types.Chain{}
for i, consumerID := range consumerIDs {
pk.SetConsumerChainId(ctx, consumerID, chainIDs[i])
Expand Down Expand Up @@ -493,24 +499,27 @@ func TestGetConsumerChain(t *testing.T) {
metadataLists = append(metadataLists, types.ConsumerMetadata{Name: chainIDs[i]})
pk.SetConsumerMetadata(ctx, consumerID, metadataLists[i])

pk.SetAllowlistedRewardDenoms(ctx, consumerID, allowlistedRewardDenoms[i].Denoms)

phase := types.ConsumerPhase(int32(i + 1))
pk.SetConsumerPhase(ctx, consumerID, phase)

expectedGetAllOrder = append(expectedGetAllOrder,
types.Chain{
ChainId: chainIDs[i],
ClientId: clientID,
Top_N: topN,
MinPowerInTop_N: expectedMinPowerInTopNs[i],
ValidatorSetCap: validatorSetCaps[i],
ValidatorsPowerCap: validatorPowerCaps[i],
Allowlist: strAllowlist,
Denylist: strDenylist,
Phase: phase.String(),
Metadata: metadataLists[i],
AllowInactiveVals: allowInactiveVals[i],
MinStake: minStakes[i].Uint64(),
ConsumerId: consumerIDs[i],
ChainId: chainIDs[i],
ClientId: clientID,
Top_N: topN,
MinPowerInTop_N: expectedMinPowerInTopNs[i],
ValidatorSetCap: validatorSetCaps[i],
ValidatorsPowerCap: validatorPowerCaps[i],
Allowlist: strAllowlist,
Denylist: strDenylist,
Phase: phase.String(),
Metadata: metadataLists[i],
AllowInactiveVals: allowInactiveVals[i],
MinStake: minStakes[i].Uint64(),
ConsumerId: consumerIDs[i],
AllowlistedRewardDenoms: allowlistedRewardDenoms[i],
})
}

Expand Down Expand Up @@ -647,15 +656,16 @@ func TestQueryConsumerChains(t *testing.T) {

pk.SetConsumerPhase(ctx, consumerId, phases[i])
c := types.Chain{
ChainId: chainID,
MinPowerInTop_N: -1,
ValidatorsPowerCap: 0,
ValidatorSetCap: 0,
Allowlist: []string{},
Denylist: []string{},
Phase: phases[i].String(),
Metadata: metadata,
ConsumerId: consumerId,
ChainId: chainID,
MinPowerInTop_N: -1,
ValidatorsPowerCap: 0,
ValidatorSetCap: 0,
Allowlist: []string{},
Denylist: []string{},
Phase: phases[i].String(),
Metadata: metadata,
ConsumerId: consumerId,
AllowlistedRewardDenoms: &types.AllowlistedRewardDenoms{Denoms: []string{}},
}
consumerIds[i] = consumerId
consumers[i] = &c
Expand Down
4 changes: 4 additions & 0 deletions x/ccv/provider/types/msg.go
Original file line number Diff line number Diff line change
Expand Up @@ -280,13 +280,15 @@ func (msg MsgSetConsumerCommissionRate) ValidateBasic() error {
// NewMsgCreateConsumer creates a new MsgCreateConsumer instance
func NewMsgCreateConsumer(submitter, chainId string, metadata ConsumerMetadata,
initializationParameters *ConsumerInitializationParameters, powerShapingParameters *PowerShapingParameters,
allowlistedRewardDenoms *AllowlistedRewardDenoms,
) (*MsgCreateConsumer, error) {
return &MsgCreateConsumer{
Submitter: submitter,
ChainId: chainId,
Metadata: metadata,
InitializationParameters: initializationParameters,
PowerShapingParameters: powerShapingParameters,
AllowlistedRewardDenoms: allowlistedRewardDenoms,
}, nil
}

Expand Down Expand Up @@ -332,6 +334,7 @@ func (msg MsgCreateConsumer) ValidateBasic() error {
// NewMsgUpdateConsumer creates a new MsgUpdateConsumer instance
func NewMsgUpdateConsumer(owner, consumerId, ownerAddress string, metadata *ConsumerMetadata,
initializationParameters *ConsumerInitializationParameters, powerShapingParameters *PowerShapingParameters,
allowlistedRewardDenoms *AllowlistedRewardDenoms,
) (*MsgUpdateConsumer, error) {
return &MsgUpdateConsumer{
Owner: owner,
Expand All @@ -340,6 +343,7 @@ func NewMsgUpdateConsumer(owner, consumerId, ownerAddress string, metadata *Cons
Metadata: metadata,
InitializationParameters: initializationParameters,
PowerShapingParameters: powerShapingParameters,
AllowlistedRewardDenoms: allowlistedRewardDenoms,
}, nil
}

Expand Down
4 changes: 2 additions & 2 deletions x/ccv/provider/types/msg_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -471,7 +471,7 @@ func TestMsgCreateConsumerValidateBasic(t *testing.T) {

for _, tc := range testCases {
validConsumerMetadata := types.ConsumerMetadata{Name: "name", Description: "description", Metadata: "metadata"}
msg, err := types.NewMsgCreateConsumer("submitter", tc.chainId, validConsumerMetadata, nil, tc.powerShapingParameters)
msg, err := types.NewMsgCreateConsumer("submitter", tc.chainId, validConsumerMetadata, nil, tc.powerShapingParameters, nil)
require.NoError(t, err)
err = msg.ValidateBasic()
if tc.expPass {
Expand Down Expand Up @@ -546,7 +546,7 @@ func TestMsgUpdateConsumerValidateBasic(t *testing.T) {

for _, tc := range testCases {
// TODO (PERMISSIONLESS) add more tests
msg, _ := types.NewMsgUpdateConsumer("", "0", "cosmos1p3ucd3ptpw902fluyjzhq3ffgq4ntddac9sa3s", nil, nil, &tc.powerShapingParameters)
msg, _ := types.NewMsgUpdateConsumer("", "0", "cosmos1p3ucd3ptpw902fluyjzhq3ffgq4ntddac9sa3s", nil, nil, &tc.powerShapingParameters, nil)
err := msg.ValidateBasic()
if tc.expPass {
require.NoError(t, err, "valid case: %s should not return error. got %w", tc.name, err)
Expand Down
33 changes: 28 additions & 5 deletions x/ccv/provider/types/provider.pb.go

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

Loading

0 comments on commit 47d7934

Please sign in to comment.