2 * Copyright (c) 2014 Cisco Systems, 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.controller.sal.compatibility
10 import java.util.Arrays
11 import java.util.Dictionary
12 import java.util.Hashtable
13 import org.apache.felix.dm.Component
14 import org.opendaylight.controller.clustering.services.IClusterGlobalServices
15 import org.opendaylight.controller.sal.binding.api.BindingAwareBroker
16 import org.opendaylight.controller.sal.binding.api.BindingAwareBroker.ConsumerContext
17 import org.opendaylight.controller.sal.binding.api.BindingAwareBroker.ProviderContext
18 import org.opendaylight.controller.sal.binding.api.BindingAwareProvider
19 import org.opendaylight.controller.sal.binding.api.NotificationService
20 import org.opendaylight.controller.sal.binding.api.data.DataBrokerService
21 import org.opendaylight.controller.sal.binding.api.data.DataProviderService
22 import org.opendaylight.controller.sal.compatibility.adsal.DataPacketServiceAdapter
23 import org.opendaylight.controller.sal.compatibility.topology.TopologyAdapter
24 import org.opendaylight.controller.sal.compatibility.topology.TopologyProvider
25 import org.opendaylight.controller.sal.core.ComponentActivatorAbstractBase
26 import org.opendaylight.controller.sal.core.Node
27 import org.opendaylight.controller.sal.core.NodeConnector
28 import org.opendaylight.controller.sal.discovery.IDiscoveryService
29 import org.opendaylight.controller.sal.flowprogrammer.IPluginInFlowProgrammerService
30 import org.opendaylight.controller.sal.flowprogrammer.IPluginOutFlowProgrammerService
31 import org.opendaylight.controller.sal.inventory.IPluginInInventoryService
32 import org.opendaylight.controller.sal.inventory.IPluginOutInventoryService
33 import org.opendaylight.controller.sal.packet.IPluginInDataPacketService
34 import org.opendaylight.controller.sal.packet.IPluginOutDataPacketService
35 import org.opendaylight.controller.sal.reader.IPluginInReadService
36 import org.opendaylight.controller.sal.reader.IPluginOutReadService
37 import org.opendaylight.controller.sal.topology.IPluginInTopologyService
38 import org.opendaylight.controller.sal.topology.IPluginOutTopologyService
39 import org.opendaylight.controller.sal.utils.GlobalConstants
40 import org.opendaylight.controller.sal.utils.INodeConnectorFactory
41 import org.opendaylight.controller.sal.utils.INodeFactory
42 import org.opendaylight.yang.gen.v1.urn.opendaylight.flow.service.rev130819.SalFlowService
43 import org.opendaylight.yang.gen.v1.urn.opendaylight.flow.statistics.rev130819.OpendaylightFlowStatisticsService
44 import org.opendaylight.yang.gen.v1.urn.opendaylight.flow.table.statistics.rev131215.OpendaylightFlowTableStatisticsService
45 import org.opendaylight.yang.gen.v1.urn.opendaylight.flow.topology.discovery.rev130819.FlowTopologyDiscoveryService
46 import org.opendaylight.yang.gen.v1.urn.opendaylight.packet.service.rev130709.PacketProcessingService
47 import org.opendaylight.yang.gen.v1.urn.opendaylight.port.statistics.rev131214.OpendaylightPortStatisticsService
48 import org.osgi.framework.BundleContext
50 import static org.opendaylight.controller.sal.compatibility.NodeMapping.*
52 class ComponentActivator extends ComponentActivatorAbstractBase {
54 private BundleContext context;
57 FlowProgrammerAdapter flow = new FlowProgrammerAdapter;
60 InventoryAndReadAdapter inventory = new InventoryAndReadAdapter;
63 DataPacketAdapter dataPacket = new DataPacketAdapter;
66 INodeFactory nodeFactory = new MDSalNodeFactory
69 INodeConnectorFactory nodeConnectorFactory = new MDSalNodeConnectorFactory
72 TopologyAdapter topology = new TopologyAdapter
75 TopologyProvider tpProvider = new TopologyProvider()
78 DataPacketServiceAdapter dataPacketService = new DataPacketServiceAdapter()
82 override protected init() {
83 Node.NodeIDType.registerIDType(MD_SAL_TYPE, String);
84 NodeConnector.NodeConnectorIDType.registerIDType(MD_SAL_TYPE, String, MD_SAL_TYPE);
87 override start(BundleContext context) {
89 this.context = context;
92 def setBroker(BindingAwareBroker broker) {
93 broker.registerProvider(new SalCompatibilityProvider(this), context)
97 override protected getGlobalImplementations() {
98 return Arrays.asList(this, flow, inventory, dataPacket, nodeFactory, nodeConnectorFactory,topology,tpProvider)
101 override protected configureGlobalInstance(Component c, Object imp) {
105 override protected getImplementations() {
106 return Arrays.asList(dataPacketService)
109 override protected configureInstance(Component c, Object imp, String containerName) {
110 instanceConfigure(imp, c, containerName);
113 private def dispatch configure(MDSalNodeFactory imp, Component it) {
114 setInterface(INodeFactory.name, properties);
117 private def dispatch configure(MDSalNodeConnectorFactory imp, Component it) {
118 setInterface(INodeConnectorFactory.name, properties);
121 private def dispatch configure(ComponentActivator imp, Component it) {
123 createServiceDependency().setService(BindingAwareBroker) //
124 .setCallbacks("setBroker", "setBroker") //
130 private def dispatch configure(DataPacketAdapter imp, Component it) {
132 createServiceDependency() //
133 .setService(IPluginOutDataPacketService) //
134 .setCallbacks("setDataPacketPublisher", "setDataPacketPublisher") //
138 private def dispatch configure(FlowProgrammerAdapter imp, Component it) {
139 setInterface(IPluginInFlowProgrammerService.name, properties)
141 createServiceDependency() //
142 .setService(IPluginOutFlowProgrammerService) //
143 .setCallbacks("setFlowProgrammerPublisher", "setFlowProgrammerPublisher") //
147 createServiceDependency() //
148 .setService(IClusterGlobalServices) //
149 .setCallbacks("setClusterGlobalServices", "unsetClusterGlobalServices") //
154 private def dispatch instanceConfigure(DataPacketServiceAdapter imp, Component it, String containerName) {
155 setInterface(IPluginInDataPacketService.name, properties)
158 private def dispatch instanceConfigure(ComponentActivator imp, Component it, String containerName) {
162 private def dispatch configure(InventoryAndReadAdapter imp, Component it) {
163 setInterface(Arrays.asList(IPluginInInventoryService.name, IPluginInReadService.name), properties)
165 createServiceDependency() //
166 .setService(IPluginOutReadService) //
167 .setCallbacks("setReadPublisher", "unsetReadPublisher") //
170 createServiceDependency() //
171 .setService(IPluginOutInventoryService) //
172 .setCallbacks("setInventoryPublisher", "unsetInventoryPublisher") //
175 createServiceDependency() //
176 .setService(IDiscoveryService) //
177 .setCallbacks("setDiscoveryPublisher", "setDiscoveryPublisher") //
183 private def dispatch configure (TopologyAdapter imp, Component it) {
184 setInterface(Arrays.asList(IPluginInTopologyService.name), properties)
186 createServiceDependency() //
187 .setService(IPluginOutTopologyService) //
188 .setCallbacks("setTopologyPublisher", "setTopologyPublisher") //
192 private def dispatch configure (TopologyProvider imp, Component it) {
194 createServiceDependency() //
195 .setService(IPluginOutTopologyService) //
196 .setCallbacks("setTopologyPublisher", "setTopologyPublisher") //
200 private def Dictionary<String, Object> properties() {
201 val props = new Hashtable<String, Object>();
202 props.put(GlobalConstants.PROTOCOLPLUGINTYPE.toString, MD_SAL_TYPE)
203 props.put("protocolName", MD_SAL_TYPE);
207 package class SalCompatibilityProvider implements BindingAwareProvider {
209 private val ComponentActivator activator;
211 new(ComponentActivator cmpAct) {
215 override getFunctionality() {
219 override getImplementations() {
224 override onSessionInitialized(ConsumerContext session) {
229 override onSessionInitiated(ProviderContext session) {
231 val subscribe = session.getSALService(NotificationService)
233 // Registration of Flow Service
234 flow.delegate = session.getRpcService(SalFlowService)
235 flow.dataBrokerService = session.getSALService(DataBrokerService);
236 subscribe.registerNotificationListener(flow);
238 // Data Packet Service
239 subscribe.registerNotificationListener(inventory);
240 dataPacketService.delegate = session.getRpcService(PacketProcessingService)
243 inventory.dataService = session.getSALService(DataBrokerService);
244 inventory.flowStatisticsService = session.getRpcService(OpendaylightFlowStatisticsService);
245 inventory.flowTableStatisticsService = session.getRpcService(OpendaylightFlowTableStatisticsService);
246 inventory.nodeConnectorStatisticsService = session.getRpcService(OpendaylightPortStatisticsService);
247 inventory.topologyDiscovery = session.getRpcService(FlowTopologyDiscoveryService);
248 inventory.dataProviderService = session.getSALService(DataProviderService)
249 topology.dataService = session.getSALService(DataProviderService)
250 tpProvider.dataService = session.getSALService(DataProviderService)
252 inventory.startAdapter();
254 tpProvider.startAdapter();
256 subscribe.registerNotificationListener(dataPacket)