error logging with schiavo -> error logging with sentry

This commit is contained in:
Howl 2016-06-16 12:45:10 +02:00
parent 24d34eb741
commit 06eb64ecf5
3 changed files with 17 additions and 28 deletions

View File

@ -1,27 +0,0 @@
package app
import (
"fmt"
"git.zxq.co/ripple/schiavolib"
"github.com/fatih/color"
"github.com/gin-gonic/gin"
)
// ErrorHandler is a middleware for gin that takes care of calls to c.Error().
func ErrorHandler() gin.HandlerFunc {
return func(c *gin.Context) {
c.Next()
errs := c.Errors.Errors()
if len(errs) != 0 {
color.Red("!!! ERRORS OCCURRED !!!")
var out string
out += fmt.Sprintf("==> %s %s\n", c.Request.Method, c.Request.URL.Path)
for _, err := range errs {
out += fmt.Sprintf("===> %s\n", err)
}
color.Red(out)
go schiavo.Bunker.Send("Errors occurred:\n```\n" + out + "```")
}
}
}

View File

@ -2,12 +2,15 @@ package app
import (
"database/sql"
"fmt"
"git.zxq.co/ripple/rippleapi/app/internals"
"git.zxq.co/ripple/rippleapi/app/peppy"
"git.zxq.co/ripple/rippleapi/app/v1"
"git.zxq.co/ripple/rippleapi/common"
"github.com/getsentry/raven-go"
"github.com/gin-gonic/contrib/gzip"
"github.com/gin-gonic/contrib/sentry"
"github.com/gin-gonic/gin"
)
@ -17,7 +20,16 @@ var db *sql.DB
func Start(conf common.Conf, dbO *sql.DB) *gin.Engine {
db = dbO
r := gin.Default()
r.Use(gzip.Gzip(gzip.DefaultCompression), ErrorHandler())
r.Use(gzip.Gzip(gzip.DefaultCompression))
if conf.SentryDSN != "" {
ravenClient, err := raven.New(conf.SentryDSN)
if err != nil {
fmt.Println(err)
} else {
r.Use(sentry.Recovery(ravenClient, false))
}
}
api := r.Group("/api")
{
@ -80,6 +92,9 @@ func Start(conf common.Conf, dbO *sql.DB) *gin.Engine {
}
api.GET("/status", internals.Status)
api.GET("/errore_meme", func(c *gin.Context) {
c.Error(fmt.Errorf("This is a test error!"))
})
// peppyapi
api.GET("/get_user", PeppyMethod(peppy.GetUser))

View File

@ -13,6 +13,7 @@ type Conf struct {
DSN string `description:"The Data Source Name for the database. More: https://github.com/go-sql-driver/mysql#dsn-data-source-name"`
ListenTo string `description:"The IP/Port combination from which to take connections, e.g. :8080"`
Unix bool `description:"Bool indicating whether ListenTo is a UNIX socket or an address."`
SentryDSN string `description:"thing for sentry whatever"`
}
var cachedConf *Conf