1
0
mirror of https://github.com/imgproxy/imgproxy.git synced 2025-01-08 10:45:04 +02:00
imgproxy/errors.go

46 lines
960 B
Go
Raw Normal View History

2017-10-04 21:44:58 +02:00
package main
import (
"fmt"
2018-09-07 19:41:06 +02:00
"log"
2017-10-04 21:44:58 +02:00
"runtime"
"strings"
)
type imgproxyError struct {
StatusCode int
Message string
PublicMessage string
}
func (e imgproxyError) Error() string {
return e.Message
}
func newError(status int, msg string, pub string) imgproxyError {
return imgproxyError{status, msg, pub}
}
func newUnexpectedError(err error, skip int) imgproxyError {
msg := fmt.Sprintf("Unexpected error: %s\n%s", err, stacktrace(skip+1))
return imgproxyError{500, msg, "Internal error"}
}
func stacktrace(skip int) string {
callers := make([]uintptr, 10)
n := runtime.Callers(skip+1, callers)
lines := make([]string, n)
for i, pc := range callers[:n] {
f := runtime.FuncForPC(pc)
file, line := f.FileLine(pc)
lines[i] = fmt.Sprintf("%s:%d %s", file, line, f.Name())
}
return strings.Join(lines, "\n")
}
2018-09-07 19:41:06 +02:00
func warning(f string, args ...interface{}) {
2018-09-07 19:49:46 +02:00
log.Printf("\033[1;33m[WARNING]\033[0m %s", fmt.Sprintf(f, args...))
2018-09-07 19:41:06 +02:00
}