2 * Copyright (c) 2013 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.openflowplugin.openflow.md.core.sal;
10 import com.google.common.annotations.VisibleForTesting;
11 import java.util.Collection;
12 import org.opendaylight.controller.md.sal.binding.api.DataBroker;
13 import org.opendaylight.controller.sal.binding.api.NotificationProviderService;
14 import org.opendaylight.controller.sal.binding.api.RpcProviderRegistry;
15 import org.opendaylight.openflowjava.protocol.spi.connection.SwitchConnectionProvider;
16 import org.opendaylight.openflowplugin.api.openflow.statistics.MessageCountDumper;
17 import org.opendaylight.openflowplugin.api.openflow.statistics.MessageObservatory;
18 import org.opendaylight.openflowplugin.extension.api.ExtensionConverterRegistrator;
19 import org.opendaylight.openflowplugin.extension.api.OpenFlowPluginExtensionRegistratorProvider;
20 import org.opendaylight.openflowplugin.openflow.md.core.MDController;
21 import org.opendaylight.openflowplugin.openflow.md.core.extension.ExtensionConverterManager;
22 import org.opendaylight.openflowplugin.openflow.md.core.extension.ExtensionConverterManagerImpl;
23 import org.opendaylight.openflowplugin.openflow.md.core.session.OFRoleManager;
24 import org.opendaylight.openflowplugin.openflow.md.core.session.OFSessionUtil;
25 import org.opendaylight.openflowplugin.statistics.MessageSpyCounterImpl;
26 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.openflow.common.config.impl.rev140326.OfpRole;
27 import org.opendaylight.yangtools.yang.binding.DataContainer;
28 import org.slf4j.Logger;
29 import org.slf4j.LoggerFactory;
32 * OFPlugin provider implementation
34 public class OpenflowPluginProvider implements AutoCloseable, OpenFlowPluginExtensionRegistratorProvider {
36 private static final Logger LOG = LoggerFactory.getLogger(OpenflowPluginProvider.class);
38 private Collection<SwitchConnectionProvider> switchConnectionProviders;
40 private MDController mdController;
42 private MessageObservatory<DataContainer> messageCountProvider;
44 private SalRegistrationManager registrationManager;
46 private ExtensionConverterManager extensionConverterManager;
50 private OFRoleManager roleManager;
51 private DataBroker dataBroker;
52 private NotificationProviderService notificationService;
53 private RpcProviderRegistry rpcRegistry;
56 * Initialization of services and msgSpy counter
58 public void initialization() {
59 messageCountProvider = new MessageSpyCounterImpl();
60 extensionConverterManager = new ExtensionConverterManagerImpl();
61 roleManager = new OFRoleManager(OFSessionUtil.getSessionManager());
63 LOG.debug("dependencies gathered..");
64 registrationManager = new SalRegistrationManager();
65 registrationManager.setDataService(dataBroker);
66 registrationManager.setPublishService(notificationService);
67 registrationManager.setRpcProviderRegistry(rpcRegistry);
68 registrationManager.init();
70 mdController = new MDController();
71 mdController.setSwitchConnectionProviders(switchConnectionProviders);
72 mdController.setMessageSpyCounter(messageCountProvider);
73 mdController.setExtensionConverterProvider(extensionConverterManager);
79 * @param switchConnectionProvider
81 public void setSwitchConnectionProviders(Collection<SwitchConnectionProvider> switchConnectionProvider) {
82 this.switchConnectionProviders = switchConnectionProvider;
90 registrationManager.close();
91 registrationManager = null;
94 public MessageCountDumper getMessageCountDumper() {
95 return messageCountProvider;
99 * @return the extensionConverterRegistry
102 public ExtensionConverterRegistrator getExtensionConverterRegistrator() {
103 return extensionConverterManager;
107 * @param role of instance
109 public void setRole(OfpRole role) {
116 public void fireRoleChange(OfpRole newRole) {
117 if (!role.equals(newRole)) {
118 LOG.debug("my role was chaged from {} to {}", role, newRole);
122 //TODO: implement appropriate action
123 roleManager.manageRoleChange(role);
126 //TODO: implement appropriate action
127 roleManager.manageRoleChange(role);
130 //TODO: implement appropriate action
131 roleManager.manageRoleChange(role);
134 LOG.warn("role not supported: {}", role);
140 public void setDataBroker(DataBroker dataBroker) {
141 this.dataBroker = dataBroker;
144 public void setNotificationService(NotificationProviderService notificationService) {
145 this.notificationService = notificationService;
148 public void setRpcRegistry(RpcProviderRegistry rpcRegistry) {
149 this.rpcRegistry = rpcRegistry;
153 protected RpcProviderRegistry getRpcRegistry() {
158 protected NotificationProviderService getNotificationService() {
159 return notificationService;
163 protected DataBroker getDataBroker() {