db60c89f935ca001c3f558bda3068dd55d232661
[portal.git] / ecomp-portal-BE-os / src / main / java / org / openecomp / portalapp / uebhandler / InitUebHandler.java
1 /*-
2  * ============LICENSE_START==========================================
3  * ONAP Portal
4  * ===================================================================
5  * Copyright © 2017 AT&T Intellectual Property. All rights reserved.
6  * ===================================================================
7  *
8  * Unless otherwise specified, all software contained herein is licensed
9  * under the Apache License, Version 2.0 (the “License”);
10  * you may not use this software except in compliance with the License.
11  * You may obtain a copy of the License at
12  *
13  *             http://www.apache.org/licenses/LICENSE-2.0
14  *
15  * Unless required by applicable law or agreed to in writing, software
16  * distributed under the License is distributed on an "AS IS" BASIS,
17  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
18  * See the License for the specific language governing permissions and
19  * limitations under the License.
20  *
21  * Unless otherwise specified, all documentation contained herein is licensed
22  * under the Creative Commons License, Attribution 4.0 Intl. (the “License”);
23  * you may not use this documentation except in compliance with the License.
24  * You may obtain a copy of the License at
25  *
26  *             https://creativecommons.org/licenses/by/4.0/
27  *
28  * Unless required by applicable law or agreed to in writing, documentation
29  * distributed under the License is distributed on an "AS IS" BASIS,
30  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
31  * See the License for the specific language governing permissions and
32  * limitations under the License.
33  *
34  * ============LICENSE_END============================================
35  *
36  * ECOMP is a trademark and service mark of AT&T Intellectual Property.
37  */
38 package org.openecomp.portalapp.uebhandler;
39
40 import java.util.concurrent.ConcurrentLinkedQueue;
41
42 import org.openecomp.portalsdk.core.logging.logic.EELFLoggerDelegate;
43 import org.openecomp.portalsdk.core.onboarding.ueb.UebManager;
44 import org.openecomp.portalsdk.core.onboarding.ueb.UebMsg;
45 import org.openecomp.portalsdk.core.onboarding.util.PortalApiConstants;
46 import org.openecomp.portalsdk.core.onboarding.util.PortalApiProperties;
47
48 //
49 // Adding this class for the sole purpose of insuring that the MainUebHandler really 
50 // honors @Async and kicks off a thread.  For more info google @Async and read about
51 // @Async only working if called from different class.
52 //
53 //@Configuration
54 //@EnableAspectJAutoProxy
55 //@EPMetricsLog
56 public class InitUebHandler {
57         private EELFLoggerDelegate logger = EELFLoggerDelegate.getLogger(InitUebHandler.class);
58
59         // @Autowired
60         private MainUebHandler mainUebHandler;
61
62         public InitUebHandler() {
63
64         }
65
66         // @PostConstruct
67         public void initUeb() {
68                 try {
69                         String enableListenerThread = PortalApiProperties.getProperty(PortalApiConstants.UEB_LISTENERS_ENABLE);
70                         if (enableListenerThread.equalsIgnoreCase("true")) {
71                                 ConcurrentLinkedQueue<UebMsg> inboxQueue = new ConcurrentLinkedQueue<UebMsg>();
72                                 UebManager.getInstance().initListener(inboxQueue);
73                                 mainUebHandler.runHandler(inboxQueue);
74                                 logger.info(EELFLoggerDelegate.errorLogger, "Returned from initiating mainUebHandler...");
75                         } else {
76                                 logger.info(EELFLoggerDelegate.errorLogger,
77                                                 "Not starting UEB listening thread because ueb_listeners_enable is not set to true in the properties file.");
78                         }
79                 } catch (Exception e) {
80                         logger.error(EELFLoggerDelegate.errorLogger, "initUeb failed", e);
81                         logger.info(EELFLoggerDelegate.errorLogger,
82                                         "Not starting UEB listening thread because property could not be read "
83                                                         + PortalApiConstants.UEB_LISTENERS_ENABLE + e.getMessage());
84                 }
85         }
86 }