2022-04-22 13:29:43 +00:00
|
|
|
package shard
|
|
|
|
|
|
|
|
import (
|
2023-03-07 13:38:26 +00:00
|
|
|
"git.frostfs.info/TrueCloudLab/frostfs-node/pkg/local_object_storage/pilorama"
|
|
|
|
"git.frostfs.info/TrueCloudLab/frostfs-node/pkg/local_object_storage/util/logicerr"
|
|
|
|
cidSDK "git.frostfs.info/TrueCloudLab/frostfs-sdk-go/container/id"
|
2022-04-22 13:29:43 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
var _ pilorama.Forest = (*Shard)(nil)
|
|
|
|
|
2022-07-18 10:16:23 +00:00
|
|
|
// ErrPiloramaDisabled is returned when pilorama was disabled in the configuration.
|
2022-10-31 07:02:30 +00:00
|
|
|
var ErrPiloramaDisabled = logicerr.New("pilorama is disabled")
|
2022-07-18 10:16:23 +00:00
|
|
|
|
2022-04-22 13:29:43 +00:00
|
|
|
// TreeMove implements the pilorama.Forest interface.
|
2023-01-25 11:12:02 +00:00
|
|
|
func (s *Shard) TreeMove(d pilorama.CIDDescriptor, treeID string, m *pilorama.Move) (*pilorama.Move, error) {
|
2022-07-18 10:16:23 +00:00
|
|
|
if s.pilorama == nil {
|
|
|
|
return nil, ErrPiloramaDisabled
|
|
|
|
}
|
2022-12-07 17:42:35 +00:00
|
|
|
|
|
|
|
s.m.RLock()
|
|
|
|
defer s.m.RUnlock()
|
|
|
|
|
|
|
|
if s.info.Mode.ReadOnly() {
|
2022-05-16 13:02:35 +00:00
|
|
|
return nil, ErrReadOnlyMode
|
|
|
|
}
|
2023-04-05 07:46:59 +00:00
|
|
|
if s.info.Mode.NoMetabase() {
|
|
|
|
return nil, ErrDegradedMode
|
|
|
|
}
|
2022-05-27 12:55:02 +00:00
|
|
|
return s.pilorama.TreeMove(d, treeID, m)
|
2022-04-22 13:29:43 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// TreeAddByPath implements the pilorama.Forest interface.
|
2023-01-25 11:12:02 +00:00
|
|
|
func (s *Shard) TreeAddByPath(d pilorama.CIDDescriptor, treeID string, attr string, path []string, meta []pilorama.KeyValue) ([]pilorama.Move, error) {
|
2022-07-18 10:16:23 +00:00
|
|
|
if s.pilorama == nil {
|
|
|
|
return nil, ErrPiloramaDisabled
|
|
|
|
}
|
2022-12-07 17:42:35 +00:00
|
|
|
|
|
|
|
s.m.RLock()
|
|
|
|
defer s.m.RUnlock()
|
|
|
|
|
|
|
|
if s.info.Mode.ReadOnly() {
|
2022-05-16 13:02:35 +00:00
|
|
|
return nil, ErrReadOnlyMode
|
|
|
|
}
|
2023-04-05 07:46:59 +00:00
|
|
|
if s.info.Mode.NoMetabase() {
|
|
|
|
return nil, ErrDegradedMode
|
|
|
|
}
|
2022-05-27 12:55:02 +00:00
|
|
|
return s.pilorama.TreeAddByPath(d, treeID, attr, path, meta)
|
2022-04-22 13:29:43 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// TreeApply implements the pilorama.Forest interface.
|
2023-03-21 12:43:12 +00:00
|
|
|
func (s *Shard) TreeApply(cnr cidSDK.ID, treeID string, m *pilorama.Move, backgroundSync bool) error {
|
2022-07-18 10:16:23 +00:00
|
|
|
if s.pilorama == nil {
|
|
|
|
return ErrPiloramaDisabled
|
|
|
|
}
|
2022-12-07 17:42:35 +00:00
|
|
|
|
|
|
|
s.m.RLock()
|
|
|
|
defer s.m.RUnlock()
|
|
|
|
|
|
|
|
if s.info.Mode.ReadOnly() {
|
2022-05-16 13:02:35 +00:00
|
|
|
return ErrReadOnlyMode
|
|
|
|
}
|
2023-04-05 07:46:59 +00:00
|
|
|
if s.info.Mode.NoMetabase() {
|
|
|
|
return ErrDegradedMode
|
|
|
|
}
|
2023-03-21 12:43:12 +00:00
|
|
|
return s.pilorama.TreeApply(cnr, treeID, m, backgroundSync)
|
2022-04-22 13:29:43 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// TreeGetByPath implements the pilorama.Forest interface.
|
|
|
|
func (s *Shard) TreeGetByPath(cid cidSDK.ID, treeID string, attr string, path []string, latest bool) ([]pilorama.Node, error) {
|
2022-07-18 10:16:23 +00:00
|
|
|
if s.pilorama == nil {
|
|
|
|
return nil, ErrPiloramaDisabled
|
|
|
|
}
|
2023-04-05 07:46:59 +00:00
|
|
|
|
|
|
|
s.m.RLock()
|
|
|
|
defer s.m.RUnlock()
|
|
|
|
|
|
|
|
if s.info.Mode.NoMetabase() {
|
|
|
|
return nil, ErrDegradedMode
|
|
|
|
}
|
2022-04-22 13:29:43 +00:00
|
|
|
return s.pilorama.TreeGetByPath(cid, treeID, attr, path, latest)
|
|
|
|
}
|
|
|
|
|
|
|
|
// TreeGetMeta implements the pilorama.Forest interface.
|
2022-05-20 08:41:37 +00:00
|
|
|
func (s *Shard) TreeGetMeta(cid cidSDK.ID, treeID string, nodeID pilorama.Node) (pilorama.Meta, uint64, error) {
|
2022-07-18 10:16:23 +00:00
|
|
|
if s.pilorama == nil {
|
|
|
|
return pilorama.Meta{}, 0, ErrPiloramaDisabled
|
|
|
|
}
|
2023-04-05 07:46:59 +00:00
|
|
|
|
|
|
|
s.m.RLock()
|
|
|
|
defer s.m.RUnlock()
|
|
|
|
|
|
|
|
if s.info.Mode.NoMetabase() {
|
|
|
|
return pilorama.Meta{}, 0, ErrDegradedMode
|
|
|
|
}
|
2022-04-22 13:29:43 +00:00
|
|
|
return s.pilorama.TreeGetMeta(cid, treeID, nodeID)
|
|
|
|
}
|
2022-04-29 10:06:10 +00:00
|
|
|
|
|
|
|
// TreeGetChildren implements the pilorama.Forest interface.
|
|
|
|
func (s *Shard) TreeGetChildren(cid cidSDK.ID, treeID string, nodeID pilorama.Node) ([]uint64, error) {
|
2022-07-18 10:16:23 +00:00
|
|
|
if s.pilorama == nil {
|
|
|
|
return nil, ErrPiloramaDisabled
|
|
|
|
}
|
2023-04-05 07:46:59 +00:00
|
|
|
|
|
|
|
s.m.RLock()
|
|
|
|
defer s.m.RUnlock()
|
|
|
|
|
|
|
|
if s.info.Mode.NoMetabase() {
|
|
|
|
return nil, ErrDegradedMode
|
|
|
|
}
|
2022-04-29 10:06:10 +00:00
|
|
|
return s.pilorama.TreeGetChildren(cid, treeID, nodeID)
|
|
|
|
}
|
2022-05-11 13:29:04 +00:00
|
|
|
|
|
|
|
// TreeGetOpLog implements the pilorama.Forest interface.
|
|
|
|
func (s *Shard) TreeGetOpLog(cid cidSDK.ID, treeID string, height uint64) (pilorama.Move, error) {
|
2022-07-18 10:16:23 +00:00
|
|
|
if s.pilorama == nil {
|
|
|
|
return pilorama.Move{}, ErrPiloramaDisabled
|
|
|
|
}
|
2023-04-05 07:46:59 +00:00
|
|
|
|
|
|
|
s.m.RLock()
|
|
|
|
defer s.m.RUnlock()
|
|
|
|
|
|
|
|
if s.info.Mode.NoMetabase() {
|
|
|
|
return pilorama.Move{}, ErrDegradedMode
|
|
|
|
}
|
2022-05-11 13:29:04 +00:00
|
|
|
return s.pilorama.TreeGetOpLog(cid, treeID, height)
|
|
|
|
}
|
2022-09-07 08:46:13 +00:00
|
|
|
|
|
|
|
// TreeDrop implements the pilorama.Forest interface.
|
|
|
|
func (s *Shard) TreeDrop(cid cidSDK.ID, treeID string) error {
|
|
|
|
if s.pilorama == nil {
|
|
|
|
return ErrPiloramaDisabled
|
|
|
|
}
|
2023-04-05 07:46:59 +00:00
|
|
|
|
|
|
|
s.m.RLock()
|
|
|
|
defer s.m.RUnlock()
|
|
|
|
|
|
|
|
if s.info.Mode.NoMetabase() {
|
|
|
|
return ErrDegradedMode
|
|
|
|
}
|
2022-09-07 08:46:13 +00:00
|
|
|
return s.pilorama.TreeDrop(cid, treeID)
|
|
|
|
}
|
2022-10-18 11:59:32 +00:00
|
|
|
|
|
|
|
// TreeList implements the pilorama.Forest interface.
|
|
|
|
func (s *Shard) TreeList(cid cidSDK.ID) ([]string, error) {
|
2022-10-18 12:49:40 +00:00
|
|
|
if s.pilorama == nil {
|
|
|
|
return nil, ErrPiloramaDisabled
|
|
|
|
}
|
2023-04-05 07:46:59 +00:00
|
|
|
|
|
|
|
s.m.RLock()
|
|
|
|
defer s.m.RUnlock()
|
|
|
|
|
|
|
|
if s.info.Mode.NoMetabase() {
|
|
|
|
return nil, ErrDegradedMode
|
|
|
|
}
|
2022-10-18 12:49:40 +00:00
|
|
|
return s.pilorama.TreeList(cid)
|
2022-10-18 11:59:32 +00:00
|
|
|
}
|
2022-10-06 16:06:19 +00:00
|
|
|
|
2023-04-07 10:26:54 +00:00
|
|
|
func (s *Shard) TreeHeight(cid cidSDK.ID, treeID string) (uint64, error) {
|
|
|
|
if s.pilorama == nil {
|
|
|
|
return 0, ErrPiloramaDisabled
|
|
|
|
}
|
|
|
|
return s.pilorama.TreeHeight(cid, treeID)
|
|
|
|
}
|
|
|
|
|
2022-10-06 16:06:19 +00:00
|
|
|
// TreeExists implements the pilorama.Forest interface.
|
|
|
|
func (s *Shard) TreeExists(cid cidSDK.ID, treeID string) (bool, error) {
|
|
|
|
if s.pilorama == nil {
|
|
|
|
return false, ErrPiloramaDisabled
|
|
|
|
}
|
2023-04-05 07:46:59 +00:00
|
|
|
|
|
|
|
s.m.RLock()
|
|
|
|
defer s.m.RUnlock()
|
|
|
|
|
|
|
|
if s.info.Mode.NoMetabase() {
|
|
|
|
return false, ErrDegradedMode
|
|
|
|
}
|
2022-10-06 16:06:19 +00:00
|
|
|
return s.pilorama.TreeExists(cid, treeID)
|
|
|
|
}
|
2023-01-25 10:25:45 +00:00
|
|
|
|
|
|
|
// TreeUpdateLastSyncHeight implements the pilorama.Forest interface.
|
|
|
|
func (s *Shard) TreeUpdateLastSyncHeight(cid cidSDK.ID, treeID string, height uint64) error {
|
|
|
|
if s.pilorama == nil {
|
|
|
|
return ErrPiloramaDisabled
|
|
|
|
}
|
2023-04-05 07:46:59 +00:00
|
|
|
|
|
|
|
s.m.RLock()
|
|
|
|
defer s.m.RUnlock()
|
|
|
|
|
|
|
|
if s.info.Mode.ReadOnly() {
|
|
|
|
return ErrReadOnlyMode
|
|
|
|
}
|
|
|
|
if s.info.Mode.NoMetabase() {
|
|
|
|
return ErrDegradedMode
|
|
|
|
}
|
2023-01-25 10:25:45 +00:00
|
|
|
return s.pilorama.TreeUpdateLastSyncHeight(cid, treeID, height)
|
|
|
|
}
|
|
|
|
|
|
|
|
// TreeLastSyncHeight implements the pilorama.Forest interface.
|
|
|
|
func (s *Shard) TreeLastSyncHeight(cid cidSDK.ID, treeID string) (uint64, error) {
|
|
|
|
if s.pilorama == nil {
|
|
|
|
return 0, ErrPiloramaDisabled
|
|
|
|
}
|
2023-04-05 07:46:59 +00:00
|
|
|
|
|
|
|
s.m.RLock()
|
|
|
|
defer s.m.RUnlock()
|
|
|
|
|
|
|
|
if s.info.Mode.NoMetabase() {
|
|
|
|
return 0, ErrDegradedMode
|
|
|
|
}
|
2023-01-25 10:25:45 +00:00
|
|
|
return s.pilorama.TreeLastSyncHeight(cid, treeID)
|
|
|
|
}
|