lila/app/Global.scala
Thibault Duplessis cdf2f56981 Revert "Merge branch 'scala-2.12-play-2.6' of github.com:ornicar/lila"
This reverts commit 2d3b4872c7, reversing
changes made to 04f1d4ae6d.
2017-09-09 10:01:35 -05:00

69 lines
2.1 KiB
Scala

package lila.app
import lila.common.HTTPRequest
import play.api.mvc._
import play.api.mvc.Results._
import play.api.{ Application, GlobalSettings }
object Global extends GlobalSettings {
private val httpLogger = lila.log("http")
private def logHttp(code: Int, req: RequestHeader, exception: Option[Throwable] = None) = {
val message = s"$code ${HTTPRequest print req}"
exception match {
case Some(e) => httpLogger.warn(message, e)
case None => httpLogger.info(message)
}
}
override def onStart(app: Application) {
kamon.Kamon.start()
lila.app.Env.current
}
override def onStop(app: Application) {
kamon.Kamon.shutdown()
}
override def onRouteRequest(req: RequestHeader): Option[Handler] = {
lila.mon.http.request.all()
if (req.remoteAddress contains ":") lila.mon.http.request.ipv6()
lila.i18n.Env.current.subdomainKiller(req) orElse super.onRouteRequest(req)
}
private def niceError(req: RequestHeader): Boolean =
req.method == "GET" &&
HTTPRequest.isSynchronousHttp(req) &&
!HTTPRequest.hasFileExtension(req)
override def onHandlerNotFound(req: RequestHeader) = {
if (niceError(req)) {
logHttp(404, req)
controllers.Main.notFound(req)
} else fuccess(NotFound("404 - Resource not found"))
}
override def onBadRequest(req: RequestHeader, error: String) = {
logHttp(400, req)
if (error startsWith "Illegal character in path") fuccess(Redirect("/"))
else if (error startsWith "Cannot parse parameter") onHandlerNotFound(req)
else if (niceError(req)) {
lila.mon.http.response.code400()
controllers.Lobby.handleStatus(req, Results.BadRequest)
} else fuccess(BadRequest(error))
}
override def onError(req: RequestHeader, ex: Throwable) = {
logHttp(500, req, ex.some)
if (niceError(req)) {
if (lila.common.PlayApp.isProd) {
lila.mon.http.response.code500()
fuccess(InternalServerError(views.html.base.errorPage(ex) {
lila.api.Context(req, lila.app.Env.api.assetVersion.get, lila.i18n.defaultLang)
}))
} else super.onError(req, ex)
} else fuccess(InternalServerError(ex.getMessage))
}
}