51 lines
1.6 KiB
Scala
51 lines
1.6 KiB
Scala
package lila.app
|
|
|
|
import play.api.mvc._
|
|
import play.api.mvc.Results._
|
|
import play.api.{ Application, GlobalSettings, Mode }
|
|
|
|
import lila.hub.actorApi.monitor.AddRequest
|
|
|
|
object Global extends GlobalSettings {
|
|
|
|
override def onStart(app: Application) {
|
|
lila.app.Env.current
|
|
}
|
|
|
|
override def onRouteRequest(req: RequestHeader): Option[Handler] =
|
|
if (req.path startsWith "/ai/") super.onRouteRequest(req)
|
|
else if (Env.ai.ServerOnly) {
|
|
Action(NotFound("I am an AI server")).some
|
|
}
|
|
else {
|
|
Env.monitor.reporting ! AddRequest
|
|
// Env.security.wiretap(req)
|
|
// Env.security.firewall.requestHandler(req).await orElse
|
|
Env.i18n.requestHandler(req) orElse super.onRouteRequest(req)
|
|
}
|
|
|
|
private def niceError(req: RequestHeader): Boolean = req.method == "GET" && {
|
|
Env.ai.ServerOnly || (lila.common.HTTPRequest isSynchronousHttp req)
|
|
}
|
|
|
|
override def onHandlerNotFound(req: RequestHeader) =
|
|
if (niceError(req)) controllers.Lobby.handleStatus(req, Results.NotFound)
|
|
else fuccess(NotFound)
|
|
|
|
override def onBadRequest(req: RequestHeader, error: String) =
|
|
if (error startsWith "Illegal character in path") fuccess(Redirect("/"))
|
|
else if (niceError(req)) {
|
|
logwarn("[global] bad request: " + error)
|
|
controllers.Lobby.handleStatus(req, Results.BadRequest)
|
|
}
|
|
else fuccess(BadRequest(error))
|
|
|
|
override def onError(req: RequestHeader, ex: Throwable) =
|
|
if (niceError(req)) {
|
|
if (lila.common.PlayApp.isProd)
|
|
fuccess(InternalServerError(views.html.base.errorPage(ex)(lila.api.Context(req))))
|
|
else super.onError(req, ex)
|
|
}
|
|
else fuccess(InternalServerError(ex.getMessage))
|
|
}
|