Skip to content

Commit

Permalink
fix: allow hex strings to be prefixed by 0x optionally in queries (#2028
Browse files Browse the repository at this point in the history
)

* fix: allow hex strings to be prefixed by 0x optionally in queries

* lint
  • Loading branch information
milapsheth authored Nov 17, 2023
1 parent a80d812 commit b54ac78
Show file tree
Hide file tree
Showing 10 changed files with 85 additions and 18 deletions.
3 changes: 1 addition & 2 deletions cmd/axelard/cmd/helpers.go
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
package cmd

import (
"encoding/hex"
"encoding/json"
"fmt"
"io/ioutil"
Expand Down Expand Up @@ -45,5 +44,5 @@ func getByteCodes(file string) ([]byte, error) {
return nil, fmt.Errorf("could not retrieve bytecode from file")
}

return hex.DecodeString(str)
return utils.HexDecode(str)
}
11 changes: 11 additions & 0 deletions utils/encoding.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
package utils

import (
"encoding/hex"
"strings"
)

// Decode a hex string. Hex string can be optionally prefixed with 0x.
func HexDecode(input string) ([]byte, error) {
return hex.DecodeString(strings.TrimPrefix(input, "0x"))
}
59 changes: 59 additions & 0 deletions utils/encoding_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,59 @@
package utils

import (
"testing"

"github.com/stretchr/testify/assert"
)

func TestHexDecode(t *testing.T) {
tests := []struct {
name string
input string
want []byte
wantErr bool
}{
{
name: "empty input",
input: "",
want: []byte{},
wantErr: false,
},
{
name: "valid input with 0x prefix",
input: "0x68656c6c6f",
want: []byte("hello"),
wantErr: false,
},
{
name: "valid input without 0x prefix",
input: "68656c6c6f",
want: []byte("hello"),
wantErr: false,
},
{
name: "invalid input with odd number of characters",
input: "68656c6c6",
want: nil,
wantErr: true,
},
{
name: "invalid input with non-hex characters",
input: "68656c6c6z",
want: nil,
wantErr: true,
},
}

for _, test := range tests {
t.Run(test.name, func(t *testing.T) {
got, err := HexDecode(test.input)
if test.wantErr {
assert.Error(t, err)
return
}

assert.Equal(t, test.want, got)
})
}
}
5 changes: 3 additions & 2 deletions vald/sign.go
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@ import (
"github.com/ethereum/go-ethereum/common"
"github.com/spf13/cobra"

"github.com/axelarnetwork/axelar-core/utils"
"github.com/axelarnetwork/axelar-core/vald/config"
"github.com/axelarnetwork/axelar-core/vald/tss"
evm "github.com/axelarnetwork/axelar-core/x/evm/types"
Expand Down Expand Up @@ -61,7 +62,7 @@ func GetSignCommand() *cobra.Command {
}
}

pubKeyRaw, err := hex.DecodeString(pubKeyHex)
pubKeyRaw, err := utils.HexDecode(pubKeyHex)
if err != nil {
return err
}
Expand All @@ -71,7 +72,7 @@ func GetSignCommand() *cobra.Command {
return err
}

hashRaw, err := hex.DecodeString(args[2])
hashRaw, err := utils.HexDecode(args[2])
if err != nil {
return err
}
Expand Down
5 changes: 2 additions & 3 deletions x/axelarnet/client/cli/tx.go
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
package cli

import (
"encoding/hex"
"fmt"
"os"
"strconv"
Expand Down Expand Up @@ -316,7 +315,7 @@ func getGeneralMessage() *cobra.Command {
}

id := utils.NormalizeString(args[0])
payload, err := hex.DecodeString(args[1])
payload, err := utils.HexDecode(args[1])
if err != nil {
return err
}
Expand Down Expand Up @@ -357,7 +356,7 @@ func getCmdCallContract() *cobra.Command {
return err
}

payload, err := hex.DecodeString(strings.TrimPrefix(args[2], "0x"))
payload, err := utils.HexDecode(args[2])
if err != nil {
return err
}
Expand Down
3 changes: 2 additions & 1 deletion x/evm/keeper/grpc_query.go
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ import (
"google.golang.org/grpc/codes"
"google.golang.org/grpc/status"

"github.com/axelarnetwork/axelar-core/utils"
"github.com/axelarnetwork/axelar-core/x/evm/types"
multisig "github.com/axelarnetwork/axelar-core/x/multisig/exported"
nexustypes "github.com/axelarnetwork/axelar-core/x/nexus/exported"
Expand Down Expand Up @@ -259,7 +260,7 @@ func (q Querier) BatchedCommands(c context.Context, req *types.BatchedCommandsRe
return nil, status.Error(codes.NotFound, sdkerrors.Wrap(types.ErrEVM, fmt.Sprintf("could not get the latest batched commands for chain %s", req.Chain)).Error())
}
default:
commandBatchID, err := hex.DecodeString(req.Id)
commandBatchID, err := utils.HexDecode(req.Id)
if err != nil {
return nil, status.Error(codes.InvalidArgument, sdkerrors.Wrap(types.ErrEVM, fmt.Sprintf("invalid batched commands ID: %v", err)).Error())
}
Expand Down
5 changes: 2 additions & 3 deletions x/evm/keeper/migrate.go
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
package keeper

import (
"encoding/hex"
"fmt"

sdk "github.com/cosmos/cosmos-sdk/types"
Expand Down Expand Up @@ -140,12 +139,12 @@ func AlwaysMigrateBytecode(k *BaseKeeper, n types.Nexus, otherMigrations func(ct
// EVM chain. It's crucial whenever contracts are changed between versions.
// DO NOT DELETE
func migrateContractsBytecode(ctx sdk.Context, ck chainKeeper) error {
bzToken, err := hex.DecodeString(types.Token)
bzToken, err := utils.HexDecode(types.Token)
if err != nil {
return err
}

bzBurnable, err := hex.DecodeString(types.Burnable)
bzBurnable, err := utils.HexDecode(types.Burnable)
if err != nil {
return err
}
Expand Down
5 changes: 2 additions & 3 deletions x/evm/types/params.go
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
package types

import (
"encoding/hex"
"fmt"

sdk "github.com/cosmos/cosmos-sdk/types"
Expand Down Expand Up @@ -39,12 +38,12 @@ func KeyTable() params.KeyTable {

// DefaultParams returns the module's parameter set initialized with default values
func DefaultParams() []Params {
bzToken, err := hex.DecodeString(Token)
bzToken, err := utils.HexDecode(Token)
if err != nil {
panic(err)
}

bzBurnable, err := hex.DecodeString(Burnable)
bzBurnable, err := utils.HexDecode(Burnable)
if err != nil {
panic(err)
}
Expand Down
5 changes: 2 additions & 3 deletions x/evm/types/testutils/rand.go
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
package testutils

import (
"encoding/hex"
"fmt"
"math/big"
"strings"
Expand Down Expand Up @@ -323,7 +322,7 @@ func RandomTokens() []types.ERC20TokenMetadata {

// RandomToken returns a random (valid) token for testing
func RandomToken() types.ERC20TokenMetadata {
bzBurnable, err := hex.DecodeString(types.Burnable)
bzBurnable, err := utils.HexDecode(types.Burnable)
if err != nil {
panic(err)
}
Expand Down Expand Up @@ -390,7 +389,7 @@ func RandomBurnerInfo() types.BurnerInfo {

// RandomParams returns a random (valid) params instance for testing
func RandomParams() types.Params {
bzBurnable, err := hex.DecodeString(types.Burnable)
bzBurnable, err := utils.HexDecode(types.Burnable)
if err != nil {
panic(err)
}
Expand Down
2 changes: 1 addition & 1 deletion x/evm/types/types.go
Original file line number Diff line number Diff line change
Expand Up @@ -703,7 +703,7 @@ func CommandIDFromTransferID(id nexus.TransferID) CommandID {

// HexToCommandID decodes a hex representation of a CommandID
func HexToCommandID(id string) (CommandID, error) {
bz, err := hex.DecodeString(id)
bz, err := utils.HexDecode(id)
if err != nil {
return CommandID{}, err
}
Expand Down

0 comments on commit b54ac78

Please sign in to comment.