Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Pointers contracts: support for ERC1155 and CW1155 contracts #1755

Merged
merged 113 commits into from
Dec 5, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
113 commits
Select commit Hold shift + click to select a range
9eab721
wip cw1155 pointer
dirtyshab May 24, 2024
33d8bfd
cleanup todos
dirtyshab Jun 5, 2024
0061483
sync events with current standard
dirtyshab Jun 5, 2024
9f0d299
fix query BalanceOfBatch
dirtyshab Jun 5, 2024
45c654f
fix import
dirtyshab Jun 5, 2024
0269627
Fix up cwerc1155 compiled files
dvli2007 Jun 15, 2024
4d706dd
Add 1155 requests into bindings
dvli2007 Jun 20, 2024
533bca6
queries
mr-meat Jun 20, 2024
792da46
follow same coding style
mr-meat Jun 20, 2024
6304c6d
Add cwerc1155.wasm binary to `/contracts`
dvli2007 Jun 21, 2024
68df425
Add go code to support new pointer contract
dvli2007 Jun 21, 2024
3502209
Fix typo
dvli2007 Jun 21, 2024
cca521c
Add updated protobuf files
dvli2007 Jun 21, 2024
f7fa05d
Fix up tests
dvli2007 Jun 21, 2024
2e6622e
Merge pull request #5 from palletexchange/add-new-pointer
dvli2007 Jun 21, 2024
aa22642
Merge branch 'main' into cw1155
dvli2007 Jun 21, 2024
ae6a095
Deprecate pointer proposals
dvli2007 Jun 21, 2024
5082b6b
queries
mr-meat Jun 20, 2024
cb2ba41
follow same coding style
mr-meat Jun 20, 2024
d260408
safetransfer functions, royalyinfo, set approval
mr-meat Jun 25, 2024
1e2ca09
add in exe queries and royaltyinfo
mr-meat Jun 25, 2024
39978bb
Merge branch 'main' into cw1155
dvli2007 Jun 25, 2024
a05cbac
Merge branch 'cw1155' into davy/cw1155
dvli2007 Jun 25, 2024
1ee0e92
adding in transfer and approval tests
mr-meat Jun 25, 2024
1d91ef5
solc and abigen
mr-meat Jun 26, 2024
b117fb2
clean up unused artifacts
mr-meat Jun 26, 2024
8b818a0
Merge pull request #6 from palletexchange/erc1155
dvli2007 Jun 27, 2024
ed38c98
Merge branch 'cw1155' into davy/cw1155
dvli2007 Jun 27, 2024
68ed5a0
Add all go bindings
dvli2007 Jun 30, 2024
3989fc3
Merge pull request #7 from palletexchange/davy/cw1155
dvli2007 Jun 30, 2024
2cce20c
return unsupported for methods not supported in erc standard
dirtyshab Jul 1, 2024
7b0668e
Merge pull request #9 from palletexchange/cw1155
scottirvine Jul 1, 2024
f5858a8
fix query BalanceOfBatch response
dirtyshab Jul 1, 2024
5d0750c
Add new test files
dvli2007 Jul 1, 2024
a00687b
fix Erc1155BalanceOfBatchResponse
dirtyshab Jul 2, 2024
18768c1
More testing
dvli2007 Jul 2, 2024
b2b9a6c
Merge pull request #8 from palletexchange/cw1155-cleanup
dvli2007 Jul 2, 2024
ae52356
Merge pull request #10 from palletexchange/davy/test-cw1155
dvli2007 Jul 2, 2024
327d5fd
Update cwerc1155.wasm
dvli2007 Jul 2, 2024
6736609
More tests
dvli2007 Jul 3, 2024
95fc243
return true/false instead of erroring in query IsApprovedForAll
dirtyshab Jul 3, 2024
219a3ca
use correct response for query BalanceOfBatch
dirtyshab Jul 3, 2024
134252a
pass optional token id field to evm query TotalSupply
dirtyshab Jul 3, 2024
0c429e9
remove todos
dirtyshab Jul 3, 2024
f2b67b3
remove AllTokenInfo query
dirtyshab Jul 3, 2024
bcfc760
Fix balances query struct
dvli2007 Jul 3, 2024
eaa110d
Update and rebuild CW1155 pointer
dvli2007 Jul 3, 2024
d9b54b3
Add new cw1155 wasms
dvli2007 Jul 3, 2024
4ae3e4b
Merge pull request #12 from palletexchange/cw1155
scottirvine Jul 3, 2024
d91e3cb
merge
mr-meat Jul 3, 2024
846f7c2
Update cwerc1155.wasm
dvli2007 Jul 3, 2024
61e2c27
Fix up ERC1155 pointer tests
dvli2007 Jul 3, 2024
2c537ed
balanceOfBatch
mr-meat Jul 3, 2024
2c0c498
adding in expect calls
mr-meat Jul 3, 2024
7c8bc90
remove unused import
mr-meat Jul 3, 2024
60cbbce
Round of updates to cw1155 contracts
dvli2007 Jul 3, 2024
487ac30
Update cw1155 pointer tests
dvli2007 Jul 3, 2024
8c1e7a4
Fix: missing ERC1155TransferPayload
dvli2007 Jul 3, 2024
0d7a6cb
removing unnecessary return
mr-meat Jul 3, 2024
8949624
Update binary
dvli2007 Jul 3, 2024
b964fd0
Merge branch 'erc1155' into cw1155-localtest
dvli2007 Jul 3, 2024
db6af24
Fix balance of batch
dvli2007 Jul 3, 2024
b3ac9de
Merge branch 'erc1155' into cw1155-localtest
dvli2007 Jul 3, 2024
bcb3b3c
Merge pull request #14 from palletexchange/cw1155-localtest
dvli2007 Jul 3, 2024
a5a1c51
Merge branch 'main' into cw1155
dvli2007 Jul 4, 2024
e372e13
add minor checks
dvli2007 Jul 4, 2024
f129599
Update integration test with latest main updates
dvli2007 Jul 4, 2024
adc2519
Fix up erc721-payload and erc1155-payload cli commands
dvli2007 Jul 4, 2024
2e2d938
Merge branch 'main' into pointers/erc1155-cw1155
dvli2007 Jul 9, 2024
7541497
Lint code
dvli2007 Jul 12, 2024
a73a8a1
Merge branch 'main' into pointers/erc1155-cw1155
dvli2007 Jul 12, 2024
4f6aa54
Merge branch 'pointers/erc1155-cw1155' of github.com:palletexchange/s…
dvli2007 Jul 12, 2024
d39f380
Update integration test with new pointer contract code id
dvli2007 Jul 12, 2024
532a24d
Merge branch 'main' into pointers/erc1155-cw1155
dvli2007 Jul 22, 2024
0fdfbe5
Map CW1155 events to EVM
dvli2007 Jul 23, 2024
86d0dd3
updates from cw1155 base
dirtyshab Jul 23, 2024
1caea56
update cw1155 base
dirtyshab Jul 24, 2024
fd8ef0f
Test events emissions for cw1155 events
dvli2007 Jul 24, 2024
649e610
Update wasm build for cwerc1155
dvli2007 Jul 24, 2024
4229eeb
Merge branch 'update-base-cw1155' into pointers/erc1155-cw1155
dvli2007 Jul 24, 2024
66bc71c
Fix integration test 1
dvli2007 Jul 24, 2024
6478b68
update cw1155 cargo, add optimize script to cargo
dirtyshab Jul 25, 2024
89b349b
Merge branch 'update-base-cw1155' into pointers/erc1155-cw1155
dvli2007 Jul 25, 2024
21f7765
Update wasm builds
dvli2007 Jul 25, 2024
01322e9
Merge branch 'main' into pointers/erc1155-cw1155
dvli2007 Jul 25, 2024
dbdcbc0
Add migrations for 1155s
dvli2007 Jul 25, 2024
2c0db74
Code quality
dvli2007 Jul 25, 2024
b9389cb
Merge branch 'main' into pointers/erc1155-cw1155
dvli2007 Jul 25, 2024
c004c54
Remove unnecessary lines
dvli2007 Jul 26, 2024
e9ffdc3
Merge branch 'main' into pointers/erc1155-cw1155
dvli2007 Jul 26, 2024
9e53e07
updates from audit on cw1155 standard
dirtyshab Oct 14, 2024
28a803e
[P1-I-01] Validate parameters in the "balanceOfBatch" function
dvli2007 Oct 16, 2024
bd6825d
build pointer wasm from audit changes
dirtyshab Oct 16, 2024
5707da9
update pointer wasms in other places
dirtyshab Oct 16, 2024
3593569
[P1-H-01] Fix "safeBatchTransferFrom" - change to "onERC1155BatchRece…
dvli2007 Oct 16, 2024
b1b963d
[P1-I-02] Consider adding "ERC1155Burnable" to "CW1155ERC1155Pointer"
dvli2007 Oct 16, 2024
11c38df
Fix CW1155ERC1155Pointer.sol styles
dvli2007 Oct 16, 2024
253f3de
Update ERC1155 pointer artifacts
dvli2007 Oct 16, 2024
6aa1613
Merge pull request #20 from palletexchange/erc1155-audit
dvli2007 Oct 16, 2024
304f47f
send funds if empty msg in send and send_batch
dirtyshab Oct 22, 2024
728be34
Merge pull request #18 from palletexchange/sec3-audit
dvli2007 Nov 20, 2024
800b40f
Merge branch 'main' into pointers/erc1155-cw1155
dvli2007 Nov 20, 2024
26e5f38
Merge branch 'main' into pointers/erc1155-cw1155
dvli2007 Nov 21, 2024
cf69463
Merge branch 'main' into pointers/erc1155-cw1155
dvli2007 Nov 21, 2024
55ec5d7
rebuild cw1155 pointer/standard
dirtyshab Nov 21, 2024
28d679f
fix version issue
dirtyshab Nov 21, 2024
77c841f
cw1155_base wasm fix
dirtyshab Nov 22, 2024
1d839d0
Update and fix tests
dvli2007 Nov 22, 2024
038f177
Fix tests
dvli2007 Nov 22, 2024
89c1367
Remove events from 1155 pointer so as not to double-emit
dvli2007 Nov 22, 2024
3e057bf
Linting
dvli2007 Nov 22, 2024
91c36bd
Merge branch 'main' into pointers/erc1155-cw1155
dvli2007 Nov 22, 2024
f8498b8
Merge branch 'main' into pointers/erc1155-cw1155
dvli2007 Dec 3, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Fix tests
  • Loading branch information
dvli2007 committed Nov 22, 2024
commit 038f1771a5816f0d54710e2c3f9332d9f98a849e
13 changes: 2 additions & 11 deletions contracts/test/ERC1155toCW1155PointerTest.js
Original file line number Diff line number Diff line change
Expand Up @@ -93,11 +93,8 @@ describe("ERC1155 to CW1155 Pointer", function () {
expect(balance0).to.equal(11);
let balance1 = await pointerAcc0.balanceOf(accounts[1].evmAddress, 1);
expect(balance1).to.equal(0);
transferTxResp = await pointerAcc0.safeTransferFrom(accounts[0].evmAddress, accounts[1].evmAddress, 1, 5, '0x');
const transferTxResp = await pointerAcc0.safeTransferFrom(accounts[0].evmAddress, accounts[1].evmAddress, 1, 5, '0x');
await transferTxResp.wait();
await expect(transferTxResp)
.to.emit(pointerAcc0, 'TransferSingle')
.withArgs(accounts[0].evmAddress, accounts[0].evmAddress, accounts[1].evmAddress, 1, 5);
balance0 = await pointerAcc0.balanceOf(accounts[0].evmAddress, 1);
expect(balance0).to.equal(6);
balance1 = await pointerAcc0.balanceOf(accounts[1].evmAddress, 1);
Expand All @@ -123,17 +120,14 @@ describe("ERC1155 to CW1155 Pointer", function () {
expect(balances[1]).to.equal(12);
expect(balances[2]).to.equal(0);
expect(balances[3]).to.equal(0);
transferTxResp = await pointerAcc1.safeBatchTransferFrom(
const transferTxResp = await pointerAcc1.safeBatchTransferFrom(
accounts[1].evmAddress,
accounts[0].evmAddress,
tids,
tamounts,
'0x'
);
await transferTxResp.wait();
await expect(transferTxResp)
.to.emit(pointerAcc1, 'TransferBatch')
.withArgs(accounts[1].evmAddress, accounts[1].evmAddress, accounts[0].evmAddress, tids, tamounts);
balances = await pointerAcc1.balanceOfBatch(
[accounts[1].evmAddress, accounts[1].evmAddress, accounts[0].evmAddress, accounts[0].evmAddress],
[...tids, ...tids]
Expand All @@ -147,9 +141,6 @@ describe("ERC1155 to CW1155 Pointer", function () {
it("set approval for all", async function () {
const setApprovalForAllTxResp = await pointerAcc0.setApprovalForAll(accounts[1].evmAddress, true);
await setApprovalForAllTxResp.wait();
await expect(setApprovalForAllTxResp)
.to.emit(pointerAcc0, 'ApprovalForAll')
.withArgs(accounts[0].evmAddress, accounts[1].evmAddress, true);
const approved = await pointerAcc0.isApprovedForAll(accounts[0].evmAddress, accounts[1].evmAddress);
expect(approved).to.equal(true);

Expand Down
6 changes: 6 additions & 0 deletions docs/swagger-ui/swagger.yml
Original file line number Diff line number Diff line change
Expand Up @@ -34966,9 +34966,11 @@ paths:
enum:
- ERC20
- ERC721
- ERC1155
- NATIVE
- CW20
- CW721
- CW1155
default: ERC20
- name: pointee
in: query
Expand Down Expand Up @@ -35184,9 +35186,11 @@ paths:
enum:
- ERC20
- ERC721
- ERC1155
- NATIVE
- CW20
- CW721
- CW1155
default: ERC20
tags:
- Query
Expand Down Expand Up @@ -61401,9 +61405,11 @@ definitions:
enum:
- ERC20
- ERC721
- ERC1155
- NATIVE
- CW20
- CW721
- CW1155
default: ERC20
seiprotocol.seichain.evm.QueryEVMAddressBySeiAddressResponse:
type: object
Expand Down
1 change: 0 additions & 1 deletion x/evm/artifacts/cw1155/artifacts.go
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,6 @@ const CurrentVersion uint16 = 1
var f embed.FS

var cachedBin []byte
var cachedLegacyBin []byte
var cachedABI *abi.ABI

func GetABI() []byte {
Expand Down
8 changes: 4 additions & 4 deletions x/evm/integration_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -305,7 +305,7 @@ func TestERC1155RoyaltiesPointerToCW1155Royalties(t *testing.T) {
txData := ethtypes.LegacyTx{
Nonce: 0,
GasPrice: big.NewInt(1000000000),
Gas: 5000000,
Gas: 6000000,
To: &to,
Data: data,
}
Expand Down Expand Up @@ -338,7 +338,7 @@ func TestERC1155RoyaltiesPointerToCW1155Royalties(t *testing.T) {
txData = ethtypes.LegacyTx{
Nonce: 1,
GasPrice: big.NewInt(1000000000),
Gas: 1000000,
Gas: 300000,
To: &pointerAddr,
Data: data,
}
Expand Down Expand Up @@ -388,7 +388,7 @@ func TestCW1155RoyaltiesPointerToERC1155Royalties(t *testing.T) {
txData := ethtypes.LegacyTx{
Nonce: 0,
GasPrice: big.NewInt(1000000000),
Gas: 5000000,
Gas: 6000000,
To: nil,
Data: append(bz, data...),
}
Expand Down Expand Up @@ -423,7 +423,7 @@ func TestCW1155RoyaltiesPointerToERC1155Royalties(t *testing.T) {
txData = ethtypes.LegacyTx{
Nonce: 1,
GasPrice: big.NewInt(1000000000),
Gas: 1000000,
Gas: 300000,
To: &to,
Data: data,
}
Expand Down
14 changes: 14 additions & 0 deletions x/evm/keeper/grpc_query.go
Original file line number Diff line number Diff line change
Expand Up @@ -196,6 +196,13 @@ func (q Querier) Pointee(c context.Context, req *types.QueryPointeeRequest) (*ty
Version: uint32(v),
Exists: e,
}, nil
case types.PointerType_CW1155:
p, v, e := q.Keeper.GetCW1155Pointee(ctx, common.HexToAddress(req.Pointer))
return &types.QueryPointeeResponse{
Pointee: p,
Version: uint32(v),
Exists: e,
}, nil
case types.PointerType_ERC20:
p, v, e := q.Keeper.GetERC20Pointee(ctx, req.Pointer)
return &types.QueryPointeeResponse{
Expand All @@ -210,6 +217,13 @@ func (q Querier) Pointee(c context.Context, req *types.QueryPointeeRequest) (*ty
Version: uint32(v),
Exists: e,
}, nil
case types.PointerType_ERC1155:
p, v, e := q.Keeper.GetERC1155Pointee(ctx, req.Pointer)
return &types.QueryPointeeResponse{
Pointee: p.Hex(),
Version: uint32(v),
Exists: e,
}, nil
default:
return nil, errors.ErrUnsupported
}
Expand Down
24 changes: 24 additions & 0 deletions x/evm/keeper/grpc_query_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -68,6 +68,8 @@ func TestQueryPointee(t *testing.T) {
seiAddr3, evmAddr3 := testkeeper.MockAddressPair()
seiAddr4, evmAddr4 := testkeeper.MockAddressPair()
seiAddr5, evmAddr5 := testkeeper.MockAddressPair()
seiAddr6, evmAddr6 := testkeeper.MockAddressPair()
seiAddr7, evmAddr7 := testkeeper.MockAddressPair()
goCtx := sdk.WrapSDKContext(ctx)

// Set up pointers for each type
Expand All @@ -76,6 +78,8 @@ func TestQueryPointee(t *testing.T) {
k.SetERC721CW721Pointer(ctx, seiAddr3.String(), evmAddr3)
k.SetCW20ERC20Pointer(ctx, evmAddr4, seiAddr4.String())
k.SetCW721ERC721Pointer(ctx, evmAddr5, seiAddr5.String())
k.SetERC1155CW1155Pointer(ctx, seiAddr6.String(), evmAddr6)
k.SetCW1155ERC1155Pointer(ctx, evmAddr7, seiAddr7.String())

q := keeper.Querier{k}

Expand All @@ -94,6 +98,11 @@ func TestQueryPointee(t *testing.T) {
require.Nil(t, err)
require.Equal(t, types.QueryPointeeResponse{Pointee: seiAddr3.String(), Version: uint32(cw721.CurrentVersion), Exists: true}, *res)

// Test for CW1155 Pointee
res, err = q.Pointee(goCtx, &types.QueryPointeeRequest{PointerType: types.PointerType_CW1155, Pointer: evmAddr6.Hex()})
require.Nil(t, err)
require.Equal(t, types.QueryPointeeResponse{Pointee: seiAddr6.String(), Version: uint32(cw1155.CurrentVersion), Exists: true}, *res)

// Test for ERC20 Pointee
res, err = q.Pointee(goCtx, &types.QueryPointeeRequest{PointerType: types.PointerType_ERC20, Pointer: seiAddr4.String()})
require.Nil(t, err)
Expand All @@ -104,6 +113,11 @@ func TestQueryPointee(t *testing.T) {
require.Nil(t, err)
require.Equal(t, types.QueryPointeeResponse{Pointee: evmAddr5.Hex(), Version: uint32(erc721.CurrentVersion), Exists: true}, *res)

// Test for ERC1155 Pointee
res, err = q.Pointee(goCtx, &types.QueryPointeeRequest{PointerType: types.PointerType_ERC1155, Pointer: seiAddr7.String()})
require.Nil(t, err)
require.Equal(t, types.QueryPointeeResponse{Pointee: evmAddr7.Hex(), Version: uint32(erc1155.CurrentVersion), Exists: true}, *res)

// Test for not registered Native Pointee
res, err = q.Pointee(goCtx, &types.QueryPointeeRequest{PointerType: types.PointerType_NATIVE, Pointer: "0x1234567890123456789012345678901234567890"})
require.Nil(t, err)
Expand All @@ -119,6 +133,11 @@ func TestQueryPointee(t *testing.T) {
require.Nil(t, err)
require.Equal(t, types.QueryPointeeResponse{Pointee: "", Version: 0, Exists: false}, *res)

// Test for not registered CW1155 Pointee
res, err = q.Pointee(goCtx, &types.QueryPointeeRequest{PointerType: types.PointerType_CW1155, Pointer: "0x1234567890123456789012345678901234567890"})
require.Nil(t, err)
require.Equal(t, types.QueryPointeeResponse{Pointee: "", Version: 0, Exists: false}, *res)

// Test for not registered ERC20 Pointee
res, err = q.Pointee(goCtx, &types.QueryPointeeRequest{PointerType: types.PointerType_ERC20, Pointer: "sei1notregistered"})
require.Nil(t, err)
Expand All @@ -129,6 +148,11 @@ func TestQueryPointee(t *testing.T) {
require.Nil(t, err)
require.Equal(t, types.QueryPointeeResponse{Pointee: "0x0000000000000000000000000000000000000000", Version: 0, Exists: false}, *res)

// Test for not registered ERC1155 Pointee
res, err = q.Pointee(goCtx, &types.QueryPointeeRequest{PointerType: types.PointerType_ERC1155, Pointer: "sei1notregistered"})
require.Nil(t, err)
require.Equal(t, types.QueryPointeeResponse{Pointee: "0x0000000000000000000000000000000000000000", Version: 0, Exists: false}, *res)

// Test cases for invalid inputs
testCases := []struct {
name string
Expand Down
16 changes: 16 additions & 0 deletions x/evm/keeper/pointer.go
Original file line number Diff line number Diff line change
Expand Up @@ -346,6 +346,14 @@ func (k *Keeper) GetCW721Pointee(ctx sdk.Context, erc721Address common.Address)
return
}

func (k *Keeper) GetCW1155Pointee(ctx sdk.Context, erc1155Address common.Address) (cw1155Address string, version uint16, exists bool) {
addrBz, version, exists := k.GetPointerInfo(ctx, types.PointerReverseRegistryKey(erc1155Address))
if exists {
cw1155Address = string(addrBz)
}
return
}

func (k *Keeper) GetERC20Pointee(ctx sdk.Context, cw20Address string) (erc20Address common.Address, version uint16, exists bool) {
addrBz, version, exists := k.GetPointerInfo(ctx, types.PointerReverseRegistryKey(common.BytesToAddress([]byte(cw20Address))))
if exists {
Expand All @@ -362,6 +370,14 @@ func (k *Keeper) GetERC721Pointee(ctx sdk.Context, cw721Address string) (erc721A
return
}

func (k *Keeper) GetERC1155Pointee(ctx sdk.Context, cw1155Address string) (erc1155Address common.Address, version uint16, exists bool) {
addrBz, version, exists := k.GetPointerInfo(ctx, types.PointerReverseRegistryKey(common.BytesToAddress([]byte(cw1155Address))))
if exists {
erc1155Address = common.BytesToAddress(addrBz)
}
return
}

func (k *Keeper) GetNativePointee(ctx sdk.Context, erc20Address string) (token string, version uint16, exists bool) {
// Ensure the key matches how it was set in SetERC20NativePointer
key := types.PointerReverseRegistryKey(common.HexToAddress(erc20Address))
Expand Down
2 changes: 1 addition & 1 deletion x/evm/keeper/pointer_upgrade.go
Original file line number Diff line number Diff line change
Expand Up @@ -77,7 +77,7 @@ func (k *Keeper) UpsertERCCW1155Pointer(
ctx sdk.Context, evm *vm.EVM, cw1155Addr string, metadata utils.ERCMetadata,
) (contractAddr common.Address, err error) {
return k.UpsertERCPointer(
ctx, evm, "cw721", []interface{}{
ctx, evm, "cw1155", []interface{}{
cw1155Addr, metadata.Name, metadata.Symbol,
}, k.GetERC1155CW1155Pointer, k.SetERC1155CW1155Pointer,
)
Expand Down
2 changes: 1 addition & 1 deletion x/evm/types/gov.go
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,7 @@ func init() {
govtypes.RegisterProposalTypeCodec(&AddCWERC20PointerProposal{}, "evm/AddCWERC20PointerProposal")
govtypes.RegisterProposalTypeCodec(&AddCWERC721PointerProposal{}, "evm/AddCWERC721PointerProposal")
govtypes.RegisterProposalTypeCodec(&AddCWERC1155PointerProposal{}, "evm/AddCWERC1155PointerProposal")
govtypes.RegisterProposalTypeCodec(&AddERCNativePointerProposalV2{}, "evm/AddCWERC721PointerProposalV2")
govtypes.RegisterProposalTypeCodec(&AddERCNativePointerProposalV2{}, "evm/AddERCNativePointerProposalV2")
}

func (p *AddERCNativePointerProposal) GetTitle() string { return p.Title }
Expand Down