Skip to content

Commit

Permalink
imp: deny selected client types from VerifyMembership rpc (backport #…
Browse files Browse the repository at this point in the history
…5871) (#5885)

* imp: deny selected client types from VerifyMembership rpc (#5871)

* chore: add client status check to verify membership rpc

* imp: deny selected client types from VerifyMembership rpc

(cherry picked from commit 4f14cfd)

# Conflicts:
#	modules/core/02-client/keeper/grpc_query.go
#	modules/core/02-client/keeper/grpc_query_test.go

* fix conflicts

* fix test

---------

Co-authored-by: Damian Nolan <[email protected]>
Co-authored-by: Carlos Rodriguez <[email protected]>
  • Loading branch information
3 people authored Feb 23, 2024
1 parent 6c33a93 commit 9048012
Show file tree
Hide file tree
Showing 2 changed files with 29 additions and 0 deletions.
11 changes: 11 additions & 0 deletions modules/core/02-client/keeper/grpc_query.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ import (
"bytes"
"context"
"fmt"
"slices"
"sort"
"strings"

Expand Down Expand Up @@ -341,6 +342,16 @@ func (k Keeper) VerifyMembership(c context.Context, req *types.QueryVerifyMember
return nil, status.Error(codes.InvalidArgument, err.Error())
}

clientType, _, err := types.ParseClientIdentifier(req.ClientId)
if err != nil {
return nil, status.Error(codes.InvalidArgument, err.Error())
}

denyClients := []string{exported.Localhost, exported.Solomachine}
if slices.Contains(denyClients, clientType) {
return nil, status.Error(codes.InvalidArgument, errorsmod.Wrapf(types.ErrInvalidClientType, "verify membership is disabled for client types %s", denyClients).Error())
}

if len(req.Proof) == 0 {
return nil, status.Error(codes.InvalidArgument, "empty proof")
}
Expand Down
18 changes: 18 additions & 0 deletions modules/core/02-client/keeper/grpc_query_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -714,6 +714,24 @@ func (suite *KeeperTestSuite) TestQueryVerifyMembershipProof() {
},
host.ErrInvalidID,
},
{
"localhost client ID is denied",
func() {
req = &types.QueryVerifyMembershipRequest{
ClientId: exported.LocalhostClientID,
}
},
types.ErrInvalidClientType,
},
{
"solomachine client ID is denied",
func() {
req = &types.QueryVerifyMembershipRequest{
ClientId: types.FormatClientIdentifier(exported.Solomachine, 1),
}
},
types.ErrInvalidClientType,
},
{
"empty proof",
func() {
Expand Down

0 comments on commit 9048012

Please sign in to comment.