mirror of
https://github.com/anyproto/any-sync.git
synced 2025-06-08 14:07:02 +09:00
52 lines
975 B
Go
52 lines
975 B
Go
package objecttree
|
|
|
|
import (
|
|
"errors"
|
|
)
|
|
|
|
var ErrLoadBeforeRoot = errors.New("can't load before root")
|
|
|
|
type HistoryTree interface {
|
|
ReadableObjectTree
|
|
}
|
|
|
|
type historyTree struct {
|
|
*objectTree
|
|
}
|
|
|
|
func (h *historyTree) rebuildFromStorage(beforeId string, include bool) (err error) {
|
|
ot := h.objectTree
|
|
ot.treeBuilder.Reset()
|
|
if beforeId == ot.Id() && !include {
|
|
return ErrLoadBeforeRoot
|
|
}
|
|
|
|
heads := []string{beforeId}
|
|
if beforeId == "" {
|
|
heads, err = ot.treeStorage.Heads()
|
|
if err != nil {
|
|
return
|
|
}
|
|
} else if !include {
|
|
beforeChange, err := ot.treeBuilder.loadChange(beforeId)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
heads = beforeChange.PreviousIds
|
|
}
|
|
|
|
ot.tree, err = ot.treeBuilder.build(heads, nil, nil)
|
|
if err != nil {
|
|
return
|
|
}
|
|
ot.aclList.RLock()
|
|
defer ot.aclList.RUnlock()
|
|
state := ot.aclList.AclState()
|
|
|
|
if len(ot.keys) != len(state.UserReadKeys()) {
|
|
for key, value := range state.UserReadKeys() {
|
|
ot.keys[key] = value
|
|
}
|
|
}
|
|
return
|
|
}
|