Skip to content
New issue

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

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

Already on GitHub? Sign in to your account

fix: has relayer permission #279

Merged
merged 4 commits into from
Oct 7, 2024
Merged
Show file tree
Hide file tree
Changes from 3 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion app/upgrade.go
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ import (
vmtypes "github.com/initia-labs/movevm/types"
)

const upgradeName = "0.5.5"
const upgradeName = "0.5.6"

// RegisterUpgradeHandlers returns upgrade handlers
func (app *InitiaApp) RegisterUpgradeHandlers(cfg module.Configurator) {
Expand Down
2 changes: 1 addition & 1 deletion x/ibc/perm/keeper/keeper.go
Original file line number Diff line number Diff line change
Expand Up @@ -126,7 +126,7 @@ func (k Keeper) HasAdminPermission(ctx context.Context, portID, channelID string
// HasRelayerPermission checks if the relayer has permission to relay packets on the channel.
func (k Keeper) HasRelayerPermission(ctx context.Context, portID, channelID string, relayer sdk.AccAddress) (bool, error) {
permRelayers, err := k.ChannelStates.Get(ctx, collections.Join(portID, channelID))
if err != nil && errors.Is(err, collections.ErrNotFound) {
if (err != nil && errors.Is(err, collections.ErrNotFound)) || (err == nil && len(permRelayers.Relayers) == 0) {
// if no permissioned relayers are set, all relayers are allowed
return true, nil
Comment on lines +129 to 131
Copy link

Choose a reason for hiding this comment

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

💡 Codebase verification

Add specific tests and documentation for the updated relayer permission logic

The current test coverage for HasRelayerPermission does not include scenarios where permRelayers exists but has no relayers. Additionally, the documentation lacks detailed explanations of this new conditional logic.

  • Tests Needed:

    • Verify that when permRelayers exists but len(permRelayers.Relayers) == 0, all relayers are allowed.
  • Documentation Enhancements:

    • Explain the reasoning behind allowing all relayers when permRelayers is empty.
    • Detail the implications of this condition to prevent potential security concerns.
🔗 Analysis chain

Clarify the intention behind broadening relayer permission conditions

The conditional logic for determining relayer permissions has been expanded. Now, all relayers are allowed not only when no permissioned relayers are found (error case) but also when the permRelayers object exists but has no relayers.

This change has the following implications:

  1. It broadens the conditions under which all relayers are allowed.
  2. It treats an empty list of permissioned relayers the same as having no permissioned relayers set.

Please clarify:

  1. Is this the intended behavior?
  2. Does this align with the module's specifications or requirements?

Consider adding a comment to explain this logic, for example:

// Allow all relayers if no permissioned relayers are set or if the list of permissioned relayers is empty
if (err != nil && errors.Is(err, collections.ErrNotFound)) || (err == nil && len(permRelayers.Relayers) == 0) {
    return true, nil
}

To ensure this change aligns with the module's intended behavior, please run the following verification script:

This script will help us understand the test coverage, usage, and documentation around the HasRelayerPermission method, which can provide context for whether this change aligns with the overall module design.

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Description: Verify the usage and impact of HasRelayerPermission

# Test 1: Check for any tests related to HasRelayerPermission
echo "Checking for tests related to HasRelayerPermission:"
rg --type go -i "test.*hasrelayerpermission" -A 10

# Test 2: Look for other usages of HasRelayerPermission in the codebase
echo "Checking for other usages of HasRelayerPermission:"
rg --type go "HasRelayerPermission" -A 5

# Test 3: Search for any documentation or comments related to relayer permissions
echo "Searching for documentation or comments about relayer permissions:"
rg --type go -i "relayer.*permission" -A 5

Length of output: 24688

} else if err != nil {
Expand Down
Loading