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.viewinspect.sync;
25 import org.onap.aai.sparky.config.oxm.CrossEntityReferenceLookup;
26 import org.onap.aai.sparky.config.oxm.OxmEntityLookup;
27 import org.onap.aai.sparky.config.oxm.SearchableEntityLookup;
28 import org.onap.aai.sparky.crossentityreference.sync.CrossEntityReferenceSynchronizer;
29 import org.onap.aai.sparky.dal.ActiveInventoryAdapter;
30 import org.onap.aai.sparky.dal.ElasticSearchAdapter;
31 import org.onap.aai.sparky.sync.ElasticSearchIndexCleaner;
32 import org.onap.aai.sparky.sync.ElasticSearchSchemaFactory;
33 import org.onap.aai.sparky.sync.IndexCleaner;
34 import org.onap.aai.sparky.sync.IndexIntegrityValidator;
35 import org.onap.aai.sparky.sync.SyncControllerImpl;
36 import org.onap.aai.sparky.sync.SyncControllerRegistrar;
37 import org.onap.aai.sparky.sync.SyncControllerRegistry;
38 import org.onap.aai.sparky.sync.config.ElasticSearchEndpointConfig;
39 import org.onap.aai.sparky.sync.config.ElasticSearchSchemaConfig;
40 import org.onap.aai.sparky.sync.config.NetworkStatisticsConfig;
41 import org.onap.aai.sparky.sync.config.SyncControllerConfig;
43 public class ViewInspectSyncController extends SyncControllerImpl
44 implements SyncControllerRegistrar {
46 private SyncControllerRegistry syncControllerRegistry;
47 private ActiveInventoryAdapter aaiAdapter;
48 private ElasticSearchAdapter esAdapter;
49 private ElasticSearchSchemaConfig schemaConfig;
50 private ElasticSearchEndpointConfig endpointConfig;
52 public ViewInspectSyncController(SyncControllerConfig syncControllerConfig,
53 ActiveInventoryAdapter aaiAdapter, ElasticSearchAdapter esAdapter,
54 ElasticSearchSchemaConfig schemaConfig, ElasticSearchEndpointConfig endpointConfig,
55 NetworkStatisticsConfig aaiStatConfig, NetworkStatisticsConfig esStatConfig,
56 CrossEntityReferenceLookup crossEntityReferenceLookup, OxmEntityLookup oxmEntityLookup,
57 SearchableEntityLookup searchableEntityLookup) throws Exception {
58 super(syncControllerConfig);
61 // final String controllerName = "View and Inspect Entity Synchronizer";
63 this.aaiAdapter = aaiAdapter;
64 this.esAdapter = esAdapter;
65 this.schemaConfig = schemaConfig;
66 this.endpointConfig = endpointConfig;
67 IndexIntegrityValidator indexValidator = new IndexIntegrityValidator(esAdapter, schemaConfig,
68 endpointConfig, ElasticSearchSchemaFactory.getIndexSchema(schemaConfig));
70 registerIndexValidator(indexValidator);
73 ViewInspectEntitySynchronizer ses = new ViewInspectEntitySynchronizer(schemaConfig,
74 syncControllerConfig.getNumInternalSyncWorkers(),
75 syncControllerConfig.getNumSyncActiveInventoryWorkers(),
76 syncControllerConfig.getNumSyncElasticWorkers(), aaiStatConfig, esStatConfig,
77 oxmEntityLookup, searchableEntityLookup);
79 ses.setAaiAdapter(aaiAdapter);
80 ses.setElasticSearchAdapter(esAdapter);
82 registerEntitySynchronizer(ses);
84 CrossEntityReferenceSynchronizer cers = new CrossEntityReferenceSynchronizer(schemaConfig,
85 syncControllerConfig.getNumInternalSyncWorkers(),
86 syncControllerConfig.getNumSyncActiveInventoryWorkers(),
87 syncControllerConfig.getNumSyncElasticWorkers(),aaiStatConfig,esStatConfig,
88 crossEntityReferenceLookup, oxmEntityLookup, searchableEntityLookup);
90 cers.setAaiAdapter(aaiAdapter);
91 cers.setElasticSearchAdapter(esAdapter);
93 registerEntitySynchronizer(cers);
95 IndexCleaner indexCleaner =
96 new ElasticSearchIndexCleaner(esAdapter, endpointConfig, schemaConfig);
98 registerIndexCleaner(indexCleaner);
102 public SyncControllerRegistry getSyncControllerRegistry() {
103 return syncControllerRegistry;
106 public void setSyncControllerRegistry(SyncControllerRegistry syncControllerRegistry) {
107 this.syncControllerRegistry = syncControllerRegistry;
111 public void registerController() {
112 if ( syncControllerRegistry != null ) {
113 if ( syncControllerConfig.isEnabled()) {
114 syncControllerRegistry.registerSyncController(this);