forked from lichess-org/lila
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathGlobal.scala
50 lines (41 loc) · 1.57 KB
/
Global.scala
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
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 (Env.ai.isServer) {
if (req.path startsWith "/ai/") super.onRouteRequest(req)
else 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.isServer || (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 (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))
}