Scala - 如何使用Futures

时间:2017-02-21 19:12:50

标签: java mongodb scala concurrency future

我正在开发一个我想要非阻塞的端点。此端点的目的非常简单,即将文档写入Mongo存储。我在Play 2.5.x应用中使用官方MongoDB Scala Driver

我的理解是MongoDB使用toFuture()方法支持Futures。 Source

问题是我的控制器中的处理方法希望解析为Future[Result]类型。但是,onComplete回调(或其他回调函数)仅返回类型Unit,从而导致编译错误。是否有任何替代模式用于这些情况?我有什么选择?

注意 - 我知道Play会在写入失败并自动抛出500时捕获异常。但在这种情况下,我想手动处理它

class WriteController extends Controller {

  def writeSingleEvent = Action.async { implicit request =>
    val mongo = mongoService.getMongoClient() // my mongoservice
    val database_name: String = request.getQueryString("database").getOrElse("")
    val collection_name: String = request.getQueryString("collection").getOrElse("")

    if (database_name == "" || collection_name == "") {
      Future(BadRequest("Must specify database and collection names"))
    } else {
      val database = mongo.getDatabase(database_name)
      val collection = database.getCollection(collection_name)

      val body = request.body.asJson.get.toString
      val bsondocument = BsonDocument.apply(body)
      val document = Document(bsondocument)

      val insertFuture = collection.insertOne(document).toFuture()
      insertFuture.onComplete {
        case Success(_) => Future(Ok("Inserted"))
        case Failure(_) => Future(InternalServerError)
      }
    }
  }

2 个答案:

答案 0 :(得分:2)

使用此代替onCompleteonComplete用于执行任何副作用操作。

insertFuture
   .map(_ => Ok("Inserted"))
   .recover({case _ => InternalServerError})

答案 1 :(得分:1)

根据您的尝试,您可能正在寻找transform方法:

QAbstractItemModel