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.viewinspect.sync;
23 import org.onap.aai.sparky.config.oxm.CrossEntityReferenceLookup;
24 import org.onap.aai.sparky.config.oxm.OxmEntityLookup;
25 import org.onap.aai.sparky.config.oxm.SearchableEntityLookup;
26 import org.onap.aai.sparky.crossentityreference.sync.CrossEntityReferenceSynchronizer;
27 import org.onap.aai.sparky.dal.ActiveInventoryAdapter;
28 import org.onap.aai.sparky.dal.ElasticSearchAdapter;
29 import org.onap.aai.sparky.sync.ElasticSearchIndexCleaner;
30 import org.onap.aai.sparky.sync.ElasticSearchSchemaFactory;
31 import org.onap.aai.sparky.sync.IndexCleaner;
32 import org.onap.aai.sparky.sync.IndexIntegrityValidator;
33 import org.onap.aai.sparky.sync.SyncControllerImpl;
34 import org.onap.aai.sparky.sync.SyncControllerRegistrar;
35 import org.onap.aai.sparky.sync.SyncControllerRegistry;
36 import org.onap.aai.sparky.sync.config.ElasticSearchEndpointConfig;
37 import org.onap.aai.sparky.sync.config.ElasticSearchSchemaConfig;
38 import org.onap.aai.sparky.sync.config.NetworkStatisticsConfig;
39 import org.onap.aai.sparky.sync.config.SyncControllerConfig;
41 public class ViewInspectSyncController extends SyncControllerImpl
42 implements SyncControllerRegistrar {
44 private SyncControllerRegistry syncControllerRegistry;
45 private ActiveInventoryAdapter aaiAdapter;
46 private ElasticSearchAdapter esAdapter;
47 private ElasticSearchSchemaConfig schemaConfig;
48 private ElasticSearchEndpointConfig endpointConfig;
50 public ViewInspectSyncController(SyncControllerConfig syncControllerConfig,
51 ActiveInventoryAdapter aaiAdapter, ElasticSearchAdapter esAdapter,
52 ElasticSearchSchemaConfig schemaConfig, ElasticSearchEndpointConfig endpointConfig,
53 NetworkStatisticsConfig aaiStatConfig, NetworkStatisticsConfig esStatConfig,
54 CrossEntityReferenceLookup crossEntityReferenceLookup, OxmEntityLookup oxmEntityLookup,
55 SearchableEntityLookup searchableEntityLookup) throws Exception {
56 super(syncControllerConfig);
59 // final String controllerName = "View and Inspect Entity Synchronizer";
61 this.aaiAdapter = aaiAdapter;
62 this.esAdapter = esAdapter;
63 this.schemaConfig = schemaConfig;
64 this.endpointConfig = endpointConfig;
65 IndexIntegrityValidator indexValidator = new IndexIntegrityValidator(esAdapter, schemaConfig,
66 endpointConfig, ElasticSearchSchemaFactory.getIndexSchema(schemaConfig));
68 registerIndexValidator(indexValidator);
71 ViewInspectEntitySynchronizer ses = new ViewInspectEntitySynchronizer(schemaConfig,
72 syncControllerConfig.getNumInternalSyncWorkers(),
73 syncControllerConfig.getNumSyncActiveInventoryWorkers(),
74 syncControllerConfig.getNumSyncElasticWorkers(), aaiStatConfig, esStatConfig,
75 oxmEntityLookup, searchableEntityLookup);
77 ses.setAaiAdapter(aaiAdapter);
78 ses.setElasticSearchAdapter(esAdapter);
80 registerEntitySynchronizer(ses);
82 CrossEntityReferenceSynchronizer cers = new CrossEntityReferenceSynchronizer(schemaConfig,
83 syncControllerConfig.getNumInternalSyncWorkers(),
84 syncControllerConfig.getNumSyncActiveInventoryWorkers(),
85 syncControllerConfig.getNumSyncElasticWorkers(),aaiStatConfig,esStatConfig,
86 crossEntityReferenceLookup, oxmEntityLookup, searchableEntityLookup);
88 cers.setAaiAdapter(aaiAdapter);
89 cers.setElasticSearchAdapter(esAdapter);
91 registerEntitySynchronizer(cers);
93 IndexCleaner indexCleaner =
94 new ElasticSearchIndexCleaner(esAdapter, endpointConfig, schemaConfig);
96 registerIndexCleaner(indexCleaner);
100 public SyncControllerRegistry getSyncControllerRegistry() {
101 return syncControllerRegistry;
104 public void setSyncControllerRegistry(SyncControllerRegistry syncControllerRegistry) {
105 this.syncControllerRegistry = syncControllerRegistry;
109 public void registerController() {
110 if ( syncControllerRegistry != null ) {
111 if ( syncControllerConfig.isEnabled()) {
112 syncControllerRegistry.registerSyncController(this);