2 * ============LICENSE_START=======================================================
4 * ================================================================================
5 * Copyright © 2017 AT&T Intellectual Property. All rights reserved.
6 * Copyright © 2017 Amdocs
7 * ================================================================================
8 * Licensed under the Apache License, Version 2.0 (the "License");
9 * you may not use this file except in compliance with the License.
10 * You may obtain a copy of the License at
12 * http://www.apache.org/licenses/LICENSE-2.0
14 * Unless required by applicable law or agreed to in writing, software
15 * distributed under the License is distributed on an "AS IS" BASIS,
16 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17 * See the License for the specific language governing permissions and
18 * limitations under the License.
19 * ============LICENSE_END=========================================================
21 * ECOMP is a trademark and service mark of AT&T Intellectual Property.
23 package org.onap.aai.sparky.aggregation.sync;
25 import org.onap.aai.sparky.config.oxm.SearchableEntityLookup;
26 import org.onap.aai.sparky.dal.ActiveInventoryAdapter;
27 import org.onap.aai.sparky.dal.ElasticSearchAdapter;
28 import org.onap.aai.sparky.sync.ElasticSearchSchemaFactory;
29 import org.onap.aai.sparky.sync.IndexIntegrityValidator;
30 import org.onap.aai.sparky.sync.SyncControllerImpl;
31 import org.onap.aai.sparky.sync.SyncControllerRegistrar;
32 import org.onap.aai.sparky.sync.SyncControllerRegistry;
33 import org.onap.aai.sparky.sync.config.ElasticSearchEndpointConfig;
34 import org.onap.aai.sparky.sync.config.ElasticSearchSchemaConfig;
35 import org.onap.aai.sparky.sync.config.NetworkStatisticsConfig;
36 import org.onap.aai.sparky.sync.config.SyncControllerConfig;
38 public class HistoricalEntitySyncController extends SyncControllerImpl
39 implements SyncControllerRegistrar {
41 private SyncControllerRegistry syncControllerRegistry;
43 public HistoricalEntitySyncController(SyncControllerConfig syncControllerConfig,
44 ActiveInventoryAdapter aaiAdapter, ElasticSearchAdapter esAdapter,
45 ElasticSearchSchemaConfig schemaConfig, ElasticSearchEndpointConfig endpointConfig,
46 int syncFrequencyInMinutes, NetworkStatisticsConfig aaiStatConfig,
47 NetworkStatisticsConfig esStatConfig, SearchableEntityLookup searchableEntityLookup)
49 super(syncControllerConfig);
51 // final String controllerName = "Historical Entity Count Synchronizer";
53 long taskFrequencyInMs = syncFrequencyInMinutes * 60 * 1000;
55 setDelayInMs(taskFrequencyInMs);
56 setSyncFrequencyInMs(taskFrequencyInMs);
58 IndexIntegrityValidator entityCounterHistoryValidator = new IndexIntegrityValidator(esAdapter,
59 schemaConfig, endpointConfig, ElasticSearchSchemaFactory.getIndexSchema(schemaConfig));
61 registerIndexValidator(entityCounterHistoryValidator);
63 HistoricalEntitySummarizer historicalSummarizer = new HistoricalEntitySummarizer(schemaConfig,
64 syncControllerConfig.getNumInternalSyncWorkers(),
65 syncControllerConfig.getNumSyncActiveInventoryWorkers(),
66 syncControllerConfig.getNumSyncElasticWorkers(),aaiStatConfig, esStatConfig,searchableEntityLookup);
68 historicalSummarizer.setAaiAdapter(aaiAdapter);
69 historicalSummarizer.setElasticSearchAdapter(esAdapter);
71 registerEntitySynchronizer(historicalSummarizer);
75 public SyncControllerRegistry getSyncControllerRegistry() {
76 return syncControllerRegistry;
79 public void setSyncControllerRegistry(SyncControllerRegistry syncControllerRegistry) {
80 this.syncControllerRegistry = syncControllerRegistry;
84 public void registerController() {
85 if ( syncControllerRegistry != null ) {
86 if ( syncControllerConfig.isEnabled()) {
87 syncControllerRegistry.registerSyncController(this);