2

コントローラーで Finagle クライアントのメソッド (FinagleClient.longRunningComputation) を使用しています

def alfa = Action.async(parse.json) { request =>

    val response = FinagleClient.longRunningComputation(request.body )          
    response.map( rest => Ok("Got result: " + rest ))

}

play Controller で com.twitter.util.Future の結果を取得する必要があります

Returning futuresを使用しようとしましたが、コンパイラは次のエラーを返します。

found   : com.twitter.util.Future[play.api.mvc.Result]
required: scala.concurrent.Future[play.api.mvc.Result]

response.map(rest => Ok("Got result: " + rest))

play Controller で com.twitter.util.Future を使用する必要があります

これどうやってするの?

4

1 に答える 1

2

に変換するscala.concurrent.Future必要がありますが、これは を使用して行うことができますPromise

このようなもの:

def alfa = Action.async(parse.json) { request =>
    val p = Promise[Result]
    val response = FinagleClient.longRunningComputation(request.body )          
    val twitterFuture = response.map( rest => Ok("Got result: " + rest ))
    twitterFuture.onSuccess(p.success)
    twitterFuture.onFailure(p.failure)

    p.future
}

これを一般化して、暗黙的に に変換com.twitter.util.Future[A]できscala.concurrent.Future[A]ます。

import com.twitter.util.{Future => TwitterFuture}
import scala.concurrent.{Future, Promise}

object TwitterConversions {
    def twitter2Scala[A](f: TwitterFuture[A]): Future[A] = {
        val p = Promise[A]
        f.onSuccess(p.success)
        f.onFailure(p.failure)
        p.future
    }
}

次に、コントローラーで行う必要があるのはimport TwitterConversions._(またはそれを入れるパッケージ)だけです。

于 2015-04-15T22:53:27.343 に答える