fbed86da2c
There is no point to pass key storage in parameters because it can be defined on the service level of application. Signed-off-by: Alex Vanin <alexey@nspcc.ru>
34 lines
877 B
Go
34 lines
877 B
Go
package deletesvc
|
|
|
|
import (
|
|
"github.com/nspcc-dev/neofs-api-go/pkg/object"
|
|
objectV2 "github.com/nspcc-dev/neofs-api-go/v2/object"
|
|
deletesvc "github.com/nspcc-dev/neofs-node/pkg/services/object/delete"
|
|
"github.com/nspcc-dev/neofs-node/pkg/services/object/util"
|
|
)
|
|
|
|
type tombstoneBodyWriter struct {
|
|
body *objectV2.DeleteResponseBody
|
|
}
|
|
|
|
func (s *Service) toPrm(req *objectV2.DeleteRequest, respBody *objectV2.DeleteResponseBody) (*deletesvc.Prm, error) {
|
|
commonPrm, err := util.CommonPrmFromV2(req)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
p := new(deletesvc.Prm)
|
|
p.SetCommonParameters(commonPrm)
|
|
|
|
body := req.GetBody()
|
|
p.WithAddress(object.NewAddressFromV2(body.GetAddress()))
|
|
p.WithTombstoneAddressTarget(&tombstoneBodyWriter{
|
|
body: respBody,
|
|
})
|
|
|
|
return p, nil
|
|
}
|
|
|
|
func (w *tombstoneBodyWriter) SetAddress(addr *object.Address) {
|
|
w.body.SetTombstone(addr.ToV2())
|
|
}
|