X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=servicehandler%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Ftransportpce%2Fservicehandler%2Fimpl%2FServicehandlerProvider.java;h=d8662c68db7cb1176e5db77da786a11d8e5312d3;hb=cb8ebd04e8e896faf9f2157ca182939191dd7ea2;hp=9237fd28494c7f7865186ff5e7a9207f2f59cbe2;hpb=f635c4d0e4252050154b89d53bd7e658eaf75be8;p=transportpce.git
diff --git a/servicehandler/src/main/java/org/opendaylight/transportpce/servicehandler/impl/ServicehandlerProvider.java b/servicehandler/src/main/java/org/opendaylight/transportpce/servicehandler/impl/ServicehandlerProvider.java
index 9237fd284..d8662c68d 100644
--- a/servicehandler/src/main/java/org/opendaylight/transportpce/servicehandler/impl/ServicehandlerProvider.java
+++ b/servicehandler/src/main/java/org/opendaylight/transportpce/servicehandler/impl/ServicehandlerProvider.java
@@ -8,24 +8,28 @@
package org.opendaylight.transportpce.servicehandler.impl;
-import org.opendaylight.controller.md.sal.binding.api.DataBroker;
-import org.opendaylight.controller.md.sal.binding.api.NotificationPublishService;
-import org.opendaylight.controller.md.sal.binding.api.NotificationService;
-import org.opendaylight.controller.sal.binding.api.BindingAwareBroker.RpcRegistration;
-import org.opendaylight.controller.sal.binding.api.RpcProviderRegistry;
-import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.servicehandler.rev170930.ServicehandlerService;
-import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.stubpce.rev170426.StubpceListener;
-import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.stubrenderer.rev170426.StubrendererListener;
-import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev161014.OrgOpenroadmServiceService;
+import org.opendaylight.mdsal.binding.api.DataBroker;
+import org.opendaylight.mdsal.binding.api.NotificationPublishService;
+import org.opendaylight.mdsal.binding.api.NotificationService;
+import org.opendaylight.mdsal.binding.api.RpcProviderService;
+import org.opendaylight.transportpce.pce.service.PathComputationService;
+import org.opendaylight.transportpce.renderer.provisiondevice.RendererServiceOperations;
+import org.opendaylight.transportpce.servicehandler.listeners.NetworkModelListenerImpl;
+import org.opendaylight.transportpce.servicehandler.listeners.PceListenerImpl;
+import org.opendaylight.transportpce.servicehandler.listeners.RendererListenerImpl;
+import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.networkmodel.rev201116.TransportpceNetworkmodelListener;
+import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.pce.rev200128.TransportpcePceListener;
+import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.renderer.rev201125.TransportpceRendererListener;
+import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev190531.OrgOpenroadmServiceService;
import org.opendaylight.yangtools.concepts.ListenerRegistration;
+import org.opendaylight.yangtools.concepts.ObjectRegistration;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
* Class to register
* Servicehandler Service and Notification.
- *
- * @author Martial Coulibaly on behalf of Orange
+ * @author Martial Coulibaly ( martial.coulibaly@gfi.com ) on behalf of Orange
*
*/
public class ServicehandlerProvider {
@@ -33,22 +37,25 @@ public class ServicehandlerProvider {
private static final Logger LOG = LoggerFactory.getLogger(ServicehandlerProvider.class);
private final DataBroker dataBroker;
- private final RpcProviderRegistry rpcRegistry;
+ private final RpcProviderService rpcService;
private final NotificationService notificationService;
private final NotificationPublishService notificationPublishService;
+ private ListenerRegistration pcelistenerRegistration;
+ private ListenerRegistration rendererlistenerRegistration;
+ private ListenerRegistration networkmodellistenerRegistration;
+ private ObjectRegistration rpcRegistration;
+ private PathComputationService pathComputationService;
+ private RendererServiceOperations rendererServiceOperations;
- /** Listener register for TransportpceService Notification. */
- private ListenerRegistration stubpcelistenerRegistration;
- private ListenerRegistration stubrendererlistenerRegistration;
- private RpcRegistration rpcRegistration;
- private RpcRegistration rpcRegistrationServiceHandler;
-
-
- public ServicehandlerProvider(final DataBroker dataBroker, RpcProviderRegistry rpcProviderRegistry,
- NotificationService notificationService, NotificationPublishService notificationPublishService) {
+ public ServicehandlerProvider(final DataBroker dataBroker, RpcProviderService rpcProviderService,
+ NotificationService notificationService, PathComputationService pathComputationService,
+ RendererServiceOperations rendererServiceOperations,
+ NotificationPublishService notificationPublishService) {
this.dataBroker = dataBroker;
- this.rpcRegistry = rpcProviderRegistry;
+ this.rpcService = rpcProviderService;
this.notificationService = notificationService;
+ this.pathComputationService = pathComputationService;
+ this.rendererServiceOperations = rendererServiceOperations;
this.notificationPublishService = notificationPublishService;
}
@@ -57,11 +64,20 @@ public class ServicehandlerProvider {
*/
public void init() {
LOG.info("ServicehandlerProvider Session Initiated");
- final ServicehandlerImpl consumer = new ServicehandlerImpl(dataBroker, rpcRegistry, notificationPublishService);
- stubpcelistenerRegistration = notificationService.registerNotificationListener(consumer);
- stubrendererlistenerRegistration = notificationService.registerNotificationListener(consumer);
- rpcRegistration = rpcRegistry.addRpcImplementation(OrgOpenroadmServiceService.class, consumer);
- rpcRegistrationServiceHandler = rpcRegistry.addRpcImplementation(ServicehandlerService.class, consumer);
+ final PceListenerImpl pceListenerImpl = new PceListenerImpl(rendererServiceOperations,
+ pathComputationService, notificationPublishService, null);
+ final RendererListenerImpl rendererListenerImpl =
+ new RendererListenerImpl(pathComputationService, notificationPublishService);
+ final NetworkModelListenerImpl networkModelListenerImpl =
+ new NetworkModelListenerImpl(notificationPublishService, null);
+ pcelistenerRegistration = notificationService.registerNotificationListener(pceListenerImpl);
+ rendererlistenerRegistration = notificationService.registerNotificationListener(rendererListenerImpl);
+ networkmodellistenerRegistration = notificationService.registerNotificationListener(networkModelListenerImpl);
+ final ServicehandlerImpl servicehandler = new ServicehandlerImpl(dataBroker, pathComputationService,
+ rendererServiceOperations, notificationPublishService, pceListenerImpl, rendererListenerImpl,
+ networkModelListenerImpl);
+ rpcRegistration =
+ rpcService.registerRpcImplementation(OrgOpenroadmServiceService.class, servicehandler);
}
/**
@@ -69,9 +85,10 @@ public class ServicehandlerProvider {
*/
public void close() {
LOG.info("ServicehandlerProvider Closed");
- stubpcelistenerRegistration.close();
- stubrendererlistenerRegistration.close();
+ pcelistenerRegistration.close();
+ rendererlistenerRegistration.close();
+ networkmodellistenerRegistration.close();
rpcRegistration.close();
- rpcRegistrationServiceHandler.close();
}
+
}