From ace4c6bee062d463ee2bad8cba344e8dbf2f254f Mon Sep 17 00:00:00 2001 From: Morgan Bazalgette Date: Tue, 18 Apr 2017 21:13:31 +0200 Subject: [PATCH] make sure panics don't slip out of websockets --- app/websockets/main_handler.go | 1 + app/websockets/scores.go | 9 +++++++++ 2 files changed, 10 insertions(+) diff --git a/app/websockets/main_handler.go b/app/websockets/main_handler.go index 74cb995..632d3ae 100644 --- a/app/websockets/main_handler.go +++ b/app/websockets/main_handler.go @@ -12,6 +12,7 @@ import ( var stepNumber uint64 func handler(rawConn *websocket.Conn) { + defer catchPanic() defer rawConn.Close() step := atomic.AddUint64(&stepNumber, 1) diff --git a/app/websockets/scores.go b/app/websockets/scores.go index c6af733..910c250 100644 --- a/app/websockets/scores.go +++ b/app/websockets/scores.go @@ -75,6 +75,7 @@ type score struct { } func handleNewScore(id string) { + defer catchPanic() var s score err := db.Get(&s, ` SELECT @@ -131,3 +132,11 @@ func inModes(modes []int, i int) bool { } return false } + +func catchPanic() { + r := recover() + if r != nil { + fmt.Println(r) + // TODO: sentry + } +}