mirror of
https://github.com/status-im/status-go.git
synced 2025-01-27 23:18:40 +00:00
fix: request token balance for overridden tokens
Fix balance for tokens overrides are not requested in case of fall back when etherscan bulk fetch not working. Updates status-desktop: #9091
This commit is contained in:
parent
5b642d3bed
commit
8934426cbd
@ -44,6 +44,7 @@ func (t *Token) IsNative() bool {
|
|||||||
return t.Address == nativeChainAddress
|
return t.Address == nativeChainAddress
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Manager is used for accessing token store. It changes the token store based on overridden tokens
|
||||||
type Manager struct {
|
type Manager struct {
|
||||||
db *sql.DB
|
db *sql.DB
|
||||||
RPCClient *rpc.Client
|
RPCClient *rpc.Client
|
||||||
@ -56,27 +57,41 @@ func NewTokenManager(
|
|||||||
networkManager *network.Manager,
|
networkManager *network.Manager,
|
||||||
) *Manager {
|
) *Manager {
|
||||||
tokenManager := &Manager{db, RPCClient, networkManager}
|
tokenManager := &Manager{db, RPCClient, networkManager}
|
||||||
// Check the networks' custom tokens to see if we must update the tokenStore
|
|
||||||
networks := networkManager.GetConfiguredNetworks()
|
overrideTokensInPlace(networkManager.GetConfiguredNetworks(), tokenStore)
|
||||||
|
|
||||||
|
return tokenManager
|
||||||
|
}
|
||||||
|
|
||||||
|
// overrideTokensInPlace overrides tokens in the store with the ones from the networks
|
||||||
|
// BEWARE: overridden tokens will have their original address removed and replaced by the one in networks
|
||||||
|
func overrideTokensInPlace(networks []params.Network, store map[uint64]map[common.Address]*Token) {
|
||||||
for _, network := range networks {
|
for _, network := range networks {
|
||||||
if len(network.TokenOverrides) == 0 {
|
if len(network.TokenOverrides) == 0 {
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Map from original address to overridden address
|
||||||
|
overriddenMap := make(map[common.Address]common.Address, len(network.TokenOverrides))
|
||||||
|
tokensMap, ok := store[network.ChainID]
|
||||||
|
if !ok {
|
||||||
|
continue
|
||||||
|
}
|
||||||
for _, overrideToken := range network.TokenOverrides {
|
for _, overrideToken := range network.TokenOverrides {
|
||||||
tokensMap, ok := tokenStore[network.ChainID]
|
|
||||||
if !ok {
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
for _, token := range tokensMap {
|
for _, token := range tokensMap {
|
||||||
if token.Symbol == overrideToken.Symbol {
|
if token.Symbol == overrideToken.Symbol {
|
||||||
token.Address = overrideToken.Address
|
overriddenMap[token.Address] = overrideToken.Address
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
for originalAddress, newAddress := range overriddenMap {
|
||||||
|
newToken := *tokensMap[originalAddress]
|
||||||
|
tokensMap[newAddress] = &newToken
|
||||||
|
newToken.Address = newAddress
|
||||||
|
|
||||||
return tokenManager
|
delete(tokensMap, originalAddress)
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (tm *Manager) inStore(address common.Address, chainID uint64) bool {
|
func (tm *Manager) inStore(address common.Address, chainID uint64) bool {
|
||||||
|
@ -1,8 +1,6 @@
|
|||||||
package token
|
package token
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"io/ioutil"
|
|
||||||
"os"
|
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/stretchr/testify/require"
|
"github.com/stretchr/testify/require"
|
||||||
@ -10,17 +8,14 @@ import (
|
|||||||
"github.com/ethereum/go-ethereum/common"
|
"github.com/ethereum/go-ethereum/common"
|
||||||
|
|
||||||
"github.com/status-im/status-go/appdatabase"
|
"github.com/status-im/status-go/appdatabase"
|
||||||
"github.com/status-im/status-go/sqlite"
|
"github.com/status-im/status-go/params"
|
||||||
)
|
)
|
||||||
|
|
||||||
func setupTestTokenDB(t *testing.T) (*Manager, func()) {
|
func setupTestTokenDB(t *testing.T) (*Manager, func()) {
|
||||||
tmpfile, err := ioutil.TempFile("", "wallet-token-tests-")
|
db, err := appdatabase.InitializeDB(":memory:", "wallet-token-tests", 1)
|
||||||
require.NoError(t, err)
|
|
||||||
db, err := appdatabase.InitializeDB(tmpfile.Name(), "wallet-token-tests", sqlite.ReducedKDFIterationsNumber)
|
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
return &Manager{db, nil, nil}, func() {
|
return &Manager{db, nil, nil}, func() {
|
||||||
require.NoError(t, db.Close())
|
require.NoError(t, db.Close())
|
||||||
require.NoError(t, os.Remove(tmpfile.Name()))
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -56,3 +51,58 @@ func TestCustoms(t *testing.T) {
|
|||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
require.Equal(t, 0, len(rst))
|
require.Equal(t, 0, len(rst))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestTokenOverride(t *testing.T) {
|
||||||
|
networks := []params.Network{
|
||||||
|
{
|
||||||
|
ChainID: 1,
|
||||||
|
ChainName: "TestChain1",
|
||||||
|
TokenOverrides: []params.TokenOverride{
|
||||||
|
{
|
||||||
|
Symbol: "SNT",
|
||||||
|
Address: common.Address{11},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}, {
|
||||||
|
ChainID: 2,
|
||||||
|
ChainName: "TestChain2",
|
||||||
|
TokenOverrides: []params.TokenOverride{
|
||||||
|
{
|
||||||
|
Symbol: "STT",
|
||||||
|
Address: common.Address{33},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
testTokenStore := map[uint64]map[common.Address]*Token{
|
||||||
|
1: {
|
||||||
|
common.Address{1}: {
|
||||||
|
Address: common.Address{1},
|
||||||
|
Symbol: "SNT",
|
||||||
|
},
|
||||||
|
common.Address{2}: {
|
||||||
|
Address: common.Address{2},
|
||||||
|
Symbol: "TNT",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
2: {
|
||||||
|
common.Address{3}: {
|
||||||
|
Address: common.Address{3},
|
||||||
|
Symbol: "STT",
|
||||||
|
},
|
||||||
|
common.Address{4}: {
|
||||||
|
Address: common.Address{4},
|
||||||
|
Symbol: "TTT",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
overrideTokensInPlace(networks, testTokenStore)
|
||||||
|
_, found := testTokenStore[1][common.Address{1}]
|
||||||
|
require.False(t, found)
|
||||||
|
require.Equal(t, common.Address{11}, testTokenStore[1][common.Address{11}].Address)
|
||||||
|
require.Equal(t, common.Address{2}, testTokenStore[1][common.Address{2}].Address)
|
||||||
|
_, found = testTokenStore[2][common.Address{3}]
|
||||||
|
require.False(t, found)
|
||||||
|
require.Equal(t, common.Address{33}, testTokenStore[2][common.Address{33}].Address)
|
||||||
|
require.Equal(t, common.Address{4}, testTokenStore[2][common.Address{4}].Address)
|
||||||
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user