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