oracle: add logging, refactor request processing a bit

And return more appropriate errors in some cases.
This commit is contained in:
Roman Khimov 2021-04-06 17:02:00 +03:00
parent d2f7f00997
commit f69fd34220

View file

@ -98,20 +98,27 @@ func (o *Oracle) processRequest(priv *keys.PrivateKey, req request) error {
resp := &transaction.OracleResponse{ID: req.ID} resp := &transaction.OracleResponse{ID: req.ID}
u, err := url.ParseRequestURI(req.Req.URL) u, err := url.ParseRequestURI(req.Req.URL)
if err != nil { if err != nil {
resp.Code = transaction.Forbidden o.Log.Warn("malformed oracle request", zap.String("url", req.Req.URL), zap.Error(err))
} else if u.Scheme == "https" { resp.Code = transaction.ProtocolNotSupported
} else {
switch u.Scheme {
case "https":
if !o.MainCfg.AllowPrivateHost { if !o.MainCfg.AllowPrivateHost {
err = o.URIValidator(u) err = o.URIValidator(u)
if err != nil { if err != nil {
o.Log.Warn("forbidden oracle request", zap.String("url", req.Req.URL))
resp.Code = transaction.Forbidden resp.Code = transaction.Forbidden
break
} }
} }
if err == nil {
r, err := o.Client.Get(req.Req.URL) r, err := o.Client.Get(req.Req.URL)
switch { if err != nil {
case err != nil: o.Log.Warn("oracle request failed", zap.String("url", req.Req.URL), zap.Error(err))
resp.Code = transaction.Error resp.Code = transaction.Error
case r.StatusCode == http.StatusOK: break
}
switch r.StatusCode {
case http.StatusOK:
result, err := readResponse(r.Body, transaction.MaxOracleResultSize) result, err := readResponse(r.Body, transaction.MaxOracleResultSize)
if err != nil { if err != nil {
if errors.Is(err, ErrResponseTooLarge) { if errors.Is(err, ErrResponseTooLarge) {
@ -119,30 +126,36 @@ func (o *Oracle) processRequest(priv *keys.PrivateKey, req request) error {
} else { } else {
resp.Code = transaction.Error resp.Code = transaction.Error
} }
o.Log.Warn("failed to read data for oracle request", zap.String("url", req.Req.URL), zap.Error(err))
break break
} }
resp.Code, resp.Result = filterRequest(result, req.Req) resp.Code, resp.Result = filterRequest(result, req.Req)
case r.StatusCode == http.StatusForbidden: case http.StatusForbidden:
resp.Code = transaction.Forbidden resp.Code = transaction.Forbidden
case r.StatusCode == http.StatusNotFound: case http.StatusNotFound:
resp.Code = transaction.NotFound resp.Code = transaction.NotFound
case r.StatusCode == http.StatusRequestTimeout: case http.StatusRequestTimeout:
resp.Code = transaction.Timeout resp.Code = transaction.Timeout
default: default:
resp.Code = transaction.Error resp.Code = transaction.Error
} }
} case neofs.URIScheme:
} else if err == nil && u.Scheme == neofs.URIScheme {
ctx, cancel := context.WithTimeout(context.Background(), time.Duration(o.MainCfg.NeoFS.Timeout)*time.Millisecond) ctx, cancel := context.WithTimeout(context.Background(), time.Duration(o.MainCfg.NeoFS.Timeout)*time.Millisecond)
defer cancel() defer cancel()
index := (int(req.ID) + incTx.attempts) % len(o.MainCfg.NeoFS.Nodes) index := (int(req.ID) + incTx.attempts) % len(o.MainCfg.NeoFS.Nodes)
res, err := neofs.Get(ctx, priv, u, o.MainCfg.NeoFS.Nodes[index]) res, err := neofs.Get(ctx, priv, u, o.MainCfg.NeoFS.Nodes[index])
if err != nil { if err != nil {
o.Log.Warn("oracle request failed", zap.String("url", req.Req.URL), zap.Error(err))
resp.Code = transaction.Error resp.Code = transaction.Error
} else { } else {
resp.Code, resp.Result = filterRequest(res, req.Req) resp.Code, resp.Result = filterRequest(res, req.Req)
} }
default:
resp.Code = transaction.ProtocolNotSupported
o.Log.Warn("unknown oracle request scheme", zap.String("url", req.Req.URL))
} }
}
o.Log.Debug("oracle request processed", zap.String("url", req.Req.URL), zap.Int("code", int(resp.Code)), zap.String("result", string(resp.Result)))
currentHeight := o.Chain.BlockHeight() currentHeight := o.Chain.BlockHeight()
_, h, err := o.Chain.GetTransaction(req.Req.OriginalTxID) _, h, err := o.Chain.GetTransaction(req.Req.OriginalTxID)