mirror of
https://github.com/grassrootseconomics/eth-tracker.git
synced 2025-04-18 06:41:01 +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/celoutils/v2"
|
||||
"github.com/grassrootseconomics/w3-celo"
|
||||
"github.com/grassrootseconomics/w3-celo/module/eth"
|
||||
)
|
||||
|
||||
type (
|
||||
@ -26,6 +27,10 @@ type (
|
||||
}
|
||||
)
|
||||
|
||||
var (
|
||||
tokenRegistryFunc = w3.MustNewFunc("tokenRegistry()", "address")
|
||||
)
|
||||
|
||||
func New(o CacheOpts) (Cache, error) {
|
||||
var (
|
||||
cache Cache
|
||||
@ -68,9 +73,28 @@ func New(o CacheOpts) (Cache, error) {
|
||||
|
||||
for _, pool := range pools {
|
||||
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())
|
||||
|
||||
|
@ -26,14 +26,17 @@ func (p *Processor) processBlock(ctx context.Context, block types.Block) error {
|
||||
for i, receipt := range receiptsResp {
|
||||
if receipt.Status > 0 {
|
||||
for _, log := range receipt.Logs {
|
||||
if err := p.handleLogs(ctx, log); err != nil {
|
||||
p.logg.Error("hanlder error", "error", err)
|
||||
if p.cache.Exists(log.Address.Hex()) {
|
||||
if err := p.handleLogs(ctx, log); err != nil {
|
||||
p.logg.Error("hanlder error", "error", err)
|
||||
}
|
||||
}
|
||||
}
|
||||
} else {
|
||||
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()))
|
||||
|
||||
if p.cache.Exists(txs[i].To().Hex()) {
|
||||
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