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