-/*
- * ===============================LICENSE_START======================================
- * dcae-analytics
- * ================================================================================
- * Copyright © 2017 AT&T Intellectual Property. All rights reserved.
- * ================================================================================
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- * ============================LICENSE_END===========================================
- */
-
-package org.openecomp.dcae.apod.analytics.cdap.tca.worker;
-
-import co.cask.cdap.api.annotation.Property;
-import co.cask.cdap.api.worker.AbstractWorker;
-import co.cask.cdap.api.worker.WorkerContext;
-import com.fasterxml.jackson.core.type.TypeReference;
-import org.openecomp.dcae.apod.analytics.cdap.tca.settings.TCAAppPreferences;
-import org.openecomp.dcae.apod.analytics.cdap.tca.utils.CDAPTCAUtils;
-import org.openecomp.dcae.apod.analytics.common.exception.DCAEAnalyticsRuntimeException;
-import org.openecomp.dcae.apod.analytics.model.domain.cef.EventListener;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import java.io.FileNotFoundException;
-import java.io.IOException;
-import java.io.InputStream;
-import java.util.List;
-
-import static org.openecomp.dcae.apod.analytics.tca.utils.TCAUtils.readValue;
-import static org.openecomp.dcae.apod.analytics.tca.utils.TCAUtils.writeValueAsString;
-
-/**
- * CDAP Worker which mocks fetching VES Messages from DMaaP MR topic.
- * The mock instead of making DMaaP MR calls will actually take messages
- * from file and send them to stream at subscriber polling interval
- *
- * TODO: To be removed before going to production - only for testing purposes
- *
- * @author Rajiv Singla . Creation Date: 11/4/2016.
- */
-public class TCADMaaPMockSubscriberWorker extends AbstractWorker {
-
- private static final Logger LOG = LoggerFactory.getLogger(TCADMaaPMockSubscriberWorker.class);
-
- // TODO: Remove this file before going to production - only for mocking purposes
- private static final String MOCK_MESSAGE_FILE_LOCATION = "ves_mock_messages.json";
- private static final TypeReference<List<EventListener>> EVENT_LISTENER_TYPE_REFERENCE =
- new TypeReference<List<EventListener>>() {
- };
-
- private TCAAppPreferences tcaAppPreferences;
- private boolean stopSendingMessages;
- @Property
- private final String tcaSubscriberOutputStreamName;
-
- public TCADMaaPMockSubscriberWorker(final String tcaSubscriberOutputStreamName) {
- this.tcaSubscriberOutputStreamName = tcaSubscriberOutputStreamName;
- }
-
- @Override
- public void configure() {
- setName("MockTCASubscriberWorker");
- setDescription("Writes Mocked VES messages to CDAP Stream");
- LOG.info("Configuring Mock TCA MR DMaaP Subscriber worker with name: {}", "MockTCASubscriberWorker");
- }
-
- @Override
- public void initialize(WorkerContext context) throws Exception {
- super.initialize(context);
-
- final TCAAppPreferences appPreferences = CDAPTCAUtils.getValidatedTCAAppPreferences(context);
- LOG.info("Initializing Mock TCA MR DMaaP Subscriber worker with preferences: {}", appPreferences);
- this.tcaAppPreferences = appPreferences;
- this.stopSendingMessages = false;
- }
-
-
- @Override
- public void run() {
- final Integer subscriberPollingInterval = tcaAppPreferences.getSubscriberPollingInterval();
- LOG.debug("Mock TCA Subscriber Polling interval: {}", subscriberPollingInterval);
-
- final InputStream resourceAsStream = Thread.currentThread().getContextClassLoader().getResourceAsStream
- (MOCK_MESSAGE_FILE_LOCATION);
-
- if (resourceAsStream == null) {
- LOG.error("Unable to find file at location: {}", MOCK_MESSAGE_FILE_LOCATION);
- throw new DCAEAnalyticsRuntimeException("Unable to find file", LOG, new FileNotFoundException());
- }
-
-
- try {
- List<EventListener> eventListeners = readValue(resourceAsStream, EVENT_LISTENER_TYPE_REFERENCE);
-
- final int totalMessageCount = eventListeners.size();
- LOG.debug("Mock message count to be written to cdap stream: ()", totalMessageCount);
-
- int i = 1;
- for (EventListener eventListener : eventListeners) {
- if (stopSendingMessages) {
- LOG.debug("Stop sending messages......");
- break;
- }
- final String eventListenerString = writeValueAsString(eventListener);
- LOG.debug("=======>> Writing message to cdap stream no: {} of {}", i, totalMessageCount);
- getContext().write(tcaSubscriberOutputStreamName, eventListenerString);
- i++;
-
- try {
- Thread.sleep(subscriberPollingInterval);
- } catch (InterruptedException e) {
- LOG.error("Error while sleeping");
- throw new DCAEAnalyticsRuntimeException("Error while sleeping", LOG, e);
- }
- }
-
- LOG.debug("Finished writing mock messages to CDAP Stream");
-
- } catch (IOException e) {
- LOG.error("Error while parsing json file");
- throw new DCAEAnalyticsRuntimeException("Error while parsing mock json file", LOG, e);
- }
-
-
- }
-
- @Override
- public void stop() {
- stopSendingMessages = true;
- }
-}
+/*\r
+ * ===============================LICENSE_START======================================\r
+ * dcae-analytics\r
+ * ================================================================================\r
+ * Copyright © 2017 AT&T Intellectual Property. All rights reserved.\r
+ * ================================================================================\r
+ * Licensed under the Apache License, Version 2.0 (the "License");\r
+ * you may not use this file except in compliance with the License.\r
+ * You may obtain a copy of the License at\r
+ *\r
+ * http://www.apache.org/licenses/LICENSE-2.0\r
+ *\r
+ * Unless required by applicable law or agreed to in writing, software\r
+ * distributed under the License is distributed on an "AS IS" BASIS,\r
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r
+ * See the License for the specific language governing permissions and\r
+ * limitations under the License.\r
+ * ============================LICENSE_END===========================================\r
+ */\r
+\r
+package org.openecomp.dcae.apod.analytics.cdap.tca.worker;\r
+\r
+import co.cask.cdap.api.annotation.Property;\r
+import co.cask.cdap.api.worker.AbstractWorker;\r
+import co.cask.cdap.api.worker.WorkerContext;\r
+import com.fasterxml.jackson.core.type.TypeReference;\r
+import org.openecomp.dcae.apod.analytics.cdap.tca.settings.TCAAppPreferences;\r
+import org.openecomp.dcae.apod.analytics.cdap.tca.utils.CDAPTCAUtils;\r
+import org.openecomp.dcae.apod.analytics.common.exception.DCAEAnalyticsRuntimeException;\r
+import org.openecomp.dcae.apod.analytics.model.domain.cef.EventListener;\r
+import org.slf4j.Logger;\r
+import org.slf4j.LoggerFactory;\r
+\r
+import java.io.FileNotFoundException;\r
+import java.io.IOException;\r
+import java.io.InputStream;\r
+import java.util.List;\r
+\r
+import static org.openecomp.dcae.apod.analytics.tca.utils.TCAUtils.readValue;\r
+import static org.openecomp.dcae.apod.analytics.tca.utils.TCAUtils.writeValueAsString;\r
+\r
+/**\r
+ * CDAP Worker which mocks fetching VES Messages from DMaaP MR topic.\r
+ * The mock instead of making DMaaP MR calls will actually take messages\r
+ * from file and send them to stream at subscriber polling interval\r
+ *\r
+ * TODO: To be removed before going to production - only for testing purposes\r
+ *\r
+ * @author Rajiv Singla . Creation Date: 11/4/2016.\r
+ */\r
+public class TCADMaaPMockSubscriberWorker extends AbstractWorker {\r
+\r
+ private static final Logger LOG = LoggerFactory.getLogger(TCADMaaPMockSubscriberWorker.class);\r
+\r
+ // TODO: Remove this file before going to production - only for mocking purposes\r
+ private static final String MOCK_MESSAGE_FILE_LOCATION = "ves_mock_messages.json";\r
+ private static final TypeReference<List<EventListener>> EVENT_LISTENER_TYPE_REFERENCE =\r
+ new TypeReference<List<EventListener>>() {\r
+ };\r
+\r
+ private TCAAppPreferences tcaAppPreferences;\r
+ private boolean stopSendingMessages;\r
+ @Property\r
+ private final String tcaSubscriberOutputStreamName;\r
+\r
+ public TCADMaaPMockSubscriberWorker(final String tcaSubscriberOutputStreamName) {\r
+ this.tcaSubscriberOutputStreamName = tcaSubscriberOutputStreamName;\r
+ }\r
+\r
+ @Override\r
+ public void configure() {\r
+ setName("MockTCASubscriberWorker");\r
+ setDescription("Writes Mocked VES messages to CDAP Stream");\r
+ LOG.info("Configuring Mock TCA MR DMaaP Subscriber worker with name: {}", "MockTCASubscriberWorker");\r
+ }\r
+\r
+ @Override\r
+ public void initialize(WorkerContext context) throws Exception {\r
+ super.initialize(context);\r
+\r
+ final TCAAppPreferences appPreferences = CDAPTCAUtils.getValidatedTCAAppPreferences(context);\r
+ LOG.info("Initializing Mock TCA MR DMaaP Subscriber worker with preferences: {}", appPreferences);\r
+ this.tcaAppPreferences = appPreferences;\r
+ this.stopSendingMessages = false;\r
+ }\r
+\r
+\r
+ @Override\r
+ public void run() {\r
+ final Integer subscriberPollingInterval = tcaAppPreferences.getSubscriberPollingInterval();\r
+ LOG.debug("Mock TCA Subscriber Polling interval: {}", subscriberPollingInterval);\r
+\r
+ final InputStream resourceAsStream = Thread.currentThread().getContextClassLoader().getResourceAsStream\r
+ (MOCK_MESSAGE_FILE_LOCATION);\r
+\r
+ if (resourceAsStream == null) {\r
+ LOG.error("Unable to find file at location: {}", MOCK_MESSAGE_FILE_LOCATION);\r
+ throw new DCAEAnalyticsRuntimeException("Unable to find file", LOG, new FileNotFoundException());\r
+ }\r
+\r
+\r
+ try {\r
+ List<EventListener> eventListeners = readValue(resourceAsStream, EVENT_LISTENER_TYPE_REFERENCE);\r
+\r
+ final int totalMessageCount = eventListeners.size();\r
+ LOG.debug("Mock message count to be written to cdap stream: ()", totalMessageCount);\r
+\r
+ int i = 1;\r
+ for (EventListener eventListener : eventListeners) {\r
+ if (stopSendingMessages) {\r
+ LOG.debug("Stop sending messages......");\r
+ break;\r
+ }\r
+ final String eventListenerString = writeValueAsString(eventListener);\r
+ LOG.debug("=======>> Writing message to cdap stream no: {} of {}", i, totalMessageCount);\r
+ getContext().write(tcaSubscriberOutputStreamName, eventListenerString);\r
+ i++;\r
+\r
+ try {\r
+ Thread.sleep(subscriberPollingInterval);\r
+ } catch (InterruptedException e) {\r
+ LOG.error("Error while sleeping");\r
+ throw new DCAEAnalyticsRuntimeException("Error while sleeping", LOG, e);\r
+ }\r
+ }\r
+\r
+ LOG.debug("Finished writing mock messages to CDAP Stream");\r
+\r
+ } catch (IOException e) {\r
+ LOG.error("Error while parsing json file");\r
+ throw new DCAEAnalyticsRuntimeException("Error while parsing mock json file", LOG, e);\r
+ }\r
+\r
+\r
+ }\r
+\r
+ @Override\r
+ public void stop() {\r
+ stopSendingMessages = true;\r
+ }\r
+}\r