forked from TrueCloudLab/frostfs-node
923f84722a
Signed-off-by: Pavel Karpy <p.karpy@yadro.com>
32 lines
869 B
Go
32 lines
869 B
Go
package routes
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"github.com/TrueCloudLab/frostfs-node/pkg/services/reputation"
|
|
"github.com/TrueCloudLab/frostfs-node/pkg/services/reputation/common"
|
|
"go.uber.org/zap"
|
|
)
|
|
|
|
// NextStage builds Manager list for trusting node and returns it directly.
|
|
//
|
|
// If passed route has more than one point, then endpoint of the route is reached.
|
|
func (b *Builder) NextStage(epoch uint64, t reputation.Trust, passed []common.ServerInfo) ([]common.ServerInfo, error) {
|
|
passedLen := len(passed)
|
|
|
|
b.log.Debug("building next stage for local trust route",
|
|
zap.Uint64("epoch", epoch),
|
|
zap.Int("passed_length", passedLen),
|
|
)
|
|
|
|
if passedLen > 1 {
|
|
return nil, nil
|
|
}
|
|
|
|
route, err := b.managerBuilder.BuildManagers(epoch, t.TrustingPeer())
|
|
if err != nil {
|
|
return nil, fmt.Errorf("could not build managers for epoch: %d: %w", epoch, err)
|
|
}
|
|
|
|
return route, nil
|
|
}
|