mirror of
https://github.com/kataras/iris.git
synced 2025-01-24 19:21:03 +01:00
46 lines
1.1 KiB
Go
46 lines
1.1 KiB
Go
|
package recovery
|
||
|
|
||
|
import (
|
||
|
"io"
|
||
|
"os"
|
||
|
"time"
|
||
|
|
||
|
"github.com/kataras/iris"
|
||
|
)
|
||
|
|
||
|
type recovery struct {
|
||
|
//out optional output to log any panics
|
||
|
out io.Writer
|
||
|
}
|
||
|
|
||
|
func (r recovery) Serve(ctx *iris.Context) {
|
||
|
defer func() {
|
||
|
if err := recover(); err != nil {
|
||
|
r.out.Write([]byte("[" + time.Now().String() + "]Recovery from panic \n"))
|
||
|
//ctx.Panic just sends http status 500 by default, but you can change it by: iris.OnPanic(func( c *iris.Context){})
|
||
|
ctx.Panic()
|
||
|
}
|
||
|
}()
|
||
|
ctx.Next()
|
||
|
}
|
||
|
|
||
|
// Recovery restores the server on internal server errors (panics)
|
||
|
// receives an optional writer, the default is the os.Stderr if no out writer given
|
||
|
// returns the middleware as iris.Handler
|
||
|
// same as New(...)
|
||
|
func Recovery(out ...io.Writer) iris.Handler {
|
||
|
r := recovery{os.Stderr}
|
||
|
if out != nil && len(out) == 1 {
|
||
|
r.out = out[0]
|
||
|
}
|
||
|
return r
|
||
|
}
|
||
|
|
||
|
// New restores the server on internal server errors (panics)
|
||
|
// receives an optional writer, the default is the os.Stderr if no out writer given
|
||
|
// returns the middleware as iris.Handler
|
||
|
// same as Recovery(...)
|
||
|
func New(out ...io.Writer) iris.Handler {
|
||
|
return Recovery(out...)
|
||
|
}
|