我正在尝试扩展 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 中的标志,还是我不知道的东西?