2022-04-25 15:32:46 +00:00
|
|
|
package beaconclient
|
2022-04-25 14:41:50 +00:00
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"net/http"
|
|
|
|
|
|
|
|
log "github.com/sirupsen/logrus"
|
|
|
|
"github.com/vulcanize/ipld-ethcl-indexer/pkg/loghelper"
|
|
|
|
)
|
|
|
|
|
|
|
|
// This function will ensure that we can connect to the beacon client.
|
|
|
|
// Keep in mind, the beacon client will allow you to connect to it but it might
|
|
|
|
// Not allow you to make http requests. This is part of its built in logic, and you will have
|
|
|
|
// to follow their provided guidelines. https://lighthouse-book.sigmaprime.io/api-bn.html#security
|
2022-04-26 17:57:01 +00:00
|
|
|
func (bc BeaconClient) CheckBeaconClient() error {
|
2022-04-25 14:41:50 +00:00
|
|
|
log.Debug("Attempting to connect to the beacon client")
|
2022-04-27 18:01:59 +00:00
|
|
|
bcEndpoint := bc.ServerEndpoint + bcHealthEndpoint
|
2022-04-25 14:41:50 +00:00
|
|
|
resp, err := http.Get(bcEndpoint)
|
|
|
|
if err != nil {
|
|
|
|
loghelper.LogError(err).Error("Unable to get bc endpoint: ", bcEndpoint)
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if resp.StatusCode < 200 || resp.StatusCode > 299 {
|
2022-05-12 21:41:23 +00:00
|
|
|
loghelper.LogEndpoint(bcEndpoint).Error("We recieved a non 2xx status code when checking the health of the beacon node.")
|
|
|
|
loghelper.LogEndpoint(bcEndpoint).Error("Health Endpoint Status Code: ", resp.StatusCode)
|
2022-04-25 14:41:50 +00:00
|
|
|
return fmt.Errorf("beacon Node Provided a non 2xx status code, code provided: %d", resp.StatusCode)
|
|
|
|
}
|
|
|
|
|
|
|
|
log.Info("We can successfully reach the beacon client.")
|
|
|
|
return nil
|
|
|
|
|
|
|
|
}
|