frostfs-node/pkg/services/container/announcement/load/route/placement/calls.go
Evgenii Stratonikov 71b87155ef [#521] *: use stdlib errors package
Signed-off-by: Evgenii Stratonikov <evgeniy@nspcc.ru>
2021-05-19 16:42:54 +03:00

37 lines
1 KiB
Go

package placementrouter
import (
"fmt"
"github.com/nspcc-dev/neofs-api-go/pkg/container"
loadroute "github.com/nspcc-dev/neofs-node/pkg/services/container/announcement/load/route"
)
// NextStage composes container nodes for the container and epoch from a,
// and returns the list of nodes with maximum weight (one from each vector).
//
// If passed route has more than one point, then endpoint of the route is reached.
//
// The traversed route is not checked, it is assumed to be correct.
func (b *Builder) NextStage(a container.UsedSpaceAnnouncement, passed []loadroute.ServerInfo) ([]loadroute.ServerInfo, error) {
if len(passed) > 1 {
return nil, nil
}
placement, err := b.placementBuilder.BuildPlacement(a.Epoch(), a.ContainerID())
if err != nil {
return nil, fmt.Errorf("could not build placement %s: %w", a.ContainerID(), err)
}
res := make([]loadroute.ServerInfo, 0, len(placement))
for i := range placement {
if len(placement[i]) == 0 {
continue
}
res = append(res, placement[i][0])
}
return res, nil
}