fix: missing pool token registry bootstrapper

This commit is contained in:
Mohamed Sohail 2024-04-18 13:20:04 +08:00
parent 9b31b8c3e5
commit ec5dfc784a
Signed by: kamikazechaser
GPG Key ID: 7DD45520C01CD85D
2 changed files with 33 additions and 6 deletions

View File

@ -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())

View File

@ -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()))
}
}
}