如何在Play Framework的路由文件中使用导入和隐含?

时间:2015-12-31 07:53:49

标签: scala playframework routes implicit

routes文件查找implicitPathBindableQueryStringBindable的范围是什么?

对于自定义类型,简单地在伴随对象中定义它们是很简单的,如下所示:

case class Foo(data: String)
object Foo {
  implicit val pathBinder: PathBindable[Foo] = ???
}

但是,对于现有类型,我们不清楚routes文件在哪里声明隐式,因为我们不能在此处执行任何自定义import

那么,路径文件的含义范围是什么?

2 个答案:

答案 0 :(得分:7)

这并没有直接回答这个问题,但似乎相关......

您可以添加routes

中的routesImport键,在build.sbt文件中添加自定义导入

例如:

import play.PlayImport.PlayKeys._

routesImport += "my.custom.package.Foo._"

该片段是从我刚才写的一篇名为Using Play-Framework's PathBindable

的博客文章中借来的

答案 1 :(得分:4)

我们有一个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._"
  )