mirror of
https://github.com/imgproxy/imgproxy.git
synced 2025-01-08 10:45:04 +02:00
46 lines
965 B
Go
46 lines
965 B
Go
package main
|
|
|
|
import (
|
|
"fmt"
|
|
"log"
|
|
"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")
|
|
}
|
|
|
|
func warning(f string, args ...interface{}) {
|
|
log.Printf("\033[1;33m[WARNING]\033[0m %s", fmt.Sprintf(f, args...))
|
|
}
|