Merge pull request #1830 from nspcc-dev/fix/neofs
Use filters with NeoFS responses
This commit is contained in:
commit
cb1583e317
4 changed files with 41 additions and 15 deletions
|
@ -6,6 +6,8 @@ import (
|
||||||
"unicode/utf8"
|
"unicode/utf8"
|
||||||
|
|
||||||
"github.com/PaesslerAG/jsonpath"
|
"github.com/PaesslerAG/jsonpath"
|
||||||
|
"github.com/nspcc-dev/neo-go/pkg/core/state"
|
||||||
|
"github.com/nspcc-dev/neo-go/pkg/core/transaction"
|
||||||
)
|
)
|
||||||
|
|
||||||
func filter(value []byte, path string) ([]byte, error) {
|
func filter(value []byte, path string) ([]byte, error) {
|
||||||
|
@ -22,3 +24,14 @@ func filter(value []byte, path string) ([]byte, error) {
|
||||||
}
|
}
|
||||||
return json.Marshal([]interface{}{result})
|
return json.Marshal([]interface{}{result})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func filterRequest(result []byte, req *state.OracleRequest) (transaction.OracleResponseCode, []byte) {
|
||||||
|
if req.Filter != nil {
|
||||||
|
var err error
|
||||||
|
result, err = filter(result, *req.Filter)
|
||||||
|
if err != nil {
|
||||||
|
return transaction.Error, nil
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return transaction.Success, result
|
||||||
|
}
|
||||||
|
|
|
@ -9,9 +9,11 @@ import (
|
||||||
"net/url"
|
"net/url"
|
||||||
"strconv"
|
"strconv"
|
||||||
"strings"
|
"strings"
|
||||||
|
"unicode/utf8"
|
||||||
|
|
||||||
"github.com/gogo/protobuf/jsonpb"
|
"github.com/gogo/protobuf/jsonpb"
|
||||||
"github.com/nspcc-dev/neo-go/pkg/crypto/keys"
|
"github.com/nspcc-dev/neo-go/pkg/crypto/keys"
|
||||||
|
"github.com/nspcc-dev/neo-go/pkg/util"
|
||||||
"github.com/nspcc-dev/neofs-api-go/pkg/client"
|
"github.com/nspcc-dev/neofs-api-go/pkg/client"
|
||||||
"github.com/nspcc-dev/neofs-api-go/pkg/container"
|
"github.com/nspcc-dev/neofs-api-go/pkg/container"
|
||||||
"github.com/nspcc-dev/neofs-api-go/pkg/object"
|
"github.com/nspcc-dev/neofs-api-go/pkg/object"
|
||||||
|
@ -104,7 +106,7 @@ func getPayload(ctx context.Context, c *client.Client, addr *object.Address) ([]
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
return obj.Payload(), nil
|
return checkUTF8(obj.Payload())
|
||||||
}
|
}
|
||||||
|
|
||||||
func getRange(ctx context.Context, c *client.Client, addr *object.Address, ps ...string) ([]byte, error) {
|
func getRange(ctx context.Context, c *client.Client, addr *object.Address, ps ...string) ([]byte, error) {
|
||||||
|
@ -115,7 +117,11 @@ func getRange(ctx context.Context, c *client.Client, addr *object.Address, ps ..
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
return c.ObjectPayloadRangeData(ctx, new(client.RangeDataParams).WithAddress(addr).WithRange(r))
|
data, err := c.ObjectPayloadRangeData(ctx, new(client.RangeDataParams).WithAddress(addr).WithRange(r))
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return checkUTF8(data)
|
||||||
}
|
}
|
||||||
|
|
||||||
func getHeader(ctx context.Context, c *client.Client, addr *object.Address) ([]byte, error) {
|
func getHeader(ctx context.Context, c *client.Client, addr *object.Address) ([]byte, error) {
|
||||||
|
@ -149,7 +155,7 @@ func getHash(ctx context.Context, c *client.Client, addr *object.Address, ps ...
|
||||||
if len(hashes) == 0 {
|
if len(hashes) == 0 {
|
||||||
return nil, fmt.Errorf("%w: empty response", ErrInvalidRange)
|
return nil, fmt.Errorf("%w: empty response", ErrInvalidRange)
|
||||||
}
|
}
|
||||||
return hashes[0][:], nil
|
return util.Uint256(hashes[0]).MarshalJSON()
|
||||||
}
|
}
|
||||||
|
|
||||||
func parseRange(s string) (*object.Range, error) {
|
func parseRange(s string) (*object.Range, error) {
|
||||||
|
@ -171,3 +177,10 @@ func parseRange(s string) (*object.Range, error) {
|
||||||
r.SetLength(length)
|
r.SetLength(length)
|
||||||
return r, nil
|
return r, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func checkUTF8(v []byte) ([]byte, error) {
|
||||||
|
if !utf8.Valid(v) {
|
||||||
|
return nil, errors.New("invalid UTF-8")
|
||||||
|
}
|
||||||
|
return v, nil
|
||||||
|
}
|
||||||
|
|
|
@ -81,3 +81,13 @@ func TestParseNeoFSURL(t *testing.T) {
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func Test_checkUTF8(t *testing.T) {
|
||||||
|
_, err := checkUTF8([]byte{0xFF})
|
||||||
|
require.Error(t, err)
|
||||||
|
|
||||||
|
a := []byte{1, 2, 3}
|
||||||
|
b, err := checkUTF8(a)
|
||||||
|
require.NoError(t, err)
|
||||||
|
require.Equal(t, a, b)
|
||||||
|
}
|
||||||
|
|
|
@ -117,16 +117,7 @@ func (o *Oracle) processRequest(priv *keys.PrivateKey, req request) error {
|
||||||
}
|
}
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
if req.Req.Filter != nil {
|
resp.Code, resp.Result = filterRequest(result, req.Req)
|
||||||
res, err := filter(result, *req.Req.Filter)
|
|
||||||
if err != nil {
|
|
||||||
resp.Code = transaction.Error
|
|
||||||
break
|
|
||||||
}
|
|
||||||
result = res
|
|
||||||
}
|
|
||||||
resp.Code = transaction.Success
|
|
||||||
resp.Result = result
|
|
||||||
case r.StatusCode == http.StatusForbidden:
|
case r.StatusCode == http.StatusForbidden:
|
||||||
resp.Code = transaction.Forbidden
|
resp.Code = transaction.Forbidden
|
||||||
case r.StatusCode == http.StatusNotFound:
|
case r.StatusCode == http.StatusNotFound:
|
||||||
|
@ -144,8 +135,7 @@ func (o *Oracle) processRequest(priv *keys.PrivateKey, req request) error {
|
||||||
if err != nil {
|
if err != nil {
|
||||||
resp.Code = transaction.Error
|
resp.Code = transaction.Error
|
||||||
} else {
|
} else {
|
||||||
resp.Code = transaction.Success
|
resp.Code, resp.Result = filterRequest(res, req.Req)
|
||||||
resp.Result = res
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue