Free cookie consent management tool by TermsFeed Policy Generator

source: branches/HiveStatistics/sources/HeuristicLab.Services.Hive/3.3/ServiceLocator.cs @ 10166

Last change on this file since 10166 was 9526, checked in by pfleck, 11 years ago

#2063
Added StatisticsGenerator for generating statistic data for Hive.
ServiceLocator returns the StatisticsGenerator.
Integrated StatisticsGenerator in Janitor service for periodic calls.

File size: 3.5 KB
Line 
1#region License Information
2/* HeuristicLab
3 * Copyright (C) 2002-2012 Heuristic and Evolutionary Algorithms Laboratory (HEAL)
4 *
5 * This file is part of HeuristicLab.
6 *
7 * HeuristicLab is free software: you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation, either version 3 of the License, or
10 * (at your option) any later version.
11 *
12 * HeuristicLab is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15 * GNU General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License
18 * along with HeuristicLab. If not, see <http://www.gnu.org/licenses/>.
19 */
20#endregion
21
22using HeuristicLab.Services.Hive.DataAccess;
23
24namespace HeuristicLab.Services.Hive {
25
26  public class ServiceLocator : IServiceLocator {
27    private static IServiceLocator instance;
28    public static IServiceLocator Instance {
29      get {
30        if (instance == null) instance = new ServiceLocator();
31        return instance;
32      }
33      set { instance = value; }
34    }
35
36    private IHiveDao hiveDao;
37    public IHiveDao HiveDao {
38      get {
39        if (hiveDao == null) hiveDao = new HiveDao();
40        return hiveDao;
41      }
42    }
43
44    private IOptimizedHiveDao optimizedHiveDao;
45    public IOptimizedHiveDao OptimizedHiveDao {
46      get {
47        if (optimizedHiveDao == null) optimizedHiveDao = new OptimizedHiveDao();
48        return optimizedHiveDao;
49      }
50    }
51
52    private Access.IRoleVerifier roleVerifier;
53    public Access.IRoleVerifier RoleVerifier {
54      get {
55        if (roleVerifier == null) roleVerifier = new Access.RoleVerifier();
56        return roleVerifier;
57      }
58    }
59
60    private IAuthorizationManager authorizationManager;
61    public IAuthorizationManager AuthorizationManager {
62      get {
63        if (authorizationManager == null) authorizationManager = new AuthorizationManager();
64        return authorizationManager;
65      }
66    }
67
68    private IEventManager eventManager;
69    public IEventManager EventManager {
70      get {
71        if (eventManager == null) eventManager = new EventManager();
72        return eventManager;
73      }
74    }
75
76    private IStatisticsGenerator statisticsGenerator;
77    public IStatisticsGenerator StatisticsGenerator {
78      get { return statisticsGenerator ?? (statisticsGenerator = new HiveStatisticsGenerator()); }
79    }
80
81    private ITransactionManager transactionManager;
82    public ITransactionManager TransactionManager {
83      get {
84        if (transactionManager == null) transactionManager = new TransactionManager();
85        return transactionManager;
86      }
87    }
88
89    private Access.IUserManager userManager;
90    public Access.IUserManager UserManager {
91      get {
92        if (userManager == null) userManager = new Access.UserManager();
93        return userManager;
94      }
95    }
96
97    private HeartbeatManager heartbeatManager;
98    public HeartbeatManager HeartbeatManager {
99      get {
100        if (heartbeatManager == null) heartbeatManager = new HeartbeatManager();
101        return heartbeatManager;
102      }
103    }
104
105    private ITaskScheduler taskScheduler;
106    public ITaskScheduler TaskScheduler {
107      get {
108        if (taskScheduler == null) taskScheduler = new RoundRobinTaskScheduler();
109        return taskScheduler;
110      }
111    }
112  }
113}
Note: See TracBrowser for help on using the repository browser.