lotus/chain/syncstate.go

104 lines
1.7 KiB
Go
Raw Permalink Normal View History

package chain
import (
"fmt"
"sync"
2019-12-04 03:56:29 +00:00
"time"
"github.com/filecoin-project/lotus/api"
"github.com/filecoin-project/lotus/chain/types"
)
2019-09-30 22:29:40 +00:00
func SyncStageString(v api.SyncStateStage) string {
switch v {
2019-09-30 22:29:40 +00:00
case api.StageHeaders:
return "header sync"
2019-09-30 22:29:40 +00:00
case api.StagePersistHeaders:
return "persisting headers"
2019-09-30 22:29:40 +00:00
case api.StageMessages:
return "message sync"
2019-09-30 22:29:40 +00:00
case api.StageSyncComplete:
return "complete"
2019-12-04 03:56:29 +00:00
case api.StageSyncErrored:
return "error"
default:
return fmt.Sprintf("<unknown: %d>", v)
}
}
type SyncerState struct {
2019-12-04 03:56:29 +00:00
lk sync.Mutex
Target *types.TipSet
Base *types.TipSet
Stage api.SyncStateStage
Height uint64
Message string
Start time.Time
End time.Time
}
2019-09-30 22:29:40 +00:00
func (ss *SyncerState) SetStage(v api.SyncStateStage) {
2019-11-15 21:35:29 +00:00
if ss == nil {
return
}
ss.lk.Lock()
defer ss.lk.Unlock()
ss.Stage = v
2019-12-04 03:56:29 +00:00
if v == api.StageSyncComplete {
ss.End = time.Now()
}
}
func (ss *SyncerState) Init(base, target *types.TipSet) {
2019-11-15 21:35:29 +00:00
if ss == nil {
return
}
ss.lk.Lock()
defer ss.lk.Unlock()
ss.Target = target
ss.Base = base
2019-09-30 22:29:40 +00:00
ss.Stage = api.StageHeaders
ss.Height = 0
2019-12-04 03:56:29 +00:00
ss.Message = ""
ss.Start = time.Now()
ss.End = time.Time{}
}
func (ss *SyncerState) SetHeight(h uint64) {
2019-11-15 21:35:29 +00:00
if ss == nil {
return
}
ss.lk.Lock()
defer ss.lk.Unlock()
ss.Height = h
}
2019-12-04 03:56:29 +00:00
func (ss *SyncerState) Error(err error) {
if ss == nil {
return
}
ss.lk.Lock()
defer ss.lk.Unlock()
ss.Message = err.Error()
ss.Stage = api.StageSyncErrored
ss.End = time.Now()
}
func (ss *SyncerState) Snapshot() SyncerState {
ss.lk.Lock()
defer ss.lk.Unlock()
return SyncerState{
2019-12-04 03:56:29 +00:00
Base: ss.Base,
Target: ss.Target,
Stage: ss.Stage,
Height: ss.Height,
Message: ss.Message,
Start: ss.Start,
End: ss.End,
}
}