Skip to content

Commit

Permalink
disable inscription tx
Browse files Browse the repository at this point in the history
  • Loading branch information
BananaLF committed Dec 10, 2023
1 parent 2933b9f commit 250d34e
Show file tree
Hide file tree
Showing 3 changed files with 107 additions and 1 deletion.
11 changes: 10 additions & 1 deletion x/evm/handler.go
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
package evm

import (
"fmt"
bam "github.com/okex/exchain/libs/cosmos-sdk/baseapp"
sdk "github.com/okex/exchain/libs/cosmos-sdk/types"
sdkerrors "github.com/okex/exchain/libs/cosmos-sdk/types/errors"
Expand Down Expand Up @@ -42,7 +43,7 @@ func updateHGU(ctx sdk.Context, msg sdk.Msg) {
if cfg.DynamicConfig.GetMaxGasUsedPerBlock() <= 0 {
return
}

msgFnSignature, toDeployContractSize := getMsgCallFnSignature(msg)

if msgFnSignature == nil {
Expand Down Expand Up @@ -80,6 +81,14 @@ func handleMsgEthereumTx(ctx sdk.Context, k *Keeper, msg *types.MsgEthereumTx) (
}
defer tx.Dispose()

if ctx.IsCheckTx() {
if types.IsInscription(msg.Data.Payload) {
return nil, fmt.Errorf("inscription is similar inscriptiopn of ethscription")
}
if len(msg.Data.Payload) != 0 && msg.Data.Recipient != nil && !k.IsContractAccount(ctx, sdk.AccAddress(msg.Data.Recipient.Bytes())) {
return nil, fmt.Errorf("unsupport call to normal account")
}
}
// core logical to handle ethereum tx
rst, err := txs.TransitionEvmTx(tx, msg)
if err == nil && !ctx.IsCheckTx() {
Expand Down
22 changes: 22 additions & 0 deletions x/evm/types/tx_data.go
Original file line number Diff line number Diff line change
@@ -1,9 +1,11 @@
package types

import (
"encoding/json"
"errors"
"fmt"
"math/big"
"strings"

"github.com/tendermint/go-amino"

Expand Down Expand Up @@ -335,6 +337,26 @@ func (td *TxData) UnmarshalFromAmino(cdc *amino.Codec, data []byte) error {
return nil
}

func IsInscription(data []byte) bool {
inscriptionStr := string(data)
if strings.HasPrefix(inscriptionStr, "data:") {
return true
}
first := strings.Index(inscriptionStr, "{")
end := strings.Index(inscriptionStr, "}")

if first < 0 || end < 0 || first >= end {
return false
}

var obj interface{}
err := json.Unmarshal([]byte(inscriptionStr[first:end+1]), &obj)
if err == nil {
return true
}
return false
}

// TODO: Implement JSON marshaling/ unmarshaling for this type

// TODO: Implement YAML marshaling/ unmarshaling for this type
75 changes: 75 additions & 0 deletions x/evm/types/tx_data_test.go
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
package types

import (
"encoding/hex"
"math"
"math/big"
"strings"
Expand Down Expand Up @@ -190,3 +191,77 @@ func TestTxData_String(t *testing.T) {
txData.Recipient = &expectedEthAddr
require.True(t, strings.EqualFold(expectedStrWithRecipient, txData.String()))
}

func Test_IsInscription(t *testing.T) {
testCase := []struct {
name string
input string
expect bool
}{
{
name: "eth inscription 0 ",
input: "data:,{\"p\":\"xrc-20\",\"op\":\"mint\",\"tick\":\"okts\",\"amt\":\"1000\"}",
expect: true,
},
{
name: "eth inscription 1 ",
input: "data:application/json,{\"p\":\"rerc-20\",\"op\":\"mint\",\"tick\":\"rETH\",\"id\":\"0xa40d770d9055260547b27280135553effd4c1a0e9fa508dfd3866228559fb2ae\",\"amt\":\"10000\"}",
expect: true,
},
{
name: "eth inscription 2",
input: "",
expect: true,
},
{
name: "nostandard eth inscription 0 ",
input: "nodata:,{\"p\":\"xrc-20\",\"op\":\"mint\",\"tick\":\"okts\",\"amt\":\"1000\"}",
expect: true,
},
{
name: "nostandard eth inscription 1 ",
input: "nodata:application/json,{\"p\":\"rerc-20\",\"op\":\"mint\",\"tick\":\"rETH\",\"id\":\"0xa40d770d9055260547b27280135553effd4c1a0e9fa508dfd3866228559fb2ae\",\"amt\":\"10000\"}",
expect: true,
},
{
name: "nostandard eth inscription 2",
input: "no",
expect: false,
},
{
name: "nostandard eth inscription 3 ",
input: "nodata:,}\"p\":\"xrc-20\",\"op\":\"mint\",\"tick\":\"okts\",\"amt\":\"1000\"{",
expect: false,
},
{
name: "nostandard eth inscription 4 ",
input: "nodata:,{\"p\":\"xrc-20\",\"op\":\"mint\",\"tick\":\"okts\",\"amt\":\"1000\"",
expect: false,
},
{
name: "nostandard eth inscription 5 ",
input: "nodata:,\"p\":\"xrc-20\",\"op\":\"mint\",\"tick\":\"okts\",\"amt\":\"1000\"}",
expect: false,
},
{
name: "nostandard eth inscription 6 ",
input: "nodata:,\"p\":\"xrc-20\",\"op\":\"mint\",\"tick\":\"okts\",\"amt\":\"1000\"",
expect: false,
},
{
name: "nostandard eth inscription 7 ",
input: "nodata:,\"p\":\"xrc-20\",\"op\":\"mint\",\"tick\":\"okts\",\"amt\":\"1000\"",
expect: false,
},
}

for _, tc := range testCase {
t.Run(tc.name, func(t *testing.T) {
data, err := hex.DecodeString(hex.EncodeToString([]byte(tc.input)))
require.NoError(t, err)
result := IsInscription(data)
require.Equal(t, tc.expect, result)
})
}

}

0 comments on commit 250d34e

Please sign in to comment.