From cba87a13000af3c41f93220ff4b0a0f180255b0c Mon Sep 17 00:00:00 2001 From: Leonard Lyubich Date: Thu, 19 Nov 2020 16:04:04 +0300 Subject: [PATCH] [#188] localstorage: Implement SetShardMode method Signed-off-by: Leonard Lyubich --- pkg/local_object_storage/engine/shards.go | 18 ++++++++++++++++++ 1 file changed, 18 insertions(+) diff --git a/pkg/local_object_storage/engine/shards.go b/pkg/local_object_storage/engine/shards.go index ee41e2d6..a6cf3db3 100644 --- a/pkg/local_object_storage/engine/shards.go +++ b/pkg/local_object_storage/engine/shards.go @@ -10,6 +10,8 @@ import ( "github.com/pkg/errors" ) +var errShardNotFound = errors.New("shard not found") + // AddShard adds a new shard to the storage engine. // // Returns any error encountered that did not allow adding a shard. @@ -72,3 +74,19 @@ func (e *StorageEngine) iterateOverSortedShards(addr *object.Address, handler fu } } } + +// SetShardMode sets mode of the shard with provided identifier. +// +// Returns an error if shard mode was not set, or shard was not found in storage engine. +func (e *StorageEngine) SetShardMode(id *shard.ID, m shard.Mode) error { + e.mtx.RLock() + defer e.mtx.RUnlock() + + for shID, sh := range e.shards { + if id.String() == shID { + return sh.SetMode(m) + } + } + + return errShardNotFound +}