[英]How to use imports and implicits in Play Framework's routes file?
routes
文件的范围是什么,以查找implicit
的routes
,如PathBindable
或QueryStringBindable
?
对于自定义类型,只需在伴随对象中定义它们就像下面这样简单:
case class Foo(data: String)
object Foo {
implicit val pathBinder: PathBindable[Foo] = ???
}
但是,对于现有类型,由于我们无法在此处执行任何自定义import
,因此不清楚routes
文件在何处声明隐式。
那么, 路由文件的含义范围是什么?
这并没有直接回答这个问题,但似乎相关......
您可以在自定义的进口routes
通过添加到文件routesImport
在关键build.sbt
例如:
import play.PlayImport.PlayKeys._
routesImport += "my.custom.package.Foo._"
该片段是从我刚才写的一篇名为Using Play-Framework的PathBindable的博客文章中借来的
我们有一个queryStringBindable,我们需要使用并有类似的情况,我们发现这个问题给了我们一个线索,但colinjwebb的答案已经过时了。
这是我们的示例,从字符串到Option [LoginContext]。
package controllers
import play.api.mvc.{Action, AnyContent, QueryStringBindable, Request}
...
object BindableLoginContext {
implicit def queryStringBindable(implicit stringBinder: QueryStringBindable[String]) = new QueryStringBindable[LoginContext] {
override def bind(key: String, params: Map[String, Seq[String]]): Option[Either[String, LoginContext]] =
for {
loginContextString <- stringBinder.bind(key, params)
} yield {
loginContextString match {
case Right(value) if value.toLowerCase == "web" => Right(LoginContexts.Web)
case Right(value) if value.toLowerCase == "api" => Right(LoginContexts.Api)
case _ => Left(s"Unable to bind a loginContext from $key")
}
}
override def unbind(key: String, loginContext: LoginContext): String = stringBinder.unbind(key, loginContext.toString)
}
}
要使用它,我们需要使用以下导入:
import play.sbt.routes.RoutesKeys
然后像这样将对象添加到项目中
lazy val microservice = Project(appName, file("."))
.settings(
RoutesKeys.routesImport += "controllers.BindableLoginContext._"
)
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.