Ekaterina Lebedeva
06be16b716
Some checks failed
Vulncheck / Vulncheck (pull_request) Successful in 3m6s
Pre-commit hooks / Pre-commit (pull_request) Successful in 3m29s
Tests and linters / gopls check (pull_request) Successful in 3m57s
Tests and linters / Tests with -race (pull_request) Failing after 5m52s
Tests and linters / Run gofumpt (pull_request) Successful in 5m59s
DCO action / DCO (pull_request) Successful in 6m15s
Tests and linters / Tests (pull_request) Failing after 6m47s
Build / Build Components (pull_request) Successful in 7m50s
Tests and linters / Staticcheck (pull_request) Successful in 7m59s
Tests and linters / Lint (pull_request) Successful in 8m40s
* Added new method for listing containers to container service. It opens stream and sends containers in batches. * Added TransportSplitter wrapper around ExecutionService to split container ID list read from contract in parts that are smaller than grpc max message size. Batch size can be changed in node configuration file (as in example config file). * Changed `container list` implementaion in cli: now ListStream is called by default. Old List is called only if ListStream is not implemented. * Changed `internalclient.ListContainersPrm`.`Account` to `OwnerID` since `client.PrmContainerList`.`Account` was renamed to `OwnerID` in sdk. Signed-off-by: Ekaterina Lebedeva <ekaterina.lebedeva@yadro.com>
92 lines
2.2 KiB
Go
92 lines
2.2 KiB
Go
package container
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
|
|
"git.frostfs.info/TrueCloudLab/frostfs-node/pkg/services/util"
|
|
"git.frostfs.info/TrueCloudLab/frostfs-node/pkg/services/util/response"
|
|
"git.frostfs.info/TrueCloudLab/frostfs-sdk-go/api/container"
|
|
)
|
|
|
|
type (
|
|
TransportSplitter struct {
|
|
next Server
|
|
|
|
respSvc *response.Service
|
|
cnrAmount uint32
|
|
}
|
|
|
|
listStreamMsgSizeCtrl struct {
|
|
util.ServerStream
|
|
stream ListStream
|
|
respSvc *response.Service
|
|
cnrAmount uint32
|
|
}
|
|
)
|
|
|
|
func NewSplitterService(cnrAmount uint32, respSvc *response.Service, next Server) Server {
|
|
return &TransportSplitter{
|
|
next: next,
|
|
respSvc: respSvc,
|
|
cnrAmount: cnrAmount,
|
|
}
|
|
}
|
|
|
|
func (s *TransportSplitter) Put(ctx context.Context, req *container.PutRequest) (*container.PutResponse, error) {
|
|
return s.next.Put(ctx, req)
|
|
}
|
|
|
|
func (s *TransportSplitter) Delete(ctx context.Context, req *container.DeleteRequest) (*container.DeleteResponse, error) {
|
|
return s.next.Delete(ctx, req)
|
|
}
|
|
|
|
func (s *TransportSplitter) Get(ctx context.Context, req *container.GetRequest) (*container.GetResponse, error) {
|
|
return s.next.Get(ctx, req)
|
|
}
|
|
|
|
func (s *TransportSplitter) List(ctx context.Context, req *container.ListRequest) (*container.ListResponse, error) {
|
|
return s.next.List(ctx, req)
|
|
}
|
|
|
|
func (s *TransportSplitter) ListStream(req *container.ListStreamRequest, stream ListStream) error {
|
|
return s.next.ListStream(req, &listStreamMsgSizeCtrl{
|
|
ServerStream: stream,
|
|
stream: stream,
|
|
respSvc: s.respSvc,
|
|
cnrAmount: s.cnrAmount,
|
|
})
|
|
}
|
|
|
|
func (s *listStreamMsgSizeCtrl) Send(resp *container.ListStreamResponse) error {
|
|
s.respSvc.SetMeta(resp)
|
|
body := resp.GetBody()
|
|
ids := body.GetContainerIDs()
|
|
|
|
var newResp *container.ListStreamResponse
|
|
|
|
for {
|
|
if newResp == nil {
|
|
newResp = new(container.ListStreamResponse)
|
|
newResp.SetBody(body)
|
|
}
|
|
|
|
cut := min(s.cnrAmount, uint32(len(ids)))
|
|
|
|
body.SetContainerIDs(ids[:cut])
|
|
newResp.SetMetaHeader(resp.GetMetaHeader())
|
|
newResp.SetVerificationHeader(resp.GetVerificationHeader())
|
|
|
|
if err := s.stream.Send(newResp); err != nil {
|
|
return fmt.Errorf("TransportSplitter: %w", err)
|
|
}
|
|
|
|
ids = ids[cut:]
|
|
|
|
if len(ids) == 0 {
|
|
break
|
|
}
|
|
}
|
|
|
|
return nil
|
|
}
|