forked from TrueCloudLab/neoneo-go
oracle: add logging, refactor request processing a bit
And return more appropriate errors in some cases.
This commit is contained in:
parent
d2f7f00997
commit
f69fd34220
1 changed files with 37 additions and 24 deletions
|
@ -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)
|
||||||
|
|
Loading…
Reference in a new issue