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.topology.sync;
23 import org.onap.aai.sparky.config.oxm.GeoEntityLookup;
24 import org.onap.aai.sparky.config.oxm.OxmEntityLookup;
25 import org.onap.aai.sparky.dal.ActiveInventoryAdapter;
26 import org.onap.aai.sparky.dal.ElasticSearchAdapter;
27 import org.onap.aai.sparky.sync.ElasticSearchIndexCleaner;
28 import org.onap.aai.sparky.sync.ElasticSearchSchemaFactory;
29 import org.onap.aai.sparky.sync.IndexCleaner;
30 import org.onap.aai.sparky.sync.IndexIntegrityValidator;
31 import org.onap.aai.sparky.sync.SyncControllerImpl;
32 import org.onap.aai.sparky.sync.SyncControllerRegistrar;
33 import org.onap.aai.sparky.sync.SyncControllerRegistry;
34 import org.onap.aai.sparky.sync.config.ElasticSearchEndpointConfig;
35 import org.onap.aai.sparky.sync.config.ElasticSearchSchemaConfig;
36 import org.onap.aai.sparky.sync.config.NetworkStatisticsConfig;
37 import org.onap.aai.sparky.sync.config.SyncControllerConfig;
39 public class GeoSyncController extends SyncControllerImpl implements SyncControllerRegistrar {
41 private SyncControllerRegistry syncControllerRegistry;
43 public GeoSyncController(SyncControllerConfig syncControllerConfig,
44 ActiveInventoryAdapter aaiAdapter, ElasticSearchAdapter esAdapter,
45 ElasticSearchSchemaConfig schemaConfig, ElasticSearchEndpointConfig endpointConfig,
46 NetworkStatisticsConfig aaiStatConfig, NetworkStatisticsConfig esStatConfig,
47 GeoEntityLookup geoEntityLookup, OxmEntityLookup oxmEntityLookup) throws Exception {
48 super(syncControllerConfig);
50 // final String controllerName = "Inventory Geo Synchronizer";
52 IndexIntegrityValidator indexValidator = new IndexIntegrityValidator(esAdapter, schemaConfig,
53 endpointConfig, ElasticSearchSchemaFactory.getIndexSchema(schemaConfig));
55 registerIndexValidator(indexValidator);
57 GeoSynchronizer synchronizer =
58 new GeoSynchronizer(schemaConfig, syncControllerConfig.getNumInternalSyncWorkers(),
59 syncControllerConfig.getNumSyncActiveInventoryWorkers(),
60 syncControllerConfig.getNumSyncElasticWorkers(), aaiStatConfig, esStatConfig,
61 geoEntityLookup, oxmEntityLookup);
63 synchronizer.setAaiAdapter(aaiAdapter);
64 synchronizer.setElasticSearchAdapter(esAdapter);
66 registerEntitySynchronizer(synchronizer);
69 IndexCleaner indexCleaner =
70 new ElasticSearchIndexCleaner(esAdapter, endpointConfig, schemaConfig);
72 registerIndexCleaner(indexCleaner);
76 public SyncControllerRegistry getSyncControllerRegistry() {
77 return syncControllerRegistry;
80 public void setSyncControllerRegistry(SyncControllerRegistry syncControllerRegistry) {
81 this.syncControllerRegistry = syncControllerRegistry;
85 public void registerController() {
87 if ( syncControllerRegistry != null ) {
88 if ( syncControllerConfig.isEnabled()) {
89 syncControllerRegistry.registerSyncController(this);