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

Add VerifyChannelUpgradeError and VerifyChannelUpgradeErrorAbsence methods to 03-connection #1609

Closed
5 tasks
damiannolan opened this issue Jun 29, 2022 · 1 comment

Comments

@damiannolan
Copy link
Member

damiannolan commented Jun 29, 2022

Summary

The UpgradeErrorPath MUST have an associated verification membership and non-membership function so that a counterparty may verify that chain has stored an empty or non-empty error in the UpgradeErrorPath.

Using the existing state verification keeper functions in 03-connection for reference:

  • VerifyChannelUpgradeError

  • Retrieve the ClientState and associated store using the provided connectionEnd

    • An error should be returned if the ClientState cannot be found
    • An error should be returned if the ClientState is inactive
  • Construct the MerklePath using the UpgradeErrorPath defined in 24-host

  • Invoke VerifyMembership using the associated ClientState

func (k Keeper) VerifyChannelUpgradeError(
	ctx sdk.Context,
	connection exported.ConnectionI,
	height exported.Height,
	proof []byte,
	portID,
	channelID string,
        errorReceipt channeltypes.ErrorReceipt,
) error {
        return nil
}

  • VerifyChannelUpgradeErrorAbsence

  • Retrieve the ClientState and associated store using the provided connectionEnd

    • An error should be returned if the ClientState cannot be found
    • An error should be returned if the ClientState is inactive
  • Construct the MerklePath using the UpgradeErrorPath defined in 24-host

  • Invoke VerifyNonMembership using the associated ClientState

func (k Keeper) VerifyChannelUpgradeErrorAbsence(
	ctx sdk.Context,
	connection exported.ConnectionI,
	height exported.Height,
	proof []byte,
	portID,
	channelID string,
) error {
        return nil
}

Ref: https://github.com/cosmos/ibc/blob/master/spec/core/ics-004-channel-and-packet-semantics/UPGRADES.md#UpgradeError-Path


Note the ClientState interface will contain a generic VerifyMembership method following the completion of:


For Admin Use

  • Not duplicate issue
  • Appropriate labels applied
  • Appropriate contributors tagged/assigned
@damiannolan
Copy link
Member Author

I'm going to start putting tests in place for this issue until we VerifyMembership and VerifyNonMembership merged into the feat branch

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
Archived in project
Development

No branches or pull requests

2 participants