From e037c9b629edc8127e31d4991b902fb041842a39 Mon Sep 17 00:00:00 2001 From: jgo121 Date: Wed, 6 Dec 2023 23:14:58 +0800 Subject: [PATCH 01/15] disable sig verification for MM tx demo --- app/ante/ante.go | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/app/ante/ante.go b/app/ante/ante.go index 77cb321c..da0b1e78 100644 --- a/app/ante/ante.go +++ b/app/ante/ante.go @@ -51,16 +51,16 @@ func NewAnteHandler( ante.NewConsumeGasForTxSizeDecorator(ak), // custom fee range validator NewValidateFeeRangeDecorator(sk, cgk, tk, ak), - ante.NewSetPubKeyDecorator(ak), // SetPubKeyDecorator must be called before all signature verification decorators - ante.NewValidateSigCountDecorator(ak), + // ante.NewSetPubKeyDecorator(ak), // SetPubKeyDecorator must be called before all signature verification decorators + // ante.NewValidateSigCountDecorator(ak), ante.NewDeductFeeDecorator(ak, bk, feegrantKeeper, txFeeChecker), // poor network management decorator NewPoorNetworkManagementDecorator(ak, cgk, sk), NewBlackWhiteTokensCheckDecorator(cgk, sk, tk), // custom execution fee consume decorator NewExecutionFeeRegistrationDecorator(ak, cgk, fk), - ante.NewSigGasConsumeDecorator(ak, sigGasConsumer), - ante.NewSigVerificationDecorator(ak, signModeHandler), + // ante.NewSigGasConsumeDecorator(ak, sigGasConsumer), + // ante.NewSigVerificationDecorator(ak, signModeHandler), ante.NewIncrementSequenceDecorator(ak), ) } From edb22573f5440a474759b6e0a43cbb29b8b7b314 Mon Sep 17 00:00:00 2001 From: tj327 Date: Mon, 18 Dec 2023 12:36:29 -0500 Subject: [PATCH 02/15] modify editIdentityRecord to deleteIdentityRecord --- types/Msg.go | 4 ++-- x/gov/client/cli/cli_identity_registrar_test.go | 2 +- x/gov/types/genesis.go | 2 +- x/gov/types/msg.go | 4 +++- 4 files changed, 7 insertions(+), 5 deletions(-) diff --git a/types/Msg.go b/types/Msg.go index e85b1988..d01e50c7 100644 --- a/types/Msg.go +++ b/types/Msg.go @@ -34,7 +34,7 @@ const ( MsgTypeRemoveBlacklistRolePermission = "remove-blacklist-role-permission" MsgTypeRegisterIdentityRecords = "register-identity-records" - MsgTypeEditIdentityRecord = "edit-identity-record" + MsgTypeDeleteIdentityRecord = "delete-identity-record" MsgTypeRequestIdentityRecordsVerify = "request-identity-records-verify" MsgTypeHandleIdentityRecordsVerifyRequest = "handle-identity-records-verify-request" MsgTypeCancelIdentityRecordsVerifyRequest = "cancel-identity-records-verify-request" @@ -153,7 +153,7 @@ var MsgFuncIDMapping = map[string]int64{ MsgTypeSubmitProposal: 10, MsgTypeVoteProposal: 11, MsgTypeRegisterIdentityRecords: 12, - MsgTypeEditIdentityRecord: 13, + MsgTypeDeleteIdentityRecord: 13, MsgTypeRequestIdentityRecordsVerify: 14, MsgTypeHandleIdentityRecordsVerifyRequest: 15, MsgTypeCancelIdentityRecordsVerifyRequest: 16, diff --git a/x/gov/client/cli/cli_identity_registrar_test.go b/x/gov/client/cli/cli_identity_registrar_test.go index 3f4a0021..f0396b67 100644 --- a/x/gov/client/cli/cli_identity_registrar_test.go +++ b/x/gov/client/cli/cli_identity_registrar_test.go @@ -40,7 +40,7 @@ func (s IntegrationTestSuite) TestTxRegisterIdentityRecords() { fmt.Println("out", out) } -func (s IntegrationTestSuite) TestTxEditIdentityRecord() { +func (s IntegrationTestSuite) TestTxDeleteIdentityRecord() { val := s.network.Validators[0] cmd := cli.GetTxDeleteIdentityRecords() diff --git a/x/gov/types/genesis.go b/x/gov/types/genesis.go index 9df8c86a..7080fafe 100644 --- a/x/gov/types/genesis.go +++ b/x/gov/types/genesis.go @@ -252,7 +252,7 @@ func DefaultGenesis() *GenesisState { kiratypes.MsgTypePause, kiratypes.MsgTypeUnpause, kiratypes.MsgTypeRegisterIdentityRecords, - kiratypes.MsgTypeEditIdentityRecord, + kiratypes.MsgTypeDeleteIdentityRecord, kiratypes.MsgTypeRequestIdentityRecordsVerify, kiratypes.MsgTypeHandleIdentityRecordsVerifyRequest, kiratypes.MsgTypeCancelIdentityRecordsVerifyRequest, diff --git a/x/gov/types/msg.go b/x/gov/types/msg.go index 3febb36b..4d5f8d62 100644 --- a/x/gov/types/msg.go +++ b/x/gov/types/msg.go @@ -635,6 +635,7 @@ func (m *MsgVoteProposal) GetSigners() []sdk.AccAddress { } // NewMsgPollCreate creates a new MsgPollCreate. +// //nolint:interfacer func NewMsgPollCreate(creator sdk.AccAddress, title, description string, reference string, checksum string, pollValues []string, roles []string, valueCount uint64, valueType string, possibleChoices uint64, duration string) *MsgPollCreate { m := &MsgPollCreate{ @@ -763,7 +764,7 @@ func (m *MsgDeleteIdentityRecords) Route() string { } func (m *MsgDeleteIdentityRecords) Type() string { - return types.MsgTypeEditIdentityRecord + return types.MsgTypeDeleteIdentityRecord } func (m *MsgDeleteIdentityRecords) ValidateBasic() error { @@ -902,6 +903,7 @@ func (m *MsgCancelIdentityRecordsVerifyRequest) GetSigners() []sdk.AccAddress { } // NewMsgSubmitProposal creates a new MsgSubmitProposal. +// //nolint:interfacer func NewMsgSubmitProposal(proposer sdk.AccAddress, title, description string, content Content) (*MsgSubmitProposal, error) { m := &MsgSubmitProposal{ From 7741ab0c5a58053eb8cb788168d992028e2ee0b1 Mon Sep 17 00:00:00 2001 From: jgo121 Date: Mon, 19 Feb 2024 22:58:50 +0800 Subject: [PATCH 03/15] Update SetPubKeyDecorator, ValidateSigCountDecorator, SigGasConsumeDecorator, SigVerificationDecorator to custom custom ones --- app/ante/ante.go | 8 +- app/ante/sigverify.go | 513 ++++++++++++++++++++ app/ante/testutil/expected_keepers_mocks.go | 127 +++++ 3 files changed, 644 insertions(+), 4 deletions(-) create mode 100644 app/ante/sigverify.go create mode 100644 app/ante/testutil/expected_keepers_mocks.go diff --git a/app/ante/ante.go b/app/ante/ante.go index da0b1e78..6c7bb9d4 100644 --- a/app/ante/ante.go +++ b/app/ante/ante.go @@ -51,16 +51,16 @@ func NewAnteHandler( ante.NewConsumeGasForTxSizeDecorator(ak), // custom fee range validator NewValidateFeeRangeDecorator(sk, cgk, tk, ak), - // ante.NewSetPubKeyDecorator(ak), // SetPubKeyDecorator must be called before all signature verification decorators - // ante.NewValidateSigCountDecorator(ak), + // NewSetPubKeyDecorator(ak), // SetPubKeyDecorator must be called before all signature verification decorators + // NewValidateSigCountDecorator(ak), ante.NewDeductFeeDecorator(ak, bk, feegrantKeeper, txFeeChecker), // poor network management decorator NewPoorNetworkManagementDecorator(ak, cgk, sk), NewBlackWhiteTokensCheckDecorator(cgk, sk, tk), // custom execution fee consume decorator NewExecutionFeeRegistrationDecorator(ak, cgk, fk), - // ante.NewSigGasConsumeDecorator(ak, sigGasConsumer), - // ante.NewSigVerificationDecorator(ak, signModeHandler), + // NewSigGasConsumeDecorator(ak, sigGasConsumer), + // NewSigVerificationDecorator(ak, signModeHandler), ante.NewIncrementSequenceDecorator(ak), ) } diff --git a/app/ante/sigverify.go b/app/ante/sigverify.go new file mode 100644 index 00000000..5df33f70 --- /dev/null +++ b/app/ante/sigverify.go @@ -0,0 +1,513 @@ +package ante + +import ( + "bytes" + "encoding/base64" + "encoding/hex" + "fmt" + + "github.com/cosmos/cosmos-sdk/crypto/keys/ed25519" + kmultisig "github.com/cosmos/cosmos-sdk/crypto/keys/multisig" + "github.com/cosmos/cosmos-sdk/crypto/keys/secp256k1" + "github.com/cosmos/cosmos-sdk/crypto/keys/secp256r1" + cryptotypes "github.com/cosmos/cosmos-sdk/crypto/types" + "github.com/cosmos/cosmos-sdk/crypto/types/multisig" + sdk "github.com/cosmos/cosmos-sdk/types" + sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" + "github.com/cosmos/cosmos-sdk/types/tx/signing" + "github.com/cosmos/cosmos-sdk/x/auth/ante" + "github.com/cosmos/cosmos-sdk/x/auth/migrations/legacytx" + authsigning "github.com/cosmos/cosmos-sdk/x/auth/signing" + "github.com/cosmos/cosmos-sdk/x/auth/types" +) + +var ( + // simulation signature values used to estimate gas consumption + key = make([]byte, secp256k1.PubKeySize) + simSecp256k1Pubkey = &secp256k1.PubKey{Key: key} + simSecp256k1Sig [64]byte + + _ authsigning.SigVerifiableTx = (*legacytx.StdTx)(nil) // assert StdTx implements SigVerifiableTx +) + +func init() { + // This decodes a valid hex string into a sepc256k1Pubkey for use in transaction simulation + bz, _ := hex.DecodeString("035AD6810A47F073553FF30D2FCC7E0D3B1C0B74B61A1AAA2582344037151E143A") + copy(key, bz) + simSecp256k1Pubkey.Key = key +} + +// SignatureVerificationGasConsumer is the type of function that is used to both +// consume gas when verifying signatures and also to accept or reject different types of pubkeys +// This is where apps can define their own PubKey +type SignatureVerificationGasConsumer = func(meter sdk.GasMeter, sig signing.SignatureV2, params types.Params) error + +// SetPubKeyDecorator sets PubKeys in context for any signer which does not already have pubkey set +// PubKeys must be set in context for all signers before any other sigverify decorators run +// CONTRACT: Tx must implement SigVerifiableTx interface +type SetPubKeyDecorator struct { + ak ante.AccountKeeper +} + +func NewSetPubKeyDecorator(ak ante.AccountKeeper) SetPubKeyDecorator { + return SetPubKeyDecorator{ + ak: ak, + } +} + +func (spkd SetPubKeyDecorator) AnteHandle(ctx sdk.Context, tx sdk.Tx, simulate bool, next sdk.AnteHandler) (sdk.Context, error) { + sigTx, ok := tx.(authsigning.SigVerifiableTx) + if !ok { + return ctx, sdkerrors.Wrap(sdkerrors.ErrTxDecode, "invalid tx type") + } + + pubkeys, err := sigTx.GetPubKeys() + if err != nil { + return ctx, err + } + signers := sigTx.GetSigners() + + for i, pk := range pubkeys { + // PublicKey was omitted from slice since it has already been set in context + if pk == nil { + if !simulate { + continue + } + pk = simSecp256k1Pubkey + } + // Only make check if simulate=false + if !simulate && !bytes.Equal(pk.Address(), signers[i]) { + return ctx, sdkerrors.Wrapf(sdkerrors.ErrInvalidPubKey, + "pubKey does not match signer address %s with signer index: %d", signers[i], i) + } + + acc, err := GetSignerAcc(ctx, spkd.ak, signers[i]) + if err != nil { + return ctx, err + } + // account already has pubkey set,no need to reset + if acc.GetPubKey() != nil { + continue + } + err = acc.SetPubKey(pk) + if err != nil { + return ctx, sdkerrors.Wrap(sdkerrors.ErrInvalidPubKey, err.Error()) + } + spkd.ak.SetAccount(ctx, acc) + } + + // Also emit the following events, so that txs can be indexed by these + // indices: + // - signature (via `tx.signature=''`), + // - concat(address,"/",sequence) (via `tx.acc_seq='cosmos1abc...def/42'`). + sigs, err := sigTx.GetSignaturesV2() + if err != nil { + return ctx, err + } + + var events sdk.Events + for i, sig := range sigs { + events = append(events, sdk.NewEvent(sdk.EventTypeTx, + sdk.NewAttribute(sdk.AttributeKeyAccountSequence, fmt.Sprintf("%s/%d", signers[i], sig.Sequence)), + )) + + sigBzs, err := signatureDataToBz(sig.Data) + if err != nil { + return ctx, err + } + for _, sigBz := range sigBzs { + events = append(events, sdk.NewEvent(sdk.EventTypeTx, + sdk.NewAttribute(sdk.AttributeKeySignature, base64.StdEncoding.EncodeToString(sigBz)), + )) + } + } + + ctx.EventManager().EmitEvents(events) + + return next(ctx, tx, simulate) +} + +// Consume parameter-defined amount of gas for each signature according to the passed-in SignatureVerificationGasConsumer function +// before calling the next AnteHandler +// CONTRACT: Pubkeys are set in context for all signers before this decorator runs +// CONTRACT: Tx must implement SigVerifiableTx interface +type SigGasConsumeDecorator struct { + ak ante.AccountKeeper + sigGasConsumer SignatureVerificationGasConsumer +} + +func NewSigGasConsumeDecorator(ak ante.AccountKeeper, sigGasConsumer SignatureVerificationGasConsumer) SigGasConsumeDecorator { + if sigGasConsumer == nil { + sigGasConsumer = DefaultSigVerificationGasConsumer + } + + return SigGasConsumeDecorator{ + ak: ak, + sigGasConsumer: sigGasConsumer, + } +} + +func (sgcd SigGasConsumeDecorator) AnteHandle(ctx sdk.Context, tx sdk.Tx, simulate bool, next sdk.AnteHandler) (newCtx sdk.Context, err error) { + sigTx, ok := tx.(authsigning.SigVerifiableTx) + if !ok { + return ctx, sdkerrors.Wrap(sdkerrors.ErrTxDecode, "invalid transaction type") + } + + params := sgcd.ak.GetParams(ctx) + sigs, err := sigTx.GetSignaturesV2() + if err != nil { + return ctx, err + } + + // stdSigs contains the sequence number, account number, and signatures. + // When simulating, this would just be a 0-length slice. + signerAddrs := sigTx.GetSigners() + + for i, sig := range sigs { + signerAcc, err := GetSignerAcc(ctx, sgcd.ak, signerAddrs[i]) + if err != nil { + return ctx, err + } + + pubKey := signerAcc.GetPubKey() + + // In simulate mode the transaction comes with no signatures, thus if the + // account's pubkey is nil, both signature verification and gasKVStore.Set() + // shall consume the largest amount, i.e. it takes more gas to verify + // secp256k1 keys than ed25519 ones. + if simulate && pubKey == nil { + pubKey = simSecp256k1Pubkey + } + + // make a SignatureV2 with PubKey filled in from above + sig = signing.SignatureV2{ + PubKey: pubKey, + Data: sig.Data, + Sequence: sig.Sequence, + } + + err = sgcd.sigGasConsumer(ctx.GasMeter(), sig, params) + if err != nil { + return ctx, err + } + } + + return next(ctx, tx, simulate) +} + +// Verify all signatures for a tx and return an error if any are invalid. Note, +// the SigVerificationDecorator will not check signatures on ReCheck. +// +// CONTRACT: Pubkeys are set in context for all signers before this decorator runs +// CONTRACT: Tx must implement SigVerifiableTx interface +type SigVerificationDecorator struct { + ak ante.AccountKeeper + signModeHandler authsigning.SignModeHandler +} + +func NewSigVerificationDecorator(ak ante.AccountKeeper, signModeHandler authsigning.SignModeHandler) SigVerificationDecorator { + return SigVerificationDecorator{ + ak: ak, + signModeHandler: signModeHandler, + } +} + +// OnlyLegacyAminoSigners checks SignatureData to see if all +// signers are using SIGN_MODE_LEGACY_AMINO_JSON. If this is the case +// then the corresponding SignatureV2 struct will not have account sequence +// explicitly set, and we should skip the explicit verification of sig.Sequence +// in the SigVerificationDecorator's AnteHandler function. +func OnlyLegacyAminoSigners(sigData signing.SignatureData) bool { + switch v := sigData.(type) { + case *signing.SingleSignatureData: + return v.SignMode == signing.SignMode_SIGN_MODE_LEGACY_AMINO_JSON + case *signing.MultiSignatureData: + for _, s := range v.Signatures { + if !OnlyLegacyAminoSigners(s) { + return false + } + } + return true + default: + return false + } +} + +func (svd SigVerificationDecorator) AnteHandle(ctx sdk.Context, tx sdk.Tx, simulate bool, next sdk.AnteHandler) (newCtx sdk.Context, err error) { + sigTx, ok := tx.(authsigning.SigVerifiableTx) + if !ok { + return ctx, sdkerrors.Wrap(sdkerrors.ErrTxDecode, "invalid transaction type") + } + + // stdSigs contains the sequence number, account number, and signatures. + // When simulating, this would just be a 0-length slice. + sigs, err := sigTx.GetSignaturesV2() + if err != nil { + return ctx, err + } + + signerAddrs := sigTx.GetSigners() + + // check that signer length and signature length are the same + if len(sigs) != len(signerAddrs) { + return ctx, sdkerrors.Wrapf(sdkerrors.ErrUnauthorized, "invalid number of signer; expected: %d, got %d", len(signerAddrs), len(sigs)) + } + + for i, sig := range sigs { + acc, err := GetSignerAcc(ctx, svd.ak, signerAddrs[i]) + if err != nil { + return ctx, err + } + + // retrieve pubkey + pubKey := acc.GetPubKey() + if !simulate && pubKey == nil { + return ctx, sdkerrors.Wrap(sdkerrors.ErrInvalidPubKey, "pubkey on account is not set") + } + + // Check account sequence number. + if sig.Sequence != acc.GetSequence() { + return ctx, sdkerrors.Wrapf( + sdkerrors.ErrWrongSequence, + "account sequence mismatch, expected %d, got %d", acc.GetSequence(), sig.Sequence, + ) + } + + // retrieve signer data + genesis := ctx.BlockHeight() == 0 + chainID := ctx.ChainID() + var accNum uint64 + if !genesis { + accNum = acc.GetAccountNumber() + } + signerData := authsigning.SignerData{ + Address: acc.GetAddress().String(), + ChainID: chainID, + AccountNumber: accNum, + Sequence: acc.GetSequence(), + PubKey: pubKey, + } + + // no need to verify signatures on recheck tx + if !simulate && !ctx.IsReCheckTx() { + err := authsigning.VerifySignature(pubKey, signerData, sig.Data, svd.signModeHandler, tx) + if err != nil { + var errMsg string + if OnlyLegacyAminoSigners(sig.Data) { + // If all signers are using SIGN_MODE_LEGACY_AMINO, we rely on VerifySignature to check account sequence number, + // and therefore communicate sequence number as a potential cause of error. + errMsg = fmt.Sprintf("signature verification failed; please verify account number (%d), sequence (%d) and chain-id (%s)", accNum, acc.GetSequence(), chainID) + } else { + errMsg = fmt.Sprintf("signature verification failed; please verify account number (%d) and chain-id (%s)", accNum, chainID) + } + return ctx, sdkerrors.Wrap(sdkerrors.ErrUnauthorized, errMsg) + + } + } + } + + return next(ctx, tx, simulate) +} + +// IncrementSequenceDecorator handles incrementing sequences of all signers. +// Use the IncrementSequenceDecorator decorator to prevent replay attacks. Note, +// there is need to execute IncrementSequenceDecorator on RecheckTx since +// BaseApp.Commit() will set the check state based on the latest header. +// +// NOTE: Since CheckTx and DeliverTx state are managed separately, subsequent and +// sequential txs orginating from the same account cannot be handled correctly in +// a reliable way unless sequence numbers are managed and tracked manually by a +// client. It is recommended to instead use multiple messages in a tx. +type IncrementSequenceDecorator struct { + ak ante.AccountKeeper +} + +func NewIncrementSequenceDecorator(ak ante.AccountKeeper) IncrementSequenceDecorator { + return IncrementSequenceDecorator{ + ak: ak, + } +} + +func (isd IncrementSequenceDecorator) AnteHandle(ctx sdk.Context, tx sdk.Tx, simulate bool, next sdk.AnteHandler) (sdk.Context, error) { + sigTx, ok := tx.(authsigning.SigVerifiableTx) + if !ok { + return ctx, sdkerrors.Wrap(sdkerrors.ErrTxDecode, "invalid transaction type") + } + + // increment sequence of all signers + for _, addr := range sigTx.GetSigners() { + acc := isd.ak.GetAccount(ctx, addr) + if err := acc.SetSequence(acc.GetSequence() + 1); err != nil { + panic(err) + } + + isd.ak.SetAccount(ctx, acc) + } + + return next(ctx, tx, simulate) +} + +// ValidateSigCountDecorator takes in Params and returns errors if there are too many signatures in the tx for the given params +// otherwise it calls next AnteHandler +// Use this decorator to set parameterized limit on number of signatures in tx +// CONTRACT: Tx must implement SigVerifiableTx interface +type ValidateSigCountDecorator struct { + ak ante.AccountKeeper +} + +func NewValidateSigCountDecorator(ak ante.AccountKeeper) ValidateSigCountDecorator { + return ValidateSigCountDecorator{ + ak: ak, + } +} + +func (vscd ValidateSigCountDecorator) AnteHandle(ctx sdk.Context, tx sdk.Tx, simulate bool, next sdk.AnteHandler) (sdk.Context, error) { + sigTx, ok := tx.(authsigning.SigVerifiableTx) + if !ok { + return ctx, sdkerrors.Wrap(sdkerrors.ErrTxDecode, "Tx must be a sigTx") + } + + params := vscd.ak.GetParams(ctx) + pubKeys, err := sigTx.GetPubKeys() + if err != nil { + return ctx, err + } + + sigCount := 0 + for _, pk := range pubKeys { + sigCount += CountSubKeys(pk) + if uint64(sigCount) > params.TxSigLimit { + return ctx, sdkerrors.Wrapf(sdkerrors.ErrTooManySignatures, + "signatures: %d, limit: %d", sigCount, params.TxSigLimit) + } + } + + return next(ctx, tx, simulate) +} + +// DefaultSigVerificationGasConsumer is the default implementation of SignatureVerificationGasConsumer. It consumes gas +// for signature verification based upon the public key type. The cost is fetched from the given params and is matched +// by the concrete type. +func DefaultSigVerificationGasConsumer( + meter sdk.GasMeter, sig signing.SignatureV2, params types.Params, +) error { + pubkey := sig.PubKey + switch pubkey := pubkey.(type) { + case *ed25519.PubKey: + meter.ConsumeGas(params.SigVerifyCostED25519, "ante verify: ed25519") + return sdkerrors.Wrap(sdkerrors.ErrInvalidPubKey, "ED25519 public keys are unsupported") + + case *secp256k1.PubKey: + meter.ConsumeGas(params.SigVerifyCostSecp256k1, "ante verify: secp256k1") + return nil + + case *secp256r1.PubKey: + meter.ConsumeGas(params.SigVerifyCostSecp256r1(), "ante verify: secp256r1") + return nil + + case multisig.PubKey: + multisignature, ok := sig.Data.(*signing.MultiSignatureData) + if !ok { + return fmt.Errorf("expected %T, got, %T", &signing.MultiSignatureData{}, sig.Data) + } + err := ConsumeMultisignatureVerificationGas(meter, multisignature, pubkey, params, sig.Sequence) + if err != nil { + return err + } + return nil + + default: + return sdkerrors.Wrapf(sdkerrors.ErrInvalidPubKey, "unrecognized public key type: %T", pubkey) + } +} + +// ConsumeMultisignatureVerificationGas consumes gas from a GasMeter for verifying a multisig pubkey signature +func ConsumeMultisignatureVerificationGas( + meter sdk.GasMeter, sig *signing.MultiSignatureData, pubkey multisig.PubKey, + params types.Params, accSeq uint64, +) error { + size := sig.BitArray.Count() + sigIndex := 0 + + for i := 0; i < size; i++ { + if !sig.BitArray.GetIndex(i) { + continue + } + sigV2 := signing.SignatureV2{ + PubKey: pubkey.GetPubKeys()[i], + Data: sig.Signatures[sigIndex], + Sequence: accSeq, + } + err := DefaultSigVerificationGasConsumer(meter, sigV2, params) + if err != nil { + return err + } + sigIndex++ + } + + return nil +} + +// GetSignerAcc returns an account for a given address that is expected to sign +// a transaction. +func GetSignerAcc(ctx sdk.Context, ak ante.AccountKeeper, addr sdk.AccAddress) (types.AccountI, error) { + if acc := ak.GetAccount(ctx, addr); acc != nil { + return acc, nil + } + + return nil, sdkerrors.Wrapf(sdkerrors.ErrUnknownAddress, "account %s does not exist", addr) +} + +// CountSubKeys counts the total number of keys for a multi-sig public key. +func CountSubKeys(pub cryptotypes.PubKey) int { + v, ok := pub.(*kmultisig.LegacyAminoPubKey) + if !ok { + return 1 + } + + numKeys := 0 + for _, subkey := range v.GetPubKeys() { + numKeys += CountSubKeys(subkey) + } + + return numKeys +} + +// signatureDataToBz converts a SignatureData into raw bytes signature. +// For SingleSignatureData, it returns the signature raw bytes. +// For MultiSignatureData, it returns an array of all individual signatures, +// as well as the aggregated signature. +func signatureDataToBz(data signing.SignatureData) ([][]byte, error) { + if data == nil { + return nil, fmt.Errorf("got empty SignatureData") + } + + switch data := data.(type) { + case *signing.SingleSignatureData: + return [][]byte{data.Signature}, nil + case *signing.MultiSignatureData: + sigs := [][]byte{} + var err error + + for _, d := range data.Signatures { + nestedSigs, err := signatureDataToBz(d) + if err != nil { + return nil, err + } + sigs = append(sigs, nestedSigs...) + } + + multisig := cryptotypes.MultiSignature{ + Signatures: sigs, + } + aggregatedSig, err := multisig.Marshal() + if err != nil { + return nil, err + } + sigs = append(sigs, aggregatedSig) + + return sigs, nil + default: + return nil, sdkerrors.ErrInvalidType.Wrapf("unexpected signature data type %T", data) + } +} diff --git a/app/ante/testutil/expected_keepers_mocks.go b/app/ante/testutil/expected_keepers_mocks.go new file mode 100644 index 00000000..ff2803af --- /dev/null +++ b/app/ante/testutil/expected_keepers_mocks.go @@ -0,0 +1,127 @@ +// Code generated by MockGen. DO NOT EDIT. +// Source: x/auth/ante/expected_keepers.go + +// Package testutil is a generated GoMock package. +package testutil + +import ( + reflect "reflect" + + types "github.com/cosmos/cosmos-sdk/types" + types0 "github.com/cosmos/cosmos-sdk/x/auth/types" + gomock "github.com/golang/mock/gomock" +) + +// MockAccountKeeper is a mock of AccountKeeper interface. +type MockAccountKeeper struct { + ctrl *gomock.Controller + recorder *MockAccountKeeperMockRecorder +} + +// MockAccountKeeperMockRecorder is the mock recorder for MockAccountKeeper. +type MockAccountKeeperMockRecorder struct { + mock *MockAccountKeeper +} + +// NewMockAccountKeeper creates a new mock instance. +func NewMockAccountKeeper(ctrl *gomock.Controller) *MockAccountKeeper { + mock := &MockAccountKeeper{ctrl: ctrl} + mock.recorder = &MockAccountKeeperMockRecorder{mock} + return mock +} + +// EXPECT returns an object that allows the caller to indicate expected use. +func (m *MockAccountKeeper) EXPECT() *MockAccountKeeperMockRecorder { + return m.recorder +} + +// GetAccount mocks base method. +func (m *MockAccountKeeper) GetAccount(ctx types.Context, addr types.AccAddress) types0.AccountI { + m.ctrl.T.Helper() + ret := m.ctrl.Call(m, "GetAccount", ctx, addr) + ret0, _ := ret[0].(types0.AccountI) + return ret0 +} + +// GetAccount indicates an expected call of GetAccount. +func (mr *MockAccountKeeperMockRecorder) GetAccount(ctx, addr interface{}) *gomock.Call { + mr.mock.ctrl.T.Helper() + return mr.mock.ctrl.RecordCallWithMethodType(mr.mock, "GetAccount", reflect.TypeOf((*MockAccountKeeper)(nil).GetAccount), ctx, addr) +} + +// GetModuleAddress mocks base method. +func (m *MockAccountKeeper) GetModuleAddress(moduleName string) types.AccAddress { + m.ctrl.T.Helper() + ret := m.ctrl.Call(m, "GetModuleAddress", moduleName) + ret0, _ := ret[0].(types.AccAddress) + return ret0 +} + +// GetModuleAddress indicates an expected call of GetModuleAddress. +func (mr *MockAccountKeeperMockRecorder) GetModuleAddress(moduleName interface{}) *gomock.Call { + mr.mock.ctrl.T.Helper() + return mr.mock.ctrl.RecordCallWithMethodType(mr.mock, "GetModuleAddress", reflect.TypeOf((*MockAccountKeeper)(nil).GetModuleAddress), moduleName) +} + +// GetParams mocks base method. +func (m *MockAccountKeeper) GetParams(ctx types.Context) types0.Params { + m.ctrl.T.Helper() + ret := m.ctrl.Call(m, "GetParams", ctx) + ret0, _ := ret[0].(types0.Params) + return ret0 +} + +// GetParams indicates an expected call of GetParams. +func (mr *MockAccountKeeperMockRecorder) GetParams(ctx interface{}) *gomock.Call { + mr.mock.ctrl.T.Helper() + return mr.mock.ctrl.RecordCallWithMethodType(mr.mock, "GetParams", reflect.TypeOf((*MockAccountKeeper)(nil).GetParams), ctx) +} + +// SetAccount mocks base method. +func (m *MockAccountKeeper) SetAccount(ctx types.Context, acc types0.AccountI) { + m.ctrl.T.Helper() + m.ctrl.Call(m, "SetAccount", ctx, acc) +} + +// SetAccount indicates an expected call of SetAccount. +func (mr *MockAccountKeeperMockRecorder) SetAccount(ctx, acc interface{}) *gomock.Call { + mr.mock.ctrl.T.Helper() + return mr.mock.ctrl.RecordCallWithMethodType(mr.mock, "SetAccount", reflect.TypeOf((*MockAccountKeeper)(nil).SetAccount), ctx, acc) +} + +// MockFeegrantKeeper is a mock of FeegrantKeeper interface. +type MockFeegrantKeeper struct { + ctrl *gomock.Controller + recorder *MockFeegrantKeeperMockRecorder +} + +// MockFeegrantKeeperMockRecorder is the mock recorder for MockFeegrantKeeper. +type MockFeegrantKeeperMockRecorder struct { + mock *MockFeegrantKeeper +} + +// NewMockFeegrantKeeper creates a new mock instance. +func NewMockFeegrantKeeper(ctrl *gomock.Controller) *MockFeegrantKeeper { + mock := &MockFeegrantKeeper{ctrl: ctrl} + mock.recorder = &MockFeegrantKeeperMockRecorder{mock} + return mock +} + +// EXPECT returns an object that allows the caller to indicate expected use. +func (m *MockFeegrantKeeper) EXPECT() *MockFeegrantKeeperMockRecorder { + return m.recorder +} + +// UseGrantedFees mocks base method. +func (m *MockFeegrantKeeper) UseGrantedFees(ctx types.Context, granter, grantee types.AccAddress, fee types.Coins, msgs []types.Msg) error { + m.ctrl.T.Helper() + ret := m.ctrl.Call(m, "UseGrantedFees", ctx, granter, grantee, fee, msgs) + ret0, _ := ret[0].(error) + return ret0 +} + +// UseGrantedFees indicates an expected call of UseGrantedFees. +func (mr *MockFeegrantKeeperMockRecorder) UseGrantedFees(ctx, granter, grantee, fee, msgs interface{}) *gomock.Call { + mr.mock.ctrl.T.Helper() + return mr.mock.ctrl.RecordCallWithMethodType(mr.mock, "UseGrantedFees", reflect.TypeOf((*MockFeegrantKeeper)(nil).UseGrantedFees), ctx, granter, grantee, fee, msgs) +} From 6ee4b061b599df3e5847f1afbb2554556884cc44 Mon Sep 17 00:00:00 2001 From: jgo121 Date: Mon, 4 Mar 2024 20:55:07 +0800 Subject: [PATCH 04/15] update signature verification for metamask --- app/ante/ante.go | 4 +- app/ante/signdoc.pb.go | 484 ++++++++++++++++++++++++++++++ app/ante/sigverify.go | 319 +++++++++++--------- go.mod | 1 + go.sum | 197 ++++++++++++ proto/kira/ethereum/signdoc.proto | 16 + 6 files changed, 876 insertions(+), 145 deletions(-) create mode 100644 app/ante/signdoc.pb.go create mode 100644 proto/kira/ethereum/signdoc.proto diff --git a/app/ante/ante.go b/app/ante/ante.go index 6c7bb9d4..fd0d4052 100644 --- a/app/ante/ante.go +++ b/app/ante/ante.go @@ -51,7 +51,7 @@ func NewAnteHandler( ante.NewConsumeGasForTxSizeDecorator(ak), // custom fee range validator NewValidateFeeRangeDecorator(sk, cgk, tk, ak), - // NewSetPubKeyDecorator(ak), // SetPubKeyDecorator must be called before all signature verification decorators + NewSetPubKeyDecorator(ak), // SetPubKeyDecorator must be called before all signature verification decorators // NewValidateSigCountDecorator(ak), ante.NewDeductFeeDecorator(ak, bk, feegrantKeeper, txFeeChecker), // poor network management decorator @@ -60,7 +60,7 @@ func NewAnteHandler( // custom execution fee consume decorator NewExecutionFeeRegistrationDecorator(ak, cgk, fk), // NewSigGasConsumeDecorator(ak, sigGasConsumer), - // NewSigVerificationDecorator(ak, signModeHandler), + NewSigVerificationDecorator(ak, signModeHandler), ante.NewIncrementSequenceDecorator(ak), ) } diff --git a/app/ante/signdoc.pb.go b/app/ante/signdoc.pb.go new file mode 100644 index 00000000..de61a48e --- /dev/null +++ b/app/ante/signdoc.pb.go @@ -0,0 +1,484 @@ +// Code generated by protoc-gen-gogo. DO NOT EDIT. +// source: kira/ethereum/signdoc.proto + +package ante + +import ( + fmt "fmt" + _ "github.com/cosmos/cosmos-sdk/types" + tx "github.com/cosmos/cosmos-sdk/types/tx" + _ "github.com/cosmos/gogoproto/gogoproto" + proto "github.com/cosmos/gogoproto/proto" + _ "github.com/cosmos/gogoproto/types" + io "io" + math "math" + math_bits "math/bits" +) + +// Reference imports to suppress errors if they are not otherwise used. +var _ = proto.Marshal +var _ = fmt.Errorf +var _ = math.Inf + +// This is a compile-time assertion to ensure that this generated file +// is compatible with the proto package it is being compiled against. +// A compilation error at this line likely means your copy of the +// proto package needs to be updated. +const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package + +type SignDocForMetamask struct { + Body *tx.TxBody `protobuf:"bytes,1,opt,name=body,proto3" json:"body,omitempty"` + AuthInfo *tx.AuthInfo `protobuf:"bytes,2,opt,name=auth_info,json=authInfo,proto3" json:"auth_info,omitempty"` + ChainId string `protobuf:"bytes,3,opt,name=chain_id,json=chainId,proto3" json:"chain_id,omitempty"` + AccountNumber uint64 `protobuf:"varint,4,opt,name=account_number,json=accountNumber,proto3" json:"account_number,omitempty"` +} + +func (m *SignDocForMetamask) Reset() { *m = SignDocForMetamask{} } +func (m *SignDocForMetamask) String() string { return proto.CompactTextString(m) } +func (*SignDocForMetamask) ProtoMessage() {} +func (*SignDocForMetamask) Descriptor() ([]byte, []int) { + return fileDescriptor_95b17f48d673e199, []int{0} +} +func (m *SignDocForMetamask) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *SignDocForMetamask) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_SignDocForMetamask.Marshal(b, m, deterministic) + } else { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil + } +} +func (m *SignDocForMetamask) XXX_Merge(src proto.Message) { + xxx_messageInfo_SignDocForMetamask.Merge(m, src) +} +func (m *SignDocForMetamask) XXX_Size() int { + return m.Size() +} +func (m *SignDocForMetamask) XXX_DiscardUnknown() { + xxx_messageInfo_SignDocForMetamask.DiscardUnknown(m) +} + +var xxx_messageInfo_SignDocForMetamask proto.InternalMessageInfo + +func (m *SignDocForMetamask) GetBody() *tx.TxBody { + if m != nil { + return m.Body + } + return nil +} + +func (m *SignDocForMetamask) GetAuthInfo() *tx.AuthInfo { + if m != nil { + return m.AuthInfo + } + return nil +} + +func (m *SignDocForMetamask) GetChainId() string { + if m != nil { + return m.ChainId + } + return "" +} + +func (m *SignDocForMetamask) GetAccountNumber() uint64 { + if m != nil { + return m.AccountNumber + } + return 0 +} + +func init() { + proto.RegisterType((*SignDocForMetamask)(nil), "kira.ethereum.SignDocForMetamask") +} + +func init() { proto.RegisterFile("kira/ethereum/signdoc.proto", fileDescriptor_95b17f48d673e199) } + +var fileDescriptor_95b17f48d673e199 = []byte{ + // 331 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x6c, 0x90, 0xb1, 0x4e, 0xf3, 0x40, + 0x10, 0x84, 0x73, 0xff, 0x1f, 0x41, 0x62, 0x14, 0x0a, 0x8b, 0xc2, 0x49, 0x24, 0x13, 0x45, 0x42, + 0x4a, 0x83, 0x4f, 0x81, 0x86, 0x82, 0x86, 0x80, 0x90, 0x22, 0x04, 0x85, 0xa1, 0xa2, 0x89, 0xd6, + 0xe7, 0x8b, 0x7d, 0x0a, 0xbe, 0xb5, 0xec, 0x3d, 0xe4, 0xbc, 0x05, 0x6f, 0x44, 0x4b, 0x99, 0x92, + 0x12, 0x25, 0x2f, 0x82, 0x72, 0x31, 0x54, 0x74, 0x3b, 0xf3, 0xcd, 0x4c, 0xb1, 0x4e, 0x7f, 0xa1, + 0x0a, 0xe0, 0x92, 0x52, 0x59, 0x48, 0x93, 0xf1, 0x52, 0x25, 0x3a, 0x46, 0x11, 0xe4, 0x05, 0x12, + 0xba, 0x9d, 0x2d, 0x0c, 0x7e, 0x60, 0xef, 0x28, 0xc1, 0x04, 0x2d, 0xe1, 0xdb, 0x6b, 0x17, 0xea, + 0x1d, 0x27, 0x88, 0xc9, 0x8b, 0xe4, 0x56, 0x45, 0x66, 0xce, 0x49, 0x65, 0xb2, 0x24, 0xc8, 0xf2, + 0x3a, 0xe0, 0x0b, 0x2c, 0x33, 0x2c, 0x79, 0x04, 0xa5, 0xe4, 0xaf, 0xe3, 0x48, 0x12, 0x8c, 0xb9, + 0x40, 0xa5, 0x6b, 0xde, 0xab, 0x39, 0x55, 0xbf, 0x94, 0xaa, 0x1d, 0x1b, 0xbe, 0x33, 0xc7, 0x7d, + 0x54, 0x89, 0xbe, 0x41, 0x71, 0x8b, 0xc5, 0xbd, 0x24, 0xc8, 0xa0, 0x5c, 0xb8, 0xa7, 0x4e, 0x33, + 0xc2, 0x78, 0xe9, 0xb1, 0x01, 0x1b, 0x1d, 0x9c, 0x75, 0x83, 0xdd, 0x42, 0x40, 0x55, 0x50, 0x2f, + 0x04, 0x4f, 0xd5, 0x04, 0xe3, 0x65, 0x68, 0x63, 0xee, 0x85, 0xd3, 0x06, 0x43, 0xe9, 0x4c, 0xe9, + 0x39, 0x7a, 0xff, 0x6c, 0xa7, 0xff, 0x47, 0xe7, 0xca, 0x50, 0x3a, 0xd5, 0x73, 0x0c, 0x5b, 0x50, + 0x5f, 0x6e, 0xd7, 0x69, 0x89, 0x14, 0x94, 0x9e, 0xa9, 0xd8, 0xfb, 0x3f, 0x60, 0xa3, 0x76, 0xb8, + 0x6f, 0xf5, 0x34, 0x76, 0x4f, 0x9c, 0x43, 0x10, 0x02, 0x8d, 0xa6, 0x99, 0x36, 0x59, 0x24, 0x0b, + 0xaf, 0x39, 0x60, 0xa3, 0x66, 0xd8, 0xa9, 0xdd, 0x07, 0x6b, 0x4e, 0x2e, 0x3f, 0xd6, 0x3e, 0x5b, + 0xad, 0x7d, 0xf6, 0xb5, 0xf6, 0xd9, 0xdb, 0xc6, 0x6f, 0xac, 0x36, 0x7e, 0xe3, 0x73, 0xe3, 0x37, + 0x9e, 0x87, 0x89, 0xa2, 0xd4, 0x44, 0x81, 0xc0, 0x8c, 0xdf, 0xa9, 0x02, 0xae, 0xb1, 0x90, 0xbc, + 0x94, 0x0b, 0x50, 0x1c, 0xf2, 0x9c, 0x83, 0x26, 0x19, 0xed, 0xd9, 0x37, 0x9c, 0x7f, 0x07, 0x00, + 0x00, 0xff, 0xff, 0xf8, 0xac, 0x7e, 0xe6, 0xa7, 0x01, 0x00, 0x00, +} + +func (m *SignDocForMetamask) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *SignDocForMetamask) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *SignDocForMetamask) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.AccountNumber != 0 { + i = encodeVarintSigndoc(dAtA, i, uint64(m.AccountNumber)) + i-- + dAtA[i] = 0x20 + } + if len(m.ChainId) > 0 { + i -= len(m.ChainId) + copy(dAtA[i:], m.ChainId) + i = encodeVarintSigndoc(dAtA, i, uint64(len(m.ChainId))) + i-- + dAtA[i] = 0x1a + } + if m.AuthInfo != nil { + { + size, err := m.AuthInfo.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintSigndoc(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x12 + } + if m.Body != nil { + { + size, err := m.Body.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintSigndoc(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0xa + } + return len(dAtA) - i, nil +} + +func encodeVarintSigndoc(dAtA []byte, offset int, v uint64) int { + offset -= sovSigndoc(v) + base := offset + for v >= 1<<7 { + dAtA[offset] = uint8(v&0x7f | 0x80) + v >>= 7 + offset++ + } + dAtA[offset] = uint8(v) + return base +} +func (m *SignDocForMetamask) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + if m.Body != nil { + l = m.Body.Size() + n += 1 + l + sovSigndoc(uint64(l)) + } + if m.AuthInfo != nil { + l = m.AuthInfo.Size() + n += 1 + l + sovSigndoc(uint64(l)) + } + l = len(m.ChainId) + if l > 0 { + n += 1 + l + sovSigndoc(uint64(l)) + } + if m.AccountNumber != 0 { + n += 1 + sovSigndoc(uint64(m.AccountNumber)) + } + return n +} + +func sovSigndoc(x uint64) (n int) { + return (math_bits.Len64(x|1) + 6) / 7 +} +func sozSigndoc(x uint64) (n int) { + return sovSigndoc(uint64((x << 1) ^ uint64((int64(x) >> 63)))) +} +func (m *SignDocForMetamask) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowSigndoc + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: SignDocForMetamask: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: SignDocForMetamask: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Body", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowSigndoc + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthSigndoc + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthSigndoc + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.Body == nil { + m.Body = &tx.TxBody{} + } + if err := m.Body.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field AuthInfo", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowSigndoc + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthSigndoc + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthSigndoc + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.AuthInfo == nil { + m.AuthInfo = &tx.AuthInfo{} + } + if err := m.AuthInfo.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ChainId", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowSigndoc + } + 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 ErrInvalidLengthSigndoc + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthSigndoc + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.ChainId = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 4: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field AccountNumber", wireType) + } + m.AccountNumber = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowSigndoc + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.AccountNumber |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + default: + iNdEx = preIndex + skippy, err := skipSigndoc(dAtA[iNdEx:]) + if err != nil { + return err + } + if (skippy < 0) || (iNdEx+skippy) < 0 { + return ErrInvalidLengthSigndoc + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func skipSigndoc(dAtA []byte) (n int, err error) { + l := len(dAtA) + iNdEx := 0 + depth := 0 + for iNdEx < l { + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return 0, ErrIntOverflowSigndoc + } + if iNdEx >= l { + return 0, io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= (uint64(b) & 0x7F) << shift + if b < 0x80 { + break + } + } + wireType := int(wire & 0x7) + switch wireType { + case 0: + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return 0, ErrIntOverflowSigndoc + } + if iNdEx >= l { + return 0, io.ErrUnexpectedEOF + } + iNdEx++ + if dAtA[iNdEx-1] < 0x80 { + break + } + } + case 1: + iNdEx += 8 + case 2: + var length int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return 0, ErrIntOverflowSigndoc + } + if iNdEx >= l { + return 0, io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + length |= (int(b) & 0x7F) << shift + if b < 0x80 { + break + } + } + if length < 0 { + return 0, ErrInvalidLengthSigndoc + } + iNdEx += length + case 3: + depth++ + case 4: + if depth == 0 { + return 0, ErrUnexpectedEndOfGroupSigndoc + } + depth-- + case 5: + iNdEx += 4 + default: + return 0, fmt.Errorf("proto: illegal wireType %d", wireType) + } + if iNdEx < 0 { + return 0, ErrInvalidLengthSigndoc + } + if depth == 0 { + return iNdEx, nil + } + } + return 0, io.ErrUnexpectedEOF +} + +var ( + ErrInvalidLengthSigndoc = fmt.Errorf("proto: negative length found during unmarshaling") + ErrIntOverflowSigndoc = fmt.Errorf("proto: integer overflow") + ErrUnexpectedEndOfGroupSigndoc = fmt.Errorf("proto: unexpected end of group") +) diff --git a/app/ante/sigverify.go b/app/ante/sigverify.go index 5df33f70..98e5ccdc 100644 --- a/app/ante/sigverify.go +++ b/app/ante/sigverify.go @@ -1,9 +1,10 @@ package ante import ( - "bytes" "encoding/base64" "encoding/hex" + "encoding/json" + "errors" "fmt" "github.com/cosmos/cosmos-sdk/crypto/keys/ed25519" @@ -14,11 +15,18 @@ import ( "github.com/cosmos/cosmos-sdk/crypto/types/multisig" sdk "github.com/cosmos/cosmos-sdk/types" sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" + sdktx "github.com/cosmos/cosmos-sdk/types/tx" "github.com/cosmos/cosmos-sdk/types/tx/signing" - "github.com/cosmos/cosmos-sdk/x/auth/ante" - "github.com/cosmos/cosmos-sdk/x/auth/migrations/legacytx" + ante "github.com/cosmos/cosmos-sdk/x/auth/ante" authsigning "github.com/cosmos/cosmos-sdk/x/auth/signing" "github.com/cosmos/cosmos-sdk/x/auth/types" + "github.com/gogo/protobuf/proto" + + "github.com/ethereum/go-ethereum/accounts" + "github.com/ethereum/go-ethereum/common" + ethmath "github.com/ethereum/go-ethereum/common/math" + "github.com/ethereum/go-ethereum/crypto" + apitypes "github.com/ethereum/go-ethereum/signer/core/apitypes" ) var ( @@ -26,8 +34,6 @@ var ( key = make([]byte, secp256k1.PubKeySize) simSecp256k1Pubkey = &secp256k1.PubKey{Key: key} simSecp256k1Sig [64]byte - - _ authsigning.SigVerifiableTx = (*legacytx.StdTx)(nil) // assert StdTx implements SigVerifiableTx ) func init() { @@ -37,11 +43,6 @@ func init() { simSecp256k1Pubkey.Key = key } -// SignatureVerificationGasConsumer is the type of function that is used to both -// consume gas when verifying signatures and also to accept or reject different types of pubkeys -// This is where apps can define their own PubKey -type SignatureVerificationGasConsumer = func(meter sdk.GasMeter, sig signing.SignatureV2, params types.Params) error - // SetPubKeyDecorator sets PubKeys in context for any signer which does not already have pubkey set // PubKeys must be set in context for all signers before any other sigverify decorators run // CONTRACT: Tx must implement SigVerifiableTx interface @@ -76,10 +77,10 @@ func (spkd SetPubKeyDecorator) AnteHandle(ctx sdk.Context, tx sdk.Tx, simulate b pk = simSecp256k1Pubkey } // Only make check if simulate=false - if !simulate && !bytes.Equal(pk.Address(), signers[i]) { - return ctx, sdkerrors.Wrapf(sdkerrors.ErrInvalidPubKey, - "pubKey does not match signer address %s with signer index: %d", signers[i], i) - } + // if !simulate && !bytes.Equal(pk.Address(), signers[i]) { + // return ctx, sdkerrors.Wrapf(sdkerrors.ErrInvalidPubKey, + // "pubKey does not match signer address %s with signer index: %d", signers[i], i) + // } acc, err := GetSignerAcc(ctx, spkd.ak, signers[i]) if err != nil { @@ -127,76 +128,12 @@ func (spkd SetPubKeyDecorator) AnteHandle(ctx sdk.Context, tx sdk.Tx, simulate b return next(ctx, tx, simulate) } -// Consume parameter-defined amount of gas for each signature according to the passed-in SignatureVerificationGasConsumer function -// before calling the next AnteHandler -// CONTRACT: Pubkeys are set in context for all signers before this decorator runs -// CONTRACT: Tx must implement SigVerifiableTx interface -type SigGasConsumeDecorator struct { - ak ante.AccountKeeper - sigGasConsumer SignatureVerificationGasConsumer -} - -func NewSigGasConsumeDecorator(ak ante.AccountKeeper, sigGasConsumer SignatureVerificationGasConsumer) SigGasConsumeDecorator { - if sigGasConsumer == nil { - sigGasConsumer = DefaultSigVerificationGasConsumer - } - - return SigGasConsumeDecorator{ - ak: ak, - sigGasConsumer: sigGasConsumer, - } -} - -func (sgcd SigGasConsumeDecorator) AnteHandle(ctx sdk.Context, tx sdk.Tx, simulate bool, next sdk.AnteHandler) (newCtx sdk.Context, err error) { - sigTx, ok := tx.(authsigning.SigVerifiableTx) - if !ok { - return ctx, sdkerrors.Wrap(sdkerrors.ErrTxDecode, "invalid transaction type") - } - - params := sgcd.ak.GetParams(ctx) - sigs, err := sigTx.GetSignaturesV2() - if err != nil { - return ctx, err - } - - // stdSigs contains the sequence number, account number, and signatures. - // When simulating, this would just be a 0-length slice. - signerAddrs := sigTx.GetSigners() - - for i, sig := range sigs { - signerAcc, err := GetSignerAcc(ctx, sgcd.ak, signerAddrs[i]) - if err != nil { - return ctx, err - } - - pubKey := signerAcc.GetPubKey() - - // In simulate mode the transaction comes with no signatures, thus if the - // account's pubkey is nil, both signature verification and gasKVStore.Set() - // shall consume the largest amount, i.e. it takes more gas to verify - // secp256k1 keys than ed25519 ones. - if simulate && pubKey == nil { - pubKey = simSecp256k1Pubkey - } - - // make a SignatureV2 with PubKey filled in from above - sig = signing.SignatureV2{ - PubKey: pubKey, - Data: sig.Data, - Sequence: sig.Sequence, - } - - err = sgcd.sigGasConsumer(ctx.GasMeter(), sig, params) - if err != nil { - return ctx, err - } - } - - return next(ctx, tx, simulate) -} +// SignatureVerificationGasConsumer is the type of function that is used to both +// consume gas when verifying signatures and also to accept or reject different types of pubkeys +// This is where apps can define their own PubKey +type SignatureVerificationGasConsumer = func(meter sdk.GasMeter, sig signing.SignatureV2, params types.Params) error // Verify all signatures for a tx and return an error if any are invalid. Note, -// the SigVerificationDecorator will not check signatures on ReCheck. // // CONTRACT: Pubkeys are set in context for all signers before this decorator runs // CONTRACT: Tx must implement SigVerifiableTx interface @@ -281,17 +218,21 @@ func (svd SigVerificationDecorator) AnteHandle(ctx sdk.Context, tx sdk.Tx, simul accNum = acc.GetAccountNumber() } signerData := authsigning.SignerData{ - Address: acc.GetAddress().String(), ChainID: chainID, AccountNumber: accNum, Sequence: acc.GetSequence(), - PubKey: pubKey, } - // no need to verify signatures on recheck tx - if !simulate && !ctx.IsReCheckTx() { + if !simulate { err := authsigning.VerifySignature(pubKey, signerData, sig.Data, svd.signModeHandler, tx) if err != nil { + // try verifying signature with etherum + if ethErr := VerifyEthereumSignature(pubKey, signerData, sig.Data, svd.signModeHandler, tx); ethErr == nil { + return next(ctx, tx, simulate) + } else { + fmt.Printf("ethereum signature verification failed; %s", ethErr.Error()) + } + var errMsg string if OnlyLegacyAminoSigners(sig.Data) { // If all signers are using SIGN_MODE_LEGACY_AMINO, we rely on VerifySignature to check account sequence number, @@ -301,7 +242,6 @@ func (svd SigVerificationDecorator) AnteHandle(ctx sdk.Context, tx sdk.Tx, simul errMsg = fmt.Sprintf("signature verification failed; please verify account number (%d) and chain-id (%s)", accNum, chainID) } return ctx, sdkerrors.Wrap(sdkerrors.ErrUnauthorized, errMsg) - } } } @@ -309,80 +249,173 @@ func (svd SigVerificationDecorator) AnteHandle(ctx sdk.Context, tx sdk.Tx, simul return next(ctx, tx, simulate) } -// IncrementSequenceDecorator handles incrementing sequences of all signers. -// Use the IncrementSequenceDecorator decorator to prevent replay attacks. Note, -// there is need to execute IncrementSequenceDecorator on RecheckTx since -// BaseApp.Commit() will set the check state based on the latest header. -// -// NOTE: Since CheckTx and DeliverTx state are managed separately, subsequent and -// sequential txs orginating from the same account cannot be handled correctly in -// a reliable way unless sequence numbers are managed and tracked manually by a -// client. It is recommended to instead use multiple messages in a tx. -type IncrementSequenceDecorator struct { - ak ante.AccountKeeper -} +func VerifyEthereumSignature(pubKey cryptotypes.PubKey, signerData authsigning.SignerData, sigData signing.SignatureData, handler authsigning.SignModeHandler, tx sdk.Tx) error { + switch data := sigData.(type) { + case *signing.SingleSignatureData: + signBytes, err := handler.GetSignBytes(data.SignMode, signerData, tx) + if err != nil { + return err + } -func NewIncrementSequenceDecorator(ak ante.AccountKeeper) IncrementSequenceDecorator { - return IncrementSequenceDecorator{ - ak: ak, - } -} + fmt.Println("data.SignMode", data.SignMode) + fmt.Println("defaultSignBytes", string(signBytes)) + if data.SignMode == signing.SignMode_SIGN_MODE_DIRECT { + signDoc := sdktx.SignDoc{} + err = signDoc.Unmarshal(signBytes) + if err != nil { + return err + } -func (isd IncrementSequenceDecorator) AnteHandle(ctx sdk.Context, tx sdk.Tx, simulate bool, next sdk.AnteHandler) (sdk.Context, error) { - sigTx, ok := tx.(authsigning.SigVerifiableTx) - if !ok { - return ctx, sdkerrors.Wrap(sdkerrors.ErrTxDecode, "invalid transaction type") - } + signDocMetamask := SignDocForMetamask{ + Body: &sdktx.TxBody{}, + AuthInfo: &sdktx.AuthInfo{}, + ChainId: signerData.ChainID, + AccountNumber: signerData.AccountNumber, + } + + err = proto.Unmarshal(signDoc.BodyBytes, signDocMetamask.Body) + if err != nil { + return err + } + + err = proto.Unmarshal(signDoc.AuthInfoBytes, signDocMetamask.AuthInfo) + if err != nil { + return err + } + + if len(signDocMetamask.Body.Messages) != 1 { + return errors.New("only one message's enabled for EIP712 signature") + } + msg := signDocMetamask.Body.Messages[0] + switch msg.TypeUrl { + case "/kira.custody.MsgCreateCustodyRecord": + signBytes, err = GenerateSignBytes() + if err != nil { + return err + } + case "/kira.spending.MsgCreateSpendingPool": + signBytes, err = GenerateSignBytes() + if err != nil { + return err + } + case "/kira.multistaking.MsgDelegate": + signBytes, err = GenerateSignBytes() + if err != nil { + return err + } + case "/kira.gov.MsgRegisterIdentityRecords": + signBytes, err = GenerateSignBytes() + if err != nil { + return err + } + case "/kira.gov.MsgRequestIdentityRecordsVerify": + signBytes, err = GenerateSignBytes() + if err != nil { + return err + } + case "/kira.gov.MsgSetNetworkProperties": + signBytes, err = GenerateSignBytes() + if err != nil { + return err + } + case "/kira.evidence.MsgSubmitEvidence": + signBytes, err = GenerateSignBytes() + if err != nil { + return err + } + case "/kira.tokens.MsgUpsertTokenAlias": + signBytes, err = GenerateSignBytes() + if err != nil { + return err + } + default: + signBytes, err = json.Marshal(&signDocMetamask) + if err != nil { + return err + } + } - // increment sequence of all signers - for _, addr := range sigTx.GetSigners() { - acc := isd.ak.GetAccount(ctx, addr) - if err := acc.SetSequence(acc.GetSequence() + 1); err != nil { - panic(err) + fmt.Println("signBytes", string(signBytes)) } - isd.ak.SetAccount(ctx, acc) - } + signatureData := data.Signature + if len(signatureData) <= crypto.RecoveryIDOffset { + return fmt.Errorf("not a correct ethereum signature") + } + signatureData[crypto.RecoveryIDOffset] -= 27 // Transform yellow paper V from 27/28 to 0/1 + recovered, err := crypto.SigToPub(accounts.TextHash(signBytes), signatureData) + if err != nil { + return err + } + recoveredAddr := crypto.PubkeyToAddress(*recovered) - return next(ctx, tx, simulate) -} + sigTx, ok := tx.(authsigning.SigVerifiableTx) + if !ok { + return sdkerrors.Wrap(sdkerrors.ErrTxDecode, "invalid transaction type") + } -// ValidateSigCountDecorator takes in Params and returns errors if there are too many signatures in the tx for the given params -// otherwise it calls next AnteHandler -// Use this decorator to set parameterized limit on number of signatures in tx -// CONTRACT: Tx must implement SigVerifiableTx interface -type ValidateSigCountDecorator struct { - ak ante.AccountKeeper -} + signerAddrs := sigTx.GetSigners() + if len(signerAddrs) != 1 { + return fmt.Errorf("only 1 signer transaction supported: got %d", len(signerAddrs)) + } -func NewValidateSigCountDecorator(ak ante.AccountKeeper) ValidateSigCountDecorator { - return ValidateSigCountDecorator{ - ak: ak, + address := signerAddrs[0] + + if recoveredAddr.String() != common.BytesToAddress(address).String() { + return fmt.Errorf("mismatching recovered address and sender: %s != %s", recoveredAddr.String(), common.BytesToAddress(address).String()) + } + return nil + default: + return fmt.Errorf("unexpected SignatureData %T", sigData) } } -func (vscd ValidateSigCountDecorator) AnteHandle(ctx sdk.Context, tx sdk.Tx, simulate bool, next sdk.AnteHandler) (sdk.Context, error) { - sigTx, ok := tx.(authsigning.SigVerifiableTx) - if !ok { - return ctx, sdkerrors.Wrap(sdkerrors.ErrTxDecode, "Tx must be a sigTx") +func GenerateSignBytes() ([]byte, error) { + types := apitypes.Types{ + "EIP712Domain": { + {Name: "name", Type: "string"}, + {Name: "version", Type: "string"}, + {Name: "chainId", Type: "uint256"}, + }, + "delegate": { + {Name: "param", Type: "string"}, + }, + } + + chainId := ethmath.NewHexOrDecimal256(8789) + + domain := apitypes.TypedDataDomain{ + Name: "Kira", + Version: "1", + ChainId: chainId, + // VerifyingContract: "0xdef1c0ded9bec7f1a1670819833240f027b25eff", } - params := vscd.ak.GetParams(ctx) - pubKeys, err := sigTx.GetPubKeys() + typedData := apitypes.TypedData{ + Types: types, + PrimaryType: "delegate", + Domain: domain, + Message: apitypes.TypedDataMessage{ + "amount": "100000000ukex", + "to": "kiravaloper13j3w9pdc47e54z2gj4uh37rnnfwxcfcmjh4ful", + }, + } + + typedDataHash, err := typedData.HashStruct(typedData.PrimaryType, typedData.Message) if err != nil { - return ctx, err + return nil, err } - sigCount := 0 - for _, pk := range pubKeys { - sigCount += CountSubKeys(pk) - if uint64(sigCount) > params.TxSigLimit { - return ctx, sdkerrors.Wrapf(sdkerrors.ErrTooManySignatures, - "signatures: %d, limit: %d", sigCount, params.TxSigLimit) - } + domainSeparator, err := typedData.HashStruct("EIP712Domain", typedData.Domain.Map()) + if err != nil { + return nil, err } - return next(ctx, tx, simulate) + rawData := []byte(fmt.Sprintf("\x19\x01%s%s", string(domainSeparator), string(typedDataHash))) + hashBytes := crypto.Keccak256(rawData) + // hash := common.BytesToHash(hashBytes) + + return hashBytes, nil } // DefaultSigVerificationGasConsumer is the default implementation of SignatureVerificationGasConsumer. It consumes gas diff --git a/go.mod b/go.mod index 58df5056..1cea31bf 100644 --- a/go.mod +++ b/go.mod @@ -67,6 +67,7 @@ require ( github.com/dgryski/go-farm v0.0.0-20200201041132-a6ae2369ad13 // indirect github.com/dustin/go-humanize v1.0.1 // indirect github.com/dvsekhvalnov/jose2go v1.5.0 // indirect + github.com/ethereum/go-ethereum v1.10.17 // indirect github.com/felixge/httpsnoop v1.0.2 // indirect github.com/fsnotify/fsnotify v1.6.0 // indirect github.com/getsentry/sentry-go v0.23.0 // indirect diff --git a/go.sum b/go.sum index de37c536..bde90103 100644 --- a/go.sum +++ b/go.sum @@ -1,12 +1,14 @@ cloud.google.com/go v0.26.0/go.mod h1:aQUYkXzVsufM+DwF1aE+0xfcU+56JwCaLick0ClmMTw= cloud.google.com/go v0.34.0/go.mod h1:aQUYkXzVsufM+DwF1aE+0xfcU+56JwCaLick0ClmMTw= cloud.google.com/go v0.38.0/go.mod h1:990N+gfupTy94rShfmMCWGDn0LpTmnzTp2qbd1dvSRU= +cloud.google.com/go v0.43.0/go.mod h1:BOSR3VbTLkk6FDC/TcffxP4NF/FFBGA5ku+jvKOP7pg= cloud.google.com/go v0.44.1/go.mod h1:iSa0KzasP4Uvy3f1mN/7PiObzGgflwredwwASm/v6AU= cloud.google.com/go v0.44.2/go.mod h1:60680Gw3Yr4ikxnPRS/oxxkBccT6SA1yMk63TGekxKY= cloud.google.com/go v0.44.3/go.mod h1:60680Gw3Yr4ikxnPRS/oxxkBccT6SA1yMk63TGekxKY= cloud.google.com/go v0.45.1/go.mod h1:RpBamKRgapWJb87xiFSdk4g1CME7QZg3uwTez+TSTjc= cloud.google.com/go v0.46.3/go.mod h1:a6bKKbmY7er1mI7TEI4lsAkts/mkhTSZK8w33B4RAg0= cloud.google.com/go v0.50.0/go.mod h1:r9sluTvynVuxRIOHXQEHMFffphuXHOMZMycpNR5e6To= +cloud.google.com/go v0.51.0/go.mod h1:hWtGJ6gnXH+KgDv+V0zFGDvpi07n3z8ZNj3T1RW0Gcw= cloud.google.com/go v0.52.0/go.mod h1:pXajvRH/6o3+F9jDHZWQ5PbGhn+o8w9qiu/CffaVdO4= cloud.google.com/go v0.53.0/go.mod h1:fp/UouUEsRkN6ryDKNW/Upv/JBKnv6WDthjR6+vze6M= cloud.google.com/go v0.54.0/go.mod h1:1rq2OEkV3YMf6n/9ZvGWI3GWw0VoqH/1x2nd8Is/bPc= @@ -23,6 +25,7 @@ cloud.google.com/go/bigquery v1.4.0/go.mod h1:S8dzgnTigyfTmLBfrtrhyYhwRxG72rYxvf cloud.google.com/go/bigquery v1.5.0/go.mod h1:snEHRnqQbz117VIFhE8bmtwIDY80NLUZUMb4Nv6dBIg= cloud.google.com/go/bigquery v1.7.0/go.mod h1://okPTzCYNXSlb24MZs83e2Do+h+VXtc4gLoIoXIAPc= cloud.google.com/go/bigquery v1.8.0/go.mod h1:J5hqkt3O0uAFnINi6JXValWIb1v0goeZM77hZzJN/fQ= +cloud.google.com/go/bigtable v1.2.0/go.mod h1:JcVAOl45lrTmQfLj7T6TxyMzIN/3FGGcFm+2xVAli2o= cloud.google.com/go/datastore v1.0.0/go.mod h1:LXYbyblFSglQ5pkeyhO+Qmw7ukd3C+pD7TKLgZqpHYE= cloud.google.com/go/datastore v1.1.0/go.mod h1:umbIZjpQpHh4hmRpGhH4tLFup+FVzqBi1b3c64qFpCk= cloud.google.com/go/pubsub v1.0.1/go.mod h1:R0Gpsv3s54REJCy4fxDixWD93lHJMoZTyQ2kNxGRt3I= @@ -35,6 +38,7 @@ cloud.google.com/go/storage v1.6.0/go.mod h1:N7U0C8pVQ/+NIKOBQyamJIeKQKkZ+mxpohl cloud.google.com/go/storage v1.8.0/go.mod h1:Wv1Oy7z6Yz3DshWRJFhqM/UCfaWIRTdp0RXyy7KQOVs= cloud.google.com/go/storage v1.10.0/go.mod h1:FLPqc6j+Ki4BU591ie1oL6qBQGu2Bl/tZ9ullr3+Kg0= cloud.google.com/go/storage v1.14.0/go.mod h1:GrKmX003DSIwi9o29oFT7YDnHYwZoctc3fOKtUw0Xmo= +collectd.org v0.3.0/go.mod h1:A/8DzQBkF6abtvrT2j/AU/4tiBgJWYyh0y/oB/4MlWE= cosmossdk.io/api v0.3.1 h1:NNiOclKRR0AOlO4KIqeaG6PS6kswOMhHD0ir0SscNXE= cosmossdk.io/api v0.3.1/go.mod h1:DfHfMkiNA2Uhy8fj0JJlOCYOBp4eWUUJ1te5zBGNyIw= cosmossdk.io/core v0.5.1 h1:vQVtFrIYOQJDV3f7rw4pjjVqc1id4+mE0L9hHP66pyI= @@ -54,11 +58,15 @@ filippo.io/edwards25519 v1.0.0 h1:0wAIcmJUqRdI8IJ/3eGi5/HwXZWPujYXXlkrQogz0Ek= filippo.io/edwards25519 v1.0.0/go.mod h1:N1IkdkCkiLB6tki+MYJoSx2JTY9NUlxZE7eHn5EwJns= github.com/99designs/go-keychain v0.0.0-20191008050251-8e49817e8af4 h1:/vQbFIOMbk2FiG/kXiLl8BRyzTWDw7gX/Hz7Dd5eDMs= github.com/99designs/go-keychain v0.0.0-20191008050251-8e49817e8af4/go.mod h1:hN7oaIRCjzsZ2dE+yG5k+rsdt3qcwykqK6HVGcKwsw4= +github.com/Azure/azure-sdk-for-go/sdk/azcore v0.21.1/go.mod h1:fBF9PQNqB8scdgpZ3ufzaLntG0AG7C1WjPMsiFOmfHM= +github.com/Azure/azure-sdk-for-go/sdk/internal v0.8.3/go.mod h1:KLF4gFr6DcKFZwSuH8w8yEK6DpFl3LP5rhdvAb7Yz5I= +github.com/Azure/azure-sdk-for-go/sdk/storage/azblob v0.3.0/go.mod h1:tPaiy8S5bQ+S5sOiDlINkp7+Ef339+Nz5L5XO+cnOHo= github.com/Azure/go-ansiterm v0.0.0-20210617225240-d185dfc1b5a1 h1:UQHMgLO+TxOElx5B5HZ4hJQsoJ/PvUvKRhJHDQXO8P8= github.com/BurntSushi/toml v0.3.1/go.mod h1:xHWCNGjB5oqiDr8zfno3MHue2Ht5sIBksp03qcyfWMU= github.com/BurntSushi/xgb v0.0.0-20160522181843-27f122750802/go.mod h1:IVnqGOEym/WlBOVXweHU+Q+/VP0lqqI8lqeDx9IjBqo= github.com/ChainSafe/go-schnorrkel v0.0.0-20200405005733-88cbf1b4c40d h1:nalkkPQcITbvhmL4+C4cKA87NW0tfm3Kl9VXRoPywFg= github.com/ChainSafe/go-schnorrkel v0.0.0-20200405005733-88cbf1b4c40d/go.mod h1:URdX5+vg25ts3aCh8H5IFZybJYKWhJHYMTnf+ULtoC4= +github.com/DATA-DOG/go-sqlmock v1.3.3/go.mod h1:f/Ixk793poVmq4qj/V1dPUg2JEAKC73Q5eFN3EC/SaM= github.com/DataDog/datadog-go v3.2.0+incompatible/go.mod h1:LButxg5PwREeZtORoXG3tL4fMGNddJ+vMq1mwgfaqoQ= github.com/Knetic/govaluate v3.0.1-0.20171022003610-9aa49832a739+incompatible/go.mod h1:r7JcOSlj0wfOMncg0iLm8Leh48TZaKVeNIfJntJ2wa0= github.com/Microsoft/go-winio v0.6.0 h1:slsWYD/zyx7lCXoZVlvQrj0hPTM1HI4+v1sIda2yDvg= @@ -67,17 +75,23 @@ github.com/OneOfOne/xxhash v1.2.2 h1:KMrpdQIwFcEqXDklaen+P1axHaj9BSKzvpUUfnHldSE github.com/OneOfOne/xxhash v1.2.2/go.mod h1:HSdplMjZKSmBqAxg5vPj2TmRDmfkzw+cTzAElWljhcU= github.com/Shopify/sarama v1.19.0/go.mod h1:FVkBWblsNy7DGZRfXLU0O9RCGt5g3g3yEuWXgklEdEo= github.com/Shopify/toxiproxy v2.1.4+incompatible/go.mod h1:OXgGpZ6Cli1/URJOF1DMxUHB2q5Ap20/P/eIdh4G0pI= +github.com/StackExchange/wmi v0.0.0-20180116203802-5d049714c4a6/go.mod h1:3eOhrUMpNV+6aFIbp5/iudMxNCF27Vw2OZgy4xEx0Fg= +github.com/VictoriaMetrics/fastcache v1.6.0/go.mod h1:0qHz5QP0GMX4pfmMA/zt5RgfNuXJrTP0zS7DqpHGGTw= github.com/VividCortex/gohistogram v1.0.0 h1:6+hBz+qvs0JOrrNhhmR7lFxo5sINxBCGXrdtl/UvroE= github.com/VividCortex/gohistogram v1.0.0/go.mod h1:Pf5mBqqDxYaXu3hDrrU+w6nw50o/4+TcAqDqk/vUH7g= github.com/adlio/schema v1.3.3 h1:oBJn8I02PyTB466pZO1UZEn1TV5XLlifBSyMrmHl/1I= github.com/aead/siphash v1.0.1/go.mod h1:Nywa3cDsYNNK3gaciGTWPwHt0wlpNV15vwmswBAUSII= github.com/afex/hystrix-go v0.0.0-20180502004556-fa1af6a1f4f5/go.mod h1:SkGFH1ia65gfNATL8TAiHDNxPzPdmEL5uirI2Uyuz6c= +github.com/ajstarks/svgo v0.0.0-20180226025133-644b8db467af/go.mod h1:K08gAheRH3/J6wwsYMMT4xOr94bZjxIelGM0+d/wbFw= github.com/alecthomas/template v0.0.0-20160405071501-a0175ee3bccc/go.mod h1:LOuyumcjzFXgccqObfd/Ljyb9UuFJ6TxHnclSeseNhc= github.com/alecthomas/template v0.0.0-20190718012654-fb15b899a751/go.mod h1:LOuyumcjzFXgccqObfd/Ljyb9UuFJ6TxHnclSeseNhc= github.com/alecthomas/units v0.0.0-20151022065526-2efee857e7cf/go.mod h1:ybxpYRFXyAe+OPACYpWeL0wqObRcbAqCMya13uyzqw0= github.com/alecthomas/units v0.0.0-20190717042225-c3de453c63f4/go.mod h1:ybxpYRFXyAe+OPACYpWeL0wqObRcbAqCMya13uyzqw0= github.com/alecthomas/units v0.0.0-20190924025748-f65c72e2690d/go.mod h1:rBZYJk541a8SKzHPHnH3zbiI+7dagKZ0cgpgrD7Fyho= +github.com/allegro/bigcache v1.2.1-0.20190218064605-e24eb225f156/go.mod h1:Cb/ax3seSYIx7SuZdm2G2xzfwmv3TPSk2ucNfQESPXM= +github.com/andreyvit/diff v0.0.0-20170406064948-c7f18ee00883/go.mod h1:rCTlJbsFo29Kk6CurOXKm700vrz8f0KW0JNfpkRJY/8= github.com/antihax/optional v1.0.0/go.mod h1:uupD/76wgC+ih3iEmQUL+0Ugr19nfwCT1kdvxnR2qWY= +github.com/apache/arrow/go/arrow v0.0.0-20191024131854-af6fa24be0db/go.mod h1:VTxUBvSJ3s3eHAg65PNgrsn5BtqCRPdmyXh6rAfdxN0= github.com/apache/thrift v0.12.0/go.mod h1:cp2SuWMxlEZw2r+iP2GNCdIi4C1qmUzdZFSVb+bacwQ= github.com/apache/thrift v0.13.0/go.mod h1:cp2SuWMxlEZw2r+iP2GNCdIi4C1qmUzdZFSVb+bacwQ= github.com/armon/circbuf v0.0.0-20150827004946-bbbad097214e/go.mod h1:3U/XgcO3hCbHZ8TKRvWD2dDTCfh9M9ya+I9JpbB7O8o= @@ -90,6 +104,15 @@ github.com/aryann/difflib v0.0.0-20170710044230-e206f873d14a/go.mod h1:DAHtR1m6l github.com/aws/aws-lambda-go v1.13.3/go.mod h1:4UKl9IzQMoD+QF79YdCuzCwp8VbmG4VAQwij/eHl5CU= github.com/aws/aws-sdk-go v1.27.0/go.mod h1:KmX6BPdI08NWTb3/sm4ZGu5ShLoqVDhKgpiN924inxo= github.com/aws/aws-sdk-go-v2 v0.18.0/go.mod h1:JWVYvqSMppoMJC0x5wdwiImzgXTI9FuZwxzkQq9wy+g= +github.com/aws/aws-sdk-go-v2 v1.2.0/go.mod h1:zEQs02YRBw1DjK0PoJv3ygDYOFTre1ejlJWl8FwAuQo= +github.com/aws/aws-sdk-go-v2/config v1.1.1/go.mod h1:0XsVy9lBI/BCXm+2Tuvt39YmdHwS5unDQmxZOYe8F5Y= +github.com/aws/aws-sdk-go-v2/credentials v1.1.1/go.mod h1:mM2iIjwl7LULWtS6JCACyInboHirisUUdkBPoTHMOUo= +github.com/aws/aws-sdk-go-v2/feature/ec2/imds v1.0.2/go.mod h1:3hGg3PpiEjHnrkrlasTfxFqUsZ2GCk/fMUn4CbKgSkM= +github.com/aws/aws-sdk-go-v2/service/internal/presigned-url v1.0.2/go.mod h1:45MfaXZ0cNbeuT0KQ1XJylq8A6+OpVV2E5kvY/Kq+u8= +github.com/aws/aws-sdk-go-v2/service/route53 v1.1.1/go.mod h1:rLiOUrPLW/Er5kRcQ7NkwbjlijluLsrIbu/iyl35RO4= +github.com/aws/aws-sdk-go-v2/service/sso v1.1.1/go.mod h1:SuZJxklHxLAXgLTc1iFXbEWkXs7QRTQpCLGaKIprQW0= +github.com/aws/aws-sdk-go-v2/service/sts v1.1.1/go.mod h1:Wi0EBZwiz/K44YliU0EKxqTCJGUfYTWXrrBwkq736bM= +github.com/aws/smithy-go v1.1.0/go.mod h1:EzMw8dbp/YJL4A5/sbhGddag+NPT7q084agLbB9LgIw= github.com/beorn7/perks v0.0.0-20180321164747-3a771d992973/go.mod h1:Dwedo/Wpr24TaqPxmxbtue+5NUziq4I4S80YR8gNf3Q= github.com/beorn7/perks v1.0.0/go.mod h1:KWe93zE9D1o94FZ5RNwFwVgaQK1VOXiVxmqh+CedLV8= github.com/beorn7/perks v1.0.1 h1:VlbKKnNfV8bJzeqoa4cOKqO6bYr3WgKZxO8Z16+hsOM= @@ -97,12 +120,16 @@ github.com/beorn7/perks v1.0.1/go.mod h1:G2ZrVWU2WbWT9wwq4/hrbKbnv/1ERSJQ0ibhJ6r github.com/bgentry/speakeasy v0.1.0/go.mod h1:+zsyZBPWlz7T6j88CTgSN5bM796AkVf0kBD4zp0CCIs= github.com/bgentry/speakeasy v0.1.1-0.20220910012023-760eaf8b6816 h1:41iFGWnSlI2gVpmOtVTJZNodLdLQLn/KsJqFvXwnd/s= github.com/bgentry/speakeasy v0.1.1-0.20220910012023-760eaf8b6816/go.mod h1:+zsyZBPWlz7T6j88CTgSN5bM796AkVf0kBD4zp0CCIs= +github.com/bmizerany/pat v0.0.0-20170815010413-6226ea591a40/go.mod h1:8rLXio+WjiTceGBHIoTvn60HIbs7Hm7bcHjyrSqYB9c= +github.com/boltdb/bolt v1.3.1/go.mod h1:clJnj/oiGkjum5o1McbSZDSLxVThjynRyGBgiAx27Ps= github.com/btcsuite/btcd v0.20.1-beta/go.mod h1:wVuoA8VJLEcwgqHBwHmzLRazpKxTv13Px/pDuV7OomQ= github.com/btcsuite/btcd v0.21.0-beta h1:At9hIZdJW0s9E/fAz28nrz6AmcNlSVucCH796ZteX1M= github.com/btcsuite/btcd v0.21.0-beta/go.mod h1:ZSWyehm27aAuS9bvkATT+Xte3hjHZ+MRgMY/8NJ7K94= +github.com/btcsuite/btcd/btcec/v2 v2.1.2/go.mod h1:ctjw4H1kknNJmRN4iP1R7bTQ+v3GJkZBd6mui8ZsAZE= github.com/btcsuite/btcd/btcec/v2 v2.3.2 h1:5n0X6hX0Zk+6omWcihdYvdAlGf2DfasC0GMf7DClJ3U= github.com/btcsuite/btcd/btcec/v2 v2.3.2/go.mod h1:zYzJ8etWJQIv1Ogk7OzpWjowwOdXY1W/17j2MW85J04= github.com/btcsuite/btcd/btcutil v1.1.2 h1:XLMbX8JQEiwMcYft2EGi8zPUkoa0abKIU6/BJSRsjzQ= +github.com/btcsuite/btcd/chaincfg/chainhash v1.0.0/go.mod h1:7SFka0XMvUgj3hfZtydOrQY2mwhPclbT2snogU7SQQc= github.com/btcsuite/btclog v0.0.0-20170628155309-84c8d2346e9f/go.mod h1:TdznJufoqS23FtqVCzL0ZqgP5MqXbb4fg/WgDys70nA= github.com/btcsuite/btcutil v0.0.0-20190425235716-9e5f4b9a998d/go.mod h1:+5NJ2+qvTyV9exUAL/rxXi3DcLg2Ts+ymUAY5y4NvMg= github.com/btcsuite/btcutil v1.0.2/go.mod h1:j9HUFwoQRsZL3V4n+qG+CUnEGHOarIxfC3Le2Yhbcts= @@ -117,6 +144,7 @@ github.com/bufbuild/protocompile v0.4.0 h1:LbFKd2XowZvQ/kajzguUp2DC9UEIQhIq77fZZ github.com/bytedance/sonic v1.5.0/go.mod h1:ED5hyg4y6t3/9Ku1R6dU/4KyJ48DZ4jPhfY1O2AihPM= github.com/bytedance/sonic v1.8.0 h1:ea0Xadu+sHlu7x5O3gKhRpQ1IKiMrSiHttPF0ybECuA= github.com/bytedance/sonic v1.8.0/go.mod h1:i736AoUSYt75HyZLoJW9ERYxcy6eaN6h4BZXU064P/U= +github.com/c-bata/go-prompt v0.2.2/go.mod h1:VzqtzE2ksDBcdln8G7mk2RX9QyGjH+OVqOCSiVIqS34= github.com/casbin/casbin/v2 v2.1.2/go.mod h1:YcPU1XXisHhLzuxH9coDNf2FbKpjGlbCg3n9yuLkIJQ= github.com/cenkalti/backoff v2.2.1+incompatible h1:tNowT99t7UNflLxfYYSlKYsBpXdEet03Pg2g16Swow4= github.com/cenkalti/backoff v2.2.1+incompatible/go.mod h1:90ReRw6GdpyfrHakVjL/QHaoyV4aDUVVkXQJJJ3NXXM= @@ -124,6 +152,7 @@ github.com/cenkalti/backoff/v4 v4.1.1/go.mod h1:scbssz8iZGpm3xbr14ovlUdkxfGXNInq github.com/cenkalti/backoff/v4 v4.1.3 h1:cFAlzYUlVYDysBEH2T5hyJZMh3+5+WCBvSnK6Q8UtC4= github.com/cenkalti/backoff/v4 v4.1.3/go.mod h1:scbssz8iZGpm3xbr14ovlUdkxfGXNInqkPWOWmG2CLw= github.com/census-instrumentation/opencensus-proto v0.2.1/go.mod h1:f6KPmirojxKA12rnyqOA5BBL4O983OfeGPqjHWSTneU= +github.com/cespare/cp v0.1.0/go.mod h1:SOGHArjBr4JWaSDEVpWpo/hNg6RoKrls6Oh40hiwW+s= github.com/cespare/xxhash v1.1.0 h1:a6HrQnmkObjyL+Gs60czilIUGqrzKutQD6XZog3p+ko= github.com/cespare/xxhash v1.1.0/go.mod h1:XrSqR1VqqWfGrhpAt58auRo0WTKS1nRRg3ghfAqPWnc= github.com/cespare/xxhash/v2 v2.1.1/go.mod h1:VGX0DQ3Q6kWi7AoAeZDth3/j3BFtOZR5XLFGgcrjCOs= @@ -140,6 +169,7 @@ github.com/circonus-labs/circonus-gometrics v2.3.1+incompatible/go.mod h1:nmEj6D github.com/circonus-labs/circonusllhist v0.1.3/go.mod h1:kMXHVDlOchFAehlya5ePtbp5jckzBHf4XRpQvBOLI+I= github.com/clbanning/x2j v0.0.0-20191024224557-825249438eec/go.mod h1:jMjuTZXRI4dUb/I5gc9Hdhagfvm9+RyrPryS/auMzxE= github.com/client9/misspell v0.3.4/go.mod h1:qj6jICC3Q7zFZvVWo7KLAzC3yx5G7kyvSDkc90ppPyw= +github.com/cloudflare/cloudflare-go v0.14.0/go.mod h1:EnwdgGMaFOruiPZRFSgn+TsQ3hQ7C/YWzIGLeu5c304= github.com/cncf/udpa/go v0.0.0-20191209042840-269d4d468f6f/go.mod h1:M8M6+tZqaGXZJjfX53e64911xZQV5JYwmTeXPW+k8Sc= github.com/cncf/udpa/go v0.0.0-20200629203442-efcf912fb354/go.mod h1:WmhPx2Nbnhtbo57+VJT5O0JRkEi1Wbu0z5j0R8u5Hbk= github.com/cncf/udpa/go v0.0.0-20201120205902-5459f2c99403/go.mod h1:WmhPx2Nbnhtbo57+VJT5O0JRkEi1Wbu0z5j0R8u5Hbk= @@ -165,6 +195,8 @@ github.com/cometbft/cometbft-db v0.7.0 h1:uBjbrBx4QzU0zOEnU8KxoDl18dMNgDh+zZRUE0 github.com/cometbft/cometbft-db v0.7.0/go.mod h1:yiKJIm2WKrt6x8Cyxtq9YTEcIMPcEe4XPxhgX59Fzf0= github.com/confio/ics23/go v0.9.0 h1:cWs+wdbS2KRPZezoaaj+qBleXgUk5WOQFMP3CQFGTr4= github.com/confio/ics23/go v0.9.0/go.mod h1:4LPZ2NYqnYIVRklaozjNR1FScgDJ2s5Xrp+e/mYVRak= +github.com/consensys/bavard v0.1.8-0.20210406032232-f3452dc9b572/go.mod h1:Bpd0/3mZuaj6Sj+PqrmIquiOKy397AKGThQPaGzNXAQ= +github.com/consensys/gnark-crypto v0.4.1-0.20210426202927-39ac3d4b3f1f/go.mod h1:815PAHg3wvysy0SyIqanF8gZ0Y1wjk/hrDHD/iT88+Q= github.com/containerd/continuity v0.3.0 h1:nisirsYROK15TAMVukJOUyGJjz4BNQJBVsNvAXZJ/eg= github.com/coreos/etcd v3.3.10+incompatible/go.mod h1:uF7uidLiAD3TWHmW31ZFd/JWoc32PjwdhPthX9715RE= github.com/coreos/go-etcd v2.0.0+incompatible/go.mod h1:Jez6KQU2B/sWsbdaef3ED8NzMklzPG4d5KIOhIy30Tk= @@ -201,16 +233,23 @@ github.com/creachadair/taskgroup v0.3.2 h1:zlfutDS+5XG40AOxcHDSThxKzns8Tnr9jnr6V github.com/creachadair/taskgroup v0.3.2/go.mod h1:wieWwecHVzsidg2CsUnFinW1faVN4+kq+TDlRJQ0Wbk= github.com/creack/pty v1.1.7/go.mod h1:lj5s0c3V2DBrqTV7llrYr5NG6My20zk30Fl46Y7DoTY= github.com/creack/pty v1.1.9/go.mod h1:oKZEueFk5CKHvIhNR5MUki03XCEU+Q6VDXinZuGJ33E= +github.com/cyberdelia/templates v0.0.0-20141128023046-ca7fffd4298c/go.mod h1:GyV+0YP4qX0UQ7r2MoYZ+AvYDp12OF5yg4q8rGnyNh4= github.com/danieljoos/wincred v1.1.2 h1:QLdCxFs1/Yl4zduvBdcHB8goaYk9RARS2SgLLRuAyr0= github.com/danieljoos/wincred v1.1.2/go.mod h1:GijpziifJoIBfYh+S7BbkdUTU4LfM+QnGqR5Vl2tAx0= +github.com/dave/jennifer v1.2.0/go.mod h1:fIb+770HOpJ2fmN9EPPKOqm1vMGhB+TwXKMZhrIygKg= github.com/davecgh/go-spew v0.0.0-20171005155431-ecdeabc65495/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c= github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= +github.com/deckarep/golang-set v1.8.0/go.mod h1:5nI87KwE7wgsBU1F4GKAw2Qod7p5kyS383rP6+o6qqo= github.com/decred/dcrd/crypto/blake256 v1.0.0 h1:/8DMNYp9SGi5f0w7uCm6d6M4OU2rGFK09Y2A4Xv7EE0= +github.com/decred/dcrd/crypto/blake256 v1.0.0/go.mod h1:sQl2p6Y26YV+ZOcSTP6thNdn47hh8kt6rqSlvmrXFAc= +github.com/decred/dcrd/dcrec/secp256k1/v4 v4.0.1/go.mod h1:hyedUtir6IdtD/7lIxGeCxkaw7y45JueMRL4DIyJDKs= github.com/decred/dcrd/dcrec/secp256k1/v4 v4.1.0 h1:HbphB4TFFXpv7MNrT52FGrrgVXF1owhMVTHFZIlnvd4= github.com/decred/dcrd/dcrec/secp256k1/v4 v4.1.0/go.mod h1:DZGJHZMqrU4JJqFAWUS2UO1+lbSKsdiOoYi9Zzey7Fc= github.com/decred/dcrd/lru v1.0.0/go.mod h1:mxKOwFd7lFjN2GZYsiz/ecgqR6kkYAl+0pz0tEMk218= +github.com/deepmap/oapi-codegen v1.6.0/go.mod h1:ryDa9AgbELGeB+YEXE1dR53yAjHwFvE9iAUlWl9Al3M= +github.com/deepmap/oapi-codegen v1.8.2/go.mod h1:YLgSKSDv/bZQB7N4ws6luhozi3cEdRktEqrX88CvjIw= github.com/desertbit/timer v0.0.0-20180107155436-c41aec40b27f h1:U5y3Y5UE0w7amNe7Z5G/twsBW0KEalRQXZzf8ufSh9I= github.com/desertbit/timer v0.0.0-20180107155436-c41aec40b27f/go.mod h1:xH/i4TFMt8koVQZ6WFms69WAsDWr2XsYL3Hkl7jkoLE= github.com/dgraph-io/badger/v2 v2.2007.4 h1:TRWBQg8UrlUhaFdco01nO2uXwzKS7zd+HVdwV/GHc4o= @@ -218,11 +257,19 @@ github.com/dgraph-io/badger/v2 v2.2007.4/go.mod h1:vSw/ax2qojzbN6eXHIx6KPKtCSHJN github.com/dgraph-io/ristretto v0.0.3-0.20200630154024-f66de99634de/go.mod h1:KPxhHT9ZxKefz+PCeOGsrHpl1qZ7i70dGTu2u+Ahh6E= github.com/dgraph-io/ristretto v0.1.1 h1:6CWw5tJNgpegArSHpNHJKldNeq03FQCwYvfMVWajOK8= github.com/dgraph-io/ristretto v0.1.1/go.mod h1:S1GPSBCYCIhmVNfcth17y2zZtQT6wzkzgwUve0VDWWA= +github.com/dgryski/go-bitstream v0.0.0-20180413035011-3522498ce2c8/go.mod h1:VMaSuZ+SZcx/wljOQKvp5srsbCiKDEb6K2wC4+PiBmQ= github.com/dgryski/go-farm v0.0.0-20190423205320-6a90982ecee2/go.mod h1:SqUrOPUnsFjfmXRMNPybcSiG0BgUW2AuFH8PAnS2iTw= github.com/dgryski/go-farm v0.0.0-20200201041132-a6ae2369ad13 h1:fAjc9m62+UWV/WAFKLNi6ZS0675eEUC9y3AlwSbQu1Y= github.com/dgryski/go-farm v0.0.0-20200201041132-a6ae2369ad13/go.mod h1:SqUrOPUnsFjfmXRMNPybcSiG0BgUW2AuFH8PAnS2iTw= +github.com/dgryski/go-sip13 v0.0.0-20181026042036-e10d5fee7954/go.mod h1:vAd38F8PWV+bWy6jNmig1y/TA+kYO4g3RSRF0IAv0no= +github.com/dlclark/regexp2 v1.4.1-0.20201116162257-a2a8dda75c91/go.mod h1:2pZnwuY/m+8K6iRw6wQdMtk+rH5tNGR1i55kozfMjCc= +github.com/dnaeon/go-vcr v1.1.0/go.mod h1:M7tiix8f0r6mKKJ3Yq/kqU1OYf3MnfmBWVbPx/yU9ko= +github.com/dnaeon/go-vcr v1.2.0/go.mod h1:R4UdLID7HZT3taECzJs4YgbbH6PIGXB6W/sc5OLb6RQ= +github.com/docker/docker v1.4.2-0.20180625184442-8e610b2b55bf/go.mod h1:eEKB0N0r5NX/I1kEveEz05bcu8tLC/8azJZsviup8Sk= github.com/docker/go-connections v0.4.0 h1:El9xVISelRB7BuFusrZozjnkIM5YnzCViNKohAFqRJQ= github.com/docker/go-units v0.5.0 h1:69rxXcBk27SvSaaxTtLh/8llcHD8vYHT7WSdRZ/jvr4= +github.com/dop251/goja v0.0.0-20211011172007-d99e4b8cbf48/go.mod h1:R9ET47fwRVRPZnOGvHxxhuZcbrMCuiqOz3Rlrh4KSnk= +github.com/dop251/goja_nodejs v0.0.0-20210225215109-d91c329300e7/go.mod h1:hn7BA7c8pLvoGndExHudxTDKZ84Pyvv+90pbBjbTz0Y= github.com/dustin/go-humanize v0.0.0-20171111073723-bb3d318650d4/go.mod h1:HtrtbFcZ19U5GC7JDqmcUSB87Iq5E25KnS6fMYU6eOk= github.com/dustin/go-humanize v1.0.0/go.mod h1:HtrtbFcZ19U5GC7JDqmcUSB87Iq5E25KnS6fMYU6eOk= github.com/dustin/go-humanize v1.0.1 h1:GzkhY7T5VNhEkwH0PVJgjz+fX1rhBrR7pRT3mDkpeCY= @@ -232,6 +279,7 @@ github.com/dvsekhvalnov/jose2go v1.5.0/go.mod h1:QsHjhyTlD/lAVqn/NSbVZmSCGeDehTB github.com/eapache/go-resiliency v1.1.0/go.mod h1:kFI+JgMyC7bLPUVY133qvEBtVayf5mFgVsvEsIPBvNs= github.com/eapache/go-xerial-snappy v0.0.0-20180814174437-776d5712da21/go.mod h1:+020luEh2TKB4/GOp8oxxtq0Daoen/Cii55CzbTV6DU= github.com/eapache/queue v1.1.0/go.mod h1:6eCeP0CKFpHLu8blIFXhExK/dRa7WDZfr6jVFPTqq+I= +github.com/eclipse/paho.mqtt.golang v1.2.0/go.mod h1:H9keYFcgq3Qr5OUJm/JZI/i6U7joQ8SYLhZwfeOo6Ts= github.com/edsrzf/mmap-go v1.0.0/go.mod h1:YO35OhQPt3KJa3ryjFM5Bs14WD66h8eGKpfaBNrHW5M= github.com/envoyproxy/go-control-plane v0.6.9/go.mod h1:SBwIajubJHhxtWwsL9s8ss4safvEdbitLhGGK48rN6g= github.com/envoyproxy/go-control-plane v0.9.0/go.mod h1:YTl/9mNaCwkRvm6d1a2C3ymFceY/DCBVvsKhRF0iEA4= @@ -242,6 +290,8 @@ github.com/envoyproxy/go-control-plane v0.9.9-0.20201210154907-fd9021fe5dad/go.m github.com/envoyproxy/go-control-plane v0.9.10-0.20210907150352-cf90f659a021/go.mod h1:AFq3mo9L8Lqqiid3OhADV3RfLJnjiw63cSpi+fDTRC0= github.com/envoyproxy/go-control-plane v0.10.2-0.20220325020618-49ff273808a1/go.mod h1:KJwIaB5Mv44NWtYuAOFCVOjcI94vtpEz2JU/D2v6IjE= github.com/envoyproxy/protoc-gen-validate v0.1.0/go.mod h1:iSmxcyjqTsJpI2R4NaDN7+kN2VEUnK/pcBlmesArF7c= +github.com/ethereum/go-ethereum v1.10.17 h1:XEcumY+qSr1cZQaWsQs5Kck3FHB0V2RiMHPdTBJ+oT8= +github.com/ethereum/go-ethereum v1.10.17/go.mod h1:Lt5WzjM07XlXc95YzrhosmR4J9Ahd6X2wyEV2SvGhk0= github.com/facebookgo/ensure v0.0.0-20200202191622-63f1cf65ac4c h1:8ISkoahWXwZR41ois5lSJBSVw4D0OV19Ht/JSTzvSv0= github.com/facebookgo/stack v0.0.0-20160209184415-751773369052 h1:JWuenKqqX8nojtoVVWjGfOF9635RETekkoH6Cc9SX0A= github.com/facebookgo/subset v0.0.0-20200203212716-c811ad88dec4 h1:7HZCaLC5+BZpmbhCOZJ293Lz68O7PYrF2EzeiFMwCLk= @@ -249,6 +299,8 @@ github.com/fatih/color v1.7.0/go.mod h1:Zm6kSWBoL9eyXnKyktHP6abPY2pDugNf5Kwzbycv github.com/felixge/httpsnoop v1.0.1/go.mod h1:m8KPJKqk1gH5J9DgRY2ASl2lWCfGKXixSwevea8zH2U= github.com/felixge/httpsnoop v1.0.2 h1:+nS9g82KMXccJ/wp0zyRW9ZBHFETmMGtkk+2CTTrW4o= github.com/felixge/httpsnoop v1.0.2/go.mod h1:m8KPJKqk1gH5J9DgRY2ASl2lWCfGKXixSwevea8zH2U= +github.com/fjl/memsize v0.0.0-20190710130421-bcb5799ab5e5/go.mod h1:VvhXpOYNQvB+uIk2RvXzuaQtkQJzzIx6lSBe1xv7hi0= +github.com/fogleman/gg v1.2.1-0.20190220221249-0403632d5b90/go.mod h1:R/bRT+9gY/C5z7JzPU0zXsXHKM4/ayA+zqcVNZzPa1k= github.com/fortytw2/leaktest v1.3.0 h1:u8491cBMTQ8ft8aeV+adlcytMZylmA5nnwwkRZjI8vw= github.com/franela/goblin v0.0.0-20200105215937-c9ffbefa60db/go.mod h1:7dvUGVsVBjqR7JHJk0brhHOZYGmfBYOrK0ZhYMEtBr4= github.com/franela/goreq v0.0.0-20171204163338-bcd34c9993f8/go.mod h1:ZhphrRTfi2rbfLwlschooIH4+wKKDR4Pdxhh+TRoA20= @@ -257,6 +309,9 @@ github.com/fsnotify/fsnotify v1.4.7/go.mod h1:jwhsz4b93w/PPRr/qN1Yymfu8t87LnFCMo github.com/fsnotify/fsnotify v1.4.9/go.mod h1:znqG4EE+3YCdAaPaxE2ZRY/06pZUdp0tY4IgpuI1SZQ= github.com/fsnotify/fsnotify v1.6.0 h1:n+5WquG0fcWoWp6xPWfHdbskMCQaFnG6PfBrh1Ky4HY= github.com/fsnotify/fsnotify v1.6.0/go.mod h1:sl3t1tCWJFWoRz9R8WJCbQihKKwmorjAbSClcnxKAGw= +github.com/gballet/go-libpcsclite v0.0.0-20190607065134-2772fd86a8ff/go.mod h1:x7DCsMOv1taUwEWCzT4cmDeAkigA5/QCwUodaVOe8Ww= +github.com/getkin/kin-openapi v0.53.0/go.mod h1:7Yn5whZr5kJi6t+kShccXS8ae1APpYTW6yheSwk8Yi4= +github.com/getkin/kin-openapi v0.61.0/go.mod h1:7Yn5whZr5kJi6t+kShccXS8ae1APpYTW6yheSwk8Yi4= github.com/getsentry/sentry-go v0.23.0 h1:dn+QRCeJv4pPt9OjVXiMcGIBIefaTJPw/h0bZWO05nE= github.com/getsentry/sentry-go v0.23.0/go.mod h1:lc76E2QywIyW8WuBnwl8Lc4bkmQH4+w1gwTf25trprY= github.com/ghodss/yaml v1.0.0/go.mod h1:4dBDuWmgqj2HViK6kFavaiC9ZROes6MMH2rRYeMEF04= @@ -264,6 +319,9 @@ github.com/gin-contrib/sse v0.1.0 h1:Y/yl/+YNO8GZSjAhjMsSuLt29uWRFHdHYUb5lYOV9qE github.com/gin-contrib/sse v0.1.0/go.mod h1:RHrZQHXnP2xjPF+u1gW/2HnVO7nvIa9PG3Gm+fLHvGI= github.com/gin-gonic/gin v1.9.0 h1:OjyFBKICoexlu99ctXNR2gg+c5pKrKMuyjgARg9qeY8= github.com/gin-gonic/gin v1.9.0/go.mod h1:W1Me9+hsUSyj3CePGrd1/QrKJMSJ1Tu/0hFEH89961k= +github.com/glycerine/go-unsnap-stream v0.0.0-20180323001048-9f0cb55181dd/go.mod h1:/20jfyN9Y5QPEAprSgKAUr+glWDY39ZiUEAYOEv5dsE= +github.com/glycerine/goconvey v0.0.0-20190410193231-58a59202ab31/go.mod h1:Ogl1Tioa0aV7gstGFO7KhffUsb9M4ydbEbbxpcEDc24= +github.com/go-chi/chi/v5 v5.0.0/go.mod h1:BBug9lr0cqtdAhsu6R4AAdvufI0/XBzAQSsUqJpoZOs= github.com/go-errors/errors v1.4.2 h1:J6MZopCL4uSllY1OfXM374weqZFFItUbrImctkmUxIA= github.com/go-gl/glfw v0.0.0-20190409004039-e6da0acd62b1/go.mod h1:vR7hzQXu2zJy9AVAgeJqvqgH9Q5CA+iKCZ2gyEVpxRU= github.com/go-gl/glfw/v3.3/glfw v0.0.0-20191125211704-12ad95a8df72/go.mod h1:tQ2UAYgL5IevRw8kRxooKSPJfGvJ9fJQFa0TUsXzTg8= @@ -280,6 +338,9 @@ github.com/go-logfmt/logfmt v0.4.0/go.mod h1:3RMwSq7FuexP4Kalkev3ejPJsZTpXXBr9+V github.com/go-logfmt/logfmt v0.5.0/go.mod h1:wCYkCAKZfumFQihp8CzCvQ3paCTfi41vtzG1KdI/P7A= github.com/go-logfmt/logfmt v0.5.1 h1:otpy5pqBCBZ1ng9RQ0dPu4PN7ba75Y/aA+UpowDyNVA= github.com/go-logfmt/logfmt v0.5.1/go.mod h1:WYhtIu8zTZfxdn5+rREduYbwxfcBr/Vr6KEVveWlfTs= +github.com/go-ole/go-ole v1.2.1/go.mod h1:7FAglXiTm7HKlQRDeOQ6ZNUHidzCWXuZWq/1dTyBNF8= +github.com/go-openapi/jsonpointer v0.19.5/go.mod h1:Pl9vOtqEWErmShwVjC8pYs9cog34VGT37dQOVbmoatg= +github.com/go-openapi/swag v0.19.5/go.mod h1:POnQmlKehdgb5mhVOsnJFsivZCEZ/vjK9gh66Z9tfKk= github.com/go-playground/assert/v2 v2.2.0/go.mod h1:VDjEfimB/XKnb+ZQfWdccd7VUvScMdVu0Titje2rxJ4= github.com/go-playground/locales v0.14.1 h1:EWaQ/wswjilfKLTECiXz7Rh+3BjFhfDFKv/oXslEjJA= github.com/go-playground/locales v0.14.1/go.mod h1:hxrqLVvrK65+Rwrd5Fc6F2O76J/NuW9t0sjnWqG1slY= @@ -287,7 +348,9 @@ github.com/go-playground/universal-translator v0.18.1 h1:Bcnm0ZwsGyWbCzImXv+pAJn github.com/go-playground/universal-translator v0.18.1/go.mod h1:xekY+UJKNuX9WP91TpwSH2VMlDf28Uj24BCp08ZFTUY= github.com/go-playground/validator/v10 v10.11.2 h1:q3SHpufmypg+erIExEKUmsgmhDTyhcJ38oeKGACXohU= github.com/go-playground/validator/v10 v10.11.2/go.mod h1:NieE624vt4SCTJtD87arVLvdmjPAeV8BQlHtMnw9D7s= +github.com/go-sourcemap/sourcemap v2.1.3+incompatible/go.mod h1:F8jJfvm2KbVjc5NqelyYJmf/v5J0dwNLS2mL4sNA1Jg= github.com/go-sql-driver/mysql v1.4.0/go.mod h1:zAC/RDZ24gD3HViQzih4MyKcchzm+sOG5ZlKdlhCg5w= +github.com/go-sql-driver/mysql v1.4.1/go.mod h1:zAC/RDZ24gD3HViQzih4MyKcchzm+sOG5ZlKdlhCg5w= github.com/go-stack/stack v1.8.0/go.mod h1:v0f6uXyyMGvRgIKkXu+yp6POWl0qKG85gN/melR3HDY= github.com/gobwas/httphead v0.0.0-20180130184737-2c6c146eadee h1:s+21KNqlpePfkah2I+gwHF8xmJWRjooY+5248k6m4A0= github.com/gobwas/httphead v0.0.0-20180130184737-2c6c146eadee/go.mod h1:L0fX3K22YWvt/FAX9NnzrNzcI4wNYi9Yku4O0LKYflo= @@ -300,6 +363,7 @@ github.com/goccy/go-json v0.10.0/go.mod h1:6MelG93GURQebXPDq3khkgXZkazVtN9CRI+MG github.com/godbus/dbus v0.0.0-20190726142602-4481cbc300e2 h1:ZpnhV/YsD2/4cESfV5+Hoeu/iUR3ruzNvZ+yQfO03a0= github.com/godbus/dbus v0.0.0-20190726142602-4481cbc300e2/go.mod h1:bBOAhwG1umN6/6ZUMtDFBMQR8jRg9O75tm9K00oMsK4= github.com/godbus/dbus/v5 v5.0.4/go.mod h1:xhWf0FNVPg57R7Z0UbKHbJfkEywrmjJnf7w5xrFpKfA= +github.com/gofrs/uuid v3.3.0+incompatible/go.mod h1:b2aQJv3Z4Fp6yNu3cdSllBxTCLRxnplIgP/c0N/04lM= github.com/gogo/googleapis v1.1.0/go.mod h1:gf4bu3Q80BeJ6H1S1vYPm8/ELATdvryBaNFGgqEef3s= github.com/gogo/googleapis v1.4.1-0.20201022092350-68b0159b7869/go.mod h1:5YRNX2z1oM5gXdAkurHa942MDgEJyk02w4OecKY87+c= github.com/gogo/googleapis v1.4.1 h1:1Yx4Myt7BxzvUr5ldGSbwYiZG6t9wGBZ+8/fX3Wvtq0= @@ -310,7 +374,10 @@ github.com/gogo/protobuf v1.2.1/go.mod h1:hp+jE20tsWTFYpLwKvXlhS1hjn+gTNwPg2I6zV github.com/gogo/protobuf v1.3.1/go.mod h1:SlYgWuQ5SjCEi6WLHjHCa1yvBfUnHcTbrrZtXPKa29o= github.com/gogo/protobuf v1.3.2 h1:Ov1cvc58UF3b5XjBnZv7+opcTcQFZebYjWzi34vdm4Q= github.com/gogo/protobuf v1.3.2/go.mod h1:P1XiOD3dCwIKUDQYPy72D8LYyHL2YPYrpS2s69NZV8Q= +github.com/golang-jwt/jwt/v4 v4.3.0/go.mod h1:/xlHOz8bRuivTWchD4jCa+NbatV+wEUSzwAxVc6locg= github.com/golang-jwt/jwt/v4 v4.4.2/go.mod h1:m21LjoU+eqJr34lmDMbreY2eSTRJ1cv77w39/MY0Ch0= +github.com/golang/freetype v0.0.0-20170609003504-e2365dfdc4a0/go.mod h1:E/TSTwGwJL78qG/PmXZO1EjYhfJinVAhrmmHX6Z8B9k= +github.com/golang/geo v0.0.0-20190916061304-5b978397cfec/go.mod h1:QZ0nwyI2jOfgRAoBvP+ab5aRr7c9x7lhGEJrKvBwjWI= github.com/golang/glog v0.0.0-20160126235308-23def4e6c14b/go.mod h1:SBH7ygxi8pfUlaOkMMuAQtPIUF8ecWP5IEl/CR7VP2Q= github.com/golang/glog v1.1.2 h1:DVjP2PbBOzHyzA+dn3WhHIq4NdVu3Q+pvivFICf/7fo= github.com/golang/glog v1.1.2/go.mod h1:zR+okUeTbrL6EL3xHUDxZuEtGv04p5shwip1+mL/rLQ= @@ -350,10 +417,12 @@ github.com/golang/snappy v0.0.0-20180518054509-2e65f85255db/go.mod h1:/XxbfmMg8l github.com/golang/snappy v0.0.3/go.mod h1:/XxbfmMg8lxefKM7IXC3fBNl/7bRcc72aCRzEWrmP2Q= github.com/golang/snappy v0.0.4 h1:yAGX7huGHXlcLOEtBnF4w7FQwA26wojNCwOYAEhLjQM= github.com/golang/snappy v0.0.4/go.mod h1:/XxbfmMg8lxefKM7IXC3fBNl/7bRcc72aCRzEWrmP2Q= +github.com/golangci/lint-1 v0.0.0-20181222135242-d2cdd8c08219/go.mod h1:/X8TswGSh1pIozq4ZwCfxS0WA5JGXguxk94ar/4c87Y= github.com/google/btree v0.0.0-20180813153112-4030bb1f1f0c/go.mod h1:lNA+9X1NB3Zf8V7Ke586lFgjr2dZNuvo3lPJSGZ5JPQ= github.com/google/btree v1.0.0/go.mod h1:lNA+9X1NB3Zf8V7Ke586lFgjr2dZNuvo3lPJSGZ5JPQ= github.com/google/btree v1.1.2 h1:xf4v41cLI2Z6FxbKm+8Bu+m8ifhj15JuZ9sa0jZCMUU= github.com/google/btree v1.1.2/go.mod h1:qOPhT0dTNdNzV6Z/lhRX0YXUafgPLFUh+gZMl761Gm4= +github.com/google/flatbuffers v1.11.0/go.mod h1:1AeVuKshWv4vARoZatz6mlQ0JxURH0Kv5+zNeJKJCa8= github.com/google/go-cmp v0.2.0/go.mod h1:oXzfMopK8JAjlY9xF4vHSVASa0yLyX7SntLO5aqRK0M= github.com/google/go-cmp v0.3.0/go.mod h1:8QqcDgzrUqlUb/G2PQTWiueGozuR1884gddMywk6iLU= github.com/google/go-cmp v0.3.1/go.mod h1:8QqcDgzrUqlUb/G2PQTWiueGozuR1884gddMywk6iLU= @@ -369,6 +438,7 @@ github.com/google/go-cmp v0.5.9 h1:O2Tfq5qg4qc4AmwVlvv0oLiVAGB7enBSJ2x2DqQFi38= github.com/google/go-cmp v0.5.9/go.mod h1:17dUlkBOakJ0+DkrSSNjCkIjxS6bF9zb3elmeNGIjoY= github.com/google/gofuzz v0.0.0-20170612174753-24818f796faf/go.mod h1:HP5RmnzzSNb993RKQDq4+1A4ia9nllfqcQFTQJedwGI= github.com/google/gofuzz v1.0.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg= +github.com/google/gofuzz v1.1.1-0.20200604201612-c04b05f3adfa/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg= github.com/google/gofuzz v1.2.0 h1:xRy4A+RhZaiKjJ1bPfwQ8sedCA+YS2YcCHW6ec7JMi0= github.com/google/martian v2.1.0+incompatible/go.mod h1:9I4somxYTbIHy5NJKHRl3wXiIaQGbYVAs8BPL6v8lEs= github.com/google/martian/v3 v3.0.0/go.mod h1:y5Zk1BBys9G+gd6Jrk0W3cC1+ELVxBWuIGO+w/tUAp0= @@ -388,6 +458,7 @@ github.com/google/pprof v0.0.0-20201218002935-b9804c9f04c2/go.mod h1:kpwsk12EmLe github.com/google/renameio v0.1.0/go.mod h1:KWCgfxg9yswjAJkECMjeO8J8rahYeXnNhOm40UhjYkI= github.com/google/uuid v1.0.0/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= github.com/google/uuid v1.1.2/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= +github.com/google/uuid v1.2.0/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= github.com/googleapis/gax-go/v2 v2.0.4/go.mod h1:0Wqv26UfaUD9n4G6kQubkQ+KchISgw+vpHVxEJEs9eg= github.com/googleapis/gax-go/v2 v2.0.5/go.mod h1:DWXyrwAJ9X0FpwwEdw+IPEYBICEFu5mhpdKc/us6bOk= github.com/googleapis/google-cloud-go-testing v0.0.0-20200911160855-bcd43fbb19e8/go.mod h1:dvDLG8qkwmyD9a/MJJN3XJcT3xFxOKAvTZGvuZmac9g= @@ -401,8 +472,10 @@ github.com/gorilla/mux v1.8.0 h1:i40aqfkR1h2SlN9hojwV5ZA91wcXFOvkdNIeFDP5koI= github.com/gorilla/mux v1.8.0/go.mod h1:DVbg23sWSpFRCP0SfiEN6jmj59UnW/n46BH5rLB71So= github.com/gorilla/websocket v0.0.0-20170926233335-4201258b820c/go.mod h1:E7qHFY5m1UJ88s3WnNqhKjPHQ0heANvMoAMk2YaljkQ= github.com/gorilla/websocket v1.4.1/go.mod h1:YR8l580nyteQvAITg2hZ9XVh4b55+EU/adAjf1fMHhE= +github.com/gorilla/websocket v1.4.2/go.mod h1:YR8l580nyteQvAITg2hZ9XVh4b55+EU/adAjf1fMHhE= github.com/gorilla/websocket v1.5.0 h1:PPwGk2jz7EePpoHN/+ClbZu8SPxiqlu12wZP/3sWmnc= github.com/gorilla/websocket v1.5.0/go.mod h1:YR8l580nyteQvAITg2hZ9XVh4b55+EU/adAjf1fMHhE= +github.com/graph-gophers/graphql-go v1.3.0/go.mod h1:9CQHMSxwO4MprSdzoIEobiHpoLtHm77vfxsvsIN5Vuc= github.com/grpc-ecosystem/go-grpc-middleware v1.0.1-0.20190118093823-f849b5445de4/go.mod h1:FiyG127CGDf3tlThmgyCl78X/SZQqEOJBCDaAfeWzPs= github.com/grpc-ecosystem/go-grpc-middleware v1.2.2/go.mod h1:EaizFBKfUKtMIF5iaDEhniwNedqGo9FuLFzppDr3uwI= github.com/grpc-ecosystem/go-grpc-middleware v1.3.0 h1:+9834+KizmvFV7pXQGSXQTsaWhq2GjuNUt0aUU0YBYw= @@ -421,6 +494,7 @@ github.com/gtank/ristretto255 v0.1.2/go.mod h1:Ph5OpO6c7xKUGROZfWVLiJf9icMDwUeIv github.com/hashicorp/consul/api v1.3.0/go.mod h1:MmDNSzIMUjNpY/mQ398R4bk2FnqQLoPndWW5VkKPlCE= github.com/hashicorp/consul/sdk v0.3.0/go.mod h1:VKf9jXwCTEY1QZP2MOLRhb5i/I/ssyNV1vwHyQBF0x8= github.com/hashicorp/errwrap v1.0.0/go.mod h1:YH+1FKiLXxHSkmPseP+kNlulaMuP3n2brvKWEqk/Jc4= +github.com/hashicorp/go-bexpr v0.1.10/go.mod h1:oxlubA2vC/gFVfX1A6JGp7ls7uCDlfJn732ehYYg+g0= github.com/hashicorp/go-cleanhttp v0.5.0/go.mod h1:JpRdi6/HCYpAwUzNwuwqhbovhLtngrth3wmdIIUrZ80= github.com/hashicorp/go-cleanhttp v0.5.1/go.mod h1:JpRdi6/HCYpAwUzNwuwqhbovhLtngrth3wmdIIUrZ80= github.com/hashicorp/go-immutable-radix v1.0.0/go.mod h1:0y9vanUI8NX6FsYoO3zeMjhV/C5i9g4Q3DwcSNZ4P60= @@ -449,12 +523,16 @@ github.com/hashicorp/memberlist v0.1.3/go.mod h1:ajVTdAv/9Im8oMAAj5G31PhhMCZJV2p github.com/hashicorp/serf v0.8.2/go.mod h1:6hOLApaqBFA1NXqRQAsxw9QxuDEvNxSQRwA/JwenrHc= github.com/hdevalence/ed25519consensus v0.1.0 h1:jtBwzzcHuTmFrQN6xQZn6CQEO/V9f7HsjsjeEZ6auqU= github.com/hdevalence/ed25519consensus v0.1.0/go.mod h1:w3BHWjwJbFU29IRHL1Iqkw3sus+7FctEyM4RqDxYNzo= +github.com/holiman/bloomfilter/v2 v2.0.3/go.mod h1:zpoh+gs7qcpqrHr3dB55AMiJwo0iURXE7ZOP9L9hSkA= +github.com/holiman/uint256 v1.2.0/go.mod h1:y4ga/t+u+Xwd7CpDgZESaRcWy0I7XMlTMA25ApIH5Jw= github.com/hpcloud/tail v1.0.0/go.mod h1:ab1qPbhIpdTxEkNHXyeSf5vhxWSCs/tWer42PpOxQnU= github.com/huandu/go-assert v1.1.5 h1:fjemmA7sSfYHJD7CUqs9qTwwfdNAx7/j2/ZlHXzNB3c= github.com/huandu/go-assert v1.1.5/go.mod h1:yOLvuqZwmcHIC5rIzrBhT7D3Q9c3GFnd0JrPVhn/06U= github.com/huandu/skiplist v1.2.0 h1:gox56QD77HzSC0w+Ws3MH3iie755GBJU1OER3h5VsYw= github.com/huandu/skiplist v1.2.0/go.mod h1:7v3iFjLcSAzO4fN5B8dvebvo/qsfumiLiDXMrPiHF9w= github.com/hudl/fargo v1.3.0/go.mod h1:y3CKSmjA+wD2gak7sUSXTAoopbhU08POFhmITJgmKTg= +github.com/huin/goupnp v1.0.3-0.20220313090229-ca81a64b4204/go.mod h1:ZxNlw5WqJj6wSsRK5+YfflQGXYfccj5VgQsMNixHM7Y= +github.com/huin/goutil v0.0.0-20170803182201-1ca381bf3150/go.mod h1:PpLOETDnJ0o3iZrZfqZzyLl6l7F3c6L1oWn7OICBi6o= github.com/iancoleman/strcase v0.2.0 h1:05I4QRnGpI0m37iZQRuskXh+w77mr6Z41lwQzuHLwW0= github.com/iancoleman/strcase v0.2.0/go.mod h1:iwCmte+B7n89clKwxIoIXy/HfoL7AsD47ZCWhYzw7ho= github.com/ianlancetaylor/demangle v0.0.0-20181102032728-5e5cf60278f6/go.mod h1:aSSvb/t6k1mPoxDqO4vJh6VOCGPwU4O0C2/Eqndh1Sc= @@ -464,11 +542,26 @@ github.com/improbable-eng/grpc-web v0.15.0/go.mod h1:1sy9HKV4Jt9aEs9JSnkWlRJPuPt github.com/inconshreveable/mousetrap v1.0.0/go.mod h1:PxqpIevigyE2G7u3NXJIT2ANytuPF1OarO4DADm73n8= github.com/inconshreveable/mousetrap v1.0.1 h1:U3uMjPSQEBMNp1lFxmllqCPM6P5u/Xq7Pgzkat/bFNc= github.com/inconshreveable/mousetrap v1.0.1/go.mod h1:vpF70FUmC8bwa3OWnCshd2FqLfsEA9PFc4w1p2J65bw= +github.com/influxdata/flux v0.65.1/go.mod h1:J754/zds0vvpfwuq7Gc2wRdVwEodfpCFM7mYlOw2LqY= +github.com/influxdata/influxdb v1.8.3/go.mod h1:JugdFhsvvI8gadxOI6noqNeeBHvWNTbfYGtiAn+2jhI= +github.com/influxdata/influxdb-client-go/v2 v2.4.0/go.mod h1:vLNHdxTJkIf2mSLvGrpj8TCcISApPoXkaxP8g9uRlW8= github.com/influxdata/influxdb1-client v0.0.0-20191209144304-8bf82d3c094d/go.mod h1:qj24IKcXYK6Iy9ceXlo3Tc+vtHo9lIhSX5JddghvEPo= +github.com/influxdata/influxql v1.1.1-0.20200828144457-65d3ef77d385/go.mod h1:gHp9y86a/pxhjJ+zMjNXiQAA197Xk9wLxaz+fGG+kWk= +github.com/influxdata/line-protocol v0.0.0-20180522152040-32c6aa80de5e/go.mod h1:4kt73NQhadE3daL3WhR5EJ/J2ocX0PZzwxQ0gXJ7oFE= +github.com/influxdata/line-protocol v0.0.0-20200327222509-2487e7298839/go.mod h1:xaLFMmpvUxqXtVkUJfg9QmT88cDaCJ3ZKgdZ78oO8Qo= +github.com/influxdata/line-protocol v0.0.0-20210311194329-9aa0e372d097/go.mod h1:xaLFMmpvUxqXtVkUJfg9QmT88cDaCJ3ZKgdZ78oO8Qo= +github.com/influxdata/promql/v2 v2.12.0/go.mod h1:fxOPu+DY0bqCTCECchSRtWfc+0X19ybifQhZoQNF5D8= +github.com/influxdata/roaring v0.4.13-0.20180809181101-fc520f41fab6/go.mod h1:bSgUQ7q5ZLSO+bKBGqJiCBGAl+9DxyW63zLTujjUlOE= +github.com/influxdata/tdigest v0.0.0-20181121200506-bf2b5ad3c0a9/go.mod h1:Js0mqiSBE6Ffsg94weZZ2c+v/ciT8QRHFOap7EKDrR0= +github.com/influxdata/usage-client v0.0.0-20160829180054-6d3895376368/go.mod h1:Wbbw6tYNvwa5dlB6304Sd+82Z3f7PmVZHVKU637d4po= +github.com/jackpal/go-nat-pmp v1.0.2/go.mod h1:QPH045xvCAeXUZOxsnwmrtiCoxIr9eob+4orBN1SBKc= +github.com/jedisct1/go-minisign v0.0.0-20190909160543-45766022959e/go.mod h1:G1CVv03EnqU1wYL2dFwXxW2An0az9JTl/ZsqXQeBlkU= github.com/jessevdk/go-flags v0.0.0-20141203071132-1679536dcc89/go.mod h1:4FA24M0QyGHXBuZZK/XkWh8h0e1EYbRYJSGM75WSRxI= github.com/jessevdk/go-flags v1.4.0/go.mod h1:4FA24M0QyGHXBuZZK/XkWh8h0e1EYbRYJSGM75WSRxI= github.com/jhump/protoreflect v1.15.1 h1:HUMERORf3I3ZdX05WaQ6MIpd/NJ434hTp5YiKgfCL6c= github.com/jmespath/go-jmespath v0.0.0-20180206201540-c2b33e8439af/go.mod h1:Nht3zPeWKUH0NzdCt2Blrr5ys8VGpn0CEB0cQHVjt7k= +github.com/jmespath/go-jmespath v0.4.0/go.mod h1:T8mJZnbsbmF+m6zOOFylbeCJqk5+pHWvzYPziyZiYoo= +github.com/jmespath/go-jmespath/internal/testify v1.5.1/go.mod h1:L3OGu8Wl2/fWfCI6z80xFu9LTZmf1ZRjMHUOPmWr69U= github.com/jmhodges/levigo v1.0.0 h1:q5EC36kV79HWeTBWsod3mG11EgStG3qArTKcvlksN1U= github.com/jmhodges/levigo v1.0.0/go.mod h1:Q6Qx+uH3RAqyK4rFQroq9RL7mdkABMcfhEI+nNuzMJQ= github.com/jonboulle/clockwork v0.1.0/go.mod h1:Ii8DK3G1RaLaWxj9trq07+26W01tbo22gdxWY5EU2bo= @@ -483,21 +576,29 @@ github.com/json-iterator/go v1.1.12 h1:PV8peI4a0ysnczrg+LtxykD8LfKY9ML6u2jnxaEnr github.com/json-iterator/go v1.1.12/go.mod h1:e30LSqwooZae/UwlEbR2852Gd8hjQvJoHmT4TnhNGBo= github.com/jstemmer/go-junit-report v0.0.0-20190106144839-af01ea7f8024/go.mod h1:6v2b51hI/fHJwM22ozAgKL4VKDeJcHhJFhtBdhmNjmU= github.com/jstemmer/go-junit-report v0.9.1/go.mod h1:Brl9GWCQeLvo8nXZwPNNblvFj/XSXhF0NWZEnDohbsk= +github.com/jsternberg/zap-logfmt v1.0.0/go.mod h1:uvPs/4X51zdkcm5jXl5SYoN+4RK21K8mysFmDaM/h+o= github.com/jtolds/gls v4.20.0+incompatible/go.mod h1:QJZ7F/aHp+rZTRtaJ1ow/lLfFfVYBRgL+9YlvaHOwJU= github.com/julienschmidt/httprouter v1.2.0/go.mod h1:SYymIcj16QtmaHHD7aYtjjsJG7VTCxuUUipMqKk8s4w= github.com/julienschmidt/httprouter v1.3.0/go.mod h1:JR6WtHb+2LUe8TCKY3cZOxFyyO8IZAc4RVcycCCAKdM= +github.com/jung-kurt/gofpdf v1.0.3-0.20190309125859-24315acbbda5/go.mod h1:7Id9E/uU8ce6rXgefFLlgrJj/GYY22cpxn+r32jIOes= +github.com/jwilder/encoding v0.0.0-20170811194829-b4e1701a28ef/go.mod h1:Ct9fl0F6iIOGgxJ5npU/IUOhOhqlVrGjyIZc8/MagT0= +github.com/karalabe/usb v0.0.2/go.mod h1:Od972xHfMJowv7NGVDiWVxk2zxnWgjLlJzE+F4F7AGU= github.com/kisielk/errcheck v1.1.0/go.mod h1:EZBBE59ingxPouuu3KfxchcWSUPOHkagtvWXihfKN4Q= github.com/kisielk/errcheck v1.2.0/go.mod h1:/BMXB+zMLi60iA8Vv6Ksmxu/1UDYcXs4uQLJ+jE2L00= github.com/kisielk/errcheck v1.5.0/go.mod h1:pFxgyoBC7bSaBwPgfKdkLd5X25qrDl4LWUI2bnpBCr8= github.com/kisielk/gotool v1.0.0/go.mod h1:XhKaO+MFFWcvkIS/tQcRk01m1F5IRFswLeQ+oQHNcck= github.com/kkdai/bstream v0.0.0-20161212061736-f391b8402d23/go.mod h1:J+Gs4SYgM6CZQHDETBtE9HaSEkGmuNXF86RwHhHUvq4= +github.com/klauspost/compress v1.4.0/go.mod h1:RyIbtBH6LamlWaDj8nUwkbUhJ87Yi3uG0guNDohfE1A= github.com/klauspost/compress v1.10.3/go.mod h1:aoV0uJVorq1K+umq18yTdKaF57EivdYsUV+/s2qKfXs= github.com/klauspost/compress v1.11.7/go.mod h1:aoV0uJVorq1K+umq18yTdKaF57EivdYsUV+/s2qKfXs= github.com/klauspost/compress v1.12.3/go.mod h1:8dP1Hq4DHOhN9w426knH3Rhby4rFm6D8eO+e+Dq5Gzg= github.com/klauspost/compress v1.16.7 h1:2mk3MPGNzKyxErAw8YaohYh69+pa4sIQSC0fPGCFR9I= github.com/klauspost/compress v1.16.7/go.mod h1:ntbaceVETuRiXiv4DpjP66DpAtAGkEQskQzEyD//IeE= +github.com/klauspost/cpuid v0.0.0-20170728055534-ae7887de9fa5/go.mod h1:Pj4uuM528wm8OyEC2QMXAi2YiTZ96dNQPGgoMS4s3ek= github.com/klauspost/cpuid/v2 v2.0.9 h1:lgaqFMSdTdQYdZ04uHyN2d/eKdOMyi2YLSvlQIBFYa4= github.com/klauspost/cpuid/v2 v2.0.9/go.mod h1:FInQzS24/EEf25PyTYn52gqo7WaD8xa0213Md/qVLRg= +github.com/klauspost/crc32 v0.0.0-20161016154125-cb6bfca970f6/go.mod h1:+ZoRqAPRLkC4NPOvfYeR5KNOrY6TD+/sAC3HXPZgDYg= +github.com/klauspost/pgzip v1.0.2-0.20170402124221-0bf5dcad4ada/go.mod h1:Ch1tH69qFZu15pkjo5kYi6mth2Zzwzt50oCQKQE9RUs= github.com/konsorten/go-windows-terminal-sequences v1.0.1/go.mod h1:T0+1ngSBFLxvqU3pZ+m/2kptfBszLMUkC4ZK/EgS/cQ= github.com/konsorten/go-windows-terminal-sequences v1.0.3/go.mod h1:T0+1ngSBFLxvqU3pZ+m/2kptfBszLMUkC4ZK/EgS/cQ= github.com/kr/fs v0.1.0/go.mod h1:FFnZGqtBN9Gxj7eW1uZ42v5BccTP0vu6NEaFoC2HwRg= @@ -511,8 +612,13 @@ github.com/kr/pty v1.1.1/go.mod h1:pFQYn66WHrOpPYNljwOMqo10TkYh1fy3cYio2l3bCsQ= github.com/kr/text v0.1.0/go.mod h1:4Jbv+DJW3UT/LiOwJeYQe1efqtUx/iVham/4vfdArNI= github.com/kr/text v0.2.0 h1:5Nx0Ya0ZqY2ygV366QzturHI13Jq95ApcVaJBhpS+AY= github.com/kr/text v0.2.0/go.mod h1:eLer722TekiGuMkidMxC/pM04lWEeraHUUmBw8l2grE= +github.com/kylelemons/godebug v1.1.0/go.mod h1:9/0rRGxNHcop5bhtWyNeEfOS8JIWk580+fNqagV/RAw= +github.com/labstack/echo/v4 v4.2.1/go.mod h1:AA49e0DZ8kk5jTOOCKNuPR6oTnBS0dYiM4FW1e6jwpg= +github.com/labstack/gommon v0.3.0/go.mod h1:MULnywXg0yavhxWKc+lOruYdAhDwPK9wf0OL7NoOu+k= +github.com/leanovate/gopter v0.2.9/go.mod h1:U2L/78B+KVFIx2VmW6onHJQzXtFb+p5y3y2Sh+Jxxv8= github.com/leodido/go-urn v1.2.1 h1:BqpAaACuzVSgi/VLzGZIobT2z4v53pjosyNd9Yv6n/w= github.com/leodido/go-urn v1.2.1/go.mod h1:zt4jvISO2HfUBqxjfIshjdMTYS56ZS/qv49ictyFfxY= +github.com/lib/pq v1.0.0/go.mod h1:5WUZQaWbwv1U+lTReE5YruASi9Al49XbQIvNi/34Woo= github.com/lib/pq v1.10.7 h1:p7ZhMD+KsSRozJr34udlUrhboJwWAgCg34+/ZZNvZZw= github.com/lib/pq v1.10.7/go.mod h1:AlVN5x4E4T544tWzH6hKfbfQvm3HdbOxrmggDNAPY9o= github.com/libp2p/go-buffer-pool v0.1.0 h1:oK4mSFcQz7cTQIfqbe4MIj9gLW+mnanjyFtc6cdF0Y8= @@ -523,19 +629,32 @@ github.com/lyft/protoc-gen-validate v0.0.13/go.mod h1:XbGvPuh87YZc5TdIa2/I4pLk0Q github.com/magiconair/properties v1.8.0/go.mod h1:PppfXfuXeibc/6YijjN8zIbojt8czPbwD3XqdrwzmxQ= github.com/magiconair/properties v1.8.6 h1:5ibWZ6iY0NctNGWo87LalDlEZ6R41TqbbDamhfG/Qzo= github.com/magiconair/properties v1.8.6/go.mod h1:y3VJvCyxH9uVvJTWEGAELF3aiYNyPKd5NZ3oSwXrF60= +github.com/mailru/easyjson v0.0.0-20190614124828-94de47d64c63/go.mod h1:C1wdFJiN94OJF2b5HbByQZoLdCWB1Yqtg26g4irojpc= +github.com/mailru/easyjson v0.0.0-20190626092158-b2ccc519800e/go.mod h1:C1wdFJiN94OJF2b5HbByQZoLdCWB1Yqtg26g4irojpc= github.com/manifoldco/promptui v0.9.0 h1:3V4HzJk1TtXW1MTZMP7mdlwbBpIinw3HztaIlYthEiA= +github.com/matryer/moq v0.0.0-20190312154309-6cfb0558e1bd/go.mod h1:9ELz6aaclSIGnZBoaSLZ3NAl1VTufbOrXBPvtcy6WiQ= github.com/mattn/go-colorable v0.0.9/go.mod h1:9vuHe8Xs5qXnSaW/c/ABM9alt+Vo+STaOChaDxuIBZU= +github.com/mattn/go-colorable v0.1.2/go.mod h1:U0ppj6V5qS13XJ6of8GYAs25YV2eR4EVcfRqFIhoBtE= +github.com/mattn/go-colorable v0.1.7/go.mod h1:u6P/XSegPjTcexA+o6vUJrdnUu04hMope9wVRipJSqc= +github.com/mattn/go-colorable v0.1.8/go.mod h1:u6P/XSegPjTcexA+o6vUJrdnUu04hMope9wVRipJSqc= github.com/mattn/go-colorable v0.1.12/go.mod h1:u5H1YNBxpqRaxsYJYSkiCWKzEfiAb1Gb520KVy5xxl4= github.com/mattn/go-colorable v0.1.13 h1:fFA4WZxdEF4tXPZVKMLwD8oUnCTTo08duU7wxecdEvA= github.com/mattn/go-colorable v0.1.13/go.mod h1:7S9/ev0klgBDR4GtXTXX8a3vIGJpMovkB8vQcUbaXHg= github.com/mattn/go-isatty v0.0.3/go.mod h1:M+lRXTBqGeGNdLjl/ufCoiOlB5xdOkqRJdNxMWT7Zi4= github.com/mattn/go-isatty v0.0.4/go.mod h1:M+lRXTBqGeGNdLjl/ufCoiOlB5xdOkqRJdNxMWT7Zi4= +github.com/mattn/go-isatty v0.0.8/go.mod h1:Iq45c/XA43vh69/j3iqttzPXn0bhXyGjM0Hdxcsrc5s= +github.com/mattn/go-isatty v0.0.9/go.mod h1:YNRxwqDuOph6SZLI9vUUz6OYw3QyUt7WiY2yME+cCiQ= +github.com/mattn/go-isatty v0.0.12/go.mod h1:cbi8OIDigv2wuxKPP5vlRcQ1OAZbq2CE4Kysco4FUpU= github.com/mattn/go-isatty v0.0.14/go.mod h1:7GGIvUiUoEMVVmxf/4nioHXj79iQHKdU27kJ6hsGG94= github.com/mattn/go-isatty v0.0.16/go.mod h1:kYGgaQfpe5nmfYZH+SKPsOc2e4SrIfOl2e/yFXSvRLM= github.com/mattn/go-isatty v0.0.17/go.mod h1:kYGgaQfpe5nmfYZH+SKPsOc2e4SrIfOl2e/yFXSvRLM= github.com/mattn/go-isatty v0.0.19 h1:JITubQf0MOLdlGRuRq+jtsDlekdYPia9ZFsB8h/APPA= github.com/mattn/go-isatty v0.0.19/go.mod h1:W+V8PltTTMOvKvAeJH7IuucS94S2C6jfK/D7dTCTo3Y= github.com/mattn/go-runewidth v0.0.2/go.mod h1:LwmH8dsx7+W8Uxz3IHJYH5QSwggIsqBzpuz5H//U1FU= +github.com/mattn/go-runewidth v0.0.3/go.mod h1:LwmH8dsx7+W8Uxz3IHJYH5QSwggIsqBzpuz5H//U1FU= +github.com/mattn/go-runewidth v0.0.9/go.mod h1:H031xJmbD/WCDINGzjvQ9THkh0rPKHF+m2gUSrubnMI= +github.com/mattn/go-sqlite3 v1.11.0/go.mod h1:FPy6KqzDD04eiIsT53CuJW3U88zkxoIYsOqkbpncsNc= +github.com/mattn/go-tty v0.0.0-20180907095812-13ff1204f104/go.mod h1:XPvLUNfbS4fJH25nqRHfWLMa1ONC8Amw+mIA639KxkE= github.com/matttproud/golang_protobuf_extensions v1.0.1/go.mod h1:D8He9yQNgCq6Z5Ld7szi9bcBfOoFv/3dc6xSMkL2PC0= github.com/matttproud/golang_protobuf_extensions v1.0.4 h1:mmDVorXM7PCGKw94cs5zkfA9PSy5pEvNWRP0ET0TIVo= github.com/matttproud/golang_protobuf_extensions v1.0.4/go.mod h1:BSXmuO+STAnVfrANrmjBb36TMTDstsz7MSK+HVaYKv4= @@ -553,8 +672,10 @@ github.com/mitchellh/gox v0.4.0/go.mod h1:Sd9lOJ0+aimLBi73mGofS1ycjY8lL3uZM3JPS4 github.com/mitchellh/iochan v1.0.0/go.mod h1:JwYml1nuB7xOzsp52dPpHFffvOCDupsG0QubkSMEySY= github.com/mitchellh/mapstructure v0.0.0-20160808181253-ca63d7c062ee/go.mod h1:FVVH3fgwuzCH5S8UJGiWEs2h04kUh9fWfEaFds41c1Y= github.com/mitchellh/mapstructure v1.1.2/go.mod h1:FVVH3fgwuzCH5S8UJGiWEs2h04kUh9fWfEaFds41c1Y= +github.com/mitchellh/mapstructure v1.4.1/go.mod h1:bFUtVrKA4DC2yAKiSyO/QUcy7e+RRV2QTWOzhPopBRo= github.com/mitchellh/mapstructure v1.5.0 h1:jeMsZIYE/09sWLaz43PL7Gy6RuMjD2eJVyuac5Z2hdY= github.com/mitchellh/mapstructure v1.5.0/go.mod h1:bFUtVrKA4DC2yAKiSyO/QUcy7e+RRV2QTWOzhPopBRo= +github.com/mitchellh/pointerstructure v1.2.0/go.mod h1:BRAsLI5zgXmw97Lf6s25bs8ohIXc3tViBH44KcwB2g4= github.com/modern-go/concurrent v0.0.0-20180228061459-e0a39a4cb421/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q= github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd h1:TRLaZ9cD/w8PVh93nsPXa1VrQ6jlwL5oN8l14QlcNfg= github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q= @@ -562,12 +683,16 @@ github.com/modern-go/reflect2 v0.0.0-20180701023420-4b7aa43c6742/go.mod h1:bx2lN github.com/modern-go/reflect2 v1.0.1/go.mod h1:bx2lNnkwVCuqBIxFjflWJWanXIb3RllmbCylyMrvgv0= github.com/modern-go/reflect2 v1.0.2 h1:xBagoLtFs94CBntxluKeaWgTMpvLxC4ur3nMaC9Gz0M= github.com/modern-go/reflect2 v1.0.2/go.mod h1:yWuevngMOJpCy52FWWMvUC8ws7m/LJsjYzDa0/r8luk= +github.com/modocache/gover v0.0.0-20171022184752-b58185e213c5/go.mod h1:caMODM3PzxT8aQXRPkAt8xlV/e7d7w8GM5g0fa5F0D8= +github.com/mschoch/smat v0.0.0-20160514031455-90eadee771ae/go.mod h1:qAyveg+e4CE+eKJXWVjKXM4ck2QobLqTDytGJbLLhJg= github.com/mtibben/percent v0.2.1 h1:5gssi8Nqo8QU/r2pynCm+hBQHpkB/uNK7BJCFogWdzs= github.com/mtibben/percent v0.2.1/go.mod h1:KG9uO+SZkUp+VkRHsCdYQV3XSZrrSpR3O9ibNBTZrns= github.com/mwitkow/go-conntrack v0.0.0-20161129095857-cc309e4a2223/go.mod h1:qRWi+5nqEBWmkhHvq77mSJWrCKwh8bxhgT7d/eI7P4U= github.com/mwitkow/go-conntrack v0.0.0-20190716064945-2f068394615f h1:KUppIJq7/+SVif2QVs3tOP0zanoHgBEVAwHxUSIzRqU= github.com/mwitkow/go-conntrack v0.0.0-20190716064945-2f068394615f/go.mod h1:qRWi+5nqEBWmkhHvq77mSJWrCKwh8bxhgT7d/eI7P4U= github.com/mwitkow/grpc-proxy v0.0.0-20181017164139-0f1106ef9c76/go.mod h1:x5OoJHDHqxHS801UIuhqGl6QdSAEJvtausosHSdazIo= +github.com/naoina/go-stringutil v0.1.0/go.mod h1:XJ2SJL9jCtBh+P9q5btrd/Ylo8XwT/h1USek5+NqSA0= +github.com/naoina/toml v0.1.2-0.20170918210437-9fafd6967416/go.mod h1:NBIhNtsFMo3G2szEBne+bO4gS192HuIYRqfvOWb4i1E= github.com/nats-io/jwt v0.3.0/go.mod h1:fRYCDE99xlTsqUzISS1Bi75UBJ6ljOJQOAAu5VglpSg= github.com/nats-io/jwt v0.3.2/go.mod h1:/euKqTS1ZD+zzjYrY7pseZrTtWQSjujC7xjPc8wL6eU= github.com/nats-io/nats-server/v2 v2.1.2/go.mod h1:Afk+wRZqkMQs/p45uXdrVLuab3gwv3Z8C4HTBu8GD/k= @@ -580,7 +705,9 @@ github.com/nxadm/tail v1.4.4/go.mod h1:kenIhsEOeOJmVchQTgglprH7qJGnHDVpk1VPCcaMI github.com/nxadm/tail v1.4.8 h1:nPr65rt6Y5JFSKQO7qToXr7pePgD6Gwiw05lkbyAQTE= github.com/oklog/oklog v0.3.2/go.mod h1:FCV+B7mhrz4o+ueLpx+KqkyXRGMWOYEvfiXtdGtbWGs= github.com/oklog/run v1.0.0/go.mod h1:dlhp/R75TPv97u0XWUtDeV/lRKWPKSdTuV0TZvrmrQA= +github.com/oklog/ulid v1.3.1/go.mod h1:CirwcVhetQ6Lv90oh/F+FBtV6XMibvdAFo93nm5qn4U= github.com/olekukonko/tablewriter v0.0.0-20170122224234-a0225b3f23b5/go.mod h1:vsDQFd/mU46D+Z4whnwzcISnGGzXWMclvtLoiIKAKIo= +github.com/olekukonko/tablewriter v0.0.5/go.mod h1:hPp6KlRPjbx+hW8ykQs1w3UBbZlj6HuIJcUGPhkA7kY= github.com/onsi/ginkgo v1.6.0/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+WWjE= github.com/onsi/ginkgo v1.7.0/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+WWjE= github.com/onsi/ginkgo v1.12.1/go.mod h1:zj2OWP4+oCPe1qIXoGWkgMRwljMUYCdkwsT2108oapk= @@ -598,6 +725,7 @@ github.com/opencontainers/runc v1.1.3 h1:vIXrkId+0/J2Ymu2m7VjGvbSlAId9XNRPhn2p4b github.com/opentracing-contrib/go-observer v0.0.0-20170622124052-a52f23424492/go.mod h1:Ngi6UdF0k5OKD5t5wlmGhe/EDKPoUM3BXZSSfIuJbis= github.com/opentracing/basictracer-go v1.0.0/go.mod h1:QfBfYuafItcjQuMwinw9GhYKwFXS9KnPs5lxoYwgW74= github.com/opentracing/opentracing-go v1.0.2/go.mod h1:UkNAQd3GIcIGf0SeVgPpRdFStlNbqXla1AfSYxPUl2o= +github.com/opentracing/opentracing-go v1.0.3-0.20180606204148-bd9c31933947/go.mod h1:UkNAQd3GIcIGf0SeVgPpRdFStlNbqXla1AfSYxPUl2o= github.com/opentracing/opentracing-go v1.1.0/go.mod h1:UkNAQd3GIcIGf0SeVgPpRdFStlNbqXla1AfSYxPUl2o= github.com/openzipkin-contrib/zipkin-go-opentracing v0.4.5/go.mod h1:/wsWhb9smxSfWAKL3wpBW7V8scJMt8N8gnaMCS9E/cA= github.com/openzipkin/zipkin-go v0.1.6/go.mod h1:QgAqvLzwWbR/WpD4A3cGpPtJrZXNIiJc5AZX7/PBEpw= @@ -608,6 +736,7 @@ github.com/pact-foundation/pact-go v1.0.4/go.mod h1:uExwJY4kCzNPcHRj+hCR/HBbOOIw github.com/pascaldekloe/goe v0.0.0-20180627143212-57f6aae5913c/go.mod h1:lzWF7FIEvWOWxwDKqyGYQf6ZUaNfKdP144TG7ZOy1lc= github.com/pascaldekloe/goe v0.1.0 h1:cBOtyMzM9HTpWjXfbbunk26uA6nG3a8n06Wieeh0MwY= github.com/pascaldekloe/goe v0.1.0/go.mod h1:lzWF7FIEvWOWxwDKqyGYQf6ZUaNfKdP144TG7ZOy1lc= +github.com/paulbellamy/ratecounter v0.2.0/go.mod h1:Hfx1hDpSGoqxkVVpBi/IlYD7kChlfo5C6hzIHwPqfFE= github.com/pborman/uuid v1.2.0/go.mod h1:X/NO0urCmaxf9VXbdlT7C2Yzkj2IKimNn4k+gtPdI/k= github.com/pelletier/go-toml v1.2.0/go.mod h1:5z9KED0ma1S8pY6P1sdut58dfprrGBbd/94hg7ilaic= github.com/pelletier/go-toml v1.9.5 h1:4yBQzkHv+7BHq2PQUZF3Mx0IYxG7LsP222s7Agd3ve8= @@ -616,9 +745,12 @@ github.com/pelletier/go-toml/v2 v2.0.6/go.mod h1:eumQOmlWiOPt5WriQQqoM5y18pDHwha github.com/pelletier/go-toml/v2 v2.0.7 h1:muncTPStnKRos5dpVKULv2FVd4bMOhNePj9CjgDb8Us= github.com/pelletier/go-toml/v2 v2.0.7/go.mod h1:eumQOmlWiOPt5WriQQqoM5y18pDHwha2N+QD+EUNTek= github.com/performancecopilot/speed v3.0.0+incompatible/go.mod h1:/CLtqpZ5gBg1M9iaPbIdPPGyKcA8hKdoy6hAWba7Yac= +github.com/peterh/liner v1.0.1-0.20180619022028-8c1271fcf47f/go.mod h1:xIteQHvHuaLYG9IFj6mSxM0fCKrs34IrEQUhOYuGPHc= +github.com/peterh/liner v1.1.1-0.20190123174540-a2c9a5303de7/go.mod h1:CRroGNssyjTd/qIG2FyxByd2S8JEAZXBl4qUrZf8GS0= github.com/petermattis/goid v0.0.0-20180202154549-b0b1615b78e5/go.mod h1:jvVRKCrJTQWu0XVbaOlby/2lO20uSCHEMzzplHXte1o= github.com/petermattis/goid v0.0.0-20230317030725-371a4b8eda08 h1:hDSdbBuw3Lefr6R18ax0tZ2BJeNB3NehB3trOwYBsdU= github.com/petermattis/goid v0.0.0-20230317030725-371a4b8eda08/go.mod h1:pxMtw7cyUw6B2bRH0ZBANSPg+AoSud1I1iyJHI69jH4= +github.com/philhofer/fwd v1.0.0/go.mod h1:gk3iGcWd9+svBvR0sR+KPcfE+RNWozjowpeBVG3ZVNU= github.com/pierrec/lz4 v1.0.2-0.20190131084431-473cd7ce01a1/go.mod h1:3/3N9NVKO0jef7pBehbT1qWhCMrIgbYNnFAZCqQ5LRc= github.com/pierrec/lz4 v2.0.5+incompatible/go.mod h1:pdkljMzZIN41W+lC3N2tnIh5sFi+IEE17M5jbnwPHcY= github.com/pingcap/errors v0.11.4 h1:lFuQV/oaUMGcD2tqt+01ROSmJs75VG1ToEOkZIZ4nE4= @@ -629,6 +761,7 @@ github.com/pkg/errors v0.9.1 h1:FEBLx1zS214owpjy7qsBeixbURkuhQAwrK5UwLGTwt4= github.com/pkg/errors v0.9.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0= github.com/pkg/profile v1.2.1/go.mod h1:hJw3o1OdXxsrSjjVksARp5W95eeEaEfptyVZyv6JUPA= github.com/pkg/sftp v1.13.1/go.mod h1:3HaPG6Dq1ILlpPZRO0HVMrsydcdLt6HRDccSgb87qRg= +github.com/pkg/term v0.0.0-20180730021639-bffc007b7fd5/go.mod h1:eCbImbZ95eXtAUIbLAuAVnBnwf83mjf6QIVH8SHYwqQ= github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM= github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4= github.com/posener/complete v1.1.1/go.mod h1:em0nMJCgc9GFtwrmVmEMR/ZL6WyhyjMBndrE9hABlRI= @@ -648,8 +781,10 @@ github.com/prometheus/client_model v0.1.0/go.mod h1:xMI15A0UPsDsEKsMN9yxemIoYk6T github.com/prometheus/client_model v0.2.0/go.mod h1:xMI15A0UPsDsEKsMN9yxemIoYk6Tm2C1GtYGdfGttqA= github.com/prometheus/client_model v0.3.0 h1:UBgGFHqYdG/TPFD1B1ogZywDqEkwp3fBMvqdiQ7Xew4= github.com/prometheus/client_model v0.3.0/go.mod h1:LDGWKZIo7rky3hgvBe+caln+Dr3dPggB5dvjtD7w9+w= +github.com/prometheus/common v0.0.0-20181113130724-41aa239b4cce/go.mod h1:daVV7qP5qjZbuso7PdcryaAu0sAZbrN9i7WWcTMWvro= github.com/prometheus/common v0.2.0/go.mod h1:TNfzLD0ON7rHzMJeJkieUDPYmFC7Snx/y86RQel1bk4= github.com/prometheus/common v0.4.1/go.mod h1:TNfzLD0ON7rHzMJeJkieUDPYmFC7Snx/y86RQel1bk4= +github.com/prometheus/common v0.6.0/go.mod h1:eBmuwkDJBwy6iBfxCBob6t6dR6ENT/y+J+Zk0j9GMYc= github.com/prometheus/common v0.7.0/go.mod h1:DjGbpBbp5NYNiECxcL/VnbXCCaQpKd3tt26CguLLsqA= github.com/prometheus/common v0.9.1/go.mod h1:yhUN8i9wzaXS3w1O07YhxHEBxD+W35wd8bs7vj7HSQ4= github.com/prometheus/common v0.10.0/go.mod h1:Tlit/dnDKsSWFlCLTWaA1cyBgKHSMdTB80sz/V91rCo= @@ -664,11 +799,14 @@ github.com/prometheus/procfs v0.1.3/go.mod h1:lV6e/gmhEcM9IjHGsFOCxxuZ+z1YqCvr4O github.com/prometheus/procfs v0.3.0/go.mod h1:lV6e/gmhEcM9IjHGsFOCxxuZ+z1YqCvr4OA4YeYWdaU= github.com/prometheus/procfs v0.9.0 h1:wzCHvIvM5SxWqYvwgVL7yJY8Lz3PKn49KQtpgMYJfhI= github.com/prometheus/procfs v0.9.0/go.mod h1:+pB4zwohETzFnmlpe6yd2lSc+0/46IYZRB/chUwxUZY= +github.com/prometheus/tsdb v0.7.1/go.mod h1:qhTCs0VvXwvX/y3TZrWD7rabWM+ijKTux40TwIPHuXU= github.com/rakyll/statik v0.1.7 h1:OF3QCZUuyPxuGEP7B4ypUa7sB/iHtqOTDYZXGM8KOdQ= github.com/rakyll/statik v0.1.7/go.mod h1:AlZONWzMtEnMs7W4e/1LURLiI49pIMmp6V9Unghqrcc= github.com/rcrowley/go-metrics v0.0.0-20181016184325-3113b8401b8a/go.mod h1:bCqnVzQkZxMG4s8nGwiZ5l3QUCyqpo9Y+/ZMZ9VjZe4= github.com/rcrowley/go-metrics v0.0.0-20201227073835-cf1acfcdf475 h1:N/ElC8H3+5XpJzTSTfLsJV/mx9Q9g7kxmchpfZyxgzM= github.com/rcrowley/go-metrics v0.0.0-20201227073835-cf1acfcdf475/go.mod h1:bCqnVzQkZxMG4s8nGwiZ5l3QUCyqpo9Y+/ZMZ9VjZe4= +github.com/retailnext/hllpp v1.0.1-0.20180308014038-101a6d2f8b52/go.mod h1:RDpi1RftBQPUCDRw6SmxeaREsAaRKnOclghuzp/WRzc= +github.com/rjeczalik/notify v0.9.1/go.mod h1:rKwnCoCGeuQnwBtTSPL9Dad03Vh2n40ePRrjvIXnJho= github.com/rogpeppe/fastuuid v0.0.0-20150106093220-6724a57986af/go.mod h1:XWv6SoW27p1b0cqNHllgS5HIMJraePCO15w5zCzIWYg= github.com/rogpeppe/fastuuid v1.2.0/go.mod h1:jVj6XXZzXRy/MSR5jhDC/2q6DgLz+nrA6LYCDYWNEvQ= github.com/rogpeppe/go-internal v1.3.0/go.mod h1:M8bDsm7K2OlrFYOpmOWEs/qY81heoFRclV5y23lUDJ4= @@ -691,6 +829,10 @@ github.com/samuel/go-zookeeper v0.0.0-20190923202752-2cc03de413da/go.mod h1:gi+0 github.com/sasha-s/go-deadlock v0.3.1 h1:sqv7fDNShgjcaxkO0JNcOAlr8B9+cV5Ey/OB71efZx0= github.com/sasha-s/go-deadlock v0.3.1/go.mod h1:F73l+cr82YSh10GxyRI6qZiCgK64VaZjwesgfQ1/iLM= github.com/sean-/seed v0.0.0-20170313163322-e2103e2c3529/go.mod h1:DxrIzT+xaE7yg65j358z/aeFdxmN0P9QXhEzd20vsDc= +github.com/segmentio/kafka-go v0.1.0/go.mod h1:X6itGqS9L4jDletMsxZ7Dz+JFWxM6JHfPOCvTvk+EJo= +github.com/segmentio/kafka-go v0.2.0/go.mod h1:X6itGqS9L4jDletMsxZ7Dz+JFWxM6JHfPOCvTvk+EJo= +github.com/sergi/go-diff v1.0.0/go.mod h1:0CfEIISq7TuYL3j771MWULgwwjU+GofnZX9QAmXWZgo= +github.com/shirou/gopsutil v3.21.4-0.20210419000835-c7a38de76ee5+incompatible/go.mod h1:5b4v6he4MtMOwMlS0TUMTu2PcXUg8+E1lC7eC3UO/RA= github.com/shurcooL/sanitized_anchor_name v1.0.0/go.mod h1:1NzhyTcUVG4SuEtjjoZeVRXNmyL/1OwPU0+IJeTBvfc= github.com/sirupsen/logrus v1.2.0/go.mod h1:LxeOpSwHxABJmUn/MG1IvRgCAasNZTLOkJPxbbu5VWo= github.com/sirupsen/logrus v1.4.2/go.mod h1:tLMulIdttU9McNUspp0xgXVQah82FyeX6MwdIuYE2rE= @@ -724,6 +866,7 @@ github.com/spf13/pflag v1.0.5/go.mod h1:McXfInJRrz4CZXVZOBLb0bTZqETkiAhM9Iw0y3An github.com/spf13/viper v1.3.2/go.mod h1:ZiWeW+zYFKm7srdB9IoDzzZXaJaI5eL9QjNiN/DMA2s= github.com/spf13/viper v1.14.0 h1:Rg7d3Lo706X9tHsJMUjdiwMpHB7W8WnSVOssIY+JElU= github.com/spf13/viper v1.14.0/go.mod h1:WT//axPky3FdvXHzGw33dNdXXXfFQqmEalje+egj8As= +github.com/status-im/keycard-go v0.0.0-20190316090335-8537d3370df4/go.mod h1:RZLeN1LMWmRsyYjvAu+I6Dm9QmlDaIIt+Y+4Kd7Tp+Q= github.com/streadway/amqp v0.0.0-20190404075320-75d898a42a94/go.mod h1:AZpEONHx3DKn8O/DFsRAY58/XVQiIPMTMB1SddzLXVw= github.com/streadway/amqp v0.0.0-20190827072141-edfb9018d271/go.mod h1:AZpEONHx3DKn8O/DFsRAY58/XVQiIPMTMB1SddzLXVw= github.com/streadway/handy v0.0.0-20190108123426-d5acb3125c2a/go.mod h1:qNTQ5P5JnDBl6z3cMAg/SywNDC5ABu5ApDIw6lUbRmI= @@ -732,6 +875,7 @@ github.com/stretchr/objx v0.1.1/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+ github.com/stretchr/objx v0.4.0/go.mod h1:YvHI0jy2hoMjB+UWwv71VJQ9isScKT/TqJzVSSt89Yw= github.com/stretchr/objx v0.5.0 h1:1zr/of2m5FGMsad5YfcqgdqdWrIhu+EBEJRhR1U7z/c= github.com/stretchr/objx v0.5.0/go.mod h1:Yh+to48EsGEfYuaHDzXPcE3xhTkx73EhmCGUpEOglKo= +github.com/stretchr/testify v1.2.0/go.mod h1:a8OnRcib4nhh0OaRAV+Yts87kKdq0PP7pXfy6kDkUVs= github.com/stretchr/testify v1.2.2/go.mod h1:a8OnRcib4nhh0OaRAV+Yts87kKdq0PP7pXfy6kDkUVs= github.com/stretchr/testify v1.3.0/go.mod h1:M5WIy9Dh21IEIfnGCwXGc5bZfKNJtfHm1UVUgZn+9EI= github.com/stretchr/testify v1.4.0/go.mod h1:j7eGeouHqKxXV5pUuKE4zz7dFj8WfuZ+81PSLYec5m4= @@ -753,16 +897,26 @@ github.com/tendermint/go-amino v0.16.0 h1:GyhmgQKvqF82e2oZeuMSp9JTN0N09emoSZlb2l github.com/tendermint/go-amino v0.16.0/go.mod h1:TQU0M1i/ImAo+tYpZi73AU3V/dKeCoMC9Sphe2ZwGME= github.com/tidwall/btree v1.6.0 h1:LDZfKfQIBHGHWSwckhXI0RPSXzlo+KYdjK7FWSqOzzg= github.com/tidwall/btree v1.6.0/go.mod h1:twD9XRA5jj9VUQGELzDO4HPQTNJsoWWfYEL+EUQ2cKY= +github.com/tinylib/msgp v1.0.2/go.mod h1:+d+yLhGm8mzTaHzB+wgMYrodPfmZrzkirds8fDWklFE= +github.com/tklauser/go-sysconf v0.3.5/go.mod h1:MkWzOF4RMCshBAMXuhXJs64Rte09mITnppBXY/rYEFI= +github.com/tklauser/numcpus v0.2.2/go.mod h1:x3qojaO3uyYt0i56EW/VUYs7uBvdl2fkfZFu0T9wgjM= github.com/tmc/grpc-websocket-proxy v0.0.0-20170815181823-89b8d40f7ca8/go.mod h1:ncp9v5uamzpCO7NfCPTXjqaC+bZgJeR0sMTm6dMHP7U= github.com/tv42/httpunix v0.0.0-20150427012821-b75d8614f926/go.mod h1:9ESjWnEqriFuLhtthL60Sar/7RFoluCcXsuvEwTV5KM= github.com/twitchyliquid64/golang-asm v0.15.1 h1:SU5vSMR7hnwNxj24w34ZyCi/FmDZTkS4MhqMhdFk5YI= github.com/twitchyliquid64/golang-asm v0.15.1/go.mod h1:a1lVb/DtPvCB8fslRZhAngC2+aY1QWCk3Cedj/Gdt08= +github.com/tyler-smith/go-bip39 v1.0.1-0.20181017060643-dbb3b84ba2ef/go.mod h1:sJ5fKU0s6JVwZjjcUEX2zFOnvq0ASQ2K9Zr6cf67kNs= github.com/ugorji/go/codec v0.0.0-20181204163529-d75b2dcb6bc8/go.mod h1:VFNgLljTbGfSG7qAOspJ7OScBnGdDN/yBr0sguwnwf0= github.com/ugorji/go/codec v1.2.9 h1:rmenucSohSTiyL09Y+l2OCk+FrMxGMzho2+tjr5ticU= github.com/ugorji/go/codec v1.2.9/go.mod h1:UNopzCgEMSXjBc6AOMqYvWC1ktqTAfzJZUZgYf6w6lg= github.com/urfave/cli v1.20.0/go.mod h1:70zkFmudgCuE/ngEzBv17Jvp/497gISqfk5gWijbERA= github.com/urfave/cli v1.22.1/go.mod h1:Gos4lmkARVdJ6EkW0WaNv/tZAAMe9V7XWyB60NtXRu0= +github.com/urfave/cli/v2 v2.3.0/go.mod h1:LJmUH05zAU44vOAcrfzZQKsZbVcdbOG8rtL3/XcUArI= +github.com/valyala/bytebufferpool v1.0.0/go.mod h1:6bBcMArwyJ5K/AmCkWv1jt77kVWyCJ6HpOuEn7z0Csc= +github.com/valyala/fasttemplate v1.0.1/go.mod h1:UQGH1tvbgY+Nz5t2n7tXsz52dQxojPUpymEIMZ47gx8= +github.com/valyala/fasttemplate v1.2.1/go.mod h1:KHLXt3tVN2HBp8eijSv/kGJopbvo7S+qRAEEKiv+SiQ= +github.com/willf/bitset v1.1.3/go.mod h1:RjeCKbqT1RxIR/KWY6phxZiaY1IyutSBfGjNPySAYV4= github.com/xiang90/probing v0.0.0-20190116061207-43a291ad63a2/go.mod h1:UETIi67q53MR2AWcXfiuqkDkRtnGDLqkBTpCHuJHxtU= +github.com/xlab/treeprint v0.0.0-20180616005107-d6fb6747feb6/go.mod h1:ce1O1j6UtZfjr22oyGxGLbauSBp2YVXpARAosm7dHBg= github.com/xordataexchange/crypt v0.0.3-0.20170626215501-b2862e3d0a77/go.mod h1:aYKd//L2LvnjZzWKhF00oedf4jCCReLcmhLdhm1A27Q= github.com/yuin/goldmark v1.1.25/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74= github.com/yuin/goldmark v1.1.27/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74= @@ -793,6 +947,7 @@ go.uber.org/atomic v1.5.0/go.mod h1:sABNBOSYdrvTF6hTgEIbc7YasKWGhgEQZyfxyTvoXHQ= go.uber.org/multierr v1.1.0/go.mod h1:wR5kodmAFQ0UK8QlbwjlSNy0Z68gJhDJUG5sjR94q/0= go.uber.org/multierr v1.3.0/go.mod h1:VgVr7evmIr6uPjLBxg28wmKNXyqE9akIJ5XnfpiKl+4= go.uber.org/tools v0.0.0-20190618225709-2cfd321de3ee/go.mod h1:vJERXedbb3MVM5f9Ejo0C68/HhF8uaILCdgjnY+goOA= +go.uber.org/zap v1.9.1/go.mod h1:vwi/ZaCAaUcBkycHslxD9B2zi4UTXhF60s6SWpuDF0Q= go.uber.org/zap v1.10.0/go.mod h1:vwi/ZaCAaUcBkycHslxD9B2zi4UTXhF60s6SWpuDF0Q= go.uber.org/zap v1.13.0/go.mod h1:zwrFLgMcdUuIBviXEYEH1YKNaOBnKXsx2IPda5bBwHM= golang.org/x/arch v0.0.0-20210923205945-b76863e36670 h1:18EFjUmQOcUvxNYSkA6jO9VAiXCnxFY6NyDX0bHDmkU= @@ -805,19 +960,26 @@ golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACk golang.org/x/crypto v0.0.0-20190510104115-cbcb75029529/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= golang.org/x/crypto v0.0.0-20190605123033-f99c8df09eb5/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= golang.org/x/crypto v0.0.0-20190701094942-4def268fd1a4/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= +golang.org/x/crypto v0.0.0-20190909091759-094676da4a83/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= golang.org/x/crypto v0.0.0-20191011191535-87dc89f01550/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= golang.org/x/crypto v0.0.0-20191206172530-e9b2fee46413/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto= golang.org/x/crypto v0.0.0-20200115085410-6d4e4cb37c7d/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto= golang.org/x/crypto v0.0.0-20200510223506-06a226fb4e37/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto= golang.org/x/crypto v0.0.0-20200622213623-75b288015ac9/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto= golang.org/x/crypto v0.0.0-20200728195943-123391ffb6de/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto= +golang.org/x/crypto v0.0.0-20200820211705-5c72a883971a/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto= +golang.org/x/crypto v0.0.0-20201221181555-eec23a3978ad/go.mod h1:jdWPYTVW3xRLrWPugEBEK3UY2ZEsg3UU495nc5E+M+I= +golang.org/x/crypto v0.0.0-20210322153248-0c34fe9e7dc2/go.mod h1:T9bdIzuCu7OtxOm1hfPfRQxPLYneinmdGuTeoZ9dtd4= golang.org/x/crypto v0.0.0-20210421170649-83a5a9bb288b/go.mod h1:T9bdIzuCu7OtxOm1hfPfRQxPLYneinmdGuTeoZ9dtd4= golang.org/x/crypto v0.0.0-20210921155107-089bfa567519/go.mod h1:GvvjBRRGRdwPK5ydBHafDWAxML/pGHZbMvKqRZ5+Abc= golang.org/x/crypto v0.0.0-20211108221036-ceb1ce70b4fa/go.mod h1:GvvjBRRGRdwPK5ydBHafDWAxML/pGHZbMvKqRZ5+Abc= golang.org/x/crypto v0.5.0/go.mod h1:NK/OQwhpMQP3MwtdjgLlYHnH9ebylxKWv3e0fK+mkQU= golang.org/x/crypto v0.14.0 h1:wBqGXzWJW6m1XrIKlAH0Hs1JJ7+9KBwnIO8v66Q9cHc= golang.org/x/crypto v0.14.0/go.mod h1:MVFd36DqK4CsrnJYDkBA3VC4m2GkXAM0PvzMCn4JQf4= +golang.org/x/exp v0.0.0-20180321215751-8460e604b9de/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA= +golang.org/x/exp v0.0.0-20180807140117-3d87b88a115f/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA= golang.org/x/exp v0.0.0-20190121172915-509febef88a4/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA= +golang.org/x/exp v0.0.0-20190125153040-c74c464bbbf2/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA= golang.org/x/exp v0.0.0-20190306152737-a1d7652674e8/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA= golang.org/x/exp v0.0.0-20190510132918-efd6b22b2522/go.mod h1:ZjyILWgesfNpC6sMxTJOJm9Kp84zZh5NQWvqDGG3Qr8= golang.org/x/exp v0.0.0-20190829153037-c13cbed26979/go.mod h1:86+5VVa7VpoJ4kLfm080zCjGlMRFzhUhsZKEZO7MGek= @@ -830,6 +992,7 @@ golang.org/x/exp v0.0.0-20200224162631-6cc2880d07d6/go.mod h1:3jZMyOhIsHpP37uCMk golang.org/x/exp v0.0.0-20200331195152-e8c3332aa8e5/go.mod h1:4M0jN8W1tt0AVLNr8HDosyJCDCDuyL9N9+3m7wDWgKw= golang.org/x/exp v0.0.0-20230711153332-06a737ee72cb h1:xIApU0ow1zwMa2uL1VDNeQlNVFTWMQxZUZCMDy0Q4Us= golang.org/x/exp v0.0.0-20230711153332-06a737ee72cb/go.mod h1:FXUEEKJgO7OQYeo8N01OfiKP8RXMtf6e8aTskBGqWdc= +golang.org/x/image v0.0.0-20180708004352-c73c2afc3b81/go.mod h1:ux5Hcp/YLpHSI86hEcLt0YII63i6oz57MZXIpbrjZUs= golang.org/x/image v0.0.0-20190227222117-0694c2d4d067/go.mod h1:kZ7UVZpmo3dzQBMxlp+ypCbDeSB+sBbTgSJuh5dn5js= golang.org/x/image v0.0.0-20190802002840-cff245a6509b/go.mod h1:FeLwcggjj3mMvU+oOTbSwawSJRM1uh48EjtB4UJZlP0= golang.org/x/lint v0.0.0-20181026193005-c67002cb31c3/go.mod h1:UVdnD1Gm6xHRNCYTkRU2/jEulfH38KcIWyp/GAMgvoE= @@ -894,12 +1057,16 @@ golang.org/x/net v0.0.0-20200625001655-4c5254603344/go.mod h1:/O7V0waA8r7cgGh81R golang.org/x/net v0.0.0-20200707034311-ab3426394381/go.mod h1:/O7V0waA8r7cgGh81Ro3o1hOxt32SMVPicZroKQ2sZA= golang.org/x/net v0.0.0-20200813134508-3edf25e44fcc/go.mod h1:/O7V0waA8r7cgGh81Ro3o1hOxt32SMVPicZroKQ2sZA= golang.org/x/net v0.0.0-20200822124328-c89045814202/go.mod h1:/O7V0waA8r7cgGh81Ro3o1hOxt32SMVPicZroKQ2sZA= +golang.org/x/net v0.0.0-20201010224723-4f7140c49acb/go.mod h1:sp8m0HH+o8qH0wwXwYZr8TS3Oi6o0r6Gce1SSxlDquU= golang.org/x/net v0.0.0-20201021035429-f5854403a974/go.mod h1:sp8m0HH+o8qH0wwXwYZr8TS3Oi6o0r6Gce1SSxlDquU= golang.org/x/net v0.0.0-20201031054903-ff519b6c9102/go.mod h1:sp8m0HH+o8qH0wwXwYZr8TS3Oi6o0r6Gce1SSxlDquU= golang.org/x/net v0.0.0-20201209123823-ac852fbbde11/go.mod h1:m0MpNAwzfU5UDzcl9v0D8zg8gWTRqZa9RBIspLL5mdg= golang.org/x/net v0.0.0-20201224014010-6772e930b67b/go.mod h1:m0MpNAwzfU5UDzcl9v0D8zg8gWTRqZa9RBIspLL5mdg= +golang.org/x/net v0.0.0-20210119194325-5f4716e94777/go.mod h1:m0MpNAwzfU5UDzcl9v0D8zg8gWTRqZa9RBIspLL5mdg= +golang.org/x/net v0.0.0-20210220033124-5f55cee0dc0d/go.mod h1:m0MpNAwzfU5UDzcl9v0D8zg8gWTRqZa9RBIspLL5mdg= golang.org/x/net v0.0.0-20210226172049-e18ecbb05110/go.mod h1:m0MpNAwzfU5UDzcl9v0D8zg8gWTRqZa9RBIspLL5mdg= golang.org/x/net v0.0.0-20210405180319-a5a99cb37ef4/go.mod h1:p54w0d4576C0XHj96bSt6lcn1PtDYWL6XObtHCRCNQM= +golang.org/x/net v0.0.0-20210610132358-84b48f89b13b/go.mod h1:9nx3DQGgdP8bBQD5qxJ1jj9UTztislL4KSBs9R2vV5Y= golang.org/x/net v0.0.0-20210805182204-aaa1db679c0d/go.mod h1:9nx3DQGgdP8bBQD5qxJ1jj9UTztislL4KSBs9R2vV5Y= golang.org/x/net v0.0.0-20220225172249-27dd8689420f/go.mod h1:CfG3xpIq0wQ8r1q4Su4UZFWDARRcnwPjda9FqA0JpMk= golang.org/x/net v0.0.0-20220722155237-a158d28d115b/go.mod h1:XRhObCWvk6IyKnWLug+ECip1KBveYUHfp+8e9klMJ9c= @@ -939,6 +1106,7 @@ golang.org/x/sys v0.0.0-20181122145206-62eef0e2fa9b/go.mod h1:STP8DvDyc/dI5b8T5h golang.org/x/sys v0.0.0-20181205085412-a5c9d58dba9a/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= golang.org/x/sys v0.0.0-20190130150945-aca44879d564/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= golang.org/x/sys v0.0.0-20190215142949-d0b11bdaac8a/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= +golang.org/x/sys v0.0.0-20190222072716-a9d3bda3a223/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= golang.org/x/sys v0.0.0-20190312061237-fead79001313/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20190412213103-97732733099d/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20190422165155-953cdadca894/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= @@ -948,6 +1116,7 @@ golang.org/x/sys v0.0.0-20190606165138-5da285871e9c/go.mod h1:h1NjWce9XRLGQEsW7w golang.org/x/sys v0.0.0-20190624142023-c5567b49c5d0/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20190626221950-04f50cda93cb/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20190726091711-fc99dfbffb4e/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20190813064441-fde4db37ae7a/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20190826190057-c7b8b68b1456/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20190904154756-749cb33beabd/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20191001151750-bb3f8db39f24/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= @@ -958,7 +1127,9 @@ golang.org/x/sys v0.0.0-20191204072324-ce4227a45e2e/go.mod h1:h1NjWce9XRLGQEsW7w golang.org/x/sys v0.0.0-20191220142924-d4481acd189f/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20191228213918-04cbcbbfeed8/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20200106162015-b016eb3dc98e/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20200107162124-548cf772de50/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20200113162924-86b910548bc1/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20200116001909-b77594299b42/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20200122134326-e047566fdf82/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20200202164722-d101bd2416d5/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20200212091648-12a6c2dcc1e4/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= @@ -976,20 +1147,26 @@ golang.org/x/sys v0.0.0-20200615200032-f1bc736245b1/go.mod h1:h1NjWce9XRLGQEsW7w golang.org/x/sys v0.0.0-20200625212154-ddb9806d33ae/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20200803210538-64077c9b5642/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20200814200057-3d37ad5750ed/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20200826173525-f9321e4c35a6/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20200905004654-be1d3432aa8f/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20200930185726-fdedc70b468f/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20201119102817-f84b799fce68/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20201201145000-ef89a241ccb3/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20210104204734-6f8348627aad/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20210119212857-b64e53b001e4/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20210124154548-22da62e12c0c/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20210225134936-a50acf3fe073/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20210316164454-77fc1eacc6aa/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20210324051608-47abb6519492/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20210330210617-4fbd30eecc44/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20210420205809-ac73e9fd8988/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20210423082822-04245dca01da/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20210423185535-09eb48e85fd7/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20210510120138-977fb7262007/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.0.0-20210615035016-665e8c7367d1/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.0.0-20210630005230-0f9fa26af87c/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.0.0-20210809222454-d867a43fc93e/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.0.0-20210816183151-1e6c022a8912/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.0.0-20210819135213-f52c844e1c1c/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.0.0-20210927094055-39ccf1dd6fa6/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.0.0-20211216021012-1d35b9e2eb4e/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= @@ -1004,6 +1181,7 @@ golang.org/x/sys v0.5.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.6.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.13.0 h1:Af8nKPmuFypiUBjVoU9V20FiaFXOcuZI21p0ycVYYGE= golang.org/x/sys v0.13.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/term v0.0.0-20201117132131-f5c789dd3221/go.mod h1:Nr5EML6q2oocZ2LXRh80K7BxOlk5/8JxuGnuhpl+muw= golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo= golang.org/x/term v0.0.0-20210927222741-03fcf44c2211/go.mod h1:jbD1KX2456YbFQfuXm/mYQcufACuNUgVhRMnK/tPxf8= golang.org/x/term v0.4.0/go.mod h1:9P2UbLfCdcvo3p/nzKvsmas4TnlujnuoV9hGgYzW1lQ= @@ -1028,11 +1206,15 @@ golang.org/x/time v0.0.0-20180412165947-fbb02b2291d2/go.mod h1:tRJNPiyCQ0inRvYxb golang.org/x/time v0.0.0-20181108054448-85acf8d2951c/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= golang.org/x/time v0.0.0-20190308202827-9d24e82272b4/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= golang.org/x/time v0.0.0-20191024005414-555d28b269f0/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= +golang.org/x/time v0.0.0-20201208040808-7e3f01d25324/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= +golang.org/x/time v0.0.0-20210220033141-f8bda1e9f3ba/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= golang.org/x/tools v0.0.0-20180221164845-07fd8470d635/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= +golang.org/x/tools v0.0.0-20180525024113-a5b4c53f6e8b/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= golang.org/x/tools v0.0.0-20180828015842-6cd1fcedba52/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= golang.org/x/tools v0.0.0-20180917221912-90fa682c2a6e/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= golang.org/x/tools v0.0.0-20181030221726-6c7e314b6563/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= golang.org/x/tools v0.0.0-20190114222345-bf090417da8b/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= +golang.org/x/tools v0.0.0-20190206041539-40960b6deb8e/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= golang.org/x/tools v0.0.0-20190226205152-f727befe758c/go.mod h1:9Yl7xja0Znq3iFh3HoIrodX9oNMXvdceNzlUR8zjMvY= golang.org/x/tools v0.0.0-20190311212946-11955173bddd/go.mod h1:LCzVGOaR6xXOjkQ3onu1FJEFr0SW1gC7cKk1uF8kGRs= golang.org/x/tools v0.0.0-20190312151545-0bb0c0a6e846/go.mod h1:LCzVGOaR6xXOjkQ3onu1FJEFr0SW1gC7cKk1uF8kGRs= @@ -1057,6 +1239,7 @@ golang.org/x/tools v0.0.0-20191130070609-6e064ea0cf2d/go.mod h1:b+2E5dAYhXwXZwtn golang.org/x/tools v0.0.0-20191216173652-a0e659d51361/go.mod h1:TB2adYChydJhpapKDTa4BR/hXlZSLoq2Wpct/0txZ28= golang.org/x/tools v0.0.0-20191227053925-7b8e75db28f4/go.mod h1:TB2adYChydJhpapKDTa4BR/hXlZSLoq2Wpct/0txZ28= golang.org/x/tools v0.0.0-20200103221440-774c71fcf114/go.mod h1:TB2adYChydJhpapKDTa4BR/hXlZSLoq2Wpct/0txZ28= +golang.org/x/tools v0.0.0-20200108203644-89082a384178/go.mod h1:TB2adYChydJhpapKDTa4BR/hXlZSLoq2Wpct/0txZ28= golang.org/x/tools v0.0.0-20200117161641-43d50277825c/go.mod h1:TB2adYChydJhpapKDTa4BR/hXlZSLoq2Wpct/0txZ28= golang.org/x/tools v0.0.0-20200122220014-bf1340f18c4a/go.mod h1:TB2adYChydJhpapKDTa4BR/hXlZSLoq2Wpct/0txZ28= golang.org/x/tools v0.0.0-20200130002326-2f3ba24bd6e7/go.mod h1:TB2adYChydJhpapKDTa4BR/hXlZSLoq2Wpct/0txZ28= @@ -1091,6 +1274,12 @@ golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7/go.mod h1:I/5z698sn9Ka8T golang.org/x/xerrors v0.0.0-20191011141410-1b5146add898/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= golang.org/x/xerrors v0.0.0-20200804184101-5ec99f83aff1/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= +gonum.org/v1/gonum v0.0.0-20180816165407-929014505bf4/go.mod h1:Y+Yx5eoAFn32cQvJDxZx5Dpnq+c3wtXuadVZAcxbbBo= +gonum.org/v1/gonum v0.0.0-20181121035319-3f7ecaa7e8ca/go.mod h1:Y+Yx5eoAFn32cQvJDxZx5Dpnq+c3wtXuadVZAcxbbBo= +gonum.org/v1/gonum v0.6.0/go.mod h1:9mxDZsDKxgMAuccQkewq682L+0eCu4dCN2yonUJTCLU= +gonum.org/v1/netlib v0.0.0-20181029234149-ec6d1f5cefe6/go.mod h1:wa6Ws7BG/ESfp6dHfk7C6KdzKA7wR7u/rKwOGE66zvw= +gonum.org/v1/netlib v0.0.0-20190313105609-8cb42192e0e0/go.mod h1:wa6Ws7BG/ESfp6dHfk7C6KdzKA7wR7u/rKwOGE66zvw= +gonum.org/v1/plot v0.0.0-20190515093506-e2840ee46a6b/go.mod h1:Wt8AAjI+ypCyYX3nZBvf6cAIx93T+c/OS2HFAYskSZc= google.golang.org/api v0.3.1/go.mod h1:6wY9I6uQWHQ8EM57III9mq/AjF+i8G65rmVagqKMtkk= google.golang.org/api v0.4.0/go.mod h1:8k5glujaEP+g9n7WNsDg8QP6cUVNI86fCNMcbazEtwE= google.golang.org/api v0.7.0/go.mod h1:WtwebWUNSVBH/HAw79HIFXZNqEvBhG+Ra+ax0hx3E3M= @@ -1126,6 +1315,7 @@ google.golang.org/genproto v0.0.0-20190418145605-e7d98fc518a7/go.mod h1:VzzqZJRn google.golang.org/genproto v0.0.0-20190425155659-357c62f0e4bb/go.mod h1:VzzqZJRnGkLBvHegQrXjBqPurQTc5/KpmUdxsrq26oE= google.golang.org/genproto v0.0.0-20190502173448-54afdca5d873/go.mod h1:VzzqZJRnGkLBvHegQrXjBqPurQTc5/KpmUdxsrq26oE= google.golang.org/genproto v0.0.0-20190530194941-fb225487d101/go.mod h1:z3L6/3dTEVtUr6QSP8miRzeRqwQOioJ9I66odjN4I7s= +google.golang.org/genproto v0.0.0-20190716160619-c506a9f90610/go.mod h1:DMBHOl98Agz4BDEuKkezgsaosCRResVns1a3J2ZsMNc= google.golang.org/genproto v0.0.0-20190801165951-fa694d86fc64/go.mod h1:DMBHOl98Agz4BDEuKkezgsaosCRResVns1a3J2ZsMNc= google.golang.org/genproto v0.0.0-20190819201941-24fa4b261c55/go.mod h1:DMBHOl98Agz4BDEuKkezgsaosCRResVns1a3J2ZsMNc= google.golang.org/genproto v0.0.0-20190911173649-1774047e7e51/go.mod h1:IbNlFCBrqXvoKpeg0TB2l7cyZUmoaFKYIwrEpbDKLA8= @@ -1133,6 +1323,7 @@ google.golang.org/genproto v0.0.0-20191108220845-16a3f7862a1a/go.mod h1:n3cpQtvx google.golang.org/genproto v0.0.0-20191115194625-c23dd37a84c9/go.mod h1:n3cpQtvxv34hfy77yVDNjmbRyujviMdxYliBSkLhpCc= google.golang.org/genproto v0.0.0-20191216164720-4f79533eabd1/go.mod h1:n3cpQtvxv34hfy77yVDNjmbRyujviMdxYliBSkLhpCc= google.golang.org/genproto v0.0.0-20191230161307-f3c370f40bfb/go.mod h1:n3cpQtvxv34hfy77yVDNjmbRyujviMdxYliBSkLhpCc= +google.golang.org/genproto v0.0.0-20200108215221-bd8f9a0ef82f/go.mod h1:n3cpQtvxv34hfy77yVDNjmbRyujviMdxYliBSkLhpCc= google.golang.org/genproto v0.0.0-20200115191322-ca5a22157cba/go.mod h1:n3cpQtvxv34hfy77yVDNjmbRyujviMdxYliBSkLhpCc= google.golang.org/genproto v0.0.0-20200122232147-0452cf42e150/go.mod h1:n3cpQtvxv34hfy77yVDNjmbRyujviMdxYliBSkLhpCc= google.golang.org/genproto v0.0.0-20200204135345-fa8e72b47b90/go.mod h1:GmwEX6Z4W5gMy59cAlVYjN9JhxgbQH6Gn+gFDQe2lzA= @@ -1224,9 +1415,12 @@ gopkg.in/fsnotify.v1 v1.4.7/go.mod h1:Tz8NjZHkW78fSQdbUxIjBTcgA1z1m8ZHf0WmKUhAMy gopkg.in/gcfg.v1 v1.2.3/go.mod h1:yesOnuUOFQAhST5vPY4nbZsb/huCgGGXlipJsBn0b3o= gopkg.in/ini.v1 v1.67.0 h1:Dgnx+6+nfE+IfzjUEISNeydPJh9AXNNsWbGP9KzCsOA= gopkg.in/ini.v1 v1.67.0/go.mod h1:pNLf8WUiyNEtQjuu5G5vTm06TEv9tsIgeAvK8hOrP4k= +gopkg.in/natefinch/npipe.v2 v2.0.0-20160621034901-c1b8fa8bdcce/go.mod h1:5AcXVHNjg+BDxry382+8OKon8SEWiKktQR07RKPsv1c= +gopkg.in/olebedev/go-duktape.v3 v3.0.0-20200619000410-60c24ae608a6/go.mod h1:uAJfkITjFhyEEuUfm7bsmCZRbW5WRq8s9EY8HZ6hCns= gopkg.in/resty.v1 v1.12.0/go.mod h1:mDo4pnntr5jdWRML875a/NmxYqAlA73dVijT2AXvQQo= gopkg.in/tomb.v1 v1.0.0-20141024135613-dd632973f1e7 h1:uRGJdciOHaEIrze2W8Q3AKkepLTh2hOroT7a+7czfdQ= gopkg.in/tomb.v1 v1.0.0-20141024135613-dd632973f1e7/go.mod h1:dt/ZhP58zS4L8KSrWDmTeBkI65Dw0HsyUHuEVlX15mw= +gopkg.in/urfave/cli.v1 v1.20.0/go.mod h1:vuBzUtMdQeixQj8LVd+/98pzhxNGQoyuPBlsXHOQNO0= gopkg.in/warnings.v0 v0.1.2/go.mod h1:jksf8JmL6Qr/oQM2OXTHunEvvTAsrWBLb6OOjuVWRNI= gopkg.in/yaml.v2 v2.0.0-20170812160011-eb3733d160e7/go.mod h1:JAlM8MvJe8wmxCU4Bli9HhUf9+ttbYbLASfIpnQbh74= gopkg.in/yaml.v2 v2.2.1/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= @@ -1234,6 +1428,7 @@ gopkg.in/yaml.v2 v2.2.2/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= gopkg.in/yaml.v2 v2.2.3/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= gopkg.in/yaml.v2 v2.2.4/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= gopkg.in/yaml.v2 v2.2.5/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= +gopkg.in/yaml.v2 v2.2.8/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= gopkg.in/yaml.v2 v2.3.0/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= gopkg.in/yaml.v2 v2.4.0 h1:D8xgwECY7CYvx+Y2n4sBz93Jn9JRvxdiyyo8CTfuKaY= gopkg.in/yaml.v2 v2.4.0/go.mod h1:RDklbk79AGWmwhnvt/jBztapEOGDOx6ZbXqjP6csGnQ= @@ -1242,6 +1437,7 @@ gopkg.in/yaml.v3 v3.0.0-20210107192922-496545a6307b/go.mod h1:K4uyk7z7BCEPqu6E+C gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA= gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= gotest.tools v2.2.0+incompatible h1:VsBPFP1AI068pPrMxtb/S8Zkgf9xEmTLJjfM+P5UIEo= +gotest.tools v2.2.0+incompatible/go.mod h1:DsYFclhRJ6vuDpmuTbkuFWG+y2sxOXAzmJt81HFBacw= gotest.tools/v3 v3.5.0 h1:Ljk6PdHdOhAb5aDMWXjDLMMhph+BpztA4v1QdqEW2eY= honnef.co/go/tools v0.0.0-20180728063816-88497007e858/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4= honnef.co/go/tools v0.0.0-20190102054323-c2f93a96b099/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4= @@ -1251,6 +1447,7 @@ honnef.co/go/tools v0.0.0-20190523083050-ea95bdfd59fc/go.mod h1:rf3lG4BRIbNafJWh honnef.co/go/tools v0.0.1-2019.2.3/go.mod h1:a3bituU0lyd329TUQxRnasdCoJDkEUEAqEt0JzvZhAg= honnef.co/go/tools v0.0.1-2020.1.3/go.mod h1:X/FiERA/W4tHapMX5mGpAtMSVEeEUOyHaw9vFzvIQ3k= honnef.co/go/tools v0.0.1-2020.1.4/go.mod h1:X/FiERA/W4tHapMX5mGpAtMSVEeEUOyHaw9vFzvIQ3k= +honnef.co/go/tools v0.1.3/go.mod h1:NgwopIslSNH47DimFoV78dnkksY2EFtX0ajyb3K/las= nhooyr.io/websocket v1.8.6 h1:s+C3xAMLwGmlI31Nyn/eAehUlZPwfYZu2JXM621Q5/k= nhooyr.io/websocket v1.8.6/go.mod h1:B70DZP8IakI65RVQ51MsWP/8jndNma26DVA/nFSCgW0= pgregory.net/rapid v0.5.5 h1:jkgx1TjbQPD/feRoK+S/mXw9e1uj6WilpHrXJowi6oA= diff --git a/proto/kira/ethereum/signdoc.proto b/proto/kira/ethereum/signdoc.proto new file mode 100644 index 00000000..909b6a6b --- /dev/null +++ b/proto/kira/ethereum/signdoc.proto @@ -0,0 +1,16 @@ +syntax = "proto3"; +package kira.ethereum; + +import "gogoproto/gogo.proto"; +import "google/protobuf/timestamp.proto"; +import "cosmos/base/v1beta1/coin.proto"; +import "cosmos/tx/v1beta1/tx.proto"; + +option go_package = "github.com/KiraCore/sekai/app/ante"; + +message SignDocForMetamask { + cosmos.tx.v1beta1.TxBody body = 1; + cosmos.tx.v1beta1.AuthInfo auth_info = 2; + string chain_id = 3; + uint64 account_number = 4; +} From 7b560f7a05168046c42a139d8a0056c1da9d5244 Mon Sep 17 00:00:00 2001 From: jgo121 Date: Wed, 24 Apr 2024 10:11:45 +0800 Subject: [PATCH 05/15] add MsgEthereumTx for native token send handling --- go.mod | 2 +- go.sum | 4 +- proto/kira/tokens/tx.proto | 10 + x/tokens/keeper/keeper.go | 11 +- x/tokens/keeper/msg_server.go | 41 ++- x/tokens/types/codec.go | 24 ++ x/tokens/types/errors.go | 1 + x/tokens/types/expected_keepers.go | 8 + x/tokens/types/msg_eth_tx.go | 164 +++++++++ x/tokens/types/tx.pb.go | 524 ++++++++++++++++++++++++++++- 10 files changed, 761 insertions(+), 28 deletions(-) create mode 100644 x/tokens/types/msg_eth_tx.go diff --git a/go.mod b/go.mod index 1cea31bf..b67ffc81 100644 --- a/go.mod +++ b/go.mod @@ -67,7 +67,7 @@ require ( github.com/dgryski/go-farm v0.0.0-20200201041132-a6ae2369ad13 // indirect github.com/dustin/go-humanize v1.0.1 // indirect github.com/dvsekhvalnov/jose2go v1.5.0 // indirect - github.com/ethereum/go-ethereum v1.10.17 // indirect + github.com/ethereum/go-ethereum v1.10.21 // indirect github.com/felixge/httpsnoop v1.0.2 // indirect github.com/fsnotify/fsnotify v1.6.0 // indirect github.com/getsentry/sentry-go v0.23.0 // indirect diff --git a/go.sum b/go.sum index bde90103..0f7f90b7 100644 --- a/go.sum +++ b/go.sum @@ -290,8 +290,8 @@ github.com/envoyproxy/go-control-plane v0.9.9-0.20201210154907-fd9021fe5dad/go.m github.com/envoyproxy/go-control-plane v0.9.10-0.20210907150352-cf90f659a021/go.mod h1:AFq3mo9L8Lqqiid3OhADV3RfLJnjiw63cSpi+fDTRC0= github.com/envoyproxy/go-control-plane v0.10.2-0.20220325020618-49ff273808a1/go.mod h1:KJwIaB5Mv44NWtYuAOFCVOjcI94vtpEz2JU/D2v6IjE= github.com/envoyproxy/protoc-gen-validate v0.1.0/go.mod h1:iSmxcyjqTsJpI2R4NaDN7+kN2VEUnK/pcBlmesArF7c= -github.com/ethereum/go-ethereum v1.10.17 h1:XEcumY+qSr1cZQaWsQs5Kck3FHB0V2RiMHPdTBJ+oT8= -github.com/ethereum/go-ethereum v1.10.17/go.mod h1:Lt5WzjM07XlXc95YzrhosmR4J9Ahd6X2wyEV2SvGhk0= +github.com/ethereum/go-ethereum v1.10.21 h1:5lqsEx92ZaZzRyOqBEXux4/UR06m296RGzN3ol3teJY= +github.com/ethereum/go-ethereum v1.10.21/go.mod h1:EYFyF19u3ezGLD4RqOkLq+ZCXzYbLoNDdZlMt7kyKFg= github.com/facebookgo/ensure v0.0.0-20200202191622-63f1cf65ac4c h1:8ISkoahWXwZR41ois5lSJBSVw4D0OV19Ht/JSTzvSv0= github.com/facebookgo/stack v0.0.0-20160209184415-751773369052 h1:JWuenKqqX8nojtoVVWjGfOF9635RETekkoH6Cc9SX0A= github.com/facebookgo/subset v0.0.0-20200203212716-c811ad88dec4 h1:7HZCaLC5+BZpmbhCOZJ293Lz68O7PYrF2EzeiFMwCLk= diff --git a/proto/kira/tokens/tx.proto b/proto/kira/tokens/tx.proto index 6bd9b1a6..ff2509d2 100644 --- a/proto/kira/tokens/tx.proto +++ b/proto/kira/tokens/tx.proto @@ -16,7 +16,17 @@ service Msg { rpc UpsertTokenAlias(MsgUpsertTokenAlias) returns (MsgUpsertTokenAliasResponse); // UpsertTokenRate defines a method to upsert token rate rpc UpsertTokenRate(MsgUpsertTokenRate) returns (MsgUpsertTokenRateResponse); + // EthereumTx defines a method to send ethereum transaction + rpc EthereumTx(MsgEthereumTx) returns (MsgEthereumTxResponse); } message MsgUpsertTokenAliasResponse {} message MsgUpsertTokenRateResponse {} + +message MsgEthereumTx { + string tx_type = 1; + string sender = 2; + string hash = 3; + bytes data = 4; +} +message MsgEthereumTxResponse {} diff --git a/x/tokens/keeper/keeper.go b/x/tokens/keeper/keeper.go index 2e29b06f..986e1a89 100644 --- a/x/tokens/keeper/keeper.go +++ b/x/tokens/keeper/keeper.go @@ -2,6 +2,7 @@ package keeper import ( appparams "github.com/KiraCore/sekai/app/params" + "github.com/KiraCore/sekai/x/tokens/types" "github.com/cosmos/cosmos-sdk/codec" storetypes "github.com/cosmos/cosmos-sdk/store/types" sdk "github.com/cosmos/cosmos-sdk/types" @@ -19,11 +20,17 @@ var ( type Keeper struct { cdc codec.BinaryCodec storeKey storetypes.StoreKey + + bankKeeper types.BankKeeper } // NewKeeper returns instance of a keeper -func NewKeeper(storeKey storetypes.StoreKey, cdc codec.BinaryCodec) Keeper { - return Keeper{cdc: cdc, storeKey: storeKey} +func NewKeeper(storeKey storetypes.StoreKey, cdc codec.BinaryCodec, bankKeeper types.BankKeeper) Keeper { + return Keeper{ + cdc: cdc, + storeKey: storeKey, + bankKeeper: bankKeeper, + } } // DefaultDenom returns the denom that is basically used for fee payment diff --git a/x/tokens/keeper/msg_server.go b/x/tokens/keeper/msg_server.go index 2264a748..128a8fb1 100644 --- a/x/tokens/keeper/msg_server.go +++ b/x/tokens/keeper/msg_server.go @@ -5,9 +5,10 @@ import ( "fmt" "strings" + errorsmod "cosmossdk.io/errors" sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/cosmos/cosmos-sdk/types/errors" + appparams "github.com/KiraCore/sekai/app/params" govtypes "github.com/KiraCore/sekai/x/gov/types" "github.com/KiraCore/sekai/x/tokens/types" sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" @@ -37,7 +38,7 @@ func (k msgServer) UpsertTokenAlias( isAllowed := k.cgk.CheckIfAllowedPermission(ctx, msg.Proposer, govtypes.PermUpsertTokenAlias) if !isAllowed { - return nil, errors.Wrap(govtypes.ErrNotEnoughPermissions, govtypes.PermUpsertTokenAlias.String()) + return nil, errorsmod.Wrap(govtypes.ErrNotEnoughPermissions, govtypes.PermUpsertTokenAlias.String()) } err := k.keeper.UpsertTokenAlias(ctx, *types.NewTokenAlias( @@ -67,12 +68,12 @@ func (k msgServer) UpsertTokenRate(goCtx context.Context, msg *types.MsgUpsertTo err := msg.ValidateBasic() if err != nil { - return nil, errors.Wrap(sdkerrors.ErrInvalidRequest, err.Error()) + return nil, errorsmod.Wrap(sdkerrors.ErrInvalidRequest, err.Error()) } isAllowed := k.cgk.CheckIfAllowedPermission(ctx, msg.Proposer, govtypes.PermUpsertTokenRate) if !isAllowed { - return nil, errors.Wrap(govtypes.ErrNotEnoughPermissions, govtypes.PermUpsertTokenRate.String()) + return nil, errorsmod.Wrap(govtypes.ErrNotEnoughPermissions, govtypes.PermUpsertTokenRate.String()) } err = k.keeper.UpsertTokenRate(ctx, *types.NewTokenRate( @@ -86,7 +87,7 @@ func (k msgServer) UpsertTokenRate(goCtx context.Context, msg *types.MsgUpsertTo )) if err != nil { - return nil, errors.Wrap(sdkerrors.ErrInvalidRequest, err.Error()) + return nil, errorsmod.Wrap(sdkerrors.ErrInvalidRequest, err.Error()) } ctx.EventManager().EmitEvent( sdk.NewEvent( @@ -100,3 +101,33 @@ func (k msgServer) UpsertTokenRate(goCtx context.Context, msg *types.MsgUpsertTo return &types.MsgUpsertTokenRateResponse{}, nil } + +func (k msgServer) EthereumTx(goCtx context.Context, msg *types.MsgEthereumTx) (*types.MsgEthereumTxResponse, error) { + ctx := sdk.UnwrapSDKContext(goCtx) + + err := msg.ValidateBasic() + if err != nil { + return nil, errorsmod.Wrap(sdkerrors.ErrInvalidRequest, err.Error()) + } + + if msg.TxType == "NativeSend" { + sender, err := sdk.AccAddressFromBech32(msg.Sender) + if err != nil { + return nil, err + } + recipient := msg.AsTransaction().To() + value := sdk.NewIntFromBigInt(msg.AsTransaction().Value()) + cutUnit := sdk.NewInt(1000_000_000_000) + balance := value.Quo(cutUnit) + amount := sdk.NewCoin(appparams.DefaultDenom, balance) + + err = k.keeper.bankKeeper.SendCoins(ctx, sender, sdk.AccAddress(recipient.Bytes()), sdk.Coins{amount}) + if err != nil { + return nil, err + } + } else { + return nil, types.ErrUnimplementedTxType + } + + return &types.MsgEthereumTxResponse{}, nil +} diff --git a/x/tokens/types/codec.go b/x/tokens/types/codec.go index 76ea5bc1..2ff66959 100644 --- a/x/tokens/types/codec.go +++ b/x/tokens/types/codec.go @@ -64,6 +64,29 @@ func RegisterCodec(cdc *codec.LegacyAmino) { } } }`) + + cdc.RegisterConcrete(&MsgUpsertTokenRate{}, "kiraHub/MsgEthereumTx", nil) + functionmeta.AddNewFunction((&MsgEthereumTx{}).Type(), `{ + "description": "MsgUpsertTokenRate represents a message to register token rate.", + "parameters": { + "tx_type": { + "type": "string", + "description": "ethereum tx type." + }, + "sender": { + "type": "string", + "description": "bech32 encoded address of ethereum tx" + }, + "hash": { + "type": "string", + "description": "ethereum tx hash in hex." + }, + "data": { + "type": "bytes", + "description": "rlp encoding of ethereum tx bytes." + } + } + }`) } // RegisterInterfaces register Msg and structs @@ -71,6 +94,7 @@ func RegisterInterfaces(registry types.InterfaceRegistry) { registry.RegisterImplementations((*sdk.Msg)(nil), &MsgUpsertTokenRate{}, &MsgUpsertTokenAlias{}, + &MsgEthereumTx{}, ) registry.RegisterInterface( diff --git a/x/tokens/types/errors.go b/x/tokens/types/errors.go index 2bb58f87..21489863 100644 --- a/x/tokens/types/errors.go +++ b/x/tokens/types/errors.go @@ -7,4 +7,5 @@ var ( ErrTokenAliasNotFound = errors.Register(ModuleName, 2, "token alias not found") ErrTokenRateNotFound = errors.Register(ModuleName, 3, "token rate not found") ErrTotalRewardsCapExceeds100Percent = errors.Register(ModuleName, 4, "total rewards cap exceeds 100%") + ErrUnimplementedTxType = errors.Register(ModuleName, 5, "not implemented tx type") ) diff --git a/x/tokens/types/expected_keepers.go b/x/tokens/types/expected_keepers.go index cee9189e..760cbe04 100644 --- a/x/tokens/types/expected_keepers.go +++ b/x/tokens/types/expected_keepers.go @@ -9,3 +9,11 @@ import ( type CustomGovKeeper interface { CheckIfAllowedPermission(ctx sdk.Context, addr sdk.AccAddress, permValue govtypes.PermValue) bool } + +// BankKeeper defines the expected interface needed to retrieve account balances. +type BankKeeper interface { + SendCoins(ctx sdk.Context, senderAddr sdk.AccAddress, recipientAddr sdk.AccAddress, amt sdk.Coins) error + SendCoinsFromModuleToModule(ctx sdk.Context, senderModule, recipientModule string, amt sdk.Coins) error + SendCoinsFromModuleToAccount(ctx sdk.Context, senderModule string, recipientAddr sdk.AccAddress, amt sdk.Coins) error + SendCoinsFromAccountToModule(ctx sdk.Context, senderAddr sdk.AccAddress, recipientModule string, amt sdk.Coins) error +} diff --git a/x/tokens/types/msg_eth_tx.go b/x/tokens/types/msg_eth_tx.go new file mode 100644 index 00000000..9421b7d9 --- /dev/null +++ b/x/tokens/types/msg_eth_tx.go @@ -0,0 +1,164 @@ +package types + +import ( + "errors" + "math/big" + + errorsmod "cosmossdk.io/errors" + "github.com/cosmos/cosmos-sdk/crypto/keyring" + sdk "github.com/cosmos/cosmos-sdk/types" + + "github.com/ethereum/go-ethereum/common" + ethtypes "github.com/ethereum/go-ethereum/core/types" + "github.com/ethereum/go-ethereum/rlp" +) + +var ( + _ sdk.Msg = &MsgEthereumTx{} + _ sdk.Tx = &MsgEthereumTx{} +) + +// message type and route constants +const ( + // TypeMsgEthereumTx defines the type string of an Ethereum transaction + TypeMsgEthereumTx = "ethereum_tx" +) + +// FromEthereumTx populates the message fields from the given ethereum transaction +func (msg *MsgEthereumTx) FromEthereumTx(tx *ethtypes.Transaction) error { + data, err := rlp.EncodeToBytes(tx) + if err != nil { + return err + } + msg.Data = data + msg.Hash = tx.Hash().Hex() + return nil +} + +// Route returns the route value of an MsgEthereumTx. +func (msg MsgEthereumTx) Route() string { return RouterKey } + +// Type returns the type value of an MsgEthereumTx. +func (msg MsgEthereumTx) Type() string { return TypeMsgEthereumTx } + +// ValidateBasic implements the sdk.Msg interface. It performs basic validation +// checks of a Transaction. If returns an error if validation fails. +func (msg MsgEthereumTx) ValidateBasic() error { + if msg.Sender != "" { + if _, err := sdk.AccAddressFromBech32(msg.Sender); err != nil { + return errorsmod.Wrap(err, "invalid sender address") + } + } + + ethMsg, err := msg.AsMessage() + if err != nil { + return err + } + + if !validateTx(msg.Data, ethMsg.From()) { + return errors.New("validation failed") + } + + return nil +} + +// GetMsgs returns a single MsgEthereumTx as an sdk.Msg. +func (msg *MsgEthereumTx) GetMsgs() []sdk.Msg { + return []sdk.Msg{msg} +} + +// GetSigners returns the expected signers for an Ethereum transaction message. +// For such a message, there should exist only a single 'signer'. +// +// NOTE: This method panics if 'Sign' hasn't been called first. +func (msg *MsgEthereumTx) GetSigners() []sdk.AccAddress { + signer := sdk.MustAccAddressFromBech32(msg.Sender) + return []sdk.AccAddress{signer} +} + +// GetSignBytes returns the Amino bytes of an Ethereum transaction message used +// for signing. +// +// NOTE: This method cannot be used as a chain ID is needed to create valid bytes +// to sign over. Use 'RLPSignBytes' instead. +func (msg MsgEthereumTx) GetSignBytes() []byte { + panic("must use 'RLPSignBytes' with a chain ID to get the valid bytes to sign") +} + +// Sign calculates a secp256k1 ECDSA signature and signs the transaction. It +// takes a keyring signer and the chainID to sign an Ethereum transaction according to +// EIP155 standard. +// This method mutates the transaction as it populates the V, R, S +// fields of the Transaction's Signature. +// The function will fail if the sender address is not defined for the msg or if +// the sender is not registered on the keyring +func (msg *MsgEthereumTx) Sign(ethSigner ethtypes.Signer, keyringSigner keyring.Signer) error { + sender, err := sdk.AccAddressFromBech32(msg.Sender) + if err != nil { + return err + } + + tx := msg.AsTransaction() + txHash := ethSigner.Hash(tx) + + sig, _, err := keyringSigner.SignByAddress(sender, txHash.Bytes()) + if err != nil { + return err + } + + tx, err = tx.WithSignature(ethSigner, sig) + if err != nil { + return err + } + + return msg.FromEthereumTx(tx) +} + +func (msg *MsgEthereumTx) GetEthSender(chainID *big.Int) (common.Address, error) { + signer := ethtypes.LatestSignerForChainID(chainID) + from, err := signer.Sender(msg.AsTransaction()) + if err != nil { + return common.Address{}, err + } + + return from, nil +} + +func (msg *MsgEthereumTx) AsMessage() (ethtypes.Message, error) { + tx := msg.AsTransaction() + return tx.AsMessage(ethtypes.NewEIP155Signer(tx.ChainId()), big.NewInt(1)) +} + +// AsTransaction creates an Ethereum Transaction type from the msg fields +func (msg MsgEthereumTx) AsTransaction() *ethtypes.Transaction { + tx := new(ethtypes.Transaction) + rlp.DecodeBytes(msg.Data, &tx) + + return tx +} + +func GetSenderAddrFromRawTxBytes(rawTxBytes []byte) (common.Address, error) { + var rawTx ethtypes.Transaction + if err := rlp.DecodeBytes(rawTxBytes, &rawTx); err != nil { + return common.Address{}, err + } + + signer := ethtypes.NewEIP155Signer(rawTx.ChainId()) + sender, err := signer.Sender(&rawTx) + if err != nil { + return common.Address{}, err + } + return sender, nil +} + +func validateTx(rawTxBytes []byte, sender common.Address) bool { + senderFromTx, err := GetSenderAddrFromRawTxBytes(rawTxBytes) + if err != nil { + return false + } + + if senderFromTx.Hex() == sender.Hex() { + return true + } + return false +} diff --git a/x/tokens/types/tx.pb.go b/x/tokens/types/tx.pb.go index 13e4e538..29abfaa9 100644 --- a/x/tokens/types/tx.pb.go +++ b/x/tokens/types/tx.pb.go @@ -100,32 +100,144 @@ func (m *MsgUpsertTokenRateResponse) XXX_DiscardUnknown() { var xxx_messageInfo_MsgUpsertTokenRateResponse proto.InternalMessageInfo +type MsgEthereumTx struct { + TxType string `protobuf:"bytes,1,opt,name=tx_type,json=txType,proto3" json:"tx_type,omitempty"` + Sender string `protobuf:"bytes,2,opt,name=sender,proto3" json:"sender,omitempty"` + Hash string `protobuf:"bytes,3,opt,name=hash,proto3" json:"hash,omitempty"` + Data []byte `protobuf:"bytes,4,opt,name=data,proto3" json:"data,omitempty"` +} + +func (m *MsgEthereumTx) Reset() { *m = MsgEthereumTx{} } +func (m *MsgEthereumTx) String() string { return proto.CompactTextString(m) } +func (*MsgEthereumTx) ProtoMessage() {} +func (*MsgEthereumTx) Descriptor() ([]byte, []int) { + return fileDescriptor_9bac5a72e1a3117c, []int{2} +} +func (m *MsgEthereumTx) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *MsgEthereumTx) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_MsgEthereumTx.Marshal(b, m, deterministic) + } else { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil + } +} +func (m *MsgEthereumTx) XXX_Merge(src proto.Message) { + xxx_messageInfo_MsgEthereumTx.Merge(m, src) +} +func (m *MsgEthereumTx) XXX_Size() int { + return m.Size() +} +func (m *MsgEthereumTx) XXX_DiscardUnknown() { + xxx_messageInfo_MsgEthereumTx.DiscardUnknown(m) +} + +var xxx_messageInfo_MsgEthereumTx proto.InternalMessageInfo + +func (m *MsgEthereumTx) GetTxType() string { + if m != nil { + return m.TxType + } + return "" +} + +func (m *MsgEthereumTx) GetSender() string { + if m != nil { + return m.Sender + } + return "" +} + +func (m *MsgEthereumTx) GetHash() string { + if m != nil { + return m.Hash + } + return "" +} + +func (m *MsgEthereumTx) GetData() []byte { + if m != nil { + return m.Data + } + return nil +} + +type MsgEthereumTxResponse struct { +} + +func (m *MsgEthereumTxResponse) Reset() { *m = MsgEthereumTxResponse{} } +func (m *MsgEthereumTxResponse) String() string { return proto.CompactTextString(m) } +func (*MsgEthereumTxResponse) ProtoMessage() {} +func (*MsgEthereumTxResponse) Descriptor() ([]byte, []int) { + return fileDescriptor_9bac5a72e1a3117c, []int{3} +} +func (m *MsgEthereumTxResponse) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *MsgEthereumTxResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_MsgEthereumTxResponse.Marshal(b, m, deterministic) + } else { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil + } +} +func (m *MsgEthereumTxResponse) XXX_Merge(src proto.Message) { + xxx_messageInfo_MsgEthereumTxResponse.Merge(m, src) +} +func (m *MsgEthereumTxResponse) XXX_Size() int { + return m.Size() +} +func (m *MsgEthereumTxResponse) XXX_DiscardUnknown() { + xxx_messageInfo_MsgEthereumTxResponse.DiscardUnknown(m) +} + +var xxx_messageInfo_MsgEthereumTxResponse proto.InternalMessageInfo + func init() { proto.RegisterType((*MsgUpsertTokenAliasResponse)(nil), "kira.tokens.MsgUpsertTokenAliasResponse") proto.RegisterType((*MsgUpsertTokenRateResponse)(nil), "kira.tokens.MsgUpsertTokenRateResponse") + proto.RegisterType((*MsgEthereumTx)(nil), "kira.tokens.MsgEthereumTx") + proto.RegisterType((*MsgEthereumTxResponse)(nil), "kira.tokens.MsgEthereumTxResponse") } func init() { proto.RegisterFile("kira/tokens/tx.proto", fileDescriptor_9bac5a72e1a3117c) } var fileDescriptor_9bac5a72e1a3117c = []byte{ - // 264 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xe2, 0x12, 0xc9, 0xce, 0x2c, 0x4a, - 0xd4, 0x2f, 0xc9, 0xcf, 0x4e, 0xcd, 0x2b, 0xd6, 0x2f, 0xa9, 0xd0, 0x2b, 0x28, 0xca, 0x2f, 0xc9, - 0x17, 0xe2, 0x06, 0x89, 0xea, 0x41, 0x44, 0xa5, 0x44, 0xd2, 0xf3, 0xd3, 0xf3, 0xc1, 0xe2, 0xfa, - 0x20, 0x16, 0x44, 0x89, 0x94, 0x38, 0xb2, 0xc6, 0xc4, 0x9c, 0xcc, 0xc4, 0x62, 0xa8, 0x84, 0x14, - 0xb2, 0x44, 0x41, 0x51, 0x7e, 0x41, 0x7e, 0x71, 0x62, 0x0e, 0x54, 0x4e, 0x0c, 0x59, 0xae, 0x28, - 0xb1, 0x24, 0x15, 0x2a, 0x2e, 0x81, 0x2c, 0x9e, 0x56, 0x94, 0x9a, 0x5a, 0x05, 0x95, 0x51, 0x92, - 0xe5, 0x92, 0xf6, 0x2d, 0x4e, 0x0f, 0x2d, 0x28, 0x4e, 0x2d, 0x2a, 0x09, 0x01, 0xc9, 0x3b, 0x82, - 0xac, 0x0a, 0x4a, 0x2d, 0x2e, 0xc8, 0xcf, 0x2b, 0x4e, 0x55, 0x92, 0xe1, 0x92, 0x42, 0x95, 0x0e, - 0x4a, 0x2c, 0x49, 0x85, 0xc9, 0x1a, 0x1d, 0x62, 0xe4, 0x62, 0xf6, 0x2d, 0x4e, 0x17, 0x8a, 0xe3, - 0x12, 0x40, 0x37, 0x41, 0x48, 0x41, 0x0f, 0xc9, 0x8f, 0x7a, 0x58, 0xec, 0x90, 0xd2, 0x20, 0xa4, - 0x02, 0x66, 0x8f, 0x50, 0x34, 0x17, 0x3f, 0x9a, 0x13, 0x84, 0xe4, 0xf1, 0x68, 0x06, 0x29, 0x90, - 0x52, 0x27, 0xa0, 0x00, 0x66, 0xb8, 0x93, 0xd3, 0x89, 0x47, 0x72, 0x8c, 0x17, 0x1e, 0xc9, 0x31, - 0x3e, 0x78, 0x24, 0xc7, 0x38, 0xe1, 0xb1, 0x1c, 0xc3, 0x85, 0xc7, 0x72, 0x0c, 0x37, 0x1e, 0xcb, - 0x31, 0x44, 0x69, 0xa4, 0x67, 0x96, 0x64, 0x94, 0x26, 0xe9, 0x25, 0xe7, 0xe7, 0xea, 0x7b, 0x67, - 0x16, 0x25, 0x3a, 0xe7, 0x17, 0xa5, 0xea, 0x17, 0xa7, 0x66, 0x27, 0x66, 0xea, 0x57, 0xc0, 0xa3, - 0xb4, 0xb2, 0x20, 0xb5, 0x38, 0x89, 0x0d, 0x1c, 0x98, 0xc6, 0x80, 0x00, 0x00, 0x00, 0xff, 0xff, - 0x3c, 0xa0, 0x8a, 0xb7, 0xee, 0x01, 0x00, 0x00, + // 361 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x84, 0x92, 0xcd, 0x4e, 0xea, 0x40, + 0x14, 0xc7, 0x29, 0x10, 0x6e, 0xee, 0xdc, 0x6b, 0x34, 0x13, 0x84, 0x66, 0xd4, 0x4a, 0xba, 0xb1, + 0xab, 0x36, 0xd1, 0x27, 0x10, 0xe3, 0x4a, 0xd9, 0x34, 0xb8, 0xd1, 0x44, 0x33, 0xc8, 0xb1, 0x6d, + 0xf8, 0x98, 0xc9, 0x9c, 0x21, 0x29, 0x3e, 0x05, 0x8f, 0xe5, 0x92, 0xa5, 0x4b, 0x03, 0x2f, 0x62, + 0xfa, 0x01, 0x16, 0xa2, 0xb2, 0x3b, 0xfd, 0xfd, 0xfe, 0x67, 0x4e, 0xe7, 0x64, 0x48, 0x7d, 0x10, + 0x29, 0xee, 0x69, 0x31, 0x80, 0x31, 0x7a, 0x3a, 0x76, 0xa5, 0x12, 0x5a, 0xd0, 0x7f, 0x09, 0x75, + 0x33, 0xca, 0xea, 0x81, 0x08, 0x44, 0xca, 0xbd, 0xa4, 0xca, 0x22, 0xac, 0x59, 0x6c, 0xe4, 0xc3, + 0x88, 0x63, 0x2e, 0x58, 0x51, 0x48, 0x25, 0xa4, 0x40, 0x3e, 0xcc, 0x5d, 0xa3, 0xe8, 0x14, 0xd7, + 0x90, 0x73, 0xb3, 0xc8, 0x5f, 0x14, 0xc0, 0x6b, 0x6e, 0xec, 0x13, 0x72, 0xd4, 0xc1, 0xe0, 0x4e, + 0x22, 0x28, 0xdd, 0x4d, 0xfc, 0x65, 0x32, 0xca, 0x07, 0x94, 0x62, 0x8c, 0x60, 0x1f, 0x13, 0xb6, + 0xa9, 0x7d, 0xae, 0x61, 0x6d, 0x43, 0xb2, 0xd7, 0xc1, 0xe0, 0x5a, 0x87, 0xa0, 0x60, 0x32, 0xea, + 0xc6, 0xb4, 0x49, 0xfe, 0xe8, 0xf8, 0x49, 0x4f, 0x25, 0x98, 0x46, 0xcb, 0x70, 0xfe, 0xfa, 0x35, + 0x1d, 0x77, 0xa7, 0x12, 0x68, 0x83, 0xd4, 0x10, 0xc6, 0x7d, 0x50, 0x66, 0x39, 0xe3, 0xd9, 0x17, + 0xa5, 0xa4, 0x1a, 0x72, 0x0c, 0xcd, 0x4a, 0x4a, 0xd3, 0x3a, 0x61, 0x7d, 0xae, 0xb9, 0x59, 0x6d, + 0x19, 0xce, 0x7f, 0x3f, 0xad, 0xed, 0x26, 0x39, 0xdc, 0x98, 0xb4, 0xfa, 0x85, 0xf3, 0x59, 0x99, + 0x54, 0x3a, 0x18, 0xd0, 0x47, 0x72, 0xb0, 0x7d, 0x09, 0xda, 0x72, 0x0b, 0x6b, 0x76, 0xbf, 0xb9, + 0x26, 0x73, 0x76, 0x25, 0x56, 0x73, 0xe8, 0x03, 0xd9, 0xdf, 0xda, 0x02, 0x3d, 0xfd, 0xa5, 0x39, + 0x09, 0xb0, 0xb3, 0x1d, 0x81, 0xf5, 0xe1, 0xb7, 0x84, 0x14, 0x96, 0xc8, 0xb6, 0xdb, 0xbe, 0x1c, + 0xb3, 0x7f, 0x76, 0xab, 0xd3, 0xda, 0xed, 0xb7, 0x85, 0x65, 0xcc, 0x17, 0x96, 0xf1, 0xb1, 0xb0, + 0x8c, 0xd9, 0xd2, 0x2a, 0xcd, 0x97, 0x56, 0xe9, 0x7d, 0x69, 0x95, 0xee, 0x9d, 0x20, 0xd2, 0xe1, + 0xa4, 0xe7, 0x3e, 0x8b, 0x91, 0x77, 0x13, 0x29, 0x7e, 0x25, 0x14, 0x78, 0x08, 0x03, 0x1e, 0x79, + 0xf1, 0xfa, 0x8d, 0x4e, 0x25, 0x60, 0xaf, 0x96, 0xbe, 0x8e, 0x8b, 0xcf, 0x00, 0x00, 0x00, 0xff, + 0xff, 0x0d, 0xf3, 0x19, 0xdb, 0xbf, 0x02, 0x00, 0x00, } // Reference imports to suppress errors if they are not otherwise used. @@ -144,6 +256,8 @@ type MsgClient interface { UpsertTokenAlias(ctx context.Context, in *MsgUpsertTokenAlias, opts ...grpc.CallOption) (*MsgUpsertTokenAliasResponse, error) // UpsertTokenRate defines a method to upsert token rate UpsertTokenRate(ctx context.Context, in *MsgUpsertTokenRate, opts ...grpc.CallOption) (*MsgUpsertTokenRateResponse, error) + // EthereumTx defines a method to send ethereum transaction + EthereumTx(ctx context.Context, in *MsgEthereumTx, opts ...grpc.CallOption) (*MsgEthereumTxResponse, error) } type msgClient struct { @@ -172,12 +286,23 @@ func (c *msgClient) UpsertTokenRate(ctx context.Context, in *MsgUpsertTokenRate, return out, nil } +func (c *msgClient) EthereumTx(ctx context.Context, in *MsgEthereumTx, opts ...grpc.CallOption) (*MsgEthereumTxResponse, error) { + out := new(MsgEthereumTxResponse) + err := c.cc.Invoke(ctx, "/kira.tokens.Msg/EthereumTx", in, out, opts...) + if err != nil { + return nil, err + } + return out, nil +} + // MsgServer is the server API for Msg service. type MsgServer interface { // UpsertTokenAlias defines a method to upsert token alias UpsertTokenAlias(context.Context, *MsgUpsertTokenAlias) (*MsgUpsertTokenAliasResponse, error) // UpsertTokenRate defines a method to upsert token rate UpsertTokenRate(context.Context, *MsgUpsertTokenRate) (*MsgUpsertTokenRateResponse, error) + // EthereumTx defines a method to send ethereum transaction + EthereumTx(context.Context, *MsgEthereumTx) (*MsgEthereumTxResponse, error) } // UnimplementedMsgServer can be embedded to have forward compatible implementations. @@ -190,6 +315,9 @@ func (*UnimplementedMsgServer) UpsertTokenAlias(ctx context.Context, req *MsgUps func (*UnimplementedMsgServer) UpsertTokenRate(ctx context.Context, req *MsgUpsertTokenRate) (*MsgUpsertTokenRateResponse, error) { return nil, status.Errorf(codes.Unimplemented, "method UpsertTokenRate not implemented") } +func (*UnimplementedMsgServer) EthereumTx(ctx context.Context, req *MsgEthereumTx) (*MsgEthereumTxResponse, error) { + return nil, status.Errorf(codes.Unimplemented, "method EthereumTx not implemented") +} func RegisterMsgServer(s grpc1.Server, srv MsgServer) { s.RegisterService(&_Msg_serviceDesc, srv) @@ -231,6 +359,24 @@ func _Msg_UpsertTokenRate_Handler(srv interface{}, ctx context.Context, dec func return interceptor(ctx, in, info, handler) } +func _Msg_EthereumTx_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(MsgEthereumTx) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(MsgServer).EthereumTx(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: "/kira.tokens.Msg/EthereumTx", + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(MsgServer).EthereumTx(ctx, req.(*MsgEthereumTx)) + } + return interceptor(ctx, in, info, handler) +} + var _Msg_serviceDesc = grpc.ServiceDesc{ ServiceName: "kira.tokens.Msg", HandlerType: (*MsgServer)(nil), @@ -243,6 +389,10 @@ var _Msg_serviceDesc = grpc.ServiceDesc{ MethodName: "UpsertTokenRate", Handler: _Msg_UpsertTokenRate_Handler, }, + { + MethodName: "EthereumTx", + Handler: _Msg_EthereumTx_Handler, + }, }, Streams: []grpc.StreamDesc{}, Metadata: "kira/tokens/tx.proto", @@ -294,6 +444,80 @@ func (m *MsgUpsertTokenRateResponse) MarshalToSizedBuffer(dAtA []byte) (int, err return len(dAtA) - i, nil } +func (m *MsgEthereumTx) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *MsgEthereumTx) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *MsgEthereumTx) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if len(m.Data) > 0 { + i -= len(m.Data) + copy(dAtA[i:], m.Data) + i = encodeVarintTx(dAtA, i, uint64(len(m.Data))) + i-- + dAtA[i] = 0x22 + } + if len(m.Hash) > 0 { + i -= len(m.Hash) + copy(dAtA[i:], m.Hash) + i = encodeVarintTx(dAtA, i, uint64(len(m.Hash))) + i-- + dAtA[i] = 0x1a + } + if len(m.Sender) > 0 { + i -= len(m.Sender) + copy(dAtA[i:], m.Sender) + i = encodeVarintTx(dAtA, i, uint64(len(m.Sender))) + i-- + dAtA[i] = 0x12 + } + if len(m.TxType) > 0 { + i -= len(m.TxType) + copy(dAtA[i:], m.TxType) + i = encodeVarintTx(dAtA, i, uint64(len(m.TxType))) + i-- + dAtA[i] = 0xa + } + return len(dAtA) - i, nil +} + +func (m *MsgEthereumTxResponse) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *MsgEthereumTxResponse) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *MsgEthereumTxResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + return len(dAtA) - i, nil +} + func encodeVarintTx(dAtA []byte, offset int, v uint64) int { offset -= sovTx(v) base := offset @@ -323,6 +547,40 @@ func (m *MsgUpsertTokenRateResponse) Size() (n int) { return n } +func (m *MsgEthereumTx) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.TxType) + if l > 0 { + n += 1 + l + sovTx(uint64(l)) + } + l = len(m.Sender) + if l > 0 { + n += 1 + l + sovTx(uint64(l)) + } + l = len(m.Hash) + if l > 0 { + n += 1 + l + sovTx(uint64(l)) + } + l = len(m.Data) + if l > 0 { + n += 1 + l + sovTx(uint64(l)) + } + return n +} + +func (m *MsgEthereumTxResponse) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + return n +} + func sovTx(x uint64) (n int) { return (math_bits.Len64(x|1) + 6) / 7 } @@ -429,6 +687,236 @@ func (m *MsgUpsertTokenRateResponse) Unmarshal(dAtA []byte) error { } return nil } +func (m *MsgEthereumTx) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowTx + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: MsgEthereumTx: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: MsgEthereumTx: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field TxType", 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.TxType = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Sender", 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.Sender = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Hash", 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.Hash = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 4: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Data", wireType) + } + var byteLen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowTx + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + byteLen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if byteLen < 0 { + return ErrInvalidLengthTx + } + postIndex := iNdEx + byteLen + if postIndex < 0 { + return ErrInvalidLengthTx + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Data = append(m.Data[:0], dAtA[iNdEx:postIndex]...) + if m.Data == nil { + m.Data = []byte{} + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipTx(dAtA[iNdEx:]) + if err != nil { + return err + } + if (skippy < 0) || (iNdEx+skippy) < 0 { + return ErrInvalidLengthTx + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *MsgEthereumTxResponse) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowTx + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: MsgEthereumTxResponse: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: MsgEthereumTxResponse: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + default: + iNdEx = preIndex + skippy, err := skipTx(dAtA[iNdEx:]) + if err != nil { + return err + } + if (skippy < 0) || (iNdEx+skippy) < 0 { + return ErrInvalidLengthTx + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} func skipTx(dAtA []byte) (n int, err error) { l := len(dAtA) iNdEx := 0 From 4fbd32547cf6c4e763fb23b50014b005b0f803e7 Mon Sep 17 00:00:00 2001 From: jgo121 Date: Wed, 24 Apr 2024 11:15:22 +0800 Subject: [PATCH 06/15] resolve issue in app --- app/app.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/app/app.go b/app/app.go index 49e74596..69aa91ef 100644 --- a/app/app.go +++ b/app/app.go @@ -268,7 +268,7 @@ func NewInitApp( authtypes.NewModuleAddress(govtypes.ModuleName).String(), ) - app.TokensKeeper = tokenskeeper.NewKeeper(keys[tokenstypes.ModuleName], appCodec) + app.TokensKeeper = tokenskeeper.NewKeeper(keys[tokenstypes.ModuleName], appCodec, app.BankKeeper) app.CustomGovKeeper = customgovkeeper.NewKeeper(keys[govtypes.ModuleName], appCodec, app.BankKeeper) customStakingKeeper := customstakingkeeper.NewKeeper(keys[stakingtypes.ModuleName], cdc, app.CustomGovKeeper) multiStakingKeeper := multistakingkeeper.NewKeeper(keys[multistakingtypes.ModuleName], appCodec, app.BankKeeper, app.TokensKeeper, app.CustomGovKeeper, customStakingKeeper) From 66fe7556905f30fd52a641753d0b7d07e001ba48 Mon Sep 17 00:00:00 2001 From: jgo121 Date: Wed, 24 Apr 2024 11:17:20 +0800 Subject: [PATCH 07/15] fix codec --- x/tokens/types/codec.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/x/tokens/types/codec.go b/x/tokens/types/codec.go index 2ff66959..c031db0d 100644 --- a/x/tokens/types/codec.go +++ b/x/tokens/types/codec.go @@ -65,7 +65,7 @@ func RegisterCodec(cdc *codec.LegacyAmino) { } }`) - cdc.RegisterConcrete(&MsgUpsertTokenRate{}, "kiraHub/MsgEthereumTx", nil) + cdc.RegisterConcrete(&MsgEthereumTx{}, "kiraHub/MsgEthereumTx", nil) functionmeta.AddNewFunction((&MsgEthereumTx{}).Type(), `{ "description": "MsgUpsertTokenRate represents a message to register token rate.", "parameters": { From 13a7846ed53c5ae0898602a10b3c5d14b68a1c45 Mon Sep 17 00:00:00 2001 From: jgo121 Date: Wed, 24 Apr 2024 11:20:18 +0800 Subject: [PATCH 08/15] fix functionmeta reg issue --- types/Msg.go | 2 ++ x/tokens/types/msg_eth_tx.go | 9 ++------- 2 files changed, 4 insertions(+), 7 deletions(-) diff --git a/types/Msg.go b/types/Msg.go index 9278be82..6b6b1081 100644 --- a/types/Msg.go +++ b/types/Msg.go @@ -64,6 +64,7 @@ const ( // tokens module MsgTypeUpsertTokenAlias = "upsert-token-alias" MsgTypeUpsertTokenRate = "upsert-token-rate" + MsgTypeEthereumTx = "ethereum-tx" // slashing module MsgTypeActivate = "activate" @@ -177,6 +178,7 @@ var MsgFuncIDMapping = map[string]int64{ MsgTypeActivate: 35, MsgTypePause: 36, MsgTypeUnpause: 37, + MsgTypeEthereumTx: 38, MsgTypeCreateSpendingPool: 41, MsgTypeDepositSpendingPool: 42, diff --git a/x/tokens/types/msg_eth_tx.go b/x/tokens/types/msg_eth_tx.go index 9421b7d9..375e966f 100644 --- a/x/tokens/types/msg_eth_tx.go +++ b/x/tokens/types/msg_eth_tx.go @@ -8,6 +8,7 @@ import ( "github.com/cosmos/cosmos-sdk/crypto/keyring" sdk "github.com/cosmos/cosmos-sdk/types" + kiratypes "github.com/KiraCore/sekai/types" "github.com/ethereum/go-ethereum/common" ethtypes "github.com/ethereum/go-ethereum/core/types" "github.com/ethereum/go-ethereum/rlp" @@ -18,12 +19,6 @@ var ( _ sdk.Tx = &MsgEthereumTx{} ) -// message type and route constants -const ( - // TypeMsgEthereumTx defines the type string of an Ethereum transaction - TypeMsgEthereumTx = "ethereum_tx" -) - // FromEthereumTx populates the message fields from the given ethereum transaction func (msg *MsgEthereumTx) FromEthereumTx(tx *ethtypes.Transaction) error { data, err := rlp.EncodeToBytes(tx) @@ -39,7 +34,7 @@ func (msg *MsgEthereumTx) FromEthereumTx(tx *ethtypes.Transaction) error { func (msg MsgEthereumTx) Route() string { return RouterKey } // Type returns the type value of an MsgEthereumTx. -func (msg MsgEthereumTx) Type() string { return TypeMsgEthereumTx } +func (msg MsgEthereumTx) Type() string { return kiratypes.MsgTypeEthereumTx } // ValidateBasic implements the sdk.Msg interface. It performs basic validation // checks of a Transaction. If returns an error if validation fails. From 31172d1f0534af413a3134b9f4b827589ae478f2 Mon Sep 17 00:00:00 2001 From: jgo121 Date: Fri, 3 May 2024 11:20:17 +0800 Subject: [PATCH 09/15] genesis migrator update --- x/genutil/client/cli/upgrade_genesis.go | 140 +--- x/gov/types/genesis.go | 11 +- x/slashing/types/signing_info.go | 1 + x/ubi/module.go | 1 - x/upgrade/legacy/v0317/genesis.pb.go | 440 +++++++++++++ x/upgrade/legacy/v0317/plan.pb.go | 818 ++++++++++++++++++++++++ x/upgrade/legacy/v0317/upgrade.pb.go | 502 +++++++++++++++ 7 files changed, 1796 insertions(+), 117 deletions(-) create mode 100644 x/upgrade/legacy/v0317/genesis.pb.go create mode 100644 x/upgrade/legacy/v0317/plan.pb.go create mode 100644 x/upgrade/legacy/v0317/upgrade.pb.go diff --git a/x/genutil/client/cli/upgrade_genesis.go b/x/genutil/client/cli/upgrade_genesis.go index d15af9c2..564ff40e 100644 --- a/x/genutil/client/cli/upgrade_genesis.go +++ b/x/genutil/client/cli/upgrade_genesis.go @@ -5,16 +5,15 @@ import ( "fmt" "strings" + appparams "github.com/KiraCore/sekai/app/params" "github.com/KiraCore/sekai/x/genutil" - v01228govtypes "github.com/KiraCore/sekai/x/gov/legacy/v01228" govtypes "github.com/KiraCore/sekai/x/gov/types" - v03123upgradetypes "github.com/KiraCore/sekai/x/upgrade/legacy/v03123" + v0317upgradetypes "github.com/KiraCore/sekai/x/upgrade/legacy/v0317" upgradetypes "github.com/KiraCore/sekai/x/upgrade/types" tmjson "github.com/cometbft/cometbft/libs/json" tmos "github.com/cometbft/cometbft/libs/os" tmtypes "github.com/cometbft/cometbft/types" "github.com/cosmos/cosmos-sdk/client" - sdk "github.com/cosmos/cosmos-sdk/types" "github.com/cosmos/cosmos-sdk/types/module" "github.com/cosmos/cosmos-sdk/version" "github.com/pkg/errors" @@ -26,7 +25,7 @@ const ( FlagModulesOnly = "modules-only" ) -func upgradedPlan(plan *v03123upgradetypes.PlanV03123) *upgradetypes.Plan { +func upgradedPlan(plan *v0317upgradetypes.PlanV0317) *upgradetypes.Plan { if plan == nil { return nil } @@ -47,13 +46,13 @@ func upgradedPlan(plan *v03123upgradetypes.PlanV03123) *upgradetypes.Plan { } } -func upgradedResources(resources []v03123upgradetypes.ResourceV03123) []upgradetypes.Resource { +func upgradedResources(resources []v0317upgradetypes.ResourceV0317) []upgradetypes.Resource { upgraded := []upgradetypes.Resource{} for _, resource := range resources { upgraded = append(upgraded, upgradetypes.Resource{ Id: resource.Id, - Url: resource.Git, - Version: resource.Checkout, + Url: resource.Url, + Version: resource.Version, Checksum: resource.Checksum, }) } @@ -107,29 +106,24 @@ $ %s new-genesis-from-exported exported-genesis.json new-genesis.json } genesisState = newGenesis } else { - if err = mbm.ValidateGenesis(cdc, txEncCfg, genesisState); err != nil { - return errors.Wrap(err, "failed to validate genesis state") - } - - upgradeGenesisV03123 := v03123upgradetypes.GenesisStateV03123{} + upgradeGenesisV03123 := v0317upgradetypes.GenesisStateV0317{} err = cdc.UnmarshalJSON(genesisState[upgradetypes.ModuleName], &upgradeGenesisV03123) if err == nil { // which means old upgrade genesis upgradeGenesis := upgradetypes.GenesisState{ - Version: "v0.3.1.24", + Version: "v0.3.45", CurrentPlan: upgradedPlan(upgradeGenesisV03123.CurrentPlan), NextPlan: upgradedPlan(upgradeGenesisV03123.NextPlan), } genesisState[upgradetypes.ModuleName] = cdc.MustMarshalJSON(&upgradeGenesis) } else { - fmt.Println("error exists v0.3.1.23 upgrade genesis parsing", err) + fmt.Println("error exists v0.3.17 upgrade genesis parsing", err) } upgradeGenesis := upgradetypes.GenesisState{} cdc.MustUnmarshalJSON(genesisState[upgradetypes.ModuleName], &upgradeGenesis) - oldVersion := upgradeGenesis.Version if upgradeGenesis.Version == "" { - upgradeGenesis.Version = "v0.1.22.11" - fmt.Println("upgraded the upgrade module genesis to v0.1.22.11") + upgradeGenesis.Version = "v0.3.45" + fmt.Println("upgraded the upgrade module genesis to v0.3.45") } if upgradeGenesis.NextPlan == nil { @@ -146,114 +140,30 @@ $ %s new-genesis-from-exported exported-genesis.json new-genesis.json genesisState[upgradetypes.ModuleName] = cdc.MustMarshalJSON(&upgradeGenesis) - govGenesisV01228 := v01228govtypes.GenesisStateV01228{} - err = cdc.UnmarshalJSON(genesisState[govtypes.ModuleName], &govGenesisV01228) - - // we are referencing oldPlan.name to determine upgrade genesis or not - if err == nil && oldVersion == "" { // it means v0.1.22.8 gov genesis - govGenesis := govtypes.GenesisState{ - StartingProposalId: govGenesisV01228.StartingProposalId, - NextRoleId: govtypes.DefaultGenesis().NextRoleId, - Roles: govtypes.DefaultGenesis().Roles, - RolePermissions: govGenesisV01228.Permissions, - NetworkActors: govGenesisV01228.NetworkActors, - NetworkProperties: &govtypes.NetworkProperties{ - MinTxFee: govGenesisV01228.NetworkProperties.MinTxFee, - MaxTxFee: govGenesisV01228.NetworkProperties.MaxTxFee, - VoteQuorum: sdk.NewDecWithPrec(int64(govGenesisV01228.NetworkProperties.VoteQuorum), 2), - MinimumProposalEndTime: govGenesisV01228.NetworkProperties.ProposalEndTime, - ProposalEnactmentTime: govGenesisV01228.NetworkProperties.ProposalEnactmentTime, - MinProposalEndBlocks: govGenesisV01228.NetworkProperties.MinProposalEndBlocks, - MinProposalEnactmentBlocks: govGenesisV01228.NetworkProperties.MinProposalEnactmentBlocks, - EnableForeignFeePayments: govGenesisV01228.NetworkProperties.EnableForeignFeePayments, - MischanceRankDecreaseAmount: govGenesisV01228.NetworkProperties.MischanceRankDecreaseAmount, - MaxMischance: govGenesisV01228.NetworkProperties.MaxMischance, - MischanceConfidence: govGenesisV01228.NetworkProperties.MischanceConfidence, - InactiveRankDecreasePercent: sdk.NewDecWithPrec(int64(govGenesisV01228.NetworkProperties.InactiveRankDecreasePercent), 2), - MinValidators: govGenesisV01228.NetworkProperties.MinValidators, - PoorNetworkMaxBankSend: govGenesisV01228.NetworkProperties.PoorNetworkMaxBankSend, - UnjailMaxTime: govGenesisV01228.NetworkProperties.JailMaxTime, - EnableTokenWhitelist: govGenesisV01228.NetworkProperties.EnableTokenWhitelist, - EnableTokenBlacklist: govGenesisV01228.NetworkProperties.EnableTokenBlacklist, - MinIdentityApprovalTip: govGenesisV01228.NetworkProperties.MinIdentityApprovalTip, - UniqueIdentityKeys: govGenesisV01228.NetworkProperties.UniqueIdentityKeys, - UbiHardcap: 6000_000, - ValidatorsFeeShare: sdk.NewDecWithPrec(50, 2), // 50% - InflationRate: sdk.NewDecWithPrec(18, 2), // 18% - InflationPeriod: 31557600, // 1 year - UnstakingPeriod: 2629800, // 1 month - MaxDelegators: 100, - MinDelegationPushout: 10, - SlashingPeriod: 3600, - MaxJailedPercentage: sdk.NewDecWithPrec(25, 2), - MaxSlashingPercentage: sdk.NewDecWithPrec(5, 3), // 0.5% - MinCustodyReward: 200, - MaxCustodyTxSize: 8192, - MaxCustodyBufferSize: 10, - AbstentionRankDecreaseAmount: 1, - MaxAbstention: 2, - MinCollectiveBond: 100_000, // in KEX - MinCollectiveBondingTime: 86400, // in seconds - MaxCollectiveOutputs: 10, - MinCollectiveClaimPeriod: 14400, // 4hrs - ValidatorRecoveryBond: 300000, // 300k KEX - MaxAnnualInflation: sdk.NewDecWithPrec(35, 2), - MaxProposalTitleSize: 128, - MaxProposalDescriptionSize: 1024, - MaxProposalPollOptionSize: 64, - MaxProposalPollOptionCount: 128, - MinDappBond: 1000000, - MaxDappBond: 10000000, - DappBondDuration: 604800, - DappVerifierBond: sdk.NewDecWithPrec(1, 3), //0.1% - DappAutoDenounceTime: 60, // 60s - DappMischanceRankDecreaseAmount: 1, - DappMaxMischance: 10, - DappInactiveRankDecreasePercent: sdk.NewDecWithPrec(10, 2), - DappPoolSlippageDefault: sdk.NewDecWithPrec(1, 1), // 10% - DappLiquidationThreshold: 100_000_000_000, // default 100’000 KEX - DappLiquidationPeriod: 2419200, // default 2419200, ~28d - MintingFtFee: 100_000_000_000_000, - MintingNftFee: 100_000_000_000_000, - VetoThreshold: sdk.NewDecWithPrec(3340, 4), //33.40% - AutocompoundIntervalNumBlocks: 17280, - DowntimeInactiveDuration: 600, - }, - ExecutionFees: govGenesisV01228.ExecutionFees, - PoorNetworkMessages: govGenesisV01228.PoorNetworkMessages, - Proposals: []govtypes.Proposal{}, // govGenesisV01228.Proposals, - Votes: []govtypes.Vote{}, // govGenesisV01228.Votes, - DataRegistry: govGenesisV01228.DataRegistry, - IdentityRecords: govGenesisV01228.IdentityRecords, - LastIdentityRecordId: govGenesisV01228.LastIdentityRecordId, - IdRecordsVerifyRequests: govGenesisV01228.IdRecordsVerifyRequests, - LastIdRecordVerifyRequestId: govGenesisV01228.LastIdRecordVerifyRequestId, - ProposalDurations: make(map[string]uint64), - } - - genesisState[govtypes.ModuleName] = cdc.MustMarshalJSON(&govGenesis) - } else { - fmt.Println("GovGenesis01228 unmarshal test: ", err) - fmt.Println("Skipping governance module upgrade since it is not v0.1.22.8 genesis") - } - // upgrade gov genesis for more role permissions govGenesis := govtypes.GenesisState{} err = cdc.UnmarshalJSON(genesisState[govtypes.ModuleName], &govGenesis) if err == nil { - govGenesis.RolePermissions[govtypes.RoleSudo] = govtypes.DefaultGenesis().RolePermissions[govtypes.RoleSudo] + if govGenesis.DefaultDenom == "" { + govGenesis.DefaultDenom = appparams.DefaultDenom + } + if govGenesis.Bech32Prefix == "" { + govGenesis.Bech32Prefix = appparams.AccountAddressPrefix + } genesisState[govtypes.ModuleName] = cdc.MustMarshalJSON(&govGenesis) } else { fmt.Println("parse error for latest gov genesis", err) - fmt.Println("trying to parse v03123 gov genesis for following error on genesis parsing") - govGenesisV03123 := make(map[string]interface{}) - err = json.Unmarshal(genesisState[govtypes.ModuleName], &govGenesisV03123) + fmt.Println("trying to parse v0.3.17 gov genesis for following error on genesis parsing") + govGenesisV0317 := make(map[string]interface{}) + err = json.Unmarshal(genesisState[govtypes.ModuleName], &govGenesisV0317) if err != nil { panic(err) } - govGenesisV03123["proposals"] = []govtypes.Proposal{} - govGenesisV03123["votes"] = []govtypes.Vote{} - bz, err := json.Marshal(&govGenesisV03123) + + fmt.Println("Setting default gov data", appparams.DefaultDenom, appparams.AccountAddressPrefix) + govGenesisV0317["default_denom"] = appparams.DefaultDenom + govGenesisV0317["bech32_prefix"] = appparams.AccountAddressPrefix + bz, err := json.Marshal(&govGenesisV0317) if err != nil { panic(err) } diff --git a/x/gov/types/genesis.go b/x/gov/types/genesis.go index 1d5ce889..2584ae57 100644 --- a/x/gov/types/genesis.go +++ b/x/gov/types/genesis.go @@ -287,5 +287,14 @@ func GetBech32PrefixAndDefaultDenomFromAppState(appState map[string]json.RawMess if err != nil { panic(err) } - return genesisState["bech32_prefix"].(string), genesisState["default_denom"].(string) + bech32Prefix, ok := genesisState["bech32_prefix"].(string) + if !ok || bech32Prefix == "" { + bech32Prefix = appparams.AccountAddressPrefix + } + defaultDenom, ok := genesisState["default_denom"].(string) + if !ok || defaultDenom == "" { + defaultDenom = appparams.DefaultDenom + } + + return bech32Prefix, defaultDenom } diff --git a/x/slashing/types/signing_info.go b/x/slashing/types/signing_info.go index fb4a5bb5..47351ca6 100644 --- a/x/slashing/types/signing_info.go +++ b/x/slashing/types/signing_info.go @@ -9,6 +9,7 @@ import ( ) // NewValidatorSigningInfo creates a new ValidatorSigningInfo instance +// //nolint:interfacer func NewValidatorSigningInfo( consAddr sdk.ConsAddress, startHeight int64, diff --git a/x/ubi/module.go b/x/ubi/module.go index c72a0ee7..785068e5 100644 --- a/x/ubi/module.go +++ b/x/ubi/module.go @@ -117,7 +117,6 @@ func (am AppModule) QuerierRoute() string { return ubitypes.QuerierRoute } - func (am AppModule) BeginBlock(clientCtx sdk.Context, block abci.RequestBeginBlock) {} func (am AppModule) EndBlock(ctx sdk.Context, block abci.RequestEndBlock) []abci.ValidatorUpdate { diff --git a/x/upgrade/legacy/v0317/genesis.pb.go b/x/upgrade/legacy/v0317/genesis.pb.go new file mode 100644 index 00000000..2af963bd --- /dev/null +++ b/x/upgrade/legacy/v0317/genesis.pb.go @@ -0,0 +1,440 @@ +// Code generated by protoc-gen-gogo. DO NOT EDIT. +// source: kira/upgrade/genesis.proto + +package types + +import ( + fmt "fmt" + _ "github.com/gogo/protobuf/gogoproto" + proto "github.com/gogo/protobuf/proto" + io "io" + math "math" + math_bits "math/bits" +) + +// Reference imports to suppress errors if they are not otherwise used. +var _ = proto.Marshal +var _ = fmt.Errorf +var _ = math.Inf + +// This is a compile-time assertion to ensure that this generated file +// is compatible with the proto package it is being compiled against. +// A compilation error at this line likely means your copy of the +// proto package needs to be updated. +const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package + +type GenesisStateV0317 struct { + Version string `protobuf:"bytes,1,opt,name=version,proto3" json:"version,omitempty"` + CurrentPlan *PlanV0317 `protobuf:"bytes,2,opt,name=current_plan,json=currentPlan,proto3" json:"current_plan,omitempty"` + NextPlan *PlanV0317 `protobuf:"bytes,3,opt,name=next_plan,json=nextPlan,proto3" json:"next_plan,omitempty"` +} + +func (m *GenesisStateV0317) Reset() { *m = GenesisStateV0317{} } +func (m *GenesisStateV0317) String() string { return proto.CompactTextString(m) } +func (*GenesisStateV0317) ProtoMessage() {} +func (*GenesisStateV0317) Descriptor() ([]byte, []int) { + return fileDescriptor_af8e84a023ffb915, []int{0} +} +func (m *GenesisStateV0317) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *GenesisStateV0317) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_GenesisStateV0317.Marshal(b, m, deterministic) + } else { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil + } +} +func (m *GenesisStateV0317) XXX_Merge(src proto.Message) { + xxx_messageInfo_GenesisStateV0317.Merge(m, src) +} +func (m *GenesisStateV0317) XXX_Size() int { + return m.Size() +} +func (m *GenesisStateV0317) XXX_DiscardUnknown() { + xxx_messageInfo_GenesisStateV0317.DiscardUnknown(m) +} + +var xxx_messageInfo_GenesisStateV0317 proto.InternalMessageInfo + +func (m *GenesisStateV0317) GetVersion() string { + if m != nil { + return m.Version + } + return "" +} + +func (m *GenesisStateV0317) GetCurrentPlan() *PlanV0317 { + if m != nil { + return m.CurrentPlan + } + return nil +} + +func (m *GenesisStateV0317) GetNextPlan() *PlanV0317 { + if m != nil { + return m.NextPlan + } + return nil +} + +func init() { + proto.RegisterType((*GenesisStateV0317)(nil), "kira.upgrade.GenesisStateV0317") +} + +func init() { proto.RegisterFile("kira/upgrade/genesis.proto", fileDescriptor_af8e84a023ffb915) } + +var fileDescriptor_af8e84a023ffb915 = []byte{ + // 237 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xe2, 0x92, 0xca, 0xce, 0x2c, 0x4a, + 0xd4, 0x2f, 0x2d, 0x48, 0x2f, 0x4a, 0x4c, 0x49, 0xd5, 0x4f, 0x4f, 0xcd, 0x4b, 0x2d, 0xce, 0x2c, + 0xd6, 0x2b, 0x28, 0xca, 0x2f, 0xc9, 0x17, 0xe2, 0x01, 0xc9, 0xe9, 0x41, 0xe5, 0xa4, 0x44, 0xd2, + 0xf3, 0xd3, 0xf3, 0xc1, 0x12, 0xfa, 0x20, 0x16, 0x44, 0x8d, 0x94, 0x38, 0x8a, 0xfe, 0x82, 0x9c, + 0xc4, 0x3c, 0x88, 0x84, 0xd2, 0x04, 0x46, 0x2e, 0x1e, 0x77, 0x88, 0x71, 0xc1, 0x25, 0x89, 0x25, + 0xa9, 0x42, 0x12, 0x5c, 0xec, 0x65, 0xa9, 0x45, 0xc5, 0x99, 0xf9, 0x79, 0x12, 0x8c, 0x0a, 0x8c, + 0x1a, 0x9c, 0x41, 0x30, 0xae, 0x90, 0x29, 0x17, 0x4f, 0x72, 0x69, 0x51, 0x51, 0x6a, 0x5e, 0x49, + 0x3c, 0xc8, 0x00, 0x09, 0x26, 0x05, 0x46, 0x0d, 0x6e, 0x23, 0x21, 0x3d, 0x64, 0xeb, 0xf5, 0x02, + 0x72, 0x12, 0xf3, 0x82, 0xb8, 0xa1, 0xea, 0x40, 0x1c, 0x21, 0x7d, 0x2e, 0xce, 0xbc, 0xd4, 0x0a, + 0xa8, 0x1e, 0x66, 0x9c, 0x7a, 0x38, 0x40, 0x8a, 0x40, 0x2c, 0x27, 0xe7, 0x13, 0x8f, 0xe4, 0x18, + 0x2f, 0x3c, 0x92, 0x63, 0x7c, 0xf0, 0x48, 0x8e, 0x71, 0xc2, 0x63, 0x39, 0x86, 0x0b, 0x8f, 0xe5, + 0x18, 0x6e, 0x3c, 0x96, 0x63, 0x88, 0xd2, 0x4c, 0xcf, 0x2c, 0xc9, 0x28, 0x4d, 0xd2, 0x4b, 0xce, + 0xcf, 0xd5, 0xf7, 0xce, 0x2c, 0x4a, 0x74, 0xce, 0x2f, 0x4a, 0xd5, 0x2f, 0x4e, 0xcd, 0x4e, 0xcc, + 0xd4, 0xaf, 0x80, 0x7b, 0xae, 0xa4, 0xb2, 0x20, 0xb5, 0x38, 0x89, 0x0d, 0xec, 0x3d, 0x63, 0x40, + 0x00, 0x00, 0x00, 0xff, 0xff, 0xba, 0x62, 0x45, 0x6f, 0x39, 0x01, 0x00, 0x00, +} + +func (m *GenesisStateV0317) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *GenesisStateV0317) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *GenesisStateV0317) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.NextPlan != nil { + { + size, err := m.NextPlan.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenesis(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x1a + } + if m.CurrentPlan != nil { + { + size, err := m.CurrentPlan.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenesis(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x12 + } + if len(m.Version) > 0 { + i -= len(m.Version) + copy(dAtA[i:], m.Version) + i = encodeVarintGenesis(dAtA, i, uint64(len(m.Version))) + i-- + dAtA[i] = 0xa + } + return len(dAtA) - i, nil +} + +func encodeVarintGenesis(dAtA []byte, offset int, v uint64) int { + offset -= sovGenesis(v) + base := offset + for v >= 1<<7 { + dAtA[offset] = uint8(v&0x7f | 0x80) + v >>= 7 + offset++ + } + dAtA[offset] = uint8(v) + return base +} +func (m *GenesisStateV0317) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Version) + if l > 0 { + n += 1 + l + sovGenesis(uint64(l)) + } + if m.CurrentPlan != nil { + l = m.CurrentPlan.Size() + n += 1 + l + sovGenesis(uint64(l)) + } + if m.NextPlan != nil { + l = m.NextPlan.Size() + n += 1 + l + sovGenesis(uint64(l)) + } + return n +} + +func sovGenesis(x uint64) (n int) { + return (math_bits.Len64(x|1) + 6) / 7 +} +func sozGenesis(x uint64) (n int) { + return sovGenesis(uint64((x << 1) ^ uint64((int64(x) >> 63)))) +} +func (m *GenesisStateV0317) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenesis + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: GenesisStateV0317: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: GenesisStateV0317: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Version", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenesis + } + 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 ErrInvalidLengthGenesis + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthGenesis + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Version = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field CurrentPlanV0317", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenesis + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenesis + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenesis + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.CurrentPlan == nil { + m.CurrentPlan = &PlanV0317{} + } + if err := m.CurrentPlan.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field NextPlanV0317", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenesis + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenesis + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenesis + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.NextPlan == nil { + m.NextPlan = &PlanV0317{} + } + if err := m.NextPlan.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenesis(dAtA[iNdEx:]) + if err != nil { + return err + } + if (skippy < 0) || (iNdEx+skippy) < 0 { + return ErrInvalidLengthGenesis + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func skipGenesis(dAtA []byte) (n int, err error) { + l := len(dAtA) + iNdEx := 0 + depth := 0 + for iNdEx < l { + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return 0, ErrIntOverflowGenesis + } + if iNdEx >= l { + return 0, io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= (uint64(b) & 0x7F) << shift + if b < 0x80 { + break + } + } + wireType := int(wire & 0x7) + switch wireType { + case 0: + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return 0, ErrIntOverflowGenesis + } + if iNdEx >= l { + return 0, io.ErrUnexpectedEOF + } + iNdEx++ + if dAtA[iNdEx-1] < 0x80 { + break + } + } + case 1: + iNdEx += 8 + case 2: + var length int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return 0, ErrIntOverflowGenesis + } + if iNdEx >= l { + return 0, io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + length |= (int(b) & 0x7F) << shift + if b < 0x80 { + break + } + } + if length < 0 { + return 0, ErrInvalidLengthGenesis + } + iNdEx += length + case 3: + depth++ + case 4: + if depth == 0 { + return 0, ErrUnexpectedEndOfGroupGenesis + } + depth-- + case 5: + iNdEx += 4 + default: + return 0, fmt.Errorf("proto: illegal wireType %d", wireType) + } + if iNdEx < 0 { + return 0, ErrInvalidLengthGenesis + } + if depth == 0 { + return iNdEx, nil + } + } + return 0, io.ErrUnexpectedEOF +} + +var ( + ErrInvalidLengthGenesis = fmt.Errorf("proto: negative length found during unmarshaling") + ErrIntOverflowGenesis = fmt.Errorf("proto: integer overflow") + ErrUnexpectedEndOfGroupGenesis = fmt.Errorf("proto: unexpected end of group") +) \ No newline at end of file diff --git a/x/upgrade/legacy/v0317/plan.pb.go b/x/upgrade/legacy/v0317/plan.pb.go new file mode 100644 index 00000000..77519f6d --- /dev/null +++ b/x/upgrade/legacy/v0317/plan.pb.go @@ -0,0 +1,818 @@ +// Code generated by protoc-gen-gogo. DO NOT EDIT. +// source: kira/upgrade/plan.proto + +package types + +import ( + fmt "fmt" + _ "github.com/gogo/protobuf/gogoproto" + proto "github.com/gogo/protobuf/proto" + io "io" + math "math" + math_bits "math/bits" +) + +// Reference imports to suppress errors if they are not otherwise used. +var _ = proto.Marshal +var _ = fmt.Errorf +var _ = math.Inf + +// This is a compile-time assertion to ensure that this generated file +// is compatible with the proto package it is being compiled against. +// A compilation error at this line likely means your copy of the +// proto package needs to be updated. +const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package + +type PlanV0317 struct { + Name string `protobuf:"bytes,1,opt,name=name,proto3" json:"name,omitempty"` + Resources []ResourceV0317 `protobuf:"bytes,2,rep,name=resources,proto3" json:"resources"` + UpgradeTime int64 `protobuf:"varint,3,opt,name=upgrade_time,json=upgradeTime,proto3" json:"upgrade_time,omitempty"` + OldChainId string `protobuf:"bytes,4,opt,name=old_chain_id,json=oldChainId,proto3" json:"old_chain_id,omitempty"` + NewChainId string `protobuf:"bytes,5,opt,name=new_chain_id,json=newChainId,proto3" json:"new_chain_id,omitempty"` + RollbackChecksum string `protobuf:"bytes,6,opt,name=rollback_checksum,json=rollbackChecksum,proto3" json:"rollback_checksum,omitempty"` + MaxEnrolmentDuration int64 `protobuf:"varint,7,opt,name=max_enrolment_duration,json=maxEnrolmentDuration,proto3" json:"max_enrolment_duration,omitempty"` + InstateUpgrade bool `protobuf:"varint,8,opt,name=instate_upgrade,json=instateUpgrade,proto3" json:"instate_upgrade,omitempty"` + RebootRequired bool `protobuf:"varint,9,opt,name=reboot_required,json=rebootRequired,proto3" json:"reboot_required,omitempty"` + SkipHandler bool `protobuf:"varint,10,opt,name=skip_handler,json=skipHandler,proto3" json:"skip_handler,omitempty"` + ProposalID uint64 `protobuf:"varint,11,opt,name=proposalID,proto3" json:"proposalID,omitempty"` + ProcessedNoVoteValidators bool `protobuf:"varint,12,opt,name=processed_no_vote_validators,json=processedNoVoteValidators,proto3" json:"processed_no_vote_validators,omitempty"` +} + +func (m *PlanV0317) Reset() { *m = PlanV0317{} } +func (m *PlanV0317) String() string { return proto.CompactTextString(m) } +func (*PlanV0317) ProtoMessage() {} +func (*PlanV0317) Descriptor() ([]byte, []int) { + return fileDescriptor_96c9a10c2f596dea, []int{0} +} +func (m *PlanV0317) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *PlanV0317) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_PlanV0317.Marshal(b, m, deterministic) + } else { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil + } +} +func (m *PlanV0317) XXX_Merge(src proto.Message) { + xxx_messageInfo_PlanV0317.Merge(m, src) +} +func (m *PlanV0317) XXX_Size() int { + return m.Size() +} +func (m *PlanV0317) XXX_DiscardUnknown() { + xxx_messageInfo_PlanV0317.DiscardUnknown(m) +} + +var xxx_messageInfo_PlanV0317 proto.InternalMessageInfo + +func (m *PlanV0317) GetName() string { + if m != nil { + return m.Name + } + return "" +} + +func (m *PlanV0317) GetResources() []ResourceV0317 { + if m != nil { + return m.Resources + } + return nil +} + +func (m *PlanV0317) GetUpgradeTime() int64 { + if m != nil { + return m.UpgradeTime + } + return 0 +} + +func (m *PlanV0317) GetOldChainId() string { + if m != nil { + return m.OldChainId + } + return "" +} + +func (m *PlanV0317) GetNewChainId() string { + if m != nil { + return m.NewChainId + } + return "" +} + +func (m *PlanV0317) GetRollbackChecksum() string { + if m != nil { + return m.RollbackChecksum + } + return "" +} + +func (m *PlanV0317) GetMaxEnrolmentDuration() int64 { + if m != nil { + return m.MaxEnrolmentDuration + } + return 0 +} + +func (m *PlanV0317) GetInstateUpgrade() bool { + if m != nil { + return m.InstateUpgrade + } + return false +} + +func (m *PlanV0317) GetRebootRequired() bool { + if m != nil { + return m.RebootRequired + } + return false +} + +func (m *PlanV0317) GetSkipHandler() bool { + if m != nil { + return m.SkipHandler + } + return false +} + +func (m *PlanV0317) GetProposalID() uint64 { + if m != nil { + return m.ProposalID + } + return 0 +} + +func (m *PlanV0317) GetProcessedNoVoteValidators() bool { + if m != nil { + return m.ProcessedNoVoteValidators + } + return false +} + +func init() { + proto.RegisterType((*PlanV0317)(nil), "kira.upgrade.PlanV0317") +} + +func init() { proto.RegisterFile("kira/upgrade/plan.proto", fileDescriptor_96c9a10c2f596dea) } + +var fileDescriptor_96c9a10c2f596dea = []byte{ + // 451 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x54, 0x92, 0x4f, 0x6f, 0xd3, 0x30, + 0x14, 0xc0, 0x1b, 0x5a, 0xc6, 0xe6, 0x56, 0xfc, 0xb1, 0xa6, 0x61, 0x2a, 0x14, 0x02, 0x17, 0x8a, + 0x90, 0x1a, 0x09, 0x38, 0x71, 0x41, 0x5a, 0x87, 0xc4, 0x84, 0x84, 0x50, 0x04, 0x3b, 0x70, 0xb1, + 0xdc, 0xf8, 0xa9, 0xb5, 0xe2, 0xf8, 0x05, 0xdb, 0xd9, 0xca, 0xb7, 0xe0, 0x63, 0xed, 0xb8, 0x23, + 0x27, 0x84, 0xda, 0xef, 0xc0, 0x19, 0x25, 0x71, 0xbb, 0x71, 0x8a, 0xf5, 0xfb, 0xfd, 0x12, 0x3f, + 0x45, 0x8f, 0x3c, 0x2c, 0x94, 0x15, 0x69, 0x5d, 0x2d, 0xac, 0x90, 0x90, 0x56, 0x5a, 0x98, 0x69, + 0x65, 0xd1, 0x23, 0x1d, 0x35, 0x62, 0x1a, 0xc4, 0xf8, 0x70, 0x81, 0x0b, 0x6c, 0x45, 0xda, 0x9c, + 0xba, 0x66, 0x3c, 0xfe, 0xef, 0xe5, 0xf0, 0xec, 0xdc, 0xb3, 0xbf, 0x7d, 0x32, 0xf8, 0xac, 0x85, + 0xa1, 0x94, 0x0c, 0x8c, 0x28, 0x81, 0x45, 0x49, 0x34, 0x39, 0xc8, 0xda, 0x33, 0x7d, 0x4b, 0x0e, + 0x2c, 0x38, 0xac, 0x6d, 0x0e, 0x8e, 0xdd, 0x4a, 0xfa, 0x93, 0xe1, 0xab, 0xa3, 0xe9, 0xcd, 0x0b, + 0xa7, 0x59, 0xd0, 0xc7, 0x83, 0xcb, 0xdf, 0x4f, 0x7a, 0xd9, 0x75, 0x4e, 0x9f, 0x92, 0x51, 0x88, + 0xb8, 0x57, 0x25, 0xb0, 0x7e, 0x12, 0x4d, 0xfa, 0xd9, 0x30, 0xb0, 0x2f, 0xaa, 0x04, 0x9a, 0x90, + 0x11, 0x6a, 0xc9, 0xf3, 0xa5, 0x50, 0x86, 0x2b, 0xc9, 0x06, 0xed, 0xd5, 0x04, 0xb5, 0x9c, 0x35, + 0xe8, 0x54, 0x36, 0x85, 0x81, 0x8b, 0xeb, 0xe2, 0x76, 0x57, 0x18, 0xb8, 0xd8, 0x16, 0x2f, 0xc9, + 0x03, 0x8b, 0x5a, 0xcf, 0x45, 0x5e, 0xf0, 0x7c, 0x09, 0x79, 0xe1, 0xea, 0x92, 0xed, 0xb5, 0xd9, + 0xfd, 0xad, 0x98, 0x05, 0x4e, 0xdf, 0x90, 0xa3, 0x52, 0xac, 0x38, 0x18, 0x8b, 0xba, 0x04, 0xe3, + 0xb9, 0xac, 0xad, 0xf0, 0x0a, 0x0d, 0xbb, 0xd3, 0x4e, 0x77, 0x58, 0x8a, 0xd5, 0xfb, 0xad, 0x3c, + 0x09, 0x8e, 0x3e, 0x27, 0xf7, 0x94, 0x71, 0x5e, 0x78, 0xe0, 0x61, 0x7a, 0xb6, 0x9f, 0x44, 0x93, + 0xfd, 0xec, 0x6e, 0xc0, 0x5f, 0x3b, 0xda, 0x84, 0x16, 0xe6, 0x88, 0x9e, 0x5b, 0xf8, 0x5e, 0x2b, + 0x0b, 0x92, 0x1d, 0x74, 0x61, 0x87, 0xb3, 0x40, 0x9b, 0x7f, 0xe3, 0x0a, 0x55, 0xf1, 0xa5, 0x30, + 0x52, 0x83, 0x65, 0xa4, 0xad, 0x86, 0x0d, 0xfb, 0xd0, 0x21, 0x1a, 0x13, 0x52, 0x59, 0xac, 0xd0, + 0x09, 0x7d, 0x7a, 0xc2, 0x86, 0x49, 0x34, 0x19, 0x64, 0x37, 0x08, 0x7d, 0x47, 0x1e, 0x57, 0x16, + 0x73, 0x70, 0x0e, 0x24, 0x37, 0xc8, 0xcf, 0xd1, 0x03, 0x3f, 0x17, 0x5a, 0x49, 0xe1, 0xd1, 0x3a, + 0x36, 0x6a, 0x3f, 0xf9, 0x68, 0xd7, 0x7c, 0xc2, 0x33, 0xf4, 0x70, 0xb6, 0x0b, 0x8e, 0x67, 0x97, + 0xeb, 0x38, 0xba, 0x5a, 0xc7, 0xd1, 0x9f, 0x75, 0x1c, 0xfd, 0xdc, 0xc4, 0xbd, 0xab, 0x4d, 0xdc, + 0xfb, 0xb5, 0x89, 0x7b, 0xdf, 0x5e, 0x2c, 0x94, 0x5f, 0xd6, 0xf3, 0x69, 0x8e, 0x65, 0xfa, 0x51, + 0x59, 0x31, 0x43, 0x0b, 0xa9, 0x83, 0x42, 0xa8, 0x74, 0xb5, 0xdb, 0x22, 0xff, 0xa3, 0x02, 0x37, + 0xdf, 0x6b, 0x97, 0xe8, 0xf5, 0xbf, 0x00, 0x00, 0x00, 0xff, 0xff, 0xaa, 0x89, 0x0f, 0x8a, 0x9f, + 0x02, 0x00, 0x00, +} + +func (m *PlanV0317) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *PlanV0317) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *PlanV0317) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.ProcessedNoVoteValidators { + i-- + if m.ProcessedNoVoteValidators { + dAtA[i] = 1 + } else { + dAtA[i] = 0 + } + i-- + dAtA[i] = 0x60 + } + if m.ProposalID != 0 { + i = encodeVarintPlanV0317(dAtA, i, uint64(m.ProposalID)) + i-- + dAtA[i] = 0x58 + } + if m.SkipHandler { + i-- + if m.SkipHandler { + dAtA[i] = 1 + } else { + dAtA[i] = 0 + } + i-- + dAtA[i] = 0x50 + } + if m.RebootRequired { + i-- + if m.RebootRequired { + dAtA[i] = 1 + } else { + dAtA[i] = 0 + } + i-- + dAtA[i] = 0x48 + } + if m.InstateUpgrade { + i-- + if m.InstateUpgrade { + dAtA[i] = 1 + } else { + dAtA[i] = 0 + } + i-- + dAtA[i] = 0x40 + } + if m.MaxEnrolmentDuration != 0 { + i = encodeVarintPlanV0317(dAtA, i, uint64(m.MaxEnrolmentDuration)) + i-- + dAtA[i] = 0x38 + } + if len(m.RollbackChecksum) > 0 { + i -= len(m.RollbackChecksum) + copy(dAtA[i:], m.RollbackChecksum) + i = encodeVarintPlanV0317(dAtA, i, uint64(len(m.RollbackChecksum))) + i-- + dAtA[i] = 0x32 + } + if len(m.NewChainId) > 0 { + i -= len(m.NewChainId) + copy(dAtA[i:], m.NewChainId) + i = encodeVarintPlanV0317(dAtA, i, uint64(len(m.NewChainId))) + i-- + dAtA[i] = 0x2a + } + if len(m.OldChainId) > 0 { + i -= len(m.OldChainId) + copy(dAtA[i:], m.OldChainId) + i = encodeVarintPlanV0317(dAtA, i, uint64(len(m.OldChainId))) + i-- + dAtA[i] = 0x22 + } + if m.UpgradeTime != 0 { + i = encodeVarintPlanV0317(dAtA, i, uint64(m.UpgradeTime)) + i-- + dAtA[i] = 0x18 + } + if len(m.Resources) > 0 { + for iNdEx := len(m.Resources) - 1; iNdEx >= 0; iNdEx-- { + { + size, err := m.Resources[iNdEx].MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintPlanV0317(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x12 + } + } + if len(m.Name) > 0 { + i -= len(m.Name) + copy(dAtA[i:], m.Name) + i = encodeVarintPlanV0317(dAtA, i, uint64(len(m.Name))) + i-- + dAtA[i] = 0xa + } + return len(dAtA) - i, nil +} + +func encodeVarintPlanV0317(dAtA []byte, offset int, v uint64) int { + offset -= sovPlanV0317(v) + base := offset + for v >= 1<<7 { + dAtA[offset] = uint8(v&0x7f | 0x80) + v >>= 7 + offset++ + } + dAtA[offset] = uint8(v) + return base +} +func (m *PlanV0317) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Name) + if l > 0 { + n += 1 + l + sovPlanV0317(uint64(l)) + } + if len(m.Resources) > 0 { + for _, e := range m.Resources { + l = e.Size() + n += 1 + l + sovPlanV0317(uint64(l)) + } + } + if m.UpgradeTime != 0 { + n += 1 + sovPlanV0317(uint64(m.UpgradeTime)) + } + l = len(m.OldChainId) + if l > 0 { + n += 1 + l + sovPlanV0317(uint64(l)) + } + l = len(m.NewChainId) + if l > 0 { + n += 1 + l + sovPlanV0317(uint64(l)) + } + l = len(m.RollbackChecksum) + if l > 0 { + n += 1 + l + sovPlanV0317(uint64(l)) + } + if m.MaxEnrolmentDuration != 0 { + n += 1 + sovPlanV0317(uint64(m.MaxEnrolmentDuration)) + } + if m.InstateUpgrade { + n += 2 + } + if m.RebootRequired { + n += 2 + } + if m.SkipHandler { + n += 2 + } + if m.ProposalID != 0 { + n += 1 + sovPlanV0317(uint64(m.ProposalID)) + } + if m.ProcessedNoVoteValidators { + n += 2 + } + return n +} + +func sovPlanV0317(x uint64) (n int) { + return (math_bits.Len64(x|1) + 6) / 7 +} +func sozPlanV0317(x uint64) (n int) { + return sovPlanV0317(uint64((x << 1) ^ uint64((int64(x) >> 63)))) +} +func (m *PlanV0317) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowPlanV0317 + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: PlanV0317: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: PlanV0317: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Name", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowPlanV0317 + } + 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 ErrInvalidLengthPlanV0317 + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthPlanV0317 + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Name = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Resources", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowPlanV0317 + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthPlanV0317 + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthPlanV0317 + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Resources = append(m.Resources, ResourceV0317{}) + if err := m.Resources[len(m.Resources)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 3: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field UpgradeTime", wireType) + } + m.UpgradeTime = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowPlanV0317 + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.UpgradeTime |= int64(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 4: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field OldChainId", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowPlanV0317 + } + 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 ErrInvalidLengthPlanV0317 + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthPlanV0317 + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.OldChainId = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 5: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field NewChainId", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowPlanV0317 + } + 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 ErrInvalidLengthPlanV0317 + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthPlanV0317 + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.NewChainId = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 6: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field RollbackChecksum", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowPlanV0317 + } + 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 ErrInvalidLengthPlanV0317 + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthPlanV0317 + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.RollbackChecksum = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 7: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field MaxEnrolmentDuration", wireType) + } + m.MaxEnrolmentDuration = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowPlanV0317 + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.MaxEnrolmentDuration |= int64(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 8: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field InstateUpgrade", wireType) + } + var v int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowPlanV0317 + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.InstateUpgrade = bool(v != 0) + case 9: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field RebootRequired", wireType) + } + var v int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowPlanV0317 + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.RebootRequired = bool(v != 0) + case 10: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field SkipHandler", wireType) + } + var v int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowPlanV0317 + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.SkipHandler = bool(v != 0) + case 11: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field ProposalID", wireType) + } + m.ProposalID = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowPlanV0317 + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.ProposalID |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 12: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field ProcessedNoVoteValidators", wireType) + } + var v int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowPlanV0317 + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.ProcessedNoVoteValidators = bool(v != 0) + default: + iNdEx = preIndex + skippy, err := skipPlanV0317(dAtA[iNdEx:]) + if err != nil { + return err + } + if (skippy < 0) || (iNdEx+skippy) < 0 { + return ErrInvalidLengthPlanV0317 + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func skipPlanV0317(dAtA []byte) (n int, err error) { + l := len(dAtA) + iNdEx := 0 + depth := 0 + for iNdEx < l { + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return 0, ErrIntOverflowPlanV0317 + } + if iNdEx >= l { + return 0, io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= (uint64(b) & 0x7F) << shift + if b < 0x80 { + break + } + } + wireType := int(wire & 0x7) + switch wireType { + case 0: + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return 0, ErrIntOverflowPlanV0317 + } + if iNdEx >= l { + return 0, io.ErrUnexpectedEOF + } + iNdEx++ + if dAtA[iNdEx-1] < 0x80 { + break + } + } + case 1: + iNdEx += 8 + case 2: + var length int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return 0, ErrIntOverflowPlanV0317 + } + if iNdEx >= l { + return 0, io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + length |= (int(b) & 0x7F) << shift + if b < 0x80 { + break + } + } + if length < 0 { + return 0, ErrInvalidLengthPlanV0317 + } + iNdEx += length + case 3: + depth++ + case 4: + if depth == 0 { + return 0, ErrUnexpectedEndOfGroupPlanV0317 + } + depth-- + case 5: + iNdEx += 4 + default: + return 0, fmt.Errorf("proto: illegal wireType %d", wireType) + } + if iNdEx < 0 { + return 0, ErrInvalidLengthPlanV0317 + } + if depth == 0 { + return iNdEx, nil + } + } + return 0, io.ErrUnexpectedEOF +} + +var ( + ErrInvalidLengthPlanV0317 = fmt.Errorf("proto: negative length found during unmarshaling") + ErrIntOverflowPlanV0317 = fmt.Errorf("proto: integer overflow") + ErrUnexpectedEndOfGroupPlanV0317 = fmt.Errorf("proto: unexpected end of group") +) \ No newline at end of file diff --git a/x/upgrade/legacy/v0317/upgrade.pb.go b/x/upgrade/legacy/v0317/upgrade.pb.go new file mode 100644 index 00000000..ed51d9d2 --- /dev/null +++ b/x/upgrade/legacy/v0317/upgrade.pb.go @@ -0,0 +1,502 @@ +// Code generated by protoc-gen-gogo. DO NOT EDIT. +// source: kira/upgrade/upgrade.proto + +package types + +import ( + fmt "fmt" + _ "github.com/cosmos/cosmos-sdk/codec/types" + _ "github.com/gogo/protobuf/gogoproto" + proto "github.com/gogo/protobuf/proto" + io "io" + math "math" + math_bits "math/bits" +) + +// Reference imports to suppress errors if they are not otherwise used. +var _ = proto.Marshal +var _ = fmt.Errorf +var _ = math.Inf + +// This is a compile-time assertion to ensure that this generated file +// is compatible with the proto package it is being compiled against. +// A compilation error at this line likely means your copy of the +// proto package needs to be updated. +const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package + +type ResourceV0317 struct { + Id string `protobuf:"bytes,1,opt,name=id,proto3" json:"id,omitempty"` + Url string `protobuf:"bytes,2,opt,name=url,proto3" json:"url,omitempty"` + Version string `protobuf:"bytes,3,opt,name=version,proto3" json:"version,omitempty"` + Checksum string `protobuf:"bytes,4,opt,name=checksum,proto3" json:"checksum,omitempty"` +} + +func (m *ResourceV0317) Reset() { *m = ResourceV0317{} } +func (m *ResourceV0317) String() string { return proto.CompactTextString(m) } +func (*ResourceV0317) ProtoMessage() {} +func (*ResourceV0317) Descriptor() ([]byte, []int) { + return fileDescriptor_cfa79131e4b330bc, []int{2} +} +func (m *ResourceV0317) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *ResourceV0317) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_Resource.Marshal(b, m, deterministic) + } else { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil + } +} +func (m *ResourceV0317) XXX_Merge(src proto.Message) { + xxx_messageInfo_Resource.Merge(m, src) +} +func (m *ResourceV0317) XXX_Size() int { + return m.Size() +} +func (m *ResourceV0317) XXX_DiscardUnknown() { + xxx_messageInfo_Resource.DiscardUnknown(m) +} + +var xxx_messageInfo_Resource proto.InternalMessageInfo + +func init() { + proto.RegisterType((*ResourceV0317)(nil), "kira.upgrade.ResourceV0317") +} + +func init() { proto.RegisterFile("kira/upgrade/upgrade.proto", fileDescriptor_cfa79131e4b330bc) } + +var fileDescriptor_cfa79131e4b330bc = []byte{ + // 500 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x8c, 0x92, 0x41, 0x6f, 0xd3, 0x30, + 0x14, 0xc7, 0x9b, 0xa6, 0x6c, 0xad, 0x5b, 0x6d, 0xc3, 0x9a, 0x86, 0xa9, 0x44, 0x56, 0x76, 0x59, + 0x11, 0x52, 0x23, 0x01, 0x17, 0x76, 0x5c, 0x41, 0x80, 0xb8, 0xa0, 0x00, 0x17, 0x2e, 0x91, 0x9b, + 0xbc, 0xa5, 0x56, 0x13, 0xbf, 0xe0, 0x24, 0xb4, 0xfb, 0x16, 0x7c, 0x04, 0x3e, 0x0b, 0xa7, 0x1e, + 0x77, 0xe4, 0x84, 0xa0, 0xbd, 0xf0, 0x31, 0x50, 0x6c, 0xa7, 0xe3, 0xc8, 0x29, 0xcf, 0xbf, 0xf7, + 0x4b, 0xec, 0xfc, 0x9f, 0xc9, 0x70, 0x21, 0x14, 0xf7, 0xab, 0x3c, 0x51, 0x3c, 0x86, 0xe6, 0x39, + 0xc9, 0x15, 0x96, 0x48, 0x07, 0x75, 0x6f, 0x62, 0xd9, 0xf0, 0x7e, 0x82, 0x98, 0xa4, 0xe0, 0xeb, + 0xde, 0xac, 0xba, 0xf2, 0xb9, 0xbc, 0x36, 0xe2, 0xf0, 0x38, 0xc1, 0x04, 0x75, 0xe9, 0xd7, 0x95, + 0xa1, 0x67, 0xdf, 0x5d, 0x72, 0xef, 0x9d, 0xc2, 0x1c, 0x0b, 0x9e, 0xbe, 0xc7, 0xab, 0x72, 0xc9, + 0x15, 0x7c, 0x34, 0x1f, 0xa3, 0x94, 0x74, 0x24, 0xcf, 0x80, 0x39, 0x23, 0x67, 0xdc, 0x0b, 0x74, + 0x4d, 0x2f, 0x48, 0x4f, 0x41, 0x81, 0x95, 0x8a, 0xa0, 0x60, 0xed, 0x91, 0x3b, 0xee, 0x3f, 0x39, + 0x99, 0xfc, 0x7b, 0x84, 0x49, 0x60, 0xdb, 0x97, 0x9d, 0xf5, 0xcf, 0xd3, 0x56, 0x70, 0xab, 0xd3, + 0x87, 0x64, 0x60, 0xa5, 0xb0, 0x14, 0x19, 0x30, 0x77, 0xe4, 0x8c, 0xdd, 0xa0, 0x6f, 0xd9, 0x07, + 0x91, 0x01, 0x1d, 0x91, 0x01, 0xa6, 0x71, 0x18, 0xcd, 0xb9, 0x90, 0xa1, 0x88, 0x59, 0x47, 0x6f, + 0x4d, 0x30, 0x8d, 0xa7, 0x35, 0x7a, 0x13, 0xd7, 0x86, 0x84, 0xe5, 0xad, 0x71, 0xc7, 0x18, 0x12, + 0x96, 0x8d, 0xf1, 0x98, 0xdc, 0x55, 0x98, 0xa6, 0x33, 0x1e, 0x2d, 0xc2, 0x68, 0x0e, 0xd1, 0xa2, + 0xa8, 0x32, 0xb6, 0xa7, 0xb5, 0xa3, 0xa6, 0x31, 0xb5, 0x9c, 0x3e, 0x23, 0x27, 0x19, 0x5f, 0x85, + 0x20, 0x15, 0xa6, 0x19, 0xc8, 0x32, 0x8c, 0x2b, 0xc5, 0x4b, 0x81, 0x92, 0xed, 0xeb, 0xd3, 0x1d, + 0x67, 0x7c, 0xf5, 0xb2, 0x69, 0xbe, 0xb0, 0xbd, 0x3a, 0x99, 0x0c, 0x32, 0x64, 0x5d, 0x93, 0x4c, + 0x5d, 0xd3, 0x73, 0x72, 0x28, 0x64, 0x51, 0xf2, 0x12, 0x42, 0xfb, 0x47, 0xac, 0x37, 0x72, 0xc6, + 0xdd, 0xe0, 0xc0, 0xe2, 0x26, 0xd6, 0x73, 0x72, 0xa8, 0x60, 0x86, 0x58, 0x86, 0x0a, 0x3e, 0x57, + 0x42, 0x41, 0xcc, 0x88, 0x11, 0x0d, 0x0e, 0x2c, 0xad, 0xf3, 0x2a, 0x16, 0x22, 0x0f, 0xe7, 0x5c, + 0xc6, 0x29, 0x28, 0xd6, 0xd7, 0x56, 0xbf, 0x66, 0xaf, 0x0d, 0xba, 0xe8, 0xfc, 0xf9, 0x76, 0xea, + 0x9c, 0x3d, 0x27, 0x0f, 0x9a, 0x19, 0x4e, 0xb9, 0x8c, 0xe0, 0x7f, 0x26, 0x69, 0x5f, 0x9d, 0x93, + 0x6e, 0x33, 0x30, 0x7a, 0x40, 0xda, 0x22, 0xb6, 0x4e, 0x5b, 0xc4, 0xf4, 0x88, 0xb8, 0x95, 0x4a, + 0x59, 0x5b, 0x83, 0xba, 0xa4, 0x8c, 0xec, 0x7f, 0x01, 0x55, 0xd4, 0xf1, 0xb8, 0x9a, 0x36, 0x4b, + 0x3a, 0x24, 0xdd, 0x5d, 0xd6, 0x66, 0x68, 0xbb, 0xb5, 0xd9, 0xe9, 0xf2, 0xd5, 0xfa, 0xb7, 0xd7, + 0x5a, 0x6f, 0x3c, 0xe7, 0x66, 0xe3, 0x39, 0xbf, 0x36, 0x9e, 0xf3, 0x75, 0xeb, 0xb5, 0x6e, 0xb6, + 0x5e, 0xeb, 0xc7, 0xd6, 0x6b, 0x7d, 0x7a, 0x94, 0x88, 0x72, 0x5e, 0xcd, 0x26, 0x11, 0x66, 0xfe, + 0x5b, 0xa1, 0xf8, 0x14, 0x15, 0xf8, 0x05, 0x2c, 0xb8, 0xf0, 0x57, 0xbb, 0x9b, 0x5f, 0x5e, 0xe7, + 0x50, 0xcc, 0xf6, 0xf4, 0xcd, 0x7d, 0xfa, 0x37, 0x00, 0x00, 0xff, 0xff, 0xb2, 0x47, 0x76, 0x5e, + 0x16, 0x03, 0x00, 0x00, +} + + +func (this *ResourceV0317) Equal(that interface{}) bool { + if that == nil { + return this == nil + } + + that1, ok := that.(*ResourceV0317) + if !ok { + that2, ok := that.(ResourceV0317) + if ok { + that1 = &that2 + } else { + return false + } + } + if that1 == nil { + return this == nil + } else if this == nil { + return false + } + if this.Id != that1.Id { + return false + } + if this.Url != that1.Url { + return false + } + if this.Version != that1.Version { + return false + } + if this.Checksum != that1.Checksum { + return false + } + return true +} + +func (m *ResourceV0317) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *ResourceV0317) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *ResourceV0317) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if len(m.Checksum) > 0 { + i -= len(m.Checksum) + copy(dAtA[i:], m.Checksum) + i = encodeVarintUpgrade(dAtA, i, uint64(len(m.Checksum))) + i-- + dAtA[i] = 0x22 + } + if len(m.Version) > 0 { + i -= len(m.Version) + copy(dAtA[i:], m.Version) + i = encodeVarintUpgrade(dAtA, i, uint64(len(m.Version))) + i-- + dAtA[i] = 0x1a + } + if len(m.Url) > 0 { + i -= len(m.Url) + copy(dAtA[i:], m.Url) + i = encodeVarintUpgrade(dAtA, i, uint64(len(m.Url))) + i-- + dAtA[i] = 0x12 + } + if len(m.Id) > 0 { + i -= len(m.Id) + copy(dAtA[i:], m.Id) + i = encodeVarintUpgrade(dAtA, i, uint64(len(m.Id))) + i-- + dAtA[i] = 0xa + } + return len(dAtA) - i, nil +} + +func encodeVarintUpgrade(dAtA []byte, offset int, v uint64) int { + offset -= sovUpgrade(v) + base := offset + for v >= 1<<7 { + dAtA[offset] = uint8(v&0x7f | 0x80) + v >>= 7 + offset++ + } + dAtA[offset] = uint8(v) + return base +} + + +func (m *ResourceV0317) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Id) + if l > 0 { + n += 1 + l + sovUpgrade(uint64(l)) + } + l = len(m.Url) + if l > 0 { + n += 1 + l + sovUpgrade(uint64(l)) + } + l = len(m.Version) + if l > 0 { + n += 1 + l + sovUpgrade(uint64(l)) + } + l = len(m.Checksum) + if l > 0 { + n += 1 + l + sovUpgrade(uint64(l)) + } + return n +} + +func sovUpgrade(x uint64) (n int) { + return (math_bits.Len64(x|1) + 6) / 7 +} +func sozUpgrade(x uint64) (n int) { + return sovUpgrade(uint64((x << 1) ^ uint64((int64(x) >> 63)))) +} + + +func (m *ResourceV0317) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowUpgrade + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: Resource: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: Resource: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Id", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowUpgrade + } + 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 ErrInvalidLengthUpgrade + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthUpgrade + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Id = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Url", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowUpgrade + } + 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 ErrInvalidLengthUpgrade + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthUpgrade + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Url = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Version", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowUpgrade + } + 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 ErrInvalidLengthUpgrade + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthUpgrade + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Version = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 4: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Checksum", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowUpgrade + } + 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 ErrInvalidLengthUpgrade + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthUpgrade + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Checksum = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipUpgrade(dAtA[iNdEx:]) + if err != nil { + return err + } + if (skippy < 0) || (iNdEx+skippy) < 0 { + return ErrInvalidLengthUpgrade + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func skipUpgrade(dAtA []byte) (n int, err error) { + l := len(dAtA) + iNdEx := 0 + depth := 0 + for iNdEx < l { + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return 0, ErrIntOverflowUpgrade + } + if iNdEx >= l { + return 0, io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= (uint64(b) & 0x7F) << shift + if b < 0x80 { + break + } + } + wireType := int(wire & 0x7) + switch wireType { + case 0: + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return 0, ErrIntOverflowUpgrade + } + if iNdEx >= l { + return 0, io.ErrUnexpectedEOF + } + iNdEx++ + if dAtA[iNdEx-1] < 0x80 { + break + } + } + case 1: + iNdEx += 8 + case 2: + var length int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return 0, ErrIntOverflowUpgrade + } + if iNdEx >= l { + return 0, io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + length |= (int(b) & 0x7F) << shift + if b < 0x80 { + break + } + } + if length < 0 { + return 0, ErrInvalidLengthUpgrade + } + iNdEx += length + case 3: + depth++ + case 4: + if depth == 0 { + return 0, ErrUnexpectedEndOfGroupUpgrade + } + depth-- + case 5: + iNdEx += 4 + default: + return 0, fmt.Errorf("proto: illegal wireType %d", wireType) + } + if iNdEx < 0 { + return 0, ErrInvalidLengthUpgrade + } + if depth == 0 { + return iNdEx, nil + } + } + return 0, io.ErrUnexpectedEOF +} + +var ( + ErrInvalidLengthUpgrade = fmt.Errorf("proto: negative length found during unmarshaling") + ErrIntOverflowUpgrade = fmt.Errorf("proto: integer overflow") + ErrUnexpectedEndOfGroupUpgrade = fmt.Errorf("proto: unexpected end of group") +) \ No newline at end of file From 879cd6a4cc56984d2f4297a4e2f7c81a6bdc018d Mon Sep 17 00:00:00 2001 From: tj327 Date: Wed, 8 May 2024 10:42:46 -0400 Subject: [PATCH 10/15] sigverify update --- app/ante/ante.go | 4 +- app/ante/sigverify.go | 117 +++++++++++------------ app/ante/sigverify_test.go | 72 +++++++++++++++ app/ante/testutil_test.go | 4 +- app/app.go | 1 + types/Msg.go | 184 ++++++++++++++++++------------------- x/gov/types/genesis.go | 2 +- x/gov/types/msg.go | 2 +- 8 files changed, 228 insertions(+), 158 deletions(-) create mode 100644 app/ante/sigverify_test.go diff --git a/app/ante/ante.go b/app/ante/ante.go index fd0d4052..13c7f972 100644 --- a/app/ante/ante.go +++ b/app/ante/ante.go @@ -14,6 +14,7 @@ import ( customgovkeeper "github.com/KiraCore/sekai/x/gov/keeper" customstakingkeeper "github.com/KiraCore/sekai/x/staking/keeper" tokenskeeper "github.com/KiraCore/sekai/x/tokens/keeper" + codectypes "github.com/cosmos/cosmos-sdk/codec/types" sdk "github.com/cosmos/cosmos-sdk/types" sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" "github.com/cosmos/cosmos-sdk/x/auth/ante" @@ -39,6 +40,7 @@ func NewAnteHandler( sigGasConsumer ante.SignatureVerificationGasConsumer, signModeHandler signing.SignModeHandler, txFeeChecker ante.TxFeeChecker, + interfaceRegistry codectypes.InterfaceRegistry, ) sdk.AnteHandler { return sdk.ChainAnteDecorators( ante.NewSetUpContextDecorator(), // outermost AnteDecorator. SetUpContext must be called first @@ -60,7 +62,7 @@ func NewAnteHandler( // custom execution fee consume decorator NewExecutionFeeRegistrationDecorator(ak, cgk, fk), // NewSigGasConsumeDecorator(ak, sigGasConsumer), - NewSigVerificationDecorator(ak, signModeHandler), + NewSigVerificationDecorator(ak, signModeHandler, interfaceRegistry), ante.NewIncrementSequenceDecorator(ak), ) } diff --git a/app/ante/sigverify.go b/app/ante/sigverify.go index 98e5ccdc..3a9cbadb 100644 --- a/app/ante/sigverify.go +++ b/app/ante/sigverify.go @@ -1,12 +1,15 @@ package ante import ( + "bytes" "encoding/base64" "encoding/hex" "encoding/json" "errors" "fmt" + kiratypes "github.com/KiraCore/sekai/types" + tokenstypes "github.com/KiraCore/sekai/x/tokens/types" "github.com/cosmos/cosmos-sdk/crypto/keys/ed25519" kmultisig "github.com/cosmos/cosmos-sdk/crypto/keys/multisig" "github.com/cosmos/cosmos-sdk/crypto/keys/secp256k1" @@ -22,7 +25,7 @@ import ( "github.com/cosmos/cosmos-sdk/x/auth/types" "github.com/gogo/protobuf/proto" - "github.com/ethereum/go-ethereum/accounts" + codectypes "github.com/cosmos/cosmos-sdk/codec/types" "github.com/ethereum/go-ethereum/common" ethmath "github.com/ethereum/go-ethereum/common/math" "github.com/ethereum/go-ethereum/crypto" @@ -34,6 +37,7 @@ var ( key = make([]byte, secp256k1.PubKeySize) simSecp256k1Pubkey = &secp256k1.PubKey{Key: key} simSecp256k1Sig [64]byte + EthChainID = uint64(8789) ) func init() { @@ -138,14 +142,16 @@ type SignatureVerificationGasConsumer = func(meter sdk.GasMeter, sig signing.Sig // CONTRACT: Pubkeys are set in context for all signers before this decorator runs // CONTRACT: Tx must implement SigVerifiableTx interface type SigVerificationDecorator struct { - ak ante.AccountKeeper - signModeHandler authsigning.SignModeHandler + ak ante.AccountKeeper + signModeHandler authsigning.SignModeHandler + interfaceRegistry codectypes.InterfaceRegistry } -func NewSigVerificationDecorator(ak ante.AccountKeeper, signModeHandler authsigning.SignModeHandler) SigVerificationDecorator { +func NewSigVerificationDecorator(ak ante.AccountKeeper, signModeHandler authsigning.SignModeHandler, interfaceRegistry codectypes.InterfaceRegistry) SigVerificationDecorator { return SigVerificationDecorator{ - ak: ak, - signModeHandler: signModeHandler, + ak: ak, + signModeHandler: signModeHandler, + interfaceRegistry: interfaceRegistry, } } @@ -224,15 +230,18 @@ func (svd SigVerificationDecorator) AnteHandle(ctx sdk.Context, tx sdk.Tx, simul } if !simulate { - err := authsigning.VerifySignature(pubKey, signerData, sig.Data, svd.signModeHandler, tx) - if err != nil { - // try verifying signature with etherum - if ethErr := VerifyEthereumSignature(pubKey, signerData, sig.Data, svd.signModeHandler, tx); ethErr == nil { + if !bytes.Equal(pubKey.Address(), acc.GetAddress()) { + // try verifying ethereum signature + if ethErr := VerifyEthereumSignature(pubKey, signerData, sig.Data, svd.signModeHandler, tx, svd.interfaceRegistry); ethErr == nil { return next(ctx, tx, simulate) } else { - fmt.Printf("ethereum signature verification failed; %s", ethErr.Error()) + errMsg := fmt.Sprintf("ethereum signature verification failed; %s", ethErr.Error()) + return ctx, sdkerrors.Wrap(sdkerrors.ErrUnauthorized, errMsg) } + } + err := authsigning.VerifySignature(pubKey, signerData, sig.Data, svd.signModeHandler, tx) + if err != nil { var errMsg string if OnlyLegacyAminoSigners(sig.Data) { // If all signers are using SIGN_MODE_LEGACY_AMINO, we rely on VerifySignature to check account sequence number, @@ -249,7 +258,7 @@ func (svd SigVerificationDecorator) AnteHandle(ctx sdk.Context, tx sdk.Tx, simul return next(ctx, tx, simulate) } -func VerifyEthereumSignature(pubKey cryptotypes.PubKey, signerData authsigning.SignerData, sigData signing.SignatureData, handler authsigning.SignModeHandler, tx sdk.Tx) error { +func VerifyEthereumSignature(pubKey cryptotypes.PubKey, signerData authsigning.SignerData, sigData signing.SignatureData, handler authsigning.SignModeHandler, tx sdk.Tx, interfaceRegistry codectypes.InterfaceRegistry) error { switch data := sigData.(type) { case *signing.SingleSignatureData: signBytes, err := handler.GetSignBytes(data.SignMode, signerData, tx) @@ -257,8 +266,6 @@ func VerifyEthereumSignature(pubKey cryptotypes.PubKey, signerData authsigning.S return err } - fmt.Println("data.SignMode", data.SignMode) - fmt.Println("defaultSignBytes", string(signBytes)) if data.SignMode == signing.SignMode_SIGN_MODE_DIRECT { signDoc := sdktx.SignDoc{} err = signDoc.Unmarshal(signBytes) @@ -287,55 +294,33 @@ func VerifyEthereumSignature(pubKey cryptotypes.PubKey, signerData authsigning.S return errors.New("only one message's enabled for EIP712 signature") } msg := signDocMetamask.Body.Messages[0] + err := signDocMetamask.Body.UnpackInterfaces(interfaceRegistry) + if err != nil { + return err + } + switch msg.TypeUrl { - case "/kira.custody.MsgCreateCustodyRecord": - signBytes, err = GenerateSignBytes() - if err != nil { - return err + case "/kira.tokens.MsgEthereumTx": + msg := msg.GetCachedValue().(*tokenstypes.MsgEthereumTx) + tx := msg.AsTransaction() + if signerData.Sequence != tx.Nonce() { + return sdkerrors.Wrapf( + sdkerrors.ErrWrongSequence, + "ethereum account sequence mismatch, expected %d, got %d", signerData.Sequence, tx.Nonce(), + ) } - case "/kira.spending.MsgCreateSpendingPool": - signBytes, err = GenerateSignBytes() - if err != nil { - return err - } - case "/kira.multistaking.MsgDelegate": - signBytes, err = GenerateSignBytes() - if err != nil { - return err - } - case "/kira.gov.MsgRegisterIdentityRecords": - signBytes, err = GenerateSignBytes() - if err != nil { - return err - } - case "/kira.gov.MsgRequestIdentityRecordsVerify": - signBytes, err = GenerateSignBytes() - if err != nil { - return err - } - case "/kira.gov.MsgSetNetworkProperties": - signBytes, err = GenerateSignBytes() - if err != nil { - return err - } - case "/kira.evidence.MsgSubmitEvidence": - signBytes, err = GenerateSignBytes() - if err != nil { - return err - } - case "/kira.tokens.MsgUpsertTokenAlias": - signBytes, err = GenerateSignBytes() - if err != nil { - return err + + if EthChainID != tx.ChainId().Uint64() { + return fmt.Errorf("invalid ethereum chain ID, expected %d, got %d", EthChainID, tx.ChainId().Uint64()) } + return msg.ValidateBasic() default: - signBytes, err = json.Marshal(&signDocMetamask) + msg := msg.GetCachedValue().(sdk.Msg) + signBytes, err = GenEIP712SignBytesFromMsg(msg, signerData.Sequence) if err != nil { return err } } - - fmt.Println("signBytes", string(signBytes)) } signatureData := data.Signature @@ -343,7 +328,7 @@ func VerifyEthereumSignature(pubKey cryptotypes.PubKey, signerData authsigning.S return fmt.Errorf("not a correct ethereum signature") } signatureData[crypto.RecoveryIDOffset] -= 27 // Transform yellow paper V from 27/28 to 0/1 - recovered, err := crypto.SigToPub(accounts.TextHash(signBytes), signatureData) + recovered, err := crypto.SigToPub(signBytes, signatureData) if err != nil { return err } @@ -370,19 +355,27 @@ func VerifyEthereumSignature(pubKey cryptotypes.PubKey, signerData authsigning.S } } -func GenerateSignBytes() ([]byte, error) { +func GenEIP712SignBytesFromMsg(msg sdk.Msg, nonce uint64) ([]byte, error) { + msgName := kiratypes.MsgType(msg) + msgData, err := json.Marshal(msg) + if err != nil { + return nil, err + } + types := apitypes.Types{ "EIP712Domain": { {Name: "name", Type: "string"}, {Name: "version", Type: "string"}, {Name: "chainId", Type: "uint256"}, }, - "delegate": { + msgName: { {Name: "param", Type: "string"}, + {Name: "nonce", Type: "uint256"}, }, } - chainId := ethmath.NewHexOrDecimal256(8789) + chainId := ethmath.NewHexOrDecimal256(int64(EthChainID)) + nonceEth := ethmath.NewHexOrDecimal256(int64(nonce)) domain := apitypes.TypedDataDomain{ Name: "Kira", @@ -393,11 +386,11 @@ func GenerateSignBytes() ([]byte, error) { typedData := apitypes.TypedData{ Types: types, - PrimaryType: "delegate", + PrimaryType: msgName, Domain: domain, Message: apitypes.TypedDataMessage{ - "amount": "100000000ukex", - "to": "kiravaloper13j3w9pdc47e54z2gj4uh37rnnfwxcfcmjh4ful", + "param": string(msgData), + "nonce": nonceEth, }, } diff --git a/app/ante/sigverify_test.go b/app/ante/sigverify_test.go new file mode 100644 index 00000000..816b89b3 --- /dev/null +++ b/app/ante/sigverify_test.go @@ -0,0 +1,72 @@ +package ante_test + +import ( + "encoding/hex" + "fmt" + + ethmath "github.com/ethereum/go-ethereum/common/math" + "github.com/ethereum/go-ethereum/crypto" + apitypes "github.com/ethereum/go-ethereum/signer/core/apitypes" +) + +func GenerateEIP712SignBytes() ([]byte, error) { + types := apitypes.Types{ + "EIP712Domain": { + {Name: "name", Type: "string"}, + {Name: "version", Type: "string"}, + {Name: "chainId", Type: "uint256"}, + }, + "delegate": { + {Name: "param", Type: "string"}, + }, + } + + chainId := ethmath.NewHexOrDecimal256(int64(EthChainID)) + + domain := apitypes.TypedDataDomain{ + Name: "Kira", + Version: "1", + ChainId: chainId, + // VerifyingContract: "0xdef1c0ded9bec7f1a1670819833240f027b25eff", + } + + typedData := apitypes.TypedData{ + Types: types, + PrimaryType: "delegate", + Domain: domain, + Message: apitypes.TypedDataMessage{ + "param": `{"amount":"100000000ukex","to":"kiravaloper13j3w9pdc47e54z2gj4uh37rnnfwxcfcmjh4ful"}`, + }, + } + + typedDataHash, err := typedData.HashStruct(typedData.PrimaryType, typedData.Message) + if err != nil { + return nil, err + } + + domainSeparator, err := typedData.HashStruct("EIP712Domain", typedData.Domain.Map()) + if err != nil { + return nil, err + } + + rawData := []byte(fmt.Sprintf("\x19\x01%s%s", string(domainSeparator), string(typedDataHash))) + hashBytes := crypto.Keccak256(rawData) + // hash := common.BytesToHash(hashBytes) + + return hashBytes, nil +} + +func (suite *AnteTestSuite) TestGenerateEIP712SignBytes() { + suite.SetupTest(false) // reset + + bytes, err := GenerateEIP712SignBytes() + suite.Require().NoError(err) + + signatureData, err := hex.DecodeString("0a59681b3be1c26a71072989a43cca378ba2726f7183078865117715b9634f7d4c4c31fc008c411bb75739d44afd68a4f561b8176eb6cd38184a762ec83550e31b") + suite.Require().NoError(err) + signatureData[crypto.RecoveryIDOffset] -= 27 // Transform yellow paper V from 27/28 to 0/1 + recovered, err := crypto.SigToPub(bytes, signatureData) + suite.Require().NoError(err) + recoveredAddr := crypto.PubkeyToAddress(*recovered) + suite.Require().Equal(hex.EncodeToString(recoveredAddr[:]), "3f48fdb5ee16f729b16f4084ed1577557b6855cf") +} diff --git a/app/ante/testutil_test.go b/app/ante/testutil_test.go index 2916884c..911d1432 100644 --- a/app/ante/testutil_test.go +++ b/app/ante/testutil_test.go @@ -74,7 +74,9 @@ func (suite *AnteTestSuite) SetupTest(isCheckTx bool) { nil, ante.DefaultSigVerificationGasConsumer, encodingConfig.TxConfig.SignModeHandler(), - nil) + nil, + suite.app.InterfaceRegistry(), + ) } // CreateTestAccounts creates `numAccs` accounts, and return all relevant diff --git a/app/app.go b/app/app.go index 69aa91ef..20531906 100644 --- a/app/app.go +++ b/app/app.go @@ -531,6 +531,7 @@ func NewInitApp( ante.DefaultSigVerificationGasConsumer, encodingConfig.TxConfig.SignModeHandler(), nil, + encodingConfig.InterfaceRegistry, ), ) app.SetEndBlocker(app.EndBlocker) diff --git a/types/Msg.go b/types/Msg.go index 6b6b1081..a629adea 100644 --- a/types/Msg.go +++ b/types/Msg.go @@ -11,36 +11,36 @@ const ( TypeMsgSubmitEvidence = "submit_evidence" // governance - MsgTypeSubmitProposal = "submit-proposal" - MsgTypeVoteProposal = "vote-proposal" - MsgTypeCreatePoll = "create-poll" - MsgTypeVotePoll = "vote-poll" - MsgTypeAddressPoll = "address-poll" - - MsgTypeWhitelistPermissions = "whitelist-permissions" - MsgTypeBlacklistPermissions = "blacklist-permissions" - - MsgTypeClaimCouncilor = "claim-councilor" - MsgTypeSetNetworkProperties = "set-network-properties" - MsgTypeSetExecutionFee = "set-execution-fee" - - MsgTypeCreateRole = "create-role" - MsgTypeAssignRole = "assign-role" - MsgTypeUnassignRole = "unassign-role" - - MsgTypeWhitelistRolePermission = "whitelist-role-permission" - MsgTypeBlacklistRolePermission = "blacklist-role-permission" - MsgTypeRemoveWhitelistRolePermission = "remove-whitelist-role-permission" - MsgTypeRemoveBlacklistRolePermission = "remove-blacklist-role-permission" - - MsgTypeRegisterIdentityRecords = "register-identity-records" - MsgTypeDeleteIdentityRecord = "delete-identity-record" - MsgTypeRequestIdentityRecordsVerify = "request-identity-records-verify" - MsgTypeHandleIdentityRecordsVerifyRequest = "handle-identity-records-verify-request" - MsgTypeCancelIdentityRecordsVerifyRequest = "cancel-identity-records-verify-request" + MsgTypeSubmitProposal = "submit_proposal" + MsgTypeVoteProposal = "vote_proposal" + MsgTypeCreatePoll = "create_poll" + MsgTypeVotePoll = "vote_poll" + MsgTypeAddressPoll = "address_poll" + + MsgTypeWhitelistPermissions = "whitelist_permissions" + MsgTypeBlacklistPermissions = "blacklist_permissions" + + MsgTypeClaimCouncilor = "claim_councilor" + MsgTypeSetNetworkProperties = "set_network_properties" + MsgTypeSetExecutionFee = "set_execution_fee" + + MsgTypeCreateRole = "create_role" + MsgTypeAssignRole = "assign_role" + MsgTypeUnassignRole = "unassign_role" + + MsgTypeWhitelistRolePermission = "whitelist_role_permission" + MsgTypeBlacklistRolePermission = "blacklist_role_permission" + MsgTypeRemoveWhitelistRolePermission = "remove_whitelist_role_permission" + MsgTypeRemoveBlacklistRolePermission = "remove_blacklist_role_permission" + + MsgTypeRegisterIdentityRecords = "register_identity_records" + MsgTypeDeleteIdentityRecords = "delete_identity_records" + MsgTypeRequestIdentityRecordsVerify = "request_identity_records_verify" + MsgTypeHandleIdentityRecordsVerifyRequest = "handle_identity_records_verify_request" + MsgTypeCancelIdentityRecordsVerifyRequest = "cancel_identity_records_verify_request" // staking module - MsgTypeClaimValidator = "claim-validator" + MsgTypeClaimValidator = "claim_validator" // multistaking module MsgTypeUpsertStakingPool = "upsert_staking_pool" @@ -53,18 +53,18 @@ const ( MsgTypeRegisterDelegator = "register_delegator" // basket module - MsgTypeDisableBasketDeposits = "disable-basket-deposits" - MsgTypeDisableBasketWithdraws = "disable-basket-withdraws" - MsgTypeDisableBasketSwaps = "disable-basket-swaps" - MsgTypeBasketTokenMint = "basket-token-mint" - MsgTypeBasketTokenBurn = "basket-token-burn" - MsgTypeBasketTokenSwap = "basket-token-swap" - MsgTypeBasketClaimRewards = "basket-claim-rewards" + MsgTypeDisableBasketDeposits = "disable_basket_deposits" + MsgTypeDisableBasketWithdraws = "disable_basket_withdraws" + MsgTypeDisableBasketSwaps = "disable_basket_swaps" + MsgTypeBasketTokenMint = "basket_token_mint" + MsgTypeBasketTokenBurn = "basket_token_burn" + MsgTypeBasketTokenSwap = "basket_token_swap" + MsgTypeBasketClaimRewards = "basket_claim_rewards" // tokens module - MsgTypeUpsertTokenAlias = "upsert-token-alias" - MsgTypeUpsertTokenRate = "upsert-token-rate" - MsgTypeEthereumTx = "ethereum-tx" + MsgTypeUpsertTokenAlias = "upsert_token_alias" + MsgTypeUpsertTokenRate = "upsert_token_rate" + MsgTypeEthereumTx = "ethereum_tx" // slashing module MsgTypeActivate = "activate" @@ -72,69 +72,69 @@ const ( MsgTypeUnpause = "unpause" // recovery module - MsgTypeRegisterRecoverySecret = "register-recovery-secret" - MsgTypeRotateRecoveryAddress = "rotate-recovery-address" - MsgTypeIssueRecoveryTokens = "issue-recovery-tokens" - MsgTypeBurnRecoveryTokens = "burn-recovery-tokens" - MsgTypeRegisterRRTokenHolder = "register-rrtoken-holder" - MsgTypeClaimRRHolderRewards = "claim-rrholder-rewards" - MsgTypeRotateValidatorByHalfRRTokenHolder = "rotate-validator-by-half-rr-token-holder" + MsgTypeRegisterRecoverySecret = "register_recovery_secret" + MsgTypeRotateRecoveryAddress = "rotate_recovery_address" + MsgTypeIssueRecoveryTokens = "issue_recovery_tokens" + MsgTypeBurnRecoveryTokens = "burn_recovery_tokens" + MsgTypeRegisterRRTokenHolder = "register_rrtoken_holder" + MsgTypeClaimRRHolderRewards = "claim_rrholder_rewards" + MsgTypeRotateValidatorByHalfRRTokenHolder = "rotate_validator_by_half_rr_token_holder" //upgrade module // spending module - MsgTypeCreateSpendingPool = "create-spending-pool" - MsgTypeDepositSpendingPool = "deposit-spending-pool" - MsgTypeRegisterSpendingPoolBeneficiary = "register-spending-pool-beneficiary" - MsgTypeClaimSpendingPool = "claim-spending-pool" + MsgTypeCreateSpendingPool = "create_spending_pool" + MsgTypeDepositSpendingPool = "deposit_spending_pool" + MsgTypeRegisterSpendingPoolBeneficiary = "register_spending_pool_beneficiary" + MsgTypeClaimSpendingPool = "claim_spending_pool" // custody module - MsgTypeCreateCustody = "create-custody" - MsgTypeDisableCustody = "disable-custody" - MsgTypeDropCustody = "drop-custody" - MsgTypeAddToCustodyWhiteList = "add-to-custody-whitelist" - MsgTypeAddToCustodyCustodians = "add-to-custody-custodians" - MsgTypeRemoveFromCustodyCustodians = "remove-from-custody-custodians" - MsgTypeDropCustodyCustodians = "drop-custody-custodians" - MsgTypeRemoveFromCustodyWhiteList = "remove-from-custody-whitelist" - MsgTypeDropCustodyWhiteList = "drop-custody-whitelist" - MsgApproveCustodyTransaction = "approve-custody-transaction" - MsgDeclineCustodyTransaction = "decline-custody-transaction" - MsgPasswordConfirmTransaction = "password-confirm-transaction" - MsgTypeSend = "custody-send" + MsgTypeCreateCustody = "create_custody" + MsgTypeDisableCustody = "disable_custody" + MsgTypeDropCustody = "drop_custody" + MsgTypeAddToCustodyWhiteList = "add_to_custody_whitelist" + MsgTypeAddToCustodyCustodians = "add_to_custody_custodians" + MsgTypeRemoveFromCustodyCustodians = "remove_from_custody_custodians" + MsgTypeDropCustodyCustodians = "drop_custody_custodians" + MsgTypeRemoveFromCustodyWhiteList = "remove_from_custody_whitelist" + MsgTypeDropCustodyWhiteList = "drop_custody_whitelist" + MsgApproveCustodyTransaction = "approve_custody_transaction" + MsgDeclineCustodyTransaction = "decline_custody_transaction" + MsgPasswordConfirmTransaction = "password_confirm_transaction" + MsgTypeSend = "custody_send" // collectives module - MsgTypeCreateCollective = "create-collective" - MsgTypeBondCollective = "bond-collective" - MsgTypeDonateCollective = "donate-collective" - MsgTypeWithdrawCollective = "withdraw-collective" + MsgTypeCreateCollective = "create_collective" + MsgTypeBondCollective = "bond_collective" + MsgTypeDonateCollective = "donate_collective" + MsgTypeWithdrawCollective = "withdraw_collective" // layer2 module - MsgTypeCreateDappProposal = "create-dapp-proposal" - MsgTypeBondDappProposal = "bond-dapp-proposal" - MsgTypeReclaimDappBondProposal = "reclaim-dapp-bond-proposal" - MsgTypeJoinDappVerifierWithBond = "join-dapp-verifier-with-bond" - MsgTypeExitDapp = "exit-dapp" - MsgTypeVoteDappOperatorTx = "vote-dapp-operator-tx" - MsgTypeRedeemDappPoolTx = "redeem-dapp-pool-tx" - MsgTypeSwapDappPoolTx = "swap-dapp-pool-tx" - MsgTypeConvertDappPoolTx = "convert-dapp-pool-tx" - MsgTypePauseDappTx = "pause-dapp-tx" - MsgTypeUnPauseDappTx = "unpause-dapp-tx" - MsgTypeReactivateDappTx = "reactivate-dapp-tx" - MsgTypeExecuteDappTx = "execute-dapp-tx" - MsgTypeDenounceLeaderTx = "denounce-leader-tx" - MsgTypeTransitionDappTx = "transition-dapp-tx" - MsgTypeApproveDappTransitionTx = "approve-dapp-transition-tx" - MsgTypeRejectDappTransitionTx = "reject-dapp-transition-tx" - MsgTypeUpsertDappProposalTx = "upsert-dapp-proposal-tx" - MsgTypeVoteUpsertDappProposalTx = "vote-upsert-dapp-proposal-tx" - MsgTypeTransferDappTx = "transfer-dapp-tx" - MsgTypeAckTransferDappTx = "ack-transfer-dapp-tx" - MsgTypeMintCreateFtTx = "mint-create-ft-tx" - MsgTypeMintCreateNftTx = "mint-create-nft-tx" - MsgTypeMintIssueTx = "mint-issue-tx" - MsgTypeMintBurnTx = "mint-burn-tx" + MsgTypeCreateDappProposal = "create_dapp_proposal" + MsgTypeBondDappProposal = "bond_dapp_proposal" + MsgTypeReclaimDappBondProposal = "reclaim_dapp_bond_proposal" + MsgTypeJoinDappVerifierWithBond = "join_dapp_verifier_with_bond" + MsgTypeExitDapp = "exit_dapp" + MsgTypeVoteDappOperatorTx = "vote_dapp_operator_tx" + MsgTypeRedeemDappPoolTx = "redeem_dapp_pool_tx" + MsgTypeSwapDappPoolTx = "swap_dapp_pool_tx" + MsgTypeConvertDappPoolTx = "convert_dapp_pool_tx" + MsgTypePauseDappTx = "pause_dapp_tx" + MsgTypeUnPauseDappTx = "unpause_dapp_tx" + MsgTypeReactivateDappTx = "reactivate_dapp_tx" + MsgTypeExecuteDappTx = "execute_dapp_tx" + MsgTypeDenounceLeaderTx = "denounce_leader_tx" + MsgTypeTransitionDappTx = "transition_dapp_tx" + MsgTypeApproveDappTransitionTx = "approve_dapp_transition_tx" + MsgTypeRejectDappTransitionTx = "reject_dapp_transition_tx" + MsgTypeUpsertDappProposalTx = "upsert_dapp_proposal_tx" + MsgTypeVoteUpsertDappProposalTx = "vote_upsert_dapp_proposal_tx" + MsgTypeTransferDappTx = "transfer_dapp_tx" + MsgTypeAckTransferDappTx = "ack_transfer_dapp_tx" + MsgTypeMintCreateFtTx = "mint_create_ft_tx" + MsgTypeMintCreateNftTx = "mint_create_nft_tx" + MsgTypeMintIssueTx = "mint_issue_tx" + MsgTypeMintBurnTx = "mint_burn_tx" ) // Msg defines the interface a transaction message must fulfill. @@ -155,7 +155,7 @@ var MsgFuncIDMapping = map[string]int64{ MsgTypeSubmitProposal: 10, MsgTypeVoteProposal: 11, MsgTypeRegisterIdentityRecords: 12, - MsgTypeDeleteIdentityRecord: 13, + MsgTypeDeleteIdentityRecords: 13, MsgTypeRequestIdentityRecordsVerify: 14, MsgTypeHandleIdentityRecordsVerifyRequest: 15, MsgTypeCancelIdentityRecordsVerifyRequest: 16, diff --git a/x/gov/types/genesis.go b/x/gov/types/genesis.go index 7080fafe..31c8a427 100644 --- a/x/gov/types/genesis.go +++ b/x/gov/types/genesis.go @@ -252,7 +252,7 @@ func DefaultGenesis() *GenesisState { kiratypes.MsgTypePause, kiratypes.MsgTypeUnpause, kiratypes.MsgTypeRegisterIdentityRecords, - kiratypes.MsgTypeDeleteIdentityRecord, + kiratypes.MsgTypeDeleteIdentityRecords, kiratypes.MsgTypeRequestIdentityRecordsVerify, kiratypes.MsgTypeHandleIdentityRecordsVerifyRequest, kiratypes.MsgTypeCancelIdentityRecordsVerifyRequest, diff --git a/x/gov/types/msg.go b/x/gov/types/msg.go index 4d5f8d62..d124b4bd 100644 --- a/x/gov/types/msg.go +++ b/x/gov/types/msg.go @@ -764,7 +764,7 @@ func (m *MsgDeleteIdentityRecords) Route() string { } func (m *MsgDeleteIdentityRecords) Type() string { - return types.MsgTypeDeleteIdentityRecord + return types.MsgTypeDeleteIdentityRecords } func (m *MsgDeleteIdentityRecords) ValidateBasic() error { From 363a2e2f2b3594ca73e3c1b0b01c3e775f5416fd Mon Sep 17 00:00:00 2001 From: jgo121 Date: Sat, 11 May 2024 01:45:26 +0800 Subject: [PATCH 11/15] update genesis migration script based on discussion --- x/genutil/client/cli/upgrade_genesis.go | 116 +++++++++++++----------- 1 file changed, 62 insertions(+), 54 deletions(-) diff --git a/x/genutil/client/cli/upgrade_genesis.go b/x/genutil/client/cli/upgrade_genesis.go index 564ff40e..ed4fda0d 100644 --- a/x/genutil/client/cli/upgrade_genesis.go +++ b/x/genutil/client/cli/upgrade_genesis.go @@ -14,6 +14,7 @@ import ( tmos "github.com/cometbft/cometbft/libs/os" tmtypes "github.com/cometbft/cometbft/types" "github.com/cosmos/cosmos-sdk/client" + sdk "github.com/cosmos/cosmos-sdk/types" "github.com/cosmos/cosmos-sdk/types/module" "github.com/cosmos/cosmos-sdk/version" "github.com/pkg/errors" @@ -105,70 +106,76 @@ $ %s new-genesis-from-exported exported-genesis.json new-genesis.json newGenesis[module] = moduleGenesis } genesisState = newGenesis - } else { - upgradeGenesisV03123 := v0317upgradetypes.GenesisStateV0317{} - err = cdc.UnmarshalJSON(genesisState[upgradetypes.ModuleName], &upgradeGenesisV03123) - if err == nil { // which means old upgrade genesis - upgradeGenesis := upgradetypes.GenesisState{ - Version: "v0.3.45", - CurrentPlan: upgradedPlan(upgradeGenesisV03123.CurrentPlan), - NextPlan: upgradedPlan(upgradeGenesisV03123.NextPlan), - } - genesisState[upgradetypes.ModuleName] = cdc.MustMarshalJSON(&upgradeGenesis) - } else { - fmt.Println("error exists v0.3.17 upgrade genesis parsing", err) - } + } - upgradeGenesis := upgradetypes.GenesisState{} - cdc.MustUnmarshalJSON(genesisState[upgradetypes.ModuleName], &upgradeGenesis) - if upgradeGenesis.Version == "" { - upgradeGenesis.Version = "v0.3.45" - fmt.Println("upgraded the upgrade module genesis to v0.3.45") + upgradeGenesisV03123 := v0317upgradetypes.GenesisStateV0317{} + err = cdc.UnmarshalJSON(genesisState[upgradetypes.ModuleName], &upgradeGenesisV03123) + if err == nil { // which means old upgrade genesis + upgradeGenesis := upgradetypes.GenesisState{ + Version: "v0.3.45", + CurrentPlan: upgradedPlan(upgradeGenesisV03123.CurrentPlan), + NextPlan: upgradedPlan(upgradeGenesisV03123.NextPlan), } + genesisState[upgradetypes.ModuleName] = cdc.MustMarshalJSON(&upgradeGenesis) + } else { + fmt.Println("error exists v0.3.17 upgrade genesis parsing", err) + } - if upgradeGenesis.NextPlan == nil { - return fmt.Errorf("next plan is not available") - } + upgradeGenesis := upgradetypes.GenesisState{} + cdc.MustUnmarshalJSON(genesisState[upgradetypes.ModuleName], &upgradeGenesis) + if upgradeGenesis.Version == "" { + upgradeGenesis.Version = "v0.3.45" + fmt.Println("upgraded the upgrade module genesis to v0.3.45") + } - if genDoc.ChainID != upgradeGenesis.NextPlan.OldChainId { - return fmt.Errorf("next plan has different oldchain id, current chain_id=%s, next_plan.old_chain_id=%s", genDoc.ChainID, upgradeGenesis.NextPlan.OldChainId) - } + // if upgradeGenesis.NextPlan == nil { + // return fmt.Errorf("next plan is not available") + // } + // if genDoc.ChainID != upgradeGenesis.NextPlan.OldChainId { + // return fmt.Errorf("next plan has different oldchain id, current chain_id=%s, next_plan.old_chain_id=%s", genDoc.ChainID, upgradeGenesis.NextPlan.OldChainId) + // } + if upgradeGenesis.NextPlan != nil { genDoc.ChainID = upgradeGenesis.NextPlan.NewChainId - upgradeGenesis.CurrentPlan = upgradeGenesis.NextPlan - upgradeGenesis.NextPlan = nil + } - genesisState[upgradetypes.ModuleName] = cdc.MustMarshalJSON(&upgradeGenesis) + upgradeGenesis.CurrentPlan = upgradeGenesis.NextPlan + upgradeGenesis.NextPlan = nil - // upgrade gov genesis for more role permissions - govGenesis := govtypes.GenesisState{} - err = cdc.UnmarshalJSON(genesisState[govtypes.ModuleName], &govGenesis) - if err == nil { - if govGenesis.DefaultDenom == "" { - govGenesis.DefaultDenom = appparams.DefaultDenom - } - if govGenesis.Bech32Prefix == "" { - govGenesis.Bech32Prefix = appparams.AccountAddressPrefix - } - genesisState[govtypes.ModuleName] = cdc.MustMarshalJSON(&govGenesis) - } else { - fmt.Println("parse error for latest gov genesis", err) - fmt.Println("trying to parse v0.3.17 gov genesis for following error on genesis parsing") - govGenesisV0317 := make(map[string]interface{}) - err = json.Unmarshal(genesisState[govtypes.ModuleName], &govGenesisV0317) - if err != nil { - panic(err) - } + genesisState[upgradetypes.ModuleName] = cdc.MustMarshalJSON(&upgradeGenesis) - fmt.Println("Setting default gov data", appparams.DefaultDenom, appparams.AccountAddressPrefix) - govGenesisV0317["default_denom"] = appparams.DefaultDenom - govGenesisV0317["bech32_prefix"] = appparams.AccountAddressPrefix - bz, err := json.Marshal(&govGenesisV0317) - if err != nil { - panic(err) - } - genesisState[govtypes.ModuleName] = bz + // upgrade gov genesis for more role permissions + govGenesis := govtypes.GenesisState{} + err = cdc.UnmarshalJSON(genesisState[govtypes.ModuleName], &govGenesis) + if err == nil { + if govGenesis.DefaultDenom == "" { + govGenesis.DefaultDenom = appparams.DefaultDenom + } + if govGenesis.Bech32Prefix == "" { + govGenesis.Bech32Prefix = appparams.AccountAddressPrefix + } + govGenesis.NetworkProperties.VoteQuorum = sdk.NewDecWithPrec(33, 2) // 33% + govGenesis.NetworkProperties.VetoThreshold = sdk.NewDecWithPrec(3340, 4) // 33.4% + govGenesis.NetworkProperties.DappInactiveRankDecreasePercent = sdk.NewDecWithPrec(1, 1) // 10% + govGenesis.NetworkProperties.SlashingPeriod = 2629800 + genesisState[govtypes.ModuleName] = cdc.MustMarshalJSON(&govGenesis) + } else { + fmt.Println("parse error for latest gov genesis", err) + fmt.Println("trying to parse v0.3.17 gov genesis for following error on genesis parsing") + govGenesisV0317 := make(map[string]interface{}) + err = json.Unmarshal(genesisState[govtypes.ModuleName], &govGenesisV0317) + if err != nil { + panic(err) + } + + fmt.Println("Setting default gov data", appparams.DefaultDenom, appparams.AccountAddressPrefix) + govGenesisV0317["default_denom"] = appparams.DefaultDenom + govGenesisV0317["bech32_prefix"] = appparams.AccountAddressPrefix + bz, err := json.Marshal(&govGenesisV0317) + if err != nil { + panic(err) } + genesisState[govtypes.ModuleName] = bz } appState, err := json.MarshalIndent(genesisState, "", " ") @@ -177,6 +184,7 @@ $ %s new-genesis-from-exported exported-genesis.json new-genesis.json } genDoc.AppState = appState + genDoc.InitialHeight = 0 if jsonMinimize, _ := cmd.Flags().GetBool(FlagJsonMinimize); jsonMinimize { genDocBytes, err := tmjson.Marshal(genDoc) From 5f119a8bd4bbb0102a3785aad8e116b801f43261 Mon Sep 17 00:00:00 2001 From: jgo121 Date: Mon, 13 May 2024 21:57:56 +0800 Subject: [PATCH 12/15] txs simplification and ante revert intermediary changes --- app/ante/ante.go | 4 +- app/ante/signdoc.pb.go | 484 ------------------------------ app/ante/sigverify.go | 22 +- app/ante/sigverify_test.go | 4 +- proto/kira/ethereum/signdoc.proto | 16 - x/tokens/types/msg_eth_tx.go | 40 --- 6 files changed, 9 insertions(+), 561 deletions(-) delete mode 100644 app/ante/signdoc.pb.go delete mode 100644 proto/kira/ethereum/signdoc.proto diff --git a/app/ante/ante.go b/app/ante/ante.go index 13c7f972..4f526352 100644 --- a/app/ante/ante.go +++ b/app/ante/ante.go @@ -54,14 +54,14 @@ func NewAnteHandler( // custom fee range validator NewValidateFeeRangeDecorator(sk, cgk, tk, ak), NewSetPubKeyDecorator(ak), // SetPubKeyDecorator must be called before all signature verification decorators - // NewValidateSigCountDecorator(ak), + ante.NewValidateSigCountDecorator(ak), ante.NewDeductFeeDecorator(ak, bk, feegrantKeeper, txFeeChecker), // poor network management decorator NewPoorNetworkManagementDecorator(ak, cgk, sk), NewBlackWhiteTokensCheckDecorator(cgk, sk, tk), // custom execution fee consume decorator NewExecutionFeeRegistrationDecorator(ak, cgk, fk), - // NewSigGasConsumeDecorator(ak, sigGasConsumer), + ante.NewSigGasConsumeDecorator(ak, sigGasConsumer), NewSigVerificationDecorator(ak, signModeHandler, interfaceRegistry), ante.NewIncrementSequenceDecorator(ak), ) diff --git a/app/ante/signdoc.pb.go b/app/ante/signdoc.pb.go deleted file mode 100644 index de61a48e..00000000 --- a/app/ante/signdoc.pb.go +++ /dev/null @@ -1,484 +0,0 @@ -// Code generated by protoc-gen-gogo. DO NOT EDIT. -// source: kira/ethereum/signdoc.proto - -package ante - -import ( - fmt "fmt" - _ "github.com/cosmos/cosmos-sdk/types" - tx "github.com/cosmos/cosmos-sdk/types/tx" - _ "github.com/cosmos/gogoproto/gogoproto" - proto "github.com/cosmos/gogoproto/proto" - _ "github.com/cosmos/gogoproto/types" - io "io" - math "math" - math_bits "math/bits" -) - -// Reference imports to suppress errors if they are not otherwise used. -var _ = proto.Marshal -var _ = fmt.Errorf -var _ = math.Inf - -// This is a compile-time assertion to ensure that this generated file -// is compatible with the proto package it is being compiled against. -// A compilation error at this line likely means your copy of the -// proto package needs to be updated. -const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package - -type SignDocForMetamask struct { - Body *tx.TxBody `protobuf:"bytes,1,opt,name=body,proto3" json:"body,omitempty"` - AuthInfo *tx.AuthInfo `protobuf:"bytes,2,opt,name=auth_info,json=authInfo,proto3" json:"auth_info,omitempty"` - ChainId string `protobuf:"bytes,3,opt,name=chain_id,json=chainId,proto3" json:"chain_id,omitempty"` - AccountNumber uint64 `protobuf:"varint,4,opt,name=account_number,json=accountNumber,proto3" json:"account_number,omitempty"` -} - -func (m *SignDocForMetamask) Reset() { *m = SignDocForMetamask{} } -func (m *SignDocForMetamask) String() string { return proto.CompactTextString(m) } -func (*SignDocForMetamask) ProtoMessage() {} -func (*SignDocForMetamask) Descriptor() ([]byte, []int) { - return fileDescriptor_95b17f48d673e199, []int{0} -} -func (m *SignDocForMetamask) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *SignDocForMetamask) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_SignDocForMetamask.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *SignDocForMetamask) XXX_Merge(src proto.Message) { - xxx_messageInfo_SignDocForMetamask.Merge(m, src) -} -func (m *SignDocForMetamask) XXX_Size() int { - return m.Size() -} -func (m *SignDocForMetamask) XXX_DiscardUnknown() { - xxx_messageInfo_SignDocForMetamask.DiscardUnknown(m) -} - -var xxx_messageInfo_SignDocForMetamask proto.InternalMessageInfo - -func (m *SignDocForMetamask) GetBody() *tx.TxBody { - if m != nil { - return m.Body - } - return nil -} - -func (m *SignDocForMetamask) GetAuthInfo() *tx.AuthInfo { - if m != nil { - return m.AuthInfo - } - return nil -} - -func (m *SignDocForMetamask) GetChainId() string { - if m != nil { - return m.ChainId - } - return "" -} - -func (m *SignDocForMetamask) GetAccountNumber() uint64 { - if m != nil { - return m.AccountNumber - } - return 0 -} - -func init() { - proto.RegisterType((*SignDocForMetamask)(nil), "kira.ethereum.SignDocForMetamask") -} - -func init() { proto.RegisterFile("kira/ethereum/signdoc.proto", fileDescriptor_95b17f48d673e199) } - -var fileDescriptor_95b17f48d673e199 = []byte{ - // 331 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x6c, 0x90, 0xb1, 0x4e, 0xf3, 0x40, - 0x10, 0x84, 0x73, 0xff, 0x1f, 0x41, 0x62, 0x14, 0x0a, 0x8b, 0xc2, 0x49, 0x24, 0x13, 0x45, 0x42, - 0x4a, 0x83, 0x4f, 0x81, 0x86, 0x82, 0x86, 0x80, 0x90, 0x22, 0x04, 0x85, 0xa1, 0xa2, 0x89, 0xd6, - 0xe7, 0x8b, 0x7d, 0x0a, 0xbe, 0xb5, 0xec, 0x3d, 0xe4, 0xbc, 0x05, 0x6f, 0x44, 0x4b, 0x99, 0x92, - 0x12, 0x25, 0x2f, 0x82, 0x72, 0x31, 0x54, 0x74, 0x3b, 0xf3, 0xcd, 0x4c, 0xb1, 0x4e, 0x7f, 0xa1, - 0x0a, 0xe0, 0x92, 0x52, 0x59, 0x48, 0x93, 0xf1, 0x52, 0x25, 0x3a, 0x46, 0x11, 0xe4, 0x05, 0x12, - 0xba, 0x9d, 0x2d, 0x0c, 0x7e, 0x60, 0xef, 0x28, 0xc1, 0x04, 0x2d, 0xe1, 0xdb, 0x6b, 0x17, 0xea, - 0x1d, 0x27, 0x88, 0xc9, 0x8b, 0xe4, 0x56, 0x45, 0x66, 0xce, 0x49, 0x65, 0xb2, 0x24, 0xc8, 0xf2, - 0x3a, 0xe0, 0x0b, 0x2c, 0x33, 0x2c, 0x79, 0x04, 0xa5, 0xe4, 0xaf, 0xe3, 0x48, 0x12, 0x8c, 0xb9, - 0x40, 0xa5, 0x6b, 0xde, 0xab, 0x39, 0x55, 0xbf, 0x94, 0xaa, 0x1d, 0x1b, 0xbe, 0x33, 0xc7, 0x7d, - 0x54, 0x89, 0xbe, 0x41, 0x71, 0x8b, 0xc5, 0xbd, 0x24, 0xc8, 0xa0, 0x5c, 0xb8, 0xa7, 0x4e, 0x33, - 0xc2, 0x78, 0xe9, 0xb1, 0x01, 0x1b, 0x1d, 0x9c, 0x75, 0x83, 0xdd, 0x42, 0x40, 0x55, 0x50, 0x2f, - 0x04, 0x4f, 0xd5, 0x04, 0xe3, 0x65, 0x68, 0x63, 0xee, 0x85, 0xd3, 0x06, 0x43, 0xe9, 0x4c, 0xe9, - 0x39, 0x7a, 0xff, 0x6c, 0xa7, 0xff, 0x47, 0xe7, 0xca, 0x50, 0x3a, 0xd5, 0x73, 0x0c, 0x5b, 0x50, - 0x5f, 0x6e, 0xd7, 0x69, 0x89, 0x14, 0x94, 0x9e, 0xa9, 0xd8, 0xfb, 0x3f, 0x60, 0xa3, 0x76, 0xb8, - 0x6f, 0xf5, 0x34, 0x76, 0x4f, 0x9c, 0x43, 0x10, 0x02, 0x8d, 0xa6, 0x99, 0x36, 0x59, 0x24, 0x0b, - 0xaf, 0x39, 0x60, 0xa3, 0x66, 0xd8, 0xa9, 0xdd, 0x07, 0x6b, 0x4e, 0x2e, 0x3f, 0xd6, 0x3e, 0x5b, - 0xad, 0x7d, 0xf6, 0xb5, 0xf6, 0xd9, 0xdb, 0xc6, 0x6f, 0xac, 0x36, 0x7e, 0xe3, 0x73, 0xe3, 0x37, - 0x9e, 0x87, 0x89, 0xa2, 0xd4, 0x44, 0x81, 0xc0, 0x8c, 0xdf, 0xa9, 0x02, 0xae, 0xb1, 0x90, 0xbc, - 0x94, 0x0b, 0x50, 0x1c, 0xf2, 0x9c, 0x83, 0x26, 0x19, 0xed, 0xd9, 0x37, 0x9c, 0x7f, 0x07, 0x00, - 0x00, 0xff, 0xff, 0xf8, 0xac, 0x7e, 0xe6, 0xa7, 0x01, 0x00, 0x00, -} - -func (m *SignDocForMetamask) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *SignDocForMetamask) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *SignDocForMetamask) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if m.AccountNumber != 0 { - i = encodeVarintSigndoc(dAtA, i, uint64(m.AccountNumber)) - i-- - dAtA[i] = 0x20 - } - if len(m.ChainId) > 0 { - i -= len(m.ChainId) - copy(dAtA[i:], m.ChainId) - i = encodeVarintSigndoc(dAtA, i, uint64(len(m.ChainId))) - i-- - dAtA[i] = 0x1a - } - if m.AuthInfo != nil { - { - size, err := m.AuthInfo.MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintSigndoc(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x12 - } - if m.Body != nil { - { - size, err := m.Body.MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintSigndoc(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func encodeVarintSigndoc(dAtA []byte, offset int, v uint64) int { - offset -= sovSigndoc(v) - base := offset - for v >= 1<<7 { - dAtA[offset] = uint8(v&0x7f | 0x80) - v >>= 7 - offset++ - } - dAtA[offset] = uint8(v) - return base -} -func (m *SignDocForMetamask) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - if m.Body != nil { - l = m.Body.Size() - n += 1 + l + sovSigndoc(uint64(l)) - } - if m.AuthInfo != nil { - l = m.AuthInfo.Size() - n += 1 + l + sovSigndoc(uint64(l)) - } - l = len(m.ChainId) - if l > 0 { - n += 1 + l + sovSigndoc(uint64(l)) - } - if m.AccountNumber != 0 { - n += 1 + sovSigndoc(uint64(m.AccountNumber)) - } - return n -} - -func sovSigndoc(x uint64) (n int) { - return (math_bits.Len64(x|1) + 6) / 7 -} -func sozSigndoc(x uint64) (n int) { - return sovSigndoc(uint64((x << 1) ^ uint64((int64(x) >> 63)))) -} -func (m *SignDocForMetamask) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowSigndoc - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: SignDocForMetamask: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: SignDocForMetamask: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Body", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowSigndoc - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthSigndoc - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthSigndoc - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if m.Body == nil { - m.Body = &tx.TxBody{} - } - if err := m.Body.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field AuthInfo", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowSigndoc - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthSigndoc - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthSigndoc - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if m.AuthInfo == nil { - m.AuthInfo = &tx.AuthInfo{} - } - if err := m.AuthInfo.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 3: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ChainId", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowSigndoc - } - 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 ErrInvalidLengthSigndoc - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthSigndoc - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.ChainId = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 4: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field AccountNumber", wireType) - } - m.AccountNumber = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowSigndoc - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.AccountNumber |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - default: - iNdEx = preIndex - skippy, err := skipSigndoc(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthSigndoc - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func skipSigndoc(dAtA []byte) (n int, err error) { - l := len(dAtA) - iNdEx := 0 - depth := 0 - for iNdEx < l { - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowSigndoc - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - wireType := int(wire & 0x7) - switch wireType { - case 0: - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowSigndoc - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - iNdEx++ - if dAtA[iNdEx-1] < 0x80 { - break - } - } - case 1: - iNdEx += 8 - case 2: - var length int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowSigndoc - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - length |= (int(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - if length < 0 { - return 0, ErrInvalidLengthSigndoc - } - iNdEx += length - case 3: - depth++ - case 4: - if depth == 0 { - return 0, ErrUnexpectedEndOfGroupSigndoc - } - depth-- - case 5: - iNdEx += 4 - default: - return 0, fmt.Errorf("proto: illegal wireType %d", wireType) - } - if iNdEx < 0 { - return 0, ErrInvalidLengthSigndoc - } - if depth == 0 { - return iNdEx, nil - } - } - return 0, io.ErrUnexpectedEOF -} - -var ( - ErrInvalidLengthSigndoc = fmt.Errorf("proto: negative length found during unmarshaling") - ErrIntOverflowSigndoc = fmt.Errorf("proto: integer overflow") - ErrUnexpectedEndOfGroupSigndoc = fmt.Errorf("proto: unexpected end of group") -) diff --git a/app/ante/sigverify.go b/app/ante/sigverify.go index 3a9cbadb..5ea96f61 100644 --- a/app/ante/sigverify.go +++ b/app/ante/sigverify.go @@ -273,28 +273,17 @@ func VerifyEthereumSignature(pubKey cryptotypes.PubKey, signerData authsigning.S return err } - signDocMetamask := SignDocForMetamask{ - Body: &sdktx.TxBody{}, - AuthInfo: &sdktx.AuthInfo{}, - ChainId: signerData.ChainID, - AccountNumber: signerData.AccountNumber, - } - - err = proto.Unmarshal(signDoc.BodyBytes, signDocMetamask.Body) - if err != nil { - return err - } - - err = proto.Unmarshal(signDoc.AuthInfoBytes, signDocMetamask.AuthInfo) + txBody := &sdktx.TxBody{} + err = proto.Unmarshal(signDoc.BodyBytes, txBody) if err != nil { return err } - if len(signDocMetamask.Body.Messages) != 1 { + if len(txBody.Messages) != 1 { return errors.New("only one message's enabled for EIP712 signature") } - msg := signDocMetamask.Body.Messages[0] - err := signDocMetamask.Body.UnpackInterfaces(interfaceRegistry) + msg := txBody.Messages[0] + err := txBody.UnpackInterfaces(interfaceRegistry) if err != nil { return err } @@ -406,7 +395,6 @@ func GenEIP712SignBytesFromMsg(msg sdk.Msg, nonce uint64) ([]byte, error) { rawData := []byte(fmt.Sprintf("\x19\x01%s%s", string(domainSeparator), string(typedDataHash))) hashBytes := crypto.Keccak256(rawData) - // hash := common.BytesToHash(hashBytes) return hashBytes, nil } diff --git a/app/ante/sigverify_test.go b/app/ante/sigverify_test.go index 816b89b3..6c8f1945 100644 --- a/app/ante/sigverify_test.go +++ b/app/ante/sigverify_test.go @@ -4,6 +4,7 @@ import ( "encoding/hex" "fmt" + "github.com/KiraCore/sekai/app/ante" ethmath "github.com/ethereum/go-ethereum/common/math" "github.com/ethereum/go-ethereum/crypto" apitypes "github.com/ethereum/go-ethereum/signer/core/apitypes" @@ -21,7 +22,7 @@ func GenerateEIP712SignBytes() ([]byte, error) { }, } - chainId := ethmath.NewHexOrDecimal256(int64(EthChainID)) + chainId := ethmath.NewHexOrDecimal256(int64(ante.EthChainID)) domain := apitypes.TypedDataDomain{ Name: "Kira", @@ -51,7 +52,6 @@ func GenerateEIP712SignBytes() ([]byte, error) { rawData := []byte(fmt.Sprintf("\x19\x01%s%s", string(domainSeparator), string(typedDataHash))) hashBytes := crypto.Keccak256(rawData) - // hash := common.BytesToHash(hashBytes) return hashBytes, nil } diff --git a/proto/kira/ethereum/signdoc.proto b/proto/kira/ethereum/signdoc.proto deleted file mode 100644 index 909b6a6b..00000000 --- a/proto/kira/ethereum/signdoc.proto +++ /dev/null @@ -1,16 +0,0 @@ -syntax = "proto3"; -package kira.ethereum; - -import "gogoproto/gogo.proto"; -import "google/protobuf/timestamp.proto"; -import "cosmos/base/v1beta1/coin.proto"; -import "cosmos/tx/v1beta1/tx.proto"; - -option go_package = "github.com/KiraCore/sekai/app/ante"; - -message SignDocForMetamask { - cosmos.tx.v1beta1.TxBody body = 1; - cosmos.tx.v1beta1.AuthInfo auth_info = 2; - string chain_id = 3; - uint64 account_number = 4; -} diff --git a/x/tokens/types/msg_eth_tx.go b/x/tokens/types/msg_eth_tx.go index 375e966f..a7f2588c 100644 --- a/x/tokens/types/msg_eth_tx.go +++ b/x/tokens/types/msg_eth_tx.go @@ -5,7 +5,6 @@ import ( "math/big" errorsmod "cosmossdk.io/errors" - "github.com/cosmos/cosmos-sdk/crypto/keyring" sdk "github.com/cosmos/cosmos-sdk/types" kiratypes "github.com/KiraCore/sekai/types" @@ -19,7 +18,6 @@ var ( _ sdk.Tx = &MsgEthereumTx{} ) -// FromEthereumTx populates the message fields from the given ethereum transaction func (msg *MsgEthereumTx) FromEthereumTx(tx *ethtypes.Transaction) error { data, err := rlp.EncodeToBytes(tx) if err != nil { @@ -30,14 +28,10 @@ func (msg *MsgEthereumTx) FromEthereumTx(tx *ethtypes.Transaction) error { return nil } -// Route returns the route value of an MsgEthereumTx. func (msg MsgEthereumTx) Route() string { return RouterKey } -// Type returns the type value of an MsgEthereumTx. func (msg MsgEthereumTx) Type() string { return kiratypes.MsgTypeEthereumTx } -// ValidateBasic implements the sdk.Msg interface. It performs basic validation -// checks of a Transaction. If returns an error if validation fails. func (msg MsgEthereumTx) ValidateBasic() error { if msg.Sender != "" { if _, err := sdk.AccAddressFromBech32(msg.Sender); err != nil { @@ -62,10 +56,6 @@ func (msg *MsgEthereumTx) GetMsgs() []sdk.Msg { return []sdk.Msg{msg} } -// GetSigners returns the expected signers for an Ethereum transaction message. -// For such a message, there should exist only a single 'signer'. -// -// NOTE: This method panics if 'Sign' hasn't been called first. func (msg *MsgEthereumTx) GetSigners() []sdk.AccAddress { signer := sdk.MustAccAddressFromBech32(msg.Sender) return []sdk.AccAddress{signer} @@ -80,35 +70,6 @@ func (msg MsgEthereumTx) GetSignBytes() []byte { panic("must use 'RLPSignBytes' with a chain ID to get the valid bytes to sign") } -// Sign calculates a secp256k1 ECDSA signature and signs the transaction. It -// takes a keyring signer and the chainID to sign an Ethereum transaction according to -// EIP155 standard. -// This method mutates the transaction as it populates the V, R, S -// fields of the Transaction's Signature. -// The function will fail if the sender address is not defined for the msg or if -// the sender is not registered on the keyring -func (msg *MsgEthereumTx) Sign(ethSigner ethtypes.Signer, keyringSigner keyring.Signer) error { - sender, err := sdk.AccAddressFromBech32(msg.Sender) - if err != nil { - return err - } - - tx := msg.AsTransaction() - txHash := ethSigner.Hash(tx) - - sig, _, err := keyringSigner.SignByAddress(sender, txHash.Bytes()) - if err != nil { - return err - } - - tx, err = tx.WithSignature(ethSigner, sig) - if err != nil { - return err - } - - return msg.FromEthereumTx(tx) -} - func (msg *MsgEthereumTx) GetEthSender(chainID *big.Int) (common.Address, error) { signer := ethtypes.LatestSignerForChainID(chainID) from, err := signer.Sender(msg.AsTransaction()) @@ -124,7 +85,6 @@ func (msg *MsgEthereumTx) AsMessage() (ethtypes.Message, error) { return tx.AsMessage(ethtypes.NewEIP155Signer(tx.ChainId()), big.NewInt(1)) } -// AsTransaction creates an Ethereum Transaction type from the msg fields func (msg MsgEthereumTx) AsTransaction() *ethtypes.Transaction { tx := new(ethtypes.Transaction) rlp.DecodeBytes(msg.Data, &tx) From dc36ffc7fbae3ec6a3b9b7a06e8a6cc5bd0fe993 Mon Sep 17 00:00:00 2001 From: jgo121 Date: Mon, 13 May 2024 23:37:38 +0800 Subject: [PATCH 13/15] remove unused sigverify functions --- app/ante/sigverify.go | 83 ------------------------------------------- 1 file changed, 83 deletions(-) diff --git a/app/ante/sigverify.go b/app/ante/sigverify.go index 5ea96f61..6fde379a 100644 --- a/app/ante/sigverify.go +++ b/app/ante/sigverify.go @@ -10,12 +10,8 @@ import ( kiratypes "github.com/KiraCore/sekai/types" tokenstypes "github.com/KiraCore/sekai/x/tokens/types" - "github.com/cosmos/cosmos-sdk/crypto/keys/ed25519" - kmultisig "github.com/cosmos/cosmos-sdk/crypto/keys/multisig" "github.com/cosmos/cosmos-sdk/crypto/keys/secp256k1" - "github.com/cosmos/cosmos-sdk/crypto/keys/secp256r1" cryptotypes "github.com/cosmos/cosmos-sdk/crypto/types" - "github.com/cosmos/cosmos-sdk/crypto/types/multisig" sdk "github.com/cosmos/cosmos-sdk/types" sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" sdktx "github.com/cosmos/cosmos-sdk/types/tx" @@ -36,7 +32,6 @@ var ( // simulation signature values used to estimate gas consumption key = make([]byte, secp256k1.PubKeySize) simSecp256k1Pubkey = &secp256k1.PubKey{Key: key} - simSecp256k1Sig [64]byte EthChainID = uint64(8789) ) @@ -399,69 +394,6 @@ func GenEIP712SignBytesFromMsg(msg sdk.Msg, nonce uint64) ([]byte, error) { return hashBytes, nil } -// DefaultSigVerificationGasConsumer is the default implementation of SignatureVerificationGasConsumer. It consumes gas -// for signature verification based upon the public key type. The cost is fetched from the given params and is matched -// by the concrete type. -func DefaultSigVerificationGasConsumer( - meter sdk.GasMeter, sig signing.SignatureV2, params types.Params, -) error { - pubkey := sig.PubKey - switch pubkey := pubkey.(type) { - case *ed25519.PubKey: - meter.ConsumeGas(params.SigVerifyCostED25519, "ante verify: ed25519") - return sdkerrors.Wrap(sdkerrors.ErrInvalidPubKey, "ED25519 public keys are unsupported") - - case *secp256k1.PubKey: - meter.ConsumeGas(params.SigVerifyCostSecp256k1, "ante verify: secp256k1") - return nil - - case *secp256r1.PubKey: - meter.ConsumeGas(params.SigVerifyCostSecp256r1(), "ante verify: secp256r1") - return nil - - case multisig.PubKey: - multisignature, ok := sig.Data.(*signing.MultiSignatureData) - if !ok { - return fmt.Errorf("expected %T, got, %T", &signing.MultiSignatureData{}, sig.Data) - } - err := ConsumeMultisignatureVerificationGas(meter, multisignature, pubkey, params, sig.Sequence) - if err != nil { - return err - } - return nil - - default: - return sdkerrors.Wrapf(sdkerrors.ErrInvalidPubKey, "unrecognized public key type: %T", pubkey) - } -} - -// ConsumeMultisignatureVerificationGas consumes gas from a GasMeter for verifying a multisig pubkey signature -func ConsumeMultisignatureVerificationGas( - meter sdk.GasMeter, sig *signing.MultiSignatureData, pubkey multisig.PubKey, - params types.Params, accSeq uint64, -) error { - size := sig.BitArray.Count() - sigIndex := 0 - - for i := 0; i < size; i++ { - if !sig.BitArray.GetIndex(i) { - continue - } - sigV2 := signing.SignatureV2{ - PubKey: pubkey.GetPubKeys()[i], - Data: sig.Signatures[sigIndex], - Sequence: accSeq, - } - err := DefaultSigVerificationGasConsumer(meter, sigV2, params) - if err != nil { - return err - } - sigIndex++ - } - - return nil -} - // GetSignerAcc returns an account for a given address that is expected to sign // a transaction. func GetSignerAcc(ctx sdk.Context, ak ante.AccountKeeper, addr sdk.AccAddress) (types.AccountI, error) { @@ -472,21 +404,6 @@ func GetSignerAcc(ctx sdk.Context, ak ante.AccountKeeper, addr sdk.AccAddress) ( return nil, sdkerrors.Wrapf(sdkerrors.ErrUnknownAddress, "account %s does not exist", addr) } -// CountSubKeys counts the total number of keys for a multi-sig public key. -func CountSubKeys(pub cryptotypes.PubKey) int { - v, ok := pub.(*kmultisig.LegacyAminoPubKey) - if !ok { - return 1 - } - - numKeys := 0 - for _, subkey := range v.GetPubKeys() { - numKeys += CountSubKeys(subkey) - } - - return numKeys -} - // signatureDataToBz converts a SignatureData into raw bytes signature. // For SingleSignatureData, it returns the signature raw bytes. // For MultiSignatureData, it returns an array of all individual signatures, From b390025f83dea2c2c95cbacb9424f79facc886c9 Mon Sep 17 00:00:00 2001 From: jgo121 Date: Mon, 13 May 2024 23:54:55 +0800 Subject: [PATCH 14/15] fix unit tests --- x/gov/genesis_test.go | 56 +++++++++++++++++++++---------------------- 1 file changed, 28 insertions(+), 28 deletions(-) diff --git a/x/gov/genesis_test.go b/x/gov/genesis_test.go index 166e7cd6..811e4ffb 100644 --- a/x/gov/genesis_test.go +++ b/x/gov/genesis_test.go @@ -29,8 +29,8 @@ func TestSimappExportGenesis(t *testing.T) { bz, err := app.AppCodec().MarshalJSON(genesis) require.NoError(t, err) buffer := new(bytes.Buffer) - err = json.Compact(buffer, []byte(`{ - "default_denom": "ukex", + err = json.Compact(buffer, []byte(`{ + "default_denom": "ukex", "bech32_prefix": "kira", "starting_proposal_id": "1", "next_role_id": "3", @@ -172,8 +172,8 @@ func TestSimappExportGenesis(t *testing.T) { "max_proposal_poll_option_count": "128", "max_proposal_reference_size": "512", "max_proposal_checksum_size": "128", - "min_dapp_bond": "1000000", - "max_dapp_bond": "10000000", + "min_dapp_bond": "1000000", + "max_dapp_bond": "10000000", "dapp_liquidation_threshold": "0", "dapp_liquidation_period": "0", "dapp_bond_duration": "604800", @@ -197,21 +197,21 @@ func TestSimappExportGenesis(t *testing.T) { "default_parameters": "0" }, { - "transaction_type": "claim-councilor", + "transaction_type": "claim-proposal-type-x", "execution_fee": "100", "failure_fee": "1", "timeout": "10", "default_parameters": "0" }, { - "transaction_type": "claim-proposal-type-x", + "transaction_type": "claim_councilor", "execution_fee": "100", "failure_fee": "1", "timeout": "10", "default_parameters": "0" }, { - "transaction_type": "claim-validator", + "transaction_type": "claim_validator", "execution_fee": "100", "failure_fee": "1", "timeout": "10", @@ -239,7 +239,7 @@ func TestSimappExportGenesis(t *testing.T) { "default_parameters": "0" }, { - "transaction_type": "upsert-token-alias", + "transaction_type": "upsert_token_alias", "execution_fee": "100", "failure_fee": "1", "timeout": "10", @@ -262,28 +262,28 @@ func TestSimappExportGenesis(t *testing.T) { ], "poor_network_messages": { "messages": [ - "submit-proposal", - "set-network-properties", - "vote-proposal", - "claim-councilor", - "whitelist-permissions", - "blacklist-permissions", - "create-role", - "assign-role", - "unassign-role", - "whitelist-role-permission", - "blacklist-role-permission", - "remove-whitelist-role-permission", - "remove-blacklist-role-permission", - "claim-validator", + "submit_proposal", + "set_network_properties", + "vote_proposal", + "claim_councilor", + "whitelist_permissions", + "blacklist_permissions", + "create_role", + "assign_role", + "unassign_role", + "whitelist_role_permission", + "blacklist_role_permission", + "remove_whitelist_role_permission", + "remove_blacklist_role_permission", + "claim_validator", "activate", "pause", "unpause", - "register-identity-records", - "edit-identity-record", - "request-identity-records-verify", - "handle-identity-records-verify-request", - "cancel-identity-records-verify-request" + "register_identity_records", + "delete_identity_records", + "request_identity_records_verify", + "handle_identity_records_verify_request", + "cancel_identity_records_verify_request" ] }, "proposals": [], @@ -527,7 +527,7 @@ func TestExportInitGenesis(t *testing.T) { ], "poor_network_messages": { "messages": [ - "set-network-properties" + "set_network_properties" ] }, "proposals": [], From 7e04f1bc48f5f04aac5280cf02eb831c67a32972 Mon Sep 17 00:00:00 2001 From: jgo121 Date: Tue, 14 May 2024 00:51:56 +0800 Subject: [PATCH 15/15] add new release log for v0.3.45 --- RELEASE.md | 9 +++------ types/constants.go | 2 +- 2 files changed, 4 insertions(+), 7 deletions(-) diff --git a/RELEASE.md b/RELEASE.md index ef4078f4..9d859049 100644 --- a/RELEASE.md +++ b/RELEASE.md @@ -1,8 +1,5 @@ Features: -- Unique identity keys -- Genesis init fix -- CLI to use flags for execution fees proposal -- Slashing module params to gov module properties -- Identity record verification bug fix -- Network properties handling fix +- Signature verification codebase for metamask token send and EIP712 transactions +- Transaction type text updates to use camelcase +- Upgrade genesis script modification to migrate from v0.3.17 to v0.3.45 diff --git a/types/constants.go b/types/constants.go index d8a2bbeb..bc4b930d 100644 --- a/types/constants.go +++ b/types/constants.go @@ -3,6 +3,6 @@ package types const ( // we set page iteration limit for safety PageIterationLimit = 512 - SekaiVersion = "v0.3.44" + SekaiVersion = "v0.3.45" CosmosVersion = "v0.47.6" )