Initial source code
[oam/tr069-adapter.git] / netconf-server / src / main / java / org / commscope / tr069adapter / netconf / server / RestartNetconfServerHandler.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.netconf.server;\r
20 \r
21 import java.util.List;\r
22 \r
23 import org.commscope.tr069adapter.netconf.entity.NetConfServerDetailsEntity;\r
24 import org.commscope.tr069adapter.netconf.error.RetryFailedException;\r
25 import org.slf4j.Logger;\r
26 import org.slf4j.LoggerFactory;\r
27 import org.springframework.beans.factory.annotation.Autowired;\r
28 import org.springframework.retry.annotation.Backoff;\r
29 import org.springframework.retry.annotation.Recover;\r
30 import org.springframework.retry.annotation.Retryable;\r
31 import org.springframework.stereotype.Service;\r
32 \r
33 @Service\r
34 public class RestartNetconfServerHandler {\r
35 \r
36   private static final Logger logger = LoggerFactory.getLogger(RestartNetconfServerHandler.class);\r
37 \r
38   @Autowired\r
39   NetConfServerManagerImpl manager;\r
40 \r
41   @Retryable(value = {RetryFailedException.class}, maxAttempts = 100,\r
42       backoff = @Backoff(delay = 15000))\r
43   public void restart(List<NetConfServerDetailsEntity> serverDetailsList)\r
44       throws RetryFailedException {\r
45     try {\r
46       // restart netconf servers\r
47       manager.restartServersOnStartup(serverDetailsList);\r
48     } catch (Exception e) {\r
49       logger.error("Retry to netconf servers has  is failed. {}", e.toString());\r
50       throw new RetryFailedException(e);\r
51     }\r
52 \r
53     if (!serverDetailsList.isEmpty()) {\r
54       logger.error("Failed to start some of netconf servers. Retrying starting servers : {}",\r
55           serverDetailsList);\r
56       throw new RetryFailedException(\r
57           "Failed to start some of netconf servers. server list : " + serverDetailsList);\r
58     }\r
59     logger.debug("Successfully started all failed netconf servers.");\r
60   }\r
61 \r
62   @Recover\r
63   public void recover(List<NetConfServerDetailsEntity> serverDetailsList) {\r
64     logger.debug("Retrying starting failed netconf servers.");\r
65     try {\r
66       restart(serverDetailsList);\r
67     } catch (RetryFailedException e) {\r
68       logger.error("Failed to start failed netconf servers. {}", e.toString());\r
69     }\r
70   }\r
71 }\r