2023-01-04 13:22:41 +00:00
|
|
|
package modules
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"path/filepath"
|
|
|
|
|
|
|
|
"go.uber.org/fx"
|
|
|
|
|
2023-01-13 16:49:01 +00:00
|
|
|
"github.com/filecoin-project/lotus/chain/ethhashlookup"
|
2023-01-04 13:22:41 +00:00
|
|
|
"github.com/filecoin-project/lotus/chain/events"
|
|
|
|
"github.com/filecoin-project/lotus/chain/messagepool"
|
|
|
|
"github.com/filecoin-project/lotus/chain/stmgr"
|
|
|
|
"github.com/filecoin-project/lotus/chain/store"
|
|
|
|
"github.com/filecoin-project/lotus/node/config"
|
|
|
|
"github.com/filecoin-project/lotus/node/impl/full"
|
|
|
|
"github.com/filecoin-project/lotus/node/modules/helpers"
|
|
|
|
"github.com/filecoin-project/lotus/node/repo"
|
|
|
|
)
|
|
|
|
|
2023-01-13 16:49:01 +00:00
|
|
|
func EthModuleAPI(cfg config.FevmConfig) func(helpers.MetricsCtx, repo.LockedRepo, fx.Lifecycle, *store.ChainStore, *stmgr.StateManager, EventAPI, *messagepool.MessagePool, full.StateAPI, full.ChainAPI, full.MpoolAPI) (*full.EthModule, error) {
|
2023-01-04 13:22:41 +00:00
|
|
|
return func(mctx helpers.MetricsCtx, r repo.LockedRepo, lc fx.Lifecycle, cs *store.ChainStore, sm *stmgr.StateManager, evapi EventAPI, mp *messagepool.MessagePool, stateapi full.StateAPI, chainapi full.ChainAPI, mpoolapi full.MpoolAPI) (*full.EthModule, error) {
|
2023-01-19 22:44:58 +00:00
|
|
|
sqlitePath, err := r.SqlitePath()
|
2023-01-04 13:22:41 +00:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
2023-01-19 22:44:58 +00:00
|
|
|
transactionHashLookup, err := ethhashlookup.NewTransactionHashLookup(filepath.Join(sqlitePath, "txhash.db"))
|
2023-01-04 13:22:41 +00:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
lc.Append(fx.Hook{
|
|
|
|
OnStop: func(ctx context.Context) error {
|
|
|
|
return transactionHashLookup.Close()
|
|
|
|
},
|
|
|
|
})
|
|
|
|
|
|
|
|
ethTxHashManager := full.EthTxHashManager{
|
|
|
|
StateAPI: stateapi,
|
|
|
|
TransactionHashLookup: transactionHashLookup,
|
|
|
|
}
|
|
|
|
|
|
|
|
const ChainHeadConfidence = 1
|
|
|
|
|
|
|
|
ctx := helpers.LifecycleCtx(mctx, lc)
|
|
|
|
lc.Append(fx.Hook{
|
|
|
|
OnStart: func(context.Context) error {
|
|
|
|
ev, err := events.NewEventsWithConfidence(ctx, &evapi, ChainHeadConfidence)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// Tipset listener
|
|
|
|
_ = ev.Observe(ðTxHashManager)
|
|
|
|
|
|
|
|
ch, err := mp.Updates(ctx)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
go full.WaitForMpoolUpdates(ctx, ch, ðTxHashManager)
|
2023-01-16 07:56:45 +00:00
|
|
|
go full.EthTxHashGC(ctx, cfg.EthTxHashMappingLifetimeDays, ðTxHashManager)
|
2023-01-04 13:22:41 +00:00
|
|
|
|
|
|
|
return nil
|
|
|
|
},
|
|
|
|
})
|
|
|
|
|
2023-01-19 18:30:18 +00:00
|
|
|
return &full.EthModule{
|
|
|
|
Chain: cs,
|
|
|
|
Mpool: mp,
|
|
|
|
StateManager: sm,
|
|
|
|
|
|
|
|
ChainAPI: chainapi,
|
|
|
|
MpoolAPI: mpoolapi,
|
|
|
|
StateAPI: stateapi,
|
|
|
|
|
|
|
|
EthTxHashManager: ðTxHashManager,
|
|
|
|
}, nil
|
2023-01-04 13:22:41 +00:00
|
|
|
}
|
|
|
|
}
|