2017-10-05 01:44:58 +06:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
2018-09-07 23:41:06 +06:00
|
|
|
"log"
|
2017-10-05 01:44:58 +06: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 23:41:06 +06:00
|
|
|
|
|
|
|
func warning(f string, args ...interface{}) {
|
2018-09-07 23:49:46 +06:00
|
|
|
log.Printf("\033[1;33m[WARNING]\033[0m %s", fmt.Sprintf(f, args...))
|
2018-09-07 23:41:06 +06:00
|
|
|
}
|