2 * ============LICENSE_START=======================================================
4 * ================================================================================
5 * Copyright © 2017-2018 AT&T Intellectual Property. All rights reserved.
6 * Copyright © 2017-2018 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 package org.onap.aai.sparky.aggregation.sync;
23 import org.onap.aai.sparky.config.oxm.SearchableEntityLookup;
24 import org.onap.aai.sparky.dal.ActiveInventoryAdapter;
25 import org.onap.aai.sparky.dal.ElasticSearchAdapter;
26 import org.onap.aai.sparky.sync.ElasticSearchSchemaFactory;
27 import org.onap.aai.sparky.sync.IndexIntegrityValidator;
28 import org.onap.aai.sparky.sync.SyncControllerImpl;
29 import org.onap.aai.sparky.sync.SyncControllerRegistrar;
30 import org.onap.aai.sparky.sync.SyncControllerRegistry;
31 import org.onap.aai.sparky.sync.config.ElasticSearchEndpointConfig;
32 import org.onap.aai.sparky.sync.config.ElasticSearchSchemaConfig;
33 import org.onap.aai.sparky.sync.config.NetworkStatisticsConfig;
34 import org.onap.aai.sparky.sync.config.SyncControllerConfig;
36 public class HistoricalEntitySyncController extends SyncControllerImpl
37 implements SyncControllerRegistrar {
39 private SyncControllerRegistry syncControllerRegistry;
41 public HistoricalEntitySyncController(SyncControllerConfig syncControllerConfig,
42 ActiveInventoryAdapter aaiAdapter, ElasticSearchAdapter esAdapter,
43 ElasticSearchSchemaConfig schemaConfig, ElasticSearchEndpointConfig endpointConfig,
44 int syncFrequencyInMinutes, NetworkStatisticsConfig aaiStatConfig,
45 NetworkStatisticsConfig esStatConfig, SearchableEntityLookup searchableEntityLookup)
47 super(syncControllerConfig);
49 // final String controllerName = "Historical Entity Count Synchronizer";
51 long taskFrequencyInMs = syncFrequencyInMinutes * 60 * 1000;
53 setDelayInMs(taskFrequencyInMs);
54 setSyncFrequencyInMs(taskFrequencyInMs);
56 IndexIntegrityValidator entityCounterHistoryValidator = new IndexIntegrityValidator(esAdapter,
57 schemaConfig, endpointConfig, ElasticSearchSchemaFactory.getIndexSchema(schemaConfig));
59 registerIndexValidator(entityCounterHistoryValidator);
61 HistoricalEntitySummarizer historicalSummarizer = new HistoricalEntitySummarizer(schemaConfig,
62 syncControllerConfig.getNumInternalSyncWorkers(),
63 syncControllerConfig.getNumSyncActiveInventoryWorkers(),
64 syncControllerConfig.getNumSyncElasticWorkers(),aaiStatConfig, esStatConfig,searchableEntityLookup);
66 historicalSummarizer.setAaiAdapter(aaiAdapter);
67 historicalSummarizer.setElasticSearchAdapter(esAdapter);
69 registerEntitySynchronizer(historicalSummarizer);
73 public SyncControllerRegistry getSyncControllerRegistry() {
74 return syncControllerRegistry;
77 public void setSyncControllerRegistry(SyncControllerRegistry syncControllerRegistry) {
78 this.syncControllerRegistry = syncControllerRegistry;
82 public void registerController() {
83 if ( syncControllerRegistry != null ) {
84 if ( syncControllerConfig.isEnabled()) {
85 syncControllerRegistry.registerSyncController(this);