| 
									
										
										
										
											2015-11-19 14:39:21 -08:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Copyright 2015 LinkedIn Corp. All rights reserved.
 | 
					
						
							|  |  |  |  *
 | 
					
						
							|  |  |  |  * Licensed under the Apache License, Version 2.0 (the "License");
 | 
					
						
							|  |  |  |  * you may not use this file except in compliance with the License.
 | 
					
						
							|  |  |  |  * You may obtain a copy of the License at
 | 
					
						
							|  |  |  |  *
 | 
					
						
							|  |  |  |  * http://www.apache.org/licenses/LICENSE-2.0
 | 
					
						
							|  |  |  |  *
 | 
					
						
							|  |  |  |  * Unless required by applicable law or agreed to in writing, software
 | 
					
						
							|  |  |  |  * distributed under the License is distributed on an "AS IS" BASIS,
 | 
					
						
							|  |  |  |  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
					
						
							|  |  |  |  */
 | 
					
						
							|  |  |  | package actors;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import akka.actor.ActorRef;
 | 
					
						
							|  |  |  | import akka.actor.ActorSystem;
 | 
					
						
							|  |  |  | import akka.actor.Props;
 | 
					
						
							|  |  |  | import akka.actor.Scheduler;
 | 
					
						
							| 
									
										
										
										
											2016-10-19 17:08:07 -07:00
										 |  |  | import akka.routing.SmallestMailboxPool;
 | 
					
						
							| 
									
										
										
										
											2017-06-28 11:41:35 -07:00
										 |  |  | import play.Play;
 | 
					
						
							| 
									
										
										
										
											2015-11-19 14:39:21 -08:00
										 |  |  | import scala.concurrent.ExecutionContext;
 | 
					
						
							| 
									
										
										
										
											2017-11-07 15:54:05 -08:00
										 |  |  | import wherehows.common.Constant;
 | 
					
						
							| 
									
										
										
										
											2015-11-19 14:39:21 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Created by zechen on 9/4/15.
 | 
					
						
							|  |  |  |  */
 | 
					
						
							|  |  |  | public class ActorRegistry {
 | 
					
						
							| 
									
										
										
										
											2017-06-28 11:41:35 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-11-07 15:54:05 -08:00
										 |  |  |   private static final int ETL_POOL_SIZE =
 | 
					
						
							|  |  |  |       Play.application().configuration().getInt(Constant.WH_ETL_MAX_CONCURERNT_JOBS);
 | 
					
						
							| 
									
										
										
										
											2017-06-28 11:41:35 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-11-19 14:39:21 -08:00
										 |  |  |   private static ActorSystem actorSystem = ActorSystem.create("WhereHowsETLService");
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   public static ExecutionContext dispatcher = actorSystem.dispatcher();
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   public static Scheduler scheduler = actorSystem.scheduler();
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   public static ActorRef schedulerActor = actorSystem.actorOf(Props.create(SchedulerActor.class), "SchedulerActor");
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   public static ActorRef etlJobActor =
 | 
					
						
							| 
									
										
										
										
											2017-06-28 11:41:35 -07:00
										 |  |  |       actorSystem.actorOf(new SmallestMailboxPool(ETL_POOL_SIZE).props(Props.create(EtlJobActor.class)), "EtlJobActor");
 | 
					
						
							| 
									
										
										
										
											2015-11-19 14:39:21 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-28 11:41:35 -07:00
										 |  |  |   public static ActorRef treeBuilderActor =
 | 
					
						
							|  |  |  |       actorSystem.actorOf(Props.create(TreeBuilderActor.class), "TreeBuilderActor");
 | 
					
						
							| 
									
										
										
										
											2015-11-19 14:39:21 -08:00
										 |  |  | }
 |