VES Heartbeat and Software Management Feature
[oam/tr069-adapter.git] / common / src / main / java / org / commscope / tr069adapter / common / timer / impl / TimerHandlerDM.java
1 /*\r
2  * ============LICENSE_START========================================================================\r
3  * ONAP : tr-069-adapter\r
4  * =================================================================================================\r
5  * Copyright (C) 2020 CommScope Inc Intellectual Property.\r
6  * =================================================================================================\r
7  * This tr-069-adapter software file is distributed by CommScope Inc under the Apache License,\r
8  * Version 2.0 (the "License"); you may not use this file except in compliance with the License. You\r
9  * may obtain a copy of the License at\r
10  *\r
11  * http://www.apache.org/licenses/LICENSE-2.0\r
12  *\r
13  * This file is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,\r
14  * either express or implied. See the License for the specific language governing permissions and\r
15  * limitations under the License.\r
16  * ===============LICENSE_END=======================================================================\r
17  */\r
18 \r
19 package org.commscope.tr069adapter.common.timer.impl;\r
20 \r
21 import static org.commscope.tr069adapter.common.scheduler.impl.TimerAPIConstants.TIMER_DATA_KEY;\r
22 import static org.commscope.tr069adapter.common.scheduler.impl.TimerAPIConstants.TIMER_LISTENER_KEY;\r
23 \r
24 import java.io.Serializable;\r
25 import java.util.Date;\r
26 \r
27 import org.commscope.tr069adapter.common.scheduler.ExecutionContext;\r
28 import org.commscope.tr069adapter.common.scheduler.Job;\r
29 import org.commscope.tr069adapter.common.scheduler.impl.QuartzJob;\r
30 import org.commscope.tr069adapter.common.timer.TimerListener;\r
31 import org.slf4j.Logger;\r
32 import org.slf4j.LoggerFactory;\r
33 import org.springframework.context.ApplicationContext;\r
34 import org.springframework.stereotype.Component;\r
35 \r
36 @Component("timerHandler")\r
37 public class TimerHandlerDM implements Job {\r
38 \r
39   private static final Logger logger = LoggerFactory.getLogger(TimerHandlerDM.class);\r
40 \r
41   @Override\r
42   public void execute(ExecutionContext context) {\r
43 \r
44     try {\r
45       logger.debug("Notification is received at {} for timer :{}", new Date(), context.getJobId());\r
46       String beanName = context.getJobData(TIMER_LISTENER_KEY) + "";\r
47       String timerId = context.getJobId();\r
48       Object obj = context.getJobData(TIMER_DATA_KEY);\r
49       Serializable data = (obj == null) ? null : (Serializable) obj;\r
50       ApplicationContext ctx = QuartzJob.getApplicationContext();\r
51       TimerListener listener = (TimerListener) ctx.getBean(beanName);\r
52       listener.notifyTimeout(timerId, data);\r
53     } catch (Exception e) {\r
54       logger.error("Error while notifying timer listener. {}", e.toString());\r
55     }\r
56 \r
57   }\r
58 \r
59 }\r