forked from TrueCloudLab/frostfs-node
[#13] services/object: Implement Put handlers
Signed-off-by: Leonard Lyubich <leonard@nspcc.ru>
This commit is contained in:
parent
d03b153e09
commit
62d0c50b15
2 changed files with 75 additions and 7 deletions
|
@ -27,7 +27,7 @@ type GetRangeObjectBodyStreamer interface {
|
||||||
|
|
||||||
type ServiceExecutor interface {
|
type ServiceExecutor interface {
|
||||||
Get(context.Context, *object.GetRequestBody) (GetObjectBodyStreamer, error)
|
Get(context.Context, *object.GetRequestBody) (GetObjectBodyStreamer, error)
|
||||||
Put(context.Context) (object.PutObjectStreamer, error)
|
Put(context.Context) (PutObjectBodyStreamer, error)
|
||||||
Head(context.Context, *object.HeadRequestBody) (*object.HeadResponseBody, error)
|
Head(context.Context, *object.HeadRequestBody) (*object.HeadResponseBody, error)
|
||||||
Search(context.Context, *object.SearchRequestBody) (SearchObjectBodyStreamer, error)
|
Search(context.Context, *object.SearchRequestBody) (SearchObjectBodyStreamer, error)
|
||||||
Delete(context.Context, *object.DeleteRequestBody) (*object.DeleteResponseBody, error)
|
Delete(context.Context, *object.DeleteRequestBody) (*object.DeleteResponseBody, error)
|
||||||
|
@ -53,6 +53,12 @@ type getStreamer struct {
|
||||||
metaHdr *session.ResponseMetaHeader
|
metaHdr *session.ResponseMetaHeader
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type putStreamer struct {
|
||||||
|
bodyStreamer PutObjectBodyStreamer
|
||||||
|
|
||||||
|
metaHdr *session.ResponseMetaHeader
|
||||||
|
}
|
||||||
|
|
||||||
// NewExecutionService wraps ServiceExecutor and returns Object Service interface.
|
// NewExecutionService wraps ServiceExecutor and returns Object Service interface.
|
||||||
//
|
//
|
||||||
// Passed meta header is attached to all responses.
|
// Passed meta header is attached to all responses.
|
||||||
|
@ -79,7 +85,7 @@ func (s *getStreamer) Recv() (*object.GetResponse, error) {
|
||||||
func (s *executorSvc) Get(ctx context.Context, req *object.GetRequest) (object.GetObjectStreamer, error) {
|
func (s *executorSvc) Get(ctx context.Context, req *object.GetRequest) (object.GetObjectStreamer, error) {
|
||||||
bodyStream, err := s.exec.Get(ctx, req.GetBody())
|
bodyStream, err := s.exec.Get(ctx, req.GetBody())
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, errors.Wrap(err, "could not execute Balance request")
|
return nil, errors.Wrap(err, "could not execute Get request")
|
||||||
}
|
}
|
||||||
|
|
||||||
return &getStreamer{
|
return &getStreamer{
|
||||||
|
@ -88,8 +94,33 @@ func (s *executorSvc) Get(ctx context.Context, req *object.GetRequest) (object.G
|
||||||
}, nil
|
}, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (*executorSvc) Put(context.Context) (object.PutObjectStreamer, error) {
|
func (s *putStreamer) Send(req *object.PutRequest) error {
|
||||||
panic("implement me")
|
return s.bodyStreamer.Send(req.GetBody())
|
||||||
|
}
|
||||||
|
|
||||||
|
func (s *putStreamer) CloseAndRecv() (*object.PutResponse, error) {
|
||||||
|
body, err := s.bodyStreamer.CloseAndRecv()
|
||||||
|
if err != nil {
|
||||||
|
return nil, errors.Wrap(err, "could not receive response body")
|
||||||
|
}
|
||||||
|
|
||||||
|
resp := new(object.PutResponse)
|
||||||
|
resp.SetBody(body)
|
||||||
|
resp.SetMetaHeader(s.metaHdr)
|
||||||
|
|
||||||
|
return resp, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (s *executorSvc) Put(ctx context.Context) (object.PutObjectStreamer, error) {
|
||||||
|
bodyStream, err := s.exec.Put(ctx)
|
||||||
|
if err != nil {
|
||||||
|
return nil, errors.Wrap(err, "could not execute Put request")
|
||||||
|
}
|
||||||
|
|
||||||
|
return &putStreamer{
|
||||||
|
bodyStreamer: bodyStream,
|
||||||
|
metaHdr: s.metaHeader,
|
||||||
|
}, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (*executorSvc) Head(context.Context, *object.HeadRequest) (*object.HeadResponse, error) {
|
func (*executorSvc) Head(context.Context, *object.HeadRequest) (*object.HeadResponse, error) {
|
||||||
|
@ -112,7 +143,7 @@ func (s *searchStreamer) Recv() (*object.SearchResponse, error) {
|
||||||
func (s *executorSvc) Search(ctx context.Context, req *object.SearchRequest) (object.SearchObjectStreamer, error) {
|
func (s *executorSvc) Search(ctx context.Context, req *object.SearchRequest) (object.SearchObjectStreamer, error) {
|
||||||
bodyStream, err := s.exec.Search(ctx, req.GetBody())
|
bodyStream, err := s.exec.Search(ctx, req.GetBody())
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, errors.Wrap(err, "could not execute Balance request")
|
return nil, errors.Wrap(err, "could not execute Search request")
|
||||||
}
|
}
|
||||||
|
|
||||||
return &searchStreamer{
|
return &searchStreamer{
|
||||||
|
|
|
@ -15,6 +15,7 @@ type signService struct {
|
||||||
|
|
||||||
searchSigService *util.UnarySignService
|
searchSigService *util.UnarySignService
|
||||||
getSigService *util.UnarySignService
|
getSigService *util.UnarySignService
|
||||||
|
putService object.Service
|
||||||
}
|
}
|
||||||
|
|
||||||
type searchStreamSigner struct {
|
type searchStreamSigner struct {
|
||||||
|
@ -29,6 +30,12 @@ type getStreamSigner struct {
|
||||||
stream object.GetObjectStreamer
|
stream object.GetObjectStreamer
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type putStreamSigner struct {
|
||||||
|
key *ecdsa.PrivateKey
|
||||||
|
|
||||||
|
stream object.PutObjectStreamer
|
||||||
|
}
|
||||||
|
|
||||||
func NewSignService(key *ecdsa.PrivateKey, svc object.Service) object.Service {
|
func NewSignService(key *ecdsa.PrivateKey, svc object.Service) object.Service {
|
||||||
return &signService{
|
return &signService{
|
||||||
key: key,
|
key: key,
|
||||||
|
@ -44,6 +51,7 @@ func NewSignService(key *ecdsa.PrivateKey, svc object.Service) object.Service {
|
||||||
return svc.Get(ctx, req.(*object.GetRequest))
|
return svc.Get(ctx, req.(*object.GetRequest))
|
||||||
},
|
},
|
||||||
),
|
),
|
||||||
|
putService: svc,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -72,8 +80,37 @@ func (s *signService) Get(ctx context.Context, req *object.GetRequest) (object.G
|
||||||
}, nil
|
}, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *signService) Put(context.Context) (object.PutObjectStreamer, error) {
|
func (s *putStreamSigner) Send(req *object.PutRequest) error {
|
||||||
panic("implement me")
|
if err := signature.VerifyServiceMessage(req); err != nil {
|
||||||
|
return errors.Wrap(err, "could not verify request")
|
||||||
|
}
|
||||||
|
|
||||||
|
return s.stream.Send(req)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (s *putStreamSigner) CloseAndRecv() (*object.PutResponse, error) {
|
||||||
|
r, err := s.stream.CloseAndRecv()
|
||||||
|
if err != nil {
|
||||||
|
return nil, errors.Wrap(err, "could not receive response")
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := signature.SignServiceMessage(s.key, r); err != nil {
|
||||||
|
return nil, errors.Wrap(err, "could not sign response")
|
||||||
|
}
|
||||||
|
|
||||||
|
return r, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (s *signService) Put(ctx context.Context) (object.PutObjectStreamer, error) {
|
||||||
|
stream, err := s.putService.Put(ctx)
|
||||||
|
if err != nil {
|
||||||
|
return nil, errors.Wrap(err, "could not create Put object streamer")
|
||||||
|
}
|
||||||
|
|
||||||
|
return &putStreamSigner{
|
||||||
|
key: s.key,
|
||||||
|
stream: stream,
|
||||||
|
}, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *signService) Head(context.Context, *object.HeadRequest) (*object.HeadResponse, error) {
|
func (s *signService) Head(context.Context, *object.HeadRequest) (*object.HeadResponse, error) {
|
||||||
|
|
Loading…
Reference in a new issue