From ff8a2f03a996bfefaa0f57e85e82026b5a3c91df Mon Sep 17 00:00:00 2001 From: Tobie Morgan Hitchcock Date: Wed, 14 Sep 2016 22:33:09 +0100 Subject: [PATCH] Improve http error messages --- web/err.go | 45 ++++++++++++++++++++++----------------------- web/routes.go | 15 +++++++++++++-- 2 files changed, 35 insertions(+), 25 deletions(-) diff --git a/web/err.go b/web/err.go index f55283c5..69ce2e94 100644 --- a/web/err.go +++ b/web/err.go @@ -17,44 +17,43 @@ package web import ( "github.com/abcum/fibre" "github.com/abcum/surreal/kvs" + "github.com/abcum/surreal/sql" ) func errors(err error, c *fibre.Context) { - code := 500 - text := err.Error() + var code int + var text string + var info map[string]interface{} - switch err.(type) { + switch e := err.(type) { default: - err = fibre.NewHTTPError(400, text) + code = 400 case *kvs.DBError: - err = fibre.NewHTTPError(503, text) + code, text = 503, e.Error() case *kvs.TXError: - err = fibre.NewHTTPError(500, text) + code, text = 500, e.Error() case *kvs.KVError: - err = fibre.NewHTTPError(409, text) + code, text = 409, e.Error() case *kvs.CKError: - err = fibre.NewHTTPError(403, text) - } - - if e, ok := err.(*fibre.HTTPError); ok { + code, text = 403, e.Error() + case *sql.ParseError: + code, text = 400, e.Error() + case *fibre.HTTPError: code = e.Code() - text = e.Error() } - switch c.Type() { - default: - c.Text(code, text) - case "application/json": - info := errs[code] - info["information"] = text - c.JSON(code, info) - case "application/msgpack": - info := errs[code] - info["information"] = text - c.PACK(code, info) + if _, ok := errs[code]; !ok { + code = 500 } + info = errs[code] + if text != "" { + info["information"] = text + } + + c.Send(code, info) + } var errs = map[int]map[string]interface{}{ diff --git a/web/routes.go b/web/routes.go index 711df547..4d8ea241 100644 --- a/web/routes.go +++ b/web/routes.go @@ -17,10 +17,20 @@ package web import ( "github.com/abcum/fibre" "github.com/abcum/surreal/db" + "github.com/abcum/surreal/sql" ) -func output(c *fibre.Context, res interface{}) error { - switch ret := res.(*db.Response); ret.Status { +func output(c *fibre.Context, err error, res []*db.Response) error { + + if err != nil { + return fibre.NewHTTPError(500) + } + + if len(res) == 0 { + return fibre.NewHTTPError(500) + } + + switch ret := res[0]; ret.Status { case "OK": return c.Send(200, ret.Result) case "ERR_DB": @@ -34,6 +44,7 @@ func output(c *fibre.Context, res interface{}) error { default: return fibre.NewHTTPError(400) } + } func routes(s *fibre.Fibre) {