2023-11-07 12:50:36 +00:00
|
|
|
package diagnostics
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"net/http"
|
|
|
|
|
|
|
|
"github.com/ledgerwatch/erigon-lib/common"
|
|
|
|
diaglib "github.com/ledgerwatch/erigon-lib/diagnostics"
|
|
|
|
"github.com/ledgerwatch/erigon/turbo/node"
|
|
|
|
"github.com/ledgerwatch/log/v3"
|
|
|
|
"github.com/urfave/cli/v2"
|
|
|
|
)
|
|
|
|
|
|
|
|
type DiagnosticClient struct {
|
|
|
|
ctx *cli.Context
|
|
|
|
metricsMux *http.ServeMux
|
|
|
|
node *node.ErigonNode
|
|
|
|
|
|
|
|
snapshotDownload map[string]diaglib.DownloadStatistics
|
|
|
|
}
|
|
|
|
|
|
|
|
func NewDiagnosticClient(ctx *cli.Context, metricsMux *http.ServeMux, node *node.ErigonNode) *DiagnosticClient {
|
|
|
|
return &DiagnosticClient{ctx: ctx, metricsMux: metricsMux, node: node, snapshotDownload: map[string]diaglib.DownloadStatistics{}}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (d *DiagnosticClient) Setup() {
|
|
|
|
d.runSnapshotListener()
|
|
|
|
}
|
|
|
|
|
|
|
|
func (d *DiagnosticClient) runSnapshotListener() {
|
|
|
|
go func() {
|
2023-11-08 14:02:30 +00:00
|
|
|
ctx, ch, cancel := diaglib.Context[diaglib.DownloadStatistics](context.Background(), 1)
|
|
|
|
defer cancel()
|
2023-11-07 12:50:36 +00:00
|
|
|
|
|
|
|
rootCtx, _ := common.RootContext()
|
|
|
|
|
|
|
|
diaglib.StartProviders(ctx, diaglib.TypeOf(diaglib.DownloadStatistics{}), log.Root())
|
|
|
|
for {
|
|
|
|
select {
|
|
|
|
case <-rootCtx.Done():
|
2023-11-08 14:02:30 +00:00
|
|
|
cancel()
|
2023-11-07 12:50:36 +00:00
|
|
|
return
|
|
|
|
case info := <-ch:
|
|
|
|
d.snapshotDownload[info.StagePrefix] = info
|
|
|
|
if info.DownloadFinished {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}()
|
|
|
|
}
|
|
|
|
|
|
|
|
func (d *DiagnosticClient) SnapshotDownload() map[string]diaglib.DownloadStatistics {
|
|
|
|
return d.snapshotDownload
|
|
|
|
}
|