From 0e19128251137e951a2e3b270143ac9147f1d9ef Mon Sep 17 00:00:00 2001 From: Simon Noetzlin Date: Mon, 20 Nov 2023 20:27:49 +0100 Subject: [PATCH] fix: update consumer double vote cmd (#1439) add cmd fix --- x/ccv/provider/client/cli/tx.go | 23 ++++++++++++++++++----- 1 file changed, 18 insertions(+), 5 deletions(-) diff --git a/x/ccv/provider/client/cli/tx.go b/x/ccv/provider/client/cli/tx.go index 6d975bc3e4..4db910bdee 100644 --- a/x/ccv/provider/client/cli/tx.go +++ b/x/ccv/provider/client/cli/tx.go @@ -1,7 +1,9 @@ package cli import ( + "encoding/json" "fmt" + "os" "strings" "github.com/spf13/cobra" @@ -141,17 +143,28 @@ Example: WithTxConfig(clientCtx.TxConfig).WithAccountRetriever(clientCtx.AccountRetriever) submitter := clientCtx.GetFromAddress() - var ev *tmproto.DuplicateVoteEvidence - if err := clientCtx.Codec.UnmarshalInterfaceJSON([]byte(args[1]), &ev); err != nil { + + ev := tmproto.DuplicateVoteEvidence{} + evidenceJson, err := os.ReadFile(args[0]) + if err != nil { return err } - var header ibctmtypes.Header - if err := clientCtx.Codec.UnmarshalInterfaceJSON([]byte(args[2]), &header); err != nil { + if err := json.Unmarshal(evidenceJson, &ev); err != nil { + return fmt.Errorf("duplicate vote evidence unmarshalling failed: %s", err) + } + + headerRaw, err := os.ReadFile(args[1]) + if err != nil { return err } - msg, err := types.NewMsgSubmitConsumerDoubleVoting(submitter, ev, &header) + header := ibctmtypes.Header{} + if err := types.ModuleCdc.UnmarshalJSON(headerRaw, &header); err != nil { + return fmt.Errorf("infraction IBC header unmarshalling failed: %s", err) + } + + msg, err := types.NewMsgSubmitConsumerDoubleVoting(submitter, &ev, &header) if err != nil { return err }