2019-10-09 08:50:57 +00:00
|
|
|
package chain
|
|
|
|
|
|
|
|
import (
|
2020-07-06 17:23:29 +00:00
|
|
|
"fmt"
|
|
|
|
|
2023-09-21 15:37:02 +00:00
|
|
|
"github.com/hashicorp/golang-lru/arc/v2"
|
2019-10-09 08:50:57 +00:00
|
|
|
"github.com/ipfs/go-cid"
|
2022-06-14 15:00:51 +00:00
|
|
|
|
|
|
|
"github.com/filecoin-project/lotus/build"
|
2019-10-09 08:50:57 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
type BadBlockCache struct {
|
2023-09-21 15:37:02 +00:00
|
|
|
badBlocks *arc.ARCCache[cid.Cid, BadBlockReason]
|
2019-10-09 08:50:57 +00:00
|
|
|
}
|
|
|
|
|
2020-07-06 17:23:29 +00:00
|
|
|
type BadBlockReason struct {
|
|
|
|
Reason string
|
|
|
|
TipSet []cid.Cid
|
|
|
|
OriginalReason *BadBlockReason
|
|
|
|
}
|
|
|
|
|
|
|
|
func NewBadBlockReason(cid []cid.Cid, format string, i ...interface{}) BadBlockReason {
|
|
|
|
return BadBlockReason{
|
|
|
|
TipSet: cid,
|
|
|
|
Reason: fmt.Sprintf(format, i...),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (bbr BadBlockReason) Linked(reason string, i ...interface{}) BadBlockReason {
|
|
|
|
or := &bbr
|
|
|
|
if bbr.OriginalReason != nil {
|
|
|
|
or = bbr.OriginalReason
|
|
|
|
}
|
2020-07-08 01:55:56 +00:00
|
|
|
return BadBlockReason{Reason: fmt.Sprintf(reason, i...), OriginalReason: or}
|
2020-07-06 17:23:29 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (bbr BadBlockReason) String() string {
|
|
|
|
res := bbr.Reason
|
|
|
|
if bbr.OriginalReason != nil {
|
2020-07-06 17:46:25 +00:00
|
|
|
res += " caused by: " + fmt.Sprintf("%s %s", bbr.OriginalReason.TipSet, bbr.OriginalReason.String())
|
2020-07-06 17:23:29 +00:00
|
|
|
}
|
|
|
|
return res
|
|
|
|
}
|
|
|
|
|
2019-10-09 08:50:57 +00:00
|
|
|
func NewBadBlockCache() *BadBlockCache {
|
2023-09-21 15:37:02 +00:00
|
|
|
cache, err := arc.NewARC[cid.Cid, BadBlockReason](build.BadBlockCacheSize)
|
2019-10-09 12:23:45 +00:00
|
|
|
if err != nil {
|
2019-11-16 23:41:14 +00:00
|
|
|
panic(err) // ok
|
2019-10-09 12:23:45 +00:00
|
|
|
}
|
|
|
|
|
2019-10-09 08:50:57 +00:00
|
|
|
return &BadBlockCache{
|
2019-10-09 12:23:45 +00:00
|
|
|
badBlocks: cache,
|
2019-10-09 08:50:57 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-07-06 17:23:29 +00:00
|
|
|
func (bts *BadBlockCache) Add(c cid.Cid, bbr BadBlockReason) {
|
|
|
|
bts.badBlocks.Add(c, bbr)
|
2019-10-09 08:50:57 +00:00
|
|
|
}
|
|
|
|
|
2020-09-09 07:24:09 +00:00
|
|
|
func (bts *BadBlockCache) Remove(c cid.Cid) {
|
|
|
|
bts.badBlocks.Remove(c)
|
|
|
|
}
|
|
|
|
|
2020-10-10 08:26:42 +00:00
|
|
|
func (bts *BadBlockCache) Purge() {
|
|
|
|
bts.badBlocks.Purge()
|
|
|
|
}
|
|
|
|
|
2020-07-06 17:23:29 +00:00
|
|
|
func (bts *BadBlockCache) Has(c cid.Cid) (BadBlockReason, bool) {
|
2023-03-13 22:29:09 +00:00
|
|
|
return bts.badBlocks.Get(c)
|
2019-10-09 08:50:57 +00:00
|
|
|
}
|