0

我正在尝试扩展 pac4j-play 模块的 SecureAction,因为我想要验证一些额外的内容并将其添加到请求中,以便在控制器中轻松访问。

但是我遇到了类型不匹配的编译问题,我似乎无法理解为什么。

class SecureSiteAction[P<:CommonProfile, ContentType, R[X]>:AuthenticatedRequest[P, X]<:Request[X]](clients: String, authorizers: String, matchers: String, multiProfile: Boolean, parser: BodyParser[ContentType], playSessionStore: PlaySessionStore, config: Config)(implicit implicitExecutionContext: ExecutionContext)
  extends SecureAction[P, ContentType, R](clients, authorizers, matchers, multiProfile, parser, playSessionStore, config) {

  override def invokeBlock[A](request: Request[A], block: R[A] => Future[Result]): Future[Result] = {
    super.invokeBlock(request, { request: R[A] =>
      val site = Site(request.host)
      val profiles = request.asInstanceOf[AuthenticatedRequest[P, A]].profiles
      block(AuthenticatedSiteRequest(site, profiles, request))
    })
  }
}

case class AuthenticatedSiteRequest[P<:CommonProfile, +A](site: Site, profiles: List[P], request: Request[A]) extends WrappedRequest[A](request)

我已经从原始类中导入了类似import scala.language.higherKinds和其余部分的内容(请参阅https://github.com/pac4j/play-pac4j/blob/master/shared/src/main/scala/org/pac4j/play/scala/Security.斯卡拉)。SecureAction

以下行是问题:

block(AuthenticatedSiteRequest(site, profiles, request))

这给出了类型错误:

type mismatch;
[error]  found   : binders.AuthenticatedSiteRequest[P,A]
[error]  required: R[A]
[error]       block(AuthenticatedSiteRequest(site, profiles, request))

“有趣”的事情是,当我直接从 pac4j-play 的SecureAction案例类中复制/粘贴源代码到我的 IDE 中时,我得到了完全相同的编译错误。

什么可以使这个编译?它是 sbt 中的标志,还是我不知道的东西?

4

1 回答 1

0

您需要更改要使用的下限类型AuthenticatedSiteRequest,以便将一种类型参数固定到类的给定P参数SecureSiteAction

class SecureSiteAction[
    P <: CommonProfile, ContentType,
    R[X] >: AuthenticatedSiteRequest[P, X] <: Request[X]
  ] //      ^^^^^^^^^^^^^^^^^^^^^^^^ 

“有趣”的事情是,当我直接从 pac4j-play 的 SecureAction 案例类复制/粘贴源代码到我的 IDE 中时,我得到完全相同的编译错误。

这似乎是您的 IDE 的问题,可能是 IntelliJ?

于 2020-02-03T08:21:35.280 回答