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,
56 ElasticSearchSchemaFactory elasticSearchSchemaFactory) throws Exception {
57 super(syncControllerConfig);
60 // final String controllerName = "View and Inspect Entity Synchronizer";
62 this.aaiAdapter = aaiAdapter;
63 this.esAdapter = esAdapter;
64 this.schemaConfig = schemaConfig;
65 this.endpointConfig = endpointConfig;
66 IndexIntegrityValidator indexValidator = new IndexIntegrityValidator(esAdapter, schemaConfig,
67 endpointConfig, elasticSearchSchemaFactory.getIndexSchema(schemaConfig));
69 registerIndexValidator(indexValidator);
72 ViewInspectEntitySynchronizer ses = new ViewInspectEntitySynchronizer(schemaConfig,
73 syncControllerConfig.getNumInternalSyncWorkers(),
74 syncControllerConfig.getNumSyncActiveInventoryWorkers(),
75 syncControllerConfig.getNumSyncElasticWorkers(), aaiStatConfig, esStatConfig,
76 oxmEntityLookup, searchableEntityLookup);
78 ses.setAaiAdapter(aaiAdapter);
79 ses.setElasticSearchAdapter(esAdapter);
81 registerEntitySynchronizer(ses);
83 CrossEntityReferenceSynchronizer cers = new CrossEntityReferenceSynchronizer(schemaConfig,
84 syncControllerConfig.getNumInternalSyncWorkers(),
85 syncControllerConfig.getNumSyncActiveInventoryWorkers(),
86 syncControllerConfig.getNumSyncElasticWorkers(),aaiStatConfig,esStatConfig,
87 crossEntityReferenceLookup, oxmEntityLookup, searchableEntityLookup);
89 cers.setAaiAdapter(aaiAdapter);
90 cers.setElasticSearchAdapter(esAdapter);
92 registerEntitySynchronizer(cers);
94 IndexCleaner indexCleaner =
95 new ElasticSearchIndexCleaner(esAdapter, endpointConfig, schemaConfig);
97 registerIndexCleaner(indexCleaner);
101 public SyncControllerRegistry getSyncControllerRegistry() {
102 return syncControllerRegistry;
105 public void setSyncControllerRegistry(SyncControllerRegistry syncControllerRegistry) {
106 this.syncControllerRegistry = syncControllerRegistry;
110 public void registerController() {
111 if ( syncControllerRegistry != null ) {
112 if ( syncControllerConfig.isEnabled()) {
113 syncControllerRegistry.registerSyncController(this);