2 * Copyright (c) 2018 Pantheon Technologies s.r.o. 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 https://www.eclipse.org/legal/epl-v10.html
9 package io.lighty.controllers.tpce.module;
11 import io.lighty.core.controller.api.AbstractLightyModule;
12 import io.lighty.core.controller.api.LightyServices;
13 import org.opendaylight.transportpce.common.crossconnect.CrossConnectImpl;
14 import org.opendaylight.transportpce.common.crossconnect.CrossConnectImpl121;
15 import org.opendaylight.transportpce.common.crossconnect.CrossConnectImpl221;
16 import org.opendaylight.transportpce.common.device.DeviceTransactionManagerImpl;
17 import org.opendaylight.transportpce.common.fixedflex.FixedFlexImpl;
18 import org.opendaylight.transportpce.common.mapping.MappingUtilsImpl;
19 import org.opendaylight.transportpce.common.mapping.PortMappingImpl;
20 import org.opendaylight.transportpce.common.mapping.PortMappingVersion121;
21 import org.opendaylight.transportpce.common.mapping.PortMappingVersion221;
22 import org.opendaylight.transportpce.common.network.NetworkTransactionImpl;
23 import org.opendaylight.transportpce.common.network.RequestProcessor;
24 import org.opendaylight.transportpce.common.openroadminterfaces.OpenRoadmInterfacesImpl;
25 import org.opendaylight.transportpce.common.openroadminterfaces.OpenRoadmInterfacesImpl121;
26 import org.opendaylight.transportpce.common.openroadminterfaces.OpenRoadmInterfacesImpl221;
27 import org.opendaylight.transportpce.networkmodel.NetConfTopologyListener;
28 import org.opendaylight.transportpce.networkmodel.NetworkModelProvider;
29 import org.opendaylight.transportpce.networkmodel.NetworkUtilsImpl;
30 import org.opendaylight.transportpce.networkmodel.R2RLinkDiscovery;
31 import org.opendaylight.transportpce.networkmodel.service.NetworkModelServiceImpl;
32 // OpenRoadmFctory and OpenRoadmTopology22 has been deleted
33 import org.opendaylight.transportpce.networkmodel.util.OpenRoadmTopology;
35 import org.opendaylight.transportpce.olm.OlmPowerServiceRpcImpl;
36 import org.opendaylight.transportpce.olm.OlmProvider;
37 import org.opendaylight.transportpce.olm.power.PowerMgmt;
38 import org.opendaylight.transportpce.olm.power.PowerMgmtImpl;
39 import org.opendaylight.transportpce.olm.service.OlmPowerServiceImpl;
40 import org.opendaylight.transportpce.pce.impl.PceProvider;
41 import org.opendaylight.transportpce.pce.service.PathComputationServiceImpl;
42 import org.opendaylight.transportpce.renderer.NetworkModelWavelengthServiceImpl;
43 import org.opendaylight.transportpce.renderer.RendererProvider;
44 import org.opendaylight.transportpce.renderer.openroadminterface.OpenRoadmInterface121;
45 import org.opendaylight.transportpce.renderer.openroadminterface.OpenRoadmInterface221;
46 // Adding OTN interface
47 import org.opendaylight.transportpce.renderer.openroadminterface.OpenRoadmOtnInterface221;
49 import org.opendaylight.transportpce.renderer.openroadminterface.OpenRoadmInterfaceFactory;
50 import org.opendaylight.transportpce.renderer.provisiondevice.DeviceRendererServiceImpl;
52 import org.opendaylight.transportpce.renderer.provisiondevice.OtnDeviceRendererServiceImpl;
54 import org.opendaylight.transportpce.renderer.provisiondevice.RendererServiceOperationsImpl;
55 import org.opendaylight.transportpce.renderer.rpcs.DeviceRendererRPCImpl;
57 import org.opendaylight.transportpce.servicehandler.impl.ServicehandlerProvider;
58 import org.slf4j.Logger;
59 import org.slf4j.LoggerFactory;
61 public class TransportPCEImpl extends AbstractLightyModule implements TransportPCE {
63 private static final Logger LOG = LoggerFactory.getLogger(TransportPCEImpl.class);
64 private static final long MaxDurationToSubmitTransaction = 1500;
67 private final DeviceTransactionManagerImpl deviceTransactionManager;
68 private final MappingUtilsImpl mappingUtils;
69 private final OpenRoadmInterfacesImpl121 openRoadmInterfacesImpl121;
70 private final OpenRoadmInterfacesImpl221 openRoadmInterfacesImpl221;
71 private final OpenRoadmInterfacesImpl openRoadmInterfaces;
72 private final PortMappingVersion221 portMappingVersion221;
73 private final RequestProcessor requestProcessor;
74 private final NetworkTransactionImpl networkTransaction;
75 private final PortMappingVersion121 portMappingVersion121;
76 private final PortMappingImpl portMapping;
77 private final CrossConnectImpl121 crossConnectImpl121;
78 private final CrossConnectImpl221 crossConnectImpl221;
79 private final CrossConnectImpl crossConnect;
80 private final FixedFlexImpl fixedFlex;
83 private final PathComputationServiceImpl pathComputationService;
84 private final PceProvider pceProvider;
86 // network model beans
87 // private final OpenRoadmTopology22 openRoadmTopology22;
88 // private final OpenRoadmFactory openRoadmFactory;
89 // private final OpenRoadmTopology openRoadmTopology;
91 private final R2RLinkDiscovery linkDiscoveryImpl;
92 private final NetworkUtilsImpl networkutilsServiceImpl;
93 private final NetworkModelServiceImpl networkModelService;
94 private final NetConfTopologyListener netConfTopologyListener;
95 private final NetworkModelProvider networkModelProvider;
98 private final PowerMgmt powerMgmt;
99 private final OlmPowerServiceImpl olmPowerService;
100 private final OlmProvider olmProvider;
101 private final OlmPowerServiceRpcImpl olmPowerServiceRpc;
104 private final OpenRoadmInterface121 openRoadmInterface121;
105 private final OpenRoadmInterface221 openRoadmInterface221;
106 private final OpenRoadmOtnInterface221 openRoadmOtnInterface221;
108 private final OpenRoadmInterfaceFactory openRoadmInterfaceFactory;
109 private final DeviceRendererServiceImpl deviceRendererService;
110 private final OtnDeviceRendererServiceImpl otnDeviceRendererService;
111 private final DeviceRendererRPCImpl deviceRendererRPC;
112 private final NetworkModelWavelengthServiceImpl networkModelWavelengthService;
113 private final RendererServiceOperationsImpl rendererServiceOperations;
114 private final RendererProvider rendererProvider;
116 // service-handler beans
117 private final ServicehandlerProvider servicehandlerProvider;
119 public TransportPCEImpl(LightyServices lightyServices) {
120 LOG.info("Creating common beans ...");
121 deviceTransactionManager = new DeviceTransactionManagerImpl(lightyServices.getBindingMountPointService(), MaxDurationToSubmitTransaction);
122 mappingUtils = new MappingUtilsImpl(lightyServices.getBindingDataBroker());
123 openRoadmInterfacesImpl121 = new OpenRoadmInterfacesImpl121(deviceTransactionManager);
124 openRoadmInterfacesImpl221 = new OpenRoadmInterfacesImpl221(deviceTransactionManager);
125 openRoadmInterfaces = new OpenRoadmInterfacesImpl(deviceTransactionManager, mappingUtils, openRoadmInterfacesImpl121, openRoadmInterfacesImpl221);
126 portMappingVersion221 = new PortMappingVersion221(lightyServices.getBindingDataBroker(), deviceTransactionManager, openRoadmInterfaces);
127 requestProcessor = new RequestProcessor(lightyServices.getBindingDataBroker());
128 networkTransaction = new NetworkTransactionImpl(requestProcessor);
129 portMappingVersion121 = new PortMappingVersion121(lightyServices.getBindingDataBroker(), deviceTransactionManager, openRoadmInterfaces);
130 portMapping = new PortMappingImpl(lightyServices.getBindingDataBroker(), portMappingVersion221, portMappingVersion121);
131 crossConnectImpl121 = new CrossConnectImpl121(deviceTransactionManager);
132 crossConnectImpl221 = new CrossConnectImpl221(deviceTransactionManager);
133 crossConnect = new CrossConnectImpl(deviceTransactionManager, mappingUtils, crossConnectImpl121, crossConnectImpl221);
134 fixedFlex = new FixedFlexImpl();
136 LOG.info("Creating PCE beans ...");
137 pathComputationService = new PathComputationServiceImpl(networkTransaction, lightyServices.getBindingNotificationPublishService());
138 pceProvider = new PceProvider(lightyServices.getRpcProviderService(), pathComputationService);
140 LOG.info("Creating network-model beans ...");
141 // TODO: Need to look into it
145 // TODO: Add OTN network model
147 linkDiscoveryImpl = new R2RLinkDiscovery(lightyServices.getBindingDataBroker(), deviceTransactionManager, networkTransaction);
148 networkutilsServiceImpl = new NetworkUtilsImpl(lightyServices.getBindingDataBroker());
149 networkModelService = new NetworkModelServiceImpl(networkTransaction, linkDiscoveryImpl, portMapping);
150 netConfTopologyListener = new NetConfTopologyListener(networkModelService, lightyServices.getBindingDataBroker(), deviceTransactionManager);
151 networkModelProvider = new NetworkModelProvider(networkTransaction, lightyServices.getBindingDataBroker(),
152 lightyServices.getRpcProviderService(), networkutilsServiceImpl, netConfTopologyListener);
154 LOG.info("Creating OLM beans ...");
155 powerMgmt = new PowerMgmtImpl(lightyServices.getBindingDataBroker(), openRoadmInterfaces, crossConnect, deviceTransactionManager);
156 olmPowerService = new OlmPowerServiceImpl(lightyServices.getBindingDataBroker(), powerMgmt, deviceTransactionManager, portMapping, mappingUtils, openRoadmInterfaces);
157 olmProvider = new OlmProvider(lightyServices.getRpcProviderService(), olmPowerService);
158 olmPowerServiceRpc = new OlmPowerServiceRpcImpl(olmPowerService);
160 LOG.info("Creating renderer beans ...");
161 openRoadmInterface121 = new OpenRoadmInterface121(portMapping, openRoadmInterfaces);
162 openRoadmInterface221 = new OpenRoadmInterface221(portMapping, openRoadmInterfaces, fixedFlex);
163 openRoadmOtnInterface221 = new OpenRoadmOtnInterface221(portMapping, openRoadmInterfaces);
164 openRoadmInterfaceFactory = new OpenRoadmInterfaceFactory(mappingUtils, openRoadmInterface121,
165 openRoadmInterface221, openRoadmOtnInterface221);
166 deviceRendererService = new DeviceRendererServiceImpl(lightyServices.getBindingDataBroker(), deviceTransactionManager,
167 openRoadmInterfaceFactory, openRoadmInterfaces, crossConnect, portMapping, networkModelService);
168 otnDeviceRendererService = new OtnDeviceRendererServiceImpl(openRoadmInterfaceFactory, crossConnect, openRoadmInterfaces,
169 deviceTransactionManager, networkModelService);
170 deviceRendererRPC = new DeviceRendererRPCImpl(deviceRendererService, otnDeviceRendererService);
171 networkModelWavelengthService = new NetworkModelWavelengthServiceImpl(lightyServices.getBindingDataBroker());
172 rendererServiceOperations = new RendererServiceOperationsImpl(deviceRendererService, olmPowerServiceRpc, lightyServices.getBindingDataBroker(), networkModelWavelengthService, lightyServices.getBindingNotificationPublishService());
173 rendererProvider = new RendererProvider(lightyServices.getRpcProviderService(), deviceRendererRPC, rendererServiceOperations);
175 LOG.info("Creating service-handler beans ...");
176 servicehandlerProvider = new ServicehandlerProvider(lightyServices.getBindingDataBroker(), lightyServices.getRpcProviderService(), lightyServices.getNotificationService(),
177 pathComputationService, rendererServiceOperations, networkModelWavelengthService, lightyServices.getBindingNotificationPublishService());
182 protected boolean initProcedure() {
183 LOG.info("Initializing common beans ...");
184 LOG.info("Initializing PCE beans ...");
185 pathComputationService.init();
187 LOG.info("Initializing network-model beans ...");
188 networkModelProvider.init();
189 LOG.info("Initializing OLM beans ...");
190 olmPowerService.init();
192 LOG.info("Initializing renderer beans ...");
193 rendererProvider.init();
194 LOG.info("Initializing service-handler beans ...");
195 servicehandlerProvider.init();
196 LOG.info("Init done.");
201 protected boolean stopProcedure() {
202 LOG.info("Shutting down service-handler beans ...");
203 servicehandlerProvider.close();
204 LOG.info("Shutting down renderer beans ...");
205 rendererProvider.close();
206 LOG.info("Shutting down OLM beans ...");
208 olmPowerService.close();
209 LOG.info("Shutting down network-model beans ...");
210 networkModelProvider.close();
211 LOG.info("Shutting down PCE beans ...");
212 pathComputationService.close();
214 LOG.info("Shutting down common beans ...");
215 networkTransaction.close();
216 deviceTransactionManager.preDestroy();
217 LOG.info("Shutdown done.");