cdf2f56981
This reverts commit2d3b4872c7
, reversing changes made to04f1d4ae6d
.
85 lines
2.9 KiB
Scala
85 lines
2.9 KiB
Scala
package controllers
|
|
|
|
import play.api.libs.json._
|
|
import play.api.mvc._
|
|
import scala.util.{ Success, Failure }
|
|
|
|
import lila.app._
|
|
import lila.common.HTTPRequest
|
|
import lila.fishnet.JsonApi.readers._
|
|
import lila.fishnet.JsonApi.writers._
|
|
import lila.fishnet.{ JsonApi, Work }
|
|
|
|
object Fishnet extends LilaController {
|
|
|
|
private def env = Env.fishnet
|
|
private def api = env.api
|
|
private val logger = lila.log("fishnet")
|
|
|
|
def acquire = ClientAction[JsonApi.Request.Acquire] { req => client =>
|
|
api acquire client map Right.apply
|
|
}
|
|
|
|
def move(workId: String) = ClientAction[JsonApi.Request.PostMove] { data => client =>
|
|
api.postMove(Work.Id(workId), client, data) >>
|
|
api.acquire(client).map(Right.apply)
|
|
}
|
|
|
|
def analysis(workId: String) = ClientAction[JsonApi.Request.PostAnalysis] { data => client =>
|
|
import lila.fishnet.FishnetApi._
|
|
def acquireNext = api acquire client map Right.apply
|
|
api.postAnalysis(Work.Id(workId), client, data).flatFold({
|
|
case WorkNotFound => acquireNext
|
|
case GameNotFound => acquireNext
|
|
case NotAcquired => acquireNext
|
|
case WeakAnalysis => acquireNext
|
|
// case WeakAnalysis => fuccess(Left(UnprocessableEntity("Not enough nodes per move")))
|
|
case e => fuccess(Left(InternalServerError(e.getMessage)))
|
|
}, {
|
|
case _: PostAnalysisResult.Complete => acquireNext
|
|
case _: PostAnalysisResult.Partial => fuccess(Left(NoContent))
|
|
case PostAnalysisResult.UnusedPartial => fuccess(Left(NoContent))
|
|
})
|
|
}
|
|
|
|
def abort(workId: String) = ClientAction[JsonApi.Request.Acquire] { req => client =>
|
|
api.abort(Work.Id(workId), client) inject Right(none)
|
|
}
|
|
|
|
def keyExists(key: String) = Action.async { req =>
|
|
api keyExists lila.fishnet.Client.Key(key) map {
|
|
case true => Ok
|
|
case false =>
|
|
val ip = HTTPRequest.lastRemoteAddress(req)
|
|
logger.info(s"Unauthorized key: $key ip: $ip")
|
|
NotFound
|
|
}
|
|
}
|
|
|
|
def status = Action.async {
|
|
api.status map { Ok(_) }
|
|
}
|
|
|
|
private def ClientAction[A <: JsonApi.Request](f: A => lila.fishnet.Client => Fu[Either[Result, Option[JsonApi.Work]]])(implicit reads: Reads[A]) =
|
|
Action.async(BodyParsers.parse.tolerantJson) { req =>
|
|
req.body.validate[A].fold(
|
|
err => {
|
|
logger.warn(s"Malformed request: $err\n${req.body}")
|
|
BadRequest(jsonError(JsError toJson err)).fuccess
|
|
},
|
|
data => api.authenticateClient(data, HTTPRequest lastRemoteAddress req) flatMap {
|
|
case Failure(msg) => {
|
|
val ip = HTTPRequest.lastRemoteAddress(req)
|
|
logger.info(s"Unauthorized key: ${data.fishnet.apikey} ip: $ip | ${msg.getMessage}")
|
|
Unauthorized(jsonError(msg.getMessage)).fuccess
|
|
}
|
|
case Success(client) => f(data)(client).map {
|
|
case Right(Some(work)) => Accepted(Json toJson work)
|
|
case Right(None) => NoContent
|
|
case Left(result) => result
|
|
}
|
|
}
|
|
)
|
|
}
|
|
}
|