2 * Copyright © 2024 Orange, Inc. and others. All rights reserved.
4 * This program and the accompanying materials are made available under the
5 * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6 * and is available at http://www.eclipse.org/legal/epl-v10.html
8 package org.opendaylight.transportpce.servicehandler.impl;
10 import com.google.common.util.concurrent.ListenableFuture;
11 import java.time.OffsetDateTime;
12 import java.time.ZoneOffset;
13 import java.time.format.DateTimeFormatter;
14 import java.util.Optional;
15 import org.opendaylight.transportpce.servicehandler.DowngradeConstraints;
16 import org.opendaylight.transportpce.servicehandler.ModelMappingUtils;
17 import org.opendaylight.transportpce.servicehandler.ServiceInput;
18 import org.opendaylight.transportpce.servicehandler.impl.ServicehandlerImpl.LogMessages;
19 import org.opendaylight.transportpce.servicehandler.listeners.NetworkListener;
20 import org.opendaylight.transportpce.servicehandler.listeners.PceListener;
21 import org.opendaylight.transportpce.servicehandler.listeners.RendererListener;
22 import org.opendaylight.transportpce.servicehandler.service.RendererServiceWrapper;
23 import org.opendaylight.transportpce.servicehandler.service.ServiceDataStoreOperations;
24 import org.opendaylight.yang.gen.v1.http.org.openroadm.common.service.types.rev230526.RpcActions;
25 import org.opendaylight.yang.gen.v1.http.org.openroadm.common.service.types.rev230526.ServiceNotificationTypes;
26 import org.opendaylight.yang.gen.v1.http.org.openroadm.common.service.types.rev230526.configuration.response.common.ConfigurationResponseCommon;
27 import org.opendaylight.yang.gen.v1.http.org.openroadm.common.service.types.rev230526.sdnc.request.header.SdncRequestHeaderBuilder;
28 import org.opendaylight.yang.gen.v1.http.org.openroadm.common.state.types.rev191129.State;
29 import org.opendaylight.yang.gen.v1.http.org.openroadm.routing.constraints.rev221209.routing.constraints.HardConstraints;
30 import org.opendaylight.yang.gen.v1.http.org.openroadm.routing.constraints.rev221209.routing.constraints.SoftConstraints;
31 import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev230526.ServiceDeleteInputBuilder;
32 import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev230526.ServiceRestoration;
33 import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev230526.ServiceRestorationInput;
34 import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev230526.ServiceRestorationOutput;
35 import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev230526.service.delete.input.ServiceDeleteReqInfo.TailRetention;
36 import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev230526.service.delete.input.ServiceDeleteReqInfoBuilder;
37 import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev230526.service.list.Services;
38 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.yang.types.rev130715.DateAndTime;
39 import org.opendaylight.yangtools.yang.common.RpcResult;
40 import org.slf4j.Logger;
41 import org.slf4j.LoggerFactory;
44 public class ServiceRestorationImpl implements ServiceRestoration {
45 private static final Logger LOG = LoggerFactory.getLogger(ServiceRestorationImpl.class);
46 private static final String SERVICE_RESTORATION_MSG = "serviceRestoration: {}";
48 private ServiceDataStoreOperations serviceDataStoreOperations;
49 private PceListener pceListener;
50 private RendererListener rendererListener;
51 private NetworkListener networkListener;
52 private RendererServiceWrapper rendererServiceWrapper;
54 public ServiceRestorationImpl(final ServiceDataStoreOperations serviceDataStoreOperations,
55 final PceListener pceListener, RendererListener rendererListener, NetworkListener networkListener,
56 RendererServiceWrapper rendererServiceWrapper) {
57 this.serviceDataStoreOperations = serviceDataStoreOperations;
58 this.pceListener = pceListener;
59 this.rendererListener = rendererListener;
60 this.networkListener = networkListener;
61 this.rendererServiceWrapper = rendererServiceWrapper;
65 public ListenableFuture<RpcResult<ServiceRestorationOutput>> invoke(ServiceRestorationInput input) {
66 String serviceName = input.getServiceName();
67 LOG.info("RPC serviceRestoration received for {}", serviceName);
68 Optional<Services> servicesObject = this.serviceDataStoreOperations.getService(serviceName);
70 if (!servicesObject.isPresent()) {
71 LOG.warn(SERVICE_RESTORATION_MSG, LogMessages.serviceNotInDS(serviceName));
72 return ModelMappingUtils.createRestoreServiceReply(
73 LogMessages.serviceNotInDS(serviceName));
76 Services service = servicesObject.orElseThrow();
77 State state = service.getOperationalState();
79 if (state == State.InService) {
80 LOG.error(SERVICE_RESTORATION_MSG, LogMessages.serviceInService(serviceName));
81 return ModelMappingUtils.createRestoreServiceReply(
82 LogMessages.serviceInService(serviceName));
85 DateTimeFormatter dtf = DateTimeFormatter.ofPattern("yyyy-MM-dd'T'HH:mm:ssxxx");
86 OffsetDateTime offsetDateTime = OffsetDateTime.now(ZoneOffset.UTC);
87 DateAndTime datetime = new DateAndTime(dtf.format(offsetDateTime));
88 SdncRequestHeaderBuilder sdncBuilder = new SdncRequestHeaderBuilder()
89 .setNotificationUrl(service.getSdncRequestHeader().getNotificationUrl())
90 .setRequestId(service.getSdncRequestHeader().getRequestId())
91 .setRequestSystemId(service.getSdncRequestHeader().getRequestSystemId())
92 .setRpcAction(RpcActions.ServiceDelete);
93 ServiceDeleteInputBuilder deleteInputBldr = new ServiceDeleteInputBuilder()
94 .setServiceDeleteReqInfo(new ServiceDeleteReqInfoBuilder()
95 .setServiceName(serviceName)
97 .setTailRetention(TailRetention.No).build())
98 .setSdncRequestHeader(sdncBuilder.build());
99 ServiceInput serviceInput = new ServiceInput(deleteInputBldr.build());
100 serviceInput.setServiceAEnd(service.getServiceAEnd());
101 serviceInput.setServiceZEnd(service.getServiceZEnd());
102 serviceInput.setConnectionType(service.getConnectionType());
103 HardConstraints hardConstraints = service.getHardConstraints();
104 if (hardConstraints == null) {
105 LOG.warn("service '{}' HardConstraints is not set !", serviceName);
107 SoftConstraints softConstraints = service.getSoftConstraints();
108 if (softConstraints == null) {
109 LOG.warn("service '{}' SoftConstraints is not set !", serviceName);
110 serviceInput.setSoftConstraints(DowngradeConstraints.convertToSoftConstraints(hardConstraints));
112 LOG.info("converting hard constraints to soft constraints ...");
113 serviceInput.setSoftConstraints(
114 DowngradeConstraints.updateSoftConstraints(hardConstraints, softConstraints));
116 serviceInput.setHardConstraints(DowngradeConstraints.downgradeHardConstraints(hardConstraints));
118 this.pceListener.setInput(serviceInput);
119 this.pceListener.setServiceReconfigure(true);
120 this.pceListener.setserviceDataStoreOperations(this.serviceDataStoreOperations);
121 this.rendererListener.setServiceInput(serviceInput);
122 this.rendererListener.setserviceDataStoreOperations(this.serviceDataStoreOperations);
123 this.networkListener.setserviceDataStoreOperations(serviceDataStoreOperations);
124 org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.renderer.rev210915
125 .ServiceDeleteInput serviceDeleteInput = ModelMappingUtils.createServiceDeleteInput(
126 new ServiceInput(deleteInputBldr.build()));
127 org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.renderer.rev210915
128 .ServiceDeleteOutput output = this.rendererServiceWrapper.performRenderer(serviceDeleteInput,
129 ServiceNotificationTypes.ServiceDeleteResult, null);
130 if (output == null) {
131 LOG.error(SERVICE_RESTORATION_MSG, LogMessages.RENDERER_DELETE_FAILED);
132 return ModelMappingUtils.createRestoreServiceReply(LogMessages.RENDERER_DELETE_FAILED);
134 LOG.info("RPC serviceRestore in progress...");
135 ConfigurationResponseCommon common = output.getConfigurationResponseCommon();
136 return ModelMappingUtils.createRestoreServiceReply(common.getResponseMessage());