2019-01-30 17:00:00 -05:00
|
|
|
// Copyright 2013 Martini Authors
|
|
|
|
// Copyright 2014 The Macaron Authors
|
|
|
|
// Copyright 2019 The Gitea Authors. All rights reserved.
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License"): you may
|
|
|
|
// not use this file except in compliance with the License. You may obtain
|
|
|
|
// a copy of the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
|
|
// WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
|
|
// License for the specific language governing permissions and limitations
|
|
|
|
// under the License.
|
|
|
|
|
|
|
|
package context
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
|
2019-04-02 03:48:31 -04:00
|
|
|
"code.gitea.io/gitea/modules/log"
|
2019-01-30 17:00:00 -05:00
|
|
|
macaron "gopkg.in/macaron.v1"
|
|
|
|
)
|
|
|
|
|
|
|
|
// Recovery returns a middleware that recovers from any panics and writes a 500 and a log if so.
|
|
|
|
// Although similar to macaron.Recovery() the main difference is that this error will be created
|
|
|
|
// with the gitea 500 page.
|
|
|
|
func Recovery() macaron.Handler {
|
|
|
|
return func(ctx *Context) {
|
|
|
|
defer func() {
|
|
|
|
if err := recover(); err != nil {
|
2019-04-02 03:48:31 -04:00
|
|
|
combinedErr := fmt.Errorf("%s\n%s", err, string(log.Stack(2)))
|
2019-01-30 17:00:00 -05:00
|
|
|
ctx.ServerError("PANIC:", combinedErr)
|
|
|
|
}
|
|
|
|
}()
|
|
|
|
|
|
|
|
ctx.Next()
|
|
|
|
}
|
|
|
|
}
|