2020-04-02 02:29:14 +03:00
|
|
|
package eventsubscribers
|
|
|
|
|
|
|
|
import (
|
|
|
|
"net"
|
2020-04-02 19:34:39 +03:00
|
|
|
"net/http"
|
2020-04-02 02:29:14 +03:00
|
|
|
"net/url"
|
2020-04-03 17:18:02 +03:00
|
|
|
"strings"
|
2020-04-02 02:29:14 +03:00
|
|
|
"syscall"
|
|
|
|
|
|
|
|
"github.com/mono83/slf"
|
|
|
|
"github.com/mono83/slf/wd"
|
|
|
|
|
|
|
|
"github.com/elyby/chrly/api/mojang"
|
|
|
|
)
|
|
|
|
|
|
|
|
type Logger struct {
|
|
|
|
slf.Logger
|
|
|
|
}
|
|
|
|
|
2020-04-03 22:20:56 +03:00
|
|
|
func (l *Logger) ConfigureWithDispatcher(d Subscriber) {
|
2020-04-02 19:34:39 +03:00
|
|
|
d.Subscribe("skinsystem:after_request", l.handleAfterSkinsystemRequest)
|
|
|
|
|
2020-04-02 02:29:14 +03:00
|
|
|
d.Subscribe("mojang_textures:usernames:after_call", l.createMojangTexturesErrorHandler("usernames"))
|
|
|
|
d.Subscribe("mojang_textures:textures:after_call", l.createMojangTexturesErrorHandler("textures"))
|
|
|
|
}
|
|
|
|
|
2020-04-02 19:34:39 +03:00
|
|
|
func (l *Logger) handleAfterSkinsystemRequest(req *http.Request, statusCode int) {
|
2020-04-03 17:18:02 +03:00
|
|
|
path := req.URL.Path
|
|
|
|
if req.URL.RawQuery != "" {
|
|
|
|
path += "?" + req.URL.RawQuery
|
2020-04-02 19:34:39 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
l.Info(
|
2020-04-03 17:18:02 +03:00
|
|
|
":ip - - \":method :path\" :statusCode - \":userAgent\" \":forwardedIp\"",
|
|
|
|
wd.StringParam("ip", trimPort(req.RemoteAddr)),
|
2020-04-02 19:34:39 +03:00
|
|
|
wd.StringParam("method", req.Method),
|
2020-04-03 17:18:02 +03:00
|
|
|
wd.StringParam("path", path),
|
2020-04-02 19:34:39 +03:00
|
|
|
wd.IntParam("statusCode", statusCode),
|
|
|
|
wd.StringParam("userAgent", req.UserAgent()),
|
2020-04-03 17:18:02 +03:00
|
|
|
wd.StringParam("forwardedIp", req.Header.Get("X-Forwarded-For")),
|
2020-04-02 19:34:39 +03:00
|
|
|
)
|
|
|
|
}
|
|
|
|
|
2020-04-02 02:29:14 +03:00
|
|
|
func (l *Logger) createMojangTexturesErrorHandler(provider string) func(identity string, result interface{}, err error) {
|
|
|
|
providerParam := wd.NameParam(provider)
|
|
|
|
return func(identity string, result interface{}, err error) {
|
|
|
|
if err == nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
errParam := wd.ErrParam(err)
|
|
|
|
|
|
|
|
switch err.(type) {
|
|
|
|
case *mojang.BadRequestError:
|
|
|
|
l.logMojangTexturesWarning(providerParam, errParam)
|
|
|
|
return
|
|
|
|
case *mojang.ForbiddenError:
|
|
|
|
l.logMojangTexturesWarning(providerParam, errParam)
|
|
|
|
return
|
|
|
|
case *mojang.TooManyRequestsError:
|
|
|
|
l.logMojangTexturesWarning(providerParam, errParam)
|
|
|
|
return
|
|
|
|
case net.Error:
|
|
|
|
if err.(net.Error).Timeout() {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
if _, ok := err.(*url.Error); ok {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
if opErr, ok := err.(*net.OpError); ok && (opErr.Op == "dial" || opErr.Op == "read") {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
if err == syscall.ECONNREFUSED {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
l.Error(":name: Unexpected Mojang response error: :err", providerParam, errParam)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (l *Logger) logMojangTexturesWarning(providerParam slf.Param, errParam slf.Param) {
|
|
|
|
l.Warning(":name: :err", providerParam, errParam)
|
|
|
|
}
|
2020-04-03 17:18:02 +03:00
|
|
|
|
|
|
|
func trimPort(ip string) string {
|
|
|
|
// Don't care about possible -1 result because RemoteAddr will always contain ip and port
|
|
|
|
cutTo := strings.LastIndexByte(ip, ':')
|
|
|
|
|
|
|
|
return ip[0:cutTo]
|
|
|
|
}
|