WIP: next hard fork #5
4 changed files with 69 additions and 4 deletions
|
@ -89,7 +89,9 @@ func New(cfg config.Config) (*ClaimTrie, error) {
|
||||||
return nil, errors.Wrap(err, "creating node base manager")
|
return nil, errors.Wrap(err, "creating node base manager")
|
||||||
}
|
}
|
||||||
normalizingManager := node.NewNormalizingManager(baseManager)
|
normalizingManager := node.NewNormalizingManager(baseManager)
|
||||||
nodeManager := &node.HashV2Manager{Manager: normalizingManager}
|
hashV2Manager := &node.HashV2Manager{Manager: normalizingManager}
|
||||||
|
nodeManager := &node.HashV3Manager{Manager: hashV2Manager}
|
||||||
|
|
||||||
cleanups = append(cleanups, nodeManager.Close)
|
cleanups = append(cleanups, nodeManager.Close)
|
||||||
|
|
||||||
var trie merkletrie.MerkleTrie
|
var trie merkletrie.MerkleTrie
|
||||||
|
|
63
claimtrie/node/hash_manager.go
Normal file
63
claimtrie/node/hash_manager.go
Normal file
|
@ -0,0 +1,63 @@
|
||||||
|
package node
|
||||||
|
|
||||||
|
import (
|
||||||
|
"github.com/btcsuite/btcd/chaincfg/chainhash"
|
||||||
|
"github.com/lbryio/chain/claimtrie/change"
|
||||||
|
"github.com/lbryio/chain/claimtrie/param"
|
||||||
|
)
|
||||||
|
|
||||||
|
type HashV2Manager struct {
|
||||||
|
Manager
|
||||||
|
}
|
||||||
|
|
||||||
|
type HashV3Manager struct {
|
||||||
|
Manager
|
||||||
|
}
|
||||||
|
|
||||||
|
func (nm *HashV2Manager) claimHashes(name []byte) (*chainhash.Hash, int32) {
|
||||||
|
|
||||||
|
n, err := nm.NodeAt(nm.Height(), name)
|
||||||
|
if err != nil || n == nil {
|
||||||
|
return nil, 0
|
||||||
|
}
|
||||||
|
|
||||||
|
n.SortClaimsByBid()
|
||||||
|
claimHashes := make([]*chainhash.Hash, 0, len(n.Claims))
|
||||||
|
for _, c := range n.Claims {
|
||||||
|
if c.Status == Activated { // TODO: unit test this line
|
||||||
|
claimHashes = append(claimHashes, calculateNodeHash(c.OutPoint, n.TakenOverAt))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if len(claimHashes) > 0 {
|
||||||
|
return ComputeMerkleRoot(claimHashes), n.NextUpdate(nm.Height())
|
||||||
|
}
|
||||||
|
return nil, n.NextUpdate(nm.Height())
|
||||||
|
}
|
||||||
|
|
||||||
|
func (nm *HashV2Manager) Hash(name []byte) (*chainhash.Hash, int32) {
|
||||||
|
|
||||||
|
if nm.Height() >= param.ActiveParams.AllClaimsInMerkleForkHeight {
|
||||||
|
return nm.claimHashes(name)
|
||||||
|
}
|
||||||
|
|
||||||
|
return nm.Manager.Hash(name)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (nm *HashV3Manager) AppendChange(chg change.Change) {
|
||||||
|
if nm.Height() >= param.ActiveParams.GrandForkHeight && len(chg.Name) == 0 {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
nm.Manager.AppendChange(chg)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (nm *HashV3Manager) Hash(name []byte) (*chainhash.Hash, int32) {
|
||||||
|
|
||||||
|
if nm.Height() >= param.ActiveParams.GrandForkHeight {
|
||||||
|
if len(name) == 0 {
|
||||||
|
return nil, 0 // empty name's claims are not included in the hash
|
||||||
|
}
|
||||||
|
// return nm.detailHash()
|
||||||
|
}
|
||||||
|
|
||||||
|
return nm.Manager.Hash(name)
|
||||||
|
}
|
|
@ -187,7 +187,7 @@ func (nm *BaseManager) IncrementHeightTo(height int32) ([][]byte, error) {
|
||||||
panic("invalid height")
|
panic("invalid height")
|
||||||
}
|
}
|
||||||
|
|
||||||
if height >= param.ActiveParams.MaxRemovalWorkaroundHeight {
|
if height >= param.ActiveParams.MaxRemovalWorkaroundHeight && height < param.ActiveParams.GrandForkHeight {
|
||||||
// not technically needed until block 884430, but to be true to the arbitrary rollback length...
|
// not technically needed until block 884430, but to be true to the arbitrary rollback length...
|
||||||
collectChildNames(nm.changes)
|
collectChildNames(nm.changes)
|
||||||
}
|
}
|
||||||
|
|
|
@ -271,7 +271,7 @@ func TestEndOfExpiration(t *testing.T) {
|
||||||
r.NoError(err)
|
r.NoError(err)
|
||||||
n, err := m.NodeAt(m.height, name1)
|
n, err := m.NodeAt(m.height, name1)
|
||||||
r.NoError(err)
|
r.NoError(err)
|
||||||
r.Equal(m.height + param.ActiveParams.ExtendedClaimExpirationTime, n.NextUpdate(m.height))
|
r.Equal(m.height+param.ActiveParams.ExtendedClaimExpirationTime, n.NextUpdate(m.height))
|
||||||
|
|
||||||
_, err = m.IncrementHeightTo(gf)
|
_, err = m.IncrementHeightTo(gf)
|
||||||
r.NoError(err)
|
r.NoError(err)
|
||||||
|
@ -279,4 +279,4 @@ func TestEndOfExpiration(t *testing.T) {
|
||||||
n, err = m.NodeAt(m.height, name1)
|
n, err = m.NodeAt(m.height, name1)
|
||||||
r.NoError(err)
|
r.NoError(err)
|
||||||
r.Equal(int32(0), n.NextUpdate(m.height))
|
r.Equal(int32(0), n.NextUpdate(m.height))
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue