Update errors and error messages

This commit is contained in:
Tobie Morgan Hitchcock 2016-07-16 14:44:48 +01:00
parent d16d9cab48
commit 2334d9f7a1
3 changed files with 24 additions and 28 deletions

View file

@ -120,16 +120,16 @@ func status(e error) interface{} {
switch e.(type) { switch e.(type) {
default: default:
return "OK" return "OK"
case error:
return "ERR"
case *kvs.DBError: case *kvs.DBError:
return "ERR_DB" return "ERR_DB"
case *kvs.TXError: case *kvs.TXError:
return "ERR_DB" return "ERR_TX"
case *kvs.CKError: case *kvs.CKError:
return "ERR_CK" return "ERR_CK"
case *kvs.KVError: case *kvs.KVError:
return "ERR_EXISTS" return "ERR_KV"
case error:
return "ERR"
} }
} }
@ -139,14 +139,6 @@ func detail(e error) interface{} {
return nil return nil
case error: case error:
return err.Error() return err.Error()
case *kvs.DBError:
return "A database error occured"
case *kvs.TXError:
return "A database error occured"
case *kvs.CKError:
return "A cipherkey error occured"
case *kvs.KVError:
return "The item already exists"
} }
} }

View file

@ -35,7 +35,7 @@ type DBError struct {
// Error returns the string representation of the error. // Error returns the string representation of the error.
func (e *DBError) Error() string { func (e *DBError) Error() string {
return fmt.Sprintf("There was a problem performing a read or write with the database: %s", e.Err.Error()) return fmt.Sprintf("There was a problem writing to the database")
} }
// TXError is an error which occurs when there is a // TXError is an error which occurs when there is a
@ -46,7 +46,7 @@ type TXError struct {
// Error returns the string representation of the error. // Error returns the string representation of the error.
func (e *TXError) Error() string { func (e *TXError) Error() string {
return fmt.Sprintf("There was a problem performing a read or write with the transaction: %s", e.Err.Error()) return fmt.Sprintf("There was a problem with the transaction")
} }
// CKError is an error which occurs when there is a // CKError is an error which occurs when there is a
@ -57,7 +57,7 @@ type CKError struct {
// Error returns the string representation of the error. // Error returns the string representation of the error.
func (e *CKError) Error() string { func (e *CKError) Error() string {
return fmt.Sprintf("There was a problem performing a read or write with the cipherkey: %s", e.Err.Error()) return fmt.Sprintf("This cipherkey used is not valid")
} }
// KVError is an error which occurs when there is a // KVError is an error which occurs when there is a
@ -71,5 +71,5 @@ type KVError struct {
// Error returns the string representation of the error. // Error returns the string representation of the error.
func (e *KVError) Error() string { func (e *KVError) Error() string {
return fmt.Sprintf("Key `%s` already exists. Expecting `%s`, but found `%s`", e.Key, e.Exp, e.Val) return fmt.Sprintf("Database record already exists.")
} }

View file

@ -24,9 +24,13 @@ func output(c *fibre.Context, res interface{}) error {
case "OK": case "OK":
return c.Send(200, ret.Result) return c.Send(200, ret.Result)
case "ERR_DB": case "ERR_DB":
return fibre.NewHTTPError(503)
case "ERR_TX":
return fibre.NewHTTPError(500) return fibre.NewHTTPError(500)
case "ERR_EXISTS": case "ERR_KV":
return fibre.NewHTTPError(409) return fibre.NewHTTPError(409)
case "ERR_CK":
return fibre.NewHTTPError(403)
default: default:
return fibre.NewHTTPError(400) return fibre.NewHTTPError(400)
} }
@ -73,8 +77,8 @@ func routes(s *fibre.Fibre) {
s.Post("/sql", func(c *fibre.Context) error { s.Post("/sql", func(c *fibre.Context) error {
res, err := db.Execute(c, c.Request().Body) res, err := db.Execute(c, c.Request().Body)
if err != nil { if err != nil {
return c.Send(400, map[string]interface{}{ return c.Send(500, map[string]interface{}{
"code": 400, "code": 500,
"details": "Request problems detected", "details": "Request problems detected",
"documentation": "https://docs.surreal.io/", "documentation": "https://docs.surreal.io/",
"information": err.Error(), "information": err.Error(),
@ -95,7 +99,7 @@ func routes(s *fibre.Fibre) {
sql := db.Prepare("SELECT * FROM ⟨%v⟩", c.Param("class")) sql := db.Prepare("SELECT * FROM ⟨%v⟩", c.Param("class"))
res, err := db.Execute(c, sql) res, err := db.Execute(c, sql)
if err != nil { if err != nil {
return fibre.NewHTTPError(400) return fibre.NewHTTPError(500)
} }
return output(c, res[0]) return output(c, res[0])
}) })
@ -104,7 +108,7 @@ func routes(s *fibre.Fibre) {
sql := db.Prepare("CREATE ⟨%v⟩ CONTENT %v RETURN AFTER", c.Param("class"), string(c.Body())) sql := db.Prepare("CREATE ⟨%v⟩ CONTENT %v RETURN AFTER", c.Param("class"), string(c.Body()))
res, err := db.Execute(c, sql) res, err := db.Execute(c, sql)
if err != nil { if err != nil {
return fibre.NewHTTPError(400) return fibre.NewHTTPError(500)
} }
return output(c, res[0]) return output(c, res[0])
}) })
@ -113,7 +117,7 @@ func routes(s *fibre.Fibre) {
sql := db.Prepare("DELETE FROM ⟨%v⟩", c.Param("class")) sql := db.Prepare("DELETE FROM ⟨%v⟩", c.Param("class"))
res, err := db.Execute(c, sql) res, err := db.Execute(c, sql)
if err != nil { if err != nil {
return fibre.NewHTTPError(400) return fibre.NewHTTPError(500)
} }
return output(c, res[0]) return output(c, res[0])
}) })
@ -130,7 +134,7 @@ func routes(s *fibre.Fibre) {
sql := db.Prepare("SELECT * FROM @⟨%v⟩:⟨%v⟩", c.Param("class"), c.Param("id")) sql := db.Prepare("SELECT * FROM @⟨%v⟩:⟨%v⟩", c.Param("class"), c.Param("id"))
res, err := db.Execute(c, sql) res, err := db.Execute(c, sql)
if err != nil { if err != nil {
return fibre.NewHTTPError(400) return fibre.NewHTTPError(500)
} }
return output(c, res[0]) return output(c, res[0])
}) })
@ -139,7 +143,7 @@ func routes(s *fibre.Fibre) {
sql := db.Prepare("CREATE @⟨%v⟩:⟨%v⟩ CONTENT %v RETURN AFTER", c.Param("class"), c.Param("id"), string(c.Body())) sql := db.Prepare("CREATE @⟨%v⟩:⟨%v⟩ CONTENT %v RETURN AFTER", c.Param("class"), c.Param("id"), string(c.Body()))
res, err := db.Execute(c, sql) res, err := db.Execute(c, sql)
if err != nil { if err != nil {
return fibre.NewHTTPError(400) return fibre.NewHTTPError(500)
} }
return output(c, res[0]) return output(c, res[0])
}) })
@ -148,7 +152,7 @@ func routes(s *fibre.Fibre) {
sql := db.Prepare("UPDATE @⟨%v⟩:⟨%v⟩ CONTENT %v RETURN AFTER", c.Param("class"), c.Param("id"), string(c.Body())) sql := db.Prepare("UPDATE @⟨%v⟩:⟨%v⟩ CONTENT %v RETURN AFTER", c.Param("class"), c.Param("id"), string(c.Body()))
res, err := db.Execute(c, sql) res, err := db.Execute(c, sql)
if err != nil { if err != nil {
return fibre.NewHTTPError(400) return fibre.NewHTTPError(500)
} }
return output(c, res[0]) return output(c, res[0])
}) })
@ -157,7 +161,7 @@ func routes(s *fibre.Fibre) {
sql := db.Prepare("MODIFY @⟨%v⟩:⟨%v⟩ DIFF %v RETURN AFTER", c.Param("class"), c.Param("id"), string(c.Body())) sql := db.Prepare("MODIFY @⟨%v⟩:⟨%v⟩ DIFF %v RETURN AFTER", c.Param("class"), c.Param("id"), string(c.Body()))
res, err := db.Execute(c, sql) res, err := db.Execute(c, sql)
if err != nil { if err != nil {
return fibre.NewHTTPError(400) return fibre.NewHTTPError(500)
} }
return output(c, res[0]) return output(c, res[0])
}) })
@ -166,7 +170,7 @@ func routes(s *fibre.Fibre) {
sql := db.Prepare("SELECT HISTORY FROM @⟨%v⟩:⟨%v⟩", c.Param("class"), c.Param("id")) sql := db.Prepare("SELECT HISTORY FROM @⟨%v⟩:⟨%v⟩", c.Param("class"), c.Param("id"))
res, err := db.Execute(c, sql) res, err := db.Execute(c, sql)
if err != nil { if err != nil {
return fibre.NewHTTPError(400) return fibre.NewHTTPError(500)
} }
return output(c, res[0]) return output(c, res[0])
}) })
@ -175,7 +179,7 @@ func routes(s *fibre.Fibre) {
sql := db.Prepare("DELETE @⟨%v⟩:⟨%v⟩", c.Param("class"), c.Param("id")) sql := db.Prepare("DELETE @⟨%v⟩:⟨%v⟩", c.Param("class"), c.Param("id"))
res, err := db.Execute(c, sql) res, err := db.Execute(c, sql)
if err != nil { if err != nil {
return fibre.NewHTTPError(400) return fibre.NewHTTPError(500)
} }
return output(c, res[0]) return output(c, res[0])
}) })