Aşağıdaki "" kullanıcı girişi "anlamına gelen aşağıda tanımlanan aktöre sahibim.Akka aktörleri her zaman dışarıda beklerler
object AuthenticationActor {
def props = Props[AuthenticationActor]
case class LoginUser(id: UUID)
}
class AuthenticationActor @Inject()(cache: CacheApi, userService: UserService) extends Actor{
import AuthenticationActor._
def receive = {
case LoginEmployee(id: UUID) => {
userService.getUserById(id).foreach {
case Some(e) => {
println("Logged user in")
val sessionId = UUID.randomUUID()
cache.set(sessionId.toString, e)
sender() ! Some(e, sessionId)
}
case None => println("No user was found")
}
}
}
}
Not: userService.getUserById
bir Future[Option[User]]
Ve bunun
class EmployeeController @Inject()(@Named("authentication-actor") authActor: ActorRef)(implicit ec: ExecutionContext) extends Controller {
override implicit val timeout: Timeout = 5.seconds
def login(id: UUID) = Action.async { implicit request =>
(authActor ? LoginUser(id)).mapTo[Option[(User, UUID)]].map {
case Some(authInfo) => Ok("Authenticated").withSession(request.session + ("auth" -> authInfo._2.toString))
case None => Forbidden("Not Authenticated")
}
}
}
İkisi println
aramalar çalıştırır aşağıdaki çok basit API cal döndürür, ancak login
çağrı hep vardır sormak söyleyerek başarısız olur zaman aşımı. Baska öneri? Eğer (Future
s callback'inde içinde gönderen erişim) böyle bir şey yaptığınızda
i/mapTo o pipeTo kullanmamalısınız
sender
veya baskılar
Future
sonucudur? – Ashalynd