mirror of
https://gitlab.com/pulsechaincom/erigon-pulse.git
synced 2025-01-05 10:32:19 +00:00
159 lines
7.4 KiB
Go
159 lines
7.4 KiB
Go
package handler
|
|
|
|
import (
|
|
"net/http"
|
|
"sync"
|
|
|
|
"github.com/go-chi/chi/v5"
|
|
"github.com/ledgerwatch/erigon-lib/gointerfaces/sentinel"
|
|
"github.com/ledgerwatch/erigon-lib/kv"
|
|
"github.com/ledgerwatch/erigon/cl/beacon/beaconhttp"
|
|
"github.com/ledgerwatch/erigon/cl/beacon/synced_data"
|
|
"github.com/ledgerwatch/erigon/cl/clparams"
|
|
"github.com/ledgerwatch/erigon/cl/cltypes/solid"
|
|
"github.com/ledgerwatch/erigon/cl/persistence"
|
|
"github.com/ledgerwatch/erigon/cl/persistence/state/historical_states_reader"
|
|
"github.com/ledgerwatch/erigon/cl/phase1/forkchoice"
|
|
"github.com/ledgerwatch/erigon/cl/pool"
|
|
"github.com/ledgerwatch/erigon/turbo/snapshotsync/freezeblocks"
|
|
)
|
|
|
|
type ApiHandler struct {
|
|
o sync.Once
|
|
mux *chi.Mux
|
|
|
|
blockReader freezeblocks.BeaconSnapshotReader
|
|
indiciesDB kv.RoDB
|
|
genesisCfg *clparams.GenesisConfig
|
|
beaconChainCfg *clparams.BeaconChainConfig
|
|
forkchoiceStore forkchoice.ForkChoiceStorage
|
|
operationsPool pool.OperationsPool
|
|
syncedData *synced_data.SyncedDataManager
|
|
stateReader *historical_states_reader.HistoricalStatesReader
|
|
sentinel sentinel.SentinelClient
|
|
|
|
version string // Node's version
|
|
|
|
// pools
|
|
randaoMixesPool sync.Pool
|
|
}
|
|
|
|
func NewApiHandler(genesisConfig *clparams.GenesisConfig, beaconChainConfig *clparams.BeaconChainConfig, source persistence.RawBeaconBlockChain, indiciesDB kv.RoDB, forkchoiceStore forkchoice.ForkChoiceStorage, operationsPool pool.OperationsPool, rcsn freezeblocks.BeaconSnapshotReader, syncedData *synced_data.SyncedDataManager, stateReader *historical_states_reader.HistoricalStatesReader, sentinel sentinel.SentinelClient, version string) *ApiHandler {
|
|
return &ApiHandler{o: sync.Once{}, genesisCfg: genesisConfig, beaconChainCfg: beaconChainConfig, indiciesDB: indiciesDB, forkchoiceStore: forkchoiceStore, operationsPool: operationsPool, blockReader: rcsn, syncedData: syncedData, stateReader: stateReader, randaoMixesPool: sync.Pool{New: func() interface{} {
|
|
return solid.NewHashVector(int(beaconChainConfig.EpochsPerHistoricalVector))
|
|
}}, sentinel: sentinel, version: version}
|
|
}
|
|
|
|
func (a *ApiHandler) Init() {
|
|
a.o.Do(func() {
|
|
a.init()
|
|
})
|
|
}
|
|
func (a *ApiHandler) init() {
|
|
r := chi.NewRouter()
|
|
a.mux = r
|
|
// This is the set of apis for validation + otterscan
|
|
// otterscn specific ones are commented as such
|
|
r.Route("/eth", func(r chi.Router) {
|
|
r.Route("/v1", func(r chi.Router) {
|
|
r.Get("/builder/states/{state_id}/expected_withdrawals", beaconhttp.HandleEndpointFunc(a.GetEth1V1BuilderStatesExpectedWit))
|
|
r.Get("/events", http.NotFound)
|
|
r.Route("/node", func(r chi.Router) {
|
|
r.Get("/health", a.GetEthV1NodeHealth)
|
|
r.Get("/version", a.GetEthV1NodeVersion)
|
|
})
|
|
r.Get("/debug/fork_choice", a.GetEthV1DebugBeaconForkChoice)
|
|
r.Route("/config", func(r chi.Router) {
|
|
r.Get("/spec", beaconhttp.HandleEndpointFunc(a.getSpec))
|
|
r.Get("/deposit_contract", beaconhttp.HandleEndpointFunc(a.getDepositContract))
|
|
r.Get("/fork_schedule", beaconhttp.HandleEndpointFunc(a.getForkSchedule))
|
|
})
|
|
r.Route("/beacon", func(r chi.Router) {
|
|
r.Route("/rewards", func(r chi.Router) {
|
|
r.Post("/sync_committee/{block_id}", beaconhttp.HandleEndpointFunc(a.getSyncCommitteesRewards))
|
|
r.Get("/blocks/{block_id}", beaconhttp.HandleEndpointFunc(a.getBlockRewards))
|
|
r.Post("/attestations/{epoch}", beaconhttp.HandleEndpointFunc(a.getAttestationsRewards))
|
|
})
|
|
r.Route("/headers", func(r chi.Router) {
|
|
r.Get("/", beaconhttp.HandleEndpointFunc(a.getHeaders))
|
|
r.Get("/{block_id}", beaconhttp.HandleEndpointFunc(a.getHeader))
|
|
})
|
|
r.Route("/blocks", func(r chi.Router) {
|
|
r.Post("/", http.NotFound)
|
|
r.Get("/{block_id}", beaconhttp.HandleEndpointFunc(a.getBlock))
|
|
r.Get("/{block_id}/attestations", beaconhttp.HandleEndpointFunc(a.getBlockAttestations))
|
|
r.Get("/{block_id}/root", beaconhttp.HandleEndpointFunc(a.getBlockRoot))
|
|
})
|
|
r.Get("/genesis", beaconhttp.HandleEndpointFunc(a.getGenesis))
|
|
r.Get("/blinded_blocks/{block_id}", beaconhttp.HandleEndpointFunc(a.getBlindedBlock))
|
|
r.Route("/pool", func(r chi.Router) {
|
|
r.Get("/voluntary_exits", beaconhttp.HandleEndpointFunc(a.GetEthV1BeaconPoolVoluntaryExits))
|
|
r.Post("/voluntary_exits", a.PostEthV1BeaconPoolVoluntaryExits)
|
|
r.Get("/attester_slashings", beaconhttp.HandleEndpointFunc(a.GetEthV1BeaconPoolAttesterSlashings))
|
|
r.Post("/attester_slashings", a.PostEthV1BeaconPoolAttesterSlashings)
|
|
r.Get("/proposer_slashings", beaconhttp.HandleEndpointFunc(a.GetEthV1BeaconPoolProposerSlashings))
|
|
r.Post("/proposer_slashings", a.PostEthV1BeaconPoolProposerSlashings)
|
|
r.Get("/bls_to_execution_changes", beaconhttp.HandleEndpointFunc(a.GetEthV1BeaconPoolBLSExecutionChanges))
|
|
r.Post("/bls_to_execution_changes", a.PostEthV1BeaconPoolBlsToExecutionChanges)
|
|
r.Get("/attestations", beaconhttp.HandleEndpointFunc(a.GetEthV1BeaconPoolAttestations))
|
|
r.Post("/attestations", http.NotFound) // TODO
|
|
r.Post("/sync_committees", http.NotFound) // TODO
|
|
})
|
|
r.Get("/node/syncing", http.NotFound)
|
|
r.Route("/states", func(r chi.Router) {
|
|
r.Route("/{state_id}", func(r chi.Router) {
|
|
r.Get("/randao", beaconhttp.HandleEndpointFunc(a.getRandao))
|
|
r.Get("/committees", beaconhttp.HandleEndpointFunc(a.getCommittees))
|
|
r.Get("/sync_committees", beaconhttp.HandleEndpointFunc(a.getSyncCommittees)) // otterscan
|
|
r.Get("/finality_checkpoints", beaconhttp.HandleEndpointFunc(a.getFinalityCheckpoints))
|
|
r.Get("/validators", http.NotFound)
|
|
r.Get("/root", beaconhttp.HandleEndpointFunc(a.getStateRoot))
|
|
r.Get("/fork", beaconhttp.HandleEndpointFunc(a.getStateFork))
|
|
r.Get("/validators", beaconhttp.HandleEndpointFunc(a.getAllValidators))
|
|
r.Get("/validator_balances", beaconhttp.HandleEndpointFunc(a.getAllValidatorsBalances))
|
|
r.Get("/validators/{validator_id}", beaconhttp.HandleEndpointFunc(a.getSingleValidator))
|
|
})
|
|
})
|
|
})
|
|
r.Route("/validator", func(r chi.Router) {
|
|
r.Route("/duties", func(r chi.Router) {
|
|
r.Post("/attester/{epoch}", beaconhttp.HandleEndpointFunc(a.getAttesterDuties))
|
|
r.Get("/proposer/{epoch}", beaconhttp.HandleEndpointFunc(a.getDutiesProposer))
|
|
r.Post("/sync/{epoch}", beaconhttp.HandleEndpointFunc(a.getSyncDuties))
|
|
})
|
|
r.Get("/blinded_blocks/{slot}", http.NotFound)
|
|
r.Get("/attestation_data", http.NotFound)
|
|
r.Get("/aggregate_attestation", http.NotFound)
|
|
r.Post("/aggregate_and_proofs", a.PostEthV1ValidatorAggregatesAndProof)
|
|
r.Post("/beacon_committee_subscriptions", http.NotFound)
|
|
r.Post("/sync_committee_subscriptions", http.NotFound)
|
|
r.Get("/sync_committee_contribution", http.NotFound)
|
|
r.Post("/contribution_and_proofs", http.NotFound)
|
|
r.Post("/prepare_beacon_proposer", http.NotFound)
|
|
r.Post("/liveness/{epoch}", beaconhttp.HandleEndpointFunc(a.liveness))
|
|
})
|
|
})
|
|
r.Route("/v2", func(r chi.Router) {
|
|
r.Route("/debug", func(r chi.Router) {
|
|
r.Route("/beacon", func(r chi.Router) {
|
|
r.Get("/states/{state_id}", beaconhttp.HandleEndpointFunc(a.getFullState))
|
|
r.Get("/heads", beaconhttp.HandleEndpointFunc(a.GetEthV2DebugBeaconHeads))
|
|
})
|
|
})
|
|
r.Route("/beacon", func(r chi.Router) {
|
|
r.Get("/blocks/{block_id}", beaconhttp.HandleEndpointFunc(a.getBlock))
|
|
})
|
|
r.Route("/validator", func(r chi.Router) {
|
|
r.Post("/blocks/{slot}", http.NotFound)
|
|
})
|
|
})
|
|
})
|
|
}
|
|
|
|
func (a *ApiHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
|
|
a.o.Do(func() {
|
|
a.init()
|
|
})
|
|
a.mux.ServeHTTP(w, r)
|
|
}
|