Skip to content

Commit

Permalink
Merge pull request #1077 from gobitfly/staging
Browse files Browse the repository at this point in the history
merge staging->main
  • Loading branch information
guybrush authored Nov 4, 2024
2 parents 447f4f3 + a7ed988 commit d11424c
Show file tree
Hide file tree
Showing 67 changed files with 2,017 additions and 1,352 deletions.
1 change: 0 additions & 1 deletion .github/workflows/backend-converted-types-check.yml
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,6 @@ jobs:
newHash=$(find ../frontend/types/api -type f -print0 | sort -z | xargs -0 sha1sum | sha256sum | head -c 64)
if [ "$currHash" != "$newHash" ]; then
echo "frontend-types have changed, please commit the changes"
git diff --stat
exit 1
fi
51 changes: 36 additions & 15 deletions backend/cmd/evm_node_indexer/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@ import (
"fmt"
"io"
"net/http"
"os"
"regexp"
"strings"
"sync/atomic"
Expand All @@ -24,6 +25,7 @@ import (
"github.com/gobitfly/beaconchain/pkg/commons/db"
"github.com/gobitfly/beaconchain/pkg/commons/hexutil"
"github.com/gobitfly/beaconchain/pkg/commons/log"
"github.com/gobitfly/beaconchain/pkg/commons/metrics"
"github.com/gobitfly/beaconchain/pkg/commons/types"
"github.com/gobitfly/beaconchain/pkg/commons/utils"
"github.com/gobitfly/beaconchain/pkg/commons/version"
Expand Down Expand Up @@ -103,22 +105,32 @@ func init() {

// main
func Run() {
fs := flag.NewFlagSet("fs", flag.ExitOnError)

// read / set parameter
configPath := flag.String("config", "config/default.config.yml", "Path to the config file")
startBlockNumber := flag.Int64("start-block-number", -1, "trigger a REEXPORT, only working in combination with end-block-number, defined block is included, will be the first action done and will quite afterwards, ignore every other action")
endBlockNumber := flag.Int64("end-block-number", -1, "trigger a REEXPORT, only working in combination with start-block-number, defined block is included, will be the first action done and will quite afterwards, ignore every other action")
reorgDepth = flag.Int64("reorg.depth", 32, fmt.Sprintf("lookback to check and handle chain reorgs (MAX %s), you should NEVER reduce this after the first start, otherwise there will be unchecked areas", _formatInt64(MAX_REORG_DEPTH)))
concurrency := flag.Int64("concurrency", 8, "maximum threads used (running on maximum whenever possible)")
nodeRequestsAtOnce := flag.Int64("node-requests-at-once", 16, fmt.Sprintf("bulk size per node = bt = db request (MAX %s)", _formatInt64(MAX_NODE_REQUESTS_AT_ONCE)))
skipHoleCheck := flag.Bool("skip-hole-check", false, "skips the initial check for holes, doesn't go very well with only-hole-check")
onlyHoleCheck := flag.Bool("only-hole-check", false, "just check for holes and quit, can be used for a reexport running simulation to a normal setup, just remove entries in postgres and start with this flag, doesn't go very well with skip-hole-check")
noNewBlocks := flag.Bool("ignore-new-blocks", false, "there are no new blocks, at all")
noNewBlocksThresholdSeconds := flag.Int("fatal-if-no-new-block-for-x-seconds", 600, "will fatal if there is no new block for x seconds (MIN 30), will start throwing errors at 2/3 of the time, will start throwing warnings at 1/3 of the time, doesn't go very well with ignore-new-blocks")
discordWebhookBlockThreshold := flag.Int64("discord-block-threshold", 100000, "every x blocks an update is send to Discord")
discordWebhookReportUrl := flag.String("discord-url", "", "report progress to discord url")
discordWebhookUser := flag.String("discord-user", "", "report progress to discord user")
discordWebhookAddTextFatal := flag.String("discord-fatal-text", "", "this text will be added to the discord message in the case of an fatal")
flag.Parse()
configPath := fs.String("config", "config/default.config.yml", "Path to the config file")
versionFlag := fs.Bool("version", false, "print version and exit")
startBlockNumber := fs.Int64("start-block-number", -1, "trigger a REEXPORT, only working in combination with end-block-number, defined block is included, will be the first action done and will quite afterwards, ignore every other action")
endBlockNumber := fs.Int64("end-block-number", -1, "trigger a REEXPORT, only working in combination with start-block-number, defined block is included, will be the first action done and will quite afterwards, ignore every other action")
reorgDepth = fs.Int64("reorg.depth", 32, fmt.Sprintf("lookback to check and handle chain reorgs (MAX %s), you should NEVER reduce this after the first start, otherwise there will be unchecked areas", _formatInt64(MAX_REORG_DEPTH)))
concurrency := fs.Int64("concurrency", 8, "maximum threads used (running on maximum whenever possible)")
nodeRequestsAtOnce := fs.Int64("node-requests-at-once", 16, fmt.Sprintf("bulk size per node = bt = db request (MAX %s)", _formatInt64(MAX_NODE_REQUESTS_AT_ONCE)))
skipHoleCheck := fs.Bool("skip-hole-check", false, "skips the initial check for holes, doesn't go very well with only-hole-check")
onlyHoleCheck := fs.Bool("only-hole-check", false, "just check for holes and quit, can be used for a reexport running simulation to a normal setup, just remove entries in postgres and start with this flag, doesn't go very well with skip-hole-check")
noNewBlocks := fs.Bool("ignore-new-blocks", false, "there are no new blocks, at all")
noNewBlocksThresholdSeconds := fs.Int("fatal-if-no-new-block-for-x-seconds", 600, "will fatal if there is no new block for x seconds (MIN 30), will start throwing errors at 2/3 of the time, will start throwing warnings at 1/3 of the time, doesn't go very well with ignore-new-blocks")
discordWebhookBlockThreshold := fs.Int64("discord-block-threshold", 100000, "every x blocks an update is send to Discord")
discordWebhookReportUrl := fs.String("discord-url", "", "report progress to discord url")
discordWebhookUser := fs.String("discord-user", "", "report progress to discord user")
discordWebhookAddTextFatal := fs.String("discord-fatal-text", "", "this text will be added to the discord message in the case of an fatal")
err := fs.Parse(os.Args[2:])
if err != nil {
log.Fatal(err, "error parsing flags", 0)
}
if *versionFlag {
log.Info(version.Version)
return
}

// tell the user about all parameter
{
Expand Down Expand Up @@ -161,6 +173,15 @@ func Run() {
} else {
eth1RpcEndpoint = utils.Config.Eth1GethEndpoint
}

if utils.Config.Metrics.Enabled {
go func() {
log.Infof("serving metrics on %v", utils.Config.Metrics.Address)
if err := metrics.Serve(utils.Config.Metrics.Address, utils.Config.Metrics.Pprof, utils.Config.Metrics.PprofExtra); err != nil {
log.Fatal(err, "error serving metrics", 0)
}
}()
}
}

// check parameters
Expand Down
24 changes: 12 additions & 12 deletions backend/cmd/misc/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -565,19 +565,19 @@ func collectNotifications(startEpoch uint64) error {
spew.Dump(notifications[0])
}

emails, err := notification.RenderEmailsForUserEvents(0, notifications)
if err != nil {
return err
}
// emails, err := notification.RenderEmailsForUserEvents(0, notifications)
// if err != nil {
// return err
// }

for _, email := range emails {
// if email.Address == "" {
log.Infof("to: %v", email.Address)
log.Infof("subject: %v", email.Subject)
log.Infof("body: %v", email.Email.Body)
log.Info("-----")
// }
}
// for _, email := range emails {
// // if email.Address == "" {
// log.Infof("to: %v", email.Address)
// log.Infof("subject: %v", email.Subject)
// log.Infof("body: %v", email.Email.Body)
// log.Info("-----")
// // }
// }

// pushMessages, err := notification.RenderPushMessagesForUserEvents(0, notifications)
// if err != nil {
Expand Down
4 changes: 2 additions & 2 deletions backend/pkg/api/data_access/archiver.go
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ func (d *DataAccessService) GetValidatorDashboardsCountInfo(ctx context.Context)
}

var dbReturn []DashboardInfo
err := d.readerDb.Select(&dbReturn, `
err := d.readerDb.SelectContext(ctx, &dbReturn, `
WITH dashboards_groups AS
(SELECT
dashboard_id,
Expand Down Expand Up @@ -91,7 +91,7 @@ func (d *DataAccessService) UpdateValidatorDashboardsArchiving(ctx context.Conte

query, args, err := ds.Prepared(true).ToSQL()
if err != nil {
return fmt.Errorf("error preparing query: %v", err)
return fmt.Errorf("error preparing query: %w", err)
}

_, err = d.writerDb.ExecContext(ctx, query, args...)
Expand Down
18 changes: 9 additions & 9 deletions backend/pkg/api/data_access/block.go
Original file line number Diff line number Diff line change
Expand Up @@ -74,71 +74,71 @@ func (d *DataAccessService) GetBlockBlobs(ctx context.Context, chainId, block ui
}

func (d *DataAccessService) GetSlot(ctx context.Context, chainId, slot uint64) (*t.BlockSummary, error) {
block, err := d.GetBlockHeightAt(slot)
block, err := d.GetBlockHeightAt(ctx, slot)
if err != nil {
return nil, err
}
return d.GetBlock(ctx, chainId, block)
}

func (d *DataAccessService) GetSlotOverview(ctx context.Context, chainId, slot uint64) (*t.BlockOverview, error) {
block, err := d.GetBlockHeightAt(slot)
block, err := d.GetBlockHeightAt(ctx, slot)
if err != nil {
return nil, err
}
return d.GetBlockOverview(ctx, chainId, block)
}

func (d *DataAccessService) GetSlotTransactions(ctx context.Context, chainId, slot uint64) ([]t.BlockTransactionTableRow, error) {
block, err := d.GetBlockHeightAt(slot)
block, err := d.GetBlockHeightAt(ctx, slot)
if err != nil {
return nil, err
}
return d.GetBlockTransactions(ctx, chainId, block)
}

func (d *DataAccessService) GetSlotVotes(ctx context.Context, chainId, slot uint64) ([]t.BlockVoteTableRow, error) {
block, err := d.GetBlockHeightAt(slot)
block, err := d.GetBlockHeightAt(ctx, slot)
if err != nil {
return nil, err
}
return d.GetBlockVotes(ctx, chainId, block)
}

func (d *DataAccessService) GetSlotAttestations(ctx context.Context, chainId, slot uint64) ([]t.BlockAttestationTableRow, error) {
block, err := d.GetBlockHeightAt(slot)
block, err := d.GetBlockHeightAt(ctx, slot)
if err != nil {
return nil, err
}
return d.GetBlockAttestations(ctx, chainId, block)
}

func (d *DataAccessService) GetSlotWithdrawals(ctx context.Context, chainId, slot uint64) ([]t.BlockWithdrawalTableRow, error) {
block, err := d.GetBlockHeightAt(slot)
block, err := d.GetBlockHeightAt(ctx, slot)
if err != nil {
return nil, err
}
return d.GetBlockWithdrawals(ctx, chainId, block)
}

func (d *DataAccessService) GetSlotBlsChanges(ctx context.Context, chainId, slot uint64) ([]t.BlockBlsChangeTableRow, error) {
block, err := d.GetBlockHeightAt(slot)
block, err := d.GetBlockHeightAt(ctx, slot)
if err != nil {
return nil, err
}
return d.GetBlockBlsChanges(ctx, chainId, block)
}

func (d *DataAccessService) GetSlotVoluntaryExits(ctx context.Context, chainId, slot uint64) ([]t.BlockVoluntaryExitTableRow, error) {
block, err := d.GetBlockHeightAt(slot)
block, err := d.GetBlockHeightAt(ctx, slot)
if err != nil {
return nil, err
}
return d.GetBlockVoluntaryExits(ctx, chainId, block)
}

func (d *DataAccessService) GetSlotBlobs(ctx context.Context, chainId, slot uint64) ([]t.BlockBlobTableRow, error) {
block, err := d.GetBlockHeightAt(slot)
block, err := d.GetBlockHeightAt(ctx, slot)
if err != nil {
return nil, err
}
Expand Down
11 changes: 5 additions & 6 deletions backend/pkg/api/data_access/data_access.go
Original file line number Diff line number Diff line change
Expand Up @@ -35,16 +35,15 @@ type DataAccessor interface {

Close()

GetLatestFinalizedEpoch() (uint64, error)
GetLatestSlot() (uint64, error)
GetLatestBlock() (uint64, error)
GetBlockHeightAt(slot uint64) (uint64, error)
GetLatestExchangeRates() ([]t.EthConversionRate, error)
GetLatestFinalizedEpoch(ctx context.Context) (uint64, error)
GetLatestSlot(ctx context.Context) (uint64, error)
GetLatestBlock(ctx context.Context) (uint64, error)
GetLatestExchangeRates(ctx context.Context) ([]t.EthConversionRate, error)

GetProductSummary(ctx context.Context) (*t.ProductSummary, error)
GetFreeTierPerks(ctx context.Context) (*t.PremiumPerks, error)

GetValidatorsFromSlices(indices []uint64, publicKeys []string) ([]t.VDBValidator, error)
GetValidatorsFromSlices(ctx context.Context, indices []uint64, publicKeys []string) ([]t.VDBValidator, error)
}

type DataAccessService struct {
Expand Down
Loading

0 comments on commit d11424c

Please sign in to comment.