Update errors and error messages
This commit is contained in:
parent
d16d9cab48
commit
2334d9f7a1
3 changed files with 24 additions and 28 deletions
16
db/db.go
16
db/db.go
|
@ -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"
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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.")
|
||||||
}
|
}
|
||||||
|
|
|
@ -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])
|
||||||
})
|
})
|
||||||
|
|
Loading…
Reference in a new issue