2020-01-15 14:56:50 +01:00
package trie
2020-03-25 22:40:30 +07:00
import "errors"
2020-05-12 15:24:43 +01:00
func ( t * Trie ) ExtractWitness ( trace bool , rl RetainDecider ) ( * Witness , error ) {
var rd RetainDecider
if rl != nil {
rd = rl
2020-04-08 15:59:30 +03:00
}
2020-05-12 15:24:43 +01:00
return extractWitnessFromRootNode ( t . root , trace , rd )
2020-01-24 11:58:01 +01:00
}
2020-05-12 15:24:43 +01:00
func ( t * Trie ) ExtractWitnessForPrefix ( prefix [ ] byte , trace bool , rl RetainDecider ) ( * Witness , error ) {
2020-04-16 08:42:25 +01:00
foundNode , _ , found , _ := t . getNode ( prefix , false )
2020-03-25 22:40:30 +07:00
if ! found {
return nil , errors . New ( "no data found for given prefix" )
}
2020-05-12 15:24:43 +01:00
return extractWitnessFromRootNode ( foundNode , trace , rl )
2020-03-25 22:40:30 +07:00
}
2020-05-12 08:22:45 +01:00
// ExtractWitnesses extracts witnesses for subtries starting from the specified root
2020-05-12 15:24:43 +01:00
// if retainDec param is nil it will make a witness for the full subtrie,
// if retainDec param is set to a RetainList instance, it will make a witness for only the accounts/storages that were actually touched; other paths will be hashed.
func ExtractWitnesses ( subTries SubTries , trace bool , retainDec RetainDecider ) ( [ ] * Witness , error ) {
2020-05-12 08:22:45 +01:00
var witnesses [ ] * Witness
for _ , root := range subTries . roots {
builder := NewWitnessBuilder ( root , trace )
var limiter * MerklePathLimiter = nil
2020-05-12 15:24:43 +01:00
if retainDec != nil {
2020-05-12 08:22:45 +01:00
hr := newHasher ( false )
defer returnHasherToPool ( hr )
2020-05-12 15:24:43 +01:00
limiter = & MerklePathLimiter { retainDec , hr . hash }
2020-05-12 08:22:45 +01:00
}
if witness , err := builder . Build ( limiter ) ; err == nil {
witnesses = append ( witnesses , witness )
} else {
return witnesses , err
}
}
return witnesses , nil
}
// extractWitnessFromRootNode extracts witness for subtrie starting from the specified root
2020-05-12 15:24:43 +01:00
// if retainDec param is nil it will make a witness for the full subtrie,
// if retainDec param is set to a RetainList instance, it will make a witness for only the accounts/storages that were actually touched; other paths will be hashed.
func extractWitnessFromRootNode ( root node , trace bool , retainDec RetainDecider ) ( * Witness , error ) {
2020-05-12 08:22:45 +01:00
builder := NewWitnessBuilder ( root , trace )
2020-04-08 15:59:30 +03:00
var limiter * MerklePathLimiter = nil
2020-05-12 15:24:43 +01:00
if retainDec != nil {
2020-01-24 11:58:01 +01:00
hr := newHasher ( false )
defer returnHasherToPool ( hr )
2020-05-12 15:24:43 +01:00
limiter = & MerklePathLimiter { retainDec , hr . hash }
2020-01-24 11:58:01 +01:00
}
return builder . Build ( limiter )
2020-01-15 14:56:50 +01:00
}