mirror of
https://github.com/grassrootseconomics/eth-tracker.git
synced 2025-04-20 07:21:02 +02:00
fix: missing pool token registry bootstrapper
This commit is contained in:
parent
9b31b8c3e5
commit
ec5dfc784a
26
internal/cache/cache.go
vendored
26
internal/cache/cache.go
vendored
@ -8,6 +8,7 @@ import (
|
|||||||
"github.com/grassrootseconomics/celo-tracker/internal/chain"
|
"github.com/grassrootseconomics/celo-tracker/internal/chain"
|
||||||
"github.com/grassrootseconomics/celoutils/v2"
|
"github.com/grassrootseconomics/celoutils/v2"
|
||||||
"github.com/grassrootseconomics/w3-celo"
|
"github.com/grassrootseconomics/w3-celo"
|
||||||
|
"github.com/grassrootseconomics/w3-celo/module/eth"
|
||||||
)
|
)
|
||||||
|
|
||||||
type (
|
type (
|
||||||
@ -26,6 +27,10 @@ type (
|
|||||||
}
|
}
|
||||||
)
|
)
|
||||||
|
|
||||||
|
var (
|
||||||
|
tokenRegistryFunc = w3.MustNewFunc("tokenRegistry()", "address")
|
||||||
|
)
|
||||||
|
|
||||||
func New(o CacheOpts) (Cache, error) {
|
func New(o CacheOpts) (Cache, error) {
|
||||||
var (
|
var (
|
||||||
cache Cache
|
cache Cache
|
||||||
@ -68,9 +73,28 @@ func New(o CacheOpts) (Cache, error) {
|
|||||||
|
|
||||||
for _, pool := range pools {
|
for _, pool := range pools {
|
||||||
cache.Add(pool.Hex())
|
cache.Add(pool.Hex())
|
||||||
|
|
||||||
|
var (
|
||||||
|
poolTokenRegistry common.Address
|
||||||
|
)
|
||||||
|
err := o.Chain.Provider.Client.CallCtx(
|
||||||
|
ctx,
|
||||||
|
eth.CallFunc(pool, tokenRegistryFunc).Returns(&poolTokenRegistry),
|
||||||
|
)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
poolTokens, err := o.Chain.GetAllTokensFromTokenIndex(ctx, poolTokenRegistry)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, token := range poolTokens {
|
||||||
|
cache.Add(token.Hex())
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
o.Logg.Debug("cache bootstrap complete", "cached_addresses", cache.Size())
|
o.Logg.Debug("cache bootstrap complete", "cached_addresses", cache.Size())
|
||||||
|
|
||||||
|
@ -26,14 +26,17 @@ func (p *Processor) processBlock(ctx context.Context, block types.Block) error {
|
|||||||
for i, receipt := range receiptsResp {
|
for i, receipt := range receiptsResp {
|
||||||
if receipt.Status > 0 {
|
if receipt.Status > 0 {
|
||||||
for _, log := range receipt.Logs {
|
for _, log := range receipt.Logs {
|
||||||
if err := p.handleLogs(ctx, log); err != nil {
|
if p.cache.Exists(log.Address.Hex()) {
|
||||||
p.logg.Error("hanlder error", "error", err)
|
if err := p.handleLogs(ctx, log); err != nil {
|
||||||
|
p.logg.Error("hanlder error", "error", err)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
revertReason, _ := p.chain.GetRevertReason(ctx, receipt.TxHash, receipt.BlockNumber)
|
if p.cache.Exists(txs[i].To().Hex()) {
|
||||||
p.logg.Debug("tx reverted", "hash", receipt.TxHash, "revert_reason", revertReason, "input_data", common.Bytes2Hex(txs[i].Data()))
|
revertReason, _ := p.chain.GetRevertReason(ctx, receipt.TxHash, receipt.BlockNumber)
|
||||||
|
p.logg.Debug("tx reverted", "hash", receipt.TxHash, "revert_reason", revertReason, "input_data", common.Bytes2Hex(txs[i].Data()))
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user