2022-04-27 18:01:59 +00:00
|
|
|
// This file will call all the functions to start and stop capturing the head of the beacon chain.
|
|
|
|
|
2022-04-26 17:57:01 +00:00
|
|
|
package beaconclient
|
|
|
|
|
|
|
|
import (
|
|
|
|
"time"
|
|
|
|
|
|
|
|
log "github.com/sirupsen/logrus"
|
2022-05-04 21:25:36 +00:00
|
|
|
"github.com/vulcanize/ipld-ethcl-indexer/pkg/database/sql"
|
2022-04-26 17:57:01 +00:00
|
|
|
"github.com/vulcanize/ipld-ethcl-indexer/pkg/loghelper"
|
|
|
|
)
|
|
|
|
|
|
|
|
// This function will perform all the heavy lifting for tracking the head of the chain.
|
2022-05-04 21:25:36 +00:00
|
|
|
func (bc *BeaconClient) CaptureHead(db sql.Database) {
|
2022-04-26 17:57:01 +00:00
|
|
|
log.Info("We are tracking the head of the chain.")
|
2022-04-28 18:50:29 +00:00
|
|
|
//bc.tempHelper()
|
2022-05-04 21:25:36 +00:00
|
|
|
go bc.handleHead(db)
|
|
|
|
//go bc.handleFinalizedCheckpoint()
|
2022-04-28 18:50:29 +00:00
|
|
|
go bc.handleReorgs()
|
|
|
|
bc.captureEventTopic()
|
2022-04-27 18:01:59 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// A temporary helper function to see the output of beacon block and states.
|
2022-05-04 13:34:23 +00:00
|
|
|
//func (bc *BeaconClient) tempHelper() {
|
|
|
|
// slot := "3200"
|
|
|
|
// blockEndpoint := bc.ServerEndpoint + bcBlockQueryEndpoint + slot
|
|
|
|
// stateEndpoint := bc.ServerEndpoint + bcStateQueryEndpoint + slot
|
|
|
|
// // Query
|
|
|
|
// log.Info("Get")
|
|
|
|
// blockSsz, _ := querySsz(blockEndpoint, slot)
|
|
|
|
// stateSsz, _ := querySsz(stateEndpoint, slot)
|
|
|
|
// // Transform
|
|
|
|
// log.Info("Tranform")
|
|
|
|
// stateObj := new(spectests.BeaconState)
|
|
|
|
// err := stateObj.UnmarshalSSZ(stateSsz)
|
|
|
|
// if err != nil {
|
|
|
|
// loghelper.LogSlotError(slot, err).Error("Unable to unmarshal the SSZ response from the Beacon Node Successfully!")
|
|
|
|
// }
|
|
|
|
//
|
|
|
|
// blockObj := new(spectests.SignedBeaconBlock)
|
|
|
|
// err = blockObj.UnmarshalSSZ(blockSsz)
|
|
|
|
// if err != nil {
|
|
|
|
// loghelper.LogSlotError(slot, err).Error("Unable to unmarshal the SSZ response from the Beacon Node Successfully!")
|
|
|
|
// }
|
|
|
|
//
|
|
|
|
// // Check
|
|
|
|
// log.Info("Check")
|
|
|
|
// log.Info("State Slot: ", stateObj.Slot)
|
|
|
|
// log.Info("Block Slot: ", blockObj.Block.Slot)
|
|
|
|
//}
|
|
|
|
//
|
2022-04-26 17:57:01 +00:00
|
|
|
// Stop the head tracking service.
|
|
|
|
func (bc *BeaconClient) StopHeadTracking() error {
|
|
|
|
log.Info("We are going to stop tracking the head of chain because of the shutdown signal.")
|
|
|
|
chHead := make(chan bool)
|
|
|
|
chReorg := make(chan bool)
|
2022-04-29 22:26:52 +00:00
|
|
|
//chFinal := make(chan bool)
|
2022-04-26 17:57:01 +00:00
|
|
|
|
|
|
|
go bc.HeadTracking.finishProcessingChannel(chHead)
|
|
|
|
go bc.ReOrgTracking.finishProcessingChannel(chReorg)
|
2022-04-29 22:26:52 +00:00
|
|
|
//go bc.FinalizationTracking.finishProcessingChannel(chFinal)
|
2022-04-26 17:57:01 +00:00
|
|
|
|
|
|
|
<-chHead
|
2022-04-29 22:26:52 +00:00
|
|
|
//<-chFinal
|
2022-04-26 17:57:01 +00:00
|
|
|
<-chReorg
|
|
|
|
log.Info("Successfully stopped the head tracking service.")
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2022-04-27 14:28:42 +00:00
|
|
|
// This function closes the SSE subscription, but waits until the MessagesCh is empty
|
2022-04-26 17:57:01 +00:00
|
|
|
func (se *SseEvents[ProcessedEvents]) finishProcessingChannel(finish chan<- bool) {
|
2022-04-27 18:01:59 +00:00
|
|
|
loghelper.LogEndpoint(se.Endpoint).Info("Received a close event.")
|
2022-04-26 17:57:01 +00:00
|
|
|
se.SseClient.Unsubscribe(se.MessagesCh)
|
2022-04-28 18:50:29 +00:00
|
|
|
for len(se.MessagesCh) != 0 || len(se.ProcessCh) != 0 {
|
2022-04-26 17:57:01 +00:00
|
|
|
time.Sleep(time.Duration(shutdownWaitInterval) * time.Millisecond)
|
|
|
|
}
|
2022-04-27 18:01:59 +00:00
|
|
|
loghelper.LogEndpoint(se.Endpoint).Info("Done processing all messages, ready for shutdown")
|
2022-04-26 17:57:01 +00:00
|
|
|
finish <- true
|
|
|
|
}
|