From d59dc53744bf6b2522c33fdeb1ea772eaa17668f Mon Sep 17 00:00:00 2001 From: Vincent Geddes Date: Tue, 22 Jun 2021 16:55:38 +0200 Subject: [PATCH 1/2] Key/values for Offchain RPC should not be SCALE-encoded --- rpc/offchain/get_local_storage.go | 19 ++----------------- 1 file changed, 2 insertions(+), 17 deletions(-) diff --git a/rpc/offchain/get_local_storage.go b/rpc/offchain/get_local_storage.go index ff23cb7d6..6b1461f5a 100644 --- a/rpc/offchain/get_local_storage.go +++ b/rpc/offchain/get_local_storage.go @@ -20,12 +20,7 @@ const ( func (c *Offchain) LocalStorageGet(kind StorageKind, key []byte) (*types.StorageDataRaw, error) { var res string - kb, err := types.EncodeToHexString(key) - if err != nil { - return nil, fmt.Errorf("failed to encode key: %w", err) - } - - err = c.client.Call(&res, "offchain_localStorageGet", kind, kb) + err := c.client.Call(&res, "offchain_localStorageGet", kind, fmt.Sprintf("%#x", key)) if err != nil { return nil, err } @@ -47,17 +42,7 @@ func (c *Offchain) LocalStorageGet(kind StorageKind, key []byte) (*types.Storage func (c *Offchain) LocalStorageSet(kind StorageKind, key []byte, value []byte) error { var res string - kb, err := types.EncodeToHexString(key) - if err != nil { - return fmt.Errorf("failed to encode key: %w", err) - } - - vb, err := types.EncodeToHexString(value) - if err != nil { - return fmt.Errorf("failed to encode value: %w", err) - } - - err = c.client.Call(&res, "offchain_localStorageSet", kind, kb, vb) + err := c.client.Call(&res, "offchain_localStorageSet", kind, fmt.Sprintf("%#x", key), fmt.Sprintf("%#x", value)) if err != nil { return err } From 3fe6e43e83bea685672df0167de2c608d9e5c353 Mon Sep 17 00:00:00 2001 From: Vincent Geddes Date: Tue, 22 Jun 2021 17:07:36 +0200 Subject: [PATCH 2/2] Update tests --- rpc/offchain/get_local_storage_test.go | 10 ++++------ 1 file changed, 4 insertions(+), 6 deletions(-) diff --git a/rpc/offchain/get_local_storage_test.go b/rpc/offchain/get_local_storage_test.go index 894558cfe..f9d03017e 100644 --- a/rpc/offchain/get_local_storage_test.go +++ b/rpc/offchain/get_local_storage_test.go @@ -4,7 +4,6 @@ import ( "crypto/rand" "testing" - "github.com/centrifuge/go-substrate-rpc-client/v3/types" "github.com/stretchr/testify/assert" ) @@ -14,18 +13,17 @@ func TestOffchain_LocalStorageGetSet(t *testing.T) { assert.NoError(t, err) assert.Equal(t, 20, n) + value := []byte{0, 1, 2} + data, err := offchain.LocalStorageGet(Persistent, key) assert.NoError(t, err) assert.Empty(t, data) - err = offchain.LocalStorageSet(Persistent, key, key) + err = offchain.LocalStorageSet(Persistent, key, value) assert.NoError(t, err) data, err = offchain.LocalStorageGet(Persistent, key) assert.NoError(t, err) - got := make([]byte, 0, 20) - err = types.DecodeFromHexString(data.Hex(), &got) - assert.NoError(t, err) - assert.Equal(t, key, got) + assert.Equal(t, value, []byte(*data)) }