Skip to content

Advanced: asynchronous support

Manabu Nakamura edited this page Jun 5, 2013 · 8 revisions

Asynchronous Libraries Support

This feature is available from 0.10-SNAPSHOT!

You can use asynchronous libraries ( for example: ReactiveMongo ) for User resolver.

trait AuthConfigImpl extends AuthConfig {

  ...snip

  def resolveUser(id: Id): Option[User] = throw new AssertionError("dont use!")

  override def resolveUserAsync(id: Id)(implicit context: ExecutionContext): Future[Option[User]] = 
    collection.find(BSONDocument("id" -> id)).cursor[User].headOption()

}

AuthElement trait use the resolveUserAsync method always.

Old Style

If you use old style ( that Auth trait was used ), you can use AsyncAuth insted of Auth.

trait Messages extends Controller with AsyncAuth with AuthConfigImpl {

  import scala.concurrent.ExecutionContext.Implicits.global

  def main = authorizedAction(NormalUser) { user => request =>
    val title = "message main"
    Ok(html.message.main(title))
  }

  def list = authorizedAction(NormalUser) { user => request =>
    val title = "all messages"
    Ok(html.message.list(title))
  }

}

Clone this wiki locally