Revision 4d7acc86
b/logic/src/main/scala/gr/grnet/aquarium/actor/SimpleLocalActorProvider.scala | ||
---|---|---|
1 |
/* |
|
2 |
* Copyright 2011 GRNET S.A. All rights reserved. |
|
3 |
* |
|
4 |
* Redistribution and use in source and binary forms, with or |
|
5 |
* without modification, are permitted provided that the following |
|
6 |
* conditions are met: |
|
7 |
* |
|
8 |
* 1. Redistributions of source code must retain the above |
|
9 |
* copyright notice, this list of conditions and the following |
|
10 |
* disclaimer. |
|
11 |
* |
|
12 |
* 2. Redistributions in binary form must reproduce the above |
|
13 |
* copyright notice, this list of conditions and the following |
|
14 |
* disclaimer in the documentation and/or other materials |
|
15 |
* provided with the distribution. |
|
16 |
* |
|
17 |
* THIS SOFTWARE IS PROVIDED BY GRNET S.A. ``AS IS'' AND ANY EXPRESS |
|
18 |
* OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED |
|
19 |
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR |
|
20 |
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL GRNET S.A OR |
|
21 |
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
|
22 |
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
|
23 |
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF |
|
24 |
* USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED |
|
25 |
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT |
|
26 |
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN |
|
27 |
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE |
|
28 |
* POSSIBILITY OF SUCH DAMAGE. |
|
29 |
* |
|
30 |
* The views and conclusions contained in the software and |
|
31 |
* documentation are those of the authors and should not be |
|
32 |
* interpreted as representing official policies, either expressed |
|
33 |
* or implied, of GRNET S.A. |
|
34 |
*/ |
|
35 |
|
|
36 |
package gr.grnet.aquarium.actor |
|
37 |
|
|
38 |
import com.ckkloverdos.props.Props |
|
39 |
import akka.actor.ActorRef |
|
40 |
import gr.grnet.aquarium.Configurable |
|
41 |
|
|
42 |
|
|
43 |
/** |
|
44 |
* All actors are provided locally. |
|
45 |
* |
|
46 |
* @author Christos KK Loverdos <loverdos@gmail.com>. |
|
47 |
*/ |
|
48 |
class SimpleLocalActorProvider extends ActorProvider with Configurable { |
|
49 |
def configure(props: Props): Unit = { |
|
50 |
|
|
51 |
} |
|
52 |
|
|
53 |
@throws(classOf[Exception]) |
|
54 |
def actorForRole(role: ActorRole, hints: Props = Props.empty) = { |
|
55 |
SimpleLocalActorProvider.ActorRefByRoles.get(role) match { |
|
56 |
case Some(actorRef) ⇒ |
|
57 |
actorRef |
|
58 |
case None ⇒ |
|
59 |
throw new Exception("Cannot create actor for role %s".format(role)) |
|
60 |
} |
|
61 |
} |
|
62 |
} |
|
63 |
|
|
64 |
object SimpleLocalActorProvider { |
|
65 |
lazy val ActorClassByRole: Map[ActorRole, Class[_ <: AquariumActor]] = |
|
66 |
(DispatcherRole :: ResourceProcessorRole :: Nil) map { role ⇒ |
|
67 |
(role, role.actorType) |
|
68 |
} toMap |
|
69 |
|
|
70 |
lazy val ActorRefByRoles: Map[ActorRole, ActorRef] = ActorClassByRole map { case (role, clazz) ⇒ |
|
71 |
(role, akka.actor.Actor.actorOf(clazz).start()) |
|
72 |
} |
|
73 |
} |
/dev/null | ||
---|---|---|
1 |
/* |
|
2 |
* Copyright 2011 GRNET S.A. All rights reserved. |
|
3 |
* |
|
4 |
* Redistribution and use in source and binary forms, with or |
|
5 |
* without modification, are permitted provided that the following |
|
6 |
* conditions are met: |
|
7 |
* |
|
8 |
* 1. Redistributions of source code must retain the above |
|
9 |
* copyright notice, this list of conditions and the following |
|
10 |
* disclaimer. |
|
11 |
* |
|
12 |
* 2. Redistributions in binary form must reproduce the above |
|
13 |
* copyright notice, this list of conditions and the following |
|
14 |
* disclaimer in the documentation and/or other materials |
|
15 |
* provided with the distribution. |
|
16 |
* |
|
17 |
* THIS SOFTWARE IS PROVIDED BY GRNET S.A. ``AS IS'' AND ANY EXPRESS |
|
18 |
* OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED |
|
19 |
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR |
|
20 |
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL GRNET S.A OR |
|
21 |
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
|
22 |
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
|
23 |
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF |
|
24 |
* USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED |
|
25 |
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT |
|
26 |
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN |
|
27 |
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE |
|
28 |
* POSSIBILITY OF SUCH DAMAGE. |
|
29 |
* |
|
30 |
* The views and conclusions contained in the software and |
|
31 |
* documentation are those of the authors and should not be |
|
32 |
* interpreted as representing official policies, either expressed |
|
33 |
* or implied, of GRNET S.A. |
|
34 |
*/ |
|
35 |
|
|
36 |
package gr.grnet.aquarium.processor.actor |
|
37 |
|
|
38 |
import com.ckkloverdos.props.Props |
|
39 |
import gr.grnet.aquarium.actor._ |
|
40 |
import akka.actor.ActorRef |
|
41 |
|
|
42 |
|
|
43 |
/** |
|
44 |
* All actors are provided locally. |
|
45 |
* |
|
46 |
* @author Christos KK Loverdos <loverdos@gmail.com>. |
|
47 |
*/ |
|
48 |
class SimpleLocalActorProvider extends ActorProvider { |
|
49 |
@throws(classOf[Exception]) |
|
50 |
def actorForRole(role: ActorRole, hints: Props = Props.empty) = { |
|
51 |
SimpleLocalActorProvider.ActorRefByRoles.get(role) match { |
|
52 |
case Some(actorRef) ⇒ |
|
53 |
actorRef |
|
54 |
case None ⇒ |
|
55 |
throw new Exception("Cannot create actor for role %s".format(role)) |
|
56 |
} |
|
57 |
} |
|
58 |
} |
|
59 |
|
|
60 |
object SimpleLocalActorProvider { |
|
61 |
lazy val ActorClassByRole: Map[ActorRole, Class[_ <: AquariumActor]] = |
|
62 |
(DispatcherRole :: ResourceProcessorRole :: Nil) map { role ⇒ |
|
63 |
(role, role.actorType) |
|
64 |
} toMap |
|
65 |
|
|
66 |
lazy val ActorRefByRoles: Map[ActorRole, ActorRef] = ActorClassByRole map { case (role, clazz) ⇒ |
|
67 |
(role, akka.actor.Actor.actorOf(clazz).start()) |
|
68 |
} |
|
69 |
} |
Also available in: Unified diff