Bug 868: Remove AD-SAL components which were deprecated in Lithium 40/18740/4
authorTony Tkacik <ttkacik@cisco.com>
Mon, 27 Apr 2015 08:24:21 +0000 (08:24 +0000)
committerTony Tkacik <ttkacik@cisco.com>
Thu, 21 May 2015 17:33:18 +0000 (19:33 +0200)
Removes legacy components,which were deprecated in Lithium
and scheduled to be removed Berrylium.

Code is still preserved on stable/lithium branch.

Change-Id: Icef5e39cc59324db203ccb2cb5f9a3aea0e57b21
Signed-off-by: Tony Tkacik <ttkacik@cisco.com>
1010 files changed:
karaf/opendaylight-karaf/pom.xml
opendaylight/adsal/adsal-enunciate-parent/enunciate.xml [deleted file]
opendaylight/adsal/adsal-enunciate-parent/pom.xml [deleted file]
opendaylight/adsal/appauth/pom.xml [deleted file]
opendaylight/adsal/appauth/src/main/java/org/opendaylight/controller/appauth/Application.java [deleted file]
opendaylight/adsal/appauth/src/main/java/org/opendaylight/controller/appauth/authorization/Authorization.java [deleted file]
opendaylight/adsal/arphandler/pom.xml [deleted file]
opendaylight/adsal/arphandler/src/main/java/org/opendaylight/controller/arphandler/ARPCacheEvent.java [deleted file]
opendaylight/adsal/arphandler/src/main/java/org/opendaylight/controller/arphandler/ARPEvent.java [deleted file]
opendaylight/adsal/arphandler/src/main/java/org/opendaylight/controller/arphandler/ARPReply.java [deleted file]
opendaylight/adsal/arphandler/src/main/java/org/opendaylight/controller/arphandler/ARPRequest.java [deleted file]
opendaylight/adsal/arphandler/src/main/java/org/opendaylight/controller/arphandler/internal/Activator.java [deleted file]
opendaylight/adsal/arphandler/src/main/java/org/opendaylight/controller/arphandler/internal/ArpHandler.java [deleted file]
opendaylight/adsal/arphandler/src/test/java/org/opendaylight/controller/arphandler/internal/ArphandlerTest.java [deleted file]
opendaylight/adsal/clustering/integrationtest/pom.xml [deleted file]
opendaylight/adsal/clustering/integrationtest/src/test/java/org/opendaylight/controller/clustering/services_implementation/internal/ClusteringServicesIT.java [deleted file]
opendaylight/adsal/clustering/integrationtest/src/test/resources/logback.xml [deleted file]
opendaylight/adsal/clustering/services/pom.xml [deleted file]
opendaylight/adsal/clustering/services/src/main/java/org/opendaylight/controller/clustering/services/CacheConfigException.java [deleted file]
opendaylight/adsal/clustering/services/src/main/java/org/opendaylight/controller/clustering/services/CacheExistException.java [deleted file]
opendaylight/adsal/clustering/services/src/main/java/org/opendaylight/controller/clustering/services/CacheListenerAddException.java [deleted file]
opendaylight/adsal/clustering/services/src/main/java/org/opendaylight/controller/clustering/services/ICacheUpdateAware.java [deleted file]
opendaylight/adsal/clustering/services/src/main/java/org/opendaylight/controller/clustering/services/IClusterContainerServices.java [deleted file]
opendaylight/adsal/clustering/services/src/main/java/org/opendaylight/controller/clustering/services/IClusterGlobalServices.java [deleted file]
opendaylight/adsal/clustering/services/src/main/java/org/opendaylight/controller/clustering/services/IClusterServices.java [deleted file]
opendaylight/adsal/clustering/services/src/main/java/org/opendaylight/controller/clustering/services/IClusterServicesCommon.java [deleted file]
opendaylight/adsal/clustering/services/src/main/java/org/opendaylight/controller/clustering/services/ICoordinatorChangeAware.java [deleted file]
opendaylight/adsal/clustering/services/src/main/java/org/opendaylight/controller/clustering/services/IGetUpdates.java [deleted file]
opendaylight/adsal/clustering/services/src/main/java/org/opendaylight/controller/clustering/services/IListenRoleChange.java [deleted file]
opendaylight/adsal/clustering/services/src/main/java/org/opendaylight/controller/clustering/services/ListenRoleChangeAddException.java [deleted file]
opendaylight/adsal/clustering/services_implementation/pom.xml [deleted file]
opendaylight/adsal/clustering/services_implementation/src/main/java/org/opendaylight/controller/clustering/services_implementation/internal/Activator.java [deleted file]
opendaylight/adsal/clustering/services_implementation/src/main/java/org/opendaylight/controller/clustering/services_implementation/internal/CacheListenerContainer.java [deleted file]
opendaylight/adsal/clustering/services_implementation/src/main/java/org/opendaylight/controller/clustering/services_implementation/internal/ClassResolver.java [deleted file]
opendaylight/adsal/clustering/services_implementation/src/main/java/org/opendaylight/controller/clustering/services_implementation/internal/ClusterContainerManager.java [deleted file]
opendaylight/adsal/clustering/services_implementation/src/main/java/org/opendaylight/controller/clustering/services_implementation/internal/ClusterGlobalManager.java [deleted file]
opendaylight/adsal/clustering/services_implementation/src/main/java/org/opendaylight/controller/clustering/services_implementation/internal/ClusterManager.java [deleted file]
opendaylight/adsal/clustering/services_implementation/src/main/java/org/opendaylight/controller/clustering/services_implementation/internal/ClusterManagerCLI.java [deleted file]
opendaylight/adsal/clustering/services_implementation/src/main/java/org/opendaylight/controller/clustering/services_implementation/internal/ClusterManagerCommon.java [deleted file]
opendaylight/adsal/clustering/services_implementation/src/main/java/org/opendaylight/controller/clustering/services_implementation/internal/GetUpdatesContainer.java [deleted file]
opendaylight/adsal/clustering/services_implementation/src/main/resources/config/infinispan-config.xml [deleted file]
opendaylight/adsal/clustering/services_implementation/src/main/resources/config/jgroups.xml [deleted file]
opendaylight/adsal/clustering/services_implementation/src/test/java/org/opendaylight/controller/clustering/services_implementation/internal/ClusterManagerTest.java [deleted file]
opendaylight/adsal/clustering/stub/pom.xml [deleted file]
opendaylight/adsal/clustering/stub/src/main/java/org/opendaylight/controller/clustering/stub/internal/Activator.java [deleted file]
opendaylight/adsal/clustering/stub/src/main/java/org/opendaylight/controller/clustering/stub/internal/ClusterContainerManager.java [deleted file]
opendaylight/adsal/clustering/stub/src/main/java/org/opendaylight/controller/clustering/stub/internal/ClusterGlobalManager.java [deleted file]
opendaylight/adsal/clustering/stub/src/main/java/org/opendaylight/controller/clustering/stub/internal/ClusterManagerCommon.java [deleted file]
opendaylight/adsal/clustering/stub/src/test/java/org/opendaylight/controller/clustering/stub/internal/TestClusteringStub.java [deleted file]
opendaylight/adsal/clustering/test/pom.xml [deleted file]
opendaylight/adsal/clustering/test/src/main/java/org/opendaylight/controller/clustering/test/internal/Activator.java [deleted file]
opendaylight/adsal/clustering/test/src/main/java/org/opendaylight/controller/clustering/test/internal/ComplexClass.java [deleted file]
opendaylight/adsal/clustering/test/src/main/java/org/opendaylight/controller/clustering/test/internal/ComplexClass1.java [deleted file]
opendaylight/adsal/clustering/test/src/main/java/org/opendaylight/controller/clustering/test/internal/ComplexContainer.java [deleted file]
opendaylight/adsal/clustering/test/src/main/java/org/opendaylight/controller/clustering/test/internal/IComplex.java [deleted file]
opendaylight/adsal/clustering/test/src/main/java/org/opendaylight/controller/clustering/test/internal/LoggingListener.java [deleted file]
opendaylight/adsal/clustering/test/src/main/java/org/opendaylight/controller/clustering/test/internal/SimpleClient.java [deleted file]
opendaylight/adsal/clustering/test/src/main/java/org/opendaylight/controller/clustering/test/internal/StringContainer.java [deleted file]
opendaylight/adsal/clustering/test/src/test/java/org/opendaylight/controller/clustering/test/internal/TestClusteringTest.java [deleted file]
opendaylight/adsal/commons/httpclient/pom.xml [deleted file]
opendaylight/adsal/commons/httpclient/src/main/java/org/opendaylight/controller/commons/httpclient/HTTPClient.java [deleted file]
opendaylight/adsal/commons/httpclient/src/main/java/org/opendaylight/controller/commons/httpclient/HTTPRequest.java [deleted file]
opendaylight/adsal/commons/httpclient/src/main/java/org/opendaylight/controller/commons/httpclient/HTTPResponse.java [deleted file]
opendaylight/adsal/commons/integrationtest/pom.xml [deleted file]
opendaylight/adsal/configuration/api/pom.xml [deleted file]
opendaylight/adsal/configuration/api/src/main/java/org/opendaylight/controller/configuration/ConfigurationEvent.java [deleted file]
opendaylight/adsal/configuration/api/src/main/java/org/opendaylight/controller/configuration/ConfigurationObject.java [deleted file]
opendaylight/adsal/configuration/api/src/main/java/org/opendaylight/controller/configuration/IConfigurationAware.java [deleted file]
opendaylight/adsal/configuration/api/src/main/java/org/opendaylight/controller/configuration/IConfigurationAwareCommon.java [deleted file]
opendaylight/adsal/configuration/api/src/main/java/org/opendaylight/controller/configuration/IConfigurationContainerAware.java [deleted file]
opendaylight/adsal/configuration/api/src/main/java/org/opendaylight/controller/configuration/IConfigurationContainerService.java [deleted file]
opendaylight/adsal/configuration/api/src/main/java/org/opendaylight/controller/configuration/IConfigurationService.java [deleted file]
opendaylight/adsal/configuration/api/src/main/java/org/opendaylight/controller/configuration/IConfigurationServiceCommon.java [deleted file]
opendaylight/adsal/configuration/implementation/pom.xml [deleted file]
opendaylight/adsal/configuration/implementation/src/main/java/org/opendaylight/controller/configuration/internal/Activator.java [deleted file]
opendaylight/adsal/configuration/implementation/src/main/java/org/opendaylight/controller/configuration/internal/ConfigurationService.java [deleted file]
opendaylight/adsal/configuration/implementation/src/main/java/org/opendaylight/controller/configuration/internal/ContainerConfigurationService.java [deleted file]
opendaylight/adsal/configuration/implementation/src/test/java/org/opendaylight/controller/configuration/internal/ConfigurationAwareTest.java [deleted file]
opendaylight/adsal/configuration/implementation/src/test/java/org/opendaylight/controller/configuration/internal/ConfigurationContainerAwareTest.java [deleted file]
opendaylight/adsal/configuration/implementation/src/test/java/org/opendaylight/controller/configuration/internal/ConfigurationContainerImplTest.java [deleted file]
opendaylight/adsal/configuration/implementation/src/test/java/org/opendaylight/controller/configuration/internal/ConfigurationImplTest.java [deleted file]
opendaylight/adsal/configuration/integrationtest/.gitignore [deleted file]
opendaylight/adsal/configuration/integrationtest/pom.xml [deleted file]
opendaylight/adsal/configuration/integrationtest/src/test/java/org/opendaylight/controller/configuration/internal/ConfigurationIT.java [deleted file]
opendaylight/adsal/configuration/integrationtest/src/test/resources/logback.xml [deleted file]
opendaylight/adsal/connectionmanager/api/pom.xml [deleted file]
opendaylight/adsal/connectionmanager/api/src/main/java/org/opendaylight/controller/connectionmanager/ConnectionMgmtScheme.java [deleted file]
opendaylight/adsal/connectionmanager/api/src/main/java/org/opendaylight/controller/connectionmanager/IConnectionManager.java [deleted file]
opendaylight/adsal/connectionmanager/api/src/main/java/org/opendaylight/controller/connectionmanager/NodeAccessPermission.java [deleted file]
opendaylight/adsal/connectionmanager/implementation/pom.xml [deleted file]
opendaylight/adsal/connectionmanager/implementation/src/main/java/org/opendaylight/controller/connectionmanager/internal/Activator.java [deleted file]
opendaylight/adsal/connectionmanager/implementation/src/main/java/org/opendaylight/controller/connectionmanager/internal/ConnectionManager.java [deleted file]
opendaylight/adsal/connectionmanager/implementation/src/main/java/org/opendaylight/controller/connectionmanager/internal/ConnectionMgmtEvent.java [deleted file]
opendaylight/adsal/connectionmanager/implementation/src/main/java/org/opendaylight/controller/connectionmanager/internal/ConnectionMgmtEventType.java [deleted file]
opendaylight/adsal/connectionmanager/implementation/src/main/java/org/opendaylight/controller/connectionmanager/scheme/AbstractScheme.java [deleted file]
opendaylight/adsal/connectionmanager/implementation/src/main/java/org/opendaylight/controller/connectionmanager/scheme/AnyControllerScheme.java [deleted file]
opendaylight/adsal/connectionmanager/implementation/src/main/java/org/opendaylight/controller/connectionmanager/scheme/ControllerConfig.java [deleted file]
opendaylight/adsal/connectionmanager/implementation/src/main/java/org/opendaylight/controller/connectionmanager/scheme/LoadBalancedScheme.java [deleted file]
opendaylight/adsal/connectionmanager/implementation/src/main/java/org/opendaylight/controller/connectionmanager/scheme/RoundRobinScheme.java [deleted file]
opendaylight/adsal/connectionmanager/implementation/src/main/java/org/opendaylight/controller/connectionmanager/scheme/SchemeFactory.java [deleted file]
opendaylight/adsal/connectionmanager/implementation/src/main/java/org/opendaylight/controller/connectionmanager/scheme/SingleControllerScheme.java [deleted file]
opendaylight/adsal/containermanager/api/pom.xml [deleted file]
opendaylight/adsal/containermanager/api/src/main/java/org/opendaylight/controller/containermanager/ContainerChangeEvent.java [deleted file]
opendaylight/adsal/containermanager/api/src/main/java/org/opendaylight/controller/containermanager/ContainerConfig.java [deleted file]
opendaylight/adsal/containermanager/api/src/main/java/org/opendaylight/controller/containermanager/ContainerData.java [deleted file]
opendaylight/adsal/containermanager/api/src/main/java/org/opendaylight/controller/containermanager/ContainerFlowChangeEvent.java [deleted file]
opendaylight/adsal/containermanager/api/src/main/java/org/opendaylight/controller/containermanager/ContainerFlowConfig.java [deleted file]
opendaylight/adsal/containermanager/api/src/main/java/org/opendaylight/controller/containermanager/IContainerAuthorization.java [deleted file]
opendaylight/adsal/containermanager/api/src/main/java/org/opendaylight/controller/containermanager/IContainerManager.java [deleted file]
opendaylight/adsal/containermanager/api/src/main/java/org/opendaylight/controller/containermanager/IContainerManagerShell.java [deleted file]
opendaylight/adsal/containermanager/api/src/main/java/org/opendaylight/controller/containermanager/NodeConnectorsChangeEvent.java [deleted file]
opendaylight/adsal/containermanager/implementation/pom.xml [deleted file]
opendaylight/adsal/containermanager/implementation/src/main/java/org/opendaylight/controller/containermanager/internal/Activator.java [deleted file]
opendaylight/adsal/containermanager/implementation/src/main/java/org/opendaylight/controller/containermanager/internal/ContainerImpl.java [deleted file]
opendaylight/adsal/containermanager/implementation/src/main/java/org/opendaylight/controller/containermanager/internal/ContainerManager.java [deleted file]
opendaylight/adsal/containermanager/implementation/src/main/java/org/opendaylight/controller/containermanager/internal/IContainerInternal.java [deleted file]
opendaylight/adsal/containermanager/it.implementation/pom.xml [deleted file]
opendaylight/adsal/containermanager/it.implementation/src/main/java/org/opendaylight/controller/containermanager/internal/Activator.java [deleted file]
opendaylight/adsal/containermanager/it.implementation/src/main/java/org/opendaylight/controller/containermanager/internal/ContainerImpl.java [deleted file]
opendaylight/adsal/containermanager/it.implementation/src/main/java/org/opendaylight/controller/containermanager/internal/ContainerManager.java [deleted file]
opendaylight/adsal/containermanager/it.implementation/src/test/java/org/opendaylight/controller/containermanager/internal/ContainerImplTest.java [deleted file]
opendaylight/adsal/containermanager/it.implementation/src/test/java/org/opendaylight/controller/containermanager/internal/ContainerManagerTest.java [deleted file]
opendaylight/adsal/containermanager/shell/pom.xml [deleted file]
opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/AddContainer.java [deleted file]
opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/AddContainerEntry.java [deleted file]
opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/AddContainerFlow.java [deleted file]
opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/ContainermgrGetAuthorizedGroups.java [deleted file]
opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/ContainermgrGetAuthorizedResources.java [deleted file]
opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/ContainermgrGetResourcesForGroup.java [deleted file]
opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/ContainermgrGetRoles.java [deleted file]
opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/ContainermgrGetUserLevel.java [deleted file]
opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/ContainermgrGetUserResources.java [deleted file]
opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/CreateContainer.java [deleted file]
opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/Pfc.java [deleted file]
opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/Psc.java [deleted file]
opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/Psd.java [deleted file]
opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/Psm.java [deleted file]
opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/Psp.java [deleted file]
opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/RemoveContainer.java [deleted file]
opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/RemoveContainerEntry.java [deleted file]
opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/RemoveContainerFlow.java [deleted file]
opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/SaveConfig.java [deleted file]
opendaylight/adsal/containermanager/shell/src/main/resources/OSGI-INF/blueprint/blueprint.xml [deleted file]
opendaylight/adsal/containermanager/shell/src/test/java/org/opendaylight/controller/containermanager/shell/ContainerManagerShellTest.java [deleted file]
opendaylight/adsal/dummy-console/README [deleted file]
opendaylight/adsal/dummy-console/pom.xml [deleted file]
opendaylight/adsal/dummy-console/src/main/java/org/eclipse/osgi/framework/console/CommandInterpreter.java [deleted file]
opendaylight/adsal/dummy-console/src/main/java/org/eclipse/osgi/framework/console/CommandProvider.java [deleted file]
opendaylight/adsal/features/adsal/pom.xml [deleted file]
opendaylight/adsal/features/adsal/src/main/resources/features.xml [deleted file]
opendaylight/adsal/features/base/pom.xml [deleted file]
opendaylight/adsal/features/base/src/main/resources/features.xml [deleted file]
opendaylight/adsal/features/controller/pom.xml [deleted file]
opendaylight/adsal/features/controller/src/main/resources/features.xml [deleted file]
opendaylight/adsal/features/extras/pom.xml [deleted file]
opendaylight/adsal/features/extras/src/main/resources/features.xml [deleted file]
opendaylight/adsal/features/nsf/pom.xml [deleted file]
opendaylight/adsal/features/nsf/src/main/resources/features.xml [deleted file]
opendaylight/adsal/forwarding/staticrouting/pom.xml [deleted file]
opendaylight/adsal/forwarding/staticrouting/src/main/java/org/opendaylight/controller/forwarding/staticrouting/IForwardingStaticRouting.java [deleted file]
opendaylight/adsal/forwarding/staticrouting/src/main/java/org/opendaylight/controller/forwarding/staticrouting/IStaticRoutingAware.java [deleted file]
opendaylight/adsal/forwarding/staticrouting/src/main/java/org/opendaylight/controller/forwarding/staticrouting/StaticRoute.java [deleted file]
opendaylight/adsal/forwarding/staticrouting/src/main/java/org/opendaylight/controller/forwarding/staticrouting/StaticRouteConfig.java [deleted file]
opendaylight/adsal/forwarding/staticrouting/src/main/java/org/opendaylight/controller/forwarding/staticrouting/internal/Activator.java [deleted file]
opendaylight/adsal/forwarding/staticrouting/src/main/java/org/opendaylight/controller/forwarding/staticrouting/internal/StaticRoutingImplementation.java [deleted file]
opendaylight/adsal/forwarding/staticrouting/src/test/java/org/opendaylight/controller/forwarding/staticrouting/StaticRouteConfigTest.java [deleted file]
opendaylight/adsal/forwarding/staticrouting/src/test/java/org/opendaylight/controller/forwarding/staticrouting/StaticRouteTest.java [deleted file]
opendaylight/adsal/forwarding/staticrouting/src/test/java/org/opendaylight/controller/forwarding/staticrouting/internal/StaticRoutingImplementationTest.java [deleted file]
opendaylight/adsal/forwardingrulesmanager/api/pom.xml [deleted file]
opendaylight/adsal/forwardingrulesmanager/api/src/main/java/org/opendaylight/controller/forwardingrulesmanager/FlowConfig.java [deleted file]
opendaylight/adsal/forwardingrulesmanager/api/src/main/java/org/opendaylight/controller/forwardingrulesmanager/FlowEntry.java [deleted file]
opendaylight/adsal/forwardingrulesmanager/api/src/main/java/org/opendaylight/controller/forwardingrulesmanager/FlowEntryInstall.java [deleted file]
opendaylight/adsal/forwardingrulesmanager/api/src/main/java/org/opendaylight/controller/forwardingrulesmanager/IForwardingRulesManager.java [deleted file]
opendaylight/adsal/forwardingrulesmanager/api/src/main/java/org/opendaylight/controller/forwardingrulesmanager/IForwardingRulesManagerAware.java [deleted file]
opendaylight/adsal/forwardingrulesmanager/api/src/main/java/org/opendaylight/controller/forwardingrulesmanager/PortGroup.java [deleted file]
opendaylight/adsal/forwardingrulesmanager/api/src/main/java/org/opendaylight/controller/forwardingrulesmanager/PortGroupChangeListener.java [deleted file]
opendaylight/adsal/forwardingrulesmanager/api/src/main/java/org/opendaylight/controller/forwardingrulesmanager/PortGroupConfig.java [deleted file]
opendaylight/adsal/forwardingrulesmanager/api/src/main/java/org/opendaylight/controller/forwardingrulesmanager/PortGroupProvider.java [deleted file]
opendaylight/adsal/forwardingrulesmanager/api/src/test/java/org/opendaylight/controller/forwardingrulesmanager/frmTest.java [deleted file]
opendaylight/adsal/forwardingrulesmanager/implementation/pom.xml [deleted file]
opendaylight/adsal/forwardingrulesmanager/implementation/src/main/java/org/opendaylight/controller/forwardingrulesmanager/implementation/data/FlowEntryDistributionOrder.java [deleted file]
opendaylight/adsal/forwardingrulesmanager/implementation/src/main/java/org/opendaylight/controller/forwardingrulesmanager/internal/Activator.java [deleted file]
opendaylight/adsal/forwardingrulesmanager/implementation/src/main/java/org/opendaylight/controller/forwardingrulesmanager/internal/FlowEntryDistributionOrderFutureTask.java [deleted file]
opendaylight/adsal/forwardingrulesmanager/implementation/src/main/java/org/opendaylight/controller/forwardingrulesmanager/internal/ForwardingRulesManager.java [deleted file]
opendaylight/adsal/forwardingrulesmanager/implementation/src/main/java/org/opendaylight/controller/forwardingrulesmanager/internal/ForwardingRulesManagerCLI.java [deleted file]
opendaylight/adsal/forwardingrulesmanager/integrationtest/pom.xml [deleted file]
opendaylight/adsal/forwardingrulesmanager/integrationtest/src/test/java/org/opendaylight/controller/forwardingrulesmanager/internal/ForwardingRulesManagerIT.java [deleted file]
opendaylight/adsal/forwardingrulesmanager/integrationtest/src/test/resources/logback.xml [deleted file]
opendaylight/adsal/hosttracker/api/pom.xml [deleted file]
opendaylight/adsal/hosttracker/api/src/main/java/org/opendaylight/controller/hosttracker/HostIdFactory.java [deleted file]
opendaylight/adsal/hosttracker/api/src/main/java/org/opendaylight/controller/hosttracker/IHostId.java [deleted file]
opendaylight/adsal/hosttracker/api/src/main/java/org/opendaylight/controller/hosttracker/IHostTrackerShell.java [deleted file]
opendaylight/adsal/hosttracker/api/src/main/java/org/opendaylight/controller/hosttracker/IPHostId.java [deleted file]
opendaylight/adsal/hosttracker/api/src/main/java/org/opendaylight/controller/hosttracker/IPMacHostId.java [deleted file]
opendaylight/adsal/hosttracker/api/src/main/java/org/opendaylight/controller/hosttracker/IfHostListener.java [deleted file]
opendaylight/adsal/hosttracker/api/src/main/java/org/opendaylight/controller/hosttracker/IfIptoHost.java [deleted file]
opendaylight/adsal/hosttracker/api/src/main/java/org/opendaylight/controller/hosttracker/IfNewHostNotify.java [deleted file]
opendaylight/adsal/hosttracker/api/src/main/java/org/opendaylight/controller/hosttracker/hostAware/HostNodeConnector.java [deleted file]
opendaylight/adsal/hosttracker/api/src/main/java/org/opendaylight/controller/hosttracker/hostAware/IHostFinder.java [deleted file]
opendaylight/adsal/hosttracker/api/src/test/java/org/opendaylight/controller/hosttracker/hostAware/HostNodeConnectorTest.java [deleted file]
opendaylight/adsal/hosttracker/implementation/pom.xml [deleted file]
opendaylight/adsal/hosttracker/implementation/src/main/java/org/opendaylight/controller/hosttracker/internal/Activator.java [deleted file]
opendaylight/adsal/hosttracker/implementation/src/main/java/org/opendaylight/controller/hosttracker/internal/HostTracker.java [deleted file]
opendaylight/adsal/hosttracker/implementation/src/main/java/org/opendaylight/controller/hosttracker/internal/HostTrackerCallable.java [deleted file]
opendaylight/adsal/hosttracker/implementation/src/test/java/org/opendaylight/controller/hosttracker/internal/HostTrackerTest.java [deleted file]
opendaylight/adsal/hosttracker/integrationtest/pom.xml [deleted file]
opendaylight/adsal/hosttracker/integrationtest/src/test/java/org/opendaylight/controller/hosttracker/internal/HostTrackerIT.java [deleted file]
opendaylight/adsal/hosttracker/integrationtest/src/test/resources/logback.xml [deleted file]
opendaylight/adsal/hosttracker/shell/pom.xml [deleted file]
opendaylight/adsal/hosttracker/shell/src/main/java/org/opendaylight/controller/hosttracker/shell/DumpFailedARPReqList.java [deleted file]
opendaylight/adsal/hosttracker/shell/src/main/java/org/opendaylight/controller/hosttracker/shell/DumpPendingARPReqList.java [deleted file]
opendaylight/adsal/hosttracker/shell/src/main/resources/OSGI-INF/blueprint/blueprint.xml [deleted file]
opendaylight/adsal/hosttracker/shell/src/test/java/org/opendaylight/controller/hosttracker/shell/HostTrackerShellTest.java [deleted file]
opendaylight/adsal/hosttracker_new/api/pom.xml [deleted file]
opendaylight/adsal/hosttracker_new/api/src/main/java/org/opendaylight/controller/hosttracker/Entity.java [deleted file]
opendaylight/adsal/hosttracker_new/api/src/main/java/org/opendaylight/controller/hosttracker/IDevice.java [deleted file]
opendaylight/adsal/hosttracker_new/api/src/main/java/org/opendaylight/controller/hosttracker/IDeviceListener.java [deleted file]
opendaylight/adsal/hosttracker_new/api/src/main/java/org/opendaylight/controller/hosttracker/IDeviceService.java [deleted file]
opendaylight/adsal/hosttracker_new/api/src/main/java/org/opendaylight/controller/hosttracker/IEntityClass.java [deleted file]
opendaylight/adsal/hosttracker_new/api/src/main/java/org/opendaylight/controller/hosttracker/IEntityClassListener.java [deleted file]
opendaylight/adsal/hosttracker_new/api/src/main/java/org/opendaylight/controller/hosttracker/IEntityClassifierService.java [deleted file]
opendaylight/adsal/hosttracker_new/api/src/main/java/org/opendaylight/controller/hosttracker/IfHostListener.java [deleted file]
opendaylight/adsal/hosttracker_new/api/src/main/java/org/opendaylight/controller/hosttracker/IfIptoHost.java [deleted file]
opendaylight/adsal/hosttracker_new/api/src/main/java/org/opendaylight/controller/hosttracker/IfNewHostNotify.java [deleted file]
opendaylight/adsal/hosttracker_new/api/src/main/java/org/opendaylight/controller/hosttracker/SwitchPort.java [deleted file]
opendaylight/adsal/hosttracker_new/api/src/main/java/org/opendaylight/controller/hosttracker/hostAware/HostNodeConnector.java [deleted file]
opendaylight/adsal/hosttracker_new/api/src/main/java/org/opendaylight/controller/hosttracker/hostAware/IHostFinder.java [deleted file]
opendaylight/adsal/hosttracker_new/api/src/test/java/org/opendaylight/controller/hosttracker/hostAware/HostNodeConnectorTest.java [deleted file]
opendaylight/adsal/hosttracker_new/implementation/pom.xml [deleted file]
opendaylight/adsal/hosttracker_new/implementation/src/main/java/org/opendaylight/controller/hosttracker/internal/Activator.java [deleted file]
opendaylight/adsal/hosttracker_new/implementation/src/main/java/org/opendaylight/controller/hosttracker/internal/AttachmentPoint.java [deleted file]
opendaylight/adsal/hosttracker_new/implementation/src/main/java/org/opendaylight/controller/hosttracker/internal/DefaultEntityClassifier.java [deleted file]
opendaylight/adsal/hosttracker_new/implementation/src/main/java/org/opendaylight/controller/hosttracker/internal/Device.java [deleted file]
opendaylight/adsal/hosttracker_new/implementation/src/main/java/org/opendaylight/controller/hosttracker/internal/DeviceIndex.java [deleted file]
opendaylight/adsal/hosttracker_new/implementation/src/main/java/org/opendaylight/controller/hosttracker/internal/DeviceIndexInterator.java [deleted file]
opendaylight/adsal/hosttracker_new/implementation/src/main/java/org/opendaylight/controller/hosttracker/internal/DeviceIterator.java [deleted file]
opendaylight/adsal/hosttracker_new/implementation/src/main/java/org/opendaylight/controller/hosttracker/internal/DeviceManagerImpl.java [deleted file]
opendaylight/adsal/hosttracker_new/implementation/src/main/java/org/opendaylight/controller/hosttracker/internal/DeviceMultiIndex.java [deleted file]
opendaylight/adsal/hosttracker_new/implementation/src/main/java/org/opendaylight/controller/hosttracker/internal/DeviceUniqueIndex.java [deleted file]
opendaylight/adsal/hosttracker_new/implementation/src/main/java/org/opendaylight/controller/hosttracker/internal/IndexedEntity.java [deleted file]
opendaylight/adsal/hosttracker_new/implementation/src/test/java/org/opendaylight/controller/hosttracker/internal/DeviceManagerImplTest.java [deleted file]
opendaylight/adsal/hosttracker_new/implementation/src/test/java/org/opendaylight/controller/hosttracker/internal/DeviceUniqueIndexTest.java [deleted file]
opendaylight/adsal/hosttracker_new/implementation/src/test/java/org/opendaylight/controller/hosttracker/test/MockDevice.java [deleted file]
opendaylight/adsal/hosttracker_new/implementation/src/test/java/org/opendaylight/controller/hosttracker/test/MockDeviceManager.java [deleted file]
opendaylight/adsal/hosttracker_new/implementation/src/test/java/org/opendaylight/controller/hosttracker/test/MockEntityClassifier.java [deleted file]
opendaylight/adsal/hosttracker_new/implementation/src/test/java/org/opendaylight/controller/hosttracker/test/MockEntityClassifierMac.java [deleted file]
opendaylight/adsal/hosttracker_new/implementation/src/test/java/org/opendaylight/controller/hosttracker/test/MockFlexEntityClassifier.java [deleted file]
opendaylight/adsal/karaf-tomcat-security/pom.xml [deleted file]
opendaylight/adsal/karaf-tomcat-security/src/main/java/org/opendaylight/controller/karafsecurity/ControllerCustomRealm.java [deleted file]
opendaylight/adsal/logging/bridge/pom.xml [deleted file]
opendaylight/adsal/logging/bridge/src/main/java/org/opendaylight/controller/logging/bridge/internal/Activator.java [deleted file]
opendaylight/adsal/logging/bridge/src/main/java/org/opendaylight/controller/logging/bridge/internal/LogListenerImpl.java [deleted file]
opendaylight/adsal/logging/bridge/src/main/java/org/opendaylight/controller/logging/bridge/internal/UncaughtExceptionPolicy.java [deleted file]
opendaylight/adsal/logging/bridge/src/test/java/org/opendaylight/controller/logging/bridge/internal/LogListenerImplTest.java [deleted file]
opendaylight/adsal/northbound/archetype-app-northbound/pom.xml [deleted file]
opendaylight/adsal/northbound/archetype-app-northbound/src/main/resources/META-INF/maven/archetype-metadata.xml [deleted file]
opendaylight/adsal/northbound/archetype-app-northbound/src/main/resources/archetype-resources/pom.xml [deleted file]
opendaylight/adsal/northbound/archetype-app-northbound/src/main/resources/archetype-resources/src/main/java/Northbound.java [deleted file]
opendaylight/adsal/northbound/archetype-app-northbound/src/main/resources/archetype-resources/src/main/resources/WEB-INF/web.xml [deleted file]
opendaylight/adsal/northbound/archetype-app-northbound/src/test/resources/projects/basic/archetype.properties [deleted file]
opendaylight/adsal/northbound/archetype-app-northbound/src/test/resources/projects/basic/goal.txt [deleted file]
opendaylight/adsal/northbound/bundlescanner/api/pom.xml [deleted file]
opendaylight/adsal/northbound/bundlescanner/api/src/main/java/org/opendaylight/controller/northbound/bundlescanner/IBundleScanService.java [deleted file]
opendaylight/adsal/northbound/bundlescanner/implementation/pom.xml [deleted file]
opendaylight/adsal/northbound/bundlescanner/implementation/src/main/java/org/opendaylight/controller/northbound/bundlescanner/internal/Activator.java [deleted file]
opendaylight/adsal/northbound/bundlescanner/implementation/src/main/java/org/opendaylight/controller/northbound/bundlescanner/internal/BundleInfo.java [deleted file]
opendaylight/adsal/northbound/bundlescanner/implementation/src/main/java/org/opendaylight/controller/northbound/bundlescanner/internal/BundleScanServiceImpl.java [deleted file]
opendaylight/adsal/northbound/bundlescanner/implementation/src/main/java/org/opendaylight/controller/northbound/bundlescanner/internal/BundleScanner.java [deleted file]
opendaylight/adsal/northbound/bundlescanner/implementation/src/test/java/bundle_base/Animal.java [deleted file]
opendaylight/adsal/northbound/bundlescanner/implementation/src/test/java/bundle_base/BasePerson.java [deleted file]
opendaylight/adsal/northbound/bundlescanner/implementation/src/test/java/bundle_base/Mammal.java [deleted file]
opendaylight/adsal/northbound/bundlescanner/implementation/src/test/java/bundle_base/NoAnnotation.java [deleted file]
opendaylight/adsal/northbound/bundlescanner/implementation/src/test/java/bundle_base/NonRelevantAnnotation.java [deleted file]
opendaylight/adsal/northbound/bundlescanner/implementation/src/test/java/bundle_base/Person.java [deleted file]
opendaylight/adsal/northbound/bundlescanner/implementation/src/test/java/bundle_misc/Misc.java [deleted file]
opendaylight/adsal/northbound/bundlescanner/implementation/src/test/java/bundle_sub1/NoAnnotation.java [deleted file]
opendaylight/adsal/northbound/bundlescanner/implementation/src/test/java/bundle_sub1/Zoo.java [deleted file]
opendaylight/adsal/northbound/bundlescanner/implementation/src/test/java/bundle_sub2/Agent.java [deleted file]
opendaylight/adsal/northbound/bundlescanner/implementation/src/test/java/bundle_sub2/Customer.java [deleted file]
opendaylight/adsal/northbound/bundlescanner/implementation/src/test/java/bundle_sub2/NoAnnotation.java [deleted file]
opendaylight/adsal/northbound/bundlescanner/implementation/src/test/java/org/opendaylight/controller/northbound/bundlescanner/internal/BundleScannerTest.java [deleted file]
opendaylight/adsal/northbound/commons/pom.xml [deleted file]
opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/JacksonJsonProcessingExceptionMapper.java [deleted file]
opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/NorthboundApplication.java [deleted file]
opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/RestMessages.java [deleted file]
opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/BadRequestException.java [deleted file]
opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/GenericExceptionMapper.java [deleted file]
opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/InternalServerErrorException.java [deleted file]
opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/MethodNotAllowed.java [deleted file]
opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/MethodNotAllowedException.java [deleted file]
opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/NotAcceptableException.java [deleted file]
opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/NotImplemented.java [deleted file]
opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/NotImplementedException.java [deleted file]
opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/ResourceConflictException.java [deleted file]
opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/ResourceForbiddenException.java [deleted file]
opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/ResourceGoneException.java [deleted file]
opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/ResourceNotFoundException.java [deleted file]
opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/ServiceUnavailableException.java [deleted file]
opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/UnauthorizedException.java [deleted file]
opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/UnsupportedMediaTypeException.java [deleted file]
opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/package-info.java [deleted file]
opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/query/Accessor.java [deleted file]
opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/query/CompareExpression.java [deleted file]
opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/query/Expression.java [deleted file]
opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/query/ExpressionBuilder.java [deleted file]
opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/query/IteratableTypeInfo.java [deleted file]
opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/query/LogicalExpression.java [deleted file]
opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/query/Query.java [deleted file]
opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/query/QueryContext.java [deleted file]
opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/query/QueryContextImpl.java [deleted file]
opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/query/QueryContextProvider.java [deleted file]
opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/query/QueryException.java [deleted file]
opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/query/QueryImpl.java [deleted file]
opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/query/TypeInfo.java [deleted file]
opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/query/Visitor.java [deleted file]
opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/query/WrapperTypeInfo.java [deleted file]
opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/types/StringList.java [deleted file]
opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/utils/NorthboundUtils.java [deleted file]
opendaylight/adsal/northbound/commons/src/main/javacc/fiql.jj [deleted file]
opendaylight/adsal/northbound/commons/src/test/java/org/opendaylight/controller/northbound/commons/CommonsNorthboundTest.java [deleted file]
opendaylight/adsal/northbound/commons/src/test/java/org/opendaylight/controller/northbound/commons/exception/CommonsNorthboundExceptionTest.java [deleted file]
opendaylight/adsal/northbound/commons/src/test/java/org/opendaylight/controller/northbound/commons/query/BookBean.java [deleted file]
opendaylight/adsal/northbound/commons/src/test/java/org/opendaylight/controller/northbound/commons/query/ExpresssionTest.java [deleted file]
opendaylight/adsal/northbound/commons/src/test/java/org/opendaylight/controller/northbound/commons/query/Library.java [deleted file]
opendaylight/adsal/northbound/commons/src/test/java/org/opendaylight/controller/northbound/commons/query/PersonBean.java [deleted file]
opendaylight/adsal/northbound/commons/src/test/java/org/opendaylight/controller/northbound/commons/query/QueryContextTest.java [deleted file]
opendaylight/adsal/northbound/commons/src/test/java/org/opendaylight/controller/northbound/commons/query/ReviewBean.java [deleted file]
opendaylight/adsal/northbound/commons/src/test/java/org/opendaylight/controller/northbound/commons/query/XMLAccessorTypeTest.java [deleted file]
opendaylight/adsal/northbound/commons/src/test/resources/logback.xml [deleted file]
opendaylight/adsal/northbound/connectionmanager/enunciate.xml [deleted file]
opendaylight/adsal/northbound/connectionmanager/pom.xml [deleted file]
opendaylight/adsal/northbound/connectionmanager/src/main/java/org/opendaylight/controller/connectionmanager/northbound/ConnectionManagerNorthbound.java [deleted file]
opendaylight/adsal/northbound/connectionmanager/src/main/java/org/opendaylight/controller/connectionmanager/northbound/Nodes.java [deleted file]
opendaylight/adsal/northbound/connectionmanager/src/main/resources/WEB-INF/web.xml [deleted file]
opendaylight/adsal/northbound/containermanager/enunciate.xml [deleted file]
opendaylight/adsal/northbound/containermanager/pom.xml [deleted file]
opendaylight/adsal/northbound/containermanager/src/main/java/org/opendaylight/controller/containermanager/northbound/ContainerConfigs.java [deleted file]
opendaylight/adsal/northbound/containermanager/src/main/java/org/opendaylight/controller/containermanager/northbound/ContainerManagerNorthbound.java [deleted file]
opendaylight/adsal/northbound/containermanager/src/main/java/org/opendaylight/controller/containermanager/northbound/ContainerManagerNorthboundRSApplication.java [deleted file]
opendaylight/adsal/northbound/containermanager/src/main/java/org/opendaylight/controller/containermanager/northbound/FlowSpecConfigs.java [deleted file]
opendaylight/adsal/northbound/containermanager/src/main/java/org/opendaylight/controller/containermanager/northbound/StringList.java [deleted file]
opendaylight/adsal/northbound/containermanager/src/main/resources/META-INF/spring.factories [deleted file]
opendaylight/adsal/northbound/containermanager/src/main/resources/META-INF/spring.handlers [deleted file]
opendaylight/adsal/northbound/containermanager/src/main/resources/META-INF/spring.schemas [deleted file]
opendaylight/adsal/northbound/containermanager/src/main/resources/META-INF/spring.tooling [deleted file]
opendaylight/adsal/northbound/containermanager/src/main/resources/WEB-INF/web.xml [deleted file]
opendaylight/adsal/northbound/controllermanager/enunciate.xml [deleted file]
opendaylight/adsal/northbound/controllermanager/pom.xml [deleted file]
opendaylight/adsal/northbound/controllermanager/src/main/java/org/opendaylight/controller/controllermanager/northbound/ControllerManagerNorthbound.java [deleted file]
opendaylight/adsal/northbound/controllermanager/src/main/java/org/opendaylight/controller/controllermanager/northbound/ControllerProperties.java [deleted file]
opendaylight/adsal/northbound/controllermanager/src/main/resources/WEB-INF/web.xml [deleted file]
opendaylight/adsal/northbound/controllermanager/src/test/java/org/opendaylight/controller/controllermanager/northbound/ControllerManagerNorthboundTest.java [deleted file]
opendaylight/adsal/northbound/flowprogrammer/enunciate.xml [deleted file]
opendaylight/adsal/northbound/flowprogrammer/pom.xml [deleted file]
opendaylight/adsal/northbound/flowprogrammer/src/main/java/org/opendaylight/controller/flowprogrammer/northbound/FlowConfigs.java [deleted file]
opendaylight/adsal/northbound/flowprogrammer/src/main/java/org/opendaylight/controller/flowprogrammer/northbound/FlowProgrammerNorthbound.java [deleted file]
opendaylight/adsal/northbound/flowprogrammer/src/main/resources/META-INF/spring.factories [deleted file]
opendaylight/adsal/northbound/flowprogrammer/src/main/resources/META-INF/spring.handlers [deleted file]
opendaylight/adsal/northbound/flowprogrammer/src/main/resources/META-INF/spring.schemas [deleted file]
opendaylight/adsal/northbound/flowprogrammer/src/main/resources/META-INF/spring.tooling [deleted file]
opendaylight/adsal/northbound/flowprogrammer/src/main/resources/WEB-INF/web.xml [deleted file]
opendaylight/adsal/northbound/flowprogrammer/src/test/java/org/opendaylight/controller/flowprogrammer/northbound/FlowProgrammerNorthboundTest.java [deleted file]
opendaylight/adsal/northbound/hosttracker/enunciate.xml [deleted file]
opendaylight/adsal/northbound/hosttracker/pom.xml [deleted file]
opendaylight/adsal/northbound/hosttracker/src/main/java/org/opendaylight/controller/hosttracker/northbound/HostConfig.java [deleted file]
opendaylight/adsal/northbound/hosttracker/src/main/java/org/opendaylight/controller/hosttracker/northbound/HostTrackerNorthbound.java [deleted file]
opendaylight/adsal/northbound/hosttracker/src/main/java/org/opendaylight/controller/hosttracker/northbound/Hosts.java [deleted file]
opendaylight/adsal/northbound/hosttracker/src/main/resources/META-INF/spring.factories [deleted file]
opendaylight/adsal/northbound/hosttracker/src/main/resources/META-INF/spring.handlers [deleted file]
opendaylight/adsal/northbound/hosttracker/src/main/resources/META-INF/spring.schemas [deleted file]
opendaylight/adsal/northbound/hosttracker/src/main/resources/META-INF/spring.tooling [deleted file]
opendaylight/adsal/northbound/hosttracker/src/main/resources/WEB-INF/web.xml [deleted file]
opendaylight/adsal/northbound/hosttracker/src/test/java/org/opendaylight/controller/hosttracker/northbound/HostTrackerNorthboundTest.java [deleted file]
opendaylight/adsal/northbound/httpservice-bridge/pom.xml [deleted file]
opendaylight/adsal/northbound/httpservice-bridge/src/main/resources/WEB-INF/web.xml [deleted file]
opendaylight/adsal/northbound/integrationtest/pom.xml [deleted file]
opendaylight/adsal/northbound/integrationtest/src/test/java/org/opendaylight/controller/northbound/integrationtest/NorthboundIT.java [deleted file]
opendaylight/adsal/northbound/integrationtest/src/test/resources/exam.properties [deleted file]
opendaylight/adsal/northbound/integrationtest/src/test/resources/logback.xml [deleted file]
opendaylight/adsal/northbound/integrationtest/src/test/resources/tomcat-server.xml [deleted file]
opendaylight/adsal/northbound/java-client/enunciate.xml [deleted file]
opendaylight/adsal/northbound/java-client/pom.xml [deleted file]
opendaylight/adsal/northbound/jolokia/pom.xml [deleted file]
opendaylight/adsal/northbound/jolokia/src/main/resources/WEB-INF/web.xml [deleted file]
opendaylight/adsal/northbound/networkconfiguration/bridgedomain/enunciate.xml [deleted file]
opendaylight/adsal/northbound/networkconfiguration/bridgedomain/pom.xml [deleted file]
opendaylight/adsal/northbound/networkconfiguration/bridgedomain/src/main/java/org/opendaylight/controller/networkconfig/bridgedomain/northbound/BridgeDomainNorthbound.java [deleted file]
opendaylight/adsal/northbound/networkconfiguration/bridgedomain/src/main/resources/WEB-INF/web.xml [deleted file]
opendaylight/adsal/northbound/staticrouting/enunciate.xml [deleted file]
opendaylight/adsal/northbound/staticrouting/pom.xml [deleted file]
opendaylight/adsal/northbound/staticrouting/src/main/java/org/opendaylight/controller/forwarding/staticrouting/northbound/StaticRoute.java [deleted file]
opendaylight/adsal/northbound/staticrouting/src/main/java/org/opendaylight/controller/forwarding/staticrouting/northbound/StaticRoutes.java [deleted file]
opendaylight/adsal/northbound/staticrouting/src/main/java/org/opendaylight/controller/forwarding/staticrouting/northbound/StaticRoutingNorthbound.java [deleted file]
opendaylight/adsal/northbound/staticrouting/src/main/resources/META-INF/spring.factories [deleted file]
opendaylight/adsal/northbound/staticrouting/src/main/resources/META-INF/spring.handlers [deleted file]
opendaylight/adsal/northbound/staticrouting/src/main/resources/META-INF/spring.schemas [deleted file]
opendaylight/adsal/northbound/staticrouting/src/main/resources/META-INF/spring.tooling [deleted file]
opendaylight/adsal/northbound/staticrouting/src/main/resources/WEB-INF/web.xml [deleted file]
opendaylight/adsal/northbound/staticrouting/src/test/java/org/opendaylight/controller/forwarding/staticrouting/northbound/StaticRoutingNorthboundTest.java [deleted file]
opendaylight/adsal/northbound/statistics/enunciate.xml [deleted file]
opendaylight/adsal/northbound/statistics/pom.xml [deleted file]
opendaylight/adsal/northbound/statistics/src/main/java/org/opendaylight/controller/statistics/northbound/AllFlowStatistics.java [deleted file]
opendaylight/adsal/northbound/statistics/src/main/java/org/opendaylight/controller/statistics/northbound/AllPortStatistics.java [deleted file]
opendaylight/adsal/northbound/statistics/src/main/java/org/opendaylight/controller/statistics/northbound/AllTableStatistics.java [deleted file]
opendaylight/adsal/northbound/statistics/src/main/java/org/opendaylight/controller/statistics/northbound/FlowStatistics.java [deleted file]
opendaylight/adsal/northbound/statistics/src/main/java/org/opendaylight/controller/statistics/northbound/PortStatistics.java [deleted file]
opendaylight/adsal/northbound/statistics/src/main/java/org/opendaylight/controller/statistics/northbound/StatisticsNorthbound.java [deleted file]
opendaylight/adsal/northbound/statistics/src/main/java/org/opendaylight/controller/statistics/northbound/TableStatistics.java [deleted file]
opendaylight/adsal/northbound/statistics/src/main/resources/META-INF/spring.factories [deleted file]
opendaylight/adsal/northbound/statistics/src/main/resources/META-INF/spring.handlers [deleted file]
opendaylight/adsal/northbound/statistics/src/main/resources/META-INF/spring.schemas [deleted file]
opendaylight/adsal/northbound/statistics/src/main/resources/META-INF/spring.tooling [deleted file]
opendaylight/adsal/northbound/statistics/src/main/resources/WEB-INF/web.xml [deleted file]
opendaylight/adsal/northbound/statistics/src/test/java/org/opendaylight/controller/statistics/northbound/StatisticsNorthboundTest.java [deleted file]
opendaylight/adsal/northbound/subnets/enunciate.xml [deleted file]
opendaylight/adsal/northbound/subnets/pom.xml [deleted file]
opendaylight/adsal/northbound/subnets/src/main/java/org/opendaylight/controller/subnets/northbound/SubnetConfigs.java [deleted file]
opendaylight/adsal/northbound/subnets/src/main/java/org/opendaylight/controller/subnets/northbound/SubnetsNorthbound.java [deleted file]
opendaylight/adsal/northbound/subnets/src/main/resources/META-INF/spring.factories [deleted file]
opendaylight/adsal/northbound/subnets/src/main/resources/META-INF/spring.handlers [deleted file]
opendaylight/adsal/northbound/subnets/src/main/resources/META-INF/spring.schemas [deleted file]
opendaylight/adsal/northbound/subnets/src/main/resources/META-INF/spring.tooling [deleted file]
opendaylight/adsal/northbound/subnets/src/main/resources/WEB-INF/web.xml [deleted file]
opendaylight/adsal/northbound/subnets/src/test/java/org/opendaylight/controller/subnets/northbound/SubnetsNorthboundTest.java [deleted file]
opendaylight/adsal/northbound/swagger-ui/pom.xml [deleted file]
opendaylight/adsal/northbound/swagger-ui/src/main/java/org/opendaylight/controller/swaggerui/BasePathModifierServlet.java [deleted file]
opendaylight/adsal/northbound/swagger-ui/src/main/resources/WEB-INF/web.xml [deleted file]
opendaylight/adsal/northbound/swagger-ui/src/main/resources/css/custom.css [deleted file]
opendaylight/adsal/northbound/swagger-ui/src/main/resources/images/logo.png [deleted file]
opendaylight/adsal/northbound/swagger-ui/src/main/resources/index.html [deleted file]
opendaylight/adsal/northbound/switchmanager/enunciate.xml [deleted file]
opendaylight/adsal/northbound/switchmanager/pom.xml [deleted file]
opendaylight/adsal/northbound/switchmanager/src/main/java/org/opendaylight/controller/switchmanager/northbound/NodeConnectorProperties.java [deleted file]
opendaylight/adsal/northbound/switchmanager/src/main/java/org/opendaylight/controller/switchmanager/northbound/NodeConnectors.java [deleted file]
opendaylight/adsal/northbound/switchmanager/src/main/java/org/opendaylight/controller/switchmanager/northbound/NodeProperties.java [deleted file]
opendaylight/adsal/northbound/switchmanager/src/main/java/org/opendaylight/controller/switchmanager/northbound/Nodes.java [deleted file]
opendaylight/adsal/northbound/switchmanager/src/main/java/org/opendaylight/controller/switchmanager/northbound/SwitchNorthbound.java [deleted file]
opendaylight/adsal/northbound/switchmanager/src/main/resources/META-INF/spring.factories [deleted file]
opendaylight/adsal/northbound/switchmanager/src/main/resources/META-INF/spring.handlers [deleted file]
opendaylight/adsal/northbound/switchmanager/src/main/resources/META-INF/spring.schemas [deleted file]
opendaylight/adsal/northbound/switchmanager/src/main/resources/META-INF/spring.tooling [deleted file]
opendaylight/adsal/northbound/switchmanager/src/main/resources/WEB-INF/web.xml [deleted file]
opendaylight/adsal/northbound/switchmanager/src/test/java/org/opendaylight/controller/switchmanager/northbound/SwitchManagerNorthboundTest.java [deleted file]
opendaylight/adsal/northbound/topology/enunciate.xml [deleted file]
opendaylight/adsal/northbound/topology/pom.xml [deleted file]
opendaylight/adsal/northbound/topology/src/main/java/org/opendaylight/controller/topology/northbound/EdgeProperties.java [deleted file]
opendaylight/adsal/northbound/topology/src/main/java/org/opendaylight/controller/topology/northbound/Topology.java [deleted file]
opendaylight/adsal/northbound/topology/src/main/java/org/opendaylight/controller/topology/northbound/TopologyNorthboundJAXRS.java [deleted file]
opendaylight/adsal/northbound/topology/src/main/java/org/opendaylight/controller/topology/northbound/TopologyUserLinks.java [deleted file]
opendaylight/adsal/northbound/topology/src/main/resources/META-INF/spring.factories [deleted file]
opendaylight/adsal/northbound/topology/src/main/resources/META-INF/spring.handlers [deleted file]
opendaylight/adsal/northbound/topology/src/main/resources/META-INF/spring.schemas [deleted file]
opendaylight/adsal/northbound/topology/src/main/resources/META-INF/spring.tooling [deleted file]
opendaylight/adsal/northbound/topology/src/main/resources/WEB-INF/web.xml [deleted file]
opendaylight/adsal/northbound/topology/src/test/java/org/opendaylight/controller/topology/northbound/TopologyTest.java [deleted file]
opendaylight/adsal/northbound/usermanager/enunciate.xml [deleted file]
opendaylight/adsal/northbound/usermanager/pom.xml [deleted file]
opendaylight/adsal/northbound/usermanager/src/main/java/org/opendaylight/controller/usermanager/northbound/UserManagerNorthbound.java [deleted file]
opendaylight/adsal/northbound/usermanager/src/main/resources/WEB-INF/web.xml [deleted file]
opendaylight/adsal/northbound/usermanager/src/test/java/org/opendaylight/controller/subnets/northbound/UserManagerNorthboundTest.java [deleted file]
opendaylight/adsal/northboundtest/unit_test_suite/pom.xml [deleted file]
opendaylight/adsal/northboundtest/unit_test_suite/src/main/java/org/opendaylight/controller/northboundtest/unittestsuite/internal/API3UnitTest.java [deleted file]
opendaylight/adsal/northboundtest/unit_test_suite/src/main/java/org/opendaylight/controller/northboundtest/unittestsuite/internal/Activator.java [deleted file]
opendaylight/adsal/pom.xml [deleted file]
opendaylight/adsal/protocol_plugins/openflow/pom.xml [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/IDataPacketListen.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/IDataPacketMux.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/IDiscoveryListener.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/IFlowProgrammerNotifier.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/IInventoryProvider.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/IInventoryShimExternalListener.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/IInventoryShimInternalListener.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/IOFStatisticsListener.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/IOFStatisticsManager.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/IReadFilterInternalListener.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/IReadServiceFilter.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/IRefreshInternalProvider.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/ITopologyServiceShimListener.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/core/IController.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/core/IMessageListener.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/core/IMessageReadWrite.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/core/ISwitch.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/core/ISwitchStateListener.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/core/internal/Controller.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/core/internal/ControllerIO.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/core/internal/MessageReadWriteService.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/core/internal/PriorityMessage.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/core/internal/SecureMessageReadWriteService.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/core/internal/StatisticsCollector.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/core/internal/SwitchEvent.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/core/internal/SwitchHandler.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/core/internal/SynchronousMessage.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/Activator.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/DataPacketMuxDemux.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/DataPacketServices.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/DescStatisticsConverter.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/DiscoveryService.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/FlowConverter.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/FlowProgrammerNotifier.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/FlowProgrammerService.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/FlowStatisticsConverter.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/InventoryService.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/InventoryServiceHelper.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/InventoryServiceShim.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/OFStatisticsManager.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/PortConverter.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/PortStatisticsConverter.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/ReadService.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/ReadServiceFilter.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/TableConverter.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/TableStatisticsConverter.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/TopologyServiceShim.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/TopologyServices.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/Utils.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/vendorextension/v6extension/V6Error.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/vendorextension/v6extension/V6FlowMod.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/vendorextension/v6extension/V6Match.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/vendorextension/v6extension/V6StatsReply.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/vendorextension/v6extension/V6StatsRequest.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/test/java/org/opendaylight/controller/protocol_plugin/openflow/internal/FlowProgrammerServiceTest.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/test/java/org/opendaylight/controller/protocol_plugin/openflow/vendorextension/v6extension/V6ExtensionTest.java [deleted file]
opendaylight/adsal/protocol_plugins/openflow/src/test/java/org/opendaylight/controller/protocol_plugin/openflow/vendorextension/v6extension/V6MatchTest.java [deleted file]
opendaylight/adsal/protocol_plugins/stub/pom.xml [deleted file]
opendaylight/adsal/protocol_plugins/stub/src/main/java/org/opendaylight/controller/protocol_plugins/stub/internal/Activator.java [deleted file]
opendaylight/adsal/protocol_plugins/stub/src/main/java/org/opendaylight/controller/protocol_plugins/stub/internal/FlowProgrammerService.java [deleted file]
opendaylight/adsal/protocol_plugins/stub/src/main/java/org/opendaylight/controller/protocol_plugins/stub/internal/InventoryService.java [deleted file]
opendaylight/adsal/protocol_plugins/stub/src/main/java/org/opendaylight/controller/protocol_plugins/stub/internal/ReadService.java [deleted file]
opendaylight/adsal/protocol_plugins/stub/src/main/java/org/opendaylight/controller/protocol_plugins/stub/internal/StubNodeConnectorFactory.java [deleted file]
opendaylight/adsal/protocol_plugins/stub/src/main/java/org/opendaylight/controller/protocol_plugins/stub/internal/StubNodeFactory.java [deleted file]
opendaylight/adsal/protocol_plugins/stub/src/main/java/org/opendaylight/controller/protocol_plugins/stub/internal/TopologyServices.java [deleted file]
opendaylight/adsal/routing/dijkstra_implementation/pom.xml [deleted file]
opendaylight/adsal/routing/dijkstra_implementation/src/main/java/org/opendaylight/controller/routing/dijkstra_implementation/internal/Activator.java [deleted file]
opendaylight/adsal/routing/dijkstra_implementation/src/main/java/org/opendaylight/controller/routing/dijkstra_implementation/internal/DijkstraImplementation.java [deleted file]
opendaylight/adsal/routing/dijkstra_implementation/src/main/java/org/opendaylight/controller/routing/dijkstra_implementation/internal/DijkstraImplementationCLI.java [deleted file]
opendaylight/adsal/routing/dijkstra_implementation/src/test/java/org/opendaylight/controller/routing/dijkstra_implementation/DijkstraTest.java [deleted file]
opendaylight/adsal/routing/dijkstra_implementation/src/test/java/org/opendaylight/controller/routing/dijkstra_implementation/MaxThruputTest.java [deleted file]
opendaylight/adsal/sal/api/pom.xml [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/Action.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/ActionType.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/Controller.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/Drop.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/Enqueue.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/Flood.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/FloodAll.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/HwPath.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/Loopback.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/Output.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/PopVlan.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/PushVlan.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/SetDlDst.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/SetDlSrc.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/SetDlType.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/SetNextHop.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/SetNwDst.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/SetNwSrc.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/SetNwTos.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/SetTpDst.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/SetTpSrc.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/SetVlanCfi.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/SetVlanId.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/SetVlanPcp.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/SupportedFlowActions.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/SwPath.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/authorization/AppRole.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/authorization/AppRoleLevel.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/authorization/AuthResultEnum.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/authorization/IResourceAuthorization.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/authorization/Privilege.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/authorization/Resource.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/authorization/ResourceGroup.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/authorization/UserLevel.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/Actions.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/AdvertisedBandwidth.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/Bandwidth.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/Buffers.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/Capabilities.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/ComponentActivatorAbstractBase.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/Config.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/ConstructionException.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/ContainerFlow.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/ContainerServiceDependency.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/Description.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/Edge.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/ForwardingMode.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/Host.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/IContainer.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/IContainerAware.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/IContainerListener.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/IContainerLocalListener.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/Latency.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/MacAddress.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/Name.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/Node.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/NodeConnector.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/NodeTable.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/Path.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/PeerBandwidth.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/Property.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/State.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/SupportedBandwidth.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/Tables.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/Tier.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/TimeStamp.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/UpdateType.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/discovery/IDiscoveryService.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/flowprogrammer/Flow.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/flowprogrammer/IFlowProgrammerListener.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/flowprogrammer/IFlowProgrammerService.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/flowprogrammer/IPluginInFlowProgrammerService.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/flowprogrammer/IPluginOutFlowProgrammerService.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/inventory/IInventoryService.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/inventory/IListenInventoryUpdates.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/inventory/IPluginInInventoryService.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/inventory/IPluginOutInventoryService.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/Match.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/MatchField.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/MatchType.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/extensible/DlDst.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/extensible/DlSrc.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/extensible/DlType.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/extensible/DlVlan.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/extensible/DlVlanPriority.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/extensible/InPort.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/extensible/Match.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/extensible/MatchField.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/extensible/NwDst.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/extensible/NwProtocol.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/extensible/NwSrc.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/extensible/NwTos.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/extensible/TpDst.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/extensible/TpSrc.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/ARP.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/BitBufferHelper.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/BufferException.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/Ethernet.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/ICMP.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/IDataPacketService.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/IEEE8021Q.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/IListenDataPacket.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/IPluginInDataPacketService.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/IPluginOutDataPacketService.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/IPv4.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/LLDP.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/LLDPTLV.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/LinkEncap.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/Packet.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/PacketException.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/PacketResult.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/RawPacket.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/TCP.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/UDP.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/address/DataLinkAddress.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/address/EthernetAddress.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/reader/FlowOnNode.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/reader/IPluginInReadService.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/reader/IPluginOutReadService.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/reader/IReadService.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/reader/IReadServiceListener.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/reader/NodeConnectorStatistics.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/reader/NodeDescription.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/reader/NodeTableStatistics.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/routing/IListenRoutingUpdates.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/routing/IRouting.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/topology/IListenTopoUpdates.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/topology/IPluginInTopologyService.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/topology/IPluginOutTopologyService.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/topology/ITopologyService.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/topology/TopoEdgeUpdate.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/ConfigurationObject.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/Direction.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/EtherTypes.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/FilterIterator.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/GUIField.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/GlobalConstants.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/HexEncode.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/IListener.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/INodeConnectorFactory.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/INodeFactory.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/IObjectReader.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/IPProtocols.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/IterableIterator.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/ListenerDispatcher.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/MultiIterator.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/NetUtils.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/NodeConnectorCreator.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/NodeCreator.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/NodeTableCreator.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/ObjectReader.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/ObjectWriter.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/ReadFromFile.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/ServiceHelper.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/SingletonTask.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/Status.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/StatusCode.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/TierHelper.java [deleted file]
opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/WriteToFile.java [deleted file]
opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/action/ActionTest.java [deleted file]
opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/authorization/AuthorizationTest.java [deleted file]
opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/core/EdgeTest.java [deleted file]
opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/core/NodeConnectorTest.java [deleted file]
opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/core/NodeTableTest.java [deleted file]
opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/core/NodeTest.java [deleted file]
opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/core/PathTest.java [deleted file]
opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/core/PropertyTest.java [deleted file]
opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/flowprogrammer/FlowTest.java [deleted file]
opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/match/MatchExtensibleTest.java [deleted file]
opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/match/MatchTest.java [deleted file]
opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/packet/ARPTest.java [deleted file]
opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/packet/BitBufferHelperTest.java [deleted file]
opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/packet/EthernetTest.java [deleted file]
opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/packet/ICMPTest.java [deleted file]
opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/packet/IEEE8021QTest.java [deleted file]
opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/packet/IPv4Test.java [deleted file]
opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/packet/PacketTest.java [deleted file]
opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/packet/TCPTest.java [deleted file]
opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/packet/UDPTest.java [deleted file]
opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/packet/address/EthernetAddressTest.java [deleted file]
opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/reader/FlowOnNodeTest.java [deleted file]
opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/reader/NodeConnectorStatisticsTest.java [deleted file]
opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/reader/NodeDescriptionTest.java [deleted file]
opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/reader/NodeTableStatisticsTest.java [deleted file]
opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/utils/EtherTypesTest.java [deleted file]
opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/utils/HexEncodeTest.java [deleted file]
opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/utils/IPProtocolsTest.java [deleted file]
opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/utils/NetUtilsTest.java [deleted file]
opendaylight/adsal/sal/connection/api/pom.xml [deleted file]
opendaylight/adsal/sal/connection/api/src/main/java/org/opendaylight/controller/sal/connection/ConnectionConstants.java [deleted file]
opendaylight/adsal/sal/connection/api/src/main/java/org/opendaylight/controller/sal/connection/ConnectionLocality.java [deleted file]
opendaylight/adsal/sal/connection/api/src/main/java/org/opendaylight/controller/sal/connection/IConnectionListener.java [deleted file]
opendaylight/adsal/sal/connection/api/src/main/java/org/opendaylight/controller/sal/connection/IConnectionService.java [deleted file]
opendaylight/adsal/sal/connection/api/src/main/java/org/opendaylight/controller/sal/connection/IPluginInConnectionService.java [deleted file]
opendaylight/adsal/sal/connection/api/src/main/java/org/opendaylight/controller/sal/connection/IPluginOutConnectionService.java [deleted file]
opendaylight/adsal/sal/connection/implementation/pom.xml [deleted file]
opendaylight/adsal/sal/connection/implementation/src/main/java/org/opendaylight/controller/sal/connection/implementation/internal/Activator.java [deleted file]
opendaylight/adsal/sal/connection/implementation/src/main/java/org/opendaylight/controller/sal/connection/implementation/internal/ConnectionService.java [deleted file]
opendaylight/adsal/sal/implementation/pom.xml [deleted file]
opendaylight/adsal/sal/implementation/src/main/java/org/opendaylight/controller/sal/implementation/internal/Activator.java [deleted file]
opendaylight/adsal/sal/implementation/src/main/java/org/opendaylight/controller/sal/implementation/internal/DataPacketService.java [deleted file]
opendaylight/adsal/sal/implementation/src/main/java/org/opendaylight/controller/sal/implementation/internal/FlowProgrammerService.java [deleted file]
opendaylight/adsal/sal/implementation/src/main/java/org/opendaylight/controller/sal/implementation/internal/Inventory.java [deleted file]
opendaylight/adsal/sal/implementation/src/main/java/org/opendaylight/controller/sal/implementation/internal/ProtocolService.java [deleted file]
opendaylight/adsal/sal/implementation/src/main/java/org/opendaylight/controller/sal/implementation/internal/ReadService.java [deleted file]
opendaylight/adsal/sal/implementation/src/main/java/org/opendaylight/controller/sal/implementation/internal/Topology.java [deleted file]
opendaylight/adsal/sal/implementation/src/test/java/org/opendaylight/controller/sal/implementation/DataPacketServiceTest.java [deleted file]
opendaylight/adsal/sal/implementation/src/test/java/org/opendaylight/controller/sal/implementation/ProtocolServiceTest.java [deleted file]
opendaylight/adsal/sal/networkconfiguration/api/pom.xml [deleted file]
opendaylight/adsal/sal/networkconfiguration/api/src/main/java/org/opendaylight/controller/sal/networkconfig/bridgedomain/BridgeDomainConfigServiceException.java [deleted file]
opendaylight/adsal/sal/networkconfiguration/api/src/main/java/org/opendaylight/controller/sal/networkconfig/bridgedomain/ConfigConstants.java [deleted file]
opendaylight/adsal/sal/networkconfiguration/api/src/main/java/org/opendaylight/controller/sal/networkconfig/bridgedomain/IBridgeDomainConfigService.java [deleted file]
opendaylight/adsal/sal/networkconfiguration/api/src/main/java/org/opendaylight/controller/sal/networkconfig/bridgedomain/IPluginInBridgeDomainConfigService.java [deleted file]
opendaylight/adsal/sal/networkconfiguration/implementation/pom.xml [deleted file]
opendaylight/adsal/sal/networkconfiguration/implementation/src/main/java/org/opendaylight/controller/sal/networkconfig/bridgedomain/internal/BridgeDomainConfigService.java [deleted file]
opendaylight/adsal/sal/networkconfiguration/implementation/src/main/java/org/opendaylight/controller/sal/networkconfig/internal/Activator.java [deleted file]
opendaylight/adsal/samples/clustersession/pom.xml [deleted file]
opendaylight/adsal/samples/clustersession/src/main/java/org/opendaylight/controller/clustersession/ClusterSession.java [deleted file]
opendaylight/adsal/samples/clustersession/src/main/java/org/opendaylight/controller/clustersession/ClusterSessionData.java [deleted file]
opendaylight/adsal/samples/clustersession/src/main/java/org/opendaylight/controller/clustersession/ClusterSessionManager.java [deleted file]
opendaylight/adsal/samples/clustersession/src/main/java/org/opendaylight/controller/clustersession/ClusterSessionUtil.java [deleted file]
opendaylight/adsal/samples/clustersession/src/main/java/org/opendaylight/controller/clustersession/impl/ClusterSessionServiceImpl.java [deleted file]
opendaylight/adsal/samples/clustersession/src/main/java/org/opendaylight/controller/clustersession/service/ClusterSessionService.java [deleted file]
opendaylight/adsal/samples/clustersession/src/test/java/org/opendaylight/controller/clustersession/ClusterSessionManagerTest.java [deleted file]
opendaylight/adsal/samples/clustersession/src/test/java/org/opendaylight/controller/clustersession/ClusterSessionServiceImplTest.java [deleted file]
opendaylight/adsal/samples/clustersession/src/test/java/org/opendaylight/controller/clustersession/ClusterSessionUtilTest.java [deleted file]
opendaylight/adsal/samples/loadbalancer/pom.xml [deleted file]
opendaylight/adsal/samples/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/ConfigManager.java [deleted file]
opendaylight/adsal/samples/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/IConfigManager.java [deleted file]
opendaylight/adsal/samples/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/LBConst.java [deleted file]
opendaylight/adsal/samples/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/LBUtil.java [deleted file]
opendaylight/adsal/samples/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/entities/Client.java [deleted file]
opendaylight/adsal/samples/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/entities/Pool.java [deleted file]
opendaylight/adsal/samples/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/entities/PoolMember.java [deleted file]
opendaylight/adsal/samples/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/entities/VIP.java [deleted file]
opendaylight/adsal/samples/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/internal/Activator.java [deleted file]
opendaylight/adsal/samples/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/internal/LoadBalancerService.java [deleted file]
opendaylight/adsal/samples/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/policies/ILoadBalancingPolicy.java [deleted file]
opendaylight/adsal/samples/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/policies/RandomLBPolicy.java [deleted file]
opendaylight/adsal/samples/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/policies/RoundRobinLBPolicy.java [deleted file]
opendaylight/adsal/samples/loadbalancer/src/test/java/org/opendaylight/controller/samples/loadbalancer/internal/LoadBalancerTest.java [deleted file]
opendaylight/adsal/samples/northbound/loadbalancer/enunciate.xml [deleted file]
opendaylight/adsal/samples/northbound/loadbalancer/pom.xml [deleted file]
opendaylight/adsal/samples/northbound/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/northbound/LoadBalancerNorthbound.java [deleted file]
opendaylight/adsal/samples/northbound/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/northbound/NBConst.java [deleted file]
opendaylight/adsal/samples/northbound/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/northbound/Pools.java [deleted file]
opendaylight/adsal/samples/northbound/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/northbound/VIPs.java [deleted file]
opendaylight/adsal/samples/northbound/loadbalancer/src/main/resources/META-INF/spring.factories [deleted file]
opendaylight/adsal/samples/northbound/loadbalancer/src/main/resources/META-INF/spring.handlers [deleted file]
opendaylight/adsal/samples/northbound/loadbalancer/src/main/resources/META-INF/spring.schemas [deleted file]
opendaylight/adsal/samples/northbound/loadbalancer/src/main/resources/META-INF/spring.tooling [deleted file]
opendaylight/adsal/samples/northbound/loadbalancer/src/main/resources/WEB-INF/web.xml [deleted file]
opendaylight/adsal/samples/simpleforwarding/pom.xml [deleted file]
opendaylight/adsal/samples/simpleforwarding/src/main/java/org/opendaylight/controller/samples/simpleforwarding/HostNodePair.java [deleted file]
opendaylight/adsal/samples/simpleforwarding/src/main/java/org/opendaylight/controller/samples/simpleforwarding/IBroadcastHandler.java [deleted file]
opendaylight/adsal/samples/simpleforwarding/src/main/java/org/opendaylight/controller/samples/simpleforwarding/IBroadcastPortSelector.java [deleted file]
opendaylight/adsal/samples/simpleforwarding/src/main/java/org/opendaylight/controller/samples/simpleforwarding/internal/Activator.java [deleted file]
opendaylight/adsal/samples/simpleforwarding/src/main/java/org/opendaylight/controller/samples/simpleforwarding/internal/SimpleBroadcastHandlerImpl.java [deleted file]
opendaylight/adsal/samples/simpleforwarding/src/main/java/org/opendaylight/controller/samples/simpleforwarding/internal/SimpleForwardingImpl.java [deleted file]
opendaylight/adsal/samples/simpleforwarding/src/test/java/org/opendaylight/controller/samples/simpleforwarding/internal/HostSwitchTest.java [deleted file]
opendaylight/adsal/security/pom.xml [deleted file]
opendaylight/adsal/security/src/main/java/org/opendaylight/controller/security/ControllerCustomRealm.java [deleted file]
opendaylight/adsal/statisticsmanager/api/pom.xml [deleted file]
opendaylight/adsal/statisticsmanager/api/src/main/java/org/opendaylight/controller/statisticsmanager/IStatisticsManager.java [deleted file]
opendaylight/adsal/statisticsmanager/implementation/pom.xml [deleted file]
opendaylight/adsal/statisticsmanager/implementation/src/main/java/org/opendaylight/controller/statisticsmanager/internal/Activator.java [deleted file]
opendaylight/adsal/statisticsmanager/implementation/src/main/java/org/opendaylight/controller/statisticsmanager/internal/StatisticsManager.java [deleted file]
opendaylight/adsal/statisticsmanager/implementation/src/test/java/org/opendaylight/controller/statisticsmanager/internal/StatisticsManagerTest.java [deleted file]
opendaylight/adsal/statisticsmanager/integrationtest/pom.xml [deleted file]
opendaylight/adsal/statisticsmanager/integrationtest/src/test/java/org/opendaylight/controller/statisticsmanager/internal/StatisticsManagerIT.java [deleted file]
opendaylight/adsal/statisticsmanager/integrationtest/src/test/resources/logback.xml [deleted file]
opendaylight/adsal/switchmanager/api/pom.xml [deleted file]
opendaylight/adsal/switchmanager/api/src/main/java/org/opendaylight/controller/switchmanager/IInventoryListener.java [deleted file]
opendaylight/adsal/switchmanager/api/src/main/java/org/opendaylight/controller/switchmanager/ISpanAware.java [deleted file]
opendaylight/adsal/switchmanager/api/src/main/java/org/opendaylight/controller/switchmanager/ISwitchManager.java [deleted file]
opendaylight/adsal/switchmanager/api/src/main/java/org/opendaylight/controller/switchmanager/ISwitchManagerAware.java [deleted file]
opendaylight/adsal/switchmanager/api/src/main/java/org/opendaylight/controller/switchmanager/SpanConfig.java [deleted file]
opendaylight/adsal/switchmanager/api/src/main/java/org/opendaylight/controller/switchmanager/Subnet.java [deleted file]
opendaylight/adsal/switchmanager/api/src/main/java/org/opendaylight/controller/switchmanager/SubnetConfig.java [deleted file]
opendaylight/adsal/switchmanager/api/src/main/java/org/opendaylight/controller/switchmanager/Switch.java [deleted file]
opendaylight/adsal/switchmanager/api/src/main/java/org/opendaylight/controller/switchmanager/SwitchConfig.java [deleted file]
opendaylight/adsal/switchmanager/api/src/test/java/org/opendaylight/controller/switchmanager/SubnetConfigTest.java [deleted file]
opendaylight/adsal/switchmanager/api/src/test/java/org/opendaylight/controller/switchmanager/SubnetTest.java [deleted file]
opendaylight/adsal/switchmanager/api/src/test/java/org/opendaylight/controller/switchmanager/SwitchTest.java [deleted file]
opendaylight/adsal/switchmanager/implementation/pom.xml [deleted file]
opendaylight/adsal/switchmanager/implementation/src/main/java/org/opendaylight/controller/switchmanager/internal/Activator.java [deleted file]
opendaylight/adsal/switchmanager/implementation/src/main/java/org/opendaylight/controller/switchmanager/internal/ControllerProperties.java [deleted file]
opendaylight/adsal/switchmanager/implementation/src/main/java/org/opendaylight/controller/switchmanager/internal/IControllerProperties.java [deleted file]
opendaylight/adsal/switchmanager/implementation/src/main/java/org/opendaylight/controller/switchmanager/internal/SwitchManager.java [deleted file]
opendaylight/adsal/switchmanager/implementation/src/main/java/org/opendaylight/controller/switchmanager/internal/SwitchManagerCLI.java [deleted file]
opendaylight/adsal/switchmanager/implementation/src/test/java/org/opendaylight/controller/switchmanager/internal/SwitchManagerTest.java [deleted file]
opendaylight/adsal/switchmanager/integrationtest/pom.xml [deleted file]
opendaylight/adsal/switchmanager/integrationtest/src/test/java/org/opendaylight/controller/switchmanager/internal/SwitchManagerIT.java [deleted file]
opendaylight/adsal/switchmanager/integrationtest/src/test/resources/logback.xml [deleted file]
opendaylight/adsal/topologymanager/implementation/pom.xml [deleted file]
opendaylight/adsal/topologymanager/implementation/src/main/java/org/opendaylight/controller/topologymanager/ITopologyManager.java [deleted file]
opendaylight/adsal/topologymanager/implementation/src/main/java/org/opendaylight/controller/topologymanager/ITopologyManagerAware.java [deleted file]
opendaylight/adsal/topologymanager/implementation/src/main/java/org/opendaylight/controller/topologymanager/ITopologyManagerClusterWideAware.java [deleted file]
opendaylight/adsal/topologymanager/implementation/src/main/java/org/opendaylight/controller/topologymanager/ITopologyManagerShell.java [deleted file]
opendaylight/adsal/topologymanager/implementation/src/main/java/org/opendaylight/controller/topologymanager/TopologyUserLinkConfig.java [deleted file]
opendaylight/adsal/topologymanager/implementation/src/main/java/org/opendaylight/controller/topologymanager/internal/Activator.java [deleted file]
opendaylight/adsal/topologymanager/implementation/src/main/java/org/opendaylight/controller/topologymanager/internal/TopologyManagerImpl.java [deleted file]
opendaylight/adsal/topologymanager/implementation/src/test/java/org/opendaylight/controller/topologymanager/internal/TopologyManagerImplTest.java [deleted file]
opendaylight/adsal/topologymanager/integrationtest/pom.xml [deleted file]
opendaylight/adsal/topologymanager/integrationtest/src/test/java/org/opendaylight/controller/topologymanager/TopologyManagerIT.java [deleted file]
opendaylight/adsal/topologymanager/integrationtest/src/test/resources/logback.xml [deleted file]
opendaylight/adsal/topologymanager/shell/pom.xml [deleted file]
opendaylight/adsal/topologymanager/shell/src/main/java/org/opendaylight/controller/topologymanager/shell/AddUserLink.java [deleted file]
opendaylight/adsal/topologymanager/shell/src/main/java/org/opendaylight/controller/topologymanager/shell/DeleteUserLink.java [deleted file]
opendaylight/adsal/topologymanager/shell/src/main/java/org/opendaylight/controller/topologymanager/shell/PrintNodeEdges.java [deleted file]
opendaylight/adsal/topologymanager/shell/src/main/java/org/opendaylight/controller/topologymanager/shell/PrintUserLink.java [deleted file]
opendaylight/adsal/topologymanager/shell/src/main/resources/OSGI-INF/blueprint/blueprint.xml [deleted file]
opendaylight/adsal/usermanager/api/pom.xml [deleted file]
opendaylight/adsal/usermanager/api/src/main/java/org/opendaylight/controller/usermanager/AuthResponse.java [deleted file]
opendaylight/adsal/usermanager/api/src/main/java/org/opendaylight/controller/usermanager/AuthenticatedUser.java [deleted file]
opendaylight/adsal/usermanager/api/src/main/java/org/opendaylight/controller/usermanager/AuthorizationConfig.java [deleted file]
opendaylight/adsal/usermanager/api/src/main/java/org/opendaylight/controller/usermanager/IAAAProvider.java [deleted file]
opendaylight/adsal/usermanager/api/src/main/java/org/opendaylight/controller/usermanager/ISessionManager.java [deleted file]
opendaylight/adsal/usermanager/api/src/main/java/org/opendaylight/controller/usermanager/IUserManager.java [deleted file]
opendaylight/adsal/usermanager/api/src/main/java/org/opendaylight/controller/usermanager/ODLUserLevel.java [deleted file]
opendaylight/adsal/usermanager/api/src/main/java/org/opendaylight/controller/usermanager/ServerConfig.java [deleted file]
opendaylight/adsal/usermanager/api/src/main/java/org/opendaylight/controller/usermanager/UserConfig.java [deleted file]
opendaylight/adsal/usermanager/api/src/test/java/org/opendaylight/controller/usermanager/AuthResponseTest.java [deleted file]
opendaylight/adsal/usermanager/api/src/test/java/org/opendaylight/controller/usermanager/AuthenticatedUserTest.java [deleted file]
opendaylight/adsal/usermanager/api/src/test/java/org/opendaylight/controller/usermanager/AuthorizationUserConfigTest.java [deleted file]
opendaylight/adsal/usermanager/api/src/test/java/org/opendaylight/controller/usermanager/ServerConfigTest.java [deleted file]
opendaylight/adsal/usermanager/implementation/pom.xml [deleted file]
opendaylight/adsal/usermanager/implementation/src/main/java/org/opendaylight/controller/usermanager/internal/Activator.java [deleted file]
opendaylight/adsal/usermanager/implementation/src/main/java/org/opendaylight/controller/usermanager/internal/UserManager.java [deleted file]
opendaylight/adsal/usermanager/implementation/src/main/java/org/opendaylight/controller/usermanager/security/SessionManager.java [deleted file]
opendaylight/adsal/usermanager/implementation/src/main/java/org/opendaylight/controller/usermanager/security/UserSecurityContextRepository.java [deleted file]
opendaylight/adsal/usermanager/implementation/src/test/java/org/opendaylight/controller/usermanager/internal/UserManagerImplTest.java [deleted file]
opendaylight/adsal/web/brandfragment/pom.xml [deleted file]
opendaylight/adsal/web/brandfragment/src/main/resources/WEB-INF/jsp/customerror.jsp [deleted file]
opendaylight/adsal/web/brandfragment/src/main/resources/WEB-INF/jsp/customlogin.jsp [deleted file]
opendaylight/adsal/web/brandfragment/src/main/resources/WEB-INF/jsp/custommain.jsp [deleted file]
opendaylight/adsal/web/brandfragment/src/main/resources/css/customlogin.less [deleted file]
opendaylight/adsal/web/brandfragment/src/main/resources/css/custommain.less [deleted file]
opendaylight/adsal/web/brandfragment/src/main/resources/img/logo.png [deleted file]
opendaylight/adsal/web/devices/pom.xml [deleted file]
opendaylight/adsal/web/devices/src/main/java/org/opendaylight/controller/devices/web/Devices.java [deleted file]
opendaylight/adsal/web/devices/src/main/java/org/opendaylight/controller/devices/web/DevicesJsonBean.java [deleted file]
opendaylight/adsal/web/devices/src/main/java/org/opendaylight/controller/devices/web/NodeJsonBean.java [deleted file]
opendaylight/adsal/web/devices/src/main/java/org/opendaylight/controller/devices/web/PortJsonBean.java [deleted file]
opendaylight/adsal/web/devices/src/main/java/org/opendaylight/controller/devices/web/SpanPortJsonBean.java [deleted file]
opendaylight/adsal/web/devices/src/main/java/org/opendaylight/controller/devices/web/StatusJsonBean.java [deleted file]
opendaylight/adsal/web/devices/src/main/java/org/opendaylight/controller/devices/web/SubnetGatewayPortBean.java [deleted file]
opendaylight/adsal/web/devices/src/main/resources/META-INF/spring.factories [deleted file]
opendaylight/adsal/web/devices/src/main/resources/META-INF/spring.handlers [deleted file]
opendaylight/adsal/web/devices/src/main/resources/META-INF/spring.schemas [deleted file]
opendaylight/adsal/web/devices/src/main/resources/META-INF/spring.tooling [deleted file]
opendaylight/adsal/web/devices/src/main/resources/WEB-INF/Devices-servlet.xml [deleted file]
opendaylight/adsal/web/devices/src/main/resources/WEB-INF/jsp/autherror.jsp [deleted file]
opendaylight/adsal/web/devices/src/main/resources/WEB-INF/jsp/error.jsp [deleted file]
opendaylight/adsal/web/devices/src/main/resources/WEB-INF/jsp/login.jsp [deleted file]
opendaylight/adsal/web/devices/src/main/resources/WEB-INF/web.xml [deleted file]
opendaylight/adsal/web/devices/src/main/resources/js/page.js [deleted file]
opendaylight/adsal/web/flows/pom.xml [deleted file]
opendaylight/adsal/web/flows/src/main/java/org/opendaylight/controller/flows/web/Flows.java [deleted file]
opendaylight/adsal/web/flows/src/main/resources/META-INF/spring.factories [deleted file]
opendaylight/adsal/web/flows/src/main/resources/META-INF/spring.handlers [deleted file]
opendaylight/adsal/web/flows/src/main/resources/META-INF/spring.schemas [deleted file]
opendaylight/adsal/web/flows/src/main/resources/META-INF/spring.tooling [deleted file]
opendaylight/adsal/web/flows/src/main/resources/WEB-INF/Flows-servlet.xml [deleted file]
opendaylight/adsal/web/flows/src/main/resources/WEB-INF/jsp/autherror.jsp [deleted file]
opendaylight/adsal/web/flows/src/main/resources/WEB-INF/jsp/error.jsp [deleted file]
opendaylight/adsal/web/flows/src/main/resources/WEB-INF/jsp/login.jsp [deleted file]
opendaylight/adsal/web/flows/src/main/resources/WEB-INF/web.xml [deleted file]
opendaylight/adsal/web/flows/src/main/resources/js/page.js [deleted file]
opendaylight/adsal/web/osgi-brandfragment/pom.xml [deleted file]
opendaylight/adsal/web/osgi-brandfragment/src/main/resources/META-INF/webconsole.properties [deleted file]
opendaylight/adsal/web/osgi-brandfragment/src/main/resources/res/imgs/odl/favicon.ico [deleted file]
opendaylight/adsal/web/osgi-brandfragment/src/main/resources/res/imgs/odl/logo.png [deleted file]
opendaylight/adsal/web/root/pom.xml [deleted file]
opendaylight/adsal/web/root/src/main/java/org/opendaylight/controller/web/ClusterNodeBean.java [deleted file]
opendaylight/adsal/web/root/src/main/java/org/opendaylight/controller/web/ControllerUISessionManager.java [deleted file]
opendaylight/adsal/web/root/src/main/java/org/opendaylight/controller/web/DaylightWeb.java [deleted file]
opendaylight/adsal/web/root/src/main/java/org/opendaylight/controller/web/DaylightWebAdmin.java [deleted file]
opendaylight/adsal/web/root/src/main/java/org/opendaylight/controller/web/DaylightWebUtil.java [deleted file]
opendaylight/adsal/web/root/src/main/java/org/opendaylight/controller/web/IDaylightWeb.java [deleted file]
opendaylight/adsal/web/root/src/main/java/org/opendaylight/controller/web/NodeBean.java [deleted file]
opendaylight/adsal/web/root/src/main/java/org/opendaylight/controller/web/UserBean.java [deleted file]
opendaylight/adsal/web/root/src/main/resources/META-INF/spring.factories [deleted file]
opendaylight/adsal/web/root/src/main/resources/META-INF/spring.handlers [deleted file]
opendaylight/adsal/web/root/src/main/resources/META-INF/spring.schemas [deleted file]
opendaylight/adsal/web/root/src/main/resources/META-INF/spring.tooling [deleted file]
opendaylight/adsal/web/root/src/main/resources/WEB-INF/RootGUI-servlet.xml [deleted file]
opendaylight/adsal/web/root/src/main/resources/WEB-INF/jsp/autherror.jsp [deleted file]
opendaylight/adsal/web/root/src/main/resources/WEB-INF/jsp/error.jsp [deleted file]
opendaylight/adsal/web/root/src/main/resources/WEB-INF/jsp/login.jsp [deleted file]
opendaylight/adsal/web/root/src/main/resources/WEB-INF/jsp/main.jsp [deleted file]
opendaylight/adsal/web/root/src/main/resources/WEB-INF/spring/servlet/security.xml [deleted file]
opendaylight/adsal/web/root/src/main/resources/WEB-INF/web.xml [deleted file]
opendaylight/adsal/web/root/src/main/resources/css/bootstrap.min.css [deleted file]
opendaylight/adsal/web/root/src/main/resources/css/fuelux-responsive.min.css [deleted file]
opendaylight/adsal/web/root/src/main/resources/css/fuelux.min.css [deleted file]
opendaylight/adsal/web/root/src/main/resources/css/login.less [deleted file]
opendaylight/adsal/web/root/src/main/resources/css/one.less [deleted file]
opendaylight/adsal/web/root/src/main/resources/css/opendaylight.css [deleted file]
opendaylight/adsal/web/root/src/main/resources/img/Device_pc_3045_default_64.png [deleted file]
opendaylight/adsal/web/root/src/main/resources/img/Device_switch_3062_unknown_64.png [deleted file]
opendaylight/adsal/web/root/src/main/resources/img/Expand16T.png [deleted file]
opendaylight/adsal/web/root/src/main/resources/img/Key_0024_16.png [deleted file]
opendaylight/adsal/web/root/src/main/resources/img/alert_unreachable_2008_128.png [deleted file]
opendaylight/adsal/web/root/src/main/resources/img/form.png [deleted file]
opendaylight/adsal/web/root/src/main/resources/img/logo.png [deleted file]
opendaylight/adsal/web/root/src/main/resources/img/logo_16.png [deleted file]
opendaylight/adsal/web/root/src/main/resources/img/nextpageleft.png [deleted file]
opendaylight/adsal/web/root/src/main/resources/img/nextpageright.png [deleted file]
opendaylight/adsal/web/root/src/main/resources/img/open_1054_16.png [deleted file]
opendaylight/adsal/web/root/src/main/resources/img/open_1054_24.png [deleted file]
opendaylight/adsal/web/root/src/main/resources/img/save_as_0106_16.png [deleted file]
opendaylight/adsal/web/root/src/main/resources/img/save_as_0106_24.png [deleted file]
opendaylight/adsal/web/root/src/main/resources/img/search.png [deleted file]
opendaylight/adsal/web/root/src/main/resources/img/searchremove.png [deleted file]
opendaylight/adsal/web/root/src/main/resources/img/sort_down.png [deleted file]
opendaylight/adsal/web/root/src/main/resources/img/sort_up.png [deleted file]
opendaylight/adsal/web/root/src/main/resources/img/topology_view_1033_128.png [deleted file]
opendaylight/adsal/web/root/src/main/resources/img/topology_view_1033_16.png [deleted file]
opendaylight/adsal/web/root/src/main/resources/img/user_0020_16.png [deleted file]
opendaylight/adsal/web/root/src/main/resources/img/user_0020_24.png [deleted file]
opendaylight/adsal/web/root/src/main/resources/img/user_group_0107_16.png [deleted file]
opendaylight/adsal/web/root/src/main/resources/img/user_group_0107_24.png [deleted file]
opendaylight/adsal/web/root/src/main/resources/js/bootstrap.min.js [deleted file]
opendaylight/adsal/web/root/src/main/resources/js/datasource.js [deleted file]
opendaylight/adsal/web/root/src/main/resources/js/fuelux/COPYING [deleted file]
opendaylight/adsal/web/root/src/main/resources/js/fuelux/all.min.js [deleted file]
opendaylight/adsal/web/root/src/main/resources/js/fuelux/checkbox.js [deleted file]
opendaylight/adsal/web/root/src/main/resources/js/fuelux/combobox.js [deleted file]
opendaylight/adsal/web/root/src/main/resources/js/fuelux/datagrid.js [deleted file]
opendaylight/adsal/web/root/src/main/resources/js/fuelux/loader.min.js [deleted file]
opendaylight/adsal/web/root/src/main/resources/js/fuelux/pillbox.js [deleted file]
opendaylight/adsal/web/root/src/main/resources/js/fuelux/radio.js [deleted file]
opendaylight/adsal/web/root/src/main/resources/js/fuelux/search.js [deleted file]
opendaylight/adsal/web/root/src/main/resources/js/fuelux/select.js [deleted file]
opendaylight/adsal/web/root/src/main/resources/js/fuelux/spinner.js [deleted file]
opendaylight/adsal/web/root/src/main/resources/js/fuelux/tree.js [deleted file]
opendaylight/adsal/web/root/src/main/resources/js/fuelux/util.js [deleted file]
opendaylight/adsal/web/root/src/main/resources/js/fuelux/wizard.js [deleted file]
opendaylight/adsal/web/root/src/main/resources/js/jit.js [deleted file]
opendaylight/adsal/web/root/src/main/resources/js/jquery-1.9.1.min.js [deleted file]
opendaylight/adsal/web/root/src/main/resources/js/less-1.3.3.min.js [deleted file]
opendaylight/adsal/web/root/src/main/resources/js/lib.js [deleted file]
opendaylight/adsal/web/root/src/main/resources/js/open-topology.js [deleted file]
opendaylight/adsal/web/root/src/main/resources/js/open.js [deleted file]
opendaylight/adsal/web/root/src/main/resources/js/underscore-min.js [deleted file]
opendaylight/adsal/web/topology/pom.xml [deleted file]
opendaylight/adsal/web/topology/src/main/java/org/opendaylight/controller/topology/web/Topology.java [deleted file]
opendaylight/adsal/web/topology/src/main/resources/META-INF/spring.factories [deleted file]
opendaylight/adsal/web/topology/src/main/resources/META-INF/spring.handlers [deleted file]
opendaylight/adsal/web/topology/src/main/resources/META-INF/spring.schemas [deleted file]
opendaylight/adsal/web/topology/src/main/resources/META-INF/spring.tooling [deleted file]
opendaylight/adsal/web/topology/src/main/resources/WEB-INF/Topology-servlet.xml [deleted file]
opendaylight/adsal/web/topology/src/main/resources/WEB-INF/jsp/autherror.jsp [deleted file]
opendaylight/adsal/web/topology/src/main/resources/WEB-INF/jsp/error.jsp [deleted file]
opendaylight/adsal/web/topology/src/main/resources/WEB-INF/jsp/login.jsp [deleted file]
opendaylight/adsal/web/topology/src/main/resources/WEB-INF/web.xml [deleted file]
opendaylight/adsal/web/topology/src/main/resources/js/page.js [deleted file]
opendaylight/adsal/web/topology/src/test/java/org/opendaylight/controller/topology/web/TopologyTest.java [deleted file]
opendaylight/adsal/web/troubleshoot/pom.xml [deleted file]
opendaylight/adsal/web/troubleshoot/src/main/java/org/opendaylight/controller/troubleshoot/web/Troubleshoot.java [deleted file]
opendaylight/adsal/web/troubleshoot/src/main/java/org/opendaylight/controller/troubleshoot/web/TroubleshootingJsonBean.java [deleted file]
opendaylight/adsal/web/troubleshoot/src/main/resources/META-INF/spring.factories [deleted file]
opendaylight/adsal/web/troubleshoot/src/main/resources/META-INF/spring.handlers [deleted file]
opendaylight/adsal/web/troubleshoot/src/main/resources/META-INF/spring.schemas [deleted file]
opendaylight/adsal/web/troubleshoot/src/main/resources/META-INF/spring.tooling [deleted file]
opendaylight/adsal/web/troubleshoot/src/main/resources/WEB-INF/Troubleshoot-servlet.xml [deleted file]
opendaylight/adsal/web/troubleshoot/src/main/resources/WEB-INF/jsp/autherror.jsp [deleted file]
opendaylight/adsal/web/troubleshoot/src/main/resources/WEB-INF/jsp/error.jsp [deleted file]
opendaylight/adsal/web/troubleshoot/src/main/resources/WEB-INF/jsp/login.jsp [deleted file]
opendaylight/adsal/web/troubleshoot/src/main/resources/WEB-INF/web.xml [deleted file]
opendaylight/adsal/web/troubleshoot/src/main/resources/js/page.js [deleted file]
pom.xml

index 57d46572713eaa088d6de24e33da7bcf3f6ec7ac..8365369d5b296f30f737f87d9931ea0981488008 100644 (file)
       <type>xml</type>
       <scope>runtime</scope>
     </dependency>
       <type>xml</type>
       <scope>runtime</scope>
     </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>features-adsal</artifactId>
-      <classifier>features</classifier>
-      <type>xml</type>
-      <scope>runtime</scope>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>features-nsf</artifactId>
-      <classifier>features</classifier>
-      <type>xml</type>
-      <scope>runtime</scope>
-    </dependency>
     <!-- MD-SAL Related Features -->
     <dependency>
       <groupId>org.opendaylight.controller</groupId>
     <!-- MD-SAL Related Features -->
     <dependency>
       <groupId>org.opendaylight.controller</groupId>
diff --git a/opendaylight/adsal/adsal-enunciate-parent/enunciate.xml b/opendaylight/adsal/adsal-enunciate-parent/enunciate.xml
deleted file mode 100644 (file)
index 431ea7b..0000000
+++ /dev/null
@@ -1,12 +0,0 @@
-<?xml version="1.0"?>
-<!-- vi: set et smarttab sw=4 tabstop=4: -->
-<!--
- copyright (c) 2015 cisco systems, inc. and others.  all rights reserved.
-
- this program and the accompanying materials are made available under the
- terms of the eclipse public license v1.0 which accompanies this distribution,
- and is available at http://www.eclipse.org/legal/epl-v10.html
--->
-<enunciate label="full" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="http://enunciate.codehaus.org/schemas/enunciate-1.28.xsd">
-</enunciate>
-
diff --git a/opendaylight/adsal/adsal-enunciate-parent/pom.xml b/opendaylight/adsal/adsal-enunciate-parent/pom.xml
deleted file mode 100644 (file)
index 1c6f99f..0000000
+++ /dev/null
@@ -1,42 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<!-- vi: set et smarttab sw=4 tabstop=4: -->
-<!--
- copyright (c) 2015 cisco systems, inc. and others.  all rights reserved.
-
- this program and the accompanying materials are made available under the
- terms of the eclipse public license v1.0 which accompanies this distribution,
- and is available at http://www.eclipse.org/legal/epl-v10.html
--->
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
-         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-
-    <parent>
-        <groupId>org.opendaylight.controller</groupId>
-        <artifactId>enunciate-parent</artifactId>
-        <version>1.6.0-SNAPSHOT</version>
-        <relativePath>../../commons/enunciate-parent</relativePath>
-    </parent>
-
-    <modelVersion>4.0.0</modelVersion>
-    <artifactId>adsal-enunciate-parent</artifactId>
-    <packaging>pom</packaging>
-
-    <build>
-        <pluginManagement>
-            <plugins>
-                <plugin>
-                    <groupId>org.codehaus.enunciate</groupId>
-                    <artifactId>maven-enunciate-plugin</artifactId>
-                    <dependencies>
-                        <dependency>
-                            <groupId>org.opendaylight.controller</groupId>
-                            <artifactId>sal</artifactId>
-                            <version>${sal.version}</version>
-                        </dependency>
-                    </dependencies>
-                </plugin>
-            </plugins>
-        </pluginManagement>
-    </build>
-</project>
-
diff --git a/opendaylight/adsal/appauth/pom.xml b/opendaylight/adsal/appauth/pom.xml
deleted file mode 100644 (file)
index 00de90b..0000000
+++ /dev/null
@@ -1,61 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../commons/opendaylight</relativePath>
-  </parent>
-  <artifactId>appauth</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-
-  <dependencies>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>configuration</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>containermanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>usermanager</artifactId>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Import-Package>org.opendaylight.controller.configuration,
-                            org.opendaylight.controller.containermanager,
-                            org.opendaylight.controller.sal.authorization,
-                            org.opendaylight.controller.sal.utils,
-                            org.opendaylight.controller.usermanager,
-                            org.slf4j,
-                            org.apache.felix.dm,</Import-Package>
-            <Export-Package>org.opendaylight.controller.appauth,
-                            org.opendaylight.controller.appauth.authorization</Export-Package>
-          </instructions>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/appauth/src/main/java/org/opendaylight/controller/appauth/Application.java b/opendaylight/adsal/appauth/src/main/java/org/opendaylight/controller/appauth/Application.java
deleted file mode 100644 (file)
index 84a2e91..0000000
+++ /dev/null
@@ -1,20 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.appauth;
-
-import org.opendaylight.controller.appauth.authorization.Authorization;
-
-public abstract class Application<T> extends Authorization<T> {
-
-    public Application() {
-        super();
-    }
-
-}
diff --git a/opendaylight/adsal/appauth/src/main/java/org/opendaylight/controller/appauth/authorization/Authorization.java b/opendaylight/adsal/appauth/src/main/java/org/opendaylight/controller/appauth/authorization/Authorization.java
deleted file mode 100644 (file)
index b70a79b..0000000
+++ /dev/null
@@ -1,675 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.appauth.authorization;
-
-import java.util.ArrayList;
-import java.util.HashSet;
-import java.util.List;
-import java.util.Map.Entry;
-import java.util.Set;
-import java.util.concurrent.ConcurrentMap;
-
-import org.opendaylight.controller.configuration.ConfigurationObject;
-import org.opendaylight.controller.containermanager.IContainerAuthorization;
-import org.opendaylight.controller.sal.authorization.AppRoleLevel;
-import org.opendaylight.controller.sal.authorization.IResourceAuthorization;
-import org.opendaylight.controller.sal.authorization.Privilege;
-import org.opendaylight.controller.sal.authorization.Resource;
-import org.opendaylight.controller.sal.authorization.ResourceGroup;
-import org.opendaylight.controller.sal.authorization.UserLevel;
-import org.opendaylight.controller.sal.utils.ServiceHelper;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.sal.utils.StatusCode;
-import org.opendaylight.controller.usermanager.IUserManager;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * This abstract class implements the methods defined by IResourceAuthorization
- * interface for each application class.
- */
-public abstract class Authorization<T> implements IResourceAuthorization {
-private static final Logger logger = LoggerFactory.getLogger(Authorization.class);
-    private static final String namesRegex = ConfigurationObject.getRegularExpression();
-    /*
-     * The configured resource groups
-     */
-    protected ConcurrentMap<String, Set<T>> resourceGroups;
-    /*
-     * The configured roles along with their level
-     */
-    protected ConcurrentMap<String, AppRoleLevel> roles;
-    /*
-     * The association of groups to roles
-     */
-    protected ConcurrentMap<String, Set<ResourceGroup>> groupsAuthorizations;
-    /*
-     * The name of the default group. It is the group which contains all the
-     * resources
-     */
-    protected String allResourcesGroupName;
-
-    @Override
-    public Status createRole(String role, AppRoleLevel level) {
-        if (role == null || role.trim().isEmpty()
-                || !role.matches(Authorization.namesRegex)) {
-            return new Status(StatusCode.BADREQUEST,
-                    "Role name must start with alphanumeric, no special characters.");
-        }
-        if (isControllerRole(role)) {
-            return new Status(StatusCode.NOTALLOWED,
-                    "Controller roles cannot be explicitely "
-                            + "created in App context");
-        }
-        if (isContainerRole(role)) {
-            return new Status(StatusCode.NOTALLOWED,
-                    "Container roles cannot be explicitely "
-                            + "created in App context");
-        }
-        if (isRoleInUse(role)) {
-            return new Status(StatusCode.CONFLICT, "Role already in use");
-        }
-        if (roles.containsKey(role)) {
-            if (roles.get(role).equals(level)) {
-                return new Status(StatusCode.SUCCESS, "Role is already present");
-            } else {
-                return new Status(StatusCode.BADREQUEST,
-                        "Role exists and has different level");
-            }
-        }
-
-        return createRoleInternal(role, level);
-    }
-
-    protected Status createRoleInternal(String role, AppRoleLevel level) {
-        roles.put(role, level);
-        groupsAuthorizations.put(role, new HashSet<ResourceGroup>());
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    @Override
-    public Status removeRole(String role) {
-        if (role == null || role.trim().isEmpty()) {
-            return new Status(StatusCode.BADREQUEST, "Role name can't be empty");
-        }
-        if (isControllerRole(role)) {
-            return new Status(StatusCode.NOTALLOWED,
-                    "Controller roles cannot be removed");
-        }
-        if (isContainerRole(role)) {
-            return new Status(StatusCode.NOTALLOWED,
-                    "Container roles cannot be removed");
-        }
-        return removeRoleInternal(role);
-    }
-
-    protected Status removeRoleInternal(String role) {
-        groupsAuthorizations.remove(role);
-        roles.remove(role);
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    @Override
-    public List<String> getRoles() {
-        return new ArrayList<String>(groupsAuthorizations.keySet());
-    }
-
-    @SuppressWarnings("unchecked")
-    @Override
-    public Status createResourceGroup(String groupName, List<Object> resources) {
-        //verify group name not null/empty
-        if (groupName == null || groupName.trim().isEmpty()
-                || !groupName.matches(Authorization.namesRegex)) {
-            return new Status(StatusCode.BADREQUEST, "Group name must start with alphanumeric, no special characters");
-        }
-        //verify group name is not same as all-resources
-        if (groupName.equals(this.allResourcesGroupName)) {
-            return new Status(StatusCode.NOTALLOWED, "All resource group cannot be created");
-        }
-        //verify group name is unique
-        if (resourceGroups.containsKey(groupName)) {
-            return new Status(StatusCode.CONFLICT, "Group name already exists");
-        }
-
-        //try adding resources, discard if not of type T
-        Set<T> toBeAdded = new HashSet<T>();
-        boolean allAdded = true;
-        for (Object obj : resources) {
-            try {
-                toBeAdded.add((T) obj);
-            } catch (ClassCastException e) {
-                logger.debug("Attempt to add a resource with invalid type");
-                allAdded = false;
-            }
-        }
-        resourceGroups.put(groupName, toBeAdded);
-        return (allAdded ? new Status(StatusCode.SUCCESS, "All resources added succesfully") :
-            new Status(StatusCode.SUCCESS, "One or more resources couldn't be added"));
-    }
-
-    @SuppressWarnings("unchecked")
-    @Override
-    public Status addResourceToGroup(String groupName, Object resource) {
-        if (groupName == null || groupName.trim().isEmpty()) {
-            return new Status(StatusCode.BADREQUEST, "Invalid group name");
-        }
-
-        if (resource == null) {
-            return new Status(StatusCode.BADREQUEST, "Null resource");
-        }
-
-        T castedResource = null;
-        try {
-            castedResource = (T) resource;
-        } catch (ClassCastException e) {
-            logger.debug("Attempt to add a resource with invalid type");
-            return new Status(StatusCode.BADREQUEST, "Incompatible resource");
-        }
-
-        Set<T> group = resourceGroups.get(groupName);
-        if (group == null) {
-            return new Status(StatusCode.NOTFOUND, "Group not found");
-        }
-
-        return addResourceToGroupInternal(groupName, castedResource);
-    }
-
-    /*
-     * Method child classes can overload if they need application specific
-     * checks on the resource
-     */
-    protected Status addResourceToGroupInternal(String groupName, T resource) {
-        Set<T> group = resourceGroups.get(groupName);
-        // Update group and cluster
-        group.add(resource);
-        resourceGroups.put(groupName, group);
-
-        return new Status(StatusCode.SUCCESS, "Resource added successfully");
-
-    }
-
-    private Status removeRoleResourceGroupMapping(String groupName) {
-        List<String> affectedRoles = new ArrayList<String>();
-        Status result;
-        for (Entry<String, Set<ResourceGroup>> pairs : groupsAuthorizations.entrySet()) {
-            String role = pairs.getKey();
-            Set<ResourceGroup> groups = pairs.getValue();
-            for (ResourceGroup group : groups) {
-                if (group.getGroupName().equals(groupName)) {
-                    affectedRoles.add(role);
-                    break;
-                }
-            }
-        }
-        StringBuffer msg = new StringBuffer();
-        for (String role : affectedRoles) {
-            result = unassignResourceGroupFromRole(groupName, role);
-            if (!result.isSuccess()) {
-                msg.append(result.getDescription());
-                msg.append(' ');
-            }
-        }
-
-        if (msg.length() != 0) {
-            return new Status(StatusCode.BADREQUEST, msg.toString());
-        } else {
-            return new Status(StatusCode.SUCCESS);
-        }
-    }
-
-    @Override
-    public Status removeResourceGroup(String groupName) {
-        // Default resource group cannot be deleted
-        if (groupName == null || groupName.trim().isEmpty()) {
-            return new Status(StatusCode.BADREQUEST, "Invalid group name");
-        }
-        if (groupName.equals(this.allResourcesGroupName)) {
-            return new Status(StatusCode.NOTALLOWED,
-                    "All resource group cannot be removed");
-        }
-        resourceGroups.remove(groupName);
-        Status result = removeRoleResourceGroupMapping(groupName);
-
-        return result.isSuccess() ? result :
-            new Status(StatusCode.SUCCESS, "Failed removing group from: " + result.getDescription());
-    }
-
-
-    @Override
-    public Status removeResourceFromGroup(String groupName, Object resource) {
-        if (groupName == null || groupName.trim().isEmpty()) {
-            return new Status(StatusCode.BADREQUEST, "Invalid group name");
-        }
-
-        Set<T> group = resourceGroups.get(groupName);
-        if (group != null && group.remove(resource)) {
-            // Update cluster
-            resourceGroups.put(groupName, group);
-            return new Status(StatusCode.SUCCESS, "Resource removed successfully");
-        }
-
-        return new Status(StatusCode.NOTFOUND, "Group/Resource not found");
-    }
-
-
-    /**
-     * Relay the call to user manager
-     */
-    @Override
-    public UserLevel getUserLevel(String userName) {
-        IUserManager userManager = (IUserManager) ServiceHelper
-                .getGlobalInstance(IUserManager.class, this);
-
-        if (logger.isDebugEnabled()) {
-            logger.debug("User {} has UserLevel {}", userName, userManager.getUserLevel(userName));
-        }
-
-        return (userManager == null) ? UserLevel.NOUSER : userManager
-                .getUserLevel(userName);
-    }
-
-    @Override
-    public Set<Resource> getAllResourcesforUser(String userName) {
-        Set<Resource> resources = new HashSet<Resource>();
-        IUserManager userManager = (IUserManager) ServiceHelper
-                .getGlobalInstance(IUserManager.class, this);
-        if (userManager == null) {
-            return new HashSet<Resource>(0);
-        }
-
-        // Get the roles associated with this user
-        List<String> roles = userManager.getUserRoles(userName);
-        if (roles == null) {
-            return resources;
-        }
-
-        for (String role : roles) {
-            // Get our resource groups associated with this role
-            List<ResourceGroup> groups = this.getAuthorizedGroups(role);
-            if (groups.isEmpty()) {
-                continue;
-            }
-            for (ResourceGroup group : groups) {
-                // Get the list of resources in this group
-                List<Object> list = this.getResources(group.getGroupName());
-                if (list.isEmpty()) {
-                    continue;
-                }
-                for (Object resource : list) {
-                    Resource toBeAdded = new Resource(resource,
-                            group.getPrivilege());
-                    /*
-                     * Add the resource to the set if the same resource with
-                     * higher privilege is not present. If the same resource
-                     * with lower privilege is present, remove it. No check on
-                     * same privilege resource as set guarantees no duplicates.
-                     */
-                    Resource existing = higherPrivilegeResourcePresent(
-                            resources, toBeAdded);
-                    if (existing == null) {
-                        resources.add(toBeAdded);
-                    }
-                    existing = lowerPrivilegeResourcePresent(resources,
-                            toBeAdded);
-                    if (existing != null) {
-                        resources.remove(existing);
-                    }
-                }
-            }
-        }
-
-        if (logger.isDebugEnabled()) {
-            logger.debug("User {} has resources {}", userName, resources);
-        }
-
-        return resources;
-    }
-
-    @Override
-    public List<Resource> getAuthorizedResources(String role) {
-        Set<Resource> resources = new HashSet<Resource>();
-
-        // Get our resource groups associated with this role
-        List<ResourceGroup> groups = this.getAuthorizedGroups(role);
-        if (groups.isEmpty()) {
-            return new ArrayList<Resource>(0);
-        }
-        for (ResourceGroup group : groups) {
-            // Get the list of resources in this group
-            List<Object> list = this.getResources(group.getGroupName());
-            if (list.isEmpty()) {
-                continue;
-            }
-            for (Object resource : list) {
-                Resource toBeAdded = new Resource(resource,
-                        group.getPrivilege());
-                /*
-                 * Add the resource to the set if the same resource with higher
-                 * privilege is not present. If the same resource with lower
-                 * privilege is present, remove it. No check on same privilege
-                 * resource as set guarantees no duplicates.
-                 */
-                Resource existing = higherPrivilegeResourcePresent(resources,
-                        toBeAdded);
-                if (existing == null) {
-                    resources.add(toBeAdded);
-                }
-                existing = lowerPrivilegeResourcePresent(resources, toBeAdded);
-                if (existing != null) {
-                    resources.remove(existing);
-                }
-            }
-        }
-
-        if (logger.isDebugEnabled()) {
-            logger.debug("For the Role {}, Authorized Resources are {}", role, resources);
-        }
-
-        return new ArrayList<Resource>(resources);
-    }
-
-    /**
-     * Given a set of resources and a resource to test, it returns the element
-     * in the set which represent the same resource with a lower privilege
-     * associated to it, if present.
-     *
-     * @param resources
-     * @param resource
-     * @return
-     */
-    private Resource lowerPrivilegeResourcePresent(Set<Resource> resources,
-            Resource resource) {
-
-        if (resource == null || resources == null) {
-            return null;
-        }
-
-        Object resourceElement = resource.getResource();
-        Privilege resourcePrivilege = resource.getPrivilege();
-        for (Resource element : resources) {
-            if (element.getResource().equals(resourceElement)
-                    && element.getPrivilege().ordinal() < resourcePrivilege
-                            .ordinal()) {
-                return element;
-            }
-        }
-        return null;
-    }
-
-    /**
-     * Given a set of resources and a resource to test, it returns the element
-     * in the set which represents the same resource with an higher privilege,
-     * if present.
-     *
-     * @param resources
-     * @param resource
-     * @return
-     */
-    private Resource higherPrivilegeResourcePresent(Set<Resource> resources,
-            Resource resource) {
-
-        if (resource == null || resources == null) {
-            return null;
-        }
-
-        Object resourceElement = resource.getResource();
-        Privilege resourcePrivilege = resource.getPrivilege();
-        for (Resource element : resources) {
-            if (element.getResource().equals(resourceElement)
-                    && element.getPrivilege().ordinal() > resourcePrivilege
-                            .ordinal()) {
-                return element;
-            }
-        }
-
-        return null;
-    }
-
-    @Override
-    public Privilege getResourcePrivilege(String userName, Object resource) {
-
-        if (userName == null || userName.trim().isEmpty() || resource == null) {
-            return Privilege.NONE;
-        }
-
-        Set<Resource> hisResources = getAllResourcesforUser(userName);
-        for (Resource element : hisResources) {
-            if (element.getResource().equals(resource)) {
-                return element.getPrivilege();
-            }
-        }
-
-        return Privilege.NONE;
-    }
-
-    @Override
-    public List<String> getResourceGroups() {
-        return new ArrayList<String>(resourceGroups.keySet());
-    }
-
-    @Override
-    public Status assignResourceGroupToRole(String group, Privilege privilege,
-            String role) {
-        if (group == null || group.trim().isEmpty()) {
-            return new Status(StatusCode.BADREQUEST, "Invalid group name");
-        }
-        if (role == null || role.trim().isEmpty()) {
-            return new Status(StatusCode.BADREQUEST, "Role name can't be empty");
-        }
-        if (isControllerRole(role)) {
-            return new Status(StatusCode.NOTALLOWED,
-                    "No group assignment is accepted for Controller roles");
-        }
-
-        return assignResourceGroupToRoleInternal(group, privilege, role);
-    }
-
-    protected Status assignResourceGroupToRoleInternal(String group, Privilege privilege, String role) {
-        Set<ResourceGroup> roleGroups = groupsAuthorizations.get(role);
-        roleGroups.add(new ResourceGroup(group, privilege));
-        // Update cluster
-        groupsAuthorizations.put(role, roleGroups);
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    @Override
-    public Status assignResourceGroupToRole(String groupName, String roleName) {
-        if (groupName == null || groupName.trim().isEmpty()) {
-            return new Status(StatusCode.BADREQUEST, "Group name can't be empty");
-        }
-        if (roleName == null || roleName.trim().isEmpty()) {
-            return new Status(StatusCode.BADREQUEST, "Role name can't be empty");
-        }
-        // Infer group privilege from role's level
-        Privilege privilege = Privilege.NONE;
-        switch (this.getApplicationRoleLevel(roleName)) {
-        case APPADMIN:
-            privilege = Privilege.WRITE;
-            break;
-        case APPUSER:
-            privilege = Privilege.USE;
-            break;
-        case APPOPERATOR:
-            privilege = Privilege.READ;
-            break;
-        default:
-            break;
-        }
-        return this.assignResourceGroupToRole(groupName, privilege, roleName);
-    }
-
-    @Override
-    public Status unassignResourceGroupFromRole(String group, String role) {
-        if (group == null || group.trim().isEmpty()) {
-            return new Status(StatusCode.BADREQUEST, "Group name can't be empty");
-        }
-        if (role == null || role.trim().isEmpty()) {
-            return new Status(StatusCode.BADREQUEST, "Role name can't be empty");
-        }
-        if (isControllerRole(role)) {
-            return new Status(StatusCode.NOTALLOWED,
-                    "No group assignment change is allowed for "
-                            + "Controller roles");
-        }
-
-        return unassignResourceGroupFromRoleInternal(group, role);
-    }
-
-    protected Status unassignResourceGroupFromRoleInternal(String group, String role) {
-        ResourceGroup target = null;
-        for (ResourceGroup rGroup : groupsAuthorizations.get(role)) {
-            if (rGroup.getGroupName().equals(group)) {
-                target = rGroup;
-                break;
-            }
-        }
-        if (target == null) {
-            return new Status(StatusCode.SUCCESS, "Group " + group + " was not assigned to " + role);
-        } else {
-            Set<ResourceGroup> groups = groupsAuthorizations.get(role);
-            groups.remove(target);
-            // Update cluster
-            groupsAuthorizations.put(role, groups);
-            return new Status(StatusCode.SUCCESS);
-
-        }
-    }
-
-    @Override
-    public List<ResourceGroup> getAuthorizedGroups(String role) {
-        return (groupsAuthorizations.containsKey(role)) ? new ArrayList<ResourceGroup>(
-                groupsAuthorizations.get(role))
-                : new ArrayList<ResourceGroup>();
-    }
-
-    @Override
-    public List<Object> getResources(String groupName) {
-        return (resourceGroups.containsKey(groupName)) ? new ArrayList<Object>(
-                resourceGroups.get(groupName)) : new ArrayList<Object>(0);
-    }
-
-    @Override
-    public boolean isApplicationRole(String roleName) {
-        if (roleName == null) {
-            return false;
-        }
-        return roles.containsKey(roleName);
-    }
-
-    @Override
-    public boolean isApplicationUser(String userName) {
-        IUserManager userManager = (IUserManager) ServiceHelper
-                .getGlobalInstance(IUserManager.class, this);
-        if (userManager == null) {
-            return false;
-        }
-        List<String> roles = userManager.getUserRoles(userName);
-        if (roles != null && !roles.isEmpty()) {
-            for (String role : roles) {
-                if (isApplicationRole(role)) {
-                    return true;
-                }
-            }
-        }
-        return false;
-    }
-
-    @Override
-    public AppRoleLevel getApplicationRoleLevel(String roleName) {
-        if (roleName == null || roleName.trim().isEmpty()) {
-            return AppRoleLevel.NOUSER;
-        }
-
-        if (isControllerRole(roleName)) {
-            if (roleName.equals(UserLevel.NETWORKADMIN.toString()) ||
-                    roleName.equals(UserLevel.SYSTEMADMIN.toString())) {
-                return AppRoleLevel.APPADMIN;
-            } else {
-                return AppRoleLevel.APPOPERATOR;
-            }
-        }
-
-        return (roles.containsKey(roleName)) ? roles.get(roleName)
-                : AppRoleLevel.NOUSER;
-    }
-
-    @Override
-    public AppRoleLevel getUserApplicationLevel(String userName) {
-        List<String> roles = null;
-        IUserManager userManager = (IUserManager) ServiceHelper
-                .getGlobalInstance(IUserManager.class, this);
-
-        if (userName == null || userName.trim().isEmpty()
-                || (userManager == null)
-                || (roles = userManager.getUserRoles(userName)).isEmpty()) {
-            return AppRoleLevel.NOUSER;
-        }
-        AppRoleLevel highestLevel = AppRoleLevel.NOUSER;
-        for (String role : roles) {
-            AppRoleLevel level = getApplicationRoleLevel(role);
-            if (level.ordinal() < highestLevel.ordinal()) {
-                highestLevel = level;
-            }
-        }
-        return highestLevel;
-    }
-
-    /**
-     * Returns the highest role the specified user has in this application
-     * context
-     *
-     * @param user
-     *            The user name
-     * @return The highest role associated to the user in this application
-     *         context
-     */
-    public String getHighestUserRole(String user) {
-        IUserManager userManager = (IUserManager) ServiceHelper.getGlobalInstance(IUserManager.class, this);
-        String highestRole = "";
-        if (userManager != null && !userManager.getUserRoles(user).isEmpty()) {
-            List<String> roles = userManager.getUserRoles(user);
-            AppRoleLevel highestLevel = AppRoleLevel.NOUSER;
-            for (String role : roles) {
-                AppRoleLevel current;
-                if (isApplicationRole(role)
-                        && (current = getApplicationRoleLevel(role)).ordinal() < highestLevel.ordinal()) {
-                    highestRole = role;
-                    highestLevel = current;
-                }
-            }
-        }
-        return highestRole;
-    }
-
-    private boolean isControllerRole(String role) {
-        return (role.equals(UserLevel.NETWORKADMIN.toString())
-                || role.equals(UserLevel.SYSTEMADMIN.toString()) || role
-                    .equals(UserLevel.NETWORKOPERATOR.toString()));
-    }
-
-    private boolean isContainerRole(String role) {
-        IContainerAuthorization containerAuth = (IContainerAuthorization) ServiceHelper.getGlobalInstance(
-                IContainerAuthorization.class, this);
-        if (containerAuth == null) {
-            return false;
-        }
-        return containerAuth.isApplicationRole(role);
-    }
-
-    private boolean isRoleInUse(String role) {
-        IUserManager userManager = (IUserManager) ServiceHelper
-                .getGlobalInstance(IUserManager.class, this);
-
-        if (userManager == null) {
-            return true;
-        }
-        return userManager.isRoleInUse(role);
-    }
-}
diff --git a/opendaylight/adsal/arphandler/pom.xml b/opendaylight/adsal/arphandler/pom.xml
deleted file mode 100644 (file)
index 34cecaf..0000000
+++ /dev/null
@@ -1,85 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../commons/opendaylight</relativePath>
-  </parent>
-  <artifactId>arphandler</artifactId>
-  <version>0.7.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>clustering.services</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>connectionmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>hosttracker</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal.connection</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>switchmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>topologymanager</artifactId>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Import-Package>org.opendaylight.controller.sal.packet.address,
-              org.opendaylight.controller.connectionmanager,
-              org.opendaylight.controller.sal.connection,
-              org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.sal.utils,
-              org.opendaylight.controller.sal.packet,
-              org.opendaylight.controller.sal.routing,
-              org.opendaylight.controller.switchmanager,
-              org.opendaylight.controller.topologymanager,
-              org.opendaylight.controller.clustering.services,
-              org.opendaylight.controller.hosttracker,
-              org.opendaylight.controller.hosttracker.hostAware,
-              org.apache.felix.dm,
-              org.osgi.service.component,
-              org.slf4j</Import-Package>
-            <Export-Package>org.opendaylight.controller.arphandler</Export-Package>
-            <Bundle-Activator>org.opendaylight.controller.arphandler.internal.Activator</Bundle-Activator>
-          </instructions>
-          <manifestLocation>${project.basedir}/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/arphandler/src/main/java/org/opendaylight/controller/arphandler/ARPCacheEvent.java b/opendaylight/adsal/arphandler/src/main/java/org/opendaylight/controller/arphandler/ARPCacheEvent.java
deleted file mode 100644 (file)
index e7b342f..0000000
+++ /dev/null
@@ -1,62 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.arphandler;
-
-public class ARPCacheEvent {
-    private ARPEvent event;
-    private boolean newReply;
-
-    public ARPCacheEvent(ARPEvent event, boolean newReply) {
-        super();
-        this.event = event;
-        this.newReply = newReply;
-    }
-
-    public ARPEvent getEvent() {
-        return event;
-    }
-
-    public boolean isNewReply() {
-        return newReply;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + ((event == null) ? 0 : event.hashCode());
-        result = prime * result + (newReply ? 1231 : 1237);
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj)
-            return true;
-        if (obj == null)
-            return false;
-        if (getClass() != obj.getClass())
-            return false;
-        ARPCacheEvent other = (ARPCacheEvent) obj;
-        if (event == null) {
-            if (other.event != null)
-                return false;
-        } else if (!event.equals(other.event))
-            return false;
-        if (newReply != other.newReply)
-            return false;
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        return "ARPCacheEvent [event=" + event + ", newReply=" + newReply + "]";
-    }
-}
diff --git a/opendaylight/adsal/arphandler/src/main/java/org/opendaylight/controller/arphandler/ARPEvent.java b/opendaylight/adsal/arphandler/src/main/java/org/opendaylight/controller/arphandler/ARPEvent.java
deleted file mode 100644 (file)
index f676a79..0000000
+++ /dev/null
@@ -1,76 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.arphandler;
-
-import java.io.Serializable;
-import java.net.InetAddress;
-/*
- * ARP Event base class
- */
-public abstract class ARPEvent implements Serializable{
-
-    private static final long serialVersionUID = 1L;
-    private final InetAddress tIP;
-
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = prime + ((tIP == null) ? 0 : tIP.hashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (!(obj instanceof ARPEvent)) {
-            return false;
-        }
-        ARPEvent other = (ARPEvent) obj;
-        if (tIP == null) {
-            if (other.tIP != null) {
-                return false;
-            }
-        } else if (!tIP.equals(other.tIP)) {
-            return false;
-        }
-        return true;
-    }
-
-    public ARPEvent(InetAddress ip) {
-        this.tIP = ip;
-    }
-
-    public InetAddress getTargetIP() {
-        return tIP;
-    }
-
-    /*
-     * (non-Javadoc)
-     *
-     * @see java.lang.Object#toString()
-     */
-    @Override
-    public String toString() {
-        StringBuilder builder = new StringBuilder();
-        builder.append("ARPEvent [");
-        if (tIP != null) {
-            builder.append("tIP=")
-                    .append(tIP);
-        }
-        builder.append("]");
-        return builder.toString();
-    }
-}
diff --git a/opendaylight/adsal/arphandler/src/main/java/org/opendaylight/controller/arphandler/ARPReply.java b/opendaylight/adsal/arphandler/src/main/java/org/opendaylight/controller/arphandler/ARPReply.java
deleted file mode 100644 (file)
index 1a446b8..0000000
+++ /dev/null
@@ -1,151 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.arphandler;
-
-import java.net.InetAddress;
-import java.util.Arrays;
-
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.utils.HexEncode;
-/*
- * ARP Reply event wrapper
- */
-public class ARPReply extends ARPEvent {
-    private static final long serialVersionUID = 1L;
-    private final NodeConnector port;
-    private final byte[] tMac;
-    private final byte[] sMac;
-    private final InetAddress sIP;
-    private final short vlan;
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = super.hashCode();
-        result = prime * result + ((port == null) ? 0 : port.hashCode());
-        result = prime * result + ((sIP == null) ? 0 : sIP.hashCode());
-        result = prime * result + Arrays.hashCode(sMac);
-        result = prime * result + Arrays.hashCode(tMac);
-        result = prime * result + vlan;
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (!super.equals(obj)) {
-            return false;
-        }
-        if (!(obj instanceof ARPReply)) {
-            return false;
-        }
-        ARPReply other = (ARPReply) obj;
-        if (port == null) {
-            if (other.port != null) {
-                return false;
-            }
-        } else if (!port.equals(other.port)) {
-            return false;
-        }
-        if (sIP == null) {
-            if (other.sIP != null) {
-                return false;
-            }
-        } else if (!sIP.equals(other.sIP)) {
-            return false;
-        }
-        if (!Arrays.equals(sMac, other.sMac)) {
-            return false;
-        }
-        if (!Arrays.equals(tMac, other.tMac)) {
-            return false;
-        }
-        if (vlan != other.vlan) {
-            return false;
-        }
-        return true;
-    }
-
-    public ARPReply(NodeConnector port, InetAddress sIP, byte[] sMAC, InetAddress tIP, byte[] tMAC, short vlan) {
-        super(tIP);
-        this.tMac = tMAC;
-        this.sIP = sIP;
-        this.sMac = sMAC;
-        this.port = port;
-        this.vlan = vlan;
-    }
-
-    public ARPReply(InetAddress tIP, byte[] tMAC, short vlan) {
-        super(tIP);
-        this.tMac = tMAC;
-        this.sIP = null;
-        this.sMac = null;
-        this.port = null;
-        this.vlan = vlan;
-    }
-
-    public byte[] getTargetMac() {
-        return tMac;
-    }
-
-    public byte[] getSourceMac() {
-        return sMac;
-    }
-
-    public InetAddress getSourceIP() {
-        return sIP;
-    }
-
-    public NodeConnector getPort() {
-        return port;
-    }
-
-    public short getVlan() {
-        return vlan;
-    }
-
-    /*
-     * (non-Javadoc)
-     *
-     * @see java.lang.Object#toString()
-     */
-    @Override
-    public String toString() {
-        StringBuilder builder = new StringBuilder();
-        builder.append("ARPReply [");
-        if (port != null) {
-            builder.append("port=")
-                    .append(port)
-                    .append(", ");
-        }
-        if (tMac != null) {
-            builder.append("tMac=")
-                    .append(HexEncode.bytesToHexString(tMac))
-                    .append(", ");
-        }
-        if (sMac != null) {
-            builder.append("sMac=")
-                    .append(HexEncode.bytesToHexString(sMac))
-                    .append(", ");
-        }
-        if (sIP != null) {
-            builder.append("sIP=")
-                    .append(sIP);
-        }
-        if (vlan != 0) {
-            builder.append(", vlan=")
-            .append(vlan);
-        }
-        builder.append("]");
-        return builder.toString();
-    }
-}
diff --git a/opendaylight/adsal/arphandler/src/main/java/org/opendaylight/controller/arphandler/ARPRequest.java b/opendaylight/adsal/arphandler/src/main/java/org/opendaylight/controller/arphandler/ARPRequest.java
deleted file mode 100644 (file)
index 051635a..0000000
+++ /dev/null
@@ -1,107 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.arphandler;
-
-import java.net.InetAddress;
-
-import org.opendaylight.controller.hosttracker.hostAware.HostNodeConnector;
-import org.opendaylight.controller.switchmanager.Subnet;
-/*
- * ARP Request event wrapper Consists of IP and Subnet (and a
- * HostNodeConnector if is unicast) For unicast request, construct with a
- * specified host
- */
-public class ARPRequest extends ARPEvent {
-    private static final long serialVersionUID = 1L;
-    private final Subnet subnet;
-    private final HostNodeConnector host;
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = super.hashCode();
-        result = prime * result + ((host == null) ? 0 : host.hashCode());
-        result = prime * result + ((subnet == null) ? 0 : subnet.hashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (!(obj instanceof ARPRequest)) {
-            return false;
-        }
-        ARPRequest other = (ARPRequest) obj;
-        if (host == null) {
-            if (other.host != null) {
-                return false;
-            }
-        } else if (!host.equals(other.host)) {
-            return false;
-        }
-        if (subnet == null) {
-            if (other.subnet != null) {
-                return false;
-            }
-        } else if (!subnet.equals(other.subnet)) {
-            return false;
-        }
-        return true;
-    }
-
-    // broadcast
-    public ARPRequest(InetAddress ip, Subnet subnet) {
-        super(ip);
-        this.subnet = subnet;
-        this.host = null;
-    }
-
-    // unicast
-    public ARPRequest(HostNodeConnector host, Subnet subnet) {
-        super(host.getNetworkAddress());
-        this.host = host;
-        this.subnet = subnet;
-    }
-
-    public Subnet getSubnet() {
-        return subnet;
-    }
-
-    public HostNodeConnector getHost() {
-        return host;
-    }
-
-    /*
-     * (non-Javadoc)
-     *
-     * @see java.lang.Object#toString()
-     */
-    @Override
-    public String toString() {
-        StringBuilder builder = new StringBuilder();
-        builder.append("ARPRequest [");
-        if (subnet != null) {
-            builder.append("subnet=")
-                    .append(subnet)
-                    .append(", ");
-        }
-        if (host != null) {
-            builder.append("host=")
-                    .append(host);
-        }
-        builder.append("]");
-        return builder.toString();
-    }
-}
diff --git a/opendaylight/adsal/arphandler/src/main/java/org/opendaylight/controller/arphandler/internal/Activator.java b/opendaylight/adsal/arphandler/src/main/java/org/opendaylight/controller/arphandler/internal/Activator.java
deleted file mode 100644 (file)
index b7639be..0000000
+++ /dev/null
@@ -1,115 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.arphandler.internal;
-
-import java.util.Dictionary;
-import java.util.HashSet;
-import java.util.Hashtable;
-import java.util.Set;
-
-import org.apache.felix.dm.Component;
-import org.opendaylight.controller.clustering.services.ICacheUpdateAware;
-import org.opendaylight.controller.clustering.services.IClusterContainerServices;
-import org.opendaylight.controller.connectionmanager.IConnectionManager;
-import org.opendaylight.controller.hosttracker.IfHostListener;
-import org.opendaylight.controller.hosttracker.IfIptoHost;
-import org.opendaylight.controller.hosttracker.hostAware.IHostFinder;
-import org.opendaylight.controller.sal.core.ComponentActivatorAbstractBase;
-import org.opendaylight.controller.sal.packet.IDataPacketService;
-import org.opendaylight.controller.sal.packet.IListenDataPacket;
-import org.opendaylight.controller.switchmanager.ISwitchManager;
-import org.opendaylight.controller.topologymanager.ITopologyManager;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-public class Activator extends ComponentActivatorAbstractBase {
-    protected static final Logger logger = LoggerFactory
-            .getLogger(Activator.class);
-
-
-    /**
-     * Function that is used to communicate to dependency manager the
-     * list of known implementations for services inside a container
-     *
-     *
-     * @return An array containing all the CLASS objects that will be
-     * instantiated in order to get an fully working implementation
-     * Object
-     */
-    @Override
-    public Object[] getImplementations() {
-        Object[] res = { ArpHandler.class };
-        return res;
-    }
-
-    /**
-     * Function that is called when configuration of the dependencies
-     * is required.
-     *
-     * @param c dependency manager Component object, used for
-     * configuring the dependencies exported and imported
-     * @param imp Implementation class that is being configured,
-     * needed as long as the same routine can configure multiple
-     * implementations
-     * @param containerName The containerName being configured, this allow
-     * also optional per-container different behavior if needed, usually
-     * should not be the case though.
-     */
-    @Override
-    public void configureInstance(Component c, Object imp, String containerName) {
-        if (imp.equals(ArpHandler.class)) {
-            // export the service
-            Dictionary<String, Object> props = new Hashtable<String, Object>();
-            props.put("salListenerName", "arphandler");
-            Set<String> propSet = new HashSet<String>();
-            propSet.add(ArpHandler.ARP_EVENT_CACHE_NAME);
-            props.put("cachenames", propSet);
-
-            c.setInterface(new String[] {
-                    IHostFinder.class.getName(),
-                    IListenDataPacket.class.getName(),
-                    ICacheUpdateAware.class.getName()}, props);
-
-            // We need connection mgr to distribute packet out across the cluster
-            c.add(createServiceDependency().setService(
-                    IConnectionManager.class).setCallbacks("setConnectionManager",
-                    "unsetConnectionManager").setRequired(true));
-
-
-            c.add(createContainerServiceDependency(containerName).setService(
-                    ISwitchManager.class).setCallbacks("setSwitchManager",
-                    "unsetSwitchManager").setRequired(true));
-
-            c.add(createContainerServiceDependency(containerName).setService(
-                    ITopologyManager.class).setCallbacks("setTopologyManager",
-                    "unsetTopologyMananger").setRequired(true));
-
-            c.add(createContainerServiceDependency(containerName).setService(
-                    IDataPacketService.class).setCallbacks(
-                    "setDataPacketService", "unsetDataPacketService")
-                    .setRequired(true));
-
-            c.add(createContainerServiceDependency(containerName).setService(
-                   IClusterContainerServices.class).setCallbacks(
-                   "setClusterContainerService", "unsetClusterContainerService")
-                   .setRequired(true));
-
-            // the Host Listener is optional
-            c.add(createContainerServiceDependency(containerName).setService(
-                    IfHostListener.class).setCallbacks("setHostListener",
-                    "unsetHostListener").setRequired(false));
-
-            // the IfIptoHost is a required dependency
-            c.add(createContainerServiceDependency(containerName).setService(
-                    IfIptoHost.class).setCallbacks("setHostTracker",
-                    "unsetHostTracker").setRequired(true));
-        }
-    }
-}
diff --git a/opendaylight/adsal/arphandler/src/main/java/org/opendaylight/controller/arphandler/internal/ArpHandler.java b/opendaylight/adsal/arphandler/src/main/java/org/opendaylight/controller/arphandler/internal/ArpHandler.java
deleted file mode 100644 (file)
index 4efcada..0000000
+++ /dev/null
@@ -1,855 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/*
- *
- */
-package org.opendaylight.controller.arphandler.internal;
-
-import java.net.InetAddress;
-import java.net.UnknownHostException;
-import java.util.Arrays;
-import java.util.Collections;
-import java.util.EnumSet;
-import java.util.HashSet;
-import java.util.Set;
-import java.util.Timer;
-import java.util.TimerTask;
-import java.util.concurrent.BlockingQueue;
-import java.util.concurrent.ConcurrentHashMap;
-import java.util.concurrent.ConcurrentMap;
-import java.util.concurrent.CopyOnWriteArraySet;
-import java.util.concurrent.LinkedBlockingQueue;
-
-import org.opendaylight.controller.arphandler.ARPCacheEvent;
-import org.opendaylight.controller.arphandler.ARPEvent;
-import org.opendaylight.controller.arphandler.ARPReply;
-import org.opendaylight.controller.arphandler.ARPRequest;
-import org.opendaylight.controller.clustering.services.CacheConfigException;
-import org.opendaylight.controller.clustering.services.CacheExistException;
-import org.opendaylight.controller.clustering.services.ICacheUpdateAware;
-import org.opendaylight.controller.clustering.services.IClusterContainerServices;
-import org.opendaylight.controller.clustering.services.IClusterServices;
-import org.opendaylight.controller.connectionmanager.IConnectionManager;
-import org.opendaylight.controller.hosttracker.HostIdFactory;
-import org.opendaylight.controller.hosttracker.IHostId;
-import org.opendaylight.controller.hosttracker.IfHostListener;
-import org.opendaylight.controller.hosttracker.IfIptoHost;
-import org.opendaylight.controller.hosttracker.hostAware.HostNodeConnector;
-import org.opendaylight.controller.hosttracker.hostAware.IHostFinder;
-import org.opendaylight.controller.sal.connection.ConnectionLocality;
-import org.opendaylight.controller.sal.core.ConstructionException;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.packet.ARP;
-import org.opendaylight.controller.sal.packet.Ethernet;
-import org.opendaylight.controller.sal.packet.IDataPacketService;
-import org.opendaylight.controller.sal.packet.IEEE8021Q;
-import org.opendaylight.controller.sal.packet.IListenDataPacket;
-import org.opendaylight.controller.sal.packet.IPv4;
-import org.opendaylight.controller.sal.packet.Packet;
-import org.opendaylight.controller.sal.packet.PacketResult;
-import org.opendaylight.controller.sal.packet.RawPacket;
-import org.opendaylight.controller.sal.utils.EtherTypes;
-import org.opendaylight.controller.sal.utils.HexEncode;
-import org.opendaylight.controller.sal.utils.NetUtils;
-import org.opendaylight.controller.switchmanager.ISwitchManager;
-import org.opendaylight.controller.switchmanager.Subnet;
-import org.opendaylight.controller.topologymanager.ITopologyManager;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * The ArpHandler offers services to react on ARP requests and replies
- * sent by network hosts. Moreover it allows for creating ARP messages
- * by the controller itself.
- *
- * The ARP Handler on ODL doesn't use the requester MAC address in
- * order to avoid to have to build a spanning tree where to forward
- * ARP Requests. The ARP requests are broadcast packets so in order to
- * reach everywhere need to be flooded, when you flood in a network
- * that is not a tree (all the networks has some level of redundancy)
- * that would create forwarding loops without a spanning tree. Given
- * the need is only to send out the ARP requests toward all the hosts
- * we actually don't need to implement a flooding mechanism in software
- * (which would be expensive) we just send out the ARP request toward
- * all the ports that are suspected to be host ports on all the
- * switches (from the controller). Now the condition for which a port
- * is marked as host port could potentially be incorrect so when the
- * controller sends out the ARP Request that could come back to the
- * controller and could cause another request not needed. So changing
- * the source MAC address of the request to be the one of the controller,
- * controller can protect itself from honoring twice the same request.
- * This enables an ARP handler resolution, without the need of spanning
- * tree and limiting software flooding to the minimum required.
- */
-
-public class ArpHandler implements IHostFinder, IListenDataPacket, ICacheUpdateAware<ARPEvent, Boolean> {
-    private static final Logger log = LoggerFactory.getLogger(ArpHandler.class);
-    static final String ARP_EVENT_CACHE_NAME = "arphandler.arpRequestReplyEvent";
-    private IfIptoHost hostTracker;
-    private ISwitchManager switchManager;
-    private ITopologyManager topologyManager;
-    private IDataPacketService dataPacketService;
-    private IClusterContainerServices clusterContainerService;
-    private IConnectionManager connectionManager;
-    private Set<IfHostListener> hostListeners = new CopyOnWriteArraySet<IfHostListener>();
-    private ConcurrentMap<InetAddress, Set<HostNodeConnector>> arpRequestors;
-    private ConcurrentMap<InetAddress, Short> countDownTimers;
-    private Timer periodicTimer;
-    private BlockingQueue<ARPCacheEvent> ARPCacheEvents = new LinkedBlockingQueue<ARPCacheEvent>();
-    private Thread cacheEventHandler;
-    private boolean stopping = false;
-
-    /*
-     * A cluster allocated cache. Used for synchronizing ARP request/reply
-     * events across all cluster controllers. To raise an event, we put() a
-     * specific event object (as key) and all nodes handle it in the
-     * entryUpdated callback.
-     *
-     * In case of ARPReply, we put true value to send replies to any requestors
-     * by calling generateAndSendReply
-     */
-    private ConcurrentMap<ARPEvent, Boolean> arpRequestReplyEvent;
-
-    void setConnectionManager(IConnectionManager cm) {
-        this.connectionManager = cm;
-    }
-
-    void unsetConnectionManager(IConnectionManager cm) {
-        if (this.connectionManager == cm) {
-            connectionManager = null;
-        }
-    }
-
-    void setClusterContainerService(IClusterContainerServices s) {
-        this.clusterContainerService = s;
-    }
-
-    void unsetClusterContainerService(IClusterContainerServices s) {
-        if (this.clusterContainerService == s) {
-            this.clusterContainerService = null;
-        }
-    }
-
-    void setHostListener(IfHostListener s) {
-        if (this.hostListeners != null) {
-            this.hostListeners.add(s);
-        }
-    }
-
-    void unsetHostListener(IfHostListener s) {
-        if (this.hostListeners != null) {
-            this.hostListeners.remove(s);
-        }
-    }
-
-    void setDataPacketService(IDataPacketService s) {
-        this.dataPacketService = s;
-    }
-
-    void unsetDataPacketService(IDataPacketService s) {
-        if (this.dataPacketService == s) {
-            this.dataPacketService = null;
-        }
-    }
-
-    public void setHostTracker(IfIptoHost hostTracker) {
-        log.debug("Setting HostTracker");
-        this.hostTracker = hostTracker;
-    }
-
-    public void unsetHostTracker(IfIptoHost s) {
-        log.debug("UNSetting HostTracker");
-        if (this.hostTracker == s) {
-            this.hostTracker = null;
-        }
-    }
-
-    public void setTopologyManager(ITopologyManager tm) {
-        this.topologyManager = tm;
-    }
-
-    public void unsetTopologyManager(ITopologyManager tm) {
-        if (this.topologyManager == tm) {
-            this.topologyManager = null;
-        }
-    }
-
-    protected void sendARPReply(NodeConnector p, byte[] sMAC, InetAddress sIP, byte[] tMAC, InetAddress tIP, short vlan) {
-        byte[] senderIP = sIP.getAddress();
-        byte[] targetIP = tIP.getAddress();
-        ARP arp = createARP(ARP.REPLY, sMAC, senderIP, tMAC, targetIP);
-
-        if(log.isTraceEnabled()) {
-            log.trace("Sending Arp Reply with srcMac {} - srcIp {} - dstMac {} - dstIp {} - outport {}",
-                    HexEncode.bytesToHexString(sMAC),
-                    sIP, HexEncode.bytesToHexString(tMAC), tIP, p);
-        }
-
-        Ethernet ethernet = createEthernet(sMAC, tMAC, arp, vlan);
-
-        RawPacket destPkt = this.dataPacketService.encodeDataPacket(ethernet);
-        destPkt.setOutgoingNodeConnector(p);
-
-        this.dataPacketService.transmitDataPacket(destPkt);
-    }
-
-    private void logArpPacket(ARP pkt, NodeConnector p, short vlan) {
-        try {
-            log.trace("Received Arp {} with srcMac {} - srcIp {} - dstMac {} - dstIp {} - inport {} {}",
-                    ((pkt.getOpCode() == ARP.REQUEST) ? "Request" : "Reply"),
-                    HexEncode.bytesToHexString(pkt.getSenderHardwareAddress()),
-                    InetAddress.getByAddress(pkt.getSenderProtocolAddress()),
-                    HexEncode.bytesToHexString(pkt.getTargetHardwareAddress()),
-                    InetAddress.getByAddress(pkt.getTargetProtocolAddress()), p, (vlan != 0 ? "on vlan " + vlan : ""));
-
-        } catch (UnknownHostException e) {
-            log.warn("Illegal Ip Address in the ARP packet", e);
-        }
-    }
-
-    protected void handleARPPacket(Ethernet eHeader, ARP pkt, NodeConnector p, short vlan) {
-
-        if(log.isTraceEnabled()) {
-            logArpPacket(pkt, p, vlan);
-        }
-
-        byte[] sourceMAC = eHeader.getSourceMACAddress();
-        byte[] targetMAC = eHeader.getDestinationMACAddress();
-        /*
-         * Sanity Check; drop ARP packets originated by the controller itself.
-         * This is to avoid continuous flooding
-         */
-        if (Arrays.equals(sourceMAC, getControllerMAC())) {
-            if (log.isDebugEnabled()) {
-                log.debug("Receive a self originated ARP pkt (srcMAC {}) --> DROP",
-                        HexEncode.bytesToHexString(sourceMAC));
-            }
-            return;
-        }
-
-        InetAddress targetIP, sourceIP;
-        try {
-            targetIP = InetAddress.getByAddress(pkt.getTargetProtocolAddress());
-            sourceIP = InetAddress.getByAddress(pkt.getSenderProtocolAddress());
-        } catch (UnknownHostException e1) {
-            log.debug("Invalid host in ARP packet: {}", e1.getMessage());
-            return;
-        }
-
-        Subnet subnet = null;
-        if (switchManager != null) {
-            subnet = switchManager.getSubnetByNetworkAddress(sourceIP);
-        }
-        if (subnet == null) {
-            log.debug("ARPHandler: can't find subnet matching {}, drop packet", sourceIP);
-            return;
-        }
-
-        // Make sure that the host is a legitimate member of this subnet
-        if (!subnet.hasNodeConnector(p)) {
-            log.debug("{} showing up on {} does not belong to {}", new Object[] { sourceIP, p, subnet });
-            return;
-        }
-
-        HostNodeConnector requestor = null;
-        if (NetUtils.isUnicastMACAddr(sourceMAC) && p.getNode() != null) {
-            try {
-                requestor = new HostNodeConnector(sourceMAC, sourceIP, p, vlan);
-            } catch (ConstructionException e) {
-                log.debug("Received ARP packet with invalid MAC: {}", HexEncode.bytesToHexString(sourceMAC));
-                return;
-            }
-            /*
-             * Learn host from the received ARP REQ/REPLY, inform Host Tracker
-             */
-            log.trace("Inform Host tracker of new host {}", requestor.getNetworkAddress());
-            for (IfHostListener listener : this.hostListeners) {
-                listener.hostListener(requestor);
-            }
-        }
-
-        /*
-         * OpCode != request -> ARP Reply. If there are hosts (in arpRequestors)
-         * waiting for the ARP reply for this sourceIP, it's time to generate
-         * the reply and send it to these hosts.
-         *
-         * If sourceIP==targetIP, it is a Gratuitous ARP. If there are hosts (in
-         * arpRequestors) waiting for the ARP reply for this sourceIP, it's time
-         * to generate the reply and send it to these hosts
-         */
-
-        if (pkt.getOpCode() != ARP.REQUEST || sourceIP.equals(targetIP)) {
-            // Raise a reply event so that any waiting requestors will be sent a
-            // reply
-            // the true value indicates we should generate replies to requestors
-            // across the cluster
-            log.trace("Received ARP reply packet from {}, reply to all requestors.", sourceIP);
-            arpRequestReplyEvent.put(new ARPReply(sourceIP, sourceMAC, vlan), true);
-            return;
-        }
-
-        /*
-         * ARP Request Handling: If targetIP is the IP of the subnet, reply with
-         * ARP REPLY If targetIP is a known host, PROXY ARP (by sending ARP
-         * REPLY) on behalf of known target hosts. For unknown target hosts,
-         * generate and send an ARP request to ALL switches/ports using the IP
-         * address defined in the subnet as source address
-         */
-        /*
-         * If target IP is gateway IP, Send ARP reply
-         */
-        if ((targetIP.equals(subnet.getNetworkAddress()))
-                && (NetUtils.isBroadcastMACAddr(targetMAC) || Arrays.equals(targetMAC, getControllerMAC()))) {
-            if (connectionManager.getLocalityStatus(p.getNode()) == ConnectionLocality.LOCAL) {
-                if (log.isTraceEnabled()) {
-                    log.trace("Received local ARP req. for default gateway. Replying with controller MAC: {}",
-                            HexEncode.bytesToHexString(getControllerMAC()));
-                }
-                sendARPReply(p, getControllerMAC(), targetIP, pkt.getSenderHardwareAddress(), sourceIP, vlan);
-            } else {
-                log.trace("Received non-local ARP req. for default gateway. Raising reply event");
-                arpRequestReplyEvent.put(
-                        new ARPReply(p, targetIP, getControllerMAC(), sourceIP, pkt.getSenderHardwareAddress(), vlan), false);
-            }
-            return;
-        }
-
-        // Hosttracker hosts db key implementation
-        IHostId id = HostIdFactory.create(targetIP, null);
-        HostNodeConnector host = hostTracker.hostQuery(id);
-        // unknown host, initiate ARP request
-        if (host == null) {
-            // add the requestor to the list so that we can replay the reply
-            // when the host responds
-            if (requestor != null) {
-                Set<HostNodeConnector> requestorSet = arpRequestors.get(targetIP);
-                if (requestorSet == null) {
-                    requestorSet = Collections.newSetFromMap(new ConcurrentHashMap<HostNodeConnector, Boolean>());
-                    arpRequestors.put(targetIP, requestorSet);
-                }
-                requestorSet.add(requestor);
-                countDownTimers.put(targetIP, (short) 2); // reset timeout to
-                                                          // 2sec
-            }
-            // Raise a bcast request event, all controllers need to send one
-            log.trace("Sending a bcast ARP request for {}", targetIP);
-            arpRequestReplyEvent.put(new ARPRequest(targetIP, subnet), false);
-        } else {
-            /*
-             * Target host known (across the cluster), send ARP REPLY make sure
-             * that targetMAC matches the host's MAC if it is not broadcastMAC
-             */
-            if (NetUtils.isBroadcastMACAddr(targetMAC) || Arrays.equals(host.getDataLayerAddressBytes(), targetMAC)) {
-                log.trace("Received ARP req. for known host {}, sending reply...", targetIP);
-                if (connectionManager.getLocalityStatus(p.getNode()) == ConnectionLocality.LOCAL) {
-                    sendARPReply(p, host.getDataLayerAddressBytes(), host.getNetworkAddress(),
-                            pkt.getSenderHardwareAddress(), sourceIP, vlan);
-                } else {
-                    arpRequestReplyEvent.put(new ARPReply(p, host.getNetworkAddress(), host.getDataLayerAddressBytes(),
-                            sourceIP, pkt.getSenderHardwareAddress(), vlan), false);
-                }
-            } else {
-                /*
-                 * Target MAC has been changed. For now, discard it. TODO: We
-                 * may need to send unicast ARP REQUEST on behalf of the target
-                 * back to the sender to trigger the sender to update its table
-                 */
-            }
-        }
-    }
-
-    /**
-     * Send a broadcast ARP Request to the switch/ ports using the
-     * networkAddress of the subnet as sender IP the controller's MAC as sender
-     * MAC the targetIP as the target Network Address
-     */
-    protected void sendBcastARPRequest(InetAddress targetIP, Subnet subnet) {
-        log.trace("sendBcatARPRequest targetIP:{} subnet:{}", targetIP, subnet);
-        Set<NodeConnector> nodeConnectors;
-        if (subnet.isFlatLayer2()) {
-            nodeConnectors = new HashSet<NodeConnector>();
-            for (Node n : this.switchManager.getNodes()) {
-                nodeConnectors.addAll(this.switchManager.getUpNodeConnectors(n));
-            }
-        } else {
-            nodeConnectors = subnet.getNodeConnectors();
-        }
-        byte[] targetHardwareAddress = new byte[] { (byte) 0, (byte) 0, (byte) 0, (byte) 0, (byte) 0, (byte) 0 };
-
-        // TODO: should use IBroadcastHandler instead
-        for (NodeConnector p : nodeConnectors) {
-            // filter out any non-local or internal ports
-            if (!(connectionManager.getLocalityStatus(p.getNode()) == ConnectionLocality.LOCAL)
-                    || topologyManager.isInternal(p)) {
-                continue;
-            }
-            log.trace("Sending toward nodeConnector:{}", p);
-            byte[] senderIP = subnet.getNetworkAddress().getAddress();
-            byte[] targetIPByte = targetIP.getAddress();
-            ARP arp = createARP(ARP.REQUEST, getControllerMAC(), senderIP, targetHardwareAddress, targetIPByte);
-
-            if(log.isTraceEnabled()) {
-                log.trace("Sending Broadcast Arp Request with srcMac {} - srcIp {} - dstMac {} - dstIp {} - outport {}", HexEncode.bytesToHexString(getControllerMAC()),
-                        subnet.getNetworkAddress(), HexEncode.bytesToHexString(targetHardwareAddress), targetIP, p);
-            }
-
-            byte[] destMACAddress = NetUtils.getBroadcastMACAddr();
-            Ethernet ethernet = createEthernet(getControllerMAC(), destMACAddress, arp, (short)0);
-
-            // TODO For now send port-by-port, see how to optimize to
-            // send to multiple ports at once
-            RawPacket destPkt = this.dataPacketService.encodeDataPacket(ethernet);
-            destPkt.setOutgoingNodeConnector(p);
-
-            this.dataPacketService.transmitDataPacket(destPkt);
-        }
-    }
-
-    /**
-     * Send a unicast ARP Request to the known host on specific (switch/port,
-     * vlan) as defined in the host. The sender IP is the networkAddress of the
-     * subnet The sender MAC is the controller's MAC
-     */
-    protected void sendUcastARPRequest(HostNodeConnector host, Subnet subnet) {
-        log.trace("sendUcastARPRequest host:{} subnet:{}", host, subnet);
-        NodeConnector outPort = host.getnodeConnector();
-        if (outPort == null) {
-            log.error("Failed sending UcastARP because cannot extract output port from Host: {}", host);
-            return;
-        }
-
-        byte[] senderIP = subnet.getNetworkAddress().getAddress();
-        byte[] targetIP = host.getNetworkAddress().getAddress();
-        byte[] targetMAC = host.getDataLayerAddressBytes();
-        ARP arp = createARP(ARP.REQUEST, getControllerMAC(), senderIP, targetMAC, targetIP);
-
-        if(log.isTraceEnabled()) {
-            log.trace("Sending Unicast Arp Request with srcMac {} - srcIp {} - dstMac {} - dstIp {} - outport {}",
-                    HexEncode.bytesToHexString(getControllerMAC()),
-                    subnet.getNetworkAddress(), HexEncode.bytesToHexString(targetMAC), host.getNetworkAddress(),
-                    outPort);
-        }
-
-        Ethernet ethernet = createEthernet(getControllerMAC(), targetMAC, arp, host.getVlan());
-
-        RawPacket destPkt = this.dataPacketService.encodeDataPacket(ethernet);
-        destPkt.setOutgoingNodeConnector(outPort);
-
-        this.dataPacketService.transmitDataPacket(destPkt);
-    }
-
-    @Override
-    public void find(InetAddress networkAddress) {
-        log.trace("Received find IP {}", networkAddress);
-
-        Subnet subnet = null;
-        if (switchManager != null) {
-            subnet = switchManager.getSubnetByNetworkAddress(networkAddress);
-        }
-        if (subnet == null) {
-            log.debug("Can't find subnet matching IP {}", networkAddress);
-            return;
-        }
-
-        // send a broadcast ARP Request to this IP
-        arpRequestReplyEvent.put(new ARPRequest(networkAddress, subnet), false);
-    }
-
-    /*
-     * Probe the host by sending a unicast ARP Request to the host
-     */
-    @Override
-    public void probe(HostNodeConnector host) {
-        log.trace("Received probe host {}", host);
-
-        Subnet subnet = null;
-        if (switchManager != null) {
-            subnet = switchManager.getSubnetByNetworkAddress(host.getNetworkAddress());
-        }
-        if (subnet == null) {
-            log.debug("can't find subnet matching {}", host.getNetworkAddress());
-            return;
-        }
-
-        if (connectionManager.getLocalityStatus(host.getnodeconnectorNode()) == ConnectionLocality.LOCAL) {
-            log.trace("Send a ucast ARP req. to: {}", host);
-            sendUcastARPRequest(host, subnet);
-        } else {
-            log.trace("Raise a ucast ARP req. event to: {}", host);
-            arpRequestReplyEvent.put(new ARPRequest(host, subnet), false);
-        }
-    }
-
-    /**
-     * An IP packet is punted to the controller, this means that the destination
-     * host is not known to the controller. Need to discover it by sending a
-     * Broadcast ARP Request
-     *
-     * @param pkt
-     * @param p
-     */
-    protected void handlePuntedIPPacket(IPv4 pkt, NodeConnector p, short vlan) {
-
-        InetAddress dIP = NetUtils.getInetAddress(pkt.getDestinationAddress());
-        if (dIP == null) {
-            return;
-        }
-
-        // try to find a matching subnet
-        Subnet subnet = null;
-        if (switchManager != null) {
-            subnet = switchManager.getSubnetByNetworkAddress(dIP);
-        }
-        if (subnet == null) {
-            log.debug("Can't find subnet matching {}, drop packet", dIP);
-            return;
-        }
-        // If packet is sent to the default gw (us), ignore it for now
-        if (subnet.getNetworkAddress().equals(dIP)) {
-            log.trace("Ignore IP packet destined to default gw");
-            return;
-        }
-
-        // see if we know about the host
-        // Hosttracker hosts db key implementation
-        HostNodeConnector host = hostTracker.hostFind(dIP);
-
-        if (host == null) {
-            // if we don't know about the host, try to find it
-            log.trace("Punted IP pkt to {}, sending bcast ARP event...", dIP);
-            /*
-             * unknown destination host, initiate bcast ARP request
-             */
-            arpRequestReplyEvent.put(new ARPRequest(dIP, subnet), false);
-
-        } else {
-            log.trace("Ignoring punted IP pkt to known host: {} (received on: {})", dIP, p);
-        }
-    }
-
-    public byte[] getControllerMAC() {
-        if (switchManager == null) {
-            return null;
-        }
-        return switchManager.getControllerMAC();
-    }
-
-    /**
-     * Function called by the dependency manager when all the required
-     * dependencies are satisfied
-     *
-     */
-    void init() {
-        arpRequestors = new ConcurrentHashMap<InetAddress, Set<HostNodeConnector>>();
-        countDownTimers = new ConcurrentHashMap<InetAddress, Short>();
-        cacheEventHandler = new Thread(new ARPCacheEventHandler(), "ARPCacheEventHandler Thread");
-
-        allocateCaches();
-        retrieveCaches();
-
-    }
-
-    @SuppressWarnings({ "unchecked" })
-    private void retrieveCaches() {
-        ConcurrentMap<?, ?> map;
-
-        if (this.clusterContainerService == null) {
-            log.error("Cluster service unavailable, can't retieve ARPHandler caches!");
-            return;
-        }
-
-        map = clusterContainerService.getCache(ARP_EVENT_CACHE_NAME);
-        if (map != null) {
-            this.arpRequestReplyEvent = (ConcurrentMap<ARPEvent, Boolean>) map;
-        } else {
-            log.error("Cache allocation failed for {}", ARP_EVENT_CACHE_NAME);
-        }
-    }
-
-    private void allocateCaches() {
-        if (clusterContainerService == null) {
-            nonClusterObjectCreate();
-            log.error("Clustering service unavailable. Allocated non-cluster caches for ARPHandler.");
-            return;
-        }
-
-        try {
-            clusterContainerService.createCache(ARP_EVENT_CACHE_NAME,
-                    EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-        } catch (CacheConfigException e) {
-            log.error("ARPHandler cache configuration invalid!");
-        } catch (CacheExistException e) {
-            log.debug("ARPHandler cache exists, skipped allocation.");
-        }
-
-    }
-
-    private void nonClusterObjectCreate() {
-        arpRequestReplyEvent = new ConcurrentHashMap<ARPEvent, Boolean>();
-    }
-
-    /**
-     * Function called by the dependency manager when at least one dependency
-     * become unsatisfied or when the component is shutting down because for
-     * example bundle is being stopped.
-     *
-     */
-    void destroy() {
-        cacheEventHandler.interrupt();
-    }
-
-    /**
-     * Function called by dependency manager after "init ()" is called and after
-     * the services provided by the class are registered in the service registry
-     *
-     */
-    void start() {
-        stopping = false;
-        startPeriodicTimer();
-        cacheEventHandler.start();
-    }
-
-    /**
-     * Function called by the dependency manager before the services exported by
-     * the component are unregistered, this will be followed by a "destroy ()"
-     * calls
-     *
-     */
-    void stop() {
-    }
-
-    void stopping() {
-        stopping = true;
-        cancelPeriodicTimer();
-    }
-
-    void setSwitchManager(ISwitchManager s) {
-        log.debug("SwitchManager service set.");
-        this.switchManager = s;
-    }
-
-    void unsetSwitchManager(ISwitchManager s) {
-        if (this.switchManager == s) {
-            log.debug("SwitchManager service UNset.");
-            this.switchManager = null;
-        }
-    }
-
-    @Override
-    public PacketResult receiveDataPacket(RawPacket inPkt) {
-        if (inPkt == null) {
-            return PacketResult.IGNORED;
-        }
-        log.trace("Received a frame of size: {}", inPkt.getPacketData().length);
-        Packet formattedPak = this.dataPacketService.decodeDataPacket(inPkt);
-        if (formattedPak instanceof Ethernet) {
-            Packet nextPak = formattedPak.getPayload();
-            short vlan = 0;
-            if (nextPak instanceof IEEE8021Q) {
-                vlan = ((IEEE8021Q) nextPak).getVid();
-                log.trace("Moved after the dot1Q header");
-                nextPak = ((IEEE8021Q) nextPak).getPayload();
-            }
-            if (nextPak instanceof IPv4) {
-                log.trace("Handle IP packet: {}", formattedPak);
-                handlePuntedIPPacket((IPv4) nextPak, inPkt.getIncomingNodeConnector(), vlan);
-            } else if (nextPak instanceof ARP) {
-                log.trace("Handle ARP packet: {}", formattedPak);
-                handleARPPacket((Ethernet) formattedPak, (ARP) nextPak, inPkt.getIncomingNodeConnector(), vlan);
-            }
-        }
-        return PacketResult.IGNORED;
-    }
-
-    private ARP createARP(short opCode, byte[] senderMacAddress, byte[] senderIP, byte[] targetMacAddress,
-            byte[] targetIP) {
-        ARP arp = new ARP();
-        arp.setHardwareType(ARP.HW_TYPE_ETHERNET);
-        arp.setProtocolType(EtherTypes.IPv4.shortValue());
-        arp.setHardwareAddressLength((byte) 6);
-        arp.setProtocolAddressLength((byte) 4);
-        arp.setOpCode(opCode);
-        arp.setSenderHardwareAddress(senderMacAddress);
-        arp.setSenderProtocolAddress(senderIP);
-        arp.setTargetHardwareAddress(targetMacAddress);
-        arp.setTargetProtocolAddress(targetIP);
-        return arp;
-    }
-
-    private Ethernet createEthernet(byte[] sourceMAC, byte[] targetMAC, ARP arp, short vlan) {
-        Ethernet ethernet = new Ethernet();
-        ethernet.setSourceMACAddress(sourceMAC);
-        ethernet.setDestinationMACAddress(targetMAC);
-        if (vlan == 0) {
-            ethernet.setEtherType(EtherTypes.ARP.shortValue());
-            ethernet.setPayload(arp);
-        } else {
-            IEEE8021Q dot1q = new IEEE8021Q();
-            dot1q.setVid(vlan);
-            dot1q.setEtherType(EtherTypes.ARP.shortValue());
-            dot1q.setPayload(arp);
-            dot1q.setCfi((byte)0);
-            dot1q.setPcp((byte)0);
-            ethernet.setEtherType(EtherTypes.VLANTAGGED.shortValue());
-            ethernet.setPayload(dot1q);
-        }
-        return ethernet;
-    }
-
-    private void startPeriodicTimer() {
-        this.periodicTimer = new Timer("ArpHandler Periodic Timer");
-        this.periodicTimer.scheduleAtFixedRate(new TimerTask() {
-            @Override
-            public void run() {
-                Set<InetAddress> targetIPs = countDownTimers.keySet();
-                Set<InetAddress> expiredTargets = new HashSet<InetAddress>();
-                for (InetAddress t : targetIPs) {
-                    short tick = countDownTimers.get(t);
-                    tick--;
-                    if (tick <= 0) {
-                        expiredTargets.add(t);
-                    } else {
-                        countDownTimers.replace(t, tick);
-                    }
-                }
-                for (InetAddress tIP : expiredTargets) {
-                    countDownTimers.remove(tIP);
-                    // Remove the requestor(s) who have been waiting for the ARP
-                    // reply from this target for more than 1sec
-                    arpRequestors.remove(tIP);
-                    log.debug("ARP reply was not received from {}", tIP);
-                }
-
-                // Clean up ARP event cache
-                try {
-                    if (clusterContainerService.amICoordinator() && !arpRequestReplyEvent.isEmpty()) {
-                        arpRequestReplyEvent.clear();
-                    }
-                } catch (Exception e) {
-                    log.warn("ARPHandler: A cluster member failed to clear event cache.");
-                }
-            }
-        }, 0, 1000);
-    }
-
-    private void cancelPeriodicTimer() {
-        if (this.periodicTimer != null) {
-            this.periodicTimer.cancel();
-        }
-    }
-
-    private void generateAndSendReply(InetAddress sourceIP, byte[] sourceMAC, short vlan) {
-        if (log.isTraceEnabled()) {
-            log.trace("generateAndSendReply called with params sourceIP:{} sourceMAC:{}", sourceIP,
-                    HexEncode.bytesToHexString(sourceMAC));
-        }
-        Set<HostNodeConnector> hosts = arpRequestors.remove(sourceIP);
-        if ((hosts == null) || hosts.isEmpty()) {
-            log.trace("Bailing out no requestors Hosts");
-            return;
-        }
-        countDownTimers.remove(sourceIP);
-        for (HostNodeConnector host : hosts) {
-            if (log.isTraceEnabled()) {
-                log.trace(
-                        "Sending ARP Reply with src {}/{}, target {}/{} {}",
-                        new Object[] { HexEncode.bytesToHexString(sourceMAC), sourceIP,
-                                HexEncode.bytesToHexString(host.getDataLayerAddressBytes()), host.getNetworkAddress(),
-                                (vlan != 0 ? "on vlan " + vlan : "") });
-            }
-            if (connectionManager.getLocalityStatus(host.getnodeconnectorNode()) == ConnectionLocality.LOCAL) {
-                sendARPReply(host.getnodeConnector(), sourceMAC, sourceIP, host.getDataLayerAddressBytes(),
-                        host.getNetworkAddress(), vlan);
-            } else {
-                /*
-                 * In the remote event a requestor moved to another controller
-                 * it may turn out it now we need to send the ARP reply from a
-                 * different controller, this cover the case
-                 */
-                arpRequestReplyEvent.put(
-                        new ARPReply(host.getnodeConnector(), sourceIP, sourceMAC, host.getNetworkAddress(), host
-                                .getDataLayerAddressBytes(), vlan), false);
-            }
-        }
-    }
-
-    @Override
-    public void entryUpdated(ARPEvent key, Boolean new_value, String cacheName, boolean originLocal) {
-        log.trace("Got and entryUpdated for cacheName {} key {} isNew {}", cacheName, key, new_value);
-        enqueueARPCacheEvent(key, new_value);
-    }
-
-    @Override
-    public void entryCreated(ARPEvent key, String cacheName, boolean originLocal) {
-        // nothing to do
-    }
-
-    @Override
-    public void entryDeleted(ARPEvent key, String cacheName, boolean originLocal) {
-        // nothing to do
-    }
-
-    private void enqueueARPCacheEvent(ARPEvent event, boolean new_value) {
-        try {
-            ARPCacheEvent cacheEvent = new ARPCacheEvent(event, new_value);
-            if (!ARPCacheEvents.contains(cacheEvent)) {
-                this.ARPCacheEvents.add(cacheEvent);
-                log.trace("Enqueued {}", event);
-            }
-        } catch (Exception e) {
-            log.debug("enqueueARPCacheEvent caught Interrupt Exception for event {}", event);
-        }
-    }
-
-    /*
-     * this thread monitors the connectionEvent queue for new incoming events
-     * from
-     */
-    private class ARPCacheEventHandler implements Runnable {
-        @Override
-        public void run() {
-            while (!stopping) {
-                try {
-                    ARPCacheEvent ev = ARPCacheEvents.take();
-                    ARPEvent event = ev.getEvent();
-                    if (event instanceof ARPRequest) {
-                        ARPRequest req = (ARPRequest) event;
-                        // If broadcast request
-                        if (req.getHost() == null) {
-                            log.trace("Trigger and ARP Broadcast Request upon receipt of {}", req);
-                            sendBcastARPRequest(req.getTargetIP(), req.getSubnet());
-
-                            // If unicast and local, send reply
-                        } else if (connectionManager.getLocalityStatus(req.getHost().getnodeconnectorNode()) == ConnectionLocality.LOCAL) {
-                            log.trace("ARPCacheEventHandler - sendUcatARPRequest upon receipt of {}", req);
-                            sendUcastARPRequest(req.getHost(), req.getSubnet());
-                        }
-                    } else if (event instanceof ARPReply) {
-                        ARPReply rep = (ARPReply) event;
-                        // New reply received by controller, notify all awaiting
-                        // requestors across the cluster
-                        if (ev.isNewReply()) {
-                            log.trace("Trigger a generateAndSendReply in response to {}", rep);
-                            generateAndSendReply(rep.getTargetIP(), rep.getTargetMac(), rep.getVlan());
-                            // Otherwise, a specific reply. If local, send out.
-                        } else if (connectionManager.getLocalityStatus(rep.getPort().getNode()) == ConnectionLocality.LOCAL) {
-                            log.trace("ARPCacheEventHandler - sendUcatARPReply locally in response to {}", rep);
-                            sendARPReply(rep.getPort(), rep.getSourceMac(), rep.getSourceIP(), rep.getTargetMac(),
-                                    rep.getTargetIP(), rep.getVlan());
-                        }
-                    }
-                } catch (InterruptedException e) {
-                    ARPCacheEvents.clear();
-                    return;
-                }
-            }
-        }
-    }
-}
diff --git a/opendaylight/adsal/arphandler/src/test/java/org/opendaylight/controller/arphandler/internal/ArphandlerTest.java b/opendaylight/adsal/arphandler/src/test/java/org/opendaylight/controller/arphandler/internal/ArphandlerTest.java
deleted file mode 100644 (file)
index 892a0bc..0000000
+++ /dev/null
@@ -1,27 +0,0 @@
-\r
-/*\r
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.\r
- *\r
- * This program and the accompanying materials are made available under the\r
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,\r
- * and is available at http://www.eclipse.org/legal/epl-v10.html\r
- */\r
-\r
-package org.opendaylight.controller.arphandler.internal;\r
-\r
-\r
-import org.junit.Assert;\r
-import org.junit.Test;\r
-\r
-public class ArphandlerTest  {\r
-\r
-        @Test\r
-        public void testArphandlerCreation() {\r
-\r
-                ArpHandler ah = null;\r
-                ah = new ArpHandler();\r
-                Assert.assertTrue(ah != null);\r
-\r
-        }\r
-\r
-}\r
diff --git a/opendaylight/adsal/clustering/integrationtest/pom.xml b/opendaylight/adsal/clustering/integrationtest/pom.xml
deleted file mode 100644 (file)
index e30eb67..0000000
+++ /dev/null
@@ -1,123 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.integrationtest</artifactId>
-    <version>0.7.0-SNAPSHOT</version>
-    <relativePath>../../commons/integrationtest</relativePath>
-  </parent>
-
-  <artifactId>clustering.services.integrationtest</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <properties>
-    <sonar.jacoco.itReportPath>../../implementation/target/jacoco-it.exec</sonar.jacoco.itReportPath>
-    <!-- Sonar jacoco plugin to get integration test coverage info -->
-    <sonar.jacoco.reportPath>../../implementation/target/jacoco.exec</sonar.jacoco.reportPath>
-  </properties>
-
-  <dependencies>
-    <dependency>
-      <groupId>ch.qos.logback</groupId>
-      <artifactId>logback-classic</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>ch.qos.logback</groupId>
-      <artifactId>logback-core</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>eclipselink</groupId>
-      <artifactId>javax.resource</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.apache.felix</groupId>
-      <artifactId>org.apache.felix.dependencymanager.shell</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>clustering.services</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>clustering.services-implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>containermanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>containermanager.it.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.slf4j</groupId>
-      <artifactId>log4j-over-slf4j</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.ops4j.pax.exam</groupId>
-      <artifactId>pax-exam-container-native</artifactId>
-      <scope>test</scope>
-    </dependency>
-    <dependency>
-      <groupId>org.ops4j.pax.exam</groupId>
-      <artifactId>pax-exam-junit4</artifactId>
-      <scope>test</scope>
-    </dependency>
-    <dependency>
-      <groupId>org.ops4j.pax.exam</groupId>
-      <artifactId>pax-exam-link-mvn</artifactId>
-      <scope>test</scope>
-    </dependency>
-    <dependency>
-      <groupId>org.ops4j.pax.url</groupId>
-      <artifactId>pax-url-aether</artifactId>
-      <scope>test</scope>
-    </dependency>
-  </dependencies>
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.jacoco</groupId>
-        <artifactId>jacoco-maven-plugin</artifactId>
-        <configuration>
-          <destFile>../../implementation/target/jacoco-it.exec</destFile>
-          <includes>
-            <include>org.opendaylight.controller.*</include>
-          </includes>
-        </configuration>
-        <executions>
-          <execution>
-            <id>pre-test</id>
-            <goals>
-              <goal>prepare-agent</goal>
-            </goals>
-          </execution>
-          <execution>
-            <id>post-test</id>
-            <configuration>
-              <skip>true</skip>
-            </configuration>
-          </execution>
-        </executions>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/clustering/integrationtest/src/test/java/org/opendaylight/controller/clustering/services_implementation/internal/ClusteringServicesIT.java b/opendaylight/adsal/clustering/integrationtest/src/test/java/org/opendaylight/controller/clustering/services_implementation/internal/ClusteringServicesIT.java
deleted file mode 100644 (file)
index 166dec4..0000000
+++ /dev/null
@@ -1,717 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.clustering.services_implementation.internal;\r
-\r
-import static org.junit.Assert.assertEquals;\r
-import static org.junit.Assert.assertFalse;\r
-import static org.junit.Assert.assertNotNull;\r
-import static org.junit.Assert.assertNull;\r
-import static org.junit.Assert.assertTrue;\r
-import static org.ops4j.pax.exam.CoreOptions.junitBundles;\r
-import static org.ops4j.pax.exam.CoreOptions.mavenBundle;\r
-import static org.ops4j.pax.exam.CoreOptions.options;\r
-import static org.ops4j.pax.exam.CoreOptions.systemPackages;\r
-import static org.ops4j.pax.exam.CoreOptions.systemProperty;\r
-\r
-import java.util.List;\r
-import java.util.concurrent.CopyOnWriteArrayList;\r
-import java.util.concurrent.TimeUnit;\r
-import java.net.InetAddress;\r
-import java.util.Dictionary;\r
-import java.util.HashSet;\r
-import java.util.Hashtable;\r
-import java.util.Set;\r
-import java.util.concurrent.ConcurrentMap;\r
-\r
-import javax.inject.Inject;\r
-\r
-import org.junit.Before;\r
-import org.junit.Test;\r
-import org.junit.runner.RunWith;\r
-import org.opendaylight.controller.clustering.services.CacheConfigException;\r
-import org.opendaylight.controller.clustering.services.CacheExistException;\r
-import org.opendaylight.controller.clustering.services.CacheListenerAddException;\r
-import org.opendaylight.controller.clustering.services.IClusterGlobalServices;\r
-import org.opendaylight.controller.clustering.services.IClusterServices;\r
-import org.opendaylight.controller.clustering.services.IClusterContainerServices;\r
-import org.opendaylight.controller.clustering.services.IClusterServices.cacheMode;\r
-import org.opendaylight.controller.clustering.services.IGetUpdates;\r
-import org.opendaylight.controller.clustering.services.ICacheUpdateAware;\r
-import org.opendaylight.controller.sal.utils.ServiceHelper;\r
-import org.opendaylight.controller.sal.core.UpdateType;\r
-import org.ops4j.pax.exam.Option;\r
-import org.ops4j.pax.exam.Configuration;\r
-import org.ops4j.pax.exam.junit.PaxExam;\r
-import org.ops4j.pax.exam.util.PathUtils;\r
-import org.osgi.framework.Bundle;\r
-import org.osgi.framework.BundleContext;\r
-import org.osgi.framework.ServiceRegistration;\r
-import org.slf4j.Logger;\r
-import org.slf4j.LoggerFactory;\r
-import java.util.concurrent.CountDownLatch;\r
-\r
-@RunWith(PaxExam.class)\r
-public class ClusteringServicesIT {\r
-    private Logger log = LoggerFactory\r
-        .getLogger(ClusteringServicesIT.class);\r
-    // get the OSGI bundle context\r
-    @Inject\r
-    private BundleContext bc;\r
-    private IClusterServices clusterServices = null;\r
-    private IClusterContainerServices clusterDefaultServices = null;\r
-    private IClusterGlobalServices clusterGlobalServices = null;\r
-\r
-    // Configure the OSGi container\r
-    @Configuration\r
-    public Option[] config() {\r
-        return options(\r
-            //\r
-            systemProperty("logback.configurationFile").value(\r
-                "file:" + PathUtils.getBaseDir()\r
-                + "/src/test/resources/logback.xml"),\r
-            // To start OSGi console for inspection remotely\r
-            systemProperty("osgi.console").value("2401"),\r
-            // Set the systemPackages (used by clustering)\r
-            systemPackages("sun.reflect", "sun.reflect.misc", "sun.misc"),\r
-            // List framework bundles\r
-            mavenBundle("equinoxSDK381",\r
-                        "org.eclipse.equinox.console").versionAsInProject(),\r
-            mavenBundle("equinoxSDK381",\r
-                        "org.eclipse.equinox.util").versionAsInProject(),\r
-            mavenBundle("equinoxSDK381",\r
-                        "org.eclipse.osgi.services").versionAsInProject(),\r
-            mavenBundle("equinoxSDK381",\r
-                        "org.eclipse.equinox.ds").versionAsInProject(),\r
-            mavenBundle("equinoxSDK381",\r
-                        "org.apache.felix.gogo.command").versionAsInProject(),\r
-            mavenBundle("equinoxSDK381",\r
-                        "org.apache.felix.gogo.runtime").versionAsInProject(),\r
-            mavenBundle("equinoxSDK381",\r
-                        "org.apache.felix.gogo.shell").versionAsInProject(),\r
-            // List logger bundles\r
-            mavenBundle("org.slf4j", "slf4j-api").versionAsInProject(),\r
-            mavenBundle("org.slf4j", "log4j-over-slf4j").versionAsInProject(),\r
-            mavenBundle("ch.qos.logback", "logback-core").versionAsInProject(),\r
-            mavenBundle("ch.qos.logback", "logback-classic").versionAsInProject(),\r
-            // List all the bundles on which the test case depends\r
-            mavenBundle("org.opendaylight.controller",\r
-                        "clustering.services").versionAsInProject(),\r
-            mavenBundle("org.opendaylight.controller",\r
-                        "clustering.services-implementation").versionAsInProject(),\r
-            mavenBundle("org.opendaylight.controller", "sal").versionAsInProject(),\r
-            mavenBundle("org.opendaylight.controller",\r
-                        "sal.implementation").versionAsInProject(),\r
-            mavenBundle("org.opendaylight.controller", "configuration").versionAsInProject(),\r
-            mavenBundle("org.opendaylight.controller", "containermanager").versionAsInProject(),\r
-            mavenBundle("org.opendaylight.controller",\r
-                        "containermanager.it.implementation").versionAsInProject(),\r
-            mavenBundle("org.jboss.spec.javax.transaction",\r
-                        "jboss-transaction-api_1.1_spec").versionAsInProject(),\r
-            mavenBundle("org.apache.commons", "commons-lang3").versionAsInProject(),\r
-            mavenBundle("org.apache.felix",\r
-                        "org.apache.felix.dependencymanager").versionAsInProject(),\r
-            mavenBundle("org.apache.felix",\r
-                        "org.apache.felix.dependencymanager.shell").versionAsInProject(),\r
-            mavenBundle("eclipselink", "javax.resource").versionAsInProject(),\r
-            junitBundles());\r
-    }\r
-\r
-    private String stateToString(int state) {\r
-        switch (state) {\r
-        case Bundle.ACTIVE:\r
-            return "ACTIVE";\r
-        case Bundle.INSTALLED:\r
-            return "INSTALLED";\r
-        case Bundle.RESOLVED:\r
-            return "RESOLVED";\r
-        case Bundle.UNINSTALLED:\r
-            return "UNINSTALLED";\r
-        default:\r
-            return "Not CONVERTED";\r
-        }\r
-    }\r
-\r
-    @Before\r
-    public void areWeReady() {\r
-        assertNotNull(bc);\r
-        boolean debugit = false;\r
-        Bundle b[] = bc.getBundles();\r
-        for (Bundle element : b) {\r
-            int state = element.getState();\r
-            if (state != Bundle.ACTIVE && state != Bundle.RESOLVED) {\r
-                log.debug("Bundle:" + element.getSymbolicName() + " state:"\r
-                          + stateToString(state));\r
-                debugit = true;\r
-            }\r
-        }\r
-        if (debugit) {\r
-            log.debug("Do some debugging because some bundle is "\r
-                      + "unresolved");\r
-        }\r
-\r
-        // Assert if true, if false we are good to go!\r
-        assertFalse(debugit);\r
-\r
-        this.clusterServices = (IClusterServices)ServiceHelper\r
-            .getGlobalInstance(IClusterServices.class, this);\r
-        assertNotNull(this.clusterServices);\r
-\r
-        this.clusterDefaultServices = (IClusterContainerServices)ServiceHelper\r
-            .getInstance(IClusterContainerServices.class, "default", this);\r
-        assertNotNull(this.clusterDefaultServices);\r
-\r
-        this.clusterGlobalServices = (IClusterGlobalServices)ServiceHelper\r
-            .getGlobalInstance(IClusterGlobalServices.class, this);\r
-        assertNotNull(this.clusterGlobalServices);\r
-    }\r
-\r
-    @Test\r
-    public void clusterTest() throws CacheExistException, CacheConfigException,\r
-        CacheListenerAddException {\r
-\r
-        String container1 = "Container1";\r
-        String container2 = "Container2";\r
-        String cache1 = "Cache1";\r
-        String cache2 = "Cache2";\r
-        String cache3 = "Cache3";\r
-\r
-        HashSet<cacheMode> cacheModeSet = new HashSet<cacheMode>();\r
-        cacheModeSet.add(cacheMode.NON_TRANSACTIONAL);\r
-        ConcurrentMap cm11 = this.clusterServices.createCache(container1,\r
-                cache1, cacheModeSet);\r
-        assertNotNull(cm11);\r
-\r
-        assertNull(this.clusterServices.getCache(container2, cache2));\r
-        assertEquals(cm11, this.clusterServices.getCache(container1, cache1));\r
-\r
-        assertFalse(this.clusterServices.existCache(container2, cache2));\r
-        assertTrue(this.clusterServices.existCache(container1, cache1));\r
-\r
-        ConcurrentMap cm12 = this.clusterServices.createCache(container1,\r
-                cache2, cacheModeSet);\r
-        ConcurrentMap cm23 = this.clusterServices.createCache(container2,\r
-                cache3, cacheModeSet);\r
-\r
-        HashSet<String> cacheList = (HashSet<String>) this.clusterServices\r
-                .getCacheList(container1);\r
-        assertEquals(2, cacheList.size());\r
-        assertTrue(cacheList.contains(cache1));\r
-        assertTrue(cacheList.contains(cache2));\r
-        assertFalse(cacheList.contains(cache3));\r
-\r
-        assertNotNull(this.clusterServices.getCacheProperties(container1,\r
-                cache1));\r
-\r
-        HashSet<IGetUpdates<?, ?>> listeners = (HashSet<IGetUpdates<?, ?>>) this.clusterServices\r
-                .getListeners(container1, cache1);\r
-        assertEquals(0, listeners.size());\r
-\r
-        IGetUpdates<?, ?> getUpdate1 = new GetUpdates();\r
-        this.clusterServices.addListener(container1, cache1, getUpdate1);\r
-        listeners = (HashSet<IGetUpdates<?, ?>>) this.clusterServices\r
-                .getListeners(container1, cache1);\r
-        assertEquals(1, listeners.size());\r
-        this.clusterServices.addListener(container1, cache1, new GetUpdates());\r
-        listeners = (HashSet<IGetUpdates<?, ?>>) this.clusterServices\r
-                .getListeners(container1, cache1);\r
-        assertEquals(2, listeners.size());\r
-\r
-        listeners = (HashSet<IGetUpdates<?, ?>>) this.clusterServices\r
-                .getListeners(container2, cache3);\r
-        assertEquals(0, listeners.size());\r
-\r
-        this.clusterServices.removeListener(container1, cache1, getUpdate1);\r
-        listeners = (HashSet<IGetUpdates<?, ?>>) this.clusterServices\r
-                .getListeners(container1, cache1);\r
-        assertEquals(1, listeners.size());\r
-\r
-        InetAddress addr = this.clusterServices.getMyAddress();\r
-        assertNotNull(addr);\r
-\r
-        List<InetAddress> addrList = this.clusterServices\r
-                .getClusteredControllers();\r
-\r
-        this.clusterServices.destroyCache(container1, cache1);\r
-        assertFalse(this.clusterServices.existCache(container1, cache1));\r
-\r
-    }\r
-\r
-    private class GetUpdates implements IGetUpdates<Integer, String> {\r
-\r
-        @Override\r
-        public void entryCreated(Integer key, String containerName,\r
-                String cacheName, boolean originLocal) {\r
-            return;\r
-        }\r
-\r
-        @Override\r
-        public void entryUpdated(Integer key, String newValue,\r
-                String containerName, String cacheName, boolean originLocal) {\r
-            return;\r
-        }\r
-\r
-        @Override\r
-        public void entryDeleted(Integer key, String containerName,\r
-                String cacheName, boolean originLocal) {\r
-            return;\r
-        }\r
-    }\r
-\r
-    @Test\r
-    public void clusterContainerAndGlobalTest() throws CacheExistException, CacheConfigException,\r
-        CacheListenerAddException, InterruptedException {\r
-        String cache1 = "Cache1";\r
-        String cache2 = "Cache2";\r
-        // Lets test the case of caches with same name in different\r
-        // containers (actually global an container case)\r
-        String cache3 = "Cache2";\r
-\r
-        HashSet<cacheMode> cacheModeSet = new HashSet<cacheMode>();\r
-        cacheModeSet.add(cacheMode.NON_TRANSACTIONAL);\r
-        ConcurrentMap cm11 = this.clusterDefaultServices.createCache(cache1, cacheModeSet);\r
-        assertNotNull(cm11);\r
-\r
-        assertTrue(this.clusterDefaultServices.existCache(cache1));\r
-        assertEquals(cm11, this.clusterDefaultServices.getCache(cache1));\r
-\r
-        ConcurrentMap cm12 = this.clusterDefaultServices.createCache(cache2, cacheModeSet);\r
-        ConcurrentMap cm23 = this.clusterGlobalServices.createCache(cache3, cacheModeSet);\r
-\r
-        // Now given cahe2 and cache3 have same name lets make sure\r
-        // they don't return the same reference\r
-        assertNotNull(this.clusterGlobalServices.getCache(cache2));\r
-        // cm12 reference must be different than cm23\r
-        assertTrue(cm12 != cm23);\r
-\r
-        HashSet<String> cacheList = (HashSet<String>) this.clusterDefaultServices\r
-            .getCacheList();\r
-        assertEquals(2, cacheList.size());\r
-        assertTrue(cacheList.contains(cache1));\r
-        assertTrue(cacheList.contains(cache2));\r
-\r
-        assertNotNull(this.clusterDefaultServices.getCacheProperties(cache1));\r
-\r
-        {\r
-            /***********************************/\r
-            /* Testing cacheAware in Container */\r
-            /***********************************/\r
-            Dictionary<String, Object> props = new Hashtable<String, Object>();\r
-            Set<String> propSet = new HashSet<String>();\r
-            propSet.add(cache1);\r
-            propSet.add(cache2);\r
-            props.put("cachenames", propSet);\r
-            CacheAware listener = new CacheAware();\r
-            CacheAware listenerRepeated = new CacheAware();\r
-            ServiceRegistration updateServiceReg = ServiceHelper.registerServiceWReg(ICacheUpdateAware.class, "default",\r
-                                                                                     listener, props);\r
-            assertNotNull(updateServiceReg);\r
-\r
-            // Register another service for the same caches, this\r
-            // should not get any update because we don't allow to\r
-            // override the existing unless before unregistered\r
-            ServiceRegistration updateServiceRegRepeated = ServiceHelper.registerServiceWReg(ICacheUpdateAware.class,\r
-                                                                                             "default",\r
-                                                                                             listenerRepeated, props);\r
-            assertNotNull(updateServiceRegRepeated);\r
-            CountDownLatch res = null;\r
-            List<Update> ups = null;\r
-            Update up = null;\r
-            Integer k1 = new Integer(10);\r
-            Long k2 = new Long(100L);\r
-\r
-            /***********************/\r
-            /* CREATE NEW KEY CASE */\r
-            /***********************/\r
-            // Start monitoring the updates\r
-            res = listener.restart(2);\r
-            // modify the cache\r
-            cm11.put(k1, "foo");\r
-            // Wait\r
-            res.await(100L, TimeUnit.SECONDS);\r
-            // Analyze the updates\r
-            ups = listener.getUpdates();\r
-            assertTrue(ups.size() == 2);\r
-            // Validate that first we get an update (yes even in case of a\r
-            // new value added)\r
-            up = ups.get(0);\r
-            assertTrue(up.t.equals(UpdateType.CHANGED));\r
-            assertTrue(up.key.equals(k1));\r
-            assertTrue(up.value.equals("foo"));\r
-            assertTrue(up.cacheName.equals(cache1));\r
-            // Validate that we then get a create\r
-            up = ups.get(1);\r
-            assertTrue(up.t.equals(UpdateType.ADDED));\r
-            assertTrue(up.key.equals(k1));\r
-            assertNull(up.value);\r
-            assertTrue(up.cacheName.equals(cache1));\r
-\r
-            /*******************************/\r
-            /* UPDATE AN EXISTING KEY CASE */\r
-            /*******************************/\r
-            // Start monitoring the updates\r
-            res = listener.restart(1);\r
-            // modify the cache\r
-            cm11.put(k1, "baz");\r
-            // Wait\r
-            res.await(100L, TimeUnit.SECONDS);\r
-            // Analyze the updates\r
-            ups = listener.getUpdates();\r
-            assertTrue(ups.size() == 1);\r
-            // Validate we get an update with expect fields\r
-            up = ups.get(0);\r
-            assertTrue(up.t.equals(UpdateType.CHANGED));\r
-            assertTrue(up.key.equals(k1));\r
-            assertTrue(up.value.equals("baz"));\r
-            assertTrue(up.cacheName.equals(cache1));\r
-\r
-            /**********************************/\r
-            /* RE-UPDATE AN EXISTING KEY CASE */\r
-            /**********************************/\r
-            // Start monitoring the updates\r
-            res = listener.restart(1);\r
-            // modify the cache\r
-            cm11.put(k1, "baz");\r
-            // Wait\r
-            res.await(100L, TimeUnit.SECONDS);\r
-            // Analyze the updates\r
-            ups = listener.getUpdates();\r
-            assertTrue(ups.size() == 1);\r
-            // Validate we get an update with expect fields\r
-            up = ups.get(0);\r
-            assertTrue(up.t.equals(UpdateType.CHANGED));\r
-            assertTrue(up.key.equals(k1));\r
-            assertTrue(up.value.equals("baz"));\r
-            assertTrue(up.cacheName.equals(cache1));\r
-\r
-            /********************************/\r
-            /* REMOVAL OF EXISTING KEY CASE */\r
-            /********************************/\r
-            // Start monitoring the updates\r
-            res = listener.restart(1);\r
-            // modify the cache\r
-            cm11.remove(k1);\r
-            // Wait\r
-            res.await(100L, TimeUnit.SECONDS);\r
-            // Analyze the updates\r
-            ups = listener.getUpdates();\r
-            assertTrue(ups.size() == 1);\r
-            // Validate we get a delete with expected fields\r
-            up = ups.get(0);\r
-            assertTrue(up.t.equals(UpdateType.REMOVED));\r
-            assertTrue(up.key.equals(k1));\r
-            assertNull(up.value);\r
-            assertTrue(up.cacheName.equals(cache1));\r
-\r
-            /***********************/\r
-            /* CREATE NEW KEY CASE */\r
-            /***********************/\r
-            // Start monitoring the updates\r
-            res = listener.restart(2);\r
-            // modify the cache\r
-            cm12.put(k2, new Short((short)15));\r
-            // Wait\r
-            res.await(100L, TimeUnit.SECONDS);\r
-            // Analyze the updates\r
-            ups = listener.getUpdates();\r
-            assertTrue(ups.size() == 2);\r
-            // Validate that first we get an update (yes even in case of a\r
-            // new value added)\r
-            up = ups.get(0);\r
-            assertTrue(up.t.equals(UpdateType.CHANGED));\r
-            assertTrue(up.key.equals(k2));\r
-            assertTrue(up.value.equals(new Short((short)15)));\r
-            assertTrue(up.cacheName.equals(cache2));\r
-            // Validate that we then get a create\r
-            up = ups.get(1);\r
-            assertTrue(up.t.equals(UpdateType.ADDED));\r
-            assertTrue(up.key.equals(k2));\r
-            assertNull(up.value);\r
-            assertTrue(up.cacheName.equals(cache2));\r
-\r
-            /*******************************/\r
-            /* UPDATE AN EXISTING KEY CASE */\r
-            /*******************************/\r
-            // Start monitoring the updates\r
-            res = listener.restart(1);\r
-            // modify the cache\r
-            cm12.put(k2, "BAZ");\r
-            // Wait\r
-            res.await(100L, TimeUnit.SECONDS);\r
-            // Analyze the updates\r
-            ups = listener.getUpdates();\r
-            assertTrue(ups.size() == 1);\r
-            // Validate we get an update with expect fields\r
-            up = ups.get(0);\r
-            assertTrue(up.t.equals(UpdateType.CHANGED));\r
-            assertTrue(up.key.equals(k2));\r
-            assertTrue(up.value.equals("BAZ"));\r
-            assertTrue(up.cacheName.equals(cache2));\r
-\r
-            /********************************/\r
-            /* REMOVAL OF EXISTING KEY CASE */\r
-            /********************************/\r
-            // Start monitoring the updates\r
-            res = listener.restart(1);\r
-            // modify the cache\r
-            cm12.remove(k2);\r
-            // Wait\r
-            res.await(100L, TimeUnit.SECONDS);\r
-            // Analyze the updates\r
-            ups = listener.getUpdates();\r
-            assertTrue(ups.size() == 1);\r
-            // Validate we get a delete with expected fields\r
-            up = ups.get(0);\r
-            assertTrue(up.t.equals(UpdateType.REMOVED));\r
-            assertTrue(up.key.equals(k2));\r
-            assertNull(up.value);\r
-            assertTrue(up.cacheName.equals(cache2));\r
-\r
-            /******************************************************************/\r
-            /* NOW LETS REMOVE THE REGISTRATION AND MAKE SURE NO UPDATS COMES */\r
-            /******************************************************************/\r
-            updateServiceReg.unregister();\r
-            // Start monitoring the updates, noone should come in\r
-            res = listener.restart(1);\r
-\r
-            /***********************/\r
-            /* CREATE NEW KEY CASE */\r
-            /***********************/\r
-            // modify the cache\r
-            cm11.put(k1, "foo");\r
-\r
-            /*******************************/\r
-            /* UPDATE AN EXISTING KEY CASE */\r
-            /*******************************/\r
-            // modify the cache\r
-            cm11.put(k1, "baz");\r
-\r
-            /********************************/\r
-            /* REMOVAL OF EXISTING KEY CASE */\r
-            /********************************/\r
-            // modify the cache\r
-            cm11.remove(k1);\r
-\r
-            /***********************/\r
-            /* CREATE NEW KEY CASE */\r
-            /***********************/\r
-            // modify the cache\r
-            cm12.put(k2, new Short((short)15));\r
-\r
-            /*******************************/\r
-            /* UPDATE AN EXISTING KEY CASE */\r
-            /*******************************/\r
-            // modify the cache\r
-            cm12.put(k2, "BAZ");\r
-\r
-            /********************************/\r
-            /* REMOVAL OF EXISTING KEY CASE */\r
-            /********************************/\r
-            // modify the cache\r
-            cm12.remove(k2);\r
-\r
-\r
-            // Wait to make sure no updates came in, clearly this is\r
-            // error prone as logic, but cannot find a better way than\r
-            // this to make sure updates didn't get in\r
-            res.await(1L, TimeUnit.SECONDS);\r
-            // Analyze the updates\r
-            ups = listener.getUpdates();\r
-            assertTrue(ups.size() == 0);\r
-        }\r
-\r
-        {\r
-            /***********************************/\r
-            /* Testing cacheAware in Global */\r
-            /***********************************/\r
-            Dictionary<String, Object> props = new Hashtable<String, Object>();\r
-            Set<String> propSet = new HashSet<String>();\r
-            propSet.add(cache3);\r
-            props.put("cachenames", propSet);\r
-            CacheAware listener = new CacheAware();\r
-            ServiceRegistration updateServiceReg = ServiceHelper.registerGlobalServiceWReg(ICacheUpdateAware.class,\r
-                                                                                           listener, props);\r
-            assertNotNull(updateServiceReg);\r
-\r
-            CountDownLatch res = null;\r
-            List<Update> ups = null;\r
-            Update up = null;\r
-            Integer k1 = new Integer(10);\r
-\r
-            /***********************/\r
-            /* CREATE NEW KEY CASE */\r
-            /***********************/\r
-            // Start monitoring the updates\r
-            res = listener.restart(2);\r
-            // modify the cache\r
-            cm23.put(k1, "foo");\r
-            // Wait\r
-            res.await(100L, TimeUnit.SECONDS);\r
-            // Analyze the updates\r
-            ups = listener.getUpdates();\r
-            assertTrue(ups.size() == 2);\r
-            // Validate that first we get an update (yes even in case of a\r
-            // new value added)\r
-            up = ups.get(0);\r
-            assertTrue(up.t.equals(UpdateType.CHANGED));\r
-            assertTrue(up.key.equals(k1));\r
-            assertTrue(up.value.equals("foo"));\r
-            assertTrue(up.cacheName.equals(cache3));\r
-            // Validate that we then get a create\r
-            up = ups.get(1);\r
-            assertTrue(up.t.equals(UpdateType.ADDED));\r
-            assertTrue(up.key.equals(k1));\r
-            assertNull(up.value);\r
-            assertTrue(up.cacheName.equals(cache3));\r
-\r
-            /*******************************/\r
-            /* UPDATE AN EXISTING KEY CASE */\r
-            /*******************************/\r
-            // Start monitoring the updates\r
-            res = listener.restart(1);\r
-            // modify the cache\r
-            cm23.put(k1, "baz");\r
-            // Wait\r
-            res.await(100L, TimeUnit.SECONDS);\r
-            // Analyze the updates\r
-            ups = listener.getUpdates();\r
-            assertTrue(ups.size() == 1);\r
-            // Validate we get an update with expect fields\r
-            up = ups.get(0);\r
-            assertTrue(up.t.equals(UpdateType.CHANGED));\r
-            assertTrue(up.key.equals(k1));\r
-            assertTrue(up.value.equals("baz"));\r
-            assertTrue(up.cacheName.equals(cache3));\r
-\r
-            /********************************/\r
-            /* REMOVAL OF EXISTING KEY CASE */\r
-            /********************************/\r
-            // Start monitoring the updates\r
-            res = listener.restart(1);\r
-            // modify the cache\r
-            cm23.remove(k1);\r
-            // Wait\r
-            res.await(100L, TimeUnit.SECONDS);\r
-            // Analyze the updates\r
-            ups = listener.getUpdates();\r
-            assertTrue(ups.size() == 1);\r
-            // Validate we get a delete with expected fields\r
-            up = ups.get(0);\r
-            assertTrue(up.t.equals(UpdateType.REMOVED));\r
-            assertTrue(up.key.equals(k1));\r
-            assertNull(up.value);\r
-            assertTrue(up.cacheName.equals(cache3));\r
-\r
-            /******************************************************************/\r
-            /* NOW LETS REMOVE THE REGISTRATION AND MAKE SURE NO UPDATS COMES */\r
-            /******************************************************************/\r
-            updateServiceReg.unregister();\r
-            // Start monitoring the updates, noone should come in\r
-            res = listener.restart(1);\r
-\r
-            /***********************/\r
-            /* CREATE NEW KEY CASE */\r
-            /***********************/\r
-            // modify the cache\r
-            cm23.put(k1, "foo");\r
-\r
-            /*******************************/\r
-            /* UPDATE AN EXISTING KEY CASE */\r
-            /*******************************/\r
-            // modify the cache\r
-            cm23.put(k1, "baz");\r
-\r
-            /********************************/\r
-            /* REMOVAL OF EXISTING KEY CASE */\r
-            /********************************/\r
-            // modify the cache\r
-            cm23.remove(k1);\r
-\r
-            // Wait to make sure no updates came in, clearly this is\r
-            // error prone as logic, but cannot find a better way than\r
-            // this to make sure updates didn't get in\r
-            res.await(1L, TimeUnit.SECONDS);\r
-            // Analyze the updates\r
-            ups = listener.getUpdates();\r
-            assertTrue(ups.size() == 0);\r
-        }\r
-\r
-        InetAddress addr = this.clusterDefaultServices.getMyAddress();\r
-        assertNotNull(addr);\r
-\r
-        List<InetAddress> addrList = this.clusterDefaultServices\r
-            .getClusteredControllers();\r
-\r
-        this.clusterDefaultServices.destroyCache(cache1);\r
-        assertFalse(this.clusterDefaultServices.existCache(cache1));\r
-    }\r
-\r
-    private class Update {\r
-        Object key;\r
-        Object value;\r
-        String cacheName;\r
-        UpdateType t;\r
-\r
-        Update (UpdateType t, Object key, Object value, String cacheName) {\r
-            this.t = t;\r
-            this.key = key;\r
-            this.value = value;\r
-            this.cacheName = cacheName;\r
-        }\r
-    }\r
-\r
-    private class CacheAware implements ICacheUpdateAware {\r
-        private CopyOnWriteArrayList<Update> gotUpdates;\r
-        private CountDownLatch latch = null;\r
-\r
-        CacheAware() {\r
-            this.gotUpdates = new CopyOnWriteArrayList<Update>();\r
-        }\r
-\r
-\r
-        /**\r
-         * Restart the monitor of the updates on the CacheAware object\r
-         *\r
-         * @param expectedOperations Number of expected updates\r
-         *\r
-         * @return a countdown latch which will be used to wait till the updates are done\r
-         */\r
-        CountDownLatch restart(int expectedOperations) {\r
-            this.gotUpdates.clear();\r
-            this.latch = new CountDownLatch(expectedOperations);\r
-            return this.latch;\r
-        }\r
-\r
-        List<Update> getUpdates() {\r
-            return this.gotUpdates;\r
-        }\r
-\r
-        @Override\r
-        public void entryCreated(Object key, String cacheName, boolean originLocal) {\r
-            log.debug("CACHE[{}] Got an entry created for key:{}", cacheName, key);\r
-            Update u = new Update(UpdateType.ADDED, key, null, cacheName);\r
-            this.gotUpdates.add(u);\r
-            this.latch.countDown();\r
-        }\r
-\r
-        @Override\r
-        public void entryUpdated(Object key, Object newValue, String cacheName, boolean originLocal) {\r
-            log.debug("CACHE[{}] Got an entry updated for key:{} newValue:{}", cacheName, key, newValue);\r
-            Update u = new Update(UpdateType.CHANGED, key, newValue, cacheName);\r
-            this.gotUpdates.add(u);\r
-            this.latch.countDown();\r
-        }\r
-\r
-        @Override\r
-        public void entryDeleted(Object key, String cacheName, boolean originLocal) {\r
-            log.debug("CACHE[{}] Got an entry delete for key:{}", cacheName, key);\r
-            Update u = new Update(UpdateType.REMOVED, key, null, cacheName);\r
-            this.gotUpdates.add(u);\r
-            this.latch.countDown();\r
-        }\r
-    }\r
-}\r
diff --git a/opendaylight/adsal/clustering/integrationtest/src/test/resources/logback.xml b/opendaylight/adsal/clustering/integrationtest/src/test/resources/logback.xml
deleted file mode 100644 (file)
index 6d9dfda..0000000
+++ /dev/null
@@ -1,12 +0,0 @@
-<configuration scan="true">
-  <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
-    <encoder>
-      <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n
-      </pattern>
-    </encoder>
-  </appender>
-
-  <root level="error">
-    <appender-ref ref="STDOUT" />
-  </root>
-</configuration>
diff --git a/opendaylight/adsal/clustering/services/pom.xml b/opendaylight/adsal/clustering/services/pom.xml
deleted file mode 100644 (file)
index ebe8436..0000000
+++ /dev/null
@@ -1,44 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>clustering.services</artifactId>
-  <version>0.7.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-
-  <dependencies>
-    <dependency>
-      <groupId>org.jboss.spec.javax.transaction</groupId>
-      <artifactId>jboss-transaction-api_1.1_spec</artifactId>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Export-Package>org.opendaylight.controller.clustering.services</Export-Package>
-            <Import-Package>javax.transaction</Import-Package>
-          </instructions>
-          <manifestLocation>${project.basedir}/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/clustering/services/src/main/java/org/opendaylight/controller/clustering/services/CacheConfigException.java b/opendaylight/adsal/clustering/services/src/main/java/org/opendaylight/controller/clustering/services/CacheConfigException.java
deleted file mode 100644 (file)
index e030142..0000000
+++ /dev/null
@@ -1,35 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * @file   CacheConfigException.java
- *
- * @brief  Describe an exception that is raised when the cache being
- * allocated has configuration errors, like mismatch parameters are
- * passed and so on.
- *
- *
- */
-package org.opendaylight.controller.clustering.services;
-
-/**
- * Describe an exception that is raised when the cache being
- * allocated has configuration errors, like mismatch parameters are
- * passed and so on.
- */
-public class CacheConfigException extends Exception {
-    private static final long serialVersionUID = 1L;
-
-    /**
-     * Instantiates a new cache config exception.
-     */
-    public CacheConfigException() {
-        super();
-    }
-}
diff --git a/opendaylight/adsal/clustering/services/src/main/java/org/opendaylight/controller/clustering/services/CacheExistException.java b/opendaylight/adsal/clustering/services/src/main/java/org/opendaylight/controller/clustering/services/CacheExistException.java
deleted file mode 100644 (file)
index 70165cc..0000000
+++ /dev/null
@@ -1,34 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * @file   CacheExistException.java
- *
- * @brief  Describe an exception that is raised when the cache being
- * allocated already exists
- *
- *
- */
-package org.opendaylight.controller.clustering.services;
-
-
-/**
- * Describe an exception that is raised when the cache being
- * allocated already exists
- */
-public class CacheExistException extends Exception {
-    private static final long serialVersionUID = 1L;
-
-    /**
-     * Instantiates a new cache exist exception.
-     */
-    public CacheExistException() {
-        super();
-    }
-}
diff --git a/opendaylight/adsal/clustering/services/src/main/java/org/opendaylight/controller/clustering/services/CacheListenerAddException.java b/opendaylight/adsal/clustering/services/src/main/java/org/opendaylight/controller/clustering/services/CacheListenerAddException.java
deleted file mode 100644 (file)
index 996e0a0..0000000
+++ /dev/null
@@ -1,32 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * @file   CacheListenerAddException.java
- *
- * @brief  Describe an exception that is raised when the cache
- * Listener being added fails for any reason
- *
- */
-package org.opendaylight.controller.clustering.services;
-
-/**
- * Describe an exception that is raised when the cache
- * Listener being added fails for any reason
- */
-public class CacheListenerAddException extends Exception {
-    private static final long serialVersionUID = 1L;
-
-    /**
-     * Instantiates a new cache listener add exception.
-     */
-    public CacheListenerAddException() {
-        super();
-    }
-}
diff --git a/opendaylight/adsal/clustering/services/src/main/java/org/opendaylight/controller/clustering/services/ICacheUpdateAware.java b/opendaylight/adsal/clustering/services/src/main/java/org/opendaylight/controller/clustering/services/ICacheUpdateAware.java
deleted file mode 100644 (file)
index 187309b..0000000
+++ /dev/null
@@ -1,67 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * @file   ICacheUpdateAware.java
- *
- * @brief Interface for getting clustered cache updates
- *
- * Interface that needs to be implemented by the components
- * that want to be informed of an update in a Clustered Cache. The
- * interface need to be registerd in the OSGi service registry with a
- * property "cachenames" which will contains a PropertySet object
- * listing all the caches for which their is interes.
- */
-package org.opendaylight.controller.clustering.services;
-
-/**
- * Interface that needs to be implemented by the components
- * that want to be informed of an update in a Clustered Cache. The
- * interface need to be registerd in the OSGi service registry with a
- * property "cachenames" which will contains a PropertySet object
- * listing all the caches for which their is interes.
- *
- */
-public interface ICacheUpdateAware<K, V> {
-    /**
-     * Invoked when a new entry is available in the cache, the key is
-     * only provided, the value will come as an entryUpdate invocation
-     *
-     * @param key Key for the entry just created
-     * @param cacheName name of the cache for which update has been
-     * received
-     * @param originLocal true if the event is generated from this
-     * node
-     */
-    void entryCreated(K key, String cacheName, boolean originLocal);
-
-    /**
-     * Called anytime a given entry is updated
-     *
-     * @param key Key for the entry modified
-     * @param new_value the new value the key will have
-     * @param cacheName name of the cache for which update has been
-     * received
-     * @param originLocal true if the event is generated from this
-     * node
-     */
-    void entryUpdated(K key, V new_value, String cacheName, boolean originLocal);
-
-    /**
-     * Called anytime a given key is removed from the
-     * ConcurrentHashMap we are listening to.
-     *
-     * @param key Key of the entry removed
-     * @param cacheName name of the cache for which update has been
-     * received
-     * @param originLocal true if the event is generated from this
-     * node
-     */
-    void entryDeleted(K key, String cacheName, boolean originLocal);
-}
diff --git a/opendaylight/adsal/clustering/services/src/main/java/org/opendaylight/controller/clustering/services/IClusterContainerServices.java b/opendaylight/adsal/clustering/services/src/main/java/org/opendaylight/controller/clustering/services/IClusterContainerServices.java
deleted file mode 100644 (file)
index fdf08bc..0000000
+++ /dev/null
@@ -1,30 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * @file   IClusterContainerServices.java
- *
- * @brief  : Set of services an application will expect from the
- * clustering services provider. This interface is per-container and so
- * the container parameter is implicitely known
- *
- * Contract between the applications and the clustering service
- * providers. Container version
- */
-
-package org.opendaylight.controller.clustering.services;
-
-/**
- * Set of services an application will expect from the clustering services
- * provider. This interface is per-container and so the container parameter is
- * implicitly known
- *
- */
-public interface IClusterContainerServices extends IClusterServicesCommon {
-}
diff --git a/opendaylight/adsal/clustering/services/src/main/java/org/opendaylight/controller/clustering/services/IClusterGlobalServices.java b/opendaylight/adsal/clustering/services/src/main/java/org/opendaylight/controller/clustering/services/IClusterGlobalServices.java
deleted file mode 100644 (file)
index e25a953..0000000
+++ /dev/null
@@ -1,30 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * @file   IClusterGlobalServices.java
- *
- * @brief  : Set of services an application will expect from the
- * clustering services provider. This interface is supposed to have
- * Global scope
- *
- * Contract between the applications and the clustering service
- * providers. Global version
- */
-
-package org.opendaylight.controller.clustering.services;
-
-/**
- * Set of services an application will expect from the clustering services
- * provider. This interface is supposed to have Global scope
- *
- */
-public interface IClusterGlobalServices extends IClusterServicesCommon {
-    public void removeContainerCaches(String containerName);
-}
diff --git a/opendaylight/adsal/clustering/services/src/main/java/org/opendaylight/controller/clustering/services/IClusterServices.java b/opendaylight/adsal/clustering/services/src/main/java/org/opendaylight/controller/clustering/services/IClusterServices.java
deleted file mode 100644 (file)
index b3427c7..0000000
+++ /dev/null
@@ -1,312 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * @file   IClusterServices.java
- *
- * @brief  : Set of services an application will expect from the
- * clustering services provider
- *
- * Contract between the applications and the clustering service
- * providers.
- */
-
-package org.opendaylight.controller.clustering.services;
-
-import java.net.InetAddress;
-import java.util.List;
-import java.util.Properties;
-import java.util.Set;
-import java.util.concurrent.ConcurrentMap;
-import java.util.concurrent.TimeUnit;
-
-import javax.transaction.HeuristicMixedException;
-import javax.transaction.HeuristicRollbackException;
-import javax.transaction.NotSupportedException;
-import javax.transaction.RollbackException;
-import javax.transaction.SystemException;
-import javax.transaction.Transaction;
-
-/**
- * Set of services an application will expect from the
- * clustering services provider
- *
- */
-public interface IClusterServices {
-
-    /**
-     * Enumeration of the several modality with which a
-     * ConcurrentHashMap cache can be requested to the clustering
-     * services. The property that can be requested can be multiple.
-     *
-     */
-    public enum cacheMode {
-        /**
-         * Set for a cache that supports transaction that implies that
-         * is a transaction is open on the current thread the data
-         * will not immediately be reflected in the cache but will be
-         * staged till commit or rollback. If the transaction if NOT
-         * open the data will immediately go in the cache without
-         * staging.
-         */
-        TRANSACTIONAL,
-        /**
-         * Set on a cache that doesn't want to support
-         * transaction, so irrespective of the fact that we are in
-         * the middle of a transaction or no data will be
-         * immediately committed in the cache.
-         *
-         */
-        NON_TRANSACTIONAL,
-        /**
-         * Set on a cache that can transfer the updates asynchronously from the
-         * calling thread. The caller when doing put/clear/remove cannot expect
-         * that the operation has happened clusterwide
-         */
-        ASYNC,
-        /**
-         * Set on a cache that transfer the updates synchronously to the calling
-         * thread so when getting back the operation is supposed to have
-         * completed on all the cluster nodes. Slow but safe.
-         */
-        SYNC;
-    }
-
-    /**
-     * Enumeration of the several properties that a cache can carry
-     *
-     */
-    public enum cacheProps {
-        /**
-         * The property returned describe the characteristics of the
-         * transaction setup for the cache it was retrieved.
-         */
-        TRANSACTION_PROP,
-        /**
-         * The property returned report the clustering
-         * characteristics of the cache for which property was
-         * queried.
-         */
-        CLUSTERING_PROP,
-        /**
-         * The property returned reports the locking
-         * characteristics of the cache for which the property was
-         * queried
-         */
-        LOCKING_PROP;
-    }
-
-    /**
-     * Method that will create a new named cache per-container. The data
-     * structure if already present will cause an exception to be
-     * thrown to the caller.
-     *
-     * @param containerName Container to which the datastructure is associated
-     * @param cacheName Name of the ConcurrentHashMap to create
-     * @param cMode Mode of the cache that need to be retrieved. This
-     * is a set such that more than one property can be provided, of
-     * course contrasting requirements will not be accepted and in
-     * that case an exception is thrown
-     *
-     * @return ConcurrentHashMap to be used to modify the data structure
-     */
-    ConcurrentMap<?, ?> createCache(String containerName, String cacheName,
-            Set<cacheMode> cMode) throws CacheExistException,
-            CacheConfigException;
-
-    /**
-     * Method that will retrieve and return the handle to modify a
-     * data structire distributed via clustering services. The
-     * datastructure shall already have been created else a null
-     * reference will be returned.
-     *
-     * @param containerName Container to which the datastructure is associated
-     * @param cacheName Name of the ConcurrentHashMap to retrieve
-     *
-     * @return ConcurrentHashMap to be used to modify the data structure
-     */
-    ConcurrentMap<? extends Object, ? extends Object> getCache(String containerName, String cacheName);
-
-    /**
-     * Destroy a cachename given containerName/cachename, if doesn't exist
-     * the function does nothing. If the datastructure exists, the
-     * whole cluster will destroy the instance
-     *
-     * @param containerName Container to which the datastructure is associated
-     * @param cacheName Name of the ConcurrentHashMap to destroy
-     */
-    void destroyCache(String containerName, String cacheName);
-
-    /**
-     * Function to test the existance of a cache with a given name already
-     *
-     * @param containerName Container to which the datastructure is associated
-     * @param cacheName Name of the ConcurrentHashMap to destroy
-     *
-     * @return true if exists already, false otherwise
-     */
-    boolean existCache(String containerName, String cacheName);
-
-    /**
-     * Return the list of all teh caches registered with a container
-     *
-     * @param containerName Container for which we want to list all the caches registered
-     *
-     * @return The set of names, expressed as strings
-     */
-    Set<String> getCacheList(String containerName);
-
-    /**
-     * Return a list of properties that caracterize the cache
-     *
-     * @param containerName Name of the container where data structure resides
-     * @param cacheName Name of the cache
-     *
-     * @return The list of properties related to the cache
-     */
-    Properties getCacheProperties(String containerName, String cacheName);
-
-    /**
-     * Register an update handler for a given containerName/cacheName
-     * shared data structure. Multiple listeners are possible.
-     *
-     * @param containerName Container to which the datastructure is associated
-     * @param cacheName Name of the ConcurrentHashMap for which we
-     * want to register the listener
-     * @param u Interface to invoke when the updates are received
-     */
-    void addListener(String containerName, String cacheName, IGetUpdates<?, ?> u)
-            throws CacheListenerAddException;
-
-    /**
-     * Return a set of interfaces that are interesteed to listen to
-     * updates coming for a given datastructure shared via clustering
-     * services.
-     *
-     * @param containerName Container to which the datastructure is associated
-     * @param cacheName Name of the ConcurrentHashMap for which we
-     * want to retrieve the listener
-     */
-    Set<IGetUpdates<?, ?>> getListeners(String containerName, String cacheName);
-
-    /**
-     * UN-Register an update handler for a given containerName/cacheName
-     * shared data structure. Multiple listeners are possible.
-     *
-     * @param containerName Container to which the datastructure is associated
-     * @param cacheName Name of the ConcurrentHashMap for which we
-     * want to un-register the listener
-     * @param u Interface to un-register
-     */
-    void removeListener(String containerName, String cacheName,
-            IGetUpdates<?, ?> u);
-
-    /**
-     * Begin a transaction covering with all the data structures/HW
-     * updates. One transaction per-thread can be opened at the
-     * most, that means if multiple thread are available, multiple
-     * transactions can be outstanding.
-     *
-     */
-    void tbegin() throws NotSupportedException, SystemException;
-
-    /**
-     * tbegin with a timeout
-     * @see IClusterServices#tbegin
-     * @param timeout the transaction timeout
-     * @param unit TimeUnit for the timeout
-     * @throws NotSupportedException
-     * @throws SystemException
-     */
-    void tbegin(long timeout, TimeUnit unit) throws NotSupportedException, SystemException;
-
-    /**
-     * Commit a transaction covering all the data structures/HW updates.
-     */
-    void tcommit() throws RollbackException, HeuristicMixedException,
-            HeuristicRollbackException, java.lang.SecurityException,
-            java.lang.IllegalStateException, SystemException;
-
-    /**
-     * Rollback a transaction covering all the data structures/HW updates
-     */
-    void trollback() throws java.lang.IllegalStateException,
-            java.lang.SecurityException, SystemException;
-
-    /**
-     * Return the javax.transaction.Transaction associated with this thread
-     *
-     *
-     * @return Return the current transaction associated with this thread
-     */
-    Transaction tgetTransaction() throws SystemException;
-
-    /**
-     * @deprecated
-     * Function that says if we are standby in the 1-1 redundancy with
-     * active/standby model. The API is not encouraged hence is
-     * deprecated. It is supposed to be used as a stop-gap till the
-     * active-standby goal is achieved. The only guys that are
-     * supposed to use are:
-     * - southbound layer, should not listen on the OF port if standby
-     * - jetty configuration, on standby jetty should redirect calls
-     * to the active.
-     *
-     * @return true if the role is the one of standby, else false
-     */
-    @Deprecated
-    boolean amIStandby();
-
-    /**
-     * @deprecated
-     * Get the InetAddress of the active controller for the
-     * active-standby case, where the standby controller has to
-     * redirect the HTTP requests received from applications layer
-     *
-     * @return Address of the active controller
-     */
-    @Deprecated
-    InetAddress getActiveAddress();
-
-    /**
-     * Get the InetAddress of the all the controllers that make up this
-     * Cluster
-     *
-     * @return List of InetAddress'es of all the controllers
-     */
-    List<InetAddress> getClusteredControllers();
-
-    /**
-     * Get the InetAddress of this Controller as seen by the Cluster Manager
-     *
-     * @return InetAddress of this Controller as seen by the Cluster Manager.
-     */
-    InetAddress getMyAddress();
-
-    /**
-     * @deprecated
-     * Register a listener to the event of ChangeRole, raised every
-     * time there is a change in the role of active or standby.
-     *
-     * @param i Interface that will be called when the Role Change happens
-     */
-    @Deprecated
-    void listenRoleChange(IListenRoleChange i)
-            throws ListenRoleChangeAddException;
-
-    /**
-     * @deprecated
-     * UN-Register a listener to the event of ChangeRole, raised every
-     * time there is a change in the role of active or standby.
-     *
-     * @param i Interface that will be called when the Role Change happens
-     */
-    @Deprecated
-    void unlistenRoleChange(IListenRoleChange i);
-}
diff --git a/opendaylight/adsal/clustering/services/src/main/java/org/opendaylight/controller/clustering/services/IClusterServicesCommon.java b/opendaylight/adsal/clustering/services/src/main/java/org/opendaylight/controller/clustering/services/IClusterServicesCommon.java
deleted file mode 100644 (file)
index 7ea86c6..0000000
+++ /dev/null
@@ -1,190 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * @file   IClusterServicesCommon.java
- *
- * @brief  : Set of services an application will expect from the
- * clustering services provider. This interface is going to be the
- * base for per-container and Global services and so the container
- * parameter is omitted but who uses knows about it
- *
- * Contract between the applications and the clustering service
- * providers. Common version
- */
-
-package org.opendaylight.controller.clustering.services;
-
-import java.net.InetAddress;
-import java.util.List;
-import java.util.Properties;
-import java.util.Set;
-import java.util.concurrent.ConcurrentMap;
-import java.util.concurrent.TimeUnit;
-
-import javax.transaction.HeuristicMixedException;
-import javax.transaction.HeuristicRollbackException;
-import javax.transaction.NotSupportedException;
-import javax.transaction.RollbackException;
-import javax.transaction.SystemException;
-import javax.transaction.Transaction;
-
-/**
- * This WILL NOT BE USED DIRECTLY, but VIA SUBCLASS
- *
- * Set of services and application will expect from the clustering services
- * provider. This interface is going to be the base for per-container and Global
- * services and so the container parameter is omitted but who uses knows about
- * it
- *
- */
-public interface IClusterServicesCommon {
-    /**
-     * Method that will create a new named cache. The data
-     * structure if already present will cause an exception to be
-     * thrown to the caller.
-     *
-     * @param cacheName Name of the ConcurrentHashMap to create
-     * @param cMode Mode of the cache that need to be retrieved. This
-     * is a set such that more than one property can be provided, of
-     * course contrasting requirements will not be accepted and in
-     * that case an exception is thrown
-     *
-     * @return ConcurrentHashMap to be used to modify the data structure
-     */
-    ConcurrentMap<?, ?> createCache(String cacheName,
-            Set<IClusterServices.cacheMode> cMode) throws CacheExistException,
-            CacheConfigException;
-
-    /**
-     * Method that will retrieve and return the handle to modify a
-     * data structire distributed via clustering services. The
-     * datastructure shall already have been created else a null
-     * reference will be returned.
-     *
-     * @param cacheName Name of the ConcurrentHashMap to retrieve
-     *
-     * @return ConcurrentHashMap to be used to modify the data structure
-     */
-    ConcurrentMap<?, ?> getCache(String cacheName);
-
-    /**
-     * Destroy a cachename given cachename, if doesn't exist
-     * the function does nothing. If the datastructure exists, the
-     * whole cluster will destroy the instance
-     *
-     * @param cacheName Name of the ConcurrentHashMap to destroy
-     */
-    void destroyCache(String cacheName);
-
-    /**
-     * Function to test the existance of a cache with a given name already
-     *
-     * @param cacheName Name of the ConcurrentHashMap to destroy
-     *
-     * @return true if exists already, false otherwise
-     */
-    boolean existCache(String cacheName);
-
-    /**
-     * Return the list of all teh caches registered in the context of
-     * the called
-     *
-     *
-     * @return The set of names, expressed as strings
-     */
-    Set<String> getCacheList();
-
-    /**
-     * Return a list of properties that caracterize the cache
-     *
-     * @param cacheName Name of the cache
-     *
-     * @return The list of properties related to the cache
-     */
-    Properties getCacheProperties(String cacheName);
-
-    /**
-     * Begin a transaction covering with all the data structures/HW
-     * updates. One transaction per-thread can be opened at the
-     * most, that means if multiple thread are available, multiple
-     * transactions can be outstanding.
-     *
-     */
-    void tbegin() throws NotSupportedException, SystemException;
-
-    /**
-     * tbegin with a timeout
-     * @see IClusterServicesCommon#tbegin
-     * @param timeout the transaction timeout
-     * @param unit TimeUnit for the timeout
-     * @throws NotSupportedException
-     * @throws SystemException
-     */
-    void tbegin(long timeout, TimeUnit unit) throws NotSupportedException, SystemException;
-
-    /**
-     * Commit a transaction covering all the data structures/HW updates.
-     */
-    void tcommit() throws RollbackException, HeuristicMixedException,
-            HeuristicRollbackException, java.lang.SecurityException,
-            java.lang.IllegalStateException, SystemException;
-
-    /**
-     * Rollback a transaction covering all the data structures/HW updates
-     */
-    void trollback() throws java.lang.IllegalStateException,
-            java.lang.SecurityException, SystemException;
-
-    /**
-     * Return the javax.transaction.Transaction associated with this thread
-     *
-     *
-     * @return Return the current transaction associated with this thread
-     */
-    Transaction tgetTransaction() throws SystemException;
-
-    /**
-     *
-     * Get the InetAddress of the coordinator controller in the cluster
-     *
-     * @return Address of the coordinator controller
-     */
-    InetAddress getCoordinatorAddress();
-
-    /**
-     * Get the InetAddress of the all the controllers that make up this
-     * Cluster
-     *
-     * @return List of InetAddress'es of all the controllers
-     */
-    List<InetAddress> getClusteredControllers();
-
-    /**
-     * Get the InetAddress of this Controller as seen by the Cluster Manager
-     *
-     * @return InetAddress of this Controller as seen by the Cluster Manager.
-     */
-    InetAddress getMyAddress();
-
-    /**
-     * Function that is used to know if the node on which is called is
-     * the cluster coordinator. The API is useful in scenario where
-     * the same logic is not worthed to be replicated on multiple
-     * nodes in the cluster and one can cook it up for all the
-     * others. In this scenario running the logic on the coordinator
-     * make sense, this of course implies logics that are not heavy
-     * and don't need to be scaled out linearly with the size of the
-     * cluster.
-     *
-     * @return true if the node on which the API is called is the
-     * coordinator for the cluster
-     */
-    boolean amICoordinator();
-}
diff --git a/opendaylight/adsal/clustering/services/src/main/java/org/opendaylight/controller/clustering/services/ICoordinatorChangeAware.java b/opendaylight/adsal/clustering/services/src/main/java/org/opendaylight/controller/clustering/services/ICoordinatorChangeAware.java
deleted file mode 100644 (file)
index 5d0edd8..0000000
+++ /dev/null
@@ -1,32 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * @file   ICoordinatorChangeAware.java
- *
- *
- * @brief  Interface that needs to be implemented by who wants to be
- * notified of coordinator role change
- *
- */
-package org.opendaylight.controller.clustering.services;
-
-/**
- * Interface that needs to be implemented by who wants to be
- * notified of coordinator role change
- *
- */
-public interface ICoordinatorChangeAware {
-
-    /**
-     * Function that will be called when there is the event of
-     * coordinator change in the cluster.
-     */
-    void coordinatorChanged();
-}
diff --git a/opendaylight/adsal/clustering/services/src/main/java/org/opendaylight/controller/clustering/services/IGetUpdates.java b/opendaylight/adsal/clustering/services/src/main/java/org/opendaylight/controller/clustering/services/IGetUpdates.java
deleted file mode 100644 (file)
index 1f9a45a..0000000
+++ /dev/null
@@ -1,59 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * @file   IGetUpdates.java
- *
- * @brief  Interface that needs to be implemented by the listeners of
- * updates received on data structure shared in the cluster
- *
- * Interface that needs to be implemented by the listeners of updates
- * received on data structure shared in the cluster
- */
-package org.opendaylight.controller.clustering.services;
-
-/**
- * @deprecated for internal use
- * Interface that needs to be implemented by the listeners of
- * updates received on data structure shared in the cluster
- */
-public interface IGetUpdates<K, V> {
-    /**
-     * Invoked when a new entry is available in the cache, the key is
-     * only provided, the value will come as an entryUpdate invocation
-     *
-     * @param key Key for the entry just created
-     * @param containerName container for which the update has been received
-     * @param cacheName name of the cache for which update has been received
-     */
-    void entryCreated(K key, String containerName, String cacheName,
-            boolean local);
-
-    /**
-     * Called anytime a given entry is updated
-     *
-     * @param key Key for the entry modified
-     * @param new_value the new value the key will have
-     * @param containerName container for which the update has been received
-     * @param cacheName name of the cache for which update has been received
-     */
-    void entryUpdated(K key, V new_value, String containerName,
-            String cacheName, boolean local);
-
-    /**
-     * Called anytime a given key is removed from the
-     * ConcurrentHashMap we are listening to.
-     *
-     * @param key Key of the entry removed
-     * @param containerName container for which the update has been received
-     * @param cacheName name of the cache for which update has been received
-     */
-    void entryDeleted(K key, String containerName, String cacheName,
-            boolean originLocal);
-}
diff --git a/opendaylight/adsal/clustering/services/src/main/java/org/opendaylight/controller/clustering/services/IListenRoleChange.java b/opendaylight/adsal/clustering/services/src/main/java/org/opendaylight/controller/clustering/services/IListenRoleChange.java
deleted file mode 100644 (file)
index b8798e6..0000000
+++ /dev/null
@@ -1,41 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * @file   IListenRoleChange.java
- *
- *
- * @brief  Interface that needs to be implemented by who wants to be
- * notified of new active change
- *
- * @deprecated
- *
- * Interface that needs to be implemented by who wants to be notified
- * of newly active taking over. Interface that is supposed to be
- * short-lived and will be removed as soon as active-standby goal is reached.
- */
-package org.opendaylight.controller.clustering.services;
-
-/**
- * Interface that needs to be implemented by who wants to be notified
- * of newly active taking over. Interface that is supposed to be
- * short-lived and will be removed as soon as active-standby goal is reached.
- *
- */
-public interface IListenRoleChange {
-
-    /**
-     * @deprecated
-     * Function that will be called when a new active is
-     * available. This function is supposed only to be of use till
-     * active-standby milestone is reached, after will be removed.
-     *
-     */
-    void newActiveAvailable();
-}
diff --git a/opendaylight/adsal/clustering/services/src/main/java/org/opendaylight/controller/clustering/services/ListenRoleChangeAddException.java b/opendaylight/adsal/clustering/services/src/main/java/org/opendaylight/controller/clustering/services/ListenRoleChangeAddException.java
deleted file mode 100644 (file)
index dd2585b..0000000
+++ /dev/null
@@ -1,33 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * @file   ListenRoleChangeAddException.java
- *
- * @brief  Describe an exception that is raised when the cache
- * Listener being added fails for any reason
- *
- */
-package org.opendaylight.controller.clustering.services;
-
-/**
- * @deprecated for internal use
- * The Class ListenRoleChangeAddException.
- */
-@Deprecated
-public class ListenRoleChangeAddException extends Exception {
-    private static final long serialVersionUID = 1L;
-
-    /**
-     * Instantiates a new listen role change add exception.
-     */
-    public ListenRoleChangeAddException() {
-        super();
-    }
-}
diff --git a/opendaylight/adsal/clustering/services_implementation/pom.xml b/opendaylight/adsal/clustering/services_implementation/pom.xml
deleted file mode 100644 (file)
index d3b0578..0000000
+++ /dev/null
@@ -1,152 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>clustering.services-implementation</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <properties>
-    <!-- Sonar properties using jacoco to retrieve integration test results -->
-    <sonar.dynamicAnalysis>reuseReports</sonar.dynamicAnalysis>
-    <sonar.jacoco.Reportpath>target/jacoco.exec</sonar.jacoco.Reportpath>
-    <sonar.jacoco.itReportPath>target/jacoco-it.exec</sonar.jacoco.itReportPath>
-  </properties>
-  <dependencies>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>org.apache.felix.gogo.runtime</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.infinispan</groupId>
-      <artifactId>infinispan-core</artifactId>
-      <version>6.0.2.Final</version>
-    </dependency>
-    <dependency>
-      <groupId>org.jboss.jbossts.jta</groupId>
-      <artifactId>narayana-jta</artifactId>
-      <version>4.17.7.Final</version>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>clustering.services</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>commons.logback_settings</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-  </dependencies>
-  <build>
-    <pluginManagement>
-      <plugins>
-        <plugin>
-          <groupId>org.jacoco</groupId>
-          <artifactId>jacoco-maven-plugin</artifactId>
-          <version>${jacoco.version}</version>
-        </plugin>
-      </plugins>
-    </pluginManagement>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Import-Package>org.slf4j,
-              !org.apache.logging.log4j.*,
-              !bsh*,
-              !net.jcip.*,
-              !javax.swing,
-              !org.hornetq.*,
-              !org.jboss.*,
-              javax.transaction,
-              org.opendaylight.controller.clustering.services,
-              org.opendaylight.controller.sal.core,*</Import-Package>
-            <Bundle-Activator>org.opendaylight.controller.clustering.services_implementation.internal.Activator</Bundle-Activator>
-            <!-- Add in the DynamicImport-Package ONLY the packages that -->
-            <!-- contains types that MUST be unmarshalled by the -->
-            <!-- infinispan. They need to be wired at runtime even during -->
-            <!-- the bundle is already RESOLVED, but at the same time if -->
-            <!-- those are missing the bundle will still come up, this is -->
-            <!-- why those dependencies ends in the DynamicImport-Package -->
-            <!-- rather in the Import-Package -->
-            <DynamicImport-Package>*</DynamicImport-Package>
-            <Embed-Dependency>infinispan-core,infinispan-commons,jgroups,jboss-marshalling-river,jboss-marshalling,jboss-logging,staxmapper,narayana-jta;type=!pom;inline=false</Embed-Dependency>
-            <Embed-Transitive>true</Embed-Transitive>
-          </instructions>
-          <manifestLocation>${project.basedir}/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-      <plugin>
-        <groupId>org.apache.maven.plugins</groupId>
-        <artifactId>maven-enforcer-plugin</artifactId>
-        <version>${enforcer.version}</version>
-        <executions>
-          <execution>
-            <id>enforce-banned-dependencies</id>
-            <goals>
-              <goal>enforce</goal>
-            </goals>
-            <configuration>
-              <rules>
-                <bannedDependencies>
-                  <excludes>
-                    <exclude>org.infinispan:infinispan-core:*</exclude>
-                  </excludes>
-                  <includes>
-                    <include>org.infinispan:infinispan-core:[6.0.2.Final]</include>
-                  </includes>
-                </bannedDependencies>
-              </rules>
-              <fail>true</fail>
-            </configuration>
-          </execution>
-        </executions>
-      </plugin>
-      <plugin>
-        <groupId>org.jacoco</groupId>
-        <artifactId>jacoco-maven-plugin</artifactId>
-        <configuration>
-          <includes>
-            <include>org.opendaylight.controller.*</include>
-          </includes>
-        </configuration>
-        <executions>
-          <execution>
-            <id>pre-test</id>
-            <goals>
-              <goal>prepare-agent</goal>
-            </goals>
-          </execution>
-          <execution>
-            <id>post-test</id>
-            <goals>
-              <goal>report</goal>
-            </goals>
-            <phase>test</phase>
-          </execution>
-        </executions>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/clustering/services_implementation/src/main/java/org/opendaylight/controller/clustering/services_implementation/internal/Activator.java b/opendaylight/adsal/clustering/services_implementation/src/main/java/org/opendaylight/controller/clustering/services_implementation/internal/Activator.java
deleted file mode 100644 (file)
index 1c6a5db..0000000
+++ /dev/null
@@ -1,139 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.clustering.services_implementation.internal;
-
-import org.opendaylight.controller.sal.core.ComponentActivatorAbstractBase;
-
-import org.opendaylight.controller.clustering.services.ICacheUpdateAware;
-import org.opendaylight.controller.clustering.services.IClusterContainerServices;
-import org.opendaylight.controller.clustering.services.IClusterGlobalServices;
-import org.opendaylight.controller.clustering.services.IClusterServices;
-import org.opendaylight.controller.clustering.services.ICoordinatorChangeAware;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-import org.apache.felix.dm.Component;
-
-public class Activator extends ComponentActivatorAbstractBase {
-    protected static final Logger logger = LoggerFactory
-            .getLogger(Activator.class);
-
-
-
-    /**
-     * Function that is used to communicate to dependency manager the
-     * list of known implementations for services inside a container
-     *
-     *
-     * @return An array containing all the CLASS objects that will be
-     * instantiated in order to get an fully working implementation
-     * Object
-     */
-    @Override
-    public Object[] getGlobalImplementations() {
-        Object[] res = { ClusterManager.class, ClusterGlobalManager.class, ClusterManagerCLI.class };
-        return res;
-    }
-
-    /**
-     * Function that is used to communicate to dependency manager the
-     * list of known implementations for services inside a container
-     *
-     *
-     * @return An array containing all the CLASS objects that will be
-     * instantiated in order to get an fully working implementation
-     * Object
-     */
-    @Override
-    public Object[] getImplementations() {
-        Object[] res = { ClusterContainerManager.class };
-        return res;
-    }
-
-    /**
-     * Function that is called when configuration of the dependencies
-     * is required.
-     *
-     * @param c dependency manager Component object, used for
-     * configuring the dependencies exported and imported
-     * @param imp Implementation class that is being configured,
-     * needed as long as the same routine can configure multiple
-     * implementations
-     * @param containerName The containerName being configured, this allow
-     * also optional per-container different behavior if needed, usually
-     * should not be the case though.
-     */
-    @Override
-    public void configureInstance(Component c, Object imp, String containerName) {
-        if (imp.equals(ClusterContainerManager.class)) {
-            c.setInterface(new String[] { IClusterContainerServices.class.getName() },
-                           null);
-
-            c.add(createServiceDependency()
-                  .setService(IClusterServices.class)
-                  .setCallbacks("setClusterService", "unsetClusterService")
-                  .setRequired(true));
-
-            // CacheUpdate services will be none or many so the
-            // dependency is optional
-            c.add(createContainerServiceDependency(containerName)
-                  .setService(ICacheUpdateAware.class)
-                  .setCallbacks("setCacheUpdateAware", "unsetCacheUpdateAware")
-                  .setRequired(false));
-
-            // Coordinator change event can be one or many so
-            // dependency is optional
-            c.add(createContainerServiceDependency(containerName)
-                  .setService(ICoordinatorChangeAware.class)
-                  .setCallbacks("setCoordinatorChangeAware", "unsetCoordinatorChangeAware")
-                  .setRequired(false));
-        }
-    }
-
-    /**
-     * Function that is called when configuration of the dependencies
-     * is required.
-     *
-     * @param c dependency manager Component object, used for
-     * configuring the dependencies exported and imported
-     * @param imp Implementation class that is being configured,
-     * needed as long as the same routine can configure multiple
-     * implementations
-     */
-    @Override
-    public void configureGlobalInstance(Component c, Object imp) {
-        if (imp.equals(ClusterManager.class)) {
-            // export the service for Apps and Plugins
-            c.setInterface(new String[] { IClusterServices.class.getName() }, null);
-        }
-
-        if (imp.equals(ClusterGlobalManager.class)) {
-            c.setInterface(new String[] { IClusterGlobalServices.class.getName() }, null);
-
-            c.add(createServiceDependency()
-                  .setService(IClusterServices.class)
-                  .setCallbacks("setClusterService", "unsetClusterService")
-                  .setRequired(true));
-
-            // CacheUpdate services will be none or many so the
-            // dependency is optional
-            c.add(createServiceDependency()
-                  .setService(ICacheUpdateAware.class)
-                  .setCallbacks("setCacheUpdateAware", "unsetCacheUpdateAware")
-                  .setRequired(false));
-
-            // Coordinator change event can be one or many so
-            // dependency is optional
-            c.add(createServiceDependency()
-                  .setService(ICoordinatorChangeAware.class)
-                  .setCallbacks("setCoordinatorChangeAware", "unsetCoordinatorChangeAware")
-                  .setRequired(false));
-        }
-    }
-}
diff --git a/opendaylight/adsal/clustering/services_implementation/src/main/java/org/opendaylight/controller/clustering/services_implementation/internal/CacheListenerContainer.java b/opendaylight/adsal/clustering/services_implementation/src/main/java/org/opendaylight/controller/clustering/services_implementation/internal/CacheListenerContainer.java
deleted file mode 100644 (file)
index c3c0621..0000000
+++ /dev/null
@@ -1,73 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.clustering.services_implementation.internal;
-
-import org.infinispan.notifications.Listener;
-import org.infinispan.notifications.cachelistener.annotation.CacheEntryCreated;
-import org.infinispan.notifications.cachelistener.annotation.CacheEntryModified;
-import org.infinispan.notifications.cachelistener.annotation.CacheEntryRemoved;
-import org.infinispan.notifications.cachelistener.event.CacheEntryCreatedEvent;
-import org.infinispan.notifications.cachelistener.event.CacheEntryModifiedEvent;
-import org.infinispan.notifications.cachelistener.event.CacheEntryRemovedEvent;
-import org.opendaylight.controller.clustering.services.IGetUpdates;
-
-@Listener
-public class CacheListenerContainer {
-    private IGetUpdates toBeUpdated;
-    private String containerName;
-    private String cacheName;
-
-    public CacheListenerContainer(IGetUpdates i, String containerName,
-            String cacheName) {
-        this.toBeUpdated = i;
-        this.containerName = containerName;
-        this.cacheName = cacheName;
-    }
-
-    public IGetUpdates whichListener() {
-        return this.toBeUpdated;
-    }
-
-    @CacheEntryCreated
-    public void observeCreate(CacheEntryCreatedEvent<Object, Object> event) {
-        if (event.isPre()) {
-            return;
-        }
-
-        if (this.toBeUpdated != null) {
-            this.toBeUpdated.entryCreated(event.getKey(), this.containerName,
-                    this.cacheName, event.isOriginLocal());
-        }
-    }
-
-    @CacheEntryModified
-    public void observeModify(CacheEntryModifiedEvent<Object, Object> event) {
-        if (event.isPre()) {
-            return;
-        }
-
-        if (this.toBeUpdated != null) {
-            this.toBeUpdated.entryUpdated(event.getKey(), event.getValue(),
-                    this.containerName, this.cacheName, event.isOriginLocal());
-        }
-    }
-
-    @CacheEntryRemoved
-    public void observeRemove(CacheEntryRemovedEvent<Object, Object> event) {
-        if (event.isPre()) {
-            return;
-        }
-
-        if (this.toBeUpdated != null) {
-            this.toBeUpdated.entryDeleted(event.getKey(), this.containerName,
-                    this.cacheName, event.isOriginLocal());
-        }
-    }
-}
diff --git a/opendaylight/adsal/clustering/services_implementation/src/main/java/org/opendaylight/controller/clustering/services_implementation/internal/ClassResolver.java b/opendaylight/adsal/clustering/services_implementation/src/main/java/org/opendaylight/controller/clustering/services_implementation/internal/ClassResolver.java
deleted file mode 100644 (file)
index 521a773..0000000
+++ /dev/null
@@ -1,46 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others. All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.clustering.services_implementation.internal;
-
-import java.lang.ref.WeakReference;
-
-import org.jboss.marshalling.ContextClassResolver;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-public final class ClassResolver extends ContextClassResolver {
-    private WeakReference<ClassLoader> osgiClassLoader = null;
-    private static final Logger logger = LoggerFactory.getLogger(ClassResolver.class);
-
-    public ClassResolver() {
-        ClassLoader cl = this.getClass()
-                .getClassLoader();
-        if (cl != null) {
-            this.osgiClassLoader = new WeakReference<ClassLoader>(cl);
-            logger.trace("Acquired weak reference to OSGi classLoader {}", cl);
-        }
-    }
-
-    @Override
-    protected ClassLoader getClassLoader() {
-        ClassLoader ret = null;
-        if (this.osgiClassLoader != null) {
-            ret = this.osgiClassLoader.get();
-            if (ret != null) {
-                if (logger.isTraceEnabled()) {
-                    logger.trace("Returning OSGi class loader {}", ret);
-                }
-                return ret;
-            }
-        }
-
-        logger.warn("Could not resolve classloader!");
-        return ret;
-    }
-}
diff --git a/opendaylight/adsal/clustering/services_implementation/src/main/java/org/opendaylight/controller/clustering/services_implementation/internal/ClusterContainerManager.java b/opendaylight/adsal/clustering/services_implementation/src/main/java/org/opendaylight/controller/clustering/services_implementation/internal/ClusterContainerManager.java
deleted file mode 100644 (file)
index 9496c33..0000000
+++ /dev/null
@@ -1,16 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.clustering.services_implementation.internal;
-
-import org.opendaylight.controller.clustering.services.IClusterContainerServices;
-
-public class ClusterContainerManager extends ClusterManagerCommon implements
-        IClusterContainerServices {
-}
diff --git a/opendaylight/adsal/clustering/services_implementation/src/main/java/org/opendaylight/controller/clustering/services_implementation/internal/ClusterGlobalManager.java b/opendaylight/adsal/clustering/services_implementation/src/main/java/org/opendaylight/controller/clustering/services_implementation/internal/ClusterGlobalManager.java
deleted file mode 100644 (file)
index e05f9df..0000000
+++ /dev/null
@@ -1,54 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.clustering.services_implementation.internal;
-
-import java.util.Map;
-
-import org.opendaylight.controller.clustering.services.ICacheUpdateAware;
-import org.opendaylight.controller.clustering.services.IClusterGlobalServices;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-public class ClusterGlobalManager
-    extends ClusterManagerCommon
-    implements IClusterGlobalServices {
-    protected static final Logger logger = LoggerFactory.getLogger(ClusterGlobalManager.class);
-
-    @Override
-    void setCacheUpdateAware(Map props, ICacheUpdateAware s) {
-        logger.trace("setCacheUpdateAware: {}",s);
-        if (props.get("containerName") != null) {
-            // If we got a reference with the containerName property
-            // that is not what we are looking for, so filter it out.
-            return;
-        }
-        super.setCacheUpdateAware(props, s);
-    }
-
-    @Override
-    void unsetCacheUpdateAware(Map props, ICacheUpdateAware s) {
-        logger.trace("unsetCacheUpdateAware: {}",s);
-        if (props.get("containerName") != null) {
-            // If we got a reference with the containerName property
-            // that is not what we are looking for, so filter it out.
-            return;
-        }
-        super.unsetCacheUpdateAware(props, s);
-    }
-
-    @Override
-    public void removeContainerCaches(String containerName) {
-        logger.debug("Removing caches for container {}", containerName);
-        for (String cacheName : clusterService.getCacheList(containerName)) {
-            clusterService.destroyCache(containerName, cacheName);
-        }
-    }
-
-}
diff --git a/opendaylight/adsal/clustering/services_implementation/src/main/java/org/opendaylight/controller/clustering/services_implementation/internal/ClusterManager.java b/opendaylight/adsal/clustering/services_implementation/src/main/java/org/opendaylight/controller/clustering/services_implementation/internal/ClusterManager.java
deleted file mode 100644 (file)
index 4febcd0..0000000
+++ /dev/null
@@ -1,783 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.clustering.services_implementation.internal;
-
-import java.net.InetAddress;
-import java.net.NetworkInterface;
-import java.net.SocketException;
-import java.net.UnknownHostException;
-import java.net.URI;
-import java.net.URISyntaxException;
-import java.util.ArrayList;
-import java.util.EnumSet;
-import java.util.Enumeration;
-import java.util.HashSet;
-import java.util.List;
-import java.util.Properties;
-import java.util.Set;
-import java.util.StringTokenizer;
-import java.util.concurrent.ConcurrentMap;
-import java.util.concurrent.TimeUnit;
-
-import javax.transaction.HeuristicMixedException;
-import javax.transaction.HeuristicRollbackException;
-import javax.transaction.NotSupportedException;
-import javax.transaction.RollbackException;
-import javax.transaction.SystemException;
-import javax.transaction.Transaction;
-import javax.transaction.TransactionManager;
-
-import org.infinispan.Cache;
-import org.infinispan.configuration.cache.Configuration;
-import org.infinispan.configuration.cache.ConfigurationBuilder;
-import org.infinispan.configuration.global.GlobalConfigurationBuilder;
-import org.infinispan.configuration.parsing.ConfigurationBuilderHolder;
-import org.infinispan.configuration.parsing.ParserRegistry;
-import org.infinispan.manager.DefaultCacheManager;
-import org.infinispan.manager.EmbeddedCacheManager;
-import org.infinispan.notifications.Listener;
-import org.infinispan.notifications.cachemanagerlistener.annotation.ViewChanged;
-import org.infinispan.notifications.cachemanagerlistener.event.ViewChangedEvent;
-import org.infinispan.remoting.transport.Address;
-import org.infinispan.remoting.transport.Transport;
-import org.infinispan.remoting.transport.jgroups.JGroupsAddress;
-import org.infinispan.remoting.transport.jgroups.JGroupsTransport;
-import org.jgroups.Channel;
-import org.jgroups.Event;
-import org.jgroups.stack.GossipRouter;
-import org.opendaylight.controller.clustering.services.CacheConfigException;
-import org.opendaylight.controller.clustering.services.CacheExistException;
-import org.opendaylight.controller.clustering.services.CacheListenerAddException;
-import org.opendaylight.controller.clustering.services.IClusterServices;
-import org.opendaylight.controller.clustering.services.IGetUpdates;
-import org.opendaylight.controller.clustering.services.IListenRoleChange;
-import org.opendaylight.controller.clustering.services.ListenRoleChangeAddException;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-public class ClusterManager implements IClusterServices {
-    protected static final Logger logger = LoggerFactory
-            .getLogger(ClusterManager.class);
-    private DefaultCacheManager cm;
-    GossipRouter gossiper;
-    private HashSet<IListenRoleChange> roleChangeListeners;
-    private ViewChangedListener cacheManagerListener;
-
-    private static String loopbackAddress = InetAddress.getLoopbackAddress().getHostAddress();
-    private static final int gossipRouterPortDefault = 12001;
-    // defaultTransactionTimeout is 60 seconds
-    private static int DEFAULT_TRANSACTION_TIMEOUT = 60;
-
-    /**
-     * Start a JGroups GossipRouter if we are a supernode. The
-     * GosispRouter is nothing more than a simple
-     * rendevouz-pointer. All the nodes that wants to join the cluster
-     * will come to any of the rendevouz point and they introduce the
-     * nodes to all the others. Once the meet and greet phase if over,
-     * the nodes will open a full-mesh with the remaining n-1 nodes,
-     * so even if the GossipRouter goes down nothing is lost.
-     * NOTE: This function has the side effect to set some of the
-     * JGROUPS configurations, this because in this function already
-     * we try to retrieve some of the network capabilities of the
-     * device and so it's better not to do that again
-     *
-     *
-     * @return GossipRouter
-     */
-    private GossipRouter startGossiper() {
-        boolean amIGossipRouter = false;
-        Integer gossipRouterPort = gossipRouterPortDefault;
-        InetAddress gossipRouterAddress = null;
-        String supernodes_list = System.getProperty("supernodes",
-                loopbackAddress);
-        /*
-         * Check the environment for the "container" variable, if this is set
-         * and is equal to "lxc", then ODL is running inside an lxc
-         * container, and address resolution of supernodes will be modified
-         * accordingly.
-         */
-        boolean inContainer = "lxc".equals(System.getenv("container"));
-        StringBuffer sanitized_supernodes_list = new StringBuffer();
-        List<InetAddress> myAddresses = new ArrayList<InetAddress>();
-
-        if (inContainer) {
-            logger.trace("DOCKER: Resolving supernode host names using docker container semantics");
-        }
-
-        StringTokenizer supernodes = new StringTokenizer(supernodes_list, ":");
-        if (supernodes.hasMoreTokens()) {
-            // Populate the list of my addresses
-            try {
-                Enumeration<NetworkInterface> e = NetworkInterface.getNetworkInterfaces();
-                while (e.hasMoreElements()) {
-                    NetworkInterface n = e.nextElement();
-                    Enumeration<InetAddress> ee = n.getInetAddresses();
-                    while (ee.hasMoreElements()) {
-                        InetAddress i = ee.nextElement();
-                        myAddresses.add(i);
-                    }
-                }
-            } catch (SocketException se) {
-                logger.error("Cannot get the list of network interfaces");
-                return null;
-            }
-        }
-        while (supernodes.hasMoreTokens()) {
-            String curr_supernode = supernodes.nextToken();
-            logger.debug("Examining supernode {}", curr_supernode);
-            StringTokenizer host_port = new StringTokenizer(curr_supernode,
-                    "[]");
-            String host;
-            String port;
-            Integer port_num = gossipRouterPortDefault;
-            if (host_port.countTokens() > 2) {
-                logger.error("Error parsing supernode {} proceed to the next one",
-                        curr_supernode);
-                continue;
-            }
-            host = host_port.nextToken();
-            InetAddress hostAddr;
-            /*
-             * If we are in a container and the hostname begins with a '+', this is
-             * an indication that we should resolve this host name in the context
-             * of a docker container.
-             *
-             * Specifically this means:
-             * '+self'   : self reference and the host will be mapped to the value of
-             *             HOSTNAME in the environment
-             * '+<name>' : references another container by its name. The docker established
-             *             environment variables will be used to resolve the host to an
-             *             IP address.
-             */
-            if (inContainer && host != null && host.charAt(0) == '+') {
-                if ("+self".equals(host)) {
-                    host = System.getenv("HOSTNAME");
-                } else {
-                    String link = System.getenv(host.substring(1).toUpperCase() + "_PORT");
-                    if (link != null) {
-                        try {
-                            host = new URI(link).getHost();
-                        } catch (URISyntaxException e) {
-                            logger.error("DOCKER: Unable to translate container reference ({}) to host IP Address, will attempt using normal host name",
-                                host.substring(1));
-                        }
-                    }
-                }
-            }
-
-            try {
-                hostAddr = InetAddress.getByName(host);
-            } catch (UnknownHostException ue) {
-                logger.error("Host {} is not known", host);
-                continue;
-            }
-            if (host_port.hasMoreTokens()) {
-                port = host_port.nextToken();
-                try {
-                    port_num = Integer.valueOf(port);
-                } catch (NumberFormatException ne) {
-                    logger.error("Supplied supernode gossip port is not recognized, using default gossip port {}",
-                                 gossipRouterPortDefault);
-                    port_num = gossipRouterPortDefault;
-                }
-                if ((port_num > 65535) || (port_num < 0)) {
-                    logger.error("Supplied supernode gossip port is outside a valid TCP port range");
-                    port_num = gossipRouterPortDefault;
-                }
-            }
-            if (!amIGossipRouter) {
-                if (host != null) {
-                    for (InetAddress myAddr : myAddresses) {
-                        if (myAddr.equals(hostAddr)) {
-                            amIGossipRouter = true;
-                            gossipRouterAddress = hostAddr;
-                            gossipRouterPort = port_num;
-                            break;
-                        }
-                    }
-                }
-            }
-            if (!sanitized_supernodes_list.toString().equals("")) {
-                sanitized_supernodes_list.append(",");
-            }
-            sanitized_supernodes_list.append(hostAddr.getHostAddress()).append("[").append(port_num).append("]");
-        }
-
-        if (amIGossipRouter) {
-            // Set the Jgroups binding interface to the one we got
-            // from the supernodes attribute
-            if (gossipRouterAddress != null) {
-                System.setProperty("jgroups.tcp.address", gossipRouterAddress
-                        .getHostAddress());
-            }
-        } else {
-            // Set the Jgroup binding interface to the one we are well
-            // known outside or else to the first with non-local
-            // scope.
-            try {
-                String myBind = InetAddress.getLocalHost().getHostAddress();
-                if (myBind == null
-                        || InetAddress.getLocalHost().isLoopbackAddress()) {
-                    for (InetAddress myAddr : myAddresses) {
-                        if (myAddr.isLoopbackAddress()
-                                || myAddr.isLinkLocalAddress()) {
-                            logger.debug("Skipping local address {}",
-                                         myAddr.getHostAddress());
-                            continue;
-                        } else {
-                            // First non-local address
-                            myBind = myAddr.getHostAddress();
-                            logger.debug("First non-local address {}", myBind);
-                            break;
-                        }
-                    }
-                }
-                String jgroupAddress = System
-                        .getProperty("jgroups.tcp.address");
-                if (jgroupAddress == null) {
-                    if (myBind != null) {
-                        logger.debug("Set bind address to be {}", myBind);
-                        System.setProperty("jgroups.tcp.address", myBind);
-                    } else {
-                        logger
-                                .debug("Set bind address to be LOCALHOST=127.0.0.1");
-                        System.setProperty("jgroups.tcp.address", "127.0.0.1");
-                    }
-                } else {
-                    logger.debug("jgroup.tcp.address already set to be {}",
-                            jgroupAddress);
-                }
-            } catch (UnknownHostException uhe) {
-                logger
-                        .error("Met UnknownHostException while trying to get binding address for jgroups");
-            }
-        }
-
-        // The supernodes list constitute also the tcpgossip initial
-        // host list
-        System.setProperty("jgroups.tcpgossip.initial_hosts",
-                sanitized_supernodes_list.toString());
-        logger.debug("jgroups.tcp.address set to {}",
-                System.getProperty("jgroups.tcp.address"));
-        logger.debug("jgroups.tcpgossip.initial_hosts set to {}",
-                System.getProperty("jgroups.tcpgossip.initial_hosts"));
-        GossipRouter res = null;
-        if (amIGossipRouter) {
-            logger.info("I'm a GossipRouter will listen on port {}",
-                    gossipRouterPort);
-            // Start a GossipRouter with JMX support
-            res = new GossipRouter(gossipRouterPort, null, true);
-        }
-        return res;
-    }
-
-    private void exitOnSecurityException(Exception ioe) {
-        Throwable cause = ioe.getCause();
-        while (cause != null) {
-            if (cause instanceof java.lang.SecurityException) {
-                logger.error("Failed Cluster authentication. Stopping Controller...");
-                System.exit(0);
-            }
-            cause = cause.getCause();
-        }
-    }
-
-    public void start() {
-        this.gossiper = startGossiper();
-        if (this.gossiper != null) {
-            logger.debug("Trying to start Gossiper");
-            try {
-                this.gossiper.start();
-                logger.info("Started GossipRouter");
-            } catch (Exception e) {
-                logger.error("GossipRouter didn't start. Exception Stack Trace",
-                             e);
-            }
-        }
-        logger.info("Starting the ClusterManager");
-        try {
-            ParserRegistry parser = new ParserRegistry(this.getClass()
-                    .getClassLoader());
-            String infinispanConfigFile =
-                    System.getProperty("org.infinispan.config.file", "config/infinispan-config.xml");
-            logger.debug("Using configuration file:{}", infinispanConfigFile);
-            ConfigurationBuilderHolder holder = parser.parseFile(infinispanConfigFile);
-            GlobalConfigurationBuilder globalBuilder = holder.getGlobalConfigurationBuilder();
-            globalBuilder.serialization()
-                    .classResolver(new ClassResolver())
-                    .build();
-            this.cm = new DefaultCacheManager(holder, false);
-            logger.debug("Allocated ClusterManager");
-            if (this.cm != null) {
-                this.cm.start();
-                this.cm.startCache();
-                logger.debug("Started the ClusterManager");
-            }
-        } catch (Exception ioe) {
-            logger.error("Cannot configure infinispan .. bailing out ");
-            logger.error("Stack Trace that raised th exception");
-            logger.error("",ioe);
-            this.cm = null;
-            exitOnSecurityException(ioe);
-            this.stop();
-        }
-        logger.debug("Cache Manager has value {}", this.cm);
-    }
-
-    public void stop() {
-        logger.info("Stopping the ClusterManager");
-        if (this.cm != null) {
-            logger.info("Found a valid ClusterManager, now let it be stopped");
-            this.cm.stop();
-            this.cm = null;
-        }
-        if (this.gossiper != null) {
-            this.gossiper.stop();
-            this.gossiper = null;
-        }
-    }
-
-    @Override
-    public ConcurrentMap<?, ?> createCache(String containerName,
-            String cacheName, Set<cacheMode> cMode) throws CacheExistException,
-            CacheConfigException {
-        EmbeddedCacheManager manager = this.cm;
-        Cache<Object,Object> c;
-        String realCacheName = "{" + containerName + "}_{" + cacheName + "}";
-        if (manager == null) {
-            return null;
-        }
-
-        if (manager.cacheExists(realCacheName)) {
-            throw new CacheExistException();
-        }
-
-        // Sanity check to avoid contrasting parameters between transactional
-        // and not
-        if (cMode.containsAll(EnumSet.of(IClusterServices.cacheMode.NON_TRANSACTIONAL,
-                IClusterServices.cacheMode.TRANSACTIONAL))) {
-            throw new CacheConfigException();
-        }
-
-        // Sanity check to avoid contrasting parameters between sync and async
-        if (cMode.containsAll(EnumSet.of(IClusterServices.cacheMode.SYNC, IClusterServices.cacheMode.ASYNC))) {
-            throw new CacheConfigException();
-        }
-
-        Configuration fromTemplateConfig = null;
-        /*
-         * Fetch transactional/non-transactional templates
-         */
-        // Check if transactional
-        if (cMode.contains(IClusterServices.cacheMode.TRANSACTIONAL)) {
-            fromTemplateConfig = manager.getCacheConfiguration("transactional-type");
-        } else if (cMode.contains(IClusterServices.cacheMode.NON_TRANSACTIONAL)) {
-            fromTemplateConfig = manager.getDefaultCacheConfiguration();
-        }
-
-        // If none set the transactional property then just return null
-        if (fromTemplateConfig == null) {
-            return null;
-        }
-
-        ConfigurationBuilder builder = new ConfigurationBuilder();
-        builder.read(fromTemplateConfig);
-        /*
-         * Now evaluate async/sync
-         */
-        if (cMode.contains(IClusterServices.cacheMode.ASYNC)) {
-            builder.clustering()
-                    .cacheMode(fromTemplateConfig.clustering()
-                            .cacheMode()
-                            .toAsync());
-        } else if (cMode.contains(IClusterServices.cacheMode.SYNC)) {
-            builder.clustering()
-                    .cacheMode(fromTemplateConfig.clustering()
-                            .cacheMode()
-                            .toSync());
-        }
-
-        manager.defineConfiguration(realCacheName, builder.build());
-        c = manager.getCache(realCacheName);
-        return c;
-    }
-
-    @Override
-    public ConcurrentMap<?, ?> getCache(String containerName, String cacheName) {
-        EmbeddedCacheManager manager = this.cm;
-        Cache<Object,Object> c;
-        String realCacheName = "{" + containerName + "}_{" + cacheName + "}";
-        if (manager == null) {
-            return null;
-        }
-
-        if (manager.cacheExists(realCacheName)) {
-            c = manager.getCache(realCacheName);
-            return c;
-        }
-        return null;
-    }
-
-    @Override
-    public void destroyCache(String containerName, String cacheName) {
-        EmbeddedCacheManager manager = this.cm;
-        String realCacheName = "{" + containerName + "}_{" + cacheName + "}";
-        if (manager == null) {
-            return;
-        }
-        if (manager.cacheExists(realCacheName)) {
-            manager.removeCache(realCacheName);
-        }
-    }
-
-    @Override
-    public boolean existCache(String containerName, String cacheName) {
-        EmbeddedCacheManager manager = this.cm;
-
-        if (manager == null) {
-            return false;
-        }
-
-        String realCacheName = "{" + containerName + "}_{" + cacheName + "}";
-        return manager.cacheExists(realCacheName);
-    }
-
-    @Override
-    public Set<String> getCacheList(String containerName) {
-        Set<String> perContainerCaches = new HashSet<String>();
-        EmbeddedCacheManager manager = this.cm;
-        if (manager == null) {
-            return null;
-        }
-        for (String cacheName : manager.getCacheNames()) {
-            if (!manager.isRunning(cacheName)) {
-                continue;
-            }
-            if (cacheName.startsWith("{" + containerName + "}_")) {
-                String[] res = cacheName.split("[{}]");
-                if (res.length >= 4 && res[1].equals(containerName)
-                        && res[2].equals("_")) {
-                    perContainerCaches.add(res[3]);
-                }
-            }
-        }
-
-        return (perContainerCaches);
-    }
-
-    @Override
-    public Properties getCacheProperties(String containerName, String cacheName) {
-        EmbeddedCacheManager manager = this.cm;
-        if (manager == null) {
-            return null;
-        }
-        String realCacheName = "{" + containerName + "}_{" + cacheName + "}";
-        if (!manager.cacheExists(realCacheName)) {
-            return null;
-        }
-        Configuration conf = manager.getCache(realCacheName).getAdvancedCache()
-                .getCacheConfiguration();
-        Properties p = new Properties();
-        p.setProperty(IClusterServices.cacheProps.TRANSACTION_PROP.toString(),
-                conf.transaction().toString());
-        p.setProperty(IClusterServices.cacheProps.CLUSTERING_PROP.toString(),
-                conf.clustering().toString());
-        p.setProperty(IClusterServices.cacheProps.LOCKING_PROP.toString(), conf
-                .locking().toString());
-        return p;
-    }
-
-    @Override
-    public void addListener(String containerName, String cacheName,
-            IGetUpdates<?, ?> u) throws CacheListenerAddException {
-        EmbeddedCacheManager manager = this.cm;
-        Cache<Object,Object> c;
-        String realCacheName = "{" + containerName + "}_{" + cacheName + "}";
-        if (manager == null) {
-            return;
-        }
-
-        if (!manager.cacheExists(realCacheName)) {
-            throw new CacheListenerAddException();
-        }
-        c = manager.getCache(realCacheName);
-        CacheListenerContainer cl = new CacheListenerContainer(u,
-                containerName, cacheName);
-        c.addListener(cl);
-    }
-
-    @Override
-    public Set<IGetUpdates<?, ?>> getListeners(String containerName,
-            String cacheName) {
-        EmbeddedCacheManager manager = this.cm;
-        Cache<Object,Object> c;
-        String realCacheName = "{" + containerName + "}_{" + cacheName + "}";
-        if (manager == null) {
-            return null;
-        }
-
-        if (!manager.cacheExists(realCacheName)) {
-            return null;
-        }
-        c = manager.getCache(realCacheName);
-
-        Set<IGetUpdates<?, ?>> res = new HashSet<IGetUpdates<?, ?>>();
-        Set<Object> listeners = c.getListeners();
-        for (Object listener : listeners) {
-            if (listener instanceof CacheListenerContainer) {
-                CacheListenerContainer cl = (CacheListenerContainer) listener;
-                res.add(cl.whichListener());
-            }
-        }
-
-        return res;
-    }
-
-    @Override
-    public void removeListener(String containerName, String cacheName,
-            IGetUpdates<?, ?> u) {
-        EmbeddedCacheManager manager = this.cm;
-        Cache<Object,Object> c;
-        String realCacheName = "{" + containerName + "}_{" + cacheName + "}";
-        if (manager == null) {
-            return;
-        }
-
-        if (!manager.cacheExists(realCacheName)) {
-            return;
-        }
-        c = manager.getCache(realCacheName);
-
-        Set<Object> listeners = c.getListeners();
-        for (Object listener : listeners) {
-            if (listener instanceof CacheListenerContainer) {
-                CacheListenerContainer cl = (CacheListenerContainer) listener;
-                if (cl.whichListener() == u) {
-                    c.removeListener(listener);
-                    return;
-                }
-            }
-        }
-    }
-
-    @Override
-    public void tbegin() throws NotSupportedException, SystemException {
-        // call tbegin with the default timeout
-        tbegin(DEFAULT_TRANSACTION_TIMEOUT, TimeUnit.SECONDS);
-    }
-
-    @Override
-    public void tbegin(long timeout, TimeUnit unit) throws NotSupportedException, SystemException {
-        EmbeddedCacheManager manager = this.cm;
-        if (manager == null) {
-            throw new IllegalStateException();
-        }
-        TransactionManager tm = manager.getCache("transactional-type")
-                .getAdvancedCache().getTransactionManager();
-        if (tm == null) {
-            throw new IllegalStateException();
-        }
-        long timeoutSec = unit.toSeconds(timeout);
-        if((timeoutSec > Integer.MAX_VALUE) || (timeoutSec <= 0)) {
-            // fall back to the default timeout
-            tm.setTransactionTimeout(DEFAULT_TRANSACTION_TIMEOUT);
-        } else {
-            // cast is ok here
-            // as here we are sure that timeoutSec < = Integer.MAX_VALUE.
-            tm.setTransactionTimeout((int) timeoutSec);
-        }
-        tm.begin();
-    }
-
-    @Override
-    public void tcommit() throws RollbackException, HeuristicMixedException,
-            HeuristicRollbackException, java.lang.SecurityException,
-            java.lang.IllegalStateException, SystemException {
-        EmbeddedCacheManager manager = this.cm;
-        if (manager == null) {
-            throw new IllegalStateException();
-        }
-        TransactionManager tm = manager.getCache("transactional-type")
-                .getAdvancedCache().getTransactionManager();
-        if (tm == null) {
-            throw new IllegalStateException();
-        }
-        tm.commit();
-    }
-
-    @Override
-    public void trollback() throws java.lang.IllegalStateException,
-            java.lang.SecurityException, SystemException {
-        EmbeddedCacheManager manager = this.cm;
-        if (manager == null) {
-            throw new IllegalStateException();
-        }
-        TransactionManager tm = manager.getCache("transactional-type")
-                .getAdvancedCache().getTransactionManager();
-        if (tm == null) {
-            throw new IllegalStateException();
-        }
-        tm.rollback();
-    }
-
-    @Override
-    public Transaction tgetTransaction() throws SystemException {
-        EmbeddedCacheManager manager = this.cm;
-        if (manager == null) {
-            throw new IllegalStateException();
-        }
-        TransactionManager tm = manager.getCache("transactional-type")
-                .getAdvancedCache().getTransactionManager();
-        if (tm == null) {
-            return null;
-        }
-        return tm.getTransaction();
-    }
-
-    @Override
-    public boolean amIStandby() {
-        EmbeddedCacheManager manager = this.cm;
-        if (manager == null) {
-            // In case we cannot fetch the information, lets assume we
-            // are standby, so to have less responsibility.
-            return true;
-        }
-        return (!manager.isCoordinator());
-    }
-
-    private InetAddress addressToInetAddress(Address a) {
-        EmbeddedCacheManager manager = this.cm;
-        if ((manager == null) || (a == null)) {
-            // In case we cannot fetch the information, lets assume we
-            // are standby, so to have less responsibility.
-            return null;
-        }
-        Transport t = manager.getTransport();
-        if (t instanceof JGroupsTransport) {
-            JGroupsTransport jt = (JGroupsTransport) t;
-            Channel c = jt.getChannel();
-            if (a instanceof JGroupsAddress) {
-                JGroupsAddress ja = (JGroupsAddress) a;
-                org.jgroups.Address phys = (org.jgroups.Address) c
-                        .down(new Event(Event.GET_PHYSICAL_ADDRESS, ja
-                                .getJGroupsAddress()));
-                if (phys instanceof org.jgroups.stack.IpAddress) {
-                    InetAddress bindAddress = ((org.jgroups.stack.IpAddress) phys)
-                            .getIpAddress();
-                    return bindAddress;
-                }
-            }
-        }
-        return null;
-    }
-
-    @Override
-    public List<InetAddress> getClusteredControllers() {
-        EmbeddedCacheManager manager = this.cm;
-        if (manager == null) {
-            return null;
-        }
-        List<Address> controllers = manager.getMembers();
-        if ((controllers == null) || controllers.size() == 0) {
-            return null;
-        }
-
-        List<InetAddress> clusteredControllers = new ArrayList<InetAddress>();
-        for (Address a : controllers) {
-            InetAddress inetAddress = addressToInetAddress(a);
-            if (inetAddress != null
-                    && !inetAddress.getHostAddress().equals(loopbackAddress)) {
-                clusteredControllers.add(inetAddress);
-            }
-        }
-        return clusteredControllers;
-    }
-
-    @Override
-    public InetAddress getMyAddress() {
-        EmbeddedCacheManager manager = this.cm;
-        if (manager == null) {
-            return null;
-        }
-        return addressToInetAddress(manager.getAddress());
-    }
-
-    @Override
-    public InetAddress getActiveAddress() {
-        EmbeddedCacheManager manager = this.cm;
-        if (manager == null) {
-            // In case we cannot fetch the information, lets assume we
-            // are standby, so to have less responsibility.
-            return null;
-        }
-
-        return addressToInetAddress(manager.getCoordinator());
-    }
-
-    @Override
-    public void listenRoleChange(IListenRoleChange i)
-            throws ListenRoleChangeAddException {
-        EmbeddedCacheManager manager = this.cm;
-        if (manager == null) {
-            // In case we cannot fetch the information, lets assume we
-            // are standby, so to have less responsibility.
-            throw new ListenRoleChangeAddException();
-        }
-
-        if (this.roleChangeListeners == null) {
-            this.roleChangeListeners = new HashSet<IListenRoleChange>();
-            this.cacheManagerListener = new ViewChangedListener(
-                    this.roleChangeListeners);
-            manager.addListener(this.cacheManagerListener);
-        }
-
-        if (this.roleChangeListeners != null) {
-            this.roleChangeListeners.add(i);
-        }
-    }
-
-    @Override
-    public void unlistenRoleChange(IListenRoleChange i) {
-        EmbeddedCacheManager manager = this.cm;
-        if (manager == null) {
-            // In case we cannot fetch the information, lets assume we
-            // are standby, so to have less responsibility.
-            return;
-        }
-
-        if (this.roleChangeListeners != null) {
-            this.roleChangeListeners.remove(i);
-        }
-
-        if ((this.roleChangeListeners != null && this.roleChangeListeners
-                .isEmpty())
-                && (this.cacheManagerListener != null)) {
-            manager.removeListener(this.cacheManagerListener);
-            this.cacheManagerListener = null;
-            this.roleChangeListeners = null;
-        }
-    }
-
-    @Listener
-    public class ViewChangedListener {
-        Set<IListenRoleChange> roleListeners;
-
-        public ViewChangedListener(Set<IListenRoleChange> s) {
-            this.roleListeners = s;
-        }
-
-        @ViewChanged
-        public void viewChanged(ViewChangedEvent e) {
-            for (IListenRoleChange i : this.roleListeners) {
-                i.newActiveAvailable();
-            }
-        }
-    }
-}
diff --git a/opendaylight/adsal/clustering/services_implementation/src/main/java/org/opendaylight/controller/clustering/services_implementation/internal/ClusterManagerCLI.java b/opendaylight/adsal/clustering/services_implementation/src/main/java/org/opendaylight/controller/clustering/services_implementation/internal/ClusterManagerCLI.java
deleted file mode 100644 (file)
index 402b853..0000000
+++ /dev/null
@@ -1,76 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.clustering.services_implementation.internal;
-
-import java.util.Dictionary;
-import java.util.Hashtable;
-import java.util.concurrent.ConcurrentMap;
-
-import org.apache.felix.service.command.Descriptor;
-import org.infinispan.AdvancedCache;
-import org.infinispan.distribution.DistributionManager;
-import org.opendaylight.controller.clustering.services.IClusterContainerServices;
-import org.opendaylight.controller.sal.utils.ServiceHelper;
-import org.osgi.framework.ServiceRegistration;
-
-public class ClusterManagerCLI {
-    @SuppressWarnings("rawtypes")
-    private ServiceRegistration sr = null;
-
-    public void init() {
-    }
-
-    public void destroy() {
-    }
-
-    public void start() {
-        final Dictionary<String, Object> props = new Hashtable<String, Object>();
-        props.put("osgi.command.scope", "odpcontroller");
-        props.put("osgi.command.function", new String[] { "getContainerAdvancedCacheInfo" });
-        this.sr = ServiceHelper.registerGlobalServiceWReg(ClusterManagerCLI.class, this, props);
-    }
-
-    public void stop() {
-        if (this.sr != null) {
-            this.sr.unregister();
-            this.sr = null;
-        }
-    }
-
-    @Descriptor("Get advanced cache infos")
-    public void getContainerAdvancedCacheInfo(@Descriptor("Container for the cache to be fetched") String container,
-            @Descriptor("cache to get information about") String cacheName) {
-        IClusterContainerServices s =
-                (IClusterContainerServices) ServiceHelper.getInstance(IClusterContainerServices.class, container, this);
-        if (s == null) {
-            System.out.println("Could not get an handle to the container cluster service:" + container);
-            return;
-        }
-        if (!s.existCache(cacheName)) {
-            System.out.println("Could not get cache named:" + cacheName);
-        }
-        ConcurrentMap<?, ?> aC = s.getCache(cacheName);
-        if (aC == null) {
-            System.out.println("Could not get cache named:" + cacheName);
-            return;
-        }
-        if (aC instanceof AdvancedCache) {
-            @SuppressWarnings("rawtypes")
-            AdvancedCache advCache = (AdvancedCache) aC;
-            System.out.println("AdvancedCache retrieved!");
-            DistributionManager dMgr = advCache.getDistributionManager();
-            if (dMgr == null) {
-                return;
-            }
-            System.out.println("Routing Table for the Hash:" + dMgr.getConsistentHash()
-                    .getRoutingTableAsString());
-            System.out.println("Get Members:" + dMgr.getConsistentHash()
-                    .getMembers());
-        }
-    }
-}
diff --git a/opendaylight/adsal/clustering/services_implementation/src/main/java/org/opendaylight/controller/clustering/services_implementation/internal/ClusterManagerCommon.java b/opendaylight/adsal/clustering/services_implementation/src/main/java/org/opendaylight/controller/clustering/services_implementation/internal/ClusterManagerCommon.java
deleted file mode 100644 (file)
index 06e5bc5..0000000
+++ /dev/null
@@ -1,333 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.clustering.services_implementation.internal;
-
-import java.net.InetAddress;
-import java.util.Collections;
-import java.util.Dictionary;
-import java.util.HashSet;
-import java.util.List;
-import java.util.Map;
-import java.util.Properties;
-import java.util.Set;
-import java.util.concurrent.ConcurrentHashMap;
-import java.util.concurrent.ConcurrentMap;
-import java.util.concurrent.TimeUnit;
-
-import javax.transaction.HeuristicMixedException;
-import javax.transaction.HeuristicRollbackException;
-import javax.transaction.NotSupportedException;
-import javax.transaction.RollbackException;
-import javax.transaction.SystemException;
-import javax.transaction.Transaction;
-
-import org.apache.felix.dm.Component;
-import org.opendaylight.controller.clustering.services.CacheConfigException;
-import org.opendaylight.controller.clustering.services.CacheExistException;
-import org.opendaylight.controller.clustering.services.CacheListenerAddException;
-import org.opendaylight.controller.clustering.services.ICacheUpdateAware;
-import org.opendaylight.controller.clustering.services.IClusterServices;
-import org.opendaylight.controller.clustering.services.IClusterServicesCommon;
-import org.opendaylight.controller.clustering.services.ICoordinatorChangeAware;
-import org.opendaylight.controller.clustering.services.IListenRoleChange;
-import org.opendaylight.controller.clustering.services.ListenRoleChangeAddException;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-public abstract class ClusterManagerCommon implements IClusterServicesCommon {
-    protected String containerName = null;
-    protected IClusterServices clusterService = null;
-    protected static final Logger logger = LoggerFactory
-            .getLogger(ClusterManagerCommon.class);
-    private ConcurrentMap<String, GetUpdatesContainer> cacheUpdateAware =
-        new ConcurrentHashMap<String, GetUpdatesContainer>();
-    private Set<ICoordinatorChangeAware> coordinatorChangeAware = Collections
-            .synchronizedSet(new HashSet<ICoordinatorChangeAware>());
-    private ListenCoordinatorChange coordinatorChangeListener = null;
-
-    /**
-     * Class needed to listen to the role changes from the cluster
-     * manager and to pass it along to the other components that
-     * export the interface ICoordinatorChangeAware
-     */
-    class ListenCoordinatorChange implements IListenRoleChange {
-        @Override
-        public void newActiveAvailable() {
-            if (coordinatorChangeAware != null) {
-                // Make sure to look the set while walking it
-                synchronized (coordinatorChangeAware) {
-                    for (ICoordinatorChangeAware s : coordinatorChangeAware) {
-                        // Now walk every instance and signal that the
-                        // coordinator has changed
-                        s.coordinatorChanged();
-                    }
-                }
-            }
-        }
-    }
-
-    void setCoordinatorChangeAware(ICoordinatorChangeAware s) {
-        if (this.coordinatorChangeAware != null) {
-            this.coordinatorChangeAware.add(s);
-        }
-    }
-
-    void unsetCoordinatorChangeAware(ICoordinatorChangeAware s) {
-        if (this.coordinatorChangeAware != null) {
-            this.coordinatorChangeAware.remove(s);
-        }
-    }
-
-    void setCacheUpdateAware(Map props, ICacheUpdateAware s) {
-        logger.trace("CacheUpdateAware being set on container:{}",
-                     this.containerName);
-        if (this.cacheUpdateAware != null) {
-            Set<String> caches = (Set<String>)props.get("cachenames");
-            if (caches != null) {
-                logger.trace("cachenames provided below:");
-                for (String cache : caches) {
-                    if (this.cacheUpdateAware.get(cache) != null) {
-                        logger.error("cachename:{} on container:{} has already a listener", cache, this.containerName);
-                    } else {
-                        GetUpdatesContainer<?, ?> up = new GetUpdatesContainer(s, this.containerName, cache);
-                        if (up != null) {
-                            try {
-                                this.clusterService.addListener(this.containerName,
-                                                                cache, up);
-                                this.cacheUpdateAware.put(cache, up);
-                                logger.trace("cachename:{} on container:{} has " +
-                                             "been registered", cache,
-                                             this.containerName);
-                            } catch (CacheListenerAddException exc) {
-                                logger.debug("Cache {} didn't exist when {} tried to register to its updates", cache, s);
-                                // Do nothing, the important is that
-                                // we don't register the listener in
-                                // the shadow, and we are not doing
-                                // that.
-                            }
-                        }
-                    }
-                }
-            }
-        }
-    }
-
-    void unsetCacheUpdateAware(Map props, ICacheUpdateAware s) {
-        logger.trace("CacheUpdateAware being unset on container:{}",
-                     this.containerName);
-        if (this.cacheUpdateAware != null) {
-            Set<String> caches = (Set<String>)props.get("cachenames");
-            if (caches != null) {
-                logger.trace("cachenames provided below:");
-                GetUpdatesContainer<?, ?> up = null;
-                for (String cache : caches) {
-                    up = this.cacheUpdateAware.get(cache);
-                    if (up != null) {
-                        this.cacheUpdateAware.remove(cache);
-                        this.clusterService.removeListener(this.containerName,
-                                                           cache, up);
-                    }
-                }
-            }
-        }
-    }
-
-    public void setClusterService(IClusterServices s) {
-        this.clusterService = s;
-    }
-
-    public void unsetClusterServices(IClusterServices s) {
-        if (this.clusterService == s) {
-            this.clusterService = null;
-        }
-    }
-
-    /**
-     * Function called by the dependency manager when all the required
-     * dependencies are satisfied
-     *
-     */
-    void init(Component c) {
-        Dictionary props = c.getServiceProperties();
-        if (props != null) {
-            this.containerName = (String) props.get("containerName");
-            logger.debug("Running containerName: {}", this.containerName);
-        } else {
-            // In the Global instance case the containerName is empty
-            this.containerName = "";
-        }
-        if (this.clusterService != null) {
-            this.coordinatorChangeListener = new ListenCoordinatorChange();
-            try {
-                this.clusterService
-                        .listenRoleChange(this.coordinatorChangeListener);
-                logger.debug("Coordinator change handler registered");
-            } catch (ListenRoleChangeAddException ex) {
-                logger.error("Could not register coordinator change");
-            }
-        }
-    }
-
-    /**
-     * Function called by the dependency manager when any of the required
-     * dependencies are going away
-     *
-     */
-    void destroy() {
-        if (this.clusterService != null
-                && this.coordinatorChangeListener != null) {
-            this.clusterService
-                    .unlistenRoleChange(this.coordinatorChangeListener);
-            this.coordinatorChangeListener = null;
-            logger.debug("Coordinator change handler UNregistered");
-        }
-    }
-
-    @Override
-    public ConcurrentMap<?, ?> createCache(String cacheName,
-            Set<IClusterServices.cacheMode> cMode) throws CacheExistException,
-            CacheConfigException {
-        if (this.clusterService != null) {
-            return this.clusterService.createCache(this.containerName,
-                    cacheName, cMode);
-        } else {
-            return null;
-        }
-    }
-
-    @Override
-    public ConcurrentMap<?, ?> getCache(String cacheName) {
-        if (this.clusterService != null) {
-            return this.clusterService.getCache(this.containerName, cacheName);
-        } else {
-            return null;
-        }
-    }
-
-    @Override
-    public void destroyCache(String cacheName) {
-        if (this.clusterService != null) {
-            this.clusterService.destroyCache(this.containerName, cacheName);
-        }
-    }
-
-    @Override
-    public boolean existCache(String cacheName) {
-        if (this.clusterService != null) {
-            return this.clusterService
-                    .existCache(this.containerName, cacheName);
-        } else {
-            return false;
-        }
-    }
-
-    @Override
-    public Set<String> getCacheList() {
-        if (this.clusterService != null) {
-            return this.clusterService.getCacheList(this.containerName);
-        } else {
-            return null;
-        }
-    }
-
-    @Override
-    public Properties getCacheProperties(String cacheName) {
-        if (this.clusterService != null) {
-            return this.clusterService.getCacheProperties(this.containerName,
-                    cacheName);
-        } else {
-            return null;
-        }
-    }
-
-    @Override
-    public void tbegin() throws NotSupportedException, SystemException {
-        if (this.clusterService != null) {
-            this.clusterService.tbegin();
-        } else {
-            throw new IllegalStateException();
-        }
-    }
-
-    @Override
-    public void tbegin(long timeout, TimeUnit unit) throws NotSupportedException, SystemException {
-        if (this.clusterService != null) {
-            this.clusterService.tbegin(timeout, unit);
-        } else {
-            throw new IllegalStateException();
-        }
-    }
-
-    @Override
-    public void tcommit() throws RollbackException, HeuristicMixedException,
-            HeuristicRollbackException, java.lang.SecurityException,
-            java.lang.IllegalStateException, SystemException {
-        if (this.clusterService != null) {
-            this.clusterService.tcommit();
-        } else {
-            throw new IllegalStateException();
-        }
-    }
-
-    @Override
-    public void trollback() throws java.lang.IllegalStateException,
-            java.lang.SecurityException, SystemException {
-        if (this.clusterService != null) {
-            this.clusterService.trollback();
-        } else {
-            throw new IllegalStateException();
-        }
-    }
-
-    @Override
-    public Transaction tgetTransaction() throws SystemException {
-        if (this.clusterService != null) {
-            return this.clusterService.tgetTransaction();
-        } else {
-            return null;
-        }
-    }
-
-    @Override
-    public List<InetAddress> getClusteredControllers() {
-        if (this.clusterService != null) {
-            return this.clusterService.getClusteredControllers();
-        } else {
-            return null;
-        }
-    }
-
-    @Override
-    public InetAddress getMyAddress() {
-        if (this.clusterService != null) {
-            return this.clusterService.getMyAddress();
-        } else {
-            return null;
-        }
-    }
-
-    @Override
-    public InetAddress getCoordinatorAddress() {
-        if (this.clusterService != null) {
-            return this.clusterService.getActiveAddress();
-        } else {
-            return null;
-        }
-    }
-
-    @Override
-    public boolean amICoordinator() {
-        if (this.clusterService != null) {
-            return (!this.clusterService.amIStandby());
-        } else {
-            return false;
-        }
-    }
-}
diff --git a/opendaylight/adsal/clustering/services_implementation/src/main/java/org/opendaylight/controller/clustering/services_implementation/internal/GetUpdatesContainer.java b/opendaylight/adsal/clustering/services_implementation/src/main/java/org/opendaylight/controller/clustering/services_implementation/internal/GetUpdatesContainer.java
deleted file mode 100644 (file)
index 3444a17..0000000
+++ /dev/null
@@ -1,54 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.clustering.services_implementation.internal;
-
-import org.opendaylight.controller.clustering.services.IGetUpdates;
-import org.opendaylight.controller.clustering.services.ICacheUpdateAware;
-
-public class GetUpdatesContainer<K,V> implements IGetUpdates<K,V> {
-    private ICacheUpdateAware<K,V> toBeUpdated;
-    private String containerName;
-    private String cacheName;
-
-    public GetUpdatesContainer(ICacheUpdateAware<K,V> i, String containerName,
-                               String cacheName) {
-        this.toBeUpdated = i;
-        this.containerName = containerName;
-        this.cacheName = cacheName;
-    }
-
-    public ICacheUpdateAware<K,V> whichListener() {
-        return this.toBeUpdated;
-    }
-
-    @Override
-    public void entryCreated(K key, String containerName, String cacheName,
-                             boolean local) {
-        if (this.toBeUpdated != null) {
-            this.toBeUpdated.entryCreated(key, cacheName, local);
-        }
-    }
-
-    @Override
-    public void entryUpdated(K key, V new_value, String containerName,
-                             String cacheName,
-                             boolean local) {
-        if (this.toBeUpdated != null) {
-            this.toBeUpdated.entryUpdated(key, new_value, cacheName, local);
-        }
-    }
-
-    @Override
-    public void entryDeleted(K key, String containerName, String cacheName,
-                             boolean local) {
-        if (this.toBeUpdated != null) {
-            this.toBeUpdated.entryDeleted(key, cacheName, local);
-        }
-    }
-}
diff --git a/opendaylight/adsal/clustering/services_implementation/src/main/resources/config/infinispan-config.xml b/opendaylight/adsal/clustering/services_implementation/src/main/resources/config/infinispan-config.xml
deleted file mode 100644 (file)
index 5fb0ddf..0000000
+++ /dev/null
@@ -1,39 +0,0 @@
-<infinispan>
-  <global>
-    <transport>
-      <properties>
-        <property name="configurationFile" value="config/jgroups.xml"/>
-      </properties>
-    </transport>
-    <!-- Enable JMX statistics -->
-    <globalJmxStatistics
-        enabled="true"
-        jmxDomain="org.infinispan"
-        cacheManagerName="SampleCacheManager"/>
-  </global>
-
- <default>
-    <jmxStatistics enabled="true"/>
-        <clustering mode="replication">
-        <sync/>
-        </clustering>
-        </default>
- <namedCache name="transactional-type">
-    <transaction
-        transactionManagerLookupClass="org.infinispan.transaction.lookup.JBossStandaloneJTAManagerLookup"
-        syncRollbackPhase="true"
-        syncCommitPhase="true"
-        cacheStopTimeout="30000"
-        use1PcForAutoCommitTransactions="true"
-        autoCommit="true"
-        lockingMode="OPTIMISTIC"
-        useEagerLocking="true"
-        useSynchronization="true"
-        transactionMode="TRANSACTIONAL"
-        />
-        <clustering mode="replication">
-        <sync/>
-        </clustering>
-  </namedCache>
-
-</infinispan>
diff --git a/opendaylight/adsal/clustering/services_implementation/src/main/resources/config/jgroups.xml b/opendaylight/adsal/clustering/services_implementation/src/main/resources/config/jgroups.xml
deleted file mode 100644 (file)
index b1dc033..0000000
+++ /dev/null
@@ -1,77 +0,0 @@
-<!--
-    TCP based stack, with flow control and message bundling. This is usually used when IP
-    multicasting cannot be used in a network, e.g. because it is disabled (routers discard multicast).
-    Note that TCP.bind_addr and TCPPING.initial_hosts should be set, possibly via system properties, e.g.
-    -Djgroups.bind_addr=192.168.5.2 and -Djgroups.tcpping.initial_hosts=192.168.5.2[7800]".
-    author: Bela Ban
--->
-<config xmlns="urn:org:jgroups"
-        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
-        xsi:schemaLocation="urn:org:jgroups http://www.jgroups.org/schema/JGroups-3.0.xsd">
-
-  <TCP loopback="true"
-       bind_addr="${jgroups.tcp.address:127.0.0.1}"
-       bind_port="${jgroups.tcp.port:7800}"
-       recv_buf_size="${tcp.recv_buf_size:20M}"
-       send_buf_size="${tcp.send_buf_size:640K}"
-       discard_incompatible_packets="true"
-       max_bundle_size="64K"
-       max_bundle_timeout="30"
-       enable_bundling="true"
-       use_send_queues="true"
-       sock_conn_timeout="300"
-       timer_type="new"
-       timer.min_threads="4"
-       timer.max_threads="10"
-       timer.keep_alive_time="3000"
-       timer.queue_max_size="500"
-       thread_pool.enabled="true"
-       thread_pool.min_threads="2"
-       thread_pool.max_threads="30"
-       thread_pool.keep_alive_time="60000"
-       thread_pool.queue_enabled="false"
-       thread_pool.queue_max_size="100"
-       thread_pool.rejection_policy="discard"
-       oob_thread_pool.enabled="true"
-       oob_thread_pool.min_threads="2"
-       oob_thread_pool.max_threads="30"
-       oob_thread_pool.keep_alive_time="60000"
-       oob_thread_pool.queue_enabled="false"
-       oob_thread_pool.queue_max_size="100"
-       oob_thread_pool.rejection_policy="discard"/>
-
-    <!-- <TCP_NIO -->
-    <!--         bind_port="7800" -->
-    <!--         bind_interface="${jgroups.tcp_nio.bind_interface:bond0}" -->
-    <!--         use_send_queues="true" -->
-    <!--         sock_conn_timeout="300" -->
-    <!--         reader_threads="3" -->
-    <!--         writer_threads="3" -->
-    <!--         processor_threads="0" -->
-    <!--         processor_minThreads="0" -->
-    <!--         processor_maxThreads="0" -->
-    <!--         processor_queueSize="100" -->
-    <!--         processor_keepAliveTime="9223372036854775807"/> -->
-    <TCPGOSSIP initial_hosts="${jgroups.tcpgossip.initial_hosts}"/>
-    <!-- <TCPPING initial_hosts="${jgroups.tcpping.initial_hosts}" -->
-    <!--          port_range="0" -->
-    <!--          timeout="3000" -->
-    <!--          /> -->
-    <MERGE2 max_interval="30000" min_interval="10000"/>
-    <FD_SOCK/>
-    <FD timeout="3000" max_tries="3"/>
-    <VERIFY_SUSPECT timeout="1500"/>
-    <pbcast.NAKACK
-        use_mcast_xmit="false"
-        retransmit_timeout="300,600,1200,2400,4800"
-        discard_delivered_msgs="false"/>
-    <UNICAST2 timeout="300,600,1200"
-              stable_interval="5000"
-              max_bytes="1m"/>
-    <pbcast.STABLE stability_delay="500" desired_avg_gossip="5000" max_bytes="1m"/>
-    <pbcast.GMS print_local_addr="false" join_timeout="3000" view_bundling="true"/>
-    <UFC max_credits="200k" min_threshold="0.20"/>
-    <MFC max_credits="200k" min_threshold="0.20"/>
-    <FRAG2 frag_size="60000"/>
-    <RSVP timeout="60000" resend_interval="500" ack_on_delivery="false" />
-</config>
diff --git a/opendaylight/adsal/clustering/services_implementation/src/test/java/org/opendaylight/controller/clustering/services_implementation/internal/ClusterManagerTest.java b/opendaylight/adsal/clustering/services_implementation/src/test/java/org/opendaylight/controller/clustering/services_implementation/internal/ClusterManagerTest.java
deleted file mode 100644 (file)
index 3d234d3..0000000
+++ /dev/null
@@ -1,177 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.clustering.services_implementation.internal;
-
-import static org.junit.Assert.assertFalse;
-import static org.junit.Assert.fail;
-
-import java.net.InetAddress;
-import java.util.HashSet;
-import java.util.List;
-import java.util.Properties;
-
-import org.infinispan.CacheImpl;
-import org.junit.Assert;
-import org.junit.Test;
-import org.opendaylight.controller.clustering.services.CacheConfigException;
-import org.opendaylight.controller.clustering.services.CacheExistException;
-import org.opendaylight.controller.clustering.services.IClusterServices;
-import org.opendaylight.controller.clustering.services.IClusterServices.cacheMode;
-
-public class ClusterManagerTest {
-
-    @Test
-    public void noManagerSetTest() throws CacheExistException,
-            CacheConfigException {
-        ClusterManager cm = new ClusterManager();
-        CacheImpl<String, Integer> c1 = null;
-        CacheImpl<String, Integer> c2 = null;
-        Assert.assertNull(cm.createCache("Container", "Cache", null));
-        Assert.assertNull(cm.getCacheProperties("Container", "Cache"));
-        Assert.assertNull(cm.getCache("Container", "Cache"));
-        Assert.assertFalse(cm.existCache("Container", "Cache"));
-        Assert.assertNull(cm.getCacheList("Container"));
-        Assert.assertTrue(cm.amIStandby());
-        Assert.assertNull(cm.getActiveAddress());
-        Assert.assertNull(cm.getMyAddress());
-        Assert.assertNull(cm.getClusteredControllers());
-    }
-
-    @Test
-    public void withManagerTest() throws CacheExistException,
-            CacheConfigException {
-
-        ClusterManager cm = new ClusterManager();
-        CacheImpl<String, Integer> c1 = null;
-        CacheImpl<String, Integer> c2 = null;
-
-        cm.start();
-
-        // Check no cache created yet
-        assertFalse(cm.existCache("NonExistantContainerName",
-                "NonExistantCacheName"));
-
-        String cacheName = "Cache1";
-        String containerName = "Container1";
-        // Create cache with no cacheMode set, expecting it to fail
-        HashSet<cacheMode> cacheModeSet = new HashSet<cacheMode>();
-        Assert.assertNull(cm.createCache(containerName,cacheName, cacheModeSet));
-
-        // Create first cache as transactional
-        cacheModeSet.add(cacheMode.TRANSACTIONAL);
-        try {
-            c1 = (CacheImpl<String, Integer>) cm.createCache(containerName,
-                    cacheName, cacheModeSet);
-        } catch (CacheExistException | CacheConfigException cce) {
-           fail("Failed to create cache " + cacheName);
-        }
-
-        // Try creating exact same cache again
-        try {
-            c1 = (CacheImpl<String, Integer>) cm.createCache(containerName,
-                    cacheName, cacheModeSet);
-        } catch (CacheExistException cee) {
-
-        } catch (CacheConfigException cce) {
-            fail("Creating cache failed with " + cce);
-        }
-
-        // Create second cache with both types of cacheMode, expecting it to
-        // complain
-        String cacheName2 = "Cache2";
-        cacheModeSet.add(cacheMode.NON_TRANSACTIONAL);
-        try {
-            c2 = (CacheImpl<String, Integer>) cm.createCache(containerName,
-                    cacheName2, cacheModeSet);
-        } catch (CacheExistException cee) {
-            fail("Failed to create cache " + cacheName2 + cee);
-        } catch (CacheConfigException cce) {
-
-        }
-
-        // Create second cache NON_TRANSACTIONAL but with both ASYNC and SYNC,
-        // expect to complain
-        cacheModeSet.remove(cacheMode.TRANSACTIONAL);
-        cacheModeSet.add(cacheMode.SYNC);
-        cacheModeSet.add(cacheMode.ASYNC);
-        try {
-            c2 = (CacheImpl<String, Integer>) cm.createCache(containerName, cacheName2, cacheModeSet);
-        } catch (CacheExistException cee) {
-            fail("Attempted to create cache " + cacheName2 + " with illegal cache modes set " + cacheModeSet);
-        } catch (CacheConfigException cce) {
-
-        }
-
-        // Create second cache properly this time, as non_transactional and
-        // ASYNC
-        cacheModeSet.remove(cacheMode.SYNC);
-        try {
-            c2 = (CacheImpl<String, Integer>) cm.createCache(containerName,
-                    cacheName2, cacheModeSet);
-        } catch (CacheExistException | CacheConfigException e) {
-            fail("Failed to create cache " + cacheName + " though it was supposed to succeed." + e);
-        }
-
-        // Make sure correct caches exists
-        Assert.assertTrue(cm.existCache(containerName, cacheName));
-        c1 = (CacheImpl<String, Integer>) cm.getCache(containerName, cacheName);
-        Assert.assertNotNull(c1);
-
-        Assert.assertTrue(cm.existCache(containerName, cacheName2));
-        c2 = (CacheImpl<String, Integer>) cm.getCache(containerName, cacheName2);
-        Assert.assertNotNull(c2);
-
-        Assert.assertNull(cm.getCache(containerName, "Cache3"));
-
-        // Get CacheList
-        HashSet<String> cacheList = (HashSet<String>) cm
-                .getCacheList("Container2");
-        Assert.assertEquals(0, cacheList.size());
-
-        cacheList = (HashSet<String>) cm.getCacheList(containerName);
-        Assert.assertEquals(2, cacheList.size());
-        Assert.assertTrue(cacheList.contains(cacheName));
-        Assert.assertTrue(cacheList.contains(cacheName2));
-
-        // Get CacheProperties
-        Assert.assertNull(cm.getCacheProperties(containerName, ""));
-        Properties p = cm.getCacheProperties(containerName, cacheName);
-        Assert.assertEquals(3, p.size());
-        Assert.assertNotNull(p
-                .getProperty(IClusterServices.cacheProps.TRANSACTION_PROP
-                        .toString()));
-        Assert.assertNotNull(p
-                .getProperty(IClusterServices.cacheProps.CLUSTERING_PROP
-                        .toString()));
-        Assert.assertNotNull(p
-                .getProperty(IClusterServices.cacheProps.LOCKING_PROP
-                        .toString()));
-
-        // Destroy cache1 and make sure it's gone
-        cm.destroyCache(containerName, cacheName);
-        cm.destroyCache(containerName, "Cache3");
-        Assert.assertFalse(cm.existCache(containerName, cacheName));
-        Assert.assertTrue(cm.existCache(containerName, cacheName2));
-
-        // Check amIStandBy()
-        boolean standby = cm.amIStandby();
-        Assert.assertFalse(standby);
-
-        // Check addresses, which are all loopback
-        InetAddress activeAddress = cm.getActiveAddress();
-        Assert.assertEquals("/127.0.0.1", activeAddress.toString());
-        InetAddress myAddress = cm.getMyAddress();
-        Assert.assertEquals("/127.0.0.1", myAddress.toString());
-
-        List<InetAddress> cc = cm.getClusteredControllers();
-        Assert.assertEquals(0, cc.size());
-
-        cm.stop();
-    }
-
-}
diff --git a/opendaylight/adsal/clustering/stub/pom.xml b/opendaylight/adsal/clustering/stub/pom.xml
deleted file mode 100644 (file)
index b2e845f..0000000
+++ /dev/null
@@ -1,55 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>clustering.stub</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>clustering.services</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Import-Package>javax.transaction,
-              org.apache.felix.dm,
-              org.slf4j,
-              org.opendaylight.controller.clustering.services,
-              org.opendaylight.controller.sal.core</Import-Package>
-            <Bundle-Activator>org.opendaylight.controller.clustering.stub.internal.Activator</Bundle-Activator>
-          </instructions>
-          <manifestLocation>${project.basedir}/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/clustering/stub/src/main/java/org/opendaylight/controller/clustering/stub/internal/Activator.java b/opendaylight/adsal/clustering/stub/src/main/java/org/opendaylight/controller/clustering/stub/internal/Activator.java
deleted file mode 100644 (file)
index 437d736..0000000
+++ /dev/null
@@ -1,89 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.clustering.stub.internal;
-
-import org.opendaylight.controller.sal.core.ComponentActivatorAbstractBase;
-
-import org.opendaylight.controller.clustering.services.IClusterContainerServices;
-import org.opendaylight.controller.clustering.services.IClusterGlobalServices;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-import org.apache.felix.dm.Component;
-
-public class Activator extends ComponentActivatorAbstractBase {
-    protected static final Logger logger = LoggerFactory
-            .getLogger(Activator.class);
-
-
-    /**
-     * Function that is used to communicate to dependency manager the
-     * list of known implementations for services inside a container
-     *
-     *
-     * @return An array containing all the CLASS objects that will be
-     * instantiated in order to get an fully working implementation
-     * Object
-     */
-    public Object[] getGlobalImplementations() {
-        Object[] res = { ClusterGlobalManager.class };
-        return res;
-    }
-
-    /**
-     * Function that is used to communicate to dependency manager the
-     * list of known implementations for services inside a container
-     *
-     *
-     * @return An array containing all the CLASS objects that will be
-     * instantiated in order to get an fully working implementation
-     * Object
-     */
-    public Object[] getImplementations() {
-        Object[] res = { ClusterContainerManager.class };
-        return res;
-    }
-
-    /**
-     * Function that is called when configuration of the dependencies
-     * is required.
-     *
-     * @param c dependency manager Component object, used for
-     * configuring the dependencies exported and imported
-     * @param imp Implementation class that is being configured,
-     * needed as long as the same routine can configure multiple
-     * implementations
-     * @param containerName The containerName being configured, this allow
-     * also optional per-container different behavior if needed, usually
-     * should not be the case though.
-     */
-    public void configureInstance(Component c, Object imp, String containerName) {
-        if (imp.equals(ClusterContainerManager.class)) {
-            c.setInterface(new String[] { IClusterContainerServices.class
-                    .getName() }, null);
-        }
-    }
-
-    /**
-     * Function that is called when configuration of the dependencies
-     * is required.
-     *
-     * @param c dependency manager Component object, used for
-     * configuring the dependencies exported and imported
-     * @param imp Implementation class that is being configured,
-     * needed as long as the same routine can configure multiple
-     * implementations
-     */
-    public void configureGlobalInstance(Component c, Object imp) {
-        if (imp.equals(ClusterGlobalManager.class)) {
-            c.setInterface(new String[] { IClusterGlobalServices.class
-                    .getName() }, null);
-        }
-    }
-}
diff --git a/opendaylight/adsal/clustering/stub/src/main/java/org/opendaylight/controller/clustering/stub/internal/ClusterContainerManager.java b/opendaylight/adsal/clustering/stub/src/main/java/org/opendaylight/controller/clustering/stub/internal/ClusterContainerManager.java
deleted file mode 100644 (file)
index 627db22..0000000
+++ /dev/null
@@ -1,21 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.clustering.stub.internal;
-
-import java.net.UnknownHostException;
-
-import org.opendaylight.controller.clustering.services.IClusterContainerServices;
-
-public class ClusterContainerManager extends ClusterManagerCommon implements
-        IClusterContainerServices {
-    public ClusterContainerManager() throws UnknownHostException {
-        super();
-    }
-}
diff --git a/opendaylight/adsal/clustering/stub/src/main/java/org/opendaylight/controller/clustering/stub/internal/ClusterGlobalManager.java b/opendaylight/adsal/clustering/stub/src/main/java/org/opendaylight/controller/clustering/stub/internal/ClusterGlobalManager.java
deleted file mode 100644 (file)
index 6dcc0a1..0000000
+++ /dev/null
@@ -1,23 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.clustering.stub.internal;
-
-import java.net.UnknownHostException;
-
-import org.opendaylight.controller.clustering.services.IClusterGlobalServices;
-
-public class ClusterGlobalManager extends ClusterManagerCommon implements
-        IClusterGlobalServices {
-    public ClusterGlobalManager() throws UnknownHostException {
-        super();
-    }
-    public void removeContainerCaches(String containerName) {
-    }
-}
diff --git a/opendaylight/adsal/clustering/stub/src/main/java/org/opendaylight/controller/clustering/stub/internal/ClusterManagerCommon.java b/opendaylight/adsal/clustering/stub/src/main/java/org/opendaylight/controller/clustering/stub/internal/ClusterManagerCommon.java
deleted file mode 100644 (file)
index f27e6f0..0000000
+++ /dev/null
@@ -1,159 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.clustering.stub.internal;
-
-import java.net.InetAddress;
-import java.net.UnknownHostException;
-import java.util.ArrayList;
-import java.util.Dictionary;
-import java.util.List;
-import java.util.Properties;
-import java.util.Set;
-import java.util.concurrent.ConcurrentHashMap;
-import java.util.concurrent.ConcurrentMap;
-import java.util.concurrent.TimeUnit;
-
-import javax.transaction.HeuristicMixedException;
-import javax.transaction.HeuristicRollbackException;
-import javax.transaction.NotSupportedException;
-import javax.transaction.RollbackException;
-import javax.transaction.SystemException;
-import javax.transaction.Transaction;
-
-import org.apache.felix.dm.Component;
-import org.opendaylight.controller.clustering.services.CacheConfigException;
-import org.opendaylight.controller.clustering.services.CacheExistException;
-import org.opendaylight.controller.clustering.services.IClusterServices;
-import org.opendaylight.controller.clustering.services.IClusterServicesCommon;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-public abstract class ClusterManagerCommon implements IClusterServicesCommon {
-    protected String containerName = "";
-    protected static final Logger logger = LoggerFactory
-            .getLogger(ClusterManagerCommon.class);
-    private InetAddress loopbackAddress;
-    private ConcurrentMap<String, ConcurrentMap<?, ?>> caches = new ConcurrentHashMap<String, ConcurrentMap<?, ?>>();
-
-    protected ClusterManagerCommon() throws UnknownHostException {
-        loopbackAddress = InetAddress.getLoopbackAddress();
-    }
-
-    /**
-     * Function called by the dependency manager when all the required
-     * dependencies are satisfied
-     *
-     */
-    void init(Component c) {
-        Dictionary props = c.getServiceProperties();
-        if (props != null) {
-            this.containerName = (String) props.get("containerName");
-            logger.debug("Running containerName: {}", this.containerName);
-        } else {
-            // In the Global instance case the containerName is empty
-            this.containerName = "";
-        }
-    }
-
-    /**
-     * Function called by the dependency manager when any of the required
-     * dependencies are going away
-     *
-     */
-    void destroy() {
-        // Clear the caches, will restart on the new life
-        this.caches.clear();
-    }
-
-    @Override
-    public ConcurrentMap<?, ?> createCache(String cacheName,
-            Set<IClusterServices.cacheMode> cMode) throws CacheExistException,
-            CacheConfigException {
-        ConcurrentMap<?, ?> res = this.caches.get(cacheName);
-        if (res == null) {
-            res = new ConcurrentHashMap<Object, Object>();
-            this.caches.put(cacheName, res);
-            return res;
-        }
-        throw new CacheExistException();
-    }
-
-    @Override
-    public ConcurrentMap<?, ?> getCache(String cacheName) {
-        return this.caches.get(cacheName);
-    }
-
-    @Override
-    public void destroyCache(String cacheName) {
-        this.caches.remove(cacheName);
-    }
-
-    @Override
-    public boolean existCache(String cacheName) {
-        return (this.caches.get(cacheName) != null);
-    }
-
-    @Override
-    public Set<String> getCacheList() {
-        return this.caches.keySet();
-    }
-
-    @Override
-    public Properties getCacheProperties(String cacheName) {
-        return null;
-    }
-
-    @Override
-    public void tbegin() throws NotSupportedException, SystemException {
-    }
-
-    @Override
-    public void tcommit() throws RollbackException, HeuristicMixedException,
-            HeuristicRollbackException, java.lang.SecurityException,
-            java.lang.IllegalStateException, SystemException {
-    }
-
-    @Override
-    public void tbegin(long timeout, TimeUnit unit) throws NotSupportedException, SystemException {
-
-    }
-
-    @Override
-    public void trollback() throws java.lang.IllegalStateException,
-            java.lang.SecurityException, SystemException {
-    }
-
-    @Override
-    public Transaction tgetTransaction() throws SystemException {
-        return null;
-    }
-
-    @Override
-    public List<InetAddress> getClusteredControllers() {
-        List<InetAddress> res = new ArrayList<InetAddress>();
-        res.add(loopbackAddress);
-        return res;
-    }
-
-    @Override
-    public InetAddress getMyAddress() {
-        return loopbackAddress;
-    }
-
-    @Override
-    public InetAddress getCoordinatorAddress() {
-        return loopbackAddress;
-    }
-
-    @Override
-    public boolean amICoordinator() {
-        return true;
-    }
-}
diff --git a/opendaylight/adsal/clustering/stub/src/test/java/org/opendaylight/controller/clustering/stub/internal/TestClusteringStub.java b/opendaylight/adsal/clustering/stub/src/test/java/org/opendaylight/controller/clustering/stub/internal/TestClusteringStub.java
deleted file mode 100644 (file)
index 93f35ac..0000000
+++ /dev/null
@@ -1,201 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * @file   TestClusteringStub.java
- *
- * @brief  Unit tests for the stub implementation of clustering,
- * needed only to run the integration tests
- *
- * Unit tests for the stub implementation of clustering,
- * needed only to run the integration tests
- */
-package org.opendaylight.controller.clustering.stub.internal;
-
-import java.util.Set;
-import java.util.concurrent.ConcurrentMap;
-
-import java.net.UnknownHostException;
-import org.junit.Assert;
-import org.junit.Test;
-import org.opendaylight.controller.clustering.services.CacheConfigException;
-import org.opendaylight.controller.clustering.services.CacheExistException;
-import org.opendaylight.controller.clustering.services.IClusterGlobalServices;
-
-public class TestClusteringStub {
-    @Test
-    public void testStub1() {
-        IClusterGlobalServices c = null;
-        ClusterGlobalManager cm = null;
-        try {
-            cm = new ClusterGlobalManager();
-            c = (IClusterGlobalServices) cm;
-        } catch (UnknownHostException un) {
-            // Don't expect this assertion, so if happens signal a
-            // failure in the testcase
-            Assert.assertTrue(false);
-        }
-
-        // Make sure the stub cluster manager is allocated
-        Assert.assertTrue(cm != null);
-        Assert.assertTrue(c != null);
-
-        // ========================================
-        // Now start testing the several aspects of it.
-        // ========================================
-
-        // Allocate few caches
-        ConcurrentMap<String, Integer> c1 = null;
-        ConcurrentMap<String, Integer> c2 = null;
-        ConcurrentMap<String, Integer> c3 = null;
-        try {
-            c1 = (ConcurrentMap<String, Integer>) c.createCache("c1", null);
-        } catch (CacheExistException cee) {
-            // Don't expect this assertion, so if happens signal a
-            // failure in the testcase
-            Assert.assertTrue(false);
-        } catch (CacheConfigException cce) {
-            // Don't expect this assertion, so if happens signal a
-            // failure in the testcase
-            Assert.assertTrue(false);
-        }
-
-        // Put some data to it
-        c1.put("FOO", 1);
-        c1.put("BAZ", 2);
-        c1.put("BAR", 3);
-
-        try {
-            c1 = (ConcurrentMap<String, Integer>) c.createCache("c1", null);
-        } catch (CacheExistException cee) {
-            // This exception should be raised because the cache
-            // already exists
-            Assert.assertTrue(true);
-        } catch (CacheConfigException cce) {
-            // Don't expect this assertion, so if happens signal a
-            // failure in the testcase
-            Assert.assertTrue(false);
-        }
-
-        // Make sure this cache is retrieved
-        c1 = (ConcurrentMap<String, Integer>) c.getCache("c1");
-        Assert.assertTrue(c1 != null);
-
-        // Now make sure the data exists
-        Integer res = null;
-        res = c1.get("FOO");
-        Assert.assertTrue(res != null);
-        res = c1.get("BAR");
-        Assert.assertTrue(res != null);
-        res = c1.get("BAZ");
-        Assert.assertTrue(res != null);
-
-        // Now create yet another two caches
-        try {
-            c2 = (ConcurrentMap<String, Integer>) c.createCache("c2", null);
-            c3 = (ConcurrentMap<String, Integer>) c.createCache("c3", null);
-        } catch (CacheExistException cee) {
-            // Don't expect this assertion, so if happens signal a
-            // failure in the testcase
-            Assert.assertTrue(false);
-        } catch (CacheConfigException cce) {
-            // Don't expect this assertion, so if happens signal a
-            // failure in the testcase
-            Assert.assertTrue(false);
-        }
-
-        // Make sure the caches exist
-        Assert.assertTrue(c2 != null);
-        Assert.assertTrue(c3 != null);
-
-        // Put some fake data
-        c2.put("FOO", 11);
-        c2.put("BAZ", 22);
-        c2.put("BAR", 33);
-
-        c3.put("FOOBAR", 110);
-
-        // Test for cache existance
-        Assert.assertTrue(c.existCache("c1"));
-        Assert.assertTrue(c.existCache("c2"));
-        Assert.assertTrue(c.existCache("c3"));
-
-        // Get the Cache List
-        Set<String> caches = c.getCacheList();
-        Assert.assertTrue(caches != null);
-
-        // Check if the cachelist is correct
-        System.out.println("cache size:" + caches.size());
-        Assert.assertTrue(caches.size() == 3);
-        Assert.assertTrue(caches.contains("c1"));
-        Assert.assertTrue(caches.contains("c2"));
-        Assert.assertTrue(caches.contains("c3"));
-
-        // Check that the utility API for the cluster are working too
-        Assert.assertTrue(c.getCoordinatorAddress() != null);
-        Assert.assertTrue(c.getClusteredControllers() != null);
-        // This a one man-show
-        Assert.assertTrue(c.getClusteredControllers().size() == 1);
-        Assert.assertTrue(c.getMyAddress() != null);
-        // Make sure i'm the coordinator
-        Assert.assertTrue(c.amICoordinator());
-
-        // Now destroy some caches make sure they are gone
-        c.destroyCache("c1");
-        Assert.assertTrue(!c.existCache("c1"));
-        caches = c.getCacheList();
-        Assert.assertTrue(caches.size() == 2);
-
-        // Now recreate the cache, make sure a different one is
-        // retrieved, which should be empty
-        try {
-            c1 = (ConcurrentMap<String, Integer>) c.createCache("c1", null);
-        } catch (CacheExistException cee) {
-            // This exception should be raised because the cache
-            // already exists
-            Assert.assertTrue(true);
-        } catch (CacheConfigException cce) {
-            // Don't expect this assertion, so if happens signal a
-            // failure in the testcase
-            Assert.assertTrue(false);
-        }
-        c1 = (ConcurrentMap<String, Integer>) c.getCache("c1");
-        Assert.assertTrue(c1 != null);
-        Assert.assertTrue(c1.keySet().size() == 0);
-        caches = c.getCacheList();
-        Assert.assertTrue(caches.size() == 3);
-
-        // Now destroy the cache manager and make sure things are
-        // clean
-        cm.destroy();
-        caches = c.getCacheList();
-        Assert.assertTrue(caches.size() == 0);
-
-        // Now to re-create two caches and make sure they exists, but
-        // are different than in previous life
-        try {
-            c2 = (ConcurrentMap<String, Integer>) c.createCache("c2", null);
-            c3 = (ConcurrentMap<String, Integer>) c.createCache("c3", null);
-        } catch (CacheExistException cee) {
-            // Don't expect this assertion, so if happens signal a
-            // failure in the testcase
-            Assert.assertTrue(false);
-        } catch (CacheConfigException cce) {
-            // Don't expect this assertion, so if happens signal a
-            // failure in the testcase
-            Assert.assertTrue(false);
-        }
-        Assert.assertTrue(c2 != null);
-        Assert.assertTrue(c3 != null);
-        caches = c.getCacheList();
-        Assert.assertTrue(caches.size() == 2);
-        Assert.assertTrue(c2.keySet().size() == 0);
-        Assert.assertTrue(c3.keySet().size() == 0);
-    }
-}
diff --git a/opendaylight/adsal/clustering/test/pom.xml b/opendaylight/adsal/clustering/test/pom.xml
deleted file mode 100644 (file)
index 6e2c6dc..0000000
+++ /dev/null
@@ -1,87 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>clustering.test</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>ch.qos.logback</groupId>
-      <artifactId>logback-classic</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>ch.qos.logback</groupId>
-      <artifactId>logback-core</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>org.apache.felix.gogo.command</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>org.apache.felix.gogo.runtime</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>org.apache.felix.gogo.shell</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>org.eclipse.osgi</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>org.eclipse.osgi.services</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>clustering.services</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-      <scope>test</scope>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Import-Package>org.slf4j,
-            javax.transaction,
-            org.eclipse.osgi.framework.console,
-            ch.qos.logback.classic,
-            org.opendaylight.controller.clustering.services,
-            org.opendaylight.controller.sal.core,
-            org.apache.felix.dm</Import-Package>
-            <Export-Package>org.opendaylight.controller.clustering.test.internal</Export-Package>
-            <Bundle-Activator>org.opendaylight.controller.clustering.test.internal.Activator</Bundle-Activator>
-          </instructions>
-          <manifestLocation>${project.basedir}/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/clustering/test/src/main/java/org/opendaylight/controller/clustering/test/internal/Activator.java b/opendaylight/adsal/clustering/test/src/main/java/org/opendaylight/controller/clustering/test/internal/Activator.java
deleted file mode 100644 (file)
index 1c02a14..0000000
+++ /dev/null
@@ -1,57 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.clustering.test.internal;
-
-import org.opendaylight.controller.sal.core.ComponentActivatorAbstractBase;
-import org.opendaylight.controller.clustering.services.IClusterServices;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-import org.apache.felix.dm.Component;
-
-public class Activator extends ComponentActivatorAbstractBase {
-    protected static final Logger logger = LoggerFactory
-            .getLogger(Activator.class);
-
-
-    /**
-     * Function that is used to communicate to dependency manager the
-     * list of known implementations for services inside a container
-     *
-     *
-     * @return An array containing all the CLASS objects that will be
-     * instantiated in order to get an fully working implementation
-     * Object
-     */
-    public Object[] getGlobalImplementations() {
-        Object[] res = { SimpleClient.class };
-        return res;
-    }
-
-    /**
-     * Function that is called when configuration of the dependencies
-     * is required.
-     *
-     * @param c dependency manager Component object, used for
-     * configuring the dependencies exported and imported
-     * @param imp Implementation class that is being configured,
-     * needed as long as the same routine can configure multiple
-     * implementations
-     */
-    public void configureGlobalInstance(Component c, Object imp) {
-        if (imp.equals(SimpleClient.class)) {
-            // export the service for Apps and Plugins
-            c.setInterface(new String[] { org.eclipse.osgi.framework.console.CommandProvider.class.getName() },
-                           null);
-            c.add(createServiceDependency().setService(IClusterServices.class)
-                  .setCallbacks("setIClusterServices", "unsetIClusterServices")
-                  .setRequired(true));
-        }
-    }
-}
diff --git a/opendaylight/adsal/clustering/test/src/main/java/org/opendaylight/controller/clustering/test/internal/ComplexClass.java b/opendaylight/adsal/clustering/test/src/main/java/org/opendaylight/controller/clustering/test/internal/ComplexClass.java
deleted file mode 100644 (file)
index 51f8128..0000000
+++ /dev/null
@@ -1,31 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.clustering.test.internal;
-
-import java.io.Serializable;
-
-public class ComplexClass implements IComplex, Serializable {
-    private static final long serialVersionUID = 1L;
-    private String identity;
-
-    public ComplexClass(String i) {
-        this.identity = i;
-    }
-
-    @Override
-    public String whoAmI() {
-        return ("ComplexClass_" + this.identity);
-    }
-
-    @Override
-    public void IAm(String s) {
-        this.identity = s;
-    }
-}
diff --git a/opendaylight/adsal/clustering/test/src/main/java/org/opendaylight/controller/clustering/test/internal/ComplexClass1.java b/opendaylight/adsal/clustering/test/src/main/java/org/opendaylight/controller/clustering/test/internal/ComplexClass1.java
deleted file mode 100644 (file)
index 876fb65..0000000
+++ /dev/null
@@ -1,31 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.clustering.test.internal;
-
-import java.io.Serializable;
-
-public class ComplexClass1 implements IComplex, Serializable {
-    private static final long serialVersionUID = 1L;
-    private String identity;
-
-    public ComplexClass1(String i) {
-        this.identity = i;
-    }
-
-    @Override
-    public String whoAmI() {
-        return ("ComplexClass1_" + this.identity);
-    }
-
-    @Override
-    public void IAm(String s) {
-        this.identity = s;
-    }
-}
diff --git a/opendaylight/adsal/clustering/test/src/main/java/org/opendaylight/controller/clustering/test/internal/ComplexContainer.java b/opendaylight/adsal/clustering/test/src/main/java/org/opendaylight/controller/clustering/test/internal/ComplexContainer.java
deleted file mode 100644 (file)
index d07c192..0000000
+++ /dev/null
@@ -1,50 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.clustering.test.internal;
-
-import java.io.Serializable;
-
-public class ComplexContainer implements Serializable {
-    private static final long serialVersionUID = 1L;
-    private final IComplex f;
-    private final IComplex f1;
-    private final Integer state;
-
-    public ComplexContainer(String i, Integer s) {
-        this.state = s;
-        this.f = new ComplexClass(i);
-        this.f1 = new ComplexClass1(i);
-    }
-
-    public String getIdentity() {
-        if (this.f != null && this.f1 != null) {
-            return ("[" + f.whoAmI() + "]-[" + f1.whoAmI() + "]");
-        }
-        return "<NOTSET>";
-    }
-
-    public void setIdentity(String i) {
-        if (this.f != null) {
-            this.f.IAm(i);
-        }
-        if (this.f1 != null) {
-            this.f1.IAm(i);
-        }
-    }
-
-    public Integer getState() {
-        return this.state;
-    }
-
-    @Override
-    public String toString() {
-        return ("{ID:" + this.getIdentity() + ",STATE:" + this.state + "}");
-    }
-}
diff --git a/opendaylight/adsal/clustering/test/src/main/java/org/opendaylight/controller/clustering/test/internal/IComplex.java b/opendaylight/adsal/clustering/test/src/main/java/org/opendaylight/controller/clustering/test/internal/IComplex.java
deleted file mode 100644 (file)
index c1d5c31..0000000
+++ /dev/null
@@ -1,16 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.clustering.test.internal;
-
-public interface IComplex {
-    String whoAmI();
-
-    void IAm(String s);
-}
diff --git a/opendaylight/adsal/clustering/test/src/main/java/org/opendaylight/controller/clustering/test/internal/LoggingListener.java b/opendaylight/adsal/clustering/test/src/main/java/org/opendaylight/controller/clustering/test/internal/LoggingListener.java
deleted file mode 100644 (file)
index 1aef9ce..0000000
+++ /dev/null
@@ -1,40 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.clustering.test.internal;
-
-import org.opendaylight.controller.clustering.services.IGetUpdates;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-public class LoggingListener implements IGetUpdates<Integer, StringContainer> {
-    protected static Logger logger = LoggerFactory
-            .getLogger(LoggingListener.class);
-
-    @Override
-    public void entryCreated(Integer key, String containerName,
-            String cacheName, boolean originLocal) {
-        logger.debug(" Cache entry with key " + key + " created in cache "
-                + cacheName);
-    }
-
-    @Override
-    public void entryUpdated(Integer key, StringContainer newValue,
-            String containerName, String cacheName, boolean originLocal) {
-        logger.debug(" Cache entry with key " + key + " modified to value "
-                + newValue + "  in cache " + cacheName);
-    }
-
-    @Override
-    public void entryDeleted(Integer key, String containerName,
-            String cacheName, boolean originLocal) {
-        logger.debug(" Cache entry with key " + key + " removed in cache "
-                + cacheName);
-    }
-}
diff --git a/opendaylight/adsal/clustering/test/src/main/java/org/opendaylight/controller/clustering/test/internal/SimpleClient.java b/opendaylight/adsal/clustering/test/src/main/java/org/opendaylight/controller/clustering/test/internal/SimpleClient.java
deleted file mode 100644 (file)
index 52cc56e..0000000
+++ /dev/null
@@ -1,653 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.clustering.test.internal;
-
-import java.net.InetAddress;
-import java.util.ArrayList;
-import java.util.EnumSet;
-import java.util.List;
-import java.util.Map;
-import java.util.Properties;
-import java.util.Set;
-import java.util.concurrent.ConcurrentMap;
-
-import org.eclipse.osgi.framework.console.CommandInterpreter;
-import org.eclipse.osgi.framework.console.CommandProvider;
-import org.opendaylight.controller.clustering.services.CacheConfigException;
-import org.opendaylight.controller.clustering.services.CacheExistException;
-import org.opendaylight.controller.clustering.services.CacheListenerAddException;
-import org.opendaylight.controller.clustering.services.IClusterServices;
-import org.opendaylight.controller.clustering.services.IGetUpdates;
-import org.opendaylight.controller.clustering.services.IListenRoleChange;
-import org.opendaylight.controller.clustering.services.ListenRoleChangeAddException;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-public class SimpleClient implements CommandProvider {
-    protected static Logger logger = LoggerFactory
-            .getLogger(SimpleClient.class);
-    IClusterServices icluster;
-    DoListenRoleChanged doListen;
-
-    public void _tbegin(CommandInterpreter ci) {
-        if (this.icluster == null) {
-            ci.println("\nNo Clustering services available");
-            return;
-        }
-        try {
-            this.icluster.tbegin();
-            ci.println("Transaction Open "
-                    + this.icluster.tgetTransaction().toString());
-        } catch (Exception e) {
-            ci.println("Caught exception during transaction begin: " + e);
-        }
-    }
-
-    public void _tcommit(CommandInterpreter ci) {
-        if (this.icluster == null) {
-            ci.println("\nNo Clustering services available");
-            return;
-        }
-        try {
-            ci.println("Committing transaction ....."
-                    + this.icluster.tgetTransaction().toString());
-            this.icluster.tcommit();
-            ci.println("Transaction Committed");
-        } catch (Exception e) {
-            ci.println("Caught exception during transaction commit: " + e);
-        }
-    }
-
-    public void _trollback(CommandInterpreter ci) {
-        if (this.icluster == null) {
-            ci.println("\nNo Clustering services available");
-            return;
-        }
-        try {
-            ci.println("Rolling back transaction ....."
-                    + this.icluster.tgetTransaction().toString());
-            this.icluster.trollback();
-            ci.println("Transaction Rolled Back");
-        } catch (Exception e) {
-            ci.println("Caught exception during transaction rollback: " + e);
-        }
-    }
-
-    public void _cacheinfo(CommandInterpreter ci) {
-        if (this.icluster == null) {
-            ci.println("\nNo Clustering services available");
-            return;
-        }
-        String containerName = ci.nextArgument();
-        if (containerName == null) {
-            ci.println("containerName not supplied");
-            return;
-        }
-        String cacheName = ci.nextArgument();
-        if (cacheName == null) {
-            ci.println("Cache not supplied");
-            return;
-        }
-        if (!this.icluster.existCache(containerName, cacheName)) {
-            ci.println("\tCache " + cacheName + " doesn't exists");
-            return;
-        }
-        ci.println("\tInfo for cache " + cacheName + " on container "
-                + containerName);
-        Properties p = this.icluster.getCacheProperties(containerName,
-                cacheName);
-        if (p != null) {
-            for (String key : p.stringPropertyNames()) {
-                ci.println("\t\t" + key + " = " + p.getProperty(key));
-            }
-        }
-    }
-
-    public void _setLogLevel(CommandInterpreter ci) {
-        String loggerName = ci.nextArgument();
-        if (loggerName == null) {
-            ci.println("Logger Name not supplied");
-            return;
-        }
-        String loggerLevel = ci.nextArgument();
-        if (loggerLevel == null) {
-            ci.println("Logger Level not supplied");
-            return;
-        }
-
-        ch.qos.logback.classic.Logger l = (ch.qos.logback.classic.Logger) LoggerFactory
-                .getLogger(loggerName);
-        ch.qos.logback.classic.Level level = ch.qos.logback.classic.Level
-                .toLevel(loggerLevel);
-        if (level == null) {
-            ci.println("Level not understood");
-            return;
-        }
-        l.setLevel(level);
-    }
-
-    private String retrieveLogLevel(ch.qos.logback.classic.Logger l) {
-        if (l == null) {
-            return ("Logger not supplied");
-        }
-        ch.qos.logback.classic.Level level = l.getLevel();
-        if (level == null) {
-            return ("Logger " + l.getName() + " at unknown level");
-        } else {
-            return ("Logger " + l.getName() + " at level " + l.getLevel()
-                    .toString());
-        }
-    }
-
-    public void _getLogLevel(CommandInterpreter ci) {
-        String loggerName = ci.nextArgument();
-        ch.qos.logback.classic.LoggerContext lc = (ch.qos.logback.classic.LoggerContext) LoggerFactory
-                .getILoggerFactory();
-        if (lc != null) {
-            for (ch.qos.logback.classic.Logger l : lc.getLoggerList()) {
-                if ((loggerName == null) || l.getName().startsWith(loggerName)) {
-                    ci.println(retrieveLogLevel(l));
-                }
-            }
-        }
-    }
-
-    public void _create(CommandInterpreter ci) {
-        if (this.icluster == null) {
-            ci.println("\nNo Clustering services available");
-            return;
-        }
-        String containerName = ci.nextArgument();
-        if (containerName == null) {
-            ci.println("containerName not supplied");
-            return;
-        }
-        String cacheName = ci.nextArgument();
-        if (cacheName == null) {
-            ci.println("Cache not supplied");
-            return;
-        }
-        try {
-            if (cacheName.startsWith("T-")) {
-                this.icluster.createCache(containerName, cacheName, EnumSet
-                        .of(IClusterServices.cacheMode.TRANSACTIONAL));
-            } else {
-                this.icluster.createCache(containerName, cacheName, EnumSet
-                        .of(IClusterServices.cacheMode.NON_TRANSACTIONAL));
-            }
-        } catch (CacheExistException ce) {
-            ci
-                    .println("\nCache already exits - destroy and recreate if needed");
-            return;
-        } catch (CacheConfigException cfe) {
-            ci.println("\nCache configured with contrasting parameters");
-            return;
-        }
-
-        if (this.icluster.existCache(containerName, cacheName)) {
-            ci.println(cacheName + " has been created on container "
-                    + containerName);
-        }
-    }
-
-    public void _destroy(CommandInterpreter ci) {
-        if (this.icluster == null) {
-            ci.println("\nNo Clustering services available");
-            return;
-        }
-        String containerName = ci.nextArgument();
-        if (containerName == null) {
-            ci.println("containerName not supplied");
-            return;
-        }
-        String cacheName = ci.nextArgument();
-        if (cacheName == null) {
-            ci.println("Cache not supplied");
-            return;
-        }
-        if (this.icluster.existCache(containerName, cacheName)) {
-            this.icluster.destroyCache(containerName, cacheName);
-            ci.println(cacheName + " has been destroyed");
-        }
-    }
-
-    public void _listen(CommandInterpreter ci) {
-        if (this.icluster == null) {
-            ci.println("\nNo Clustering services available");
-            return;
-        }
-        String containerName = ci.nextArgument();
-        if (containerName == null) {
-            ci.println("containerName not supplied");
-            return;
-        }
-        String cacheName = ci.nextArgument();
-        if (cacheName == null) {
-            ci.println("Cache not supplied");
-            return;
-        }
-        try {
-            this.icluster.addListener(containerName, cacheName,
-                    new LoggingListener());
-            ci.println("cache " + cacheName + " on container " + containerName
-                    + " is begin monitored for updates");
-        } catch (CacheListenerAddException clae) {
-            ci.println("Couldn't attach the listener to cache " + cacheName
-                    + " on container " + containerName);
-        }
-    }
-
-    @SuppressWarnings("deprecation") //IGetUpdates intentionally deprecated
-    public void _unlisten(CommandInterpreter ci) {
-        if (this.icluster == null) {
-            ci.println("\nNo Clustering services available");
-            return;
-        }
-        String containerName = ci.nextArgument();
-        if (containerName == null) {
-            ci.println("containerName not supplied");
-            return;
-        }
-        String cacheName = ci.nextArgument();
-        if (cacheName == null) {
-            ci.println("Cache not supplied");
-            return;
-        }
-
-        Set<IGetUpdates<?, ?>> listeners = this.icluster.getListeners(
-                containerName, cacheName);
-        for (IGetUpdates<?, ?> l : listeners) {
-            this.icluster.removeListener(containerName, cacheName, l);
-        }
-        ci.println(cacheName + " is no longer being monitored for updates");
-    }
-
-    public void _myController(CommandInterpreter ci) {
-        if (this.icluster == null) {
-            ci.println("\nNo Clustering services available");
-            return;
-        }
-        ci.println("This Controller : " +icluster.getMyAddress().getHostAddress());
-    }
-
-    public void _getClusterNodes(CommandInterpreter ci) {
-        if (this.icluster == null) {
-            ci.println("\nNo Clustering services available");
-            return;
-        }
-        for (InetAddress address : icluster.getClusteredControllers()) {
-            ci.println("\t"+address.getHostAddress());
-        }
-    }
-
-    public void _listcaches(CommandInterpreter ci) {
-        if (this.icluster == null) {
-            ci.println("\nNo Clustering services available");
-            return;
-        }
-        String containerName = ci.nextArgument().toLowerCase();
-        if (containerName == null) {
-            ci.println("containerName not supplied");
-            return;
-        }
-
-        // For user's convenience, let's return the sorted cache list
-        List<String> sortedCacheList = new ArrayList<String>(this.icluster
-                .getCacheList(containerName));
-        java.util.Collections.sort(sortedCacheList);
-        for (String cacheName : sortedCacheList) {
-            ci.println("\t" + cacheName);
-        }
-    }
-
-    public void _put(CommandInterpreter ci) {
-        ConcurrentMap<Integer, StringContainer> c;
-        if (this.icluster == null) {
-            ci.println("\nNo Clustering services available");
-            return;
-        }
-        String containerName = ci.nextArgument();
-        if (containerName == null) {
-            ci.println("containerName not supplied");
-            return;
-        }
-        String cacheName = ci.nextArgument();
-        if (cacheName == null) {
-            ci.println("Cache not supplied");
-            return;
-        }
-        String sKey = ci.nextArgument();
-        String sValue = ci.nextArgument();
-        if (sKey == null) {
-            ci.println("Key not supplied");
-            return;
-        }
-        if (sValue == null) {
-            ci.println("Value not supplied");
-            return;
-        }
-        Integer key = null;
-        try {
-            key = Integer.valueOf(sKey);
-        } catch (NumberFormatException nfe) {
-            ci.println("Key is not a valid integer: " + sKey);
-        }
-
-        c = (ConcurrentMap<Integer, StringContainer>) this.icluster.getCache(
-                containerName, cacheName);
-        if (c != null) {
-            ci.println("\nAdd mapping " + key + " = " + sValue);
-            try {
-                c.put(key, new StringContainer(sValue));
-            } catch (Exception e) {
-                ci.println("Exception raised:" + e);
-                ci.println("\tStacktrace:");
-                e.printStackTrace();
-            }
-        } else {
-            ci.println("Cache " + cacheName + " on container " + containerName
-                    + " not existant!");
-        }
-    }
-
-    public void _remove(CommandInterpreter ci) {
-        ConcurrentMap<Integer, StringContainer> c;
-        if (this.icluster == null) {
-            ci.println("\nNo Clustering services available");
-            return;
-        }
-        String containerName = ci.nextArgument();
-        if (containerName == null) {
-            ci.println("containerName not supplied");
-            return;
-        }
-        String cacheName = ci.nextArgument();
-        if (cacheName == null) {
-            ci.println("Cache not supplied");
-            return;
-        }
-        String sKey = ci.nextArgument();
-        if (sKey == null) {
-            ci.println("Key not supplied");
-            return;
-        }
-        Integer key = null;
-        try {
-            key = Integer.valueOf(sKey);
-        } catch (NumberFormatException nfe) {
-            ci.println("Key is not a valid integer: " + sKey);
-        }
-        c = (ConcurrentMap<Integer, StringContainer>) this.icluster.getCache(
-                containerName, cacheName);
-        if (c != null) {
-            ci.println("\nDelete key " + key);
-            c.remove(key);
-        } else {
-            ci.println("Cache " + cacheName + " on container " + containerName
-                    + " not existant!");
-        }
-    }
-
-    public void _dumper(CommandInterpreter ci) {
-        ConcurrentMap<Object, Object> c;
-        String containerName = ci.nextArgument().toLowerCase();
-        if (containerName == null) {
-            ci.println("containerName not supplied");
-            return;
-        }
-        String cacheName = ci.nextArgument();
-        if (cacheName == null) {
-            ci.println("Cache not supplied");
-            return;
-        }
-        int count = 0;
-        c = (ConcurrentMap<Object, Object>) this.icluster.getCache(containerName, cacheName);
-        if (c != null) {
-            for (Map.Entry<Object, Object> e : c.entrySet()) {
-                Map.Entry<Object, Object> entry = e;
-                Object v = entry.getValue();
-                String res = "<NOT KNOWN>";
-                if (v != null) {
-                    res = v.toString();
-                }
-                ci.println("Element " + entry.getKey() + "(hashCode="
-                        + entry.getKey().hashCode() + ") has value = (" + res
-                        + ")");
-                count++;
-            }
-            ci.println("Dumped " + count + " records");
-        } else {
-            ci.println("Cache " + cacheName + " on container " + containerName
-                    + " not existant!");
-        }
-    }
-
-    public void _get(CommandInterpreter ci) {
-        ConcurrentMap<Integer, StringContainer> c;
-        if (this.icluster == null) {
-            ci.println("\nNo Clustering services available");
-            return;
-        }
-        String containerName = ci.nextArgument();
-        if (containerName == null) {
-            ci.println("containerName not supplied");
-            return;
-        }
-        String cacheName = ci.nextArgument();
-        if (cacheName == null) {
-            ci.println("Cache not supplied");
-            return;
-        }
-        String sKey = ci.nextArgument();
-        if (sKey == null) {
-            ci.println("Key not supplied");
-            return;
-        }
-        Integer key = null;
-        try {
-            key = Integer.valueOf(sKey);
-        } catch (NumberFormatException nfe) {
-            ci.println("Key is not a valid integer: " + sKey);
-        }
-        c = (ConcurrentMap<Integer, StringContainer>) this.icluster.getCache(
-                containerName, cacheName);
-        if (c != null) {
-            ci.println("\nGet key (" + key + ")=(" + c.get(key) + ")");
-        } else {
-            ci.println("Cache " + cacheName + " on container " + containerName
-                    + " not existant!");
-        }
-    }
-
-    @SuppressWarnings("deprecation") //TODO: remove use of deprecated listenRoleChange
-    public void _listenActive(CommandInterpreter ci) {
-        if (this.icluster == null) {
-            ci.println("\nNo Clustering services available");
-            return;
-        }
-        this.doListen = new DoListenRoleChanged();
-        try {
-            this.icluster.listenRoleChange(this.doListen);
-        } catch (ListenRoleChangeAddException e) {
-            ci.println("Exception while registering the listener");
-            return;
-        }
-        ci.println("Register listenRoleChanges");
-    }
-
-    @SuppressWarnings("deprecation") //TODO: remove deprecated call to unlistenRoleChange
-    public void _unlistenActive(CommandInterpreter ci) {
-        if (this.icluster == null) {
-            ci.println("\nNo Clustering services available");
-            return;
-        }
-        if (this.doListen != null) {
-            this.icluster.unlistenRoleChange(this.doListen);
-            ci.println("Unregistered Active notifications");
-        }
-    }
-
-    class DoListenRoleChanged implements IListenRoleChange {
-        @Override
-        public void newActiveAvailable() {
-            logger.debug("New Active is available");
-        }
-    }
-
-    public void _putComplex(CommandInterpreter ci) {
-        ConcurrentMap<StringContainer, ComplexContainer> c;
-        if (this.icluster == null) {
-            ci.println("\nNo Clustering services available");
-            return;
-        }
-        String containerName = ci.nextArgument();
-        if (containerName == null) {
-            ci.println("containerName not supplied");
-            return;
-        }
-        String cacheName = ci.nextArgument();
-        if (cacheName == null) {
-            ci.println("Cache not supplied");
-            return;
-        }
-        String key = ci.nextArgument();
-        if (key == null) {
-            ci.println("Key not supplied (String)");
-            return;
-        }
-        String valueIdentity = ci.nextArgument();
-        if (valueIdentity == null) {
-            ci.println("Value for Identity not supplied (String)");
-            return;
-        }
-        String sValueState = ci.nextArgument();
-        if (sValueState == null) {
-            ci.println("Value for State not supplied (Integer)");
-            return;
-        }
-        Integer valueState = null;
-        try {
-            valueState = Integer.valueOf(sValueState);
-        } catch (NumberFormatException nfe) {
-            ci.println("Value State is not a valid integer: " + sValueState);
-            return;
-        }
-        c = (ConcurrentMap<StringContainer, ComplexContainer>) this.icluster
-                .getCache(containerName, cacheName);
-        if (c != null) {
-            c.put(new StringContainer(key), new ComplexContainer(valueIdentity,
-                    valueState));
-            ci.println("\nPut in key (" + key + ")={String:" + valueIdentity
-                    + ",Integer:" + valueState + "}");
-        } else {
-            ci.println("Cache " + cacheName + " on container " + containerName
-                    + " not existant!");
-        }
-    }
-
-    public void _updateComplex(CommandInterpreter ci) {
-        ConcurrentMap<StringContainer, ComplexContainer> c;
-        if (this.icluster == null) {
-            ci.println("\nNo Clustering services available");
-            return;
-        }
-        String containerName = ci.nextArgument();
-        if (containerName == null) {
-            ci.println("containerName not supplied");
-            return;
-        }
-        String cacheName = ci.nextArgument();
-        if (cacheName == null) {
-            ci.println("Cache not supplied");
-            return;
-        }
-        String key = ci.nextArgument();
-        if (key == null) {
-            ci.println("Key not supplied (String)");
-            return;
-        }
-        String valueIdentity = ci.nextArgument();
-        if (valueIdentity == null) {
-            ci.println("Value for Identity not supplied (String)");
-            return;
-        }
-        c = (ConcurrentMap<StringContainer, ComplexContainer>) this.icluster
-                .getCache(containerName, cacheName);
-        if (c != null) {
-            StringContainer k = new StringContainer(key);
-            ComplexContainer v = c.get(k);
-            if (v != null) {
-                v.setIdentity(valueIdentity);
-                ci.println("\nUpdate key (" + key + ")={String:"
-                        + valueIdentity + "}");
-
-                // IMPORTANT ON UPDATING ANY FIELD OF THE CHILD MAKE
-                // SURE TO PUT THE NEW VALUE IN THE CACHE ELSE THE
-                // VALUE WILL NOT PROPAGATE!!
-                c.put(k, v);
-            } else {
-                ci.println("\nCannot Update key (" + key
-                        + ") doesn't exist in the database");
-            }
-        } else {
-            ci.println("Cache " + cacheName + " on container " + containerName
-                    + " not existant!");
-        }
-    }
-
-    public void setIClusterServices(IClusterServices i) {
-        this.icluster = i;
-        logger.debug("IClusterServices set");
-    }
-
-    public void unsetIClusterServices(IClusterServices i) {
-        if (this.icluster == i) {
-            this.icluster = null;
-            logger.debug("IClusterServices UNset");
-        }
-    }
-
-    public void startUp() {
-        logger.debug("Started clustering test plugin");
-    }
-
-    public void shutDown() {
-        logger.debug("Stopped clustering test plugin");
-    }
-
-    @Override
-    public String getHelp() {
-        StringBuffer help = new StringBuffer();
-        help.append("---Clustering Service Testing---\n");
-        help.append("\tput              - Put a key,value in the cache\n");
-        help.append("\tremove           - Delete a key from the cache\n");
-        help.append("\tget              - Get a key from the cache\n");
-        help.append("\tdumper           - Dump the cache\n");
-        help
-                .append("\tcacheinfo        - Dump the configuration for a cache\n");
-        help.append("\ttbegin           - Transaction begin\n");
-        help.append("\ttcommit          - Transaction Commit\n");
-        help.append("\ttrollback        - Transaction Rollback\n");
-        help.append("\tlistcaches       - List all the Caches\n");
-        help.append("\tlisten           - Listen to cache updates\n");
-        help.append("\tunlisten         - UNListen to cache updates\n");
-        help.append("\tlistenActive     - Listen to Active updates\n");
-        help.append("\tunlistenActive   - UNListen to Active updates\n");
-        help.append("\tdestroy          - Destroy a cache\n");
-        help.append("\tcreate           - Create a cache\n");
-        help.append("\tmyController     - Print this controller's Cluster identifier\n");
-        help.append("\tgetClusterNodes  - Print all the controllers that make this cluster\n");
-        help.append("\tputComplex       - Fill a more complex data structure\n");
-        help.append("\tupdateComplex    - Update the value of a more complex data structure\n");
-        help.append("\tgetLogLevel      - Get the loglevel for the logger specified\n");
-        help.append("\tsetLogLevel      - Set the loglevel for the logger specified\n");
-        return help.toString();
-    }
-}
diff --git a/opendaylight/adsal/clustering/test/src/main/java/org/opendaylight/controller/clustering/test/internal/StringContainer.java b/opendaylight/adsal/clustering/test/src/main/java/org/opendaylight/controller/clustering/test/internal/StringContainer.java
deleted file mode 100644 (file)
index 7cdb032..0000000
+++ /dev/null
@@ -1,56 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.clustering.test.internal;
-
-import java.io.Serializable;
-
-public class StringContainer implements Serializable {
-    private static final long serialVersionUID = 1L;
-    private String mystring;
-
-    public StringContainer() {
-        this.mystring = null;
-    }
-
-    public StringContainer(String s) {
-        setMystring(s);
-    }
-
-    public String getMystring() {
-        return mystring;
-    }
-
-    public void setMystring(String mystring) {
-        this.mystring = mystring;
-    }
-
-    // Return the hashCode of the containing string
-    @Override
-    public int hashCode() {
-        if (this.mystring != null) {
-            return this.mystring.hashCode();
-        }
-        return 0;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (obj instanceof StringContainer) {
-            StringContainer o = (StringContainer) obj;
-            return this.mystring.equals(o.getMystring());
-        }
-        return false;
-    }
-
-    @Override
-    public String toString() {
-        return "{" + this.mystring + "}";
-    }
-}
diff --git a/opendaylight/adsal/clustering/test/src/test/java/org/opendaylight/controller/clustering/test/internal/TestClusteringTest.java b/opendaylight/adsal/clustering/test/src/test/java/org/opendaylight/controller/clustering/test/internal/TestClusteringTest.java
deleted file mode 100644 (file)
index d143a51..0000000
+++ /dev/null
@@ -1,65 +0,0 @@
-\r
-/*\r
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.\r
- *\r
- * This program and the accompanying materials are made available under the\r
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,\r
- * and is available at http://www.eclipse.org/legal/epl-v10.html\r
- */\r
-\r
-package org.opendaylight.controller.clustering.test.internal;\r
-\r
-\r
-import org.junit.Assert;\r
-import org.junit.Test;\r
-\r
-public class TestClusteringTest {\r
-\r
-        @Test\r
-        public void testComplexClass() {\r
-                ComplexClass cc = new ComplexClass("cplxc1");\r
-                Assert.assertTrue(cc.whoAmI().equals("ComplexClass_cplxc1"));\r
-                cc.IAm("cplxc2");\r
-                Assert.assertTrue(cc.whoAmI().equals("ComplexClass_cplxc2"));\r
-        }\r
-\r
-        @Test\r
-        public void testComplexClass1() {\r
-                ComplexClass1 cc1 = new ComplexClass1("cplxc1a");\r
-                Assert.assertTrue(cc1.whoAmI().equals("ComplexClass1_cplxc1a"));\r
-                cc1.IAm("cplxc1b");\r
-                Assert.assertTrue(cc1.whoAmI().equals("ComplexClass1_cplxc1b"));\r
-        }\r
-\r
-\r
-        @Test\r
-        public void testComplexContainer() {\r
-                ComplexContainer cplxcontnr1 = new ComplexContainer("cct1", 5);\r
-                Assert.assertTrue(cplxcontnr1.getIdentity().equals("[ComplexClass_cct1]-[ComplexClass1_cct1]"));\r
-                Assert.assertTrue(cplxcontnr1.getState() == 5);\r
-\r
-                cplxcontnr1.setIdentity("cct2");\r
-                Assert.assertTrue(cplxcontnr1.getIdentity().equals("[ComplexClass_cct2]-[ComplexClass1_cct2]"));\r
-\r
-                Assert.assertTrue(cplxcontnr1.toString().equals(\r
-                                "{ID:[ComplexClass_cct2]-[ComplexClass1_cct2],STATE:5}"));\r
-        }\r
-\r
-        @Test\r
-        public void testStringContainer() {\r
-                StringContainer strcontainer1 = new StringContainer();\r
-                Assert.assertTrue(strcontainer1.getMystring() == null);\r
-                Assert.assertTrue(strcontainer1.hashCode() == 0);\r
-\r
-                StringContainer strcontainer2 = new StringContainer("foo");\r
-                Assert.assertTrue(strcontainer2.getMystring() != null);\r
-                Assert.assertTrue(strcontainer2.hashCode() != 0);\r
-\r
-                strcontainer1.setMystring("foo");\r
-                Assert.assertTrue(strcontainer2.equals(strcontainer1));\r
-\r
-                Assert.assertTrue(strcontainer2.toString().equals("{foo}"));\r
-        }\r
-\r
-\r
-}\r
diff --git a/opendaylight/adsal/commons/httpclient/pom.xml b/opendaylight/adsal/commons/httpclient/pom.xml
deleted file mode 100644 (file)
index 16f05e0..0000000
+++ /dev/null
@@ -1,85 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>commons.httpclient</artifactId>
-  <version>0.3.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>commons-logging</groupId>
-      <artifactId>commons-logging</artifactId>
-      <version>1.1.3</version>
-    </dependency>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.apache.httpcomponents</groupId>
-      <artifactId>httpclient</artifactId>
-      <version>4.3</version>
-    </dependency>
-    <dependency>
-      <groupId>org.apache.httpcomponents</groupId>
-      <artifactId>httpcore</artifactId>
-      <version>4.3</version>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Import-Package>javax.crypto,
-            javax.crypto.spec,
-            javax.net,
-            javax.net.ssl,
-            javax.security.auth.x500,
-            javax.servlet,
-            org.apache.log4j,
-            org.ietf.jgss,
-            !org.apache.commons.codec.*,
-            !org.apache.log,
-            !org.apache.avalon.framework.*</Import-Package>
-            <Export-Package>org.opendaylight.controller.commons.httpclient</Export-Package>
-            <Embed-Dependency>httpclient,httpcore,commons-logging</Embed-Dependency>
-            <Embed-Transitive>false</Embed-Transitive>
-          </instructions>
-          <manifestLocation>${project.basedir}/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-      <plugin>
-        <groupId>org.apache.maven.plugins</groupId>
-        <artifactId>maven-checkstyle-plugin</artifactId>
-        <configuration>
-          <failsOnError>true</failsOnError>
-          <configLocation>controller/checkstyle.xml</configLocation>
-        </configuration>
-        <dependencies>
-          <dependency>
-            <groupId>org.opendaylight.controller</groupId>
-            <artifactId>checkstyle</artifactId>
-            <version>0.2.0-SNAPSHOT</version>
-          </dependency>
-        </dependencies>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/commons/httpclient/src/main/java/org/opendaylight/controller/commons/httpclient/HTTPClient.java b/opendaylight/adsal/commons/httpclient/src/main/java/org/opendaylight/controller/commons/httpclient/HTTPClient.java
deleted file mode 100644 (file)
index 87664f0..0000000
+++ /dev/null
@@ -1,115 +0,0 @@
-/*
- * Copyright IBM Corporation, 2013.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.commons.httpclient;\r
-\r
-import java.util.ArrayList;\r
-import java.util.HashMap;\r
-import java.util.Iterator;\r
-import java.util.List;\r
-\r
-import org.apache.http.Header;\r
-import org.apache.http.HeaderIterator;\r
-import org.apache.http.HttpEntity;\r
-import org.apache.http.client.ClientProtocolException;\r
-import org.apache.http.client.config.RequestConfig;\r
-import org.apache.http.client.methods.CloseableHttpResponse;\r
-import org.apache.http.client.methods.HttpDelete;\r
-import org.apache.http.client.methods.HttpEntityEnclosingRequestBase;\r
-import org.apache.http.client.methods.HttpGet;\r
-import org.apache.http.client.methods.HttpPost;\r
-import org.apache.http.client.methods.HttpPut;\r
-import org.apache.http.client.methods.HttpRequestBase;\r
-import org.apache.http.entity.StringEntity;\r
-import org.apache.http.impl.client.CloseableHttpClient;\r
-import org.apache.http.impl.client.HttpClients;\r
-import org.apache.http.util.EntityUtils;\r
-\r
-public class HTTPClient {\r
-    static public HTTPResponse sendRequest(HTTPRequest request) throws Exception {\r
-\r
-        CloseableHttpClient httpclient = HttpClients.createDefault();\r
-        if (httpclient == null)\r
-            throw new ClientProtocolException("Couldn't create an HTTP client");\r
-        RequestConfig requestConfig = RequestConfig.custom().setSocketTimeout(request.getTimeout())\r
-            .setConnectTimeout(request.getTimeout()).build();\r
-        HttpRequestBase httprequest;\r
-        String method = request.getMethod();\r
-\r
-        if (method.equalsIgnoreCase("GET")) {\r
-            httprequest = new HttpGet(request.getUri());\r
-        } else if (method.equalsIgnoreCase("POST")) {\r
-            httprequest = new HttpPost(request.getUri());\r
-            if (request.getEntity() != null) {\r
-                StringEntity sentEntity = new StringEntity(request.getEntity());\r
-                sentEntity.setContentType(request.getContentType());\r
-                ((HttpEntityEnclosingRequestBase) httprequest).setEntity(sentEntity);\r
-            }\r
-        } else if (method.equalsIgnoreCase("PUT")) {\r
-            httprequest = new HttpPut(request.getUri());\r
-            if (request.getEntity() != null) {\r
-                StringEntity sentEntity = new StringEntity(request.getEntity());\r
-                sentEntity.setContentType(request.getContentType());\r
-                ((HttpEntityEnclosingRequestBase) httprequest).setEntity(sentEntity);\r
-            }\r
-        } else if (method.equalsIgnoreCase("DELETE")) {\r
-            httprequest = new HttpDelete(request.getUri());\r
-        } else {\r
-            httpclient.close();\r
-            throw new IllegalArgumentException("This profile class only supports GET, POST, PUT, and DELETE methods");\r
-        }\r
-        httprequest.setConfig(requestConfig);\r
-\r
-        // add request headers\r
-        Iterator<String> headerIterator = request.getHeaders().keySet().iterator();\r
-        while (headerIterator.hasNext()) {\r
-            String header = headerIterator.next();\r
-            Iterator<String> valueIterator = request.getHeaders().get(header).iterator();\r
-            while (valueIterator.hasNext()) {\r
-                httprequest.addHeader(header, valueIterator.next());\r
-            }\r
-        }\r
-\r
-        CloseableHttpResponse response = httpclient.execute(httprequest);\r
-        try {\r
-            HttpEntity receivedEntity = response.getEntity();\r
-            int httpResponseCode = response.getStatusLine().getStatusCode();\r
-            HTTPResponse ans = new HTTPResponse();\r
-            HashMap<String, List<String>> headerMap = new HashMap<String, List<String>>();\r
-\r
-            // copy response headers\r
-            HeaderIterator it = response.headerIterator();\r
-            while (it.hasNext()) {\r
-                Header h = it.nextHeader();\r
-                String name = h.getName();\r
-                String value = h.getValue();\r
-                if (headerMap.containsKey(name))\r
-                    headerMap.get(name).add(value);\r
-                else {\r
-                    List<String> list = new ArrayList<String>();\r
-                    list.add(value);\r
-                    headerMap.put(name, list);\r
-                }\r
-            }\r
-            ans.setHeaders(headerMap);\r
-\r
-            if (httpResponseCode > 299) {\r
-                ans.setStatus(httpResponseCode);\r
-                ans.setEntity(response.getStatusLine().getReasonPhrase());\r
-                return ans;\r
-            }\r
-            ans.setStatus(response.getStatusLine().getStatusCode());\r
-            if (receivedEntity != null)\r
-                ans.setEntity(EntityUtils.toString(receivedEntity));\r
-            else\r
-                ans.setEntity(null);\r
-            return ans;\r
-        } finally {\r
-            response.close();\r
-        }\r
-    }\r
-}\r
diff --git a/opendaylight/adsal/commons/httpclient/src/main/java/org/opendaylight/controller/commons/httpclient/HTTPRequest.java b/opendaylight/adsal/commons/httpclient/src/main/java/org/opendaylight/controller/commons/httpclient/HTTPRequest.java
deleted file mode 100644 (file)
index 7e39a78..0000000
+++ /dev/null
@@ -1,86 +0,0 @@
-/*\r
- * Copyright IBM Corporation, 2013.  All rights reserved.\r
- *\r
- * This program and the accompanying materials are made available under the\r
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,\r
- * and is available at http://www.eclipse.org/legal/epl-v10.html\r
- */\r
-\r
-package org.opendaylight.controller.commons.httpclient;\r
-\r
-import java.util.List;\r
-import java.util.Map;\r
-\r
-\r
-public class HTTPRequest {\r
-    // the HTTP method to use: currently GET, POST, PUT, and DELETE are supported\r
-    String method;\r
-\r
-    // the full URI to send to (including protocol)\r
-    String uri;\r
-\r
-    // the entity body to send\r
-    String entity;\r
-\r
-    // additional headers (separate from content-type) to include in the request\r
-    Map<String, List<String>> headers;\r
-\r
-    // timeout in milliseconds.  Defaults to 3 seconds\r
-    int timeout;\r
-\r
-    // content type to set.  Defaults to application/json\r
-    String contentType;\r
-\r
-    public HTTPRequest() {\r
-        timeout = 3000;\r
-        contentType = "application/json";\r
-    }\r
-\r
-    public String getMethod() {\r
-        return method;\r
-    }\r
-\r
-    public void setMethod(String method) {\r
-        this.method = method;\r
-    }\r
-\r
-    public String getUri() {\r
-        return uri;\r
-    }\r
-\r
-    public void setUri(String uri) {\r
-        this.uri = uri;\r
-    }\r
-\r
-    public String getEntity() {\r
-        return entity;\r
-    }\r
-\r
-    public void setEntity(String entity) {\r
-        this.entity = entity;\r
-    }\r
-\r
-    public Map<String, List<String>> getHeaders() {\r
-        return headers;\r
-    }\r
-\r
-    public void setHeaders(Map<String, List<String>> headers) {\r
-        this.headers = headers;\r
-    }\r
-\r
-    public int getTimeout() {\r
-        return timeout;\r
-    }\r
-\r
-    public void setTimeout(int timeout) {\r
-        this.timeout = timeout;\r
-    }\r
-\r
-    public String getContentType() {\r
-        return contentType;\r
-    }\r
-\r
-    public void setContentType(String contentType) {\r
-        this.contentType = contentType;\r
-    }\r
-}\r
diff --git a/opendaylight/adsal/commons/httpclient/src/main/java/org/opendaylight/controller/commons/httpclient/HTTPResponse.java b/opendaylight/adsal/commons/httpclient/src/main/java/org/opendaylight/controller/commons/httpclient/HTTPResponse.java
deleted file mode 100644 (file)
index 096fce2..0000000
+++ /dev/null
@@ -1,45 +0,0 @@
-/*\r
- * Copyright IBM Corporation, 2013.  All rights reserved.\r
- *\r
- * This program and the accompanying materials are made available under the\r
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,\r
- * and is available at http://www.eclipse.org/legal/epl-v10.html\r
- */\r
-\r
-package org.opendaylight.controller.commons.httpclient;\r
-\r
-import java.util.List;\r
-import java.util.Map;\r
-\r
-public class HTTPResponse {\r
-    Integer status;        // response status\r
-    String  entity;        // response entity\r
-    Map<String, List<String>> headers;  // http header values\r
-\r
-    public HTTPResponse() {\r
-    }\r
-\r
-    public Integer getStatus() {\r
-        return status;\r
-    }\r
-\r
-    public void setStatus(Integer status) {\r
-        this.status = status;\r
-    }\r
-\r
-    public String getEntity() {\r
-        return entity;\r
-    }\r
-\r
-    public void setEntity(String entity) {\r
-        this.entity = entity;\r
-    }\r
-\r
-    public Map<String, List<String>> getHeaders() {\r
-        return headers;\r
-    }\r
-\r
-    public void setHeaders(Map<String, List<String>> map) {\r
-        this.headers = map;\r
-    }\r
-}\r
diff --git a/opendaylight/adsal/commons/integrationtest/pom.xml b/opendaylight/adsal/commons/integrationtest/pom.xml
deleted file mode 100644 (file)
index fbb1d0e..0000000
+++ /dev/null
@@ -1,142 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>commons.integrationtest</artifactId>
-  <version>0.7.0-SNAPSHOT</version>
-  <packaging>pom</packaging>
-
-  <dependencies>
-    <dependency>
-      <groupId>ch.qos.logback</groupId>
-      <artifactId>logback-classic</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>ch.qos.logback</groupId>
-      <artifactId>logback-core</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>org.apache.felix.gogo.command</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>org.apache.felix.gogo.runtime</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>org.apache.felix.gogo.shell</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>org.eclipse.equinox.console</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>org.eclipse.equinox.ds</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>org.eclipse.equinox.util</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>org.eclipse.osgi.services</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.slf4j</groupId>
-      <artifactId>log4j-over-slf4j</artifactId>
-    </dependency>
-    <!-- Add Pax Exam -->
-    <dependency>
-      <groupId>org.ops4j.pax.exam</groupId>
-      <artifactId>pax-exam-junit4</artifactId>
-      <scope>test</scope>
-    </dependency>
-    <dependency>
-      <groupId>org.ops4j.pax.exam</groupId>
-      <artifactId>pax-exam-link-mvn</artifactId>
-      <scope>test</scope>
-    </dependency>
-    <dependency>
-      <groupId>org.ops4j.pax.url</groupId>
-      <artifactId>pax-url-aether</artifactId>
-      <scope>test</scope>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.maven.plugins</groupId>
-        <artifactId>maven-checkstyle-plugin</artifactId>
-        <configuration>
-          <failsOnError>true</failsOnError>
-          <configLocation>controller/checkstyle.xml</configLocation>
-        </configuration>
-        <dependencies>
-          <dependency>
-            <groupId>org.opendaylight.controller</groupId>
-            <artifactId>checkstyle</artifactId>
-            <version>0.2.0-SNAPSHOT</version>
-          </dependency>
-        </dependencies>
-      </plugin>
-      <plugin>
-        <groupId>org.apache.maven.plugins</groupId>
-        <artifactId>maven-surefire-plugin</artifactId>
-        <configuration>
-          <skipTests>true</skipTests>
-        </configuration>
-      </plugin>
-      <plugin>
-        <groupId>org.codehaus.mojo</groupId>
-        <artifactId>properties-maven-plugin</artifactId>
-        <version>${propertymavenplugin.version}</version>
-        <executions>
-          <execution>
-            <goals>
-              <goal>set-system-properties</goal>
-            </goals>
-            <configuration>
-              <properties>
-                <property>
-                  <name>logback.configurationFile</name>
-                  <value>${project.parent.parent.basedir}/logback.xml</value>
-                </property>
-              </properties>
-            </configuration>
-          </execution>
-        </executions>
-      </plugin>
-      <plugin>
-        <groupId>org.ops4j.pax.exam</groupId>
-        <artifactId>maven-paxexam-plugin</artifactId>
-        <executions>
-          <execution>
-            <id>generate-config</id>
-            <goals>
-              <goal>generate-depends-file</goal>
-            </goals>
-          </execution>
-        </executions>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/configuration/api/pom.xml b/opendaylight/adsal/configuration/api/pom.xml
deleted file mode 100644 (file)
index 00591e0..0000000
+++ /dev/null
@@ -1,43 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>configuration</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Import-Package>org.opendaylight.controller.sal.utils</Import-Package>
-            <Export-Package>org.opendaylight.controller.configuration</Export-Package>
-          </instructions>
-          <manifestLocation>${project.basedir}/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/configuration/api/src/main/java/org/opendaylight/controller/configuration/ConfigurationEvent.java b/opendaylight/adsal/configuration/api/src/main/java/org/opendaylight/controller/configuration/ConfigurationEvent.java
deleted file mode 100644 (file)
index a7e9365..0000000
+++ /dev/null
@@ -1,34 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.configuration;
-
-public enum ConfigurationEvent {
-    SAVE("Save"),
-    BACKUP("Backup"),
-    RESTORE("Restore"),
-    DELETE("Delete");
-
-    private ConfigurationEvent(String name) {
-        this.name = name;
-    }
-
-    private String name;
-
-    public String toString() {
-        return name;
-    }
-
-    public static ConfigurationEvent fromString(String pName) {
-        for(ConfigurationEvent p:ConfigurationEvent.values()) {
-            if (p.toString().equals(pName)) {
-                return p;
-            }
-        }
-        return null;
-    }
-}
diff --git a/opendaylight/adsal/configuration/api/src/main/java/org/opendaylight/controller/configuration/ConfigurationObject.java b/opendaylight/adsal/configuration/api/src/main/java/org/opendaylight/controller/configuration/ConfigurationObject.java
deleted file mode 100644 (file)
index 7151e56..0000000
+++ /dev/null
@@ -1,46 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.configuration;
-
-import java.io.Serializable;
-
-public abstract class ConfigurationObject implements Serializable {
-    private static final long serialVersionUID = 1L;
-    private static final String DEFAULT_REGEX = "^[\\w-=\\+\\*\\.\\(\\)\\[\\]\\@\\|\\:]{1,256}$";
-    private static final String REGEX_PROP_NAME = "resourceNameRegularExpression";
-    private static String regex;
-
-    static {
-        String customRegex = System.getProperty(REGEX_PROP_NAME);
-        regex = (customRegex != null) ? customRegex : DEFAULT_REGEX;
-    }
-
-    /**
-     * Checks if the provided resource name matches the controller resource name
-     * regular expression
-     *
-     * @param name
-     *            The resource name to test
-     * @return true if the resource name is not null and matches the controller
-     *         resource name regular expression, false otherwise
-     */
-    protected boolean isValidResourceName(String name) {
-        return name != null && name.matches(regex);
-    }
-
-    /**
-     * Return the regular expression currently in use for testing the controller
-     * resource names
-     *
-     * @return The regular expression
-     */
-    public static String getRegularExpression() {
-        return regex;
-    }
-}
diff --git a/opendaylight/adsal/configuration/api/src/main/java/org/opendaylight/controller/configuration/IConfigurationAware.java b/opendaylight/adsal/configuration/api/src/main/java/org/opendaylight/controller/configuration/IConfigurationAware.java
deleted file mode 100644 (file)
index 1983b01..0000000
+++ /dev/null
@@ -1,17 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.configuration;
-
-
-/**
- * Listener Interface for receiving Configuration events.
- */
-public interface IConfigurationAware extends IConfigurationAwareCommon {
-}
diff --git a/opendaylight/adsal/configuration/api/src/main/java/org/opendaylight/controller/configuration/IConfigurationAwareCommon.java b/opendaylight/adsal/configuration/api/src/main/java/org/opendaylight/controller/configuration/IConfigurationAwareCommon.java
deleted file mode 100644 (file)
index c909bff..0000000
+++ /dev/null
@@ -1,25 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.configuration;
-
-import org.opendaylight.controller.sal.utils.Status;
-
-
-/**
- * Listener Interface for receiving Configuration events.
- */
-public interface IConfigurationAwareCommon {
-    /**
-     * Trigger from Configuration Service or Container Configuration Service to
-     * persist the configuration state for this component on the local cluster
-     * node
-     */
-    Status saveConfiguration();
-}
diff --git a/opendaylight/adsal/configuration/api/src/main/java/org/opendaylight/controller/configuration/IConfigurationContainerAware.java b/opendaylight/adsal/configuration/api/src/main/java/org/opendaylight/controller/configuration/IConfigurationContainerAware.java
deleted file mode 100644 (file)
index f759315..0000000
+++ /dev/null
@@ -1,18 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.configuration;
-
-
-/**
- * Listener Interface for receiving Configuration events for components that
- * live in a container
- */
-public interface IConfigurationContainerAware extends IConfigurationAwareCommon {
-}
diff --git a/opendaylight/adsal/configuration/api/src/main/java/org/opendaylight/controller/configuration/IConfigurationContainerService.java b/opendaylight/adsal/configuration/api/src/main/java/org/opendaylight/controller/configuration/IConfigurationContainerService.java
deleted file mode 100644 (file)
index b8461ce..0000000
+++ /dev/null
@@ -1,34 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.configuration;
-
-/**
- * Container configuration service
- */
-public interface IConfigurationContainerService extends IConfigurationServiceCommon {
-
-    /**
-     * This function returns the path to the configuration directory of the
-     * current container.
-     *
-     * @return The path to active container's configuration directory
-     */
-    public String getConfigurationRoot();
-
-    /**
-     * Function checks whether there exists a saved configuration for this
-     * container (This is essentially checking whether the container's root
-     * configuration directory exists)
-     *
-     * @return True iff container config has been saved at least once
-     */
-    public boolean hasBeenSaved();
-
-}
diff --git a/opendaylight/adsal/configuration/api/src/main/java/org/opendaylight/controller/configuration/IConfigurationService.java b/opendaylight/adsal/configuration/api/src/main/java/org/opendaylight/controller/configuration/IConfigurationService.java
deleted file mode 100644 (file)
index d892a59..0000000
+++ /dev/null
@@ -1,17 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.configuration;
-
-
-/**
- * Configuration Service interface
- */
-public interface IConfigurationService extends IConfigurationServiceCommon {
-}
diff --git a/opendaylight/adsal/configuration/api/src/main/java/org/opendaylight/controller/configuration/IConfigurationServiceCommon.java b/opendaylight/adsal/configuration/api/src/main/java/org/opendaylight/controller/configuration/IConfigurationServiceCommon.java
deleted file mode 100644 (file)
index bbc9ee1..0000000
+++ /dev/null
@@ -1,61 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.configuration;
-
-import java.util.List;
-
-import org.opendaylight.controller.sal.utils.IObjectReader;
-import org.opendaylight.controller.sal.utils.Status;
-
-/**
- * Common configuration interface for Configuration Service and Container
- * Configuration Service
- */
-public interface IConfigurationServiceCommon {
-    /**
-     * Represent the trigger to save the controller configuration cluster wide.
-     * When called on IConfigurationService, it will trigger a cluster wide save
-     * configuration event for all the global instance components and all
-     * components in all containers. When called on
-     * IContainerConfigurationService, it will trigger a cluster wide save
-     * configuration event for all components in the current container.
-     *
-     * @return the Status object representing the result of the saving request
-     */
-    Status saveConfigurations();
-
-    /**
-     * Bundle will call this function to ask Configuration Manager to persist
-     * their configurations. It is up to the Configuration Manager to decide
-     * how the configuration will be persisted
-     *
-     * @param config
-     *            The bundle configuration as a collection of
-     *            ConfigurationObject
-     * @param storeName
-     *            The identifier for this configuration
-     * @return The Status of the operation
-     */
-    Status persistConfiguration(List<ConfigurationObject> config, String storeName);
-
-    /**
-     * Bundle will call this function to ask Configuration Manager to retrieve
-     * the configuration identified by the passed store name
-     *
-     * @param reader
-     *            The reader object for parsing the configuration provided by
-     *            the caller
-     * @param storeName
-     *            The identifier for the configuration
-     * @return The retrieved configuration as a collection of
-     *         ConfigurationObject
-     */
-    List<ConfigurationObject> retrieveConfiguration(IObjectReader reader, String storeName);
-}
diff --git a/opendaylight/adsal/configuration/implementation/pom.xml b/opendaylight/adsal/configuration/implementation/pom.xml
deleted file mode 100644 (file)
index 8ea8997..0000000
+++ /dev/null
@@ -1,62 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>configuration.implementation</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>clustering.services</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>configuration</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Import-Package>org.opendaylight.controller.configuration,
-              org.opendaylight.controller.clustering.services,
-              org.opendaylight.controller.sal.utils,
-              org.opendaylight.controller.sal.core,
-              org.osgi.framework,
-              org.slf4j,
-              org.apache.felix.dm</Import-Package>
-            <Export-Package></Export-Package>
-            <Bundle-Activator>org.opendaylight.controller.configuration.internal.Activator</Bundle-Activator>
-          </instructions>
-          <manifestLocation>${project.basedir}/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/configuration/implementation/src/main/java/org/opendaylight/controller/configuration/internal/Activator.java b/opendaylight/adsal/configuration/implementation/src/main/java/org/opendaylight/controller/configuration/internal/Activator.java
deleted file mode 100644 (file)
index c798eeb..0000000
+++ /dev/null
@@ -1,144 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.configuration.internal;
-
-import java.util.Dictionary;
-import java.util.HashSet;
-import java.util.Hashtable;
-import java.util.Set;
-
-import org.apache.felix.dm.Component;
-import org.opendaylight.controller.clustering.services.ICacheUpdateAware;
-import org.opendaylight.controller.clustering.services.IClusterContainerServices;
-import org.opendaylight.controller.clustering.services.IClusterGlobalServices;
-import org.opendaylight.controller.configuration.IConfigurationAware;
-import org.opendaylight.controller.configuration.IConfigurationContainerAware;
-import org.opendaylight.controller.configuration.IConfigurationContainerService;
-import org.opendaylight.controller.configuration.IConfigurationService;
-import org.opendaylight.controller.sal.core.ComponentActivatorAbstractBase;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * @file Activator.java
- *
- * @brief Component Activator for ConfigurationService Management.
- *
- *
- *
- */
-public class Activator extends ComponentActivatorAbstractBase {
-    protected static final Logger logger = LoggerFactory
-            .getLogger(Activator.class);
-
-
-    /**
-     * Function that is used to communicate to dependency manager the
-     * list of known implementations for services inside a container
-     *
-     *
-     * @return An array containing all the CLASS objects that will be
-     * instantiated in order to get an fully working implementation
-     * Object
-     */
-    @Override
-    public Object[] getImplementations() {
-        Object[] res = { ContainerConfigurationService.class };
-        return res;
-    }
-
-    /**
-     * Function that is called when configuration of the dependencies
-     * is required.
-     *
-     * @param c dependency manager Component object, used for
-     * configuring the dependencies exported and imported
-     * @param imp Implementation class that is being configured,
-     * needed as long as the same routine can configure multiple
-     * implementations
-     * @param containerName The containerName being configured, this allow
-     * also optional per-container different behavior if needed, usually
-     * should not be the case though.
-     */
-    @Override
-    public void configureInstance(Component c, Object imp, String containerName) {
-        if (imp.equals(ContainerConfigurationService.class)) {
-            Dictionary<String, Set<String>> props = new Hashtable<String, Set<String>>();
-            Set<String> propSet = new HashSet<String>();
-            propSet.add(ContainerConfigurationService.CONTAINER_SAVE_EVENT_CACHE);
-            props.put("cachenames", propSet);
-
-            // export the service
-            c.setInterface(
-                    new String[] { IConfigurationContainerService.class.getName(), IConfigurationAware.class.getName(),
-                            ICacheUpdateAware.class.getName() }, props);
-
-            c.add(createContainerServiceDependency(containerName).setService(
-                    IConfigurationContainerAware.class).setCallbacks(
-                            "addConfigurationContainerAware",
-                            "removeConfigurationContainerAware").setRequired(false));
-
-            c.add(createContainerServiceDependency(containerName).setService(IClusterContainerServices.class)
-                    .setCallbacks("setClusterServices", "unsetClusterServices").setRequired(true));
-        }
-    }
-
-    /**
-     * Method which tells how many Global implementations are
-     * supported by the bundle. This way we can tune the number of
-     * components created. This components will be created ONLY at the
-     * time of bundle startup and will be destroyed only at time of
-     * bundle destruction, this is the major difference with the
-     * implementation retrieved via getImplementations where all of
-     * them are assumed to be in a container!
-     *
-     *
-     * @return The list of implementations the bundle will support,
-     * in Global version
-     */
-    @Override
-    protected Object[] getGlobalImplementations() {
-        Object[] res = { ConfigurationService.class };
-        return res;
-    }
-
-    /**
-     * Configure the dependency for a given instance Global
-     *
-     * @param c Component assigned for this instance, this will be
-     * what will be used for configuration
-     * @param imp implementation to be configured
-     * @param containerName container on which the configuration happens
-     */
-    @Override
-    protected void configureGlobalInstance(Component c, Object imp) {
-        if (imp.equals(ConfigurationService.class)) {
-            Dictionary<String, Set<String>> props = new Hashtable<String, Set<String>>();
-            Set<String> propSet = new HashSet<String>();
-            propSet.add(ConfigurationService.SAVE_EVENT_CACHE);
-            props.put("cachenames", propSet);
-
-            // export the service
-            c.setInterface(
-                    new String[] { IConfigurationService.class.getName(),
-                            ICacheUpdateAware.class.getName() }, props);
-
-            c.add(createServiceDependency().setService(
-                    IClusterGlobalServices.class).setCallbacks(
-                            "setClusterServices", "unsetClusterServices").setRequired(
-                                    true));
-
-            c.add(createServiceDependency().setService(
-                    IConfigurationAware.class).setCallbacks(
-                            "addConfigurationAware", "removeConfigurationAware")
-                            .setRequired(false));
-        }
-    }
-}
diff --git a/opendaylight/adsal/configuration/implementation/src/main/java/org/opendaylight/controller/configuration/internal/ConfigurationService.java b/opendaylight/adsal/configuration/implementation/src/main/java/org/opendaylight/controller/configuration/internal/ConfigurationService.java
deleted file mode 100644 (file)
index de76211..0000000
+++ /dev/null
@@ -1,260 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.configuration.internal;
-
-import java.io.File;
-import java.util.ArrayList;
-import java.util.Collections;
-import java.util.EnumSet;
-import java.util.HashSet;
-import java.util.List;
-import java.util.Set;
-import java.util.concurrent.ConcurrentMap;
-
-import org.opendaylight.controller.clustering.services.CacheConfigException;
-import org.opendaylight.controller.clustering.services.CacheExistException;
-import org.opendaylight.controller.clustering.services.ICacheUpdateAware;
-import org.opendaylight.controller.clustering.services.IClusterGlobalServices;
-import org.opendaylight.controller.clustering.services.IClusterServices;
-import org.opendaylight.controller.configuration.ConfigurationEvent;
-import org.opendaylight.controller.configuration.ConfigurationObject;
-import org.opendaylight.controller.configuration.IConfigurationAware;
-import org.opendaylight.controller.configuration.IConfigurationContainerService;
-import org.opendaylight.controller.configuration.IConfigurationService;
-import org.opendaylight.controller.sal.utils.GlobalConstants;
-import org.opendaylight.controller.sal.utils.IObjectReader;
-import org.opendaylight.controller.sal.utils.ObjectReader;
-import org.opendaylight.controller.sal.utils.ObjectWriter;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.sal.utils.StatusCode;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * @file   ConfigurationImpl.java
- *
- * @brief  Backend functionality for all ConfigurationService related tasks.
- *
- */
-
-public class ConfigurationService implements IConfigurationService, ICacheUpdateAware<String, String> {
-    private static final Logger logger = LoggerFactory
-            .getLogger(ConfigurationService.class);
-    public static final String SAVE_EVENT_CACHE = "config.event.save";
-    private static final String ROOT = GlobalConstants.STARTUPHOME.toString();
-    private IClusterGlobalServices clusterServices;
-    private ConcurrentMap<String, String> configEvent;
-    private Set<IConfigurationAware> configurationAwareList = Collections
-            .synchronizedSet(new HashSet<IConfigurationAware>());
-    private ObjectReader objReader;
-    private ObjectWriter objWriter;
-
-
-    public int getConfigurationAwareListSize() {
-        return this.configurationAwareList.size();
-    }
-
-    public void addConfigurationAware(IConfigurationAware configurationAware) {
-        if (!this.configurationAwareList.contains(configurationAware)) {
-            this.configurationAwareList.add(configurationAware);
-        }
-    }
-
-    public void removeConfigurationAware(IConfigurationAware configurationAware) {
-        this.configurationAwareList.remove(configurationAware);
-    }
-
-    public void setClusterServices(IClusterGlobalServices i) {
-        this.clusterServices = i;
-        logger.debug("IClusterServices set");
-    }
-
-    public void unsetClusterServices(IClusterGlobalServices i) {
-        if (this.clusterServices == i) {
-            this.clusterServices = null;
-            logger.debug("IClusterServices Unset");
-        }
-    }
-
-    public void init() {
-        logger.info("ConfigurationService Manager init");
-
-        // Create the default startup directory, so that container unaware apps can initiate save
-        createContainerDirectory(ROOT + GlobalConstants.DEFAULT.toString());
-    }
-
-    public void start() {
-        allocateCache();
-        retrieveCache();
-        objReader = new ObjectReader();
-        objWriter = new ObjectWriter();
-    }
-
-    public void destroy() {
-        // Clear local states
-        this.configurationAwareList.clear();
-    }
-
-    @Override
-    public Status saveConfigurations() {
-        if (configEvent != null) {
-            configEvent.put(ConfigurationEvent.SAVE.toString(), "");
-        }
-        return saveConfigurationsInternal();
-    }
-
-
-    private List<String> getContainerDirectoryList() {
-        List<String> containerList = new ArrayList<String>();
-        for (IConfigurationAware configurationAware : this.configurationAwareList) {
-            if (configurationAware instanceof IConfigurationContainerService) {
-                String containerFilePath = ((IConfigurationContainerService)configurationAware).getConfigurationRoot();
-                containerList.add(containerFilePath);
-            }
-        }
-        return containerList;
-    }
-
-    private void createContainerDirectory(IConfigurationAware configurationAware) {
-        String containerFilePath = ((IConfigurationContainerService) configurationAware).getConfigurationRoot();
-        createContainerDirectory(containerFilePath);
-    }
-
-    private void createContainerDirectory(String containerFilePath) {
-
-        try {
-            if (!new File(containerFilePath).exists()) {
-                boolean created = new File(containerFilePath).mkdir();
-                if (!created) {
-                    logger.error("Failed to create config directory: {}", containerFilePath);
-                }
-            }
-        } catch (Exception e) {
-            logger.error("Failed to create config directory: {} ({})", containerFilePath, e.getMessage());
-        }
-    }
-
-    private void clearStaleContainerDirectories() {
-        List<String> activeContainers = getContainerDirectoryList();
-        for (File file : new File(ROOT).listFiles()) {
-            if (file.isDirectory() && !activeContainers.contains(file.toPath() + File.separator)) {
-                logger.trace("Removing directory for container {}", file.getName());
-                for (File innerFile : file.listFiles()) {
-                      innerFile.delete();
-                }
-                boolean removed = file.delete();
-                if (!removed) {
-                   logger.warn("Failed to remove stale directory: {}", file.getName());
-                }
-            }
-        }
-    }
-
-
-    private Status saveConfigurationsInternal() {
-        boolean success = true;
-        for (IConfigurationAware configurationAware : configurationAwareList) {
-            if (configurationAware instanceof IConfigurationContainerService) {
-                // Create directory for new containers
-                createContainerDirectory(configurationAware);
-            }
-            Status status = configurationAware.saveConfiguration();
-            if (!status.isSuccess()) {
-                success = false;
-                logger.warn("Failed to save config for {}", configurationAware.getClass().getName());
-            }
-        }
-        // Remove startup directories of containers that were removed from
-        // the configuration but not saved
-        clearStaleContainerDirectories();
-
-        if (success) {
-            return new Status(StatusCode.SUCCESS);
-        } else {
-            return new Status(StatusCode.INTERNALERROR, "Failed to Save All Configurations");
-        }
-    }
-
-    @Override
-    public void entryCreated(String key, String cacheName,
-            boolean originLocal) {
-        if (originLocal) {
-            return;
-        }
-    }
-
-    @Override
-    public void entryUpdated(String key, String new_value,
-            String cacheName, boolean originLocal) {
-        if (originLocal) {
-            return;
-        }
-        if (key.equals(ConfigurationEvent.SAVE.toString())) {
-            saveConfigurationsInternal();
-        }
-    }
-
-    @Override
-    public void entryDeleted(String key, String cacheName,
-            boolean originLocal) {
-        if (originLocal) {
-            return;
-        }
-    }
-
-    private void allocateCache() {
-        if (this.clusterServices == null) {
-            logger.error("uninitialized clusterServices, can't create cache");
-            return;
-        }
-        try {
-            this.clusterServices.createCache(SAVE_EVENT_CACHE,
-                    EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-        } catch (CacheConfigException cce) {
-            logger.debug("Error creating ConfigurationService cache ", cce);
-        } catch (CacheExistException cce) {
-            logger.debug("ConfigurationService Cache already exists, destroy and recreate ", cce);
-        }
-    }
-
-    @SuppressWarnings({ "unchecked" })
-    private void retrieveCache() {
-        if (this.clusterServices == null) {
-            logger.error("uninitialized clusterServices, can't retrieve cache");
-            return;
-        }
-        configEvent = (ConcurrentMap<String, String>) this.clusterServices.getCache(SAVE_EVENT_CACHE);
-        if (configEvent == null) {
-            logger.error("Failed to retrieve configuration Cache");
-        }
-    }
-
-    @Override
-    public Status persistConfiguration(List<ConfigurationObject> config, String fileName) {
-        String destination = String.format("%s%s", ROOT, fileName);
-        return objWriter.write(config, destination);
-    }
-
-    @Override
-    public List<ConfigurationObject> retrieveConfiguration(IObjectReader reader, String fileName) {
-        if (!clusterServices.amICoordinator()) {
-            return Collections.emptyList();
-        }
-        String source = String.format("%s%s", ROOT, fileName);
-        Object obj = objReader.read(reader, source);
-        if (obj == null) {
-            return Collections.<ConfigurationObject> emptyList();
-        }
-        if (obj instanceof ConcurrentMap) {
-            return new ArrayList<ConfigurationObject>(((ConcurrentMap)obj).values());
-        }
-        return (List<ConfigurationObject>) obj;
-    }
-}
diff --git a/opendaylight/adsal/configuration/implementation/src/main/java/org/opendaylight/controller/configuration/internal/ContainerConfigurationService.java b/opendaylight/adsal/configuration/implementation/src/main/java/org/opendaylight/controller/configuration/internal/ContainerConfigurationService.java
deleted file mode 100644 (file)
index dcab1f6..0000000
+++ /dev/null
@@ -1,242 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.configuration.internal;
-
-import java.io.File;
-import java.util.ArrayList;
-import java.util.Collections;
-import java.util.Dictionary;
-import java.util.EnumSet;
-import java.util.HashSet;
-import java.util.List;
-import java.util.Set;
-import java.util.concurrent.ConcurrentMap;
-
-import org.apache.felix.dm.Component;
-import org.opendaylight.controller.clustering.services.CacheConfigException;
-import org.opendaylight.controller.clustering.services.CacheExistException;
-import org.opendaylight.controller.clustering.services.ICacheUpdateAware;
-import org.opendaylight.controller.clustering.services.IClusterContainerServices;
-import org.opendaylight.controller.clustering.services.IClusterServices;
-import org.opendaylight.controller.configuration.ConfigurationEvent;
-import org.opendaylight.controller.configuration.ConfigurationObject;
-import org.opendaylight.controller.configuration.IConfigurationAware;
-import org.opendaylight.controller.configuration.IConfigurationContainerAware;
-import org.opendaylight.controller.configuration.IConfigurationContainerService;
-import org.opendaylight.controller.sal.utils.GlobalConstants;
-import org.opendaylight.controller.sal.utils.IObjectReader;
-import org.opendaylight.controller.sal.utils.ObjectReader;
-import org.opendaylight.controller.sal.utils.ObjectWriter;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.sal.utils.StatusCode;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * @file   ConfigurationImpl.java
- *
- * @brief  Backend functionality for all ConfigurationService related tasks.
- *
- */
-
-public class ContainerConfigurationService implements IConfigurationContainerService,
-        IConfigurationAware,
-        ICacheUpdateAware<String, String> {
-    public static final String CONTAINER_SAVE_EVENT_CACHE = "config.container.event.save";
-    private static final Logger logger = LoggerFactory.getLogger(ContainerConfigurationService.class);
-    private IClusterContainerServices clusterServices;
-    private ConcurrentMap<String, String> containerConfigEvent;
-    // Directory which contains the startup files for this container
-    private String root;
-    private Set<IConfigurationContainerAware> configurationAwareList = Collections
-            .synchronizedSet(new HashSet<IConfigurationContainerAware>());
-    private ObjectReader objReader;
-    private ObjectWriter objWriter;
-    private String containerName;
-
-    public void addConfigurationContainerAware(
-            IConfigurationContainerAware configurationAware) {
-        if (!this.configurationAwareList.contains(configurationAware)) {
-            this.configurationAwareList.add(configurationAware);
-        }
-    }
-
-    public int getConfigurationAwareListSize() {
-        return this.configurationAwareList.size();
-    }
-
-    public void removeConfigurationContainerAware(
-            IConfigurationContainerAware configurationAware) {
-        this.configurationAwareList.remove(configurationAware);
-    }
-
-    public void setClusterServices(IClusterContainerServices i) {
-        this.clusterServices = i;
-        logger.debug("IClusterServices set");
-    }
-
-    public void unsetClusterServices(IClusterContainerServices i) {
-        if (this.clusterServices == i) {
-            this.clusterServices = null;
-            logger.debug("IClusterServices Unset");
-        }
-    }
-
-    void init(Component c) {
-        Dictionary<?, ?> props = c.getServiceProperties();
-        containerName = (props != null) ? (String) props.get("containerName") :
-            GlobalConstants.DEFAULT.toString();
-        root =  String.format("%s%s/", GlobalConstants.STARTUPHOME.toString(), containerName);
-    }
-
-    public void start() {
-        allocateCache();
-        retrieveCache();
-        objReader = new ObjectReader();
-        objWriter = new ObjectWriter();
-    }
-
-    public void destroy() {
-        // Clear local states
-        this.configurationAwareList.clear();
-    }
-
-    /**
-     * Function called by the dependency manager before Container is Stopped and Destroyed.
-     */
-    public void containerStop() {
-        // Do nothing
-    }
-
-    @Override
-    public String getConfigurationRoot() {
-        return root;
-    }
-
-    @Override
-    public Status saveConfiguration() {
-        boolean success = true;
-
-        for (IConfigurationContainerAware configurationAware : configurationAwareList) {
-            logger.trace("Save Config triggered for {}", configurationAware.getClass().getSimpleName());
-
-            Status status = configurationAware.saveConfiguration();
-            if (!status.isSuccess()) {
-                success = false;
-                logger.warn("Failed to save config for {} ({})", configurationAware.getClass().getSimpleName(),
-                        status.getDescription());
-            }
-        }
-        if (success) {
-            return new Status(StatusCode.SUCCESS);
-        } else {
-            return new Status(StatusCode.INTERNALERROR, "Failed to save one or more configurations");
-        }
-    }
-
-    @Override
-    public Status saveConfigurations() {
-        containerConfigEvent.put(ConfigurationEvent.SAVE.toString(), "");
-        return saveConfiguration();
-    }
-
-    @Override
-    public void entryCreated(String key, String cacheName,
-            boolean originLocal) {
-        if (originLocal) {
-            return;
-        }
-    }
-
-    @Override
-    public void entryUpdated(String key, String new_value,
-            String cacheName, boolean originLocal) {
-        if (originLocal) {
-            return;
-        }
-        logger.debug("Processing {} event", key);
-        if (key.equals(ConfigurationEvent.SAVE.toString())) {
-            saveConfiguration();
-        }
-    }
-
-    @Override
-    public void entryDeleted(String key, String cacheName,
-            boolean originLocal) {
-        if (originLocal) {
-            return;
-        }
-    }
-
-    private void allocateCache() {
-        if (this.clusterServices == null) {
-            logger.error("uninitialized clusterServices, can't create cache");
-            return;
-        }
-        try {
-            this.clusterServices.createCache(CONTAINER_SAVE_EVENT_CACHE,
-                    EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-        } catch (CacheConfigException cce) {
-            logger.debug("Error creating ContainerConfigurationService cache ", cce);
-        } catch (CacheExistException cce) {
-            logger.debug("ConfigurationService Cache already exists, destroy and recreate ", cce);
-        }
-    }
-
-    @SuppressWarnings({ "unchecked" })
-    private void retrieveCache() {
-        if (this.clusterServices == null) {
-            logger.error("uninitialized clusterServices, can't retrieve cache");
-            return;
-        }
-        containerConfigEvent =
-                (ConcurrentMap<String, String>) this.clusterServices.getCache(CONTAINER_SAVE_EVENT_CACHE);
-        if (containerConfigEvent == null) {
-            logger.error("Failed to retrieve configuration Cache");
-        }
-    }
-
-    @Override
-    public Status persistConfiguration(List<ConfigurationObject> config, String fileName) {
-        if (!hasBeenSaved()) {
-            return new Status(StatusCode.NOTALLOWED,
-                    String.format("Container %s has not been saved yet", containerName));
-        }
-        String destination = String.format("%s%s", root, fileName);
-        return objWriter.write(config, destination);
-    }
-
-    @Override
-    public List<ConfigurationObject> retrieveConfiguration(IObjectReader reader, String fileName) {
-        if (!clusterServices.amICoordinator()) {
-            return Collections.emptyList();
-        }
-        String source = String.format("%s%s", root, fileName);
-        Object obj = objReader.read(reader, source);
-        if (obj == null) {
-            return Collections.<ConfigurationObject> emptyList();
-        }
-        if (obj instanceof ConcurrentMap) {
-            return new ArrayList<ConfigurationObject>(((ConcurrentMap)obj).values());
-        }
-        return (List<ConfigurationObject>) obj;
-    }
-
-    @Override
-    public boolean hasBeenSaved() {
-        try {
-            File configRoot = new File(this.getConfigurationRoot());
-            return configRoot.exists();
-        } catch (Exception e) {
-            return false;
-        }
-
-    }
-}
diff --git a/opendaylight/adsal/configuration/implementation/src/test/java/org/opendaylight/controller/configuration/internal/ConfigurationAwareTest.java b/opendaylight/adsal/configuration/implementation/src/test/java/org/opendaylight/controller/configuration/internal/ConfigurationAwareTest.java
deleted file mode 100644 (file)
index 185fb17..0000000
+++ /dev/null
@@ -1,32 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.configuration.internal;
-
-import org.opendaylight.controller.configuration.IConfigurationAware;
-import org.opendaylight.controller.sal.utils.Status;
-
-/**
- * @file   TestConfigurationAware.java
- *
- * @brief  Test Class to create for jUnit test cases for ConfigurationService Implementation
- *
- *
- */
-
-public class ConfigurationAwareTest implements
-IConfigurationAware {
-
-        @Override
-        public Status saveConfiguration() {
-                return null;
-        }
-
-
-}
diff --git a/opendaylight/adsal/configuration/implementation/src/test/java/org/opendaylight/controller/configuration/internal/ConfigurationContainerAwareTest.java b/opendaylight/adsal/configuration/implementation/src/test/java/org/opendaylight/controller/configuration/internal/ConfigurationContainerAwareTest.java
deleted file mode 100644 (file)
index ff627aa..0000000
+++ /dev/null
@@ -1,35 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.configuration.internal;
-
-import org.opendaylight.controller.configuration.IConfigurationContainerAware;
-import org.opendaylight.controller.sal.utils.Status;
-
-/**
- * @file   TestConfigurationAware.java
- *
- * @brief  Test Class to create for jUnit test cases for ConfigurationService Implementation
- *
- *
- */
-
-public class ConfigurationContainerAwareTest implements
-         IConfigurationContainerAware {
-
-
-
-
-        @Override
-        public Status saveConfiguration() {
-                return null;
-        }
-
-
-}
diff --git a/opendaylight/adsal/configuration/implementation/src/test/java/org/opendaylight/controller/configuration/internal/ConfigurationContainerImplTest.java b/opendaylight/adsal/configuration/implementation/src/test/java/org/opendaylight/controller/configuration/internal/ConfigurationContainerImplTest.java
deleted file mode 100644 (file)
index baf3004..0000000
+++ /dev/null
@@ -1,65 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.configuration.internal;
-
-import org.junit.Assert;
-import org.junit.Test;
-import org.opendaylight.controller.configuration.IConfigurationContainerAware;
-
-
-
-public class ConfigurationContainerImplTest {
-
-
-        @Test
-        public void testAddRemoveSaveConfiguration() {
-
-                ContainerConfigurationService configurationContainerImpl = new ContainerConfigurationService();
-                IConfigurationContainerAware testConfigurationContainerAware = new ConfigurationContainerAwareTest();
-
-                configurationContainerImpl.addConfigurationContainerAware(testConfigurationContainerAware);
-                configurationContainerImpl.addConfigurationContainerAware(testConfigurationContainerAware);
-
-                Assert.assertEquals(1, configurationContainerImpl.getConfigurationAwareListSize());
-
-                IConfigurationContainerAware testConfigurationAware1 = new ConfigurationContainerAwareTest();
-                configurationContainerImpl.addConfigurationContainerAware(testConfigurationAware1);
-
-                Assert.assertEquals(2, configurationContainerImpl.getConfigurationAwareListSize());
-
-                IConfigurationContainerAware testConfigurationAware2 = new ConfigurationContainerAwareTest();
-                configurationContainerImpl.addConfigurationContainerAware(testConfigurationAware2);
-
-                Assert.assertEquals(3, configurationContainerImpl.getConfigurationAwareListSize());
-
-                IConfigurationContainerAware testConfigurationAware3 = new ConfigurationContainerAwareTest();
-                configurationContainerImpl.addConfigurationContainerAware(testConfigurationAware3);
-
-                Assert.assertEquals(4, configurationContainerImpl.getConfigurationAwareListSize());
-
-                configurationContainerImpl.removeConfigurationContainerAware(testConfigurationContainerAware);
-                Assert.assertEquals(3, configurationContainerImpl.getConfigurationAwareListSize());
-
-                configurationContainerImpl.removeConfigurationContainerAware(testConfigurationContainerAware);
-                Assert.assertEquals(3, configurationContainerImpl.getConfigurationAwareListSize());
-
-                configurationContainerImpl.removeConfigurationContainerAware(testConfigurationAware3);
-                Assert.assertEquals(2, configurationContainerImpl.getConfigurationAwareListSize());
-
-                configurationContainerImpl.removeConfigurationContainerAware(testConfigurationAware2);
-                Assert.assertEquals(1, configurationContainerImpl.getConfigurationAwareListSize());
-
-                configurationContainerImpl.removeConfigurationContainerAware(testConfigurationAware1);
-                Assert.assertEquals(0, configurationContainerImpl.getConfigurationAwareListSize());
-
-
-        }
-
-}
diff --git a/opendaylight/adsal/configuration/implementation/src/test/java/org/opendaylight/controller/configuration/internal/ConfigurationImplTest.java b/opendaylight/adsal/configuration/implementation/src/test/java/org/opendaylight/controller/configuration/internal/ConfigurationImplTest.java
deleted file mode 100644 (file)
index f981100..0000000
+++ /dev/null
@@ -1,63 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.configuration.internal;
-
-import org.junit.Assert;
-import org.junit.Test;
-import org.opendaylight.controller.configuration.IConfigurationAware;
-
-public class ConfigurationImplTest {
-
-
-        @Test
-        public void testAddRemoveSaveConfiguration() {
-
-                ConfigurationService configurationImpl = new ConfigurationService();
-                IConfigurationAware testConfigurationAware = new ConfigurationAwareTest();
-
-                configurationImpl.addConfigurationAware(testConfigurationAware);
-                configurationImpl.addConfigurationAware(testConfigurationAware);
-
-                Assert.assertEquals(1, configurationImpl.getConfigurationAwareListSize());
-
-                ConfigurationAwareTest testConfigurationAware1 = new ConfigurationAwareTest();
-                configurationImpl.addConfigurationAware(testConfigurationAware1);
-
-                Assert.assertEquals(2, configurationImpl.getConfigurationAwareListSize());
-
-                ConfigurationAwareTest testConfigurationAware2 = new ConfigurationAwareTest();
-                configurationImpl.addConfigurationAware(testConfigurationAware2);
-
-                Assert.assertEquals(3, configurationImpl.getConfigurationAwareListSize());
-
-                ConfigurationAwareTest testConfigurationAware3 = new ConfigurationAwareTest();
-                configurationImpl.addConfigurationAware(testConfigurationAware3);
-
-                Assert.assertEquals(4, configurationImpl.getConfigurationAwareListSize());
-
-
-                configurationImpl.removeConfigurationAware(testConfigurationAware);
-                Assert.assertEquals(3, configurationImpl.getConfigurationAwareListSize());
-
-                configurationImpl.removeConfigurationAware(testConfigurationAware);
-                Assert.assertEquals(3, configurationImpl.getConfigurationAwareListSize());
-
-                configurationImpl.removeConfigurationAware(testConfigurationAware3);
-                Assert.assertEquals(2, configurationImpl.getConfigurationAwareListSize());
-
-                configurationImpl.removeConfigurationAware(testConfigurationAware1);
-                Assert.assertEquals(1, configurationImpl.getConfigurationAwareListSize());
-
-                configurationImpl.removeConfigurationAware(testConfigurationAware2);
-                Assert.assertEquals(0, configurationImpl.getConfigurationAwareListSize());
-
-        }
-
-}
diff --git a/opendaylight/adsal/configuration/integrationtest/.gitignore b/opendaylight/adsal/configuration/integrationtest/.gitignore
deleted file mode 100644 (file)
index f92f363..0000000
+++ /dev/null
@@ -1 +0,0 @@
-configuration
diff --git a/opendaylight/adsal/configuration/integrationtest/pom.xml b/opendaylight/adsal/configuration/integrationtest/pom.xml
deleted file mode 100644 (file)
index 5ae64e7..0000000
+++ /dev/null
@@ -1,123 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.integrationtest</artifactId>
-    <version>0.7.0-SNAPSHOT</version>
-    <relativePath>../../commons/integrationtest</relativePath>
-  </parent>
-
-  <artifactId>configuration.integrationtest</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <dependencies>
-    <dependency>
-      <groupId>ch.qos.logback</groupId>
-      <artifactId>logback-classic</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>ch.qos.logback</groupId>
-      <artifactId>logback-core</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>eclipselink</groupId>
-      <artifactId>javax.resource</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>clustering.services</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>clustering.services-implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>clustering.stub</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>configuration</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>configuration.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>containermanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>containermanager.it.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>forwardingrulesmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>hosttracker</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>protocol_plugins.stub</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>switchmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>switchmanager.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>topologymanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.slf4j</groupId>
-      <artifactId>log4j-over-slf4j</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-      <scope>test</scope>
-    </dependency>
-    <!-- Add Pax Exam -->
-    <dependency>
-      <groupId>org.ops4j.pax.exam</groupId>
-      <artifactId>pax-exam-container-native</artifactId>
-      <scope>test</scope>
-    </dependency>
-    <dependency>
-      <groupId>org.ops4j.pax.exam</groupId>
-      <artifactId>pax-exam-junit4</artifactId>
-      <scope>test</scope>
-    </dependency>
-    <dependency>
-      <groupId>org.ops4j.pax.exam</groupId>
-      <artifactId>pax-exam-link-mvn</artifactId>
-      <scope>test</scope>
-    </dependency>
-    <dependency>
-      <groupId>org.ops4j.pax.url</groupId>
-      <artifactId>pax-url-aether</artifactId>
-      <scope>test</scope>
-    </dependency>
-  </dependencies>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/configuration/integrationtest/src/test/java/org/opendaylight/controller/configuration/internal/ConfigurationIT.java b/opendaylight/adsal/configuration/integrationtest/src/test/java/org/opendaylight/controller/configuration/internal/ConfigurationIT.java
deleted file mode 100644 (file)
index eb9ce47..0000000
+++ /dev/null
@@ -1,181 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.configuration.internal;
-
-import static org.junit.Assert.assertFalse;
-import static org.junit.Assert.assertNotNull;
-import static org.ops4j.pax.exam.CoreOptions.junitBundles;
-import static org.ops4j.pax.exam.CoreOptions.mavenBundle;
-import static org.ops4j.pax.exam.CoreOptions.options;
-import static org.ops4j.pax.exam.CoreOptions.systemPackages;
-import static org.ops4j.pax.exam.CoreOptions.systemProperty;
-
-import java.io.File;
-
-import javax.inject.Inject;
-
-import org.junit.Assert;
-import org.junit.Before;
-import org.junit.Test;
-import org.junit.runner.RunWith;
-import org.opendaylight.controller.configuration.IConfigurationService;
-import org.opendaylight.controller.sal.utils.GlobalConstants;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.sal.utils.StatusCode;
-import org.ops4j.pax.exam.Option;
-import org.ops4j.pax.exam.Configuration;
-import org.ops4j.pax.exam.junit.PaxExam;
-import org.ops4j.pax.exam.util.PathUtils;
-import org.osgi.framework.Bundle;
-import org.osgi.framework.BundleContext;
-import org.osgi.framework.ServiceReference;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-@RunWith(PaxExam.class)
-public class ConfigurationIT {
-    private final Logger logger = LoggerFactory
-            .getLogger(ConfigurationIT.class);
-    // get the OSGI bundle context
-    @Inject
-    private BundleContext bc;
-    private IConfigurationService configService = null;
-
-    // Configure the OSGi container
-    @Configuration
-    public Option[] config() {
-        return options(
-                systemProperty("logback.configurationFile").value(
-                        "file:" + PathUtils.getBaseDir()
-                                + "/src/test/resources/logback.xml"),
-                // To start OSGi console for inspection remotely
-                systemProperty("osgi.console").value("2401"),
-                // Set the systemPackages (used by clustering)
-                systemPackages("sun.reflect", "sun.reflect.misc", "sun.misc"),
-                // List framework bundles
-                mavenBundle("equinoxSDK381", "org.eclipse.equinox.console").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "org.eclipse.equinox.util").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "org.eclipse.osgi.services").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "org.eclipse.equinox.ds").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "org.apache.felix.gogo.command").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "org.apache.felix.gogo.runtime").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "org.apache.felix.gogo.shell").versionAsInProject(),
-                // List logger bundles
-                mavenBundle("org.slf4j", "slf4j-api").versionAsInProject(),
-                mavenBundle("org.slf4j", "log4j-over-slf4j").versionAsInProject(),
-                mavenBundle("ch.qos.logback", "logback-core").versionAsInProject(),
-                mavenBundle("ch.qos.logback", "logback-classic").versionAsInProject(),
-                mavenBundle("org.apache.commons", "commons-lang3").versionAsInProject(),
-                mavenBundle("org.jboss.spec.javax.transaction", "jboss-transaction-api_1.1_spec").versionAsInProject(),
-                mavenBundle("eclipselink", "javax.resource").versionAsInProject(),
-                mavenBundle("org.apache.felix", "org.apache.felix.dependencymanager").versionAsInProject(),
-                // List all the bundles on which the test case depends
-                mavenBundle("org.opendaylight.controller", "sal").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "sal.implementation").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "protocol_plugins.stub").versionAsInProject(),
-                // needed bundles by switchmanager
-                mavenBundle("org.opendaylight.controller", "containermanager").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "containermanager.it.implementation").versionAsInProject(),
-                // needed bundles by configuration
-                mavenBundle("org.opendaylight.controller", "clustering.services").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "clustering.stub").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "configuration").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "configuration.implementation").versionAsInProject(),
-                junitBundles());
-    }
-
-    private String stateToString(int state) {
-        switch (state) {
-        case Bundle.ACTIVE:
-            return "ACTIVE";
-        case Bundle.INSTALLED:
-            return "INSTALLED";
-        case Bundle.RESOLVED:
-            return "RESOLVED";
-        case Bundle.UNINSTALLED:
-            return "UNINSTALLED";
-        default:
-            return "Not CONVERTED";
-        }
-    }
-
-    @Before
-    public void areWeReadyForClustering() {
-        assertNotNull(bc);
-        boolean debugit = false;
-        Bundle b[] = bc.getBundles();
-        for (int i = 0; i < b.length; i++) {
-            int state = b[i].getState();
-            if (state != Bundle.ACTIVE && state != Bundle.RESOLVED) {
-                logger.debug("Bundle:" + b[i].getSymbolicName() + " state:"
-                        + stateToString(state));
-                debugit = true;
-            }
-        }
-        if (debugit) {
-            logger.debug("Do some debugging because some bundle is unresolved");
-        }
-
-        // Assert if true, if false we are good to go!
-        assertFalse(debugit);
-    }
-
-    @Before
-    public void areWeReadyForConfiguration() {
-        assertNotNull(bc);
-        boolean debugit = false;
-        Bundle b[] = bc.getBundles();
-        for (int i = 0; i < b.length; i++) {
-            int state = b[i].getState();
-            if (state != Bundle.ACTIVE && state != Bundle.RESOLVED) {
-                logger.debug("Bundle:" + b[i].getSymbolicName() + " state:"
-                        + stateToString(state));
-                debugit = true;
-            }
-        }
-        if (debugit) {
-            logger.debug("Do some debugging because some bundle is unresolved");
-        }
-
-        // Assert if true, if false we are good to go!
-        assertFalse(debugit);
-        ServiceReference r = bc.getServiceReference(IConfigurationService.class
-                .getName());
-        if (r != null) {
-            this.configService = (IConfigurationService) bc.getService(r);
-        }
-        // If StatisticsManager is null, cannot run tests.
-        assertNotNull(this.configService);
-
-    }
-
-    @Test
-    public void saveConfiguration() {
-        File f = new File(GlobalConstants.STARTUPHOME.toString());
-        boolean success = f.exists();
-        if (!success) {
-            success = f.mkdirs();
-        }
-        if(success){
-            Status status = new Status(StatusCode.SUCCESS, null);
-            if (this.configService != null) {
-                status = this.configService.saveConfigurations();
-            }
-            if (status.getCode().equals(StatusCode.SUCCESS)) {
-                Assert.assertTrue("Successfully saved config for "
-                        + configService.getClass().getSimpleName(), status
-                        .getCode().equals(StatusCode.SUCCESS));
-            } else {
-                Assert.assertFalse("Failed to save config for "
-                        + configService.getClass().getSimpleName(), status
-                        .getCode().equals(StatusCode.INTERNALERROR));
-            }
-        }
-    }
-
-}
diff --git a/opendaylight/adsal/configuration/integrationtest/src/test/resources/logback.xml b/opendaylight/adsal/configuration/integrationtest/src/test/resources/logback.xml
deleted file mode 100644 (file)
index 2d63ce5..0000000
+++ /dev/null
@@ -1,13 +0,0 @@
-<configuration scan="true">
-
-  <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
-    <encoder>
-      <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n
-      </pattern>
-    </encoder>
-  </appender>
-
-  <root level="error">
-    <appender-ref ref="STDOUT" />
-  </root>
-</configuration>
diff --git a/opendaylight/adsal/connectionmanager/api/pom.xml b/opendaylight/adsal/connectionmanager/api/pom.xml
deleted file mode 100644 (file)
index 21f4df1..0000000
+++ /dev/null
@@ -1,49 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>connectionmanager</artifactId>
-  <version>0.3.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal.connection</artifactId>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Import-Package>org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.sal.utils,
-              org.opendaylight.controller.sal.connection</Import-Package>
-            <Export-Package>org.opendaylight.controller.connectionmanager</Export-Package>
-          </instructions>
-          <manifestLocation>${project.basedir}/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/connectionmanager/api/src/main/java/org/opendaylight/controller/connectionmanager/ConnectionMgmtScheme.java b/opendaylight/adsal/connectionmanager/api/src/main/java/org/opendaylight/controller/connectionmanager/ConnectionMgmtScheme.java
deleted file mode 100644 (file)
index 49e77b2..0000000
+++ /dev/null
@@ -1,65 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.connectionmanager;
-
-/**
- * Enumeration that represents the Connectivity Scheme / Algorithm for South-Bound nodes
- * towards an Active-Active Clustered Controllers.
- */
-public enum ConnectionMgmtScheme {
-    /**
-     * All the nodes are connected with a Single Controller.
-     * The SingleControllerScheme algorithm will determine that one controller to which all
-     * the nodes are connected with.
-     * This is like Active-Standby model from a South-Bound perspective.
-     */
-    SINGLE_CONTROLLER("All nodes connected with a Single Controller"),
-
-    /**
-     * Any node can be connected with any controller. But with just 1 master controller.
-     */
-    ANY_CONTROLLER_ONE_MASTER("Nodes can to connect with any controller in the cluster"),
-
-    /**
-     * Simple Round Robin Scheme that will let the nodes connect with each controller in
-     * Active-Active cluster in a round robin fashion.
-     */
-    ROUND_ROBIN("Each node is connected with individual Controller in Round-Robin fashion"),
-
-    /**
-     * Complex Load Balancing scheme that will let the nodes connect with controller based
-     * on the resource usage in each of the controllers in a cluster.
-     */
-    LOAD_BALANCED("Connect nodes to controllers based on the Controller Load"),
-
-    /**
-     * Container based scheme will let the nodes connect with controller based
-     * on the container configuration.
-     */
-    CONTAINER_BASED("Connect nodes to controllers based on Container they belong to");
-
-    private ConnectionMgmtScheme(String name) {
-        this.name = name;
-    }
-
-    private String name;
-
-    public String toString() {
-        return name;
-    }
-
-    public static ConnectionMgmtScheme fromString(String pName) {
-        for(ConnectionMgmtScheme p:ConnectionMgmtScheme.values()) {
-            if (p.toString().equals(pName)) {
-                return p;
-            }
-        }
-        return null;
-    }
-}
diff --git a/opendaylight/adsal/connectionmanager/api/src/main/java/org/opendaylight/controller/connectionmanager/IConnectionManager.java b/opendaylight/adsal/connectionmanager/api/src/main/java/org/opendaylight/controller/connectionmanager/IConnectionManager.java
deleted file mode 100644 (file)
index c7e7fa4..0000000
+++ /dev/null
@@ -1,140 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.connectionmanager;
-
-import java.net.InetAddress;
-import java.util.Map;
-import java.util.Set;
-
-import org.opendaylight.controller.sal.connection.ConnectionConstants;
-import org.opendaylight.controller.sal.connection.ConnectionLocality;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.utils.Status;
-
-/**
- * Connection Manager provides south-bound connectivity services. The APIs are
- * currently focused towards Active-Active Clustering support wherein the node
- * can connect to any of the Active Controller in the Cluster. This component
- * can also host the necessary logic for south-bound connectivity when partial
- * cluster is identified during Partition scenarios.
- *
- * This (and its corresponding implementation) component can also be enhanced
- * further for more fancy algorithms/criteria for connection acceptance.
- */
-
-public interface IConnectionManager {
-    /**
-     * This method returns Connectivity Algorithm (Scheme) that is currently
-     * being used.
-     *
-     * @return ConnectionMgmtScheme Enum that represents the active scheme.
-     */
-    public ConnectionMgmtScheme getActiveScheme();
-
-    /**
-     * Method that will retrieve and return a Set of Nodes that is currently
-     * connected to the given controller.
-     *
-     * @param controller
-     *            InetAddress of the Controller that is currently connected to a
-     *            set of Nodes.
-     *
-     * @return Set<Node> Set of Nodes connected to a controller.
-     */
-    public Set<Node> getNodes(InetAddress controller);
-
-    /**
-     * Method that will retrieve and return a Set of Nodes that is currently
-     * connected to the controller on which this method is executed.
-     *
-     * @return Set<Node> Set of Nodes connected to this controller.
-     */
-    public Set<Node> getLocalNodes();
-
-    /**
-     * @deprecated Use getLocalityStatus(Node node) instead.
-     *
-     *             Method to test if a node is local to a controller.
-     *
-     * @param node
-     *            The node for which the locality is being tested
-     * @return true if node is local to this controller.<br>
-     *         false if either node is not connected to this controller or not
-     *         connected to any other controllers in the cluster.
-     */
-    public boolean isLocal(Node node);
-
-    /**
-     * getLocalityStatus provides the tri-state connectivity status as opposed
-     * to the binary status returned by isLocal. ConnectionLocality enum that is
-     * returned by this method also includes the case of a Node not connected to
-     * any of the controllers in the cluster.
-     *
-     * @param node
-     *            The node for which the locality is being verified
-     * @return ConnectionLocality
-     */
-    public ConnectionLocality getLocalityStatus(Node node);
-
-    /**
-     * Disconnect a Node from the controller.
-     *
-     * @return Status of the disconnect Operation.
-     */
-    public Status disconnect(Node node);
-
-    /**
-     * Connect to a node
-     *
-     * @param connectionIdentifier
-     *            identifier with which the application would refer to a given
-     *            connection.
-     * @param params
-     *            Connection Params in Map format. This is entirely handled by
-     *            the south-bound plugins and is an opaque value for SAL or
-     *            Connection Manager. Typical values keyed inside this params
-     *            are Management IP-Address, Username, Password, Security Keys,
-     *            etc...
-     *
-     * @return Node Node connected to.
-     */
-    public Node connect(String connectionIdentifier,
-            Map<ConnectionConstants, String> params);
-
-    /**
-     * Connect to a node
-     *
-     * @param type
-     *            Type of the node representing NodeIDType.
-     * @param connectionIdentifier
-     *            identifier with which the application would refer to a given
-     *            connection.
-     * @param params
-     *            Connection Params in Map format. This is entirely handled by
-     *            the south-bound plugins and is an opaque value for SAL or
-     *            Connection Manager. Typical values keyed inside this params
-     *            are Management IP-Address, Username, Password, Security Keys,
-     *            etc...
-     *
-     * @return Status of the Connect Operation.
-     */
-    public Node connect(String type, String connectionIdentifier,
-            Map<ConnectionConstants, String> params);
-
-    /**
-     * Retrieve list of cluster-members to which Node is connected to
-     *
-     * @param node
-     *            Node for which cluster-members to be retrieved
-     *
-     * @return Set<InetAddress> List of cluster-member addresses to which the
-     *         node is connected
-     */
-    public Set<InetAddress> getControllers(Node node);
-}
diff --git a/opendaylight/adsal/connectionmanager/api/src/main/java/org/opendaylight/controller/connectionmanager/NodeAccessPermission.java b/opendaylight/adsal/connectionmanager/api/src/main/java/org/opendaylight/controller/connectionmanager/NodeAccessPermission.java
deleted file mode 100644 (file)
index c59e297..0000000
+++ /dev/null
@@ -1,40 +0,0 @@
-/*
- * Copyright IBM Corporation, 2013.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.connectionmanager;
-
-/*
- *
- *  This enum enables the options which could be used for querying
- *  the cluster-members based on the state-change permissions.
- *
- *  SB Plugin or any other means could be used to store this metadata
- *  against each connection w.r.t. Node
- *
- *  TODO: When connection-manager is enhanced later to store connection
- *  metadata with permissions, this could be used to query the connections
- *  based on permission-level of the connection
- *
- */
-
-public enum NodeAccessPermission {
-
-    /*
-     * This option could be used to retrieve the cluster-members who have rights
-     * only to read the Node state but are not eligible for modifying the state
-     * of Node
-     */
-    READONLY_ACCESS,
-
-    /*
-     * This option could be used to retrieve the cluster-members who have rights
-     * to read and modify the state of Node
-     */
-    READWRITE_ACCESS
-
-}
diff --git a/opendaylight/adsal/connectionmanager/implementation/pom.xml b/opendaylight/adsal/connectionmanager/implementation/pom.xml
deleted file mode 100644 (file)
index 0ae29a7..0000000
+++ /dev/null
@@ -1,69 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>connectionmanager.implementation</artifactId>
-  <version>0.3.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>org.eclipse.osgi</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>clustering.services</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>connectionmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal.connection</artifactId>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Import-Package>org.opendaylight.controller.connectionmanager,
-              org.opendaylight.controller.clustering.services,
-              org.opendaylight.controller.sal.utils,
-              org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.sal.connection,
-              org.opendaylight.controller.sal.inventory,
-              org.eclipse.osgi.framework.console,
-              org.osgi.framework,
-              org.slf4j,
-              org.apache.felix.dm</Import-Package>
-            <Export-Package></Export-Package>
-            <Bundle-Activator>org.opendaylight.controller.connectionmanager.internal.Activator</Bundle-Activator>
-          </instructions>
-          <manifestLocation>${project.basedir}/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/connectionmanager/implementation/src/main/java/org/opendaylight/controller/connectionmanager/internal/Activator.java b/opendaylight/adsal/connectionmanager/implementation/src/main/java/org/opendaylight/controller/connectionmanager/internal/Activator.java
deleted file mode 100644 (file)
index 8912aeb..0000000
+++ /dev/null
@@ -1,95 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.connectionmanager.internal;
-
-import java.util.Dictionary;
-import java.util.HashSet;
-import java.util.Hashtable;
-import java.util.Set;
-
-import org.opendaylight.controller.clustering.services.ICacheUpdateAware;
-import org.opendaylight.controller.clustering.services.IClusterGlobalServices;
-import org.opendaylight.controller.clustering.services.ICoordinatorChangeAware;
-import org.opendaylight.controller.connectionmanager.ConnectionMgmtScheme;
-import org.opendaylight.controller.connectionmanager.IConnectionManager;
-import org.opendaylight.controller.sal.connection.IConnectionListener;
-import org.opendaylight.controller.sal.connection.IConnectionService;
-import org.apache.felix.dm.Component;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-import org.opendaylight.controller.sal.core.ComponentActivatorAbstractBase;
-import org.opendaylight.controller.sal.inventory.IInventoryService;
-import org.opendaylight.controller.sal.inventory.IListenInventoryUpdates;
-
-public class Activator extends ComponentActivatorAbstractBase {
-    protected static final Logger logger = LoggerFactory
-            .getLogger(Activator.class);
-
-
-    /**
-     * Method which tells how many Global implementations are
-     * supported by the bundle. This way we can tune the number of
-     * components created. This components will be created ONLY at the
-     * time of bundle startup and will be destroyed only at time of
-     * bundle destruction, this is the major difference with the
-     * implementation retrieved via getImplementations where all of
-     * them are assumed to be in a container!
-     *
-     *
-     * @return The list of implementations the bundle will support,
-     * in Global version
-     */
-    @Override
-    protected Object[] getGlobalImplementations() {
-        Object[] res = { ConnectionManager.class };
-        return res;
-    }
-
-    /**
-     * Configure the dependency for a given instance Global
-     *
-     * @param c Component assigned for this instance, this will be
-     * what will be used for configuration
-     * @param imp implementation to be configured
-     * @param containerName container on which the configuration happens
-     */
-    @Override
-    protected void configureGlobalInstance(Component c, Object imp) {
-        if (imp.equals(ConnectionManager.class)) {
-            Dictionary<String, Object> props = new Hashtable<String, Object>();
-            Set<String> propSet = new HashSet<String>();
-            for (ConnectionMgmtScheme scheme:ConnectionMgmtScheme.values()) {
-                propSet.add("connectionmanager."+scheme.name()+".nodeconnections");
-            }
-            props.put("cachenames", propSet);
-            props.put("scope", "Global");
-
-            // export the service
-            c.setInterface(new String[] { IConnectionManager.class.getName(),
-                                          IConnectionListener.class.getName(),
-                                          ICoordinatorChangeAware.class.getName(),
-                                          IListenInventoryUpdates.class.getName(),
-                                          ICacheUpdateAware.class.getName()},
-                                          props);
-
-            c.add(createServiceDependency()
-                    .setService(IClusterGlobalServices.class)
-                    .setCallbacks("setClusterServices", "unsetClusterServices")
-                    .setRequired(true));
-
-            c.add(createServiceDependency().setService(IConnectionService.class)
-                    .setCallbacks("setConnectionService", "unsetConnectionService")
-                    .setRequired(true));
-            c.add(createServiceDependency().setService(IInventoryService.class, "(scope=Global)")
-                    .setCallbacks("setInventoryService", "unsetInventoryService")
-                    .setRequired(true));
-        }
-    }
-}
diff --git a/opendaylight/adsal/connectionmanager/implementation/src/main/java/org/opendaylight/controller/connectionmanager/internal/ConnectionManager.java b/opendaylight/adsal/connectionmanager/implementation/src/main/java/org/opendaylight/controller/connectionmanager/internal/ConnectionManager.java
deleted file mode 100644 (file)
index d76c094..0000000
+++ /dev/null
@@ -1,451 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * Connection Manager provides south-bound connectivity services.
- * The APIs are currently focused towards Active-Active Clustering support
- * wherein the node can connect to any of the Active Controller in the Cluster.
- * This component can also host the necessary logic for south-bound connectivity
- * when partial cluster is identified during Partition scenarios.
- *
- * But this (and its corresponding implementation) component can also be used for
- * basic connectivity mechansims for various south-bound plugins.
- */
-
-package org.opendaylight.controller.connectionmanager.internal;
-
-import java.net.InetAddress;
-import java.net.UnknownHostException;
-import java.util.Collections;
-import java.util.HashSet;
-import java.util.Map;
-import java.util.Set;
-import java.util.concurrent.BlockingQueue;
-import java.util.concurrent.ConcurrentHashMap;
-import java.util.concurrent.ConcurrentMap;
-import java.util.concurrent.LinkedBlockingQueue;
-
-import org.eclipse.osgi.framework.console.CommandInterpreter;
-import org.eclipse.osgi.framework.console.CommandProvider;
-import org.opendaylight.controller.clustering.services.ICacheUpdateAware;
-import org.opendaylight.controller.clustering.services.IClusterGlobalServices;
-import org.opendaylight.controller.clustering.services.ICoordinatorChangeAware;
-import org.opendaylight.controller.connectionmanager.ConnectionMgmtScheme;
-import org.opendaylight.controller.connectionmanager.IConnectionManager;
-import org.opendaylight.controller.connectionmanager.scheme.AbstractScheme;
-import org.opendaylight.controller.connectionmanager.scheme.SchemeFactory;
-import org.opendaylight.controller.sal.connection.ConnectionConstants;
-import org.opendaylight.controller.sal.connection.ConnectionLocality;
-import org.opendaylight.controller.sal.connection.IConnectionListener;
-import org.opendaylight.controller.sal.connection.IConnectionService;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.core.UpdateType;
-import org.opendaylight.controller.sal.inventory.IInventoryService;
-import org.opendaylight.controller.sal.inventory.IListenInventoryUpdates;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.sal.utils.StatusCode;
-import org.osgi.framework.BundleContext;
-import org.osgi.framework.FrameworkUtil;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-public class ConnectionManager implements IConnectionManager,
-        IConnectionListener, ICoordinatorChangeAware, IListenInventoryUpdates,
-        ICacheUpdateAware<Node, Set<InetAddress>>, CommandProvider {
-    private static final Logger logger = LoggerFactory
-            .getLogger(ConnectionManager.class);
-    private ConnectionMgmtScheme activeScheme = ConnectionMgmtScheme.ANY_CONTROLLER_ONE_MASTER;
-    private IClusterGlobalServices clusterServices;
-    private ConcurrentMap<ConnectionMgmtScheme, AbstractScheme> schemes;
-    private IConnectionService connectionService;
-    private Thread connectionEventThread;
-    private BlockingQueue<ConnectionMgmtEvent> connectionEvents;
-    private IInventoryService inventoryService;
-
-    public void setClusterServices(IClusterGlobalServices i) {
-        this.clusterServices = i;
-    }
-
-    public void unsetClusterServices(IClusterGlobalServices i) {
-        if (this.clusterServices == i) {
-            this.clusterServices = null;
-        }
-    }
-
-    public void setConnectionService(IConnectionService i) {
-        this.connectionService = i;
-    }
-
-    public void unsetConnectionService(IConnectionService i) {
-        if (this.connectionService == i) {
-            this.connectionService = null;
-        }
-    }
-
-    public void setInventoryService(IInventoryService service) {
-        logger.trace("Got inventory service set request {}", service);
-        this.inventoryService = service;
-    }
-
-    public void unsetInventoryService(IInventoryService service) {
-        logger.trace("Got a service UNset request");
-        this.inventoryService = null;
-    }
-
-    private void getInventories() {
-        Map<Node, Map<String, Property>> nodeProp = this.inventoryService
-                .getNodeProps();
-        for (Map.Entry<Node, Map<String, Property>> entry : nodeProp.entrySet()) {
-            Node node = entry.getKey();
-            logger.debug("getInventories for node:{}", new Object[] { node });
-            Map<String, Property> propMap = entry.getValue();
-            Set<Property> props = new HashSet<Property>();
-            for (Property property : propMap.values()) {
-                props.add(property);
-            }
-            updateNode(node, UpdateType.ADDED, props);
-        }
-
-        Map<NodeConnector, Map<String, Property>> nodeConnectorProp = this.inventoryService
-                .getNodeConnectorProps();
-        for (Map.Entry<NodeConnector, Map<String, Property>> entry : nodeConnectorProp
-                .entrySet()) {
-            Map<String, Property> propMap = entry.getValue();
-            Set<Property> props = new HashSet<Property>();
-            for (Property property : propMap.values()) {
-                props.add(property);
-            }
-            updateNodeConnector(entry.getKey(), UpdateType.ADDED, props);
-        }
-    }
-
-    public void started() {
-
-        connectionEventThread.start();
-
-        registerWithOSGIConsole();
-        notifyClusterViewChanged();
-        // Should pull the Inventory updates in case we missed it
-        getInventories();
-    }
-
-    public void init() {
-        connectionEventThread = new Thread(new EventHandler(),
-                "ConnectionEvent Thread");
-        this.connectionEvents = new LinkedBlockingQueue<ConnectionMgmtEvent>();
-        schemes = new ConcurrentHashMap<ConnectionMgmtScheme, AbstractScheme>();
-
-        String schemeStr = System.getProperty("connection.scheme");
-        for (ConnectionMgmtScheme scheme : ConnectionMgmtScheme.values()) {
-            AbstractScheme schemeImpl = SchemeFactory.getScheme(scheme, clusterServices);
-            if (schemeImpl != null) {
-                schemes.put(scheme, schemeImpl);
-                if (scheme.name().equalsIgnoreCase(schemeStr)) {
-                    activeScheme = scheme;
-                }
-            }
-        }
-    }
-
-    public void stopping() {
-        connectionEventThread.interrupt();
-        Set<Node> localNodes = getLocalNodes();
-        if (localNodes != null) {
-            AbstractScheme scheme = schemes.get(activeScheme);
-            for (Node localNode : localNodes) {
-                connectionService.disconnect(localNode);
-                if (scheme != null)
-                    scheme.removeNode(localNode);
-            }
-        }
-    }
-
-    @Override
-    public ConnectionMgmtScheme getActiveScheme() {
-        return activeScheme;
-    }
-
-    @Override
-    public Set<Node> getNodes(InetAddress controller) {
-        AbstractScheme scheme = schemes.get(activeScheme);
-        if (scheme == null)
-            return null;
-        return scheme.getNodes(controller);
-    }
-
-    @Override
-    public Set<Node> getLocalNodes() {
-        AbstractScheme scheme = schemes.get(activeScheme);
-        if (scheme == null)
-            return null;
-        return scheme.getNodes();
-    }
-
-    @Override
-    public boolean isLocal(Node node) {
-        AbstractScheme scheme = schemes.get(activeScheme);
-        if (scheme == null)
-            return false;
-        return scheme.isLocal(node);
-    }
-
-    @Override
-    public ConnectionLocality getLocalityStatus(Node node) {
-        AbstractScheme scheme = schemes.get(activeScheme);
-        if (scheme == null)
-            return ConnectionLocality.NOT_CONNECTED;
-        return scheme.getLocalityStatus(node);
-    }
-
-    @Override
-    public void updateNode(Node node, UpdateType type, Set<Property> props) {
-        logger.debug("updateNode: {} type {} props {}", node, type, props);
-        AbstractScheme scheme = schemes.get(activeScheme);
-        if (scheme == null)
-            return;
-        switch (type) {
-        case ADDED:
-            scheme.addNode(node);
-            break;
-        case REMOVED:
-            scheme.removeNode(node);
-            break;
-        default:
-            break;
-        }
-    }
-
-    @Override
-    public void updateNodeConnector(NodeConnector nodeConnector,
-            UpdateType type, Set<Property> props) {
-        logger.debug("updateNodeConnector: {} type {} props {}", nodeConnector,
-                type, props);
-        AbstractScheme scheme = schemes.get(activeScheme);
-        if (scheme == null)
-            return;
-        switch (type) {
-        case ADDED:
-            scheme.addNode(nodeConnector.getNode());
-            break;
-        default:
-            break;
-        }
-    }
-
-    @Override
-    public void coordinatorChanged() {
-        notifyClusterViewChanged();
-    }
-
-    @Override
-    public Node connect(String connectionIdentifier,
-            Map<ConnectionConstants, String> params) {
-        if (connectionService == null)
-            return null;
-        Node node = connectionService.connect(connectionIdentifier, params);
-        AbstractScheme scheme = schemes.get(activeScheme);
-        if (scheme != null && node != null)
-            scheme.addNode(node);
-        return node;
-    }
-
-    @Override
-    public Node connect(String type, String connectionIdentifier,
-            Map<ConnectionConstants, String> params) {
-        if (connectionService == null)
-            return null;
-        Node node = connectionService.connect(type, connectionIdentifier, params);
-        AbstractScheme scheme = schemes.get(activeScheme);
-        if (scheme != null && node != null)
-            scheme.addNode(node);
-        return node;
-    }
-
-    @Override
-    public Status disconnect(Node node) {
-        if (node == null)
-            return new Status(StatusCode.BADREQUEST);
-        if (connectionService == null)
-            return new Status(StatusCode.NOSERVICE);
-        Status status = connectionService.disconnect(node);
-        if (status.isSuccess()) {
-            AbstractScheme scheme = schemes.get(activeScheme);
-            if (scheme != null)
-                scheme.removeNode(node);
-        }
-        return status;
-    }
-
-    @Override
-    public void entryCreated(Node key, String cacheName, boolean originLocal) {
-        if (originLocal)
-            return;
-    }
-
-    /*
-     * Clustering Services doesn't provide the existing states in the cache
-     * update callbacks. Hence, using a scratch local cache to maintain the
-     * existing state.
-     */
-    private ConcurrentMap<Node, Set<InetAddress>> existingConnections = new ConcurrentHashMap<Node, Set<InetAddress>>();
-
-    @Override
-    public void entryUpdated(Node node, Set<InetAddress> newControllers,
-            String cacheName, boolean originLocal) {
-        if (originLocal)
-            return;
-        Set<InetAddress> existingControllers = existingConnections.get(node);
-        if (existingControllers != null) {
-            logger.debug("Processing Update for : {} NewControllers : {} existingControllers : {}", node,
-                    newControllers.toString(), existingControllers.toString());
-            if (newControllers.size() < existingControllers.size()) {
-                Set<InetAddress> removed = new HashSet<InetAddress>(existingControllers);
-                if (removed.removeAll(newControllers)) {
-                    logger.debug("notifyNodeDisconnectFromMaster({})", node);
-                    notifyNodeDisconnectedEvent(node);
-                }
-            }
-        } else {
-            logger.debug("Ignoring the Update for : {} NewControllers : {}", node, newControllers.toString());
-        }
-        existingConnections.put(node, newControllers);
-    }
-
-    @Override
-    public void entryDeleted(Node key, String cacheName, boolean originLocal) {
-        if (originLocal)
-            return;
-        logger.debug("Deleted entry {} from cache : {}", key, cacheName);
-        notifyNodeDisconnectedEvent(key);
-    }
-
-    private void enqueueConnectionEvent(ConnectionMgmtEvent event) {
-        try {
-            if (!connectionEvents.contains(event)) {
-                this.connectionEvents.put(event);
-            }
-        } catch (InterruptedException e) {
-            logger.debug(
-                    "enqueueConnectionEvent caught Interrupt Exception for event {}",
-                    event);
-        }
-    }
-
-    private void notifyClusterViewChanged() {
-        ConnectionMgmtEvent event = new ConnectionMgmtEvent(
-                ConnectionMgmtEventType.CLUSTER_VIEW_CHANGED, null);
-        enqueueConnectionEvent(event);
-    }
-
-    private void notifyNodeDisconnectedEvent(Node node) {
-        ConnectionMgmtEvent event = new ConnectionMgmtEvent(
-                ConnectionMgmtEventType.NODE_DISCONNECTED_FROM_MASTER, node);
-        enqueueConnectionEvent(event);
-    }
-
-    /*
-     * this thread monitors the connectionEvent queue for new incoming events
-     * from
-     */
-    private class EventHandler implements Runnable {
-        @Override
-        public void run() {
-
-            while (true) {
-                try {
-                    ConnectionMgmtEvent ev = connectionEvents.take();
-                    ConnectionMgmtEventType eType = ev.getEvent();
-                    switch (eType) {
-                    case NODE_DISCONNECTED_FROM_MASTER:
-                        Node node = (Node) ev.getData();
-                        connectionService.notifyNodeDisconnectFromMaster(node);
-                        break;
-                    case CLUSTER_VIEW_CHANGED:
-                        AbstractScheme scheme = schemes.get(activeScheme);
-                        if (scheme == null)
-                            return;
-                        scheme.handleClusterViewChanged();
-                        connectionService.notifyClusterViewChanged();
-                        break;
-                    default:
-                        logger.error("Unknown Connection event {}",
-                                eType.ordinal());
-                    }
-                } catch (InterruptedException e) {
-                    connectionEvents.clear();
-                    return;
-                }
-            }
-        }
-    }
-
-    private void registerWithOSGIConsole() {
-        BundleContext bundleContext = FrameworkUtil.getBundle(this.getClass())
-                .getBundleContext();
-        bundleContext.registerService(CommandProvider.class.getName(), this,
-                null);
-    }
-
-    public void _scheme(CommandInterpreter ci) {
-        String schemeStr = ci.nextArgument();
-        if (schemeStr == null) {
-            ci.println("Please enter valid Scheme name");
-            ci.println("Current Scheme : " + activeScheme.name());
-            return;
-        }
-        ConnectionMgmtScheme scheme = ConnectionMgmtScheme.valueOf(schemeStr);
-        if (scheme == null) {
-            ci.println("Please enter a valid Scheme name");
-            return;
-        }
-        activeScheme = scheme;
-    }
-
-    public void _printNodes(CommandInterpreter ci) {
-        String controller = ci.nextArgument();
-        if (controller == null) {
-            ci.println("Nodes connected to this controller : ");
-            if (this.getLocalNodes() == null) {
-                ci.println("None");
-            } else {
-                ci.println(this.getLocalNodes().toString());
-            }
-            return;
-        }
-        try {
-            InetAddress address = InetAddress.getByName(controller);
-            ci.println("Nodes connected to controller " + controller);
-            if (this.getNodes(address) == null) {
-                ci.println("None");
-            } else {
-                ci.println(this.getNodes(address).toString());
-            }
-        } catch (UnknownHostException e) {
-            logger.error("An error occured", e);
-        }
-    }
-
-    @Override
-    public String getHelp() {
-        StringBuffer help = new StringBuffer();
-        help.append("---Connection Manager---\n");
-        help.append("\t scheme [<name>]                      - Print / Set scheme\n");
-        help.append("\t printNodes [<controller>]            - Print connected nodes\n");
-        return help.toString();
-    }
-
-    @Override
-    public Set<InetAddress> getControllers(Node node) {
-        AbstractScheme scheme = schemes.get(activeScheme);
-        if (scheme == null)
-            return Collections.emptySet();
-        return scheme.getControllers(node);
-    }
-}
diff --git a/opendaylight/adsal/connectionmanager/implementation/src/main/java/org/opendaylight/controller/connectionmanager/internal/ConnectionMgmtEvent.java b/opendaylight/adsal/connectionmanager/implementation/src/main/java/org/opendaylight/controller/connectionmanager/internal/ConnectionMgmtEvent.java
deleted file mode 100644 (file)
index bb353ff..0000000
+++ /dev/null
@@ -1,54 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.connectionmanager.internal;
-
-public class ConnectionMgmtEvent {
-    ConnectionMgmtEventType event;
-    Object data;
-    public ConnectionMgmtEvent(ConnectionMgmtEventType event, Object data) {
-        this.event = event;
-        this.data = data;
-    }
-    public ConnectionMgmtEventType getEvent() {
-        return event;
-    }
-    public Object getData() {
-        return data;
-    }
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + ((data == null) ? 0 : data.hashCode());
-        result = prime * result + ((event == null) ? 0 : event.hashCode());
-        return result;
-    }
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj)
-            return true;
-        if (obj == null)
-            return false;
-        if (getClass() != obj.getClass())
-            return false;
-        ConnectionMgmtEvent other = (ConnectionMgmtEvent) obj;
-        if (data == null) {
-            if (other.data != null)
-                return false;
-        } else if (!data.equals(other.data))
-            return false;
-        if (event != other.event)
-            return false;
-        return true;
-    }
-    @Override
-    public String toString() {
-        return "ConnectionMgmtEvent [event=" + event + ", data=" + data + "]";
-    }
-}
diff --git a/opendaylight/adsal/connectionmanager/implementation/src/main/java/org/opendaylight/controller/connectionmanager/internal/ConnectionMgmtEventType.java b/opendaylight/adsal/connectionmanager/implementation/src/main/java/org/opendaylight/controller/connectionmanager/internal/ConnectionMgmtEventType.java
deleted file mode 100644 (file)
index cefae55..0000000
+++ /dev/null
@@ -1,32 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.connectionmanager.internal;
-
-public enum ConnectionMgmtEventType {
-    NODE_DISCONNECTED_FROM_MASTER("Node is disconnected from master"),
-    CLUSTER_VIEW_CHANGED("Cluster Composition changed");
-
-    private ConnectionMgmtEventType(String name) {
-        this.name = name;
-    }
-
-    private String name;
-
-    public String toString() {
-        return name;
-    }
-
-    public static ConnectionMgmtEventType fromString(String pName) {
-        for(ConnectionMgmtEventType p:ConnectionMgmtEventType.values()) {
-            if (p.toString().equals(pName)) {
-                return p;
-            }
-        }
-        return null;
-    }
-}
diff --git a/opendaylight/adsal/connectionmanager/implementation/src/main/java/org/opendaylight/controller/connectionmanager/scheme/AbstractScheme.java b/opendaylight/adsal/connectionmanager/implementation/src/main/java/org/opendaylight/controller/connectionmanager/scheme/AbstractScheme.java
deleted file mode 100644 (file)
index 68d1b23..0000000
+++ /dev/null
@@ -1,390 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.connectionmanager.scheme;
-
-import java.net.InetAddress;
-import java.util.ArrayList;
-import java.util.Collections;
-import java.util.EnumSet;
-import java.util.HashSet;
-import java.util.Iterator;
-import java.util.List;
-import java.util.Set;
-import java.util.concurrent.ConcurrentHashMap;
-import java.util.concurrent.ConcurrentMap;
-
-import org.opendaylight.controller.clustering.services.CacheConfigException;
-import org.opendaylight.controller.clustering.services.CacheExistException;
-import org.opendaylight.controller.clustering.services.IClusterGlobalServices;
-import org.opendaylight.controller.clustering.services.IClusterServices;
-import org.opendaylight.controller.connectionmanager.ConnectionMgmtScheme;
-import org.opendaylight.controller.sal.connection.ConnectionLocality;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.sal.utils.StatusCode;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-public abstract class AbstractScheme {
-    private static final Logger log = LoggerFactory.getLogger(AbstractScheme.class);
-    protected IClusterGlobalServices clusterServices = null;
-    /*
-     * A more natural Map data-structure is to have a Key=Controller IP-address with value = a set of Nodes.
-     * But, such a data-structure results in some complex event processing during the Cluster operations
-     * to sync up the Connection states.
-     *
-     * A data-structure with Node as the key and set of controllers provides a good balance
-     * between the needed functionality and simpler clustering implementation for Connection Manager.
-     */
-    protected ConcurrentMap <Node, Set<InetAddress>> nodeConnections;
-    protected abstract boolean isConnectionAllowedInternal(Node node);
-    private final String name;
-    private final String nodeConnectionsCacheName;
-
-    protected AbstractScheme(IClusterGlobalServices clusterServices, ConnectionMgmtScheme type) {
-        this.clusterServices = clusterServices;
-        name = (type != null ? type.name() : "UNKNOWN");
-        nodeConnectionsCacheName = "connectionmanager."+name+".nodeconnections";
-        if (clusterServices != null) {
-            allocateCaches();
-            retrieveCaches();
-        } else {
-            log.error("Couldn't retrieve caches for scheme {}. Clustering service unavailable", name);
-        }
-    }
-
-    protected ConcurrentMap <InetAddress, Set<Node>> getControllerToNodesMap() {
-        ConcurrentMap <InetAddress, Set<Node>> controllerNodesMap = new ConcurrentHashMap <InetAddress, Set<Node>>();
-        for (Node node : nodeConnections.keySet()) {
-            Set<InetAddress> controllers = nodeConnections.get(node);
-            if (controllers == null) continue;
-            for (InetAddress controller : controllers) {
-                Set<Node> nodes = controllerNodesMap.get(controller);
-                if (nodes == null) {
-                    nodes = new HashSet<Node>();
-                }
-                nodes.add(node);
-                controllerNodesMap.put(controller, nodes);
-            }
-        }
-        return controllerNodesMap;
-    }
-
-    public boolean isConnectionAllowed (Node node) {
-        if (clusterServices == null || nodeConnections == null) {
-            return false;
-        }
-
-        return isConnectionAllowedInternal(node);
-    }
-
-    public void handleClusterViewChanged() {
-        log.debug("Handling Cluster View changed notification");
-        List<InetAddress> controllers = clusterServices.getClusteredControllers();
-        ConcurrentMap <InetAddress, Set<Node>> controllerNodesMap = getControllerToNodesMap();
-        List<InetAddress> toRemove = new ArrayList<InetAddress>();
-        for (InetAddress c : controllerNodesMap.keySet()) {
-            if (!controllers.contains(c)) {
-                toRemove.add(c);
-            }
-        }
-
-        boolean retry = false;
-        for (InetAddress c : toRemove) {
-            log.debug("Removing Controller : {} from the Connections table", c);
-            for (Iterator<Node> nodeIterator = nodeConnections.keySet().iterator();nodeIterator.hasNext();) {
-                Node node = nodeIterator.next();
-                Set <InetAddress> oldControllers = nodeConnections.get(node);
-                Set <InetAddress> newControllers = new HashSet<InetAddress>(oldControllers);
-                if (newControllers.remove(c)) {
-                    try {
-                        clusterServices.tbegin();
-                        if (!nodeConnections.replace(node, oldControllers, newControllers)) {
-                            log.debug("Replace Failed for {} ", node.toString());
-                            retry = true;
-                            clusterServices.trollback();
-                            break;
-                        } else {
-                            clusterServices.tcommit();
-                        }
-                    } catch (Exception e) {
-                        log.debug("Exception in replacing nodeConnections ", e);
-                        retry = true;
-                        try {
-                            clusterServices.trollback();
-                        } catch (Exception e1) {}
-                        break;
-                    }
-                }
-            }
-        }
-        if (retry) {
-            try {
-                Thread.sleep(1000);
-            } catch (InterruptedException e) {}
-            handleClusterViewChanged();
-        }
-    }
-
-    public Set<Node> getNodes(InetAddress controller) {
-        ConcurrentMap <InetAddress, Set<Node>> controllerNodesMap = getControllerToNodesMap();
-        return controllerNodesMap.get(controller);
-    }
-
-    public Set<Node> getNodes() {
-        return getNodes(clusterServices.getMyAddress());
-    }
-
-    public Set<InetAddress> getControllers(Node node) {
-        if (nodeConnections != null) return nodeConnections.get(node);
-        return Collections.emptySet();
-    }
-
-    public ConcurrentMap<Node, Set<InetAddress>> getNodeConnections() {
-        return nodeConnections;
-    }
-
-    public boolean isLocal(Node node) {
-        if (nodeConnections == null) return false;
-        InetAddress myController = clusterServices.getMyAddress();
-        Set<InetAddress> controllers = nodeConnections.get(node);
-        return (controllers != null && controllers.contains(myController));
-    }
-
-    public ConnectionLocality getLocalityStatus(Node node) {
-        if (nodeConnections == null) return ConnectionLocality.NOT_CONNECTED;
-        Set<InetAddress> controllers = nodeConnections.get(node);
-        if (controllers == null || controllers.size() == 0) return ConnectionLocality.NOT_CONNECTED;
-        InetAddress myController = clusterServices.getMyAddress();
-        return controllers.contains(myController) ? ConnectionLocality.LOCAL:
-                                                    ConnectionLocality.NOT_LOCAL;
-    }
-
-    public Status removeNode (Node node) {
-        return removeNodeFromController(node, clusterServices.getMyAddress());
-    }
-
-    protected Status removeNodeFromController (Node node, InetAddress controller) {
-        if (node == null || controller == null) {
-            return new Status(StatusCode.BADREQUEST, "Invalid Node or Controller Address Specified.");
-        }
-
-        if (clusterServices == null || nodeConnections == null) {
-            return new Status(StatusCode.SUCCESS);
-        }
-
-        Set<InetAddress> oldControllers = nodeConnections.get(node);
-
-        if (oldControllers != null && oldControllers.contains(controller)) {
-            Set<InetAddress> newControllers = new HashSet<InetAddress>(oldControllers);
-            if (newControllers.remove(controller)) {
-                try {
-                    clusterServices.tbegin();
-                    if (newControllers.size() > 0) {
-                        if (!nodeConnections.replace(node, oldControllers, newControllers)) {
-                            clusterServices.trollback();
-                            try {
-                                Thread.sleep(100);
-                            } catch ( InterruptedException e) {}
-                            return removeNodeFromController(node, controller);
-                        }
-                    } else {
-                        nodeConnections.remove(node);
-                    }
-                    clusterServices.tcommit();
-                } catch (Exception e) {
-                    log.error("Exception in removing Controller from a Node", e);
-                    try {
-                        clusterServices.trollback();
-                    } catch (Exception e1) {
-                        log.error("Error Rolling back the node Connections Changes ", e);
-                    }
-                    return new Status(StatusCode.INTERNALERROR);
-                }
-
-            }
-        }
-        return new Status(StatusCode.SUCCESS);
-
-    }
-
-    /*
-     * A few race-conditions were seen with the Clustered caches in putIfAbsent and replace
-     * functions. Leaving a few debug logs behind to assist in debugging if strange things happen.
-     */
-    private Status putNodeToController (Node node, InetAddress controller) {
-        if (clusterServices == null || nodeConnections == null) {
-            return new Status(StatusCode.INTERNALERROR, "Cluster service unavailable, or node connections info missing.");
-        }
-        log.debug("Trying to Put {} to {}", controller.getHostAddress(), node.toString());
-
-        Set <InetAddress> oldControllers = nodeConnections.get(node);
-        Set <InetAddress> newControllers = null;
-        if (oldControllers == null) {
-            newControllers = new HashSet<InetAddress>();
-        } else {
-            if (oldControllers.size() > 0 && !isConnectionAllowed(node)) {
-                /*
-                 * In certain race conditions, the putIfAbsent fails to be atomic.
-                 * This check is added to identify such cases and report an warning
-                 * for debugging.
-                 */
-                log.warn("States Exists for {} : {}", node, oldControllers.toString());
-            }
-            newControllers = new HashSet<InetAddress>(oldControllers);
-        }
-        newControllers.add(controller);
-
-        try {
-            clusterServices.tbegin();
-            if (nodeConnections.putIfAbsent(node, newControllers) != null) {
-                log.debug("PutIfAbsent failed {} to {}", controller.getHostAddress(), node.toString());
-                /*
-                 * This check is needed again to take care of the case where some schemes
-                 * would not allow nodes to be connected to multiple controllers.
-                 * Hence, if putIfAbsent fails, that means, some other controller is competing
-                 * with this controller to take hold of a Node.
-                 */
-                if (isConnectionAllowed(node)) {
-                    if (oldControllers == null || !nodeConnections.replace(node, oldControllers, newControllers)) {
-                        clusterServices.trollback();
-                        try {
-                            Thread.sleep(100);
-                        } catch ( InterruptedException e) {}
-                        log.debug("Retrying ... {} with {}", controller.getHostAddress(), node.toString());
-                        return putNodeToController(node, controller);
-                    } else {
-                        log.debug("Replace successful old={} with new={} for {} to {}", oldControllers.toString(), newControllers.toString(),
-                                controller.getHostAddress(), node.toString());
-                    }
-                } else {
-                    clusterServices.trollback();
-                    return new Status(StatusCode.CONFLICT);
-                }
-            } else {
-                log.debug("Added {} to {}", controller.getHostAddress(), node.toString());
-            }
-            clusterServices.tcommit();
-        } catch (Exception e) {
-            log.error("Excepion in adding Controller to a Node", e);
-            try {
-                clusterServices.trollback();
-            } catch (Exception e1) {
-                log.error("Error Rolling back the node Connections Changes ", e);
-            }
-            return new Status(StatusCode.INTERNALERROR);
-        }
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    public Status addNode (Node node, InetAddress controller) {
-        if (node == null || controller == null) {
-            if (node == null) {
-                log.warn("addNode: node is null");
-            } else if (controller == null) {
-                log.error("Failed to add node {}. The controller address retrieved from clusterServices is null.", node);
-            }
-            return new Status(StatusCode.BADREQUEST);
-        }
-        if (isLocal(node))  {
-            return new Status(StatusCode.SUCCESS);
-        }
-        if (isConnectionAllowed(node)) {
-            return putNodeToController(node, controller);
-        } else {
-            return new Status(StatusCode.NOTALLOWED);
-        }
-    }
-
-    public Status addNode (Node node) {
-        return addNode(node, clusterServices.getMyAddress());
-    }
-
-    @SuppressWarnings({ "unchecked" })
-    private void retrieveCaches() {
-        if (this.clusterServices == null) {
-            log.error("Un-initialized Cluster Services, can't retrieve caches for scheme: {}", name);
-            return;
-        }
-
-        nodeConnections = (ConcurrentMap<Node, Set<InetAddress>>) clusterServices.getCache(nodeConnectionsCacheName);
-
-        if (nodeConnections == null) {
-            log.error("\nFailed to get cache: {}", nodeConnectionsCacheName);
-        }
-    }
-
-    private void allocateCaches() {
-        if (this.clusterServices == null) {
-            log.error("Un-initialized clusterServices, can't create cache");
-            return;
-        }
-
-        try {
-            clusterServices.createCache(nodeConnectionsCacheName, EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-        } catch (CacheExistException cee) {
-            log.debug("\nCache already exists: {}", nodeConnectionsCacheName);
-        } catch (CacheConfigException cce) {
-            log.error("\nCache configuration invalid - check cache mode");
-        } catch (Exception e) {
-            log.error("An error occured",e);
-        }
-    }
-
-    /* (non-Javadoc)
-     * @see java.lang.Object#hashCode()
-     */
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + ((name == null) ? 0 : name.hashCode());
-        result = prime * result + ((nodeConnections == null) ? 0 : nodeConnections.hashCode());
-        result = prime * result + ((nodeConnectionsCacheName == null) ? 0 : nodeConnectionsCacheName.hashCode());
-        return result;
-    }
-
-    /* (non-Javadoc)
-     * @see java.lang.Object#equals(java.lang.Object)
-     */
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (!(obj instanceof AbstractScheme)) {
-            return false;
-        }
-        AbstractScheme other = (AbstractScheme) obj;
-        if (name == null) {
-            if (other.name != null) {
-                return false;
-            }
-        } else if (!name.equals(other.name)) {
-            return false;
-        }
-        if (nodeConnections == null) {
-            if (other.nodeConnections != null) {
-                return false;
-            }
-        } else if (!nodeConnections.equals(other.nodeConnections)) {
-            return false;
-        }
-        if (nodeConnectionsCacheName == null) {
-            if (other.nodeConnectionsCacheName != null) {
-                return false;
-            }
-        } else if (!nodeConnectionsCacheName.equals(other.nodeConnectionsCacheName)) {
-            return false;
-        }
-        return true;
-    }
-}
diff --git a/opendaylight/adsal/connectionmanager/implementation/src/main/java/org/opendaylight/controller/connectionmanager/scheme/AnyControllerScheme.java b/opendaylight/adsal/connectionmanager/implementation/src/main/java/org/opendaylight/controller/connectionmanager/scheme/AnyControllerScheme.java
deleted file mode 100644 (file)
index a4138c4..0000000
+++ /dev/null
@@ -1,37 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.connectionmanager.scheme;
-
-import java.net.InetAddress;
-import java.util.Set;
-
-import org.opendaylight.controller.clustering.services.IClusterGlobalServices;
-import org.opendaylight.controller.connectionmanager.ConnectionMgmtScheme;
-import org.opendaylight.controller.sal.core.Node;
-
-class AnyControllerScheme extends AbstractScheme {
-    private static AbstractScheme myScheme= null;
-
-    protected AnyControllerScheme(IClusterGlobalServices clusterServices) {
-        super(clusterServices, ConnectionMgmtScheme.ANY_CONTROLLER_ONE_MASTER);
-    }
-
-    public static AbstractScheme getScheme(IClusterGlobalServices clusterServices) {
-        if (myScheme == null) {
-            myScheme = new AnyControllerScheme(clusterServices);
-        }
-        return myScheme;
-    }
-
-    @Override
-    public boolean isConnectionAllowedInternal(Node node) {
-        Set <InetAddress> controllers = nodeConnections.get(node);
-        if (controllers == null || controllers.size() == 0) return true;
-        return (controllers.size() == 1 && controllers.contains(clusterServices.getMyAddress()));
-    }
-}
diff --git a/opendaylight/adsal/connectionmanager/implementation/src/main/java/org/opendaylight/controller/connectionmanager/scheme/ControllerConfig.java b/opendaylight/adsal/connectionmanager/implementation/src/main/java/org/opendaylight/controller/connectionmanager/scheme/ControllerConfig.java
deleted file mode 100644 (file)
index e186d2b..0000000
+++ /dev/null
@@ -1,69 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.connectionmanager.scheme;
-
-import java.net.InetAddress;
-
-/**
- * Configuration object that can be used to prioritize or add weight to a given controller.
- * This can be potentially used by the Connection management scheme algorithms.
- *
- * This is currently not used.
- *
- */
-public class ControllerConfig {
-    private InetAddress controllerId;
-    private int priority;
-    private int weight;
-
-    public ControllerConfig(InetAddress controllerId, int priority, int weight) {
-        this.controllerId = controllerId;
-        this.priority = priority;
-        this.weight = weight;
-    }
-
-    public InetAddress getControllerId() {
-        return controllerId;
-    }
-    public int getPriority() {
-        return priority;
-    }
-    public int getWeight() {
-        return weight;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result
-                + ((controllerId == null) ? 0 : controllerId.hashCode());
-        return result;
-    }
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj)
-            return true;
-        if (obj == null)
-            return false;
-        if (getClass() != obj.getClass())
-            return false;
-        ControllerConfig other = (ControllerConfig) obj;
-        if (controllerId == null) {
-            if (other.controllerId != null)
-                return false;
-        } else if (!controllerId.equals(other.controllerId))
-            return false;
-        return true;
-    }
-    @Override
-    public String toString() {
-        return "ControllerConfig [controllerId=" + controllerId + ", priority="
-                + priority + ", weight=" + weight + "]";
-    }
-}
diff --git a/opendaylight/adsal/connectionmanager/implementation/src/main/java/org/opendaylight/controller/connectionmanager/scheme/LoadBalancedScheme.java b/opendaylight/adsal/connectionmanager/implementation/src/main/java/org/opendaylight/controller/connectionmanager/scheme/LoadBalancedScheme.java
deleted file mode 100644 (file)
index 04b6e1b..0000000
+++ /dev/null
@@ -1,37 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.connectionmanager.scheme;
-
-
-import org.opendaylight.controller.clustering.services.IClusterGlobalServices;
-import org.opendaylight.controller.connectionmanager.ConnectionMgmtScheme;
-import org.opendaylight.controller.sal.core.Node;
-
-/**
- * Load Balancing scheme will let the nodes connect with controller based
- * on the resource usage in each of the controllers in a cluster.
- *
- * Incomplete and Currently not used.
- */
-
-class LoadBalancedScheme extends AbstractScheme {
-
-    protected LoadBalancedScheme(IClusterGlobalServices clusterServices) {
-        super(clusterServices, ConnectionMgmtScheme.LOAD_BALANCED);
-    }
-
-    public static AbstractScheme getScheme(IClusterGlobalServices clusterServices) {
-        return null;
-    }
-
-    @Override
-    public boolean isConnectionAllowedInternal(Node node) {
-        return false;
-    }
-
-}
diff --git a/opendaylight/adsal/connectionmanager/implementation/src/main/java/org/opendaylight/controller/connectionmanager/scheme/RoundRobinScheme.java b/opendaylight/adsal/connectionmanager/implementation/src/main/java/org/opendaylight/controller/connectionmanager/scheme/RoundRobinScheme.java
deleted file mode 100644 (file)
index eed120b..0000000
+++ /dev/null
@@ -1,30 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.connectionmanager.scheme;
-
-import org.opendaylight.controller.clustering.services.IClusterGlobalServices;
-import org.opendaylight.controller.connectionmanager.ConnectionMgmtScheme;
-import org.opendaylight.controller.sal.core.Node;
-
-class RoundRobinScheme extends AbstractScheme {
-    protected RoundRobinScheme(IClusterGlobalServices clusterServices) {
-        super(clusterServices, ConnectionMgmtScheme.ROUND_ROBIN);
-        // TODO Auto-generated constructor stub
-    }
-
-    public static AbstractScheme getScheme(IClusterGlobalServices clusterServices) {
-        return null;
-    }
-
-    @Override
-    public boolean isConnectionAllowedInternal(Node node) {
-        // TODO Auto-generated method stub
-        return false;
-    }
-
-}
diff --git a/opendaylight/adsal/connectionmanager/implementation/src/main/java/org/opendaylight/controller/connectionmanager/scheme/SchemeFactory.java b/opendaylight/adsal/connectionmanager/implementation/src/main/java/org/opendaylight/controller/connectionmanager/scheme/SchemeFactory.java
deleted file mode 100644 (file)
index 2a6a91f..0000000
+++ /dev/null
@@ -1,26 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.connectionmanager.scheme;
-
-import org.opendaylight.controller.clustering.services.IClusterGlobalServices;
-import org.opendaylight.controller.connectionmanager.ConnectionMgmtScheme;
-
-public class SchemeFactory {
-    public static AbstractScheme getScheme(ConnectionMgmtScheme scheme, IClusterGlobalServices clusterServices) {
-        if (scheme == ConnectionMgmtScheme.SINGLE_CONTROLLER) {
-            return SingleControllerScheme.getScheme(clusterServices);
-        } else if (scheme == ConnectionMgmtScheme.ROUND_ROBIN) {
-            return RoundRobinScheme.getScheme(clusterServices);
-        } else if (scheme == ConnectionMgmtScheme.LOAD_BALANCED) {
-            return LoadBalancedScheme.getScheme(clusterServices);
-        } else if (scheme == ConnectionMgmtScheme.ANY_CONTROLLER_ONE_MASTER) {
-            return AnyControllerScheme.getScheme(clusterServices);
-        }
-        return null;
-    }
-}
diff --git a/opendaylight/adsal/connectionmanager/implementation/src/main/java/org/opendaylight/controller/connectionmanager/scheme/SingleControllerScheme.java b/opendaylight/adsal/connectionmanager/implementation/src/main/java/org/opendaylight/controller/connectionmanager/scheme/SingleControllerScheme.java
deleted file mode 100644 (file)
index 292773a..0000000
+++ /dev/null
@@ -1,34 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.connectionmanager.scheme;
-
-import org.opendaylight.controller.clustering.services.IClusterGlobalServices;
-import org.opendaylight.controller.connectionmanager.ConnectionMgmtScheme;
-import org.opendaylight.controller.sal.core.Node;
-
-class SingleControllerScheme extends AbstractScheme {
-
-    private static AbstractScheme myScheme = null;
-
-    protected SingleControllerScheme(IClusterGlobalServices clusterServices) {
-        super(clusterServices, ConnectionMgmtScheme.SINGLE_CONTROLLER);
-    }
-
-    public static AbstractScheme getScheme(IClusterGlobalServices clusterServices) {
-        if (myScheme == null) {
-            myScheme = new SingleControllerScheme(clusterServices);
-        }
-        return myScheme;
-    }
-
-    @Override
-    public boolean isConnectionAllowedInternal(Node node) {
-        // Lets make it simple. The Cluster Coordinator is the master
-        return clusterServices.amICoordinator();
-    }
-}
diff --git a/opendaylight/adsal/containermanager/api/pom.xml b/opendaylight/adsal/containermanager/api/pom.xml
deleted file mode 100644 (file)
index 20687ed..0000000
+++ /dev/null
@@ -1,57 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>containermanager</artifactId>
-  <version>0.7.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>configuration</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Import-Package>org.opendaylight.controller.configuration,
-              org.opendaylight.controller.sal.authorization,
-              org.opendaylight.controller.sal.utils,
-              org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.sal.action,
-              org.opendaylight.controller.sal.match,
-              org.opendaylight.controller.sal.packet,
-              org.opendaylight.controller.sal.reader,
-              org.slf4j,
-              javax.xml.bind.annotation,
-              javax.xml.bind</Import-Package>
-            <Export-Package>org.opendaylight.controller.containermanager</Export-Package>
-          </instructions>
-          <manifestLocation>${project.basedir}/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/containermanager/api/src/main/java/org/opendaylight/controller/containermanager/ContainerChangeEvent.java b/opendaylight/adsal/containermanager/api/src/main/java/org/opendaylight/controller/containermanager/ContainerChangeEvent.java
deleted file mode 100644 (file)
index 7e040c7..0000000
+++ /dev/null
@@ -1,33 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.containermanager;
-
-import java.io.Serializable;
-
-import org.opendaylight.controller.sal.core.UpdateType;
-
-public class ContainerChangeEvent implements Serializable {
-    private static final long serialVersionUID = 1L;
-    private ContainerConfig config;
-    private UpdateType update;
-
-    public ContainerChangeEvent(ContainerConfig config, UpdateType update) {
-        this.config = config;
-        this.update = update;
-    }
-
-    public UpdateType getUpdateType() {
-        return update;
-    }
-
-    public ContainerConfig getConfig() {
-        return config;
-    }
-}
diff --git a/opendaylight/adsal/containermanager/api/src/main/java/org/opendaylight/controller/containermanager/ContainerConfig.java b/opendaylight/adsal/containermanager/api/src/main/java/org/opendaylight/controller/containermanager/ContainerConfig.java
deleted file mode 100644 (file)
index 3c086cb..0000000
+++ /dev/null
@@ -1,645 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.containermanager;
-
-import java.io.Serializable;
-import java.util.ArrayList;
-import java.util.HashSet;
-import java.util.List;
-import java.util.Set;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.configuration.ConfigurationObject;
-import org.opendaylight.controller.sal.core.ContainerFlow;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.match.Match;
-import org.opendaylight.controller.sal.utils.GlobalConstants;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.sal.utils.StatusCode;
-
-/**
- * Container Configuration Java Object for Container Manager Represents a container
- * configuration information for Container Manager.
- *
- * Objects of this class are also serialized to and deserialized from binary
- * files through java serialization API when saving to/reading from Container
- * Manager startup configuration file.
- */
-@XmlRootElement(name = "containerConfig")
-@XmlAccessorType(XmlAccessType.NONE)
-public class ContainerConfig extends ConfigurationObject implements Serializable {
-    private static final long serialVersionUID = 2L;
-    private static final String regexName = "^\\w+$";
-    private static final String containerProfile = System.getProperty("container.profile") == null ? "Container"
-            : System.getProperty("container.profile");
-    private static final String ADMIN_SUFFIX = "Admin";
-    private static final String OPERATOR_SUFFIX = "Operator";
-
-    @XmlElement
-    private String container;
-
-    @XmlElement
-    private String staticVlan;
-
-    @XmlElement(name = "nodeConnectors")
-    private List<String> ports;
-
-    @XmlElement(name = "flowSpecs")
-    private List<ContainerFlowConfig> containerFlows;
-
-    public String getContainer() {
-        return container;
-    }
-
-    public void setContainer(String container) {
-        this.container = container;
-    }
-
-    public String getStaticVlan() {
-        return staticVlan;
-    }
-
-    public void setStaticVlan(String staticVlan) {
-        this.staticVlan = staticVlan;
-    }
-
-    public List<ContainerFlowConfig> getContainerFlows() {
-        return containerFlows;
-    }
-
-    public void setContainerFlows(List<ContainerFlowConfig> containerFlows) {
-        this.containerFlows = containerFlows;
-    }
-
-    public static long getSerialversionuid() {
-        return serialVersionUID;
-    }
-
-    public static String getRegexname() {
-        return regexName;
-    }
-
-    public void setPorts(List<String> ports) {
-        this.ports = ports;
-    }
-
-    /**
-     * Default constructor needed by Gson.
-     *
-     * @return a Default ContainerConfig
-     */
-    public ContainerConfig() {
-        this.container = null;
-        this.staticVlan = null;
-        this.ports = new ArrayList<String>(0);
-        this.containerFlows = new ArrayList<ContainerFlowConfig>(0);
-    }
-
-    /**
-     * Constructor for the ContainerConfig.
-     *
-     * @param container
-     *            Name of the container in this configuration
-     * @param vlan
-     *            vlan assigned to this container
-     * @param nodeName
-     *            the name of the node assigned to the container from this
-     *            configuration
-     * @param ports
-     *            the list of NodeConnectors on the Node belonging to the container
-     * @return the constructed object
-     */
-    public ContainerConfig(String container, String vlan, List<String> portList, List<ContainerFlowConfig> containerFlows) {
-        this.container = container;
-        this.staticVlan = vlan;
-        this.ports = (portList == null) ? new ArrayList<String>(0) : new ArrayList<String>(portList);
-        this.containerFlows = (containerFlows == null) ? new ArrayList<ContainerFlowConfig>(0)
-                : new ArrayList<ContainerFlowConfig>(containerFlows);
-    }
-
-    public ContainerConfig(ContainerConfig config) {
-        this.container = config.container;
-        this.staticVlan = config.staticVlan;
-        this.ports = (config.ports == null) ? new ArrayList<String>(0) : new ArrayList<String>(config.ports);
-        this.containerFlows = (config.containerFlows == null) ? new ArrayList<ContainerFlowConfig>(0)
-                : new ArrayList<ContainerFlowConfig>(config.containerFlows);
-    }
-
-    /**
-     * Returns the container name.
-     *
-     * @return the container name
-     */
-    public String getContainerName() {
-        return container;
-    }
-
-    /**
-     * Returns the Vlan tag.
-     *
-     * @return the Vlan Tag configured for this container configuration
-     */
-    public String getVlanTag() {
-        return staticVlan;
-    }
-
-    /**
-     * Returns the configured ports.
-     *
-     * @return the string with the list of ports associated to the container on this
-     *         configuration
-     */
-    public List<String> getPorts() {
-        return new ArrayList<String>(ports);
-    }
-
-    /**
-     * Returns the list of container flows configured for this container
-     *
-     * @return
-     */
-    public List<ContainerFlowConfig> getContainerFlowConfigs() {
-        return (containerFlows == null || containerFlows.isEmpty()) ? new ArrayList<ContainerFlowConfig>(0)
-                : new ArrayList<ContainerFlowConfig>(containerFlows);
-    }
-
-    /**
-     * Matches container name against passed parameter.
-     *
-     * @param name
-     *            name of the container to be matched
-     * @return true if the passed argument correspond with the container name in the
-     *         configuration
-     */
-    public boolean matchName(String name) {
-        return this.container.equals(name);
-    }
-
-    /**
-     * Parse the port list in several NodeConnector descriptor.
-     *
-     * @return the list of NodeConnector corresponding to the ports configured
-     *         on this configuration
-     */
-    public List<NodeConnector> getPortList() {
-        List<NodeConnector> portList = new ArrayList<NodeConnector>();
-        if (ports != null && !ports.isEmpty()) {
-            for (String portString : ports) {
-                portList.add(NodeConnector.fromString(portString));
-            }
-        }
-        return portList;
-    }
-
-    /**
-     * Checks if this is a valid container configuration
-     *
-     * @return true, if is valid container configuration, false otherwise
-     */
-    public Status validate() {
-        Status status = validateName();
-        if (status.isSuccess()) {
-            status = validateStaticVlan();
-            if (status.isSuccess()) {
-                status = validatePorts();
-                if (status.isSuccess()) {
-                    status = validateContainerFlows();
-                }
-            }
-        }
-        return status;
-    }
-
-    /**
-     * Checks for valid name.
-     *
-     * @return true, if successful
-     */
-    private Status validateName() {
-        // No Container configuration allowed to container default
-        return (isValidResourceName(container) && !container.equalsIgnoreCase(GlobalConstants.DEFAULT.toString())) ?
-                new Status(StatusCode.SUCCESS) : new Status(StatusCode.BADREQUEST, "Invalid container name");
-    }
-
-    /**
-     * Checks for valid ports.
-     *
-     * @return true, if successful
-     */
-    private Status validatePorts() {
-        return validateNodeConnectors(this.ports);
-    }
-
-    public static Status validateNodeConnectors(List<String> connectorList) {
-        if (connectorList != null && !connectorList.isEmpty()) {
-            for (String ncString : connectorList) {
-                if (NodeConnector.fromString(ncString) == null) {
-                    return new Status(StatusCode.BADREQUEST, "Invalid node connector: " + ncString);
-                }
-            }
-
-        }
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    public static List<NodeConnector> nodeConnectorsFromString(List<String> nodeConnectorStrings) {
-        List<NodeConnector> list = new ArrayList<NodeConnector>(nodeConnectorStrings.size());
-        for (String str : nodeConnectorStrings) {
-            list.add(NodeConnector.fromString(str));
-        }
-        return list;
-    }
-
-    /**
-     * Checks for valid static vlan.
-     *
-     * @return true, if successful
-     */
-    private Status validateStaticVlan() {
-        if (staticVlan != null && !staticVlan.trim().isEmpty()) {
-            short vl = 0;
-            try {
-                vl = Short.valueOf(staticVlan);
-            } catch (NumberFormatException e) {
-                return new Status(StatusCode.BADREQUEST, "Static Vlan Value must be between 1 and 4095");
-            }
-            if ((vl < 1) || (vl > 4095)) {
-                return new Status(StatusCode.BADREQUEST, "Static Vlan Value must be between 1 and 4095");
-            }
-        }
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    private Status validateContainerFlows() {
-        if (containerFlows != null && !containerFlows.isEmpty()) {
-            for (ContainerFlowConfig conf : containerFlows) {
-                Status status = conf.validate();
-                if (!status.isSuccess()) {
-                    return new Status(StatusCode.BADREQUEST, "Invalid Flow Spec: " + status.getDescription());
-                }
-            }
-        }
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    /**
-     * Returns Vlan value in short
-     *
-     * @return the Vlan tag
-     */
-    public short getStaticVlanValue() {
-        if ((staticVlan == null) || (staticVlan.trim().isEmpty())) {
-            return 0;
-        }
-        try {
-            return Short.valueOf(staticVlan);
-        } catch (NumberFormatException e) {
-            return 0;
-        }
-    }
-
-    public Status addNodeConnectors(List<String> ncList) {
-        // Syntax check
-        Status status = ContainerConfig.validateNodeConnectors(ncList);
-        if (!status.isSuccess()) {
-            return status;
-        }
-
-        // Add ports
-        ports.addAll(ncList);
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    public Status removeNodeConnectors(List<String> ncList) {
-        // Syntax check
-        Status status = ContainerConfig.validateNodeConnectors(ncList);
-        if (!status.isSuccess()) {
-            return status;
-        }
-        // Presence check
-        if (ports.isEmpty()) {
-            return new Status(StatusCode.BADREQUEST, "The following node connectors are not part of this container: "
-                    + ncList);
-        }
-        List<String> extra = new ArrayList<String>(ncList);
-        extra.removeAll(ports);
-        if (!extra.isEmpty()) {
-            return new Status(StatusCode.CONFLICT, "The following node connectors are not part of this container: " + extra);
-        }
-        // Remove ports
-        ports.removeAll(ncList);
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    public Status validateContainerFlowModify(List<ContainerFlowConfig> cFlowConfigs, boolean delete) {
-        // Sanity Check
-        if (cFlowConfigs == null || cFlowConfigs.isEmpty()) {
-            return new Status(StatusCode.BADREQUEST, "Invalid Flow Spec configuration(s): null or empty list");
-        }
-        // Validity check
-        for (ContainerFlowConfig cFlowConf : cFlowConfigs) {
-            Status status = cFlowConf.validate();
-            if (!status.isSuccess()) {
-                return new Status(StatusCode.BADREQUEST, String.format("Invalid Flow Spec configuration (%s): %s",
-                        cFlowConf.getName(), status.getDescription()));
-            }
-        }
-        // Name conflict check
-        List<String> existingNames = this.getContainerFlowConfigsNames();
-        List<String> proposedNames = this.getContainerFlowConfigsNames(cFlowConfigs);
-
-        // Check for duplicates in the request
-        if (proposedNames.size() < cFlowConfigs.size()) {
-            return new Status(StatusCode.BADREQUEST,
-                    "Invalid Flow Spec configuration(s): duplicate name configs present");
-        }
-
-        // Check for overflow
-        if (delete) {
-            // Raw size check
-            if (proposedNames.size() > existingNames.size()) {
-                return new Status(StatusCode.BADREQUEST,
-                        "Invalid request: requested to remove more flow spec configs than available ones");
-            }
-            // Presence check
-            for (ContainerFlowConfig config : cFlowConfigs) {
-                if (!this.containerFlows.contains(config)) {
-                    return new Status(StatusCode.BADREQUEST, String.format(
-                            "Invalid request: requested to remove nonexistent flow spec config: %s",
-                            config.getName()));
-                }
-            }
-        } else {
-            // Check for conflicting names with existing cFlows
-            List<String> conflicting = new ArrayList<String>(existingNames);
-            conflicting.retainAll(proposedNames);
-            if (!conflicting.isEmpty()) {
-                return new Status(StatusCode.CONFLICT,
-                        "Invalid Flow Spec configuration: flow spec name(s) conflict with existing flow specs: "
-                                + conflicting.toString());
-            }
-
-            /*
-             * Check for conflicting flow spec match (we only check for strict
-             * equality). Remove this in case (*) is reintroduced
-             */
-            if (this.containerFlows != null && !this.containerFlows.isEmpty()) {
-                Set<Match> existingMatches = new HashSet<Match>();
-                for (ContainerFlowConfig existing : this.containerFlows) {
-                    existingMatches.addAll(existing.getMatches());
-                }
-                for (ContainerFlowConfig proposed : cFlowConfigs) {
-                    if (existingMatches.removeAll(proposed.getMatches())) {
-                        return new Status(StatusCode.CONFLICT, String.format(
-                                "Invalid Flow Spec configuration: %s conflicts with existing flow spec",
-                                proposed.getName()));
-                    }
-                }
-            }
-        }
-
-
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    public ContainerFlowConfig getContainerFlowConfig(String name) {
-        if (this.containerFlows != null && !this.containerFlows.isEmpty()) {
-            for (ContainerFlowConfig conf : this.containerFlows) {
-                if (conf.getName().equals(name)) {
-                    return new ContainerFlowConfig(conf);
-                }
-            }
-        }
-        return null;
-    }
-
-    public List<String> getContainerFlowConfigsNames() {
-        return getContainerFlowConfigsNames(this.containerFlows);
-    }
-
-    /**
-     * Returns the list of unique names for the passed list of
-     * ContainerFlowConfig objects. the list will not contain duplicates even
-     * though the passed object list has ContainerFlowConfig objects with same
-     * names
-     *
-     * @param confList
-     *            the list of ContainerFlowConfig objects
-     * @return the list of correspondent unique container flow names. The return
-     *         list may differ from the passed list in size, if the latter
-     *         contains duplicates
-     */
-    private List<String> getContainerFlowConfigsNames(List<ContainerFlowConfig> confList) {
-        // Use set to check for duplicates later
-        Set<String> namesSet = new HashSet<String>();
-        if (confList != null) {
-            for (ContainerFlowConfig conf : confList) {
-                namesSet.add(conf.getName());
-            }
-        }
-        return new ArrayList<String>(namesSet);
-    }
-
-    /**
-     * Add the proposed list of container flow configurations to this container
-     * configuration. A validation check on the operation is first run.
-     *
-     * @param containerFlowConfigs
-     *            the proposed list of container flow configuration objects to
-     *            add to this container configuration object
-     * @return the result of this request as Status object
-     */
-    public Status addContainerFlows(List<ContainerFlowConfig> containerFlowConfigs) {
-        Status status = this.validateContainerFlowModify(containerFlowConfigs, false);
-        if (!status.isSuccess()) {
-            return status;
-        }
-        if (this.containerFlows.addAll(containerFlowConfigs) == false) {
-            return new Status(StatusCode.INTERNALERROR, "Unable to update the flow spec configuration(s)");
-        }
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    public Status removeContainerFlows(List<ContainerFlowConfig> containerFlowConfigs) {
-        Status status = this.validateContainerFlowModify(containerFlowConfigs, true);
-        if (!status.isSuccess()) {
-            return status;
-        }
-        if (this.containerFlows.removeAll(containerFlowConfigs) == false) {
-            return new Status(StatusCode.INTERNALERROR, "Unable to update the flow spec configuration(s)");
-        }
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    public Status removeContainerFlows(Set<String> names) {
-        // Sanity check
-        if (names == null || names.isEmpty()) {
-            return new Status(StatusCode.BADREQUEST, "Invalid flow spec names list");
-        }
-        // Validation check
-        List<String> present = this.getContainerFlowConfigsNames();
-        if (!present.containsAll(names)) {
-            List<String> notPresent = new ArrayList<String>(names);
-            notPresent.retainAll(present);
-            return new Status(StatusCode.BADREQUEST, "Following flow spec(s) are not present: " + notPresent);
-        }
-        // Remove
-        List<ContainerFlowConfig> toDelete = new ArrayList<ContainerFlowConfig>(names.size());
-        for (ContainerFlowConfig config : this.containerFlows) {
-            if (names.contains(config.getName())) {
-                toDelete.add(config);
-            }
-        }
-        if (this.containerFlows.removeAll(toDelete) == false) {
-            return new Status(StatusCode.INTERNALERROR, "Unable to remove the flow spec configuration(s)");
-        }
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    public List<ContainerFlowConfig> getContainerFlowConfigs(Set<String> names) {
-        List<ContainerFlowConfig> list = new ArrayList<ContainerFlowConfig>(names.size());
-        for (String name : names) {
-            ContainerFlowConfig conf = this.getContainerFlowConfig(name);
-            if (conf != null) {
-                list.add(new ContainerFlowConfig(conf));
-            }
-        }
-        return list;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + ((containerFlows == null) ? 0 : containerFlows.hashCode());
-        result = prime * result + ((ports == null) ? 0 : ports.hashCode());
-        result = prime * result + ((container == null) ? 0 : container.hashCode());
-        result = prime * result + ((staticVlan == null) ? 0 : staticVlan.hashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        ContainerConfig other = (ContainerConfig) obj;
-        if (containerFlows == null) {
-            if (other.containerFlows != null) {
-                return false;
-            }
-        } else if (!containerFlows.equals(other.containerFlows)) {
-            return false;
-        }
-        if (ports == null) {
-            if (other.ports != null) {
-                return false;
-            }
-        } else if (!ports.equals(other.ports)) {
-            return false;
-        }
-        if (container == null) {
-            if (other.container != null) {
-                return false;
-            }
-        } else if (!container.equals(other.container)) {
-            return false;
-        }
-        if (staticVlan == null) {
-            if (other.staticVlan != null) {
-                return false;
-            }
-        } else if (!staticVlan.equals(other.staticVlan)) {
-            return false;
-        }
-        return true;
-    }
-
-
-    /*
-     * (non-Javadoc)
-     *
-     * @see java.lang.Object#toString()
-     */
-    @Override
-    public String toString() {
-        String vlString = "";
-        if (staticVlan != null) {
-            vlString = staticVlan;
-        }
-        return "container=" + container + ((vlString.equals("") ? "" : " static Vlan=" + vlString)) + " ports=" + ports + " flowspecs=" + containerFlows;
-    }
-
-    /**
-     * Returns whether this Container configuration object has any ports specified
-     *
-     * @return true if any port is specified, false otherwise
-     */
-    public boolean hasNodeConnectors() {
-        return (ports != null && !ports.isEmpty());
-    }
-
-    /**
-     * Returns whether this Container configuration object has any flow specs specified
-     *
-     * @return true if any flow spec is specified, false otherwise
-     */
-    public boolean hasFlowSpecs() {
-        return (containerFlows != null && !containerFlows.isEmpty());
-    }
-
-    public List<ContainerFlow> getContainerFlowSpecs() {
-        List<ContainerFlow> list = new ArrayList<ContainerFlow>();
-        if (containerFlows != null && !containerFlows.isEmpty()) {
-            for (ContainerFlowConfig flowSpec : containerFlows) {
-                for (Match match : flowSpec.getMatches()) {
-                    list.add(new ContainerFlow(match));
-                }
-            }
-        }
-        return list;
-    }
-
-    private String getContainerRole(boolean admin) {
-        return String.format("%s-%s-%s", containerProfile, container, (admin ? ADMIN_SUFFIX : OPERATOR_SUFFIX));
-    }
-
-    /**
-     * Return the well known administrator role for this container
-     *
-     * @return The administrator role for this container
-     */
-    public String getContainerAdminRole() {
-        return getContainerRole(true);
-    }
-
-    /**
-     * Return the well known operator role for this container
-     *
-     * @return The operator role for this container
-     */
-    public String getContainerOperatorRole() {
-        return getContainerRole(false);
-    }
-
-    public String getContainerGroupName() {
-        return String.format("%s-%s", containerProfile, container);
-    }
-}
diff --git a/opendaylight/adsal/containermanager/api/src/main/java/org/opendaylight/controller/containermanager/ContainerData.java b/opendaylight/adsal/containermanager/api/src/main/java/org/opendaylight/controller/containermanager/ContainerData.java
deleted file mode 100644 (file)
index 0c8c531..0000000
+++ /dev/null
@@ -1,239 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.containermanager;
-
-import java.io.Serializable;
-import java.util.ArrayList;
-import java.util.HashSet;
-import java.util.List;
-import java.util.Locale;
-import java.util.Map;
-import java.util.Set;
-import java.util.concurrent.ConcurrentHashMap;
-import java.util.concurrent.ConcurrentMap;
-
-import org.opendaylight.controller.sal.core.ContainerFlow;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-
-
-/**
- * This Class contains all the configurations pertained to this container
- *
- */
-public class ContainerData implements Serializable {
-    private static final long serialVersionUID = 1L;
-    private String containerAdminRole;
-    private String containerOperatorRole;
-    private String name;
-    private ConcurrentMap<Node, Set<NodeConnector>> swPorts;
-    private short staticVlan;
-    private List<ContainerFlow> cFlowList;
-
-    /**
-     * Build a ContainerData from container configuration
-     *
-     * @param conf configuration from where the ContainerData need to be extracted
-     *
-     * @return the constructed containerData
-     */
-    public ContainerData(ContainerConfig conf) {
-        /*
-         * Back-end Non-Configuration Classes store names in lower case
-         */
-        name = conf.getContainerName().toLowerCase(Locale.ENGLISH);
-        swPorts = new ConcurrentHashMap<Node, Set<NodeConnector>>();
-        cFlowList = new ArrayList<ContainerFlow>();
-        staticVlan = conf.getStaticVlanValue();
-        containerAdminRole = conf.getContainerAdminRole();
-        containerOperatorRole = conf.getContainerOperatorRole();
-    }
-
-    /**
-     * getter for containerName
-     *
-     *
-     * @return the container name
-     */
-    public String getContainerName() {
-        return name;
-    }
-
-    /**
-     * getter for static vlan
-     *
-     *
-     * @return attribute static vlan
-     */
-    public short getStaticVlan() {
-        return staticVlan;
-    }
-
-    /**
-     * Check if the static vlan has non-zero value in that case is
-     * assumed to be assigned
-     *
-     *
-     * @return true if static vlan non-zero
-     */
-    public boolean hasStaticVlanAssigned() {
-        return (staticVlan != 0);
-    }
-
-    /**
-     * retrieve all NodeConnectors on a given switch on the containerName
-     * used in this object
-     *
-     * @param switchId the Node for switch we want to retrieve the list of ports
-     *
-     * @return get all the ports in form of a set of nodeconnectors
-     */
-    public Set<NodeConnector> getPorts(Node switchId) {
-        Set<NodeConnector> swpinfo = swPorts.get(switchId);
-        if (swpinfo != null) {
-            return swpinfo;
-        }
-        return null;
-    }
-
-    /**
-     * Returns the DB of all the association Node -> List of
-     * NodeConnectors composing this container
-     *
-     * @return the ConcurrentMap of all the association Node -> List
-     * of NodeConnectors
-     */
-    public ConcurrentMap<Node, Set<NodeConnector>> getSwPorts() {
-        return swPorts;
-    }
-
-    /**
-     * Add to the container a NodeConnector, that implicitely means also
-     * the Node being added
-     *
-     * @param port NodeConnector corresponding to the port being added
-     * in the container
-     */
-    public void addPortToSwitch(NodeConnector port) {
-        Node switchId = port.getNode();
-        if (switchId == null) {
-            return;
-        }
-        Set<NodeConnector> portSet = swPorts.get(switchId);
-        if (portSet == null) {
-            portSet = new HashSet<NodeConnector>();
-            swPorts.put(switchId, portSet);
-        }
-        portSet.add(port);
-    }
-
-    /**
-     * Remove from the container a NodeConnector, that implicitely means also
-     * the Node being removed
-     *
-     * @param port NodeConnector corresponding to the port being removed
-     * in the container
-     */
-    public void removePortFromSwitch(NodeConnector port) {
-        Node switchId = port.getNode();
-        if (switchId == null) {
-            return;
-        }
-        Set<NodeConnector> swpinfo = swPorts.get(switchId);
-        if (swpinfo != null) {
-            swpinfo.remove(port);
-            if (swpinfo.isEmpty()) {
-                // There are no more ports lets get ride of the switch
-                swPorts.remove(switchId);
-            }
-        }
-    }
-
-    /**
-     * Existence check of a Node in a container
-     *
-     * @param switchId See if a particular node is part of the container
-     *
-     * @return true if the node is in it else false
-     */
-    public boolean isSwitchInContainer(Node switchId) {
-        if (swPorts.containsKey(switchId)) {
-            return true;
-        } else {
-            return false;
-        }
-    }
-
-    /**
-     * Test for existance of NodeConnectors on a Node in a container
-     *
-     * @param switchId Node we are testing for port existance
-     *
-     * @return ture if the portset is non-empty
-     */
-    public boolean portListEmpty(Node switchId) {
-        Set<NodeConnector> swpinfo = swPorts.get(switchId);
-        if (swpinfo != null) {
-            if (!swpinfo.isEmpty()) {
-                return false;
-            }
-        }
-        return true;
-    }
-
-    public void deleteFlowSpec(ContainerFlow cFlow) {
-        cFlowList.remove(cFlow);
-    }
-
-    public void addFlowSpec(ContainerFlow cFlow) {
-        cFlowList.add(cFlow);
-    }
-
-    public boolean isFlowSpecEmpty() {
-        return (cFlowList.isEmpty());
-
-    }
-
-    public boolean containsFlowSpec(ContainerFlow cFlow) {
-        return cFlowList.contains(cFlow);
-    }
-
-    public int getFlowSpecCount() {
-        return cFlowList.size();
-    }
-
-    public List<ContainerFlow> getContainerFlowSpecs() {
-        return cFlowList;
-    }
-
-    public boolean matchName(String name) {
-        return this.name.equalsIgnoreCase(name);
-    }
-
-    /**
-     * Returns all the node connectors part of the container
-     * @return The node connectors belonging to this container. The returning set is never null.
-     */
-    public Set<NodeConnector> getNodeConnectors() {
-        Set<NodeConnector> set = new HashSet<NodeConnector>();
-        for (Map.Entry<Node, Set<NodeConnector>> entry : swPorts.entrySet()) {
-            set.addAll(entry.getValue());
-        }
-        return set;
-    }
-
-    public String getContainerAdminRole() {
-        return containerAdminRole;
-    }
-
-    public String getContainerOperatorRole() {
-        return containerOperatorRole;
-    }
-}
diff --git a/opendaylight/adsal/containermanager/api/src/main/java/org/opendaylight/controller/containermanager/ContainerFlowChangeEvent.java b/opendaylight/adsal/containermanager/api/src/main/java/org/opendaylight/controller/containermanager/ContainerFlowChangeEvent.java
deleted file mode 100644 (file)
index 7405a72..0000000
+++ /dev/null
@@ -1,39 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.containermanager;
-
-import java.io.Serializable;
-import java.util.List;
-
-import org.opendaylight.controller.sal.core.UpdateType;
-
-public class ContainerFlowChangeEvent implements Serializable {
-    private static final long serialVersionUID = 1L;
-    private List<ContainerFlowConfig> configs;
-    private UpdateType updateType;
-
-    public ContainerFlowChangeEvent(List<ContainerFlowConfig> configs, UpdateType updateType) {
-        this.configs = configs;
-        this.updateType = updateType;
-    }
-
-    public List<ContainerFlowConfig> getConfigList() {
-        return configs;
-    }
-
-    public UpdateType getUpdateType() {
-        return updateType;
-    }
-
-    @Override
-    public String toString() {
-        return "ContainerFlowChangeEvent [configs: " + configs + " updateType: " + updateType + "]";
-    }
-}
diff --git a/opendaylight/adsal/containermanager/api/src/main/java/org/opendaylight/controller/containermanager/ContainerFlowConfig.java b/opendaylight/adsal/containermanager/api/src/main/java/org/opendaylight/controller/containermanager/ContainerFlowConfig.java
deleted file mode 100644 (file)
index 6abd1ac..0000000
+++ /dev/null
@@ -1,819 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.containermanager;
-
-import java.io.Serializable;
-import java.net.Inet4Address;
-import java.net.Inet6Address;
-import java.net.InetAddress;
-import java.net.UnknownHostException;
-import java.util.ArrayList;
-import java.util.HashSet;
-import java.util.List;
-import java.util.Set;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.configuration.ConfigurationObject;
-import org.opendaylight.controller.sal.match.Match;
-import org.opendaylight.controller.sal.match.MatchType;
-import org.opendaylight.controller.sal.packet.BitBufferHelper;
-import org.opendaylight.controller.sal.utils.IPProtocols;
-import org.opendaylight.controller.sal.utils.NetUtils;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.sal.utils.StatusCode;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * Flow Specification Java Object for Container Manager
- * Represents a container flow configuration information for Container Manager.
- *
- * Objects of this class are serialized to and de-serialized from binary files through
- * java serialization API when saving to/reading from Container manager startup
- * configuration file.
- */
-@XmlRootElement (name = "flow-spec-config")
-@XmlAccessorType(XmlAccessType.NONE)
-public class ContainerFlowConfig extends ConfigurationObject implements Serializable {
-    private static Logger log = LoggerFactory.getLogger(ContainerFlowConfig.class);
-
-    /** The Constant serialVersionUID. */
-    private static final long serialVersionUID = 1L;
-
-    /** Flow Spec name. */
-    @XmlElement
-    private String name;
-
-    /** The vlan. */
-    @XmlElement
-    private String dlVlan;
-
-    /** The network Source. */
-    @XmlElement
-    private String nwSrc;
-
-    /** The network Destination */
-    @XmlElement
-    private String nwDst;
-
-    /** The protocol. */
-    @XmlElement
-    private String protocol;
-
-    /** The transport source */
-    @XmlElement
-    private String tpSrc;
-
-    /** The transport destination */
-    @XmlElement
-    private String tpDst;
-
-    /* unidirectional flag
-    do not include this flag in equality check
-    @XmlElement */
-    private static boolean unidirectional = false;
-
-
-    /**
-     * Instantiates a new container flow config.
-     */
-    public ContainerFlowConfig() {
-    }
-
-    /**
-     * Instantiates a new container flow config.
-     *
-     * @param name Flow Spec configuration name
-     * @param container Container Name
-     * @param srcIP Source IP Address
-     * @param dstIP Destination IP Address
-     * @param proto Protocol
-     * @param srcPort Source Layer4 Port
-     * @param dstPort Destination Layer4 Port
-     */
-    public ContainerFlowConfig(String name, String srcIP, String dstIP, String proto, String srcPort,
-            String dstPort) {
-        this.name = name;
-        this.dlVlan = null;
-        this.nwSrc = srcIP;
-        this.nwDst = dstIP;
-        this.protocol = proto;
-        this.tpSrc = srcPort;
-        this.tpDst = dstPort;
-        //this.unidirectional = false;
-    }
-
-    public ContainerFlowConfig(String name, String dlVlan, String srcIP, String dstIP, String proto, String srcPort,
-            String dstPort) {
-        this.name = name;
-        this.dlVlan = dlVlan;
-        this.nwSrc = srcIP;
-        this.nwDst = dstIP;
-        this.protocol = proto;
-        this.tpSrc = srcPort;
-        this.tpDst = dstPort;
-    }
-
-
-    public ContainerFlowConfig(ContainerFlowConfig containerFlowConfig) {
-        this.name = containerFlowConfig.name;
-        this.dlVlan = containerFlowConfig.dlVlan;
-        this.nwSrc = containerFlowConfig.nwSrc;
-        this.nwDst = containerFlowConfig.nwDst;
-        this.protocol = containerFlowConfig.protocol;
-        this.tpSrc = containerFlowConfig.tpSrc;
-        this.tpDst = containerFlowConfig.tpDst;
-        //this.unidirectional = containerFlowConfig.unidirectional;
-    }
-
-    /**
-     * Returns the name of this Flow Specification
-     *
-     * @return the name of the Flow Specification
-     */
-    public String getName() {
-        // mandatory field
-        return name;
-    }
-
-    /**
-     * Returns the vlan id.
-     *
-     * @return the Vlan Id
-     */
-    public String getVlan() {
-        return (dlVlan == null || dlVlan.isEmpty()) ? null : dlVlan;
-    }
-
-    /**
-     * Returns the Source IP Address.
-     *
-     * @return the Source IP Address
-     */
-    public String getSrcIP() {
-        return (nwSrc == null || nwSrc.isEmpty()) ? null : nwSrc;
-    }
-
-    /**
-     * Returns the Destination IP Address.
-     *
-     * @return the Destination IP Address
-     */
-    public String getDstIP() {
-        return (nwDst == null || nwDst.isEmpty()) ? null : nwDst;
-    }
-
-    /**
-     * Returns the protocol.
-     *
-     * @return the protocol
-     */
-    public String getProtocol() {
-        return protocol;
-    }
-
-    /**
-     * Returns Source Layer4 Port.
-     *
-     * @return Source Layer4 Port
-     */
-    public String getSrcPort() {
-        return (tpSrc == null || tpSrc.isEmpty()) ? null : tpSrc;
-    }
-
-    /**
-     * Returns Destination Layer4 Port.
-     *
-     * @return Destination Layer4 Port
-     */
-    public String getDstPort() {
-        return (tpDst == null || tpDst.isEmpty()) ? null : tpDst;
-    }
-
-    /*
-     * @return the unidirectional flag
-     */
-    public boolean isUnidirectional() {
-        return unidirectional;
-    }
-
-    /* (non-Javadoc)
-     * @see java.lang.Object#hashCode()
-     */
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result
-                + ((protocol == null) ? 0 : protocol.hashCode());
-        result = prime * result + ((name == null) ? 0 : name.hashCode());
-        result = prime * result + ((dlVlan == null) ? 0 : dlVlan.hashCode());
-        result = prime * result + ((nwDst == null) ? 0 : nwDst.hashCode());
-        result = prime * result + ((tpDst == null) ? 0 : tpDst.hashCode());
-        result = prime * result + ((nwSrc == null) ? 0 : nwSrc.hashCode());
-        result = prime * result + ((tpSrc == null) ? 0 : tpSrc.hashCode());
-        return result;
-    }
-
-    /*
-     * For comparison, consider that container flow can have empty fields
-     */
-    /* (non-Javadoc)
-     * @see java.lang.Object#equals(java.lang.Object)
-     */
-    @Override
-    public boolean equals(Object obj) {
-        /*
-         * Configuration will be stored in collection only if it is valid
-         * Hence we don't check here for uninitialized fields
-         */
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        ContainerFlowConfig other = (ContainerFlowConfig) obj;
-        if (matchName(other) && matchDlVlan(other) && matchSrcIP(other)
-                && matchDstIP(other) && matchProtocol(other)
-                && matchSrcPort(other) && matchDstPort(other)) {
-            return true;
-        }
-        return false;
-    }
-
-    /**
-     * Equals by Flow Spec name.
-     *
-     * @param name flow spec name for comparison
-     * @return true, if successful
-     */
-    public boolean equalsByName(String name) {
-        return this.name.equals(name);
-    }
-
-    /**
-     * equalsByMatch
-     *
-     * @param that ContainerFlowConfig for comparison
-     * @return true, if any match is equal
-     */
-    public boolean equalsByMatch(ContainerFlowConfig that) {
-        // get both matches
-        // the match is equal if any of the match is equal
-        List<Match> thisMatch = this.getMatches();
-        List<Match> otherMatch = that.getMatches();
-        // both the lists cannot be null
-        for(Match m1 : thisMatch) {
-            for(Match m2 : otherMatch) {
-                  if(m1.equals(m2)) {
-                    return true;
-                }
-            }
-        }
-        // if you have reached here without a match
-        // being found
-        // return false
-        return false;
-    }
-
-    /**
-     * Matches the name of this flow spec with that of ContainerFlowConfig parameter's flow spec.
-     *
-     * @param o the ContainerFlowConfig parameter
-     * @return true, if successful
-     */
-    private boolean matchName(ContainerFlowConfig flowSpec) {
-        if (name == flowSpec.name) {
-            return true;
-        }
-        if (name == null || flowSpec.name == null) {
-            return false;
-        }
-        return name.equals(flowSpec.name);
-    }
-
-    /**
-     * Match the set of these vlans with that of flowSpec's vlans.
-     *
-     * @param flowSpec
-     *            Flow Specification
-     * @return true, if successful
-     */
-    private boolean matchDlVlan(ContainerFlowConfig flowSpec) {
-        if (dlVlan == flowSpec.dlVlan) {
-            return true;
-        }
-        if (dlVlan == null || flowSpec.dlVlan == null) {
-            return false;
-        }
-
-        return this.getVlanList().equals(flowSpec.getVlanList());
-    }
-
-    /**
-     * Match Source IP Address.
-     *
-     * @param flowSpec Flow Specification
-     * @return true, if successful
-     */
-    private boolean matchSrcIP(ContainerFlowConfig flowSpec) {
-        if (nwSrc == flowSpec.nwSrc) {
-            return true;
-        }
-        if (nwSrc == null || flowSpec.nwSrc == null) {
-            return false;
-        }
-        return nwSrc.equals(flowSpec.nwSrc);
-    }
-
-    /**
-     * Match Destination IP Address.
-     *
-     * @param flowSpec Flow Specification
-     * @return true, if successful
-     */
-    private boolean matchDstIP(ContainerFlowConfig flowSpec) {
-        if (nwDst == flowSpec.nwDst) {
-            return true;
-        }
-        if (nwDst == null || flowSpec.nwDst == null) {
-            return false;
-        }
-        return this.nwDst.equals(flowSpec.nwDst);
-    }
-
-    /**
-     * Match protocol.
-     *
-     * @param flowSpec Flow Specification
-     * @return true, if successful
-     */
-    private boolean matchProtocol(ContainerFlowConfig flowSpec) {
-        if (protocol == flowSpec.protocol) {
-            return true;
-        }
-        if (protocol == null || flowSpec.protocol == null) {
-            return false;
-        }
-        return this.protocol.equals(flowSpec.protocol);
-    }
-
-    /**
-     * Match Source Layer4 Port.
-     *
-     * @param flowSpec Flow Specification
-     * @return true, if successful
-     */
-    private boolean matchSrcPort(ContainerFlowConfig flowSpec) {
-        if (tpSrc == flowSpec.tpSrc) {
-            return true;
-        }
-        if (tpSrc == null || flowSpec.tpSrc == null) {
-            return false;
-        }
-        return tpSrc.equals(flowSpec.tpSrc);
-    }
-
-    /**
-     * Match Destination Layer4 Port.
-     *
-     * @param flowSpec Flow Specification
-     * @return true, if successful
-     */
-    private boolean matchDstPort(ContainerFlowConfig flowSpec) {
-        if (tpDst == flowSpec.tpDst) {
-            return true;
-        }
-        if (tpDst == null || flowSpec.tpDst == null) {
-            return false;
-        }
-        return this.tpDst.equals(flowSpec.tpDst);
-    }
-
-    /**
-     * Returns the vlan id number for all vlans specified
-     *
-     * @return the vlan id number for all vlans specified
-     */
-    public Set<Short> getVlanList() {
-        /*
-         * example: Vlan = "1,3,5-12"
-         * elemArray = ["1" "3" "5-12"]
-         * elem[2] = "5-12" --> limits = ["5" "12"]
-         * vlanList = [1 3 5 6 7 8 9 10 11 12]
-         */
-        Set<Short> vlanList = new HashSet<Short>();
-        try {
-            String[] elemArray = dlVlan.split(",");
-            for (String elem : elemArray) {
-                if (elem.contains("-")) {
-                    String[] limits = elem.split("-");
-                    for (short j = Short.valueOf(limits[0]); j <= Short.valueOf(limits[1]); j++) {
-                        vlanList.add(Short.valueOf(j));
-                    }
-                } else {
-                    vlanList.add(Short.valueOf(elem));
-                }
-            }
-        } catch (NumberFormatException e) {
-
-        }
-        return vlanList;
-    }
-
-    /**
-     * Returns the Source IP Address mask length.
-     *
-     * @return the Source IP Address mask length
-     */
-    public Short getSrcIPMaskLen() {
-        Short maskLen = 0;
-
-        if (nwSrc != null && !nwSrc.isEmpty()) {
-            String[] s = nwSrc.split("/");
-            if (s.length == 2) {
-                try {
-                    maskLen = Short.valueOf(s[1]);
-                } catch (Exception e) {
-                    // no mask or bad mask
-                }
-            } else {
-                InetAddress ip = this.getSrcIPNum();
-                maskLen = (short) ((ip instanceof Inet4Address) ? 32 : 128);
-            }
-        }
-        return maskLen;
-    }
-
-    /**
-     * Returns the Destination IP Address mask length.
-     *
-     * @return the Destination IP Address mask length
-     */
-    public Short getDstIPMaskLen() {
-        Short maskLen = 0;
-        if (nwDst != null && !nwDst.isEmpty()) {
-            String[] s = nwDst.split("/");
-            if (s.length == 2) {
-                try {
-                    maskLen = Short.valueOf(s[1]);
-                } catch (Exception e) {
-                    // no mask or bad mask
-                }
-            } else {
-                InetAddress ip = this.getDstIPNum();
-                maskLen = (short) ((ip instanceof Inet4Address) ? 32 : 128);
-            }
-        }
-        return maskLen;
-    }
-
-    /**
-     * Returns the Source IP Address.
-     *
-     * @return the Source IP Address
-     */
-    public InetAddress getSrcIPNum() {
-        InetAddress ip = null;
-        if (nwSrc == null || nwSrc.isEmpty()) {
-            try {
-                ip = InetAddress.getByAddress(new byte[16]);
-                return ip;
-            } catch (UnknownHostException e) {
-                log.error("", e);
-                return null;
-            }
-        }
-        try {
-            ip = InetAddress.getByName(nwSrc.split("/")[0]);
-        } catch (UnknownHostException e1) {
-            log.error("", e1);
-            return null;
-        }
-        return ip;
-    }
-
-    /**
-     * Returns the Destination IP Address.
-     *
-     * @return the Destination IP Address
-     */
-    public InetAddress getDstIPNum() {
-        InetAddress ip = null;
-        if (nwDst == null || nwDst.isEmpty()) {
-            try {
-                ip = InetAddress.getByAddress(new byte[16]);
-                return ip;
-            } catch (UnknownHostException e) {
-                log.error("",e);
-                return null;
-            }
-        }
-        try {
-            ip = InetAddress.getByName(nwDst.split("/")[0]);
-        } catch (UnknownHostException e1) {
-            log.error("", e1);
-            return null;
-        }
-        return ip;
-    }
-
-    /**
-     * Returns Source Layer4 Port number.
-     *
-     * @return Source Layer4 Port number
-     */
-    public Short getSrcPortNum() {
-        return (tpSrc == null || tpSrc.isEmpty()) ? Short.valueOf((short) 0)
-                : Short.valueOf(tpSrc);
-    }
-
-    /**
-     * Returns Destination Layer4 Port number.
-     *
-     * @return Destination Layer4 Port number
-     */
-    public Short getDstPortNum() {
-        return (tpDst == null || tpDst.isEmpty()) ? Short.valueOf((short) 0)
-                : Short.valueOf(tpDst);
-    }
-
-    /**
-     * Get the IP protocol value
-     *
-     * @return the protocol
-     */
-    public Short getProtoNum() {
-        return protocol == null ? null : IPProtocols.getProtocolNumberShort(protocol);
-    }
-
-    /**
-     * Returns whether this container flow overlap with the passed one This is
-     * true when any two of the resulting matches for the two container flow
-     * configurations intersect.
-     *
-     * @param other
-     *            the other container flow config with which checking the
-     *            overlap
-     * @return true if the two configurations overlap, false otherwise
-     */
-    public boolean overlap(ContainerFlowConfig other) {
-        if (other == null) {
-            return false;
-        }
-        List<Match> myMathes = this.getMatches();
-        List<Match> hisMatches = other.getMatches();
-        for (Match mine : myMathes) {
-            for (Match his : hisMatches) {
-                if (mine.intersetcs(his)) {
-                    return true;
-                }
-            }
-        }
-        return false;
-    }
-
-    /**
-     * Checks if this flow specification configuration is valid.
-     *
-     * @return true, if is valid
-     */
-    public Status validate() {
-        if (!isValidResourceName(name)) {
-            return new Status(StatusCode.BADREQUEST, "Invalid name");
-        }
-        Status status = validateVlan();
-        if (!status.isSuccess()) {
-            return status;
-        }
-        status = validateIPs();
-        if (!status.isSuccess()) {
-            return status;
-        }
-        if(!hasValidProtocol()) {
-            return new Status(StatusCode.BADREQUEST, "Invalid IP protocol");
-        }
-        if (!hasValidPorts()) {
-            return new Status(StatusCode.BADREQUEST, "Invalid Source or Destination Port");
-        }
-        if (this.getMatches().get(0).getMatches() == 0) {
-            return new Status(StatusCode.BADREQUEST, "Flow Spec is empty");
-        }
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    /**
-     * Validates the vlan number
-     *
-     * @return the result of the check as Status object
-     */
-    private Status validateVlan() {
-        if (dlVlan != null) {
-            short vlanId = 0;
-            try {
-                String[] elemArray = dlVlan.split(",");
-                for (String elem : elemArray) {
-                    if (elem.contains("-")) {
-                        String[] limits = elem.split("-");
-                        if (Short.parseShort(limits[0]) < 0
-                                || Short.parseShort(limits[0]) >= Short.parseShort(limits[1])
-                                || Short.parseShort(limits[1]) > 0xfff) {
-                            return new Status(StatusCode.BADREQUEST, "Invalid vlan id");
-                        }
-                    } else {
-                        vlanId = Short.parseShort(elem);
-                        if (vlanId < 0 || vlanId > 0xfff) {
-                            return new Status(StatusCode.BADREQUEST, "Invalid vlan id");
-                        }
-                    }
-                }
-            } catch (NumberFormatException e) {
-                return new Status(StatusCode.BADREQUEST, "Invalid vlan id");
-            }
-        }
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    /**
-     * Validates the network addresses, checks syntax and semantic
-     *
-     * @return the result of the check as Status object, if successful
-     */
-    private Status validateIPs() {
-        if (nwSrc != null) {
-            if (!NetUtils.isIPAddressValid(nwSrc)) {
-                return new Status(StatusCode.BADREQUEST, "Invalid network source address");
-            }
-            byte[] bytePrefix = NetUtils.getSubnetPrefix(this.getSrcIPNum(), this.getSrcIPMaskLen()).getAddress();
-            long prefix = BitBufferHelper.getLong(bytePrefix);
-            if (prefix == 0) {
-                return new Status(StatusCode.BADREQUEST, "Invalid network source address: subnet zero");
-            }
-        }
-        if (nwDst != null) {
-            if (!NetUtils.isIPAddressValid(nwDst)) {
-                return new Status(StatusCode.BADREQUEST, "Invalid network destination address");
-            }
-            byte[] bytePrefix = NetUtils.getSubnetPrefix(this.getDstIPNum(), this.getDstIPMaskLen()).getAddress();
-            long prefix = BitBufferHelper.getLong(bytePrefix);
-            if (prefix == 0) {
-                return new Status(StatusCode.BADREQUEST, "Invalid network destination address: subnet zero");
-            }
-        }
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    /**
-     * Validate the protocol field. Either it can be a enum defined in IPProtocols.java
-     * or a valid IP proto value between 0 and 255, see:
-     * http://www.iana.org/assignments/protocol-numbers/protocol-numbers.xhtml
-     * for more details.
-     *
-     * @return true if a valid protocol value
-     */
-    private boolean hasValidProtocol() {
-        IPProtocols p = IPProtocols.fromString(protocol);
-        return p != null;
-    }
-
-    /**
-     *
-     * @param tpPort
-     *               String representing the transport protocol port number
-     * @return true if tpPort contains a decimal value between 0 and 65535
-     */
-    private boolean hasValidPort(String tpPort) {
-        try {
-            int port = Integer.decode(tpPort);
-            return ((port >= 0) && (port <= 0xffff));
-        } catch (NumberFormatException e) {
-            return false;
-        }
-    }
-
-    /**
-     * Validate the transport protocol source and destination ports as
-     * entered by users.
-     *
-     * @return true if ports are defined and are in valid range
-     */
-    private boolean hasValidPorts() {
-        if (tpSrc !=null && !tpSrc.isEmpty()) {
-            if (!hasValidPort(tpSrc)) {
-                return false;
-            }
-        }
-
-        if (tpDst !=null && !tpDst.isEmpty()) {
-            return hasValidPort(tpDst);
-        }
-        return true;
-    }
-
-    /**
-     * Returns the matches.
-     * If unidirectional flag is set, there will be only one match per vlan in the list
-     * If unidirectional flag is unset there will be two matches per vlan in the list,
-     * only if the specified flow has an intrinsic direction.
-     * For Ex. if the cFlow only has the protocol field configured, no matter
-     * if unidirectional flag is set or not, only one match per vlan will be returned
-     * The client just has to iterate over the returned list
-     * @return the matches
-     */
-    public List<Match> getMatches() {
-        List<Match> matches = new ArrayList<Match>();
-
-        if (this.dlVlan != null && !this.dlVlan.isEmpty()) {
-            for(Short vlan:getVlanList()){
-                Match match = getMatch(vlan);
-                matches.add(match);
-            }
-        }
-        else{
-            Match match = getMatch(null);
-            matches.add(match);
-        }
-
-        if (!ContainerFlowConfig.unidirectional) {
-            List<Match> forwardMatches = new ArrayList<Match>(matches);
-            for (Match match : forwardMatches) {
-                Match reverse = match.reverse();
-                if (!match.equals(reverse)) {
-                    matches.add(reverse);
-                }
-            }
-        }
-
-        return matches;
-    }
-
-    private Match getMatch(Short vlan){
-        Match match = new Match();
-
-        if (vlan != null) {
-            match.setField(MatchType.DL_VLAN, vlan);
-        }
-        if (this.nwSrc != null && !this.nwSrc.trim().isEmpty()) {
-            String parts[] = this.nwSrc.split("/");
-            InetAddress ip = NetUtils.parseInetAddress(parts[0]);
-            InetAddress mask = null;
-            int maskLen = 0;
-            if (parts.length > 1) {
-                maskLen = Integer.parseInt(parts[1]);
-            } else {
-                maskLen = (ip instanceof Inet6Address) ? 128 : 32;
-            }
-            mask = NetUtils.getInetNetworkMask(maskLen, ip instanceof Inet6Address);
-            match.setField(MatchType.NW_SRC, ip, mask);
-        }
-        if (this.nwDst != null && !this.nwDst.trim().isEmpty()) {
-            String parts[] = this.nwDst.split("/");
-            InetAddress ip = NetUtils.parseInetAddress(parts[0]);
-            InetAddress mask = null;
-            int maskLen = 0;
-            if (parts.length > 1) {
-                maskLen = Integer.parseInt(parts[1]);
-            } else {
-                maskLen = (ip instanceof Inet6Address) ? 128 : 32;
-            }
-            mask = NetUtils.getInetNetworkMask(maskLen, ip instanceof Inet6Address);
-            match.setField(MatchType.NW_DST, ip, mask);
-        }
-        if (IPProtocols.fromString(this.protocol) != IPProtocols.ANY) {
-            match.setField(MatchType.NW_PROTO, IPProtocols.getProtocolNumberByte(this.protocol));
-        }
-        if (this.tpSrc != null && !this.tpSrc.trim().isEmpty()) {
-            match.setField(MatchType.TP_SRC, Integer.valueOf(tpSrc).shortValue());
-        }
-        if (this.tpDst != null && !this.tpDst.trim().isEmpty()) {
-            match.setField(MatchType.TP_DST, Integer.valueOf(tpDst).shortValue());
-        }
-        return match;
-    }
-
-    /*
-     * (non-Javadoc)
-     *
-     * @see java.lang.Object#toString()
-     */
-    @Override
-    public String toString() {
-        return "Container Flow={name:" + name + " dlVlan:" + dlVlan + " nwSrc:" + nwSrc + " nwDst:" + nwDst + " " + "protocol:" + protocol
-                + " tpSrc:" + tpSrc + " tpDst:" + tpDst + "}";
-    }
-}
diff --git a/opendaylight/adsal/containermanager/api/src/main/java/org/opendaylight/controller/containermanager/IContainerAuthorization.java b/opendaylight/adsal/containermanager/api/src/main/java/org/opendaylight/controller/containermanager/IContainerAuthorization.java
deleted file mode 100644 (file)
index 6d3d9f8..0000000
+++ /dev/null
@@ -1,19 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.containermanager;
-
-import org.opendaylight.controller.sal.authorization.IResourceAuthorization;
-
-/**
- * Container groups and container users authorizations
- */
-public interface IContainerAuthorization extends IResourceAuthorization {
-
-}
diff --git a/opendaylight/adsal/containermanager/api/src/main/java/org/opendaylight/controller/containermanager/IContainerManager.java b/opendaylight/adsal/containermanager/api/src/main/java/org/opendaylight/controller/containermanager/IContainerManager.java
deleted file mode 100644 (file)
index b2e2a76..0000000
+++ /dev/null
@@ -1,197 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.containermanager;
-
-import java.util.List;
-import java.util.Map;
-import java.util.Set;
-import org.opendaylight.controller.sal.utils.Status;
-
-/**
- * Container Manager provides an ability for the Network Administrators to
- * partitions a production network into smaller, isolated and manageable
- * networks. IContainerManager interface exposes these Container management capabilities
- * via the supported APIs
- */
-public interface IContainerManager {
-
-    /**
-     * Create a Container
-     *
-     * @param configObject
-     *            ContainerConfig object that carries name of the Container to be
-     *            created
-     * @return returns the status code of adding a container
-     */
-    public Status addContainer(ContainerConfig configObject);
-
-    /**
-     * Remove a container
-     *
-     * @param configObject
-     *            ContainerConfig object that carries the name of the Container to be
-     *            removed
-     * @return returns the status code of removing a container
-     */
-    public Status removeContainer(ContainerConfig configObject);
-
-    /**
-     * Remove a container
-     *
-     * @param containerName
-     *            the container name
-     * @return returns the status code of removing a container
-     */
-    public Status removeContainer(String containerName);
-
-    /**
-     * Adds resources to a given container. Updates the container data based on new
-     * resources added
-     *
-     * @param configObject
-     *            refer to {@link com.ContainerConfig.csdn.containermanager.ContainerConfig
-     *            ContainerConfig}
-     * @return returns the status code of adding a container entry
-     */
-    public Status addContainerEntry(String containerName, List<String> portList);
-
-    /**
-     * Remove a resource from a given container. Updates the container data based on new
-     * resources removed.
-     *
-     * @param configObject
-     *            refer to {@link com.ContainerConfig.csdn.containermanager.ContainerConfig
-     *            ContainerConfig}
-     * @return returns the status code of removing a container entry
-     */
-    public Status removeContainerEntry(String containerName, List<String> portList);
-
-    /**
-     * Adds/Removes a container flow
-     *
-     * @param configObject
-     *            refer to {@link com.ContainerConfig.csdn.containermanager.ContainerConfig
-     *            ContainerConfig}
-     * @return returns the status code of adding a container flow
-     */
-    public Status addContainerFlows(String containerName, List<ContainerFlowConfig> configObject);
-
-    /**
-     * Remove a container flow
-     *
-     * @param configObject
-     *            refer to {@link com.ContainerConfig.csdn.containermanager.ContainerConfig
-     *            ContainerConfig}
-     * @return returns the status of removing a container flow
-     */
-    public Status removeContainerFlows(String containerName, List<ContainerFlowConfig> configObject);
-
-    /**
-     * Remove a container flow
-     *
-     * @param containerName
-     *            the name of the container
-     * @param name
-     *            the name of the container flow
-     * @return the status of the request
-     */
-    public Status removeContainerFlows(String containerName, Set<String> name);
-
-    /**
-     * Get the list of {@link com.ContainerConfig.csdn.containermanager.ContainerConfig
-     * ContainerConfig} objects representing all the containers that have been
-     * configured previously.
-     *
-     * @return the lsit of {@link com.ContainerConfig.csdn.containermanager.ContainerConfig
-     *         ContainerConfig} objects configured so far
-     */
-    public List<ContainerConfig> getContainerConfigList();
-
-    /**
-     * Get the configuration object for the specified container
-     *
-     * @param containerName
-     *            the name of the container
-     * @return a copy of the {@link com.ContainerConfig.csdn.containermanager.ContainerConfig
-     *         ContainerConfig} object for the specified container if present, null
-     *         otherwise
-     */
-    public ContainerConfig getContainerConfig(String containerName);
-
-    /**
-     * Returns a list of container names that currently exist.
-     *
-     * @return array of String container names
-     */
-    public List<String> getContainerNameList();
-
-    /**
-     * Check for the existence of a container
-     *
-     * @param ContainerId
-     *            Name of the Container
-     *
-     * @return true if it exists, false otherwise
-     */
-    public boolean doesContainerExist(String ContainerId);
-
-    /**
-     * Get an array of ContainerFlowConfig objects representing all the
-     * container flows that have been configured previously.
-     *
-     * @return array of {@link org.opendaylight.controller.containermanager.ContainerFlowConfig
-     *         ContainerFlowConfig}
-     */
-    public Map<String, List<ContainerFlowConfig>> getContainerFlows();
-
-    /**
-     * Get an array of {@link org.opendaylight.controller.containermanager.ContainerFlowConfig
-     * ContainerFlowConfig} objects representing all the container flows that
-     * have been configured previously on the given containerName
-     *
-     * @param containerName
-     *            the container name
-     * @return array of {@link org.opendaylight.controller.containermanager.ContainerFlowConfig
-     *         ContainerFlowConfig}
-     */
-    public List<ContainerFlowConfig> getContainerFlows(String containerName);
-
-    /**
-     * Get an the list of names of the container flows that have been configured
-     * previously on the given containerName
-     *
-     * @param containerName
-     *            the container name
-     * @return the array containing the names of the container flows configured
-     *         on the specified container
-     */
-    public List<String> getContainerFlowNameList(String containerName);
-
-    /**
-     * Returns true if there are any non-default Containers present.
-     *
-     * @return  true if any non-default container is present false otherwise.
-     */
-    public boolean hasNonDefaultContainer();
-
-    /**
-     * Returns a list of the existing containers.
-     *
-     * @return  List of Container name strings.
-     */
-    public List<String> getContainerNames();
-
-    /**
-     * Returns whether the controller is running in container mode
-     *
-     * @return true if controller is in container mode, false otherwise
-     */
-    public boolean inContainerMode();
-}
diff --git a/opendaylight/adsal/containermanager/api/src/main/java/org/opendaylight/controller/containermanager/IContainerManagerShell.java b/opendaylight/adsal/containermanager/api/src/main/java/org/opendaylight/controller/containermanager/IContainerManagerShell.java
deleted file mode 100644 (file)
index 2024b18..0000000
+++ /dev/null
@@ -1,25 +0,0 @@
-package org.opendaylight.controller.containermanager;
-
-import java.util.List;
-
-public interface IContainerManagerShell {
-    public List<String> psc();
-    public List<String> pfc();
-    public List<String> psd();
-    public List<String> psp();
-    public List<String> psm();
-    public List<String> addContainer(String arg1, String arg2);
-    public List<String> createContainer(String arg1, String arg2);
-    public List<String> removeContainerShell(String arg1);
-    public List<String> addContainerEntry(String arg1, String arg2, String arg3);
-    public List<String> removeContainerEntry(String arg1, String arg2, String arg3);
-    public List<String> addContainerFlow(String arg1, String arg2, String arg3);
-    public List<String> removeContainerFlow(String arg1, String arg2);
-    public List<String> containermgrGetRoles();
-    public List<String> containermgrGetAuthorizedGroups(String arg1);
-    public List<String> containermgrGetAuthorizedResources(String arg1);
-    public List<String> containermgrGetResourcesForGroup(String arg1);
-    public List<String> containermgrGetUserLevel(String arg1);
-    public List<String> containermgrGetUserResources(String arg1);
-    public List<String> saveConfig();
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/containermanager/api/src/main/java/org/opendaylight/controller/containermanager/NodeConnectorsChangeEvent.java b/opendaylight/adsal/containermanager/api/src/main/java/org/opendaylight/controller/containermanager/NodeConnectorsChangeEvent.java
deleted file mode 100644 (file)
index 5f992c7..0000000
+++ /dev/null
@@ -1,43 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.containermanager;
-
-import java.io.Serializable;
-import java.util.List;
-
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.UpdateType;
-
-/**
- * Class that represent the event of a configuration change for a container
- */
-public class NodeConnectorsChangeEvent implements Serializable {
-    private static final long serialVersionUID = 1L;
-    private List<NodeConnector> ncList;
-    private UpdateType updateType;
-
-    public NodeConnectorsChangeEvent(List<NodeConnector> ncList, UpdateType updateType) {
-        this.ncList = ncList;
-        this.updateType = updateType;
-    }
-
-    public List<NodeConnector> getNodeConnectors() {
-        return ncList;
-    }
-
-    public UpdateType getUpdateType() {
-        return updateType;
-    }
-
-    @Override
-    public String toString() {
-        return "ContainerConnectorsChangeEvent [ncList: " + ncList + " updateType: " + updateType + "]";
-    }
-}
diff --git a/opendaylight/adsal/containermanager/implementation/pom.xml b/opendaylight/adsal/containermanager/implementation/pom.xml
deleted file mode 100644 (file)
index 2889779..0000000
+++ /dev/null
@@ -1,80 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>containermanager.implementation</artifactId>
-  <version>0.7.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>appauth</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>clustering.services</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>configuration</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>containermanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>topologymanager</artifactId>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Import-Package>org.opendaylight.controller.containermanager,
-              org.opendaylight.controller.appauth.authorization,
-              org.opendaylight.controller.configuration,
-              org.opendaylight.controller.clustering.services,
-              org.opendaylight.controller.sal.authorization,
-              org.opendaylight.controller.sal.packet,
-              org.opendaylight.controller.sal.utils,
-              org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.sal.action,
-              org.opendaylight.controller.sal.flowprogrammer,
-              org.opendaylight.controller.sal.match,
-              org.opendaylight.controller.sal.reader,
-              org.opendaylight.controller.topologymanager,
-              org.eclipse.osgi.framework.console,
-              org.osgi.framework,
-              org.slf4j,
-              org.apache.felix.dm</Import-Package>
-            <Export-Package></Export-Package>
-            <Bundle-Activator>org.opendaylight.controller.containermanager.internal.Activator</Bundle-Activator>
-          </instructions>
-          <manifestLocation>${project.basedir}/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/containermanager/implementation/src/main/java/org/opendaylight/controller/containermanager/internal/Activator.java b/opendaylight/adsal/containermanager/implementation/src/main/java/org/opendaylight/controller/containermanager/internal/Activator.java
deleted file mode 100644 (file)
index 61c8ab6..0000000
+++ /dev/null
@@ -1,163 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.containermanager.internal;
-
-import org.eclipse.osgi.framework.console.CommandProvider;
-
-import java.util.Dictionary;
-import java.util.HashSet;
-import java.util.Set;
-import java.util.Hashtable;
-
-import org.opendaylight.controller.containermanager.IContainerManager;
-import org.opendaylight.controller.containermanager.IContainerManagerShell;
-import org.apache.felix.dm.Component;
-import org.opendaylight.controller.clustering.services.ICacheUpdateAware;
-import org.opendaylight.controller.clustering.services.IClusterGlobalServices;
-import org.opendaylight.controller.configuration.IConfigurationAware;
-import org.opendaylight.controller.configuration.IConfigurationService;
-import org.opendaylight.controller.containermanager.IContainerAuthorization;
-import org.opendaylight.controller.sal.core.ComponentActivatorAbstractBase;
-import org.opendaylight.controller.sal.core.IContainer;
-import org.opendaylight.controller.sal.core.IContainerAware;
-import org.opendaylight.controller.sal.core.IContainerListener;
-import org.opendaylight.controller.sal.core.IContainerLocalListener;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-
-public class Activator extends ComponentActivatorAbstractBase {
-    protected static final Logger logger = LoggerFactory.getLogger(Activator.class);
-
-
-    /**
-     * Function that is used to communicate to dependency manager the list of
-     * known implementations for containerd-services
-     *
-     *
-     * @return An array containing all the CLASS objects that will be
-     *         instantiated in order to get an fully working implementation
-     *         Object
-     */
-    @Override
-    public Object[] getImplementations() {
-        Object[] res = { ContainerImpl.class };
-        return res;
-    }
-
-    /**
-     * Function that is called when configuration of the dependencies is
-     * required.
-     *
-     * @param c
-     *            dependency manager Component object, used for configuring the
-     *            dependencies exported and imported
-     * @param imp
-     *            Implementation class that is being configured, needed as long
-     *            as the same routine can configure multiple implementations
-     * @param containerName
-     *            The containername being configured, this allow also optional
-     *            per-container different behavior if needed, usually should not be
-     *            the case though.
-     */
-    @Override
-    public void configureInstance(Component c, Object imp, String containerName) {
-        if (imp.equals(ContainerImpl.class)) {
-            // export the service
-            c.setInterface(new String[] { IContainer.class.getName() }, null);
-
-            // private interface exported by ContainerManager to retrieve
-            // internal data, this is mandatory to implement the
-            // IContainer functionality
-            c.add(createServiceDependency().setService(IContainerInternal.class)
-                    .setCallbacks("setIContainerInternal", "unsetIContainerInternal")
-                    .setRequired(true));
-        }
-    }
-
-    /**
-     * Method which tells how many NON-containerd implementations are supported by
-     * the bundle. This way we can tune the number of components created. This
-     * components will be created ONLY at the time of bundle startup and will be
-     * destroyed only at time of bundle destruction, this is the major
-     * difference with the implementation retrieved via getImplementations where
-     * all of them are assumed to be containerd!
-     *
-     *
-     * @return The list of implementations the bundle will support, in
-     *         non-containerd version
-     */
-    @Override
-    protected Object[] getGlobalImplementations() {
-        Object[] res = { ContainerManager.class };
-        return res;
-    }
-
-    /**
-     * Configure the dependency for a given instance non-containerd
-     *
-     * @param c
-     *            Component assigned for this instance, this will be what will
-     *            be used for configuration
-     * @param imp
-     *            implementation to be configured
-     * @param containerName
-     *            container on which the configuration happens
-     */
-    @Override
-    protected void configureGlobalInstance(Component c, Object imp) {
-        if (imp.equals(ContainerManager.class)) {
-            Dictionary<String, Set<String>> props = new Hashtable<String, Set<String>>();
-            Set<String> propSet = new HashSet<String>();
-            propSet.add("containermgr.event.containerChange");
-            props.put("cachenames", propSet);
-
-            // export the service
-            c.setInterface(
-                    new String[] { IContainerManager.class.getName(),
-                            IContainerManager.class.getName(),
-                            IConfigurationAware.class.getName(),
-                            CommandProvider.class.getName(),
-                            IContainerInternal.class.getName(),
-                            IContainerAuthorization.class.getName(),
-                            ICacheUpdateAware.class.getName(),
-                            IContainerManagerShell.class.getName()}, props);
-
-            c.add(createServiceDependency()
-                    .setService(IClusterGlobalServices.class)
-                    .setCallbacks("setClusterServices", "unsetClusterServices")
-                    .setRequired(true));
-
-            c.add(createServiceDependency().setService(
-                    IConfigurationService.class).setCallbacks(
-                    "setConfigurationService",
-                    "unsetConfigurationService").setRequired(true));
-
-            // Key kick-starter for container creation in each component
-            c.add(createServiceDependency().setService(IContainerAware.class)
-                    .setCallbacks("setIContainerAware", "unsetIContainerAware")
-                    .setRequired(false));
-
-            // Optional interface expected to be exported by the
-            // protocol plugins to setup proper filtering based on
-            // slicing events
-            c.add(createServiceDependency()
-                    .setService(IContainerListener.class)
-                    .setCallbacks("setIContainerListener", "unsetIContainerListener")
-                    .setRequired(false));
-
-            // Interface expected to be exported by the Functional Modules
-            c.add(createServiceDependency()
-                    .setService(IContainerLocalListener.class)
-                    .setCallbacks("setIContainerLocalListener", "unsetIContainerLocalListener")
-                    .setRequired(false));
-        }
-    }
-}
diff --git a/opendaylight/adsal/containermanager/implementation/src/main/java/org/opendaylight/controller/containermanager/internal/ContainerImpl.java b/opendaylight/adsal/containermanager/implementation/src/main/java/org/opendaylight/controller/containermanager/internal/ContainerImpl.java
deleted file mode 100644 (file)
index cb2a289..0000000
+++ /dev/null
@@ -1,125 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * @file   ContainerImpl.java
- *
- * @brief  Class that instantiated per-container implements the
- * interface IContainer
- *
- */
-package org.opendaylight.controller.containermanager.internal;
-
-import java.util.ArrayList;
-import java.util.Dictionary;
-import java.util.HashSet;
-import java.util.List;
-import java.util.Map;
-import java.util.Set;
-import java.util.concurrent.ConcurrentMap;
-
-import org.apache.felix.dm.Component;
-import org.opendaylight.controller.containermanager.ContainerData;
-import org.opendaylight.controller.sal.core.ContainerFlow;
-import org.opendaylight.controller.sal.core.IContainer;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-
-public class ContainerImpl implements IContainer {
-    private String containerName = null;
-    private IContainerInternal iContainerInternal = null;
-
-    public void setIContainerInternal(IContainerInternal s) {
-        this.iContainerInternal = s;
-    }
-
-    public void unsetIContainerInternal(IContainerInternal s) {
-        if (this.iContainerInternal == s) {
-            this.iContainerInternal = null;
-        }
-    }
-
-    /**
-     * Function called by the dependency manager when all the required
-     * dependencies are satisfied
-     *
-     */
-    void init(Component c) {
-        Dictionary<?, ?> props = c.getServiceProperties();
-        if (props != null) {
-            this.containerName = (String) props.get("containerName");
-        }
-    }
-
-    @Override
-    public String getName() {
-        return this.containerName;
-    }
-
-    @Override
-    public List<ContainerFlow> getContainerFlows() {
-        List<ContainerFlow> list = new ArrayList<ContainerFlow>();
-
-        ContainerData d = this.iContainerInternal.getContainerData(this.containerName);
-        if (d != null) {
-            list.addAll(d.getContainerFlowSpecs());
-        }
-        return list;
-    }
-
-    @Override
-    public short getTag(Node n) {
-        ContainerData d = this.iContainerInternal.getContainerData(this.containerName);
-        if (d != null) {
-            return d.getStaticVlan();
-        }
-        // Return 0 because in containerData that means an unassigned tag
-        return (short) 0;
-    }
-
-    @Override
-    public Set<NodeConnector> getNodeConnectors() {
-        Set<NodeConnector> set = new HashSet<NodeConnector>();
-
-        ContainerData d = this.iContainerInternal.getContainerData(this.containerName);
-        if (d != null) {
-            ConcurrentMap<Node, Set<NodeConnector>> m = d.getSwPorts();
-            if (m != null) {
-                for (Map.Entry<Node, Set<NodeConnector>> entry : m.entrySet()) {
-                    set.addAll(entry.getValue());
-                }
-            }
-        }
-        return set;
-    }
-
-    @Override
-    public Set<Node> getNodes() {
-        Set<Node> set = new HashSet<Node>();
-
-        ContainerData d = this.iContainerInternal.getContainerData(this.containerName);
-        if (d != null) {
-            ConcurrentMap<Node, Set<NodeConnector>> m = d.getSwPorts();
-            if (m != null) {
-                set.addAll(m.keySet());
-            }
-        }
-        return set;
-    }
-
-    @Override
-    public String getContainerAdminRole() {
-        return iContainerInternal.getContainerData(containerName).getContainerAdminRole();
-    }
-
-    @Override
-    public String getContainerOperatorRole() {
-        return iContainerInternal.getContainerData(containerName).getContainerOperatorRole();
-    }
-}
diff --git a/opendaylight/adsal/containermanager/implementation/src/main/java/org/opendaylight/controller/containermanager/internal/ContainerManager.java b/opendaylight/adsal/containermanager/implementation/src/main/java/org/opendaylight/controller/containermanager/internal/ContainerManager.java
deleted file mode 100644 (file)
index 98378e8..0000000
+++ /dev/null
@@ -1,1905 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.containermanager.internal;
-
-import java.io.FileNotFoundException;
-import java.io.IOException;
-import java.io.ObjectInputStream;
-import java.util.ArrayList;
-import java.util.Collections;
-import java.util.EnumSet;
-import java.util.HashMap;
-import java.util.HashSet;
-import java.util.Iterator;
-import java.util.List;
-import java.util.Locale;
-import java.util.Map;
-import java.util.Map.Entry;
-import java.util.Set;
-import java.util.concurrent.ConcurrentMap;
-import java.util.concurrent.CopyOnWriteArrayList;
-
-import org.eclipse.osgi.framework.console.CommandInterpreter;
-import org.eclipse.osgi.framework.console.CommandProvider;
-import org.opendaylight.controller.appauth.authorization.Authorization;
-import org.opendaylight.controller.clustering.services.CacheConfigException;
-import org.opendaylight.controller.clustering.services.CacheExistException;
-import org.opendaylight.controller.clustering.services.ICacheUpdateAware;
-import org.opendaylight.controller.clustering.services.IClusterGlobalServices;
-import org.opendaylight.controller.clustering.services.IClusterServices;
-import org.opendaylight.controller.configuration.ConfigurationObject;
-import org.opendaylight.controller.configuration.IConfigurationAware;
-import org.opendaylight.controller.configuration.IConfigurationService;
-import org.opendaylight.controller.containermanager.ContainerChangeEvent;
-import org.opendaylight.controller.containermanager.ContainerConfig;
-import org.opendaylight.controller.containermanager.ContainerData;
-import org.opendaylight.controller.containermanager.ContainerFlowChangeEvent;
-import org.opendaylight.controller.containermanager.ContainerFlowConfig;
-import org.opendaylight.controller.containermanager.IContainerAuthorization;
-import org.opendaylight.controller.containermanager.IContainerManager;
-import org.opendaylight.controller.containermanager.IContainerManagerShell;
-import org.opendaylight.controller.containermanager.NodeConnectorsChangeEvent;
-import org.opendaylight.controller.sal.authorization.AppRoleLevel;
-import org.opendaylight.controller.sal.authorization.Privilege;
-import org.opendaylight.controller.sal.authorization.Resource;
-import org.opendaylight.controller.sal.authorization.ResourceGroup;
-import org.opendaylight.controller.sal.authorization.UserLevel;
-import org.opendaylight.controller.sal.core.ContainerFlow;
-import org.opendaylight.controller.sal.core.IContainerAware;
-import org.opendaylight.controller.sal.core.IContainerListener;
-import org.opendaylight.controller.sal.core.IContainerLocalListener;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.UpdateType;
-import org.opendaylight.controller.sal.match.Match;
-import org.opendaylight.controller.sal.utils.GlobalConstants;
-import org.opendaylight.controller.sal.utils.IObjectReader;
-import org.opendaylight.controller.sal.utils.NodeConnectorCreator;
-import org.opendaylight.controller.sal.utils.NodeCreator;
-import org.opendaylight.controller.sal.utils.ServiceHelper;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.sal.utils.StatusCode;
-import org.opendaylight.controller.topologymanager.ITopologyManager;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-public class ContainerManager extends Authorization<String> implements IContainerManager, IObjectReader,
-        CommandProvider, ICacheUpdateAware<String, Object>, IContainerInternal, IContainerAuthorization,
-        IConfigurationAware, IContainerManagerShell {
-    private static final Logger logger = LoggerFactory.getLogger(ContainerManager.class);
-    private static String CONTAINERS_FILE_NAME = "containers.conf";
-    private static final String allContainersGroup = "allContainers";
-    private IClusterGlobalServices clusterServices;
-    private IConfigurationService configurationService;
-    /*
-     * Collection containing the configuration objects. This is configuration
-     * world: container names (also the map key) are maintained as they were
-     * configured by user, same case
-     */
-    private ConcurrentMap<String, ContainerConfig> containerConfigs;
-    private ConcurrentMap<String, ContainerData> containerData;
-    private ConcurrentMap<NodeConnector, CopyOnWriteArrayList<String>> nodeConnectorToContainers;
-    private ConcurrentMap<Node, Set<String>> nodeToContainers;
-    private ConcurrentMap<String, Object> containerChangeEvents;
-    private final Set<IContainerAware> iContainerAware = Collections.synchronizedSet(new HashSet<IContainerAware>());
-    private final Set<IContainerListener> iContainerListener = Collections
-            .synchronizedSet(new HashSet<IContainerListener>());
-    private final Set<IContainerLocalListener> iContainerLocalListener = Collections
-            .synchronizedSet(new HashSet<IContainerLocalListener>());
-
-    void setIContainerListener(IContainerListener s) {
-        if (this.iContainerListener != null) {
-            this.iContainerListener.add(s);
-            /*
-             * At boot with startup, containers are created before listeners have
-             * joined. Replaying here the first container creation notification for
-             * the joining listener when containers are already present. Also
-             * replaying all the node connectors and container flows additions
-             * to the existing containers.
-             */
-            if (!this.containerData.isEmpty()) {
-                s.containerModeUpdated(UpdateType.ADDED);
-            }
-            for (ConcurrentMap.Entry<NodeConnector, CopyOnWriteArrayList<String>> entry : nodeConnectorToContainers
-                    .entrySet()) {
-                NodeConnector port = entry.getKey();
-                for (String container : entry.getValue()) {
-                    s.nodeConnectorUpdated(container, port, UpdateType.ADDED);
-                }
-            }
-            for (Map.Entry<String, ContainerData> container : containerData.entrySet()) {
-                for (ContainerFlow cFlow : container.getValue().getContainerFlowSpecs()) {
-                    s.containerFlowUpdated(container.getKey(), cFlow, cFlow, UpdateType.ADDED);
-                }
-            }
-        }
-    }
-
-    void unsetIContainerListener(IContainerListener s) {
-        if (this.iContainerListener != null) {
-            this.iContainerListener.remove(s);
-        }
-    }
-
-    void setIContainerLocalListener(IContainerLocalListener s) {
-        if (this.iContainerLocalListener != null) {
-            this.iContainerLocalListener.add(s);
-        }
-    }
-
-    void unsetIContainerLocalListener(IContainerLocalListener s) {
-        if (this.iContainerLocalListener != null) {
-            this.iContainerLocalListener.remove(s);
-        }
-    }
-
-    public void setIContainerAware(IContainerAware iContainerAware) {
-        if (!this.iContainerAware.contains(iContainerAware)) {
-            this.iContainerAware.add(iContainerAware);
-            // Now call the container creation for all the known containers so far
-            for (String container : getContainerNameList()) {
-                iContainerAware.containerCreate(container.toLowerCase(Locale.ENGLISH));
-            }
-        }
-    }
-
-    public void unsetIContainerAware(IContainerAware iContainerAware) {
-        this.iContainerAware.remove(iContainerAware);
-        // There is no need to do cleanup of the component when
-        // unregister because it will be taken care by the Container
-        // component itself
-    }
-
-    public void setClusterServices(IClusterGlobalServices i) {
-        this.clusterServices = i;
-        logger.debug("IClusterServices set");
-    }
-
-    public void unsetClusterServices(IClusterGlobalServices i) {
-        if (this.clusterServices == i) {
-            this.clusterServices = null;
-            logger.debug("IClusterServices Unset");
-        }
-    }
-
-    public void setConfigurationService(IConfigurationService service) {
-        logger.trace("Got configuration service set request {}", service);
-        this.configurationService = service;
-    }
-
-    public void unsetConfigurationService(IConfigurationService service) {
-        logger.trace("Got configuration service UNset request");
-        this.configurationService = null;
-    }
-
-    private void allocateCaches() {
-        logger.debug("Container Manager allocating caches");
-
-        if (clusterServices == null) {
-            logger.warn("un-initialized Cluster Services, can't allocate caches");
-            return;
-        }
-        try {
-            clusterServices.createCache("containermgr.containerConfigs", EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-
-            clusterServices.createCache("containermgr.event.containerChange",
-                    EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-
-            clusterServices.createCache("containermgr.containerData", EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-
-            clusterServices.createCache("containermgr.nodeConnectorToContainers",
-                    EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-
-            clusterServices.createCache("containermgr.nodeToContainers", EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-
-            clusterServices.createCache("containermgr.containerGroups", EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-
-            clusterServices.createCache("containermgr.containerAuthorizations",
-                    EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-
-            clusterServices.createCache("containermgr.roles", EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-        } catch (CacheConfigException cce) {
-            logger.error("Cache configuration invalid - check cache mode");
-        } catch (CacheExistException ce) {
-            logger.error("Cache already exits - destroy and recreate if needed");
-        }
-    }
-
-    @SuppressWarnings({ "unchecked" })
-    private void retrieveCaches() {
-        logger.debug("Container Manager retrieving caches");
-
-        if (clusterServices == null) {
-            logger.warn("un-initialized Cluster Services, can't retrieve caches");
-            return;
-        }
-
-        containerConfigs = (ConcurrentMap<String, ContainerConfig>) clusterServices.getCache("containermgr.containerConfigs");
-
-        containerChangeEvents = (ConcurrentMap<String, Object>) clusterServices.getCache("containermgr.event.containerChange");
-
-        containerData = (ConcurrentMap<String, ContainerData>) clusterServices.getCache("containermgr.containerData");
-
-        nodeConnectorToContainers = (ConcurrentMap<NodeConnector, CopyOnWriteArrayList<String>>) clusterServices
-                .getCache("containermgr.nodeConnectorToContainers");
-
-        nodeToContainers = (ConcurrentMap<Node, Set<String>>) clusterServices.getCache("containermgr.nodeToContainers");
-
-        resourceGroups = (ConcurrentMap<String, Set<String>>) clusterServices.getCache("containermgr.containerGroups");
-
-        groupsAuthorizations = (ConcurrentMap<String, Set<ResourceGroup>>) clusterServices
-                .getCache("containermgr.containerAuthorizations");
-
-        roles = (ConcurrentMap<String, AppRoleLevel>) clusterServices.getCache("containermgr.roles");
-
-        if (inContainerMode()) {
-            for (Map.Entry<String, ContainerConfig> entry : containerConfigs.entrySet()) {
-                // Notify global and local listeners about the mode change
-                notifyContainerChangeInternal(entry.getValue(), UpdateType.ADDED, true);
-            }
-        }
-    }
-
-    @Override
-    public void entryCreated(String containerName, String cacheName, boolean originLocal) {
-
-    }
-
-    @Override
-    public void entryUpdated(String key, Object value, String cacheName, boolean originLocal) {
-        /*
-         * This is were container manager replays a configuration event that was
-         * notified by its peer from a cluster node where the configuration
-         * happened. Only the global listeners, the cluster unaware classes,
-         * (mainly the shim classes in the sdn protocol plugins) need to receive
-         * these notifications on this cluster node. The cluster aware classes,
-         * like the functional modules which reacts on these events, must _not_
-         * be notified to avoid parallel computation in the cluster.
-         */
-        if (!originLocal) {
-            if (value instanceof NodeConnectorsChangeEvent) {
-                NodeConnectorsChangeEvent event = (NodeConnectorsChangeEvent) value;
-                List<NodeConnector> ncList = event.getNodeConnectors();
-                notifyContainerEntryChangeInternal(key, ncList, event.getUpdateType(), false);
-            } else if (value instanceof ContainerFlowChangeEvent) {
-                ContainerFlowChangeEvent event = (ContainerFlowChangeEvent) value;
-                notifyCFlowChangeInternal(key, event.getConfigList(), event.getUpdateType(), false);
-            } else if (value instanceof ContainerChangeEvent) {
-                ContainerChangeEvent event = (ContainerChangeEvent) value;
-                notifyContainerChangeInternal(event.getConfig(), event.getUpdateType(), false);
-            }
-        }
-    }
-
-    @Override
-    public void entryDeleted(String containerName, String cacheName, boolean originLocal) {
-    }
-
-    public ContainerManager() {
-    }
-
-    public void init() {
-
-    }
-
-    public void start() {
-        // Get caches from cluster manager
-        allocateCaches();
-        retrieveCaches();
-
-        // Allocates default groups and association to default roles
-        createDefaultAuthorizationGroups();
-
-        // Read startup configuration and create local database
-        loadContainerConfig();
-    }
-
-    public void destroy() {
-        // Clear local states
-        this.iContainerAware.clear();
-        this.iContainerListener.clear();
-        this.iContainerLocalListener.clear();
-    }
-
-    /**
-     * Adds/Remove the list of flow specs to/from the specified container. This
-     * function is supposed to be called after all the validation checks have
-     * already been run on the proposed configuration.
-     */
-    private Status updateContainerFlow(String containerName, List<ContainerFlowConfig> confList, boolean delete) {
-        ContainerData container = getContainerByName(containerName);
-        if (container == null) {
-            return new Status(StatusCode.GONE, "Container not present");
-        }
-
-        for (ContainerFlowConfig conf : confList) {
-            // Validation was fine. Modify the database now.
-            for (Match match : conf.getMatches()) {
-                ContainerFlow cFlow = new ContainerFlow(match);
-                if (delete) {
-                    logger.trace("Removing Flow Spec {} from Container {}", conf.getName(), containerName);
-                    container.deleteFlowSpec(cFlow);
-                } else {
-                    logger.trace("Adding Flow Spec {} to Container {}", conf.getName(), containerName);
-                    container.addFlowSpec(cFlow);
-
-                }
-                // Update Database
-                putContainerDataByName(containerName, container);
-            }
-        }
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    /**
-     * Adds/Remove this container to/from the Container database, no updates are going
-     * to be generated here other that the destroying and creation of the container.
-     * This function is supposed to be called after all the validation checks
-     * have already been run on the configuration object
-     */
-    private Status updateContainerDatabase(ContainerConfig containerConf, boolean delete) {
-        /*
-         * Back-end world here, container names are all stored in lower case
-         */
-        String containerName = containerConf.getContainerName();
-        ContainerData container = getContainerByName(containerName);
-        if (delete && container == null) {
-            return new Status(StatusCode.NOTFOUND, "Container is not present");
-        }
-        if (!delete && container != null) {
-            // A container with the same (lower case) name already exists
-            return new Status(StatusCode.CONFLICT, "A container with the same name already exists");
-        }
-        if (delete) {
-            logger.debug("Removing container {}", containerName);
-            removeNodeToContainersMapping(container);
-            removeNodeConnectorToContainersMapping(container);
-            removeContainerDataByName(containerName);
-        } else {
-            logger.debug("Adding container {}", containerName);
-            container = new ContainerData(containerConf);
-            putContainerDataByName(containerName, container);
-
-            // If flow specs are specified, add them
-            if (containerConf.hasFlowSpecs()) {
-                updateContainerFlow(containerName, containerConf.getContainerFlowConfigs(), delete);
-            }
-
-            // If ports are specified, add them
-            if (!containerConf.getPortList().isEmpty()) {
-                updateContainerEntryDatabase(containerName, containerConf.getPortList(), delete);
-            }
-        }
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    private void removeNodeConnectorToContainersMapping(ContainerData container) {
-        Iterator<Entry<NodeConnector, CopyOnWriteArrayList<String>>> it = nodeConnectorToContainers.entrySet().iterator();
-        String containerName = container.getContainerName();
-        for (; it.hasNext();) {
-            Entry<NodeConnector, CopyOnWriteArrayList<String>> entry = it.next();
-            final NodeConnector nc = entry.getKey();
-            final CopyOnWriteArrayList<String> slist = entry.getValue();
-            for (final String sdata : slist) {
-                if (sdata.equalsIgnoreCase(containerName)) {
-                    logger.debug("Removing NodeConnector->Containers mapping, nodeConnector: {}", nc);
-                    slist.remove(containerName);
-                    if (slist.isEmpty()) {
-                        nodeConnectorToContainers.remove(nc);
-                    } else {
-                        nodeConnectorToContainers.put(nc, slist);
-                    }
-                    break;
-                }
-            }
-        }
-    }
-
-    private void removeNodeToContainersMapping(ContainerData container) {
-        for (Entry<Node, Set<String>> entry : nodeToContainers.entrySet()) {
-            Node node = entry.getKey();
-            for (String sdata : entry.getValue()) {
-                if (sdata.equals(container.getContainerName())) {
-                    logger.debug("Removing Node->Containers mapping, node {} container {}", node, sdata);
-                    Set<String> value = nodeToContainers.get(node);
-                    value.remove(sdata);
-                    nodeToContainers.put(node, value);
-                    break;
-                }
-            }
-        }
-    }
-
-    /**
-     * Adds/Remove container data to/from the container. This function is supposed to be
-     * called after all the validation checks have already been run on the
-     * configuration object
-     */
-    private Status updateContainerEntryDatabase(String containerName, List<NodeConnector> nodeConnectors, boolean delete) {
-        ContainerData container = getContainerByName(containerName);
-        // Presence check
-        if (container == null) {
-            return new Status(StatusCode.NOTFOUND, "Container Not Found");
-        }
-
-        // Check changes in the portlist
-        for (NodeConnector port : nodeConnectors) {
-            Node node = port.getNode();
-            if (delete) {
-                container.removePortFromSwitch(port);
-                putContainerDataByName(containerName, container);
-
-                /* remove <sp> - container mapping */
-                if (nodeConnectorToContainers.containsKey(port)) {
-                    nodeConnectorToContainers.remove(port);
-                }
-                /*
-                 * If no more ports in the switch, remove switch from container
-                 * Generate switchRemoved Event
-                 */
-                if (container.portListEmpty(node)) {
-                    logger.debug("Port List empty for switch {}", node);
-                    putContainerDataByName(containerName, container);
-                    // remove node->containers mapping
-                    Set<String> slist = nodeToContainers.get(node);
-                    if (slist != null) {
-                        logger.debug("Removing container from switch-container list. node{}, container{}", node, containerName);
-                        slist.remove(container.getContainerName());
-                        nodeToContainers.put(node, slist);
-                        if (slist.isEmpty()) {
-                            logger.debug("Container list empty for switch {}. removing switch-container mapping", node);
-                            nodeToContainers.remove(node);
-                        }
-                    }
-                }
-            } else {
-                if (container.isSwitchInContainer(node) == false) {
-                    Set<String> value = nodeToContainers.get(node);
-                    // Add node->containers mapping
-                    if (value == null) {
-                        value = new HashSet<String>();
-                        logger.debug("Creating new Container Set for switch {}", node);
-                    }
-                    value.add(container.getContainerName());
-                    nodeToContainers.put(node, value);
-                }
-                container.addPortToSwitch(port);
-                putContainerDataByName(containerName, container);
-
-                // added nc->containers mapping
-                CopyOnWriteArrayList<String> slist = nodeConnectorToContainers.get(port);
-                if (slist == null) {
-                    slist = new CopyOnWriteArrayList<String>();
-                }
-                slist.add(container.getContainerName());
-                nodeConnectorToContainers.put(port, slist);
-            }
-        }
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    private Status validateContainerFlowAddRemoval(String containerName, ContainerFlow cFlow, boolean delete) {
-        /*
-         * It used to be the comment below: ~~~~~~~~~~~~~~~~~~~~ If Link Sharing
-         * at Host facing interfaces, then disallow last ContainerFlow removal
-         * ~~~~~~~~~~~~~~~~~~~~ But the interface being host facing is a
-         * condition that can change at runtime and so the final effect will be
-         * unreliable. So now we will always allow the container flow removal,
-         * if this is a link host facing and is shared by many that will cause
-         * issues but that validation should be done not at the configuration
-         * but in the UI/northbound side.
-         */
-        ContainerData container = this.getContainerByName(containerName);
-        if (container == null) {
-            String error = String.format("Cannot validate flow specs for container %s: (Container does not exist)", containerName);
-            logger.warn(error);
-            return new Status(StatusCode.BADREQUEST, error);
-        }
-
-        if (delete) {
-            Set<NodeConnector> thisContainerPorts = container.getNodeConnectors();
-            // Go through all the installed containers
-            for (Map.Entry<String, ContainerData> entry : containerData.entrySet()) {
-                if (containerName.equalsIgnoreCase(entry.getKey())) {
-                    continue;
-                }
-                // Derive the common ports
-                Set<NodeConnector> commonPorts = entry.getValue().getNodeConnectors();
-                commonPorts.retainAll(thisContainerPorts);
-                if (commonPorts.isEmpty()) {
-                    continue;
-                }
-
-                // Check if this operation would remove the only flow spec
-                // assigned to this container
-                if (container.getFlowSpecCount() == 1) {
-                    if (!container.hasStaticVlanAssigned()) {
-                        // Ports are shared and static vlan is not present: this
-                        // is a failure
-                        // regardless the shared ports are host facing or
-                        // interswitch ports
-                        return new Status(StatusCode.BADREQUEST, "Container shares port with another container: "
-                                + "The only one flow spec assigned to this container cannot be removed,"
-                                + "because this container is not assigned any static vlan");
-                    }
-
-                    // Check on host facing port
-                    ITopologyManager topologyManager = (ITopologyManager) ServiceHelper.getInstance(
-                            ITopologyManager.class, GlobalConstants.DEFAULT.toString(), this);
-                    if (topologyManager == null) {
-                        return new Status(StatusCode.NOSERVICE,
-                                "Cannot validate the request: Required service is not available");
-                    }
-                    for (NodeConnector nc : commonPorts) {
-                        /*
-                         * Shared link case : For internal port check if it has
-                         * a vlan configured. If vlan is configured, allow the
-                         * flowspec to be deleted If the port is host-facing, do
-                         * not allow the flowspec to be deleted
-                         */
-                        if (!topologyManager.isInternal(nc)) {
-                            return new Status(StatusCode.BADREQUEST, String.format(
-                                    "Port %s is shared and is host facing port: "
-                                            + "The only one flow spec assigned to this container cannot be removed", nc));
-                        }
-                    }
-                }
-            }
-        } else {
-            // Adding a new flow spec: need to check if other containers with common
-            // ports do not have same flow spec
-            Set<NodeConnector> thisContainerPorts = container.getNodeConnectors();
-            List<ContainerFlow> proposed = new ArrayList<ContainerFlow>(container.getContainerFlowSpecs());
-            proposed.add(cFlow);
-            for (Map.Entry<String, ContainerData> entry : containerData.entrySet()) {
-                if (containerName.equalsIgnoreCase(entry.getKey())) {
-                    continue;
-                }
-                ContainerData otherContainer = entry.getValue();
-                Set<NodeConnector> commonPorts = otherContainer.getNodeConnectors();
-                commonPorts.retainAll(thisContainerPorts);
-
-                if (!commonPorts.isEmpty()) {
-                    Status status = checkCommonContainerFlow(otherContainer.getContainerFlowSpecs(), proposed);
-                    if (!status.isSuccess()) {
-                        return new Status(StatusCode.BADREQUEST, String.format(
-                                "Container %s which shares ports with this container has overlapping flow spec: %s",
-                                entry.getKey(), status.getDescription()));
-                    }
-                }
-            }
-        }
-
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    /**
-     * Checks if the passed list of node connectors can be safely applied to the
-     * specified existing container in terms of port sharing with other containers.
-     *
-     * @param containerName
-     *            the name of the existing container
-     * @param portList
-     *            the list of node connectors to be added to the container
-     * @return the status object representing the result of the check
-     */
-    private Status validatePortSharing(String containerName, List<NodeConnector> portList) {
-        ContainerData container = this.getContainerByName(containerName);
-        if (container == null) {
-            String error = String
-                    .format("Cannot validate port sharing for container %s: (container does not exist)", containerName);
-            logger.error(error);
-            return new Status(StatusCode.BADREQUEST, error);
-        }
-        return validatePortSharingInternal(portList, container.getContainerFlowSpecs());
-    }
-
-    /**
-     * Checks if the proposed container configuration is valid to be applied in
-     * terms of port sharing with other containers.
-     *
-     * @param containerConf
-     *            the container configuration object containing the list of node
-     *            connectors
-     * @return the status object representing the result of the check
-     */
-    private Status validatePortSharing(ContainerConfig containerConf) {
-        return validatePortSharingInternal(containerConf.getPortList(), containerConf.getContainerFlowSpecs());
-    }
-
-    /*
-     * If any port is shared with an existing container, need flowSpec to be
-     * configured. If no flowSpec for this or other container, or if containers have any
-     * overlapping flowspec in common, then let the caller know this
-     * configuration has to be rejected.
-     */
-    private Status validatePortSharingInternal(List<NodeConnector> portList, List<ContainerFlow> flowSpecList) {
-        for (NodeConnector port : portList) {
-            List<String> slist = nodeConnectorToContainers.get(port);
-            if (slist != null && !slist.isEmpty()) {
-                for (String otherContainerName : slist) {
-                    String msg = null;
-                    ContainerData other = containerData.get(otherContainerName);
-                    if (flowSpecList.isEmpty()) {
-                        msg = String.format("Port %s is shared and flow spec is empty for this container", port);
-                    } else if (other.isFlowSpecEmpty()) {
-                        msg = String.format("Port %s is shared and flow spec is empty for the other container", port);
-                    } else if (!checkCommonContainerFlow(flowSpecList, other.getContainerFlowSpecs()).isSuccess()) {
-                        msg = String.format("Port %s is shared and other container has common flow spec", port);
-                    }
-                    if (msg != null) {
-                        logger.debug(msg);
-                        return new Status(StatusCode.BADREQUEST, msg);
-                    }
-                }
-            }
-        }
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    /**
-     * Utility function to check if two lists of container flows share any same
-     * or overlapping container flows.
-     *
-     * @param oneFlowList
-     *            One of the two lists of container flows to test
-     * @param twoFlowList
-     *            One of the two lists of container flows to test
-     * @return The status of the check. Either SUCCESS or CONFLICT. In case of
-     *         conflict, the Status will contain the description for the failed
-     *         check.
-     */
-    private Status checkCommonContainerFlow(List<ContainerFlow> oneFlowList, List<ContainerFlow> twoFlowList) {
-        for (ContainerFlow oneFlow : oneFlowList) {
-            for (ContainerFlow twoFlow : twoFlowList) {
-                if (oneFlow.getMatch().intersetcs(twoFlow.getMatch())) {
-                    return new Status(StatusCode.CONFLICT, String.format("Flow Specs overlap: %s %s",
-                            oneFlow.getMatch(), twoFlow.getMatch()));
-                }
-            }
-        }
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    /**
-     * Return the ContainerData object for the passed container name. Given this is a
-     * backend database, the lower case version of the passed name is used while
-     * searching for the corresponding ContainerData object.
-     *
-     * @param name
-     *            The container name in any case
-     * @return The corresponding ContainerData object
-     */
-    private ContainerData getContainerByName(String name) {
-        return containerData.get(name.toLowerCase(Locale.ENGLISH));
-    }
-
-    /**
-     * Add a ContainerData object for the given container name.
-     *
-     * @param name
-     *            The container name in any case
-     * @param sData
-     *            The container data object
-     */
-    private void putContainerDataByName(String name, ContainerData sData) {
-        containerData.put(name.toLowerCase(Locale.ENGLISH), sData);
-    }
-
-    /**
-     * Removes the ContainerData object for the given container name.
-     *
-     * @param name
-     *            The container name in any case
-     */
-    private void removeContainerDataByName(String name) {
-        containerData.remove(name.toLowerCase(Locale.ENGLISH));
-    }
-
-    @Override
-    public List<ContainerConfig> getContainerConfigList() {
-        return new ArrayList<ContainerConfig>(containerConfigs.values());
-    }
-
-    @Override
-    public ContainerConfig getContainerConfig(String containerName) {
-        ContainerConfig target = containerConfigs.get(containerName);
-        return (target == null) ? null : new ContainerConfig(target);
-    }
-
-    @Override
-    public List<String> getContainerNameList() {
-        /*
-         * Return container names as they were configured by user (case sensitive)
-         * along with the default container
-         */
-        List<String> containerNameList = new ArrayList<String>();
-        containerNameList.add(GlobalConstants.DEFAULT.toString());
-        containerNameList.addAll(containerConfigs.keySet());
-        return containerNameList;
-    }
-
-    @Override
-    public Map<String, List<ContainerFlowConfig>> getContainerFlows() {
-        Map<String, List<ContainerFlowConfig>> flowSpecConfig = new HashMap<String, List<ContainerFlowConfig>>();
-        for (Map.Entry<String, ContainerConfig> entry : containerConfigs.entrySet()) {
-            List<ContainerFlowConfig> set = entry.getValue().getContainerFlowConfigs();
-            flowSpecConfig.put(entry.getKey(), set);
-        }
-        return flowSpecConfig;
-    }
-
-    private Status saveContainerConfig() {
-        return saveContainerConfigLocal();
-    }
-
-    public Status saveContainerConfigLocal() {
-        Status status = configurationService.persistConfiguration(
-                new ArrayList<ConfigurationObject>(containerConfigs.values()), CONTAINERS_FILE_NAME);
-
-        if (!status.isSuccess()) {
-            return new Status(StatusCode.INTERNALERROR, "Failed to save container configurations: "
-                    + status.getDescription());
-        }
-        return status;
-    }
-
-    /**
-     * Create and initialize default all resource group and create association
-     * with default well known users and profiles, if not already learnt from
-     * another cluster node
-     */
-    private void createDefaultAuthorizationGroups() {
-        allResourcesGroupName = ContainerManager.allContainersGroup;
-
-        // Add the default container to the all containers group if needed
-        String defaultContainer = GlobalConstants.DEFAULT.toString();
-        Set<String> allContainers = (resourceGroups.containsKey(allResourcesGroupName)) ? resourceGroups
-                .get(allResourcesGroupName) : new HashSet<String>();
-        if (!allContainers.contains(defaultContainer)) {
-            // Add Default container
-            allContainers.add(defaultContainer);
-            // Update cluster
-            resourceGroups.put(allResourcesGroupName, allContainers);
-        }
-
-        // Add the controller well known roles, if not known already
-        if (!roles.containsKey(UserLevel.SYSTEMADMIN.toString())) {
-            roles.put(UserLevel.SYSTEMADMIN.toString(), AppRoleLevel.APPADMIN);
-        }
-        if (!roles.containsKey(UserLevel.NETWORKADMIN.toString())) {
-            roles.put(UserLevel.NETWORKADMIN.toString(), AppRoleLevel.APPADMIN);
-        }
-        if (!roles.containsKey(UserLevel.NETWORKOPERATOR.toString())) {
-            roles.put(UserLevel.NETWORKOPERATOR.toString(), AppRoleLevel.APPOPERATOR);
-        }
-
-        /*
-         * Create and add the all containers user groups and associate them to the
-         * default well known user roles, if not present already
-         */
-        if (!groupsAuthorizations.containsKey(UserLevel.NETWORKADMIN.toString())) {
-            Set<ResourceGroup> writeProfile = new HashSet<ResourceGroup>(1);
-            Set<ResourceGroup> readProfile = new HashSet<ResourceGroup>(1);
-            writeProfile.add(new ResourceGroup(allResourcesGroupName, Privilege.WRITE));
-            readProfile.add(new ResourceGroup(allResourcesGroupName, Privilege.READ));
-            groupsAuthorizations.put(UserLevel.SYSTEMADMIN.toString(), writeProfile);
-            groupsAuthorizations.put(UserLevel.NETWORKADMIN.toString(), writeProfile);
-            groupsAuthorizations.put(UserLevel.NETWORKOPERATOR.toString(), readProfile);
-        }
-    }
-
-    /**
-     * Until manual configuration is not available, automatically maintain the
-     * well known resource groups
-     *
-     * @param containerName
-     * @param delete
-     */
-    private void updateResourceGroups(ContainerConfig containerConf, boolean delete) {
-        // Container Roles and Container Resource Group
-        String containerName = containerConf.getContainer();
-        String groupName = containerConf.getContainerGroupName();
-        String containerAdminRole = containerConf.getContainerAdminRole();
-        String containerOperatorRole = containerConf.getContainerOperatorRole();
-        Set<String> allContainerSet = resourceGroups.get(allResourcesGroupName);
-        if (delete) {
-            resourceGroups.remove(groupName);
-            groupsAuthorizations.remove(containerAdminRole);
-            groupsAuthorizations.remove(containerOperatorRole);
-            roles.remove(containerAdminRole);
-            roles.remove(containerOperatorRole);
-            // Update the all container group
-            allContainerSet.remove(containerName);
-        } else {
-            Set<String> resources = new HashSet<String>(1);
-            resources.add(containerName);
-            resourceGroups.put(groupName, resources);
-            Set<ResourceGroup> adminGroups = new HashSet<ResourceGroup>(1);
-            Set<ResourceGroup> operatorGroups = new HashSet<ResourceGroup>(1);
-            adminGroups.add(new ResourceGroup(groupName, Privilege.WRITE));
-            operatorGroups.add(new ResourceGroup(groupName, Privilege.READ));
-            groupsAuthorizations.put(containerAdminRole, adminGroups);
-            groupsAuthorizations.put(containerOperatorRole, operatorGroups);
-            roles.put(containerAdminRole, AppRoleLevel.APPADMIN);
-            roles.put(containerOperatorRole, AppRoleLevel.APPOPERATOR);
-            // Update the all containers resource group
-            allContainerSet.add(containerName);
-        }
-        // Update resource groups in cluster
-        resourceGroups.put(allResourcesGroupName, allContainerSet);
-    }
-
-    /**
-     * Notify ContainerAware listeners of the creation/deletion of the container
-     *
-     * @param containerName
-     * @param delete
-     *            true is container was removed, false otherwise
-     */
-    private void notifyContainerAwareListeners(String containerName, boolean delete) {
-        // Back-end World: container name forced to lower case
-        String name = containerName.toLowerCase(Locale.ENGLISH);
-
-        synchronized (this.iContainerAware) {
-            for (IContainerAware i : this.iContainerAware) {
-                if (delete) {
-                    i.containerDestroy(name);
-                } else {
-                    i.containerCreate(name);
-                }
-            }
-        }
-    }
-
-    /**
-     * Notify the ContainerListener listeners in case the container mode has
-     * changed following a container configuration operation Note: this call
-     * must happen after the configuration db has been updated
-     *
-     * @param lastActionDelete
-     *            true if the last container configuration operation was a
-     *            container delete operation
-     * @param notifyLocal
-     *            if true, the notification is also sent to the
-     *            IContainerLocalListener classes besides the IContainerListener
-     *            classes
-     */
-    private void notifyContainerModeChange(boolean lastActionDelete, boolean notifyLocal) {
-        if (lastActionDelete == false && containerConfigs.size() == 1) {
-            logger.trace("First container Creation. Inform listeners");
-            synchronized (this.iContainerListener) {
-                for (IContainerListener i : this.iContainerListener) {
-                    i.containerModeUpdated(UpdateType.ADDED);
-                }
-            }
-            if (notifyLocal) {
-                synchronized (this.iContainerLocalListener) {
-                    for (IContainerLocalListener i : this.iContainerLocalListener) {
-                        i.containerModeUpdated(UpdateType.ADDED);
-                    }
-                }
-            }
-        } else if (lastActionDelete == true && containerConfigs.isEmpty()) {
-            logger.trace("Last container Deletion. Inform listeners");
-            synchronized (this.iContainerListener) {
-                for (IContainerListener i : this.iContainerListener) {
-                    i.containerModeUpdated(UpdateType.REMOVED);
-                }
-            }
-            if (notifyLocal) {
-                synchronized (this.iContainerLocalListener) {
-                    for (IContainerLocalListener i : this.iContainerLocalListener) {
-                        i.containerModeUpdated(UpdateType.REMOVED);
-                    }
-                }
-            }
-        }
-    }
-
-    private Status addRemoveContainerEntries(String containerName, List<String> nodeConnectorsString, boolean delete) {
-        // Construct action message
-        String action = String.format("Node connector(s) %s container %s: %s", delete ? "removal from" : "addition to",
-                containerName, nodeConnectorsString);
-
-        // Validity Check
-        if (nodeConnectorsString == null || nodeConnectorsString.isEmpty()) {
-            return new Status(StatusCode.BADREQUEST, "Node connector list is null or empty");
-        }
-
-        // Presence check
-        ContainerConfig entryConf = containerConfigs.get(containerName);
-        if (entryConf == null) {
-            String msg = String.format("Container not found: %s", containerName);
-            String error = String.format("Failed to apply %s: (%s)", action, msg);
-            logger.warn(error);
-            return new Status(StatusCode.NOTFOUND, msg);
-        }
-
-        // Validation check
-        Status status = ContainerConfig.validateNodeConnectors(nodeConnectorsString);
-        if (!status.isSuccess()) {
-            String error = String.format("Failed to apply %s: (%s)", action, status.getDescription());
-            logger.warn(error);
-            return status;
-        }
-
-        List<NodeConnector> nodeConnectors = ContainerConfig.nodeConnectorsFromString(nodeConnectorsString);
-
-        // Port sharing check
-        if (!delete) {
-            /*
-             * Check if the ports being added to this container already belong to
-             * other containers. If so check whether the the appropriate flow specs
-             * are configured on this container
-             */
-            status = validatePortSharing(containerName, nodeConnectors);
-            if (!status.isSuccess()) {
-                String error = String.format("Failed to apply %s: (%s)", action, status.getDescription());
-                logger.warn(error);
-                return status;
-            }
-        }
-
-        // Update Database
-        status = updateContainerEntryDatabase(containerName, nodeConnectors, delete);
-        if (!status.isSuccess()) {
-            String error = String.format("Failed to apply %s: (%s)", action, status.getDescription());
-            logger.warn(error);
-            return status;
-        }
-
-        // Update Configuration
-        status = (delete) ? entryConf.removeNodeConnectors(nodeConnectorsString) : entryConf
-                .addNodeConnectors(nodeConnectorsString);
-        if (!status.isSuccess()) {
-            String error = String.format("Failed to modify config for %s: (%s)", action, status.getDescription());
-            logger.warn(error);
-            // Revert backend changes
-            Status statusRevert = updateContainerEntryDatabase(containerName, nodeConnectors, !delete);
-            if (!statusRevert.isSuccess()) {
-                // Unlikely
-                logger.error("Failed to revert changes in database (CRITICAL)");
-            }
-            return status;
-        }
-
-        // Update cluster Configuration cache
-        containerConfigs.put(containerName, entryConf);
-
-        // Notify global and local listeners
-        UpdateType update = (delete) ? UpdateType.REMOVED : UpdateType.ADDED;
-        notifyContainerEntryChangeInternal(containerName, nodeConnectors, update, true);
-        // Trigger cluster notification
-        containerChangeEvents.put(containerName, new NodeConnectorsChangeEvent(nodeConnectors, update));
-
-        return status;
-    }
-
-    private void notifyContainerChangeInternal(ContainerConfig conf, UpdateType update, boolean notifyLocal) {
-        String containerName = conf.getContainerName();
-        logger.trace("Notifying listeners on {} for container {}", update, containerName);
-        // Back-end World: container name forced to lower case
-        String container = containerName.toLowerCase(Locale.ENGLISH);
-        boolean delete = (update == UpdateType.REMOVED);
-        // Check if a container mode change notification is needed
-        notifyContainerModeChange(delete, notifyLocal);
-        // Notify listeners
-        notifyContainerAwareListeners(container, delete);
-    }
-
-    private void notifyContainerEntryChangeInternal(String containerName, List<NodeConnector> ncList, UpdateType update, boolean notifyLocal) {
-        logger.trace("Notifying listeners on {} for ports {} in container {}", update, ncList, containerName);
-        // Back-end World: container name forced to lower case
-        String container = containerName.toLowerCase(Locale.ENGLISH);
-        for (NodeConnector nodeConnector : ncList) {
-            // Now signal that the port has been added/removed
-            synchronized (this.iContainerListener) {
-                for (IContainerListener i : this.iContainerListener) {
-                    i.nodeConnectorUpdated(container, nodeConnector, update);
-                }
-            }
-            // Check if the Functional Modules need to be notified as well
-            if (notifyLocal) {
-                synchronized (this.iContainerLocalListener) {
-                    for (IContainerLocalListener i : this.iContainerLocalListener) {
-                        i.nodeConnectorUpdated(container, nodeConnector, update);
-                    }
-                }
-            }
-        }
-    }
-
-    private void notifyCFlowChangeInternal(String containerName, List<ContainerFlowConfig> confList, UpdateType update,
-            boolean notifyLocal) {
-        logger.trace("Notifying listeners on {} for flow specs {} in container {}", update, confList, containerName);
-        // Back-end World: container name forced to lower case
-        String container = containerName.toLowerCase(Locale.ENGLISH);
-
-        for (ContainerFlowConfig conf : confList) {
-            for (Match match : conf.getMatches()) {
-                ContainerFlow cFlow = new ContainerFlow(match);
-                synchronized (this.iContainerListener) {
-                    for (IContainerListener i : this.iContainerListener) {
-                        i.containerFlowUpdated(container, cFlow, cFlow, update);
-                    }
-                }
-                // Check if the Functional Modules need to be notified as well
-                if (notifyLocal) {
-                    synchronized (this.iContainerLocalListener) {
-                        for (IContainerLocalListener i : this.iContainerLocalListener) {
-                            i.containerFlowUpdated(container, cFlow, cFlow, update);
-                        }
-                    }
-                }
-            }
-        }
-    }
-
-    private Status addRemoveContainerFlow(String containerName, List<ContainerFlowConfig> cFlowConfList, boolean delete) {
-        // Construct action message
-        String action = String.format("Flow spec(s) %s container %s: %s", delete ? "removal from" : "addition to",
-                containerName, cFlowConfList);
-
-        // Presence check
-        ContainerConfig containerConfig = this.containerConfigs.get(containerName);
-        if (containerConfig == null) {
-            String msg = String.format("Container not found: %s", containerName);
-            String error = String.format("Failed to apply %s: (%s)", action, msg);
-            logger.warn(error);
-            return new Status(StatusCode.NOTFOUND, "Container not present");
-        }
-
-        // Validity check, check for overlaps on current container configuration
-        Status status = containerConfig.validateContainerFlowModify(cFlowConfList, delete);
-        if (!status.isSuccess()) {
-            String msg = status.getDescription();
-            String error = String.format("Failed to apply %s: (%s)", action, msg);
-            logger.warn(error);
-            return new Status(StatusCode.BADREQUEST, msg);
-        }
-
-        // Validate the operation in terms to the port sharing with other containers
-        for (ContainerFlowConfig conf : cFlowConfList) {
-            for (Match match : conf.getMatches()) {
-                ContainerFlow cFlow = new ContainerFlow(match);
-                status = validateContainerFlowAddRemoval(containerName, cFlow, delete);
-                if (!status.isSuccess()) {
-                    String msg = "Validation failed: " + status.getDescription();
-                    String error = String.format("Failed to apply %s: (%s)", action, msg);
-                    logger.warn(error);
-                    return new Status(StatusCode.BADREQUEST, msg);
-                }
-            }
-        }
-
-        // Update Database
-        status = updateContainerFlow(containerName, cFlowConfList, delete);
-        if (!status.isSuccess()) {
-            String error = String.format("Failed to apply %s: (%s)", action, status.getDescription());
-            logger.error(error);
-            return status;
-        }
-
-        // Update Configuration
-        status = (delete) ? containerConfig.removeContainerFlows(cFlowConfList) : containerConfig
-                .addContainerFlows(cFlowConfList);
-        if (!status.isSuccess()) {
-            String error = String.format("Failed to modify config for %s: (%s)", action, status.getDescription());
-            logger.error(error);
-            // Revert backend changes
-            Status statusRevert = updateContainerFlow(containerName, cFlowConfList, !delete);
-            if (!statusRevert.isSuccess()) {
-                // Unlikely
-                logger.error("Failed to revert changes in database (CRITICAL)");
-            }
-            return status;
-        }
-        // Update cluster cache
-        this.containerConfigs.put(containerName, containerConfig);
-
-        // Notify global and local listeners
-        UpdateType update = (delete) ? UpdateType.REMOVED : UpdateType.ADDED;
-        notifyCFlowChangeInternal(containerName, cFlowConfList, update, true);
-        // Trigger cluster notification
-        containerChangeEvents.put(containerName, new ContainerFlowChangeEvent(cFlowConfList, update));
-
-        return status;
-    }
-
-    private Status addRemoveContainer(ContainerConfig containerConf, boolean delete) {
-        // Construct action message
-        String action = String.format("Container %s", delete ? "removal" : "creation");
-
-        // Valid configuration check
-        Status status = null;
-        String error = (containerConfigs == null) ? String.format("Invalid %s configuration: (null config object)", action)
-                : (!(status = containerConf.validate()).isSuccess()) ? String.format("Invalid %s configuration: (%s)",
-                        action, status.getDescription()) : null;
-        if (error != null) {
-            logger.warn(error);
-            return new Status(StatusCode.BADREQUEST, error);
-        }
-
-        // Configuration presence check
-        String containerName = containerConf.getContainerName();
-        if (delete) {
-            if (!containerConfigs.containsKey(containerName)) {
-                String msg = String.format("%s Failed: (Container does not exist: %s)", action, containerName);
-                logger.warn(msg);
-                return new Status(StatusCode.NOTFOUND, msg);
-            }
-        } else {
-            if (containerConfigs.containsKey(containerName)) {
-                String msg = String.format("%s Failed: (Container already exist: %s)", action, containerName);
-                logger.warn(msg);
-                return new Status(StatusCode.CONFLICT, msg);
-            }
-        }
-
-        /*
-         * The proposed container configuration could be a complex one containing
-         * both ports and flow spec. If so, check if it has shared ports with
-         * other existing containers. If that is the case verify flow spec isolation
-         * is in place. No need to check on flow spec validation first. This
-         * would take care of both
-         */
-        if (!delete) {
-            status = validatePortSharing(containerConf);
-            if (!status.isSuccess()) {
-                error = String.format("%s Failed: (%s)", action, status.getDescription());
-                logger.error(error);
-                return status;
-            }
-        }
-
-        // Update Database
-        status = updateContainerDatabase(containerConf, delete);
-
-        // Abort and exit here if back-end database update failed
-        if (!status.isSuccess()) {
-            return status;
-        }
-
-        /*
-         * Update Configuration: This will trigger the notifications on cache
-         * update callback locally and on the other cluster nodes
-         */
-        if (delete) {
-            this.containerConfigs.remove(containerName);
-        } else {
-            this.containerConfigs.put(containerName, containerConf);
-        }
-
-        // Automatically create and populate user and resource groups
-        updateResourceGroups(containerConf, delete);
-
-        // Notify global and local listeners
-        UpdateType update = (delete) ? UpdateType.REMOVED : UpdateType.ADDED;
-        notifyContainerChangeInternal(containerConf, update, true);
-
-        // Trigger cluster notification
-        containerChangeEvents.put(containerName, new ContainerChangeEvent(containerConf, update));
-
-        if (update == UpdateType.ADDED) {
-            if (containerConf.hasFlowSpecs()) {
-                List<ContainerFlowConfig> specList = containerConf.getContainerFlowConfigs();
-                // Notify global and local listeners about flow spec addition
-                notifyCFlowChangeInternal(containerName, specList, update, true);
-
-                // Trigger cluster notification
-                containerChangeEvents.put(containerName, new ContainerFlowChangeEvent(specList, update));
-            }
-
-            if (containerConf.hasNodeConnectors()) {
-                List<NodeConnector> ncList = containerConf.getPortList();
-                // Notify global and local listeners about port(s) addition
-                notifyContainerEntryChangeInternal(containerName, ncList, update, true);
-                // Trigger cluster notification
-                containerChangeEvents.put(containerName, new NodeConnectorsChangeEvent(ncList, update));
-            }
-        }
-
-        if (delete) {
-            clusterServices.removeContainerCaches(containerName);
-        }
-        return status;
-    }
-
-    @Override
-    public Status addContainer(ContainerConfig containerConf) {
-        return addRemoveContainer(containerConf, false);
-    }
-
-    @Override
-    public Status removeContainer(ContainerConfig containerConf) {
-        return addRemoveContainer(containerConf, true);
-    }
-
-    @Override
-    public Status removeContainer(String containerName) {
-        // Construct action message
-        String action = String.format("Container removal: %s", containerName);
-
-        ContainerConfig containerConf = containerConfigs.get(containerName);
-        if (containerConf == null) {
-            String msg = String.format("Container not found");
-            String error = String.format("Failed to apply %s: (%s)", action, msg);
-            logger.warn(error);
-            return new Status(StatusCode.NOTFOUND, msg);
-        }
-        return addRemoveContainer(containerConf, true);
-    }
-
-    @Override
-    public Status addContainerEntry(String containerName, List<String> nodeConnectors) {
-        return addRemoveContainerEntries(containerName, nodeConnectors, false);
-    }
-
-    @Override
-    public Status removeContainerEntry(String containerName, List<String> nodeConnectors) {
-        return addRemoveContainerEntries(containerName, nodeConnectors, true);
-    }
-
-    @Override
-    public Status addContainerFlows(String containerName, List<ContainerFlowConfig> fSpecConf) {
-        return addRemoveContainerFlow(containerName, fSpecConf, false);
-    }
-
-    @Override
-    public Status removeContainerFlows(String containerName, List<ContainerFlowConfig> fSpecConf) {
-        return addRemoveContainerFlow(containerName, fSpecConf, true);
-    }
-
-    @Override
-    public Status removeContainerFlows(String containerName, Set<String> names) {
-        // Construct action message
-        String action = String.format("Flow spec(s) removal from container %s: %s", containerName, names);
-
-        // Presence check
-        ContainerConfig sc = containerConfigs.get(containerName);
-        if (sc == null) {
-            String msg = String.format("Container not found: %s", containerName);
-            String error = String.format("Failed to apply %s: (%s)", action, msg);
-            logger.warn(error);
-            return new Status(StatusCode.NOTFOUND, msg);
-        }
-        List<ContainerFlowConfig> list = sc.getContainerFlowConfigs(names);
-        if (list.isEmpty() || list.size() != names.size()) {
-            String msg = String.format("Cannot find all the specified flow specs");
-            String error = String.format("Failed to apply %s: (%s)", action, msg);
-            logger.warn(error);
-            return new Status(StatusCode.BADREQUEST, msg);
-        }
-        return addRemoveContainerFlow(containerName, list, true);
-    }
-
-    @Override
-    public List<ContainerFlowConfig> getContainerFlows(String containerName) {
-        ContainerConfig sc = containerConfigs.get(containerName);
-        return (sc == null) ? new ArrayList<ContainerFlowConfig>(0) : sc.getContainerFlowConfigs();
-    }
-
-    @Override
-    public List<String> getContainerFlowNameList(String containerName) {
-        ContainerConfig sc = containerConfigs.get(containerName);
-        return (sc == null) ? new ArrayList<String>(0) : sc.getContainerFlowConfigsNames();
-    }
-
-    @Override
-    public Object readObject(ObjectInputStream ois) throws FileNotFoundException, IOException, ClassNotFoundException {
-        // Perform the class deserialization locally, from inside the package
-        // where the class is defined
-        return ois.readObject();
-    }
-
-    private void loadContainerConfig() {
-        for (ConfigurationObject conf : configurationService.retrieveConfiguration(this, CONTAINERS_FILE_NAME)) {
-            addContainer((ContainerConfig) conf);
-        }
-    }
-
-    public void _psc(CommandInterpreter ci) {
-        for (Map.Entry<String, ContainerConfig> entry : containerConfigs.entrySet()) {
-            ContainerConfig sc = entry.getValue();
-            ci.println(String.format("%s: %s", sc.getContainerName(), sc.toString()));
-        }
-        ci.println("Total number of containers: " + containerConfigs.entrySet().size());
-    }
-
-    public void _pfc(CommandInterpreter ci) {
-        for (Map.Entry<String, ContainerConfig> entry : containerConfigs.entrySet()) {
-            ContainerConfig sc = entry.getValue();
-            ci.println(String.format("%s: %s", sc.getContainerName(), sc.getContainerFlowConfigs()));
-        }
-    }
-
-    public void _psd(CommandInterpreter ci) {
-        for (String containerName : containerData.keySet()) {
-            ContainerData sd = containerData.get(containerName);
-            for (Node sid : sd.getSwPorts().keySet()) {
-                Set<NodeConnector> s = sd.getSwPorts().get(sid);
-                ci.println("\t" + sid + " : " + s);
-            }
-
-            for (ContainerFlow s : sd.getContainerFlowSpecs()) {
-                ci.println("\t" + s.toString());
-            }
-        }
-    }
-
-    public void _psp(CommandInterpreter ci) {
-        for (NodeConnector sp : nodeConnectorToContainers.keySet()) {
-            ci.println(nodeConnectorToContainers.get(sp));
-        }
-    }
-
-    public void _psm(CommandInterpreter ci) {
-        for (Node sp : nodeToContainers.keySet()) {
-            ci.println(nodeToContainers.get(sp));
-        }
-    }
-
-    public void _addContainer(CommandInterpreter ci) {
-        String containerName = ci.nextArgument();
-        if (containerName == null) {
-            ci.print("Container Name not specified");
-            return;
-        }
-        String staticVlan = ci.nextArgument();
-        ContainerConfig containerConfig = new ContainerConfig(containerName, staticVlan, null, null);
-        ci.println(this.addRemoveContainer(containerConfig, false));
-    }
-
-    public void _createContainer(CommandInterpreter ci) {
-        String containerName = ci.nextArgument();
-        if (containerName == null) {
-            ci.print("Container Name not specified");
-            return;
-        }
-        String staticVlan = ci.nextArgument();
-        if (staticVlan == null) {
-            ci.print("Static Vlan not specified");
-            return;
-        }
-        List<String> ports = new ArrayList<String>();
-        for (long l = 1L; l < 10L; l++) {
-            ports.add(NodeConnectorCreator.createOFNodeConnector((short) 1, NodeCreator.createOFNode(l)).toString());
-        }
-        List<ContainerFlowConfig> cFlowList = new ArrayList<ContainerFlowConfig>();
-        cFlowList.add(this.createSampleContainerFlowConfig("tcp", true));
-        ContainerConfig containerConfig = new ContainerConfig(containerName, staticVlan, ports, cFlowList);
-        ci.println(this.addRemoveContainer(containerConfig, false));
-    }
-
-    public void _removeContainer(CommandInterpreter ci) {
-        String containerName = ci.nextArgument();
-        if (containerName == null) {
-            ci.print("Container Name not specified");
-            return;
-        }
-        ContainerConfig containerConfig = new ContainerConfig(containerName, "", null, null);
-        ci.println(this.addRemoveContainer(containerConfig, true));
-    }
-
-    public void _addContainerEntry(CommandInterpreter ci) {
-        String containerName = ci.nextArgument();
-        if (containerName == null) {
-            ci.print("Container Name not specified");
-            return;
-        }
-        String nodeId = ci.nextArgument();
-        if (nodeId == null) {
-            ci.print("Node Id not specified");
-            return;
-        }
-        String portId = ci.nextArgument();
-        if (portId == null) {
-            ci.print("Port not specified");
-            return;
-        }
-        Node node = NodeCreator.createOFNode(Long.valueOf(nodeId));
-        Short port = Short.valueOf(portId);
-        NodeConnector nc = NodeConnectorCreator.createOFNodeConnector(port, node);
-        List<String> portList = new ArrayList<String>(1);
-        portList.add(nc.toString());
-        ci.println(this.addRemoveContainerEntries(containerName, portList, false));
-    }
-
-    public void _removeContainerEntry(CommandInterpreter ci) {
-        String containerName = ci.nextArgument();
-        if (containerName == null) {
-            ci.print("Container Name not specified");
-            return;
-        }
-        String nodeId = ci.nextArgument();
-        if (nodeId == null) {
-            ci.print("Node Id not specified");
-            return;
-        }
-        String portId = ci.nextArgument();
-        if (portId == null) {
-            ci.print("Port not specified");
-            return;
-        }
-        Node node = NodeCreator.createOFNode(Long.valueOf(nodeId));
-        Short port = Short.valueOf(portId);
-        NodeConnector nc = NodeConnectorCreator.createOFNodeConnector(port, node);
-        List<String> portList = new ArrayList<String>(1);
-        portList.add(nc.toString());
-        ci.println(this.addRemoveContainerEntries(containerName, portList, true));
-    }
-
-    private ContainerFlowConfig createSampleContainerFlowConfig(String cflowName, boolean boolUnidirectional) {
-        ContainerFlowConfig cfg = new ContainerFlowConfig(cflowName, "9.9.1.0/24", "19.9.1.2", "TCP", "1234", "25");
-        return cfg;
-    }
-
-    public void _addContainerFlow(CommandInterpreter ci) {
-        String containerName = ci.nextArgument();
-        if (containerName == null) {
-            ci.print("Container Name not specified");
-            return;
-        }
-        String cflowName = ci.nextArgument();
-        if (cflowName == null) {
-            ci.print("cflowName not specified");
-            return;
-        }
-        String unidirectional = ci.nextArgument();
-        boolean boolUnidirectional = Boolean.parseBoolean(unidirectional);
-        List<ContainerFlowConfig> list = new ArrayList<ContainerFlowConfig>();
-        list.add(createSampleContainerFlowConfig(cflowName, boolUnidirectional));
-        ci.println(this.addRemoveContainerFlow(containerName, list, false));
-    }
-
-    public void _removeContainerFlow(CommandInterpreter ci) {
-        String containerName = ci.nextArgument();
-        if (containerName == null) {
-            ci.print("Container Name not specified");
-            return;
-        }
-        String cflowName = ci.nextArgument();
-        if (cflowName == null) {
-            ci.print("cflowName not specified");
-            return;
-        }
-        Set<String> set = new HashSet<String>(1);
-        set.add(cflowName);
-        ci.println(this.removeContainerFlows(containerName, set));
-    }
-
-    @Override
-    public String getHelp() {
-        StringBuffer help = new StringBuffer();
-        help.append("---ContainerManager Testing---\n");
-        help.append("\tpsc        - Print ContainerConfigs\n");
-        help.append("\tpfc        - Print FlowSpecConfigs\n");
-        help.append("\tpsd        - Print ContainerData\n");
-        help.append("\tpsp        - Print nodeConnectorToContainers\n");
-        help.append("\tpsm        - Print nodeToContainers\n");
-        help.append("\t addContainer <containerName> <staticVlan> \n");
-        help.append("\t removeContainer <containerName> \n");
-        help.append("\t addContainerEntry <containerName> <nodeId> <port> \n");
-        help.append("\t removeContainerEntry <containerName> <nodeId> <port> \n");
-        help.append("\t addContainerFlow <containerName> <cflowName> <unidirectional true/false>\n");
-        help.append("\t removeContainerFlow <containerName> <cflowName> \n");
-        return help.toString();
-    }
-
-    @Override
-    public boolean doesContainerExist(String containerName) {
-        // Test for default container
-        if (GlobalConstants.DEFAULT.toString().equalsIgnoreCase(containerName)) {
-            return true;
-        }
-        // Test for non-default one
-        return (getContainerByName(containerName) != null);
-    }
-
-    @Override
-    public ContainerData getContainerData(String containerName) {
-        return (getContainerByName(containerName));
-    }
-
-    @Override
-    public Status saveConfiguration() {
-        return saveContainerConfig();
-    }
-
-    public void _containermgrGetRoles(CommandInterpreter ci) {
-        ci.println("Configured roles for Container Mgr:");
-        List<String> list = this.getRoles();
-        for (String role : list) {
-            ci.println(role + "\t" + roles.get(role));
-        }
-    }
-
-    public void _containermgrGetAuthorizedGroups(CommandInterpreter ci) {
-        String roleName = ci.nextArgument();
-        if (roleName == null || roleName.trim().isEmpty()) {
-            ci.println("Invalid argument");
-            ci.println("mmGetAuthorizedGroups <role_name>");
-            return;
-        }
-        ci.println("Resource Groups associated to role " + roleName + ":");
-        List<ResourceGroup> list = this.getAuthorizedGroups(roleName);
-        for (ResourceGroup group : list) {
-            ci.println(group.toString());
-        }
-    }
-
-    public void _containermgrGetAuthorizedResources(CommandInterpreter ci) {
-        String roleName = ci.nextArgument();
-        if (roleName == null || roleName.trim().isEmpty()) {
-            ci.println("Invalid argument");
-            ci.println("mmGetAuthorizedResources <role_name>");
-            return;
-        }
-        ci.println("Resource associated to role " + roleName + ":");
-        List<Resource> list = this.getAuthorizedResources(roleName);
-        for (Resource resource : list) {
-            ci.println(resource.toString());
-        }
-    }
-
-    public void _containermgrGetResourcesForGroup(CommandInterpreter ci) {
-        String groupName = ci.nextArgument();
-        if (groupName == null || groupName.trim().isEmpty()) {
-            ci.println("Invalid argument");
-            ci.println("containermgrResourcesForGroup <group_name>");
-            return;
-        }
-        ci.println("Group " + groupName + " contains the following resources:");
-        List<Object> resources = this.getResources(groupName);
-        for (Object resource : resources) {
-            ci.println(resource.toString());
-        }
-    }
-
-    public void _containermgrGetUserLevel(CommandInterpreter ci) {
-        String userName = ci.nextArgument();
-        if (userName == null || userName.trim().isEmpty()) {
-            ci.println("Invalid argument");
-            ci.println("containermgrGetUserLevel <user_name>");
-            return;
-        }
-        ci.println("User " + userName + " has level: " + this.getUserLevel(userName));
-    }
-
-    public void _containermgrGetUserResources(CommandInterpreter ci) {
-        String userName = ci.nextArgument();
-        if (userName == null || userName.trim().isEmpty()) {
-            ci.println("Invalid argument");
-            ci.println("containermgrGetUserResources <user_name>");
-            return;
-        }
-        ci.println("User " + userName + " owns the following resources: ");
-        Set<Resource> resources = this.getAllResourcesforUser(userName);
-        for (Resource resource : resources) {
-            ci.println(resource.toString());
-        }
-    }
-
-    /*
-     * For scalability testing where as of now controller gui is unresponsive
-     * providing here an osgi hook to trigger the save config so that DT do not
-     * have to reaply the scalable configuration each time they restart the
-     * controller
-     */
-    // TODO: remove when no longer needed
-    public void _saveConfig(CommandInterpreter ci) {
-        Status status = new Status(StatusCode.NOSERVICE, "Configuration service not reachable");
-
-        IConfigurationService configService = (IConfigurationService) ServiceHelper.getGlobalInstance(
-                IConfigurationService.class, this);
-        if (configService != null) {
-            status = configService.saveConfigurations();
-        }
-        ci.println(status.toString());
-    }
-
-    @Override
-    public List<String> getContainerNames() {
-        return getContainerNameList();
-    }
-
-    @Override
-    public boolean hasNonDefaultContainer() {
-        return !containerConfigs.keySet().isEmpty();
-    }
-
-    @Override
-    public boolean inContainerMode() {
-        return this.containerConfigs.size() > 0;
-    }
-
-    public List<String> psc() {
-        List<String> result = new ArrayList<String>();
-        for (Map.Entry<String, ContainerConfig> entry : containerConfigs.entrySet()) {
-            ContainerConfig sc = entry.getValue();
-            result.add(String.format("%s: %s", sc.getContainerName(), sc.toString()));
-        }
-        result.add("Total number of containers: " + containerConfigs.entrySet().size());
-        return result;
-    }
-
-    public List<String> pfc() {
-        List<String> result = new ArrayList<String>();
-        for (Map.Entry<String, ContainerConfig> entry : containerConfigs.entrySet()) {
-            ContainerConfig sc = entry.getValue();
-            result.add(String.format("%s: %s", sc.getContainerName(), sc.getContainerFlowConfigs()));
-        }
-        return result;
-    }
-
-    public List<String> psd() {
-        List<String> result = new ArrayList<String>();
-        for (String containerName : containerData.keySet()) {
-            ContainerData sd = containerData.get(containerName);
-            for (Node sid : sd.getSwPorts().keySet()) {
-                Set<NodeConnector> s = sd.getSwPorts().get(sid);
-                result.add("\t" + sid + " : " + s);
-            }
-
-            for (ContainerFlow s : sd.getContainerFlowSpecs()) {
-                result.add("\t" + s.toString());
-            }
-        }
-        return result;
-    }
-
-    public List<String> psp() {
-        List<String> result = new ArrayList<String>();
-        for (NodeConnector sp : nodeConnectorToContainers.keySet()) {
-            result.add(nodeConnectorToContainers.get(sp).toString());
-        }
-        return result;
-    }
-
-    public List<String> psm() {
-        List<String> result = new ArrayList<String>();
-        for (Node sp : nodeToContainers.keySet()) {
-            result.add(nodeToContainers.get(sp).toString());
-        }
-        return result;
-    }
-
-    public List<String> addContainer(String arg1, String arg2) {
-        List<String> result = new ArrayList<String>();
-        String containerName = arg1;
-        if (containerName == null) {
-            result.add("Container Name not specified");
-            return result;
-        }
-        String staticVlan = arg2;
-        ContainerConfig containerConfig = new ContainerConfig(containerName, staticVlan, null, null);
-        result.add((this.addRemoveContainer(containerConfig, false)).toString());
-        return result;
-    }
-
-    public List<String> createContainer(String arg1, String arg2) {
-        List<String> result = new ArrayList<String>();
-        String containerName = arg1;
-        if (containerName == null) {
-            result.add("Container Name not specified");
-            return result;
-        }
-        String staticVlan = arg2;
-        if (staticVlan == null) {
-            result.add("Static Vlan not specified");
-            return result;
-        }
-        List<String> ports = new ArrayList<String>();
-        for (long l = 1L; l < 10L; l++) {
-            ports.add(NodeConnectorCreator.createOFNodeConnector((short) 1, NodeCreator.createOFNode(l)).toString());
-        }
-        List<ContainerFlowConfig> cFlowList = new ArrayList<ContainerFlowConfig>();
-        cFlowList.add(this.createSampleContainerFlowConfig("tcp", true));
-        ContainerConfig containerConfig = new ContainerConfig(containerName, staticVlan, ports, cFlowList);
-        result.add((this.addRemoveContainer(containerConfig, false)).toString());
-        return result;
-    }
-
-    public List<String> removeContainerShell(String arg1) {
-        List<String> result = new ArrayList<String>();
-        String containerName = arg1;
-        if (containerName == null) {
-            result.add("Container Name not specified");
-            return result;
-        }
-        ContainerConfig containerConfig = new ContainerConfig(containerName, "", null, null);
-        result.add((this.addRemoveContainer(containerConfig, true)).toString());
-        return result;
-    }
-
-    public List<String> addContainerEntry(String arg1, String arg2, String arg3) {
-        List<String> result = new ArrayList<String>();
-        String containerName = arg1;
-        if (containerName == null) {
-            result.add("Container Name not specified");
-            return result;
-        }
-        String nodeId = arg2;
-        if (nodeId == null) {
-            result.add("Node Id not specified");
-            return result;
-        }
-        String portId = arg3;
-        if (portId == null) {
-            result.add("Port not specified");
-            return result;
-        }
-        Node node = NodeCreator.createOFNode(Long.valueOf(nodeId));
-        Short port = Short.valueOf(portId);
-        NodeConnector nc = NodeConnectorCreator.createOFNodeConnector(port, node);
-        List<String> portList = new ArrayList<String>(1);
-        portList.add(nc.toString());
-        result.add((this.addRemoveContainerEntries(containerName, portList, false)).toString());
-        return result;
-    }
-
-    public List<String> removeContainerEntry(String arg1, String arg2, String arg3) {
-        List<String> result = new ArrayList<String>();
-        String containerName = arg1;
-        if (containerName == null) {
-            result.add("Container Name not specified");
-            return result;
-        }
-        String nodeId = arg2;
-        if (nodeId == null) {
-            result.add("Node Id not specified");
-            return result;
-        }
-        String portId = arg3;
-        if (portId == null) {
-            result.add("Port not specified");
-            return result;
-        }
-        Node node = NodeCreator.createOFNode(Long.valueOf(nodeId));
-        Short port = Short.valueOf(portId);
-        NodeConnector nc = NodeConnectorCreator.createOFNodeConnector(port, node);
-        List<String> portList = new ArrayList<String>(1);
-        portList.add(nc.toString());
-        result.add((this.addRemoveContainerEntries(containerName, portList, true)).toString());
-        return result;
-    }
-    public List<String> addContainerFlow(String arg1, String arg2, String arg3) {
-        List<String> result = new ArrayList<String>();
-        String containerName = arg1;
-        if (containerName == null) {
-            result.add("Container Name not specified");
-            return result;
-        }
-        String cflowName = arg2;
-        if (cflowName == null) {
-            result.add("cflowName not specified");
-            return result;
-        }
-        String unidirectional = arg3;
-        boolean boolUnidirectional = Boolean.parseBoolean(unidirectional);
-        List<ContainerFlowConfig> list = new ArrayList<ContainerFlowConfig>();
-        list.add(createSampleContainerFlowConfig(cflowName, boolUnidirectional));
-        result.add((this.addRemoveContainerFlow(containerName, list, false)).toString());
-        return result;
-    }
-
-    public List<String> removeContainerFlow(String arg1, String arg2) {
-        List<String> result = new ArrayList<String>();
-        String containerName = arg1;
-        if (containerName == null) {
-            result.add("Container Name not specified");
-            return result;
-        }
-        String cflowName = arg2;
-        if (cflowName == null) {
-            result.add("cflowName not specified");
-            return result;
-        }
-        Set<String> set = new HashSet<String>(1);
-        set.add(cflowName);
-        result.add((this.removeContainerFlows(containerName, set)).toString());
-        return result;
-    }
-
-    public List<String> containermgrGetRoles() {
-        List<String> result = new ArrayList<String>();
-        result.add("Configured roles for Container Mgr:");
-        List<String> list = this.getRoles();
-        for (String role : list) {
-            result.add(role + "\t" + roles.get(role));
-        }
-        return result;
-    }
-
-    public List<String> containermgrGetAuthorizedGroups(String arg1) {
-        List<String> result = new ArrayList<String>();
-        String roleName = arg1;
-        if (roleName == null || roleName.trim().isEmpty()) {
-            result.add("Invalid argument");
-            result.add("mmGetAuthorizedGroups <role_name>");
-            return result;
-        }
-        result.add("Resource Groups associated to role " + roleName + ":");
-        List<ResourceGroup> list = this.getAuthorizedGroups(roleName);
-        for (ResourceGroup group : list) {
-            result.add(group.toString());
-        }
-        return result;
-    }
-    public List<String> containermgrGetAuthorizedResources(String arg1) {
-        List<String> result = new ArrayList<String>();
-        String roleName = arg1;
-        if (roleName == null || roleName.trim().isEmpty()) {
-            result.add("Invalid argument");
-            result.add("mmGetAuthorizedResources <role_name>");
-            return result;
-        }
-        result.add("Resource associated to role " + roleName + ":");
-        List<Resource> list = this.getAuthorizedResources(roleName);
-        for (Resource resource : list) {
-            result.add(resource.toString());
-        }
-        return result;
-    }
-    public List<String> containermgrGetResourcesForGroup(String arg1) {
-        List<String> result = new ArrayList<String>();
-        String groupName = arg1;
-        if (groupName == null || groupName.trim().isEmpty()) {
-            result.add("Invalid argument");
-            result.add("containermgrResourcesForGroup <group_name>");
-            return result;
-        }
-        result.add("Group " + groupName + " contains the following resources:");
-        List<Object> resources = this.getResources(groupName);
-        for (Object resource : resources) {
-            result.add(resource.toString());
-        }
-        return result;
-    }
-    public List<String> containermgrGetUserLevel(String arg1) {
-        List<String> result = new ArrayList<String>();
-        String userName = arg1;
-        if (userName == null || userName.trim().isEmpty()) {
-            result.add("Invalid argument");
-            result.add("containermgrGetUserLevel <user_name>");
-            return result;
-        }
-        result.add("User " + userName + " has level: " + this.getUserLevel(userName));
-        return result;
-    }
-    public List<String> containermgrGetUserResources(String arg1) {
-        List<String> result = new ArrayList<String>();
-        String userName = arg1;
-        if (userName == null || userName.trim().isEmpty()) {
-            result.add("Invalid argument");
-            result.add("containermgrGetUserResources <user_name>");
-            return result;
-        }
-        result.add("User " + userName + " owns the following resources: ");
-        Set<Resource> resources = this.getAllResourcesforUser(userName);
-        for (Resource resource : resources) {
-            result.add(resource.toString());
-        }
-        return result;
-    }
-    public List<String> saveConfig() {
-        List<String> result = new ArrayList<String>();
-        Status status = new Status(StatusCode.NOSERVICE, "Configuration service not reachable");
-
-        IConfigurationService configService = (IConfigurationService) ServiceHelper.getGlobalInstance(
-                IConfigurationService.class, this);
-        if (configService != null) {
-            status = configService.saveConfigurations();
-        }
-        result.add(status.toString());
-        return result;
-    }
-}
diff --git a/opendaylight/adsal/containermanager/implementation/src/main/java/org/opendaylight/controller/containermanager/internal/IContainerInternal.java b/opendaylight/adsal/containermanager/implementation/src/main/java/org/opendaylight/controller/containermanager/internal/IContainerInternal.java
deleted file mode 100644 (file)
index 555f37a..0000000
+++ /dev/null
@@ -1,33 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.containermanager.internal;
-
-import org.opendaylight.controller.containermanager.ContainerData;
-
-/**
- * @file   IContainerInternal.java
- *
- * @brief  Interface to export internal container manager data to friend classes
- *
- * Interface to export internal container manager data to friend classes
- */
-
-interface IContainerInternal {
-    /**
-     * Return a reference to containerData if available so a friend class
-     * can extract all the data and cook them up.
-     *
-     * @param containerName ContainerName for which we want to export the data
-     *
-     * @return null if containerName doesn't exist or a reference to
-     * ContainerData if exists
-     */
-    ContainerData getContainerData(String containerName);
-}
diff --git a/opendaylight/adsal/containermanager/it.implementation/pom.xml b/opendaylight/adsal/containermanager/it.implementation/pom.xml
deleted file mode 100644 (file)
index 241d9fb..0000000
+++ /dev/null
@@ -1,68 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>containermanager.it.implementation</artifactId>
-  <version>0.7.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>clustering.services</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>containermanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Import-Package>org.opendaylight.controller.containermanager,
-              org.opendaylight.controller.clustering.services,
-              org.opendaylight.controller.sal.packet,
-              org.opendaylight.controller.sal.utils,
-              org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.sal.action,
-              org.opendaylight.controller.sal.flowprogrammer,
-              org.opendaylight.controller.sal.match,
-              org.opendaylight.controller.sal.reader,
-              org.eclipse.osgi.framework.console,
-              org.osgi.framework,
-              org.slf4j,
-              org.apache.felix.dm</Import-Package>
-            <Export-Package></Export-Package>
-            <Bundle-Activator>org.opendaylight.controller.containermanager.internal.Activator</Bundle-Activator>
-          </instructions>
-          <manifestLocation>${project.basedir}/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/containermanager/it.implementation/src/main/java/org/opendaylight/controller/containermanager/internal/Activator.java b/opendaylight/adsal/containermanager/it.implementation/src/main/java/org/opendaylight/controller/containermanager/internal/Activator.java
deleted file mode 100644 (file)
index bc0bba8..0000000
+++ /dev/null
@@ -1,114 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.containermanager.internal;
-
-import org.opendaylight.controller.clustering.services.IClusterGlobalServices;
-import org.opendaylight.controller.containermanager.IContainerManager;
-import org.opendaylight.controller.sal.core.IContainerAware;
-import org.opendaylight.controller.sal.core.IContainer;
-import org.opendaylight.controller.sal.core.IContainerListener;
-import org.apache.felix.dm.Component;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-import org.opendaylight.controller.sal.core.ComponentActivatorAbstractBase;
-
-public class Activator extends ComponentActivatorAbstractBase {
-    protected static final Logger logger = LoggerFactory
-            .getLogger(Activator.class);
-
-
-
-    /**
-     * Function that is used to communicate to dependency manager the
-     * list of known implementations for services inside a container
-     *
-     *
-     * @return An array containing all the CLASS objects that will be
-     * instantiated in order to get an fully working implementation
-     * Object
-     */
-    public Object[] getImplementations() {
-        Object[] res = { ContainerImpl.class };
-        return res;
-    }
-
-    /**
-     * Function that is called when configuration of the dependencies
-     * is required.
-     *
-     * @param c dependency manager Component object, used for
-     * configuring the dependencies exported and imported
-     * @param imp Implementation class that is being configured,
-     * needed as long as the same routine can configure multiple
-     * implementations
-     * @param containerName The containerName being configured, this allow
-     * also optional per-container different behavior if needed, usually
-     * should not be the case though.
-     */
-    public void configureInstance(Component c, Object imp, String containerName) {
-        if (imp.equals(ContainerImpl.class)) {
-            // export the service
-            c.setInterface(new String[] { IContainer.class.getName() }, null);
-        }
-    }
-
-    /**
-     * Method which tells how many Global implementations are
-     * supported by the bundle. This way we can tune the number of
-     * components created. This components will be created ONLY at the
-     * time of bundle startup and will be destroyed only at time of
-     * bundle destruction, this is the major difference with the
-     * implementation retrieved via getImplementations where all of
-     * them are assumed to be in a container!
-     *
-     *
-     * @return The list of implementations the bundle will support,
-     * in Global version
-     */
-    protected Object[] getGlobalImplementations() {
-        Object[] res = { ContainerManager.class };
-        return res;
-    }
-
-    /**
-     * Configure the dependency for a given instance Global
-     *
-     * @param c Component assigned for this instance, this will be
-     * what will be used for configuration
-     * @param imp implementation to be configured
-     * @param containerName container on which the configuration happens
-     */
-    protected void configureGlobalInstance(Component c, Object imp) {
-        if (imp.equals(ContainerManager.class)) {
-
-            // export the service
-            c.setInterface(new String[] { IContainerManager.class.getName() },
-                    null);
-
-            c.add(createServiceDependency().setService(
-                    IClusterGlobalServices.class).setCallbacks(
-                    "setClusterServices", "unsetClusterServices").setRequired(
-                    true));
-
-            // Key kick-starter for container creation in each component
-            c.add(createServiceDependency().setService(IContainerAware.class)
-                    .setCallbacks("setIContainerAware", "unsetIContainerAware")
-                    .setRequired(false));
-
-            // Optional interface expected to be exported by the
-            // protocol plugins to setup proper filtering based on
-            // slicing events
-            c.add(createServiceDependency()
-                    .setService(IContainerListener.class).setCallbacks(
-                            "setIContainerListener", "unsetIContainerListener")
-                    .setRequired(false));
-        }
-    }
-}
diff --git a/opendaylight/adsal/containermanager/it.implementation/src/main/java/org/opendaylight/controller/containermanager/internal/ContainerImpl.java b/opendaylight/adsal/containermanager/it.implementation/src/main/java/org/opendaylight/controller/containermanager/internal/ContainerImpl.java
deleted file mode 100644 (file)
index 27874dc..0000000
+++ /dev/null
@@ -1,80 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * @file   ContainerImpl.java
- *
- * @brief  Class that instantiated per-container implements the
- * interface IContainer
- *
- *
- */
-package org.opendaylight.controller.containermanager.internal;
-
-import java.util.Dictionary;
-import org.apache.felix.dm.Component;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import java.util.Set;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.ContainerFlow;
-import java.util.List;
-import org.opendaylight.controller.sal.core.IContainer;
-
-public class ContainerImpl implements IContainer {
-    private String containerName = null;
-    private String containerAdminRole;
-    private String containerOperatorRole;
-
-    /**
-     * Function called by the dependency manager when all the required
-     * dependencies are satisfied
-     *
-     */
-    void init(Component c) {
-        Dictionary<?, ?> props = c.getServiceProperties();
-        if (props != null) {
-            this.containerName = (String) props.get("containerName");
-        }
-    }
-
-    @Override
-    public String getName() {
-        return this.containerName;
-    }
-
-    @Override
-    public List<ContainerFlow> getContainerFlows() {
-        return null;
-    }
-
-    @Override
-    public short getTag(Node n) {
-        return (short) 0;
-    }
-
-    @Override
-    public Set<NodeConnector> getNodeConnectors() {
-        return null;
-    }
-
-    @Override
-    public Set<Node> getNodes() {
-        return null;
-    }
-
-    @Override
-    public String getContainerAdminRole() {
-        return containerAdminRole;
-    }
-
-    @Override
-    public String getContainerOperatorRole() {
-        return containerOperatorRole;
-    }
-}
diff --git a/opendaylight/adsal/containermanager/it.implementation/src/main/java/org/opendaylight/controller/containermanager/internal/ContainerManager.java b/opendaylight/adsal/containermanager/it.implementation/src/main/java/org/opendaylight/controller/containermanager/internal/ContainerManager.java
deleted file mode 100644 (file)
index f2219e5..0000000
+++ /dev/null
@@ -1,222 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * @file   ContainerManager.java
- *
- * @brief  Manage one or many Containers
- *
- *
- */
-package org.opendaylight.controller.containermanager.internal;
-
-import java.util.ArrayList;
-import java.util.Collections;
-import java.util.HashSet;
-import java.util.List;
-import java.util.Map;
-import java.util.Set;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import org.opendaylight.controller.clustering.services.IClusterGlobalServices;
-import org.opendaylight.controller.containermanager.ContainerConfig;
-import org.opendaylight.controller.containermanager.ContainerFlowConfig;
-import org.opendaylight.controller.containermanager.IContainerManager;
-import org.opendaylight.controller.sal.core.IContainerAware;
-import org.opendaylight.controller.sal.core.IContainerListener;
-import org.opendaylight.controller.sal.utils.GlobalConstants;
-import org.opendaylight.controller.sal.utils.Status;
-
-public class ContainerManager implements IContainerManager {
-    private static final Logger logger = LoggerFactory
-            .getLogger(ContainerManager.class);
-    private IClusterGlobalServices clusterServices;
-    /*
-     * Collection containing the configuration objects.
-     * This is configuration world: container names (also the map key)
-     * are maintained as they were configured by user, same case
-     */
-    private Set<IContainerAware> iContainerAware = Collections
-            .synchronizedSet(new HashSet<IContainerAware>());
-    private Set<IContainerListener> iContainerListener = Collections
-            .synchronizedSet(new HashSet<IContainerListener>());
-
-    void setIContainerListener(IContainerListener s) {
-        if (this.iContainerListener != null) {
-            this.iContainerListener.add(s);
-        }
-    }
-
-    void unsetIContainerListener(IContainerListener s) {
-        if (this.iContainerListener != null) {
-            this.iContainerListener.remove(s);
-        }
-    }
-
-    public void setIContainerAware(IContainerAware iContainerAware) {
-        if (!this.iContainerAware.contains(iContainerAware)) {
-            this.iContainerAware.add(iContainerAware);
-            // Now call the container creation for all the known containers so
-            // far
-            List<String> containerDB = getContainerNames();
-            if (containerDB != null) {
-                for (int i = 0; i < containerDB.size(); i++) {
-                    iContainerAware.containerCreate(containerDB.get(i));
-                }
-            }
-        }
-    }
-
-    public void unsetIContainerAware(IContainerAware iContainerAware) {
-        this.iContainerAware.remove(iContainerAware);
-        // There is no need to do cleanup of the component when
-        // unregister because it will be taken care by the Containerd
-        // component itself
-    }
-
-    public void setClusterServices(IClusterGlobalServices i) {
-        this.clusterServices = i;
-        logger.debug("IClusterServices set");
-    }
-
-    public void unsetClusterServices(IClusterGlobalServices i) {
-        if (this.clusterServices == i) {
-            this.clusterServices = null;
-            logger.debug("IClusterServices Unset");
-        }
-    }
-
-    public void init() {
-        logger.info("ContainerManager startup....");
-    }
-
-    public void destroy() {
-        // Clear local states
-        this.iContainerAware.clear();
-        this.iContainerListener.clear();
-
-        logger.info("ContainerManager Shutdown....");
-    }
-
-    @Override
-    public List<String> getContainerNames() {
-        /*
-         * Return container names as they were configured by user (case sensitive)
-         * along with the default container
-         */
-        List<String> containerNameList = new ArrayList<String>();
-        containerNameList.add(GlobalConstants.DEFAULT.toString());
-        return containerNameList;
-    }
-
-    @Override
-    public boolean hasNonDefaultContainer() {
-        return false;
-    }
-
-    @Override
-    public Status addContainer(ContainerConfig configObject) {
-        // TODO Auto-generated method stub
-        return null;
-    }
-
-    @Override
-    public Status removeContainer(ContainerConfig configObject) {
-        // TODO Auto-generated method stub
-        return null;
-    }
-
-    @Override
-    public Status removeContainer(String containerName) {
-        // TODO Auto-generated method stub
-        return null;
-    }
-
-    @Override
-    public Status addContainerEntry(String containerName, List<String> portList) {
-        // TODO Auto-generated method stub
-        return null;
-    }
-
-    @Override
-    public Status removeContainerEntry(String containerName,
-            List<String> portList) {
-        // TODO Auto-generated method stub
-        return null;
-    }
-
-    @Override
-    public Status addContainerFlows(String containerName,
-            List<ContainerFlowConfig> configObject) {
-        // TODO Auto-generated method stub
-        return null;
-    }
-
-    @Override
-    public Status removeContainerFlows(String containerName,
-            List<ContainerFlowConfig> configObject) {
-        // TODO Auto-generated method stub
-        return null;
-    }
-
-    @Override
-    public Status removeContainerFlows(String containerName, Set<String> name) {
-        // TODO Auto-generated method stub
-        return null;
-    }
-
-    @Override
-    public List<ContainerConfig> getContainerConfigList() {
-        // TODO Auto-generated method stub
-        return null;
-    }
-
-    @Override
-    public ContainerConfig getContainerConfig(String containerName) {
-        // TODO Auto-generated method stub
-        return null;
-    }
-
-    @Override
-    public List<String> getContainerNameList() {
-        // TODO Auto-generated method stub
-        return null;
-    }
-
-    @Override
-    public boolean doesContainerExist(String ContainerId) {
-        return GlobalConstants.DEFAULT.toString().equalsIgnoreCase(ContainerId);
-    }
-
-    @Override
-    public Map<String, List<ContainerFlowConfig>> getContainerFlows() {
-        // TODO Auto-generated method stub
-        return null;
-    }
-
-    @Override
-    public List<ContainerFlowConfig> getContainerFlows(String containerName) {
-        // TODO Auto-generated method stub
-        return null;
-    }
-
-    @Override
-    public List<String> getContainerFlowNameList(String containerName) {
-        // TODO Auto-generated method stub
-        return null;
-    }
-
-    @Override
-    public boolean inContainerMode() {
-        // TODO Auto-generated method stub
-        return false;
-    }
-
-}
diff --git a/opendaylight/adsal/containermanager/it.implementation/src/test/java/org/opendaylight/controller/containermanager/internal/ContainerImplTest.java b/opendaylight/adsal/containermanager/it.implementation/src/test/java/org/opendaylight/controller/containermanager/internal/ContainerImplTest.java
deleted file mode 100644 (file)
index cea81db..0000000
+++ /dev/null
@@ -1,61 +0,0 @@
-\r
-/*\r
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.\r
- *\r
- * This program and the accompanying materials are made available under the\r
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,\r
- * and is available at http://www.eclipse.org/legal/epl-v10.html\r
- */\r
-\r
-package org.opendaylight.controller.containermanager.internal;\r
-\r
-import org.apache.felix.dm.impl.ComponentImpl;\r
-import org.junit.Test;\r
-import org.opendaylight.controller.sal.core.Node;\r
-import org.opendaylight.controller.sal.utils.NodeCreator;\r
-\r
-import java.util.Hashtable;\r
-\r
-import static org.junit.Assert.assertNull;\r
-import static org.junit.Assert.assertEquals;\r
-\r
-public class ContainerImplTest {\r
-\r
-        @Test\r
-        public void test() {\r
-\r
-                ContainerImpl container1 = new ContainerImpl();\r
-\r
-                //Create Component for init\r
-                ComponentImpl component1 = new ComponentImpl(null, null, null);\r
-                component1.setInterface("serviceTestName", null);\r
-\r
-                //container1 does not have name yet\r
-                container1.init(component1);\r
-                assertNull(container1.getName());\r
-\r
-                //Sets container1 name to TestName\r
-                Hashtable<String, String> properties = new Hashtable<String, String>();\r
-                properties.put("dummyKey", "dummyValue");\r
-                properties.put("containerName", "TestName");\r
-                component1.setInterface("serviceTestName", properties);\r
-\r
-                container1.init(component1);\r
-                assertEquals("TestName", container1.getName());\r
-\r
-                //getContainerFlows always returns null for now\r
-                assertNull(container1.getContainerFlows());\r
-\r
-                //getTag always returns 0 for now\r
-                Node n = NodeCreator.createOFNode(1L);\r
-                assertEquals(0, container1.getTag(n));\r
-\r
-                //getNodeConnectors always returns null for now\r
-                assertNull(container1.getNodeConnectors());\r
-\r
-                //getNodes always returns null for now\r
-                assertNull(container1.getNodes());\r
-\r
-        }\r
-\r
-}\r
diff --git a/opendaylight/adsal/containermanager/it.implementation/src/test/java/org/opendaylight/controller/containermanager/internal/ContainerManagerTest.java b/opendaylight/adsal/containermanager/it.implementation/src/test/java/org/opendaylight/controller/containermanager/internal/ContainerManagerTest.java
deleted file mode 100644 (file)
index 53f19de..0000000
+++ /dev/null
@@ -1,40 +0,0 @@
-\r
-/*\r
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.\r
- *\r
- * This program and the accompanying materials are made available under the\r
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,\r
- * and is available at http://www.eclipse.org/legal/epl-v10.html\r
- */\r
-\r
-package org.opendaylight.controller.containermanager.internal;\r
-\r
-\r
-import org.junit.Test;\r
-import org.opendaylight.controller.sal.utils.GlobalConstants;\r
-\r
-import java.util.ArrayList;\r
-\r
-import static org.junit.Assert.assertEquals;\r
-import static org.junit.Assert.assertFalse;\r
-\r
-\r
-public class ContainerManagerTest {\r
-\r
-        @Test\r
-        public void test() {\r
-                ContainerManager cm = new ContainerManager();\r
-\r
-                cm.init();\r
-\r
-                ArrayList<String> names = (ArrayList<String>) cm.getContainerNames();\r
-                assertEquals(1, names.size());\r
-                assertEquals(GlobalConstants.DEFAULT.toString(), names.get(0));\r
-\r
-                assertFalse(cm.hasNonDefaultContainer());\r
-\r
-                cm.destroy();\r
-\r
-        }\r
-\r
-}\r
diff --git a/opendaylight/adsal/containermanager/shell/pom.xml b/opendaylight/adsal/containermanager/shell/pom.xml
deleted file mode 100644 (file)
index aa3c457..0000000
+++ /dev/null
@@ -1,52 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-  <artifactId>containermanager.shell</artifactId>
-  <version>${containermanager.shell.version}</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.apache.karaf.shell</groupId>
-      <artifactId>org.apache.karaf.shell.console</artifactId>
-      <version>${karaf.shell.version}</version>
-    </dependency>
-    <dependency>
-      <groupId>org.mockito</groupId>
-      <artifactId>mockito-all</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>containermanager</artifactId>
-      <version>${containermanager.version}</version>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <version>${bundle.plugin.version}</version>
-        <configuration>
-          <instructions>
-            <Import-Package>org.apache.felix.service.command,
-              org.apache.karaf.shell.commands,
-              org.apache.karaf.shell.console,
-              *</Import-Package>
-          </instructions>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-
-</project>
diff --git a/opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/AddContainer.java b/opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/AddContainer.java
deleted file mode 100644 (file)
index 2b75d54..0000000
+++ /dev/null
@@ -1,29 +0,0 @@
-package org.opendaylight.controller.containermanager.shell;
-
-import org.apache.karaf.shell.commands.Command;
-import org.apache.karaf.shell.commands.Argument;
-import org.apache.karaf.shell.console.OsgiCommandSupport;
-import org.opendaylight.controller.containermanager.IContainerManagerShell;
-
-@Command(scope = "containermanager", name = "addcontainer", description="Add Container")
-public class AddContainer extends OsgiCommandSupport{
-    private IContainerManagerShell containerManager;
-
-    @Argument(index=0, name="containerName", description="container name", required=true, multiValued=false)
-    String containerName = null;
-
-    @Argument(index=1, name="staticVlan", description="staticVlan", required=true, multiValued=false)
-    String staticVlan = null;
-
-    @Override
-    protected Object doExecute() throws Exception {
-        for(String p : containerManager.addContainer(containerName, staticVlan)) {
-            System.out.println(p);
-        }
-        return null;
-    }
-
-    public void setContainerManager(IContainerManagerShell containerManager){
-        this.containerManager = containerManager;
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/AddContainerEntry.java b/opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/AddContainerEntry.java
deleted file mode 100644 (file)
index 936e1d5..0000000
+++ /dev/null
@@ -1,32 +0,0 @@
-package org.opendaylight.controller.containermanager.shell;
-
-import org.apache.karaf.shell.commands.Command;
-import org.apache.karaf.shell.commands.Argument;
-import org.apache.karaf.shell.console.OsgiCommandSupport;
-import org.opendaylight.controller.containermanager.IContainerManagerShell;
-
-@Command(scope = "containermanager", name = "AddContainerEntry", description="add container entry")
-public class AddContainerEntry extends OsgiCommandSupport{
-    private IContainerManagerShell containerManager;
-
-    @Argument(index=0, name="containerName", description="container name", required=true, multiValued=false)
-    String containerName = null;
-
-    @Argument(index=1, name="nodeId", description="node ID", required=true, multiValued=false)
-    String nodeId = null;
-
-    @Argument(index=2, name="portId", description="portId", required=true, multiValued=false)
-    String portId = null;
-
-    @Override
-    protected Object doExecute() throws Exception {
-        for(String p : containerManager.addContainerEntry(containerName, nodeId, portId)) {
-            System.out.println(p);
-        }
-        return null;
-    }
-
-    public void setContainerManager(IContainerManagerShell containerManager){
-        this.containerManager = containerManager;
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/AddContainerFlow.java b/opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/AddContainerFlow.java
deleted file mode 100644 (file)
index bbfbc2f..0000000
+++ /dev/null
@@ -1,32 +0,0 @@
-package org.opendaylight.controller.containermanager.shell;
-
-import org.apache.karaf.shell.commands.Command;
-import org.apache.karaf.shell.commands.Argument;
-import org.apache.karaf.shell.console.OsgiCommandSupport;
-import org.opendaylight.controller.containermanager.IContainerManagerShell;
-
-@Command(scope = "containermanager", name = "addContainerFlow", description="adds container flow")
-public class AddContainerFlow extends OsgiCommandSupport{
-    private IContainerManagerShell containerManager;
-
-    @Argument(index=0, name="containerName", description="container name", required=true, multiValued=false)
-    String containerName = null;
-
-    @Argument(index=1, name="cflowName", description="c Flow name", required=true, multiValued=false)
-    String cflowName = null;
-
-    @Argument(index=2, name="unidirectional", description="unidirectional", required=true, multiValued=false)
-    String unidirectional = null;
-
-    @Override
-    protected Object doExecute() throws Exception {
-        for(String p : containerManager.addContainerFlow(containerName, cflowName, unidirectional)) {
-            System.out.println(p);
-        }
-        return null;
-    }
-
-    public void setContainerManager(IContainerManagerShell containerManager){
-        this.containerManager = containerManager;
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/ContainermgrGetAuthorizedGroups.java b/opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/ContainermgrGetAuthorizedGroups.java
deleted file mode 100644 (file)
index 72f82fd..0000000
+++ /dev/null
@@ -1,26 +0,0 @@
-package org.opendaylight.controller.containermanager.shell;
-
-import org.apache.karaf.shell.commands.Command;
-import org.apache.karaf.shell.commands.Argument;
-import org.apache.karaf.shell.console.OsgiCommandSupport;
-import org.opendaylight.controller.containermanager.IContainerManagerShell;
-
-@Command(scope = "containermanager", name = "containermgrGetAuthorizedGroups", description="Get authorized groups")
-public class ContainermgrGetAuthorizedGroups extends OsgiCommandSupport{
-    private IContainerManagerShell containerManager;
-
-    @Argument(index=0, name="roleName", description="role name", required=true, multiValued=false)
-    String roleName = null;
-
-    @Override
-    protected Object doExecute() throws Exception {
-        for(String p : containerManager.containermgrGetAuthorizedGroups(roleName)) {
-            System.out.println(p);
-        }
-        return null;
-    }
-
-    public void setContainerManager(IContainerManagerShell containerManager){
-        this.containerManager = containerManager;
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/ContainermgrGetAuthorizedResources.java b/opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/ContainermgrGetAuthorizedResources.java
deleted file mode 100644 (file)
index d625d09..0000000
+++ /dev/null
@@ -1,26 +0,0 @@
-package org.opendaylight.controller.containermanager.shell;
-
-import org.apache.karaf.shell.commands.Command;
-import org.apache.karaf.shell.commands.Argument;
-import org.apache.karaf.shell.console.OsgiCommandSupport;
-import org.opendaylight.controller.containermanager.IContainerManagerShell;
-
-@Command(scope = "containermanager", name = "containermgrGetAuthorizedResources", description="Get authorized resources")
-public class ContainermgrGetAuthorizedResources extends OsgiCommandSupport{
-    private IContainerManagerShell containerManager;
-
-    @Argument(index=0, name="roleName", description="role name", required=true, multiValued=false)
-    String roleName = null;
-
-    @Override
-    protected Object doExecute() throws Exception {
-        for(String p : containerManager.containermgrGetAuthorizedResources(roleName)) {
-            System.out.println(p);
-        }
-        return null;
-    }
-
-    public void setContainerManager(IContainerManagerShell containerManager){
-        this.containerManager = containerManager;
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/ContainermgrGetResourcesForGroup.java b/opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/ContainermgrGetResourcesForGroup.java
deleted file mode 100644 (file)
index e21eed6..0000000
+++ /dev/null
@@ -1,26 +0,0 @@
-package org.opendaylight.controller.containermanager.shell;
-
-import org.apache.karaf.shell.commands.Command;
-import org.apache.karaf.shell.commands.Argument;
-import org.apache.karaf.shell.console.OsgiCommandSupport;
-import org.opendaylight.controller.containermanager.IContainerManagerShell;
-
-@Command(scope = "containermanager", name = "containermgrGetResourcesForGroup", description="Get resources for group")
-public class ContainermgrGetResourcesForGroup extends OsgiCommandSupport{
-    private IContainerManagerShell containerManager;
-
-    @Argument(index=0, name="groupName", description="group name", required=true, multiValued=false)
-    String groupName = null;
-
-    @Override
-    protected Object doExecute() throws Exception {
-        for(String p : containerManager.containermgrGetResourcesForGroup(groupName)) {
-            System.out.println(p);
-        }
-        return null;
-    }
-
-    public void setContainerManager(IContainerManagerShell containerManager){
-        this.containerManager = containerManager;
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/ContainermgrGetRoles.java b/opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/ContainermgrGetRoles.java
deleted file mode 100644 (file)
index 4f8fa14..0000000
+++ /dev/null
@@ -1,22 +0,0 @@
-package org.opendaylight.controller.containermanager.shell;
-
-import org.apache.karaf.shell.commands.Command;
-import org.apache.karaf.shell.console.OsgiCommandSupport;
-import org.opendaylight.controller.containermanager.IContainerManagerShell;
-
-@Command(scope = "containermanager", name = "containermgrGetRoles", description="Get container mgr roles")
-public class ContainermgrGetRoles extends OsgiCommandSupport{
-    private IContainerManagerShell containerManager;
-
-    @Override
-    protected Object doExecute() throws Exception {
-        for(String p : containerManager.containermgrGetRoles()) {
-            System.out.println(p);
-        }
-        return null;
-    }
-
-    public void setContainerManager(IContainerManagerShell containerManager){
-        this.containerManager = containerManager;
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/ContainermgrGetUserLevel.java b/opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/ContainermgrGetUserLevel.java
deleted file mode 100644 (file)
index e47cc12..0000000
+++ /dev/null
@@ -1,26 +0,0 @@
-package org.opendaylight.controller.containermanager.shell;
-
-import org.apache.karaf.shell.commands.Command;
-import org.apache.karaf.shell.commands.Argument;
-import org.apache.karaf.shell.console.OsgiCommandSupport;
-import org.opendaylight.controller.containermanager.IContainerManagerShell;
-
-@Command(scope = "containermanager", name = "containermgrGetUserLevel", description="Get user level")
-public class ContainermgrGetUserLevel extends OsgiCommandSupport{
-    private IContainerManagerShell containerManager;
-
-    @Argument(index=0, name="userName", description="user name", required=true, multiValued=false)
-    String userName = null;
-
-    @Override
-    protected Object doExecute() throws Exception {
-        for(String p : containerManager.containermgrGetUserLevel(userName)) {
-            System.out.println(p);
-        }
-        return null;
-    }
-
-    public void setContainerManager(IContainerManagerShell containerManager){
-        this.containerManager = containerManager;
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/ContainermgrGetUserResources.java b/opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/ContainermgrGetUserResources.java
deleted file mode 100644 (file)
index da19499..0000000
+++ /dev/null
@@ -1,26 +0,0 @@
-package org.opendaylight.controller.containermanager.shell;
-
-import org.apache.karaf.shell.commands.Command;
-import org.apache.karaf.shell.commands.Argument;
-import org.apache.karaf.shell.console.OsgiCommandSupport;
-import org.opendaylight.controller.containermanager.IContainerManagerShell;
-
-@Command(scope = "containermanager", name = "containermgrGetUserResources", description="Get user resources")
-public class ContainermgrGetUserResources extends OsgiCommandSupport{
-    private IContainerManagerShell containerManager;
-
-    @Argument(index=0, name="userName", description="user name", required=true, multiValued=false)
-    String userName = null;
-
-    @Override
-    protected Object doExecute() throws Exception {
-        for(String p : containerManager.containermgrGetUserResources(userName)) {
-            System.out.println(p);
-        }
-        return null;
-    }
-
-    public void setContainerManager(IContainerManagerShell containerManager){
-        this.containerManager = containerManager;
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/CreateContainer.java b/opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/CreateContainer.java
deleted file mode 100644 (file)
index 0f74d40..0000000
+++ /dev/null
@@ -1,29 +0,0 @@
-package org.opendaylight.controller.containermanager.shell;
-
-import org.apache.karaf.shell.commands.Command;
-import org.apache.karaf.shell.commands.Argument;
-import org.apache.karaf.shell.console.OsgiCommandSupport;
-import org.opendaylight.controller.containermanager.IContainerManagerShell;
-
-@Command(scope = "containermanager", name = "createcontainer", description="create container")
-public class CreateContainer extends OsgiCommandSupport{
-    private IContainerManagerShell containerManager;
-
-    @Argument(index=0, name="containerName", description="container name", required=true, multiValued=false)
-    String containerName = null;
-
-    @Argument(index=1, name="staticVlan", description="staticVlan", required=true, multiValued=false)
-    String staticVlan = null;
-
-    @Override
-    protected Object doExecute() throws Exception {
-        for(String p : containerManager.createContainer(containerName, staticVlan)) {
-            System.out.println(p);
-        }
-        return null;
-    }
-
-    public void setContainerManager(IContainerManagerShell containerManager){
-        this.containerManager = containerManager;
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/Pfc.java b/opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/Pfc.java
deleted file mode 100644 (file)
index 72ee7f2..0000000
+++ /dev/null
@@ -1,22 +0,0 @@
-package org.opendaylight.controller.containermanager.shell;
-
-import org.apache.karaf.shell.commands.Command;
-import org.apache.karaf.shell.console.OsgiCommandSupport;
-import org.opendaylight.controller.containermanager.IContainerManagerShell;
-
-@Command(scope = "containermanager", name = "pfc", description="Display pfc")
-public class Pfc extends OsgiCommandSupport{
-    private IContainerManagerShell containerManager;
-
-    @Override
-    protected Object doExecute() throws Exception {
-        for(String p : containerManager.pfc()) {
-            System.out.println(p);
-        }
-        return null;
-    }
-
-    public void setContainerManager(IContainerManagerShell containerManager){
-        this.containerManager = containerManager;
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/Psc.java b/opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/Psc.java
deleted file mode 100644 (file)
index 6604748..0000000
+++ /dev/null
@@ -1,22 +0,0 @@
-package org.opendaylight.controller.containermanager.shell;
-
-import org.apache.karaf.shell.commands.Command;
-import org.apache.karaf.shell.console.OsgiCommandSupport;
-import org.opendaylight.controller.containermanager.IContainerManagerShell;
-
-@Command(scope = "containermanager", name = "psc", description="Display ")
-public class Psc extends OsgiCommandSupport{
-    private IContainerManagerShell containerManager;
-
-    @Override
-    protected Object doExecute() throws Exception {
-        for(String p : containerManager.psc()) {
-            System.out.println(p);
-        }
-        return null;
-    }
-
-    public void setContainerManager(IContainerManagerShell containerManager){
-        this.containerManager = containerManager;
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/Psd.java b/opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/Psd.java
deleted file mode 100644 (file)
index c637048..0000000
+++ /dev/null
@@ -1,22 +0,0 @@
-package org.opendaylight.controller.containermanager.shell;
-
-import org.apache.karaf.shell.commands.Command;
-import org.apache.karaf.shell.console.OsgiCommandSupport;
-import org.opendaylight.controller.containermanager.IContainerManagerShell;
-
-@Command(scope = "containermanager", name = "psd", description="Display psd")
-public class Psd extends OsgiCommandSupport{
-    private IContainerManagerShell containerManager;
-
-    @Override
-    protected Object doExecute() throws Exception {
-        for(String p : containerManager.psd()) {
-            System.out.println(p);
-        }
-        return null;
-    }
-
-    public void setContainerManager(IContainerManagerShell containerManager){
-        this.containerManager = containerManager;
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/Psm.java b/opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/Psm.java
deleted file mode 100644 (file)
index ca5d96b..0000000
+++ /dev/null
@@ -1,22 +0,0 @@
-package org.opendaylight.controller.containermanager.shell;
-
-import org.apache.karaf.shell.commands.Command;
-import org.apache.karaf.shell.console.OsgiCommandSupport;
-import org.opendaylight.controller.containermanager.IContainerManagerShell;
-
-@Command(scope = "containermanager", name = "psm", description="Display psm")
-public class Psm extends OsgiCommandSupport{
-    private IContainerManagerShell containerManager;
-
-    @Override
-    protected Object doExecute() throws Exception {
-        for(String p : containerManager.psm()) {
-            System.out.println(p);
-        }
-        return null;
-    }
-
-    public void setContainerManager(IContainerManagerShell containerManager){
-        this.containerManager = containerManager;
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/Psp.java b/opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/Psp.java
deleted file mode 100644 (file)
index a38c5ab..0000000
+++ /dev/null
@@ -1,22 +0,0 @@
-package org.opendaylight.controller.containermanager.shell;
-
-import org.apache.karaf.shell.commands.Command;
-import org.apache.karaf.shell.console.OsgiCommandSupport;
-import org.opendaylight.controller.containermanager.IContainerManagerShell;
-
-@Command(scope = "containermanager", name = "psp", description="Display psp")
-public class Psp extends OsgiCommandSupport{
-    private IContainerManagerShell containerManager;
-
-    @Override
-    protected Object doExecute() throws Exception {
-        for(String p : containerManager.psp()) {
-            System.out.println(p);
-        }
-        return null;
-    }
-
-    public void setContainerManager(IContainerManagerShell containerManager){
-        this.containerManager = containerManager;
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/RemoveContainer.java b/opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/RemoveContainer.java
deleted file mode 100644 (file)
index 0c6322a..0000000
+++ /dev/null
@@ -1,26 +0,0 @@
-package org.opendaylight.controller.containermanager.shell;
-
-import org.apache.karaf.shell.commands.Command;
-import org.apache.karaf.shell.commands.Argument;
-import org.apache.karaf.shell.console.OsgiCommandSupport;
-import org.opendaylight.controller.containermanager.IContainerManagerShell;
-
-@Command(scope = "containermanager", name = "removecontainer", description="remove container")
-public class RemoveContainer extends OsgiCommandSupport{
-    private IContainerManagerShell containerManager;
-
-    @Argument(index=0, name="containerName", description="container name", required=true, multiValued=false)
-    String containerName = null;
-
-    @Override
-    protected Object doExecute() throws Exception {
-        for(String p : containerManager.removeContainerShell(containerName)) {
-            System.out.println(p);
-        }
-        return null;
-    }
-
-    public void setContainerManager(IContainerManagerShell containerManager){
-        this.containerManager = containerManager;
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/RemoveContainerEntry.java b/opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/RemoveContainerEntry.java
deleted file mode 100644 (file)
index c126a03..0000000
+++ /dev/null
@@ -1,32 +0,0 @@
-package org.opendaylight.controller.containermanager.shell;
-
-import org.apache.karaf.shell.commands.Command;
-import org.apache.karaf.shell.commands.Argument;
-import org.apache.karaf.shell.console.OsgiCommandSupport;
-import org.opendaylight.controller.containermanager.IContainerManagerShell;
-
-@Command(scope = "containermanager", name = "removeContainerEntry", description="remove container entry")
-public class RemoveContainerEntry extends OsgiCommandSupport{
-    private IContainerManagerShell containerManager;
-
-    @Argument(index=0, name="containerName", description="container name", required=true, multiValued=false)
-    String containerName = null;
-
-    @Argument(index=1, name="nodeId", description="node ID", required=true, multiValued=false)
-    String nodeId = null;
-
-    @Argument(index=2, name="portId", description="portId", required=true, multiValued=false)
-    String portId = null;
-
-    @Override
-    protected Object doExecute() throws Exception {
-        for(String p : containerManager.removeContainerEntry(containerName, nodeId, portId)) {
-            System.out.println(p);
-        }
-        return null;
-    }
-
-    public void setContainerManager(IContainerManagerShell containerManager){
-        this.containerManager = containerManager;
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/RemoveContainerFlow.java b/opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/RemoveContainerFlow.java
deleted file mode 100644 (file)
index 8ba532a..0000000
+++ /dev/null
@@ -1,29 +0,0 @@
-package org.opendaylight.controller.containermanager.shell;
-
-import org.apache.karaf.shell.commands.Command;
-import org.apache.karaf.shell.commands.Argument;
-import org.apache.karaf.shell.console.OsgiCommandSupport;
-import org.opendaylight.controller.containermanager.IContainerManagerShell;
-
-@Command(scope = "containermanager", name = "removeContainerFlow", description="removes container flow")
-public class RemoveContainerFlow extends OsgiCommandSupport{
-    private IContainerManagerShell containerManager;
-
-    @Argument(index=0, name="containerName", description="container name", required=true, multiValued=false)
-    String containerName = null;
-
-    @Argument(index=1, name="cflowName", description="c Flow name", required=true, multiValued=false)
-    String cflowName = null;
-
-    @Override
-    protected Object doExecute() throws Exception {
-        for(String p : containerManager.removeContainerFlow(containerName, cflowName)) {
-            System.out.println(p);
-        }
-        return null;
-    }
-
-    public void setContainerManager(IContainerManagerShell containerManager){
-        this.containerManager = containerManager;
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/SaveConfig.java b/opendaylight/adsal/containermanager/shell/src/main/java/org/opendaylight/controller/containermanager/shell/SaveConfig.java
deleted file mode 100644 (file)
index c4b7a9c..0000000
+++ /dev/null
@@ -1,22 +0,0 @@
-package org.opendaylight.controller.containermanager.shell;
-
-import org.apache.karaf.shell.commands.Command;
-import org.apache.karaf.shell.console.OsgiCommandSupport;
-import org.opendaylight.controller.containermanager.IContainerManagerShell;
-
-@Command(scope = "containermanager", name = "saveConfig", description="Save config")
-public class SaveConfig extends OsgiCommandSupport{
-    private IContainerManagerShell containerManager;
-
-    @Override
-    protected Object doExecute() throws Exception {
-        for(String p : containerManager.saveConfig()) {
-            System.out.println(p);
-        }
-        return null;
-    }
-
-    public void setContainerManager(IContainerManagerShell containerManager){
-        this.containerManager = containerManager;
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/containermanager/shell/src/main/resources/OSGI-INF/blueprint/blueprint.xml b/opendaylight/adsal/containermanager/shell/src/main/resources/OSGI-INF/blueprint/blueprint.xml
deleted file mode 100644 (file)
index e7e01f8..0000000
+++ /dev/null
@@ -1,123 +0,0 @@
-<blueprint xmlns="http://www.osgi.org/xmlns/blueprint/v1.0.0">
-
-    <reference id="containerManagerRef" interface="org.opendaylight.controller.containermanager.IContainerManagerShell"/>
-    <command-bundle xmlns="http://karaf.apache.org/xmlns/shell/v1.1.0">
-
-        <command>
-        <action class="org.opendaylight.controller.containermanager.shell.AddContainer">
-            <property name="containerManager" ref="containerManagerRef"/>
-            </action>
-        </command>
-
-        <command>
-        <action class="org.opendaylight.controller.containermanager.shell.AddContainerEntry">
-            <property name="containerManager" ref="containerManagerRef"/>
-            </action>
-        </command>
-
-        <command>
-        <action class="org.opendaylight.controller.containermanager.shell.AddContainerFlow">
-            <property name="containerManager" ref="containerManagerRef"/>
-            </action>
-        </command>
-
-        <command>
-        <action class="org.opendaylight.controller.containermanager.shell.ContainermgrGetAuthorizedGroups">
-            <property name="containerManager" ref="containerManagerRef"/>
-            </action>
-        </command>
-
-        <command>
-        <action class="org.opendaylight.controller.containermanager.shell.ContainermgrGetAuthorizedResources">
-            <property name="containerManager" ref="containerManagerRef"/>
-            </action>
-        </command>
-
-        <command>
-        <action class="org.opendaylight.controller.containermanager.shell.ContainermgrGetResourcesForGroup">
-            <property name="containerManager" ref="containerManagerRef"/>
-            </action>
-        </command>
-
-        <command>
-        <action class="org.opendaylight.controller.containermanager.shell.ContainermgrGetRoles">
-            <property name="containerManager" ref="containerManagerRef"/>
-            </action>
-        </command>
-
-        <command>
-        <action class="org.opendaylight.controller.containermanager.shell.ContainermgrGetUserLevel">
-            <property name="containerManager" ref="containerManagerRef"/>
-            </action>
-        </command>
-
-        <command>
-        <action class="org.opendaylight.controller.containermanager.shell.ContainermgrGetUserResources">
-            <property name="containerManager" ref="containerManagerRef"/>
-            </action>
-        </command>
-
-        <command>
-        <action class="org.opendaylight.controller.containermanager.shell.CreateContainer">
-            <property name="containerManager" ref="containerManagerRef"/>
-            </action>
-        </command>
-
-        <command>
-        <action class="org.opendaylight.controller.containermanager.shell.Pfc">
-            <property name="containerManager" ref="containerManagerRef"/>
-            </action>
-        </command>
-
-        <command>
-        <action class="org.opendaylight.controller.containermanager.shell.Psc">
-            <property name="containerManager" ref="containerManagerRef"/>
-            </action>
-        </command>
-
-        <command>
-        <action class="org.opendaylight.controller.containermanager.shell.Psd">
-            <property name="containerManager" ref="containerManagerRef"/>
-            </action>
-        </command>
-
-        <command>
-        <action class="org.opendaylight.controller.containermanager.shell.Psm">
-            <property name="containerManager" ref="containerManagerRef"/>
-            </action>
-        </command>
-
-        <command>
-        <action class="org.opendaylight.controller.containermanager.shell.Psp">
-            <property name="containerManager" ref="containerManagerRef"/>
-            </action>
-        </command>
-
-        <command>
-        <action class="org.opendaylight.controller.containermanager.shell.RemoveContainer">
-            <property name="containerManager" ref="containerManagerRef"/>
-            </action>
-        </command>
-
-        <command>
-        <action class="org.opendaylight.controller.containermanager.shell.RemoveContainerEntry">
-            <property name="containerManager" ref="containerManagerRef"/>
-            </action>
-        </command>
-
-        <command>
-        <action class="org.opendaylight.controller.containermanager.shell.RemoveContainerFlow">
-            <property name="containerManager" ref="containerManagerRef"/>
-            </action>
-        </command>
-
-        <command>
-        <action class="org.opendaylight.controller.containermanager.shell.SaveConfig">
-            <property name="containerManager" ref="containerManagerRef"/>
-            </action>
-        </command>
-
-    </command-bundle>
-
-
-</blueprint>
diff --git a/opendaylight/adsal/containermanager/shell/src/test/java/org/opendaylight/controller/containermanager/shell/ContainerManagerShellTest.java b/opendaylight/adsal/containermanager/shell/src/test/java/org/opendaylight/controller/containermanager/shell/ContainerManagerShellTest.java
deleted file mode 100644 (file)
index f11d1da..0000000
+++ /dev/null
@@ -1,368 +0,0 @@
-package org.opendaylight.controller.containermanager.shell;
-
-import java.io.ByteArrayOutputStream;
-import java.io.PrintStream;
-import java.util.ArrayList;
-import java.util.Arrays;
-import java.util.List;
-import java.lang.reflect.Field;
-
-import org.junit.Assert;
-import org.junit.Test;
-import static org.mockito.Mockito.mock;
-import static org.mockito.Mockito.when;
-import org.opendaylight.controller.containermanager.IContainerManagerShell;
-
-
-public class ContainerManagerShellTest {
-    private IContainerManagerShell containerManager;
-
-    @Test
-    public void testAddContainer() throws Exception {
-        String containerName = "test", staticVlan = "1234";
-        AddContainer addConTest = new AddContainer();
-        containerManager = mock(IContainerManagerShell.class);
-        List<String> result = new ArrayList<String>(Arrays.asList("status"));
-        List<String> result2 = new ArrayList<String>(Arrays.asList("Container Name not specified"));
-        when(containerManager.addContainer(containerName, staticVlan)).thenReturn(result);
-        when(containerManager.addContainer(null, null)).thenReturn(result2);
-
-        Field cNField = addConTest.getClass().getDeclaredField("containerName");
-        cNField.setAccessible(true);
-        Field sVField = addConTest.getClass().getDeclaredField("staticVlan");
-        sVField.setAccessible(true);
-
-        cNField.set(addConTest, "test");
-        sVField.set(addConTest, "1234");
-
-        addConTest.setContainerManager(containerManager);
-        ByteArrayOutputStream baos = new ByteArrayOutputStream();
-        System.setOut(new PrintStream(baos));
-        addConTest.doExecute();
-        Assert.assertEquals("status\n", baos.toString());
-        baos.reset();
-
-        cNField.set(addConTest, null);
-        sVField.set(addConTest, null);
-        addConTest.doExecute();
-        Assert.assertEquals("Container Name not specified\n", baos.toString());
-    }
-
-    @Test
-    public void testAddContainerEntry() throws Exception {
-        String containerName = "test", nodeId = "1234", portId = "5678";
-        AddContainerEntry addConEntTest = new AddContainerEntry();
-        containerManager = mock(IContainerManagerShell.class);
-        List<String> result = new ArrayList<String>(Arrays.asList("status"));
-        when(containerManager.addContainerEntry(containerName, nodeId, portId)).thenReturn(result);
-
-        Field cNField = addConEntTest.getClass().getDeclaredField("containerName");
-        cNField.setAccessible(true);
-        Field nIField = addConEntTest.getClass().getDeclaredField("nodeId");
-        nIField.setAccessible(true);
-        Field pIField = addConEntTest.getClass().getDeclaredField("portId");
-        pIField.setAccessible(true);
-
-        cNField.set(addConEntTest, "test");
-        nIField.set(addConEntTest, "1234");
-        pIField.set(addConEntTest, "5678");
-
-        addConEntTest.setContainerManager(containerManager);
-        ByteArrayOutputStream baos = new ByteArrayOutputStream();
-        System.setOut(new PrintStream(baos));
-        addConEntTest.doExecute();
-        Assert.assertEquals("status\n", baos.toString());
-    }
-
-    @Test
-    public void testAddContainerFlow() throws Exception {
-        String containerName = "test", cflowName = "1234", unidirectional = "5678";
-        AddContainerFlow addConFlowTest = new AddContainerFlow();
-        containerManager = mock(IContainerManagerShell.class);
-        List<String> result = new ArrayList<String>(Arrays.asList("status"));
-        when(containerManager.addContainerFlow(containerName, cflowName, unidirectional)).thenReturn(result);
-
-        Field cNField = addConFlowTest.getClass().getDeclaredField("containerName");
-        cNField.setAccessible(true);
-        Field cfField = addConFlowTest.getClass().getDeclaredField("cflowName");
-        cfField.setAccessible(true);
-        Field unField = addConFlowTest.getClass().getDeclaredField("unidirectional");
-        unField.setAccessible(true);
-
-        cNField.set(addConFlowTest, "test");
-        cfField.set(addConFlowTest, "1234");
-        unField.set(addConFlowTest, "5678");
-
-        addConFlowTest.setContainerManager(containerManager);
-        ByteArrayOutputStream baos = new ByteArrayOutputStream();
-        System.setOut(new PrintStream(baos));
-        addConFlowTest.doExecute();
-        Assert.assertEquals("status\n", baos.toString());
-    }
-
-    @Test
-    public void testContainermgrGetAuthorizedGroups() throws Exception {
-        String roleName = "test";
-        ContainermgrGetAuthorizedGroups contmgrGTest = new ContainermgrGetAuthorizedGroups();
-        containerManager = mock(IContainerManagerShell.class);
-        List<String> result = new ArrayList<String>(Arrays.asList("status"));
-        when(containerManager.containermgrGetAuthorizedGroups(roleName)).thenReturn(result);
-
-        Field rNField = contmgrGTest.getClass().getDeclaredField("roleName");
-        rNField.setAccessible(true);
-
-        rNField.set(contmgrGTest, "test");
-
-        contmgrGTest.setContainerManager(containerManager);
-        ByteArrayOutputStream baos = new ByteArrayOutputStream();
-        System.setOut(new PrintStream(baos));
-        contmgrGTest.doExecute();
-        Assert.assertEquals("status\n", baos.toString());
-    }
-
-    @Test
-    public void testContainermgrGetAuthorizedResources() throws Exception {
-        String roleName = "test";
-        ContainermgrGetAuthorizedResources contmgrRTest = new ContainermgrGetAuthorizedResources();
-        containerManager = mock(IContainerManagerShell.class);
-        List<String> result = new ArrayList<String>(Arrays.asList("status"));
-        when(containerManager.containermgrGetAuthorizedResources(roleName)).thenReturn(result);
-
-        Field rNField = contmgrRTest.getClass().getDeclaredField("roleName");
-        rNField.setAccessible(true);
-
-        rNField.set(contmgrRTest, "test");
-
-        contmgrRTest.setContainerManager(containerManager);
-        ByteArrayOutputStream baos = new ByteArrayOutputStream();
-        System.setOut(new PrintStream(baos));
-        contmgrRTest.doExecute();
-        Assert.assertEquals("status\n", baos.toString());
-    }
-
-    @Test
-    public void testContainermgrGetResourcesForGroup() throws Exception {
-        String groupName = "test";
-        ContainermgrGetResourcesForGroup contmgrRTest = new ContainermgrGetResourcesForGroup();
-        containerManager = mock(IContainerManagerShell.class);
-        List<String> result = new ArrayList<String>(Arrays.asList("status"));
-        when(containerManager.containermgrGetResourcesForGroup(groupName)).thenReturn(result);
-
-        Field gNField = contmgrRTest.getClass().getDeclaredField("groupName");
-        gNField.setAccessible(true);
-
-        gNField.set(contmgrRTest, groupName);
-
-        contmgrRTest.setContainerManager(containerManager);
-        ByteArrayOutputStream baos = new ByteArrayOutputStream();
-        System.setOut(new PrintStream(baos));
-        contmgrRTest.doExecute();
-        Assert.assertEquals("status\n", baos.toString());
-    }
-
-    @Test
-    public void testContainermgrGetRoles() throws Exception {
-        ContainermgrGetRoles contmgrRTest = new ContainermgrGetRoles();
-        containerManager = mock(IContainerManagerShell.class);
-        List<String> result = new ArrayList<String>(Arrays.asList("status"));
-        when(containerManager.containermgrGetRoles()).thenReturn(result);
-
-        contmgrRTest.setContainerManager(containerManager);
-        ByteArrayOutputStream baos = new ByteArrayOutputStream();
-        System.setOut(new PrintStream(baos));
-        contmgrRTest.doExecute();
-        Assert.assertEquals("status\n", baos.toString());
-    }
-
-    @Test
-    public void testContainermgrGetUserLevel() throws Exception {
-        String userName = "test";
-        ContainermgrGetUserLevel contmgrUTest = new ContainermgrGetUserLevel();
-        containerManager = mock(IContainerManagerShell.class);
-        List<String> result = new ArrayList<String>(Arrays.asList("status"));
-        when(containerManager.containermgrGetUserLevel(userName)).thenReturn(result);
-
-        Field gNField = contmgrUTest.getClass().getDeclaredField("userName");
-        gNField.setAccessible(true);
-
-        gNField.set(contmgrUTest, userName);
-
-        contmgrUTest.setContainerManager(containerManager);
-        ByteArrayOutputStream baos = new ByteArrayOutputStream();
-        System.setOut(new PrintStream(baos));
-        contmgrUTest.doExecute();
-        Assert.assertEquals("status\n", baos.toString());
-    }
-
-    @Test
-    public void testContainermgrGetUserResources() throws Exception {
-        String userName = "test";
-        ContainermgrGetUserResources contmgrUTest = new ContainermgrGetUserResources();
-        containerManager = mock(IContainerManagerShell.class);
-        List<String> result = new ArrayList<String>(Arrays.asList("status"));
-        when(containerManager.containermgrGetUserResources(userName)).thenReturn(result);
-
-        Field gNField = contmgrUTest.getClass().getDeclaredField("userName");
-        gNField.setAccessible(true);
-
-        gNField.set(contmgrUTest, userName);
-
-        contmgrUTest.setContainerManager(containerManager);
-        ByteArrayOutputStream baos = new ByteArrayOutputStream();
-        System.setOut(new PrintStream(baos));
-        contmgrUTest.doExecute();
-        Assert.assertEquals("status\n", baos.toString());
-    }
-
-    @Test
-    public void testPfc() throws Exception {
-        Pfc pfc = new Pfc();
-        containerManager = mock(IContainerManagerShell.class);
-        List<String> result = new ArrayList<String>(Arrays.asList("status"));
-        when(containerManager.pfc()).thenReturn(result);
-
-        pfc.setContainerManager(containerManager);
-        ByteArrayOutputStream baos = new ByteArrayOutputStream();
-        System.setOut(new PrintStream(baos));
-        pfc.doExecute();
-        Assert.assertEquals("status\n", baos.toString());
-    }
-
-    @Test
-    public void testPsc() throws Exception {
-        Psc psc = new Psc();
-        containerManager = mock(IContainerManagerShell.class);
-        List<String> result = new ArrayList<String>(Arrays.asList("status"));
-        when(containerManager.psc()).thenReturn(result);
-
-        psc.setContainerManager(containerManager);
-        ByteArrayOutputStream baos = new ByteArrayOutputStream();
-        System.setOut(new PrintStream(baos));
-        psc.doExecute();
-        Assert.assertEquals("status\n", baos.toString());
-    }
-
-    @Test
-    public void testPsd() throws Exception {
-        Psd psd = new Psd();
-        containerManager = mock(IContainerManagerShell.class);
-        List<String> result = new ArrayList<String>(Arrays.asList("status"));
-        when(containerManager.psd()).thenReturn(result);
-
-        psd.setContainerManager(containerManager);
-        ByteArrayOutputStream baos = new ByteArrayOutputStream();
-        System.setOut(new PrintStream(baos));
-        psd.doExecute();
-        Assert.assertEquals("status\n", baos.toString());
-    }
-
-    @Test
-    public void testPsm() throws Exception {
-        Psm psm = new Psm();
-        containerManager = mock(IContainerManagerShell.class);
-        List<String> result = new ArrayList<String>(Arrays.asList("status"));
-        when(containerManager.psm()).thenReturn(result);
-
-        psm.setContainerManager(containerManager);
-        ByteArrayOutputStream baos = new ByteArrayOutputStream();
-        System.setOut(new PrintStream(baos));
-        psm.doExecute();
-        Assert.assertEquals("status\n", baos.toString());
-    }
-
-    @Test
-    public void testPsp() throws Exception {
-        Psp psp = new Psp();
-        containerManager = mock(IContainerManagerShell.class);
-        List<String> result = new ArrayList<String>(Arrays.asList("status"));
-        when(containerManager.psp()).thenReturn(result);
-
-        psp.setContainerManager(containerManager);
-        ByteArrayOutputStream baos = new ByteArrayOutputStream();
-        System.setOut(new PrintStream(baos));
-        psp.doExecute();
-        Assert.assertEquals("status\n", baos.toString());
-    }
-
-    @Test
-    public void testRemoveContainer() throws Exception {
-        String containerName = "test";
-        RemoveContainer remConTest = new RemoveContainer();
-        containerManager = mock(IContainerManagerShell.class);
-        List<String> result = new ArrayList<String>(Arrays.asList("status"));
-        when(containerManager.removeContainerShell(containerName)).thenReturn(result);
-
-        Field cNField = remConTest.getClass().getDeclaredField("containerName");
-        cNField.setAccessible(true);
-        cNField.set(remConTest, "test");
-
-        remConTest.setContainerManager(containerManager);
-        ByteArrayOutputStream baos = new ByteArrayOutputStream();
-        System.setOut(new PrintStream(baos));
-        remConTest.doExecute();
-        Assert.assertEquals("status\n", baos.toString());
-    }
-
-    @Test
-    public void testRemoveContainerEntry() throws Exception {
-        String containerName = "test", nodeId = "1234", portId = "5678";
-        RemoveContainerEntry remConEntTest = new RemoveContainerEntry();
-        containerManager = mock(IContainerManagerShell.class);
-        List<String> result = new ArrayList<String>(Arrays.asList("status"));
-        when(containerManager.removeContainerEntry(containerName, nodeId, portId)).thenReturn(result);
-
-        Field cNField = remConEntTest.getClass().getDeclaredField("containerName");
-        cNField.setAccessible(true);
-        Field nIField = remConEntTest.getClass().getDeclaredField("nodeId");
-        nIField.setAccessible(true);
-        Field pIField = remConEntTest.getClass().getDeclaredField("portId");
-        pIField.setAccessible(true);
-
-        cNField.set(remConEntTest, "test");
-        nIField.set(remConEntTest, "1234");
-        pIField.set(remConEntTest, "5678");
-
-        remConEntTest.setContainerManager(containerManager);
-        ByteArrayOutputStream baos = new ByteArrayOutputStream();
-        System.setOut(new PrintStream(baos));
-        remConEntTest.doExecute();
-        Assert.assertEquals("status\n", baos.toString());
-    }
-
-    @Test
-    public void testRemoveContainerFlow() throws Exception {
-        String containerName = "test", cflowName = "1234";
-        RemoveContainerFlow remConFlowTest = new RemoveContainerFlow();
-        containerManager = mock(IContainerManagerShell.class);
-        List<String> result = new ArrayList<String>(Arrays.asList("status"));
-        when(containerManager.removeContainerFlow(containerName, cflowName)).thenReturn(result);
-
-        Field cNField = remConFlowTest.getClass().getDeclaredField("containerName");
-        cNField.setAccessible(true);
-        Field cfField = remConFlowTest.getClass().getDeclaredField("cflowName");
-        cfField.setAccessible(true);
-
-        cNField.set(remConFlowTest, "test");
-        cfField.set(remConFlowTest, "1234");
-
-        remConFlowTest.setContainerManager(containerManager);
-        ByteArrayOutputStream baos = new ByteArrayOutputStream();
-        System.setOut(new PrintStream(baos));
-        remConFlowTest.doExecute();
-        Assert.assertEquals("status\n", baos.toString());
-    }
-
-    @Test
-    public void testSaveConfig() throws Exception {
-        SaveConfig saveConfig = new SaveConfig();
-        containerManager = mock(IContainerManagerShell.class);
-        List<String> result = new ArrayList<String>(Arrays.asList("status"));
-        when(containerManager.saveConfig()).thenReturn(result);
-
-        saveConfig.setContainerManager(containerManager);
-        ByteArrayOutputStream baos = new ByteArrayOutputStream();
-        System.setOut(new PrintStream(baos));
-        saveConfig.doExecute();
-        Assert.assertEquals("status\n", baos.toString());
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/dummy-console/README b/opendaylight/adsal/dummy-console/README
deleted file mode 100644 (file)
index 09974d5..0000000
+++ /dev/null
@@ -1,2 +0,0 @@
-This bundle is temporary only and should be removed as soon as possible
-it is only for compatibility layer in Karaf.
diff --git a/opendaylight/adsal/dummy-console/pom.xml b/opendaylight/adsal/dummy-console/pom.xml
deleted file mode 100644 (file)
index 76aa58f..0000000
+++ /dev/null
@@ -1,35 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../commons/opendaylight</relativePath>
-  </parent>
-  <artifactId>dummy-console</artifactId>
-  <version>1.3.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <description>Dummy Console Interfaces for Equinox-specific CLI</description>
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Import-Package>*</Import-Package>
-            <Export-Package>org.eclipse.osgi.framework.console</Export-Package>
-          </instructions>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/dummy-console/src/main/java/org/eclipse/osgi/framework/console/CommandInterpreter.java b/opendaylight/adsal/dummy-console/src/main/java/org/eclipse/osgi/framework/console/CommandInterpreter.java
deleted file mode 100644 (file)
index 29e9fc9..0000000
+++ /dev/null
@@ -1,12 +0,0 @@
-/*
- * Copyright(c)2014 Inocybe Technologies, Inc. and others. All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- *
- */
-package org.eclipse.osgi.framework.console;
-
-/** Empty tag interface for Command Interpreter **/
-public interface CommandInterpreter {}
diff --git a/opendaylight/adsal/dummy-console/src/main/java/org/eclipse/osgi/framework/console/CommandProvider.java b/opendaylight/adsal/dummy-console/src/main/java/org/eclipse/osgi/framework/console/CommandProvider.java
deleted file mode 100644 (file)
index a781f6f..0000000
+++ /dev/null
@@ -1,12 +0,0 @@
-/*
- * Copyright(c)2014 Inocybe Technologies, Inc. and others. All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- *
- */
-package org.eclipse.osgi.framework.console;
-
-/** Empty tag interface for Command Provider **/
-public interface CommandProvider {}
diff --git a/opendaylight/adsal/features/adsal/pom.xml b/opendaylight/adsal/features/adsal/pom.xml
deleted file mode 100644 (file)
index 9ae5673..0000000
+++ /dev/null
@@ -1,150 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../../opendaylight/commons/opendaylight</relativePath>
-  </parent>
-  <artifactId>features-adsal</artifactId>
-  <version>${sal.version}</version>
-  <packaging>jar</packaging>
-  <name>Features :: AD-SAL Features</name>
-  <description>AD-SAL Features POM</description>
-  <properties>
-    <features.file>features.xml</features.file>
-  </properties>
-  <dependencies>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>features-base</artifactId>
-      <classifier>features</classifier>
-      <type>xml</type>
-    </dependency>
-    <!-- test to validate features.xml -->
-    <dependency>
-      <groupId>org.opendaylight.odlparent</groupId>
-      <artifactId>features-test</artifactId>
-    </dependency>
-    <!-- dependency for opendaylight-karaf-empty for use by testing -->
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>opendaylight-karaf-empty</artifactId>
-      <version>1.6.0-SNAPSHOT</version>
-      <type>zip</type>
-    </dependency>
-    <!-- Bundle dependencies -->
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>dummy-console</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal.connection</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal.connection.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal.networkconfiguration</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal.networkconfiguration.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>clustering.services</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>clustering.services-implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>clustering.stub</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>configuration</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>configuration.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>logging.bridge</artifactId>
-    </dependency>
-  </dependencies>
-  <build>
-    <resources>
-      <resource>
-        <filtering>true</filtering>
-        <directory>src/main/resources</directory>
-      </resource>
-    </resources>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.maven.plugins</groupId>
-        <artifactId>maven-resources-plugin</artifactId>
-        <executions>
-          <execution>
-            <id>filter</id>
-            <goals>
-              <goal>resources</goal>
-            </goals>
-            <phase>generate-resources</phase>
-          </execution>
-        </executions>
-      </plugin>
-      <plugin>
-        <groupId>org.codehaus.mojo</groupId>
-        <artifactId>build-helper-maven-plugin</artifactId>
-        <executions>
-          <execution>
-            <id>attach-artifacts</id>
-            <goals>
-              <goal>attach-artifact</goal>
-            </goals>
-            <phase>package</phase>
-            <configuration>
-              <artifacts>
-                <artifact>
-                  <file>${project.build.directory}/classes/${features.file}</file>
-                  <type>xml</type>
-                  <classifier>features</classifier>
-                </artifact>
-              </artifacts>
-            </configuration>
-          </execution>
-        </executions>
-      </plugin>
-      <plugin>
-        <groupId>org.apache.maven.plugins</groupId>
-        <artifactId>maven-surefire-plugin</artifactId>
-        <configuration>
-          <systemPropertyVariables>
-            <karaf.distro.groupId>org.opendaylight.controller</karaf.distro.groupId>
-            <karaf.distro.artifactId>opendaylight-karaf-empty</karaf.distro.artifactId>
-            <karaf.distro.version>${commons.opendaylight.version}</karaf.distro.version>
-          </systemPropertyVariables>
-          <dependenciesToScan>
-           <dependency>org.opendaylight.odlparent:features-test</dependency>
-          </dependenciesToScan>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-</project>
diff --git a/opendaylight/adsal/features/adsal/src/main/resources/features.xml b/opendaylight/adsal/features/adsal/src/main/resources/features.xml
deleted file mode 100644 (file)
index 397a05e..0000000
+++ /dev/null
@@ -1,50 +0,0 @@
-<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
-<features name="adsal-${project.version}" xmlns="http://karaf.apache.org/xmlns/features/v1.2.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
-   xsi:schemaLocation="http://karaf.apache.org/xmlns/features/v1.2.0 http://karaf.apache.org/xmlns/features/v1.2.0">
-   <repository>mvn:org.opendaylight.controller/features-base/${commons.opendaylight.version}/xml/features</repository>
-   <feature name="odl-adsal-all" description="OpenDaylight AD-SAL All Features" version="${sal.version}">
-      <feature version="${sal.version}">odl-adsal-core</feature>
-      <feature version="${sal.networkconfiguration.version}">odl-adsal-networkconfiguration</feature>
-      <feature version="${sal.connection.version}">odl-adsal-connection</feature>
-      <feature version="${clustering.services.version}">odl-adsal-clustering</feature>
-      <feature version="${configuration.version}">odl-adsal-configuration</feature>
-   </feature>
-   <feature name="odl-adsal-core" description="OpenDaylight :: AD-SAL :: Core" version="${sal.version}">
-      <feature>odl-base-felix-dm</feature>
-      <feature>odl-base-dummy-console</feature>
-      <feature version="${project.version}">odl-adsal-thirdparty</feature>
-      <bundle start="true">mvn:org.apache.commons/commons-lang3/${commons.lang3.version}</bundle>
-  <!--    <bundle>mvn:org.osgi/org.osgi.compendium/${osgi.compendium.version}</bundle> -->
-      <bundle>mvn:org.opendaylight.controller/sal/${sal.version}</bundle>
-      <bundle>mvn:org.opendaylight.controller/sal.implementation/${sal.implementation.version}</bundle>
-   </feature>
-   <feature name="odl-adsal-networkconfiguration" description="OpenDaylight :: AD-SAL :: Network Configuration" version="${sal.networkconfiguration.version}">
-      <feature>odl-adsal-core</feature>
-      <bundle>mvn:org.opendaylight.controller/sal.networkconfiguration/${sal.networkconfiguration.version}</bundle>
-      <bundle>mvn:org.opendaylight.controller/sal.networkconfiguration.implementation/${sal.networkconfiguration.version}</bundle>
-   </feature>
-   <feature name="odl-adsal-connection" description="OpenDaylight :: AD-SAL :: Connection" version="${sal.connection.version}">
-      <feature>odl-adsal-core</feature>
-      <bundle>mvn:org.opendaylight.controller/sal.connection/${sal.connection.version}</bundle>
-      <bundle>mvn:org.opendaylight.controller/sal.connection.implementation/${sal.connection.version}</bundle>
-   </feature>
-   <feature name="odl-adsal-clustering" description="OpenDaylight :: AD-SAL :: Clustering" version="${clustering.services.version}">
-      <feature>transaction</feature>
-      <feature>odl-base-felix-dm</feature>
-      <feature>odl-base-eclipselink-persistence</feature>
-      <feature version="${sal.version}">odl-adsal-core</feature>
-      <bundle>mvn:org.opendaylight.controller/clustering.services/${clustering.services.version}</bundle>
-      <bundle>mvn:org.opendaylight.controller/clustering.services-implementation/${clustering.services_implementation.version}</bundle>
-   </feature>
-   <feature name="odl-adsal-configuration" description="OpenDaylight :: AD-SAL :: Configuration" version="${configuration.version}">
-      <feature version="${sal.version}">odl-adsal-core</feature>
-      <feature version="${clustering.services.version}">odl-adsal-clustering</feature>
-      <bundle>mvn:org.opendaylight.controller/configuration/${configuration.version}</bundle>
-      <bundle>mvn:org.opendaylight.controller/configuration.implementation/${configuration.implementation.version}</bundle>
-   </feature>
-   <feature name="odl-adsal-thirdparty" description="OpenDaylight :: AD-SAL :: Third-Party Depenencies" version="${project.version}">
-      <!-- Removed out - causes loop in loggers which polutes logs expotencially
-         <bundle>mvn:org.opendaylight.controller/logging.bridge/${logging.bridge.version}</bundle>
-       -->
-   </feature>
-</features>
diff --git a/opendaylight/adsal/features/base/pom.xml b/opendaylight/adsal/features/base/pom.xml
deleted file mode 100644 (file)
index 3042b6a..0000000
+++ /dev/null
@@ -1,532 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../../opendaylight/commons/opendaylight</relativePath>
-  </parent>
-  <artifactId>features-base</artifactId>
-  <packaging>jar</packaging>
-  <name>${project.artifactId}</name>
-  <description>Base Features POM</description>
-  <properties>
-    <features.file>features.xml</features.file>
-  </properties>
-  <dependencies>
-    <dependency>
-      <groupId>ch.qos.logback</groupId>
-      <artifactId>logback-classic</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>ch.qos.logback</groupId>
-      <artifactId>logback-core</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>dummy-console</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>karaf-tomcat-security</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>com.fasterxml.jackson.core</groupId>
-      <artifactId>jackson-annotations</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>com.fasterxml.jackson.core</groupId>
-      <artifactId>jackson-core</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>com.fasterxml.jackson.core</groupId>
-      <artifactId>jackson-databind</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>com.fasterxml.jackson.datatype</groupId>
-      <artifactId>jackson-datatype-json-org</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>com.fasterxml.jackson.jaxrs</groupId>
-      <artifactId>jackson-jaxrs-base</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>com.fasterxml.jackson.jaxrs</groupId>
-      <artifactId>jackson-jaxrs-json-provider</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>com.fasterxml.jackson.module</groupId>
-      <artifactId>jackson-module-jaxb-annotations</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>com.google.code.gson</groupId>
-      <artifactId>gson</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>com.google.guava</groupId>
-      <artifactId>guava</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>com.sun.jersey</groupId>
-      <artifactId>jersey-client</artifactId>
-    </dependency>
-    <!-- Jersey for JAXRS -->
-    <dependency>
-      <groupId>com.sun.jersey</groupId>
-      <artifactId>jersey-core</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>com.sun.jersey</groupId>
-      <artifactId>jersey-server</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>commons-codec</groupId>
-      <artifactId>commons-codec</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>commons-fileupload</groupId>
-      <artifactId>commons-fileupload</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>commons-io</groupId>
-      <artifactId>commons-io</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>commons-net</groupId>
-      <artifactId>commons-net</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>eclipselink</groupId>
-      <artifactId>javax.persistence</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>eclipselink</groupId>
-      <artifactId>javax.resource</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>javax.servlet</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>javax.servlet.jsp</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>org.apache.felix.gogo.command</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>org.apache.felix.gogo.runtime</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>org.apache.felix.gogo.shell</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>org.eclipse.equinox.cm</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>org.eclipse.equinox.console</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>org.eclipse.equinox.ds</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>org.eclipse.equinox.launcher</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>org.eclipse.equinox.util</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>org.eclipse.osgi</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>org.eclipse.osgi.services</artifactId>
-    </dependency>
-    <!-- Gemini Web -->
-    <dependency>
-      <groupId>geminiweb</groupId>
-      <artifactId>org.eclipse.gemini.web.core</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>geminiweb</groupId>
-      <artifactId>org.eclipse.gemini.web.extender</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>geminiweb</groupId>
-      <artifactId>org.eclipse.gemini.web.tomcat</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>geminiweb</groupId>
-      <artifactId>org.eclipse.virgo.kernel.equinox.extensions</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>geminiweb</groupId>
-      <artifactId>org.eclipse.virgo.util.common</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>geminiweb</groupId>
-      <artifactId>org.eclipse.virgo.util.io</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>geminiweb</groupId>
-      <artifactId>org.eclipse.virgo.util.math</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>geminiweb</groupId>
-      <artifactId>org.eclipse.virgo.util.osgi</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>geminiweb</groupId>
-      <artifactId>org.eclipse.virgo.util.osgi.manifest</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>geminiweb</groupId>
-      <artifactId>org.eclipse.virgo.util.parser.manifest</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>io.netty</groupId>
-      <artifactId>netty-buffer</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>io.netty</groupId>
-      <artifactId>netty-codec</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>io.netty</groupId>
-      <artifactId>netty-codec-http</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>io.netty</groupId>
-      <artifactId>netty-common</artifactId>
-    </dependency>
-
-    <!--Netty-->
-    <dependency>
-      <groupId>io.netty</groupId>
-      <artifactId>netty-handler</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>io.netty</groupId>
-      <artifactId>netty-transport</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>orbit</groupId>
-      <artifactId>javax.activation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>orbit</groupId>
-      <artifactId>javax.annotation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>orbit</groupId>
-      <artifactId>javax.ejb</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>orbit</groupId>
-      <artifactId>javax.el</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>orbit</groupId>
-      <artifactId>javax.mail.glassfish</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>orbit</groupId>
-      <artifactId>javax.servlet.jsp.jstl</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>orbit</groupId>
-      <artifactId>javax.servlet.jsp.jstl.impl</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>orbit</groupId>
-      <artifactId>javax.xml.rpc</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>orbit</groupId>
-      <artifactId>org.apache.catalina</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>orbit</groupId>
-      <artifactId>org.apache.catalina.ha</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>orbit</groupId>
-      <artifactId>org.apache.catalina.tribes</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>orbit</groupId>
-      <artifactId>org.apache.coyote</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>orbit</groupId>
-      <artifactId>org.apache.el</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>orbit</groupId>
-      <artifactId>org.apache.jasper</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>orbit</groupId>
-      <artifactId>org.apache.juli.extras</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>orbit</groupId>
-      <artifactId>org.apache.tomcat.api</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>orbit</groupId>
-      <artifactId>org.apache.tomcat.util</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.aopalliance</groupId>
-      <artifactId>com.springsource.org.aopalliance</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.apache.commons</groupId>
-      <artifactId>commons-lang3</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.apache.felix</groupId>
-      <artifactId>org.apache.felix.dependencymanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.apache.felix</groupId>
-      <artifactId>org.apache.felix.dependencymanager.shell</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.apache.felix</groupId>
-      <artifactId>org.apache.felix.fileinstall</artifactId>
-    </dependency>
-    <!-- felix webconsole -->
-    <dependency>
-      <groupId>org.apache.felix</groupId>
-      <artifactId>org.apache.felix.webconsole</artifactId>
-      <classifier>all</classifier>
-    </dependency>
-
-    <dependency>
-      <groupId>org.codehaus.jettison</groupId>
-      <artifactId>jettison</artifactId>
-    </dependency>
-
-    <dependency>
-      <groupId>org.eclipse.equinox.http</groupId>
-      <artifactId>servlet</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.eclipse.persistence</groupId>
-      <artifactId>org.eclipse.persistence.antlr</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.eclipse.persistence</groupId>
-      <artifactId>org.eclipse.persistence.core</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.eclipse.persistence</groupId>
-      <artifactId>org.eclipse.persistence.moxy</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.javassist</groupId>
-      <artifactId>javassist</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.jboss.spec.javax.transaction</groupId>
-      <artifactId>jboss-transaction-api_1.1_spec</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.jolokia</groupId>
-      <artifactId>jolokia-osgi</artifactId>
-    </dependency>
-
-    <dependency>
-      <groupId>org.json</groupId>
-      <artifactId>json</artifactId>
-    </dependency>
-
-    <dependency>
-      <groupId>org.ow2.asm</groupId>
-      <artifactId>asm-all</artifactId>
-    </dependency>
-    <!-- Visual VM hook -->
-    <dependency>
-      <groupId>org.ow2.chameleon.management</groupId>
-      <artifactId>chameleon-mbeans</artifactId>
-    </dependency>
-
-    <!-- Third party depedencies -->
-    <dependency>
-      <groupId>org.slf4j</groupId>
-      <artifactId>jcl-over-slf4j</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.slf4j</groupId>
-      <artifactId>log4j-over-slf4j</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.slf4j</groupId>
-      <artifactId>slf4j-api</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.springframework</groupId>
-      <artifactId>org.springframework.aop</artifactId>
-    </dependency>
-    <!-- Add Pax Exam -->
-    <dependency>
-      <groupId>org.springframework</groupId>
-      <artifactId>org.springframework.asm</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.springframework</groupId>
-      <artifactId>org.springframework.beans</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.springframework</groupId>
-      <artifactId>org.springframework.context</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.springframework</groupId>
-      <artifactId>org.springframework.context.support</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.springframework</groupId>
-      <artifactId>org.springframework.core</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.springframework</groupId>
-      <artifactId>org.springframework.expression</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.springframework</groupId>
-      <artifactId>org.springframework.transaction</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.springframework</groupId>
-      <artifactId>org.springframework.web</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.springframework</groupId>
-      <artifactId>org.springframework.web.servlet</artifactId>
-    </dependency>
-    <!-- Spring security -->
-    <dependency>
-      <groupId>org.springframework.security</groupId>
-      <artifactId>spring-security-config</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.springframework.security</groupId>
-      <artifactId>spring-security-core</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.springframework.security</groupId>
-      <artifactId>spring-security-taglibs</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.springframework.security</groupId>
-      <artifactId>spring-security-web</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>virgomirror</groupId>
-      <artifactId>org.eclipse.jdt.core.compiler.batch</artifactId>
-    </dependency>
-
-    <!-- test to validate features.xml -->
-    <dependency>
-      <groupId>org.opendaylight.odlparent</groupId>
-      <artifactId>features-test</artifactId>
-    </dependency>
-    <!-- dependency for opendaylight-karaf-empty for use by testing -->
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>opendaylight-karaf-empty</artifactId>
-      <version>1.6.0-SNAPSHOT</version>
-      <type>zip</type>
-    </dependency>
-  </dependencies>
-  <build>
-    <resources>
-      <resource>
-        <filtering>true</filtering>
-        <directory>src/main/resources</directory>
-      </resource>
-    </resources>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.karaf.tooling</groupId>
-        <artifactId>karaf-maven-plugin</artifactId>
-        <version>${karaf.version}</version>
-        <extensions>true</extensions>
-        <executions>
-          <execution>
-            <id>features-create-kar</id>
-            <goals>
-              <goal>features-create-kar</goal>
-            </goals>
-            <configuration>
-              <featuresFile>${project.build.directory}/classes/${features.file}</featuresFile>
-            </configuration>
-          </execution>
-        </executions>
-        <!-- There is no useful configuration for the kar mojo. The features-generate-descriptor mojo configuration may be useful -->
-      </plugin>
-      <plugin>
-        <groupId>org.apache.maven.plugins</groupId>
-        <artifactId>maven-resources-plugin</artifactId>
-        <executions>
-          <execution>
-            <id>filter</id>
-            <goals>
-              <goal>resources</goal>
-            </goals>
-            <phase>generate-resources</phase>
-          </execution>
-        </executions>
-      </plugin>
-      <plugin>
-        <groupId>org.codehaus.mojo</groupId>
-        <artifactId>build-helper-maven-plugin</artifactId>
-        <executions>
-          <execution>
-            <id>attach-artifacts</id>
-            <goals>
-              <goal>attach-artifact</goal>
-            </goals>
-            <phase>package</phase>
-            <configuration>
-              <artifacts>
-                <artifact>
-                  <file>${project.build.directory}/classes/${features.file}</file>
-                  <type>xml</type>
-                  <classifier>features</classifier>
-                </artifact>
-              </artifacts>
-            </configuration>
-          </execution>
-        </executions>
-      </plugin>
-      <plugin>
-        <groupId>org.apache.maven.plugins</groupId>
-        <artifactId>maven-surefire-plugin</artifactId>
-        <configuration>
-          <systemPropertyVariables>
-            <karaf.distro.groupId>org.opendaylight.controller</karaf.distro.groupId>
-            <karaf.distro.artifactId>opendaylight-karaf-empty</karaf.distro.artifactId>
-            <karaf.distro.version>${commons.opendaylight.version}</karaf.distro.version>
-          </systemPropertyVariables>
-          <dependenciesToScan>
-           <dependency>org.opendaylight.odlparent:features-test</dependency>
-          </dependenciesToScan>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-</project>
diff --git a/opendaylight/adsal/features/base/src/main/resources/features.xml b/opendaylight/adsal/features/base/src/main/resources/features.xml
deleted file mode 100644 (file)
index 182c047..0000000
+++ /dev/null
@@ -1,155 +0,0 @@
-<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
-<features name="odl-base-${project.version}" xmlns="http://karaf.apache.org/xmlns/features/v1.2.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://karaf.apache.org/xmlns/features/v1.2.0 http://karaf.apache.org/xmlns/features/v1.2.0">
-
-   <feature name="odl-base-all" description="OpenDaylight Controller" version="${project.version}">
-      <feature>http</feature>
-      <feature>transaction</feature>
-      <feature>odl-base-felix-dm</feature>
-      <feature>odl-base-aries-spi-fly</feature>
-      <feature>odl-base-dummy-console</feature>
-      <feature>odl-base-apache-commons</feature>
-      <feature>odl-base-eclipselink-persistence</feature>
-      <feature>odl-base-gemini-web</feature>
-      <feature>odl-base-tomcat</feature>
-      <feature>odl-base-netty</feature>
-      <feature>odl-base-jersey</feature>
-      <feature>odl-base-jackson</feature>
-      <feature>odl-base-spring-security</feature>
-   </feature>
-   <feature name="odl-base-dummy-console" description="Temporary Dummy Console" version="1.3.0-SNAPSHOT">
-      <bundle>mvn:org.opendaylight.controller/dummy-console/1.3.0-SNAPSHOT</bundle>
-   </feature>
-   <feature name="odl-base-felix-dm" description="Felix Dependency Manager" version="${felix.dependencymanager.version}">
-      <bundle>mvn:org.osgi/org.osgi.compendium/${osgi.compendium.version}</bundle>
-      <bundle>mvn:org.apache.felix/org.apache.felix.dependencymanager/${felix.dependencymanager.version}</bundle>
-      <bundle>mvn:org.apache.felix/org.apache.felix.dependencymanager.shell/${felix.dependencymanager.shell.version}</bundle>
-   </feature>
-   <feature name="odl-base-aries-spi-fly" description="Aries SPI Fly" version="${spifly.version}">
-      <bundle>mvn:org.apache.aries/org.apache.aries.util/1.1.0</bundle>
-      <bundle>mvn:org.apache.aries.spifly/org.apache.aries.spifly.dynamic.bundle/${spifly.version}</bundle>
-      <bundle>mvn:org.ow2.asm/asm-all/4.0</bundle>
-   </feature>
-   <feature name='odl-base-netty' version='${netty.version}'>
-      <bundle>wrap:mvn:io.netty/netty-buffer/${netty.version}</bundle>
-      <bundle>wrap:mvn:io.netty/netty-codec/${netty.version}</bundle>
-      <bundle>wrap:mvn:io.netty/netty-transport/${netty.version}</bundle>
-      <bundle>wrap:mvn:io.netty/netty-common/${netty.version}</bundle>
-      <bundle>wrap:mvn:io.netty/netty-handler/${netty.version}</bundle>
-      <bundle>wrap:mvn:io.netty/netty-codec-http/${netty.version}</bundle>
-   </feature>
-   <feature name="odl-base-jersey" description="Jersey" version="${jersey.version}">
-      <feature>odl-base-gemini-web</feature>
-      <bundle>mvn:com.sun.jersey/jersey-server/${jersey.version}</bundle>
-      <bundle>mvn:com.sun.jersey/jersey-core/${jersey.version}</bundle>
-      <bundle>mvn:com.sun.jersey/jersey-client/${jersey.version}</bundle>
-      <bundle>mvn:com.sun.jersey/jersey-servlet/${jersey.version}</bundle>
-   </feature>
-   <feature name="odl-base-jersey2-osgi" description="OSGi friendly Jersey" version="${jersey2.publisher.version}">
-      <feature>http</feature>
-      <bundle>mvn:com.eclipsesource.jaxrs/jersey-all/${jersey2.version}</bundle>
-      <bundle>mvn:com.eclipsesource.jaxrs/publisher/${jersey2.publisher.version}</bundle>
-      <bundle start="true">mvn:javax.ws.rs/javax.ws.rs-api/${jsr311.v2.api.version}</bundle>
-      <bundle>mvn:javax.annotation/javax.annotation-api/${javax.annotation.version}</bundle>
-    </feature>
-   <feature name="odl-base-jackson" description="Jackson JAX-RS" version="${jackson.version}">
-      <bundle>mvn:com.sun.jersey/jersey-core/${jersey.version}</bundle>
-      <bundle>mvn:com.sun.jersey/jersey-client/${jersey.version}</bundle>
-      <bundle start="true">mvn:com.fasterxml.jackson.core/jackson-annotations/${jackson.version}</bundle>
-      <bundle start="true">mvn:com.fasterxml.jackson.core/jackson-core/${jackson.version}</bundle>
-      <bundle start="true">mvn:com.fasterxml.jackson.core/jackson-databind/${jackson.version}</bundle>
-      <bundle start="true">mvn:org.codehaus.jettison/jettison/${jettison.version}</bundle>
-      <bundle start="true">mvn:com.fasterxml.jackson.module/jackson-module-jaxb-annotations/${jackson.version}</bundle>
-      <bundle start="true">mvn:com.fasterxml.jackson.jaxrs/jackson-jaxrs-base/${jackson.version}</bundle>
-      <bundle start="true">mvn:com.fasterxml.jackson.jaxrs/jackson-jaxrs-json-provider/${jackson.version}</bundle>
-   </feature>
-   <feature name="odl-base-slf4j" description="SLF4J Logging" version="${slf4j.version}">
-      <bundle>mvn:org.slf4j/slf4j-jdk14/1.7.2</bundle>
-      <bundle>mvn:org.slf4j/slf4j-nop/1.7.2</bundle>
-      <bundle>mvn:org.slf4j/slf4j-simple/1.7.2</bundle>
-      <bundle start="true">mvn:org.slf4j/slf4j-api/1.7.2</bundle>
-   </feature>
-   <feature name="odl-base-apache-commons" description="Apache Commons Libraries" version="${project.version}">
-      <bundle start="true">mvn:com.google.guava/guava/${guava.version}</bundle>
-      <bundle start="true">mvn:org.javassist/javassist/${javassist.version}</bundle>
-      <bundle start="true">mvn:commons-io/commons-io/${commons.io.version}</bundle>
-      <bundle start="true">mvn:commons-codec/commons-codec/${commons.codec.version}</bundle>
-      <bundle start="true">mvn:org.apache.commons/commons-lang3/${commons.lang3.version}</bundle>
-      <bundle start="true">mvn:commons-net/commons-net/${commons.net.version}</bundle>
-   </feature>
-   <feature name="odl-base-eclipselink-persistence" description="EclipseLink Persistence API" version="2.0.4.v201112161009">
-      <bundle start="true">mvn:eclipselink/javax.persistence/2.0.4.v201112161009</bundle>
-      <bundle start="true">mvn:eclipselink/javax.resource/1.5.0.v200906010428</bundle>
-      <bundle start="true">mvn:org.eclipse.persistence/org.eclipse.persistence.antlr/2.5.0</bundle>
-      <bundle start="true">mvn:org.eclipse.persistence/org.eclipse.persistence.moxy/2.5.0</bundle>
-      <bundle start="true">mvn:org.eclipse.persistence/org.eclipse.persistence.core/2.5.0</bundle>
-   </feature>
-   <feature name="odl-base-gemini-web" description="Gemini Web" version="${geminiweb.version}">
-      <feature>http</feature>
-      <feature>transaction</feature>
-      <feature>odl-base-slf4j</feature>
-      <feature>odl-base-felix-dm</feature>
-      <feature>odl-base-jackson</feature>
-      <feature>odl-base-apache-commons</feature>
-      <bundle start="true">mvn:com.google.code.gson/gson/${gson.version}</bundle>
-      <bundle start="true">mvn:commons-fileupload/commons-fileupload/${commons.fileupload.version}</bundle>
-      <bundle start="true">mvn:geminiweb/org.eclipse.gemini.web.core/${geminiweb.version}</bundle>
-      <bundle start="true">mvn:geminiweb/org.eclipse.gemini.web.extender/${geminiweb.version}</bundle>
-      <bundle start="true">mvn:geminiweb/org.eclipse.virgo.util.common/${virgo.version}</bundle>
-      <bundle start="true">mvn:geminiweb/org.eclipse.virgo.util.io/${virgo.version}</bundle>
-      <bundle start="true">mvn:geminiweb/org.eclipse.virgo.util.math/${virgo.version}</bundle>
-      <bundle start="true">mvn:geminiweb/org.eclipse.virgo.util.osgi/${virgo.version}</bundle>
-      <bundle start="true">mvn:geminiweb/org.eclipse.virgo.util.osgi.manifest/${virgo.version}</bundle>
-      <bundle start="true">mvn:geminiweb/org.eclipse.virgo.util.parser.manifest/${virgo.version}</bundle>
-      <bundle start="true">mvn:org.apache.felix/org.apache.felix.fileinstall/3.1.6</bundle>
-      <bundle start="true">mvn:orbit/javax.activation/1.1.0.v201211130549</bundle>
-      <bundle start="true">mvn:orbit/javax.annotation/1.1.0.v201209060031</bundle>
-      <bundle start="true">mvn:orbit/javax.ejb/3.1.1.v201204261316</bundle>
-      <bundle start="true">mvn:orbit/javax.el/2.2.0.v201108011116</bundle>
-      <bundle start="true">mvn:orbit/javax.mail.glassfish/1.4.1.v201108011116</bundle>
-      <bundle start="true">mvn:orbit/javax.xml.rpc/1.1.0.v201005080400</bundle>
-      <bundle start="true">mvn:org.eclipse.jetty.orbit/javax.servlet.jsp/2.2.0.v201112011158</bundle>
-      <bundle start="true">mvn:orbit/javax.servlet.jsp.jstl/1.2.0.v201105211821</bundle>
-      <bundle start="true">mvn:orbit/javax.servlet.jsp.jstl.impl/1.2.0.v201210211230</bundle>
-   </feature>
-   <feature name="odl-base-tomcat" description="OpenDaylight Tomcat" version="7.0.53">
-      <feature>odl-base-gemini-web</feature>
-      <feature>odl-base-eclipselink-persistence</feature>
-      <bundle start="true">mvn:orbit/org.apache.catalina/${commons.catalina}</bundle>
-      <bundle start="true">mvn:geminiweb/org.eclipse.gemini.web.tomcat/${geminiweb.version}</bundle>
-      <bundle start="true">mvn:orbit/org.apache.catalina.ha/${commons.catalina.ha}</bundle>
-      <bundle start="true">mvn:orbit/org.apache.catalina.tribes/${commons.catalina.tribes}</bundle>
-      <bundle start="true">mvn:orbit/org.apache.coyote/${commons.coyote}</bundle>
-      <bundle start="true">mvn:orbit/org.apache.el/${commons.el}</bundle>
-      <bundle start="true">mvn:orbit/org.apache.jasper/${commons.jasper}</bundle>
-      <bundle start="true">mvn:orbit/org.apache.juli.extras/${commons.juli.version}</bundle>
-      <bundle start="true">mvn:orbit/org.apache.tomcat.api/${commons.tomcat.api}</bundle>
-      <bundle start="true">mvn:orbit/org.apache.tomcat.util/${commons.tomcat.util}</bundle>
-      <bundle start="true" >mvn:org.opendaylight.controller/karaf-tomcat-security/${karaf.security.version}</bundle>
-      <bundle start="true">wrap:mvn:virgomirror/org.eclipse.jdt.core.compiler.batch/${eclipse.jdt.core.compiler.batch.version}</bundle>
-   </feature>
-   <feature name="odl-base-spring" description="Opendaylight Spring Support" version="${spring.version}">
-      <bundle>mvn:org.ow2.asm/asm-all/${asm.version}</bundle>
-      <bundle>mvn:org.aopalliance/com.springsource.org.aopalliance/${aopalliance.version}</bundle>
-      <bundle>mvn:org.springframework/org.springframework.aop/${spring.version}</bundle>
-      <bundle>mvn:org.springframework/org.springframework.asm/${spring.version}</bundle>
-      <bundle>mvn:org.springframework/org.springframework.beans/${spring.version}</bundle>
-      <bundle>mvn:org.springframework/org.springframework.context/${spring.version}</bundle>
-      <bundle>mvn:org.springframework/org.springframework.context.support/${spring.version}</bundle>
-      <bundle>mvn:org.springframework/org.springframework.core/${spring.version}</bundle>
-      <bundle>mvn:org.springframework/org.springframework.expression/${spring.version}</bundle>
-      <bundle>mvn:org.springframework/org.springframework.transaction/${spring.version}</bundle>
-   </feature>
-   <feature name="odl-base-spring-web" description="OpenDaylight Spring Web" version="${spring.version}">
-      <feature>odl-base-spring</feature>
-      <feature>odl-base-gemini-web</feature>
-      <bundle>mvn:org.springframework/org.springframework.web/${spring.version}</bundle>
-      <bundle>mvn:org.springframework/org.springframework.web.servlet/${spring.version}</bundle>
-   </feature>
-   <feature name="odl-base-spring-security" description="OpenDaylight Spring Security" version="${spring-security.version}">
-      <feature>odl-base-spring-web</feature>
-      <bundle>mvn:org.springframework.security/spring-security-config/${spring-security.version}</bundle>
-      <bundle>mvn:org.springframework.security/spring-security-core/${spring-security.version}</bundle>
-      <bundle>mvn:org.springframework.security/spring-security-taglibs/${spring-security.version}</bundle>
-      <bundle>mvn:org.springframework.security/spring-security-web/${spring-security.version}</bundle>
-   </feature>
-</features>
diff --git a/opendaylight/adsal/features/controller/pom.xml b/opendaylight/adsal/features/controller/pom.xml
deleted file mode 100644 (file)
index c92e0bc..0000000
+++ /dev/null
@@ -1,62 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../../opendaylight/commons/opendaylight</relativePath>
-  </parent>
-  <artifactId>controller-features</artifactId>
-  <packaging>pom</packaging>
-  <name>${project.artifactId}</name>
-  <description>Features POM</description>
-  <properties>
-    <features.file>features.xml</features.file>
-  </properties>
-  <build>
-    <resources>
-      <resource>
-        <filtering>true</filtering>
-        <directory>src/main/resources</directory>
-      </resource>
-    </resources>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.maven.plugins</groupId>
-        <artifactId>maven-resources-plugin</artifactId>
-        <executions>
-          <execution>
-            <id>filter</id>
-            <goals>
-              <goal>resources</goal>
-            </goals>
-            <phase>generate-resources</phase>
-          </execution>
-        </executions>
-      </plugin>
-      <plugin>
-        <groupId>org.codehaus.mojo</groupId>
-        <artifactId>build-helper-maven-plugin</artifactId>
-        <executions>
-          <execution>
-            <id>attach-artifacts</id>
-            <goals>
-              <goal>attach-artifact</goal>
-            </goals>
-            <phase>package</phase>
-            <configuration>
-              <artifacts>
-                <artifact>
-                  <file>${project.build.directory}/classes/${features.file}</file>
-                  <type>xml</type>
-                  <classifier>features</classifier>
-                </artifact>
-              </artifacts>
-            </configuration>
-          </execution>
-        </executions>
-      </plugin>
-    </plugins>
-  </build>
-</project>
diff --git a/opendaylight/adsal/features/controller/src/main/resources/features.xml b/opendaylight/adsal/features/controller/src/main/resources/features.xml
deleted file mode 100644 (file)
index 1ae210a..0000000
+++ /dev/null
@@ -1,77 +0,0 @@
-<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
-<features name="controller-${project.version}" xmlns="http://karaf.apache.org/xmlns/features/v1.2.0"
-   xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
-   xsi:schemaLocation="http://karaf.apache.org/xmlns/features/v1.2.0 http://karaf.apache.org/xmlns/features/v1.2.0">
-
-   <feature name="odl-hosttracker" description="Controller Service: Host Tracker">
-      <feature>odl-clustering</feature>
-      <feature>odl-managers</feature>
-      <feature>odl-sal</feature>
-      <bundle>mvn:org.opendaylight.controller/hosttracker/${hosttracker.api.version}</bundle>
-      <bundle>mvn:org.opendaylight.controller/hosttracker.implementation/${hosttracker.implementation.version}</bundle>
-   </feature>
-   <feature name="odl-sal" description="Service Abstraction Layer"
-      version="${sal.version}">
-      <feature>base-felix-dm</feature>
-      <bundle start="true" start-level="35">mvn:org.apache.commons/commons-lang3/${commons.lang.version}</bundle>
-      <bundle>mvn:org.osgi/org.osgi.compendium/${osgi.compendium.version}</bundle>
-      <bundle>mvn:org.apache.felix/org.apache.felix.dependencymanager/${felix.dependencymanager.version}</bundle>
-      <bundle>mvn:org.opendaylight.controller/sal/${sal.version}</bundle>
-      <!-- The SAL Implementation doesn't follow API versioning, should be revisited in the bundle -->
-      <bundle>mvn:org.opendaylight.controller/sal.implementation/${sal.implementation.version}</bundle>
-      <bundle>mvn:org.opendaylight.controller/sal.networkconfiguration/${sal.networkconfiguration.version}</bundle>
-      <bundle>mvn:org.opendaylight.controller/sal.networkconfiguration.implementation/${sal.networkconfiguration.version}</bundle>
-      <bundle>mvn:org.opendaylight.controller/sal.connection/${sal.connection.version}</bundle>
-      <bundle>mvn:org.opendaylight.controller/sal.connection.implementation/${sal.connection.version}</bundle>
-   </feature>
-   <feature name="odl-clustering" description="Controller Service: Clustering">
-      <feature>transaction</feature>
-      <feature>base-felix-dm</feature>
-      <feature>base-eclipselink-persistence</feature>
-      <feature>odl-sal</feature>
-      <bundle>mvn:org.opendaylight.controller/clustering.services/${clustering.services.version}</bundle>
-      <bundle>mvn:org.opendaylight.controller/clustering.services-implementation/${clustering.services_implementation.version}</bundle>
-      <bundle>mvn:org.opendaylight.controller/clustering.stub/${clustering.stub.version}</bundle>
-   </feature>
-   <feature name="odl-legacy-configuration">
-      <feature>odl-sal</feature>
-      <bundle>mvn:org.opendaylight.controller/configuration/${configuration.version}</bundle>
-      <bundle>mvn:org.opendaylight.controller/configuration.implementation/${configuration.implementation.version}</bundle>
-   </feature>
-   <feature name="odl-configuration" description="Controller Service: Configuration">
-      <!-- org.opendaylight.controller.config.yangjmxgenerator is missing -->
-      <bundle>mvn:org.opendaylight.controller/config-api/${config.version}</bundle>
-      <bundle>mvn:org.opendaylight.controller/config-manager/${config.version}</bundle>
-      <bundle>mvn:org.opendaylight.controller/config-netconf-connector/${netconf.version}</bundle>
-      <bundle>mvn:org.opendaylight.controller/config-persister-api/${config.version}</bundle>
-      <bundle>mvn:org.opendaylight.controller/config-persister-directory-xml-adapter/${config.version}</bundle>
-      <bundle>mvn:org.opendaylight.controller/config-persister-file-xml-adapter/${config.version}</bundle>
-      <bundle>mvn:org.opendaylight.controller/config-persister-impl/${netconf.version}</bundle>
-      <bundle>mvn:org.opendaylight.controller/yang-jmx-generator/${yang-jmx-generator.version}</bundle>
-   </feature>
-   <feature name="odl-managers" description="Big boss">
-      <feature>odl-legacy-configuration</feature>
-      <feature>base-spring-security</feature>
-      <feature>base-felix-dm</feature>
-      <feature>odl-clustering</feature>
-      <bundle>mvn:org.opendaylight.controller.thirdparty/net.sf.jung2/2.0.1</bundle>
-      <bundle>mvn:org.opendaylight.controller/appauth/${appauth.version}</bundle>
-      <bundle>mvn:org.opendaylight.controller/hosttracker/${hosttracker.api.version}</bundle>
-      <bundle>mvn:org.opendaylight.controller/hosttracker.implementation/${hosttracker.implementation.version}</bundle>
-      <bundle>mvn:org.opendaylight.controller/switchmanager/${switchmanager.api.version}</bundle>
-      <bundle>mvn:org.opendaylight.controller/switchmanager.implementation/${switchmanager.implementation.version}</bundle>
-      <bundle>mvn:org.opendaylight.controller/statisticsmanager/${statisticsmanager.version}</bundle>
-      <bundle>mvn:org.opendaylight.controller/statisticsmanager.implementation/${statisticsmanager.implementation.version}</bundle>
-      <bundle>mvn:org.opendaylight.controller/forwardingrulesmanager/${forwardingrulesmanager.version}</bundle>
-      <bundle>mvn:org.opendaylight.controller/forwardingrulesmanager.implementation/${forwardingrulesmanager.implementation.version}</bundle>
-      <bundle>mvn:org.opendaylight.controller/usermanager/${usermanager.version}</bundle>
-      <bundle>mvn:org.opendaylight.controller/usermanager.implementation/${usermanager.version}</bundle>
-      <bundle>mvn:org.opendaylight.controller/containermanager/${containermanager.version}</bundle>
-      <bundle>mvn:org.opendaylight.controller/containermanager.implementation/${containermanager.version}</bundle>
-      <bundle>mvn:org.opendaylight.controller/topologymanager/${topologymanager.version}</bundle>
-      <bundle>mvn:org.opendaylight.controller/forwarding.staticrouting</bundle>
-      <bundle>mvn:org.opendaylight.controller/routing.dijkstra_implementation</bundle>
-      <bundle>mvn:org.opendaylight.controller/connectionmanager</bundle>
-      <bundle>mvn:org.opendaylight.controller/connectionmanager.implementation</bundle>
-   </feature>
-</features>
diff --git a/opendaylight/adsal/features/extras/pom.xml b/opendaylight/adsal/features/extras/pom.xml
deleted file mode 100644 (file)
index f8e04d1..0000000
+++ /dev/null
@@ -1,81 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../../opendaylight/commons/opendaylight</relativePath>
-  </parent>
-  <artifactId>extras-features</artifactId>
-  <packaging>kar</packaging>
-  <name>${project.artifactId}</name>
-  <description>Base Features POM</description>
-  <properties>
-    <features.file>features.xml</features.file>
-    <netty3.version>3.9.2.Final</netty3.version>
-  </properties>
-  <build>
-    <resources>
-      <resource>
-        <filtering>true</filtering>
-        <directory>src/main/resources</directory>
-      </resource>
-    </resources>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.karaf.tooling</groupId>
-        <artifactId>karaf-maven-plugin</artifactId>
-        <version>${karaf.version}</version>
-        <extensions>true</extensions>
-        <executions>
-          <execution>
-            <id>features-create-kar</id>
-            <goals>
-              <goal>features-create-kar</goal>
-            </goals>
-            <configuration>
-              <featuresFile>${project.build.directory}/classes/${features.file}</featuresFile>
-            </configuration>
-          </execution>
-        </executions>
-        <!-- There is no useful configuration for the kar mojo. The features-generate-descriptor mojo configuration may be useful -->
-      </plugin>
-      <plugin>
-        <groupId>org.apache.maven.plugins</groupId>
-        <artifactId>maven-resources-plugin</artifactId>
-        <executions>
-          <execution>
-            <id>filter</id>
-            <goals>
-              <goal>resources</goal>
-            </goals>
-            <phase>generate-resources</phase>
-          </execution>
-        </executions>
-      </plugin>
-      <plugin>
-        <groupId>org.codehaus.mojo</groupId>
-        <artifactId>build-helper-maven-plugin</artifactId>
-        <executions>
-          <execution>
-            <id>attach-artifacts</id>
-            <goals>
-              <goal>attach-artifact</goal>
-            </goals>
-            <phase>package</phase>
-            <configuration>
-              <artifacts>
-                <artifact>
-                  <file>${project.build.directory}/classes/${features.file}</file>
-                  <type>xml</type>
-                  <classifier>features</classifier>
-                </artifact>
-              </artifacts>
-            </configuration>
-          </execution>
-        </executions>
-      </plugin>
-    </plugins>
-  </build>
-</project>
diff --git a/opendaylight/adsal/features/extras/src/main/resources/features.xml b/opendaylight/adsal/features/extras/src/main/resources/features.xml
deleted file mode 100644 (file)
index 3be66d9..0000000
+++ /dev/null
@@ -1,34 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<features name="extras-features-${project.version}" xmlns="http://karaf.apache.org/xmlns/features/v1.0.0">
-
-   <feature name="osgi-compendium" description="OSGi compendium feature" version="${osgi.version}" resolver="(obr)">
-      <bundle start-level="10">mvn:org.osgi/org.osgi.compendium/${osgi.compendium.version}</bundle>
-   </feature>
-
-   <feature name="odl-extras-scala" description="Scala Runtime for OpenDaylight" version="${scala.version}" resolver="(obr)" start-level="10">
-      <bundle>mvn:org.scala-lang/scala-library/${scala.version}.${scala.micro.version}</bundle>
-      <bundle>mvn:org.scala-lang/scala-reflect/${scala.version}.${scala.micro.version}</bundle>
-   </feature>
-
-   <feature name="odl-extras-akka-system" description="Akka Actor Framework System Bundles" version="${akka.version}" resolver="(obr)" start-level="15">
-      <feature version="${scala.version}">odl-extras-scala</feature>
-      <bundle dependency="true">mvn:com.typesafe/config/${typesafe.config.version}</bundle>
-      <bundle dependency="true">mvn:com.typesafe.akka/akka-actor_${scala.version}/${akka.version}</bundle>
-      <bundle dependency="true">mvn:com.typesafe.akka/akka-slf4j_${scala.version}/${akka.version}</bundle>
-      <bundle>mvn:com.typesafe.akka/akka-osgi_${scala.version}/${akka.version}</bundle>
-   </feature>
-
-   <feature name="odl-extras-akka-clustering" description="Akka Clustering Support" version="${akka.version}" resolver="(obr)" start-level="20">
-      <feature version="${akka.version}">odl-extras-akka-system</feature>
-      <bundle dependency="true">wrap:mvn:org.uncommons.maths/uncommons-maths/${uncommons.maths.version}</bundle>
-      <bundle dependency="true">mvn:com.google.protobuf/protobuf-java/${protobuf.version}</bundle>
-      <bundle dependency="true">wrap:mvn:io.netty/netty/${netty3.version}</bundle>
-      <bundle>mvn:com.typesafe.akka/akka-remote_${scala.version}/${akka.version}</bundle>
-      <bundle>mvn:com.typesafe.akka/akka-cluster_${scala.version}/${akka.version}</bundle>
-   </feature>
-
-   <feature name='odl-extras-leveldb' description='LevelDB feature' version='0.7' resolver='(obr)'>
-      <bundle start-level="20">wrap:mvn:org.iq80.leveldb/leveldb/${leveldb.version}</bundle>
-      <bundle start-level="20">wrap:mvn:org.fusesource.leveldbjni/leveldbjni-all/${leveldbjni.version}</bundle>
-   </feature>
-</features>
diff --git a/opendaylight/adsal/features/nsf/pom.xml b/opendaylight/adsal/features/nsf/pom.xml
deleted file mode 100644 (file)
index 150196f..0000000
+++ /dev/null
@@ -1,327 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../../opendaylight/commons/opendaylight</relativePath>
-  </parent>
-  <artifactId>features-nsf</artifactId>
-  <version>${nsf.version}</version>
-  <packaging>jar</packaging>
-  <name>OpenDaylight :: Features :: Network Service Functions</name>
-  <description>Feature for Network Service Functions</description>
-  <properties>
-    <features.file>features.xml</features.file>
-  </properties>
-  <dependencies>
-    <!-- test to validate features.xml -->
-    <dependency>
-      <groupId>org.opendaylight.odlparent</groupId>
-      <artifactId>features-test</artifactId>
-    </dependency>
-    <!-- dependency for opendaylight-karaf-empty for use by testing -->
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>opendaylight-karaf-empty</artifactId>
-      <version>1.6.0-SNAPSHOT</version>
-      <type>zip</type>
-    </dependency>
-    <!-- Feature Dependencies -->
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>features-adsal</artifactId>
-      <version>${sal.version}</version>
-      <classifier>features</classifier>
-      <type>xml</type>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>features-base</artifactId>
-      <classifier>features</classifier>
-      <version>${commons.opendaylight.version}</version>
-      <type>xml</type>
-    </dependency>
-    <!-- Bundle Dependencies -->
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>appauth</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>arphandler</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>bundlescanner</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>bundlescanner.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>commons.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>configuration</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>configuration.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>connectionmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>connectionmanager.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>connectionmanager.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>containermanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>containermanager.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>containermanager.shell</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>containermanager.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>controllermanager.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>devices.web</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>flowprogrammer.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>flows.web</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>routing.dijkstra_implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>forwarding.staticrouting</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>forwarding.staticrouting.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>forwardingrulesmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>forwardingrulesmanager.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>hosttracker</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>hosttracker.shell</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>hosttracker.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>hosttracker.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>httpservice-bridge</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>jolokia-bridge</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>logging.bridge</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>networkconfig.bridgedomain.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>osgi-brandfragment.web</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>samples.loadbalancer</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>samples.loadbalancer.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>samples.simpleforwarding</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>security</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>statistics.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>statisticsmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>statisticsmanager.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>subnets.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>switchmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>switchmanager.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>switchmanager.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>topology.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>topology.web</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>topologymanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>topologymanager.shell</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>troubleshoot.web</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>usermanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>usermanager.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>usermanager.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller.thirdparty</groupId>
-      <artifactId>net.sf.jung2</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.eclipse.persistence</groupId>
-      <artifactId>org.eclipse.persistence.antlr</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.eclipse.persistence</groupId>
-      <artifactId>org.eclipse.persistence.core</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.eclipse.persistence</groupId>
-      <artifactId>org.eclipse.persistence.moxy</artifactId>
-    </dependency>
-  </dependencies>
-  <build>
-    <resources>
-      <resource>
-        <filtering>true</filtering>
-        <directory>src/main/resources</directory>
-      </resource>
-    </resources>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.maven.plugins</groupId>
-        <artifactId>maven-resources-plugin</artifactId>
-        <executions>
-          <execution>
-            <id>filter</id>
-            <goals>
-              <goal>resources</goal>
-            </goals>
-            <phase>generate-resources</phase>
-          </execution>
-        </executions>
-      </plugin>
-      <plugin>
-        <groupId>org.codehaus.mojo</groupId>
-        <artifactId>build-helper-maven-plugin</artifactId>
-        <executions>
-          <execution>
-            <id>attach-artifacts</id>
-            <goals>
-              <goal>attach-artifact</goal>
-            </goals>
-            <phase>package</phase>
-            <configuration>
-              <artifacts>
-                <artifact>
-                  <file>${project.build.directory}/classes/${features.file}</file>
-                  <type>xml</type>
-                  <classifier>features</classifier>
-                </artifact>
-              </artifacts>
-            </configuration>
-          </execution>
-        </executions>
-      </plugin>
-      <plugin>
-        <groupId>org.apache.maven.plugins</groupId>
-        <artifactId>maven-surefire-plugin</artifactId>
-        <configuration>
-          <systemPropertyVariables>
-            <karaf.distro.groupId>org.opendaylight.controller</karaf.distro.groupId>
-            <karaf.distro.artifactId>opendaylight-karaf-empty</karaf.distro.artifactId>
-            <karaf.distro.version>${commons.opendaylight.version}</karaf.distro.version>
-          </systemPropertyVariables>
-          <dependenciesToScan>
-           <dependency>org.opendaylight.odlparent:features-test</dependency>
-          </dependenciesToScan>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-</project>
diff --git a/opendaylight/adsal/features/nsf/src/main/resources/features.xml b/opendaylight/adsal/features/nsf/src/main/resources/features.xml
deleted file mode 100644 (file)
index 56271eb..0000000
+++ /dev/null
@@ -1,83 +0,0 @@
-<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
-<features name="nsf-${project.version}"  xmlns="http://karaf.apache.org/xmlns/features/v1.2.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://karaf.apache.org/xmlns/features/v1.2.0 http://karaf.apache.org/xmlns/features/v1.2.0">
-    <repository>mvn:org.opendaylight.controller/features-base/${commons.opendaylight.version}/xml/features</repository>
-    <repository>mvn:org.opendaylight.controller/features-adsal/${sal.version}/xml/features</repository>
-    <feature name="odl-nsf-all" description="OpenDaylight :: NSF :: All Network Service Functions" version="${project.version}">
-        <feature version="${sal.version}">odl-adsal-all</feature>
-        <feature version="${project.version}">odl-nsf-managers</feature>
-        <feature version="${project.version}">odl-adsal-northbound</feature>
-        <!--
-         TODO : Resolve this in a follow-up commit
-            <feature>odl-controller-web</feature>
-        -->
-    </feature>
-
-    <feature name="odl-nsf-service" description="OpenDaylight :: NSF :: Network Service Functions in Controller" version="${project.version}">
-        <feature version="${sal.version}">odl-adsal-all</feature>
-        <feature version="${project.version}">odl-nsf-managers</feature>
-        <feature version="${project.version}">odl-adsal-northbound</feature>
-    </feature>
-
-    <feature name="odl-nsf-managers" description="OpenDaylight :: AD-SAL :: Network Service Functions" version="${project.version}">
-        <feature version="${commons.opendaylight.version}">odl-base-all</feature>
-        <feature version="${sal.version}">odl-adsal-all</feature>
-        <bundle>mvn:org.opendaylight.controller/usermanager/${usermanager.version}</bundle>
-        <bundle>mvn:org.opendaylight.controller/usermanager.implementation/${usermanager.version}</bundle>
-
-        <bundle>mvn:org.opendaylight.controller/appauth/${appauth.version}</bundle>
-
-        <bundle>mvn:org.opendaylight.controller/connectionmanager/${connectionmanager.version}</bundle>
-        <bundle>mvn:org.opendaylight.controller/connectionmanager.implementation/${connectionmanager.version}</bundle>
-
-        <bundle>mvn:org.opendaylight.controller/containermanager/${containermanager.version}</bundle>
-        <bundle>mvn:org.opendaylight.controller/containermanager.implementation/${containermanager.version}</bundle>
-
-        <bundle>mvn:org.opendaylight.controller/statisticsmanager/${statisticsmanager.version}</bundle>
-        <bundle>mvn:org.opendaylight.controller/statisticsmanager.implementation/${statisticsmanager.implementation.version}</bundle>
-
-        <bundle>mvn:org.opendaylight.controller/switchmanager/${switchmanager.api.version}</bundle>
-        <bundle>mvn:org.opendaylight.controller/switchmanager.implementation/${switchmanager.implementation.version}</bundle>
-
-        <bundle>mvn:org.opendaylight.controller/forwardingrulesmanager/${forwardingrulesmanager.version}</bundle>
-        <bundle>mvn:org.opendaylight.controller/forwardingrulesmanager.implementation/${forwardingrulesmanager.implementation.version}</bundle>
-
-        <bundle>mvn:org.opendaylight.controller/topologymanager/${topologymanager.version}</bundle>
-        <bundle>mvn:org.opendaylight.controller/topologymanager.shell/${topologymanager.shell.version}</bundle>
-
-        <bundle>mvn:org.opendaylight.controller/hosttracker/${hosttracker.api.version}</bundle>
-        <bundle>mvn:org.opendaylight.controller/hosttracker.implementation/${hosttracker.implementation.version}</bundle>
-        <bundle>mvn:org.opendaylight.controller/hosttracker.shell/${hosttracker.shell.version}</bundle>
-
-        <bundle>mvn:org.opendaylight.controller/forwarding.staticrouting/${forwarding.staticrouting}</bundle>
-
-        <bundle>mvn:org.opendaylight.controller.thirdparty/net.sf.jung2/2.0.1</bundle>
-        <bundle>mvn:org.opendaylight.controller/routing.dijkstra_implementation/${routing.dijkstra_implementation.version}</bundle>
-    </feature>
-
-    <feature name="odl-adsal-northbound" description="OpenDaylight :: AD-SAL :: Northbound APIs" version="${project.version}">
-        <feature version="${commons.opendaylight.version}">odl-base-all</feature>
-        <feature version="${project.version}">odl-nsf-managers</feature>
-        <bundle>mvn:org.ow2.asm/asm-all/${asm.version}</bundle>
-        <!--
-            TODO : Resolve these in a follow-up commit
-            <bundle>mvn:org.opendaylight.controller/httpservice-bridge/${httpservice-bridge.northbound.version}</bundle>
-            <bundle>mvn:org.opendaylight.controller/jolokia-bridge/${jolokia-bridge.version}</bundle>
-        -->
-        <bundle>mvn:org.opendaylight.controller/bundlescanner/${bundlescanner.api.version}</bundle>
-        <bundle>mvn:org.opendaylight.controller/bundlescanner.implementation/${bundlescanner.implementation.version}</bundle>
-        <bundle>mvn:org.opendaylight.controller/commons.northbound/${northbound.commons.version}</bundle>
-        <bundle>mvn:org.opendaylight.controller/connectionmanager.northbound/${connectionmanager.version}</bundle>
-        <bundle>mvn:org.opendaylight.controller/flowprogrammer.northbound/${flowprogrammer.northbound.version}</bundle>
-        <bundle>mvn:org.opendaylight.controller/hosttracker.northbound/${hosttracker.northbound.version}</bundle>
-        <bundle>mvn:org.opendaylight.controller/networkconfig.bridgedomain.northbound/${networkconfig.bridgedomain.northbound.version}</bundle>
-        <bundle>mvn:org.eclipse.persistence/org.eclipse.persistence.antlr/${eclipse.persistence.version}</bundle>
-        <bundle>mvn:org.eclipse.persistence/org.eclipse.persistence.core/${eclipse.persistence.version}</bundle>
-        <bundle>mvn:org.eclipse.persistence/org.eclipse.persistence.moxy/${eclipse.persistence.version}</bundle>
-        <bundle>mvn:org.opendaylight.controller/forwarding.staticrouting.northbound/${forwarding.staticrouting.northbound.version}</bundle>
-        <bundle>mvn:org.opendaylight.controller/statistics.northbound/${statistics.northbound.version}</bundle>
-        <bundle>mvn:org.opendaylight.controller/subnets.northbound/${subnets.northbound.version}</bundle>
-        <bundle>mvn:org.opendaylight.controller/switchmanager.northbound/${switchmanager.northbound.version}</bundle>
-        <bundle>mvn:org.opendaylight.controller/topology.northbound/${topology.northbound.version}</bundle>
-        <bundle>mvn:org.opendaylight.controller/usermanager.northbound/${usermanager.northbound.version}</bundle>
-    </feature>
-</features>
diff --git a/opendaylight/adsal/forwarding/staticrouting/pom.xml b/opendaylight/adsal/forwarding/staticrouting/pom.xml
deleted file mode 100644 (file)
index d14b312..0000000
+++ /dev/null
@@ -1,72 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>forwarding.staticrouting</artifactId>
-  <version>0.7.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>clustering.services</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>configuration</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>hosttracker</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Import-Package>org.opendaylight.controller.sal.packet.address,
-       org.opendaylight.controller.sal.utils,
-       org.opendaylight.controller.sal.core,
-       org.opendaylight.controller.configuration,
-       org.opendaylight.controller.hosttracker,
-       org.opendaylight.controller.hosttracker.hostAware,
-       org.opendaylight.controller.clustering.services,
-       org.opendaylight.controller.sal.packet,
-       org.opendaylight.controller.sal.routing,
-       org.eclipse.osgi.framework.console,
-       org.osgi.framework,
-       org.slf4j,
-       org.apache.felix.dm</Import-Package>
-            <Export-Package>org.opendaylight.controller.forwarding.staticrouting</Export-Package>
-            <Bundle-Activator>org.opendaylight.controller.forwarding.staticrouting.internal.Activator</Bundle-Activator>
-          </instructions>
-          <manifestLocation>${project.basedir}/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/forwarding/staticrouting/src/main/java/org/opendaylight/controller/forwarding/staticrouting/IForwardingStaticRouting.java b/opendaylight/adsal/forwarding/staticrouting/src/main/java/org/opendaylight/controller/forwarding/staticrouting/IForwardingStaticRouting.java
deleted file mode 100644 (file)
index 03d9453..0000000
+++ /dev/null
@@ -1,56 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.forwarding.staticrouting;
-
-import java.net.InetAddress;
-import java.util.concurrent.ConcurrentMap;
-/**
- *
- * This interface provides APIs to configure and manage static routes.
- *
- */
-import org.opendaylight.controller.sal.utils.Status;
-
-/**
- *
- * This Interface provides APIs to manage and query the static routes
- *
- */
-public interface IForwardingStaticRouting {
-
-    /**
-     * Retrieves the StaticRoute that has the longest prefix matching the ipAddress.
-     * @param ipAddress (InetAddress) the IP address
-     * @return StaticRoute
-     */
-    StaticRoute getBestMatchStaticRoute(InetAddress ipAddress);
-
-    /**
-     * Returns all the StaticRouteConfig
-     * @return all the StaticRouteConfig
-     */
-    ConcurrentMap<String, StaticRouteConfig> getStaticRouteConfigs();
-
-    /**
-     * Adds a StaticRouteConfig
-     * @param config: the StaticRouteConfig to be added
-     * @return a text string indicating the result of the operation..
-     * If the operation is successful, the return string will be "SUCCESS"
-     */
-    Status addStaticRoute(StaticRouteConfig config);
-
-    /**
-     * Removes  the named StaticRouteConfig
-     * @param name: the name of the StaticRouteConfig to be removed
-     * @return a text string indicating the result of the operation.
-     * If the operation is successful, the return string will be "SUCCESS"
-     */
-    Status removeStaticRoute(String name);
-}
diff --git a/opendaylight/adsal/forwarding/staticrouting/src/main/java/org/opendaylight/controller/forwarding/staticrouting/IStaticRoutingAware.java b/opendaylight/adsal/forwarding/staticrouting/src/main/java/org/opendaylight/controller/forwarding/staticrouting/IStaticRoutingAware.java
deleted file mode 100644 (file)
index fb4863b..0000000
+++ /dev/null
@@ -1,25 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.forwarding.staticrouting;
-
-/**
- * Interface that will be implemented by the modules that want to
- * know when a Static Route is added or deleted.
- *
- */
-public interface IStaticRoutingAware {
-
-    /**
-     * This method  is called when a StaticRoute has added or deleted.
-     * @param s: StaticRoute
-     * @param added: boolean true if the static route is added,
-     */
-    void staticRouteUpdate(StaticRoute s, boolean added);
-}
diff --git a/opendaylight/adsal/forwarding/staticrouting/src/main/java/org/opendaylight/controller/forwarding/staticrouting/StaticRoute.java b/opendaylight/adsal/forwarding/staticrouting/src/main/java/org/opendaylight/controller/forwarding/staticrouting/StaticRoute.java
deleted file mode 100644 (file)
index f4df243..0000000
+++ /dev/null
@@ -1,322 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.forwarding.staticrouting;
-
-import java.io.Serializable;
-import java.net.Inet4Address;
-import java.net.Inet6Address;
-import java.net.InetAddress;
-import java.nio.ByteBuffer;
-import java.util.Map;
-
-import org.opendaylight.controller.hosttracker.hostAware.HostNodeConnector;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.packet.BitBufferHelper;
-import org.opendaylight.controller.sal.utils.NodeConnectorCreator;
-import org.opendaylight.controller.sal.utils.NodeCreator;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * This class defines a static route object.
- */
-public class StaticRoute implements Serializable{
-    private static final long serialVersionUID = 1L;
-    protected static final Logger logger = LoggerFactory
-    .getLogger(StaticRoute.class);
-
-    /**
-     * This Enum defines the possible types for the next hop address.
-     */
-    public enum NextHopType implements Serializable {
-        IPADDRESS("nexthop-ip"), SWITCHPORT("nexthop-interface");
-        private NextHopType(String name) {
-            this.name = name;
-        }
-
-        private String name;
-
-        public String toString() {
-            return name;
-        }
-
-        public static NextHopType fromString(String str) {
-            if (str == null)
-                return IPADDRESS;
-            if (str.equals(IPADDRESS.toString()))
-                return IPADDRESS;
-            if (str.equals(SWITCHPORT.toString()))
-                return SWITCHPORT;
-            return IPADDRESS;
-        }
-    }
-
-    InetAddress networkAddress;
-    InetAddress mask;
-    NextHopType type;
-    InetAddress nextHopAddress;
-    Node node;
-    NodeConnector port;
-    HostNodeConnector host;
-
-    /**
-     * Create a static route object with no specific information.
-     */
-    public StaticRoute() {
-
-    }
-
-    /**
-     * Create a static route object from the StaticRouteConfig.
-     * @param: config: StaticRouteConfig
-     */
-    public StaticRoute(StaticRouteConfig config) {
-        networkAddress = config.getStaticRouteIP();
-        mask = StaticRoute.getV4AddressMaskFromDecimal(config
-                .getStaticRouteMask());
-        type = NextHopType.fromString(config.getNextHopType());
-        nextHopAddress = config.getNextHopIP();
-        Map<Long, Short> switchPort = config.getNextHopSwitchPorts();
-        if ((switchPort != null) && (switchPort.size() == 1)) {
-            node = NodeCreator.createOFNode((Long) switchPort.keySet()
-                    .toArray()[0]);
-            port = NodeConnectorCreator.createOFNodeConnector(
-                    (Short) switchPort.values().toArray()[0], node);
-        }
-    }
-
-    /**
-     * Get the IP address portion of the sub-network of the static route.
-     * @return InetAddress: the IP address portion of the sub-network of the static route
-     */
-    public InetAddress getNetworkAddress() {
-        return networkAddress;
-    }
-
-    /**
-     * Set the IP address portion of the sub-network of the static route.
-     * @param networkAddress The IP address (InetAddress) to be set
-     */
-    public void setNetworkAddress(InetAddress networkAddress) {
-        this.networkAddress = networkAddress;
-    }
-
-    /**
-     * Get the mask of the sub-network of the static route.
-     * @return mask: the mask  (InetAddress) of the sub-network of the static route
-     */
-    public InetAddress getMask() {
-        return mask;
-    }
-
-    /**
-     * Set the sub-network's mask of the static route.
-     * @param mask The mask (InetAddress) to be set
-     */
-    public void setMask(InetAddress mask) {
-        this.mask = mask;
-    }
-
-    /**
-     * Get the NextHopeType of the static route.
-     * @return type: NextHopeType
-     */
-    public NextHopType getType() {
-        return type;
-    }
-
-    /**
-     * Set the nextHopType.
-     * @param type The NextHopType to be set
-     */
-    public void setType(NextHopType type) {
-        this.type = type;
-    }
-
-    /**
-     * Get the next hop IP address.
-     * @return: nextHopAddress (InetAddress)
-     */
-    public InetAddress getNextHopAddress() {
-        return nextHopAddress;
-    }
-
-    /**
-     * Set the next hop IP address.
-     * @param nextHopAddress The IP address (InetAddress) to be set
-     */
-    public void setNextHopAddress(InetAddress nextHopAddress) {
-        this.nextHopAddress = nextHopAddress;
-    }
-
-    /**
-     * Get the Node associated with the static route.
-     * @return: Node
-     */
-    public Node getNode() {
-        return node;
-    }
-
-    /**
-     * Set the node associated to the static route.
-     * @param node: The node to be set
-     */
-    public void setNode(Node node) {
-        this.node = node;
-    }
-
-    /**
-     * Set the port associated to the static route.
-     * @param port The port (NodeConnector) to be set
-     */
-    public void setPort(NodeConnector port) {
-        this.port = port;
-    }
-
-    /**
-     * Get the port associated to the static route.
-     * @return port: The port (NodeConnector)
-     */
-    public NodeConnector getPort() {
-        return port;
-    }
-
-    /**
-     * Get the Host associated to static route.
-     * @return host:  The host (HostNodeConnector)
-     */
-    public HostNodeConnector getHost() {
-        return host;
-    }
-
-    /**
-     * Set the host associated to the static route.
-     * @param host: (HostNodeConnector) to be set
-     */
-    public void setHost(HostNodeConnector host) {
-        this.host = host;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + ((host == null) ? 0 : host.hashCode());
-        result = prime * result + ((mask == null) ? 0 : mask.hashCode());
-        result = prime * result
-                + ((networkAddress == null) ? 0 : networkAddress.hashCode());
-        result = prime * result
-                + ((nextHopAddress == null) ? 0 : nextHopAddress.hashCode());
-        result = prime * result + ((port == null) ? 0 : port.hashCode());
-        result = prime * result + ((node == null) ? 0 : node.hashCode());
-        result = prime * result + ((type == null) ? 0 : type.hashCode());
-        return result;
-    }
-
-    @Override
-    public String toString() {
-        return "StaticRoute [networkAddress=" + networkAddress + ", mask="
-                + mask + ", type=" + type.toString() + ", nextHopAddress="
-                + nextHopAddress + ", swid=" + node + ", port=" + port
-                + ", host=" + host + "]";
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj)
-            return true;
-        if (obj == null)
-            return false;
-        if (getClass() != obj.getClass())
-            return false;
-        StaticRoute other = (StaticRoute) obj;
-        if (!networkAddress.equals(other.networkAddress))
-            return false;
-        if (!mask.equals(other.mask))
-            return false;
-        return true;
-    }
-
-    private static InetAddress getV4AddressMaskFromDecimal(int mask) {
-        int netmask = 0;
-        for (int i = 0; i < mask; i++) {
-            netmask |= (1 << 31 - i);
-        }
-
-        try {
-            return InetAddress.getByAddress(BitBufferHelper
-                    .toByteArray(netmask));
-        } catch (Exception e) {
-            logger.error("",e);
-            return null;
-        }
-    }
-
-    private void applyV4MaskOnByteBuffer(ByteBuffer bb, ByteBuffer bbMask) {
-        for (int i = 0; i < bb.array().length; i++) {
-            bb.put(i, (byte) (bb.get(i) & bbMask.get(i)));
-        }
-    }
-
-    /**
-     * Compute and return the IP address  with longest prefix match from the static route based on the
-     *  destNetworkAddress. Currently it only take IPv4 address format (Inet4Address)
-     * @param destNetworkAddress: the IP address to be based on
-     * @return: InetAddress: the IPv4 address with the longest prefix matching the static route.
-     * If the destNetworkkAddress is not IPv4 format, it will return null.
-     */
-    public InetAddress longestPrefixMatch(InetAddress destNetworkAddress) {
-        if (destNetworkAddress instanceof Inet4Address) {
-            ByteBuffer bbdest = ByteBuffer
-                    .wrap(destNetworkAddress.getAddress());
-            ByteBuffer bbself = ByteBuffer.wrap(networkAddress.getAddress());
-
-            ByteBuffer bbMask = ByteBuffer.wrap(mask.getAddress());
-
-            applyV4MaskOnByteBuffer(bbdest, bbMask);
-            applyV4MaskOnByteBuffer(bbself, bbMask);
-
-            if (bbdest.equals(bbself)) {
-                try {
-                    return InetAddress.getByAddress(bbself.array());
-                } catch (Exception e) {
-                    logger.error("",e);
-                }
-            }
-        }
-        return null;
-    }
-
-    /**
-     * Compare the static route with another static route. It only handles(for now) IPv4Address.
-     * @param s: the other StaticRoute
-     * @return: 0 if they are the same
-     */
-    public int compareTo(StaticRoute s) {
-        if (s == null)
-            return 1;
-        if ((networkAddress instanceof Inet6Address)
-                || (s.getNetworkAddress() instanceof Inet6Address)) {
-            // HANDLE IPv6 Later
-            return 1;
-        }
-
-        ByteBuffer bbchallenger = ByteBuffer.wrap(s.getNetworkAddress()
-                .getAddress());
-        ByteBuffer bbself = ByteBuffer.wrap(networkAddress.getAddress());
-        ByteBuffer bbChallengerMask = ByteBuffer.wrap(s.getMask().getAddress());
-        ByteBuffer bbSelfMask = ByteBuffer.wrap(getMask().getAddress());
-
-        applyV4MaskOnByteBuffer(bbchallenger, bbChallengerMask);
-        applyV4MaskOnByteBuffer(bbself, bbSelfMask);
-        return bbself.compareTo(bbchallenger);
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/forwarding/staticrouting/src/main/java/org/opendaylight/controller/forwarding/staticrouting/StaticRouteConfig.java b/opendaylight/adsal/forwarding/staticrouting/src/main/java/org/opendaylight/controller/forwarding/staticrouting/StaticRouteConfig.java
deleted file mode 100644 (file)
index 7726c0f..0000000
+++ /dev/null
@@ -1,384 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.forwarding.staticrouting;
-
-import java.io.Serializable;
-import java.lang.reflect.Field;
-import java.net.InetAddress;
-import java.net.UnknownHostException;
-import java.util.ArrayList;
-import java.util.HashMap;
-import java.util.List;
-import java.util.Map;
-
-import org.opendaylight.controller.configuration.ConfigurationObject;
-import org.opendaylight.controller.sal.utils.GUIField;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.sal.utils.StatusCode;
-
-/**
- * This class defines all the necessary configuration information for a static route.
- */
-public class StaticRouteConfig extends ConfigurationObject implements Serializable {
-    private static final long serialVersionUID = 1L;
-    private static final String regexSubnet = "^([01]?\\d\\d?|2[0-4]\\d|25[0-5])\\."
-            + "([01]?\\d\\d?|2[0-4]\\d|25[0-5])\\."
-            + "([01]?\\d\\d?|2[0-4]\\d|25[0-5])\\."
-            + "([01]?\\d\\d?|2[0-4]\\d|25[0-5])[/](\\d|[12]\\d|3[0-2])$";
-    private static final String regexIP = "^([01]?\\d\\d?|2[0-4]\\d|25[0-5])\\."
-            + "([01]?\\d\\d?|2[0-4]\\d|25[0-5])\\."
-            + "([01]?\\d\\d?|2[0-4]\\d|25[0-5])\\."
-            + "([01]?\\d\\d?|2[0-4]\\d|25[0-5])$";
-    private static final String regexDatapathID = "^([0-9a-fA-F]{1,2}[:-]){7}[0-9a-fA-F]{1,2}$";
-    private static final String regexDatapathIDLong = "^[0-9a-fA-F]{1,16}$";
-    private static final String prettyFields[] = { GUIField.NAME.toString(),
-            GUIField.STATICROUTE.toString(), GUIField.NEXTHOP.toString() };
-    private transient String nextHopType; // Ignoring NextHopType for now. Supporting just the next-hop IP-Address feature for now.
-    // Order matters: JSP file expects following fields in the following order
-    private String name;
-    private String staticRoute; // A.B.C.D/MM  Where A.B.C.D is the Default Gateway IP (L3) or ARP Querier IP (L2)
-    private String nextHop; // NextHop IP-Address (or) datapath ID/port list: xx:xx:xx:xx:xx:xx:xx:xx/a,b,c-m,r-t,y
-
-    /**
-     * Create a static route configuration  with no specific information.
-     */
-    public StaticRouteConfig() {
-        super();
-        nextHopType = StaticRoute.NextHopType.IPADDRESS.toString();
-    }
-
-    /**
-     * Create a static route configuration with all the information.
-     * @param name The name (String) of the static route config
-     * @param staticRoute The string representation of the route. e.g. 192.168.1.1/24
-     * @param nextHop The string representation of the next hop IP address. e.g. 10.10.1.1
-     */
-    public StaticRouteConfig(String name, String staticRoute, String nextHop) {
-        super();
-        this.name = name;
-        this.staticRoute = staticRoute;
-        this.nextHop = nextHop;
-    }
-
-    /**
-     * Get the name of the StaticRouteConfig.
-     * @return: The name
-     */
-    public String getName() {
-        return name;
-    }
-
-    /**
-     * Set the name of the StaticRouteConfig.
-     * @param name The name to set
-     */
-    public void setName(String name) {
-        this.name = name;
-    }
-
-    /**
-     * Get the string representation of the static route.
-     * @return The string representation of the static route
-     */
-    public String getStaticRoute() {
-        return staticRoute;
-    }
-
-    /**
-     * Set the static route of the StaticRouteConfig.
-     * @param staticRoute The string representation of the static route
-     */
-    public void setStaticRoute(String staticRoute) {
-        this.staticRoute = staticRoute;
-    }
-
-    /**
-     * Get the string representation of the next hop address type.
-     * @return The string representation of the next hop address type
-     */
-    public String getNextHopType() {
-        if (nextHopType == null) {
-            return StaticRoute.NextHopType.IPADDRESS.toString();
-        }
-        return nextHopType;
-    }
-
-    /**
-     * Set the next hop address type.
-     * @param nextHopType The string representation of the next hop address type
-     */
-    public void setNextHopType(String nextHopType) {
-        this.nextHopType = nextHopType;
-    }
-
-    /**
-     * Get all the supported next hop address types.
-     * @return The list of supported next hop address types
-     */
-    public static List<String> getSupportedNextHopTypes() {
-        List<String> s = new ArrayList<String>();
-        for (StaticRoute.NextHopType nh : StaticRoute.NextHopType.values()) {
-            s.add(nh.toString());
-        }
-        return s;
-    }
-
-    /**
-     * Get the next hop address
-     * @return The string represenation of the next hop address
-     */
-    public String getNextHop() {
-        return nextHop;
-    }
-
-    /**
-     * Set the next hop address.
-     * @param nextHop: The string representation of the next hop address to be set
-     */
-    public void setNextHop(String nextHop) {
-        this.nextHop = nextHop;
-    }
-
-    /**
-     * Return a string with text indicating if the config is valid.
-     * @return SUCCESS if the config is valid
-     */
-    public Status isValid() {
-        if (!isValidResourceName(name)) {
-            return new Status(StatusCode.BADREQUEST,
-                        "Invalid Static Route name");
-        }
-        if (!isValidStaticRouteEntry()) {
-            return new Status(StatusCode.BADREQUEST,
-                        "Invalid Static Route entry. Please use the " +
-                        "IPAddress/mask format. Default gateway " +
-                        "(0.0.0.0/0) is NOT supported.");
-        }
-        if (!isValidNextHop()) {
-            return new Status(StatusCode.BADREQUEST,
-                        "Invalid NextHop IP Address configuration. " +
-                                        "Please use the X.X.X.X format.");
-        }
-
-        return new Status(StatusCode.SUCCESS, null);
-    }
-
-    private boolean isValidAddress(String address) {
-        if ((address != null) && address.matches(regexIP)) {
-            return true;
-        }
-        return false;
-    }
-
-    private boolean isValidStaticRouteEntry() {
-        if ((staticRoute != null) && staticRoute.matches(regexSubnet)) {
-            return true;
-        }
-        return false;
-    }
-
-    private boolean isValidNextHop() {
-        if (getNextHopType().equalsIgnoreCase(
-                StaticRoute.NextHopType.IPADDRESS.toString())) {
-            return isValidNextHopIP();
-        } else if (getNextHopType().equalsIgnoreCase(
-                StaticRoute.NextHopType.SWITCHPORT.toString())) {
-            return isValidSwitchId();
-        }
-        return false;
-    }
-
-    private boolean isValidNextHopIP() {
-        return isValidAddress(nextHop);
-    }
-
-    private boolean isValidSwitchId(String switchId) {
-        return (switchId != null && (switchId.matches(regexDatapathID) || switchId
-                .matches(regexDatapathIDLong)));
-    }
-
-    private boolean isValidSwitchId() {
-        if (getNextHopType().equalsIgnoreCase(
-                StaticRoute.NextHopType.SWITCHPORT.toString())) {
-            String pieces[] = nextHop.split("/");
-            if (pieces.length < 2) {
-                return false;
-            }
-            return isValidSwitchId(pieces[0]);
-        }
-        return false;
-    }
-
-    /**
-     * Return the IP address of the static route.
-     * @return The IP address
-     */
-    public InetAddress getStaticRouteIP() {
-        if (!isValidStaticRouteEntry()) {
-            return null;
-        }
-        InetAddress ip = null;
-        try {
-            ip = InetAddress.getByName(staticRoute.split("/")[0]);
-        } catch (UnknownHostException e1) {
-            return null;
-        }
-        return ip;
-    }
-
-    /**
-     * Return the bit-mask length of the static route.
-     * @return The bit-mask length
-     */
-    public Short getStaticRouteMask() {
-        Short maskLen = 0;
-        if (isValidStaticRouteEntry()) {
-            String[] s = staticRoute.split("/");
-            maskLen = (s.length == 2) ? Short.valueOf(s[1]) : 32;
-        }
-        return maskLen;
-    }
-
-    /**
-     * Return the IP address of the next hop.
-     * @return the IP address
-     */
-    public InetAddress getNextHopIP() {
-        if ((getNextHopType()
-                .equalsIgnoreCase(StaticRoute.NextHopType.IPADDRESS.toString()))
-                && isValidNextHopIP()) {
-            InetAddress ip = null;
-            try {
-                ip = InetAddress.getByName(nextHop);
-            } catch (UnknownHostException e1) {
-                return null;
-            }
-            return ip;
-        }
-        return null;
-    }
-
-/**
- * Return the switch ID and the port ID of the next hop address.
- * @return The switchID (Long) and PortID (Short) in the map
- */
-    public Map<Long, Short> getNextHopSwitchPorts() {
-        // codedSwitchPorts = xx:xx:xx:xx:xx:xx:xx:xx/port-number
-        if (getNextHopType().equalsIgnoreCase(
-                StaticRoute.NextHopType.SWITCHPORT.toString())) {
-            Map<Long, Short> sp = new HashMap<Long, Short>(1);
-            String pieces[] = nextHop.split("/");
-            sp.put(getSwitchIDLong(pieces[0]), Short.valueOf(pieces[1]));
-            return sp;
-        }
-        return null;
-    }
-
-    private long getSwitchIDLong(String switchId) {
-        int radix = 16;
-        String switchString = "0";
-
-        if (isValidSwitchId(switchId)) {
-            if (switchId.contains(":")) {
-                // Handle the 00:00:AA:BB:CC:DD:EE:FF notation
-                switchString = switchId.replace(":", "");
-            } else if (switchId.contains("-")) {
-                // Handle the 00-00-AA-BB-CC-DD-EE-FF notation
-                switchString = switchId.replace("-", "");
-            } else {
-                // Handle the 0123456789ABCDEF notation
-                switchString = switchId;
-            }
-        }
-        return Long.parseLong(switchString, radix);
-    }
-
-    /**
-     * Return all the field names of the config.
-     * @return The list containing all the field names
-     */
-    public static List<String> getFieldsNames() {
-        List<String> fieldList = new ArrayList<String>();
-        for (Field fld : StaticRouteConfig.class.getDeclaredFields()) {
-            fieldList.add(fld.getName());
-        }
-        //remove the 6 static fields + NextHopType
-        for (short i = 0; i < 7; i++) {
-            fieldList.remove(0);
-        }
-        return fieldList;
-    }
-
-    /**
-     * Return all the GUI field names of the config.
-     * @return The list containing all the GUI field names
-     */
-    public static List<String> getGuiFieldsNames() {
-        List<String> fieldList = new ArrayList<String>();
-        for (String str : prettyFields) {
-            fieldList.add(str);
-        }
-        return fieldList;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + ((name == null) ? 0 : name.hashCode());
-        result = prime * result + ((nextHop == null) ? 0 : nextHop.hashCode());
-        result = prime * result
-                + ((staticRoute == null) ? 0 : staticRoute.hashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        StaticRouteConfig other = (StaticRouteConfig) obj;
-        if (name == null) {
-            if (other.name != null) {
-                return false;
-            }
-        } else if (!name.equals(other.name)) {
-            return false;
-        }
-        if (nextHop == null) {
-            if (other.nextHop != null) {
-                return false;
-            }
-        } else if (!nextHop.equals(other.nextHop)) {
-            return false;
-        }
-        if (staticRoute == null) {
-            if (other.staticRoute != null) {
-                return false;
-            }
-        } else if (!staticRoute.equals(other.staticRoute)) {
-            return false;
-        }
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        return "StaticRouteConfig [name=" + name + ", staticRoute="
-                + staticRoute + ", nextHopType=" + nextHopType + ", nextHop="
-                + nextHop + "]";
-    }
-}
diff --git a/opendaylight/adsal/forwarding/staticrouting/src/main/java/org/opendaylight/controller/forwarding/staticrouting/internal/Activator.java b/opendaylight/adsal/forwarding/staticrouting/src/main/java/org/opendaylight/controller/forwarding/staticrouting/internal/Activator.java
deleted file mode 100644 (file)
index 7be9c23..0000000
+++ /dev/null
@@ -1,87 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.forwarding.staticrouting.internal;
-
-import org.apache.felix.dm.Component;
-import org.opendaylight.controller.forwarding.staticrouting.IForwardingStaticRouting;
-import org.opendaylight.controller.forwarding.staticrouting.IStaticRoutingAware;
-import org.opendaylight.controller.sal.core.ComponentActivatorAbstractBase;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import org.opendaylight.controller.clustering.services.IClusterContainerServices;
-import org.opendaylight.controller.configuration.IConfigurationContainerAware;
-import org.opendaylight.controller.configuration.IConfigurationContainerService;
-import org.opendaylight.controller.hosttracker.IfIptoHost;
-import org.opendaylight.controller.hosttracker.IfNewHostNotify;
-
-public class Activator extends ComponentActivatorAbstractBase {
-    protected static final Logger logger = LoggerFactory
-            .getLogger(Activator.class);
-
-
-    /**
-     * Function that is used to communicate to dependency manager the
-     * list of known implementations for services inside a container
-     *
-     *
-     * @return An array containing all the CLASS objects that will be
-     * instantiated in order to get an fully working implementation
-     * Object
-     */
-    @Override
-    public Object[] getImplementations() {
-        Object[] res = { StaticRoutingImplementation.class };
-        return res;
-    }
-
-    /**
-     * Function that is called when configuration of the dependencies
-     * is required.
-     *
-     * @param c dependency manager Component object, used for
-     * configuring the dependencies exported and imported
-     * @param imp Implementation class that is being configured,
-     * needed as long as the same routine can configure multiple
-     * implementations
-     * @param containerName The containerName being configured, this allow
-     * also optional per-container different behavior if needed, usually
-     * should not be the case though.
-     */
-    @Override
-    public void configureInstance(Component c, Object imp, String containerName) {
-        if (imp.equals(StaticRoutingImplementation.class)) {
-            c.setInterface(new String[] {
-                    IForwardingStaticRouting.class.getName(),
-                    IfNewHostNotify.class.getName(),
-                    IConfigurationContainerAware.class.getName() }, null);
-
-            c.add(createContainerServiceDependency(containerName).setService(
-                    IClusterContainerServices.class).setCallbacks(
-                    "setClusterContainerService",
-                    "unsetClusterContainerService").setRequired(true));
-
-            c.add(createContainerServiceDependency(containerName).setService(
-                    IfIptoHost.class).setCallbacks("setHostTracker",
-                    "unsetHostTracker").setRequired(true));
-
-            // Static routing aware there could be many
-            c.add(createContainerServiceDependency(containerName).setService(
-                    IStaticRoutingAware.class).setCallbacks(
-                    "setStaticRoutingAware", "unsetStaticRoutingAware")
-                    .setRequired(false));
-
-            c.add(createContainerServiceDependency(containerName).setService(
-                    IConfigurationContainerService.class).setCallbacks(
-                    "setConfigurationContainerService",
-                    "unsetConfigurationContainerService").setRequired(true));
-        }
-    }
-}
diff --git a/opendaylight/adsal/forwarding/staticrouting/src/main/java/org/opendaylight/controller/forwarding/staticrouting/internal/StaticRoutingImplementation.java b/opendaylight/adsal/forwarding/staticrouting/src/main/java/org/opendaylight/controller/forwarding/staticrouting/internal/StaticRoutingImplementation.java
deleted file mode 100644 (file)
index fedf554..0000000
+++ /dev/null
@@ -1,484 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.forwarding.staticrouting.internal;
-
-import java.io.FileNotFoundException;
-import java.io.IOException;
-import java.io.ObjectInputStream;
-import java.net.Inet4Address;
-import java.net.InetAddress;
-import java.nio.ByteBuffer;
-import java.util.ArrayList;
-import java.util.Collections;
-import java.util.Dictionary;
-import java.util.EnumSet;
-import java.util.HashSet;
-import java.util.Map;
-import java.util.Set;
-import java.util.Timer;
-import java.util.TimerTask;
-import java.util.concurrent.Callable;
-import java.util.concurrent.ConcurrentMap;
-import java.util.concurrent.ExecutorService;
-import java.util.concurrent.Executors;
-import java.util.concurrent.Future;
-import java.util.regex.Matcher;
-import java.util.regex.Pattern;
-
-import org.apache.felix.dm.Component;
-import org.opendaylight.controller.clustering.services.CacheConfigException;
-import org.opendaylight.controller.clustering.services.CacheExistException;
-import org.opendaylight.controller.clustering.services.IClusterContainerServices;
-import org.opendaylight.controller.clustering.services.IClusterServices;
-import org.opendaylight.controller.configuration.ConfigurationObject;
-import org.opendaylight.controller.configuration.IConfigurationContainerAware;
-import org.opendaylight.controller.configuration.IConfigurationContainerService;
-import org.opendaylight.controller.forwarding.staticrouting.IForwardingStaticRouting;
-import org.opendaylight.controller.forwarding.staticrouting.IStaticRoutingAware;
-import org.opendaylight.controller.forwarding.staticrouting.StaticRoute;
-import org.opendaylight.controller.forwarding.staticrouting.StaticRouteConfig;
-import org.opendaylight.controller.hosttracker.HostIdFactory;
-import org.opendaylight.controller.hosttracker.IHostId;
-import org.opendaylight.controller.hosttracker.IfIptoHost;
-import org.opendaylight.controller.hosttracker.IfNewHostNotify;
-import org.opendaylight.controller.hosttracker.hostAware.HostNodeConnector;
-import org.opendaylight.controller.sal.utils.IObjectReader;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.sal.utils.StatusCode;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * Static Routing feature provides the bridge between SDN and Non-SDN networks.
- */
-public class StaticRoutingImplementation implements IfNewHostNotify, IForwardingStaticRouting, IObjectReader,
-        IConfigurationContainerAware {
-    private static Logger log = LoggerFactory.getLogger(StaticRoutingImplementation.class);
-    private static final String STATIC_ROUTES_FILE_NAME = "staticRouting.conf";
-    ConcurrentMap<String, StaticRoute> staticRoutes;
-    ConcurrentMap<String, StaticRouteConfig> staticRouteConfigs;
-    private IfIptoHost hostTracker;
-    private Timer gatewayProbeTimer;
-    private IClusterContainerServices clusterContainerService = null;
-    private IConfigurationContainerService configurationService;
-    private Set<IStaticRoutingAware> staticRoutingAware = Collections
-            .synchronizedSet(new HashSet<IStaticRoutingAware>());
-    private ExecutorService executor;
-
-    void setStaticRoutingAware(IStaticRoutingAware s) {
-        if (this.staticRoutingAware != null) {
-            this.staticRoutingAware.add(s);
-        }
-    }
-
-    void unsetStaticRoutingAware(IStaticRoutingAware s) {
-        if (this.staticRoutingAware != null) {
-            this.staticRoutingAware.remove(s);
-        }
-    }
-
-    public void setHostTracker(IfIptoHost hostTracker) {
-        log.debug("Setting HostTracker");
-        this.hostTracker = hostTracker;
-    }
-
-    public void unsetHostTracker(IfIptoHost hostTracker) {
-        if (this.hostTracker == hostTracker) {
-            this.hostTracker = null;
-        }
-    }
-
-    public void setConfigurationContainerService(IConfigurationContainerService service) {
-        log.trace("Got configuration service set request {}", service);
-        this.configurationService = service;
-    }
-
-    public void unsetConfigurationContainerService(IConfigurationContainerService service) {
-        log.trace("Got configuration service UNset request");
-        this.configurationService = null;
-    }
-
-    @Override
-    public ConcurrentMap<String, StaticRouteConfig> getStaticRouteConfigs() {
-        return staticRouteConfigs;
-    }
-
-    @Override
-    public Object readObject(ObjectInputStream ois) throws FileNotFoundException, IOException, ClassNotFoundException {
-        // Perform the class deserialization locally, from inside the package
-        // where the class is defined
-        return ois.readObject();
-    }
-
-
-    private void loadConfiguration() {
-        for (ConfigurationObject conf : configurationService.retrieveConfiguration(this, STATIC_ROUTES_FILE_NAME)) {
-            addStaticRoute((StaticRouteConfig) conf);
-        }
-    }
-
-    private Status saveConfig() {
-        return saveConfigInternal();
-    }
-
-    public Status saveConfigInternal() {
-        Status status = configurationService.persistConfiguration(
-                new ArrayList<ConfigurationObject>(staticRouteConfigs.values()), STATIC_ROUTES_FILE_NAME);
-
-        if (status.isSuccess()) {
-            return status;
-        } else {
-            return new Status(StatusCode.INTERNALERROR, "Save failed");
-        }
-    }
-
-    private void allocateCaches() {
-        if (this.clusterContainerService == null) {
-            log.trace("un-initialized clusterContainerService, can't create cache");
-            return;
-        }
-
-        try {
-            clusterContainerService.createCache("forwarding.staticrouting.routes",
-                    EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-            clusterContainerService.createCache("forwarding.staticrouting.configs",
-                    EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-        } catch (CacheExistException cee) {
-            log.error("\nCache already exists - destroy and recreate if needed");
-        } catch (CacheConfigException cce) {
-            log.error("\nCache configuration invalid - check cache mode");
-        }
-    }
-
-    @SuppressWarnings({ "unchecked" })
-    private void retrieveCaches() {
-        if (this.clusterContainerService == null) {
-            log.warn("un-initialized clusterContainerService, can't retrieve cache");
-            return;
-        }
-
-        staticRoutes = (ConcurrentMap<String, StaticRoute>) clusterContainerService
-                .getCache("forwarding.staticrouting.routes");
-        if (staticRoutes == null) {
-            log.error("\nFailed to get rulesDB handle");
-        }
-
-        staticRouteConfigs = (ConcurrentMap<String, StaticRouteConfig>) clusterContainerService
-                .getCache("forwarding.staticrouting.configs");
-        if (staticRouteConfigs == null) {
-            log.error("\nFailed to get rulesDB handle");
-        }
-    }
-
-    private void notifyStaticRouteUpdate(StaticRoute s, boolean update) {
-        if (this.staticRoutingAware != null) {
-            log.trace("Invoking StaticRoutingAware listeners");
-            synchronized (this.staticRoutingAware) {
-                for (IStaticRoutingAware ra : this.staticRoutingAware) {
-                    try {
-                        ra.staticRouteUpdate(s, update);
-                    } catch (Exception e) {
-                        log.error("", e);
-                    }
-                }
-            }
-        }
-    }
-
-    private class NotifyStaticRouteWorker implements Callable<Object> {
-
-        private String name;
-        private StaticRoute staticRoute;
-        private boolean added;
-
-        public NotifyStaticRouteWorker(String name, StaticRoute s, boolean update) {
-            this.name = name;
-            this.staticRoute = s;
-            this.added = update;
-        }
-
-        @Override
-        public Object call() throws Exception {
-            if (!added || (staticRoute.getType() == StaticRoute.NextHopType.SWITCHPORT)) {
-                notifyStaticRouteUpdate(staticRoute, added);
-            } else {
-                InetAddress nh = staticRoute.getNextHopAddress();
-                // HostTracker hosts db key scheme implementation
-                IHostId id = HostIdFactory.create(nh, null);
-                HostNodeConnector host = hostTracker.hostQuery(id);
-                if (host == null) {
-                    log.debug("Next hop {}  is not present, try to discover it", nh.getHostAddress());
-                    Future<HostNodeConnector> future = hostTracker.discoverHost(id);
-                    if (future != null) {
-                        try {
-                            host = future.get();
-                        } catch (InterruptedException ioe) {
-                            log.trace("Thread interrupted {}", ioe);
-                        } catch (Exception e) {
-                            log.error("", e);
-                        }
-                    }
-                }
-                if (host != null) {
-                    log.debug("Next hop {} is found", nh.getHostAddress());
-                    staticRoute.setHost(host);
-                    // static route object has changed
-                    // put the changed object back in the cache
-                    // for it to sync
-                    staticRoutes.put(name, staticRoute);
-                    notifyStaticRouteUpdate(staticRoute, added);
-                } else {
-                    log.debug("Next hop {}  is still not present, try again later", nh.getHostAddress());
-                }
-            }
-            return null;
-        }
-    }
-
-    private void checkAndUpdateListeners(String name, StaticRoute staticRoute, boolean added) {
-        NotifyStaticRouteWorker worker = new NotifyStaticRouteWorker(name, staticRoute, added);
-        try {
-            executor.submit(worker);
-        } catch (Exception e) {
-            log.error("got Exception ", e);
-        }
-    }
-
-    private void notifyHostUpdate(HostNodeConnector host, boolean added) {
-        if (host == null) {
-            return;
-        }
-        for (Map.Entry<String, StaticRoute> s : staticRoutes.entrySet()) {
-            StaticRoute route = s.getValue();
-            if (route.getType() == StaticRoute.NextHopType.SWITCHPORT) {
-                continue;
-            }
-            if (route.getNextHopAddress().equals(host.getNetworkAddress())) {
-                if (added) {
-                    route.setHost(host);
-                } else {
-                    route.setHost(null);
-                }
-                // static route object has changed
-                // put the changed object back in the cache
-                // for it to sync
-                staticRoutes.put(s.getKey(), route);
-                notifyStaticRouteUpdate(route, added);
-            }
-        }
-    }
-
-    @Override
-    public void notifyHTClient(HostNodeConnector host) {
-        notifyHostUpdate(host, true);
-    }
-
-    @Override
-    public void notifyHTClientHostRemoved(HostNodeConnector host) {
-        notifyHostUpdate(host, false);
-    }
-
-    public boolean isIPv4AddressValid(String cidr) {
-        if (cidr == null) {
-            return false;
-        }
-
-        String values[] = cidr.split("/");
-        Pattern ipv4Pattern = Pattern
-                .compile("(([01]?\\d\\d?|2[0-4]\\d|25[0-5])\\.){3}([01]?\\d\\d?|2[0-4]\\d|25[0-5])");
-        Matcher mm = ipv4Pattern.matcher(values[0]);
-        if (!mm.matches()) {
-            log.debug("IPv4 source address {} is not valid", cidr);
-            return false;
-        }
-        if (values.length >= 2) {
-            int prefix = Integer.valueOf(values[1]);
-            if ((prefix < 0) || (prefix > 32)) {
-                log.debug("prefix {} is not valid", prefix);
-                return false;
-            }
-        }
-        return true;
-    }
-
-    public static short getUnsignedByte(ByteBuffer bb, int position) {
-        return ((short) (bb.get(position) & (short) 0xff));
-    }
-
-    public static int compareByteBuffers(ByteBuffer buf1, ByteBuffer buf2) {
-        for (int i = 0; i < buf1.array().length; i++) {
-            if (getUnsignedByte(buf1, i) > getUnsignedByte(buf2, i)) {
-                return 1;
-            } else if (getUnsignedByte(buf1, i) < getUnsignedByte(buf2, i)) {
-                return -1;
-            }
-        }
-
-        return 0;
-    }
-
-    @Override
-    public StaticRoute getBestMatchStaticRoute(InetAddress ipAddress) {
-        ByteBuffer bblongestPrefix = null;
-        try {
-            bblongestPrefix = ByteBuffer.wrap(InetAddress.getByName("0.0.0.0").getAddress());
-        } catch (Exception e) {
-            return null;
-        }
-
-        if (staticRoutes == null) {
-            return null;
-        }
-
-        StaticRoute longestPrefixRoute = null;
-        for (StaticRoute s : staticRoutes.values()) {
-            InetAddress prefix = s.longestPrefixMatch(ipAddress);
-            if ((prefix != null) && (prefix instanceof Inet4Address)) {
-                ByteBuffer bbtmp = ByteBuffer.wrap(prefix.getAddress());
-                if (compareByteBuffers(bbtmp, bblongestPrefix) > 0) {
-                    bblongestPrefix = bbtmp;
-                    longestPrefixRoute = s;
-                }
-            }
-        }
-        return longestPrefixRoute;
-    }
-
-    @Override
-    public Status addStaticRoute(StaticRouteConfig config) {
-        Status status = config.isValid();
-        if (!status.isSuccess()) {
-            return status;
-        }
-        if (staticRouteConfigs.get(config.getName()) != null) {
-            return new Status(StatusCode.CONFLICT, "A valid Static Route configuration with this name "
-                    + "already exists. Please use a different name");
-        }
-
-        // Update database
-        StaticRoute sRoute = new StaticRoute(config);
-
-        for (Map.Entry<String, StaticRoute> entry : staticRoutes.entrySet()) {
-            if (entry.getValue().compareTo(sRoute) == 0) {
-                return new Status(StatusCode.CONFLICT, "This conflicts with an existing Static Route "
-                        + "Configuration. Please check the configuration " + "and try again");
-            }
-        }
-        staticRoutes.put(config.getName(), sRoute);
-
-        // Update config databse
-        staticRouteConfigs.put(config.getName(), config);
-
-        // Notify
-        checkAndUpdateListeners(config.getName(), sRoute, true);
-        return status;
-    }
-
-    @Override
-    public Status removeStaticRoute(String name) {
-        staticRouteConfigs.remove(name);
-        StaticRoute sRoute = staticRoutes.remove(name);
-        if (sRoute != null) {
-            checkAndUpdateListeners(name, sRoute, false);
-            return new Status(StatusCode.SUCCESS, null);
-        }
-        return new Status(StatusCode.NOTFOUND, "Static Route with name " + name + " is not found");
-    }
-
-    void setClusterContainerService(IClusterContainerServices s) {
-        log.debug("Cluster Service set");
-        this.clusterContainerService = s;
-    }
-
-    void unsetClusterContainerService(IClusterContainerServices s) {
-        if (this.clusterContainerService == s) {
-            log.debug("Cluster Service removed!");
-            this.clusterContainerService = null;
-        }
-    }
-
-    /**
-     * Function called by the dependency manager when all the required
-     * dependencies are satisfied
-     *
-     */
-    void init(Component c) {
-        String containerName = null;
-        Dictionary props = c.getServiceProperties();
-        if (props != null) {
-            containerName = (String) props.get("containerName");
-        } else {
-            // In the Global instance case the containerName is empty
-            containerName = "";
-        }
-
-        log.debug("forwarding.staticrouting starting on container {}", containerName);
-        allocateCaches();
-        retrieveCaches();
-        this.executor = Executors.newFixedThreadPool(1);
-        loadConfiguration();
-
-        /*
-         * Slow probe to identify any gateway that might have silently appeared
-         * after the Static Routing Configuration.
-         */
-        gatewayProbeTimer = new Timer();
-        gatewayProbeTimer.schedule(new TimerTask() {
-            @Override
-            public void run() {
-                for (Map.Entry<String, StaticRoute> s : staticRoutes.entrySet()) {
-                    StaticRoute route = s.getValue();
-                    if ((route.getType() == StaticRoute.NextHopType.IPADDRESS) && route.getHost() == null) {
-                        checkAndUpdateListeners(s.getKey(), route, true);
-                    }
-                }
-            }
-        }, 60 * 1000, 60 * 1000);
-
-    }
-
-    /**
-     * Function called by the dependency manager when at least one dependency
-     * become unsatisfied or when the component is shutting down because for
-     * example bundle is being stopped.
-     *
-     */
-    void destroy() {
-        log.debug("Destroy all the Static Routing Rules given we are " + "shutting down");
-
-        gatewayProbeTimer.cancel();
-
-        // Clear the listener so to be ready in next life
-        this.staticRoutingAware.clear();
-    }
-
-    /**
-     * Function called by dependency manager after "init ()" is called and after
-     * the services provided by the class are registered in the service registry
-     *
-     */
-    void start() {
-    }
-
-    /**
-     * Function called by the dependency manager before the services exported by
-     * the component are unregistered, this will be followed by a "destroy ()"
-     * calls
-     *
-     */
-    void stop() {
-        executor.shutdown();
-    }
-
-    @Override
-    public Status saveConfiguration() {
-        return this.saveConfig();
-    }
-
-}
diff --git a/opendaylight/adsal/forwarding/staticrouting/src/test/java/org/opendaylight/controller/forwarding/staticrouting/StaticRouteConfigTest.java b/opendaylight/adsal/forwarding/staticrouting/src/test/java/org/opendaylight/controller/forwarding/staticrouting/StaticRouteConfigTest.java
deleted file mode 100644 (file)
index 7cd085f..0000000
+++ /dev/null
@@ -1,110 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.forwarding.staticrouting;
-
-
-import java.net.InetAddress;
-import org.junit.Assert;
-import org.junit.Test;
-import org.opendaylight.controller.forwarding.staticrouting.StaticRoute.NextHopType;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.sal.utils.StatusCode;
-
-public class StaticRouteConfigTest {
-
-        @Test
-        public void testStaticRouteSetGet() {
-                StaticRouteConfig staticRouteConfig1 = new StaticRouteConfig();
-                staticRouteConfig1.setName("route");
-                staticRouteConfig1.setStaticRoute("10.1.1.2/32");
-                staticRouteConfig1.setNextHop("200.2.2.2");
-                staticRouteConfig1.setNextHopType(NextHopType.IPADDRESS.toString());
-                StaticRouteConfig staticRouteConfig2 = new StaticRouteConfig("route", "10.1.1.2/32", "200.2.2.2");
-
-                Assert.assertEquals(staticRouteConfig2.getName(), staticRouteConfig1.getName());
-                Assert.assertEquals(staticRouteConfig2.getStaticRoute(), staticRouteConfig1.getStaticRoute());
-                Assert.assertEquals(staticRouteConfig2.getNextHop(), staticRouteConfig1.getNextHop());
-                Assert.assertEquals("nexthop-ip", staticRouteConfig1.getNextHopType());
-        }
-
-        @Test
-        public void testStaticRouteisValid() {
-        StaticRouteConfig staticRouteConfig1 = new StaticRouteConfig("route1", "10.1.1.254/24", "100.1.1.1");
-                Status receivedResponse1 = staticRouteConfig1.isValid();
-                Status expectedResponse1 = new Status(StatusCode.SUCCESS, null);
-                Assert.assertEquals(expectedResponse1.toString(), receivedResponse1.toString());
-
-        StaticRouteConfig staticRouteConfig2 = new StaticRouteConfig("", "", "100.1.1.1");
-                Status receivedResponse2 = staticRouteConfig2.isValid();
-                Status expectedResponse2 = new Status(StatusCode.BADREQUEST,
-                        "Invalid Static Route name");
-                Assert.assertEquals(expectedResponse2.toString(), receivedResponse2.toString());
-
-        StaticRouteConfig staticRouteConfig3 = new StaticRouteConfig("route1", "10.1.1.254", "100.1.1.1");
-                Status receivedResponse3 = staticRouteConfig3.isValid();
-                Status expectedResponse3 = new Status(StatusCode.BADREQUEST,
-                        "Invalid Static Route entry. Please use the " +
-                        "IPAddress/mask format. Default gateway " +
-                        "(0.0.0.0/0) is NOT supported.");
-                Assert.assertEquals(expectedResponse3.toString(), receivedResponse3.toString());
-
-        StaticRouteConfig staticRouteConfig4 = new StaticRouteConfig("route1", "289.1.1.254/24", "100.1.1.1");
-                Status receivedResponse4 = staticRouteConfig4.isValid();
-                Status expectedResponse4 = new Status(StatusCode.BADREQUEST,
-                        "Invalid Static Route entry. Please use the " +
-                        "IPAddress/mask format. Default gateway " +
-                        "(0.0.0.0/0) is NOT supported.");
-                Assert.assertEquals(expectedResponse4.toString(), receivedResponse4.toString());
-
-        StaticRouteConfig staticRouteConfig5 = new StaticRouteConfig("route1", "10.1.1.254/24", "100.1.1");
-                Status receivedResponse5 = staticRouteConfig5.isValid();
-                Status expectedResponse5 = new Status(StatusCode.BADREQUEST,
-                        "Invalid NextHop IP Address configuration. " +
-                                "Please use the X.X.X.X format.");
-                Assert.assertEquals(expectedResponse5.toString(), receivedResponse5.toString());
-        }
-
-        @Test
-        public void testGetStaticRouteIP() {
-        StaticRouteConfig staticRouteConfig1 = new StaticRouteConfig("route1", "10.1.1.0/24", "100.1.1.1");
-        InetAddress ip1 = staticRouteConfig1.getStaticRouteIP();
-                Assert.assertEquals("10.1.1.0", ip1.getHostAddress());
-
-        StaticRouteConfig staticRouteConfig2 = new StaticRouteConfig("route1", "10.1.1.0/80", "100.1.1.1");
-        InetAddress ip2 = staticRouteConfig2.getStaticRouteIP();
-                Assert.assertEquals(null, ip2);
-
-        }
-
-        @Test
-        public void testGetStaticRouteMask() {
-        StaticRouteConfig staticRouteConfig1 = new StaticRouteConfig("route1", "10.1.1.0/24", "100.1.1.1");
-                Short receivedMaskLen1 = staticRouteConfig1.getStaticRouteMask();
-                Short expectedMaskLen1 = 24;
-                Assert.assertEquals(expectedMaskLen1, receivedMaskLen1);
-
-                StaticRouteConfig staticRouteConfig2 = new StaticRouteConfig("route1", "10.1.1.0/40", "100.1.1.1");
-                Short receivedMaskLen2 = staticRouteConfig2.getStaticRouteMask();
-                Short expectedMaskLen2 = 0;
-                Assert.assertEquals(expectedMaskLen2, receivedMaskLen2);
-        }
-
-        @Test
-        public void testGetNextHopIP() {
-        StaticRouteConfig staticRouteConfig1 = new StaticRouteConfig("route1", "10.1.1.254/24", "100.1.1.1");
-        InetAddress ip1 = staticRouteConfig1.getNextHopIP();
-                Assert.assertEquals("100.1.1.1", ip1.getHostAddress());
-
-                StaticRouteConfig staticRouteConfig2 = new StaticRouteConfig("route1", "10.1.1.254/24", "100.1.1");
-        InetAddress ip2 = staticRouteConfig2.getNextHopIP();
-                Assert.assertEquals(null, ip2);
-        }
-
-}
diff --git a/opendaylight/adsal/forwarding/staticrouting/src/test/java/org/opendaylight/controller/forwarding/staticrouting/StaticRouteTest.java b/opendaylight/adsal/forwarding/staticrouting/src/test/java/org/opendaylight/controller/forwarding/staticrouting/StaticRouteTest.java
deleted file mode 100644 (file)
index acfa223..0000000
+++ /dev/null
@@ -1,111 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.forwarding.staticrouting;
-
-import java.net.InetAddress;
-import java.net.UnknownHostException;
-
-import org.junit.Assert;
-import org.junit.Test;
-import org.opendaylight.controller.forwarding.staticrouting.StaticRoute.NextHopType;
-import org.opendaylight.controller.hosttracker.hostAware.HostNodeConnector;
-import org.opendaylight.controller.sal.core.ConstructionException;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.utils.NodeConnectorCreator;
-import org.opendaylight.controller.sal.utils.NodeCreator;
-
-import static org.junit.Assert.fail;
-
-public class StaticRouteTest {
-
-        @Test
-        public void testStaticRouteGetSet() {
-                StaticRoute staticRoute = new StaticRoute();
-                InetAddress networkAddress = null;
-                InetAddress mask = null;
-                InetAddress nextHopAddress = null;
-                try {
-                        networkAddress = InetAddress.getByName("10.1.1.0");
-                        mask = InetAddress.getByName("255.255.255.0");
-                        nextHopAddress = InetAddress.getByName("200.0.0.1");
-
-                } catch (UnknownHostException e) {
-                        fail("Failed due to unknown host " + e.getMessage());
-                }
-                staticRoute.setNetworkAddress(networkAddress);
-                Assert.assertEquals(networkAddress.getHostAddress(), staticRoute.getNetworkAddress().getHostAddress());
-                staticRoute.setMask(mask);
-                Assert.assertEquals(mask.getHostAddress(), staticRoute.getMask().getHostAddress());
-                staticRoute.setType(NextHopType.IPADDRESS);
-                Assert.assertEquals("nexthop-ip", staticRoute.getType().toString());
-                staticRoute.setNextHopAddress(nextHopAddress);
-                Assert.assertEquals(nextHopAddress.getHostAddress(), staticRoute.getNextHopAddress().getHostAddress());
-                Node node = NodeCreator.createOFNode(((long)10));
-                staticRoute.setNode(node);
-                Assert.assertEquals(node, staticRoute.getNode());
-                NodeConnector nc0 = NodeConnectorCreator.createOFNodeConnector((short)20, node);
-                staticRoute.setPort(nc0);
-                Assert.assertEquals(nc0, staticRoute.getPort());
-        InetAddress ip1 = null;
-        HostNodeConnector h1 = null;
-        try {
-            ip1 = InetAddress.getByName("192.1.1.1");
-        } catch (UnknownHostException e) {
-            fail("Failed due to unknown host " + e.getMessage());
-        }
-        try {
-            h1 = new HostNodeConnector(ip1);
-        } catch (ConstructionException e) {
-            fail("Failed to construct host " + e.getMessage());
-        }
-        staticRoute.setHost(h1);
-        Assert.assertEquals(h1, staticRoute.getHost());
-        }
-
-        @Test
-        public void testStaticRouteComparison() {
-        StaticRouteConfig staticRouteConfig1 = new StaticRouteConfig("route1", "10.1.1.0/24", "100.1.1.1");
-        StaticRouteConfig staticRouteConfig2 = new StaticRouteConfig("route2", "10.1.1.0/24", "100.2.1.1");
-        StaticRouteConfig staticRouteConfig3 = new StaticRouteConfig("route3", "10.2.1.0/24", "100.3.1.1");
-        StaticRouteConfig staticRouteConfig4 = new StaticRouteConfig("route4", "10.1.1.0/31", "");
-        StaticRoute staticRoute1 = new StaticRoute(staticRouteConfig1);
-        StaticRoute staticRoute2 = new StaticRoute(staticRouteConfig2);
-        StaticRoute staticRoute3 = new StaticRoute(staticRouteConfig3);
-        StaticRoute staticRoute4 = new StaticRoute(staticRouteConfig4);
-
-        Assert.assertTrue(staticRoute1.equals(staticRoute2));
-        Assert.assertFalse(staticRoute1.equals(staticRoute3));
-        Assert.assertFalse(staticRoute1.equals(staticRoute4));
-
-        Assert.assertTrue(staticRoute1.compareTo(staticRoute2) == 0);
-        Assert.assertFalse(staticRoute1.compareTo(staticRoute3) == 0);
-        Assert.assertTrue(staticRoute1.compareTo(staticRoute4) == 0);
-
-        }
-
-        @Test
-        public void testLongestPrefixMatch() {
-        StaticRouteConfig staticRouteConfig1 = new StaticRouteConfig("route1", "10.1.1.254/24", "100.1.1.1");
-        StaticRoute staticRoute1 = new StaticRoute(staticRouteConfig1);
-                InetAddress ip1 = null;
-                InetAddress ip2 = null;
-                try {
-                        ip1 = InetAddress.getByName("10.1.0.2");
-                        ip2 = InetAddress.getByName("10.1.1.2");
-                } catch (UnknownHostException e) {
-                        fail("Test failed due to unknown host " + e.getMessage());
-                }
-        InetAddress rxdIp1 = staticRoute1.longestPrefixMatch(ip1);
-        InetAddress rxdIp2 = staticRoute1.longestPrefixMatch(ip2);
-                Assert.assertNull(rxdIp1);
-                Assert.assertEquals("10.1.1.0", rxdIp2.getHostAddress());
-        }
-}
diff --git a/opendaylight/adsal/forwarding/staticrouting/src/test/java/org/opendaylight/controller/forwarding/staticrouting/internal/StaticRoutingImplementationTest.java b/opendaylight/adsal/forwarding/staticrouting/src/test/java/org/opendaylight/controller/forwarding/staticrouting/internal/StaticRoutingImplementationTest.java
deleted file mode 100644 (file)
index 4c9d4ab..0000000
+++ /dev/null
@@ -1,24 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.forwarding.staticrouting.internal;
-
-import org.junit.Assert;
-import org.junit.Test;
-
-public class StaticRoutingImplementationTest {
-
-        @Test
-        public void isIPv4AddressValidTest() {
-                StaticRoutingImplementation staticRouteImpl = new StaticRoutingImplementation();
-        Assert.assertTrue(staticRouteImpl.isIPv4AddressValid("192.168.100.0/24"));
-        Assert.assertFalse(staticRouteImpl.isIPv4AddressValid("192.168.100.0/36"));
-        Assert.assertFalse(staticRouteImpl.isIPv4AddressValid("192.168.300.0/32"));
-        }
-}
diff --git a/opendaylight/adsal/forwardingrulesmanager/api/pom.xml b/opendaylight/adsal/forwardingrulesmanager/api/pom.xml
deleted file mode 100644 (file)
index b9a46f5..0000000
+++ /dev/null
@@ -1,73 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>forwardingrulesmanager</artifactId>
-  <version>0.8.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>configuration</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>switchmanager</artifactId>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Include-Resource></Include-Resource>
-            <Export-Package>org.opendaylight.controller.forwardingrulesmanager</Export-Package>
-            <Import-Package>org.opendaylight.controller.configuration,
-              org.opendaylight.controller.switchmanager,
-              org.opendaylight.controller.sal.action,
-              org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.sal.flowprogrammer,
-              org.opendaylight.controller.sal.match,
-              org.opendaylight.controller.sal.utils,
-              org.opendaylight.controller.sal.packet,
-              javax.xml.bind.annotation,
-              javax.xml.bind,
-              org.apache.felix.dm,
-              org.apache.commons.lang3.builder,
-              org.osgi.service.component,
-              org.slf4j,
-              org.eclipse.osgi.framework.console,
-              org.osgi.framework</Import-Package>
-            <Require-Bundle>org.opendaylight.controller.hosttracker</Require-Bundle>
-            <Service-Component></Service-Component>
-          </instructions>
-          <manifestLocation>${project.basedir}/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/forwardingrulesmanager/api/src/main/java/org/opendaylight/controller/forwardingrulesmanager/FlowConfig.java b/opendaylight/adsal/forwardingrulesmanager/api/src/main/java/org/opendaylight/controller/forwardingrulesmanager/FlowConfig.java
deleted file mode 100644 (file)
index e2b6642..0000000
+++ /dev/null
@@ -1,1187 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.forwardingrulesmanager;
-
-import java.io.Serializable;
-import java.net.Inet6Address;
-import java.net.InetAddress;
-import java.util.ArrayList;
-import java.util.List;
-import java.util.regex.Matcher;
-import java.util.regex.Pattern;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.configuration.ConfigurationObject;
-import org.opendaylight.controller.sal.action.Action;
-import org.opendaylight.controller.sal.action.ActionType;
-import org.opendaylight.controller.sal.action.Controller;
-import org.opendaylight.controller.sal.action.Drop;
-import org.opendaylight.controller.sal.action.Enqueue;
-import org.opendaylight.controller.sal.action.Flood;
-import org.opendaylight.controller.sal.action.FloodAll;
-import org.opendaylight.controller.sal.action.HwPath;
-import org.opendaylight.controller.sal.action.Loopback;
-import org.opendaylight.controller.sal.action.Output;
-import org.opendaylight.controller.sal.action.PopVlan;
-import org.opendaylight.controller.sal.action.SetDlDst;
-import org.opendaylight.controller.sal.action.SetDlSrc;
-import org.opendaylight.controller.sal.action.SetNextHop;
-import org.opendaylight.controller.sal.action.SetNwDst;
-import org.opendaylight.controller.sal.action.SetNwSrc;
-import org.opendaylight.controller.sal.action.SetNwTos;
-import org.opendaylight.controller.sal.action.SetTpDst;
-import org.opendaylight.controller.sal.action.SetTpSrc;
-import org.opendaylight.controller.sal.action.SetVlanId;
-import org.opendaylight.controller.sal.action.SetVlanPcp;
-import org.opendaylight.controller.sal.action.SwPath;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.flowprogrammer.Flow;
-import org.opendaylight.controller.sal.match.Match;
-import org.opendaylight.controller.sal.match.MatchType;
-import org.opendaylight.controller.sal.utils.HexEncode;
-import org.opendaylight.controller.sal.utils.IPProtocols;
-import org.opendaylight.controller.sal.utils.NetUtils;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.sal.utils.StatusCode;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * Configuration Java Object which represents a flow configuration information
- * for Forwarding Rules Manager.
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-public class FlowConfig extends ConfigurationObject implements Serializable {
-    private static final long serialVersionUID = 1L;
-    private static final Logger log = LoggerFactory.getLogger(FlowConfig.class);
-    public static final String STATICFLOWGROUP = "__StaticFlows__";
-    public static final String INTERNALSTATICFLOWGROUP = "__InternalStaticFlows__";
-    public static final String INTERNALSTATICFLOWBEGIN = "__";
-    public static final String INTERNALSTATICFLOWEND = "__";
-    private boolean dynamic;
-    private String status;
-
-    /*
-     * The order of the object data defined below is used directly in the UI
-     * built using JSP. Hence try to keep the order in a more logical way.
-     */
-    @XmlElement
-    private String installInHw;
-    @XmlElement
-    private String name;
-    @XmlElement
-    private Node node;
-    @XmlElement
-    private String ingressPort;
-    private String portGroup;
-    @XmlElement
-    private String priority;
-    @XmlElement
-    private String etherType;
-    @XmlElement
-    private String vlanId;
-    @XmlElement
-    private String vlanPriority;
-    @XmlElement
-    private String dlSrc;
-    @XmlElement
-    private String dlDst;
-    @XmlElement
-    private String nwSrc;
-    @XmlElement
-    private String nwDst;
-    @XmlElement
-    private String protocol;
-    @XmlElement
-    private String tosBits;
-    @XmlElement
-    private String tpSrc;
-    @XmlElement
-    private String tpDst;
-    @XmlElement
-    private String cookie;
-    @XmlElement
-    private String idleTimeout;
-    @XmlElement
-    private String hardTimeout;
-    @XmlElement
-    private List<String> actions;
-
-    private enum EtherIPType {
-        ANY, V4, V6;
-    };
-
-    public FlowConfig() {
-    }
-
-    public FlowConfig(String installInHw, String name, Node node, String priority, String cookie, String ingressPort,
-            String portGroup, String vlanId, String vlanPriority, String etherType, String srcMac, String dstMac,
-            String protocol, String tosBits, String srcIP, String dstIP, String tpSrc, String tpDst,
-            String idleTimeout, String hardTimeout, List<String> actions) {
-        super();
-        this.installInHw = installInHw;
-        this.name = name;
-        this.node = node;
-        this.priority = priority;
-        this.cookie = cookie;
-        this.ingressPort = ingressPort;
-        this.portGroup = portGroup;
-        this.vlanId = vlanId;
-        this.vlanPriority = vlanPriority;
-        this.etherType = etherType;
-        this.dlSrc = srcMac;
-        this.dlDst = dstMac;
-        this.protocol = protocol;
-        this.tosBits = tosBits;
-        this.nwSrc = srcIP;
-        this.nwDst = dstIP;
-        this.tpSrc = tpSrc;
-        this.tpDst = tpDst;
-        this.idleTimeout = idleTimeout;
-        this.hardTimeout = hardTimeout;
-        this.actions = actions;
-        this.status = StatusCode.SUCCESS.toString();
-    }
-
-    public FlowConfig(FlowConfig from) {
-        this.installInHw = from.installInHw;
-        this.name = from.name;
-        this.node = from.node;
-        this.priority = from.priority;
-        this.cookie = from.cookie;
-        this.ingressPort = from.ingressPort;
-        this.portGroup = from.portGroup;
-        this.vlanId = from.vlanId;
-        this.vlanPriority = from.vlanPriority;
-        this.etherType = from.etherType;
-        this.dlSrc = from.dlSrc;
-        this.dlDst = from.dlDst;
-        this.protocol = from.protocol;
-        this.tosBits = from.tosBits;
-        this.nwSrc = from.nwSrc;
-        this.nwDst = from.nwDst;
-        this.tpSrc = from.tpSrc;
-        this.tpDst = from.tpDst;
-        this.idleTimeout = from.idleTimeout;
-        this.hardTimeout = from.hardTimeout;
-        this.actions = new ArrayList<String>(from.actions);
-    }
-
-    public boolean installInHw() {
-        if (installInHw == null) {
-            // backward compatibility
-            installInHw = Boolean.toString(true);
-        }
-        return Boolean.valueOf(installInHw);
-    }
-
-    public void setInstallInHw(boolean inHw) {
-        installInHw = String.valueOf(inHw);
-    }
-
-    public String getInstallInHw() {
-        return installInHw;
-    }
-
-    public boolean isInternalFlow() {
-        return (this.name != null &&
-                this.name.startsWith(FlowConfig.INTERNALSTATICFLOWBEGIN) &&
-                this.name.endsWith(FlowConfig.INTERNALSTATICFLOWEND));
-    }
-
-    public String getName() {
-        return name;
-    }
-
-    public void setName(String name) {
-        if (name == null) {
-            return;
-        }
-        this.name = name;
-    }
-
-    public Node getNode() {
-        return this.node;
-    }
-
-    public void setNode(Node node) {
-        this.node = node;
-    }
-
-    public String getPriority() {
-        return priority;
-    }
-
-    public void setPriority(String priority) {
-        this.priority = priority;
-    }
-
-    public String getCookie() {
-        return cookie;
-    }
-
-    public void setCookie(String cookie) {
-        this.cookie = cookie;
-    }
-
-    public String getIngressPort() {
-        return ingressPort;
-    }
-
-    public void setIngressPort(String ingressPort) {
-        this.ingressPort = ingressPort;
-    }
-
-    public String getPortGroup() {
-        return portGroup;
-    }
-
-    @Override
-    public String toString() {
-        return "FlowConfig [dynamic=" + dynamic + ", status=" + status + ", installInHw=" + installInHw + ", name="
-                + name + ", switchId=" + node + ", ingressPort=" + ingressPort + ", portGroup=" + portGroup
-                + ", etherType=" + etherType + ", priority=" + priority + ", vlanId=" + vlanId + ", vlanPriority="
-                + vlanPriority + ", dlSrc=" + dlSrc + ", dlDst=" + dlDst + ", nwSrc=" + nwSrc + ", nwDst=" + nwDst
-                + ", protocol=" + protocol + ", tosBits=" + tosBits + ", tpSrc=" + tpSrc + ", tpDst=" + tpDst
-                + ", cookie=" + cookie + ", idleTimeout=" + idleTimeout + ", hardTimeout=" + hardTimeout + ", actions="
-                + actions + "]";
-    }
-
-    public void setPortGroup(String portGroup) {
-        this.portGroup = portGroup;
-    }
-
-    public String getVlanId() {
-        return vlanId;
-    }
-
-    public void setVlanId(String vlanId) {
-        this.vlanId = vlanId;
-    }
-
-    public String getVlanPriority() {
-        return vlanPriority;
-    }
-
-    public void setVlanPriority(String vlanPriority) {
-        this.vlanPriority = vlanPriority;
-    }
-
-    public String getEtherType() {
-        return etherType;
-    }
-
-    public void setEtherType(String etherType) {
-        this.etherType = etherType;
-    }
-
-    public String getSrcMac() {
-        return dlSrc;
-    }
-
-    public void setSrcMac(String srcMac) {
-        this.dlSrc = srcMac;
-    }
-
-    public String getDstMac() {
-        return dlDst;
-    }
-
-    public void setDstMac(String dstMac) {
-        this.dlDst = dstMac;
-    }
-
-    public String getProtocol() {
-        return protocol;
-    }
-
-    public void setProtocol(String protocol) {
-        this.protocol = protocol;
-    }
-
-    public String getTosBits() {
-        return tosBits;
-    }
-
-    public void setTosBits(String tos_bits) {
-        this.tosBits = tos_bits;
-    }
-
-    public String getSrcIp() {
-        return nwSrc;
-    }
-
-    public void setSrcIp(String src_ip) {
-        this.nwSrc = src_ip;
-    }
-
-    public String getDstIp() {
-        return nwDst;
-    }
-
-    public void setDstIp(String dst_ip) {
-        this.nwDst = dst_ip;
-    }
-
-    public String getSrcPort() {
-        return tpSrc;
-    }
-
-    public void setSrcPort(String src_port) {
-        this.tpSrc = src_port;
-    }
-
-    public String getDstPort() {
-        return tpDst;
-    }
-
-    public void setDstPort(String dst_port) {
-        this.tpDst = dst_port;
-    }
-
-    public String getIdleTimeout() {
-        return idleTimeout;
-    }
-
-    public void setIdleTimeout(String idleTimeout) {
-        this.idleTimeout = idleTimeout;
-    }
-
-    public String getHardTimeout() {
-        return hardTimeout;
-    }
-
-    public void setHardTimeout(String hardTimeout) {
-        this.hardTimeout = hardTimeout;
-    }
-
-    public boolean isIPv6() {
-        return NetUtils.isIPv6AddressValid(this.getSrcIp()) || NetUtils.isIPv6AddressValid(this.getDstIp());
-    }
-
-    public List<String> getActions() {
-        return actions;
-    }
-
-    public void setActions(List<String> actions) {
-        this.actions = actions;
-    }
-
-    public boolean isPortGroupEnabled() {
-        return (portGroup != null);
-    }
-
-    public boolean isDynamic() {
-        return dynamic;
-    }
-
-    public void setDynamic(boolean dynamic) {
-        this.dynamic = dynamic;
-    }
-
-    public String getStatus() {
-        return status;
-    }
-
-    public void setStatus(String status) {
-        this.status = status;
-    }
-
-    public boolean isStatusSuccessful() {
-        return status.equals(StatusCode.SUCCESS.toString());
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + ((actions == null) ? 0 : actions.hashCode());
-        result = prime * result + ((cookie == null) ? 0 : cookie.hashCode());
-        result = prime * result + ((dlDst == null) ? 0 : dlDst.hashCode());
-        result = prime * result + ((dlSrc == null) ? 0 : dlSrc.hashCode());
-        result = prime * result + (dynamic ? 1231 : 1237);
-        result = prime * result + ((etherType == null) ? 0 : etherType.hashCode());
-        result = prime * result + ((ingressPort == null) ? 0 : ingressPort.hashCode());
-        result = prime * result + ((name == null) ? 0 : name.hashCode());
-        result = prime * result + ((nwDst == null) ? 0 : nwDst.hashCode());
-        result = prime * result + ((nwSrc == null) ? 0 : nwSrc.hashCode());
-        result = prime * result + ((portGroup == null) ? 0 : portGroup.hashCode());
-        result = prime * result + ((priority == null) ? 0 : priority.hashCode());
-        result = prime * result + ((protocol == null) ? 0 : protocol.hashCode());
-        result = prime * result + ((node == null) ? 0 : node.hashCode());
-        result = prime * result + ((tosBits == null) ? 0 : tosBits.hashCode());
-        result = prime * result + ((tpDst == null) ? 0 : tpDst.hashCode());
-        result = prime * result + ((tpSrc == null) ? 0 : tpSrc.hashCode());
-        result = prime * result + ((vlanId == null) ? 0 : vlanId.hashCode());
-        result = prime * result + ((vlanPriority == null) ? 0 : vlanPriority.hashCode());
-        result = prime * result + ((idleTimeout == null) ? 0 : idleTimeout.hashCode());
-        result = prime * result + ((hardTimeout == null) ? 0 : hardTimeout.hashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        FlowConfig other = (FlowConfig) obj;
-        if (actions == null) {
-            if (other.actions != null) {
-                return false;
-            }
-        } else if (!actions.equals(other.actions)) {
-            return false;
-        }
-        if (cookie == null) {
-            if (other.cookie != null) {
-                return false;
-            }
-        } else if (!cookie.equals(other.cookie)) {
-            return false;
-        }
-        if (dlDst == null) {
-            if (other.dlDst != null) {
-                return false;
-            }
-        } else if (!dlDst.equals(other.dlDst)) {
-            return false;
-        }
-        if (dlSrc == null) {
-            if (other.dlSrc != null) {
-                return false;
-            }
-        } else if (!dlSrc.equals(other.dlSrc)) {
-            return false;
-        }
-        if (dynamic != other.dynamic) {
-            return false;
-        }
-        if (etherType == null) {
-            if (other.etherType != null) {
-                return false;
-            }
-        } else if (!etherType.equals(other.etherType)) {
-            return false;
-        }
-        if (ingressPort == null) {
-            if (other.ingressPort != null) {
-                return false;
-            }
-        } else if (!ingressPort.equals(other.ingressPort)) {
-            return false;
-        }
-        if (name == null) {
-            if (other.name != null) {
-                return false;
-            }
-        } else if (!name.equals(other.name)) {
-            return false;
-        }
-        if (nwDst == null) {
-            if (other.nwDst != null) {
-                return false;
-            }
-        } else if (!nwDst.equals(other.nwDst)) {
-            return false;
-        }
-        if (nwSrc == null) {
-            if (other.nwSrc != null) {
-                return false;
-            }
-        } else if (!nwSrc.equals(other.nwSrc)) {
-            return false;
-        }
-        if (portGroup == null) {
-            if (other.portGroup != null) {
-                return false;
-            }
-        } else if (!portGroup.equals(other.portGroup)) {
-            return false;
-        }
-        if (priority == null) {
-            if (other.priority != null) {
-                return false;
-            }
-        } else if (!priority.equals(other.priority)) {
-            return false;
-        }
-        if (protocol == null) {
-            if (other.protocol != null) {
-                return false;
-            }
-        } else if (!protocol.equals(other.protocol)) {
-            return false;
-        }
-        if (node == null) {
-            if (other.node != null) {
-                return false;
-            }
-        } else if (!node.equals(other.node)) {
-            return false;
-        }
-        if (tosBits == null) {
-            if (other.tosBits != null) {
-                return false;
-            }
-        } else if (!tosBits.equals(other.tosBits)) {
-            return false;
-        }
-        if (tpDst == null) {
-            if (other.tpDst != null) {
-                return false;
-            }
-        } else if (!tpDst.equals(other.tpDst)) {
-            return false;
-        }
-        if (tpSrc == null) {
-            if (other.tpSrc != null) {
-                return false;
-            }
-        } else if (!tpSrc.equals(other.tpSrc)) {
-            return false;
-        }
-        if (vlanId == null) {
-            if (other.vlanId != null) {
-                return false;
-            }
-        } else if (!vlanId.equals(other.vlanId)) {
-            return false;
-        }
-        if (vlanPriority == null) {
-            if (other.vlanPriority != null) {
-                return false;
-            }
-        } else if (!vlanPriority.equals(other.vlanPriority)) {
-            return false;
-        }
-        if (idleTimeout == null) {
-            if (other.idleTimeout != null) {
-                return false;
-            }
-        } else if (!idleTimeout.equals(other.idleTimeout)) {
-            return false;
-        }
-        if (hardTimeout == null) {
-            if (other.hardTimeout != null) {
-                return false;
-            }
-        } else if (!hardTimeout.equals(other.hardTimeout)) {
-            return false;
-        }
-        return true;
-    }
-
-    public boolean isL2AddressValid(String mac) {
-        if (mac == null) {
-            return false;
-        }
-
-        Pattern macPattern = Pattern.compile("([0-9a-fA-F]{2}:){5}[0-9a-fA-F]{2}");
-        Matcher mm = macPattern.matcher(mac);
-        if (!mm.matches()) {
-            log.debug("Ethernet address {} is not valid. Example: 00:05:b9:7c:81:5f", mac);
-            return false;
-        }
-        return true;
-    }
-
-    public boolean isVlanIdValid(String vlanId) {
-        int vlan = Integer.decode(vlanId);
-        return ((vlan >= 0) && (vlan < 4096));
-    }
-
-    public boolean isVlanPriorityValid(String vlanPriority) {
-        int pri = Integer.decode(vlanPriority);
-        return ((pri >= 0) && (pri < 8));
-    }
-
-    public boolean isTOSBitsValid(String tosBits) {
-        int tos = Integer.decode(tosBits);
-        return ((tos >= 0) && (tos < 64));
-    }
-
-    public boolean isTpPortValid(String tpPort) {
-        int port = Integer.decode(tpPort);
-        return ((port >= 0) && (port <= 0xffff));
-    }
-
-    public boolean isTimeoutValid(String timeout) {
-        int to = Integer.decode(timeout);
-        return ((to >= 0) && (to <= 0xffff));
-    }
-
-    public boolean isProtocolValid(String protocol) {
-        IPProtocols proto = IPProtocols.fromString(protocol);
-        return (proto != null);
-    }
-
-    public Status validate() {
-        EtherIPType etype = EtherIPType.ANY;
-        EtherIPType ipsrctype = EtherIPType.ANY;
-        EtherIPType ipdsttype = EtherIPType.ANY;
-
-        try {
-            // Flow name cannot be internal flow signature
-            if (!isValidResourceName(name) || isInternalFlow()) {
-                return new Status(StatusCode.BADREQUEST, "Invalid name");
-            }
-
-            if (node == null) {
-                return new Status(StatusCode.BADREQUEST, "Node is null");
-            }
-
-            if (priority != null) {
-                if (Integer.decode(priority) < 0 || (Integer.decode(priority) > 65535)) {
-                    return new Status(StatusCode.BADREQUEST, String.format("priority %s is not in the range 0 - 65535",
-                            priority));
-                }
-            }
-
-            // make sure it's a valid number
-            if (cookie != null) {
-                Long.decode(cookie);
-            }
-
-            if (ingressPort != null && ingressPort.isEmpty()) {
-                return new Status(StatusCode.BADREQUEST, "Invalid ingress port");
-            }
-
-            if ((vlanId != null) && !isVlanIdValid(vlanId)) {
-                return new Status(StatusCode.BADREQUEST, String.format("Vlan ID %s is not in the range 0 - 4095",
-                        vlanId));
-            }
-
-            if ((vlanPriority != null) && !isVlanPriorityValid(vlanPriority)) {
-                return new Status(StatusCode.BADREQUEST, String.format("Vlan priority %s is not in the range 0 - 7",
-                        vlanPriority));
-            }
-            if (etherType != null) {
-                int type = Integer.decode(etherType);
-                if ((type < 0) || (type > 0xffff)) {
-                    return new Status(StatusCode.BADREQUEST, String.format("Ethernet type %s is not valid", etherType));
-                } else {
-                    if (type == 0x800) {
-                        etype = EtherIPType.V4;
-                    } else if (type == 0x86dd) {
-                        etype = EtherIPType.V6;
-                    }
-                }
-            }
-
-            if ((protocol != null) && !isProtocolValid(protocol)) {
-                return new Status(StatusCode.BADREQUEST, String.format("Protocol %s is not valid", protocol));
-            }
-
-            if ((tosBits != null) && !isTOSBitsValid(tosBits)) {
-                return new Status(StatusCode.BADREQUEST, String.format("IP ToS bits %s is not in the range 0 - 63",
-                        tosBits));
-            }
-
-            if ((tpSrc != null) && !isTpPortValid(tpSrc)) {
-                return new Status(StatusCode.BADREQUEST, String.format("Transport source port %s is not valid", tpSrc));
-            }
-
-            if ((tpDst != null) && !isTpPortValid(tpDst)) {
-                return new Status(StatusCode.BADREQUEST, String.format("Transport destination port %s is not valid",
-                        tpDst));
-            }
-
-            if ((dlSrc != null) && !isL2AddressValid(dlSrc)) {
-                return new Status(StatusCode.BADREQUEST, String.format(
-                        "Ethernet source address %s is not valid. Example: 00:05:b9:7c:81:5f", dlSrc));
-            }
-
-            if ((dlDst != null) && !isL2AddressValid(dlDst)) {
-                return new Status(StatusCode.BADREQUEST, String.format(
-                        "Ethernet destination address %s is not valid. Example: 00:05:b9:7c:81:5f", dlDst));
-            }
-
-            if (nwSrc != null) {
-                if (NetUtils.isIPv4AddressValid(nwSrc)) {
-                    ipsrctype = EtherIPType.V4;
-                } else if (NetUtils.isIPv6AddressValid(nwSrc)) {
-                    ipsrctype = EtherIPType.V6;
-                } else {
-                    return new Status(StatusCode.BADREQUEST, String.format("IP source address %s is not valid", nwSrc));
-                }
-            }
-
-            if (nwDst != null) {
-                if (NetUtils.isIPv4AddressValid(nwDst)) {
-                    ipdsttype = EtherIPType.V4;
-                } else if (NetUtils.isIPv6AddressValid(nwDst)) {
-                    ipdsttype = EtherIPType.V6;
-                } else {
-                    return new Status(StatusCode.BADREQUEST, String.format("IP destination address %s is not valid",
-                            nwDst));
-                }
-            }
-
-            if (etype != EtherIPType.ANY) {
-                if ((ipsrctype != EtherIPType.ANY) && (ipsrctype != etype)) {
-                    return new Status(StatusCode.BADREQUEST, String.format("Type mismatch between Ethernet & Src IP"));
-                }
-                if ((ipdsttype != EtherIPType.ANY) && (ipdsttype != etype)) {
-                    return new Status(StatusCode.BADREQUEST, String.format("Type mismatch between Ethernet & Dst IP"));
-                }
-            }
-            if (ipsrctype != ipdsttype) {
-                if (!((ipsrctype == EtherIPType.ANY) || (ipdsttype == EtherIPType.ANY))) {
-                    return new Status(StatusCode.BADREQUEST, String.format("IP Src Dest Type mismatch"));
-                }
-            }
-
-            if ((idleTimeout != null) && !isTimeoutValid(idleTimeout)) {
-                return new Status(StatusCode.BADREQUEST, String.format("Idle Timeout value %s is not valid",
-                        idleTimeout));
-            }
-
-            if ((hardTimeout != null) && !isTimeoutValid(hardTimeout)) {
-                return new Status(StatusCode.BADREQUEST, String.format("Hard Timeout value %s is not valid",
-                        hardTimeout));
-            }
-
-            Matcher sstr;
-            if (actions == null || actions.isEmpty()) {
-                return new Status(StatusCode.BADREQUEST, "Actions value is null or empty");
-            }
-            for (String actiongrp : actions) {
-                // Check src IP
-                sstr = Pattern.compile(ActionType.SET_NW_SRC.toString() + "=(.*)").matcher(actiongrp);
-                if (sstr.matches()) {
-                    if (!NetUtils.isIPv4AddressValid(sstr.group(1))) {
-                        return new Status(StatusCode.BADREQUEST, String.format("IP source address %s is not valid",
-                                sstr.group(1)));
-                    }
-                    continue;
-                }
-                // Check dst IP
-                sstr = Pattern.compile(ActionType.SET_NW_DST.toString() + "=(.*)").matcher(actiongrp);
-                if (sstr.matches()) {
-                    if (!NetUtils.isIPv4AddressValid(sstr.group(1))) {
-                        return new Status(StatusCode.BADREQUEST, String.format(
-                                "IP destination address %s is not valid", sstr.group(1)));
-                    }
-                    continue;
-                }
-
-                sstr = Pattern.compile(ActionType.SET_VLAN_ID.toString() + "=(.*)").matcher(actiongrp);
-                if (sstr.matches()) {
-                    if ((sstr.group(1) != null) && !isVlanIdValid(sstr.group(1))) {
-                        return new Status(StatusCode.BADREQUEST, String.format(
-                                "Vlan ID %s is not in the range 0 - 4095", sstr.group(1)));
-                    }
-                    continue;
-                }
-
-                sstr = Pattern.compile(ActionType.ENQUEUE + "=(.*)").matcher(actiongrp);
-                if (sstr.matches()) {
-                    for (String t : sstr.group(1).split(",")) {
-                        if (t != null) {
-                            String parts[] = t.split(":");
-                            String nc = String.format("%s|%s@%s", node.getType(), parts[0], node.toString());
-                            if (NodeConnector.fromString(nc) == null) {
-                                return new Status(StatusCode.BADREQUEST, String.format("Enqueue port is not valid"));
-                            }
-                            if (parts.length > 1) {
-                                try {
-                                    Integer.parseInt(parts[1]);
-                                } catch (NumberFormatException e) {
-                                    return new Status(StatusCode.BADREQUEST, String.format("Enqueue %s is not in the range 0 - 2147483647", parts[1]));
-                                }
-                            }
-                        }
-                    }
-                    continue;
-                }
-
-                sstr = Pattern.compile(ActionType.SET_VLAN_PCP.toString() + "=(.*)").matcher(actiongrp);
-                if (sstr.matches()) {
-                    if ((sstr.group(1) != null) && !isVlanPriorityValid(sstr.group(1))) {
-                        return new Status(StatusCode.BADREQUEST, String.format(
-                                "Vlan priority %s is not in the range 0 - 7", sstr.group(1)));
-                    }
-                    continue;
-                }
-
-                sstr = Pattern.compile(ActionType.SET_DL_SRC.toString() + "=(.*)").matcher(actiongrp);
-                if (sstr.matches()) {
-                    if ((sstr.group(1) != null) && !isL2AddressValid(sstr.group(1))) {
-                        return new Status(StatusCode.BADREQUEST, String.format(
-                                "Ethernet source address %s is not valid. Example: 00:05:b9:7c:81:5f",
-                                sstr.group(1)));
-                    }
-                    continue;
-                }
-                sstr = Pattern.compile(ActionType.SET_DL_DST.toString() + "=(.*)").matcher(actiongrp);
-                if (sstr.matches()) {
-                    if ((sstr.group(1) != null) && !isL2AddressValid(sstr.group(1))) {
-                        return new Status(StatusCode.BADREQUEST, String.format(
-                                "Ethernet destination address %s is not valid. Example: 00:05:b9:7c:81:5f",
-                                sstr.group(1)));
-                    }
-                    continue;
-                }
-
-                sstr = Pattern.compile(ActionType.SET_NW_TOS.toString() + "=(.*)").matcher(actiongrp);
-                if (sstr.matches()) {
-                    if ((sstr.group(1) != null) && !isTOSBitsValid(sstr.group(1))) {
-                        return new Status(StatusCode.BADREQUEST, String.format(
-                                "IP ToS bits %s is not in the range 0 - 63", sstr.group(1)));
-                    }
-                    continue;
-                }
-
-                sstr = Pattern.compile(ActionType.SET_TP_SRC.toString() + "=(.*)").matcher(actiongrp);
-                if (sstr.matches()) {
-                    if ((sstr.group(1) != null) && !isTpPortValid(sstr.group(1))) {
-                        return new Status(StatusCode.BADREQUEST, String.format(
-                                "Transport source port %s is not valid", sstr.group(1)));
-                    }
-                    continue;
-                }
-
-                sstr = Pattern.compile(ActionType.SET_TP_DST.toString() + "=(.*)").matcher(actiongrp);
-                if (sstr.matches()) {
-                    if ((sstr.group(1) != null) && !isTpPortValid(sstr.group(1))) {
-                        return new Status(StatusCode.BADREQUEST, String.format(
-                                "Transport destination port %s is not valid", sstr.group(1)));
-                    }
-                    continue;
-                }
-
-                sstr = Pattern.compile(ActionType.SET_NEXT_HOP.toString() + "=(.*)").matcher(actiongrp);
-                if (sstr.matches()) {
-                    if (!NetUtils.isIPAddressValid(sstr.group(1))) {
-                        return new Status(StatusCode.BADREQUEST, String.format(
-                                "IP destination address %s is not valid", sstr.group(1)));
-                    }
-                    continue;
-                }
-
-                sstr = Pattern.compile(ActionType.OUTPUT + "=(.*)").matcher(actiongrp);
-                if (sstr.matches()) {
-                    continue;
-                }
-
-                sstr = Pattern.compile(ActionType.DROP.toString()).matcher(actiongrp);
-                if (sstr.matches()) {
-                    continue;
-                }
-
-                sstr = Pattern.compile(ActionType.LOOPBACK.toString()).matcher(actiongrp);
-                if (sstr.matches()) {
-                    continue;
-                }
-
-                sstr = Pattern.compile(ActionType.FLOOD.toString()).matcher(actiongrp);
-                if (sstr.matches()) {
-                    continue;
-                }
-
-                sstr = Pattern.compile(ActionType.FLOOD_ALL.toString()).matcher(actiongrp);
-                if (sstr.matches()) {
-                    continue;
-                }
-
-                sstr = Pattern.compile(ActionType.SW_PATH.toString()).matcher(actiongrp);
-                if (sstr.matches()) {
-                    continue;
-                }
-
-                sstr = Pattern.compile(ActionType.HW_PATH.toString()).matcher(actiongrp);
-                if (sstr.matches()) {
-                    continue;
-                }
-
-                sstr = Pattern.compile(ActionType.CONTROLLER.toString()).matcher(actiongrp);
-                if (sstr.matches()) {
-                    continue;
-                }
-
-                sstr = Pattern.compile(ActionType.POP_VLAN.toString()).matcher(actiongrp);
-                if (sstr.matches()) {
-                    continue;
-                }
-
-                // If execution reached here, it means there is an Action
-                // which is not recognized by the controller. Return error
-
-                return new Status(StatusCode.BADREQUEST, String.format("%s is an UnSupported Action", actiongrp));
-           }
-        } catch (NumberFormatException e) {
-            return new Status(StatusCode.BADREQUEST, String.format("Invalid number format %s", e.getMessage()));
-        }
-
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    public FlowEntry getFlowEntry() {
-        String group = this.isInternalFlow() ? FlowConfig.INTERNALSTATICFLOWGROUP : FlowConfig.STATICFLOWGROUP;
-        return new FlowEntry(group, this.name, this.getFlow(), this.getNode());
-    }
-
-    public Flow getFlow() {
-        Match match = new Match();
-
-        if (this.ingressPort != null) {
-            match.setField(MatchType.IN_PORT,
-                    NodeConnector.fromString(String.format("%s|%s@%s", node.getType(), ingressPort, node.toString())));
-        }
-        if (this.dlSrc != null) {
-            match.setField(MatchType.DL_SRC, HexEncode.bytesFromHexString(this.dlSrc));
-        }
-        if (this.dlDst != null) {
-            match.setField(MatchType.DL_DST, HexEncode.bytesFromHexString(this.dlDst));
-        }
-        if (this.etherType != null) {
-            match.setField(MatchType.DL_TYPE, Integer.decode(etherType).shortValue());
-        }
-        if (this.vlanId != null) {
-            match.setField(MatchType.DL_VLAN, Short.parseShort(this.vlanId));
-        }
-        if (this.vlanPriority != null) {
-            match.setField(MatchType.DL_VLAN_PR, Byte.parseByte(this.vlanPriority));
-        }
-        if (this.nwSrc != null) {
-            String parts[] = this.nwSrc.split("/");
-            InetAddress ip = NetUtils.parseInetAddress(parts[0]);
-            InetAddress mask = null;
-            int maskLen = 0;
-            if (parts.length > 1) {
-                maskLen = Integer.parseInt(parts[1]);
-            } else {
-                maskLen = (ip instanceof Inet6Address) ? 128 : 32;
-            }
-            mask = NetUtils.getInetNetworkMask(maskLen, ip instanceof Inet6Address);
-            match.setField(MatchType.NW_SRC, ip, mask);
-        }
-        if (this.nwDst != null) {
-            String parts[] = this.nwDst.split("/");
-            InetAddress ip = NetUtils.parseInetAddress(parts[0]);
-            InetAddress mask = null;
-            int maskLen = 0;
-            if (parts.length > 1) {
-                maskLen = Integer.parseInt(parts[1]);
-            } else {
-                maskLen = (ip instanceof Inet6Address) ? 128 : 32;
-            }
-            mask = NetUtils.getInetNetworkMask(maskLen, ip instanceof Inet6Address);
-            match.setField(MatchType.NW_DST, ip, mask);
-        }
-        if (IPProtocols.fromString(this.protocol) != IPProtocols.ANY) {
-            match.setField(MatchType.NW_PROTO, IPProtocols.getProtocolNumberByte(this.protocol));
-        }
-        if (this.tosBits != null) {
-            match.setField(MatchType.NW_TOS, Byte.parseByte(this.tosBits));
-        }
-        if (this.tpSrc != null) {
-            match.setField(MatchType.TP_SRC, Integer.valueOf(this.tpSrc).shortValue());
-        }
-        if (this.tpDst != null) {
-            match.setField(MatchType.TP_DST, Integer.valueOf(this.tpDst).shortValue());
-        }
-
-        Flow flow = new Flow(match, getActionList());
-
-        if (this.cookie != null) {
-            flow.setId(Long.parseLong(cookie));
-        }
-        if (this.hardTimeout != null) {
-            flow.setHardTimeout(Short.parseShort(this.hardTimeout));
-        }
-        if (this.idleTimeout != null) {
-            flow.setIdleTimeout(Short.parseShort(idleTimeout));
-        }
-        if (this.priority != null) {
-            flow.setPriority(Integer.decode(this.priority).shortValue());
-        }
-
-
-        return flow;
-    }
-
-    public boolean isByNameAndNodeIdEqual(FlowConfig that) {
-        return (this.name.equals(that.name) && this.node.equals(that.node));
-    }
-
-    public boolean isByNameAndNodeIdEqual(String name, Node node) {
-        return (this.name.equals(name) && this.node.equals(node));
-    }
-
-    public boolean onNode(Node node) {
-        return this.node.equals(node);
-    }
-
-    public void toggleInstallation() {
-        installInHw = (installInHw == null) ? Boolean.toString(false) : Boolean.toString(!Boolean.valueOf(installInHw));
-    }
-
-    /*
-     * Parses the actions string and return the List of SAL Action No syntax
-     * check run, as this function will be called when the config validation
-     * check has already been performed
-     */
-    private List<Action> getActionList() {
-        List<Action> actionList = new ArrayList<Action>();
-
-        if (actions != null) {
-            Matcher sstr;
-            for (String actiongrp : actions) {
-                sstr = Pattern.compile(ActionType.OUTPUT + "=(.*)").matcher(actiongrp);
-                if (sstr.matches()) {
-                    for (String t : sstr.group(1).split(",")) {
-                        if (t != null) {
-                            String nc = String.format("%s|%s@%s", node.getType(), t, node.toString());
-                            actionList.add(new Output(NodeConnector.fromString(nc)));
-                        }
-                    }
-                    continue;
-                }
-
-                sstr = Pattern.compile(ActionType.ENQUEUE + "=(.*)").matcher(actiongrp);
-                if (sstr.matches()) {
-                    for (String t : sstr.group(1).split(",")) {
-                        if (t != null) {
-                            String parts[] = t.split(":");
-                            String nc = String.format("%s|%s@%s", node.getType(), parts[0], node.toString());
-                            if (parts.length == 1) {
-                                actionList.add(new Enqueue(NodeConnector.fromString(nc)));
-                            } else {
-                                actionList
-                                .add(new Enqueue(NodeConnector.fromString(nc), Integer.parseInt(parts[1])));
-                            }
-                        }
-                    }
-                    continue;
-                }
-
-                sstr = Pattern.compile(ActionType.DROP.toString()).matcher(actiongrp);
-                if (sstr.matches()) {
-                    actionList.add(new Drop());
-                    continue;
-                }
-
-                sstr = Pattern.compile(ActionType.LOOPBACK.toString()).matcher(actiongrp);
-                if (sstr.matches()) {
-                    actionList.add(new Loopback());
-                    continue;
-                }
-
-                sstr = Pattern.compile(ActionType.FLOOD.toString()).matcher(actiongrp);
-                if (sstr.matches()) {
-                    actionList.add(new Flood());
-                    continue;
-                }
-
-                sstr = Pattern.compile(ActionType.FLOOD_ALL.toString()).matcher(actiongrp);
-                if (sstr.matches()) {
-                    actionList.add(new FloodAll());
-                    continue;
-                }
-
-                sstr = Pattern.compile(ActionType.SW_PATH.toString()).matcher(actiongrp);
-                if (sstr.matches()) {
-                    actionList.add(new SwPath());
-                    continue;
-                }
-
-                sstr = Pattern.compile(ActionType.HW_PATH.toString()).matcher(actiongrp);
-                if (sstr.matches()) {
-                    actionList.add(new HwPath());
-                    continue;
-                }
-
-                sstr = Pattern.compile(ActionType.CONTROLLER.toString()).matcher(actiongrp);
-                if (sstr.matches()) {
-                    actionList.add(new Controller());
-                    continue;
-                }
-
-                sstr = Pattern.compile(ActionType.SET_VLAN_ID.toString() + "=(.*)").matcher(actiongrp);
-                if (sstr.matches()) {
-                    actionList.add(new SetVlanId(Short.parseShort(sstr.group(1))));
-                    continue;
-                }
-
-                sstr = Pattern.compile(ActionType.SET_VLAN_PCP.toString() + "=(.*)").matcher(actiongrp);
-                if (sstr.matches()) {
-                    actionList.add(new SetVlanPcp(Byte.parseByte(sstr.group(1))));
-                    continue;
-                }
-
-                sstr = Pattern.compile(ActionType.POP_VLAN.toString()).matcher(actiongrp);
-                if (sstr.matches()) {
-                    actionList.add(new PopVlan());
-                    continue;
-                }
-
-                sstr = Pattern.compile(ActionType.SET_DL_SRC.toString() + "=(.*)").matcher(actiongrp);
-                if (sstr.matches()) {
-                    actionList.add(new SetDlSrc(HexEncode.bytesFromHexString(sstr.group(1))));
-                    continue;
-                }
-
-                sstr = Pattern.compile(ActionType.SET_DL_DST.toString() + "=(.*)").matcher(actiongrp);
-                if (sstr.matches()) {
-                    actionList.add(new SetDlDst(HexEncode.bytesFromHexString(sstr.group(1))));
-                    continue;
-                }
-                sstr = Pattern.compile(ActionType.SET_NW_SRC.toString() + "=(.*)").matcher(actiongrp);
-                if (sstr.matches()) {
-                    actionList.add(new SetNwSrc(NetUtils.parseInetAddress(sstr.group(1))));
-                    continue;
-                }
-                sstr = Pattern.compile(ActionType.SET_NW_DST.toString() + "=(.*)").matcher(actiongrp);
-                if (sstr.matches()) {
-                    actionList.add(new SetNwDst(NetUtils.parseInetAddress(sstr.group(1))));
-                    continue;
-                }
-
-                sstr = Pattern.compile(ActionType.SET_NW_TOS.toString() + "=(.*)").matcher(actiongrp);
-                if (sstr.matches()) {
-                    actionList.add(new SetNwTos(Byte.parseByte(sstr.group(1))));
-                    continue;
-                }
-
-                sstr = Pattern.compile(ActionType.SET_TP_SRC.toString() + "=(.*)").matcher(actiongrp);
-                if (sstr.matches()) {
-                    actionList.add(new SetTpSrc(Integer.valueOf(sstr.group(1))));
-                    continue;
-                }
-
-                sstr = Pattern.compile(ActionType.SET_TP_DST.toString() + "=(.*)").matcher(actiongrp);
-                if (sstr.matches()) {
-                    actionList.add(new SetTpDst(Integer.valueOf(sstr.group(1))));
-                    continue;
-                }
-
-                sstr = Pattern.compile(ActionType.SET_NEXT_HOP.toString() + "=(.*)").matcher(actiongrp);
-                if (sstr.matches()) {
-                    actionList.add(new SetNextHop(NetUtils.parseInetAddress(sstr.group(1))));
-                    continue;
-                }
-            }
-        }
-        return actionList;
-    }
-
-}
diff --git a/opendaylight/adsal/forwardingrulesmanager/api/src/main/java/org/opendaylight/controller/forwardingrulesmanager/FlowEntry.java b/opendaylight/adsal/forwardingrulesmanager/api/src/main/java/org/opendaylight/controller/forwardingrulesmanager/FlowEntry.java
deleted file mode 100644 (file)
index d9a0891..0000000
+++ /dev/null
@@ -1,192 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.forwardingrulesmanager;
-
-import java.io.Serializable;
-import java.util.Date;
-
-import org.opendaylight.controller.sal.core.ContainerFlow;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.flowprogrammer.Flow;
-import org.opendaylight.controller.sal.match.Match;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * Represents a flow applications request Forwarding Rules Manager to install on
- * a network node. A FlowEntry is constituted of a flow (match + actions), the
- * target network node, and the flow name. It also includes a group name. For
- * instance the flows constituting a policy all share the same group name.
- */
-public class FlowEntry implements Cloneable, Serializable {
-    protected static final Logger logger = LoggerFactory.getLogger(FlowEntry.class);
-    private static final long serialVersionUID = 1L;
-    private static final Logger log = LoggerFactory.getLogger(FlowEntry.class);
-    private String groupName; // group name
-    private String flowName; // flow name (may be null)
-    private Node node; // network node where to install the flow
-    private Flow flow; // match + action
-
-    public FlowEntry(String groupName, String flowName, Flow flow, Node node) {
-        this.groupName = groupName;
-        this.flow = flow;
-        this.node = node;
-        this.flowName = (flowName != null) ? flowName : constructFlowName();
-    }
-
-    public String getGroupName() {
-        return groupName;
-    }
-
-    public void setGroupName(String name) {
-        this.groupName = name;
-    }
-
-    /**
-     * Return the actual Flow contained in this entry
-     *
-     * @return the flow
-     */
-    public Flow getFlow() {
-        return flow;
-    }
-
-    public Node getNode() {
-        return node;
-    }
-
-    public void setNode(Node n) {
-        this.node = n;
-    }
-
-    public String getFlowName() {
-        return flowName;
-    }
-
-    public void setFlowName(String n) {
-        this.flowName = n;
-    }
-
-    @Override
-    public FlowEntry clone() {
-        FlowEntry cloned = null;
-        try {
-            cloned = (FlowEntry) super.clone();
-            cloned.flow = this.flow.clone();
-        } catch (CloneNotSupportedException e) {
-            log.warn("exception in clone", e);
-        }
-        return cloned;
-    }
-
-    /*
-     * Only accounts fields which uniquely identify a flow for collision
-     * purposes: node, match and priority
-     */
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + ((node == null) ? 0 : node.hashCode());
-        result = prime * result + ((flow == null) ? 0 : (int) flow.getPriority());
-        result = prime * result + ((flow == null || flow.getMatch() == null) ? 0 : flow.getMatch().hashCode());
-
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        FlowEntry other = (FlowEntry) obj;
-
-        if (node == null) {
-            if (other.node != null) {
-                return false;
-            }
-        } else if (!node.equals(other.node)) {
-            return false;
-        }
-
-        if (flow == null) {
-            return other.flow == null;
-        } else if (other.flow == null) {
-            return false;
-        }
-        if (flow.getPriority() != other.flow.getPriority()) {
-            return false;
-        }
-        if (flow.getMatch() == null) {
-            if (other.flow.getMatch() != null) {
-                return false;
-            }
-        } else if (!flow.getMatch().equals(other.flow.getMatch())) {
-            return false;
-        }
-
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        return "FlowEntry[flowName = " + flowName + ", groupName = " + groupName + ", node = " + node + ", flow = "
-                + flow + "]";
-    }
-
-    private String constructFlowName() {
-        return this.groupName + "_" + new Date().toString();
-    }
-
-    public boolean equalsByNodeAndName(Node node, String flowName) {
-        return this.node.equals(node) && this.flowName.equals(flowName);
-    }
-
-    /**
-     * Merges the current Flow with the passed Container Flow
-     *
-     * Note: Container Flow merging is not an injective function. Be m1 and m2
-     * two different matches, and be f() the flow merge function, such that y1 =
-     * f(m1) and y2 = f(m2) are the two merged matches, we may have: y1 = y2
-     *
-     *
-     * @param containerFlow
-     * @return this merged FlowEntry
-     */
-    public FlowEntry mergeWith(ContainerFlow containerFlow) {
-        Match myMatch = flow.getMatch();
-
-        Match filter = containerFlow.getMatch();
-
-        // Merge
-        Match merge = myMatch.mergeWithFilter(filter);
-
-        // Replace this Flow's match with merged version
-        flow.setMatch(merge);
-
-        return this;
-    }
-
-    /**
-     * Returns whether this entry is the result of an internal generated static
-     * flow
-     *
-     * @return true if internal generated static flow, false otherwise
-     */
-    public boolean isInternal() {
-        return flowName.startsWith(FlowConfig.INTERNALSTATICFLOWBEGIN)
-                && flowName.endsWith(FlowConfig.INTERNALSTATICFLOWEND);
-    }
-}
diff --git a/opendaylight/adsal/forwardingrulesmanager/api/src/main/java/org/opendaylight/controller/forwardingrulesmanager/FlowEntryInstall.java b/opendaylight/adsal/forwardingrulesmanager/api/src/main/java/org/opendaylight/controller/forwardingrulesmanager/FlowEntryInstall.java
deleted file mode 100644 (file)
index 1318c97..0000000
+++ /dev/null
@@ -1,134 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.forwardingrulesmanager;
-
-import java.io.Serializable;
-
-import org.opendaylight.controller.sal.core.ContainerFlow;
-import org.opendaylight.controller.sal.core.Node;
-
-/**
- * The flow database object representing the flow entry to install on the
- * network node. It contains the original flow entry FRM was requested to
- * install, the container flow with which that entry had to be merged and the
- * resultant merged flow entry, which is the one that was eventually installed
- * on the network node
- *
- * Note: If the container flow is null, the install entry will be a clone of the
- * original entry
- */
-public class FlowEntryInstall implements Serializable {
-    private static final long serialVersionUID = 1L;
-    private final FlowEntry original;
-    private final ContainerFlow cFlow;
-    private final FlowEntry install;
-    private transient long requestId; // async request id
-    private transient boolean deletePending;
-
-    public FlowEntryInstall(FlowEntry original, ContainerFlow cFlow) {
-        this.original = original;
-        this.cFlow = cFlow;
-        this.install = (cFlow == null) ? original.clone() : original.clone().mergeWith(cFlow);
-        deletePending = false;
-        requestId = 0;
-    }
-
-    /*
-     * Given FlowEntryInstall is used as key for FRM map which contains the
-     * software view of installed entries, having its hashcode tied to the one
-     * of the installed FlowEntry which takes into account the fields which
-     * uniquely identify a flow from switch point of view: node, match and
-     * priority.
-     */
-    @Override
-    public int hashCode() {
-        return install.hashCode();
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        FlowEntryInstall other = (FlowEntryInstall) obj;
-        if (install == null) {
-            if (other.install != null) {
-                return false;
-            }
-        } else if (!install.equals(other.install)) {
-            return false;
-        }
-        return true;
-    }
-
-    public String getFlowName() {
-        return original.getFlowName();
-    }
-
-    public String getGroupName() {
-        return original.getGroupName();
-    }
-
-    public Node getNode() {
-        return original.getNode();
-    }
-
-    public boolean equalsByNodeAndName(Node node, String flowName) {
-        return original.equalsByNodeAndName(node, flowName);
-    }
-
-    public FlowEntry getOriginal() {
-        return original;
-    }
-
-    public ContainerFlow getContainerFlow() {
-        return cFlow;
-    }
-
-    public FlowEntry getInstall() {
-        return install;
-    }
-
-    public boolean isDeletePending() {
-        return deletePending;
-    }
-
-    public void toBeDeleted() {
-        this.deletePending = true;
-    }
-
-    public void setRequestId(long rid) {
-        this.requestId = rid;
-    }
-
-    public long getRequestId() {
-        return requestId;
-    }
-
-    /**
-     * Returns whether this entry is the result of an internal generated static
-     * flow
-     *
-     * @return true if internal generated static flow, false otherwise
-     */
-    public boolean isInternal() {
-        return original.isInternal();
-    }
-
-    @Override
-    public String toString() {
-        return "[Install = " + install + " Original = " + original + " cFlow = " + cFlow + " rid = " + requestId + "]";
-    }
-}
diff --git a/opendaylight/adsal/forwardingrulesmanager/api/src/main/java/org/opendaylight/controller/forwardingrulesmanager/IForwardingRulesManager.java b/opendaylight/adsal/forwardingrulesmanager/api/src/main/java/org/opendaylight/controller/forwardingrulesmanager/IForwardingRulesManager.java
deleted file mode 100644 (file)
index 070e8c4..0000000
+++ /dev/null
@@ -1,491 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.forwardingrulesmanager;
-
-import java.util.List;
-import java.util.Map;
-
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.utils.Status;
-
-/**
- * Interface that describes methods for installing or removing forwarding rules
- * and to access to the flows database.
- */
-public interface IForwardingRulesManager {
-
-    /**
-     * It requests FRM to install the passed Flow Entry. FRM will request the
-     * SDN protocol plugin to install the flow on the network node. Based on the
-     * result of this operation FRM will update its database accordingly and
-     * will return the proper {@code Status} code.
-     *
-     * @param flow
-     *            the flow entry to install
-     * @return the {@code Status} object indicating the result of this action.
-     */
-    public Status installFlowEntry(FlowEntry flow);
-
-    /**
-     * It requests FRM to remove the passed Flow Entry. FRM will request the SDN
-     * protocol plugin to uninstall the flow from the network node. Based on the
-     * result of this operation FRM will update its database accordingly and
-     * will return the proper {@code Status} code.
-     *
-     * @param flow
-     *            the flow entry to uninstall
-     * @return the {@code Status} object indicating the result of this action
-     */
-    public Status uninstallFlowEntry(FlowEntry flow);
-
-    /**
-     * It requests FRM to remove all the Flow Entry that are part of the
-     * specified group. FRM will request the SDN protocol plugin to uninstall
-     * the flows from the network node one by one. Based on the result of this
-     * operation FRM will update its database accordingly and will return the
-     * proper {@code Status} code.
-     *
-     * @param groupName
-     *            the group name
-     * @return the {@code Status} object indicating the result of this action
-     */
-    public Status uninstallFlowEntryGroup(String groupName);
-
-    /**
-     * It requests FRM to replace the currently installed Flow Entry with the
-     * new one. It is up to the SDN protocol plugin to decide how to convey this
-     * message to the network node. It could be a delete + add or a single
-     * modify message depending on the SDN protocol specifications If the
-     * current flow is equal to the new one it will be a no op and success code
-     * is returned.
-     *
-     * @param current
-     *            the current flow entry to modify
-     * @param newone
-     *            the new flow entry which will replace the current one
-     * @return the {@code Status} object indicating the result of this action
-     */
-    public Status modifyFlowEntry(FlowEntry current, FlowEntry newone);
-
-    /**
-     * It requests the FRM to replace the currently installed Flow Entry with
-     * the new one. The currently installed entry is derived by the Match
-     * portion of the passed Flow. FRM looks in its database for a previously
-     * installed FlowEntry which Match equals the Match of the passed Flow. If
-     * it finds it, it will request the SDN protocol plugin to replace the
-     * existing flow with the new one on the network node. If it does not find
-     * it, it will request plugin to add the new flow. If the passed entry is
-     * not valid an error code is returned. If the existing flow is equal to the
-     * passed one it will be a no op and success code is returned.
-     *
-     * @param newone
-     *            the new flow entry to install
-     * @return the {@code Status} object indicating the result of this action
-     */
-    public Status modifyOrAddFlowEntry(FlowEntry newone);
-
-    /**
-     * It requests FRM to install the passed Flow Entry through an asynchronous
-     * call. A unique request id is returned to the caller. FRM will request the
-     * SDN protocol plugin to install the flow on the network node. As immediate
-     * result of this asynchronous call, FRM will update its flow database as if
-     * the flow was successfully installed.
-     *
-     * @param flow
-     *            the flow entry to install
-     * @return the status of this request containing the request id associated
-     *         to this asynchronous request
-     */
-    public Status installFlowEntryAsync(FlowEntry flow);
-
-    /**
-     * It requests FRM to remove the passed Flow Entry through an asynchronous
-     * call. A unique request id is returned to the caller. FRM will request the
-     * SDN protocol plugin to uninstall the flow from the network node. As
-     * immediate result of this asynchronous call, FRM will update its flow
-     * database as if the flow was successfully removed.
-     *
-     * @param flow
-     *            the flow entry to uninstall
-     * @return the status of this request containing the unique id associated to
-     *         this asynchronous request
-     */
-    public Status uninstallFlowEntryAsync(FlowEntry flow);
-
-    /**
-     * It requests FRM to remove all the Flow Entry that are part of the
-     * specified group through an asynchronous call. FRM will request the SDN
-     * protocol plugin to uninstall the flows from the network node one by one.
-     * As immediate result of this asynchronous call, FRM will update its flow
-     * database as if the flow was successfully removed.
-     *
-     * @param groupName
-     *            the group name
-     * @return the {@code Status} object indicating the result of this action
-     */
-    public Status uninstallFlowEntryGroupAsync(String groupName);
-
-    /**
-     * It requests FRM to replace the currently installed Flow Entry with the
-     * new one through an asynchronous call. A unique request id is returned to
-     * the caller. It is up to the SDN protocol plugin to decide how to convey
-     * this message to the network node. It could be a delete + add or a single
-     * modify message depending on the SDN protocol specifications. If the
-     * current flow is equal to the new one it will be a no op.
-     *
-     * @param current
-     *            the current flow entry to modify
-     * @param newone
-     *            the new flow entry which will replace the current one
-     * @return the status of this request containing the request id associated
-     *         to this asynchronous request
-     */
-    public Status modifyFlowEntryAsync(FlowEntry current, FlowEntry newone);
-
-    /**
-     * It requests the FRM to replace the currently installed Flow Entry with
-     * the new one through an asynchronous call. A unique request id is returned
-     * to the caller. The currently installed entry is derived by the Match
-     * portion of the passed Flow. FRM looks in its database for a previously
-     * installed FlowEntry which Match equals the Match of the passed Flow. If
-     * it finds it, it will request the SDN protocol plugin to replace the
-     * existing flow with the new one on the network node. If it does not find
-     * it, it will request plugin to add the new flow. If the passed entry is
-     * not valid a zero request id is returned. If the existing flow is equal to
-     * the passed one it will be a no op.
-     *
-     * @param newone
-     *            the new flow entry to install
-     * @return the unique id associated to this request. In case of not
-     *         acceptable request -1 will be returned.
-     */
-    public Status modifyOrAddFlowEntryAsync(FlowEntry newone);
-
-    /**
-     * Requests ForwardingRulesManager to solicit the network node to inform us
-     * about the status of its execution on the asynchronous requests that were
-     * sent to it so far. It is a way for an application to poke the network
-     * node in order to get a feedback asap on the asynchronous requests
-     * generated by the application. The caller may decide if this is a blocking
-     * or non-blocking operation. If blocking is set to true, the caller will be
-     * blocked until the solicitation response is received from the network node
-     * or receive timeout. Otherwise, it is a non-blocking call and does not
-     * guarantee the node will respond in any given time.
-     *
-     * @param node
-     *            The network node to solicit a response
-     * @param blocking
-     *            The blocking mode
-     * @return the status of this request containing the request id associated
-     *         to this asynchronous request
-     */
-    public Status solicitStatusResponse(Node node, boolean blocking);
-
-    /**
-     * Check whether the passed flow entry conflicts with the Container flows
-     *
-     * @param flow
-     *            the flow entry to test
-     * @return true if conflicts, false otherwise
-     */
-    public boolean checkFlowEntryConflict(FlowEntry flow);
-
-    /**
-     * Returns the list of Flow entries across network nodes which are part of
-     * the same flow group, policy. This list contains the flows as they were
-     * requested to be installed by the applications, before any merging with
-     * container flow is done.
-     *
-     * @param group
-     *            the group name
-     * @return the original list of flow entries belonging to the specified group
-     */
-    public List<FlowEntry> getFlowEntriesForGroup(String group);
-
-    /**
-     * Returns the list of Flow entries installed in network nodes which are part of
-     * the same flow group, policy. This list contains the effective flows installed
-     * on the nodes after the merging with any possible container flow was performed.
-     * If no container flow are specified, this method returns the same list returned
-     * by getFlowEntriesForGroup(String group).
-     *
-     * @param group
-     *            the group name
-     * @return the list of container flow merged flow entries belonging to the specified group
-     */
-    public List<FlowEntry> getInstalledFlowEntriesForGroup(String policyName);
-
-    /**
-     * Add a list of output port to the flow with the specified name on the
-     * specified network node
-     *
-     * @param node
-     *            the network node
-     * @param flowName
-     *            the flow name
-     * @param dstPort
-     *            the list of ports to be added to the flow output actions
-     */
-    public void addOutputPort(Node node, String flowName, List<NodeConnector> dstPort);
-
-    /**
-     * Remove a list of output port from the flow with the specified name on the
-     * specified network node
-     *
-     * @param node
-     *            the network node
-     * @param flowName
-     *            the flow name
-     * @param dstPortthe
-     *            list of ports to be removed from the flow output actions
-     */
-    public void removeOutputPort(Node node, String flowName, List<NodeConnector> dstPort);
-
-    /**
-     * Replace the current output port in the specified flow with the specified
-     * one
-     *
-     * @param node
-     *            the network node
-     * @param groupName
-     *            the group name
-     * @param flowName
-     *            the flow name
-     * @param dstPort
-     *            the new output action port
-     */
-    public void replaceOutputPort(Node node, String flowName, NodeConnector outPort);
-
-    /**
-     * Returns the output port configured on the specified flow
-     *
-     * @param node
-     *            the network node
-     * @param flowName
-     *            the flow name
-     * @return the output action port for the specified flow
-     */
-    public NodeConnector getOutputPort(Node node, String flowName);
-
-    /**
-     * Returns all the troubleshooting information that applications have set
-     * along with the policy they have configured through forwarding rules
-     * manger.
-     *
-     * @return the collection of troubleshooting objects
-     */
-    public Map<String, Object> getTSPolicyData();
-
-    /**
-     * Set the troubleshooting information for the policy
-     *
-     * @param policyname
-     *            the flow group name
-     * @param o
-     *            the object containing the troubleshooting information
-     * @param add
-     *            true for adding, false for removing
-     */
-    public void setTSPolicyData(String policyName, Object o, boolean add);
-
-    /**
-     * Returns the troubleshooting information that was set for the specified
-     * policy
-     *
-     * @param groupName
-     *            the flows group name
-     * @return the troubleshooting info object
-     */
-    public Object getTSPolicyData(String policyName);
-
-    /**
-     * Returns the specifications of all the flows configured for all the
-     * switches on the current container
-     *
-     * @return the list of flow configurations present in the database
-     */
-    public List<FlowConfig> getStaticFlows();
-
-    /**
-     * Returns the specifications of all the flows configured for the given
-     * switch on the current container
-     *
-     * @param node
-     *            the network node identifier
-     * @return the list of {@code FlowConfig} objects
-     */
-    public List<FlowConfig> getStaticFlows(Node node);
-
-    /**
-     * Returns the specification of the flow configured for the given network
-     * node on the current container
-     *
-     * @param name
-     *            the flow name
-     * @param n
-     *            the network node identifier
-     * @return the {@code FlowConfig} object
-     */
-    public FlowConfig getStaticFlow(String name, Node n);
-
-    /**
-     * Returns the list of names of flows configured for the given Network node
-     * on the current container
-     *
-     * @param node
-     *            the network node identifier
-     * @return the list of flow names
-     */
-    public List<String> getStaticFlowNamesForNode(Node node);
-
-    /**
-     * Returns the list of Node(s) for which a static flow has been configured
-     *
-     * @return the list of network nodes
-     */
-    public List<Node> getListNodeWithConfiguredFlows();
-
-    /**
-     * Save the flow configured so far to file
-     *
-     * @return the {@code Status} object indicating the result of this action.
-     */
-    public Status saveConfig();
-
-    /**
-     * Add a flow specified by the {@code FlowConfig} object on the current
-     * container
-     *
-     * @param config
-     *            the {@code FlowConfig} object representing the static flow
-     * @return the {@code Status} object indicating the result of this action.
-     */
-    public Status addStaticFlow(FlowConfig config);
-
-    /**
-     * Add a flow specified by the {@code FlowConfig} object on the current
-     * container, through an asynchronous call.
-     *
-     * @param config
-     *            the {@code FlowConfig} object representing the static flow
-     * @return the {@code Status} object indicating the result of this action.
-     */
-    public Status addStaticFlowAsync(FlowConfig config);
-
-    /**
-     * Remove a flow specified by the {@code FlowConfig} object on the current
-     * container
-     *
-     * @param config
-     *            the {@code FlowConfig} object representing the static flow
-     * @return the {@code Status} object indicating the result of this action
-     */
-    public Status removeStaticFlow(FlowConfig config);
-
-    /**
-     * Remove a flow specified by the {@code FlowConfig} object on the current
-     * container, through an asynchronous call.
-     *
-     * @param config
-     *            the {@code FlowConfig} object representing the static flow
-     * @return the {@code Status} object indicating the result of this action
-     */
-    public Status removeStaticFlowAsync(FlowConfig config);
-
-    /**
-     * Replace the flow identified by the {@code FlowConfig.name} name for the
-     * {@code FlowConfig.node} network node with the new flow specified by
-     * {@code FlowConfig} object
-     *
-     * @param config
-     *            the {@code FlowConfig} object
-     * @return the {@code Status} object indicating the result of this action
-     */
-    public Status modifyStaticFlow(FlowConfig config);
-
-    /**
-     * Remove the flow specified by name on the passed network node
-     *
-     * @param name
-     *            for the static flow
-     * @param node
-     *            on which the flow is attached
-     * @return the {@code Status} object indicating the result of this action
-     */
-    public Status removeStaticFlow(String name, Node node);
-
-    /**
-     * Remove the flow specified by name on the passed network node via an
-     * asynchronous call
-     *
-     * @param name
-     *            for the static flow
-     * @param node
-     *            on which the flow is attached
-     * @return the {@code Status} object indicating the result of this action
-     */
-    public Status removeStaticFlowAsync(String name, Node node);
-
-    /**
-     * Toggle the installation status of the specified configured flow If the
-     * flow configuration status is active, this call will change the flow
-     * status to inactive and vice-versa
-     *
-     * @param configObject
-     *            the {@code FlowConfig} object
-     * @return the {@code Status} object indicating the result of this action
-     */
-    public Status toggleStaticFlowStatus(FlowConfig configObject);
-
-    /**
-     * Toggle the installation status of the specified configured flow If the
-     * flow configuration status is active, this call will change the flow
-     * status to inactive and vice-versa
-     *
-     * @param name
-     *            for the static flow
-     * @param node
-     *            on which the flow is attached
-     * @return the {@code Status} object indicating the result of this action
-     */
-    public Status toggleStaticFlowStatus(String name, Node node);
-
-    public Map<String, PortGroupConfig> getPortGroupConfigs();
-
-    public boolean addPortGroupConfig(String name, String regex, boolean load);
-
-    public boolean delPortGroupConfig(String name);
-
-    public PortGroupProvider getPortGroupProvider();
-
-    /**
-     * Returns the list of Flow entries for a network node.
-     * This list contains the flows as they were
-     * requested to be installed by the applications, before any merging with
-     * container flow is done.
-     *
-     * @param node
-     * @return the original list of flow entries belonging to the specified node
-     */
-    public List<FlowEntry> getFlowEntriesForNode(Node node);
-
-    /**
-     * Returns the list of Flow entries installed in a network node.
-     * This list contains the effective flows installed
-     * on the nodes after the merging with any possible container flow was performed.
-     * If no container flow are specified, this method returns the same list as returned
-     * by getFlowEntriesForNode(Node node).
-     *
-     * @param node
-     * @return the list of container flow merged flow entries belonging to the specified node
-     */
-    public List<FlowEntry> getInstalledFlowEntriesForNode(Node node);
-
-}
diff --git a/opendaylight/adsal/forwardingrulesmanager/api/src/main/java/org/opendaylight/controller/forwardingrulesmanager/IForwardingRulesManagerAware.java b/opendaylight/adsal/forwardingrulesmanager/api/src/main/java/org/opendaylight/controller/forwardingrulesmanager/IForwardingRulesManagerAware.java
deleted file mode 100644 (file)
index 31e1ea1..0000000
+++ /dev/null
@@ -1,42 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.forwardingrulesmanager;
-
-/**
- * The interface which describes the methods forwarding rules manager will call
- * for notifying the listeners of policy installation updates.
- */
-public interface IForwardingRulesManagerAware {
-
-    /**
-     * Inform the listeners that a troubleshooting information was added or
-     * removed for the specified policy.
-     *
-     * @param policyName
-     *            the policy affected
-     * @param add
-     *            true if the troubleshooting information was added, false
-     *            otherwise
-     */
-    public void policyUpdate(String policyName, boolean add);
-
-    /**
-     * Inform listeners that the network node has notified us about a failure in
-     * executing the controller generated asynchronous request identified by the
-     * passed unique id.
-     *
-     * @param requestId
-     *            the unique id associated with the request which failed to be
-     *            executed on the network node
-     * @param error
-     *            the string describing the error reported by the network node
-     */
-    public void requestFailed(long requestId, String error);
-
-}
diff --git a/opendaylight/adsal/forwardingrulesmanager/api/src/main/java/org/opendaylight/controller/forwardingrulesmanager/PortGroup.java b/opendaylight/adsal/forwardingrulesmanager/api/src/main/java/org/opendaylight/controller/forwardingrulesmanager/PortGroup.java
deleted file mode 100644 (file)
index b05091a..0000000
+++ /dev/null
@@ -1,102 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.forwardingrulesmanager;
-
-import java.util.HashSet;
-import java.util.Set;
-
-/**
- * PortGroup is a simple data-structure to represent any arbitrary group of
- * ports on a Switch (that is represented using its switch-ID).
- *
- * PortGroup is used by PortGroupProvider application to signal a set of ports
- * that represent a configured PortGroupConfig.
- */
-public class PortGroup {
-    private long matrixSwitchId;
-    private Set<Short> ports;
-
-    /**
-     * PortGroup Constructor using Switch and Ports.
-     *
-     * @param matrixSwitchId
-     *            Switch Id that represents an openflow Switch
-     * @param ports
-     *            Set of short values representing openflow port-ids.
-     */
-    public PortGroup(long matrixSwitchId, Set<Short> ports) {
-        super();
-        this.matrixSwitchId = matrixSwitchId;
-        this.ports = ports;
-    }
-
-    /**
-     * PortGroup Constructor using Switch.
-     *
-     * @param matrixSwitchId
-     *            Switch-Id that represents an openflow Switch
-     */
-    public PortGroup(long matrixSwitchId) {
-        this.matrixSwitchId = matrixSwitchId;
-        this.ports = new HashSet<Short>();
-    }
-
-    /**
-     * Returns the switchId representing the Switch that makes this PortGroup.
-     *
-     * @return long switchId
-     */
-    public long getMatrixSwitchId() {
-        return matrixSwitchId;
-    }
-
-    /**
-     * Assigns a Switch to this PortGroup
-     *
-     * @param matrixSwitchId
-     *            Switch-Id that represents an openflow Switch
-     */
-    public void setMatrixSwitchId(long matrixSwitchId) {
-        this.matrixSwitchId = matrixSwitchId;
-    }
-
-    /**
-     * Returns the Set of Ports that makes this PortGroup.
-     *
-     * @return Set of short values representing openflow port-ids.
-     */
-    public Set<Short> getPorts() {
-        return ports;
-    }
-
-    /**
-     * Assigns a set of openflow ports to this PortGroup
-     *
-     * @param ports
-     *            Set of short values representing openflow port-ids.
-     */
-    public void setPorts(Set<Short> ports) {
-        this.ports = ports;
-    }
-
-    /**
-     * Adds a port to this PortGroup
-     *
-     * @param port
-     *            Short value of a openflow port.
-     */
-    public void addPort(short port) {
-        ports.add(port);
-    }
-
-    @Override
-    public String toString() {
-        return "PortGroup [matrixSwitchId=" + matrixSwitchId + ", ports=" + ports + "]";
-    }
-}
diff --git a/opendaylight/adsal/forwardingrulesmanager/api/src/main/java/org/opendaylight/controller/forwardingrulesmanager/PortGroupChangeListener.java b/opendaylight/adsal/forwardingrulesmanager/api/src/main/java/org/opendaylight/controller/forwardingrulesmanager/PortGroupChangeListener.java
deleted file mode 100644 (file)
index 5f28608..0000000
+++ /dev/null
@@ -1,36 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.forwardingrulesmanager;
-
-import java.util.Map;
-
-import org.opendaylight.controller.sal.core.Node;
-
-/**
- * PortGroupChangeListener listens to the PortGroup updates provided by the
- * PortGroupProvider.
- *
- *
- */
-public interface PortGroupChangeListener {
-    /**
-     * This method is invoked by PortGroupProvider whenever it detects a change
-     * in PortGroup membership for a given PortGroupConfig.
-     *
-     * @param config
-     *            Port Group Configuration
-     * @param portGroupData
-     *            HashMap of Node id to PortGroup that represents the updated
-     *            ports as detected by PortGroupProvider.
-     * @param add
-     *            true indicates that the PortGroup is added. False indicates
-     *            that the PortGroup is removed.
-     */
-    void portGroupChanged(PortGroupConfig config, Map<Node, PortGroup> portGroupData, boolean add);
-}
diff --git a/opendaylight/adsal/forwardingrulesmanager/api/src/main/java/org/opendaylight/controller/forwardingrulesmanager/PortGroupConfig.java b/opendaylight/adsal/forwardingrulesmanager/api/src/main/java/org/opendaylight/controller/forwardingrulesmanager/PortGroupConfig.java
deleted file mode 100644 (file)
index d0878f9..0000000
+++ /dev/null
@@ -1,172 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.forwardingrulesmanager;
-
-import java.io.Serializable;
-import java.lang.reflect.Field;
-import java.util.ArrayList;
-import java.util.List;
-
-import org.opendaylight.controller.configuration.ConfigurationObject;
-
-/**
- * PortGroupConfig class represents the User's Configuration with a Opaque
- * Regular Expression String that is parsed and handled by PortGroupProvider.
- *
- * Typically, the opaque matchString will be a Regular Expression String
- * supported by a particular PortGroupProvider based on Customer requirements.
- *
- *
- *
- */
-public class PortGroupConfig extends ConfigurationObject implements Serializable {
-    private static final long serialVersionUID = 1L;
-    private static final String prettyFields[] = { "Name", "Match Criteria" };
-
-    private String name;
-    private String matchString;
-
-    /**
-     * Default Constructor with regular expression string defaulted to ".*"
-     */
-    public PortGroupConfig() {
-        name = "default";
-        matchString = ".*";
-    }
-
-    /**
-     * Constructor to create a Port Group Configuration using a Group Name and
-     * an Opaque String that is managed by PortGroupProvider.
-     *
-     * @param name
-     *            Group Name representing a Port Group configuration
-     * @param matchString
-     *            An Opaque String managed by PortGroupProvider
-     */
-    public PortGroupConfig(String name, String matchString) {
-        super();
-        this.name = name;
-        this.matchString = matchString;
-    }
-
-    /**
-     * Returns the user configured PortGroup Configuration name.
-     *
-     * @return Configuration Name
-     */
-    public String getName() {
-        return name;
-    }
-
-    /**
-     * Assigns a name to the configuration
-     *
-     * @param name
-     *            configuration name
-     */
-    public void setName(String name) {
-        this.name = name;
-    }
-
-    /**
-     * Returns the Opaque string
-     *
-     * @return
-     */
-    public String getMatchString() {
-        return matchString;
-    }
-
-    /**
-     * Assigns an opaque String to the Configuration.
-     *
-     * @param matchString
-     *            Opaque string handled by PortGroupProvider
-     */
-    public void setMatchString(String matchString) {
-        this.matchString = matchString;
-    }
-
-    /**
-     * Returns the names of all the configurable fields in PortGroupConfig. This
-     * method is typically used by NorthBound apis.
-     *
-     * @return List of Field names that can be configured.
-     */
-    public static List<String> getFieldsNames() {
-        List<String> fieldList = new ArrayList<String>();
-        for (Field fld : PortGroupConfig.class.getDeclaredFields()) {
-            fieldList.add(fld.getName());
-        }
-        // remove static field(s)
-        fieldList.remove(0);
-        fieldList.remove(0);
-
-        return fieldList;
-    }
-
-    /**
-     * Returns the names of all the configurable fields in PortGroupConfig in
-     * human readable format for UI purposes. This method is typically used by
-     * Web/UI apis.
-     *
-     * @return List of Human readable Strings that corresponds to the
-     *         configurable field names.
-     */
-    public static List<String> getPrettyFieldsNames() {
-        List<String> fieldList = new ArrayList<String>();
-        for (String str : prettyFields) {
-            fieldList.add(str);
-        }
-        return fieldList;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + ((matchString == null) ? 0 : matchString.hashCode());
-        result = prime * result + ((name == null) ? 0 : name.hashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        PortGroupConfig other = (PortGroupConfig) obj;
-        if (matchString == null) {
-            if (other.matchString != null) {
-                return false;
-            }
-        } else if (!matchString.equals(other.matchString)) {
-            return false;
-        }
-        if (name == null) {
-            if (other.name != null) {
-                return false;
-            }
-        } else if (!name.equals(other.name)) {
-            return false;
-        }
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        return "PortGroupConfig [name=" + name + ", matchString=" + matchString + "]";
-    }
-}
diff --git a/opendaylight/adsal/forwardingrulesmanager/api/src/main/java/org/opendaylight/controller/forwardingrulesmanager/PortGroupProvider.java b/opendaylight/adsal/forwardingrulesmanager/api/src/main/java/org/opendaylight/controller/forwardingrulesmanager/PortGroupProvider.java
deleted file mode 100644 (file)
index dc4f13f..0000000
+++ /dev/null
@@ -1,113 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.forwardingrulesmanager;
-
-import java.util.Map;
-
-import org.opendaylight.controller.sal.core.Node;
-
-/**
- * PortGroupProvider interface provides all the necessary blueprint for a custom
- * application to implement in order to provide Port Grouping Service. Custom
- * Application that implements this interface will have to handle the opaque
- * match criteria passed to it via PortGroupConfig.
- *
- *
- *
- */
-public interface PortGroupProvider {
-    /**
-     * This method is invoked by the Controller towards the Provider when a new
-     * port group is configured.
-     *
-     * @param config
-     *            New PortGroupConfig object created by user Configuration.
-     * @return true if successful. false otherwise.
-     */
-    boolean createPortGroupConfig(PortGroupConfig config);
-
-    /**
-     * This method is invoked by the Controller towards the Provider when an
-     * existing port group is deleted.
-     *
-     * @param config
-     *            Existing Port Group Configuration deleted by the user.
-     * @return true if successful. false otherwise.
-     */
-    boolean deletePortGroupConfig(PortGroupConfig config);
-
-    /**
-     * Returns the complete mapping database corresponds to a PortGroup
-     * Configuration. Its the PortGroupProvider Application's responsibility to
-     * manage the Switches & the Set of its Ports that correspond to each of the
-     * Configuration and return it to the Controller when requested.
-     *
-     * @param config
-     *            User Configuration
-     * @see PortGroupConfig
-     * @return Database of Switch-Id to PortGroup mapping that corresponds to
-     *         the Port Group User Configuration.
-     */
-    Map<Node, PortGroup> getPortGroupData(PortGroupConfig config);
-
-    /**
-     * Returns PortGroup data for a given Switch and user Configuration. Its the
-     * PortGroupProvider Application's responsibility to manage the Switches &
-     * the Set of its Ports that correspond to each of the Configuration and
-     * return it to the Controller when requested.
-     *
-     * @param config
-     *            User Configuration
-     * @param matrixSwitchId
-     *            Switch Id that represents an openflow Switch
-     * @see PortGroupConfig
-     * @return PortGroup data for a given Openflow switch.
-     * @see PortGroup
-     */
-    PortGroup getPortGroupData(PortGroupConfig config, long matrixSwitchId);
-
-    /**
-     * Registers a Listener for Port Group membership changes based on Custom
-     * application algorithm.
-     *
-     * @param listener
-     *            A Controller module that listens to events from the Custom
-     *            Port Grouping Application.
-     */
-    void registerPortGroupChange(PortGroupChangeListener listener);
-
-    /**
-     * Application returns an Usage string for the Match Criteria User
-     * Configuration. Controller provides an opportunity for application to
-     * implement Custom Algorithm for Port Grouping. This method exposes the
-     * custom algorithm to the user so that the user can configure the
-     * matchString regular expression in PortGroupConfig appropriately.
-     *
-     * @return Usage string.
-     */
-    String getApplicationDrivenMatchCriteriaUsage();
-
-    /**
-     * Returns the name of the Custom Application that implements
-     * PortGroupProvider interface.
-     *
-     * @return Provider Name
-     */
-    String getProviderName();
-
-    /**
-     * Controller uses this method to check with the Provider supports the
-     * matchCriteria String configured by the User.
-     *
-     * @param matchCriteria
-     * @return true if the Provider supports the matchCriteria String. false
-     *         otherwise.
-     */
-    boolean isMatchCriteriaSupported(String matchCriteria);
-}
diff --git a/opendaylight/adsal/forwardingrulesmanager/api/src/test/java/org/opendaylight/controller/forwardingrulesmanager/frmTest.java b/opendaylight/adsal/forwardingrulesmanager/api/src/test/java/org/opendaylight/controller/forwardingrulesmanager/frmTest.java
deleted file mode 100644 (file)
index 3c367b9..0000000
+++ /dev/null
@@ -1,822 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.forwardingrulesmanager;
-
-import java.net.InetAddress;
-import java.net.UnknownHostException;
-import java.util.ArrayList;
-import java.util.HashSet;
-import java.util.List;
-import java.util.Set;
-import java.util.concurrent.ConcurrentHashMap;
-import java.util.concurrent.ConcurrentMap;
-
-import org.junit.Assert;
-import org.junit.Test;
-import org.opendaylight.controller.sal.action.Action;
-import org.opendaylight.controller.sal.action.ActionType;
-import org.opendaylight.controller.sal.action.Controller;
-import org.opendaylight.controller.sal.action.Flood;
-import org.opendaylight.controller.sal.action.Output;
-import org.opendaylight.controller.sal.action.PopVlan;
-import org.opendaylight.controller.sal.action.SetDlDst;
-import org.opendaylight.controller.sal.action.SetNwDst;
-import org.opendaylight.controller.sal.action.SetVlanId;
-import org.opendaylight.controller.sal.core.ContainerFlow;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.flowprogrammer.Flow;
-import org.opendaylight.controller.sal.match.Match;
-import org.opendaylight.controller.sal.match.MatchType;
-import org.opendaylight.controller.sal.utils.EtherTypes;
-import org.opendaylight.controller.sal.utils.IPProtocols;
-import org.opendaylight.controller.sal.utils.NodeConnectorCreator;
-import org.opendaylight.controller.sal.utils.NodeCreator;
-import org.opendaylight.controller.sal.utils.Status;
-
-public class frmTest {
-
-    @Test
-    public void testFlowEntryInstall() throws UnknownHostException {
-        Node node = NodeCreator.createOFNode(1L);
-        FlowEntry pol = new FlowEntry("polTest", null, getSampleFlowV6(node), node);
-        FlowEntry pol2 = new FlowEntry("polTest2", null, getSampleFlowV6(node), node);
-        FlowEntryInstall fei = new FlowEntryInstall(pol.clone(), null);
-        FlowEntryInstall fei2 = new FlowEntryInstall(pol.clone(), null);
-        FlowEntryInstall fei3 = new FlowEntryInstall(pol2.clone(), null);
-        Assert.assertTrue(fei.getOriginal().equals(pol));
-        Assert.assertTrue(fei.getInstall().equals(pol));
-        Assert.assertTrue(fei.getFlowName().equals(pol.getFlowName()));
-        Assert.assertTrue(fei.getGroupName().equals(pol.getGroupName()));
-        Assert.assertTrue(fei.getNode().equals(pol.getNode()));
-        Assert.assertFalse(fei.isDeletePending());
-        fei.toBeDeleted();
-        Assert.assertTrue(fei.isDeletePending());
-        Assert.assertNull(fei.getContainerFlow());
-        Assert.assertTrue(fei.equalsByNodeAndName(pol.getNode(), pol.getFlowName()));
-
-        Assert.assertTrue(fei.equals(fei2));
-        Assert.assertFalse(fei.equals(null));
-        Assert.assertTrue(fei.equals(fei3));
-
-    }
-
-    @Test
-    public void testFlowEntryCreation() throws UnknownHostException {
-        Node node = NodeCreator.createOFNode(1L);
-        FlowEntry pol = new FlowEntry("polTest", null, getSampleFlowV6(node), node);
-        Assert.assertTrue(pol.getFlow().equals(getSampleFlowV6(node)));
-    }
-
-    @Test
-    public void testFlowEntrySetGet() throws UnknownHostException {
-        Node node = NodeCreator.createOFNode(1L);
-        Node node2 = NodeCreator.createOFNode(2L);
-        FlowEntry pol = new FlowEntry("polTest", null, getSampleFlowV6(node), node);
-        pol.setGroupName("polTest2");
-        pol.setFlowName("flowName");
-        Assert.assertTrue(pol.getFlowName().equals("flowName"));
-        Assert.assertTrue(pol.getGroupName().equals("polTest2"));
-        pol.setNode(node2);
-        Assert.assertTrue(pol.getNode().equals(node2));
-        Assert.assertTrue(pol.equalsByNodeAndName(node2, "flowName"));
-    }
-
-    @Test
-    public void testFlowEntryEquality() throws UnknownHostException {
-        Node node = NodeCreator.createOFNode(1L);
-        Node node2 = NodeCreator.createOFNode(1L);
-        FlowEntry pol = new FlowEntry("polTest", null, getSampleFlowV6(node), node);
-        FlowEntry pol2 = new FlowEntry("polTest", null, getSampleFlowV6(node), node2);
-        Assert.assertTrue(pol.equals(pol2));
-    }
-
-    @Test
-    public void testFlowEntryCollision() throws UnknownHostException {
-        // Create 2 equal FlowEntry objects
-        Node node1 = NodeCreator.createOFNode(1L);
-        Node node2 = NodeCreator.createOFNode(1L);
-        FlowEntry fe1 = new FlowEntry("Junit", "flow1", getSampleFlowV6(node1), node1);
-        FlowEntry fe2 = new FlowEntry("Junit", "flow2", getSampleFlowV6(node2), node1);
-
-        // Check equality in FlowEntry and parameters
-        Assert.assertTrue(fe1.getFlow().getMatch().equals(fe2.getFlow().getMatch()));
-        Assert.assertTrue(fe1.getFlow().getMatch().getMatches() == fe2.getFlow().getMatch().getMatches());
-        Assert.assertTrue(fe1.getFlow().getMatch().hashCode() == fe2.getFlow().getMatch().hashCode());
-        Assert.assertTrue(fe1.getFlow().hashCode() == fe2.getFlow().hashCode());
-        Assert.assertTrue(fe1.equals(fe2));
-        Assert.assertTrue(fe1.hashCode() == fe2.hashCode());
-
-        // Change priority field for fe2, verify inequality
-        fe2.getFlow().setPriority((short)1000);
-
-        // Verify FlowEntry works as key in collection
-        ConcurrentMap<FlowEntry, FlowEntry> map = new ConcurrentHashMap<FlowEntry, FlowEntry>();
-        Assert.assertTrue(null == map.put(fe1, fe1));
-        Assert.assertTrue(fe1.clone().equals(map.put(fe1.clone(), fe1.clone())));
-        Assert.assertTrue(map.get(fe1.clone()).equals(fe1.clone()));
-        Assert.assertTrue(map.keySet().contains(fe1.clone()));
-        Assert.assertTrue(map.containsKey(fe1));
-
-        // Remove key
-        map.remove(fe1);
-        Assert.assertTrue(map.isEmpty());
-        Assert.assertFalse(map.containsKey(fe1));
-
-        // Verify cloned object as key
-        map.put(fe1.clone(), fe1.clone());
-        Assert.assertTrue(map.containsKey(fe1));
-
-        // Verify different key is not present
-        Assert.assertFalse(map.containsKey(fe2));
-
-        // Add different key
-        map.put(fe2.clone(), fe2.clone());
-        Assert.assertTrue(map.size() == 2);
-        Assert.assertTrue(map.containsKey(fe1));
-        Assert.assertTrue(map.containsKey(fe2));
-
-        // Make fe2 equal to fe1 again
-        fe2.getFlow().setPriority((short)300);
-        Assert.assertTrue(fe2.equals(fe1));
-        Assert.assertTrue(map.containsKey(fe2));
-
-        // Clean up
-        map.clear();
-    }
-
-    @Test
-    public void testFlowEntryInstallCollision() throws UnknownHostException {
-        // Create 2 equal FlowEntryInstall objects
-        Node node1 = NodeCreator.createOFNode(1L);
-        Node node2 = NodeCreator.createOFNode(1L);
-        FlowEntry fe1 = new FlowEntry("Junit", "flow1", getSampleFlowV6(node1), node1);
-        FlowEntry fe2 = new FlowEntry("Junit", "flow2", getSampleFlowV6(node2), node1);
-        ContainerFlow cf1 = null;
-        ContainerFlow cf2 = null;
-        FlowEntryInstall fei1 = new FlowEntryInstall(fe1, cf1);
-        FlowEntryInstall fei2 = new FlowEntryInstall(fe2, cf2);
-
-        // Check equality in FlowEntry and parameters
-        Assert.assertTrue(fei1.equals(fei2));
-        Assert.assertTrue(fei1.hashCode() == fei2.hashCode());
-
-        // Verify FlowEntryInstall works as key in collection
-        ConcurrentMap<FlowEntryInstall, FlowEntryInstall> map =
-                new ConcurrentHashMap<FlowEntryInstall, FlowEntryInstall>();
-        Assert.assertTrue(null == map.put(fei1, fei1));
-        Assert.assertTrue(map.get(fei1).equals(fei2));
-        Assert.assertTrue(map.keySet().contains(fei1));
-        Assert.assertTrue(map.keySet().contains(fei2));
-        Assert.assertTrue(map.containsKey(fei1));
-
-        // Remove key
-        map.remove(fei1);
-        Assert.assertTrue(map.isEmpty());
-        Assert.assertFalse(map.containsKey(fei1));
-
-        // Verify cloned object as key
-        map.put(fei1, fei1);
-        Assert.assertTrue(map.containsKey(fei1));
-
-        // Change fei2, change relevant hashcode info
-        fei2.getInstall().getFlow().setPriority((short)301);
-        Assert.assertFalse(fei1.equals(fei2));
-        Assert.assertFalse(fei1.hashCode() == fei2.hashCode());
-
-
-        // Verify different key is not present
-        Assert.assertFalse(map.containsKey(fei2));
-
-        // Add different key
-        map.put(fei2, fei2);
-        Assert.assertTrue(map.size() == 2);
-        Assert.assertTrue(map.containsKey(fei1));
-        Assert.assertTrue(map.containsKey(fei2));
-
-        // Make fei2 equal to fei1 again
-        fei2.getInstall().getFlow().setPriority((short)300);
-        Assert.assertTrue(fei2.equals(fei1));
-        Assert.assertTrue(map.containsKey(fei2));
-
-        // Clean up
-        map.clear();
-    }
-
-    @Test
-    public void testFlowEntryCloning() throws UnknownHostException {
-        Node node = NodeCreator.createOFNode(1L);
-        FlowEntry pol = new FlowEntry("polTest", null, getSampleFlowV6(node), node);
-        FlowEntry pol2 = pol.clone();
-        Assert.assertTrue(pol.equals(pol2));
-    }
-
-    @Test
-    public void testFlowEntrySet() throws UnknownHostException {
-        Set<FlowEntry> set = new HashSet<FlowEntry>();
-
-        Node node1 = NodeCreator.createOFNode(1L);
-        Node node2 = NodeCreator.createOFNode(2L);
-        Node node3 = NodeCreator.createOFNode(3L);
-
-        Match match = new Match();
-        match.setField(MatchType.NW_SRC, InetAddress.getAllByName("1.1.1.1"));
-        match.setField(MatchType.NW_DST, InetAddress.getAllByName("2.2.2.2"));
-        match.setField(MatchType.DL_TYPE, EtherTypes.IPv4.shortValue());
-
-        List<Action> actionList = new ArrayList<Action>();
-        // actionList.add(new Drop());
-
-        Flow flow = new Flow(match, actionList);
-        FlowEntry pol1 = new FlowEntry("m1", "same", flow, node1);
-        FlowEntry pol2 = new FlowEntry("m2", "same", flow, node2);
-        FlowEntry pol3 = new FlowEntry("m3", "same", flow, node3);
-
-        set.add(pol1);
-        set.add(pol2);
-        set.add(pol3);
-
-        Assert.assertTrue(set.contains(pol1));
-        Assert.assertTrue(set.contains(pol2));
-        Assert.assertTrue(set.contains(pol3));
-
-        Assert.assertTrue(set.contains(pol1.clone()));
-        Assert.assertTrue(set.contains(pol2.clone()));
-        Assert.assertTrue(set.contains(pol3.clone()));
-
-    }
-
-    @Test
-    public void testInternalFlow() {
-        FlowConfig flowConfig = new FlowConfig();
-        Assert.assertFalse(flowConfig.isInternalFlow());
-        flowConfig.setName("__Internal__");
-        Status status = flowConfig.validate();
-        Assert.assertFalse(status.isSuccess());
-        Assert.assertTrue(status.getDescription().contains("name"));
-        Assert.assertTrue(flowConfig.isInternalFlow());
-        flowConfig.setName("External");
-        Assert.assertFalse(flowConfig.isInternalFlow());
-    }
-
-    @Test
-    public void testFlowConfigCreateSet() throws UnknownHostException {
-        FlowConfig frmC = new FlowConfig();
-        FlowConfig frmC3 = new FlowConfig();
-        Node node = NodeCreator.createOFNode(1L);
-        FlowEntry entry = new FlowEntry("polTest", null, getSampleFlowV6(node), node);
-
-        // testing equal function
-        Assert.assertFalse(frmC.equals(null));
-        Assert.assertTrue(frmC.equals(frmC));
-        Assert.assertTrue(frmC.equals(frmC3));
-        Assert.assertFalse(frmC.equals(entry));
-        FlowConfig flowC = createSampleFlowConfig();
-        Assert.assertFalse(frmC.equals(flowC));
-        // testing installInHW
-        Assert.assertTrue(frmC.installInHw());
-        frmC.setInstallInHw(false);
-        Assert.assertFalse(frmC.installInHw());
-        frmC.setInstallInHw(true);
-        Assert.assertTrue(frmC.installInHw());
-
-        // testing general set and get methods
-        ArrayList<String> actions = createSampleActionList();
-        frmC.setActions(actions);
-        Assert.assertFalse(frmC.equals(frmC3));
-        frmC3.setActions(actions);
-
-        Assert.assertFalse(frmC.equals(flowC));
-        frmC.setCookie("0");
-        Assert.assertTrue(frmC.getCookie().equals("0"));
-        Assert.assertFalse(frmC.equals(frmC3));
-        frmC3.setCookie("0");
-
-        Assert.assertFalse(frmC.equals(flowC));
-        frmC.setDstMac("00:A0:C9:22:AB:11");
-        Assert.assertTrue(frmC.getDstMac().equals("00:A0:C9:22:AB:11"));
-        Assert.assertFalse(frmC.equals(frmC3));
-        frmC3.setDstMac("00:A0:C9:22:AB:11");
-
-        Assert.assertFalse(frmC.equals(flowC));
-        frmC.setSrcMac("00:A0:C9:14:C8:29");
-        Assert.assertTrue(frmC.getSrcMac().equals("00:A0:C9:14:C8:29"));
-        Assert.assertFalse(frmC.equals(frmC3));
-        frmC3.setSrcMac("00:A0:C9:14:C8:29");
-
-        Assert.assertFalse(frmC.equals(flowC));
-        frmC.setDynamic(true);
-        Assert.assertTrue(frmC.isDynamic());
-        Assert.assertFalse(frmC.equals(frmC3));
-        frmC3.setDynamic(true);
-        flowC.setDynamic(true);
-
-        Assert.assertFalse(frmC.equals(flowC));
-        frmC.setEtherType("0x0800");
-        Assert.assertTrue(frmC.getEtherType().equals("0x0800"));
-        Assert.assertFalse(frmC.equals(frmC3));
-        frmC3.setEtherType("0x0800");
-
-        Assert.assertFalse(frmC.equals(flowC));
-        frmC.setIngressPort("60");
-        Assert.assertTrue(frmC.getIngressPort().equals("60"));
-        Assert.assertFalse(frmC.equals(frmC3));
-        frmC3.setIngressPort("60");
-
-        Assert.assertFalse(frmC.equals(flowC));
-        frmC.setName("Config1");
-        Assert.assertTrue(frmC.getName().equals("Config1"));
-        Assert.assertFalse(frmC.equals(frmC3));
-        frmC3.setName("Config1");
-
-        Assert.assertFalse(frmC.equals(flowC));
-        frmC.setDstIp("2.2.2.2");
-        Assert.assertTrue(frmC.getDstIp().equals("2.2.2.2"));
-        Assert.assertFalse(frmC.equals(frmC3));
-        frmC3.setDstIp("2.2.2.2");
-
-        Assert.assertFalse(frmC.equals(flowC));
-        frmC.setSrcIp("1.2.3.4");
-        Assert.assertTrue(frmC.getSrcIp().equals("1.2.3.4"));
-        Assert.assertFalse(frmC.equals(frmC3));
-        frmC3.setSrcIp("1.2.3.4");
-
-        Assert.assertFalse(frmC.equals(flowC));
-        Assert.assertFalse(frmC.isPortGroupEnabled());
-        frmC.setPortGroup("2");
-        Assert.assertTrue(frmC.isPortGroupEnabled());
-        Assert.assertTrue(frmC.getPortGroup().equals("2"));
-        Assert.assertFalse(frmC.equals(frmC3));
-        frmC3.setPortGroup("2");
-
-        Assert.assertFalse(frmC.equals(flowC));
-        frmC.setPriority("100");
-        Assert.assertTrue(frmC.getPriority().equals("100"));
-        Assert.assertFalse(frmC.equals(frmC3));
-        frmC3.setPriority("100");
-
-        Assert.assertFalse(frmC.equals(flowC));
-        frmC.setProtocol(IPProtocols.TCP.toString());
-        Assert.assertTrue(frmC.getProtocol().equals(IPProtocols.TCP.toString()));
-        Assert.assertFalse(frmC.equals(frmC3));
-        frmC3.setProtocol(IPProtocols.TCP.toString());
-
-        Assert.assertFalse(frmC.equals(flowC));
-        frmC.setNode(Node.fromString(Node.NodeIDType.OPENFLOW, "1"));
-        Assert.assertTrue(frmC.getNode().equals(Node.fromString(Node.NodeIDType.OPENFLOW, "1")));
-        Assert.assertFalse(frmC.equals(frmC3));
-        frmC3.setNode(Node.fromString(Node.NodeIDType.OPENFLOW, "1"));
-
-        Assert.assertFalse(frmC.equals(flowC));
-        frmC.setTosBits("0");
-        Assert.assertTrue(frmC.getTosBits().equals("0"));
-        Assert.assertFalse(frmC.equals(frmC3));
-        frmC3.setTosBits("0");
-
-        Assert.assertFalse(frmC.equals(flowC));
-        frmC.setDstPort("100");
-        Assert.assertTrue(frmC.getDstPort().equals("100"));
-        Assert.assertFalse(frmC.equals(frmC3));
-        frmC3.setDstPort("100");
-
-        Assert.assertFalse(frmC.equals(flowC));
-        frmC.setSrcPort("8080");
-        Assert.assertTrue(frmC.getSrcPort().equals("8080"));
-        Assert.assertFalse(frmC.equals(frmC3));
-        frmC3.setSrcPort("8080");
-
-        Assert.assertFalse(frmC.equals(flowC));
-        frmC.setVlanId("100");
-        Assert.assertTrue(frmC.getVlanId().equals("100"));
-        Assert.assertFalse(frmC.equals(frmC3));
-        frmC3.setVlanId("100");
-
-        Assert.assertFalse(frmC.equals(flowC));
-        frmC.setVlanPriority("0");
-        Assert.assertTrue(frmC.getVlanPriority().equals("0"));
-        Assert.assertFalse(frmC.equals(frmC3));
-        frmC3.setVlanPriority("0");
-
-        Assert.assertFalse(frmC.equals(flowC));
-        frmC.setIdleTimeout("300");
-        Assert.assertTrue(frmC.getIdleTimeout().equals("300"));
-        Assert.assertFalse(frmC.equals(frmC3));
-        frmC3.setIdleTimeout("300");
-
-        Assert.assertFalse(frmC.equals(flowC));
-        frmC.setHardTimeout("1000");
-        Assert.assertTrue(frmC.getHardTimeout().equals("1000"));
-        Assert.assertFalse(frmC.equals(frmC3));
-        frmC3.setHardTimeout("1000");
-
-        // Assert.assertFalse(frmC.equals(flowC));
-        Assert.assertTrue(actions.equals(frmC.getActions()));
-
-        FlowConfig frmC2 = new FlowConfig(frmC);
-
-        Assert.assertFalse(frmC2.equals(frmC));
-        frmC2.setDynamic(false);
-        Assert.assertFalse(frmC2.equals(frmC));
-        frmC2.setDynamic(true);
-        Assert.assertTrue(frmC2.equals(frmC));
-        // Assert.assertFalse(frmC2.equals(frmC3));
-        flowC.setDynamic(true);
-        Assert.assertTrue(flowC.equals(frmC));
-        Assert.assertTrue(flowC.isStatusSuccessful());
-        flowC.setStatus("Invalid");
-        Assert.assertFalse(flowC.isStatusSuccessful());
-
-        flowC.getActions().add(ActionType.DROP.toString());
-        Assert.assertFalse(flowC.equals(frmC));
-        Assert.assertFalse(flowC.isIPv6());
-        flowC.setDstIp("2001:420:281:1004:407a:57f4:4d15:c355");
-        Assert.assertTrue(flowC.isIPv6());
-        flowC.setSrcIp("2001:420:281:1004:407a:57f4:4d15:c355");
-        Assert.assertTrue(flowC.isIPv6());
-
-        Long id = (Long) flowC.getNode().getID();
-        Assert.assertTrue(id.toString().equals("1"));
-
-    }
-
-    @Test
-    public void testFlowConfigEqualities() throws UnknownHostException {
-        FlowConfig fc = new FlowConfig();
-        FlowConfig fc2 = new FlowConfig();
-        fc.setName("flow1");
-        fc.setNode(Node.fromString(Node.NodeIDType.OPENFLOW, "1"));
-        Assert.assertFalse(fc.onNode(Node.fromString(Node.NodeIDType.OPENFLOW, "0")));
-        Assert.assertTrue(fc.onNode(Node.fromString(Node.NodeIDType.OPENFLOW, "1")));
-
-        Assert.assertTrue(fc.isByNameAndNodeIdEqual("flow1", Node.fromString(Node.NodeIDType.OPENFLOW, "1")));
-        Assert.assertFalse(fc.isByNameAndNodeIdEqual("flow1", Node.fromString(Node.NodeIDType.OPENFLOW, "0")));
-        Assert.assertFalse(fc.isByNameAndNodeIdEqual("flow2", Node.fromString(Node.NodeIDType.OPENFLOW, "1")));
-
-        Assert.assertFalse(fc.isByNameAndNodeIdEqual(fc2));
-        fc2.setName("flow1");
-        Assert.assertFalse(fc.isByNameAndNodeIdEqual(fc2));
-        fc2.setNode(Node.fromString(Node.NodeIDType.OPENFLOW, "0"));
-        Assert.assertFalse(fc.isByNameAndNodeIdEqual(fc2));
-        fc2.setNode(Node.fromString(Node.NodeIDType.OPENFLOW, "1"));
-        Assert.assertTrue(fc.isByNameAndNodeIdEqual(fc2));
-    }
-
-    @Test
-    public void testStatusToggle() throws UnknownHostException {
-        // default is install in Hw
-        FlowConfig fc = new FlowConfig();
-        fc.toggleInstallation();
-        Assert.assertFalse(fc.installInHw());
-        fc.toggleInstallation();
-        Assert.assertTrue(fc.installInHw());
-        fc.toggleInstallation();
-        Assert.assertFalse(fc.installInHw());
-
-    }
-
-    @Test
-    public void testGetFlowEntry() throws UnknownHostException {
-        FlowConfig fc2 = createSampleFlowConfig();
-        FlowEntry fe = fc2.getFlowEntry();
-        Assert.assertNotNull(fe);
-    }
-
-    @Test
-    public void testGetFlow() throws UnknownHostException {
-        FlowConfig fc = new FlowConfig();
-        fc.setActions(createSampleActionList());
-        Flow flow = fc.getFlow();
-        Assert.assertNotNull(flow);
-    }
-
-    @Test
-    public void testL2AddressValid() {
-        FlowConfig fc = new FlowConfig();
-        Assert.assertFalse(fc.isL2AddressValid(null));
-        Assert.assertFalse(fc.isL2AddressValid("11"));
-        Assert.assertFalse(fc.isL2AddressValid("00:A0:C9:14:C8:"));
-        Assert.assertFalse(fc.isL2AddressValid("000:A01:C9:14:C8:211"));
-
-        Assert.assertTrue(fc.isL2AddressValid("00:A0:C9:14:C8:29"));
-    }
-
-    @Test
-    public void testValid() throws UnknownHostException {
-        FlowConfig fc2 = createSampleFlowConfig();
-        Assert.assertTrue(fc2.validate().isSuccess());
-
-        FlowConfig fc = new FlowConfig();
-        Status status = fc.validate();
-        Assert.assertFalse(status.isSuccess());
-        Assert.assertTrue(status.getDescription().contains("Invalid name"));
-
-        fc.setName("Config");
-        status = fc.validate();
-        Assert.assertFalse(status.isSuccess());
-        Assert.assertTrue(status.getDescription().contains("Node is null"));
-
-        fc.setNode(Node.fromString(Node.NodeIDType.OPENFLOW, "1"));
-        Assert.assertFalse(fc.validate().isSuccess());
-        List<String> actions = new ArrayList<String>();
-        fc.setActions(actions);
-        Assert.assertFalse(fc.validate().isSuccess());
-        actions.add("OUTPUT=2");
-        fc.setActions(actions);
-        Assert.assertTrue(fc.validate().isSuccess());
-
-        fc.setPriority("-1");
-        status = fc.validate();
-        Assert.assertFalse(status.isSuccess());
-        Assert.assertTrue(status.getDescription().contains("is not in the range 0 - 65535"));
-
-        fc.setPriority("100000");
-        status = fc.validate();
-        Assert.assertFalse(status.isSuccess());
-        Assert.assertTrue(status.getDescription().contains("is not in the range 0 - 65535"));
-
-        fc.setPriority("2000");
-        Assert.assertTrue(fc.validate().isSuccess());
-
-        fc.setCookie("100");
-        Assert.assertTrue(fc.validate().isSuccess());
-
-        fc.setIngressPort("100");
-        Assert.assertTrue(fc.validate().isSuccess());
-
-        fc.setVlanId(("-1"));
-        status = fc.validate();
-        Assert.assertFalse(status.isSuccess());
-        Assert.assertTrue(status.getDescription().contains("is not in the range 0 - 4095"));
-
-        fc.setVlanId("5000");
-        status = fc.validate();
-        Assert.assertFalse(status.isSuccess());
-        Assert.assertTrue(status.getDescription().contains("is not in the range 0 - 4095"));
-
-        fc.setVlanId("100");
-        Assert.assertTrue(fc.validate().isSuccess());
-
-        fc.setVlanPriority("-1");
-        status = fc.validate();
-        Assert.assertFalse(status.isSuccess());
-        Assert.assertTrue(status.getDescription().contains("is not in the range 0 - 7"));
-
-        fc.setVlanPriority("9");
-        status = fc.validate();
-        Assert.assertFalse(status.isSuccess());
-        Assert.assertTrue(status.getDescription().contains("is not in the range 0 - 7"));
-
-        fc.setVlanPriority("5");
-        Assert.assertTrue(fc.validate().isSuccess());
-
-        fc.setEtherType("-1");
-        status = fc.validate();
-        Assert.assertFalse(status.isSuccess());
-        Assert.assertTrue(status.getDescription().contains("Ethernet type"));
-
-        fc.setEtherType("0xfffff");
-        status = fc.validate();
-        Assert.assertFalse(status.isSuccess());
-        Assert.assertTrue(status.getDescription().contains("Ethernet type"));
-
-        fc.setEtherType("0x800");
-        Assert.assertTrue(fc.validate().isSuccess());
-
-        fc.setTosBits("-1");
-        status = fc.validate();
-        Assert.assertFalse(status.isSuccess());
-        Assert.assertTrue(status.getDescription().contains("IP ToS bits"));
-
-        fc.setTosBits("65");
-        status = fc.validate();
-        Assert.assertFalse(status.isSuccess());
-        Assert.assertTrue(status.getDescription().contains("IP ToS bits"));
-
-        fc.setTosBits("60");
-        Assert.assertTrue(fc.validate().isSuccess());
-
-        fc.setSrcPort("-1");
-        status = fc.validate();
-        Assert.assertFalse(status.isSuccess());
-        Assert.assertTrue(status.getDescription().contains("Transport source port"));
-
-        fc.setSrcPort("0xfffff");
-        status = fc.validate();
-        Assert.assertFalse(status.isSuccess());
-        Assert.assertTrue(status.getDescription().contains("Transport source port"));
-
-        fc.setSrcPort("0");
-        Assert.assertTrue(fc.validate().isSuccess());
-
-        fc.setSrcPort("0x00ff");
-        Assert.assertTrue(fc.validate().isSuccess());
-
-        fc.setSrcPort("0xffff");
-        Assert.assertTrue(fc.validate().isSuccess());
-
-        fc.setDstPort("-1");
-        status = fc.validate();
-        Assert.assertFalse(status.isSuccess());
-        Assert.assertTrue(status.getDescription().contains("Transport destination port"));
-
-        fc.setDstPort("0xfffff");
-        status = fc.validate();
-        Assert.assertFalse(status.isSuccess());
-        Assert.assertTrue(status.getDescription().contains("Transport destination port"));
-
-        fc.setDstPort("0");
-        Assert.assertTrue(fc.validate().isSuccess());
-
-        fc.setDstPort("0x00ff");
-        Assert.assertTrue(fc.validate().isSuccess());
-
-        fc.setDstPort("0xffff");
-        Assert.assertTrue(fc.validate().isSuccess());
-
-        fc.setSrcMac("abc");
-        status = fc.validate();
-        Assert.assertFalse(status.isSuccess());
-        Assert.assertTrue(status.getDescription().contains("Ethernet source address"));
-
-        fc.setSrcMac("00:A0:C9:14:C8:29");
-        Assert.assertTrue(fc.validate().isSuccess());
-
-        fc.setDstMac("abc");
-        status = fc.validate();
-        Assert.assertFalse(status.isSuccess());
-        Assert.assertTrue(status.getDescription().contains("Ethernet destination address"));
-
-        fc.setDstMac("00:A0:C9:22:AB:11");
-        Assert.assertTrue(fc.validate().isSuccess());
-
-        fc.setSrcIp("-1");
-        status = fc.validate();
-        Assert.assertFalse(status.isSuccess());
-        Assert.assertTrue(status.getDescription().contains("IP source address"));
-
-        fc.setSrcIp("2001:420:281:1004:407a:57f4:4d15:c355");
-        status = fc.validate();
-        Assert.assertFalse(status.isSuccess());
-        Assert.assertTrue(status.getDescription().contains("Type mismatch between Ethernet & Src IP"));
-
-        fc.setEtherType("0x86dd");
-        Assert.assertTrue(fc.validate().isSuccess());
-
-        fc.setSrcIp("1.1.1.1");
-        status = fc.validate();
-        Assert.assertFalse(status.isSuccess());
-        Assert.assertTrue(status.getDescription().contains("Type mismatch between Ethernet & Src IP"));
-
-        fc.setEtherType("0x800");
-        Assert.assertTrue(fc.validate().isSuccess());
-
-        fc.setDstIp("-1");
-        status = fc.validate();
-        Assert.assertFalse(status.isSuccess());
-        Assert.assertTrue(status.getDescription().contains("IP destination address"));
-
-        fc.setDstIp("2001:420:281:1004:407a:57f4:4d15:c355");
-        status = fc.validate();
-        Assert.assertFalse(status.isSuccess());
-        Assert.assertTrue(status.getDescription().contains("Type mismatch between Ethernet & Dst IP"));
-
-        fc.setEtherType("0x86dd");
-        fc.setSrcIp("2001:420:281:1004:407a:57f4:4d15:c355");
-        Assert.assertTrue(fc.validate().isSuccess());
-
-        fc.setDstIp("2.2.2.2");
-        status = fc.validate();
-        Assert.assertFalse(status.isSuccess());
-        Assert.assertTrue(status.getDescription().contains("Type mismatch between Ethernet & Dst IP"));
-
-        fc.setEtherType("0x800");
-        fc.setSrcIp("1.1.1.1");
-        Assert.assertTrue(fc.validate().isSuccess());
-
-        fc.setEtherType(null);
-        fc.setSrcIp("2001:420:281:1004:407a:57f4:4d15:c355");
-        status = fc.validate();
-        Assert.assertFalse(status.isSuccess());
-        Assert.assertTrue(status.getDescription().contains("IP Src Dest Type mismatch"));
-
-        fc.setSrcIp("1.1.1.1");
-        fc.setIdleTimeout("-1");
-        status = fc.validate();
-        Assert.assertFalse(status.isSuccess());
-        Assert.assertTrue(status.getDescription().contains("Idle Timeout value"));
-
-        fc.setIdleTimeout("0xfffff");
-        status = fc.validate();
-        Assert.assertFalse(status.isSuccess());
-        Assert.assertTrue(status.getDescription().contains("Idle Timeout value"));
-
-        fc.setIdleTimeout("10");
-        Assert.assertTrue(fc.validate().isSuccess());
-
-        fc.setHardTimeout("-1");
-        status = fc.validate();
-        Assert.assertFalse(status.isSuccess());
-        Assert.assertTrue(status.getDescription().contains("Hard Timeout value"));
-
-        fc.setHardTimeout("0xfffff");
-        status = fc.validate();
-        Assert.assertFalse(status.isSuccess());
-        Assert.assertTrue(status.getDescription().contains("Hard Timeout value"));
-
-        fc.setHardTimeout("10");
-        Assert.assertTrue(fc.validate().isSuccess());
-
-    }
-
-    private FlowConfig createSampleFlowConfig() throws UnknownHostException {
-        ArrayList<String> actions;
-        actions = createSampleActionList();
-        // actions.add(ActionType.CONTROLLER.toString());
-        FlowConfig flowConfig = new FlowConfig("true", "Config1", Node.fromString(Node.NodeIDType.OPENFLOW, "1"),
-                "100", "0", "60", "2", "100", "0", "0x0800", "00:A0:C9:14:C8:29", "00:A0:C9:22:AB:11",
-                IPProtocols.TCP.toString(), "0", "1.2.3.4", "2.2.2.2", "8080", "100", "300", "1000", actions);
-        return flowConfig;
-
-    }
-
-    private ArrayList<String> createSampleActionList() {
-        ArrayList<String> actions = new ArrayList<String>();
-        actions.add(ActionType.DROP.toString());
-        actions.add(ActionType.LOOPBACK.toString());
-        actions.add(ActionType.FLOOD.toString());
-        actions.add(ActionType.SW_PATH.toString());
-        actions.add(ActionType.HW_PATH.toString());
-        actions.add(ActionType.SET_VLAN_PCP.toString() + "=1");
-        actions.add(ActionType.SET_VLAN_ID.toString() + "=1");
-        actions.add(ActionType.POP_VLAN.toString());
-        actions.add(ActionType.SET_DL_SRC.toString() + "=00:A0:C1:AB:22:11");
-        actions.add(ActionType.SET_DL_DST.toString() + "=00:B1:C1:00:AA:BB");
-        actions.add(ActionType.SET_NW_SRC.toString() + "=1.1.1.1");
-        actions.add(ActionType.SET_NW_DST.toString() + "=2.2.2.2");
-        actions.add(ActionType.CONTROLLER.toString());
-        actions.add(ActionType.SET_NW_TOS.toString() + "=1");
-        actions.add(ActionType.SET_TP_SRC.toString() + "=60");
-        actions.add(ActionType.SET_TP_DST.toString() + "=8080");
-        actions.add(ActionType.SET_NEXT_HOP.toString() + "=1.1.1.1");
-
-        return actions;
-    }
-
-    private Flow getSampleFlowV6(Node node) throws UnknownHostException {
-        NodeConnector port = NodeConnectorCreator.createOFNodeConnector((short) 24, node);
-        NodeConnector oport = NodeConnectorCreator.createOFNodeConnector((short) 30, node);
-        byte srcMac[] = { (byte) 0x12, (byte) 0x34, (byte) 0x56, (byte) 0x78, (byte) 0x9a, (byte) 0xbc };
-        byte dstMac[] = { (byte) 0x1a, (byte) 0x2b, (byte) 0x3c, (byte) 0x4d, (byte) 0x5e, (byte) 0x6f };
-        byte newMac[] = { (byte) 0x11, (byte) 0xaa, (byte) 0xbb, (byte) 0x34, (byte) 0x9a, (byte) 0xee };
-        InetAddress srcIP = InetAddress.getByName("2001:420:281:1004:407a:57f4:4d15:c355");
-        InetAddress dstIP = InetAddress.getByName("2001:420:281:1004:e123:e688:d655:a1b0");
-        InetAddress ipMask = InetAddress.getByName("ffff:ffff:ffff:ffff:0:0:0:0");
-        InetAddress ipMask2 = InetAddress.getByName("ffff:ffff:ffff:ffff:ffff:ffff:ffff:0");
-        InetAddress newIP = InetAddress.getByName("2056:650::a1b0");
-        short ethertype = EtherTypes.IPv6.shortValue();
-        short vlan = (short) 27;
-        byte vlanPr = (byte) 3;
-        Byte tos = 4;
-        byte proto = IPProtocols.UDP.byteValue();
-        short src = (short) 5500;
-        short dst = 80;
-
-        /*
-         * Create a SAL Flow aFlow
-         */
-        Match match = new Match();
-        match.setField(MatchType.IN_PORT, port);
-        match.setField(MatchType.DL_SRC, srcMac);
-        match.setField(MatchType.DL_DST, dstMac);
-        match.setField(MatchType.DL_TYPE, ethertype);
-        match.setField(MatchType.DL_VLAN, vlan);
-        match.setField(MatchType.DL_VLAN_PR, vlanPr);
-        match.setField(MatchType.NW_SRC, srcIP, ipMask);
-        match.setField(MatchType.NW_DST, dstIP, ipMask2);
-        match.setField(MatchType.NW_TOS, tos);
-        match.setField(MatchType.NW_PROTO, proto);
-        match.setField(MatchType.TP_SRC, src);
-        match.setField(MatchType.TP_DST, dst);
-
-        List<Action> actions = new ArrayList<Action>();
-        actions.add(new Controller());
-        actions.add(new SetVlanId(5));
-        actions.add(new SetDlDst(newMac));
-        actions.add(new SetNwDst(newIP));
-        actions.add(new Output(oport));
-        actions.add(new PopVlan());
-        actions.add(new Flood());
-
-        Flow flow = new Flow(match, actions);
-        flow.setPriority((short) 300);
-        flow.setHardTimeout((short) 240);
-
-        return flow;
-    }
-}
diff --git a/opendaylight/adsal/forwardingrulesmanager/implementation/pom.xml b/opendaylight/adsal/forwardingrulesmanager/implementation/pom.xml
deleted file mode 100644 (file)
index d51b98b..0000000
+++ /dev/null
@@ -1,98 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>forwardingrulesmanager.implementation</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>org.apache.felix.gogo.runtime</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>clustering.services</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>configuration</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>connectionmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>containermanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>forwardingrulesmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal.connection</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>switchmanager</artifactId>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Include-Resource></Include-Resource>
-            <Export-Package>org.opendaylight.controller.forwardingrulesmanager.implementation.data</Export-Package>
-            <Import-Package>org.opendaylight.controller.clustering.services,
-              org.opendaylight.controller.configuration,
-              org.opendaylight.controller.containermanager,
-              org.opendaylight.controller.switchmanager,
-              org.opendaylight.controller.sal.action,
-              org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.sal.flowprogrammer,
-              org.opendaylight.controller.sal.match,
-              org.opendaylight.controller.sal.utils,
-              org.opendaylight.controller.sal.packet,
-              org.opendaylight.controller.sal.connection,
-              org.opendaylight.controller.forwardingrulesmanager,
-              org.opendaylight.controller.connectionmanager,
-              javax.xml.bind.annotation,
-              javax.xml.bind,
-              org.apache.felix.dm,
-              org.apache.felix.service.command,
-              org.osgi.service.component,
-              org.slf4j,
-              org.osgi.framework</Import-Package>
-            <Bundle-Activator>org.opendaylight.controller.forwardingrulesmanager.internal.Activator</Bundle-Activator>
-            <Require-Bundle>org.opendaylight.controller.hosttracker</Require-Bundle>
-            <Service-Component></Service-Component>
-          </instructions>
-          <manifestLocation>${project.basedir}/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/forwardingrulesmanager/implementation/src/main/java/org/opendaylight/controller/forwardingrulesmanager/implementation/data/FlowEntryDistributionOrder.java b/opendaylight/adsal/forwardingrulesmanager/implementation/src/main/java/org/opendaylight/controller/forwardingrulesmanager/implementation/data/FlowEntryDistributionOrder.java
deleted file mode 100644 (file)
index b55a7e3..0000000
+++ /dev/null
@@ -1,149 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others. All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * Class used by the FRM to distribute the forwarding rules programming in the
- * cluster and to collect back the results of the programming
- */
-package org.opendaylight.controller.forwardingrulesmanager.implementation.data;
-
-import java.io.Serializable;
-import java.net.InetAddress;
-
-import org.opendaylight.controller.forwardingrulesmanager.FlowEntryInstall;
-import org.opendaylight.controller.sal.core.UpdateType;
-
-/**
- * Class used by the FRM to distribute the forwarding rules programming in the
- * cluster and to collect back the results of the programming
- */
-public final class FlowEntryDistributionOrder implements Serializable {
-    /**
-     * Serialization UID
-     */
-    private static final long serialVersionUID = 416280377113255147L;
-    private final FlowEntryInstall entry;
-    private final UpdateType upType;
-    private final InetAddress requestorController;
-
-    /**
-     * @return the entry
-     */
-    public FlowEntryInstall getEntry() {
-        return entry;
-    }
-
-    /**
-     * @return the upType
-     */
-    public UpdateType getUpType() {
-        return upType;
-    }
-
-    /**
-     * @return the requestorController
-     */
-    public InetAddress getRequestorController() {
-        return requestorController;
-    }
-
-    /**
-     * @param entry
-     *            FlowEntryInstall key value
-     * @param upType
-     *            UpdateType key value
-     * @param requestorController
-     *            identifier of the controller that initiated the request
-     */
-
-    public FlowEntryDistributionOrder(FlowEntryInstall entry, UpdateType upType, InetAddress requestorController) {
-        super();
-        this.entry = entry;
-        this.upType = upType;
-        this.requestorController = requestorController;
-    }
-
-    /*
-     * (non-Javadoc)
-     *
-     * @see java.lang.Object#hashCode()
-     */
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = (prime * result) + ((entry == null) ? 0 : entry.hashCode());
-        result = (prime * result) + ((requestorController == null) ? 0 : requestorController.hashCode());
-        result = (prime * result) + ((upType == null) ? 0 : upType.calculateConsistentHashCode());
-        return result;
-    }
-
-    /*
-     * (non-Javadoc)
-     *
-     * @see java.lang.Object#equals(java.lang.Object)
-     */
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (!(obj instanceof FlowEntryDistributionOrder)) {
-            return false;
-        }
-        FlowEntryDistributionOrder other = (FlowEntryDistributionOrder) obj;
-        if (entry == null) {
-            if (other.entry != null) {
-                return false;
-            }
-        } else if (!entry.equals(other.entry)) {
-            return false;
-        }
-        if (requestorController == null) {
-            if (other.requestorController != null) {
-                return false;
-            }
-        } else if (!requestorController.equals(other.requestorController)) {
-            return false;
-        }
-        if (upType != other.upType) {
-            return false;
-        }
-        return true;
-    }
-
-    /*
-     * (non-Javadoc)
-     *
-     * @see java.lang.Object#toString()
-     */
-    @Override
-    public String toString() {
-        StringBuilder builder = new StringBuilder();
-        builder.append("FlowEntryDistributionOrder [");
-        if (entry != null) {
-            builder.append("entry=")
-                    .append(entry)
-                    .append(", ");
-        }
-        if (upType != null) {
-            builder.append("upType=")
-                    .append(upType)
-                    .append(", ");
-        }
-        if (requestorController != null) {
-            builder.append("requestorController=")
-                    .append(requestorController);
-        }
-        builder.append("]");
-        return builder.toString();
-    }
-}
diff --git a/opendaylight/adsal/forwardingrulesmanager/implementation/src/main/java/org/opendaylight/controller/forwardingrulesmanager/internal/Activator.java b/opendaylight/adsal/forwardingrulesmanager/implementation/src/main/java/org/opendaylight/controller/forwardingrulesmanager/internal/Activator.java
deleted file mode 100644 (file)
index a53ea11..0000000
+++ /dev/null
@@ -1,118 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.forwardingrulesmanager.internal;
-
-import java.util.Dictionary;
-import java.util.HashSet;
-import java.util.Hashtable;
-import java.util.Set;
-
-import org.apache.felix.dm.Component;
-import org.opendaylight.controller.clustering.services.ICacheUpdateAware;
-import org.opendaylight.controller.clustering.services.IClusterContainerServices;
-import org.opendaylight.controller.configuration.IConfigurationContainerAware;
-import org.opendaylight.controller.configuration.IConfigurationContainerService;
-import org.opendaylight.controller.connectionmanager.IConnectionManager;
-import org.opendaylight.controller.containermanager.IContainerManager;
-import org.opendaylight.controller.forwardingrulesmanager.IForwardingRulesManager;
-import org.opendaylight.controller.forwardingrulesmanager.IForwardingRulesManagerAware;
-import org.opendaylight.controller.sal.core.ComponentActivatorAbstractBase;
-import org.opendaylight.controller.sal.core.IContainer;
-import org.opendaylight.controller.sal.core.IContainerLocalListener;
-import org.opendaylight.controller.sal.flowprogrammer.IFlowProgrammerListener;
-import org.opendaylight.controller.sal.flowprogrammer.IFlowProgrammerService;
-import org.opendaylight.controller.sal.utils.GlobalConstants;
-import org.opendaylight.controller.switchmanager.IInventoryListener;
-import org.opendaylight.controller.switchmanager.ISwitchManager;
-import org.opendaylight.controller.switchmanager.ISwitchManagerAware;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-public class Activator extends ComponentActivatorAbstractBase {
-    protected static final Logger logger = LoggerFactory.getLogger(Activator.class);
-
-
-    /**
-     * Function that is used to communicate to dependency manager the list of
-     * known implementations for services inside a container
-     *
-     *
-     * @return An array containing all the CLASS objects that will be
-     *         instantiated in order to get an fully working implementation
-     *         Object
-     */
-    @Override
-    public Object[] getImplementations() {
-        Object[] res = { ForwardingRulesManager.class };
-        return res;
-    }
-
-    /**
-     * Function that is called when configuration of the dependencies is
-     * required.
-     *
-     * @param c
-     *            dependency manager Component object, used for configuring the
-     *            dependencies exported and imported
-     * @param imp
-     *            Implementation class that is being configured, needed as long
-     *            as the same routine can configure multiple implementations
-     * @param containerName
-     *            The containerName being configured, this allow also optional
-     *            per-container different behavior if needed, usually should not
-     *            be the case though.
-     */
-    @Override
-    public void configureInstance(Component c, Object imp, String containerName) {
-        if (imp.equals(ForwardingRulesManager.class)) {
-            String interfaces[] = null;
-            Dictionary<String, Object> props = new Hashtable<String, Object>();
-            Set<String> propSet = new HashSet<String>();
-            propSet.add(ForwardingRulesManager.WORK_STATUS_CACHE);
-            propSet.add(ForwardingRulesManager.WORK_ORDER_CACHE);
-            propSet.add(ForwardingRulesManager.INSTALLED_SW_VIEW_CACHE);
-            props.put("cachenames", propSet);
-
-            // export the service
-            interfaces = new String[] { IContainerLocalListener.class.getName(), ISwitchManagerAware.class.getName(),
-                    IForwardingRulesManager.class.getName(), IInventoryListener.class.getName(),
-                    IConfigurationContainerAware.class.getName(), ICacheUpdateAware.class.getName(),
-                    IFlowProgrammerListener.class.getName() };
-
-            c.setInterface(interfaces, props);
-
-            c.add(createContainerServiceDependency(containerName).setService(IFlowProgrammerService.class)
-                    .setCallbacks("setFlowProgrammerService", "unsetFlowProgrammerService").setRequired(true));
-            c.add(createContainerServiceDependency(containerName).setService(IClusterContainerServices.class)
-                    .setCallbacks("setClusterContainerService", "unsetClusterContainerService").setRequired(true));
-            c.add(createContainerServiceDependency(containerName).setService(ISwitchManager.class)
-                    .setCallbacks("setSwitchManager", "unsetSwitchManager").setRequired(true));
-            c.add(createContainerServiceDependency(containerName).setService(IForwardingRulesManagerAware.class)
-                    .setCallbacks("setFrmAware", "unsetFrmAware").setRequired(false));
-            c.add(createContainerServiceDependency(containerName).setService(IContainer.class)
-                    .setCallbacks("setIContainer", "unsetIContainer").setRequired(true));
-            c.add(createServiceDependency().setService(IConnectionManager.class)
-                    .setCallbacks("setIConnectionManager", "unsetIConnectionManager").setRequired(true));
-            c.add(createContainerServiceDependency(containerName).setService(
-                    IConfigurationContainerService.class).setCallbacks(
-                    "setConfigurationContainerService",
-                    "unsetConfigurationContainerService").setRequired(true));
-            if (GlobalConstants.DEFAULT.toString().equals(containerName)) {
-                c.add(createServiceDependency().setService(IContainerManager.class)
-                        .setCallbacks("setIContainerManager", "unsetIContainerManager").setRequired(true));
-            }
-        }
-    }
-
-    @Override
-    protected Object[] getGlobalImplementations() {
-        final Object[] res = { ForwardingRulesManagerCLI.class };
-        return res;
-    }
-}
diff --git a/opendaylight/adsal/forwardingrulesmanager/implementation/src/main/java/org/opendaylight/controller/forwardingrulesmanager/internal/FlowEntryDistributionOrderFutureTask.java b/opendaylight/adsal/forwardingrulesmanager/implementation/src/main/java/org/opendaylight/controller/forwardingrulesmanager/internal/FlowEntryDistributionOrderFutureTask.java
deleted file mode 100644 (file)
index b8c2d1d..0000000
+++ /dev/null
@@ -1,167 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others. All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * Class which will monitor the completion of a FlowEntryDistributionOrder it
- * implements a Future interface so it can be inspected by who is waiting for
- * it.
- */
-package org.opendaylight.controller.forwardingrulesmanager.internal;
-
-import java.util.concurrent.CountDownLatch;
-import java.util.concurrent.ExecutionException;
-import java.util.concurrent.Future;
-import java.util.concurrent.TimeUnit;
-import java.util.concurrent.TimeoutException;
-
-import org.opendaylight.controller.forwardingrulesmanager.implementation.data.FlowEntryDistributionOrder;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.sal.utils.StatusCode;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * Class which will monitor the completion of a FlowEntryDistributionOrder it
- * implements a Future interface so it can be inspected by who is waiting for
- * it.
- */
-final class FlowEntryDistributionOrderFutureTask implements Future<Status> {
-    private final FlowEntryDistributionOrder order;
-    private boolean amICancelled;
-    private CountDownLatch waitingLatch;
-    private Status retStatus;
-    private static final Logger logger = LoggerFactory.getLogger(FlowEntryDistributionOrderFutureTask.class);
-    // Don't wait forever to program, rather timeout if there are issues, and
-    // log an error
-    private long timeout;
-    private static final Long DEFAULTTIMEOUT = 30000L;
-
-    /**
-     * @param order
-     *            for which we are monitoring the execution
-     */
-    FlowEntryDistributionOrderFutureTask(FlowEntryDistributionOrder order) {
-        // Order being monitored
-        this.order = order;
-        this.amICancelled = false;
-        // We need to wait for one completion to happen
-        this.waitingLatch = new CountDownLatch(1);
-        // No return status yet!
-        this.retStatus = new Status(StatusCode.UNDEFINED);
-        // Set the timeout
-        String strTimeout = System.getProperty("FlowEntryDistributionOrderFutureTask.timeout",
-                                               DEFAULTTIMEOUT.toString());
-        try {
-            timeout = Long.parseLong(strTimeout);
-        } catch (Exception e) {
-            timeout = DEFAULTTIMEOUT;
-        }
-    }
-
-    @Override
-    public boolean cancel(boolean mayInterruptIfRunning) {
-        if (this.waitingLatch.getCount() != 0L) {
-            this.retStatus = new Status(StatusCode.GONE);
-            this.waitingLatch.countDown();
-            logger.trace("Cancelled the workOrder");
-            return true;
-        }
-        return false;
-    }
-
-    @Override
-    public Status get() throws InterruptedException, ExecutionException {
-        boolean didFinish = false;
-        logger.trace("Getting status for order {}", this.order);
-        // If i'm done lets return the status as many times as caller wants
-        if (this.waitingLatch.getCount() == 0L) {
-            logger.trace("get returns the status without waiting");
-            return retStatus;
-        }
-
-        logger.trace("Start waiting for status to come back");
-        // Wait till someone signal that we are done
-        didFinish = this.waitingLatch.await(this.timeout, TimeUnit.MILLISECONDS);
-
-        if (didFinish) {
-            logger.trace("Waiting for the status of order {} is over, returning it", this.order);
-            // Return the known status
-            return retStatus;
-        } else {
-            logger.error("Timing out, the workStatus for order {} has not come back in time!, it's hashcode is {}",
-                    this.order, this.order.hashCode());
-            return new Status(StatusCode.TIMEOUT);
-        }
-    }
-
-    @Override
-    public Status get(long timeout, TimeUnit unit) throws InterruptedException,
-            ExecutionException, TimeoutException {
-        boolean didFinish = false;
-        logger.trace("Getting status for order {}", this.order);
-        // If i'm done lets return the status as many times as caller wants
-        if (this.waitingLatch.getCount() == 0L) {
-            logger.trace("get returns the status without waiting");
-            return retStatus;
-        }
-
-        logger.trace("Start waiting for status to come back");
-        // Wait till someone signal that we are done
-        didFinish = this.waitingLatch.await(timeout, unit);
-
-        if (didFinish) {
-            logger.trace("Waiting for the status is over, returning it");
-            // Return the known status, could also be null if didn't return
-            return retStatus;
-        } else {
-            // No need to bark here as long as this routine could indeed
-            // timeout
-            logger.trace("Timing out, the workStatus for order {} has not come back in time!", this.order);
-            return new Status(StatusCode.TIMEOUT);
-        }
-    }
-
-    @Override
-    public boolean isCancelled() {
-        return this.amICancelled;
-    }
-
-    @Override
-    public boolean isDone() {
-        return (this.waitingLatch.getCount() == 0L);
-    }
-
-    /**
-     * Used by the thread that gets back the status for the order so can unblock
-     * an eventual caller waiting on the result to comes back
-     *
-     * @param order
-     * @param retStatus
-     */
-    void gotStatus(FlowEntryDistributionOrder order, Status retStatus) {
-        logger.trace("Got status for order:{} \n Status:{}", order, retStatus);
-        if (!order.equals(this.order)) {
-            logger.error("Didn't get a result for an order we did issue order expected:{}, order received:{}",
-                    this.order, order);
-            // Weird we got a call for an order we didn't make
-            return;
-        }
-        this.retStatus = retStatus;
-        // Now we are not waiting any longer
-        this.waitingLatch.countDown();
-        logger.trace("Unlocked the Future");
-    }
-
-    /**
-     * Getter for the workOrder for which the order is waiting for
-     * @return the order
-     */
-    public FlowEntryDistributionOrder getOrder() {
-        return order;
-    }
-}
diff --git a/opendaylight/adsal/forwardingrulesmanager/implementation/src/main/java/org/opendaylight/controller/forwardingrulesmanager/internal/ForwardingRulesManager.java b/opendaylight/adsal/forwardingrulesmanager/implementation/src/main/java/org/opendaylight/controller/forwardingrulesmanager/internal/ForwardingRulesManager.java
deleted file mode 100644 (file)
index 46008b2..0000000
+++ /dev/null
@@ -1,3273 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.forwardingrulesmanager.internal;
-
-import java.io.FileNotFoundException;
-import java.io.IOException;
-import java.io.ObjectInputStream;
-import java.util.ArrayList;
-import java.util.Collections;
-import java.util.EnumSet;
-import java.util.HashSet;
-import java.util.List;
-import java.util.Map;
-import java.util.Map.Entry;
-import java.util.Set;
-import java.util.concurrent.BlockingQueue;
-import java.util.concurrent.Callable;
-import java.util.concurrent.ConcurrentHashMap;
-import java.util.concurrent.ConcurrentMap;
-import java.util.concurrent.ExecutionException;
-import java.util.concurrent.ExecutorService;
-import java.util.concurrent.Executors;
-import java.util.concurrent.LinkedBlockingQueue;
-
-import org.opendaylight.controller.clustering.services.CacheConfigException;
-import org.opendaylight.controller.clustering.services.CacheExistException;
-import org.opendaylight.controller.clustering.services.ICacheUpdateAware;
-import org.opendaylight.controller.clustering.services.IClusterContainerServices;
-import org.opendaylight.controller.clustering.services.IClusterServices;
-import org.opendaylight.controller.configuration.ConfigurationObject;
-import org.opendaylight.controller.configuration.IConfigurationContainerAware;
-import org.opendaylight.controller.configuration.IConfigurationContainerService;
-import org.opendaylight.controller.connectionmanager.IConnectionManager;
-import org.opendaylight.controller.containermanager.IContainerManager;
-import org.opendaylight.controller.forwardingrulesmanager.FlowConfig;
-import org.opendaylight.controller.forwardingrulesmanager.FlowEntry;
-import org.opendaylight.controller.forwardingrulesmanager.FlowEntryInstall;
-import org.opendaylight.controller.forwardingrulesmanager.IForwardingRulesManager;
-import org.opendaylight.controller.forwardingrulesmanager.IForwardingRulesManagerAware;
-import org.opendaylight.controller.forwardingrulesmanager.PortGroup;
-import org.opendaylight.controller.forwardingrulesmanager.PortGroupChangeListener;
-import org.opendaylight.controller.forwardingrulesmanager.PortGroupConfig;
-import org.opendaylight.controller.forwardingrulesmanager.PortGroupProvider;
-import org.opendaylight.controller.forwardingrulesmanager.implementation.data.FlowEntryDistributionOrder;
-import org.opendaylight.controller.sal.action.Action;
-import org.opendaylight.controller.sal.action.ActionType;
-import org.opendaylight.controller.sal.action.Enqueue;
-import org.opendaylight.controller.sal.action.Flood;
-import org.opendaylight.controller.sal.action.FloodAll;
-import org.opendaylight.controller.sal.action.Output;
-import org.opendaylight.controller.sal.connection.ConnectionLocality;
-import org.opendaylight.controller.sal.core.Config;
-import org.opendaylight.controller.sal.core.ContainerFlow;
-import org.opendaylight.controller.sal.core.IContainer;
-import org.opendaylight.controller.sal.core.IContainerLocalListener;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.core.UpdateType;
-import org.opendaylight.controller.sal.flowprogrammer.Flow;
-import org.opendaylight.controller.sal.flowprogrammer.IFlowProgrammerListener;
-import org.opendaylight.controller.sal.flowprogrammer.IFlowProgrammerService;
-import org.opendaylight.controller.sal.match.Match;
-import org.opendaylight.controller.sal.match.MatchType;
-import org.opendaylight.controller.sal.utils.EtherTypes;
-import org.opendaylight.controller.sal.utils.GlobalConstants;
-import org.opendaylight.controller.sal.utils.IObjectReader;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.sal.utils.StatusCode;
-import org.opendaylight.controller.switchmanager.IInventoryListener;
-import org.opendaylight.controller.switchmanager.ISwitchManager;
-import org.opendaylight.controller.switchmanager.ISwitchManagerAware;
-import org.opendaylight.controller.switchmanager.Subnet;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * Class that manages forwarding rule installation and removal per container of
- * the network. It also maintains the central repository of all the forwarding
- * rules installed on the network nodes.
- */
-public class ForwardingRulesManager implements
-        IForwardingRulesManager,
-        PortGroupChangeListener,
-        IContainerLocalListener,
-        ISwitchManagerAware,
-        IConfigurationContainerAware,
-        IInventoryListener,
-        IObjectReader,
-        ICacheUpdateAware<Object,Object>,
-        IFlowProgrammerListener {
-
-    private static final Logger log = LoggerFactory.getLogger(ForwardingRulesManager.class);
-    private static final Logger logsync = LoggerFactory.getLogger("FRMsync");
-    private static final String PORT_REMOVED = "Port removed";
-    private static final String NODE_DOWN = "Node is Down";
-    private static final String INVALID_FLOW_ENTRY = "Invalid FlowEntry";
-    private static final String STATIC_FLOWS_FILE_NAME = "frm_staticflows.conf";
-    private static final String PORT_GROUP_FILE_NAME = "portgroup.conf";
-    private ConcurrentMap<Integer, FlowConfig> staticFlows;
-    private ConcurrentMap<Integer, Integer> staticFlowsOrdinal;
-    private ConcurrentMap<String, PortGroupConfig> portGroupConfigs;
-    private ConcurrentMap<PortGroupConfig, Map<Node, PortGroup>> portGroupData;
-    private ConcurrentMap<String, Object> TSPolicies;
-    private IContainerManager containerManager;
-    private IConfigurationContainerService configurationService;
-    private boolean inContainerMode; // being used by global instance only
-    protected boolean stopping;
-
-    /*
-     * Flow database. It's the software view of what was requested to install
-     * and what is installed on the switch. It is indexed by the entry itself.
-     * The entry's hashcode resumes the network node index, the flow's priority
-     * and the flow's match. The value element is a class which contains the
-     * flow entry pushed by the applications modules and the respective
-     * container flow merged version. In absence of container flows, the two
-     * flow entries are the same.
-     */
-    private ConcurrentMap<FlowEntry, FlowEntry> originalSwView;
-    private ConcurrentMap<FlowEntryInstall, FlowEntryInstall> installedSwView;
-    /*
-     * Per node and per group indexing
-     */
-    private ConcurrentMap<Node, List<FlowEntryInstall>> nodeFlows;
-    private ConcurrentMap<String, List<FlowEntryInstall>> groupFlows;
-
-    /*
-     * Inactive flow list. This is for the global instance of FRM It will
-     * contain all the flow entries which were installed on the global container
-     * when the first container is created.
-     */
-    private ConcurrentMap<FlowEntry, FlowEntry> inactiveFlows;
-
-    private IContainer container;
-    private Set<IForwardingRulesManagerAware> frmAware =
-        Collections.synchronizedSet(new HashSet<IForwardingRulesManagerAware>());
-    private PortGroupProvider portGroupProvider;
-    private IFlowProgrammerService programmer;
-    private IClusterContainerServices clusterContainerService = null;
-    private ISwitchManager switchManager;
-    private Thread frmEventHandler;
-    protected BlockingQueue<FRMEvent> pendingEvents;
-
-    // Distributes FRM programming in the cluster
-    private IConnectionManager connectionManager;
-
-    /*
-     * Name clustered caches used to support FRM entry distribution these are by
-     * necessity non-transactional as long as need to be able to synchronize
-     * states also while a transaction is in progress
-     */
-    static final String WORK_ORDER_CACHE = "frm.workOrder";
-    static final String WORK_STATUS_CACHE = "frm.workStatus";
-    static final String ORIGINAL_SW_VIEW_CACHE = "frm.originalSwView";
-    static final String INSTALLED_SW_VIEW_CACHE = "frm.installedSwView";
-
-    /*
-     * Data structure responsible for distributing the FlowEntryInstall requests
-     * in the cluster. The key value is entry that is being either Installed or
-     * Updated or Delete. The value field is the same of the key value in case
-     * of Installation or Deletion, it's the new entry in case of Modification,
-     * this because the clustering caches don't allow null values.
-     *
-     * The logic behind this data structure is that the controller that initiate
-     * the request will place the order here, someone will pick it and then will
-     * remove from this data structure because is being served.
-     *
-     * TODO: We need to have a way to cleanup this data structure if entries are
-     * not picked by anyone, which is always a case can happen especially on
-     * Node disconnect cases.
-     */
-    protected ConcurrentMap<FlowEntryDistributionOrder, FlowEntryInstall> workOrder;
-
-    /*
-     * Data structure responsible for retrieving the results of the workOrder
-     * submitted to the cluster.
-     *
-     * The logic behind this data structure is that the controller that has
-     * executed the order will then place the result in workStatus signaling
-     * that there was a success or a failure.
-     *
-     * TODO: The workStatus entries need to have a lifetime associated in case
-     * of requestor controller leaving the cluster.
-     */
-    protected ConcurrentMap<FlowEntryDistributionOrder, Status> workStatus;
-
-    /*
-     * Local Map used to hold the Future which a caller can use to monitor for
-     * completion
-     */
-    private ConcurrentMap<FlowEntryDistributionOrder, FlowEntryDistributionOrderFutureTask> workMonitor =
-            new ConcurrentHashMap<FlowEntryDistributionOrder, FlowEntryDistributionOrderFutureTask>();
-
-    /*
-     * Max pool size for the executor
-     */
-    private static final int maxPoolSize = 10;
-
-    /**
-     * @param e
-     *            Entry being installed/updated/removed
-     * @param u
-     *            New entry will be placed after the update operation. Valid
-     *            only for UpdateType.CHANGED, null for all the other cases
-     * @param t
-     *            Type of update
-     * @return a Future object for monitoring the progress of the result, or
-     *         null in case the processing should take place locally
-     */
-    private FlowEntryDistributionOrderFutureTask distributeWorkOrder(FlowEntryInstall e, FlowEntryInstall u,
-            UpdateType t) {
-        // A null entry it's an unexpected condition, anyway it's safe to keep
-        // the handling local
-        if (e == null) {
-            return null;
-        }
-
-        Node n = e.getNode();
-        if (connectionManager.getLocalityStatus(n) == ConnectionLocality.NOT_LOCAL) {
-            // Create the work order and distribute it
-            FlowEntryDistributionOrder fe =
-                    new FlowEntryDistributionOrder(e, t, clusterContainerService.getMyAddress());
-            // First create the monitor job
-            FlowEntryDistributionOrderFutureTask ret = new FlowEntryDistributionOrderFutureTask(fe);
-            logsync.trace("Node {} not local so sending fe {}", n, fe);
-            workMonitor.put(fe, ret);
-            if (t.equals(UpdateType.CHANGED)) {
-                // Then distribute the work
-                workOrder.put(fe, u);
-            } else {
-                // Then distribute the work
-                workOrder.put(fe, e);
-            }
-            logsync.trace("WorkOrder requested");
-            // Now create an Handle to monitor the execution of the operation
-            return ret;
-        }
-
-        logsync.trace("Node {} could be local. so processing Entry:{} UpdateType:{}", n, e, t);
-        return null;
-    }
-
-    /**
-     * Checks if the FlowEntry targets are valid for this container
-     *
-     * @param flowEntry
-     *            The flow entry to test
-     * @return a Status object representing the result of the validation
-     */
-    private Status validateEntry(FlowEntry flowEntry) {
-        // Node presence check
-        Node node = flowEntry.getNode();
-        if (!switchManager.getNodes().contains(node)) {
-            return new Status(StatusCode.BADREQUEST, String.format("Node %s is not present in this container", node));
-        }
-
-        // Ports and actions validation check
-        Flow flow = flowEntry.getFlow();
-        Match match = flow.getMatch();
-        if (match.isPresent(MatchType.IN_PORT)) {
-            NodeConnector inputPort = (NodeConnector)match.getField(MatchType.IN_PORT).getValue();
-            if (!switchManager.getNodeConnectors(node).contains(inputPort)) {
-                String msg = String.format("Ingress port %s is not present on this container", inputPort);
-                return new Status(StatusCode.BADREQUEST, msg);
-            }
-        }
-        for (Action action : flow.getActions()) {
-            if (action instanceof Flood && !GlobalConstants.DEFAULT.toString().equals(getContainerName())) {
-                return new Status(StatusCode.BADREQUEST, String.format("Flood is only allowed in default container"));
-            }
-            if (action instanceof FloodAll && !GlobalConstants.DEFAULT.toString().equals(getContainerName())) {
-                return new Status(StatusCode.BADREQUEST, String.format("FloodAll is only allowed in default container"));
-            }
-            if (action instanceof Output) {
-                Output out = (Output)action;
-                NodeConnector outputPort = out.getPort();
-                if (!switchManager.getNodeConnectors(node).contains(outputPort)) {
-                    String msg = String.format("Output port %s is not present on this container", outputPort);
-                    return new Status(StatusCode.BADREQUEST, msg);
-                }
-            }
-            if (action instanceof Enqueue) {
-                Enqueue out = (Enqueue)action;
-                NodeConnector outputPort = out.getPort();
-                if (!switchManager.getNodeConnectors(node).contains(outputPort)) {
-                    String msg = String.format("Enqueue port %s is not present on this container", outputPort);
-                    return new Status(StatusCode.BADREQUEST, msg);
-                }
-            }
-        }
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    /**
-     * Adds a flow entry onto the network node It runs various validity checks
-     * and derive the final container flows merged entries that will be
-     * attempted to be installed
-     *
-     * @param flowEntry
-     *            the original flow entry application requested to add
-     * @param async
-     *            the flag indicating if this is a asynchronous request
-     * @return the status of this request. In case of asynchronous call, it will
-     *         contain the unique id assigned to this request
-     */
-    private Status addEntry(FlowEntry flowEntry, boolean async) {
-
-        // Sanity Check
-        if (flowEntry == null || flowEntry.getNode() == null || flowEntry.getFlow() == null) {
-            String logMsg = INVALID_FLOW_ENTRY + ": {}";
-            log.warn(logMsg, flowEntry);
-            return new Status(StatusCode.NOTACCEPTABLE, INVALID_FLOW_ENTRY);
-        }
-
-        // Operational check: input, output and queue ports presence check and
-        // action validation for this container
-        Status status = validateEntry(flowEntry);
-        if (!status.isSuccess()) {
-            String msg = String.format("%s: %s", INVALID_FLOW_ENTRY, status.getDescription());
-            log.warn("{}: {}", msg, flowEntry);
-            return new Status(StatusCode.NOTACCEPTABLE, msg);
-        }
-
-        /*
-         * Redundant Check: Check if the request is a redundant one from the
-         * same application the flowEntry is equal to an existing one. Given we
-         * do not have an application signature in the requested FlowEntry yet,
-         * we are here detecting the above condition by comparing the flow
-         * names, if set. If they are equal to the installed flow, most likely
-         * this is a redundant installation request from the same application
-         * and we can silently return success
-         *
-         * TODO: in future a sort of application reference list mechanism will
-         * be added to the FlowEntry so that exact flow can be used by different
-         * applications.
-         */
-        FlowEntry present = this.originalSwView.get(flowEntry);
-        if (present != null) {
-            boolean sameFlow = present.getFlow().equals(flowEntry.getFlow());
-            boolean sameApp = present.getFlowName() != null && present.getFlowName().equals(flowEntry.getFlowName());
-            if (sameFlow && sameApp) {
-                log.trace("Skipping redundant request for flow {} on node {}", flowEntry.getFlowName(),
-                        flowEntry.getNode());
-                return new Status(StatusCode.SUCCESS, "Entry is already present");
-            }
-        }
-
-        /*
-         * Derive the container flow merged entries to install In presence of N
-         * container flows, we may end up with N different entries to install...
-         */
-        List<FlowEntryInstall> toInstallList = deriveInstallEntries(flowEntry.clone(), container.getContainerFlows());
-
-        // Container Flow conflict Check
-        if (toInstallList.isEmpty()) {
-            String msg = "Flow Entry conflicts with all Container Flows";
-            String logMsg = msg + ": {}";
-            log.warn(logMsg, flowEntry);
-            return new Status(StatusCode.CONFLICT, msg);
-        }
-
-        // Derive the list of entries good to be installed
-        List<FlowEntryInstall> toInstallSafe = new ArrayList<FlowEntryInstall>();
-        for (FlowEntryInstall entry : toInstallList) {
-            // Conflict Check: Verify new entry would not overwrite existing
-            // ones
-            if (this.installedSwView.containsKey(entry)) {
-                log.warn("Operation Rejected: A flow with same match and priority exists on the target node");
-                log.trace("Aborting to install {}", entry);
-                continue;
-            }
-            toInstallSafe.add(entry);
-        }
-
-        // Declare failure if all the container flow merged entries clash with
-        // existing entries
-        if (toInstallSafe.size() == 0) {
-            String msg = "A flow with same match and priority exists on the target node";
-            String logMsg = msg + ": {}";
-            log.warn(logMsg, flowEntry);
-            return new Status(StatusCode.CONFLICT, msg);
-        }
-
-        // Try to install an entry at the time
-        Status error = new Status(null, null);
-        Status succeded = null;
-        boolean oneSucceded = false;
-        for (FlowEntryInstall installEntry : toInstallSafe) {
-
-            // Install and update database
-            Status ret = addEntryInternal(installEntry, async);
-
-            if (ret.isSuccess()) {
-                oneSucceded = true;
-                /*
-                 * The first successful status response will be returned For the
-                 * asynchronous call, we can discard the container flow
-                 * complication for now and assume we will always deal with one
-                 * flow only per request
-                 */
-                succeded = ret;
-            } else {
-                error = ret;
-                log.trace("Failed to install the entry: {}. The failure is: {}", installEntry, ret.getDescription());
-            }
-        }
-
-        return (oneSucceded) ? succeded : error;
-    }
-
-    /**
-     * Given a flow entry and the list of container flows, it returns the list
-     * of container flow merged flow entries good to be installed on this
-     * container. If the list of container flows is null or empty, the install
-     * entry list will contain only one entry, the original flow entry. If the
-     * flow entry is congruent with all the N container flows, then the output
-     * install entry list will contain N entries. If the output list is empty,
-     * it means the passed flow entry conflicts with all the container flows.
-     *
-     * @param cFlowList
-     *            The list of container flows
-     * @return the list of container flow merged entries good to be installed on
-     *         this container
-     */
-    private List<FlowEntryInstall> deriveInstallEntries(FlowEntry request, List<ContainerFlow> cFlowList) {
-        List<FlowEntryInstall> toInstallList = new ArrayList<FlowEntryInstall>(1);
-
-        if (container.getContainerFlows() == null || container.getContainerFlows().isEmpty()) {
-            // No container flows => entry good to be installed unchanged
-            toInstallList.add(new FlowEntryInstall(request.clone(), null));
-        } else {
-            // Create the list of entries to be installed. If the flow entry is
-            // not congruent with any container flow, no install entries will be
-            // created
-            for (ContainerFlow cFlow : container.getContainerFlows()) {
-                if (cFlow.allowsFlow(request.getFlow())) {
-                    toInstallList.add(new FlowEntryInstall(request.clone(), cFlow));
-                }
-            }
-        }
-        return toInstallList;
-    }
-
-    /**
-     * Modify a flow entry with a new one It runs various validity check and
-     * derive the final container flows merged flow entries to work with
-     *
-     * @param currentFlowEntry
-     * @param newFlowEntry
-     * @param async
-     *            the flag indicating if this is a asynchronous request
-     * @return the status of this request. In case of asynchronous call, it will
-     *         contain the unique id assigned to this request
-     */
-    private Status modifyEntry(FlowEntry currentFlowEntry, FlowEntry newFlowEntry, boolean async) {
-        Status retExt;
-
-        // Sanity checks
-        if (currentFlowEntry == null || currentFlowEntry.getNode() == null || newFlowEntry == null
-                || newFlowEntry.getNode() == null || newFlowEntry.getFlow() == null) {
-            String msg = "Modify: " + INVALID_FLOW_ENTRY;
-            String logMsg = msg + ": {} or {}";
-            log.warn(logMsg, currentFlowEntry, newFlowEntry);
-            return new Status(StatusCode.NOTACCEPTABLE, msg);
-        }
-        if (!currentFlowEntry.getNode().equals(newFlowEntry.getNode())
-                || !currentFlowEntry.getFlowName().equals(newFlowEntry.getFlowName())) {
-            String msg = "Modify: Incompatible Flow Entries";
-            String logMsg = msg + ": {} and {}";
-            log.warn(logMsg, currentFlowEntry, newFlowEntry);
-            return new Status(StatusCode.NOTACCEPTABLE, msg);
-        }
-
-        // Equality Check
-        if (currentFlowEntry.getFlow().equals(newFlowEntry.getFlow())) {
-            String msg = "Modify skipped as flows are the same";
-            String logMsg = msg + ": {} and {}";
-            log.debug(logMsg, currentFlowEntry, newFlowEntry);
-            return new Status(StatusCode.SUCCESS, msg);
-        }
-
-        // Operational check: input, output and queue ports presence check and
-        // action validation for this container
-        Status status = validateEntry(newFlowEntry);
-        if (!status.isSuccess()) {
-            String msg = String.format("Modify: %s: %s", INVALID_FLOW_ENTRY, status.getDescription());
-            log.warn("{}: {}", msg, newFlowEntry);
-            return new Status(StatusCode.NOTACCEPTABLE, msg);
-        }
-
-        /*
-         * Conflict Check: Verify the new entry would not conflict with an
-         * existing one. This is a loose check on the previous original flow
-         * entry requests. No check on the container flow merged flow entries
-         * (if any) yet
-         */
-        FlowEntry sameMatchOriginalEntry = originalSwView.get(newFlowEntry);
-        if (sameMatchOriginalEntry != null && !sameMatchOriginalEntry.equals(currentFlowEntry)) {
-            String msg = "Operation Rejected: Another flow with same match and priority exists on the target node";
-            String logMsg = msg + ": {}";
-            log.warn(logMsg, currentFlowEntry);
-            return new Status(StatusCode.CONFLICT, msg);
-        }
-
-        // Derive the installed and toInstall entries
-        List<FlowEntryInstall> installedList = deriveInstallEntries(currentFlowEntry.clone(),
-                container.getContainerFlows());
-        List<FlowEntryInstall> toInstallList = deriveInstallEntries(newFlowEntry.clone(), container.getContainerFlows());
-
-        if (toInstallList.isEmpty()) {
-            String msg = "Modify Operation Rejected: The new entry conflicts with all the container flows";
-            String logMsg = msg + ": {}";
-            log.warn(logMsg, newFlowEntry);
-            log.warn(msg);
-            return new Status(StatusCode.CONFLICT, msg);
-        }
-
-        /*
-         * If the two list sizes differ, it means the new flow entry does not
-         * satisfy the same number of container flows the current entry does.
-         * This is only possible when the new entry and current entry have
-         * different match. In this scenario the modification would ultimately
-         * be handled as a remove and add operations in the protocol plugin.
-         *
-         * Also, if any of the new flow entries would clash with an existing
-         * one, we cannot proceed with the modify operation, because it would
-         * fail for some entries and leave stale entries on the network node.
-         * Modify path can be taken only if it can be performed completely, for
-         * all entries.
-         *
-         * So, for the above two cases, to simplify, let's decouple the modify
-         * in: 1) remove current entries 2) install new entries
-         */
-        Status succeeded = null;
-        boolean decouple = false;
-        if (installedList.size() != toInstallList.size()) {
-            log.trace("Modify: New flow entry does not satisfy the same "
-                    + "number of container flows as the original entry does");
-            decouple = true;
-        }
-        List<FlowEntryInstall> toInstallSafe = new ArrayList<FlowEntryInstall>();
-        for (FlowEntryInstall installEntry : toInstallList) {
-            /*
-             * Conflict Check: Verify the new entry would not overwrite another
-             * existing one
-             */
-            FlowEntryInstall sameMatchEntry = installedSwView.get(installEntry);
-            if (sameMatchEntry != null && !sameMatchEntry.getOriginal().equals(currentFlowEntry)) {
-                log.trace("Modify: new container flow merged flow entry clashes with existing flow");
-                decouple = true;
-            } else {
-                toInstallSafe.add(installEntry);
-            }
-        }
-
-        if (decouple) {
-            // Remove current entries
-            for (FlowEntryInstall currEntry : installedList) {
-                this.removeEntryInternal(currEntry, async);
-            }
-            // Install new entries
-            for (FlowEntryInstall newEntry : toInstallSafe) {
-                succeeded = this.addEntryInternal(newEntry, async);
-            }
-        } else {
-            /*
-             * The two list have the same size and the entries to install do not
-             * clash with any existing flow on the network node. We assume here
-             * (and might be wrong) that the same container flows that were
-             * satisfied by the current entries are the same that are satisfied
-             * by the new entries. Let's take the risk for now.
-             *
-             * Note: modification has to be complete. If any entry modification
-             * fails, we need to stop, restore the already modified entries, and
-             * declare failure.
-             */
-            Status retModify = null;
-            int i = 0;
-            int size = toInstallList.size();
-            while (i < size) {
-                // Modify and update database
-                retModify = modifyEntryInternal(installedList.get(i), toInstallList.get(i), async);
-                if (retModify.isSuccess()) {
-                    i++;
-                } else {
-                    break;
-                }
-            }
-            // Check if uncompleted modify
-            if (i < size) {
-                log.warn("Unable to perform a complete modify for all  the container flows merged entries");
-                // Restore original entries
-                int j = 0;
-                while (j < i) {
-                    log.info("Attempting to restore initial entries");
-                    retExt = modifyEntryInternal(toInstallList.get(i), installedList.get(i), async);
-                    if (retExt.isSuccess()) {
-                        j++;
-                    } else {
-                        break;
-                    }
-                }
-                // Fatal error, recovery failed
-                if (j < i) {
-                    String msg = "Flow recovery failed ! Unrecoverable Error";
-                    log.error(msg);
-                    return new Status(StatusCode.INTERNALERROR, msg);
-                }
-            }
-            succeeded = retModify;
-        }
-        /*
-         * The first successful status response will be returned. For the
-         * asynchronous call, we can discard the container flow complication for
-         * now and assume we will always deal with one flow only per request
-         */
-        return succeeded;
-    }
-
-    /**
-     * This is the function that modifies the final container flows merged
-     * entries on the network node and update the database. It expects that all
-     * the validity checks are passed.
-     * This function is supposed to be called only on the controller on which
-     * the IFRM call is executed.
-     *
-     * @param currentEntries
-     * @param newEntries
-     * @param async
-     *            the flag indicating if this is a asynchronous request
-     * @return the status of this request. In case of asynchronous call, it will
-     *         contain the unique id assigned to this request
-     */
-    private Status modifyEntryInternal(FlowEntryInstall currentEntries, FlowEntryInstall newEntries, boolean async) {
-        Status status = new Status(StatusCode.UNDEFINED);
-        FlowEntryDistributionOrderFutureTask futureStatus =
-                distributeWorkOrder(currentEntries, newEntries, UpdateType.CHANGED);
-        if (futureStatus != null) {
-            try {
-                status = futureStatus.get();
-                if (status.getCode()
-                        .equals(StatusCode.TIMEOUT)) {
-                    // A timeout happened, lets cleanup the workMonitor
-                    workMonitor.remove(futureStatus.getOrder());
-                }
-            } catch (InterruptedException e) {
-                log.error("", e);
-            } catch (ExecutionException e) {
-                log.error("", e);
-            }
-        } else {
-            // Modify the flow on the network node
-            status = modifyEntryInHw(currentEntries, newEntries, async);
-        }
-
-        if (!status.isSuccess()) {
-            log.trace("{} SDN Plugin failed to program the flow: {}. The failure is: {}",
-                    (futureStatus != null) ? "Remote" : "Local", newEntries.getInstall(), status.getDescription());
-            return status;
-        }
-
-        log.trace("Modified {} => {}", currentEntries.getInstall(), newEntries.getInstall());
-
-        // Update DB
-        newEntries.setRequestId(status.getRequestId());
-        updateSwViews(currentEntries, false);
-        updateSwViews(newEntries, true);
-
-        return status;
-    }
-
-    private Status modifyEntryInHw(FlowEntryInstall currentEntries, FlowEntryInstall newEntries, boolean async) {
-        return async ? programmer.modifyFlowAsync(currentEntries.getNode(), currentEntries.getInstall().getFlow(),
-                newEntries.getInstall().getFlow()) : programmer.modifyFlow(currentEntries.getNode(), currentEntries
-                .getInstall().getFlow(), newEntries.getInstall().getFlow());
-    }
-
-    /**
-     * Remove a flow entry. If the entry is not present in the software view
-     * (entry or node not present), it return successfully
-     *
-     * @param flowEntry
-     *            the flow entry to remove
-     * @param async
-     *            the flag indicating if this is a asynchronous request
-     * @return the status of this request. In case of asynchronous call, it will
-     *         contain the unique id assigned to this request
-     */
-    private Status removeEntry(FlowEntry flowEntry, boolean async) {
-        Status error = new Status(null, null);
-
-        // Sanity Check
-        if (flowEntry == null || flowEntry.getNode() == null || flowEntry.getFlow() == null) {
-            String logMsg = INVALID_FLOW_ENTRY + ": {}";
-            log.warn(logMsg, flowEntry);
-            return new Status(StatusCode.NOTACCEPTABLE, INVALID_FLOW_ENTRY);
-        }
-
-        // Derive the container flows merged installed entries
-        List<FlowEntryInstall> installedList = deriveInstallEntries(flowEntry.clone(), container.getContainerFlows());
-
-        Status succeeded = null;
-        boolean atLeastOneRemoved = false;
-        for (FlowEntryInstall entry : installedList) {
-            if (!installedSwView.containsKey(entry)) {
-                String logMsg = "Removal skipped (not present in software view) for flow entry: {}";
-                log.debug(logMsg, flowEntry);
-                if (installedList.size() == 1) {
-                    // If we had only one entry to remove, we are done
-                    return new Status(StatusCode.SUCCESS);
-                } else {
-                    continue;
-                }
-            }
-
-            // Remove and update DB
-            Status ret = removeEntryInternal(entry, async);
-
-            if (!ret.isSuccess()) {
-                error = ret;
-                log.trace("Failed to remove the entry: {}. The failure is: {}", entry.getInstall(), ret.getDescription());
-                if (installedList.size() == 1) {
-                    // If we had only one entry to remove, this is fatal failure
-                    return error;
-                }
-            } else {
-                succeeded = ret;
-                atLeastOneRemoved = true;
-            }
-        }
-
-        /*
-         * No worries if full removal failed. Consistency checker will take care
-         * of removing the stale entries later, or adjusting the software
-         * database if not in sync with hardware
-         */
-        return (atLeastOneRemoved) ? succeeded : error;
-    }
-
-    /**
-     * This is the function that removes the final container flows merged entry
-     * from the network node and update the database. It expects that all the
-     * validity checks are passed
-     * This function is supposed to be called only on the controller on which
-     * the IFRM call is executed.
-     *
-     * @param entry
-     *            the flow entry to remove
-     * @param async
-     *            the flag indicating if this is a asynchronous request
-     * @return the status of this request. In case of asynchronous call, it will
-     *         contain the unique id assigned to this request
-     */
-    private Status removeEntryInternal(FlowEntryInstall entry, boolean async) {
-        Status status = new Status(StatusCode.UNDEFINED);
-        FlowEntryDistributionOrderFutureTask futureStatus = distributeWorkOrder(entry, null, UpdateType.REMOVED);
-        if (futureStatus != null) {
-            try {
-                status = futureStatus.get();
-                if (status.getCode().equals(StatusCode.TIMEOUT)) {
-                    // A timeout happened, lets cleanup the workMonitor
-                    workMonitor.remove(futureStatus.getOrder());
-                }
-            } catch (InterruptedException e) {
-                log.error("", e);
-            } catch (ExecutionException e) {
-                log.error("", e);
-            }
-        } else {
-            // Mark the entry to be deleted (for CC just in case we fail)
-            entry.toBeDeleted();
-
-            // Remove from node
-            status = removeEntryInHw(entry, async);
-        }
-
-        if (!status.isSuccess()) {
-            log.trace("{} SDN Plugin failed to remove the flow: {}. The failure is: {}",
-                    (futureStatus != null) ? "Remote" : "Local", entry.getInstall(), status.getDescription());
-            return status;
-        }
-
-        log.trace("Removed  {}", entry.getInstall());
-
-        // Update DB
-        updateSwViews(entry, false);
-
-        return status;
-    }
-
-    private Status removeEntryInHw(FlowEntryInstall entry, boolean async) {
-        return async ? programmer.removeFlowAsync(entry.getNode(), entry.getInstall().getFlow()) : programmer
-                .removeFlow(entry.getNode(), entry.getInstall().getFlow());
-    }
-
-    /**
-     * This is the function that installs the final container flow merged entry
-     * on the network node and updates the database. It expects that all the
-     * validity and conflict checks are passed. That means it does not check
-     * whether this flow would conflict or overwrite an existing one.
-     * This function is supposed to be called only on the controller on which
-     * the IFRM call is executed.
-     *
-     * @param entry
-     *            the flow entry to install
-     * @param async
-     *            the flag indicating if this is a asynchronous request
-     * @return the status of this request. In case of asynchronous call, it will
-     *         contain the unique id assigned to this request
-     */
-    private Status addEntryInternal(FlowEntryInstall entry, boolean async) {
-        Status status = new Status(StatusCode.UNDEFINED);
-        FlowEntryDistributionOrderFutureTask futureStatus = distributeWorkOrder(entry, null, UpdateType.ADDED);
-        if (futureStatus != null) {
-            try {
-                status = futureStatus.get();
-                if (status.getCode().equals(StatusCode.TIMEOUT)) {
-                    // A timeout happened, lets cleanup the workMonitor
-                    workMonitor.remove(futureStatus.getOrder());
-                }
-            } catch (InterruptedException e) {
-                log.error("", e);
-            } catch (ExecutionException e) {
-                log.error("", e);
-            }
-        } else {
-            status = addEntryInHw(entry, async);
-        }
-
-        if (!status.isSuccess()) {
-            log.trace("{} SDN Plugin failed to program the flow: {}. The failure is: {}",
-                    (futureStatus != null) ? "Remote" : "Local", entry.getInstall(), status.getDescription());
-            return status;
-        }
-
-        log.trace("Added    {}", entry.getInstall());
-
-        // Update DB
-        entry.setRequestId(status.getRequestId());
-        updateSwViews(entry, true);
-
-        return status;
-    }
-
-    private Status addEntryInHw(FlowEntryInstall entry, boolean async) {
-        // Install the flow on the network node
-        return async ? programmer.addFlowAsync(entry.getNode(), entry.getInstall().getFlow()) : programmer.addFlow(
-                entry.getNode(), entry.getInstall().getFlow());
-    }
-
-    /**
-     * Returns true if the flow conflicts with all the container's flows. This
-     * means that if the function returns true, the passed flow entry is
-     * congruent with at least one container flow, hence it is good to be
-     * installed on this container.
-     *
-     * @param flowEntry
-     * @return true if flow conflicts with all the container flows, false
-     *         otherwise
-     */
-    private boolean entryConflictsWithContainerFlows(FlowEntry flowEntry) {
-        List<ContainerFlow> cFlowList = container.getContainerFlows();
-
-        // Validity check and avoid unnecessary computation
-        // Also takes care of default container where no container flows are
-        // present
-        if (cFlowList == null || cFlowList.isEmpty()) {
-            return false;
-        }
-
-        for (ContainerFlow cFlow : cFlowList) {
-            if (cFlow.allowsFlow(flowEntry.getFlow())) {
-                // Entry is allowed by at least one container flow: good to go
-                return false;
-            }
-        }
-        return true;
-    }
-
-    private ConcurrentMap.Entry<Integer, FlowConfig> getStaticFlowEntry(String name, Node node) {
-        for (ConcurrentMap.Entry<Integer, FlowConfig> flowEntry : staticFlows.entrySet()) {
-            FlowConfig flowConfig = flowEntry.getValue();
-            if (flowConfig.isByNameAndNodeIdEqual(name, node)) {
-                return flowEntry;
-            }
-        }
-        return null;
-    }
-
-    private void updateIndexDatabase(FlowEntryInstall entry, boolean add) {
-        // Update node indexed flow database
-        updateNodeFlowsDB(entry, add);
-
-        // Update group indexed flow database
-        updateGroupFlowsDB(entry, add);
-    }
-
-    /*
-     * Update the node mapped flows database
-     */
-    private void updateSwViews(FlowEntryInstall flowEntries, boolean add) {
-        if (add) {
-            originalSwView.put(flowEntries.getOriginal(), flowEntries.getOriginal());
-            installedSwView.put(flowEntries, flowEntries);
-        } else {
-            originalSwView.remove(flowEntries.getOriginal());
-            installedSwView.remove(flowEntries);
-        }
-    }
-
-    /*
-     * Update the node mapped flows database
-     */
-    private void updateNodeFlowsDB(FlowEntryInstall flowEntries, boolean add) {
-        Node node = flowEntries.getNode();
-
-        List<FlowEntryInstall> nodeIndeces = this.nodeFlows.get(node);
-        if (nodeIndeces == null) {
-            if (!add) {
-                return;
-            } else {
-                nodeIndeces = new ArrayList<FlowEntryInstall>();
-            }
-        }
-
-        if (add) {
-            // there may be an already existing entry.
-            // remove it before adding the new one.
-            // This is necessary since we have observed that in some cases
-            // Infinispan does aggregation for operations (eg:- remove and then put a different value)
-            // related to the same key within the same transaction.
-            // Need this defensive code as the new FlowEntryInstall may be different
-            // than the old one even though the equals method returns true. This is because
-            // the equals method does not take into account the action list.
-            if(nodeIndeces.contains(flowEntries)) {
-                nodeIndeces.remove(flowEntries);
-            }
-            nodeIndeces.add(flowEntries);
-        } else {
-            nodeIndeces.remove(flowEntries);
-        }
-
-        // Update cache across cluster
-        if (nodeIndeces.isEmpty()) {
-            this.nodeFlows.remove(node);
-        } else {
-            this.nodeFlows.put(node, nodeIndeces);
-        }
-    }
-
-    /*
-     * Update the group name mapped flows database
-     */
-    private void updateGroupFlowsDB(FlowEntryInstall flowEntries, boolean add) {
-        String groupName = flowEntries.getGroupName();
-
-        // Flow may not be part of a group
-        if (groupName == null) {
-            return;
-        }
-
-        List<FlowEntryInstall> indices = this.groupFlows.get(groupName);
-        if (indices == null) {
-            if (!add) {
-                return;
-            } else {
-                indices = new ArrayList<FlowEntryInstall>();
-            }
-        }
-
-        if (add) {
-            // same comments in the similar code section in
-            // updateNodeFlowsDB method apply here too
-            if(indices.contains(flowEntries)) {
-                indices.remove(flowEntries);
-            }
-            indices.add(flowEntries);
-        } else {
-            indices.remove(flowEntries);
-        }
-
-        // Update cache across cluster
-        if (indices.isEmpty()) {
-            this.groupFlows.remove(groupName);
-        } else {
-            this.groupFlows.put(groupName, indices);
-        }
-    }
-
-    /**
-     * Remove a flow entry that has been added previously First checks if the
-     * entry is effectively present in the local database
-     */
-    @SuppressWarnings("unused")
-    private Status removeEntry(Node node, String flowName) {
-        FlowEntryInstall target = null;
-
-        // Find in database
-        for (FlowEntryInstall entry : installedSwView.values()) {
-            if (entry.equalsByNodeAndName(node, flowName)) {
-                target = entry;
-                break;
-            }
-        }
-
-        // If it is not there, stop any further processing
-        if (target == null) {
-            return new Status(StatusCode.SUCCESS, "Entry is not present");
-        }
-
-        // Remove from node
-        Status status = programmer.removeFlow(target.getNode(), target.getInstall().getFlow());
-
-        // Update DB
-        if (status.isSuccess()) {
-            updateSwViews(target, false);
-        } else {
-            // log the error
-            log.trace("SDN Plugin failed to remove the flow: {}. The failure is: {}", target.getInstall(),
-                    status.getDescription());
-        }
-
-        return status;
-    }
-
-    @Override
-    public Status installFlowEntry(FlowEntry flowEntry) {
-        Status status;
-        if (isContainerModeAllowed(flowEntry)) {
-            status = addEntry(flowEntry, false);
-        } else {
-            String msg = "Controller in container mode: Install Refused";
-            String logMsg = msg + ": {}";
-            status = new Status(StatusCode.NOTACCEPTABLE, msg);
-            log.warn(logMsg, flowEntry);
-        }
-        return status;
-    }
-
-    @Override
-    public Status installFlowEntryAsync(FlowEntry flowEntry) {
-        Status status;
-        if (isContainerModeAllowed(flowEntry)) {
-            status = addEntry(flowEntry, true);
-        } else {
-            String msg = "Controller in container mode: Install Refused";
-            status = new Status(StatusCode.NOTACCEPTABLE, msg);
-            log.warn(msg);
-        }
-        return status;
-    }
-
-    @Override
-    public Status uninstallFlowEntry(FlowEntry flowEntry) {
-        Status status;
-        if (isContainerModeAllowed(flowEntry)) {
-            status = removeEntry(flowEntry, false);
-        } else {
-            String msg = "Controller in container mode: Uninstall Refused";
-            String logMsg = msg + ": {}";
-            status = new Status(StatusCode.NOTACCEPTABLE, msg);
-            log.warn(logMsg, flowEntry);
-        }
-        return status;
-    }
-
-    @Override
-    public Status uninstallFlowEntryAsync(FlowEntry flowEntry) {
-        Status status;
-        if (isContainerModeAllowed(flowEntry)) {
-            status = removeEntry(flowEntry, true);
-        } else {
-            String msg = "Controller in container mode: Uninstall Refused";
-            status = new Status(StatusCode.NOTACCEPTABLE, msg);
-            log.warn(msg);
-        }
-        return status;
-    }
-
-    @Override
-    public Status modifyFlowEntry(FlowEntry currentFlowEntry, FlowEntry newFlowEntry) {
-        Status status = null;
-        if (isContainerModeAllowed(currentFlowEntry)) {
-            status = modifyEntry(currentFlowEntry, newFlowEntry, false);
-        } else {
-            String msg = "Controller in container mode: Modify Refused";
-            String logMsg = msg + ": {}";
-            status = new Status(StatusCode.NOTACCEPTABLE, msg);
-            log.warn(logMsg, newFlowEntry);
-        }
-        return status;
-    }
-
-    @Override
-    public Status modifyFlowEntryAsync(FlowEntry currentFlowEntry, FlowEntry newFlowEntry) {
-        Status status = null;
-        if (isContainerModeAllowed(currentFlowEntry)) {
-            status = modifyEntry(currentFlowEntry, newFlowEntry, true);
-        } else {
-            String msg = "Controller in container mode: Modify Refused";
-            status = new Status(StatusCode.NOTACCEPTABLE, msg);
-            log.warn(msg);
-        }
-        return status;
-    }
-
-    /**
-     * Returns whether the specified flow entry is allowed to be
-     * installed/removed/modified based on the current container mode status.
-     * This call always returns true in the container instance of forwarding
-     * rules manager. It is meant for the global instance only (default
-     * container) of forwarding rules manager. Idea is that for assuring
-     * container isolation of traffic, flow installation in default container is
-     * blocked when in container mode (containers are present). The only flows
-     * that are allowed in container mode in the default container are the
-     * proactive flows, the ones automatically installed on the network node
-     * which forwarding mode has been configured to "proactive". These flows are
-     * needed by controller to discover the nodes topology and to discover the
-     * attached hosts for some SDN switches.
-     *
-     * @param flowEntry
-     *            The flow entry to be installed/removed/modified
-     * @return true if not in container mode or if flowEntry is internally
-     *         generated
-     */
-    private boolean isContainerModeAllowed(FlowEntry flowEntry) {
-        return (!inContainerMode) ? true : flowEntry.isInternal();
-    }
-
-    @Override
-    public Status modifyOrAddFlowEntry(FlowEntry newFlowEntry) {
-        /*
-         * Run a check on the original entries to decide whether to go with a
-         * add or modify method. A loose check means only check against the
-         * original flow entry requests and not against the installed flow
-         * entries which are the result of the original entry merged with the
-         * container flow(s) (if any). The modifyFlowEntry method in presence of
-         * conflicts with the Container flows (if any) would revert back to a
-         * delete + add pattern
-         */
-        FlowEntry currentFlowEntry = originalSwView.get(newFlowEntry);
-
-        if (currentFlowEntry != null) {
-            return modifyFlowEntry(currentFlowEntry, newFlowEntry);
-        } else {
-            return installFlowEntry(newFlowEntry);
-        }
-    }
-
-    @Override
-    public Status modifyOrAddFlowEntryAsync(FlowEntry newFlowEntry) {
-        /*
-         * Run a check on the original entries to decide whether to go with a
-         * add or modify method. A loose check means only check against the
-         * original flow entry requests and not against the installed flow
-         * entries which are the result of the original entry merged with the
-         * container flow(s) (if any). The modifyFlowEntry method in presence of
-         * conflicts with the Container flows (if any) would revert back to a
-         * delete + add pattern
-         */
-        FlowEntry currentFlowEntry = originalSwView.get(newFlowEntry);
-
-        if (currentFlowEntry != null) {
-            return modifyFlowEntryAsync(currentFlowEntry, newFlowEntry);
-        } else {
-            return installFlowEntryAsync(newFlowEntry);
-        }
-    }
-
-    @Override
-    public Status uninstallFlowEntryGroup(String groupName) {
-        if (groupName == null || groupName.isEmpty()) {
-            return new Status(StatusCode.BADREQUEST, "Invalid group name");
-        }
-        if (groupName.equals(FlowConfig.INTERNALSTATICFLOWGROUP)) {
-            return new Status(StatusCode.BADREQUEST, "Internal static flows group cannot be deleted through this api");
-        }
-        if (inContainerMode) {
-            String msg = "Controller in container mode: Group Uninstall Refused";
-            String logMsg = msg + ": {}";
-            log.warn(logMsg, groupName);
-            return new Status(StatusCode.NOTACCEPTABLE, msg);
-        }
-        int toBeRemoved = 0;
-        String error = "";
-        if (groupFlows.containsKey(groupName)) {
-            List<FlowEntryInstall> list = new ArrayList<FlowEntryInstall>(groupFlows.get(groupName));
-            toBeRemoved = list.size();
-            for (FlowEntryInstall entry : list) {
-                // since this is the entry that was stored in groupFlows
-                // it is already validated and merged
-                // so can call removeEntryInternal directly
-                Status status = this.removeEntryInternal(entry, false);
-                if (status.isSuccess()) {
-                    toBeRemoved -= 1;
-                } else {
-                    error = status.getDescription();
-                }
-            }
-        }
-        return (toBeRemoved == 0) ? new Status(StatusCode.SUCCESS) : new Status(StatusCode.INTERNALERROR,
-                "Not all the flows were removed: " + error);
-    }
-
-    @Override
-    public Status uninstallFlowEntryGroupAsync(String groupName) {
-        if (groupName == null || groupName.isEmpty()) {
-            return new Status(StatusCode.BADREQUEST, "Invalid group name");
-        }
-        if (groupName.equals(FlowConfig.INTERNALSTATICFLOWGROUP)) {
-            return new Status(StatusCode.BADREQUEST, "Static flows group cannot be deleted through this api");
-        }
-        if (inContainerMode) {
-            String msg = "Controller in container mode: Group Uninstall Refused";
-            String logMsg = msg + ": {}";
-            log.warn(logMsg, groupName);
-            return new Status(StatusCode.NOTACCEPTABLE, msg);
-        }
-        if (groupFlows.containsKey(groupName)) {
-            List<FlowEntryInstall> list = new ArrayList<FlowEntryInstall>(groupFlows.get(groupName));
-            for (FlowEntryInstall entry : list) {
-                this.removeEntry(entry.getOriginal(), true);
-            }
-        }
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    @Override
-    public boolean checkFlowEntryConflict(FlowEntry flowEntry) {
-        return entryConflictsWithContainerFlows(flowEntry);
-    }
-
-    /**
-     * Updates all installed flows because the container flow got updated This
-     * is obtained in two phases on per node basis: 1) Uninstall of all flows 2)
-     * Reinstall of all flows This is needed because a new container flows
-     * merged flow may conflict with an existing old container flows merged flow
-     * on the network node
-     */
-    protected void updateFlowsContainerFlow() {
-        Set<FlowEntry> toReInstall = new HashSet<FlowEntry>();
-        // First remove all installed entries
-        for (ConcurrentMap.Entry<FlowEntryInstall, FlowEntryInstall> entry : installedSwView.entrySet()) {
-            FlowEntryInstall current = entry.getValue();
-            // Store the original entry
-            toReInstall.add(current.getOriginal());
-            // Remove the old couples. No validity checks to be run, use the
-            // internal remove
-            this.removeEntryInternal(current, false);
-        }
-        // Then reinstall the original entries
-        for (FlowEntry entry : toReInstall) {
-            // Reinstall the original flow entries, via the regular path: new
-            // cFlow merge + validations
-            this.installFlowEntry(entry);
-        }
-    }
-
-    private void nonClusterObjectCreate() {
-        originalSwView = new ConcurrentHashMap<FlowEntry, FlowEntry>();
-        installedSwView = new ConcurrentHashMap<FlowEntryInstall, FlowEntryInstall>();
-        TSPolicies = new ConcurrentHashMap<String, Object>();
-        staticFlowsOrdinal = new ConcurrentHashMap<Integer, Integer>();
-        portGroupConfigs = new ConcurrentHashMap<String, PortGroupConfig>();
-        portGroupData = new ConcurrentHashMap<PortGroupConfig, Map<Node, PortGroup>>();
-        staticFlows = new ConcurrentHashMap<Integer, FlowConfig>();
-        inactiveFlows = new ConcurrentHashMap<FlowEntry, FlowEntry>();
-    }
-
-    @Override
-    public void setTSPolicyData(String policyname, Object o, boolean add) {
-
-        if (add) {
-            /* Check if this policy already exists */
-            if (!(TSPolicies.containsKey(policyname))) {
-                TSPolicies.put(policyname, o);
-            }
-        } else {
-            TSPolicies.remove(policyname);
-        }
-        if (frmAware != null) {
-            synchronized (frmAware) {
-                for (IForwardingRulesManagerAware frma : frmAware) {
-                    try {
-                        frma.policyUpdate(policyname, add);
-                    } catch (Exception e) {
-                        log.warn("Exception on callback", e);
-                    }
-                }
-            }
-        }
-    }
-
-    @Override
-    public Map<String, Object> getTSPolicyData() {
-        return TSPolicies;
-    }
-
-    @Override
-    public Object getTSPolicyData(String policyName) {
-        if (TSPolicies.containsKey(policyName)) {
-            return TSPolicies.get(policyName);
-        } else {
-            return null;
-        }
-    }
-
-    @Override
-    public List<FlowEntry> getFlowEntriesForGroup(String policyName) {
-        List<FlowEntry> list = new ArrayList<FlowEntry>();
-        if (policyName != null && !policyName.trim().isEmpty()) {
-            for (Map.Entry<FlowEntry, FlowEntry> entry : this.originalSwView.entrySet()) {
-                if (policyName.equals(entry.getKey().getGroupName())) {
-                    list.add(entry.getValue().clone());
-                }
-            }
-        }
-        return list;
-    }
-
-    @Override
-    public List<FlowEntry> getInstalledFlowEntriesForGroup(String policyName) {
-        List<FlowEntry> list = new ArrayList<FlowEntry>();
-        if (policyName != null && !policyName.trim().isEmpty()) {
-            for (Map.Entry<FlowEntryInstall, FlowEntryInstall> entry : this.installedSwView.entrySet()) {
-                if (policyName.equals(entry.getKey().getGroupName())) {
-                    list.add(entry.getValue().getInstall().clone());
-                }
-            }
-        }
-        return list;
-    }
-
-    @Override
-    public void addOutputPort(Node node, String flowName, List<NodeConnector> portList) {
-
-        for (FlowEntryInstall flow : this.nodeFlows.get(node)) {
-            if (flow.getFlowName().equals(flowName)) {
-                FlowEntry currentFlowEntry = flow.getOriginal();
-                FlowEntry newFlowEntry = currentFlowEntry.clone();
-                for (NodeConnector dstPort : portList) {
-                    newFlowEntry.getFlow().addAction(new Output(dstPort));
-                }
-                Status error = modifyEntry(currentFlowEntry, newFlowEntry, false);
-                if (error.isSuccess()) {
-                    log.trace("Ports {} added to FlowEntry {}", portList, flowName);
-                } else {
-                    log.warn("Failed to add ports {} to Flow entry {}. The failure is: {}", portList,
-                            currentFlowEntry.toString(), error.getDescription());
-                }
-                return;
-            }
-        }
-        log.warn("Failed to add ports to Flow {} on Node {}: Entry Not Found", flowName, node);
-    }
-
-    @Override
-    public void removeOutputPort(Node node, String flowName, List<NodeConnector> portList) {
-        for (FlowEntryInstall index : this.nodeFlows.get(node)) {
-            FlowEntryInstall flow = this.installedSwView.get(index);
-            if (flow.getFlowName().equals(flowName)) {
-                FlowEntry currentFlowEntry = flow.getOriginal();
-                FlowEntry newFlowEntry = currentFlowEntry.clone();
-                for (NodeConnector dstPort : portList) {
-                    Action action = new Output(dstPort);
-                    newFlowEntry.getFlow().removeAction(action);
-                }
-                Status status = modifyEntry(currentFlowEntry, newFlowEntry, false);
-                if (status.isSuccess()) {
-                    log.trace("Ports {} removed from FlowEntry {}", portList, flowName);
-                } else {
-                    log.warn("Failed to remove ports {} from Flow entry {}. The failure is: {}", portList,
-                            currentFlowEntry.toString(), status.getDescription());
-                }
-                return;
-            }
-        }
-        log.warn("Failed to remove ports from Flow {} on Node {}: Entry Not Found", flowName, node);
-    }
-
-    /*
-     * This function assumes the target flow has only one output port
-     */
-    @Override
-    public void replaceOutputPort(Node node, String flowName, NodeConnector outPort) {
-        FlowEntry currentFlowEntry = null;
-        FlowEntry newFlowEntry = null;
-
-        // Find the flow
-        for (FlowEntryInstall index : this.nodeFlows.get(node)) {
-            FlowEntryInstall flow = this.installedSwView.get(index);
-            if (flow.getFlowName().equals(flowName)) {
-                currentFlowEntry = flow.getOriginal();
-                break;
-            }
-        }
-        if (currentFlowEntry == null) {
-            log.warn("Failed to replace output port for flow {} on node {}: Entry Not Found", flowName, node);
-            return;
-        }
-
-        // Create a flow copy with the new output port
-        newFlowEntry = currentFlowEntry.clone();
-        Action target = null;
-        for (Action action : newFlowEntry.getFlow().getActions()) {
-            if (action.getType() == ActionType.OUTPUT) {
-                target = action;
-                break;
-            }
-        }
-        newFlowEntry.getFlow().removeAction(target);
-        newFlowEntry.getFlow().addAction(new Output(outPort));
-
-        // Modify on network node
-        Status status = modifyEntry(currentFlowEntry, newFlowEntry, false);
-
-        if (status.isSuccess()) {
-            log.trace("Output port replaced with {} for flow {} on node {}", outPort, flowName, node);
-        } else {
-            log.warn("Failed to replace output port for flow {} on node {}. The failure is: {}", flowName, node,
-                    status.getDescription());
-        }
-        return;
-    }
-
-    @Override
-    public NodeConnector getOutputPort(Node node, String flowName) {
-        for (FlowEntryInstall index : this.nodeFlows.get(node)) {
-            FlowEntryInstall flow = this.installedSwView.get(index);
-            if (flow.getFlowName().equals(flowName)) {
-                for (Action action : flow.getOriginal().getFlow().getActions()) {
-                    if (action.getType() == ActionType.OUTPUT) {
-                        return ((Output) action).getPort();
-                    }
-                }
-            }
-        }
-        return null;
-    }
-
-    private void cacheStartup() {
-        allocateCaches();
-        retrieveCaches();
-    }
-
-    private void allocateCaches() {
-        if (this.clusterContainerService == null) {
-            log.warn("Un-initialized clusterContainerService, can't create cache");
-            return;
-        }
-
-        log.debug("Allocating caches for Container {}", container.getName());
-
-        try {
-            clusterContainerService.createCache(ORIGINAL_SW_VIEW_CACHE,
-                    EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-
-            clusterContainerService.createCache(INSTALLED_SW_VIEW_CACHE,
-                    EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-
-            clusterContainerService.createCache("frm.inactiveFlows",
-                    EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-
-            clusterContainerService.createCache("frm.staticFlows",
-                    EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-
-            clusterContainerService.createCache("frm.staticFlowsOrdinal",
-                    EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-
-            clusterContainerService.createCache("frm.portGroupConfigs",
-                    EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-
-            clusterContainerService.createCache("frm.portGroupData",
-                    EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-
-            clusterContainerService.createCache("frm.TSPolicies",
-                    EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-
-            clusterContainerService.createCache(WORK_STATUS_CACHE,
-                    EnumSet.of(IClusterServices.cacheMode.NON_TRANSACTIONAL, IClusterServices.cacheMode.ASYNC));
-
-            clusterContainerService.createCache(WORK_ORDER_CACHE,
-                    EnumSet.of(IClusterServices.cacheMode.NON_TRANSACTIONAL, IClusterServices.cacheMode.ASYNC));
-
-        } catch (CacheConfigException cce) {
-            log.error("CacheConfigException");
-        } catch (CacheExistException cce) {
-            log.error("CacheExistException");
-        }
-    }
-
-    @SuppressWarnings({ "unchecked" })
-    private void retrieveCaches() {
-        ConcurrentMap<?, ?> map;
-
-        if (this.clusterContainerService == null) {
-            log.warn("un-initialized clusterContainerService, can't retrieve cache");
-            nonClusterObjectCreate();
-            return;
-        }
-
-        log.debug("Retrieving Caches for Container {}", container.getName());
-
-        map = clusterContainerService.getCache(ORIGINAL_SW_VIEW_CACHE);
-        if (map != null) {
-            originalSwView = (ConcurrentMap<FlowEntry, FlowEntry>) map;
-        } else {
-            log.error("Retrieval of frm.originalSwView cache failed for Container {}", container.getName());
-        }
-
-        map = clusterContainerService.getCache(INSTALLED_SW_VIEW_CACHE);
-        if (map != null) {
-            installedSwView = (ConcurrentMap<FlowEntryInstall, FlowEntryInstall>) map;
-        } else {
-            log.error("Retrieval of frm.installedSwView cache failed for Container {}", container.getName());
-        }
-
-        map = clusterContainerService.getCache("frm.inactiveFlows");
-        if (map != null) {
-            inactiveFlows = (ConcurrentMap<FlowEntry, FlowEntry>) map;
-        } else {
-            log.error("Retrieval of frm.inactiveFlows cache failed for Container {}", container.getName());
-        }
-
-        map = clusterContainerService.getCache("frm.staticFlows");
-        if (map != null) {
-            staticFlows = (ConcurrentMap<Integer, FlowConfig>) map;
-        } else {
-            log.error("Retrieval of frm.staticFlows cache failed for Container {}", container.getName());
-        }
-
-        map = clusterContainerService.getCache("frm.staticFlowsOrdinal");
-        if (map != null) {
-            staticFlowsOrdinal = (ConcurrentMap<Integer, Integer>) map;
-        } else {
-            log.error("Retrieval of frm.staticFlowsOrdinal cache failed for Container {}", container.getName());
-        }
-
-        map = clusterContainerService.getCache("frm.portGroupConfigs");
-        if (map != null) {
-            portGroupConfigs = (ConcurrentMap<String, PortGroupConfig>) map;
-        } else {
-            log.error("Retrieval of frm.portGroupConfigs cache failed for Container {}", container.getName());
-        }
-
-        map = clusterContainerService.getCache("frm.portGroupData");
-        if (map != null) {
-            portGroupData = (ConcurrentMap<PortGroupConfig, Map<Node, PortGroup>>) map;
-        } else {
-            log.error("Retrieval of frm.portGroupData allocation failed for Container {}", container.getName());
-        }
-
-        map = clusterContainerService.getCache("frm.TSPolicies");
-        if (map != null) {
-            TSPolicies = (ConcurrentMap<String, Object>) map;
-        } else {
-            log.error("Retrieval of frm.TSPolicies cache failed for Container {}", container.getName());
-        }
-
-        map = clusterContainerService.getCache(WORK_ORDER_CACHE);
-        if (map != null) {
-            workOrder = (ConcurrentMap<FlowEntryDistributionOrder, FlowEntryInstall>) map;
-        } else {
-            log.error("Retrieval of " + WORK_ORDER_CACHE + " cache failed for Container {}", container.getName());
-        }
-
-        map = clusterContainerService.getCache(WORK_STATUS_CACHE);
-        if (map != null) {
-            workStatus = (ConcurrentMap<FlowEntryDistributionOrder, Status>) map;
-        } else {
-            log.error("Retrieval of " + WORK_STATUS_CACHE + " cache failed for Container {}", container.getName());
-        }
-    }
-
-    private boolean flowConfigExists(FlowConfig config) {
-        // Flow name has to be unique on per node id basis
-        for (ConcurrentMap.Entry<Integer, FlowConfig> entry : staticFlows.entrySet()) {
-            if (entry.getValue().isByNameAndNodeIdEqual(config)) {
-                return true;
-            }
-        }
-        return false;
-    }
-
-    @Override
-    public Status addStaticFlow(FlowConfig config) {
-        return addStaticFlow(config, false);
-    }
-
-    private Status addStaticFlow(FlowConfig config, boolean async) {
-        // Configuration object validation
-        Status status = config.validate();
-        if (!status.isSuccess()) {
-            log.warn("Invalid Configuration for flow {}. The failure is {}", config, status.getDescription());
-            String error = "Invalid Configuration (" + status.getDescription() + ")";
-            config.setStatus(error);
-            return new Status(StatusCode.BADREQUEST, error);
-        }
-        return addStaticFlowInternal(config, async, false);
-    }
-
-
-    @Override
-    public Status addStaticFlowAsync(FlowConfig config) {
-        return addStaticFlow(config, true);
-    }
-
-    /**
-     * Private method to add a static flow configuration which does not run any
-     * validation on the passed FlowConfig object. If restore is set to true,
-     * configuration is stored in configuration database regardless the
-     * installation on the network node was successful. This is useful at boot
-     * when static flows are present in startup configuration and are read
-     * before the switches connects.
-     *
-     * @param config
-     *            The static flow configuration
-     * @param restore
-     *            if true, the configuration is stored regardless the
-     *            installation on the network node was successful
-     * @return The status of this request
-     */
-    private Status addStaticFlowInternal(FlowConfig config, boolean async, boolean restore) {
-        boolean multipleFlowPush = false;
-        String error;
-        Status status;
-        config.setStatus(StatusCode.SUCCESS.toString());
-
-        // Presence check
-        if (flowConfigExists(config)) {
-            error = "Entry with this name on specified switch already exists";
-            log.warn("Entry with this name on specified switch already exists: {}", config);
-            config.setStatus(error);
-            return new Status(StatusCode.CONFLICT, error);
-        }
-
-        if ((config.getIngressPort() == null) && config.getPortGroup() != null) {
-            for (String portGroupName : portGroupConfigs.keySet()) {
-                if (portGroupName.equalsIgnoreCase(config.getPortGroup())) {
-                    multipleFlowPush = true;
-                    break;
-                }
-            }
-            if (!multipleFlowPush) {
-                log.warn("Invalid Configuration(Invalid PortGroup Name) for flow {}", config);
-                error = "Invalid Configuration (Invalid PortGroup Name)";
-                config.setStatus(error);
-                return new Status(StatusCode.BADREQUEST, error);
-            }
-        }
-
-        /*
-         * If requested program the entry in hardware first before updating the
-         * StaticFlow DB
-         */
-        if (!multipleFlowPush) {
-            // Program hw
-            if (config.installInHw()) {
-                FlowEntry entry = config.getFlowEntry();
-                status = async ? this.installFlowEntryAsync(entry) : this.installFlowEntry(entry);
-                if (!status.isSuccess()) {
-                    config.setStatus(status.getDescription());
-                    if (!restore) {
-                        return status;
-                    }
-                }
-            }
-        }
-
-        /*
-         * When the control reaches this point, either of the following
-         * conditions is true 1. This is a single entry configuration (non
-         * PortGroup) and the hardware installation is successful 2. This is a
-         * multiple entry configuration (PortGroup) and hardware installation is
-         * NOT done directly on this event. 3. The User prefers to retain the
-         * configuration in Controller and skip hardware installation.
-         *
-         * Hence it is safe to update the StaticFlow DB at this point.
-         *
-         * Note : For the case of PortGrouping, it is essential to have this DB
-         * populated before the PortGroupListeners can query for the DB
-         * triggered using portGroupChanged event...
-         */
-        Integer ordinal = staticFlowsOrdinal.get(0);
-        staticFlowsOrdinal.put(0, ++ordinal);
-        staticFlows.put(ordinal, config);
-
-        if (multipleFlowPush) {
-            PortGroupConfig pgconfig = portGroupConfigs.get(config.getPortGroup());
-            Map<Node, PortGroup> existingData = portGroupData.get(pgconfig);
-            if (existingData != null) {
-                portGroupChanged(pgconfig, existingData, true);
-            }
-        }
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    private void addStaticFlowsToSwitch(Node node) {
-        for (ConcurrentMap.Entry<Integer, FlowConfig> entry : staticFlows.entrySet()) {
-            FlowConfig config = entry.getValue();
-            if (config.isPortGroupEnabled()) {
-                continue;
-            }
-            if (config.getNode().equals(node)) {
-                if (config.installInHw() && !config.getStatus().equals(StatusCode.SUCCESS.toString())) {
-                    Status status = this.installFlowEntryAsync(config.getFlowEntry());
-                    config.setStatus(status.getDescription());
-                }
-            }
-        }
-        // Update cluster cache
-        refreshClusterStaticFlowsStatus(node);
-    }
-
-    private void updateStaticFlowConfigsOnNodeDown(Node node) {
-        log.trace("Updating Static Flow configs on node down: {}", node);
-
-        List<Integer> toRemove = new ArrayList<Integer>();
-        for (Entry<Integer, FlowConfig> entry : staticFlows.entrySet()) {
-
-            FlowConfig config = entry.getValue();
-
-            if (config.isPortGroupEnabled()) {
-                continue;
-            }
-
-            if (config.installInHw() && config.getNode().equals(node)) {
-                if (config.isInternalFlow()) {
-                    // Take note of this controller generated static flow
-                    toRemove.add(entry.getKey());
-                } else {
-                    config.setStatus(NODE_DOWN);
-                }
-            }
-        }
-        // Remove controller generated static flows for this node
-        for (Integer index : toRemove) {
-            staticFlows.remove(index);
-        }
-        // Update cluster cache
-        refreshClusterStaticFlowsStatus(node);
-
-    }
-
-    private void updateStaticFlowConfigsOnContainerModeChange(UpdateType update) {
-        log.trace("Updating Static Flow configs on container mode change: {}", update);
-
-        for (ConcurrentMap.Entry<Integer, FlowConfig> entry : staticFlows.entrySet()) {
-            FlowConfig config = entry.getValue();
-            if (config.isPortGroupEnabled()) {
-                continue;
-            }
-            if (config.installInHw() && !config.isInternalFlow()) {
-                switch (update) {
-                case ADDED:
-                    config.setStatus("Removed from node because in container mode");
-                    break;
-                case REMOVED:
-                    config.setStatus(StatusCode.SUCCESS.toString());
-                    break;
-                default:
-                    break;
-                }
-            }
-        }
-        // Update cluster cache
-        refreshClusterStaticFlowsStatus(null);
-    }
-
-    @Override
-    public Status removeStaticFlow(FlowConfig config) {
-        return removeStaticFlow(config, false);
-    }
-
-    @Override
-    public Status removeStaticFlowAsync(FlowConfig config) {
-        return removeStaticFlow(config, true);
-    }
-
-    private Status removeStaticFlow(FlowConfig config, boolean async) {
-        /*
-         * No config.isInternal() check as NB does not take this path and GUI
-         * cannot issue a delete on an internal generated flow. We need this
-         * path to be accessible when switch mode is changed from proactive to
-         * reactive, so that we can remove the internal generated LLDP and ARP
-         * punt flows
-         */
-
-        // Look for the target configuration entry
-        Integer key = 0;
-        FlowConfig target = null;
-        for (ConcurrentMap.Entry<Integer, FlowConfig> entry : staticFlows.entrySet()) {
-            if (entry.getValue().isByNameAndNodeIdEqual(config)) {
-                key = entry.getKey();
-                target = entry.getValue();
-                break;
-            }
-        }
-        if (target == null) {
-            return new Status(StatusCode.NOTFOUND, "Entry Not Present");
-        }
-
-        // Program the network node
-        Status status = async ? this.uninstallFlowEntryAsync(config.getFlowEntry()) : this.uninstallFlowEntry(config
-                .getFlowEntry());
-
-        // Update configuration database if programming was successful
-        if (status.isSuccess()) {
-            staticFlows.remove(key);
-        }
-
-        return status;
-    }
-
-    @Override
-    public Status removeStaticFlow(String name, Node node) {
-       return removeStaticFlow(name, node, false);
-    }
-
-    @Override
-    public Status removeStaticFlowAsync(String name, Node node) {
-        return removeStaticFlow(name, node, true);
-    }
-
-    private Status removeStaticFlow(String name, Node node, boolean async) {
-        // Look for the target configuration entry
-        Integer key = 0;
-        FlowConfig target = null;
-        for (ConcurrentMap.Entry<Integer, FlowConfig> mapEntry : staticFlows.entrySet()) {
-            if (mapEntry.getValue().isByNameAndNodeIdEqual(name, node)) {
-                key = mapEntry.getKey();
-                target = mapEntry.getValue();
-                break;
-            }
-        }
-        if (target == null) {
-            return new Status(StatusCode.NOTFOUND, "Entry Not Present");
-        }
-
-        // Validity check for api3 entry point
-        if (target.isInternalFlow()) {
-            String msg = "Invalid operation: Controller generated flow cannot be deleted";
-            String logMsg = msg + ": {}";
-            log.warn(logMsg, name);
-            return new Status(StatusCode.NOTACCEPTABLE, msg);
-        }
-
-        if (target.isPortGroupEnabled()) {
-            String msg = "Invalid operation: Port Group flows cannot be deleted through this API";
-            String logMsg = msg + ": {}";
-            log.warn(logMsg, name);
-            return new Status(StatusCode.NOTACCEPTABLE, msg);
-        }
-
-        // Program the network node
-        Status status = this.removeEntry(target.getFlowEntry(), async);
-
-        // Update configuration database if programming was successful
-        if (status.isSuccess()) {
-            staticFlows.remove(key);
-        }
-
-        return status;
-    }
-
-    @Override
-    public Status modifyStaticFlow(FlowConfig newFlowConfig) {
-        // Validity check for api3 entry point
-        if (newFlowConfig.isInternalFlow()) {
-            String msg = "Invalid operation: Controller generated flow cannot be modified";
-            String logMsg = msg + ": {}";
-            log.warn(logMsg, newFlowConfig);
-            return new Status(StatusCode.NOTACCEPTABLE, msg);
-        }
-
-        // Validity Check
-        Status status = newFlowConfig.validate();
-        if (!status.isSuccess()) {
-            String msg = "Invalid Configuration (" + status.getDescription() + ")";
-            newFlowConfig.setStatus(msg);
-            log.warn("Invalid Configuration for flow {}. The failure is {}", newFlowConfig, status.getDescription());
-            return new Status(StatusCode.BADREQUEST, msg);
-        }
-
-        FlowConfig oldFlowConfig = null;
-        Integer index = null;
-        for (ConcurrentMap.Entry<Integer, FlowConfig> mapEntry : staticFlows.entrySet()) {
-            FlowConfig entry = mapEntry.getValue();
-            if (entry.isByNameAndNodeIdEqual(newFlowConfig.getName(), newFlowConfig.getNode())) {
-                oldFlowConfig = entry;
-                index = mapEntry.getKey();
-                break;
-            }
-        }
-
-        if (oldFlowConfig == null) {
-            String msg = "Attempt to modify a non existing static flow";
-            String logMsg = msg + ": {}";
-            log.warn(logMsg, newFlowConfig);
-            return new Status(StatusCode.NOTFOUND, msg);
-        }
-
-        // Do not attempt to reinstall the flow, warn user
-        if (newFlowConfig.equals(oldFlowConfig)) {
-            String msg = "No modification detected";
-            log.trace("Static flow modification skipped. New flow and old flow are the same: {}", newFlowConfig);
-            return new Status(StatusCode.SUCCESS, msg);
-        }
-
-        // If flow is installed, program the network node
-        status = new Status(StatusCode.SUCCESS, "Saved in config");
-        if (oldFlowConfig.installInHw()) {
-            status = this.modifyFlowEntry(oldFlowConfig.getFlowEntry(), newFlowConfig.getFlowEntry());
-        }
-
-        // Update configuration database if programming was successful
-        if (status.isSuccess()) {
-            newFlowConfig.setStatus(status.getDescription());
-            staticFlows.put(index, newFlowConfig);
-        }
-
-        return status;
-    }
-
-    @Override
-    public Status toggleStaticFlowStatus(String name, Node node) {
-        return toggleStaticFlowStatus(getStaticFlow(name, node));
-    }
-
-    @Override
-    public Status toggleStaticFlowStatus(FlowConfig config) {
-        if (config == null) {
-            String msg = "Invalid request: null flow config";
-            log.warn(msg);
-            return new Status(StatusCode.BADREQUEST, msg);
-        }
-        // Validity check for api3 entry point
-        if (config.isInternalFlow()) {
-            String msg = "Invalid operation: Controller generated flow cannot be modified";
-            String logMsg = msg + ": {}";
-            log.warn(logMsg, config);
-            return new Status(StatusCode.NOTACCEPTABLE, msg);
-        }
-
-        // Find the config entry
-        Integer key = 0;
-        FlowConfig target = null;
-        for (Map.Entry<Integer, FlowConfig> entry : staticFlows.entrySet()) {
-            FlowConfig conf = entry.getValue();
-            if (conf.isByNameAndNodeIdEqual(config)) {
-                key = entry.getKey();
-                target = conf;
-                break;
-            }
-        }
-        if (target != null) {
-            Status status = target.validate();
-            if (!status.isSuccess()) {
-                log.warn(status.getDescription());
-                return status;
-            }
-            status = (target.installInHw()) ? this.uninstallFlowEntry(target.getFlowEntry()) : this
-                                    .installFlowEntry(target.getFlowEntry());
-            if (status.isSuccess()) {
-                // Update Configuration database
-                target.setStatus(StatusCode.SUCCESS.toString());
-                target.toggleInstallation();
-                staticFlows.put(key, target);
-            }
-            return status;
-        }
-
-        return new Status(StatusCode.NOTFOUND, "Unable to locate the entry. Failed to toggle status");
-    }
-
-    /**
-     * Reinsert all static flows entries in the cache to force cache updates in
-     * the cluster. This is useful when only some parameters were changed in the
-     * entries, like the status.
-     *
-     * @param node
-     *            The node for which the static flow configurations have to be
-     *            refreshed. If null, all nodes static flows will be refreshed.
-     */
-    private void refreshClusterStaticFlowsStatus(Node node) {
-        // Refresh cluster cache
-        for (ConcurrentMap.Entry<Integer, FlowConfig> entry : staticFlows.entrySet()) {
-            if (node == null || entry.getValue().getNode().equals(node)) {
-                staticFlows.put(entry.getKey(), entry.getValue());
-            }
-        }
-    }
-
-    /**
-     * Uninstall all the non-internal Flow Entries present in the software view.
-     * If requested, a copy of each original flow entry will be stored in the
-     * inactive list so that it can be re-applied when needed (This is typically
-     * the case when running in the default container and controller moved to
-     * container mode) NOTE WELL: The routine as long as does a bulk change will
-     * operate only on the entries for nodes locally attached so to avoid
-     * redundant operations initiated by multiple nodes
-     *
-     * @param preserveFlowEntries
-     *            if true, a copy of each original entry is stored in the
-     *            inactive list
-     */
-    private void uninstallAllFlowEntries(boolean preserveFlowEntries) {
-        log.trace("Uninstalling all non-internal flows");
-
-        List<FlowEntryInstall> toRemove = new ArrayList<FlowEntryInstall>();
-
-        // Store entries / create target list
-        for (ConcurrentMap.Entry<FlowEntryInstall, FlowEntryInstall> mapEntry : installedSwView.entrySet()) {
-            FlowEntryInstall flowEntries = mapEntry.getValue();
-            // Skip internal generated static flows
-            if (!flowEntries.isInternal()) {
-                toRemove.add(flowEntries);
-                // Store the original entries if requested
-                if (preserveFlowEntries) {
-                    inactiveFlows.put(flowEntries.getOriginal(), flowEntries.getOriginal());
-                }
-            }
-        }
-
-        // Now remove the entries
-        for (FlowEntryInstall flowEntryHw : toRemove) {
-            Node n = flowEntryHw.getNode();
-            if (n != null && connectionManager.getLocalityStatus(n) == ConnectionLocality.LOCAL) {
-                Status status = this.removeEntryInternal(flowEntryHw, false);
-                if (!status.isSuccess()) {
-                    log.trace("Failed to remove entry: {}. The failure is: {}", flowEntryHw, status.getDescription());
-                }
-            } else {
-                log.debug("Not removing entry {} because not connected locally, the remote guy will do it's job",
-                        flowEntryHw);
-            }
-        }
-    }
-
-    /**
-     * Re-install all the Flow Entries present in the inactive list The inactive
-     * list will be empty at the end of this call This function is called on the
-     * default container instance of FRM only when the last container is deleted
-     */
-    private void reinstallAllFlowEntries() {
-        log.trace("Reinstalling all inactive flows");
-
-        for (FlowEntry flowEntry : this.inactiveFlows.keySet()) {
-            this.addEntry(flowEntry, false);
-        }
-
-        // Empty inactive list in any case
-        inactiveFlows.clear();
-    }
-
-    @Override
-    public List<FlowConfig> getStaticFlows() {
-        return new ArrayList<FlowConfig>(staticFlows.values());
-    }
-
-    @Override
-    public FlowConfig getStaticFlow(String name, Node node) {
-        ConcurrentMap.Entry<Integer, FlowConfig> entry = getStaticFlowEntry(name, node);
-        if(entry != null) {
-            return entry.getValue();
-        }
-        return null;
-    }
-
-    @Override
-    public List<FlowConfig> getStaticFlows(Node node) {
-        List<FlowConfig> list = new ArrayList<FlowConfig>();
-        for (ConcurrentMap.Entry<Integer, FlowConfig> entry : staticFlows.entrySet()) {
-            if (entry.getValue().onNode(node)) {
-                list.add(entry.getValue());
-            }
-        }
-        return list;
-    }
-
-    @Override
-    public List<String> getStaticFlowNamesForNode(Node node) {
-        List<String> list = new ArrayList<String>();
-        for (ConcurrentMap.Entry<Integer, FlowConfig> entry : staticFlows.entrySet()) {
-            if (entry.getValue().onNode(node)) {
-                list.add(entry.getValue().getName());
-            }
-        }
-        return list;
-    }
-
-    @Override
-    public List<Node> getListNodeWithConfiguredFlows() {
-        Set<Node> set = new HashSet<Node>();
-        for (ConcurrentMap.Entry<Integer, FlowConfig> entry : staticFlows.entrySet()) {
-            set.add(entry.getValue().getNode());
-        }
-        return new ArrayList<Node>(set);
-    }
-
-    private void loadFlowConfiguration() {
-        for (ConfigurationObject conf : configurationService.retrieveConfiguration(this, PORT_GROUP_FILE_NAME)) {
-            addPortGroupConfig(((PortGroupConfig) conf).getName(), ((PortGroupConfig) conf).getMatchString(), true);
-        }
-
-        for (ConfigurationObject conf : configurationService.retrieveConfiguration(this, STATIC_FLOWS_FILE_NAME)) {
-            addStaticFlowInternal((FlowConfig) conf, false, true);
-        }
-    }
-
-    @Override
-    public Object readObject(ObjectInputStream ois) throws FileNotFoundException, IOException, ClassNotFoundException {
-        return ois.readObject();
-    }
-
-    @Override
-    public Status saveConfig() {
-        return saveConfigInternal();
-    }
-
-    private Status saveConfigInternal() {
-        List<ConfigurationObject> nonDynamicFlows = new ArrayList<ConfigurationObject>();
-
-        for (Integer ordinal : staticFlows.keySet()) {
-            FlowConfig config = staticFlows.get(ordinal);
-            // Do not save dynamic and controller generated static flows
-            if (config.isDynamic() || config.isInternalFlow()) {
-                continue;
-            }
-            nonDynamicFlows.add(config);
-        }
-
-        configurationService.persistConfiguration(nonDynamicFlows, STATIC_FLOWS_FILE_NAME);
-        configurationService.persistConfiguration(new ArrayList<ConfigurationObject>(portGroupConfigs.values()),
-                PORT_GROUP_FILE_NAME);
-
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    @Override
-    public void subnetNotify(Subnet sub, boolean add) {
-    }
-
-    private boolean programInternalFlow(boolean proactive, FlowConfig fc) {
-        boolean retVal = true; // program flows unless determined otherwise
-        if(proactive) {
-            // if the flow already exists do not program
-            if(flowConfigExists(fc)) {
-                retVal = false;
-            }
-        } else {
-            // if the flow does not exist do not program
-            if(!flowConfigExists(fc)) {
-                retVal = false;
-            }
-        }
-        return retVal;
-    }
-
-    /**
-     * (non-Javadoc)
-     *
-     * @see org.opendaylight.controller.switchmanager.ISwitchManagerAware#modeChangeNotify(org.opendaylight.controller.sal.core.Node,
-     *      boolean)
-     *
-     *      This method can be called from within the OSGi framework context,
-     *      given the programming operation can take sometime, it not good
-     *      pratice to have in it's context operations that can take time,
-     *      hence moving off to a different thread for async processing.
-     */
-    private ExecutorService executor;
-    @Override
-    public void modeChangeNotify(final Node node, final boolean proactive) {
-        Callable<Status> modeChangeCallable = new Callable<Status>() {
-            @Override
-            public Status call() throws Exception {
-                List<FlowConfig> defaultConfigs = new ArrayList<FlowConfig>();
-
-                List<String> puntAction = new ArrayList<String>();
-                puntAction.add(ActionType.CONTROLLER.toString());
-
-                FlowConfig allowARP = new FlowConfig();
-                allowARP.setInstallInHw(true);
-                allowARP.setName(FlowConfig.INTERNALSTATICFLOWBEGIN + "Punt ARP" + FlowConfig.INTERNALSTATICFLOWEND);
-                allowARP.setPriority("1");
-                allowARP.setNode(node);
-                allowARP.setEtherType("0x" + Integer.toHexString(EtherTypes.ARP.intValue())
-                        .toUpperCase());
-                allowARP.setActions(puntAction);
-                defaultConfigs.add(allowARP);
-
-                FlowConfig allowLLDP = new FlowConfig();
-                allowLLDP.setInstallInHw(true);
-                allowLLDP.setName(FlowConfig.INTERNALSTATICFLOWBEGIN + "Punt LLDP" + FlowConfig.INTERNALSTATICFLOWEND);
-                allowLLDP.setPriority("1");
-                allowLLDP.setNode(node);
-                allowLLDP.setEtherType("0x" + Integer.toHexString(EtherTypes.LLDP.intValue())
-                        .toUpperCase());
-                allowLLDP.setActions(puntAction);
-                defaultConfigs.add(allowLLDP);
-
-                List<String> dropAction = new ArrayList<String>();
-                dropAction.add(ActionType.DROP.toString());
-
-                FlowConfig dropAllConfig = new FlowConfig();
-                dropAllConfig.setInstallInHw(true);
-                dropAllConfig.setName(FlowConfig.INTERNALSTATICFLOWBEGIN + "Catch-All Drop"
-                        + FlowConfig.INTERNALSTATICFLOWEND);
-                dropAllConfig.setPriority("0");
-                dropAllConfig.setNode(node);
-                dropAllConfig.setActions(dropAction);
-                defaultConfigs.add(dropAllConfig);
-
-                log.trace("Forwarding mode for node {} set to {}", node, (proactive ? "proactive" : "reactive"));
-                for (FlowConfig fc : defaultConfigs) {
-                    // check if the frm really needs to act on the notification.
-                    // this is to check against duplicate notifications
-                    if(programInternalFlow(proactive, fc)) {
-                        Status status = (proactive) ? addStaticFlowInternal(fc, false, false) : removeStaticFlow(fc);
-                        if (status.isSuccess()) {
-                            log.trace("{} Proactive Static flow: {}", (proactive ? "Installed" : "Removed"), fc.getName());
-                        } else {
-                            log.warn("Failed to {} Proactive Static flow: {}", (proactive ? "install" : "remove"),
-                                    fc.getName());
-                        }
-                    } else {
-                        log.debug("Got redundant install request for internal flow: {} on node: {}. Request not sent to FRM.", fc.getName(), node);
-                    }
-                }
-                return new Status(StatusCode.SUCCESS);
-            }
-        };
-
-        /*
-         * Execute the work outside the caller context, this could be an
-         * expensive operation and we don't want to block the caller for it.
-         */
-        this.executor.submit(modeChangeCallable);
-    }
-
-    /**
-     * Remove from the databases all the flows installed on the node
-     *
-     * @param node
-     */
-    private void cleanDatabaseForNode(Node node) {
-        log.trace("Cleaning Flow database for Node {}", node);
-        if (nodeFlows.containsKey(node)) {
-            List<FlowEntryInstall> toRemove = new ArrayList<FlowEntryInstall>(nodeFlows.get(node));
-
-            for (FlowEntryInstall entry : toRemove) {
-                updateSwViews(entry, false);
-            }
-        }
-    }
-
-    private boolean doesFlowContainNodeConnector(Flow flow, NodeConnector nc) {
-        if (nc == null) {
-            return false;
-        }
-
-        Match match = flow.getMatch();
-        if (match.isPresent(MatchType.IN_PORT)) {
-            NodeConnector matchPort = (NodeConnector) match.getField(MatchType.IN_PORT).getValue();
-            if (matchPort.equals(nc)) {
-                return true;
-            }
-        }
-        List<Action> actionsList = flow.getActions();
-        if (actionsList != null) {
-            for (Action action : actionsList) {
-                if (action instanceof Output) {
-                    NodeConnector actionPort = ((Output) action).getPort();
-                    if (actionPort.equals(nc)) {
-                        return true;
-                    }
-                }
-            }
-        }
-        return false;
-    }
-
-    @Override
-    public void notifyNode(Node node, UpdateType type, Map<String, Property> propMap) {
-        this.pendingEvents.offer(new NodeUpdateEvent(type, node));
-    }
-
-    @Override
-    public void notifyNodeConnector(NodeConnector nodeConnector, UpdateType type, Map<String, Property> propMap) {
-        boolean updateStaticFlowCluster = false;
-
-        switch (type) {
-        case ADDED:
-            break;
-        case CHANGED:
-            Config config = (propMap == null) ? null : (Config) propMap.get(Config.ConfigPropName);
-            if (config != null) {
-                switch (config.getValue()) {
-                case Config.ADMIN_DOWN:
-                    log.trace("Port {} is administratively down: uninstalling interested flows", nodeConnector);
-                    updateStaticFlowCluster = removeFlowsOnNodeConnectorDown(nodeConnector);
-                    break;
-                case Config.ADMIN_UP:
-                    log.trace("Port {} is administratively up: installing interested flows", nodeConnector);
-                    updateStaticFlowCluster = installFlowsOnNodeConnectorUp(nodeConnector);
-                    break;
-                case Config.ADMIN_UNDEF:
-                    break;
-                default:
-                }
-            }
-            break;
-        case REMOVED:
-            // This is the case where a switch port is removed from the SDN agent space
-            log.trace("Port {} was removed from our control: uninstalling interested flows", nodeConnector);
-            updateStaticFlowCluster = removeFlowsOnNodeConnectorDown(nodeConnector);
-            break;
-        default:
-
-        }
-
-        if (updateStaticFlowCluster) {
-            refreshClusterStaticFlowsStatus(nodeConnector.getNode());
-        }
-    }
-
-    /*
-     * It goes through the static flows configuration, it identifies the ones
-     * which have the specified node connector as input or output port and
-     * install them on the network node if they are marked to be installed in
-     * hardware and their status shows they were not installed yet
-     */
-    private boolean installFlowsOnNodeConnectorUp(NodeConnector nodeConnector) {
-        boolean updated = false;
-        List<FlowConfig> flowConfigForNode = getStaticFlows(nodeConnector.getNode());
-        for (FlowConfig flowConfig : flowConfigForNode) {
-            if (doesFlowContainNodeConnector(flowConfig.getFlow(), nodeConnector)) {
-                if (flowConfig.installInHw() && !flowConfig.getStatus().equals(StatusCode.SUCCESS.toString())) {
-                    Status status = this.installFlowEntryAsync(flowConfig.getFlowEntry());
-                    if (!status.isSuccess()) {
-                        flowConfig.setStatus(status.getDescription());
-                    } else {
-                        flowConfig.setStatus(StatusCode.SUCCESS.toString());
-                    }
-                    updated = true;
-                }
-            }
-        }
-        return updated;
-    }
-
-    /*
-     * Remove from the network node all the flows which have the specified node
-     * connector as input or output port. If any of the flow entry is a static
-     * flow, it updates the correspondent configuration.
-     */
-    private boolean removeFlowsOnNodeConnectorDown(NodeConnector nodeConnector) {
-        boolean updated = false;
-        List<FlowEntryInstall> nodeFlowEntries = nodeFlows.get(nodeConnector.getNode());
-        if (nodeFlowEntries == null) {
-            return updated;
-        }
-        for (FlowEntryInstall fei : new ArrayList<FlowEntryInstall>(nodeFlowEntries)) {
-            if (doesFlowContainNodeConnector(fei.getInstall().getFlow(), nodeConnector)) {
-                Status status = this.removeEntryInternal(fei, true);
-                if (!status.isSuccess()) {
-                    continue;
-                }
-                /*
-                 * If the flow entry is a static flow, then update its
-                 * configuration
-                 */
-                if (fei.getGroupName().equals(FlowConfig.STATICFLOWGROUP)) {
-                    FlowConfig flowConfig = getStaticFlow(fei.getFlowName(), fei.getNode());
-                    if (flowConfig != null) {
-                        flowConfig.setStatus(PORT_REMOVED);
-                        updated = true;
-                    }
-                }
-            }
-        }
-        return updated;
-    }
-
-    private FlowConfig getDerivedFlowConfig(FlowConfig original, String configName, Short port) {
-        FlowConfig derivedFlow = new FlowConfig(original);
-        derivedFlow.setDynamic(true);
-        derivedFlow.setPortGroup(null);
-        derivedFlow.setName(original.getName() + "_" + configName + "_" + port);
-        derivedFlow.setIngressPort(port + "");
-        return derivedFlow;
-    }
-
-    private void addPortGroupFlows(PortGroupConfig config, Node node, PortGroup data) {
-        for (FlowConfig staticFlow : staticFlows.values()) {
-            if (staticFlow.getPortGroup() == null) {
-                continue;
-            }
-            if ((staticFlow.getNode().equals(node)) && (staticFlow.getPortGroup().equals(config.getName()))) {
-                for (Short port : data.getPorts()) {
-                    FlowConfig derivedFlow = getDerivedFlowConfig(staticFlow, config.getName(), port);
-                    addStaticFlowInternal(derivedFlow, false, false);
-                }
-            }
-        }
-    }
-
-    private void removePortGroupFlows(PortGroupConfig config, Node node, PortGroup data) {
-        for (FlowConfig staticFlow : staticFlows.values()) {
-            if (staticFlow.getPortGroup() == null) {
-                continue;
-            }
-            if (staticFlow.getNode().equals(node) && staticFlow.getPortGroup().equals(config.getName())) {
-                for (Short port : data.getPorts()) {
-                    FlowConfig derivedFlow = getDerivedFlowConfig(staticFlow, config.getName(), port);
-                    removeStaticFlow(derivedFlow);
-                }
-            }
-        }
-    }
-
-    @Override
-    public void portGroupChanged(PortGroupConfig config, Map<Node, PortGroup> data, boolean add) {
-        log.trace("PortGroup Changed for: {} Data: {}", config, portGroupData);
-        Map<Node, PortGroup> existingData = portGroupData.get(config);
-        if (existingData != null) {
-            for (Map.Entry<Node, PortGroup> entry : data.entrySet()) {
-                PortGroup existingPortGroup = existingData.get(entry.getKey());
-                if (existingPortGroup == null) {
-                    if (add) {
-                        existingData.put(entry.getKey(), entry.getValue());
-                        addPortGroupFlows(config, entry.getKey(), entry.getValue());
-                    }
-                } else {
-                    if (add) {
-                        existingPortGroup.getPorts().addAll(entry.getValue().getPorts());
-                        addPortGroupFlows(config, entry.getKey(), entry.getValue());
-                    } else {
-                        existingPortGroup.getPorts().removeAll(entry.getValue().getPorts());
-                        removePortGroupFlows(config, entry.getKey(), entry.getValue());
-                    }
-                }
-            }
-        } else {
-            if (add) {
-                portGroupData.put(config, data);
-                for (Node swid : data.keySet()) {
-                    addPortGroupFlows(config, swid, data.get(swid));
-                }
-            }
-        }
-    }
-
-    @Override
-    public boolean addPortGroupConfig(String name, String regex, boolean restore) {
-        PortGroupConfig config = portGroupConfigs.get(name);
-        if (config != null) {
-            return false;
-        }
-
-        if ((portGroupProvider == null) && !restore) {
-            return false;
-        }
-        if ((portGroupProvider != null) && (!portGroupProvider.isMatchCriteriaSupported(regex))) {
-            return false;
-        }
-
-        config = new PortGroupConfig(name, regex);
-        portGroupConfigs.put(name, config);
-        if (portGroupProvider != null) {
-            portGroupProvider.createPortGroupConfig(config);
-        }
-        return true;
-    }
-
-    @Override
-    public boolean delPortGroupConfig(String name) {
-        PortGroupConfig config = portGroupConfigs.get(name);
-        if (config == null) {
-            return false;
-        }
-
-        if (portGroupProvider != null) {
-            portGroupProvider.deletePortGroupConfig(config);
-        }
-        portGroupConfigs.remove(name);
-        return true;
-    }
-
-    @Override
-    public Map<String, PortGroupConfig> getPortGroupConfigs() {
-        return portGroupConfigs;
-    }
-
-    public boolean isPortGroupSupported() {
-        if (portGroupProvider == null) {
-            return false;
-        }
-        return true;
-    }
-
-    public void setIContainer(IContainer s) {
-        this.container = s;
-    }
-
-    public void unsetIContainer(IContainer s) {
-        if (this.container == s) {
-            this.container = null;
-        }
-    }
-
-    public void setConfigurationContainerService(IConfigurationContainerService service) {
-        log.trace("Got configuration service set request {}", service);
-        this.configurationService = service;
-    }
-
-    public void unsetConfigurationContainerService(IConfigurationContainerService service) {
-        log.trace("Got configuration service UNset request");
-        this.configurationService = null;
-    }
-
-    @Override
-    public PortGroupProvider getPortGroupProvider() {
-        return portGroupProvider;
-    }
-
-    public void unsetPortGroupProvider(PortGroupProvider portGroupProvider) {
-        this.portGroupProvider = null;
-    }
-
-    public void setPortGroupProvider(PortGroupProvider portGroupProvider) {
-        this.portGroupProvider = portGroupProvider;
-        portGroupProvider.registerPortGroupChange(this);
-        for (PortGroupConfig config : portGroupConfigs.values()) {
-            portGroupProvider.createPortGroupConfig(config);
-        }
-    }
-
-    public void setFrmAware(IForwardingRulesManagerAware obj) {
-        this.frmAware.add(obj);
-    }
-
-    public void unsetFrmAware(IForwardingRulesManagerAware obj) {
-        this.frmAware.remove(obj);
-    }
-
-    void setClusterContainerService(IClusterContainerServices s) {
-        log.debug("Cluster Service set");
-        this.clusterContainerService = s;
-    }
-
-    void unsetClusterContainerService(IClusterContainerServices s) {
-        if (this.clusterContainerService == s) {
-            log.debug("Cluster Service removed!");
-            this.clusterContainerService = null;
-        }
-    }
-
-    private String getContainerName() {
-        if (container == null) {
-            return GlobalConstants.DEFAULT.toString();
-        }
-        return container.getName();
-    }
-
-    /**
-     * Function called by the dependency manager when all the required
-     * dependencies are satisfied
-     *
-     */
-    void init() {
-
-        inContainerMode = false;
-
-        if (portGroupProvider != null) {
-            portGroupProvider.registerPortGroupChange(this);
-        }
-
-        nodeFlows = new ConcurrentHashMap<Node, List<FlowEntryInstall>>();
-        groupFlows = new ConcurrentHashMap<String, List<FlowEntryInstall>>();
-
-        cacheStartup();
-
-        /*
-         * If we are not the first cluster node to come up, do not initialize
-         * the static flow entries ordinal
-         */
-        if (staticFlowsOrdinal.size() == 0) {
-            staticFlowsOrdinal.put(0, Integer.valueOf(0));
-        }
-
-        pendingEvents = new LinkedBlockingQueue<FRMEvent>();
-
-        // Initialize the event handler thread
-        frmEventHandler = new Thread(new Runnable() {
-            @Override
-            public void run() {
-                while (!stopping) {
-                    try {
-                        final FRMEvent event = pendingEvents.take();
-                        if (event == null) {
-                            log.warn("Dequeued null event");
-                            continue;
-                        }
-                        log.trace("Dequeued {} event", event.getClass().getSimpleName());
-                        if (event instanceof NodeUpdateEvent) {
-                            NodeUpdateEvent update = (NodeUpdateEvent) event;
-                            Node node = update.getNode();
-                            switch (update.getUpdateType()) {
-                            case ADDED:
-                                addStaticFlowsToSwitch(node);
-                                break;
-                            case REMOVED:
-                                cleanDatabaseForNode(node);
-                                updateStaticFlowConfigsOnNodeDown(node);
-                                break;
-                            default:
-                            }
-                        } else if (event instanceof ErrorReportedEvent) {
-                            ErrorReportedEvent errEvent = (ErrorReportedEvent) event;
-                            processErrorEvent(errEvent);
-                        } else if (event instanceof WorkOrderEvent) {
-                            /*
-                             * Take care of handling the remote Work request
-                             */
-                            Runnable r = new Runnable() {
-                                @Override
-                                public void run() {
-                                    WorkOrderEvent work = (WorkOrderEvent) event;
-                                    FlowEntryDistributionOrder fe = work.getFe();
-                                    if (fe != null) {
-                                        logsync.trace("Executing the workOrder {}", fe);
-                                        Status gotStatus = null;
-                                        FlowEntryInstall feiCurrent = fe.getEntry();
-                                        FlowEntryInstall feiNew = workOrder.get(fe);
-                                        switch (fe.getUpType()) {
-                                        case ADDED:
-                                            gotStatus = addEntryInHw(feiCurrent, false);
-                                            break;
-                                        case CHANGED:
-                                            gotStatus = modifyEntryInHw(feiCurrent, feiNew, false);
-                                            break;
-                                        case REMOVED:
-                                            gotStatus = removeEntryInHw(feiCurrent, false);
-                                            break;
-                                        }
-                                        // Remove the Order
-                                        workOrder.remove(fe);
-                                        logsync.trace(
-                                                "The workOrder has been executed and now the status is being returned {}", fe);
-                                        // Place the status
-                                        workStatus.put(fe, gotStatus);
-                                    } else {
-                                        log.warn("Not expected null WorkOrder", work);
-                                    }
-                                }
-                            };
-                            if(executor != null) {
-                                executor.execute(r);
-                            }
-                        } else if (event instanceof WorkStatusCleanup) {
-                            /*
-                             * Take care of handling the remote Work request
-                             */
-                            WorkStatusCleanup work = (WorkStatusCleanup) event;
-                            FlowEntryDistributionOrder fe = work.getFe();
-                            if (fe != null) {
-                                logsync.trace("The workStatus {} is being removed", fe);
-                                workStatus.remove(fe);
-                            } else {
-                                log.warn("Not expected null WorkStatus", work);
-                            }
-                        }  else if (event instanceof ContainerFlowChangeEvent) {
-                            /*
-                             * Whether it is an addition or removal, we have to
-                             * recompute the merged flows entries taking into
-                             * account all the current container flows because
-                             * flow merging is not an injective function
-                             */
-                            updateFlowsContainerFlow();
-                        } else if (event instanceof UpdateIndexDBs) {
-                            UpdateIndexDBs update = (UpdateIndexDBs)event;
-                            updateIndexDatabase(update.getFei(), update.isAddition());
-                        } else {
-                            log.warn("Dequeued unknown event {}", event.getClass().getSimpleName());
-                        }
-                    } catch (InterruptedException e) {
-                        // clear pending events
-                        pendingEvents.clear();
-                    }
-                }
-            }
-        }, "FRM EventHandler Collector");
-    }
-
-    /**
-     * Function called by the dependency manager when at least one dependency
-     * become unsatisfied or when the component is shutting down because for
-     * example bundle is being stopped.
-     *
-     */
-    void destroy() {
-        // Interrupt the thread
-        frmEventHandler.interrupt();
-        // Clear the pendingEvents queue
-        pendingEvents.clear();
-        frmAware.clear();
-        workMonitor.clear();
-    }
-
-    /**
-     * Function called by dependency manager after "init ()" is called and after
-     * the services provided by the class are registered in the service registry
-     *
-     */
-    void start() {
-        /*
-         * If running in default container, need to know if controller is in
-         * container mode
-         */
-        if (GlobalConstants.DEFAULT.toString().equals(this.getContainerName())) {
-            inContainerMode = containerManager.inContainerMode();
-        }
-
-        // Initialize graceful stop flag
-        stopping = false;
-
-        // Allocate the executor service
-        this.executor = Executors.newFixedThreadPool(maxPoolSize);
-
-        // Start event handler thread
-        frmEventHandler.start();
-
-        // replay the installedSwView data structure to populate
-        // node flows and group flows
-        for (FlowEntryInstall fei : installedSwView.values()) {
-            pendingEvents.offer(new UpdateIndexDBs(fei, true));
-        }
-
-        /*
-         * Read startup and build database if we are the coordinator
-         */
-        loadFlowConfiguration();
-    }
-
-    /**
-     * Function called by the dependency manager before Container is Stopped and Destroyed.
-     */
-    public void containerStop() {
-        uninstallAllFlowEntries(false);
-    }
-
-    /**
-     * Function called by the dependency manager before the services exported by
-     * the component are unregistered, this will be followed by a "destroy ()"
-     * calls
-     */
-    void stop() {
-        stopping = true;
-        // Shutdown executor
-        this.executor.shutdownNow();
-        // Now walk all the workMonitor and wake up the one sleeping because
-        // destruction is happening
-        for (FlowEntryDistributionOrder fe : workMonitor.keySet()) {
-            FlowEntryDistributionOrderFutureTask task = workMonitor.get(fe);
-            task.cancel(true);
-        }
-    }
-
-    public void setFlowProgrammerService(IFlowProgrammerService service) {
-        this.programmer = service;
-    }
-
-    public void unsetFlowProgrammerService(IFlowProgrammerService service) {
-        if (this.programmer == service) {
-            this.programmer = null;
-        }
-    }
-
-    public void setSwitchManager(ISwitchManager switchManager) {
-        this.switchManager = switchManager;
-    }
-
-    public void unsetSwitchManager(ISwitchManager switchManager) {
-        if (this.switchManager == switchManager) {
-            this.switchManager = null;
-        }
-    }
-
-    @Override
-    public void tagUpdated(String containerName, Node n, short oldTag, short newTag, UpdateType t) {
-        if (!container.getName().equals(containerName)) {
-            return;
-        }
-    }
-
-    @Override
-    public void containerFlowUpdated(String containerName, ContainerFlow previous, ContainerFlow current, UpdateType t) {
-        if (!container.getName().equals(containerName)) {
-            return;
-        }
-        log.trace("Container {}: Updating installed flows because of container flow change: {} {}",
-                container.getName(), t, current);
-        ContainerFlowChangeEvent ev = new ContainerFlowChangeEvent(previous, current, t);
-        pendingEvents.offer(ev);
-    }
-
-    @Override
-    public void nodeConnectorUpdated(String containerName, NodeConnector nc, UpdateType t) {
-        if (!container.getName().equals(containerName)) {
-            return;
-        }
-
-        boolean updateStaticFlowCluster = false;
-
-        switch (t) {
-        case REMOVED:
-            log.trace("Port {} was removed from container: uninstalling interested flows", nc);
-            updateStaticFlowCluster = removeFlowsOnNodeConnectorDown(nc);
-            break;
-        case ADDED:
-            log.trace("Port {} was added to container: reinstall interested flows", nc);
-            updateStaticFlowCluster = installFlowsOnNodeConnectorUp(nc);
-
-            break;
-        case CHANGED:
-            break;
-        default:
-        }
-
-        if (updateStaticFlowCluster) {
-            refreshClusterStaticFlowsStatus(nc.getNode());
-        }
-    }
-
-    @Override
-    public void containerModeUpdated(UpdateType update) {
-        // Only default container instance reacts on this event
-        if (!container.getName().equals(GlobalConstants.DEFAULT.toString())) {
-            return;
-        }
-        switch (update) {
-        case ADDED:
-            /*
-             * Controller is moving to container mode. We are in the default
-             * container context, we need to remove all our non-internal flows
-             * to prevent any container isolation breakage. We also need to
-             * preserve our flow so that they can be re-installed if we move
-             * back to non container mode (no containers).
-             */
-            this.inContainerMode = true;
-            this.uninstallAllFlowEntries(true);
-            break;
-        case REMOVED:
-            this.inContainerMode = false;
-            this.reinstallAllFlowEntries();
-            break;
-        default:
-            break;
-        }
-
-        // Update our configuration DB
-        updateStaticFlowConfigsOnContainerModeChange(update);
-    }
-
-    protected abstract class FRMEvent {
-
-    }
-
-    private class NodeUpdateEvent extends FRMEvent {
-        private final Node node;
-        private final UpdateType update;
-
-        public NodeUpdateEvent(UpdateType update, Node node) {
-            this.update = update;
-            this.node = node;
-        }
-
-        public UpdateType getUpdateType() {
-            return update;
-        }
-
-        public Node getNode() {
-            return node;
-        }
-    }
-
-    private class ErrorReportedEvent extends FRMEvent {
-        private final long rid;
-        private final Node node;
-        private final Object error;
-
-        public ErrorReportedEvent(long rid, Node node, Object error) {
-            this.rid = rid;
-            this.node = node;
-            this.error = error;
-        }
-
-        public long getRequestId() {
-            return rid;
-        }
-
-        public Object getError() {
-            return error;
-        }
-
-        public Node getNode() {
-            return node;
-        }
-    }
-
-    private class WorkOrderEvent extends FRMEvent {
-        private FlowEntryDistributionOrder fe;
-        private FlowEntryInstall newEntry;
-
-        /**
-         * @param fe
-         * @param newEntry
-         */
-        WorkOrderEvent(FlowEntryDistributionOrder fe, FlowEntryInstall newEntry) {
-            this.fe = fe;
-            this.newEntry = newEntry;
-        }
-
-        /**
-         * @return the fe
-         */
-        public FlowEntryDistributionOrder getFe() {
-            return fe;
-        }
-
-        /**
-         * @return the newEntry
-         */
-        public FlowEntryInstall getNewEntry() {
-            return newEntry;
-        }
-    }
-    private class ContainerFlowChangeEvent extends FRMEvent {
-        private final ContainerFlow previous;
-        private final ContainerFlow current;
-        private final UpdateType type;
-
-        public ContainerFlowChangeEvent(ContainerFlow previous, ContainerFlow current, UpdateType type) {
-            this.previous = previous;
-            this.current = current;
-            this.type = type;
-        }
-
-        public ContainerFlow getPrevious() {
-            return this.previous;
-        }
-
-        public ContainerFlow getCurrent() {
-            return this.current;
-        }
-
-        public UpdateType getType() {
-            return this.type;
-        }
-    }
-
-
-    private class WorkStatusCleanup extends FRMEvent {
-        private FlowEntryDistributionOrder fe;
-
-        /**
-         * @param fe
-         */
-        WorkStatusCleanup(FlowEntryDistributionOrder fe) {
-            this.fe = fe;
-        }
-
-        /**
-         * @return the fe
-         */
-        public FlowEntryDistributionOrder getFe() {
-            return fe;
-        }
-    }
-
-    private class UpdateIndexDBs extends FRMEvent {
-        private FlowEntryInstall fei;
-        private boolean add;
-
-        /**
-         *
-         * @param fei the flow entry which was installed/removed on the netwrok node
-         * @param update
-         */
-        UpdateIndexDBs(FlowEntryInstall fei, boolean add) {
-            this.fei = fei;
-            this.add = add;
-        }
-
-
-        /**
-         * @return the flowEntryInstall object which was added/removed
-         * to/from the installed software view cache
-         */
-        public FlowEntryInstall getFei() {
-            return fei;
-        }
-
-        /**
-         *
-         * @return whether this was an flow addition or removal
-         */
-        public boolean isAddition() {
-            return add;
-        }
-    }
-
-    @Override
-    public Status saveConfiguration() {
-        return saveConfig();
-    }
-
-    @Override
-    public void flowRemoved(Node node, Flow flow) {
-        log.trace("Received flow removed notification on {} for {}", node, flow);
-
-        // For flow entry identification, only node, match and priority matter
-        FlowEntryInstall test = new FlowEntryInstall(new FlowEntry("", "", flow, node), null);
-        FlowEntryInstall installedEntry = this.installedSwView.get(test);
-        if (installedEntry == null) {
-            log.trace("Entry is not known to us");
-            return;
-        }
-
-        // Update Static flow status
-        Integer key = 0;
-        FlowConfig target = null;
-        for (Map.Entry<Integer, FlowConfig> entry : staticFlows.entrySet()) {
-            FlowConfig conf = entry.getValue();
-            if (conf.isByNameAndNodeIdEqual(installedEntry.getFlowName(), node)) {
-                key = entry.getKey();
-                target = conf;
-                break;
-            }
-        }
-        if (target != null) {
-            // Update Configuration database
-            if (target.getHardTimeout() != null || target.getIdleTimeout() != null) {
-                /*
-                 * No need for checking if actual values: these strings were
-                 * validated at configuration creation. Also, after a switch
-                 * down scenario, no use to reinstall a timed flow. Mark it as
-                 * "do not install". User can manually toggle it.
-                 */
-                target.toggleInstallation();
-            }
-            target.setStatus(StatusCode.GONE.toString());
-            staticFlows.put(key, target);
-        }
-
-        // Update software views
-        this.updateSwViews(installedEntry, false);
-    }
-
-    @Override
-    public void flowErrorReported(Node node, long rid, Object err) {
-        log.trace("Got error {} for message rid {} from node {}", new Object[] { err, rid, node });
-        pendingEvents.offer(new ErrorReportedEvent(rid, node, err));
-    }
-
-    private void processErrorEvent(ErrorReportedEvent event) {
-        Node node = event.getNode();
-        long rid = event.getRequestId();
-        Object error = event.getError();
-        String errorString = (error == null) ? "Not provided" : error.toString();
-        /*
-         * If this was for a flow install, remove the corresponding entry from
-         * the software view. If it was a Looking for the rid going through the
-         * software database. TODO: A more efficient rid <-> FlowEntryInstall
-         * mapping will have to be added in future
-         */
-        FlowEntryInstall target = null;
-        List<FlowEntryInstall> flowEntryInstallList = nodeFlows.get(node);
-        // flowEntryInstallList could be null.
-        // so check for it.
-        if(flowEntryInstallList != null) {
-            for (FlowEntryInstall index : flowEntryInstallList) {
-                FlowEntryInstall entry = installedSwView.get(index);
-                if(entry != null) {
-                    if (entry.getRequestId() == rid) {
-                        target = entry;
-                        break;
-                    }
-                }
-            }
-        }
-        if (target != null) {
-            // This was a flow install, update database
-            this.updateSwViews(target, false);
-            // also update the config
-            if(FlowConfig.STATICFLOWGROUP.equals(target.getGroupName())) {
-                ConcurrentMap.Entry<Integer, FlowConfig> staticFlowEntry = getStaticFlowEntry(target.getFlowName(),target.getNode());
-                // staticFlowEntry should never be null.
-                // the null check is just an extra defensive check.
-                if(staticFlowEntry != null) {
-                    // Modify status and update cluster cache
-                    log.debug("Updating static flow configuration on async error event");
-                    String status = String.format("Cannot be installed on node. reason: %s", errorString);
-                    staticFlowEntry.getValue().setStatus(status);
-                    refreshClusterStaticFlowsStatus(node);
-                }
-            }
-        }
-
-        // Notify listeners
-        if (frmAware != null) {
-            synchronized (frmAware) {
-                for (IForwardingRulesManagerAware frma : frmAware) {
-                    try {
-                        frma.requestFailed(rid, errorString);
-                    } catch (Exception e) {
-                        log.warn("Failed to notify {}", frma);
-                    }
-                }
-            }
-        }
-    }
-
-    @Override
-    public Status solicitStatusResponse(Node node, boolean blocking) {
-        Status rv = new Status(StatusCode.INTERNALERROR);
-
-        if (this.programmer != null) {
-            if (blocking) {
-                rv = programmer.syncSendBarrierMessage(node);
-            } else {
-                rv = programmer.asyncSendBarrierMessage(node);
-            }
-        }
-
-        return rv;
-    }
-
-    public void unsetIConnectionManager(IConnectionManager s) {
-        if (s == this.connectionManager) {
-            this.connectionManager = null;
-        }
-    }
-
-    public void setIConnectionManager(IConnectionManager s) {
-        this.connectionManager = s;
-    }
-
-    public void unsetIContainerManager(IContainerManager s) {
-        if (s == this.containerManager) {
-            this.containerManager = null;
-        }
-    }
-
-    public void setIContainerManager(IContainerManager s) {
-        this.containerManager = s;
-    }
-
-    @Override
-    public void entryCreated(Object key, String cacheName, boolean originLocal) {
-        /*
-         * Do nothing
-         */
-    }
-
-    @Override
-    public void entryUpdated(Object key, Object new_value, String cacheName, boolean originLocal) {
-        /*
-         * Streamline the updates for the per node and per group index databases
-         */
-        if (cacheName.equals(INSTALLED_SW_VIEW_CACHE)) {
-            pendingEvents.offer(new UpdateIndexDBs((FlowEntryInstall)new_value, true));
-        }
-
-        if (originLocal) {
-            /*
-             * Local updates are of no interest
-             */
-            return;
-        }
-        if (cacheName.equals(WORK_ORDER_CACHE)) {
-            logsync.trace("Got a WorkOrderCacheUpdate for {}", key);
-            /*
-             * This is the case of one workOrder becoming available, so we need
-             * to dispatch the work to the appropriate handler
-             */
-            FlowEntryDistributionOrder fe = (FlowEntryDistributionOrder) key;
-            FlowEntryInstall fei = fe.getEntry();
-            if (fei == null) {
-                return;
-            }
-            Node n = fei.getNode();
-            if (connectionManager.getLocalityStatus(n) == ConnectionLocality.LOCAL) {
-                logsync.trace("workOrder for fe {} processed locally", fe);
-                // I'm the controller in charge for the request, queue it for
-                // processing
-                pendingEvents.offer(new WorkOrderEvent(fe, (FlowEntryInstall) new_value));
-            }
-        } else if (cacheName.equals(WORK_STATUS_CACHE)) {
-            logsync.trace("Got a WorkStatusCacheUpdate for {}", key);
-            /*
-             * This is the case of one workOrder being completed and a status
-             * returned
-             */
-            FlowEntryDistributionOrder fe = (FlowEntryDistributionOrder) key;
-            /*
-             * Check if the order was initiated by this controller in that case
-             * we need to actually look at the status returned
-             */
-            if (fe.getRequestorController()
-                    .equals(clusterContainerService.getMyAddress())) {
-                FlowEntryDistributionOrderFutureTask fet = workMonitor.remove(fe);
-                if (fet != null) {
-                    logsync.trace("workStatus response is for us {}", fe);
-                    // Signal we got the status
-                    fet.gotStatus(fe, workStatus.get(fe));
-                    pendingEvents.offer(new WorkStatusCleanup(fe));
-                }
-            }
-        }
-    }
-
-    @Override
-    public void entryDeleted(Object key, String cacheName, boolean originLocal) {
-        /*
-         * Streamline the updates for the per node and per group index databases
-         */
-        if (cacheName.equals(INSTALLED_SW_VIEW_CACHE)) {
-            pendingEvents.offer(new UpdateIndexDBs((FlowEntryInstall)key, false));
-        }
-    }
-
-    /**
-     * {@inheritDoc}
-     */
-    @Override
-    public List<FlowEntry> getFlowEntriesForNode(Node node) {
-        List<FlowEntry> list = new ArrayList<FlowEntry>();
-        if (node != null) {
-            for (Map.Entry<FlowEntry, FlowEntry> entry : this.originalSwView.entrySet()) {
-                if (node.equals(entry.getKey().getNode())) {
-                    list.add(entry.getValue().clone());
-                }
-            }
-        }
-        return list;
-    }
-
-    /**
-     * {@inheritDoc}
-     */
-    @Override
-    public List<FlowEntry> getInstalledFlowEntriesForNode(Node node) {
-        List<FlowEntry> list = new ArrayList<FlowEntry>();
-        if (node != null) {
-            List<FlowEntryInstall> flowEntryInstallList = this.nodeFlows.get(node);
-            if(flowEntryInstallList != null) {
-                for(FlowEntryInstall fi: flowEntryInstallList) {
-                    list.add(fi.getInstall().clone());
-                }
-            }
-        }
-        return list;
-    }
-
-}
diff --git a/opendaylight/adsal/forwardingrulesmanager/implementation/src/main/java/org/opendaylight/controller/forwardingrulesmanager/internal/ForwardingRulesManagerCLI.java b/opendaylight/adsal/forwardingrulesmanager/implementation/src/main/java/org/opendaylight/controller/forwardingrulesmanager/internal/ForwardingRulesManagerCLI.java
deleted file mode 100644 (file)
index 320561b..0000000
+++ /dev/null
@@ -1,143 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.forwardingrulesmanager.internal;
-
-import java.util.Dictionary;
-import java.util.Hashtable;
-import java.util.List;
-
-import org.apache.felix.service.command.Descriptor;
-import org.opendaylight.controller.forwardingrulesmanager.FlowEntry;
-import org.opendaylight.controller.forwardingrulesmanager.IForwardingRulesManager;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.utils.ServiceHelper;
-import org.osgi.framework.ServiceRegistration;
-
-/**
- * This class provides osgi cli commands for developers to debug
- * ForwardingRulesManager functionality
- */
-public class ForwardingRulesManagerCLI {
-    @SuppressWarnings("rawtypes")
-    private ServiceRegistration sr = null;
-
-    public void init() {
-    }
-
-    public void destroy() {
-    }
-
-    public void start() {
-        final Dictionary<String, Object> props = new Hashtable<String, Object>();
-        props.put("osgi.command.scope", "odpcontroller");
-        props.put("osgi.command.function", new String[] { "showRequestedGroupFlows", "showInstalledGroupFlows",
-                "showRequestedNodeFlows", "showInstalledNodeFlows" });
-        this.sr = ServiceHelper.registerGlobalServiceWReg(ForwardingRulesManagerCLI.class, this, props);
-    }
-
-    public void stop() {
-        if (this.sr != null) {
-            this.sr.unregister();
-            this.sr = null;
-        }
-    }
-
-    @Descriptor("Displays all the flow entries in a given group")
-    public void showRequestedGroupFlows(@Descriptor("Container in which to query FRM") String container,
-            @Descriptor("Group name") String group, @Descriptor("True for verbose else false") Boolean verbose) {
-        IForwardingRulesManager frm = (IForwardingRulesManager) ServiceHelper.getInstance(
-                IForwardingRulesManager.class, container, this);
-        if (frm == null) {
-            System.out.println("Cannot find the FRM instance on container: " + container);
-            return;
-        }
-        List<FlowEntry> groupFlows = frm.getFlowEntriesForGroup(group);
-        System.out.println("Group " + group);
-        for (FlowEntry flowEntry : groupFlows) {
-            if (!verbose) {
-                System.out.println(flowEntry.getNode() + " " + flowEntry.getFlowName());
-            } else {
-                System.out.println(flowEntry.getNode() + " " + flowEntry.toString());
-            }
-        }
-    }
-
-    @Descriptor("Displays all the installed flow entries in a given group")
-    public void showInstalledGroupFlows(@Descriptor("Container in which to query FRM") String container,
-            @Descriptor("Group name") String group, @Descriptor("True for verbose else false") Boolean verbose) {
-        IForwardingRulesManager frm = (IForwardingRulesManager) ServiceHelper.getInstance(
-                IForwardingRulesManager.class, container, this);
-        if (frm == null) {
-            System.out.println("Cannot find the FRM instance on container: " + container);
-            return;
-        }
-        List<FlowEntry> groupFlows = frm.getInstalledFlowEntriesForGroup(group);
-        System.out.println("Group " + group);
-        for (FlowEntry flowEntry : groupFlows) {
-            if (!verbose) {
-                System.out.println(flowEntry.getNode() + " " + flowEntry.getFlowName());
-            } else {
-                System.out.println(flowEntry.getNode() + " " + flowEntry.toString());
-            }
-        }
-    }
-
-    @Descriptor("Displays all the flow entries for a network node")
-    public void showRequestedNodeFlows(
-            @Descriptor("Container in which to query FRM") String container,
-            @Descriptor("String representation of the Node, this need to be consumable from Node.fromString()") String nodeId,
-            @Descriptor("True for verbose else false") Boolean verbose) {
-        IForwardingRulesManager frm = (IForwardingRulesManager) ServiceHelper.getInstance(
-                IForwardingRulesManager.class, container, this);
-        if (frm == null) {
-            System.out.println("Cannot find the FRM instance on container: " + container);
-            return;
-        }
-        Node node = Node.fromString(nodeId);
-        if (node == null) {
-            System.out.println("Please enter a valid node id");
-            return;
-        }
-        List<FlowEntry> groupFlows = frm.getFlowEntriesForNode(node);
-        System.out.println("Node " + nodeId);
-        for (FlowEntry flowEntry : groupFlows) {
-            if (!verbose) {
-                System.out.println(flowEntry.getNode() + " " + flowEntry.getFlowName());
-            } else {
-                System.out.println(flowEntry.getNode() + " " + flowEntry.toString());
-            }
-        }
-    }
-
-    @Descriptor("Displays all the flow entries installed in a network node")
-    public void showInstalledNodeFlows(
-            @Descriptor("Container in which to query FRM") String container,
-            @Descriptor("String representation of the Node, this need to be consumable from Node.fromString()") String nodeId,
-            @Descriptor("True for verbose else false") Boolean verbose) {
-        IForwardingRulesManager frm = (IForwardingRulesManager) ServiceHelper.getInstance(
-                IForwardingRulesManager.class, container, this);
-        if (frm == null) {
-            System.out.println("Cannot find the FRM instance on container: " + container);
-            return;
-        }
-        Node node = Node.fromString(nodeId);
-        if (node == null) {
-            System.out.println("Please enter a valid node id");
-            return;
-        }
-        List<FlowEntry> groupFlows = frm.getInstalledFlowEntriesForNode(node);
-        System.out.println("Node " + nodeId);
-        for (FlowEntry flowEntry : groupFlows) {
-            if (!verbose) {
-                System.out.println(flowEntry.getNode() + " " + flowEntry.getFlowName());
-            } else {
-                System.out.println(flowEntry.getNode() + " " + flowEntry.toString());
-            }
-        }
-    }
-}
diff --git a/opendaylight/adsal/forwardingrulesmanager/integrationtest/pom.xml b/opendaylight/adsal/forwardingrulesmanager/integrationtest/pom.xml
deleted file mode 100644 (file)
index 361506a..0000000
+++ /dev/null
@@ -1,172 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.integrationtest</artifactId>
-    <version>0.7.0-SNAPSHOT</version>
-    <relativePath>../../commons/integrationtest</relativePath>
-  </parent>
-
-  <artifactId>forwardingrulesmanager.integrationtest</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <properties>
-    <sonar.jacoco.itReportPath>../../implementation/target/jacoco-it.exec</sonar.jacoco.itReportPath>
-    <!-- Sonar jacoco plugin to get integration test coverage info -->
-    <sonar.jacoco.reportPath>../../implementation/target/jacoco.exec</sonar.jacoco.reportPath>
-  </properties>
-
-  <dependencies>
-    <dependency>
-      <groupId>ch.qos.logback</groupId>
-      <artifactId>logback-classic</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>ch.qos.logback</groupId>
-      <artifactId>logback-core</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>clustering.services</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>clustering.stub</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>configuration</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>configuration.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>connectionmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>connectionmanager.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>containermanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>containermanager.it.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>forwardingrulesmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>forwardingrulesmanager.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>hosttracker</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>hosttracker.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>protocol_plugins.stub</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal.connection</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal.connection.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>switchmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>switchmanager.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>topologymanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.slf4j</groupId>
-      <artifactId>log4j-over-slf4j</artifactId>
-    </dependency>
-    <!-- Add Pax Exam -->
-    <dependency>
-      <groupId>org.ops4j.pax.exam</groupId>
-      <artifactId>pax-exam-container-native</artifactId>
-      <scope>test</scope>
-    </dependency>
-    <dependency>
-      <groupId>org.ops4j.pax.exam</groupId>
-      <artifactId>pax-exam-junit4</artifactId>
-      <scope>test</scope>
-    </dependency>
-    <dependency>
-      <groupId>org.ops4j.pax.exam</groupId>
-      <artifactId>pax-exam-link-mvn</artifactId>
-      <scope>test</scope>
-    </dependency>
-    <dependency>
-      <groupId>org.ops4j.pax.url</groupId>
-      <artifactId>pax-url-aether</artifactId>
-      <scope>test</scope>
-    </dependency>
-  </dependencies>
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.jacoco</groupId>
-        <artifactId>jacoco-maven-plugin</artifactId>
-        <configuration>
-          <destFile>../../implementation/target/jacoco-it.exec</destFile>
-          <includes>
-            <include>org.opendaylight.controller.*</include>
-          </includes>
-        </configuration>
-        <executions>
-          <execution>
-            <id>pre-test</id>
-            <goals>
-              <goal>prepare-agent</goal>
-            </goals>
-          </execution>
-          <execution>
-            <id>post-test</id>
-            <configuration>
-              <skip>true</skip>
-            </configuration>
-          </execution>
-        </executions>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/forwardingrulesmanager/integrationtest/src/test/java/org/opendaylight/controller/forwardingrulesmanager/internal/ForwardingRulesManagerIT.java b/opendaylight/adsal/forwardingrulesmanager/integrationtest/src/test/java/org/opendaylight/controller/forwardingrulesmanager/internal/ForwardingRulesManagerIT.java
deleted file mode 100644 (file)
index 6fd7eb2..0000000
+++ /dev/null
@@ -1,222 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.forwardingrulesmanager.internal;
-
-import static org.junit.Assert.fail;
-import static org.junit.Assert.assertFalse;
-import static org.junit.Assert.assertNotNull;
-import static org.ops4j.pax.exam.CoreOptions.junitBundles;
-import static org.ops4j.pax.exam.CoreOptions.mavenBundle;
-import static org.ops4j.pax.exam.CoreOptions.options;
-import static org.ops4j.pax.exam.CoreOptions.systemPackages;
-import static org.ops4j.pax.exam.CoreOptions.systemProperty;
-
-import java.net.InetAddress;
-import java.net.UnknownHostException;
-import java.util.ArrayList;
-import java.util.List;
-
-import javax.inject.Inject;
-
-import org.junit.Assert;
-import org.junit.Before;
-import org.junit.Test;
-import org.junit.runner.RunWith;
-import org.opendaylight.controller.forwardingrulesmanager.FlowEntry;
-import org.opendaylight.controller.forwardingrulesmanager.IForwardingRulesManager;
-import org.opendaylight.controller.sal.action.Action;
-import org.opendaylight.controller.sal.action.Drop;
-import org.opendaylight.controller.sal.core.ConstructionException;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.flowprogrammer.Flow;
-import org.opendaylight.controller.sal.match.Match;
-import org.opendaylight.controller.sal.match.MatchType;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.sal.utils.StatusCode;
-import org.ops4j.pax.exam.Option;
-import org.ops4j.pax.exam.Configuration;
-import org.ops4j.pax.exam.junit.PaxExam;
-import org.ops4j.pax.exam.util.PathUtils;
-import org.osgi.framework.Bundle;
-import org.osgi.framework.BundleContext;
-import org.osgi.framework.ServiceReference;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-@RunWith(PaxExam.class)
-public class ForwardingRulesManagerIT {
-    private Logger log = LoggerFactory.getLogger(ForwardingRulesManagerIT.class);
-    // get the OSGI bundle context
-    @Inject
-    private BundleContext bc;
-
-    private IForwardingRulesManager manager = null;
-
-    // Configure the OSGi container
-    @Configuration
-    public Option[] config() {
-        return options(
-                //
-                systemProperty("logback.configurationFile").value(
-                        "file:" + PathUtils.getBaseDir()
-                                + "/src/test/resources/logback.xml"),
-                // To start OSGi console for inspection remotely
-                systemProperty("osgi.console").value("2401"),
-                // Set the systemPackages (used by clustering)
-                systemPackages("sun.reflect", "sun.reflect.misc", "sun.misc"),
-                // List framework bundles
-                mavenBundle("equinoxSDK381", "org.eclipse.equinox.console").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "org.eclipse.equinox.util").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "org.eclipse.osgi.services").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "org.eclipse.equinox.ds").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "org.apache.felix.gogo.command").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "org.apache.felix.gogo.runtime").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "org.apache.felix.gogo.shell").versionAsInProject(),
-                // List logger bundles
-                mavenBundle("org.slf4j", "slf4j-api").versionAsInProject(),
-                mavenBundle("org.slf4j", "log4j-over-slf4j")
-                        .versionAsInProject(),
-                mavenBundle("ch.qos.logback", "logback-core")
-                        .versionAsInProject(),
-                mavenBundle("ch.qos.logback", "logback-classic")
-                        .versionAsInProject(),
-                // List all the bundles on which the test case depends
-                mavenBundle("org.opendaylight.controller", "sal")
-                        .versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "sal.implementation")
-                        .versionAsInProject(),
-
-                mavenBundle("org.opendaylight.controller",
-                        "protocol_plugins.stub").versionAsInProject(),
-
-                mavenBundle("org.opendaylight.controller", "containermanager")
-                        .versionAsInProject(),
-                mavenBundle("org.opendaylight.controller",
-                        "containermanager.it.implementation").versionAsInProject(),
-
-                mavenBundle("org.opendaylight.controller",
-                        "forwardingrulesmanager").versionAsInProject(),
-
-                mavenBundle("org.opendaylight.controller",
-                        "forwardingrulesmanager.implementation")
-                        .versionAsInProject(),
-
-                mavenBundle("org.opendaylight.controller",
-                        "clustering.services").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "clustering.stub")
-                        .versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "switchmanager")
-                        .versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "statisticsmanager").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller",
-                        "switchmanager.implementation").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "configuration")
-                        .versionAsInProject(),
-                mavenBundle("org.opendaylight.controller",
-                        "configuration.implementation").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "hosttracker")
-                        .versionAsInProject(),
-                mavenBundle("org.opendaylight.controller",
-                        "hosttracker.implementation").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller",
-                        "connectionmanager.implementation").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller",
-                        "connectionmanager").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller",
-                        "sal.connection").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller",
-                        "sal.connection.implementation").versionAsInProject(),
-
-                // needed by hosttracker
-                mavenBundle("org.opendaylight.controller", "topologymanager")
-                        .versionAsInProject(),
-
-                mavenBundle("org.jboss.spec.javax.transaction",
-                        "jboss-transaction-api_1.1_spec").versionAsInProject(),
-                mavenBundle("org.apache.commons", "commons-lang3")
-                        .versionAsInProject(),
-                mavenBundle("org.apache.felix",
-                        "org.apache.felix.dependencymanager")
-                        .versionAsInProject(), junitBundles());
-    }
-
-    private String stateToString(int state) {
-        switch (state) {
-        case Bundle.ACTIVE:
-            return "ACTIVE";
-        case Bundle.INSTALLED:
-            return "INSTALLED";
-        case Bundle.RESOLVED:
-            return "RESOLVED";
-        case Bundle.UNINSTALLED:
-            return "UNINSTALLED";
-        default:
-            return "Not CONVERTED";
-        }
-    }
-
-    @Before
-    public void areWeReady() {
-        assertNotNull(bc);
-        boolean debugit = false;
-        Bundle b[] = bc.getBundles();
-        for (Bundle element : b) {
-            int state = element.getState();
-            if (state != Bundle.ACTIVE && state != Bundle.RESOLVED) {
-                log.debug("Bundle:" + element.getSymbolicName() + " state:"
-                        + stateToString(state));
-                debugit = true;
-            }
-        }
-        if (debugit) {
-            log.debug("Do some debugging because some bundle is "
-                    + "unresolved");
-        }
-
-        // Assert if true, if false we are good to go!
-        assertFalse(debugit);
-
-        ServiceReference r = bc.getServiceReference(IForwardingRulesManager.class.getName());
-        if (r != null) {
-            this.manager = (IForwardingRulesManager) bc.getService(r);
-        }
-        // If StatisticsManager is null, cannot run tests.
-        assertNotNull(this.manager);
-
-    }
-
-    @Test
-    public void testFlowEntries() {
-        Flow flow = new Flow();
-
-        Match match = new Match();
-        try {
-            match.setField(MatchType.NW_DST, InetAddress.getByName("1.1.1.1"));
-        } catch (UnknownHostException e) {
-        }
-        flow.setMatch(match);
-        Action action = new Drop();
-
-        List<Action> actions = new ArrayList<Action>();
-        actions.add(action);
-        flow.setActions(actions);
-        Node node;
-        try {
-            // Must use a node published by the stub protocol plugin else
-            // connection manager will not report it as a local node
-            node = new Node("STUB", 51966);
-            FlowEntry fe = new FlowEntry("g1", "f1", flow, node);
-            Status stat = manager.installFlowEntry(fe);
-
-            Assert.assertTrue(stat.getCode() == StatusCode.SUCCESS);
-        } catch (ConstructionException e) {
-            // Got a failure while allocating the node
-            fail("Failed while allocating the node " + e.getMessage());
-        }
-    }
-}
diff --git a/opendaylight/adsal/forwardingrulesmanager/integrationtest/src/test/resources/logback.xml b/opendaylight/adsal/forwardingrulesmanager/integrationtest/src/test/resources/logback.xml
deleted file mode 100644 (file)
index 2d63ce5..0000000
+++ /dev/null
@@ -1,13 +0,0 @@
-<configuration scan="true">
-
-  <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
-    <encoder>
-      <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n
-      </pattern>
-    </encoder>
-  </appender>
-
-  <root level="error">
-    <appender-ref ref="STDOUT" />
-  </root>
-</configuration>
diff --git a/opendaylight/adsal/hosttracker/api/pom.xml b/opendaylight/adsal/hosttracker/api/pom.xml
deleted file mode 100644 (file)
index 8e5a18d..0000000
+++ /dev/null
@@ -1,56 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-  <artifactId>hosttracker</artifactId>
-  <version>0.7.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Export-Package>org.opendaylight.controller.hosttracker,
-       org.opendaylight.controller.hosttracker.hostAware</Export-Package>
-            <Import-Package>org.opendaylight.controller.sal.core,
-       org.opendaylight.controller.sal.utils,
-       org.opendaylight.controller.sal.packet.address,
-       javax.xml.bind.annotation,
-       javax.xml.bind,
-       org.apache.felix.dm,
-       org.osgi.service.component,
-       org.slf4j,
-       org.eclipse.osgi.framework.console,
-       org.osgi.framework</Import-Package>
-          </instructions>
-          <manifestLocation>${project.basedir}/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/hosttracker/api/src/main/java/org/opendaylight/controller/hosttracker/HostIdFactory.java b/opendaylight/adsal/hosttracker/api/src/main/java/org/opendaylight/controller/hosttracker/HostIdFactory.java
deleted file mode 100644 (file)
index 4585306..0000000
+++ /dev/null
@@ -1,48 +0,0 @@
-/*
- * Copyright IBM Corporation, 2013.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.hosttracker;
-
-import java.net.InetAddress;
-
-import org.opendaylight.controller.sal.packet.address.DataLinkAddress;
-
-/*
- * Class used to generate a key based on the scheme choosen for hostsdb storage in hosttracker.
- * @author Deepak Udapudi
- */
-public class HostIdFactory {
-    public static final String DEFAULT_IP_KEY_SCHEME = "IP";
-    public static final String IP_MAC_KEY_SCHEME = "IP+MAC";
-    private static String scheme = null;
-    static {
-        scheme = System.getProperty("hosttracker.keyscheme");
-    }
-
-    public static String getScheme() {
-        return scheme;
-    }
-
-    public static IHostId create(InetAddress ip, DataLinkAddress mac) {
-        IHostId ipHostId = new IPHostId(ip);
-        if (scheme != null) {
-            switch (scheme) {
-
-            case DEFAULT_IP_KEY_SCHEME:
-                return ipHostId;
-            case IP_MAC_KEY_SCHEME:
-                IHostId ipMacHostId = new IPMacHostId(ip, mac);
-                return ipMacHostId;
-            default:
-                return ipHostId;
-
-            }
-        }
-        return ipHostId;
-    }
-
-}
diff --git a/opendaylight/adsal/hosttracker/api/src/main/java/org/opendaylight/controller/hosttracker/IHostId.java b/opendaylight/adsal/hosttracker/api/src/main/java/org/opendaylight/controller/hosttracker/IHostId.java
deleted file mode 100644 (file)
index 03f409e..0000000
+++ /dev/null
@@ -1,19 +0,0 @@
-/*
- * Copyright IBM Corporation, 2013.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.hosttracker;
-
-import java.io.Serializable;
-
-/*
- * Marker interface used by the key classes for their implementation
- * @author Deepak Udapudi
- */
-
-public interface IHostId extends Serializable {
-
-}
diff --git a/opendaylight/adsal/hosttracker/api/src/main/java/org/opendaylight/controller/hosttracker/IHostTrackerShell.java b/opendaylight/adsal/hosttracker/api/src/main/java/org/opendaylight/controller/hosttracker/IHostTrackerShell.java
deleted file mode 100644 (file)
index 5d11be4..0000000
+++ /dev/null
@@ -1,9 +0,0 @@
-package org.opendaylight.controller.hosttracker;
-
-import java.util.List;
-
-public interface IHostTrackerShell{
-
-    public List<String> dumpPendingArpReqList();
-    public List<String> dumpFailedArpReqList();
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/hosttracker/api/src/main/java/org/opendaylight/controller/hosttracker/IPHostId.java b/opendaylight/adsal/hosttracker/api/src/main/java/org/opendaylight/controller/hosttracker/IPHostId.java
deleted file mode 100644 (file)
index a6314e0..0000000
+++ /dev/null
@@ -1,84 +0,0 @@
-/*
- * Copyright IBM Corporation, 2013.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.hosttracker;
-
-import java.io.Serializable;
-import java.net.InetAddress;
-
-/*
- * IP only key class implementation using the marker interface IHostId
- * @author Deepak Udapudi
- */
-
-public class IPHostId implements IHostId, Serializable {
-    private static final long serialVersionUID = 1L;
-    private InetAddress ipAddress;
-
-    public InetAddress getIpAddress() {
-        return ipAddress;
-    }
-
-    public void setIpAddress(InetAddress ipAddress) {
-        this.ipAddress = ipAddress;
-    }
-
-    public IPHostId(InetAddress ipAddress) {
-        super();
-        this.ipAddress = ipAddress;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + ((ipAddress == null) ? 0 : ipAddress.hashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        IPHostId other = (IPHostId) obj;
-        if (ipAddress == null) {
-            if (other.ipAddress != null) {
-                return false;
-            }
-        } else if (!ipAddress.equals(other.ipAddress)) {
-            return false;
-        }
-        return true;
-    }
-
-    public static IHostId fromIP(InetAddress addr) {
-        return new IPHostId(addr);
-    }
-
-    /*
-     * (non-Javadoc)
-     *
-     * @see java.lang.Object#toString()
-     */
-    @Override
-    public String toString() {
-        StringBuilder builder = new StringBuilder();
-        builder.append("IP=[");
-        if (this.ipAddress != null) {
-            builder.append(this.ipAddress.getHostAddress());
-        }
-        builder.append("]");
-        return (builder.toString());
-    }
-}
diff --git a/opendaylight/adsal/hosttracker/api/src/main/java/org/opendaylight/controller/hosttracker/IPMacHostId.java b/opendaylight/adsal/hosttracker/api/src/main/java/org/opendaylight/controller/hosttracker/IPMacHostId.java
deleted file mode 100644 (file)
index 19f3f58..0000000
+++ /dev/null
@@ -1,110 +0,0 @@
-/*
- * Copyright IBM Corporation, 2013.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.hosttracker;
-
-import java.io.Serializable;
-import java.net.InetAddress;
-
-/*
- * IP + Mac key class implementation using the marker interface IHostId
- * @author Deepak Udapudi
- */
-
-import org.opendaylight.controller.sal.packet.address.DataLinkAddress;
-
-public class IPMacHostId implements IHostId, Serializable {
-
-    private static final long serialVersionUID = 1L;
-    private InetAddress ipAddress;
-    private DataLinkAddress macAddr;
-
-    public IPMacHostId(InetAddress ipAddress, DataLinkAddress macAddr) {
-        super();
-        this.ipAddress = ipAddress;
-        this.macAddr = macAddr;
-    }
-
-    public InetAddress getIpAddress() {
-        return ipAddress;
-    }
-
-    public void setIpAddress(InetAddress ipAddress) {
-        this.ipAddress = ipAddress;
-    }
-
-    public DataLinkAddress getMacAddr() {
-        return macAddr;
-    }
-
-    public void setMacAddr(DataLinkAddress macAddr) {
-        this.macAddr = macAddr;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + ((ipAddress == null) ? 0 : ipAddress.hashCode());
-        result = prime * result + ((macAddr == null) ? 0 : macAddr.hashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        IPMacHostId other = (IPMacHostId) obj;
-        if (ipAddress == null) {
-            if (other.ipAddress != null) {
-                return false;
-            }
-        } else if (!ipAddress.equals(other.ipAddress)) {
-            return false;
-        }
-        if (macAddr == null) {
-            if (other.macAddr != null) {
-                return false;
-            }
-        } else if (!macAddr.equals(other.macAddr)) {
-            return false;
-        }
-        return true;
-    }
-
-    public static IHostId fromIPAndMac(InetAddress ip, DataLinkAddress mac) {
-        return new IPMacHostId(ip, mac);
-    }
-
-    /*
-     * (non-Javadoc)
-     *
-     * @see java.lang.Object#toString()
-     */
-    @Override
-    public String toString() {
-        StringBuilder builder = new StringBuilder();
-        builder.append("IP=[");
-        if (this.ipAddress != null) {
-            builder.append(this.ipAddress.getHostAddress());
-        }
-        builder.append("]")
-               .append("MAC=[");
-        if (this.macAddr != null) {
-            builder.append(this.macAddr.toString());
-        }
-        builder.append("]");
-        return (builder.toString());
-    }
-}
diff --git a/opendaylight/adsal/hosttracker/api/src/main/java/org/opendaylight/controller/hosttracker/IfHostListener.java b/opendaylight/adsal/hosttracker/api/src/main/java/org/opendaylight/controller/hosttracker/IfHostListener.java
deleted file mode 100644 (file)
index 51d68d8..0000000
+++ /dev/null
@@ -1,31 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.hosttracker;
-
-import org.opendaylight.controller.hosttracker.hostAware.HostNodeConnector;
-
-/**
- * This interface defines the method to notify detected Host on the network. The
- * information includes Host's IP address, MAC address, switch ID, port, and
- * VLAN.
- *
- */
-
-public interface IfHostListener {
-    /**
-     * Learns new Hosts. Called by ArpHandler and implemented in
-     * HostTracker.java. If a Host is learned for the first time then adds it to
-     * the local database and informs other applications of coming up a new
-     * Host. For the hosts which it has already learned, it refreshes them.
-     *
-     * @param host
-     *            Host info encapsulated in HostNodeConnector class
-     */
-    public void hostListener(HostNodeConnector host);
-}
diff --git a/opendaylight/adsal/hosttracker/api/src/main/java/org/opendaylight/controller/hosttracker/IfIptoHost.java b/opendaylight/adsal/hosttracker/api/src/main/java/org/opendaylight/controller/hosttracker/IfIptoHost.java
deleted file mode 100644 (file)
index e70a6e1..0000000
+++ /dev/null
@@ -1,200 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.hosttracker;
-
-import java.net.InetAddress;
-import java.util.List;
-import java.util.Set;
-import java.util.concurrent.Future;
-
-import org.opendaylight.controller.hosttracker.hostAware.HostNodeConnector;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.utils.Status;
-
-/**
- * This interface defines the methods to retrieve information about learned
- * Hosts. Also provides methods to statically add/remove Hosts from the local
- * database.
- *
- */
-
-public interface IfIptoHost {
-    /**
-     * Applications call this interface methods to determine IP address to MAC
-     * binding and its connectivity to an OpenFlow switch in term of Node, Port,
-     * and VLAN. These bindings are learned dynamically as well as can be added
-     * statically through Northbound APIs. If a binding is unknown, then an ARP
-     * request is initiated immediately to discover the host.
-     *
-     * @param id
-     *            IP address and Mac Address combination encapsulated in IHostId
-     *            interface
-     * @return {@link org.opendaylight.controller.hosttracker.hostAware.HostNodeConnector}
-     *         Class that contains the Host info such as its MAC address, Switch
-     *         ID, port, VLAN. If Host is not found, returns NULL
-     */
-    public HostNodeConnector hostFind(IHostId id);
-
-    /**
-     * Applications call this interface methods to determine IP address to MAC
-     * binding and its connectivity to an OpenFlow switch in term of Node, Port,
-     * and VLAN. These bindings are learned dynamically as well as can be added
-     * statically through Northbound APIs. If a binding is unknown, then an ARP
-     * request is initiated immediately to discover the host.
-     *
-     * @param addr
-     *            IP address of the host
-     * @return {@link org.opendaylight.controller.hosttracker.hostAware.HostNodeConnector}
-     *         Class that contains the Host info such as its MAC address, Switch
-     *         ID, port, VLAN. If Host is not found, returns NULL
-     */
-    public HostNodeConnector hostFind(InetAddress addr);
-
-    /**
-     * Checks the local Host Database to see if a Host has been learned for a
-     * given IP address and Mac combination using the HostId.
-     *
-     * @param id
-     *            IP address and Mac Address combination encapsulated in IHostId
-     *            interface
-     * @return {@link org.opendaylight.controller.hosttracker.hostAware.HostNodeConnector}
-     *         Class that contains the Host info such as its MAC address, Switch
-     *         ID, port, VLAN. If Host is not found, returns NULL
-     *
-     */
-    public HostNodeConnector hostQuery(IHostId id);
-
-    /**
-     * Checks the local Host Database to see if a Host has been learned for a
-     * given IP address and Mac combination using the HostId.
-     *
-     * @param addr
-     *            IP address of the Host
-     * @return {@link org.opendaylight.controller.hosttracker.hostAware.HostNodeConnector}
-     *         Class that contains the Host info such as its MAC address, Switch
-     *         ID, port, VLAN. If Host is not found, returns NULL
-     *
-     */
-    public HostNodeConnector hostQuery(InetAddress addr);
-
-    /**
-     * Initiates an immediate discovery of the Host for a given Host id. This
-     * provides for the calling applications to block on the host discovery.
-     *
-     * @param id
-     *            IP address and Mac Address combination encapsulated in IHostId
-     *            interface
-     * @return Future
-     *         {@link org.opendaylight.controller.hosttracker.HostTrackerCallable}
-     */
-    public Future<HostNodeConnector> discoverHost(IHostId id);
-
-    /**
-     * Initiates an immediate discovery of the Host for a given Host id. This
-     * provides for the calling applications to block on the host discovery.
-     *
-     * @param addr
-     *            IP address of the host
-     * @return Future
-     *         {@link org.opendaylight.controller.hosttracker.HostTrackerCallable}
-     */
-    public Future<HostNodeConnector> discoverHost(InetAddress addr);
-
-    /**
-     * Returns the Network Hierarchy for a given Host. This API is typically
-     * used by applications like Hadoop for Rack Awareness functionality.
-     *
-     * @param id
-     *            IP address and Mac Address combination encapsulated in IHostId
-     *            interface
-     * @return List of String ArrayList containing the Hierarchies.
-     */
-    public List<List<String>> getHostNetworkHierarchy(IHostId id);
-
-    /**
-     * Returns the Network Hierarchy for a given Host. This API is typically
-     * used by applications like Hadoop for Rack Awareness functionality.
-     *
-     * @param addr
-     *            IP address of the host
-     * @return List of String ArrayList containing the Hierarchies.
-     */
-    public List<List<String>> getHostNetworkHierarchy(InetAddress addr);
-
-    /**
-     * Returns all the the Hosts either learned dynamically or added statically
-     * via Northbound APIs.
-     *
-     * @return Set of
-     *         {@link org.opendaylight.controller.hosttracker.hostAware.HostNodeConnector}
-     *         . Class that contains the Host info such as its MAC address,
-     *         Switch ID, port, VLAN.
-     */
-    public Set<HostNodeConnector> getAllHosts();
-
-    /**
-     * Returns all the "Active Hosts" learned "Statically" via Northbound APIs.
-     * These Hosts are categorized as "Active" because the Switch and Port they
-     * are connected to, are in up state.
-     *
-     * @return Set of
-     *         {@link org.opendaylight.controller.hosttracker.hostAware.HostNodeConnector}
-     *         . Class that contains the Host info such as MAC address, Switch
-     *         ID, port, VLAN. If Host is not found, returns NULL
-     */
-    public Set<HostNodeConnector> getActiveStaticHosts();
-
-    /**
-     * Returns all the "Inactive Hosts" learned "Statically" via Northbound
-     * APIs. These Hosts are categorized as "Inactive" because either the Switch
-     * or the Port they are connected to, is in down state.
-     *
-     * @return Set of HostNodeConnector
-     *         {@link org.opendaylight.controller.hosttracker.hostAware.HostNodeConnector}
-     *         . HostNodeConnector is Class that contains the Host info such as
-     *         its MAC address, OpenFlowNode ID, port, VLAN.
-     */
-    public Set<HostNodeConnector> getInactiveStaticHosts();
-
-    /**
-     * Hosts can be learned dynamically or added statically. This method allows
-     * the addition of a Host to the local database statically.
-     *
-     * @param networkAddress
-     *            IP Address of the Host
-     * @param dataLayerAddress
-     *            MAC Address of the Host
-     * @param nc
-     *            NodeConnector to which the host is attached
-     * @param vlan
-     *            VLAN the host belongs to (null or empty for no vlan)
-     * @return The status object as described in {@code Status} indicating the
-     *         result of this action.
-     */
-    public Status addStaticHost(String networkAddress, String dataLayerAddress, NodeConnector nc, String vlan);
-
-    /**
-     * Allows the deletion of statically learned Host
-     *
-     * @param networkAddress
-     * @return The status object as described in {@code Status} indicating the
-     *         result of this action.
-     */
-    public Status removeStaticHost(String networkAddress);
-
-    /**
-     * Allows the deletion of statically learned Host
-     *
-     * @param networkAddress
-     * @param macAddress
-     * @return The status object as described in {@code Status} indicating the
-     *         result of this action.
-     */
-    public Status removeStaticHostUsingIPAndMac(String networkAddress, String macAddress);
-}
diff --git a/opendaylight/adsal/hosttracker/api/src/main/java/org/opendaylight/controller/hosttracker/IfNewHostNotify.java b/opendaylight/adsal/hosttracker/api/src/main/java/org/opendaylight/controller/hosttracker/IfNewHostNotify.java
deleted file mode 100644 (file)
index ef900e4..0000000
+++ /dev/null
@@ -1,37 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.hosttracker;
-
-import org.opendaylight.controller.hosttracker.hostAware.HostNodeConnector;
-
-/**
- * This Interface defines the methods for client applications of Host Tracker to
- * get notifications when a new host is learned or existing host is removed from
- * the network.
- *
- */
-public interface IfNewHostNotify {
-    /**
-     * Notifies the HostTracker Clients that a new Host has been learned
-     *
-     * @param host
-     *            Host Info encapsulated in HostNodeConnector class
-     */
-    public void notifyHTClient(HostNodeConnector host);
-
-    /**
-     * Notifies the HostTracker Clients that a Host which was learned in the
-     * past has been removed either due to switch/port down event or due to ARP
-     * Aging
-     *
-     * @param host
-     *            Host Info encapsulated in HostNodeConnector class
-     */
-    public void notifyHTClientHostRemoved(HostNodeConnector host);
-}
diff --git a/opendaylight/adsal/hosttracker/api/src/main/java/org/opendaylight/controller/hosttracker/hostAware/HostNodeConnector.java b/opendaylight/adsal/hosttracker/api/src/main/java/org/opendaylight/controller/hosttracker/hostAware/HostNodeConnector.java
deleted file mode 100644 (file)
index f3f86a5..0000000
+++ /dev/null
@@ -1,221 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.hosttracker.hostAware;
-
-import java.net.Inet4Address;
-import java.net.Inet6Address;
-import java.net.InetAddress;
-import java.util.Arrays;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.sal.core.ConstructionException;
-import org.opendaylight.controller.sal.core.Host;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.packet.address.EthernetAddress;
-
-@XmlRootElement(name = "host")
-@XmlAccessorType(XmlAccessType.NONE)
-public class HostNodeConnector extends Host {
-    private static final long serialVersionUID = 1L;
-    @XmlElement
-    private NodeConnector nodeConnector;
-    @XmlElement
-    private short vlan;
-    @XmlElement
-    private boolean staticHost;
-    private short arpSendCountDown;
-
-    /**
-     * Private constructor used for JAXB mapping
-     */
-    @SuppressWarnings("unused")
-    private HostNodeConnector() {
-    }
-
-    public HostNodeConnector(InetAddress ip) throws ConstructionException {
-        this(ip, null);
-    }
-
-    public HostNodeConnector(InetAddress ip, NodeConnector nc)
-            throws ConstructionException {
-        this(new EthernetAddress(new byte[] { (byte) 0x00, (byte) 0x00,
-                (byte) 0x00, (byte) 0x00, (byte) 0x00, (byte) 0x00 }), ip, nc,
-                (short) 0);
-    }
-
-    public HostNodeConnector(byte[] mac, InetAddress ip, NodeConnector nc,
-            short vlan) throws ConstructionException {
-        this(new EthernetAddress(mac.clone()), ip, nc, vlan);
-    }
-
-    public HostNodeConnector(EthernetAddress eaddr, InetAddress naddr,
-            NodeConnector nc, short vlan) throws ConstructionException {
-        super(eaddr, naddr);
-        this.nodeConnector = nc;
-        this.vlan = vlan;
-    }
-
-    /**
-     * @return the NodeConnector
-     */
-    public NodeConnector getnodeConnector() {
-        return this.nodeConnector;
-    }
-
-    /**
-     * @return the Node
-     */
-    public Node getnodeconnectorNode() {
-        return this.nodeConnector.getNode();
-    }
-
-    /**
-     * @return the DataLayerAddress
-     */
-    public byte[] getDataLayerAddressBytes() {
-        byte[] macaddr = null;
-        if (getDataLayerAddress() instanceof EthernetAddress) {
-            EthernetAddress e = (EthernetAddress) getDataLayerAddress();
-            macaddr = e.getValue();
-        }
-        return macaddr;
-    }
-
-    /**
-     * @return the vlan
-     */
-    public short getVlan() {
-        return this.vlan;
-    }
-
-    public boolean isStaticHost() {
-        return this.staticHost;
-    }
-
-    public HostNodeConnector setStaticHost(boolean statically_learned) {
-        this.staticHost = statically_learned;
-        return this;
-    }
-
-    public HostNodeConnector initArpSendCountDown() {
-        this.arpSendCountDown = 24;
-        return this;
-    }
-
-    public short getArpSendCountDown() {
-        return (this.arpSendCountDown);
-    }
-
-    public HostNodeConnector setArpSendCountDown(short cntdown) {
-        this.arpSendCountDown = cntdown;
-        return this;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = super.hashCode();
-        result = prime * result
-                + ((nodeConnector == null) ? 0 : nodeConnector.hashCode());
-        result = prime * result + (staticHost ? 1231 : 1237);
-        result = prime * result + vlan;
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (!super.equals(obj)) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        HostNodeConnector other = (HostNodeConnector) obj;
-        if (nodeConnector == null) {
-            if (other.nodeConnector != null) {
-                return false;
-            }
-        } else if (!nodeConnector.equals(other.nodeConnector)) {
-            return false;
-        }
-        if (staticHost != other.staticHost) {
-            return false;
-        }
-        if (vlan != other.vlan) {
-            return false;
-        }
-        return true;
-    }
-
-    public boolean equalsByIP(InetAddress networkAddress) {
-        return (this.getNetworkAddress().equals(networkAddress));
-    }
-
-    public boolean isRewriteEnabled() {
-        byte[] emptyArray = new byte[] { (byte) 0x00, (byte) 0x00, (byte) 0x00,
-                (byte) 0x00, (byte) 0x00, (byte) 0x00 };
-        byte[] macaddr = null;
-        if (getDataLayerAddress() instanceof EthernetAddress) {
-            EthernetAddress e = (EthernetAddress) getDataLayerAddress();
-            macaddr = e.getValue();
-        }
-        if (macaddr == null) {
-            return false;
-        }
-        return !Arrays.equals(emptyArray, macaddr);
-    }
-
-    /*
-     * (non-Javadoc)
-     *
-     * @see java.lang.Object#toString()
-     */
-    @Override
-    public String toString() {
-        StringBuilder builder = new StringBuilder();
-        builder.append("HostNodeConnector [");
-        if (nodeConnector != null) {
-            builder.append("nodeConnector=")
-                    .append(nodeConnector)
-                    .append(", ");
-        }
-        builder.append("vlan=")
-                .append(vlan)
-                .append(", staticHost=")
-                .append(staticHost)
-                .append(", arpSendCountDown=")
-                .append(arpSendCountDown)
-                .append("]");
-        return builder.toString();
-    }
-
-    public boolean isV4Host() {
-        return (getNetworkAddress() instanceof Inet4Address);
-    }
-
-    public boolean isV6Host() {
-        return (getNetworkAddress() instanceof Inet6Address);
-    }
-
-    public String toJson() {
-        return "{\"host\":\"" + super.toString() + "\", " + "\"vlan\":\""
-                + String.valueOf(vlan) + "\",\"NodeConnector\":\""
-                + nodeConnector.toString() + "\"," + "\"static\":\""
-                + String.valueOf(isStaticHost()) + "\"}";
-    }
-
-}
diff --git a/opendaylight/adsal/hosttracker/api/src/main/java/org/opendaylight/controller/hosttracker/hostAware/IHostFinder.java b/opendaylight/adsal/hosttracker/api/src/main/java/org/opendaylight/controller/hosttracker/hostAware/IHostFinder.java
deleted file mode 100644 (file)
index abe7518..0000000
+++ /dev/null
@@ -1,40 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.hosttracker.hostAware;
-
-import java.net.InetAddress;
-
-/**
- * This Interface defines the methods to trigger the discovery of a Host and to
- * probe if a learned Host is still in the network.
- *
- *
- *
- */
-public interface IHostFinder {
-    /**
-     * This method initiates the discovery of a host based on its IP address.
-     * This is triggered by query of an application to the HostTracker. The
-     * requested IP address doesn't exist in the local database at this point.
-     *
-     * @param networkAddress
-     *            IP Address encapsulated in InetAddress class
-     *
-     */
-    public void find(InetAddress networkAddress);
-
-    /**
-     * This method is called by HostTracker to see if a learned Host is still in
-     * the network. Used mostly for ARP Aging.
-     *
-     * @param host
-     *            The Host that needs to be probed
-     */
-    public void probe(HostNodeConnector host);
-}
diff --git a/opendaylight/adsal/hosttracker/api/src/test/java/org/opendaylight/controller/hosttracker/hostAware/HostNodeConnectorTest.java b/opendaylight/adsal/hosttracker/api/src/test/java/org/opendaylight/controller/hosttracker/hostAware/HostNodeConnectorTest.java
deleted file mode 100644 (file)
index 96cf308..0000000
+++ /dev/null
@@ -1,92 +0,0 @@
-/*\r
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.\r
- *\r
- * This program and the accompanying materials are made available under the\r
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,\r
- * and is available at http://www.eclipse.org/legal/epl-v10.html\r
- */\r
-\r
-package org.opendaylight.controller.hosttracker.hostAware;\r
-\r
-import java.net.InetAddress;\r
-import java.net.UnknownHostException;\r
-\r
-import org.junit.Assert;\r
-import org.junit.Test;\r
-import org.opendaylight.controller.sal.core.ConstructionException;\r
-import org.opendaylight.controller.sal.core.Node;\r
-import org.opendaylight.controller.sal.core.NodeConnector;\r
-import org.opendaylight.controller.sal.packet.address.EthernetAddress;\r
-import org.opendaylight.controller.sal.utils.NodeConnectorCreator;\r
-import org.opendaylight.controller.sal.utils.NodeCreator;\r
-\r
-public class HostNodeConnectorTest {\r
-\r
-    @Test\r
-    public void testHostNodeConnector() throws UnknownHostException {\r
-        HostNodeConnector hostnodeconnector_1, hostnodeconnector_2, hostnodeconnector_3;\r
-        InetAddress hostIP_1 = InetAddress.getByName("192.168.0.8");\r
-        InetAddress hostIP_2 = InetAddress\r
-                .getByName("2001:420:281:1004:e123:e688:d655:a1b0");\r
-        InetAddress hostIP_3 = InetAddress.getByName("192.168.0.28");\r
-        byte[] hostMAC_2 = new byte[] { (byte) 0x11, (byte) 0x22, (byte) 0x33,\r
-                (byte) 0x22, (byte) 0x22, (byte) 0x22 };\r
-        byte[] hostMAC_3 = new byte[] { (byte) 0x11, (byte) 0x22, (byte) 0x33,\r
-                (byte) 0x33, (byte) 0x33, (byte) 0x33 };\r
-\r
-        Node node = NodeCreator.createOFNode(1L);\r
-        NodeConnector nc1 = NodeConnectorCreator.createOFNodeConnector(\r
-                (short) 2, node);\r
-        NodeConnector nc2 = NodeConnectorCreator.createOFNodeConnector(\r
-                (short) 1, node);\r
-\r
-        try {\r
-            hostnodeconnector_1 = new HostNodeConnector(hostIP_1);\r
-            Assert.assertTrue(hostnodeconnector_1.equalsByIP(hostIP_1));\r
-            Assert.assertTrue(hostnodeconnector_1.isV4Host());\r
-            Assert.assertTrue(hostnodeconnector_1.equalsByIP(hostIP_1));\r
-        } catch (ConstructionException e) {\r
-            Assert.assertTrue(false);\r
-        }\r
-\r
-        try {\r
-            hostnodeconnector_2 = new HostNodeConnector(hostMAC_2, hostIP_2,\r
-                    nc1, (short) 2);\r
-            Assert.assertTrue(hostnodeconnector_2.isV6Host());\r
-            Assert.assertTrue(hostnodeconnector_2.getnodeConnector()\r
-                    .equals(nc1));\r
-            Assert.assertTrue(hostnodeconnector_2.getnodeconnectorNode()\r
-                    .equals(node));\r
-            Assert.assertTrue(node.equals(hostnodeconnector_2\r
-                    .getnodeconnectorNode()));\r
-        } catch (ConstructionException e) {\r
-            Assert.assertTrue(false);\r
-        }\r
-\r
-        try {\r
-            hostnodeconnector_3 = new HostNodeConnector(new EthernetAddress(\r
-                    hostMAC_3), hostIP_3, nc2, (short) 3);\r
-            byte[] hostMAC_3_rb = hostnodeconnector_3\r
-                    .getDataLayerAddressBytes();\r
-            HostNodeConnector hostnodeconnector_3rb = new HostNodeConnector(\r
-                    new EthernetAddress(hostMAC_3_rb), hostIP_3, nc2, (short) 3);\r
-            Assert.assertTrue(hostnodeconnector_3.equals(hostnodeconnector_3rb));\r
-\r
-            Assert.assertTrue(hostnodeconnector_3.getVlan() == (short) 3);\r
-\r
-            hostnodeconnector_3.setStaticHost(true);\r
-            Assert.assertTrue(hostnodeconnector_3.isStaticHost());\r
-\r
-            Assert.assertTrue(hostnodeconnector_3.isRewriteEnabled());\r
-\r
-            hostnodeconnector_3.initArpSendCountDown().setArpSendCountDown(\r
-                    (short) 10);\r
-            Assert.assertTrue(hostnodeconnector_3.getArpSendCountDown() == (short) 10);\r
-\r
-        } catch (ConstructionException e) {\r
-            Assert.assertTrue(false);\r
-        }\r
-\r
-    }\r
-\r
-}\r
diff --git a/opendaylight/adsal/hosttracker/implementation/pom.xml b/opendaylight/adsal/hosttracker/implementation/pom.xml
deleted file mode 100644 (file)
index 50bb267..0000000
+++ /dev/null
@@ -1,120 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-  <artifactId>hosttracker.implementation</artifactId>
-  <version>0.7.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-
-  <properties>
-    <!-- Sonar properties using jacoco to retrieve integration test results -->
-    <sonar.dynamicAnalysis>reuseReports</sonar.dynamicAnalysis>
-    <sonar.jacoco.Reportpath>target/jacoco.exec</sonar.jacoco.Reportpath>
-    <sonar.jacoco.itReportPath>target/jacoco-it.exec</sonar.jacoco.itReportPath>
-  </properties>
-  <dependencies>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>clustering.services</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>hosttracker</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>switchmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>topologymanager</artifactId>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <pluginManagement>
-      <plugins>
-        <plugin>
-          <groupId>org.jacoco</groupId>
-          <artifactId>jacoco-maven-plugin</artifactId>
-          <version>${jacoco.version}</version>
-        </plugin>
-      </plugins>
-    </pluginManagement>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Export-Package></Export-Package>
-            <Import-Package>org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.sal.utils,
-              org.opendaylight.controller.sal.topology,
-              org.opendaylight.controller.hosttracker,
-              org.opendaylight.controller.topologymanager,
-              org.opendaylight.controller.sal.packet.address,
-              org.opendaylight.controller.switchmanager,
-              org.opendaylight.controller.clustering.services,
-              org.opendaylight.controller.hosttracker.hostAware,
-              javax.xml.bind.annotation,
-              javax.xml.bind,
-              org.apache.felix.dm,
-              org.apache.commons.lang3.builder,
-              org.osgi.service.component,
-              org.slf4j,
-              org.eclipse.osgi.framework.console,
-              org.osgi.framework</Import-Package>
-            <Bundle-Activator>org.opendaylight.controller.hosttracker.internal.Activator</Bundle-Activator>
-            <Service-Component></Service-Component>
-          </instructions>
-          <manifestLocation>${project.basedir}/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-      <plugin>
-        <groupId>org.jacoco</groupId>
-        <artifactId>jacoco-maven-plugin</artifactId>
-        <configuration>
-          <includes>
-            <include>org.opendaylight.controller.*</include>
-          </includes>
-        </configuration>
-        <executions>
-          <execution>
-            <id>pre-test</id>
-            <goals>
-              <goal>prepare-agent</goal>
-            </goals>
-          </execution>
-          <execution>
-            <id>post-test</id>
-            <goals>
-              <goal>report</goal>
-            </goals>
-            <phase>test</phase>
-          </execution>
-        </executions>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/hosttracker/implementation/src/main/java/org/opendaylight/controller/hosttracker/internal/Activator.java b/opendaylight/adsal/hosttracker/implementation/src/main/java/org/opendaylight/controller/hosttracker/internal/Activator.java
deleted file mode 100644 (file)
index 7e52771..0000000
+++ /dev/null
@@ -1,108 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.hosttracker.internal;
-
-import java.util.Dictionary;
-import java.util.HashSet;
-import java.util.Hashtable;
-import java.util.Set;
-
-import org.apache.felix.dm.Component;
-import org.opendaylight.controller.clustering.services.ICacheUpdateAware;
-import org.opendaylight.controller.clustering.services.IClusterContainerServices;
-import org.opendaylight.controller.hosttracker.IHostTrackerShell;
-import org.opendaylight.controller.hosttracker.IfHostListener;
-import org.opendaylight.controller.hosttracker.IfIptoHost;
-import org.opendaylight.controller.hosttracker.IfNewHostNotify;
-import org.opendaylight.controller.hosttracker.hostAware.IHostFinder;
-import org.opendaylight.controller.sal.core.ComponentActivatorAbstractBase;
-import org.opendaylight.controller.switchmanager.IInventoryListener;
-import org.opendaylight.controller.switchmanager.ISwitchManager;
-import org.opendaylight.controller.switchmanager.ISwitchManagerAware;
-import org.opendaylight.controller.topologymanager.ITopologyManager;
-import org.opendaylight.controller.topologymanager.ITopologyManagerAware;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-public class Activator extends ComponentActivatorAbstractBase {
-    protected static final Logger logger = LoggerFactory
-            .getLogger(Activator.class);
-
-
-    /**
-     * Function that is used to communicate to dependency manager the list of
-     * known implementations for services inside a container
-     *
-     *
-     * @return An array containing all the CLASS objects that will be
-     *         instantiated in order to get an fully working implementation
-     *         Object
-     */
-    @Override
-    public Object[] getImplementations() {
-        Object[] res = { HostTracker.class };
-        return res;
-    }
-
-    /**
-     * Function that is called when configuration of the dependencies is
-     * required.
-     *
-     * @param c
-     *            dependency manager Component object, used for configuring the
-     *            dependencies exported and imported
-     * @param imp
-     *            Implementation class that is being configured, needed as long
-     *            as the same routine can configure multiple implementations
-     * @param containerName
-     *            The containerName being configured, this allow also optional
-     *            per-container different behavior if needed, usually should not
-     *            be the case though.
-     */
-    @Override
-    public void configureInstance(Component c, Object imp, String containerName) {
-        if (imp.equals(HostTracker.class)) {
-            Dictionary<String, Object> props = new Hashtable<String, Object>();
-            Set<String> propSet = new HashSet<String>();
-            propSet.add(HostTracker.ACTIVE_HOST_CACHE);
-            props.put("cachenames", propSet);
-
-            // export the service
-            c.setInterface(
-                    new String[] { ISwitchManagerAware.class.getName(),
-                            IInventoryListener.class.getName(),
-                            IfIptoHost.class.getName(),
-                            IfHostListener.class.getName(),
-                            IHostTrackerShell.class.getName(),
-                            ITopologyManagerAware.class.getName(),
-                            ICacheUpdateAware.class.getName() }, props);
-
-            c.add(createContainerServiceDependency(containerName)
-                    .setService(ISwitchManager.class)
-                    .setCallbacks("setSwitchManager", "unsetSwitchManager")
-                    .setRequired(true));
-            c.add(createContainerServiceDependency(containerName)
-                    .setService(IClusterContainerServices.class)
-                    .setCallbacks("setClusterContainerService",
-                            "unsetClusterContainerService").setRequired(true));
-            c.add(createContainerServiceDependency(containerName)
-                    .setService(IHostFinder.class)
-                    .setCallbacks("setArpHandler", "unsetArpHandler")
-                    .setRequired(false));
-            c.add(createContainerServiceDependency(containerName)
-                    .setService(ITopologyManager.class)
-                    .setCallbacks("setTopologyManager", "unsetTopologyManager")
-                    .setRequired(false));
-            c.add(createContainerServiceDependency(containerName)
-                    .setService(IfNewHostNotify.class)
-                    .setCallbacks("setnewHostNotify", "unsetnewHostNotify")
-                    .setRequired(false));
-        }
-    }
-}
diff --git a/opendaylight/adsal/hosttracker/implementation/src/main/java/org/opendaylight/controller/hosttracker/internal/HostTracker.java b/opendaylight/adsal/hosttracker/implementation/src/main/java/org/opendaylight/controller/hosttracker/internal/HostTracker.java
deleted file mode 100644 (file)
index f728b35..0000000
+++ /dev/null
@@ -1,1642 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.hosttracker.internal;
-
-import java.net.InetAddress;
-import java.net.UnknownHostException;
-import java.util.ArrayList;
-import java.util.Collections;
-import java.util.Dictionary;
-import java.util.EnumSet;
-import java.util.HashSet;
-import java.util.List;
-import java.util.Map;
-import java.util.Map.Entry;
-import java.util.Set;
-import java.util.Timer;
-import java.util.TimerTask;
-import java.util.concurrent.Callable;
-import java.util.concurrent.ConcurrentHashMap;
-import java.util.concurrent.ConcurrentMap;
-import java.util.concurrent.CopyOnWriteArraySet;
-import java.util.concurrent.ExecutorService;
-import java.util.concurrent.Executors;
-import java.util.concurrent.Future;
-
-import org.apache.felix.dm.Component;
-import org.eclipse.osgi.framework.console.CommandInterpreter;
-import org.eclipse.osgi.framework.console.CommandProvider;
-import org.opendaylight.controller.clustering.services.CacheConfigException;
-import org.opendaylight.controller.clustering.services.CacheExistException;
-import org.opendaylight.controller.clustering.services.ICacheUpdateAware;
-import org.opendaylight.controller.clustering.services.IClusterContainerServices;
-import org.opendaylight.controller.clustering.services.IClusterServices;
-import org.opendaylight.controller.hosttracker.HostIdFactory;
-import org.opendaylight.controller.hosttracker.IHostId;
-import org.opendaylight.controller.hosttracker.IHostTrackerShell;
-import org.opendaylight.controller.hosttracker.IPHostId;
-import org.opendaylight.controller.hosttracker.IPMacHostId;
-import org.opendaylight.controller.hosttracker.IfHostListener;
-import org.opendaylight.controller.hosttracker.IfIptoHost;
-import org.opendaylight.controller.hosttracker.IfNewHostNotify;
-import org.opendaylight.controller.hosttracker.hostAware.HostNodeConnector;
-import org.opendaylight.controller.hosttracker.hostAware.IHostFinder;
-import org.opendaylight.controller.sal.core.ConstructionException;
-import org.opendaylight.controller.sal.core.Edge;
-import org.opendaylight.controller.sal.core.Host;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.core.State;
-import org.opendaylight.controller.sal.core.Tier;
-import org.opendaylight.controller.sal.core.UpdateType;
-import org.opendaylight.controller.sal.packet.address.DataLinkAddress;
-import org.opendaylight.controller.sal.packet.address.EthernetAddress;
-import org.opendaylight.controller.sal.topology.TopoEdgeUpdate;
-import org.opendaylight.controller.sal.utils.GlobalConstants;
-import org.opendaylight.controller.sal.utils.HexEncode;
-import org.opendaylight.controller.sal.utils.NetUtils;
-import org.opendaylight.controller.sal.utils.NodeCreator;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.sal.utils.StatusCode;
-import org.opendaylight.controller.switchmanager.IInventoryListener;
-import org.opendaylight.controller.switchmanager.ISwitchManager;
-import org.opendaylight.controller.switchmanager.ISwitchManagerAware;
-import org.opendaylight.controller.switchmanager.Subnet;
-import org.opendaylight.controller.topologymanager.ITopologyManager;
-import org.opendaylight.controller.topologymanager.ITopologyManagerAware;
-import org.osgi.framework.BundleContext;
-import org.osgi.framework.FrameworkUtil;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * @file HostTracker.java This class tracks the location of IP Hosts as to which
- *       Switch, Port, VLAN, they are connected to, as well as their MAC
- *       address. This is done dynamically as well as statically. The dynamic
- *       mechanism consists of listening to ARP messages as well sending ARP
- *       requests. Static mechanism consists of Northbound APIs to add or remove
- *       the hosts from the local database. ARP aging is also implemented to age
- *       out dynamically learned hosts. Interface methods are provided for other
- *       applications to 1. Query the local database for a single host 2. Get a
- *       list of all hosts 3. Get notification if a host is learned/added or
- *       removed the database
- */
-
-/***
- *
- * HostTracker db key scheme implementation support. Support has been added for
- * IP only or IP + MAC scheme as of now. User can use either of the schemes
- * based on the configuration done in config.ini file. By default IP only key
- * scheme is choosen. The attribute to be set in config.ini is
- * hosttracker.keyscheme. It could have a value of 0 or 1 as of now. 0 is for IP
- * only scheme. 1 is for IP + MAC scheme.
- *
- *
- */
-
-public class HostTracker implements IfIptoHost, IfHostListener, IHostTrackerShell, ISwitchManagerAware, IInventoryListener,
-        ITopologyManagerAware, ICacheUpdateAware<IHostId, HostNodeConnector>, CommandProvider {
-    static final String ACTIVE_HOST_CACHE = "hosttracker.ActiveHosts";
-    static final String INACTIVE_HOST_CACHE = "hosttracker.InactiveHosts";
-    private static final Logger logger = LoggerFactory.getLogger(HostTracker.class);
-    protected final Set<IHostFinder> hostFinders = new CopyOnWriteArraySet<IHostFinder>();
-    protected ConcurrentMap<IHostId, HostNodeConnector> hostsDB;
-    /*
-     * Following is a list of hosts which have been requested by NB APIs to be
-     * added, but either the switch or the port is not sup, so they will be
-     * added here until both come up
-     */
-    private ConcurrentMap<NodeConnector, HostNodeConnector> inactiveStaticHosts;
-    private final Set<IfNewHostNotify> newHostNotify = Collections.synchronizedSet(new HashSet<IfNewHostNotify>());
-
-    private ITopologyManager topologyManager;
-    protected IClusterContainerServices clusterContainerService = null;
-    protected ISwitchManager switchManager = null;
-    private Timer timer;
-    private Timer arpRefreshTimer;
-    private String containerName = null;
-    private ExecutorService executor;
-    protected boolean stopping;
-    private static boolean hostRefresh = true;
-    private static int hostRetryCount = 5;
-    private String keyScheme = null;
-
-    private static class ARPPending {
-        protected IHostId hostId;
-        protected short sent_count;
-        protected HostTrackerCallable hostTrackerCallable;
-
-        public IHostId getHostId() {
-            return hostId;
-        }
-
-        public short getSent_count() {
-            return sent_count;
-        }
-
-        public HostTrackerCallable getHostTrackerCallable() {
-            return hostTrackerCallable;
-        }
-
-        public void setHostId(IHostId id) {
-            this.hostId = id;
-        }
-
-        public void setSent_count(short count) {
-            this.sent_count = count;
-        }
-
-        public void setHostTrackerCallable(HostTrackerCallable callable) {
-            hostTrackerCallable = callable;
-        }
-    }
-
-    // This list contains the hosts for which ARP requests are being sent
-    // periodically
-    ConcurrentMap<IHostId, ARPPending> ARPPendingList;
-    /*
-     * This list below contains the hosts which were initially in ARPPendingList
-     * above, but ARP response didn't come from there hosts after multiple
-     * attempts over 8 seconds. The assumption is that the response didn't come
-     * back due to one of the following possibilities: 1. The L3 interface
-     * wasn't created for this host in the controller. This would cause
-     * arphandler not to know where to send the ARP 2. The host facing port is
-     * down 3. The IP host doesn't exist or is not responding to ARP requests
-     *
-     * Conditions 1 and 2 above can be recovered if ARP is sent when the
-     * relevant L3 interface is added or the port facing host comes up. Whenever
-     * L3 interface is added or host facing port comes up, ARP will be sent to
-     * hosts in this list.
-     *
-     * We can't recover from condition 3 above
-     */
-    ConcurrentMap<IHostId, ARPPending> failedARPReqList;
-
-    public HostTracker() {
-    }
-
-    private void startUp() {
-        nonClusterObjectCreate();
-        allocateCache();
-        retrieveCache();
-        stopping = false;
-
-        timer = new Timer();
-        timer.schedule(new OutStandingARPHandler(), 4000, 4000);
-        executor = Executors.newFixedThreadPool(2);
-        /* ARP Refresh Timer to go off every 5 seconds to implement ARP aging */
-        arpRefreshTimer = new Timer();
-        arpRefreshTimer.schedule(new ARPRefreshHandler(), 5000, 5000);
-        keyScheme = HostIdFactory.getScheme();
-        logger.debug("startUp: Caches created, timers started");
-    }
-
-    private void allocateCache() {
-        if (this.clusterContainerService == null) {
-            logger.error("un-initialized clusterContainerService, can't create cache");
-            return;
-        }
-        logger.debug("Creating Cache for HostTracker");
-        try {
-            this.clusterContainerService.createCache(ACTIVE_HOST_CACHE,
-                    EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-            this.clusterContainerService.createCache(INACTIVE_HOST_CACHE,
-                    EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-        } catch (CacheConfigException cce) {
-            logger.error("Cache couldn't be created for HostTracker -  check cache mode");
-        } catch (CacheExistException cce) {
-            logger.error("Cache for HostTracker already exists, destroy and recreate");
-        }
-        logger.debug("Cache successfully created for HostTracker");
-    }
-
-    @SuppressWarnings({ "unchecked" })
-    private void retrieveCache() {
-        if (this.clusterContainerService == null) {
-            logger.error("un-initialized clusterContainerService, can't retrieve cache");
-            return;
-        }
-        logger.debug("Retrieving cache for HostTrackerAH");
-        hostsDB = (ConcurrentMap<IHostId, HostNodeConnector>) this.clusterContainerService.getCache(ACTIVE_HOST_CACHE);
-        if (hostsDB == null) {
-            logger.error("Cache couldn't be retrieved for HostTracker");
-        }
-        logger.debug("Cache was successfully retrieved for HostTracker");
-        logger.debug("Retrieving cache for HostTrackerIH");
-        inactiveStaticHosts = (ConcurrentMap<NodeConnector, HostNodeConnector>) this.clusterContainerService
-                .getCache(INACTIVE_HOST_CACHE);
-        if (inactiveStaticHosts == null) {
-            logger.error("Cache couldn't be retrieved for HostTrackerIH");
-        }
-        logger.debug("Cache was successfully retrieved for HostTrackerIH");
-    }
-
-    public void nonClusterObjectCreate() {
-        hostsDB = new ConcurrentHashMap<IHostId, HostNodeConnector>();
-        inactiveStaticHosts = new ConcurrentHashMap<NodeConnector, HostNodeConnector>();
-        ARPPendingList = new ConcurrentHashMap<IHostId, ARPPending>();
-        failedARPReqList = new ConcurrentHashMap<IHostId, ARPPending>();
-    }
-
-    public void shutDown() {
-    }
-
-    public void setnewHostNotify(IfNewHostNotify obj) {
-        this.newHostNotify.add(obj);
-    }
-
-    public void unsetnewHostNotify(IfNewHostNotify obj) {
-        this.newHostNotify.remove(obj);
-    }
-
-    public void setArpHandler(IHostFinder hostFinder) {
-        this.hostFinders.add(hostFinder);
-    }
-
-    public void unsetArpHandler(IHostFinder hostFinder) {
-        logger.debug("Arp Handler Service removed!");
-        this.hostFinders.remove(hostFinder);
-    }
-
-    public void setTopologyManager(ITopologyManager s) {
-        this.topologyManager = s;
-    }
-
-    public void unsetTopologyManager(ITopologyManager s) {
-        if (this.topologyManager == s) {
-            logger.debug("Topology Manager Service removed!");
-            this.topologyManager = null;
-        }
-    }
-
-    private boolean hostExists(HostNodeConnector host) {
-        IHostId id = HostIdFactory.create(host.getNetworkAddress(), host.getDataLayerAddress());
-        HostNodeConnector lhost = hostsDB.get(id);
-        return host.equals(lhost);
-    }
-
-    private HostNodeConnector getHostFromOnActiveDB(IHostId id) {
-        return hostsDB.get(id);
-    }
-
-    private Entry<NodeConnector, HostNodeConnector> getHostFromInactiveDB(IHostId id) {
-        for (Entry<NodeConnector, HostNodeConnector> entry : inactiveStaticHosts.entrySet()) {
-            HostNodeConnector hnc = entry.getValue();
-            IHostId cmpId = HostIdFactory.create(hnc.getNetworkAddress(), hnc.getDataLayerAddress());
-            if (cmpId.equals(id)) {
-                logger.debug("getHostFromInactiveDB(): Inactive Host found for ID:{} ", decodeIPFromId(id));
-                return entry;
-            }
-        }
-        logger.debug("getHostFromInactiveDB() Inactive Host Not found for ID: {}", decodeIPFromId(id));
-        return null;
-    }
-
-    private void removeHostFromInactiveDB(IHostId id) {
-        NodeConnector nodeConnector = null;
-        for (Entry<NodeConnector, HostNodeConnector> entry : inactiveStaticHosts.entrySet()) {
-            HostNodeConnector hnc = entry.getValue();
-            IHostId cmpId = HostIdFactory.create(hnc.getNetworkAddress(), hnc.getDataLayerAddress());
-            if (cmpId.equals(id)) {
-                nodeConnector = entry.getKey();
-                break;
-            }
-        }
-        if (nodeConnector != null) {
-            inactiveStaticHosts.remove(nodeConnector);
-            logger.debug("removeHostFromInactiveDB(): Host Removed for IP: {}", decodeIPFromId(id));
-            return;
-        }
-        logger.debug("removeHostFromInactiveDB(): Host Not found for IP: {}", decodeIPFromId(id));
-    }
-
-    protected boolean hostMoved(HostNodeConnector host) {
-        IHostId id = HostIdFactory.create(host.getNetworkAddress(), host.getDataLayerAddress());
-        if (hostQuery(id) != null) {
-            return true;
-        }
-        return false;
-    }
-
-    @Override
-    public HostNodeConnector hostQuery(IHostId id) {
-        return hostsDB.get(id);
-    }
-
-    @Override
-    public Future<HostNodeConnector> discoverHost(IHostId id) {
-        if (executor == null) {
-            logger.debug("discoverHost: Null executor");
-            return null;
-        }
-        Callable<HostNodeConnector> worker = new HostTrackerCallable(this, id);
-        Future<HostNodeConnector> submit = executor.submit(worker);
-        return submit;
-    }
-
-    @Override
-    public HostNodeConnector hostFind(IHostId id) {
-        /*
-         * Sometimes at boot with containers configured in the startup we hit
-         * this path (from TIF) when hostFinder has not been set yet Caller
-         * already handles the null return
-         */
-
-        if (hostFinders.isEmpty()) {
-            logger.debug("No available host finders, exiting hostFind()");
-            return null;
-        }
-
-        HostNodeConnector host = hostQuery(id);
-        if (host != null) {
-            logger.debug("hostFind(): Host found for IP: {}", id);
-            return host;
-        }
-
-        /* Add this host to ARPPending List for any potential retries */
-
-        addToARPPendingList(id);
-        logger.debug("hostFind(): Host Not Found for IP: {}, Inititated Host Discovery ...", id);
-
-        /* host is not found, initiate a discovery */
-        for (IHostFinder hf : hostFinders) {
-            InetAddress addr = decodeIPFromId(id);
-            hf.find(addr);
-        }
-        return null;
-    }
-
-    @Override
-    public Set<HostNodeConnector> getAllHosts() {
-        Set<HostNodeConnector> allHosts = new HashSet<HostNodeConnector>(hostsDB.values());
-        return allHosts;
-    }
-
-    @Override
-    public Set<HostNodeConnector> getActiveStaticHosts() {
-        Set<HostNodeConnector> list = new HashSet<HostNodeConnector>();
-        for (Entry<IHostId, HostNodeConnector> entry : hostsDB.entrySet()) {
-            HostNodeConnector host = entry.getValue();
-            if (host.isStaticHost()) {
-                list.add(host);
-            }
-        }
-        return list;
-    }
-
-    @Override
-    public Set<HostNodeConnector> getInactiveStaticHosts() {
-        Set<HostNodeConnector> list = new HashSet<HostNodeConnector>(inactiveStaticHosts.values());
-        return list;
-    }
-
-    private void addToARPPendingList(IHostId id) {
-        ARPPending arphost = new ARPPending();
-
-        arphost.setHostId(id);
-        arphost.setSent_count((short) 1);
-        ARPPendingList.put(id, arphost);
-        logger.debug("Host Added to ARPPending List, IP: {}", decodeIPFromId(id));
-
-    }
-
-    public void setCallableOnPendingARP(IHostId id, HostTrackerCallable callable) {
-        ARPPending arphost;
-        for (Entry<IHostId, ARPPending> entry : ARPPendingList.entrySet()) {
-            arphost = entry.getValue();
-            if (arphost.getHostId().equals(id)) {
-                arphost.setHostTrackerCallable(callable);
-            }
-        }
-    }
-
-    private void processPendingARPReqs(IHostId id) {
-        ARPPending arphost;
-
-        if ((arphost = ARPPendingList.remove(id)) != null) {
-            // Remove the arphost from ARPPendingList as it has been learned now
-            logger.debug("Host Removed from ARPPending List, IP: {}", id);
-            HostTrackerCallable htCallable = arphost.getHostTrackerCallable();
-            if (htCallable != null) {
-                htCallable.wakeup();
-            }
-            return;
-        }
-
-        /*
-         * It could have been a host from the FailedARPReqList
-         */
-
-        if (failedARPReqList.containsKey(id)) {
-            failedARPReqList.remove(id);
-            logger.debug("Host Removed from FailedARPReqList List, IP: {}", decodeIPFromId(id));
-        }
-    }
-
-    // Learn a new Host
-    private void learnNewHost(HostNodeConnector host) {
-        IHostId id = HostIdFactory.create(host.getNetworkAddress(), host.getDataLayerAddress());
-        host.initArpSendCountDown();
-        HostNodeConnector rHost = hostsDB.putIfAbsent(id, host);
-        if (rHost != null) {
-            // Another host is already learned for this IP address, replace it
-            replaceHost(id, rHost, host);
-        } else {
-            logger.debug("New Host Learned: MAC: {}  IP: {}", HexEncode.bytesToHexString(host
-                    .getDataLayerAddressBytes()), host.getNetworkAddress().getHostAddress());
-        }
-    }
-
-    private void replaceHost(IHostId id, HostNodeConnector removedHost, HostNodeConnector newHost) {
-        // Ignore ARP messages from internal nodes
-        NodeConnector newHostNc = newHost.getnodeConnector();
-        boolean newHostIsInternal = topologyManager.isInternal(newHostNc);
-        if (newHostIsInternal) {
-            return;
-        }
-
-        newHost.initArpSendCountDown();
-
-        if (hostsDB.replace(id, removedHost, newHost)) {
-            logger.debug("Host move occurred: Old Host IP:{}, New Host IP: {}", removedHost.getNetworkAddress()
-                    .getHostAddress(), newHost.getNetworkAddress().getHostAddress());
-            logger.debug("Old Host MAC: {}, New Host MAC: {}",
-                    HexEncode.bytesToHexString(removedHost.getDataLayerAddressBytes()),
-                    HexEncode.bytesToHexString(newHost.getDataLayerAddressBytes()));
-            // Display the Old and New HostNodeConnectors also
-            logger.debug("Old {}, New {}", removedHost, newHost);
-        } else {
-            /*
-             * Host replacement has failed, do the recovery
-             */
-            hostsDB.put(id, newHost);
-            logger.error("Host replacement failed. Overwrite the host. Replaced Host: {}, New Host: {}", removedHost,
-                    newHost);
-        }
-        notifyHostLearnedOrRemoved(removedHost, false);
-        notifyHostLearnedOrRemoved(newHost, true);
-        if (!newHost.isStaticHost()) {
-            processPendingARPReqs(id);
-        }
-    }
-
-    // Remove known Host
-    private void removeKnownHost(IHostId key) {
-        HostNodeConnector host = hostsDB.get(key);
-        if (host != null) {
-            logger.debug("Removing Host: IP:{}", host.getNetworkAddress().getHostAddress());
-            hostsDB.remove(key);
-        } else {
-            logger.error("removeKnownHost(): Host for IP address {} not found in hostsDB", decodeIPFromId(key));
-        }
-    }
-
-    private class NotifyHostThread extends Thread {
-
-        private final HostNodeConnector host;
-
-        public NotifyHostThread(HostNodeConnector h) {
-            this.host = h;
-        }
-
-        @Override
-        public void run() {
-            HostNodeConnector removedHost = null;
-            InetAddress networkAddr = host.getNetworkAddress();
-            IHostId id = HostIdFactory.create(networkAddr, host.getDataLayerAddress());
-            /* Check for Host Move case */
-            if (hostMoved(host)) {
-                /*
-                 * Host has been moved from one location (switch,port, MAC, or
-                 * VLAN) to another. Replace the existing host and its previous
-                 * location parameters with new information, and notify the
-                 * applications listening to host move.
-                 */
-
-                removedHost = hostsDB.get(id);
-                if (removedHost != null) {
-                    replaceHost(id, removedHost, host);
-                    return;
-                } else {
-                    logger.error("Host to be removed not found in hostsDB");
-                }
-            }
-
-            // It is a new host
-            learnNewHost(host);
-
-            /* check if there is an outstanding request for this host */
-            processPendingARPReqs(id);
-            notifyHostLearnedOrRemoved(host, true);
-        }
-    }
-
-    @Override
-    public void hostListener(HostNodeConnector host) {
-        logger.debug("Received for Host: IP {}, MAC {}, {}", host.getNetworkAddress().getHostAddress(),
-                HexEncode.bytesToHexString(host.getDataLayerAddressBytes()), host);
-        if (hostExists(host)) {
-            IHostId id = HostIdFactory.create(host.getNetworkAddress(), host.getDataLayerAddress());
-            HostNodeConnector existinghost = hostsDB.get(id);
-            existinghost.initArpSendCountDown();
-            // Update the host
-
-            hostsDB.put(id, existinghost);
-            logger.debug("hostListener returned without adding the host");
-            return;
-        }
-        new NotifyHostThread(host).start();
-    }
-
-    // Notify whoever is interested that a new host was learned (dynamically or
-    // statically)
-    private void notifyHostLearnedOrRemoved(HostNodeConnector host, boolean add) {
-        // Update listeners if any
-        if (newHostNotify != null) {
-            logger.debug("Notifying Applications for Host {} Being {}", host.getNetworkAddress().getHostAddress(),
-                    add ? "Added" : "Deleted");
-            synchronized (this.newHostNotify) {
-                for (IfNewHostNotify ta : newHostNotify) {
-                    try {
-                        if (add) {
-                            ta.notifyHTClient(host);
-                        } else {
-                            ta.notifyHTClientHostRemoved(host);
-                        }
-                    } catch (Exception e) {
-                        logger.error("Exception on new host notification", e);
-                    }
-                }
-            }
-        } else {
-            logger.error("notifyHostLearnedOrRemoved(): New host notify is null");
-        }
-
-        // Topology update is for some reason outside of listeners registry
-        // logic
-        Node node = host.getnodeconnectorNode();
-        Host h = null;
-        NodeConnector p = host.getnodeConnector();
-        try {
-            DataLinkAddress dla = new EthernetAddress(host.getDataLayerAddressBytes());
-            h = new Host(dla, host.getNetworkAddress());
-        } catch (ConstructionException ce) {
-            p = null;
-            h = null;
-        }
-
-        if (topologyManager != null && p != null && h != null) {
-            logger.debug("Notifying Topology Manager for Host {} Being {}", h.getNetworkAddress().getHostAddress(),
-                    add ? "Added" : "Deleted");
-            if (add == true) {
-                Tier tier = new Tier(1);
-                switchManager.setNodeProp(node, tier);
-                topologyManager.updateHostLink(p, h, UpdateType.ADDED, null);
-            } else {
-                // No need to reset the tiering if no other hosts are currently
-                // connected
-                // If this switch was discovered to be an access switch, it
-                // still is even if the host is down
-                Tier tier = new Tier(0);
-                switchManager.setNodeProp(node, tier);
-                topologyManager.updateHostLink(p, h, UpdateType.REMOVED, null);
-            }
-        }
-    }
-
-    /**
-     * When a new Host is learnt by the hosttracker module, it places the
-     * directly connected Node in Tier-1 & using this function, updates the Tier
-     * value for all other Nodes in the network hierarchy.
-     *
-     * This is a recursive function and it takes care of updating the Tier value
-     * for all the connected and eligible Nodes.
-     *
-     * @param n
-     *            Node that represents one of the Vertex in the Topology Graph.
-     * @param currentTier
-     *            The Tier on which n belongs
-     */
-    @SuppressWarnings("unused")
-    private void updateSwitchTiers(Node n, int currentTier) {
-        Map<Node, Set<Edge>> ndlinks = topologyManager.getNodeEdges();
-        if (ndlinks == null) {
-            logger.debug("updateSwitchTiers(): ndlinks null for Node: {}, Tier:{}", n, currentTier);
-            return;
-        }
-        Set<Edge> links = ndlinks.get(n);
-        if (links == null) {
-            logger.debug("updateSwitchTiers(): links null for ndlinks:{}", ndlinks);
-            return;
-        }
-        ArrayList<Node> needsVisiting = new ArrayList<Node>();
-        for (Edge lt : links) {
-            if (!lt.getHeadNodeConnector().getType().equals(NodeConnector.NodeConnectorIDType.OPENFLOW)) {
-                // We don't want to work on Node that are not openflow
-                // for now
-                continue;
-            }
-            Node dstNode = lt.getHeadNodeConnector().getNode();
-            if (switchNeedsTieringUpdate(dstNode, currentTier + 1)) {
-                Tier t = new Tier(currentTier + 1);
-                switchManager.setNodeProp(dstNode, t);
-                needsVisiting.add(dstNode);
-            }
-        }
-
-        /*
-         * Due to the nature of the problem, having a separate loop for nodes
-         * that needs visiting provides a decent walk optimization.
-         */
-        for (Node node : needsVisiting) {
-            updateSwitchTiers(node, currentTier + 1);
-        }
-    }
-
-    /**
-     * Internal convenience routine to check the eligibility of a Switch for a
-     * Tier update. Any Node with Tier=0 or a Tier value that is greater than
-     * the new Tier Value is eligible for the update.
-     *
-     * @param n
-     *            Node for which the Tier update eligibility is checked
-     * @param tier
-     *            new Tier Value
-     * @return <code>true</code> if the Node is eligible for Tier Update
-     *         <code>false</code> otherwise
-     */
-
-    private boolean switchNeedsTieringUpdate(Node n, int tier) {
-        if (n == null) {
-            logger.error("switchNeedsTieringUpdate(): Null node for tier: {}", tier);
-            return false;
-        }
-        /*
-         * Node could have gone down
-         */
-        if (!switchManager.getNodes().contains(n)) {
-            return false;
-        }
-        // This is the case where Tier was never set for this node
-        Tier t = (Tier) switchManager.getNodeProp(n, Tier.TierPropName);
-        if (t == null) {
-            return true;
-        }
-        if (t.getValue() == 0) {
-            return true;
-        } else if (t.getValue() > tier) {
-            return true;
-        }
-        return false;
-    }
-
-    /**
-     * Internal convenience routine to clear all the Tier values to 0. This
-     * cleanup is performed during cases such as Topology Change where the
-     * existing Tier values might become incorrect
-     */
-    @SuppressWarnings("unused")
-    private void clearTiers() {
-        Set<Node> nodes = null;
-        if (switchManager == null) {
-            logger.error("clearTiers(): Null switchManager");
-            return;
-        }
-        nodes = switchManager.getNodes();
-
-        for (Node n : nodes) {
-            Tier t = new Tier(0);
-            switchManager.setNodeProp(n, t);
-        }
-    }
-
-    /**
-     * Internal convenience routine to print the hierarchies of switches.
-     */
-    @SuppressWarnings("unused")
-    private void logHierarchies(ArrayList<ArrayList<String>> hierarchies) {
-        String hierarchyString = null;
-        int num = 1;
-        for (ArrayList<String> hierarchy : hierarchies) {
-            StringBuffer buf = new StringBuffer();
-            buf.append("Hierarchy#").append(num).append(" : ");
-            for (String switchName : hierarchy) {
-                buf.append(switchName).append("/");
-            }
-            logger.debug("{} -> {}", getContainerName(), buf);
-            num++;
-        }
-    }
-
-    /**
-     * getHostNetworkHierarchy is the Back-end routine for the North-Bound API
-     * that returns the Network Hierarchy for a given Host. This API is
-     * typically used by applications like Hadoop for Rack Awareness
-     * functionality.
-     *
-     * @param hostAddress
-     *            IP-Address of the host/node.
-     * @return Network Hierarchies represented by an Array of Array (of
-     *         Switch-Ids as String).
-     */
-    @Override
-    public List<List<String>> getHostNetworkHierarchy(IHostId id) {
-        HostNodeConnector host = hostQuery(id);
-        if (host == null) {
-            return null;
-        }
-
-        List<List<String>> hierarchies = new ArrayList<List<String>>();
-        ArrayList<String> currHierarchy = new ArrayList<String>();
-        hierarchies.add(currHierarchy);
-
-        Node node = host.getnodeconnectorNode();
-        updateCurrentHierarchy(node, currHierarchy, hierarchies);
-        return hierarchies;
-    }
-
-    /**
-     * dpidToHostNameHack is a hack function for Cisco Live Hadoop Demo. Mininet
-     * is used as the network for Hadoop Demos & in order to give a meaningful
-     * rack-awareness switch names, the DPID is organized in ASCII Characters
-     * and retrieved as string.
-     *
-     * @param dpid
-     *            Switch DataPath Id
-     * @return Ascii String represented by the DPID.
-     */
-    private String dpidToHostNameHack(long dpid) {
-        String hex = Long.toHexString(dpid);
-
-        StringBuffer sb = new StringBuffer();
-        int result = 0;
-        for (int i = 0; i < hex.length(); i++) {
-            result = (int) ((dpid >> (i * 8)) & 0xff);
-            if (result == 0) {
-                continue;
-            }
-            if (result < 0x30) {
-                result += 0x40;
-            }
-            sb.append(String.format("%c", result));
-        }
-        return sb.reverse().toString();
-    }
-
-    /**
-     * A convenient recursive routine to obtain the Hierarchy of Switches.
-     *
-     * @param node
-     *            Current Node in the Recursive routine.
-     * @param currHierarchy
-     *            Array of Nodes that make this hierarchy on which the Current
-     *            Switch belong
-     * @param fullHierarchy
-     *            Array of multiple Hierarchies that represent a given host.
-     */
-    @SuppressWarnings("unchecked")
-    private void updateCurrentHierarchy(Node node, ArrayList<String> currHierarchy, List<List<String>> fullHierarchy) {
-        currHierarchy.add(dpidToHostNameHack((Long) node.getID()));
-        // Shallow copy as required
-        ArrayList<String> currHierarchyClone = (ArrayList<String>) currHierarchy.clone();
-
-        Map<Node, Set<Edge>> ndlinks = topologyManager.getNodeEdges();
-        if (ndlinks == null) {
-            logger.debug("updateCurrentHierarchy(): topologyManager returned null ndlinks for node: {}", node);
-            return;
-        }
-        Node n = NodeCreator.createOFNode((Long) node.getID());
-        Set<Edge> links = ndlinks.get(n);
-        if (links == null) {
-            logger.debug("updateCurrentHierarchy(): Null links for ndlinks");
-            return;
-        }
-        for (Edge lt : links) {
-            if (!lt.getHeadNodeConnector().getType().equals(NodeConnector.NodeConnectorIDType.OPENFLOW)) {
-                // We don't want to work on Node that are not openflow
-                // for now
-                continue;
-            }
-            Node dstNode = lt.getHeadNodeConnector().getNode();
-
-            Tier nodeTier = (Tier) switchManager.getNodeProp(node, Tier.TierPropName);
-            /*
-             * If the host is directly attached to the src node, then the node
-             * should have been assigned the "Access" tier in
-             * notifyHostLearnedOrRemoved. If not, it would be assigned
-             * "Unknown" tier. Thus the tier of host attached node cannot be
-             * null. If the src node here, is the next node in the hierarchy of
-             * the nodes, then its tier cannot be null
-             */
-
-            Tier dstNodeTier = (Tier) switchManager.getNodeProp(dstNode, Tier.TierPropName);
-            /*
-             * Skip if the tier of the destination node is null
-             */
-            if (dstNodeTier == null) {
-                continue;
-            }
-            if (dstNodeTier.getValue() > nodeTier.getValue()) {
-                ArrayList<String> buildHierarchy = currHierarchy;
-                if (currHierarchy.size() > currHierarchyClone.size()) {
-                    // Shallow copy as required
-                    buildHierarchy = (ArrayList<String>) currHierarchyClone.clone();
-                    fullHierarchy.add(buildHierarchy);
-                }
-                updateCurrentHierarchy(dstNode, buildHierarchy, fullHierarchy);
-            }
-        }
-    }
-
-    private void debugEdgeUpdate(Edge e, UpdateType type, Set<Property> props) {
-        Long srcNid = null;
-        Short srcPort = null;
-        Long dstNid = null;
-        Short dstPort = null;
-        boolean added = false;
-        String srcType = null;
-        String dstType = null;
-
-        if (e == null || type == null) {
-            logger.error("Edge or Update type are null!");
-            return;
-        } else {
-            srcType = e.getTailNodeConnector().getType();
-            dstType = e.getHeadNodeConnector().getType();
-
-            if (srcType.equals(NodeConnector.NodeConnectorIDType.PRODUCTION)) {
-                logger.debug("Skip updates for {}", e);
-                return;
-            }
-
-            if (!srcType.equals(NodeConnector.NodeConnectorIDType.OPENFLOW)) {
-                logger.debug("For now we cannot handle updates for non-openflow nodes");
-                return;
-            }
-
-            if (dstType.equals(NodeConnector.NodeConnectorIDType.PRODUCTION)) {
-                logger.debug("Skip updates for {}", e);
-                return;
-            }
-
-            if (!dstType.equals(NodeConnector.NodeConnectorIDType.OPENFLOW)) {
-                logger.debug("For now we cannot handle updates for non-openflow nodes");
-                return;
-            }
-
-            // At this point we know we got an openflow update, so
-            // lets fill everything accordingly.
-            srcNid = (Long) e.getTailNodeConnector().getNode().getID();
-            srcPort = (Short) e.getTailNodeConnector().getID();
-            dstNid = (Long) e.getHeadNodeConnector().getNode().getID();
-            dstPort = (Short) e.getHeadNodeConnector().getID();
-
-            // Now lets update the added flag
-            switch (type) {
-            case ADDED:
-            case CHANGED:
-                added = true;
-                break;
-            case REMOVED:
-                added = false;
-            }
-        }
-
-        logger.debug("HostTracker Topology linkUpdate handling src:{}[port {}] dst:{}[port {}] added: {}",
-                new Object[] { srcNid, srcPort, dstNid, dstPort, added });
-    }
-
-    @Override
-    public void edgeUpdate(List<TopoEdgeUpdate> topoedgeupdateList) {
-        if (logger.isDebugEnabled()) {
-            for (TopoEdgeUpdate topoEdgeUpdate : topoedgeupdateList) {
-                Edge e = topoEdgeUpdate.getEdge();
-                Set<Property> p = topoEdgeUpdate.getProperty();
-                UpdateType type = topoEdgeUpdate.getUpdateType();
-
-                debugEdgeUpdate(e, type, p);
-            }
-        }
-    }
-
-    @Override
-    public void subnetNotify(Subnet sub, boolean add) {
-        logger.debug("Received subnet notification: {}  add={}", sub, add);
-        if (add) {
-            for (Entry<IHostId, ARPPending> entry : failedARPReqList.entrySet()) {
-                ARPPending arphost;
-                arphost = entry.getValue();
-                if (hostFinders.isEmpty()) {
-                    logger.debug("ARPHandler Services are not available on subnet addition");
-                    continue;
-                }
-                logger.debug("Sending the ARP from FailedARPReqList fors IP: {}", decodeIPFromId(arphost.getHostId()));
-                for (IHostFinder hf : hostFinders) {
-                    hf.find(decodeIPFromId(arphost.getHostId()));
-                }
-            }
-        }
-    }
-
-    /*
-     * This thread runs every 4 seconds
-     */
-
-    class OutStandingARPHandler extends TimerTask {
-        @Override
-        public void run() {
-            if (stopping) {
-                return;
-            }
-            ARPPending arphost;
-            try {
-                for (Entry<IHostId, ARPPending> entry : ARPPendingList.entrySet()) {
-                    arphost = entry.getValue();
-
-                    if (hostsDB.containsKey(arphost.getHostId())) {
-                        // this host is already learned, shouldn't be in
-                        // ARPPendingList
-                        // Remove it and continue
-                        logger.warn("Learned Host {} found in ARPPendingList", decodeIPFromId(arphost.getHostId()));
-                        ARPPendingList.remove(entry.getKey());
-                        continue;
-                    }
-                    if (arphost.getSent_count() < hostRetryCount) {
-                        /*
-                         * No reply has been received of first ARP Req, send the
-                         * next one. Before sending the ARP, check if ARPHandler
-                         * is available or not
-                         */
-                        if (hostFinders.isEmpty()) {
-                            logger.warn("ARPHandler Services are not available for Outstanding ARPs");
-                            continue;
-                        }
-                        for (IHostFinder hf : hostFinders) {
-                            hf.find(decodeIPFromId(arphost.getHostId()));
-                        }
-                        arphost.sent_count++;
-                        logger.debug("ARP Sent from ARPPending List, IP: {}", decodeIPFromId(arphost.getHostId()));
-                    } else if (arphost.getSent_count() >= hostRetryCount) {
-                        /*
-                         * ARP requests have been sent without receiving a
-                         * reply, remove this from the pending list
-                         */
-                        ARPPendingList.remove(entry.getKey());
-                        logger.debug(
-                                "ARP reply not received after multiple attempts, removing from Pending List IP: {}",
-                                decodeIPFromId(arphost.getHostId()));
-                        /*
-                         * Add this host to a different list which will be
-                         * processed on link up events
-                         */
-                        logger.debug("Adding the host to FailedARPReqList IP: {}", decodeIPFromId(arphost.getHostId()));
-                        failedARPReqList.put(entry.getKey(), arphost);
-
-                    } else {
-                        logger.error("Inavlid arp_sent count for entry: {}", entry);
-                    }
-                }
-            } catch (IllegalStateException e) {
-                logger.debug("IllegalStateException Received by OutStandingARPHandler from: {}", e.getMessage());
-            }
-        }
-    }
-
-    private class ARPRefreshHandler extends TimerTask {
-        @Override
-        public void run() {
-            if ((clusterContainerService != null) && !clusterContainerService.amICoordinator()) {
-                return;
-            }
-            if (stopping) {
-                return;
-            }
-            if (!hostRefresh) {
-                /*
-                 * The host probe procedure is turned off
-                 */
-                return;
-            }
-            if (hostsDB == null) {
-                /* hostsDB is not allocated yet */
-                logger.error("ARPRefreshHandler(): hostsDB is not allocated yet:");
-                return;
-            }
-            try {
-                for (Entry<IHostId, HostNodeConnector> entry : hostsDB.entrySet()) {
-                    HostNodeConnector host = entry.getValue();
-                    if (host.isStaticHost()) {
-                        /* this host was learned via API3, don't age it out */
-                        continue;
-                    }
-
-                    short arp_cntdown = host.getArpSendCountDown();
-                    arp_cntdown--;
-                    if (arp_cntdown > hostRetryCount) {
-                        host.setArpSendCountDown(arp_cntdown);
-                    } else if (arp_cntdown <= 0) {
-                        /*
-                         * No ARP Reply received in last 2 minutes, remove this
-                         * host and inform applications
-                         */
-                        removeKnownHost(entry.getKey());
-                        notifyHostLearnedOrRemoved(host, false);
-                    } else if (arp_cntdown <= hostRetryCount) {
-                        /*
-                         * Use the services of arphandler to check if host is
-                         * still there
-                         */
-                        if (logger.isTraceEnabled()) {
-                            logger.trace(
-                                    "ARP Probing ({}) for {}({})",
-                                    new Object[] { arp_cntdown, host.getNetworkAddress().getHostAddress(),
-                                            HexEncode.bytesToHexString(host.getDataLayerAddressBytes()) });
-                        }
-                        host.setArpSendCountDown(arp_cntdown);
-                        if (hostFinders.isEmpty()) {
-                            /*
-                             * If hostfinder is not available, then can't send
-                             * the probe. However, continue the age out the
-                             * hosts since we don't know if the host is indeed
-                             * out there or not.
-                             */
-                            logger.trace("ARPHandler is not avaialable, can't send the probe");
-                            continue;
-                        }
-                        for (IHostFinder hf : hostFinders) {
-                            hf.probe(host);
-                        }
-                    }
-                }
-            } catch (IllegalStateException e) {
-                logger.debug("IllegalStateException  Received by ARPRefreshHandler from: {}", e.getMessage());
-            }
-        }
-    }
-
-    /**
-     * Inform the controller IP to MAC binding of a host and its connectivity to
-     * an openflow switch in terms of Node, port, and VLAN.
-     *
-     * @param networkAddr
-     *            IP address of the host
-     * @param dataLayer
-     *            Address MAC address of the host
-     * @param nc
-     *            NodeConnector to which host is connected
-     * @param port
-     *            Port of the switch to which host is connected
-     * @param vlan
-     *            Vlan of which this host is member of
-     *
-     * @return Status The status object as described in {@code Status}
-     *         indicating the result of this action.
-     */
-
-    protected Status addStaticHostReq(InetAddress networkAddr, byte[] dataLayerAddress, NodeConnector nc, short vlan) {
-        if (dataLayerAddress.length != NetUtils.MACAddrLengthInBytes) {
-            return new Status(StatusCode.BADREQUEST, "Invalid MAC address");
-        }
-
-        if (nc == null) {
-            return new Status(StatusCode.BADREQUEST, "Invalid NodeConnector");
-        }
-        HostNodeConnector host = null;
-        try {
-            host = new HostNodeConnector(dataLayerAddress, networkAddr, nc, vlan);
-            IHostId id = HostIdFactory.create(networkAddr, new EthernetAddress(dataLayerAddress));
-            if (hostExists(host)) {
-                // This host is already learned either via ARP or through a
-                // northbound request
-                HostNodeConnector transHost = hostsDB.get(networkAddr);
-                transHost.setStaticHost(true);
-                return new Status(StatusCode.SUCCESS);
-            }
-
-            if (hostsDB.get(id) != null) {
-                // There is already a host with this IP address (but behind
-                // a different (switch, port, vlan) tuple. Return an error
-                return new Status(StatusCode.CONFLICT, "Host with this IP already exists.");
-            }
-            host.setStaticHost(true);
-            /*
-             * Check if the nc is an ISL port
-             */
-            if (topologyManager != null) {
-                if (topologyManager.isInternal(nc)) {
-                    return new Status(StatusCode.BADREQUEST, "Cannot add host on ISL port");
-                }
-            }
-            /*
-             * Before adding host, Check if the switch and the port have already
-             * come up
-             */
-            if (switchManager.isNodeConnectorEnabled(nc)) {
-                learnNewHost(host);
-                processPendingARPReqs(id);
-                notifyHostLearnedOrRemoved(host, true);
-            } else {
-                inactiveStaticHosts.put(nc, host);
-                logger.debug("Switch or switchport is not up, adding host {} to inactive list",
-                        networkAddr.getHostName());
-            }
-            return new Status(StatusCode.SUCCESS);
-        } catch (ConstructionException e) {
-            logger.error("", e);
-            return new Status(StatusCode.INTERNALERROR, "Host could not be created");
-        }
-
-    }
-
-    /**
-     * Update the controller IP to MAC binding of a host and its connectivity to
-     * an openflow switch in terms of switch id, switch port, and VLAN.
-     *
-     * @param networkAddr
-     *            IP address of the host
-     * @param dataLayer
-     *            Address MAC address of the host
-     * @param nc
-     *            NodeConnector to which host is connected
-     * @param port
-     *            Port of the switch to which host is connected
-     * @param vlan
-     *            Vlan of which this host is member of
-     *
-     * @return Status The status object as described in {@code Status}
-     *         indicating the result of this action.
-     */
-    public Status updateHostReq(InetAddress networkAddr, byte[] dataLayerAddress, NodeConnector nc, short vlan) {
-        HostNodeConnector tobeUpdatedHost;
-        HostNodeConnector host = null;
-
-        if (dataLayerAddress.length != NetUtils.MACAddrLengthInBytes) {
-            return new Status(StatusCode.BADREQUEST, "Invalid MAC address");
-        }
-
-        if (nc == null) {
-            return new Status(StatusCode.BADREQUEST, "Invalid NodeConnector");
-        }
-
-        try {
-            host = new HostNodeConnector(dataLayerAddress, networkAddr, nc, vlan);
-            if (hostExists(host)) {
-                return new Status(StatusCode.BADREQUEST, "Host already exists");
-            }
-
-            IHostId id = HostIdFactory.create(networkAddr, new EthernetAddress(dataLayerAddress));
-
-            if ((tobeUpdatedHost = hostsDB.get(networkAddr)) != null) {
-                if (hostsDB.replace(id, tobeUpdatedHost, host)) {
-                    logger.debug("Host replaced from hostsDB. Old host: {} New Host: {}", tobeUpdatedHost, host);
-                    notifyHostLearnedOrRemoved(tobeUpdatedHost, false);
-                    notifyHostLearnedOrRemoved(host, true);
-                    return new Status(StatusCode.SUCCESS);
-                } else {
-                    logger.error("Static host replacement failed from hostsDB, Replaced Host: {}, New Host: {}",
-                            tobeUpdatedHost, host);
-                    return new Status(StatusCode.INTERNALERROR,
-                            "Host Replacement Failed due to presence of another host with same IP");
-                }
-            }
-
-            // Check if the host exists in inactive hosts database
-            if ((tobeUpdatedHost = inactiveStaticHosts.get(nc)) != null) {
-                if (inactiveStaticHosts.replace(nc, tobeUpdatedHost, host)) {
-                    logger.debug("Host replaced from inactive hostsDB. Old host: {} New Host: {}", tobeUpdatedHost,
-                            host);
-                    return new Status(StatusCode.SUCCESS);
-                } else {
-                    logger.error("Static host replacement failed, Replaced Host: {}, New Host: {}", tobeUpdatedHost,
-                            host);
-                    return new Status(StatusCode.INTERNALERROR,
-                            "Host Replacement Failed due to presence of another host with same IP");
-                }
-            }
-
-            // Host doesn't exist
-            return new Status(StatusCode.BADREQUEST, "Host doesn't exists, can't update");
-        } catch (ConstructionException e) {
-            logger.error("", e);
-            return new Status(StatusCode.INTERNALERROR, "host object creation failure");
-        }
-    }
-
-    /**
-     * Remove from the controller IP to MAC binding of a host and its
-     * connectivity to an openflow switch
-     *
-     * @param networkAddr
-     *            IP address of the host
-     *
-     * @return boolean true if the host was removed successfully, false
-     *         otherwise
-     */
-
-    public Status removeStaticHostReq(InetAddress networkAddress, DataLinkAddress mac) {
-        // Check if host is in active hosts database
-        IHostId id = HostIdFactory.create(networkAddress, mac);
-        HostNodeConnector host = getHostFromOnActiveDB(id);
-        if (host != null) {
-            // Validation check
-            if (!host.isStaticHost()) {
-                return new Status(StatusCode.FORBIDDEN, "Host " + networkAddress.getHostName() + " is not static");
-            }
-            // Remove and notify
-            notifyHostLearnedOrRemoved(host, false);
-            removeKnownHost(id);
-            return new Status(StatusCode.SUCCESS, null);
-        }
-
-        // Check if host is in inactive hosts database
-        Entry<NodeConnector, HostNodeConnector> entry = getHostFromInactiveDB(id);
-        if (entry != null) {
-            host = entry.getValue();
-            // Validation check
-            if (!host.isStaticHost()) {
-                return new Status(StatusCode.FORBIDDEN, "Host " + networkAddress.getHostName() + " is not static");
-            }
-            this.removeHostFromInactiveDB(id);
-            return new Status(StatusCode.SUCCESS, null);
-        }
-
-        // Host is neither in active nor inactive hosts database
-        return new Status(StatusCode.NOTFOUND, "Host does not exist");
-    }
-
-    @Override
-    public void modeChangeNotify(Node node, boolean proactive) {
-        logger.debug("Set Switch {} Mode to {}", node.getID(), proactive);
-    }
-
-    @Override
-    public void notifyNode(Node node, UpdateType type, Map<String, Property> propMap) {
-        if (node == null) {
-            return;
-        }
-
-        switch (type) {
-        case REMOVED:
-            logger.debug("Received removed node {}", node);
-            for (Entry<IHostId, HostNodeConnector> entry : hostsDB.entrySet()) {
-                HostNodeConnector host = entry.getValue();
-                if (host.getnodeconnectorNode().equals(node)) {
-                    logger.debug("Node: {} is down, remove from Hosts_DB", node);
-                    removeKnownHost(entry.getKey());
-                    notifyHostLearnedOrRemoved(host, false);
-                }
-            }
-            break;
-        default:
-            break;
-        }
-    }
-
-    @Override
-    public void notifyNodeConnector(NodeConnector nodeConnector, UpdateType type, Map<String, Property> propMap) {
-        if (nodeConnector == null) {
-            return;
-        }
-
-        boolean up = false;
-        switch (type) {
-        case ADDED:
-            up = true;
-            break;
-        case REMOVED:
-            break;
-        case CHANGED:
-            State state = (State) propMap.get(State.StatePropName);
-            if ((state != null) && (state.getValue() == State.EDGE_UP)) {
-                up = true;
-            }
-            break;
-        default:
-            return;
-        }
-
-        if (up) {
-            handleNodeConnectorStatusUp(nodeConnector);
-        } else {
-            handleNodeConnectorStatusDown(nodeConnector);
-        }
-    }
-
-    @Override
-    public Status addStaticHost(String networkAddress, String dataLayerAddress, NodeConnector nc, String vlan) {
-        try {
-            InetAddress ip = InetAddress.getByName(networkAddress);
-            short vl = 0;
-            if (vlan != null && !vlan.isEmpty()) {
-                vl = Short.decode(vlan);
-                if (vl < 1 || vl > 4095) {
-                    return new Status(StatusCode.BADREQUEST, "Host vlan out of range [1 - 4095]");
-                }
-            }
-
-            return addStaticHostReq(ip, HexEncode.bytesFromHexString(dataLayerAddress), nc, vl);
-
-        } catch (UnknownHostException e) {
-            logger.debug("Invalid host IP specified when adding static host", e);
-            return new Status(StatusCode.BADREQUEST, "Invalid Host IP Address");
-        } catch (NumberFormatException nfe) {
-            logger.debug("Invalid host vlan or MAC specified when adding static host", nfe);
-            return new Status(StatusCode.BADREQUEST, "Invalid Host vLan/MAC");
-        }
-    }
-
-    @Override
-    public Status removeStaticHost(String networkAddress) {
-        try {
-            if ((keyScheme != null) && (!keyScheme.equals(HostIdFactory.DEFAULT_IP_KEY_SCHEME))) {
-                return new Status(StatusCode.NOTALLOWED, "Host DB Key scheme used is not IP only scheme.");
-            }
-            InetAddress address = InetAddress.getByName(networkAddress);
-            return removeStaticHostReq(address, null);
-        } catch (UnknownHostException e) {
-            logger.debug("Invalid IP Address when trying to remove host", e);
-            return new Status(StatusCode.BADREQUEST, "Invalid IP Address when trying to remove host");
-        }
-    }
-
-    @Override
-    public Status removeStaticHostUsingIPAndMac(String networkAddress, String macAddress) {
-        try {
-            if ((keyScheme != null) && (keyScheme.equals(HostIdFactory.DEFAULT_IP_KEY_SCHEME))) {
-                return new Status(StatusCode.NOTALLOWED, "Host DB Key scheme used is not IP only scheme.");
-            }
-            InetAddress address = InetAddress.getByName(networkAddress);
-            DataLinkAddress mac = new EthernetAddress(HexEncode.bytesFromHexString(macAddress));
-            return removeStaticHostReq(address, mac);
-        } catch (UnknownHostException e) {
-            logger.debug("Invalid IP Address when trying to remove host", e);
-            return new Status(StatusCode.BADREQUEST, "Invalid IP Address when trying to remove host");
-        } catch (ConstructionException e) {
-            // TODO Auto-generated catch block
-            e.printStackTrace();
-            return new Status(StatusCode.BADREQUEST, "Invalid Input parameters have been passed.");
-        }
-    }
-
-    private InetAddress decodeIPFromId(IHostId id) {
-        if ((keyScheme != null) && (keyScheme.equals(HostIdFactory.DEFAULT_IP_KEY_SCHEME))) {
-            IPHostId ipId = (IPHostId) id;
-            return (ipId.getIpAddress());
-        } else if ((keyScheme != null) && (keyScheme.equals(HostIdFactory.IP_MAC_KEY_SCHEME))) {
-            IPMacHostId ipMacId = (IPMacHostId) id;
-            return (ipMacId.getIpAddress());
-        }
-        return null;
-    }
-
-    private DataLinkAddress decodeMacFromId(IHostId id) {
-        if ((keyScheme != null) && (!keyScheme.equals(HostIdFactory.DEFAULT_IP_KEY_SCHEME))) {
-            IPMacHostId ipMacId = (IPMacHostId) id;
-            return (ipMacId.getMacAddr());
-        }
-
-        return null;
-    }
-
-    private void handleNodeConnectorStatusUp(NodeConnector nodeConnector) {
-        ARPPending arphost;
-        HostNodeConnector host = null;
-
-        logger.trace("handleNodeConnectorStatusUp {}", nodeConnector);
-
-        for (Entry<IHostId, ARPPending> entry : failedARPReqList.entrySet()) {
-            arphost = entry.getValue();
-            logger.trace("Sending the ARP from FailedARPReqList fors IP: {}", arphost.getHostId());
-            if (hostFinders.isEmpty()) {
-                logger.warn("ARPHandler is not available at interface  up");
-                logger.warn("Since this event is missed, host(s) connected to interface {} may not be discovered",
-                        nodeConnector);
-                continue;
-            }
-
-            // Send a broadcast ARP only on the interface which just came up.
-            // Use hostFinder's "probe" method
-            try {
-                byte[] dataLayerAddress = NetUtils.getBroadcastMACAddr();
-                host = new HostNodeConnector(dataLayerAddress, decodeIPFromId(arphost.getHostId()), nodeConnector,
-                        (short) 0);
-                for (IHostFinder hf : hostFinders) {
-                    hf.probe(host);
-                }
-            } catch (ConstructionException e) {
-                logger.debug("HostNodeConnector couldn't be created for Host: {}, NodeConnector: {}",
-                        arphost.getHostId(), nodeConnector);
-                logger.error("", e);
-            }
-        }
-
-        host = inactiveStaticHosts.get(nodeConnector);
-        if (host != null) {
-            inactiveStaticHosts.remove(nodeConnector);
-            learnNewHost(host);
-            IHostId id = HostIdFactory.create(host.getNetworkAddress(), host.getDataLayerAddress());
-            processPendingARPReqs(id);
-            notifyHostLearnedOrRemoved(host, true);
-        }
-    }
-
-    private void handleNodeConnectorStatusDown(NodeConnector nodeConnector) {
-        logger.trace("handleNodeConnectorStatusDown {}", nodeConnector);
-
-        for (Entry<IHostId, HostNodeConnector> entry : hostsDB.entrySet()) {
-            HostNodeConnector host = entry.getValue();
-            if (host.getnodeConnector().equals(nodeConnector)) {
-                logger.debug(" NodeConnector: {} is down, remove from Hosts_DB", nodeConnector);
-                removeKnownHost(entry.getKey());
-                notifyHostLearnedOrRemoved(host, false);
-            }
-        }
-    }
-
-    void setClusterContainerService(IClusterContainerServices s) {
-        logger.debug("Cluster Service set");
-        this.clusterContainerService = s;
-    }
-
-    void unsetClusterContainerService(IClusterContainerServices s) {
-        if (this.clusterContainerService == s) {
-            logger.debug("Cluster Service removed!");
-            this.clusterContainerService = null;
-        }
-    }
-
-    void setSwitchManager(ISwitchManager s) {
-        logger.debug("SwitchManager set");
-        this.switchManager = s;
-    }
-
-    void unsetSwitchManager(ISwitchManager s) {
-        if (this.switchManager == s) {
-            logger.debug("SwitchManager removed!");
-            this.switchManager = null;
-        }
-    }
-
-    public String getContainerName() {
-        if (containerName == null) {
-            return GlobalConstants.DEFAULT.toString();
-        }
-        return containerName;
-    }
-
-    /**
-     * Function called by the dependency manager when all the required
-     * dependencies are satisfied
-     *
-     */
-    void init(Component c) {
-        Dictionary<?, ?> props = c.getServiceProperties();
-        if (props != null) {
-            this.containerName = (String) props.get("containerName");
-            logger.debug("Running containerName: {}", this.containerName);
-        } else {
-            // In the Global instance case the containerName is empty
-            this.containerName = "";
-        }
-        startUp();
-
-        logger.debug("key Scheme in hosttracker is {}", keyScheme);
-    }
-
-    /**
-     * Function called by the dependency manager when at least one dependency
-     * become unsatisfied or when the component is shutting down because for
-     * example bundle is being stopped.
-     *
-     */
-    void destroy() {
-    }
-
-    /**
-     * Function called by dependency manager after "init ()" is called and after
-     * the services provided by the class are registered in the service registry
-     *
-     */
-    void start() {
-        registerWithOSGIConsole();
-    }
-
-    /**
-     * Function called by the dependency manager before the services exported by
-     * the component are unregistered, this will be followed by a "destroy ()"
-     * calls
-     *
-     */
-    void stop() {
-    }
-
-    void stopping() {
-        stopping = true;
-        arpRefreshTimer.cancel();
-        timer.cancel();
-        executor.shutdownNow();
-    }
-
-    @Override
-    public void edgeOverUtilized(Edge edge) {
-
-    }
-
-    @Override
-    public void edgeUtilBackToNormal(Edge edge) {
-
-    }
-
-    @Override
-    public void entryCreated(IHostId key, String cacheName, boolean originLocal) {
-        if (originLocal) {
-            return;
-        }
-        processPendingARPReqs(key);
-    }
-
-    @Override
-    public void entryUpdated(IHostId key, HostNodeConnector new_value, String cacheName, boolean originLocal) {
-    }
-
-    @Override
-    public void entryDeleted(IHostId key, String cacheName, boolean originLocal) {
-    }
-
-    private void registerWithOSGIConsole() {
-        BundleContext bundleContext = FrameworkUtil.getBundle(this.getClass()).getBundleContext();
-        bundleContext.registerService(CommandProvider.class.getName(), this, null);
-    }
-
-    @Override
-    public String getHelp() {
-        return null;
-    }
-
-    public void _dumpPendingARPReqList(CommandInterpreter ci) {
-        ARPPending arphost;
-        for (Entry<IHostId, ARPPending> entry : ARPPendingList.entrySet()) {
-            arphost = entry.getValue();
-            ci.println(arphost.getHostId().toString());
-        }
-    }
-
-    public void _dumpFailedARPReqList(CommandInterpreter ci) {
-        ARPPending arphost;
-        for (Entry<IHostId, ARPPending> entry : failedARPReqList.entrySet()) {
-            arphost = entry.getValue();
-            ci.println(arphost.getHostId().toString());
-        }
-    }
-
-    @Override
-    public HostNodeConnector hostFind(InetAddress addr) {
-        IHostId id = HostIdFactory.create(addr, null);
-        return (hostFind(id));
-    }
-
-    @Override
-    public HostNodeConnector hostQuery(InetAddress addr) {
-        IHostId id = HostIdFactory.create(addr, null);
-        return (hostQuery(id));
-    }
-
-    @Override
-    public Future<HostNodeConnector> discoverHost(InetAddress addr) {
-        IHostId id = HostIdFactory.create(addr, null);
-        return discoverHost(id);
-    }
-
-    @Override
-    public List<List<String>> getHostNetworkHierarchy(InetAddress addr) {
-        IHostId id = HostIdFactory.create(addr, null);
-        return getHostNetworkHierarchy(id);
-    }
-
-    @Override
-    public List<String> dumpPendingArpReqList() {
-        ARPPending arphost;
-        List<String> arpReq = new ArrayList<String>();
-        for (Entry<IHostId, ARPPending> entry : ARPPendingList.entrySet()) {
-            arpReq.add(entry.getValue().getHostId().toString());
-        }
-        return arpReq;
-    }
-
-    @Override
-    public List<String> dumpFailedArpReqList() {
-        ARPPending arphost;
-        List<String> arpReq = new ArrayList<String>();
-        for (Entry<IHostId, ARPPending> entry : failedARPReqList.entrySet()) {
-            arpReq.add(entry.getValue().getHostId().toString());
-        }
-        return arpReq;
-    }
-}
diff --git a/opendaylight/adsal/hosttracker/implementation/src/main/java/org/opendaylight/controller/hosttracker/internal/HostTrackerCallable.java b/opendaylight/adsal/hosttracker/implementation/src/main/java/org/opendaylight/controller/hosttracker/internal/HostTrackerCallable.java
deleted file mode 100644 (file)
index 59b4a08..0000000
+++ /dev/null
@@ -1,58 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/*
- * Provides a mechanism for applications to do an inline Host Discovery as opposed
- * to a delayed discovery
- */
-package org.opendaylight.controller.hosttracker.internal;
-
-/**
- * This Class provides methods to discover Host through a blocking call
- * mechanism. Applications can make use of these methods if they don't
- * find a host in HostTracker's database and want to discover the host
- * in the same thread without being called by a callback function.
- */
-import java.util.concurrent.Callable;
-import java.util.concurrent.CountDownLatch;
-
-import org.opendaylight.controller.hosttracker.IHostId;
-import org.opendaylight.controller.hosttracker.hostAware.HostNodeConnector;
-
-/**
- *
- *
- */
-public class HostTrackerCallable implements Callable<HostNodeConnector> {
-
-    //host id which could be ip or a combination of ip + mac based on the scheme chosen.
-    IHostId trackedHost;
-    HostTracker hostTracker;
-    protected CountDownLatch latch;
-
-    public HostTrackerCallable(HostTracker tracker, IHostId inet) {
-        trackedHost = inet;
-        hostTracker = tracker;
-        latch = new CountDownLatch(1);
-    }
-
-    @Override
-    public HostNodeConnector call() throws Exception {
-        HostNodeConnector h = hostTracker.hostFind(trackedHost);
-        if (h != null) {
-            return h;
-        }
-        hostTracker.setCallableOnPendingARP(trackedHost, this);
-        Thread.sleep(2000); // wait 2sec to see if the host responds
-        return hostTracker.hostQuery(trackedHost);
-    }
-
-    public void wakeup() {
-        this.latch.countDown();
-    }
-}
diff --git a/opendaylight/adsal/hosttracker/implementation/src/test/java/org/opendaylight/controller/hosttracker/internal/HostTrackerTest.java b/opendaylight/adsal/hosttracker/implementation/src/test/java/org/opendaylight/controller/hosttracker/internal/HostTrackerTest.java
deleted file mode 100644 (file)
index 984d5d3..0000000
+++ /dev/null
@@ -1,54 +0,0 @@
-/*\r
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.\r
- *\r
- * This program and the accompanying materials are made available under the\r
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,\r
- * and is available at http://www.eclipse.org/legal/epl-v10.html\r
- */\r
-\r
-package org.opendaylight.controller.hosttracker.internal;\r
-\r
-import java.net.InetAddress;\r
-import java.net.UnknownHostException;\r
-\r
-import org.junit.Assert;\r
-import org.junit.Test;\r
-import org.opendaylight.controller.hosttracker.IHostId;\r
-import org.opendaylight.controller.hosttracker.IPHostId;\r
-\r
-public class HostTrackerTest {\r
-\r
-    @Test\r
-    public void testHostTrackerCallable() throws UnknownHostException {\r
-\r
-        HostTracker hostTracker = null;\r
-        hostTracker = new HostTracker();\r
-\r
-        InetAddress hostIP = InetAddress.getByName("192.168.0.8");\r
-        IHostId id  = IPHostId.fromIP(hostIP);\r
-\r
-        HostTrackerCallable htCallable = new HostTrackerCallable(hostTracker,\r
-                id);\r
-        Assert.assertTrue(htCallable.trackedHost.equals(id));\r
-        Assert.assertTrue(htCallable.hostTracker.equals(hostTracker));\r
-\r
-        long count = htCallable.latch.getCount();\r
-        htCallable.wakeup();\r
-        Assert.assertTrue(htCallable.latch.getCount() == (count - 1));\r
-    }\r
-\r
-    @Test\r
-    public void testHostTracker() throws UnknownHostException {\r
-        HostTracker hostTracker = null;\r
-        hostTracker = new HostTracker();\r
-\r
-        InetAddress hostIP_1 = InetAddress.getByName("192.168.0.8");\r
-        IHostId id1 = IPHostId.fromIP(hostIP_1);\r
-        InetAddress hostIP_2 = InetAddress.getByName("192.168.0.18");\r
-        IHostId id2 = IPHostId.fromIP(hostIP_2);\r
-        hostTracker.discoverHost(id1);\r
-        hostTracker.discoverHost(id2);\r
-        hostTracker.nonClusterObjectCreate();\r
-    }\r
-\r
-}\r
diff --git a/opendaylight/adsal/hosttracker/integrationtest/pom.xml b/opendaylight/adsal/hosttracker/integrationtest/pom.xml
deleted file mode 100644 (file)
index a6a39e8..0000000
+++ /dev/null
@@ -1,165 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.integrationtest</artifactId>
-    <version>0.7.0-SNAPSHOT</version>
-    <relativePath>../../commons/integrationtest</relativePath>
-  </parent>
-
-  <artifactId>hosttracker.integrationtest</artifactId>
-  <version>0.7.0-SNAPSHOT</version>
-  <properties>
-    <sonar.jacoco.itReportPath>../../implementaiton/target/jacoco-it.exec</sonar.jacoco.itReportPath>
-    <!-- Sonar jacoco plugin to get integration test coverage info -->
-    <sonar.jacoco.reportPath>../../implementation/target/jacoco.exec</sonar.jacoco.reportPath>
-  </properties>
-
-  <dependencies>
-    <dependency>
-      <groupId>ch.qos.logback</groupId>
-      <artifactId>logback-classic</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>ch.qos.logback</groupId>
-      <artifactId>logback-core</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>arphandler</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>clustering.services</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>clustering.stub</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>configuration</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>configuration.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>connectionmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>connectionmanager.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>containermanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>containermanager.it.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>hosttracker</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>hosttracker.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal.connection</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal.connection.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>switchmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>switchmanager.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>topologymanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.slf4j</groupId>
-      <artifactId>log4j-over-slf4j</artifactId>
-    </dependency>
-    <!-- Add Pax Exam -->
-    <dependency>
-      <groupId>org.ops4j.pax.exam</groupId>
-      <artifactId>pax-exam-container-native</artifactId>
-      <scope>test</scope>
-    </dependency>
-    <dependency>
-      <groupId>org.ops4j.pax.exam</groupId>
-      <artifactId>pax-exam-junit4</artifactId>
-      <scope>test</scope>
-    </dependency>
-    <dependency>
-      <groupId>org.ops4j.pax.exam</groupId>
-      <artifactId>pax-exam-link-mvn</artifactId>
-      <scope>test</scope>
-    </dependency>
-    <dependency>
-      <groupId>org.ops4j.pax.url</groupId>
-      <artifactId>pax-url-aether</artifactId>
-      <scope>test</scope>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.jacoco</groupId>
-        <artifactId>jacoco-maven-plugin</artifactId>
-        <configuration>
-          <destFile>../../implementation/target/jacoco-it.exec</destFile>
-          <includes>
-            <include>org.opendaylight.controller.*</include>
-          </includes>
-        </configuration>
-        <executions>
-          <execution>
-            <id>pre-test</id>
-            <goals>
-              <goal>prepare-agent</goal>
-            </goals>
-          </execution>
-          <execution>
-            <id>post-test</id>
-            <configuration>
-              <skip>true</skip>
-            </configuration>
-          </execution>
-        </executions>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/hosttracker/integrationtest/src/test/java/org/opendaylight/controller/hosttracker/internal/HostTrackerIT.java b/opendaylight/adsal/hosttracker/integrationtest/src/test/java/org/opendaylight/controller/hosttracker/internal/HostTrackerIT.java
deleted file mode 100644 (file)
index a454eb9..0000000
+++ /dev/null
@@ -1,276 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.hosttracker.internal;
-
-import static org.junit.Assert.assertFalse;
-import static org.junit.Assert.assertNotNull;
-import static org.junit.Assert.assertNull;
-import static org.ops4j.pax.exam.CoreOptions.junitBundles;
-import static org.ops4j.pax.exam.CoreOptions.mavenBundle;
-import static org.ops4j.pax.exam.CoreOptions.options;
-import static org.ops4j.pax.exam.CoreOptions.systemPackages;
-import static org.ops4j.pax.exam.CoreOptions.systemProperty;
-
-import java.net.InetAddress;
-import java.net.UnknownHostException;
-import java.util.Iterator;
-
-import javax.inject.Inject;
-
-import org.junit.Assert;
-import org.junit.Before;
-import org.junit.Test;
-import org.junit.runner.RunWith;
-import org.opendaylight.controller.hosttracker.IHostId;
-import org.opendaylight.controller.hosttracker.IPHostId;
-import org.opendaylight.controller.hosttracker.IfIptoHost;
-import org.opendaylight.controller.hosttracker.hostAware.HostNodeConnector;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.UpdateType;
-import org.opendaylight.controller.sal.utils.NodeConnectorCreator;
-import org.opendaylight.controller.sal.utils.NodeCreator;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.switchmanager.IInventoryListener;
-import org.ops4j.pax.exam.Option;
-import org.ops4j.pax.exam.Configuration;
-import org.ops4j.pax.exam.junit.PaxExam;
-import org.ops4j.pax.exam.util.PathUtils;
-import org.osgi.framework.Bundle;
-import org.osgi.framework.BundleContext;
-import org.osgi.framework.ServiceReference;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-//import org.opendaylight.controller.hosttracker.*;
-
-@RunWith(PaxExam.class)
-public class HostTrackerIT {
-    private Logger log = LoggerFactory.getLogger(HostTrackerIT.class);
-    // get the OSGI bundle context
-    @Inject
-    private BundleContext bc;
-
-    private IfIptoHost hosttracker = null;
-    private IInventoryListener invtoryListener = null;
-
-    // Configure the OSGi container
-    @Configuration
-    public Option[] config() {
-        return options(
-
-                //
-                systemProperty("logback.configurationFile").value(
-                        "file:" + PathUtils.getBaseDir() + "/src/test/resources/logback.xml"),
-                // To start OSGi console for inspection remotely
-                systemProperty("osgi.console").value("2401"),
-                // Set the systemPackages (used by clustering)
-                systemPackages("sun.reflect", "sun.reflect.misc", "sun.misc"),
-                // List framework bundles
-                mavenBundle("equinoxSDK381", "org.eclipse.equinox.console").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "org.eclipse.equinox.util").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "org.eclipse.osgi.services").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "org.eclipse.equinox.ds").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "org.apache.felix.gogo.command").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "org.apache.felix.gogo.runtime").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "org.apache.felix.gogo.shell").versionAsInProject(),
-                // List logger bundles
-                mavenBundle("org.slf4j", "slf4j-api").versionAsInProject(),
-                mavenBundle("org.slf4j", "log4j-over-slf4j").versionAsInProject(),
-                mavenBundle("ch.qos.logback", "logback-core").versionAsInProject(),
-                mavenBundle("ch.qos.logback", "logback-classic").versionAsInProject(),
-
-                // List all the bundles on which the test case depends
-                mavenBundle("org.opendaylight.controller", "sal").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "sal.implementation").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "sal.connection").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "sal.connection.implementation").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "connectionmanager").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "connectionmanager.implementation").versionAsInProject(),
-
-                // needed by statisticsmanager
-                mavenBundle("org.opendaylight.controller", "containermanager").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "containermanager.it.implementation").versionAsInProject(),
-
-                mavenBundle("org.opendaylight.controller", "clustering.services").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "clustering.stub").versionAsInProject(),
-
-                // needed by forwardingrulesmanager
-                mavenBundle("org.opendaylight.controller", "switchmanager").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "forwardingrulesmanager").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "statisticsmanager").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "switchmanager.implementation").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "configuration").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "configuration.implementation").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "hosttracker").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "hosttracker.implementation").versionAsInProject(),
-
-                // needed by hosttracker
-                mavenBundle("org.opendaylight.controller", "topologymanager").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "arphandler").versionAsInProject(),
-
-                mavenBundle("org.jboss.spec.javax.transaction", "jboss-transaction-api_1.1_spec").versionAsInProject(),
-                mavenBundle("org.apache.commons", "commons-lang3").versionAsInProject(),
-                mavenBundle("org.apache.felix", "org.apache.felix.dependencymanager").versionAsInProject(),
-                junitBundles());
-    }
-
-    private String stateToString(int state) {
-        switch (state) {
-        case Bundle.ACTIVE:
-            return "ACTIVE";
-        case Bundle.INSTALLED:
-            return "INSTALLED";
-        case Bundle.RESOLVED:
-            return "RESOLVED";
-        case Bundle.UNINSTALLED:
-            return "UNINSTALLED";
-        default:
-            return "Not CONVERTED";
-        }
-    }
-
-    @Before
-    public void areWeReady() {
-        assertNotNull(bc);
-        boolean debugit = false;
-        Bundle b[] = bc.getBundles();
-        for (int i = 0; i < b.length; i++) {
-            int state = b[i].getState();
-            if (state != Bundle.ACTIVE && state != Bundle.RESOLVED) {
-                log.debug("Bundle:" + b[i].getSymbolicName() + " state:" + stateToString(state));
-                debugit = true;
-            }
-        }
-        if (debugit) {
-            log.debug("Do some debugging because some bundle is " + "unresolved");
-        }
-
-        // Assert if true, if false we are good to go!
-        assertFalse(debugit);
-
-        // Now lets create a hosttracker for testing purpose
-        ServiceReference s = bc.getServiceReference(IfIptoHost.class.getName());
-        if (s != null) {
-            this.hosttracker = (IfIptoHost) bc.getService(s);
-            this.invtoryListener = (IInventoryListener) this.hosttracker;
-        }
-
-        // If StatisticsManager is null, cannot run tests.
-        assertNotNull(this.hosttracker);
-    }
-
-    @Test
-    public void testStaticHost() throws UnknownHostException {
-        String ip;
-
-        assertNotNull(this.hosttracker);
-
-        // create one node and two node connectors
-        Node node1 = NodeCreator.createOFNode(1L);
-        NodeConnector nc1_1 = NodeConnectorCreator.createOFNodeConnector((short) 1, node1);
-        NodeConnector nc1_2 = NodeConnectorCreator.createOFNodeConnector((short) 2, node1);
-
-        // test addStaticHost(), store into inactive host DB
-        Status st = this.hosttracker.addStaticHost("192.168.0.8", "11:22:33:44:55:66", nc1_1, null);
-        Assert.assertTrue(st.isSuccess());
-        st = this.hosttracker.addStaticHost("192.168.0.13", "11:22:33:44:55:77", nc1_2, "");
-        Assert.assertTrue(st.isSuccess());
-
-        // check inactive DB
-        Iterator<HostNodeConnector> hnci = this.hosttracker.getInactiveStaticHosts().iterator();
-        while (hnci.hasNext()) {
-            ip = hnci.next().getNetworkAddressAsString();
-            Assert.assertTrue(ip.equals("192.168.0.8") || ip.equals("192.168.0.13"));
-        }
-
-        // check active host DB
-        hnci = this.hosttracker.getActiveStaticHosts().iterator();
-        Assert.assertFalse(hnci.hasNext());
-
-        // test removeStaticHost()
-        st = this.hosttracker.removeStaticHost("192.168.0.8");
-        Assert.assertTrue(st.isSuccess());
-
-        hnci = this.hosttracker.getInactiveStaticHosts().iterator();
-        while (hnci.hasNext()) {
-            ip = hnci.next().getNetworkAddressAsString();
-            Assert.assertTrue(ip.equals("192.168.0.13"));
-        }
-    }
-
-    @Test
-    public void testNotifyNodeConnector() throws UnknownHostException {
-        String ip;
-
-        assertNotNull(this.invtoryListener);
-
-        // create one node and two node connectors
-        Node node1 = NodeCreator.createOFNode(1L);
-        NodeConnector nc1_1 = NodeConnectorCreator.createOFNodeConnector((short) 1, node1);
-        NodeConnector nc1_2 = NodeConnectorCreator.createOFNodeConnector((short) 2, node1);
-
-        // test addStaticHost(), put into inactive host DB if not verifiable
-        Status st = this.hosttracker.addStaticHost("192.168.0.8", "11:22:33:44:55:66", nc1_1, null);
-        Assert.assertTrue(st.isSuccess());
-        st = this.hosttracker.addStaticHost("192.168.0.13", "11:22:33:44:55:77", nc1_2, "0");
-        Assert.assertFalse(st.isSuccess());
-
-        this.invtoryListener.notifyNodeConnector(nc1_1, UpdateType.ADDED, null);
-
-        // check all host list
-        Iterator<HostNodeConnector> hnci = this.hosttracker.getAllHosts().iterator();
-        while (hnci.hasNext()) {
-            ip = hnci.next().getNetworkAddressAsString();
-            Assert.assertTrue(ip.equals("192.168.0.8"));
-        }
-
-        // check active host DB
-        hnci = this.hosttracker.getActiveStaticHosts().iterator();
-        while (hnci.hasNext()) {
-            ip = hnci.next().getNetworkAddressAsString();
-            Assert.assertTrue(ip.equals("192.168.0.8"));
-        }
-
-        // check inactive host DB
-        hnci = this.hosttracker.getInactiveStaticHosts().iterator();
-        while (hnci.hasNext()) {
-            ip = hnci.next().getNetworkAddressAsString();
-            Assert.assertTrue(ip.equals("192.168.0.13"));
-        }
-    }
-
-    @Test
-    public void testHostFind() throws UnknownHostException {
-
-        assertNotNull(this.invtoryListener);
-
-        // create one node and two node connectors
-        Node node1 = NodeCreator.createOFNode(1L);
-        NodeConnector nc1_1 = NodeConnectorCreator.createOFNodeConnector((short) 1, node1);
-        NodeConnector nc1_2 = NodeConnectorCreator.createOFNodeConnector((short) 2, node1);
-
-        // test addStaticHost(), put into inactive host DB if not verifiable
-        Status st = this.hosttracker.addStaticHost("192.168.0.8", "11:22:33:44:55:66", nc1_1, null);
-        st = this.hosttracker.addStaticHost("192.168.0.13", "11:22:33:44:55:77", nc1_2, "");
-
-        IHostId id1 = IPHostId.fromIP(InetAddress.getByName("192.168.0.8"));
-        HostNodeConnector hnc_1 = this.hosttracker.hostFind(id1);
-        assertNull(hnc_1);
-
-        this.invtoryListener.notifyNodeConnector(nc1_1, UpdateType.ADDED, null);
-
-        IHostId id2 = IPHostId.fromIP(InetAddress.getByName("192.168.0.8"));
-        hnc_1 = this.hosttracker.hostFind(id2);
-
-        assertNotNull(hnc_1);
-
-    }
-
-}
diff --git a/opendaylight/adsal/hosttracker/integrationtest/src/test/resources/logback.xml b/opendaylight/adsal/hosttracker/integrationtest/src/test/resources/logback.xml
deleted file mode 100644 (file)
index 5fa21fe..0000000
+++ /dev/null
@@ -1,13 +0,0 @@
-<configuration scan="true">\r
-\r
-  <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">\r
-    <encoder>\r
-      <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n\r
-      </pattern>\r
-    </encoder>\r
-  </appender>\r
-\r
-  <root level="error">\r
-    <appender-ref ref="STDOUT" />\r
-  </root>\r
-</configuration>\r
diff --git a/opendaylight/adsal/hosttracker/shell/pom.xml b/opendaylight/adsal/hosttracker/shell/pom.xml
deleted file mode 100644 (file)
index 2d5039c..0000000
+++ /dev/null
@@ -1,52 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-  <artifactId>hosttracker.shell</artifactId>
-  <version>${hosttracker.shell.version}</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.apache.karaf.shell</groupId>
-      <artifactId>org.apache.karaf.shell.console</artifactId>
-      <version>${karaf.version}</version>
-    </dependency>
-    <dependency>
-      <groupId>org.mockito</groupId>
-      <artifactId>mockito-all</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>hosttracker.implementation</artifactId>
-      <version>${hosttracker.implementation.version}</version>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <version>${bundle.plugin.version}</version>
-        <configuration>
-          <instructions>
-            <Import-Package>org.apache.felix.service.command,
-              org.apache.karaf.shell.commands,
-              org.apache.karaf.shell.console,
-              *</Import-Package>
-          </instructions>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-
-</project>
diff --git a/opendaylight/adsal/hosttracker/shell/src/main/java/org/opendaylight/controller/hosttracker/shell/DumpFailedARPReqList.java b/opendaylight/adsal/hosttracker/shell/src/main/java/org/opendaylight/controller/hosttracker/shell/DumpFailedARPReqList.java
deleted file mode 100644 (file)
index cb57b44..0000000
+++ /dev/null
@@ -1,28 +0,0 @@
-package org.opendaylight.controller.hosttracker.shell;
-/**
-* Copyright (c) 2014 Inocybe Technologies, and others. All rights reserved.
-*
-* This program and the accompanying materials are made available under the
-* terms of the Eclipse Public License v1.0 which accompanies this distribution,
-* and is available at http://www.eclipse.org/legal/epl-v10.html
-*/
-
-import org.apache.karaf.shell.commands.Command;
-import org.apache.karaf.shell.console.OsgiCommandSupport;
-import org.opendaylight.controller.hosttracker.IHostTrackerShell;
-
-@Command(scope = "hosttracker", name = "dumpFailedARPReqList", description="Display the dump failed ARPReqList")
-public class DumpFailedARPReqList extends OsgiCommandSupport{
-
-    private IHostTrackerShell hostTracker;
-
-    @Override
-    protected Object doExecute() throws Exception {
-        System.out.print(hostTracker.dumpFailedArpReqList());
-        return null;
-    }
-
-    public void setHostTracker(IHostTrackerShell hostTracker){
-        this.hostTracker = hostTracker;
-    }
-}
diff --git a/opendaylight/adsal/hosttracker/shell/src/main/java/org/opendaylight/controller/hosttracker/shell/DumpPendingARPReqList.java b/opendaylight/adsal/hosttracker/shell/src/main/java/org/opendaylight/controller/hosttracker/shell/DumpPendingARPReqList.java
deleted file mode 100644 (file)
index fafc48f..0000000
+++ /dev/null
@@ -1,28 +0,0 @@
-package org.opendaylight.controller.hosttracker.shell;
-/**
-* Copyright (c) 2014 Inocybe Technologies, and others. All rights reserved.
-*
-* This program and the accompanying materials are made available under the
-* terms of the Eclipse Public License v1.0 which accompanies this distribution,
-* and is available at http://www.eclipse.org/legal/epl-v10.html
-*/
-
-import org.apache.karaf.shell.commands.Command;
-import org.apache.karaf.shell.console.OsgiCommandSupport;
-import org.opendaylight.controller.hosttracker.IHostTrackerShell;
-
-@Command(scope = "hosttracker", name = "dumpPendingARPReqList", description="Display the dump pending ARPReqList")
-public class DumpPendingARPReqList extends OsgiCommandSupport{
-
-    private IHostTrackerShell hostTracker;
-
-    @Override
-    protected Object doExecute() throws Exception {
-        System.out.print(hostTracker.dumpPendingArpReqList());
-        return null;
-    }
-
-    public void setHostTracker(IHostTrackerShell hostTracker){
-        this.hostTracker = hostTracker;
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/hosttracker/shell/src/main/resources/OSGI-INF/blueprint/blueprint.xml b/opendaylight/adsal/hosttracker/shell/src/main/resources/OSGI-INF/blueprint/blueprint.xml
deleted file mode 100644 (file)
index ba79b5d..0000000
+++ /dev/null
@@ -1,17 +0,0 @@
-<blueprint xmlns="http://www.osgi.org/xmlns/blueprint/v1.0.0">
-    <reference id="HostTrackerRef" interface="org.opendaylight.controller.hosttracker.IHostTrackerShell"/>
-
-    <command-bundle xmlns="http://karaf.apache.org/xmlns/shell/v1.1.0">
-
-    <command>
-       <action class="org.opendaylight.controller.hosttracker.shell.DumpFailedARPReqList">
-          <property name="hostTracker" ref="HostTrackerRef"/>
-       </action>
-    </command>
-    <command>
-       <action class="org.opendaylight.controller.hosttracker.shell.DumpPendingARPReqList">
-          <property name="hostTracker" ref="HostTrackerRef"/>
-       </action>
-    </command>
-    </command-bundle>
-</blueprint>
diff --git a/opendaylight/adsal/hosttracker/shell/src/test/java/org/opendaylight/controller/hosttracker/shell/HostTrackerShellTest.java b/opendaylight/adsal/hosttracker/shell/src/test/java/org/opendaylight/controller/hosttracker/shell/HostTrackerShellTest.java
deleted file mode 100644 (file)
index a0a5a2e..0000000
+++ /dev/null
@@ -1,47 +0,0 @@
-package org.opendaylight.controller.hosttracker.shell;
-
-import java.io.ByteArrayOutputStream;
-import java.io.PrintStream;
-import java.util.ArrayList;
-import java.util.Arrays;
-import java.util.List;
-
-import org.junit.Assert;
-import org.junit.Test;
-import static org.mockito.Mockito.mock;
-import static org.mockito.Mockito.when;
-import org.opendaylight.controller.hosttracker.IHostTrackerShell;
-
-public class HostTrackerShellTest {
-
-    private final long COMMAND_TIMEOUT = 1000;
-    private IHostTrackerShell hostTracker;
-
-    @Test
-    public void testDumpPendingARPReqList() throws Exception {
-        DumpPendingARPReqList dumpPendTest = new DumpPendingARPReqList();
-        hostTracker = mock(IHostTrackerShell.class);
-        List<String> failedList = new ArrayList<String>(Arrays.asList("a", "b", "c"));
-        when(hostTracker.dumpPendingArpReqList()).thenReturn(failedList);
-        dumpPendTest.setHostTracker(hostTracker);
-        ByteArrayOutputStream baos = new ByteArrayOutputStream();
-        System.setOut(new PrintStream(baos));
-        dumpPendTest.doExecute();
-        //Assert.assertTrue(true);
-        Assert.assertEquals("[a, b, c]", baos.toString());
-    }
-
-    @Test
-    public void testDumpFailedARPReqList() throws Exception {
-        DumpFailedARPReqList dumpFailTest = new DumpFailedARPReqList();
-        hostTracker = mock(IHostTrackerShell.class);
-        List<String> failedList = new ArrayList<String>(Arrays.asList("a", "b", "c"));
-        when(hostTracker.dumpFailedArpReqList()).thenReturn(failedList);
-        dumpFailTest.setHostTracker(hostTracker);
-        ByteArrayOutputStream baos = new ByteArrayOutputStream();
-        System.setOut(new PrintStream(baos));
-        dumpFailTest.doExecute();
-        //Assert.assertTrue(true);
-        Assert.assertEquals("[a, b, c]", baos.toString());
-    }
-}
diff --git a/opendaylight/adsal/hosttracker_new/api/pom.xml b/opendaylight/adsal/hosttracker_new/api/pom.xml
deleted file mode 100644 (file)
index 8bb1612..0000000
+++ /dev/null
@@ -1,72 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-  <artifactId>hosttracker_new</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>clustering.services</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>switchmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>topologymanager</artifactId>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Export-Package>org.opendaylight.controller.hosttracker,
-              org.opendaylight.controller.hosttracker.hostAware</Export-Package>
-            <Import-Package>org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.sal.utils,
-              org.opendaylight.controller.topologymanager,
-              org.opendaylight.controller.sal.packet.address,
-              org.opendaylight.controller.switchmanager,
-              org.opendaylight.controller.clustering.services,
-              javax.xml.bind.annotation,
-              javax.xml.bind,
-              org.apache.felix.dm,
-              org.apache.commons.lang3.builder,
-              org.osgi.service.component,
-              org.slf4j,
-              org.eclipse.osgi.framework.console,
-              org.osgi.framework</Import-Package>
-          </instructions>
-          <manifestLocation>${project.basedir}/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/hosttracker_new/api/src/main/java/org/opendaylight/controller/hosttracker/Entity.java b/opendaylight/adsal/hosttracker_new/api/src/main/java/org/opendaylight/controller/hosttracker/Entity.java
deleted file mode 100644 (file)
index f10c116..0000000
+++ /dev/null
@@ -1,283 +0,0 @@
-/*
- * Copyright (c) 2011,2012 Big Switch Networks, Inc.
- *
- * Licensed under the Eclipse Public License, Version 1.0 (the
- * "License"); you may not use this file except in compliance with the
- * License. You may obtain a copy of the License at
- *
- *      http://www.eclipse.org/legal/epl-v10.html
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
- * implied. See the License for the specific language governing
- * permissions and limitations under the License.
- *
- * This file incorporates work covered by the following copyright and
- * permission notice:
- *
- *    Originally created by David Erickson, Stanford University
- *
- *    Licensed under the Apache License, Version 2.0 (the "License");
- *    you may not use this file except in compliance with the
- *    License. You may obtain a copy of the License at
- *
- *         http://www.apache.org/licenses/LICENSE-2.0
- *
- *    Unless required by applicable law or agreed to in writing,
- *    software distributed under the License is distributed on an "AS
- *    IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
- *    express or implied. See the License for the specific language
- *    governing permissions and limitations under the License.
- */
-
-package org.opendaylight.controller.hosttracker;
-
-import java.net.InetAddress;
-import java.util.Date;
-
-import org.opendaylight.controller.hosttracker.hostAware.HostNodeConnector;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.utils.NetUtils;
-
-/**
- * An entity on the network is a visible trace of a device that corresponds to a
- * packet received from a particular interface on the edge of a network, with a
- * particular VLAN tag, and a particular MAC address, along with any other
- * packet characteristics we might want to consider as helpful for
- * disambiguating devices.
- *
- * Entities are the most basic element of devices; devices consist of one or
- * more entities. Entities are immutable once created, except for the last seen
- * timestamp.
- *
- * @author readams
- *
- */
-public class Entity implements Comparable<Entity> {
-    /**
-     * Timeout for computing {@link Entity#activeSince}.
-     *
-     * @see {@link Entity#activeSince}
-     */
-    protected static int ACTIVITY_TIMEOUT = 30000;
-
-    /**
-     * The MAC address associated with this entity
-     */
-    protected long macAddress;
-
-    /**
-     * The IP address associated with this entity, or null if no IP learned from
-     * the network observation associated with this entity
-     */
-    protected Integer ipv4Address;
-
-    /**
-     * The VLAN tag on this entity, or null if untagged
-     */
-    protected Short vlan;
-
-    /**
-     * The attachment point for this entity
-     */
-    NodeConnector port;
-
-    /**
-     * The last time we observed this entity on the network
-     */
-    protected Date lastSeenTimestamp;
-
-    /**
-     * The time between {@link Entity#activeSince} and
-     * {@link Entity#lastSeenTimestamp} is a period of activity for this entity
-     * where it was observed repeatedly. If, when the entity is observed, the is
-     * longer ago than the activity timeout, {@link Entity#lastSeenTimestamp}
-     * and {@link Entity#activeSince} will be set to the current time.
-     */
-    protected Date activeSince;
-
-    private int hashCode = 0;
-
-    // ************
-    // Constructors
-    // ************
-
-    /**
-     * Create a new entity
-     *
-     * @param macAddress
-     * @param vlan
-     * @param ipv4Address
-     * @param switchDPID
-     * @param switchPort
-     * @param lastSeenTimestamp
-     */
-    public Entity(long macAddress, Short vlan, Integer ipv4Address,
-            NodeConnector port, Date lastSeenTimestamp) {
-        this.macAddress = macAddress;
-        this.ipv4Address = ipv4Address;
-        this.vlan = vlan;
-        this.port = port;
-        this.lastSeenTimestamp = lastSeenTimestamp;
-        this.activeSince = lastSeenTimestamp;
-    }
-
-    // ***************
-    // Getters/Setters
-    // ***************
-
-    // @JsonSerialize(using=MACSerializer.class)
-    public long getMacAddress() {
-        return macAddress;
-    }
-
-    // @JsonSerialize(using=IPv4Serializer.class)
-    public Integer getIpv4Address() {
-        return ipv4Address;
-    }
-
-    public Short getVlan() {
-        return vlan;
-    }
-
-    public NodeConnector getPort() {
-        return port;
-    }
-
-    // @JsonIgnore
-    public boolean hasSwitchPort() {
-        return port != null;
-    }
-
-    public Date getLastSeenTimestamp() {
-        return lastSeenTimestamp;
-    }
-
-    /**
-     * Set the last seen timestamp and also update {@link Entity#activeSince} if
-     * appropriate
-     *
-     * @param lastSeenTimestamp
-     *            the new last seen timestamp
-     * @see {@link Entity#activeSince}
-     */
-    public void setLastSeenTimestamp(Date lastSeenTimestamp) {
-        if (activeSince == null
-                || (activeSince.getTime() + ACTIVITY_TIMEOUT) < lastSeenTimestamp
-                        .getTime()) {
-            this.activeSince = lastSeenTimestamp;
-        }
-        this.lastSeenTimestamp = lastSeenTimestamp;
-    }
-
-    public Date getActiveSince() {
-        return activeSince;
-    }
-
-    public void setActiveSince(Date activeSince) {
-        this.activeSince = activeSince;
-    }
-
-    @Override
-    public int hashCode() {
-        if (hashCode != 0) {
-            return hashCode;
-        }
-        final int prime = 31;
-        hashCode = 1;
-        hashCode = prime * hashCode
-                + ((ipv4Address == null) ? 0 : ipv4Address.hashCode());
-        hashCode = prime * hashCode + (int) (macAddress ^ (macAddress >>> 32));
-        hashCode = prime * hashCode + ((port == null) ? 0 : port.hashCode());
-        hashCode = prime * hashCode + ((vlan == null) ? 0 : vlan.hashCode());
-        return hashCode;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        Entity other = (Entity) obj;
-        if (ipv4Address == null) {
-            if (other.ipv4Address != null) {
-                return false;
-            }
-        } else if (!ipv4Address.equals(other.ipv4Address)) {
-            return false;
-        }
-        if (macAddress != other.macAddress) {
-            return false;
-        }
-        if (port == null) {
-            if (other.port != null) {
-                return false;
-            }
-        } else if (!port.equals(other.port)) {
-            return false;
-        }
-        if (vlan == null) {
-            if (other.vlan != null) {
-                return false;
-            }
-        } else if (!vlan.equals(other.vlan)) {
-            return false;
-        }
-        return true;
-    }
-
-    public HostNodeConnector toHostNodeConnector() {
-        try {
-            NodeConnector n = this.getPort();
-            InetAddress ip = InetAddress.getByAddress(NetUtils.intToByteArray4(this.getIpv4Address()));
-            byte[] macAddr = NetUtils.longToByteArray6(this.getMacAddress());
-            HostNodeConnector nc = new HostNodeConnector(macAddr, ip, n,
-                    (short) 0);
-            return nc;
-        } catch (Exception e) {
-            return null;
-        }
-    }
-
-    @Override
-    public String toString() {
-        return "Entity [macAddress=" + macAddress + ", ipv4Address="
-                + ipv4Address + ", vlan=" + vlan + ", port=" + port + "]";
-    }
-
-    @SuppressWarnings({ "rawtypes", "unchecked" })
-    @Override
-    public int compareTo(Entity o) {
-        int r;
-        if (port == null) {
-            r = o.port == null ? 0 : -1;
-        }
-        else if (o.port == null) {
-            r = 1;
-        }
-        else {
-            // XXX - the node id is only defined as an object rather
-            // than something useful. We're just going to have to
-            // blindly cast to Comparable and hope it works.
-            Comparable switchId = (Comparable) port.getNode().getID();
-            Comparable oswitchId = (Comparable) o.port.getNode().getID();
-            r = switchId.compareTo(oswitchId);
-            if (r != 0) {
-                return r;
-            }
-
-            Comparable portId = (Comparable) port.getID();
-            Comparable oportId = (Comparable) o.port.getID();
-            r = portId.compareTo(oportId);
-        }
-        return r;
-    }
-
-}
diff --git a/opendaylight/adsal/hosttracker_new/api/src/main/java/org/opendaylight/controller/hosttracker/IDevice.java b/opendaylight/adsal/hosttracker_new/api/src/main/java/org/opendaylight/controller/hosttracker/IDevice.java
deleted file mode 100644 (file)
index 8c9367e..0000000
+++ /dev/null
@@ -1,143 +0,0 @@
-/*
- * Copyright (c) 2011,2012 Big Switch Networks, Inc.
- *
- * Licensed under the Eclipse Public License, Version 1.0 (the
- * "License"); you may not use this file except in compliance with the
- * License. You may obtain a copy of the License at
- *
- *      http://www.eclipse.org/legal/epl-v10.html
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
- * implied. See the License for the specific language governing
- * permissions and limitations under the License.
- *
- * This file incorporates work covered by the following copyright and
- * permission notice:
- *
- *    Originally created by David Erickson, Stanford University
- *
- *    Licensed under the Apache License, Version 2.0 (the "License");
- *    you may not use this file except in compliance with the
- *    License. You may obtain a copy of the License at
- *
- *         http://www.apache.org/licenses/LICENSE-2.0
- *
- *    Unless required by applicable law or agreed to in writing,
- *    software distributed under the License is distributed on an "AS
- *    IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
- *    express or implied. See the License for the specific language
- *    governing permissions and limitations under the License.
- */
-
-package org.opendaylight.controller.hosttracker;
-
-import java.util.Date;
-
-import org.opendaylight.controller.hosttracker.hostAware.HostNodeConnector;
-
-/**
- * Represents an independent device on the network. A device consists of a set
- * of entities, and all the information known about a given device comes only
- * from merging all associated entities for that device.
- *
- * @author readams
- */
-public interface IDevice {
-    /**
-     * Get the primary key for this device.
-     *
-     * @return the primary key
-     */
-    public Long getDeviceKey();
-
-    /**
-     * Get the MAC address of the device as a Long value.
-     *
-     * @return the MAC address for the device
-     */
-    public long getMACAddress();
-
-    /**
-     * Get the MAC address of the device as a String value.
-     *
-     * @return the MAC address for the device
-     */
-    public String getMACAddressString();
-
-    /**
-     * Get all unique VLAN IDs for the device. If the device has untagged
-     * entities, then the value -1 will be returned.
-     *
-     * @return an array containing all unique VLAN IDs for the device.
-     */
-    public Short[] getVlanId();
-
-    /**
-     * Get all unique IPv4 addresses associated with the device.
-     *
-     * @return an array containing the unique IPv4 addresses for the device.
-     */
-    public Integer[] getIPv4Addresses();
-
-    /**
-     * Get all unique attachment points associated with the device. This will
-     * not include any blocked attachment points.
-     *
-     * @return an array containing all unique attachment points for the device
-     */
-    public SwitchPort[] getAttachmentPoints();
-
-    /**
-     * Get all old attachment points associated with the device. this is used in
-     * host movement scenario.
-     *
-     * @return an array containing all unique old attachment points for the
-     *         device
-     */
-    public SwitchPort[] getOldAP();
-
-    /**
-     * Get all unique attachment points associated with the device.
-     *
-     * @param includeError
-     *            whether to include blocked attachment points. Blocked
-     *            attachment points should not be used for forwarding, but could
-     *            be useful to show to a user
-     * @return an array containing all unique attachment points for the device
-     */
-    public SwitchPort[] getAttachmentPoints(boolean includeError);
-
-    /**
-     * Returns all unique VLAN IDs for the device that were observed on the
-     * given switch port
-     *
-     * @param swp
-     *            the switch port to query
-     * @return an array containing the unique VLAN IDs
-     */
-    public Short[] getSwitchPortVlanIds(SwitchPort swp);
-
-    /**
-     * Get the most recent timestamp for this device
-     *
-     * @return the last seen timestamp
-     */
-    public Date getLastSeen();
-
-    /**
-     * Get the entity class for the device.
-     *
-     * @return the entity class
-     * @see IEntityClassifierService
-     */
-    public IEntityClass getEntityClass();
-
-    public boolean isStaticHost();
-
-    public void setStaticHost(boolean isStatic);
-
-    public HostNodeConnector toHostNodeConnector();
-
-}
diff --git a/opendaylight/adsal/hosttracker_new/api/src/main/java/org/opendaylight/controller/hosttracker/IDeviceListener.java b/opendaylight/adsal/hosttracker_new/api/src/main/java/org/opendaylight/controller/hosttracker/IDeviceListener.java
deleted file mode 100644 (file)
index 5861915..0000000
+++ /dev/null
@@ -1,87 +0,0 @@
-/*
- * Copyright (c) 2011 Big Switch Networks, Inc.
- *
- * Licensed under the Eclipse Public License, Version 1.0 (the
- * "License"); you may not use this file except in compliance with the
- * License. You may obtain a copy of the License at
- *
- *      http://www.eclipse.org/legal/epl-v10.html
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
- * implied. See the License for the specific language governing
- * permissions and limitations under the License.
- *
- * This file incorporates work covered by the following copyright and
- * permission notice:
- *
- *    Originally created by David Erickson, Stanford University
- *
- *    Licensed under the Apache License, Version 2.0 (the "License");
- *    you may not use this file except in compliance with the
- *    License. You may obtain a copy of the License at
- *
- *         http://www.apache.org/licenses/LICENSE-2.0
- *
- *    Unless required by applicable law or agreed to in writing,
- *    software distributed under the License is distributed on an "AS
- *    IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
- *    express or implied. See the License for the specific language
- *    governing permissions and limitations under the License.
- */
-
-package org.opendaylight.controller.hosttracker;
-
-import org.opendaylight.controller.sal.utils.IListener;
-
-/**
- * Implementors of this interface can receive updates from DeviceManager about
- * the state of devices under its control.
- *
- * @author David Erickson (daviderickson@cs.stanford.edu)
- */
-public interface IDeviceListener extends IListener<String> {
-    /**
-     * Called when a new Device is found
-     *
-     * @param device
-     *            the device that changed
-     */
-    public void deviceAdded(IDevice device);
-
-    /**
-     * Called when a Device is removed, this typically occurs when the port the
-     * Device is attached to goes down, or the switch it is attached to is
-     * removed.
-     *
-     * @param device
-     *            the device that changed
-     */
-    public void deviceRemoved(IDevice device);
-
-    /**
-     * Called when a Device has moved to a new location on the network. Note
-     * that either the switch or the port or both has changed.
-     *
-     * @param device
-     *            the device that changed
-     */
-    public void deviceMoved(IDevice device);
-
-    /**
-     * Called when a network address has been added or remove from a device
-     *
-     * @param device
-     *            the device that changed
-     */
-    public void deviceIPV4AddrChanged(IDevice device);
-
-    /**
-     * Called when a VLAN tag for the device has been added or removed
-     *
-     * @param device
-     *            the device that changed
-     */
-    public void deviceVlanChanged(IDevice device);
-}
diff --git a/opendaylight/adsal/hosttracker_new/api/src/main/java/org/opendaylight/controller/hosttracker/IDeviceService.java b/opendaylight/adsal/hosttracker_new/api/src/main/java/org/opendaylight/controller/hosttracker/IDeviceService.java
deleted file mode 100755 (executable)
index 53b23f2..0000000
+++ /dev/null
@@ -1,215 +0,0 @@
-/*
- * Copyright (c) 2011,2012 Big Switch Networks, Inc.
- *
- * Licensed under the Eclipse Public License, Version 1.0 (the
- * "License"); you may not use this file except in compliance with the
- * License. You may obtain a copy of the License at
- *
- *      http://www.eclipse.org/legal/epl-v10.html
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
- * implied. See the License for the specific language governing
- * permissions and limitations under the License.
- *
- * This file incorporates work covered by the following copyright and
- * permission notice:
- *
- *    Originally created by David Erickson, Stanford University
- *
- *    Licensed under the Apache License, Version 2.0 (the "License");
- *    you may not use this file except in compliance with the
- *    License. You may obtain a copy of the License at
- *
- *         http://www.apache.org/licenses/LICENSE-2.0
- *
- *    Unless required by applicable law or agreed to in writing,
- *    software distributed under the License is distributed on an "AS
- *    IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
- *    express or implied. See the License for the specific language
- *    governing permissions and limitations under the License.
- */
-
-package org.opendaylight.controller.hosttracker;
-
-import java.util.Collection;
-import java.util.EnumSet;
-import java.util.Iterator;
-import java.util.Set;
-
-import org.opendaylight.controller.sal.core.NodeConnector;
-
-/**
- * Device manager allows interacting with devices on the network. Note that
- * under normal circumstances, {@link Device} objects should be retrieved from
- * the {@link FloodlightContext} rather than from {@link IDeviceManager}.
- */
-public interface IDeviceService {
-
-    /**
-     * Fields used in devices for indexes and querying
-     *
-     * @see IDeviceService#addIndex
-     */
-    enum DeviceField {
-        MAC, IPV4, VLAN, SWITCHPORT
-    }
-
-    /**
-     * Get the device with the given device key.
-     *
-     * @param deviceKey
-     *            the key to search for
-     * @return the device associated with the key, or null if no such device
-     * @see IDevice#getDeviceKey()
-     */
-    public IDevice getDevice(Long deviceKey);
-
-    /**
-     * Search for a device exactly matching the provided device fields. This is
-     * the same lookup process that is used for packet_in processing and device
-     * learning. Thus, findDevice() can be used to match flow entries from
-     * switches to devices. Only the key fields as defined by the
-     * {@link IEntityClassifierService} will be important in this search. All
-     * key fields MUST be supplied.
-     *
-     * {@link queryDevices()} might be more appropriate!
-     *
-     * @param macAddress
-     *            The MAC address
-     * @param vlan
-     *            the VLAN. Null means no VLAN and is valid even if VLAN is a
-     *            key field.
-     * @param ipv4Address
-     *            the ipv4 address
-     * @param port
-     *            the node connector
-     * @return an {@link IDevice} or null if no device is found.
-     * @see IDeviceManager#setEntityClassifier(IEntityClassifierService)
-     * @throws IllegalArgumentException
-     *             if not all key fields of the current
-     *             {@link IEntityClassifierService} are specified.
-     */
-    public IDevice findDevice(long macAddress, Short vlan, Integer ipv4Address,
-            NodeConnector port) throws IllegalArgumentException;
-
-    /**
-     * Get a destination device using entity fields that corresponds with the
-     * given source device. The source device is important since there could be
-     * ambiguity in the destination device without the attachment point
-     * information. Search for a device in a given entity class. This is the
-     * same as the lookup process for destination devices.
-     *
-     * Only the key fields as defined by the reference entity class will be
-     * important in this search. All key fields MUST be supplied.
-     *
-     * @param entityClass
-     *            The entity class in which to perform the lookup.
-     * @param macAddress
-     *            The MAC address for the destination
-     * @param vlan
-     *            the VLAN if available
-     * @param ipv4Address
-     *            The IP address if available.
-     * @return an {@link IDevice} or null if no device is found.
-     * @see IDeviceService#findDevice(long, Short, Integer, Long, Integer)
-     * @throws IllegalArgumentException
-     *             if not all key fields of the source's {@link IEntityClass}
-     *             are specified.
-     */
-    public IDevice findClassDevice(IEntityClass entityClass, long macAddress,
-            Short vlan, Integer ipv4Address) throws IllegalArgumentException;
-
-    /**
-     * Get an unmodifiable collection view over all devices currently known.
-     *
-     * @return the collection of all devices
-     */
-    public Collection<? extends IDevice> getAllDevices();
-
-    /**
-     * Create an index over a set of fields. This allows efficient lookup of
-     * devices when querying using the indexed set of specified fields. The
-     * index must be registered before any device learning takes place, or it
-     * may be incomplete. It's OK if this is called multiple times with the same
-     * fields; only one index will be created for each unique set of fields.
-     *
-     * @param perClass
-     *            set to true if the index should be maintained for each entity
-     *            class separately.
-     * @param keyFields
-     *            the set of fields on which to index
-     */
-    public void addIndex(boolean perClass, EnumSet<DeviceField> keyFields);
-
-    /**
-     * Find devices that match the provided query. Any fields that are null will
-     * not be included in the query. If there is an index for the query, then it
-     * will be performed efficiently using the index. Otherwise, there will be a
-     * full scan of the device list.
-     *
-     * @param macAddress
-     *            The MAC address
-     * @param vlan
-     *            the VLAN
-     * @param ipv4Address
-     *            the ipv4 address
-     * @param port
-     *            the switch port
-     * @return an iterator over a set of devices matching the query
-     * @see IDeviceService#queryClassDevices(IEntityClass, Long, Short, Integer,
-     *      Long, Integer)
-     */
-    public Iterator<? extends IDevice> queryDevices(Long macAddress,
-            Short vlan, Integer ipv4Address, NodeConnector port);
-
-    /**
-     * Find devices that match the provided query. Only the index for the
-     * specified class will be searched. Any fields that are null will not be
-     * included in the query. If there is an index for the query, then it will
-     * be performed efficiently using the index. Otherwise, there will be a full
-     * scan of the device list.
-     *
-     * @param entityClass
-     *            The entity class in which to perform the query
-     * @param macAddress
-     *            The MAC address
-     * @param vlan
-     *            the VLAN
-     * @param ipv4Address
-     *            the ipv4 address
-     * @param port
-     *            the switch port
-     * @return an iterator over a set of devices matching the query
-     * @see IDeviceService#queryClassDevices(Long, Short, Integer, Long,
-     *      Integer)
-     */
-    public Iterator<? extends IDevice> queryClassDevices(
-            IEntityClass entityClass, Long macAddress, Short vlan,
-            Integer ipv4Address, NodeConnector port);
-
-    /**
-     * Adds a listener to listen for IDeviceManagerServices notifications
-     *
-     * @param listener
-     *            The listener that wants the notifications
-     * @param type
-     *            The type of the listener
-     */
-    public void addListener(IDeviceListener listener);
-
-    /**
-     * Specify points in the network where attachment points are not to be
-     * learned.
-     *
-     * @param sw
-     * @param port
-     */
-    public void addSuppressAPs(NodeConnector port);
-
-    public void removeSuppressAPs(NodeConnector port);
-
-    public Set<SwitchPort> getSuppressAPs();
-
-}
diff --git a/opendaylight/adsal/hosttracker_new/api/src/main/java/org/opendaylight/controller/hosttracker/IEntityClass.java b/opendaylight/adsal/hosttracker_new/api/src/main/java/org/opendaylight/controller/hosttracker/IEntityClass.java
deleted file mode 100644 (file)
index 5d57e4d..0000000
+++ /dev/null
@@ -1,73 +0,0 @@
-/*
- * Copyright (c) 2011,2012 Big Switch Networks, Inc.
- *
- * Licensed under the Eclipse Public License, Version 1.0 (the
- * "License"); you may not use this file except in compliance with the
- * License. You may obtain a copy of the License at
- *
- *      http://www.eclipse.org/legal/epl-v10.html
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
- * implied. See the License for the specific language governing
- * permissions and limitations under the License.
- *
- * This file incorporates work covered by the following copyright and
- * permission notice:
- *
- *    Originally created by David Erickson, Stanford University
- *
- *    Licensed under the Apache License, Version 2.0 (the "License");
- *    you may not use this file except in compliance with the
- *    License. You may obtain a copy of the License at
- *
- *         http://www.apache.org/licenses/LICENSE-2.0
- *
- *    Unless required by applicable law or agreed to in writing,
- *    software distributed under the License is distributed on an "AS
- *    IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
- *    express or implied. See the License for the specific language
- *    governing permissions and limitations under the License.
- */
-
-package org.opendaylight.controller.hosttracker;
-
-import java.util.EnumSet;
-
-import org.opendaylight.controller.hosttracker.IDeviceService.DeviceField;
-
-/**
- * Entities within an entity class are grouped into {@link Device} objects based
- * on the {@link IEntityClass}, and the key fields specified by the entity
- * class. A set of entities are considered to be the same device if and only if
- * they belong to the same entity class and they match on all key fields for
- * that entity class. A field is effectively wildcarded by not including it in
- * the list of key fields returned by {@link IEntityClassifierService} and/or
- * {@link IEntityClass}.
- *
- * Note that if you're not using static objects, you'll need to override
- * {@link Object#equals(Object)} and {@link Object#hashCode()}.
- *
- * @author readams
- *
- */
-public interface IEntityClass {
-    /**
-     * Return the set of key fields for this entity class. Entities belonging to
-     * this class that differ in fields not included in this collection will be
-     * considered the same device. The key fields for an entity class must not
-     * change unless associated with a flush of that entity class.
-     *
-     * @return a set containing the fields that should not be wildcarded. May be
-     *         null to indicate that all fields are key fields.
-     */
-    EnumSet<DeviceField> getKeyFields();
-
-    /**
-     * Returns a user-friendly, unique name for this EntityClass
-     *
-     * @return the name of the entity class
-     */
-    String getName();
-}
diff --git a/opendaylight/adsal/hosttracker_new/api/src/main/java/org/opendaylight/controller/hosttracker/IEntityClassListener.java b/opendaylight/adsal/hosttracker_new/api/src/main/java/org/opendaylight/controller/hosttracker/IEntityClassListener.java
deleted file mode 100644 (file)
index be5f258..0000000
+++ /dev/null
@@ -1,53 +0,0 @@
-/*
- * Copyright (c) 2011 Big Switch Networks, Inc.
- *
- * Licensed under the Eclipse Public License, Version 1.0 (the
- * "License"); you may not use this file except in compliance with the
- * License. You may obtain a copy of the License at
- *
- *      http://www.eclipse.org/legal/epl-v10.html
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
- * implied. See the License for the specific language governing
- * permissions and limitations under the License.
- *
- * This file incorporates work covered by the following copyright and
- * permission notice:
- *
- *    Originally created by David Erickson, Stanford University
- *
- *    Licensed under the Apache License, Version 2.0 (the "License");
- *    you may not use this file except in compliance with the
- *    License. You may obtain a copy of the License at
- *
- *         http://www.apache.org/licenses/LICENSE-2.0
- *
- *    Unless required by applicable law or agreed to in writing,
- *    software distributed under the License is distributed on an "AS
- *    IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
- *    express or implied. See the License for the specific language
- *    governing permissions and limitations under the License.
- */
-
-package org.opendaylight.controller.hosttracker;
-
-import java.util.Set;
-
-/**
- * Implementors of this interface can receive updates from the Entity Classifier
- * about the changes to entity Classes.
- *
- * @author Ananth Suryanarayana (Ananth.Suryanarayana@bigswitch.com)
- */
-public interface IEntityClassListener {
-
-    /**
-     * Process entity classes change event.
-     *
-     * @param entityClassNames
-     *            Set of entity classes changed
-     */
-    public void entityClassChanged(Set<String> entityClassNames);
-}
diff --git a/opendaylight/adsal/hosttracker_new/api/src/main/java/org/opendaylight/controller/hosttracker/IEntityClassifierService.java b/opendaylight/adsal/hosttracker_new/api/src/main/java/org/opendaylight/controller/hosttracker/IEntityClassifierService.java
deleted file mode 100644 (file)
index f6071e1..0000000
+++ /dev/null
@@ -1,126 +0,0 @@
-/*
- * Copyright (c) 2011,2012 Big Switch Networks, Inc.
- *
- * Licensed under the Eclipse Public License, Version 1.0 (the
- * "License"); you may not use this file except in compliance with the
- * License. You may obtain a copy of the License at
- *
- *      http://www.eclipse.org/legal/epl-v10.html
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
- * implied. See the License for the specific language governing
- * permissions and limitations under the License.
- *
- * This file incorporates work covered by the following copyright and
- * permission notice:
- *
- *    Originally created by David Erickson, Stanford University
- *
- *    Licensed under the Apache License, Version 2.0 (the "License");
- *    you may not use this file except in compliance with the
- *    License. You may obtain a copy of the License at
- *
- *         http://www.apache.org/licenses/LICENSE-2.0
- *
- *    Unless required by applicable law or agreed to in writing,
- *    software distributed under the License is distributed on an "AS
- *    IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
- *    express or implied. See the License for the specific language
- *    governing permissions and limitations under the License.
- */
-
-package org.opendaylight.controller.hosttracker;
-
-import java.util.Collection;
-import java.util.EnumSet;
-
-import org.opendaylight.controller.hosttracker.IDeviceService.DeviceField;
-
-/**
- * A component that wishes to participate in entity classification needs to
- * implement the IEntityClassifier interface, and register with the Device
- * Manager as an entity classifier. An entity is classified by the classifier
- * into an {@link IEntityClass}
- *
- * @author readams
- */
-public interface IEntityClassifierService {
-    /**
-     * Classify the given entity into an IEntityClass. It is important that the
-     * key fields returned by {@link IEntityClassifierService#getKeyFields()} be
-     * sufficient for classifying entities. That is, if two entities are
-     * identical except for a field that is not a key field, they must be
-     * assigned the same class. Furthermore, entity classification must be
-     * transitive: For all entities x, y, z, if x and y belong to a class c, and
-     * y and z belong class c, then x and z must belong to class c.
-     *
-     * @param entity
-     *            the entity to classify
-     * @return the IEntityClass resulting from the classification.
-     * @see IEntityClassifierService#getKeyFields()
-     */
-    IEntityClass classifyEntity(Entity entity);
-
-    /**
-     * Return the most general list of fields that should be used as key fields.
-     * If devices differ in any fields not listed here, they can never be
-     * considered a different device by any {@link IEntityClass} returned by
-     * {@link IEntityClassifierService#classifyEntity}. The key fields for an
-     * entity classifier must not change unless associated with a flush of all
-     * entity state. The list of key fields must be the union of all key fields
-     * that could be returned by {@link IEntityClass#getKeyFields()}.
-     *
-     * @return a set containing the fields that should not be wildcarded. May be
-     *         null to indicate that all fields are key fields.
-     * @see {@link IEntityClass#getKeyFields()}
-     * @see {@link IEntityClassifierService#classifyEntity}
-     */
-    EnumSet<DeviceField> getKeyFields();
-
-    /**
-     * Reclassify the given entity into a class. When reclassifying entities, it
-     * can be helpful to take into account the current classification either as
-     * an optimization or to allow flushing any cached state tied to the key for
-     * that device. The entity will be assigned to a new device with a new
-     * object if the entity class returned is different from the entity class
-     * for curDevice.
-     *
-     * <p>
-     * Note that you must take steps to ensure you always return classes in some
-     * consistent ordering.
-     *
-     * @param curDevice
-     *            the device currently associated with the entity
-     * @param entity
-     *            the entity to reclassify
-     * @return the IEntityClass resulting from the classification
-     */
-    IEntityClass reclassifyEntity(IDevice curDevice, Entity entity);
-
-    /**
-     * Once reclassification is complete for a device, this method will be
-     * called. If any entities within the device changed their classification,
-     * it will split into one or more new devices for each of the entities. If
-     * two devices are merged because of a reclassification, then this will be
-     * called on each of the devices, with the same device in the newDevices
-     * collection.
-     *
-     * @param oldDevice
-     *            the original device object
-     * @param newDevices
-     *            all the new devices derived from the entities of the old
-     *            device. If null, the old device was unchanged.
-     */
-    void deviceUpdate(IDevice oldDevice,
-            Collection<? extends IDevice> newDevices);
-
-    /**
-     * Adds a listener to listen for IEntityClassifierServices notifications
-     *
-     * @param listener
-     *            The listener that wants the notifications
-     */
-    public void addListener(IEntityClassListener listener);
-}
diff --git a/opendaylight/adsal/hosttracker_new/api/src/main/java/org/opendaylight/controller/hosttracker/IfHostListener.java b/opendaylight/adsal/hosttracker_new/api/src/main/java/org/opendaylight/controller/hosttracker/IfHostListener.java
deleted file mode 100644 (file)
index 51d68d8..0000000
+++ /dev/null
@@ -1,31 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.hosttracker;
-
-import org.opendaylight.controller.hosttracker.hostAware.HostNodeConnector;
-
-/**
- * This interface defines the method to notify detected Host on the network. The
- * information includes Host's IP address, MAC address, switch ID, port, and
- * VLAN.
- *
- */
-
-public interface IfHostListener {
-    /**
-     * Learns new Hosts. Called by ArpHandler and implemented in
-     * HostTracker.java. If a Host is learned for the first time then adds it to
-     * the local database and informs other applications of coming up a new
-     * Host. For the hosts which it has already learned, it refreshes them.
-     *
-     * @param host
-     *            Host info encapsulated in HostNodeConnector class
-     */
-    public void hostListener(HostNodeConnector host);
-}
diff --git a/opendaylight/adsal/hosttracker_new/api/src/main/java/org/opendaylight/controller/hosttracker/IfIptoHost.java b/opendaylight/adsal/hosttracker_new/api/src/main/java/org/opendaylight/controller/hosttracker/IfIptoHost.java
deleted file mode 100644 (file)
index 995ee57..0000000
+++ /dev/null
@@ -1,138 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.hosttracker;
-
-import java.net.InetAddress;
-import java.util.List;
-import java.util.Set;
-import java.util.concurrent.Future;
-
-import org.opendaylight.controller.hosttracker.hostAware.HostNodeConnector;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.utils.Status;
-
-/**
- * This interface defines the methods to retrieve information about learned
- * Hosts. Also provides methods to statically add/remove Hosts from the local
- * database.
- *
- */
-
-public interface IfIptoHost {
-    /**
-     * Applications call this interface methods to determine IP address to MAC
-     * binding and its connectivity to an OpenFlow switch in term of Node, Port,
-     * and VLAN. These bindings are learned dynamically as well as can be added
-     * statically through Northbound APIs. If a binding is unknown, then an ARP
-     * request is initiated immediately to discover the host.
-     *
-     * @param networkAddress
-     *            IP Address of the Host encapsulated in class InetAddress
-     * @return {@link org.opendaylight.controller.hosttracker.hostAware.HostNodeConnector}
-     *         Class that contains the Host info such as its MAC address, Switch
-     *         ID, port, VLAN. If Host is not found, returns NULL
-     */
-    public HostNodeConnector hostFind(InetAddress networkAddress);
-
-    /**
-     * Checks the local Host Database to see if a Host has been learned for a
-     * given IP address.
-     *
-     * @param networkAddress
-     *            IP Address of the Host encapsulated in class InetAddress
-     * @return {@link org.opendaylight.controller.hosttracker.hostAware.HostNodeConnector}
-     *         Class that contains the Host info such as its MAC address, Switch
-     *         ID, port, VLAN. If Host is not found, returns NULL
-     *
-     */
-    public HostNodeConnector hostQuery(InetAddress networkAddress);
-
-    /**
-     * Initiates an immediate discovery of the Host for a given IP address. This
-     * provides for the calling applications to block on the host discovery.
-     *
-     * @param networkAddress
-     *            IP address encapsulated in InetAddress class
-     * @return Future
-     *         {@link org.opendaylight.controller.hosttracker.HostTrackerCallable}
-     */
-    public Future<HostNodeConnector> discoverHost(InetAddress networkAddress);
-
-    /**
-     * Returns the Network Hierarchy for a given Host. This API is typically
-     * used by applications like Hadoop for Rack Awareness functionality.
-     *
-     * @param IP
-     *            address of the Host encapsulated in InetAddress class
-     * @return List of String ArrayList containing the Hierarchies.
-     */
-    public List<List<String>> getHostNetworkHierarchy(InetAddress hostAddress);
-
-    /**
-     * Returns all the the Hosts either learned dynamically or added statically
-     * via Northbound APIs.
-     *
-     * @return Set of
-     *         {@link org.opendaylight.controller.hosttracker.hostAware.HostNodeConnector}
-     *         . Class that contains the Host info such as its MAC address,
-     *         Switch ID, port, VLAN.
-     */
-    public Set<HostNodeConnector> getAllHosts();
-
-    /**
-     * Returns all the "Active Hosts" learned "Statically" via Northbound APIs.
-     * These Hosts are categorized as "Active" because the Switch and Port they
-     * are connected to, are in up state.
-     *
-     * @return Set of
-     *         {@link org.opendaylight.controller.hosttracker.hostAware.HostNodeConnector}
-     *         . Class that contains the Host info such as MAC address, Switch
-     *         ID, port, VLAN. If Host is not found, returns NULL
-     */
-    public Set<HostNodeConnector> getActiveStaticHosts();
-
-    /**
-     * Returns all the "Inactive Hosts" learned "Statically" via Northbound
-     * APIs. These Hosts are categorized as "Inactive" because either the Switch
-     * or the Port they are connected to, is in down state.
-     *
-     * @return Set of HostNodeConnector
-     *         {@link org.opendaylight.controller.hosttracker.hostAware.HostNodeConnector}
-     *         . HostNodeConnector is Class that contains the Host info such as
-     *         its MAC address, OpenFlowNode ID, port, VLAN.
-     */
-    public Set<HostNodeConnector> getInactiveStaticHosts();
-
-    /**
-     * Hosts can be learned dynamically or added statically. This method allows
-     * the addition of a Host to the local database statically.
-     *
-     * @param networkAddress
-     *            IP Address of the Host
-     * @param dataLayerAddress
-     *            MAC Address of the Host
-     * @param nc
-     *            NodeConnector to which the host is attached
-     * @param vlan
-     *            VLAN the host belongs to
-     * @return The status object as described in {@code Status} indicating the
-     *         result of this action.
-     */
-    public Status addStaticHost(String networkAddress, String dataLayerAddress,
-            NodeConnector nc, String vlan);
-
-    /**
-     * Allows the deletion of statically learned Host
-     *
-     * @param networkAddress
-     * @return The status object as described in {@code Status} indicating the
-     *         result of this action.
-     */
-    public Status removeStaticHost(String networkAddress);
-}
diff --git a/opendaylight/adsal/hosttracker_new/api/src/main/java/org/opendaylight/controller/hosttracker/IfNewHostNotify.java b/opendaylight/adsal/hosttracker_new/api/src/main/java/org/opendaylight/controller/hosttracker/IfNewHostNotify.java
deleted file mode 100644 (file)
index ef900e4..0000000
+++ /dev/null
@@ -1,37 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.hosttracker;
-
-import org.opendaylight.controller.hosttracker.hostAware.HostNodeConnector;
-
-/**
- * This Interface defines the methods for client applications of Host Tracker to
- * get notifications when a new host is learned or existing host is removed from
- * the network.
- *
- */
-public interface IfNewHostNotify {
-    /**
-     * Notifies the HostTracker Clients that a new Host has been learned
-     *
-     * @param host
-     *            Host Info encapsulated in HostNodeConnector class
-     */
-    public void notifyHTClient(HostNodeConnector host);
-
-    /**
-     * Notifies the HostTracker Clients that a Host which was learned in the
-     * past has been removed either due to switch/port down event or due to ARP
-     * Aging
-     *
-     * @param host
-     *            Host Info encapsulated in HostNodeConnector class
-     */
-    public void notifyHTClientHostRemoved(HostNodeConnector host);
-}
diff --git a/opendaylight/adsal/hosttracker_new/api/src/main/java/org/opendaylight/controller/hosttracker/SwitchPort.java b/opendaylight/adsal/hosttracker_new/api/src/main/java/org/opendaylight/controller/hosttracker/SwitchPort.java
deleted file mode 100644 (file)
index 892e1d6..0000000
+++ /dev/null
@@ -1,158 +0,0 @@
-/*
- * Copyright (c) 2012 Big Switch Networks, Inc.
- *
- * Licensed under the Eclipse Public License, Version 1.0 (the
- * "License"); you may not use this file except in compliance with the
- * License. You may obtain a copy of the License at
- *
- *      http://www.eclipse.org/legal/epl-v10.html
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
- * implied. See the License for the specific language governing
- * permissions and limitations under the License.
- *
- * This file incorporates work covered by the following copyright and
- * permission notice:
- *
- *    Originally created by David Erickson, Stanford University
- *
- *    Licensed under the Apache License, Version 2.0 (the "License");
- *    you may not use this file except in compliance with the
- *    License. You may obtain a copy of the License at
- *
- *         http://www.apache.org/licenses/LICENSE-2.0
- *
- *    Unless required by applicable law or agreed to in writing,
- *    software distributed under the License is distributed on an "AS
- *    IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
- *    express or implied. See the License for the specific language
- *    governing permissions and limitations under the License.
- */
-
-package org.opendaylight.controller.hosttracker;
-
-import org.opendaylight.controller.sal.core.NodeConnector;
-
-/**
- * A simple switch DPID/port pair This class is immutable
- *
- * @author readams
- *
- */
-public class SwitchPort {
-    public enum ErrorStatus {
-        DUPLICATE_DEVICE("duplicate-device");
-
-        private String value;
-
-        ErrorStatus(String v) {
-            value = v;
-        }
-
-        @Override
-        public String toString() {
-            return value;
-        }
-
-        public static ErrorStatus fromString(String str) {
-            for (ErrorStatus m : ErrorStatus.values()) {
-                if (m.value.equals(str)) {
-                    return m;
-                }
-            }
-            return null;
-        }
-    }
-
-    private final NodeConnector port;
-    private final ErrorStatus errorStatus;
-
-    /**
-     * Simple constructor
-     *
-     * @param switchDPID
-     *            the dpid
-     * @param port
-     *            the port
-     * @param errorStatus
-     *            any error status for the switch port
-     */
-    public SwitchPort(NodeConnector port, ErrorStatus errorStatus) {
-        super();
-        this.port = port;
-        this.errorStatus = errorStatus;
-    }
-
-    /**
-     * Simple constructor
-     *
-     * @param switchDPID
-     *            the dpid
-     * @param port
-     *            the port
-     */
-    public SwitchPort(NodeConnector port) {
-        super();
-        this.port = port;
-        this.errorStatus = null;
-    }
-
-    // ***************
-    // Getters/Setters
-    // ***************
-
-    public NodeConnector getPort() {
-        return port;
-    }
-
-    public ErrorStatus getErrorStatus() {
-        return errorStatus;
-    }
-
-    // ******
-    // Object
-    // ******
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result
-                + ((errorStatus == null) ? 0 : errorStatus.hashCode());
-        result = prime * result + ((port == null) ? 0 : port.hashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        SwitchPort other = (SwitchPort) obj;
-        if (errorStatus != other.errorStatus) {
-            return false;
-        }
-        if (port == null) {
-            if (other.port != null) {
-                return false;
-            }
-        } else if (!port.equals(other.port)) {
-            return false;
-        }
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        return "SwitchPort [port=" + port + ", errorStatus=" + errorStatus
-                + "]";
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/hosttracker_new/api/src/main/java/org/opendaylight/controller/hosttracker/hostAware/HostNodeConnector.java b/opendaylight/adsal/hosttracker_new/api/src/main/java/org/opendaylight/controller/hosttracker/hostAware/HostNodeConnector.java
deleted file mode 100644 (file)
index 86376be..0000000
+++ /dev/null
@@ -1,223 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.hosttracker.hostAware;
-
-import java.net.Inet4Address;
-import java.net.Inet6Address;
-import java.net.InetAddress;
-import java.util.Arrays;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.apache.commons.lang3.builder.ReflectionToStringBuilder;
-import org.opendaylight.controller.sal.core.ConstructionException;
-import org.opendaylight.controller.sal.core.Host;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.packet.address.EthernetAddress;
-
-@XmlRootElement(name = "host")
-@XmlAccessorType(XmlAccessType.NONE)
-public class HostNodeConnector extends Host {
-    private static final long serialVersionUID = 1L;
-    @XmlElement
-    private NodeConnector nodeConnector;
-    @XmlElement
-    private short vlan;
-    @XmlElement
-    private boolean staticHost;
-    private transient short arpSendCountDown;
-
-    /**
-     * Private constructor used for JAXB mapping
-     */
-    @SuppressWarnings("unused")
-    private HostNodeConnector() {
-    }
-
-    public HostNodeConnector(InetAddress ip) throws ConstructionException {
-        this(ip, null);
-    }
-
-    public HostNodeConnector(InetAddress ip, NodeConnector nc)
-            throws ConstructionException {
-        this(new EthernetAddress(new byte[] { (byte) 0x00, (byte) 0x00,
-                (byte) 0x00, (byte) 0x00, (byte) 0x00, (byte) 0x00 }), ip, nc,
-                (short) 0);
-    }
-
-    public HostNodeConnector(byte[] mac, InetAddress ip, NodeConnector nc,
-            short vlan) throws ConstructionException {
-        this(new EthernetAddress(mac.clone()), ip, nc, vlan);
-    }
-
-    public HostNodeConnector(EthernetAddress eaddr, InetAddress naddr,
-            NodeConnector nc, short vlan) throws ConstructionException {
-        super(eaddr, naddr);
-        this.nodeConnector = nc;
-        this.vlan = vlan;
-    }
-
-    /**
-     * @return the NodeConnector
-     */
-    public NodeConnector getnodeConnector() {
-        return this.nodeConnector;
-    }
-
-    /**
-     * @return the Node
-     */
-    public Node getnodeconnectorNode() {
-        return this.nodeConnector.getNode();
-    }
-
-    /**
-     * @return the NodeId
-     */
-    public Long getnodeconnectornodeId() {
-        return (Long) this.nodeConnector.getNode().getID();
-    }
-
-    /**
-     * @return the port
-     */
-    public Short getnodeconnectorportId() {
-        return (Short) this.nodeConnector.getID();
-    }
-
-    /**
-     * @return the DataLayerAddress
-     */
-    public byte[] getDataLayerAddressBytes() {
-        byte[] macaddr = null;
-        if (getDataLayerAddress() instanceof EthernetAddress) {
-            EthernetAddress e = (EthernetAddress) getDataLayerAddress();
-            macaddr = e.getValue();
-        }
-        return macaddr;
-    }
-
-    /**
-     * @return the vlan
-     */
-    public short getVlan() {
-        return this.vlan;
-    }
-
-    public boolean isStaticHost() {
-        return this.staticHost;
-    }
-
-    public HostNodeConnector setStaticHost(boolean statically_learned) {
-        this.staticHost = statically_learned;
-        return this;
-    }
-
-    public HostNodeConnector initArpSendCountDown() {
-        this.arpSendCountDown = 24;
-        return this;
-    }
-
-    public short getArpSendCountDown() {
-        return (this.arpSendCountDown);
-    }
-
-    public HostNodeConnector setArpSendCountDown(short cntdown) {
-        this.arpSendCountDown = cntdown;
-        return this;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = super.hashCode();
-        result = prime * result
-                + ((nodeConnector == null) ? 0 : nodeConnector.hashCode());
-        result = prime * result + (staticHost ? 1231 : 1237);
-        result = prime * result + vlan;
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (!super.equals(obj)) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        HostNodeConnector other = (HostNodeConnector) obj;
-        if (nodeConnector == null) {
-            if (other.nodeConnector != null) {
-                return false;
-            }
-        } else if (!nodeConnector.equals(other.nodeConnector)) {
-            return false;
-        }
-        if (staticHost != other.staticHost) {
-            return false;
-        }
-        if (vlan != other.vlan) {
-            return false;
-        }
-        return true;
-    }
-
-    public boolean equalsByIP(InetAddress networkAddress) {
-        return (this.getNetworkAddress().equals(networkAddress));
-    }
-
-    public boolean isRewriteEnabled() {
-        byte[] emptyArray = new byte[] { (byte) 0x00, (byte) 0x00, (byte) 0x00,
-                (byte) 0x00, (byte) 0x00, (byte) 0x00 };
-        byte[] macaddr = null;
-        if (getDataLayerAddress() instanceof EthernetAddress) {
-            EthernetAddress e = (EthernetAddress) getDataLayerAddress();
-            macaddr = e.getValue();
-        }
-        if (macaddr == null) {
-            return false;
-        }
-        return !Arrays.equals(emptyArray, macaddr);
-    }
-
-    /*
-     * (non-Javadoc)
-     *
-     * @see java.lang.Object#toString()
-     */
-    @Override
-    public String toString() {
-        return "HostNodeConnector[" + ReflectionToStringBuilder.toString(this)
-                + "]";
-    }
-
-    public boolean isV4Host() {
-        return (getNetworkAddress() instanceof Inet4Address);
-    }
-
-    public boolean isV6Host() {
-        return (getNetworkAddress() instanceof Inet6Address);
-    }
-
-    public String toJson() {
-        return "{\"host\":\"" + super.toString() + "\", " + "\"vlan\":\""
-                + String.valueOf(vlan) + "\",\"NodeConnector\":\""
-                + nodeConnector.toString() + "\"," + "\"static\":\""
-                + String.valueOf(isStaticHost()) + "\"}";
-    }
-
-}
diff --git a/opendaylight/adsal/hosttracker_new/api/src/main/java/org/opendaylight/controller/hosttracker/hostAware/IHostFinder.java b/opendaylight/adsal/hosttracker_new/api/src/main/java/org/opendaylight/controller/hosttracker/hostAware/IHostFinder.java
deleted file mode 100644 (file)
index abe7518..0000000
+++ /dev/null
@@ -1,40 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.hosttracker.hostAware;
-
-import java.net.InetAddress;
-
-/**
- * This Interface defines the methods to trigger the discovery of a Host and to
- * probe if a learned Host is still in the network.
- *
- *
- *
- */
-public interface IHostFinder {
-    /**
-     * This method initiates the discovery of a host based on its IP address.
-     * This is triggered by query of an application to the HostTracker. The
-     * requested IP address doesn't exist in the local database at this point.
-     *
-     * @param networkAddress
-     *            IP Address encapsulated in InetAddress class
-     *
-     */
-    public void find(InetAddress networkAddress);
-
-    /**
-     * This method is called by HostTracker to see if a learned Host is still in
-     * the network. Used mostly for ARP Aging.
-     *
-     * @param host
-     *            The Host that needs to be probed
-     */
-    public void probe(HostNodeConnector host);
-}
diff --git a/opendaylight/adsal/hosttracker_new/api/src/test/java/org/opendaylight/controller/hosttracker/hostAware/HostNodeConnectorTest.java b/opendaylight/adsal/hosttracker_new/api/src/test/java/org/opendaylight/controller/hosttracker/hostAware/HostNodeConnectorTest.java
deleted file mode 100644 (file)
index 4248c6d..0000000
+++ /dev/null
@@ -1,94 +0,0 @@
-/*\r
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.\r
- *\r
- * This program and the accompanying materials are made available under the\r
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,\r
- * and is available at http://www.eclipse.org/legal/epl-v10.html\r
- */\r
-\r
-package org.opendaylight.controller.hosttracker.hostAware;\r
-\r
-import java.net.InetAddress;\r
-import java.net.UnknownHostException;\r
-\r
-import org.junit.Assert;\r
-import org.junit.Test;\r
-import org.opendaylight.controller.sal.core.ConstructionException;\r
-import org.opendaylight.controller.sal.core.Node;\r
-import org.opendaylight.controller.sal.core.NodeConnector;\r
-import org.opendaylight.controller.sal.packet.address.EthernetAddress;\r
-import org.opendaylight.controller.sal.utils.NodeConnectorCreator;\r
-import org.opendaylight.controller.sal.utils.NodeCreator;\r
-\r
-public class HostNodeConnectorTest {\r
-\r
-    @Test\r
-    public void testHostNodeConnector() throws UnknownHostException {\r
-        HostNodeConnector hostnodeconnector_1, hostnodeconnector_2, hostnodeconnector_3;\r
-        InetAddress hostIP_1 = InetAddress.getByName("192.168.0.8");\r
-        InetAddress hostIP_2 = InetAddress\r
-                .getByName("2001:420:281:1004:e123:e688:d655:a1b0");\r
-        InetAddress hostIP_3 = InetAddress.getByName("192.168.0.28");\r
-        byte[] hostMAC_2 = new byte[] { (byte) 0x11, (byte) 0x22, (byte) 0x33,\r
-                (byte) 0x22, (byte) 0x22, (byte) 0x22 };\r
-        byte[] hostMAC_3 = new byte[] { (byte) 0x11, (byte) 0x22, (byte) 0x33,\r
-                (byte) 0x33, (byte) 0x33, (byte) 0x33 };\r
-\r
-        Node node = NodeCreator.createOFNode(1L);\r
-        NodeConnector nc1 = NodeConnectorCreator.createOFNodeConnector(\r
-                (short) 2, node);\r
-        NodeConnector nc2 = NodeConnectorCreator.createOFNodeConnector(\r
-                (short) 1, node);\r
-\r
-        try {\r
-            hostnodeconnector_1 = new HostNodeConnector(hostIP_1);\r
-            Assert.assertTrue(hostnodeconnector_1.equalsByIP(hostIP_1));\r
-            Assert.assertTrue(hostnodeconnector_1.isV4Host());\r
-            Assert.assertTrue(hostnodeconnector_1.equalsByIP(hostIP_1));\r
-        } catch (ConstructionException e) {\r
-            Assert.assertTrue(false);\r
-        }\r
-\r
-        try {\r
-            hostnodeconnector_2 = new HostNodeConnector(hostMAC_2, hostIP_2,\r
-                    nc1, (short) 2);\r
-            Assert.assertTrue(hostnodeconnector_2.isV6Host());\r
-            Assert.assertTrue(hostnodeconnector_2.getnodeConnector()\r
-                    .equals(nc1));\r
-            Assert.assertTrue(hostnodeconnector_2.getnodeconnectorNode()\r
-                    .equals(node));\r
-            Assert.assertTrue(node.getID().equals(\r
-                    hostnodeconnector_2.getnodeconnectornodeId()));\r
-            Assert.assertTrue(hostnodeconnector_2.getnodeconnectorportId()\r
-                    .equals((short) 2));\r
-        } catch (ConstructionException e) {\r
-            Assert.assertTrue(false);\r
-        }\r
-\r
-        try {\r
-            hostnodeconnector_3 = new HostNodeConnector(new EthernetAddress(\r
-                    hostMAC_3), hostIP_3, nc2, (short) 3);\r
-            byte[] hostMAC_3_rb = hostnodeconnector_3\r
-                    .getDataLayerAddressBytes();\r
-            HostNodeConnector hostnodeconnector_3rb = new HostNodeConnector(\r
-                    new EthernetAddress(hostMAC_3_rb), hostIP_3, nc2, (short) 3);\r
-            Assert.assertTrue(hostnodeconnector_3.equals(hostnodeconnector_3rb));\r
-\r
-            Assert.assertTrue(hostnodeconnector_3.getVlan() == (short) 3);\r
-\r
-            hostnodeconnector_3.setStaticHost(true);\r
-            Assert.assertTrue(hostnodeconnector_3.isStaticHost());\r
-\r
-            Assert.assertTrue(hostnodeconnector_3.isRewriteEnabled());\r
-\r
-            hostnodeconnector_3.initArpSendCountDown().setArpSendCountDown(\r
-                    (short) 10);\r
-            Assert.assertTrue(hostnodeconnector_3.getArpSendCountDown() == (short) 10);\r
-\r
-        } catch (ConstructionException e) {\r
-            Assert.assertTrue(false);\r
-        }\r
-\r
-    }\r
-\r
-}\r
diff --git a/opendaylight/adsal/hosttracker_new/implementation/pom.xml b/opendaylight/adsal/hosttracker_new/implementation/pom.xml
deleted file mode 100644 (file)
index 1b03fc4..0000000
+++ /dev/null
@@ -1,125 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-  <artifactId>hosttracker_new.implementation</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-
-  <properties>
-    <!-- Sonar properties using jacoco to retrieve integration test results -->
-    <sonar.dynamicAnalysis>reuseReports</sonar.dynamicAnalysis>
-    <sonar.jacoco.itReportPath>target/jacoco-it.exec</sonar.jacoco.itReportPath>
-    <sonar.jacoco.reportpath>target/jacoco.exec</sonar.jacoco.reportpath>
-  </properties>
-  <dependencies>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>clustering.services</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>commons.logback_settings</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>hosttracker_new</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>switchmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>topologymanager</artifactId>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <pluginManagement>
-      <plugins>
-        <plugin>
-          <groupId>org.jacoco</groupId>
-          <artifactId>jacoco-maven-plugin</artifactId>
-          <version>${jacoco.version}</version>
-        </plugin>
-      </plugins>
-    </pluginManagement>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Export-Package></Export-Package>
-            <Import-Package>org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.sal.utils,
-              org.opendaylight.controller.sal.topology,
-              org.opendaylight.controller.sal.packet,
-              org.opendaylight.controller.hosttracker,
-              org.opendaylight.controller.topologymanager,
-              org.opendaylight.controller.sal.packet.address,
-              org.opendaylight.controller.switchmanager,
-              org.opendaylight.controller.clustering.services,
-              org.opendaylight.controller.hosttracker.hostAware,
-              javax.xml.bind.annotation,
-              javax.xml.bind,
-              org.apache.felix.dm,
-              org.apache.commons.lang3.builder,
-              org.osgi.service.component,
-              org.slf4j,
-              org.eclipse.osgi.framework.console,
-              org.osgi.framework</Import-Package>
-            <Bundle-Activator>org.opendaylight.controller.hosttracker.internal.Activator</Bundle-Activator>
-            <Service-Component></Service-Component>
-          </instructions>
-          <manifestLocation>${project.basedir}/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-      <plugin>
-        <groupId>org.jacoco</groupId>
-        <artifactId>jacoco-maven-plugin</artifactId>
-        <configuration>
-          <includes>
-            <include>org.opendaylight.controller.*</include>
-          </includes>
-        </configuration>
-        <executions>
-          <execution>
-            <id>pre-test</id>
-            <goals>
-              <goal>prepare-agent</goal>
-            </goals>
-          </execution>
-          <execution>
-            <id>post-test</id>
-            <goals>
-              <goal>report</goal>
-            </goals>
-            <phase>test</phase>
-          </execution>
-        </executions>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/hosttracker_new/implementation/src/main/java/org/opendaylight/controller/hosttracker/internal/Activator.java b/opendaylight/adsal/hosttracker_new/implementation/src/main/java/org/opendaylight/controller/hosttracker/internal/Activator.java
deleted file mode 100644 (file)
index ad3f7ee..0000000
+++ /dev/null
@@ -1,131 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.hosttracker.internal;
-
-import java.util.Dictionary;
-import java.util.Hashtable;
-
-import org.apache.felix.dm.Component;
-import org.opendaylight.controller.hosttracker.IDeviceService;
-import org.opendaylight.controller.hosttracker.IfIptoHost;
-import org.opendaylight.controller.hosttracker.IfNewHostNotify;
-import org.opendaylight.controller.sal.core.ComponentActivatorAbstractBase;
-import org.opendaylight.controller.sal.packet.IDataPacketService;
-import org.opendaylight.controller.sal.packet.IListenDataPacket;
-import org.opendaylight.controller.switchmanager.ISwitchManager;
-import org.opendaylight.controller.topologymanager.ITopologyManager;
-import org.opendaylight.controller.topologymanager.ITopologyManagerAware;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-public class Activator extends ComponentActivatorAbstractBase {
-    protected static final Logger logger = LoggerFactory
-            .getLogger(Activator.class);
-
-
-    /**
-     * Function that is used to communicate to dependency manager the list of
-     * known implementations for services inside a container
-     *
-     *
-     * @return An array containing all the CLASS objects that will be
-     *         instantiated in order to get an fully working implementation
-     *         Object
-     */
-    @Override
-    public Object[] getImplementations() {
-        Object[] res = { DeviceManagerImpl.class };
-        return res;
-    }
-
-    /**
-     * Function that is called when configuration of the dependencies is
-     * required.
-     *
-     * @param c
-     *            dependency manager Component object, used for configuring the
-     *            dependencies exported and imported
-     * @param imp
-     *            Implementation class that is being configured, needed as long
-     *            as the same routine can configure multiple implementations
-     * @param containerName
-     *            The containerName being configured, this allow also optional
-     *            per-container different behavior if needed, usually should not
-     *            be the case though.
-     */
-    @Override
-    public void configureInstance(Component c, Object imp, String containerName) {
-        if (imp.equals(DeviceManagerImpl.class)) {
-            // export the service
-            // XXX - TODO merge with existing APIs
-            Dictionary<String, String> props = new Hashtable<String, String>();
-            props.put("salListenerName", "devicemanager");
-
-            c.setInterface(
-                    new String[] { IDeviceService.class.getName(),
-                            IfIptoHost.class.getName(),
-                            IListenDataPacket.class.getName(),
-                            ITopologyManagerAware.class.getName() }, props);
-
-            c.add(createContainerServiceDependency(containerName)
-                    .setService(ISwitchManager.class)
-                    .setCallbacks("setSwitchManager", "unsetSwitchManager")
-                    .setRequired(false));
-
-            c.add(createContainerServiceDependency(containerName)
-                    .setService(IDataPacketService.class)
-                    .setCallbacks("setDataPacketService",
-                            "unsetDataPacketService").setRequired(true));
-
-            c.add(createContainerServiceDependency(containerName)
-                    .setService(IfNewHostNotify.class)
-                    .setCallbacks("setNewHostNotify",
-                            "unsetNewHostNotify").setRequired(false));
-
-            c.add(createContainerServiceDependency(containerName)
-                    .setService(ITopologyManager.class)
-                    .setCallbacks("setTopologyManager", "unsetTopologyManager")
-                    .setRequired(false));
-        }
-    }
-
-    /**
-     * Method which tells how many Global implementations are supported by the
-     * bundle. This way we can tune the number of components created. This
-     * components will be created ONLY at the time of bundle startup and will be
-     * destroyed only at time of bundle destruction, this is the major
-     * difference with the implementation retrieved via getImplementations where
-     * all of them are assumed to be in a container !
-     *
-     *
-     * @return The list of implementations the bundle will support, in Global
-     *         version
-     */
-    @Override
-    protected Object[] getGlobalImplementations() {
-        return null;
-    }
-
-    /**
-     * Configure the dependency for a given instance Global
-     *
-     * @param c
-     *            Component assigned for this instance, this will be what will
-     *            be used for configuration
-     * @param imp
-     *            implementation to be configured
-     * @param containerName
-     *            container on which the configuration happens
-     */
-    @Override
-    protected void configureGlobalInstance(Component c, Object imp) {
-
-    }
-
-}
diff --git a/opendaylight/adsal/hosttracker_new/implementation/src/main/java/org/opendaylight/controller/hosttracker/internal/AttachmentPoint.java b/opendaylight/adsal/hosttracker_new/implementation/src/main/java/org/opendaylight/controller/hosttracker/internal/AttachmentPoint.java
deleted file mode 100644 (file)
index ba2c64a..0000000
+++ /dev/null
@@ -1,129 +0,0 @@
-/*
- * Copyright (c) 2011,2012 Big Switch Networks, Inc.
- *
- * Licensed under the Eclipse Public License, Version 1.0 (the
- * "License"); you may not use this file except in compliance with the
- * License. You may obtain a copy of the License at
- *
- *      http://www.eclipse.org/legal/epl-v10.html
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
- * implied. See the License for the specific language governing
- * permissions and limitations under the License.
- *
- * This file incorporates work covered by the following copyright and
- * permission notice:
- *
- *    Originally created by David Erickson, Stanford University
- *
- *    Licensed under the Apache License, Version 2.0 (the "License");
- *    you may not use this file except in compliance with the
- *    License. You may obtain a copy of the License at
- *
- *         http://www.apache.org/licenses/LICENSE-2.0
- *
- *    Unless required by applicable law or agreed to in writing,
- *    software distributed under the License is distributed on an "AS
- *    IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
- *    express or implied. See the License for the specific language
- *    governing permissions and limitations under the License.
- */
-
-/**
- * @author Srini
- */
-
-package org.opendaylight.controller.hosttracker.internal;
-
-import org.opendaylight.controller.sal.core.NodeConnector;
-
-public class AttachmentPoint {
-    NodeConnector port;
-    long activeSince;
-    long lastSeen;
-
-    // Timeout for moving attachment points from OF/broadcast
-    // domain to another.
-    public static final long INACTIVITY_INTERVAL = 30000; // 30 seconds
-    public static final long EXTERNAL_TO_EXTERNAL_TIMEOUT = 5000; // 5 seconds
-    public static final long OPENFLOW_TO_EXTERNAL_TIMEOUT = 30000; // 30 seconds
-    public static final long CONSISTENT_TIMEOUT = 30000; // 30 seconds
-
-    public AttachmentPoint(NodeConnector port, long activeSince, long lastSeen) {
-        this.port = port;
-        this.activeSince = activeSince;
-        this.lastSeen = lastSeen;
-    }
-
-    public AttachmentPoint(NodeConnector port, long lastSeen) {
-        this.port = port;
-        this.lastSeen = lastSeen;
-        this.activeSince = lastSeen;
-    }
-
-    public AttachmentPoint(AttachmentPoint ap) {
-        this.port = ap.port;
-        this.activeSince = ap.activeSince;
-        this.lastSeen = ap.lastSeen;
-    }
-
-    public NodeConnector getPort() {
-        return port;
-    }
-
-    public void setPort(NodeConnector port) {
-        this.port = port;
-    }
-
-    public long getActiveSince() {
-        return activeSince;
-    }
-
-    public void setActiveSince(long activeSince) {
-        this.activeSince = activeSince;
-    }
-
-    public long getLastSeen() {
-        return lastSeen;
-    }
-
-    public void setLastSeen(long lastSeen) {
-        if (this.lastSeen + INACTIVITY_INTERVAL < lastSeen)
-            this.activeSince = lastSeen;
-        if (this.lastSeen < lastSeen)
-            this.lastSeen = lastSeen;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + ((port == null) ? 0 : port.hashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj)
-            return true;
-        if (obj == null)
-            return false;
-        if (getClass() != obj.getClass())
-            return false;
-        AttachmentPoint other = (AttachmentPoint) obj;
-        if (port == null) {
-            if (other.port != null)
-                return false;
-        } else if (!port.equals(other.port))
-            return false;
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        return "AttachmentPoint [port=" + port + ", activeSince=" + activeSince
-                + ", lastSeen=" + lastSeen + "]";
-    }
-}
diff --git a/opendaylight/adsal/hosttracker_new/implementation/src/main/java/org/opendaylight/controller/hosttracker/internal/DefaultEntityClassifier.java b/opendaylight/adsal/hosttracker_new/implementation/src/main/java/org/opendaylight/controller/hosttracker/internal/DefaultEntityClassifier.java
deleted file mode 100644 (file)
index 39c322f..0000000
+++ /dev/null
@@ -1,108 +0,0 @@
-/*
- * Copyright (c) 2011,2012 Big Switch Networks, Inc.
- *
- * Licensed under the Eclipse Public License, Version 1.0 (the
- * "License"); you may not use this file except in compliance with the
- * License. You may obtain a copy of the License at
- *
- *      http://www.eclipse.org/legal/epl-v10.html
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
- * implied. See the License for the specific language governing
- * permissions and limitations under the License.
- *
- * This file incorporates work covered by the following copyright and
- * permission notice:
- *
- *    Originally created by David Erickson, Stanford University
- *
- *    Licensed under the Apache License, Version 2.0 (the "License");
- *    you may not use this file except in compliance with the
- *    License. You may obtain a copy of the License at
- *
- *         http://www.apache.org/licenses/LICENSE-2.0
- *
- *    Unless required by applicable law or agreed to in writing,
- *    software distributed under the License is distributed on an "AS
- *    IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
- *    express or implied. See the License for the specific language
- *    governing permissions and limitations under the License.
- */
-
-package org.opendaylight.controller.hosttracker.internal;
-
-import java.util.Collection;
-import java.util.EnumSet;
-
-import org.opendaylight.controller.hosttracker.Entity;
-import org.opendaylight.controller.hosttracker.IDevice;
-import org.opendaylight.controller.hosttracker.IDeviceService;
-import org.opendaylight.controller.hosttracker.IDeviceService.DeviceField;
-import org.opendaylight.controller.hosttracker.IEntityClass;
-import org.opendaylight.controller.hosttracker.IEntityClassListener;
-import org.opendaylight.controller.hosttracker.IEntityClassifierService;
-
-/**
- * This is a default entity classifier that simply classifies all entities into
- * a fixed entity class, with key fields of MAC and VLAN.
- *
- * @author readams
- */
-public class DefaultEntityClassifier implements IEntityClassifierService {
-    /**
-     * A default fixed entity class
-     */
-    protected static class DefaultEntityClass implements IEntityClass {
-        String name;
-
-        public DefaultEntityClass(String name) {
-            this.name = name;
-        }
-
-        @Override
-        public EnumSet<IDeviceService.DeviceField> getKeyFields() {
-            return keyFields;
-        }
-
-        @Override
-        public String getName() {
-            return name;
-        }
-    }
-
-    protected static EnumSet<DeviceField> keyFields;
-    static {
-        keyFields = EnumSet.of(DeviceField.MAC, DeviceField.VLAN);
-    }
-    protected static DefaultEntityClass entityClass = new DefaultEntityClass(
-            "DefaultEntityClass");
-
-    @Override
-    public IEntityClass classifyEntity(Entity entity) {
-        return entityClass;
-    }
-
-    @Override
-    public IEntityClass reclassifyEntity(IDevice curDevice, Entity entity) {
-        return entityClass;
-    }
-
-    @Override
-    public void deviceUpdate(IDevice oldDevice,
-            Collection<? extends IDevice> newDevices) {
-        // no-op
-    }
-
-    @Override
-    public EnumSet<DeviceField> getKeyFields() {
-        return keyFields;
-    }
-
-    @Override
-    public void addListener(IEntityClassListener listener) {
-        // no-op
-
-    }
-}
diff --git a/opendaylight/adsal/hosttracker_new/implementation/src/main/java/org/opendaylight/controller/hosttracker/internal/Device.java b/opendaylight/adsal/hosttracker_new/implementation/src/main/java/org/opendaylight/controller/hosttracker/internal/Device.java
deleted file mode 100755 (executable)
index 8fcb988..0000000
+++ /dev/null
@@ -1,828 +0,0 @@
-/*
- * Copyright (c) 2011,2012 Big Switch Networks, Inc.
- *
- * Licensed under the Eclipse Public License, Version 1.0 (the
- * "License"); you may not use this file except in compliance with the
- * License. You may obtain a copy of the License at
- *
- *      http://www.eclipse.org/legal/epl-v10.html
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
- * implied. See the License for the specific language governing
- * permissions and limitations under the License.
- *
- * This file incorporates work covered by the following copyright and
- * permission notice:
- *
- *    Originally created by David Erickson, Stanford University
- *
- *    Licensed under the Apache License, Version 2.0 (the "License");
- *    you may not use this file except in compliance with the
- *    License. You may obtain a copy of the License at
- *
- *         http://www.apache.org/licenses/LICENSE-2.0
- *
- *    Unless required by applicable law or agreed to in writing,
- *    software distributed under the License is distributed on an "AS
- *    IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
- *    express or implied. See the License for the specific language
- *    governing permissions and limitations under the License.
- */
-
-package org.opendaylight.controller.hosttracker.internal;
-
-import java.net.InetAddress;
-import java.util.ArrayList;
-import java.util.Arrays;
-import java.util.Collection;
-import java.util.Collections;
-import java.util.Date;
-import java.util.EnumSet;
-import java.util.HashMap;
-import java.util.Iterator;
-import java.util.List;
-import java.util.Map;
-import java.util.TreeSet;
-
-import org.opendaylight.controller.hosttracker.Entity;
-import org.opendaylight.controller.hosttracker.IDevice;
-import org.opendaylight.controller.hosttracker.IDeviceService.DeviceField;
-import org.opendaylight.controller.hosttracker.IEntityClass;
-import org.opendaylight.controller.hosttracker.SwitchPort;
-import org.opendaylight.controller.hosttracker.SwitchPort.ErrorStatus;
-import org.opendaylight.controller.hosttracker.hostAware.HostNodeConnector;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.utils.HexEncode;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * Concrete implementation of {@link IDevice}
- *
- * @author readams
- */
-public class Device implements IDevice {
-    protected static Logger log = LoggerFactory.getLogger(Device.class);
-    public static final short VLAN_UNTAGGED = (short) 0xffff;
-
-    private final Long deviceKey;
-    protected final DeviceManagerImpl deviceManager;
-
-    protected final Entity[] entities;
-    private final IEntityClass entityClass;
-
-    protected final String macAddressString;
-    // the vlan Ids from the entities of this device
-    protected final Short[] vlanIds;
-    protected volatile String dhcpClientName;
-
-    private boolean staticHost;
-
-    /**
-     * These are the old attachment points for the device that were valid no
-     * more than INACTIVITY_TIME ago.
-     */
-    protected volatile List<AttachmentPoint> oldAPs;
-    /**
-     * The current attachment points for the device.
-     */
-    protected volatile List<AttachmentPoint> attachmentPoints;
-
-    // ************
-    // Constructors
-    // ************
-
-    /**
-     * Create a device from an entities
-     *
-     * @param deviceManager
-     *            the device manager for this device
-     * @param deviceKey
-     *            the unique identifier for this device object
-     * @param entity
-     *            the initial entity for the device
-     * @param entityClass
-     *            the entity classes associated with the entity
-     */
-    public Device(DeviceManagerImpl deviceManager, Long deviceKey,
-            Entity entity, IEntityClass entityClass) {
-        this.deviceManager = deviceManager;
-        this.deviceKey = deviceKey;
-        this.entities = new Entity[] { entity };
-        this.macAddressString = HexEncode.longToHexString(entity
-                .getMacAddress());
-        this.entityClass = entityClass;
-        Arrays.sort(this.entities);
-
-        this.dhcpClientName = null;
-        this.oldAPs = null;
-        this.attachmentPoints = null;
-
-        if (entity.getPort() != null) {
-            NodeConnector port = entity.getPort();
-
-            if (deviceManager.isValidAttachmentPoint(port)) {
-                AttachmentPoint ap;
-                ap = new AttachmentPoint(port, entity.getLastSeenTimestamp()
-                        .getTime());
-
-                this.attachmentPoints = new ArrayList<AttachmentPoint>();
-                this.attachmentPoints.add(ap);
-            }
-        }
-        vlanIds = computeVlandIds();
-    }
-
-    /**
-     * Create a device from a set of entities
-     *
-     * @param deviceManager
-     *            the device manager for this device
-     * @param deviceKey
-     *            the unique identifier for this device object
-     * @param entities
-     *            the initial entities for the device
-     * @param entityClass
-     *            the entity class associated with the entities
-     */
-    public Device(DeviceManagerImpl deviceManager, Long deviceKey,
-            String dhcpClientName, Collection<AttachmentPoint> oldAPs,
-            Collection<AttachmentPoint> attachmentPoints,
-            Collection<Entity> entities, IEntityClass entityClass) {
-        this.deviceManager = deviceManager;
-        this.deviceKey = deviceKey;
-        this.dhcpClientName = dhcpClientName;
-        this.entities = entities.toArray(new Entity[entities.size()]);
-        this.oldAPs = null;
-        this.attachmentPoints = null;
-        if (oldAPs != null) {
-            this.oldAPs = new ArrayList<AttachmentPoint>(oldAPs);
-        }
-        if (attachmentPoints != null) {
-            this.attachmentPoints = new ArrayList<AttachmentPoint>(
-                    attachmentPoints);
-        }
-        this.macAddressString = HexEncode.longToHexString(this.entities[0]
-                .getMacAddress());
-        this.entityClass = entityClass;
-        Arrays.sort(this.entities);
-        vlanIds = computeVlandIds();
-    }
-
-    /**
-     * Construct a new device consisting of the entities from the old device
-     * plus an additional entity. The caller needs to ensure that the additional
-     * entity is not already present in the array
-     *
-     * @param device
-     *            the old device object
-     * @param newEntity
-     *            the entity to add. newEntity must be have the same entity
-     *            class as device
-     * @param insertionpoint
-     *        if positive indicates the index in the entities array were the new
-     *        entity should be inserted. If negative we will compute the correct
-     *        insertion point
-     */
-    public Device(Device device, Entity newEntity, int insertionpoint) {
-        this.deviceManager = device.deviceManager;
-        this.deviceKey = device.deviceKey;
-        this.dhcpClientName = device.dhcpClientName;
-
-        this.entities = new Entity[device.entities.length + 1];
-        if (insertionpoint < 0) {
-            insertionpoint = -(Arrays.binarySearch(device.entities, newEntity) + 1);
-        }
-        if (insertionpoint > 0) {
-            // insertion point is not the beginning:
-            // copy up to insertion point
-            System.arraycopy(device.entities, 0, this.entities, 0,
-                    insertionpoint);
-        }
-        if (insertionpoint < device.entities.length) {
-            // insertion point is not the end
-            // copy from insertion point
-            System.arraycopy(device.entities, insertionpoint, this.entities,
-                    insertionpoint + 1, device.entities.length - insertionpoint);
-        }
-        this.entities[insertionpoint] = newEntity;
-        /*
-         * this.entities = Arrays.<Entity>copyOf(device.entities,
-         * device.entities.length + 1); this.entities[this.entities.length - 1]
-         * = newEntity; Arrays.sort(this.entities);
-         */
-        this.oldAPs = null;
-        if (device.oldAPs != null) {
-            this.oldAPs = new ArrayList<AttachmentPoint>(device.oldAPs);
-        }
-        this.attachmentPoints = null;
-        if (device.attachmentPoints != null) {
-            this.attachmentPoints = new ArrayList<AttachmentPoint>(
-                    device.attachmentPoints);
-        }
-
-        this.macAddressString = HexEncode.longToHexString(this.entities[0]
-                .getMacAddress());
-
-        this.entityClass = device.entityClass;
-        vlanIds = computeVlandIds();
-    }
-
-    private Short[] computeVlandIds() {
-        if (entities.length == 1) {
-            if (entities[0].getVlan() != null) {
-                return new Short[] { entities[0].getVlan() };
-            } else {
-                return new Short[] { Short.valueOf((short) -1) };
-            }
-        }
-
-        TreeSet<Short> vals = new TreeSet<Short>();
-        for (Entity e : entities) {
-            if (e.getVlan() == null) {
-                vals.add((short) -1);
-            } else {
-                vals.add(e.getVlan());
-            }
-        }
-        return vals.toArray(new Short[vals.size()]);
-    }
-
-    /**
-     * Given a list of attachment points (apList), the procedure would return a
-     * map of attachment points for each L2 domain. L2 domain id is the key.
-     *
-     * @param apList
-     * @return
-     */
-    private Map<Long, AttachmentPoint> getAPMap(List<AttachmentPoint> apList) {
-
-        if (apList == null)
-            return null;
-        // ITopologyService topology = deviceManager.topology;
-
-        // Get the old attachment points and sort them.
-        List<AttachmentPoint> oldAP = new ArrayList<AttachmentPoint>();
-        if (apList != null)
-            oldAP.addAll(apList);
-
-        // Remove invalid attachment points before sorting.
-        List<AttachmentPoint> tempAP = new ArrayList<AttachmentPoint>();
-        for (AttachmentPoint ap : oldAP) {
-            if (deviceManager.isValidAttachmentPoint(ap.getPort())) {
-                tempAP.add(ap);
-            }
-        }
-        oldAP = tempAP;
-
-        Collections.sort(oldAP, deviceManager.apComparator);
-
-        // Map of attachment point by L2 domain Id.
-        Map<Long, AttachmentPoint> apMap = new HashMap<Long, AttachmentPoint>();
-
-        for (int i = 0; i < oldAP.size(); ++i) {
-            AttachmentPoint ap = oldAP.get(i);
-            // if this is not a valid attachment point, continue
-            if (!deviceManager.isValidAttachmentPoint(ap.getPort()))
-                continue;
-
-            // long id = topology.getL2DomainId(ap.getSw());
-            // XXX - Missing functionality
-            long id = 0;
-
-            apMap.put(id, ap);
-        }
-
-        if (apMap.isEmpty())
-            return null;
-        return apMap;
-    }
-
-    /**
-     * Remove all attachment points that are older than INACTIVITY_INTERVAL from
-     * the list.
-     *
-     * @param apList
-     * @return
-     */
-    private boolean removeExpiredAttachmentPoints(List<AttachmentPoint> apList) {
-
-        List<AttachmentPoint> expiredAPs = new ArrayList<AttachmentPoint>();
-
-        if (apList == null)
-            return false;
-
-        for (AttachmentPoint ap : apList) {
-            if (ap.getLastSeen() + AttachmentPoint.INACTIVITY_INTERVAL < System.currentTimeMillis()) {
-               expiredAPs.add(ap);
-            }
-        }
-        if (expiredAPs.size() > 0) {
-            apList.removeAll(expiredAPs);
-            return true;
-        } else {
-            return false;
-        }
-    }
-
-    /**
-     * Get a list of duplicate attachment points, given a list of old attachment
-     * points and one attachment point per L2 domain. Given a true attachment
-     * point in the L2 domain, say trueAP, another attachment point in the same
-     * L2 domain, say ap, is duplicate if: 1. ap is inconsistent with trueAP,
-     * and 2. active time of ap is after that of trueAP; and 3. last seen time
-     * of ap is within the last INACTIVITY_INTERVAL
-     *
-     * @param oldAPList
-     * @param apMap
-     * @return
-     */
-    List<AttachmentPoint> getDuplicateAttachmentPoints(
-            List<AttachmentPoint> oldAPList, Map<Long, AttachmentPoint> apMap) {
-        List<AttachmentPoint> dupAPs = new ArrayList<AttachmentPoint>();
-        long timeThreshold = System.currentTimeMillis()
-                - AttachmentPoint.INACTIVITY_INTERVAL;
-
-        if (oldAPList == null || apMap == null)
-            return dupAPs;
-
-        for (AttachmentPoint ap : oldAPList) {
-            long id = 0;
-            AttachmentPoint trueAP = apMap.get(id);
-
-            if (trueAP == null)
-                continue;
-            boolean c = true;
-            boolean active = (ap.getActiveSince() > trueAP.getActiveSince());
-            boolean last = ap.getLastSeen() > timeThreshold;
-            if (!c && active && last) {
-                dupAPs.add(ap);
-            }
-        }
-
-        return dupAPs;
-    }
-
-    /**
-     * Update the known attachment points. This method is called whenever
-     * topology changes. The method returns true if there's any change to the
-     * list of attachment points -- which indicates a possible device move.
-     *
-     * @return
-     */
-    protected boolean updateAttachmentPoint() {
-        boolean moved = false;
-        this.oldAPs = attachmentPoints;
-        if (attachmentPoints == null || attachmentPoints.isEmpty())
-            return false;
-
-        List<AttachmentPoint> apList = new ArrayList<AttachmentPoint>();
-        if (attachmentPoints != null)
-            apList.addAll(attachmentPoints);
-        Map<Long, AttachmentPoint> newMap = getAPMap(apList);
-        if (newMap == null || newMap.size() != apList.size()) {
-            moved = true;
-        }
-
-        // Prepare the new attachment point list.
-        if (moved) {
-            log.info("updateAttachmentPoint: ap {}  newmap {} ",
-                    attachmentPoints, newMap);
-            List<AttachmentPoint> newAPList = new ArrayList<AttachmentPoint>();
-            if (newMap != null)
-                newAPList.addAll(newMap.values());
-            this.attachmentPoints = newAPList;
-        }
-
-        // Set the oldAPs to null.
-        return moved;
-    }
-
-    /**
-     * Update the list of attachment points given that a new packet-in was seen
-     * from (sw, port) at time (lastSeen). The return value is true if there was
-     * any change to the list of attachment points for the device -- which
-     * indicates a device move.
-     *
-     * @param port
-     * @param lastSeen
-     * @return
-     */
-    protected boolean updateAttachmentPoint(NodeConnector port, long lastSeen) {
-        // ITopologyService topology = deviceManager.topology;
-        List<AttachmentPoint> oldAPList;
-        List<AttachmentPoint> apList;
-        boolean oldAPFlag = false;
-
-        if (!deviceManager.isValidAttachmentPoint(port))
-            return false;
-        AttachmentPoint newAP = new AttachmentPoint(port, lastSeen);
-        // Copy the oldAP and ap list.
-        apList = new ArrayList<AttachmentPoint>();
-        if (attachmentPoints != null)
-            apList.addAll(attachmentPoints);
-        oldAPList = new ArrayList<AttachmentPoint>();
-        if (oldAPs != null)
-            oldAPList.addAll(oldAPs);
-
-        // if the sw, port is in old AP, remove it from there
-        // and update the lastSeen in that object.
-        if (oldAPList.contains(newAP)) {
-            int index = oldAPList.indexOf(newAP);
-            newAP = oldAPList.remove(index);
-            newAP.setLastSeen(lastSeen);
-            this.oldAPs = oldAPList;
-            oldAPFlag = true;
-        }
-
-        // newAP now contains the new attachment point.
-
-        // Get the APMap is null or empty.
-        Map<Long, AttachmentPoint> apMap = getAPMap(apList);
-        if (apMap == null || apMap.isEmpty()) {
-            apList.add(newAP);
-            attachmentPoints = apList;
-            // there are no old attachment points - since the device exists,
-            // this
-            // may be because the host really moved (so the old AP port went
-            // down);
-            // or it may be because the switch restarted (so old APs were
-            // nullified).
-            // For now we will treat both cases as host moved.
-            return true;
-        }
-
-        // XXX - Missing functionality
-        long id = 0;
-        AttachmentPoint oldAP = apMap.get(id);
-
-        if (oldAP == null) // No attachment on this L2 domain.
-        {
-            apList = new ArrayList<AttachmentPoint>();
-            apList.addAll(apMap.values());
-            apList.add(newAP);
-            this.attachmentPoints = apList;
-            return true; // new AP found on an L2 island.
-        }
-
-        // There is already a known attachment point on the same L2 island.
-        // we need to compare oldAP and newAP.
-        if (oldAP.equals(newAP)) {
-            // nothing to do here. just the last seen has to be changed.
-            if (newAP.lastSeen > oldAP.lastSeen) {
-                oldAP.setLastSeen(newAP.lastSeen);
-            }
-            this.attachmentPoints = new ArrayList<AttachmentPoint>(
-                    apMap.values());
-            return false; // nothing to do here.
-        }
-
-        int x = deviceManager.apComparator.compare(oldAP, newAP);
-        if (x < 0) {
-            // newAP replaces oldAP.
-            apMap.put(id, newAP);
-            this.attachmentPoints = new ArrayList<AttachmentPoint>(
-                    apMap.values());
-
-            oldAPList = new ArrayList<AttachmentPoint>();
-            if (oldAPs != null)
-                oldAPList.addAll(oldAPs);
-            oldAPList.add(oldAP);
-            this.oldAPs = oldAPList;
-            return true;
-        } else if (oldAPFlag) {
-            // retain oldAP as is. Put the newAP in oldAPs for flagging
-            // possible duplicates.
-            oldAPList = new ArrayList<AttachmentPoint>();
-            if (oldAPs != null)
-                oldAPList.addAll(oldAPs);
-            // Add to oldAPList only if it was picked up from the oldAPList
-            oldAPList.add(newAP);
-            this.oldAPs = oldAPList;
-            return true;
-        }
-        return false;
-    }
-
-    /**
-     * Delete (sw,port) from the list of list of attachment points and oldAPs.
-     *
-     * @param port
-     * @return
-     */
-    public boolean deleteAttachmentPoint(NodeConnector port) {
-        AttachmentPoint ap = new AttachmentPoint(port, 0);
-
-        if (this.oldAPs != null) {
-            ArrayList<AttachmentPoint> apList = new ArrayList<AttachmentPoint>();
-            apList.addAll(this.oldAPs);
-            int index = apList.indexOf(ap);
-            if (index > 0) {
-                apList.remove(index);
-                this.oldAPs = apList;
-            }
-        }
-
-        if (this.attachmentPoints != null) {
-            ArrayList<AttachmentPoint> apList = new ArrayList<AttachmentPoint>();
-            apList.addAll(this.attachmentPoints);
-            int index = apList.indexOf(ap);
-            if (index > 0) {
-                apList.remove(index);
-                this.attachmentPoints = apList;
-                return true;
-            }
-        }
-        return false;
-    }
-
-    // *******
-    // IDevice
-    // *******
-
-    @Override
-    public SwitchPort[] getOldAP() {
-        List<SwitchPort> sp = new ArrayList<SwitchPort>();
-        SwitchPort[] returnSwitchPorts = new SwitchPort[] {};
-        if (oldAPs == null)
-            return returnSwitchPorts;
-        if (oldAPs.isEmpty())
-            return returnSwitchPorts;
-
-        // copy ap list.
-        List<AttachmentPoint> oldAPList;
-        oldAPList = new ArrayList<AttachmentPoint>();
-
-        if (oldAPs != null)
-            oldAPList.addAll(oldAPs);
-        removeExpiredAttachmentPoints(oldAPList);
-
-        if (oldAPList != null) {
-            for (AttachmentPoint ap : oldAPList) {
-                SwitchPort swport = new SwitchPort(ap.getPort());
-                sp.add(swport);
-            }
-        }
-        return sp.toArray(new SwitchPort[sp.size()]);
-    }
-
-    @Override
-    public SwitchPort[] getAttachmentPoints() {
-        return getAttachmentPoints(false);
-    }
-
-    @Override
-    public SwitchPort[] getAttachmentPoints(boolean includeError) {
-        List<SwitchPort> sp = new ArrayList<SwitchPort>();
-        SwitchPort[] returnSwitchPorts = new SwitchPort[] {};
-        if (attachmentPoints == null)
-            return returnSwitchPorts;
-        if (attachmentPoints.isEmpty())
-            return returnSwitchPorts;
-
-        // copy ap list.
-        List<AttachmentPoint> apList = attachmentPoints;
-
-        if (apList != null) {
-            for (AttachmentPoint ap : apList) {
-                SwitchPort swport = new SwitchPort(ap.getPort());
-                sp.add(swport);
-            }
-        }
-
-        if (!includeError)
-            return sp.toArray(new SwitchPort[sp.size()]);
-
-        List<AttachmentPoint> oldAPList;
-        oldAPList = new ArrayList<AttachmentPoint>();
-
-        if (oldAPs != null)
-            oldAPList.addAll(oldAPs);
-
-        if (removeExpiredAttachmentPoints(oldAPList))
-            this.oldAPs = oldAPList;
-
-        List<AttachmentPoint> dupList;
-        // get AP map.
-        Map<Long, AttachmentPoint> apMap = getAPMap(apList);
-        dupList = this.getDuplicateAttachmentPoints(oldAPList, apMap);
-        if (dupList != null) {
-            for (AttachmentPoint ap : dupList) {
-                SwitchPort swport = new SwitchPort(ap.getPort(),
-                        ErrorStatus.DUPLICATE_DEVICE);
-                sp.add(swport);
-            }
-        }
-        return sp.toArray(new SwitchPort[sp.size()]);
-    }
-
-    @Override
-    public Long getDeviceKey() {
-        return deviceKey;
-    }
-
-    @Override
-    public long getMACAddress() {
-        // we assume only one MAC per device for now.
-        return entities[0].getMacAddress();
-    }
-
-    @Override
-    public String getMACAddressString() {
-        return macAddressString;
-    }
-
-    @Override
-    public Short[] getVlanId() {
-        return Arrays.copyOf(vlanIds, vlanIds.length);
-    }
-
-    static final EnumSet<DeviceField> ipv4Fields = EnumSet.of(DeviceField.IPV4);
-
-    @Override
-    public Integer[] getIPv4Addresses() {
-        // XXX - TODO we can cache this result. Let's find out if this
-        // is really a performance bottleneck first though.
-
-        TreeSet<Integer> vals = new TreeSet<Integer>();
-        for (Entity e : entities) {
-            if (e.getIpv4Address() == null)
-                continue;
-
-            // We have an IP address only if among the devices within the class
-            // we have the most recent entity with that IP.
-            boolean validIP = true;
-            Iterator<Device> devices = deviceManager.queryClassByEntity(
-                    entityClass, ipv4Fields, e);
-            while (devices.hasNext()) {
-                Device d = devices.next();
-                if (deviceKey.equals(d.getDeviceKey()))
-                    continue;
-                for (Entity se : d.entities) {
-                    if (se.getIpv4Address() != null
-                            && se.getIpv4Address().equals(e.getIpv4Address())
-                            && se.getLastSeenTimestamp() != null
-                            && 0 < se.getLastSeenTimestamp().compareTo(
-                                    e.getLastSeenTimestamp())) {
-                        validIP = false;
-                        break;
-                    }
-                }
-                if (!validIP)
-                    break;
-            }
-
-            if (validIP)
-                vals.add(e.getIpv4Address());
-        }
-
-        return vals.toArray(new Integer[vals.size()]);
-    }
-
-    @Override
-    public Short[] getSwitchPortVlanIds(SwitchPort swp) {
-        TreeSet<Short> vals = new TreeSet<Short>();
-        for (Entity e : entities) {
-            if (e.getPort().equals(swp.getPort())) {
-                if (e.getVlan() == null) {
-                    vals.add(VLAN_UNTAGGED);
-                }
-                else  {
-                    vals.add(e.getVlan());
-                }
-            }
-        }
-        return vals.toArray(new Short[vals.size()]);
-    }
-
-    @Override
-    public Date getLastSeen() {
-        Date d = null;
-        for (int i = 0; i < entities.length; i++) {
-            if (d == null
-                    || entities[i].getLastSeenTimestamp().compareTo(d) > 0)
-                d = entities[i].getLastSeenTimestamp();
-        }
-        return d;
-    }
-
-    // ***************
-    // Getters/Setters
-    // ***************
-
-    @Override
-    public IEntityClass getEntityClass() {
-        return entityClass;
-    }
-
-    public Entity[] getEntities() {
-        return entities;
-    }
-
-    public String getDHCPClientName() {
-        return dhcpClientName;
-    }
-
-    // ***************
-    // Utility Methods
-    // ***************
-
-    /**
-     * Check whether the device contains the specified entity
-     *
-     * @param entity
-     *            the entity to search for
-     * @return the index of the entity, or <0 if not found
-     */
-    protected int entityIndex(Entity entity) {
-        return Arrays.binarySearch(entities, entity);
-    }
-
-    // ******
-    // Object
-    // ******
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + Arrays.hashCode(entities);
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj)
-            return true;
-        if (obj == null)
-            return false;
-        if (getClass() != obj.getClass())
-            return false;
-        Device other = (Device) obj;
-        if (!deviceKey.equals(other.deviceKey))
-            return false;
-        if (!Arrays.equals(entities, other.entities))
-            return false;
-        return true;
-    }
-
-    public HostNodeConnector toHostNodeConnector() {
-        Integer[] ipv4s = this.getIPv4Addresses();
-        try {
-            Entity e = this.entities[this.entities.length-1];
-            NodeConnector n = null;
-            if(e!=null)
-                 n = e.getPort();
-            InetAddress ip = InetAddress.getByName(ipv4s[ipv4s.length - 1]
-                    .toString());
-            byte[] macAddr = macLongToByte(this.getMACAddress());
-            HostNodeConnector nc = new HostNodeConnector(macAddr, ip, n,
-                    (short) 0);
-            nc.setStaticHost(this.isStaticHost());
-            return nc;
-        } catch (Exception e) {
-            return null;
-        }
-    }
-
-    private byte[] macLongToByte(long mac) {
-        byte[] macAddr = new byte[6];
-        for (int i = 0; i < 6; i++) {
-            macAddr[5 - i] = (byte) (mac >> (8 * i));
-        }
-        return macAddr;
-    }
-
-    public boolean isStaticHost(){
-        return this.staticHost;
-    }
-
-    public void setStaticHost(boolean isStatic){
-        this.staticHost = isStatic;
-    }
-
-    @Override
-    public String toString() {
-        StringBuilder builder = new StringBuilder();
-        builder.append("Device [deviceKey=");
-        builder.append(deviceKey);
-        builder.append(", entityClass=");
-        builder.append(entityClass.getName());
-        builder.append(", MAC=");
-        builder.append(macAddressString);
-        builder.append(", IPs=[");
-        boolean isFirst = true;
-        for (Integer ip : getIPv4Addresses()) {
-            if (!isFirst)
-                builder.append(", ");
-            isFirst = false;
-            builder.append(ip);
-        }
-        builder.append("], APs=");
-        builder.append(Arrays.toString(getAttachmentPoints(true)));
-        builder.append("]");
-        return builder.toString();
-    }
-}
diff --git a/opendaylight/adsal/hosttracker_new/implementation/src/main/java/org/opendaylight/controller/hosttracker/internal/DeviceIndex.java b/opendaylight/adsal/hosttracker_new/implementation/src/main/java/org/opendaylight/controller/hosttracker/internal/DeviceIndex.java
deleted file mode 100644 (file)
index 5f06806..0000000
+++ /dev/null
@@ -1,154 +0,0 @@
-/*
- * Copyright (c) 2012 Big Switch Networks, Inc.
- *
- * Licensed under the Eclipse Public License, Version 1.0 (the
- * "License"); you may not use this file except in compliance with the
- * License. You may obtain a copy of the License at
- *
- *      http://www.eclipse.org/legal/epl-v10.html
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
- * implied. See the License for the specific language governing
- * permissions and limitations under the License.
- *
- * This file incorporates work covered by the following copyright and
- * permission notice:
- *
- *    Originally created by David Erickson, Stanford University
- *
- *    Licensed under the Apache License, Version 2.0 (the "License");
- *    you may not use this file except in compliance with the
- *    License. You may obtain a copy of the License at
- *
- *         http://www.apache.org/licenses/LICENSE-2.0
- *
- *    Unless required by applicable law or agreed to in writing,
- *    software distributed under the License is distributed on an "AS
- *    IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
- *    express or implied. See the License for the specific language
- *    governing permissions and limitations under the License.
- */
-
-package org.opendaylight.controller.hosttracker.internal;
-
-import java.util.Collection;
-import java.util.EnumSet;
-import java.util.Iterator;
-
-import org.opendaylight.controller.hosttracker.Entity;
-import org.opendaylight.controller.hosttracker.IDeviceService.DeviceField;
-
-/**
- * An index that maps key fields of an entity to device keys
- */
-public abstract class DeviceIndex {
-    /**
-     * The key fields for this index
-     */
-    protected EnumSet<DeviceField> keyFields;
-
-    /**
-     * Construct a new device index using the provided key fields
-     *
-     * @param keyFields
-     *            the key fields to use
-     */
-    public DeviceIndex(EnumSet<DeviceField> keyFields) {
-        super();
-        this.keyFields = keyFields;
-    }
-
-    /**
-     * Find all device keys in the index that match the given entity on all the
-     * key fields for this index
-     *
-     * @param e
-     *            the entity to search for
-     * @return an iterator over device keys
-     */
-    public abstract Iterator<Long> queryByEntity(Entity entity);
-
-    /**
-     * Get all device keys in the index. If certain devices exist multiple
-     * times, then these devices may be returned multiple times
-     *
-     * @return an iterator over device keys
-     */
-    public abstract Iterator<Long> getAll();
-
-    /**
-     * Attempt to update an index with the entities in the provided
-     * {@link Device}. If the update fails because of a concurrent update, will
-     * return false.
-     *
-     * @param device
-     *            the device to update
-     * @param deviceKey
-     *            the device key for the device
-     * @return true if the update succeeded, false otherwise.
-     */
-    public abstract boolean updateIndex(Device device, Long deviceKey);
-
-    /**
-     * Add a mapping from the given entity to the given device key. This update
-     * will not fail because of a concurrent update
-     *
-     * @param device
-     *            the device to update
-     * @param deviceKey
-     *            the device key for the device
-     */
-    public abstract void updateIndex(Entity entity, Long deviceKey);
-
-    /**
-     * Remove the entry for the given entity
-     *
-     * @param entity
-     *            the entity to remove
-     */
-    public abstract void removeEntity(Entity entity);
-
-    /**
-     * Remove the given device key from the index for the given entity
-     *
-     * @param entity
-     *            the entity to search for
-     * @param deviceKey
-     *            the key to remove
-     */
-    public abstract void removeEntity(Entity entity, Long deviceKey);
-
-    /**
-     * Remove the give device from the index only if this the collection of
-     * others does not contain an entity that is identical on all the key fields
-     * for this index.
-     *
-     * @param entity
-     *            the entity to search for
-     * @param deviceKey
-     *            the key to remove
-     * @param others
-     *            the others against which to check
-     */
-    public void removeEntityIfNeeded(Entity entity, Long deviceKey,
-            Collection<Entity> others) {
-        IndexedEntity ie = new IndexedEntity(keyFields, entity);
-        for (Entity o : others) {
-            IndexedEntity oio = new IndexedEntity(keyFields, o);
-            if (oio.equals(ie))
-                return;
-        }
-
-        Iterator<Long> keyiter = this.queryByEntity(entity);
-        while (keyiter.hasNext()) {
-            Long key = keyiter.next();
-            if (key.equals(deviceKey)) {
-                removeEntity(entity, deviceKey);
-                break;
-            }
-        }
-    }
-
-}
diff --git a/opendaylight/adsal/hosttracker_new/implementation/src/main/java/org/opendaylight/controller/hosttracker/internal/DeviceIndexInterator.java b/opendaylight/adsal/hosttracker_new/implementation/src/main/java/org/opendaylight/controller/hosttracker/internal/DeviceIndexInterator.java
deleted file mode 100644 (file)
index 469bd61..0000000
+++ /dev/null
@@ -1,77 +0,0 @@
-/*
- * Copyright (c) 2012 Big Switch Networks, Inc.
- *
- * Licensed under the Eclipse Public License, Version 1.0 (the
- * "License"); you may not use this file except in compliance with the
- * License. You may obtain a copy of the License at
- *
- *      http://www.eclipse.org/legal/epl-v10.html
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
- * implied. See the License for the specific language governing
- * permissions and limitations under the License.
- *
- * This file incorporates work covered by the following copyright and
- * permission notice:
- *
- *    Originally created by David Erickson, Stanford University
- *
- *    Licensed under the Apache License, Version 2.0 (the "License");
- *    you may not use this file except in compliance with the
- *    License. You may obtain a copy of the License at
- *
- *         http://www.apache.org/licenses/LICENSE-2.0
- *
- *    Unless required by applicable law or agreed to in writing,
- *    software distributed under the License is distributed on an "AS
- *    IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
- *    express or implied. See the License for the specific language
- *    governing permissions and limitations under the License.
- */
-
-package org.opendaylight.controller.hosttracker.internal;
-
-import java.util.Iterator;
-
-/**
- * An iterator for handling device index queries
- */
-public class DeviceIndexInterator implements Iterator<Device> {
-    private DeviceManagerImpl deviceManager;
-    private Iterator<Long> subIterator;
-
-    /**
-     * Construct a new device index iterator referring to a device manager
-     * instance and an iterator over device keys
-     *
-     * @param deviceManager
-     *            the device manager
-     * @param subIterator
-     *            an iterator over device keys
-     */
-    public DeviceIndexInterator(DeviceManagerImpl deviceManager,
-            Iterator<Long> subIterator) {
-        super();
-        this.deviceManager = deviceManager;
-        this.subIterator = subIterator;
-    }
-
-    @Override
-    public boolean hasNext() {
-        return subIterator.hasNext();
-    }
-
-    @Override
-    public Device next() {
-        Long next = subIterator.next();
-        return deviceManager.deviceMap.get(next);
-    }
-
-    @Override
-    public void remove() {
-        subIterator.remove();
-    }
-
-}
diff --git a/opendaylight/adsal/hosttracker_new/implementation/src/main/java/org/opendaylight/controller/hosttracker/internal/DeviceIterator.java b/opendaylight/adsal/hosttracker_new/implementation/src/main/java/org/opendaylight/controller/hosttracker/internal/DeviceIterator.java
deleted file mode 100644 (file)
index 68f175c..0000000
+++ /dev/null
@@ -1,134 +0,0 @@
-/*
- * Copyright (c) 2012 Big Switch Networks, Inc.
- *
- * Licensed under the Eclipse Public License, Version 1.0 (the
- * "License"); you may not use this file except in compliance with the
- * License. You may obtain a copy of the License at
- *
- *      http://www.eclipse.org/legal/epl-v10.html
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
- * implied. See the License for the specific language governing
- * permissions and limitations under the License.
- *
- * This file incorporates work covered by the following copyright and
- * permission notice:
- *
- *    Originally created by David Erickson, Stanford University
- *
- *    Licensed under the Apache License, Version 2.0 (the "License");
- *    you may not use this file except in compliance with the
- *    License. You may obtain a copy of the License at
- *
- *         http://www.apache.org/licenses/LICENSE-2.0
- *
- *    Unless required by applicable law or agreed to in writing,
- *    software distributed under the License is distributed on an "AS
- *    IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
- *    express or implied. See the License for the specific language
- *    governing permissions and limitations under the License.
- */
-
-package org.opendaylight.controller.hosttracker.internal;
-
-import java.util.Arrays;
-import java.util.Iterator;
-
-import org.opendaylight.controller.hosttracker.IEntityClass;
-import org.opendaylight.controller.hosttracker.SwitchPort;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.utils.FilterIterator;
-
-/**
- * An iterator for handling device queries
- */
-public class DeviceIterator extends FilterIterator<Device> {
-    private IEntityClass[] entityClasses;
-
-    private Long macAddress;
-    private Short vlan;
-    private Integer ipv4Address;
-    private NodeConnector port;
-
-    /**
-     * Construct a new device iterator over the key fields
-     *
-     * @param subIterator
-     *            an iterator over the full data structure to scan
-     * @param entityClasses
-     *            the entity classes to search for
-     * @param macAddress
-     *            The MAC address
-     * @param vlan
-     *            the VLAN
-     * @param ipv4Address
-     *            the ipv4 address
-     * @param switchDPID
-     *            the switch DPID
-     * @param switchPort
-     *            the switch port
-     */
-    public DeviceIterator(Iterator<Device> subIterator,
-            IEntityClass[] entityClasses, Long macAddress, Short vlan,
-            Integer ipv4Address, NodeConnector port) {
-        super(subIterator);
-        this.entityClasses = entityClasses;
-        this.subIterator = subIterator;
-        this.macAddress = macAddress;
-        this.vlan = vlan;
-        this.ipv4Address = ipv4Address;
-        this.port = port;
-    }
-
-    @Override
-    protected boolean matches(Device value) {
-        boolean match;
-        if (entityClasses != null) {
-            IEntityClass clazz = value.getEntityClass();
-            if (clazz == null)
-                return false;
-
-            match = false;
-            for (IEntityClass entityClass : entityClasses) {
-                if (clazz.equals(entityClass)) {
-                    match = true;
-                    break;
-                }
-            }
-            if (!match)
-                return false;
-        }
-        if (macAddress != null) {
-            if (macAddress.longValue() != value.getMACAddress())
-                return false;
-        }
-        if (vlan != null) {
-            Short[] vlans = value.getVlanId();
-            if (Arrays.binarySearch(vlans, vlan) < 0)
-                return false;
-        }
-        if (ipv4Address != null) {
-            Integer[] ipv4Addresses = value.getIPv4Addresses();
-            if (Arrays.binarySearch(ipv4Addresses, ipv4Address) < 0)
-                return false;
-        }
-        if (port != null) {
-            SwitchPort[] sps = value.getAttachmentPoints();
-            if (sps == null)
-                return false;
-
-            match = false;
-            for (SwitchPort sp : sps) {
-                if (sp.getPort().equals(sp.getPort())) {
-                    match = true;
-                    break;
-                }
-            }
-            if (!match)
-                return false;
-        }
-        return true;
-    }
-}
diff --git a/opendaylight/adsal/hosttracker_new/implementation/src/main/java/org/opendaylight/controller/hosttracker/internal/DeviceManagerImpl.java b/opendaylight/adsal/hosttracker_new/implementation/src/main/java/org/opendaylight/controller/hosttracker/internal/DeviceManagerImpl.java
deleted file mode 100755 (executable)
index ee75ac0..0000000
+++ /dev/null
@@ -1,2114 +0,0 @@
-/*
- * Copyright (c) 2011,2012 Big Switch Networks, Inc.
- *
- * Licensed under the Eclipse Public License, Version 1.0 (the
- * "License"); you may not use this file except in compliance with the
- * License. You may obtain a copy of the License at
- *
- *      http://www.eclipse.org/legal/epl-v10.html
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
- * implied. See the License for the specific language governing
- * permissions and limitations under the License.
- *
- * This file incorporates work covered by the following copyright and
- * permission notice:
- *
- *    Originally created by David Erickson, Stanford University
- *
- *    Licensed under the Apache License, Version 2.0 (the "License");
- *    you may not use this file except in compliance with the
- *    License. You may obtain a copy of the License at
- *
- *         http://www.apache.org/licenses/LICENSE-2.0
- *
- *    Unless required by applicable law or agreed to in writing,
- *    software distributed under the License is distributed on an "AS
- *    IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
- *    express or implied. See the License for the specific language
- *    governing permissions and limitations under the License.
- */
-
-package org.opendaylight.controller.hosttracker.internal;
-
-import static org.opendaylight.controller.hosttracker.internal.DeviceManagerImpl.DeviceUpdate.Change.ADD;
-import static org.opendaylight.controller.hosttracker.internal.DeviceManagerImpl.DeviceUpdate.Change.CHANGE;
-import static org.opendaylight.controller.hosttracker.internal.DeviceManagerImpl.DeviceUpdate.Change.DELETE;
-
-import java.net.InetAddress;
-import java.net.UnknownHostException;
-import java.util.ArrayList;
-import java.util.Calendar;
-import java.util.Collection;
-import java.util.Collections;
-import java.util.Comparator;
-import java.util.Date;
-import java.util.EnumSet;
-import java.util.HashMap;
-import java.util.HashSet;
-import java.util.Iterator;
-import java.util.LinkedList;
-import java.util.List;
-import java.util.Map;
-import java.util.Map.Entry;
-import java.util.Queue;
-import java.util.Set;
-import java.util.concurrent.ConcurrentHashMap;
-import java.util.concurrent.Executors;
-import java.util.concurrent.Future;
-import java.util.concurrent.ScheduledExecutorService;
-import java.util.concurrent.TimeUnit;
-
-import org.opendaylight.controller.hosttracker.Entity;
-import org.opendaylight.controller.hosttracker.IDevice;
-import org.opendaylight.controller.hosttracker.IDeviceListener;
-import org.opendaylight.controller.hosttracker.IDeviceService;
-import org.opendaylight.controller.hosttracker.IEntityClass;
-import org.opendaylight.controller.hosttracker.IEntityClassListener;
-import org.opendaylight.controller.hosttracker.IEntityClassifierService;
-import org.opendaylight.controller.hosttracker.IfIptoHost;
-import org.opendaylight.controller.hosttracker.IfNewHostNotify;
-import org.opendaylight.controller.hosttracker.SwitchPort;
-import org.opendaylight.controller.hosttracker.hostAware.HostNodeConnector;
-import org.opendaylight.controller.sal.core.ConstructionException;
-import org.opendaylight.controller.sal.core.Edge;
-import org.opendaylight.controller.sal.core.Host;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.NodeConnector.NodeConnectorIDType;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.core.State;
-import org.opendaylight.controller.sal.core.Tier;
-import org.opendaylight.controller.sal.core.UpdateType;
-import org.opendaylight.controller.sal.packet.ARP;
-import org.opendaylight.controller.sal.packet.Ethernet;
-import org.opendaylight.controller.sal.packet.IDataPacketService;
-import org.opendaylight.controller.sal.packet.IListenDataPacket;
-import org.opendaylight.controller.sal.packet.Packet;
-import org.opendaylight.controller.sal.packet.PacketResult;
-import org.opendaylight.controller.sal.packet.RawPacket;
-import org.opendaylight.controller.sal.packet.address.DataLinkAddress;
-import org.opendaylight.controller.sal.packet.address.EthernetAddress;
-import org.opendaylight.controller.sal.topology.TopoEdgeUpdate;
-import org.opendaylight.controller.sal.utils.HexEncode;
-import org.opendaylight.controller.sal.utils.ListenerDispatcher;
-import org.opendaylight.controller.sal.utils.MultiIterator;
-import org.opendaylight.controller.sal.utils.NetUtils;
-import org.opendaylight.controller.sal.utils.SingletonTask;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.sal.utils.StatusCode;
-import org.opendaylight.controller.switchmanager.IInventoryListener;
-import org.opendaylight.controller.switchmanager.ISwitchManager;
-import org.opendaylight.controller.topologymanager.ITopologyManager;
-import org.opendaylight.controller.topologymanager.ITopologyManagerAware;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * DeviceManager creates Devices based upon MAC addresses seen in the network.
- * It tracks any network addresses mapped to the Device, and its location within
- * the network.
- *
- * @author readams
- */
-public class DeviceManagerImpl implements IDeviceService, IEntityClassListener,
-        IListenDataPacket, ITopologyManagerAware, IfIptoHost,
-        IInventoryListener {
-    protected static Logger logger = LoggerFactory
-            .getLogger(DeviceManagerImpl.class);
-
-    public static final String MODULE_NAME = "devicemanager";
-
-    private ITopologyManager topology;
-    private ISwitchManager switchManager = null;
-    private IDataPacketService dataPacketService = null;
-
-    public static final String CNT_INCOMING = MODULE_NAME + "-incoming";
-    public static final String CNT_RECONCILE_REQUEST = MODULE_NAME
-            + "-reconcileRequest";
-    public static final String CNT_RECONCILE_NO_SOURCE = MODULE_NAME
-            + "-reconcileNoSourceDevice";
-    public static final String CNT_RECONCILE_NO_DEST = MODULE_NAME
-            + "-reconcileNoDestDevice";
-    public static final String CNT_BROADCAST_SOURCE = MODULE_NAME
-            + "-broadcastSource";
-    public static final String CNT_NO_SOURCE = MODULE_NAME + "-noSourceDevice";
-    public static final String CNT_NO_DEST = MODULE_NAME + "-noDestDevice";
-    public static final String CNT_DHCP_CLIENT_NAME_SNOOPED = MODULE_NAME
-            + "-dhcpClientNameSnooped";
-    public static final String CNT_DEVICE_ON_INTERAL_PORT_NOT_LEARNED = MODULE_NAME
-            + "-deviceOnInternalPortNotLearned";
-    public static final String CNT_PACKET_NOT_ALLOWED = MODULE_NAME
-            + "-packetNotAllowed";
-    public static final String CNT_NEW_DEVICE = MODULE_NAME + "-newDevice";
-    public static final String CNT_PACKET_ON_INTERNAL_PORT_FOR_KNOWN_DEVICE = MODULE_NAME
-            + "-packetOnInternalPortForKnownDevice";
-    public static final String CNT_NEW_ENTITY = MODULE_NAME + "-newEntity";
-    public static final String CNT_DEVICE_CHANGED = MODULE_NAME
-            + "-deviceChanged";
-    public static final String CNT_DEVICE_MOVED = MODULE_NAME + "-deviceMoved";
-    public static final String CNT_CLEANUP_ENTITIES_RUNS = MODULE_NAME
-            + "-cleanupEntitiesRuns";
-    public static final String CNT_ENTITY_REMOVED_TIMEOUT = MODULE_NAME
-            + "-entityRemovedTimeout";
-    public static final String CNT_DEVICE_DELETED = MODULE_NAME
-            + "-deviceDeleted";
-    public static final String CNT_DEVICE_RECLASSIFY_DELETE = MODULE_NAME
-            + "-deviceReclassifyDelete";
-    public static final String CNT_DEVICE_STORED = MODULE_NAME
-            + "-deviceStored";
-    public static final String CNT_DEVICE_STORE_THROTTLED = MODULE_NAME
-            + "-deviceStoreThrottled";
-    public static final String CNT_DEVICE_REMOVED_FROM_STORE = MODULE_NAME
-            + "-deviceRemovedFromStore";
-    public static final String CNT_SYNC_EXCEPTION = MODULE_NAME
-            + "-syncException";
-    public static final String CNT_DEVICES_FROM_STORE = MODULE_NAME
-            + "-devicesFromStore";
-    public static final String CNT_CONSOLIDATE_STORE_RUNS = MODULE_NAME
-            + "-consolidateStoreRuns";
-    public static final String CNT_CONSOLIDATE_STORE_DEVICES_REMOVED = MODULE_NAME
-            + "-consolidateStoreDevicesRemoved";
-
-    static final String DEVICE_SYNC_STORE_NAME = DeviceManagerImpl.class
-            .getCanonicalName() + ".stateStore";
-
-
-    /**
-     * Time in milliseconds before entities will expire
-     */
-    protected static final int ENTITY_TIMEOUT = 60 * 60 * 1000;
-
-    /**
-     * Time in seconds between cleaning up old entities/devices
-     */
-    protected static final int ENTITY_CLEANUP_INTERVAL = 60 * 60;
-
-    /**
-     * This is the master device map that maps device IDs to {@link Device}
-     * objects.
-     */
-    protected ConcurrentHashMap<Long, Device> deviceMap;
-
-    protected ConcurrentHashMap<NodeConnector, Entity> inactiveStaticDevices;
-    /**
-     * Counter used to generate device keys
-     */
-    protected long deviceKeyCounter = 0;
-
-    /**
-     * Lock for incrementing the device key counter
-     */
-    protected Object deviceKeyLock = new Object();
-
-    /**
-     * This is the primary entity index that contains all entities
-     */
-    protected DeviceUniqueIndex primaryIndex;
-
-    /**
-     * This stores secondary indices over the fields in the devices
-     */
-    protected Map<EnumSet<DeviceField>, DeviceIndex> secondaryIndexMap;
-
-    /**
-     * This map contains state for each of the {@ref IEntityClass} that exist
-     */
-    protected ConcurrentHashMap<String, ClassState> classStateMap;
-
-    /**
-     * This is the list of indices we want on a per-class basis
-     */
-    protected Set<EnumSet<DeviceField>> perClassIndices;
-
-    /**
-     * The entity classifier currently in use
-     */
-    protected IEntityClassifierService entityClassifier;
-
-    /**
-     * Used to cache state about specific entity classes
-     */
-    protected class ClassState {
-
-        /**
-         * The class index
-         */
-        protected DeviceUniqueIndex classIndex;
-
-        /**
-         * This stores secondary indices over the fields in the device for the
-         * class
-         */
-        protected Map<EnumSet<DeviceField>, DeviceIndex> secondaryIndexMap;
-
-        /**
-         * Allocate a new {@link ClassState} object for the class
-         *
-         * @param clazz
-         *            the class to use for the state
-         */
-        public ClassState(IEntityClass clazz) {
-            EnumSet<DeviceField> keyFields = clazz.getKeyFields();
-            EnumSet<DeviceField> primaryKeyFields = entityClassifier
-                    .getKeyFields();
-            boolean keyFieldsMatchPrimary = primaryKeyFields.equals(keyFields);
-
-            if (!keyFieldsMatchPrimary)
-                classIndex = new DeviceUniqueIndex(keyFields);
-
-            secondaryIndexMap = new HashMap<EnumSet<DeviceField>, DeviceIndex>();
-            for (EnumSet<DeviceField> fields : perClassIndices) {
-                secondaryIndexMap.put(fields, new DeviceMultiIndex(fields));
-            }
-        }
-    }
-
-    /**
-     * Device manager event listeners reclassifyDeviceListeners are notified
-     * first before reconcileDeviceListeners. This is to make sure devices are
-     * correctly reclassified before reconciliation.
-     */
-    protected ListenerDispatcher<String, IDeviceListener> deviceListeners;
-
-    /**
-     * Using the IfNewHostNotify to notify listeners of host changes.
-     */
-    private Set<IfNewHostNotify> newHostNotify = Collections
-            .synchronizedSet(new HashSet<IfNewHostNotify>());
-
-    /**
-     * A device update event to be dispatched
-     */
-    protected static class DeviceUpdate {
-        public enum Change {
-            ADD, DELETE, CHANGE;
-        }
-
-        /**
-         * The affected device
-         */
-        protected Device device;
-
-        /**
-         * The change that was made
-         */
-        protected Change change;
-
-        /**
-         * If not added, then this is the list of fields changed
-         */
-        protected EnumSet<DeviceField> fieldsChanged;
-
-        public DeviceUpdate(Device device, Change change,
-                EnumSet<DeviceField> fieldsChanged) {
-            super();
-            this.device = device;
-            this.change = change;
-            this.fieldsChanged = fieldsChanged;
-        }
-
-        @Override
-        public String toString() {
-            String devIdStr = device.getEntityClass().getName() + "::"
-                    + device.getMACAddressString();
-            return "DeviceUpdate [device=" + devIdStr + ", change=" + change
-                    + ", fieldsChanged=" + fieldsChanged + "]";
-        }
-
-    }
-
-    /**
-     * AttachmentPointComparator
-     *
-     * Compares two attachment points and returns the latest one. It is assumed
-     * that the two attachment points are in the same L2 domain.
-     *
-     * @author srini
-     */
-    protected class AttachmentPointComparator implements
-            Comparator<AttachmentPoint> {
-        public AttachmentPointComparator() {
-            super();
-        }
-
-        @Override
-        public int compare(AttachmentPoint oldAP, AttachmentPoint newAP) {
-            // First compare based on L2 domain ID;
-
-            // XXX - missing functionality -- need topology
-            // long oldDomain = topology.getL2DomainId(oldSw);
-            // boolean oldBD = topology.isBroadcastDomainPort(oldSw, oldPort);
-            long oldDomain = 0;
-            boolean oldBD = false;
-
-            // XXX - missing functionality -- need topology
-            // long newDomain = topology.getL2DomainId(newSw);
-            // boolean newBD = topology.isBroadcastDomainPort(newSw, newPort);
-            long newDomain = 0;
-            boolean newBD = false;
-
-            if (oldDomain < newDomain) {
-               return -1;
-            } else if (oldDomain > newDomain) {
-                return 1;
-            }
-            // Give preference to OFPP_LOCAL always
-            if (!oldAP.getPort().getType().equals(NodeConnectorIDType.SWSTACK)
-                    && newAP.getPort().getType()
-                            .equals(NodeConnectorIDType.SWSTACK)) {
-                return -1;
-            } else if (oldAP.getPort().getType()
-                    .equals(NodeConnectorIDType.SWSTACK)
-                    && !newAP.getPort().getType()
-                            .equals(NodeConnectorIDType.SWSTACK)) {
-                return 1;
-            }
-
-            // We expect that the last seen of the new AP is higher than
-            // old AP, if it is not, just reverse and send the negative
-            // of the result.
-            if (oldAP.getActiveSince() > newAP.getActiveSince())
-                return -compare(newAP, oldAP);
-
-            long activeOffset = 0;
-
-            if (!newBD && oldBD) {
-                return -1;
-            }
-            if (newBD && oldBD) {
-                activeOffset = AttachmentPoint.EXTERNAL_TO_EXTERNAL_TIMEOUT;
-            } else if (newBD && !oldBD) {
-                activeOffset = AttachmentPoint.OPENFLOW_TO_EXTERNAL_TIMEOUT;
-            }
-
-
-            if ((newAP.getActiveSince() > oldAP.getLastSeen() + activeOffset)
-                    || (newAP.getLastSeen() > oldAP.getLastSeen()
-                            + AttachmentPoint.INACTIVITY_INTERVAL)) {
-                return -1;
-            }
-            return 1;
-        }
-    }
-
-    /**
-     * Comparator for sorting by cluster ID
-     */
-    public AttachmentPointComparator apComparator;
-
-    /**
-     * Switch ports where attachment points shouldn't be learned
-     */
-    private Set<SwitchPort> suppressAPs;
-
-    /**
-     * Periodic task to clean up expired entities
-     */
-    public SingletonTask entityCleanupTask;
-
-    // ********************
-    // Dependency injection
-    // ********************
-
-    void setNewHostNotify(IfNewHostNotify obj) {
-        this.newHostNotify.add(obj);
-    }
-
-    void unsetNewHostNotify(IfNewHostNotify obj) {
-        this.newHostNotify.remove(obj);
-    }
-
-    void setDataPacketService(IDataPacketService s) {
-        this.dataPacketService = s;
-    }
-
-    void unsetDataPacketService(IDataPacketService s) {
-        if (this.dataPacketService == s) {
-            this.dataPacketService = null;
-        }
-    }
-
-    public void setTopologyManager(ITopologyManager s) {
-        this.topology = s;
-    }
-
-    public void unsetTopologyManager(ITopologyManager s) {
-        if (this.topology == s) {
-            logger.debug("Topology Manager Service removed!");
-            this.topology = null;
-        }
-    }
-
-    private volatile boolean stopped = true;
-    private ScheduledExecutorService ses;
-
-    public void stop() {
-        stopped = true;
-        if (ses != null)
-            ses.shutdownNow();
-    }
-
-    public void start() {
-        this.perClassIndices = new HashSet<EnumSet<DeviceField>>();
-
-        // XXX - TODO need to make it possible to register a non-default
-        // classifier
-        entityClassifier = new DefaultEntityClassifier();
-        this.deviceListeners = new ListenerDispatcher<String, IDeviceListener>();
-        this.suppressAPs = Collections
-                .newSetFromMap(new ConcurrentHashMap<SwitchPort, Boolean>());
-        primaryIndex = new DeviceUniqueIndex(entityClassifier.getKeyFields());
-        secondaryIndexMap = new HashMap<EnumSet<DeviceField>, DeviceIndex>();
-
-        deviceMap = new ConcurrentHashMap<Long, Device>();
-        inactiveStaticDevices = new ConcurrentHashMap<NodeConnector, Entity>();
-        classStateMap = new ConcurrentHashMap<String, ClassState>();
-        apComparator = new AttachmentPointComparator();
-
-        addIndex(true, EnumSet.of(DeviceField.IPV4));
-
-        stopped = false;
-        // XXX - Should use a common threadpool but this doesn't currently exist
-        ses = Executors.newScheduledThreadPool(1);
-        Runnable ecr = new Runnable() {
-            @Override
-            public void run() {
-                cleanupEntities();
-                if (!stopped)
-                    entityCleanupTask.reschedule(ENTITY_CLEANUP_INTERVAL,
-                            TimeUnit.SECONDS);
-            }
-        };
-        entityCleanupTask = new SingletonTask(ses, ecr);
-        entityCleanupTask.reschedule(ENTITY_CLEANUP_INTERVAL, TimeUnit.SECONDS);
-
-        registerDeviceManagerDebugCounters();
-    }
-
-    /**
-     * Periodic task to consolidate entries in the store. I.e., delete entries
-     * in the store that are not known to DeviceManager
-     */
-    // XXX - Missing functionality
-    // private SingletonTask storeConsolidateTask;
-
-    // *********************
-    // IDeviceManagerService
-    // *********************
-
-    void setSwitchManager(ISwitchManager s) {
-        logger.debug("SwitchManager set");
-        this.switchManager = s;
-    }
-
-    void unsetSwitchManager(ISwitchManager s) {
-        if (this.switchManager == s) {
-            logger.debug("SwitchManager removed!");
-            this.switchManager = null;
-        }
-    }
-
-    @Override
-    public IDevice getDevice(Long deviceKey) {
-        return deviceMap.get(deviceKey);
-    }
-
-    @Override
-    public IDevice findDevice(long macAddress, Short vlan, Integer ipv4Address,
-            NodeConnector port) throws IllegalArgumentException {
-        if (vlan != null && vlan.shortValue() <= 0)
-            vlan = null;
-        if (ipv4Address != null && ipv4Address == 0)
-            ipv4Address = null;
-        Entity e = new Entity(macAddress, vlan, ipv4Address, port, null);
-        if (!allKeyFieldsPresent(e, entityClassifier.getKeyFields())) {
-            throw new IllegalArgumentException("Not all key fields specified."
-                    + " Required fields: " + entityClassifier.getKeyFields());
-        }
-        return findDeviceByEntity(e);
-    }
-
-    @Override
-    public IDevice findClassDevice(IEntityClass entityClass, long macAddress,
-            Short vlan, Integer ipv4Address) throws IllegalArgumentException {
-        if (vlan != null && vlan.shortValue() <= 0)
-            vlan = null;
-        if (ipv4Address != null && ipv4Address == 0)
-            ipv4Address = null;
-        Entity e = new Entity(macAddress, vlan, ipv4Address, null, null);
-        if (entityClass == null
-                || !allKeyFieldsPresent(e, entityClass.getKeyFields())) {
-            throw new IllegalArgumentException("Not all key fields and/or "
-                    + " no source device specified. Required fields: "
-                    + entityClassifier.getKeyFields());
-        }
-        return findDestByEntity(entityClass, e);
-    }
-
-    @Override
-    public Collection<? extends IDevice> getAllDevices() {
-        return Collections.unmodifiableCollection(deviceMap.values());
-    }
-
-    @Override
-    public void addIndex(boolean perClass, EnumSet<DeviceField> keyFields) {
-        if (perClass) {
-            perClassIndices.add(keyFields);
-        } else {
-            secondaryIndexMap.put(keyFields, new DeviceMultiIndex(keyFields));
-        }
-    }
-
-    @Override
-    public Iterator<? extends IDevice> queryDevices(Long macAddress,
-            Short vlan, Integer ipv4Address, NodeConnector port) {
-        DeviceIndex index = null;
-        if (secondaryIndexMap.size() > 0) {
-            EnumSet<DeviceField> keys = getEntityKeys(macAddress, vlan,
-                    ipv4Address, port);
-            index = secondaryIndexMap.get(keys);
-        }
-
-        Iterator<Device> deviceIterator = null;
-        if (index == null) {
-            // Do a full table scan
-            deviceIterator = deviceMap.values().iterator();
-        } else {
-            // index lookup
-            Entity entity = new Entity((macAddress == null ? 0 : macAddress),
-                    vlan, ipv4Address, port, null);
-            deviceIterator = new DeviceIndexInterator(this,
-                    index.queryByEntity(entity));
-        }
-
-        DeviceIterator di = new DeviceIterator(deviceIterator, null,
-                macAddress, vlan, ipv4Address, port);
-        return di;
-    }
-
-    @Override
-    public Iterator<? extends IDevice> queryClassDevices(
-            IEntityClass entityClass, Long macAddress, Short vlan,
-            Integer ipv4Address, NodeConnector port) {
-        ArrayList<Iterator<Device>> iterators = new ArrayList<Iterator<Device>>();
-        ClassState classState = getClassState(entityClass);
-
-        DeviceIndex index = null;
-        if (classState.secondaryIndexMap.size() > 0) {
-            EnumSet<DeviceField> keys = getEntityKeys(macAddress, vlan,
-                    ipv4Address, port);
-            index = classState.secondaryIndexMap.get(keys);
-        }
-
-        Iterator<Device> iter;
-        if (index == null) {
-            index = classState.classIndex;
-            if (index == null) {
-                // scan all devices
-                return new DeviceIterator(deviceMap.values().iterator(),
-                        new IEntityClass[] { entityClass }, macAddress, vlan,
-                        ipv4Address, port);
-            } else {
-                // scan the entire class
-                iter = new DeviceIndexInterator(this, index.getAll());
-            }
-        } else {
-            // index lookup
-            Entity entity = new Entity((macAddress == null ? 0 : macAddress),
-                    vlan, ipv4Address, port, null);
-            iter = new DeviceIndexInterator(this, index.queryByEntity(entity));
-        }
-        iterators.add(iter);
-
-        return new MultiIterator<Device>(iterators.iterator());
-    }
-
-    protected Iterator<Device> getDeviceIteratorForQuery(Long macAddress,
-            Short vlan, Integer ipv4Address, NodeConnector port) {
-        DeviceIndex index = null;
-        if (secondaryIndexMap.size() > 0) {
-            EnumSet<DeviceField> keys = getEntityKeys(macAddress, vlan,
-                    ipv4Address, port);
-            index = secondaryIndexMap.get(keys);
-        }
-
-        Iterator<Device> deviceIterator = null;
-        if (index == null) {
-            // Do a full table scan
-            deviceIterator = deviceMap.values().iterator();
-        } else {
-            // index lookup
-            Entity entity = new Entity((macAddress == null ? 0 : macAddress),
-                    vlan, ipv4Address, port, null);
-            deviceIterator = new DeviceIndexInterator(this,
-                    index.queryByEntity(entity));
-        }
-
-        DeviceIterator di = new DeviceIterator(deviceIterator, null,
-                macAddress, vlan, ipv4Address, port);
-        return di;
-    }
-
-    @Override
-    public void addListener(IDeviceListener listener) {
-        deviceListeners.addListener("device", listener);
-        logListeners();
-    }
-
-    @Override
-    public void addSuppressAPs(NodeConnector port) {
-        suppressAPs.add(new SwitchPort(port));
-    }
-
-    @Override
-    public void removeSuppressAPs(NodeConnector port) {
-        suppressAPs.remove(new SwitchPort(port));
-    }
-
-    @Override
-    public Set<SwitchPort> getSuppressAPs() {
-        return Collections.unmodifiableSet(suppressAPs);
-    }
-
-    private void logListeners() {
-        List<IDeviceListener> listeners = deviceListeners.getOrderedListeners();
-        if (listeners != null) {
-            StringBuffer sb = new StringBuffer();
-            sb.append("DeviceListeners: ");
-            for (IDeviceListener l : listeners) {
-                sb.append(l.getName());
-                sb.append(",");
-            }
-            logger.debug(sb.toString());
-        }
-    }
-
-
-    // *****************
-    // IListenDataPacket
-    // *****************
-
-    @Override
-    public PacketResult receiveDataPacket(RawPacket inPkt) {
-        // XXX - Can this really pass in null? Why would you ever want that?
-        if (inPkt == null) {
-            return PacketResult.IGNORED;
-        }
-
-        Packet formattedPak = this.dataPacketService.decodeDataPacket(inPkt);
-        Ethernet eth;
-        if (formattedPak instanceof Ethernet) {
-            eth = (Ethernet) formattedPak;
-        } else {
-            return PacketResult.IGNORED;
-        }
-
-        // Extract source entity information
-        NodeConnector inPort = inPkt.getIncomingNodeConnector();
-        Entity srcEntity = getSourceEntityFromPacket(eth, inPort);
-        if (srcEntity == null) {
-            return PacketResult.CONSUME;
-        }
-
-        // Learn from ARP packet for special VRRP settings.
-        // In VRRP settings, the source MAC address and sender MAC
-        // addresses can be different. In such cases, we need to learn
-        // the IP to MAC mapping of the VRRP IP address. The source
-        // entity will not have that information. Hence, a separate call
-        // to learn devices in such cases.
-        learnDeviceFromArpResponseData(eth, inPort);
-
-        // Learn/lookup device information
-        Device srcDevice = learnDeviceByEntity(srcEntity);
-        if (srcDevice == null) {
-            return PacketResult.CONSUME;
-        }
-        logger.trace("Saw packet from device {}", srcDevice);
-
-        return PacketResult.KEEP_PROCESSING;
-    }
-
-    // ****************
-    // Internal methods
-    // ****************
-
-
-    /**
-     * Check whether the given attachment point is valid given the current
-     * topology
-     *
-     * @param switchDPID
-     *            the DPID
-     * @param switchPort
-     *            the port
-     * @return true if it's a valid attachment point
-     */
-    public boolean isValidAttachmentPoint(NodeConnector port) {
-        // XXX - missing functionality -- need topology module
-        // if (topology.isAttachmentPointPort(port) == false)
-        // return false;
-        if (topology.isInternal(port))
-            return false;
-        if (!switchManager.isNodeConnectorEnabled(port))
-            return false;
-        if (suppressAPs.contains(new SwitchPort(port)))
-            return false;
-
-        return true;
-    }
-
-    /**
-     * Get sender IP address from packet if the packet is either an ARP packet.
-     *
-     * @param eth
-     * @param dlAddr
-     * @return
-     */
-    private int getSrcNwAddr(Ethernet eth, long dlAddr) {
-        if (eth.getPayload() instanceof ARP) {
-            ARP arp = (ARP) eth.getPayload();
-            if ((arp.getProtocolType() == ARP.PROTO_TYPE_IP)
-                    && (toLong(arp.getSenderHardwareAddress()) == dlAddr)) {
-                return toIPv4Address(arp.getSenderProtocolAddress());
-            }
-        }
-        return 0;
-    }
-
-    /**
-     * Parse an entity from an {@link Ethernet} packet.
-     *
-     * @param eth
-     *            the packet to parse
-     * @param sw
-     *            the switch on which the packet arrived
-     * @param pi
-     *            the original packetin
-     * @return the entity from the packet
-     */
-    protected Entity getSourceEntityFromPacket(Ethernet eth, NodeConnector port) {
-        byte[] dlAddrArr = eth.getSourceMACAddress();
-        long dlAddr = toLong(dlAddrArr);
-
-        // Ignore broadcast/multicast source
-        if ((dlAddrArr[0] & 0x1) != 0)
-            return null;
-
-        // XXX missing functionality
-        // short vlan = 0;
-        int nwSrc = getSrcNwAddr(eth, dlAddr);
-        return new Entity(dlAddr, null, ((nwSrc != 0) ? nwSrc : null), port,
-                new Date());
-    }
-
-    /**
-     * Learn device from ARP data in scenarios where the Ethernet source MAC is
-     * different from the sender hardware address in ARP data.
-     */
-    protected void learnDeviceFromArpResponseData(Ethernet eth,
-            NodeConnector port) {
-
-        if (!(eth.getPayload() instanceof ARP))
-            return;
-        ARP arp = (ARP) eth.getPayload();
-
-        byte[] dlAddrArr = eth.getSourceMACAddress();
-        long dlAddr = toLong(dlAddrArr);
-
-        byte[] senderHardwareAddr = arp.getSenderHardwareAddress();
-        long senderAddr = toLong(senderHardwareAddr);
-
-        if (dlAddr == senderAddr)
-            return;
-
-        // Ignore broadcast/multicast source
-        if ((senderHardwareAddr[0] & 0x1) != 0)
-            return;
-
-        // short vlan = eth.getVlanID();
-        int nwSrc = toIPv4Address(arp.getSenderProtocolAddress());
-
-        Entity e = new Entity(senderAddr, null, ((nwSrc != 0) ? nwSrc : null),
-                port, new Date());
-
-        learnDeviceByEntity(e);
-    }
-
-    /**
-     * Look up a {@link Device} based on the provided {@link Entity}. We first
-     * check the primary index. If we do not find an entry there we classify the
-     * device into its IEntityClass and query the classIndex. This implies that
-     * all key field of the current IEntityClassifier must be present in the
-     * entity for the lookup to succeed!
-     *
-     * @param entity
-     *            the entity to search for
-     * @return The {@link Device} object if found
-     */
-    protected Device findDeviceByEntity(Entity entity) {
-        // Look up the fully-qualified entity to see if it already
-        // exists in the primary entity index.
-        Long deviceKey = primaryIndex.findByEntity(entity);
-        IEntityClass entityClass = null;
-
-        if (deviceKey == null) {
-            // If the entity does not exist in the primary entity index,
-            // use the entity classifier for find the classes for the
-            // entity. Look up the entity in the returned class'
-            // class entity index.
-            entityClass = entityClassifier.classifyEntity(entity);
-            if (entityClass == null) {
-                return null;
-            }
-            ClassState classState = getClassState(entityClass);
-
-            if (classState.classIndex != null) {
-                deviceKey = classState.classIndex.findByEntity(entity);
-            }
-        }
-        if (deviceKey == null)
-            return null;
-        return deviceMap.get(deviceKey);
-    }
-
-    /**
-     * Get a destination device using entity fields that corresponds with the
-     * given source device. The source device is important since there could be
-     * ambiguity in the destination device without the attachment point
-     * information.
-     *
-     * @param reference
-     *            the source device's entity class. The returned destination
-     *            will be in the same entity class as the source.
-     * @param dstEntity
-     *            the entity to look up
-     * @return an {@link Device} or null if no device is found.
-     */
-    protected Device findDestByEntity(IEntityClass reference, Entity dstEntity) {
-
-        // Look up the fully-qualified entity to see if it
-        // exists in the primary entity index
-        Long deviceKey = primaryIndex.findByEntity(dstEntity);
-
-        if (deviceKey == null) {
-            // This could happen because:
-            // 1) no destination known, or a broadcast destination
-            // 2) if we have attachment point key fields since
-            // attachment point information isn't available for
-            // destination devices.
-            // For the second case, we'll need to match up the
-            // destination device with the class of the source
-            // device.
-            ClassState classState = getClassState(reference);
-            if (classState.classIndex == null) {
-                return null;
-            }
-            deviceKey = classState.classIndex.findByEntity(dstEntity);
-        }
-        if (deviceKey == null)
-            return null;
-        return deviceMap.get(deviceKey);
-    }
-
-    /**
-     * Look up a {@link Device} within a particular entity class based on the
-     * provided {@link Entity}.
-     *
-     * @param clazz
-     *            the entity class to search for the entity
-     * @param entity
-     *            the entity to search for
-     * @return The {@link Device} object if found private Device
-     *         findDeviceInClassByEntity(IEntityClass clazz, Entity entity) { //
-     *         XXX - TODO throw new UnsupportedOperationException(); }
-     */
-
-    /**
-     * Look up a {@link Device} based on the provided {@link Entity}. Also
-     * learns based on the new entity, and will update existing devices as
-     * required.
-     *
-     * @param entity
-     *            the {@link Entity}
-     * @return The {@link Device} object if found
-     */
-    protected Device learnDeviceByEntity(Entity entity) {
-        logger.info("Primary index {}", primaryIndex);
-        ArrayList<Long> deleteQueue = null;
-        LinkedList<DeviceUpdate> deviceUpdates = null;
-        Device oldDevice = null;
-        Device device = null;
-
-        // we may need to restart the learning process if we detect
-        // concurrent modification. Note that we ensure that at least
-        // one thread should always succeed so we don't get into infinite
-        // starvation loops
-        while (true) {
-            deviceUpdates = null;
-
-            // Look up the fully-qualified entity to see if it already
-            // exists in the primary entity index.
-            Long deviceKey = primaryIndex.findByEntity(entity);
-            IEntityClass entityClass = null;
-
-            if (deviceKey == null) {
-                // If the entity does not exist in the primary entity index,
-                // use the entity classifier for find the classes for the
-                // entity. Look up the entity in the returned class'
-                // class entity index.
-                entityClass = entityClassifier.classifyEntity(entity);
-                if (entityClass == null) {
-                    // could not classify entity. No device
-                    device = null;
-                    break;
-                }
-                ClassState classState = getClassState(entityClass);
-
-                if (classState.classIndex != null) {
-                    deviceKey = classState.classIndex.findByEntity(entity);
-                }
-            }
-            if (deviceKey != null) {
-                // If the primary or secondary index contains the entity
-                // use resulting device key to look up the device in the
-                // device map, and use the referenced Device below.
-                device = deviceMap.get(deviceKey);
-                if (device == null) {
-                    // This can happen due to concurrent modification
-                    if (logger.isDebugEnabled()) {
-                        logger.debug("No device for deviceKey {} while "
-                                + "while processing entity {}", deviceKey,
-                                entity);
-                    }
-                    // if so, then try again till we don't even get the device
-                    // key
-                    // and so we recreate the device
-                    continue;
-                }
-            } else {
-                // If the secondary index does not contain the entity,
-                // create a new Device object containing the entity, and
-                // generate a new device ID if the the entity is on an
-                // attachment point port. Otherwise ignore.
-                if (entity.hasSwitchPort()
-                        && !isValidAttachmentPoint(entity.getPort())) {
-                    // debugCounters.updateCounter(CNT_DEVICE_ON_INTERAL_PORT_NOT_LEARNED);
-                    if (logger.isDebugEnabled()) {
-                        logger.debug("Not learning new device on internal"
-                                + " link: {}", entity);
-                    }
-                    device = null;
-                    break;
-                }
-                // Before we create the new device also check if
-                // the entity is allowed (e.g., for spoofing protection)
-                if (!isEntityAllowed(entity, entityClass)) {
-                    // debugCounters.updateCounter(CNT_PACKET_NOT_ALLOWED);
-                    if (logger.isDebugEnabled()) {
-                        logger.debug("PacketIn is not allowed {} {}",
-                                entityClass.getName(), entity);
-                    }
-                    device = null;
-                    break;
-                }
-                synchronized (deviceKeyLock) {
-                    deviceKey = Long.valueOf(deviceKeyCounter++);
-                }
-                device = allocateDevice(deviceKey, entity, entityClass);
-
-                // Add the new device to the primary map with a simple put
-                deviceMap.put(deviceKey, device);
-
-                // update indices
-                if (!updateIndices(device, deviceKey)) {
-                    if (deleteQueue == null)
-                        deleteQueue = new ArrayList<Long>();
-                    deleteQueue.add(deviceKey);
-                    continue;
-                }
-
-                updateSecondaryIndices(entity, entityClass, deviceKey);
-
-                // We need to count and log here. If we log earlier we could
-                // hit a concurrent modification and restart the dev creation
-                // and potentially count the device twice.
-                // debugCounters.updateCounter(CNT_NEW_DEVICE);
-                if (logger.isDebugEnabled()) {
-                    logger.debug(
-                            "New device created: {} deviceKey={}, entity={}",
-                            new Object[] { device, deviceKey, entity });
-                }
-                // generate new device update
-                deviceUpdates = updateUpdates(deviceUpdates, new DeviceUpdate(
-                        device, ADD, null));
-
-                break;
-            }
-            // if it gets here, we have a pre-existing Device for this Entity
-            if (!isEntityAllowed(entity, device.getEntityClass())) {
-                // debugCounters.updateCounter(CNT_PACKET_NOT_ALLOWED);
-                if (logger.isDebugEnabled()) {
-                    logger.info("PacketIn is not allowed {} {}", device
-                            .getEntityClass().getName(), entity);
-                }
-                return null;
-            }
-            // If this is not an attachment point port we don't learn the new
-            // entity
-            // and don't update indexes. But we do allow the device to continue
-            // up
-            // the chain.
-            if (entity.hasSwitchPort()
-                    && !isValidAttachmentPoint(entity.getPort())) {
-                // debugCounters.updateCounter(CNT_PACKET_ON_INTERNAL_PORT_FOR_KNOWN_DEVICE);
-                break;
-            }
-            int entityindex = -1;
-            if ((entityindex = device.entityIndex(entity)) >= 0) {
-                // Entity already exists
-                // update timestamp on the found entity
-                Date lastSeen = entity.getLastSeenTimestamp();
-                if (lastSeen == null) {
-                    lastSeen = new Date();
-                    entity.setLastSeenTimestamp(lastSeen);
-                }
-                device.entities[entityindex].setLastSeenTimestamp(lastSeen);
-                // we break the loop after checking for changes to the AP
-            } else {
-                // New entity for this device
-                // compute the insertion point for the entity.
-                // see Arrays.binarySearch()
-                entityindex = -(entityindex + 1);
-                Device newDevice = allocateDevice(device, entity, entityindex);
-
-                // generate updates
-                EnumSet<DeviceField> changedFields = findChangedFields(device,
-                        entity);
-
-                // update the device map with a replace call
-                boolean res = deviceMap.replace(deviceKey, device, newDevice);
-                // If replace returns false, restart the process from the
-                // beginning (this implies another thread concurrently
-                // modified this Device).
-                if (!res)
-                    continue;
-                oldDevice = device;
-                device = newDevice;
-                // update indices
-                if (!updateIndices(device, deviceKey)) {
-                    continue;
-                }
-                updateSecondaryIndices(entity, device.getEntityClass(),
-                        deviceKey);
-
-                // We need to count here after all the possible "continue"
-                // statements in this branch
-                // debugCounters.updateCounter(CNT_NEW_ENTITY);
-                if (changedFields.size() > 0) {
-                    // debugCounters.updateCounter(CNT_DEVICE_CHANGED);
-                    deviceUpdates = updateUpdates(deviceUpdates,
-                            new DeviceUpdate(newDevice, CHANGE, changedFields));
-                }
-                // we break the loop after checking for changed AP
-            }
-            // Update attachment point (will only be hit if the device
-            // already existed and no concurrent modification)
-            if (entity.hasSwitchPort()) {
-                boolean moved = device.updateAttachmentPoint(entity.getPort(),
-                        entity.getLastSeenTimestamp().getTime());
-                // TODO: use update mechanism instead of sending the
-                // notification directly
-                if (moved) {
-                    // we count device moved events in
-                    // sendDeviceMovedNotification()
-                    sendDeviceMovedNotification(device, oldDevice);
-                    if (logger.isTraceEnabled()) {
-                        logger.trace("Device moved: attachment points {},"
-                                + "entities {}", device.attachmentPoints,
-                                device.entities);
-                    }
-                } else {
-                    if (logger.isTraceEnabled()) {
-                        logger.trace("Device attachment point updated: "
-                                + "attachment points {}," + "entities {}",
-                                device.attachmentPoints, device.entities);
-                    }
-                }
-            }
-            break;
-        }
-
-        if (deleteQueue != null) {
-            for (Long l : deleteQueue) {
-                Device dev = deviceMap.get(l);
-                this.deleteDevice(dev);
-            }
-        }
-
-        processUpdates(deviceUpdates);
-        // deviceSyncManager.storeDeviceThrottled(device);
-
-        return device;
-    }
-
-    protected boolean isEntityAllowed(Entity entity, IEntityClass entityClass) {
-        return true;
-    }
-
-    protected EnumSet<DeviceField> findChangedFields(Device device,
-            Entity newEntity) {
-        EnumSet<DeviceField> changedFields = EnumSet.of(DeviceField.IPV4,
-                DeviceField.VLAN, DeviceField.SWITCHPORT);
-
-        if (newEntity.getIpv4Address() == null)
-            changedFields.remove(DeviceField.IPV4);
-        if (newEntity.getVlan() == null)
-            changedFields.remove(DeviceField.VLAN);
-        if (newEntity.getPort() == null)
-            changedFields.remove(DeviceField.SWITCHPORT);
-
-        if (changedFields.size() == 0)
-            return changedFields;
-
-        for (Entity entity : device.getEntities()) {
-            if (newEntity.getIpv4Address() == null
-                    || (entity.getIpv4Address() != null && entity
-                            .getIpv4Address()
-                            .equals(newEntity.getIpv4Address())))
-                changedFields.remove(DeviceField.IPV4);
-            if (newEntity.getVlan() == null
-                    || (entity.getVlan() != null && entity.getVlan().equals(
-                            newEntity.getVlan())))
-                changedFields.remove(DeviceField.VLAN);
-            if (newEntity.getPort() == null
-                    || (entity.getPort() != null && entity.getPort().equals(
-                            newEntity.getPort())))
-                changedFields.remove(DeviceField.SWITCHPORT);
-        }
-
-        return changedFields;
-    }
-
-    /**
-     * Send update notifications to listeners
-     *
-     * @param updates
-     *            the updates to process.
-     */
-    protected void processUpdates(Queue<DeviceUpdate> updates) {
-        if (updates == null)
-            return;
-        DeviceUpdate update = null;
-        while (null != (update = updates.poll())) {
-            if (logger.isTraceEnabled()) {
-                logger.trace("Dispatching device update: {}", update);
-            }
-            // if (update.change == DeviceUpdate.Change.DELETE)
-            // deviceSyncManager.removeDevice(update.device);
-            // else
-            // deviceSyncManager.storeDevice(update.device);
-            List<IDeviceListener> listeners = deviceListeners
-                    .getOrderedListeners();
-            notifyListeners(listeners, update);
-        }
-    }
-
-    protected void notifyListeners(List<IDeviceListener> listeners,
-            DeviceUpdate update) {
-        // Topology update is for some reason outside of listeners registry
-        // logic
-        Entity[] ents = update.device.getEntities();
-        Entity e = ents[ents.length - 1];
-
-        NodeConnector p = e.getPort();
-        Node node = p.getNode();
-        Host h = null;
-        try {
-
-            byte[] mac = NetUtils.longToByteArray6(e.getMacAddress());
-            DataLinkAddress dla = new EthernetAddress(
-                    mac);
-            e.getIpv4Address();
-            InetAddress.getAllByName(e.getIpv4Address().toString());
-            h = new org.opendaylight.controller.sal.core.Host(dla,
-                    InetAddress.getByName(e.getIpv4Address().toString()));
-        } catch (ConstructionException ce) {
-            p = null;
-            h = null;
-        } catch (UnknownHostException ue) {
-            p = null;
-            h = null;
-        }
-
-        if (topology != null && p != null && h != null) {
-            if (update.change.equals(DeviceUpdate.Change.ADD)) {
-                Tier tier = new Tier(1);
-                switchManager.setNodeProp(node, tier);
-                topology.updateHostLink(p, h, UpdateType.ADDED, null);
-            } else {
-                // No need to reset the tiering if no other hosts are currently
-                // connected
-                // If this switch was discovered to be an access switch, it
-                // still is even if the host is down
-                Tier tier = new Tier(0);
-                switchManager.setNodeProp(node, tier);
-                topology.updateHostLink(p, h, UpdateType.REMOVED, null);
-            }
-        }
-
-        if (listeners == null && newHostNotify.isEmpty()) {
-            return;
-        }
-        /**
-         * TODO: IfNewHostNotify is needed for current controller API. Adding
-         * logic so that existing apps (like SimpleForwardingManager) work.
-         * IDeviceListener adds additional methods and uses IListener's callback
-         * ordering. The two interfaces need to be merged.
-         */
-
-        for (IfNewHostNotify notify : newHostNotify) {
-            switch (update.change) {
-            case ADD:
-                notify.notifyHTClient(update.device.toHostNodeConnector());
-                break;
-            case DELETE:
-                notify.notifyHTClientHostRemoved(update.device
-                        .toHostNodeConnector());
-                break;
-            case CHANGE:
-            }
-        }
-
-        /**
-         * TODO: Remove this section as IDeviceListener functionality gets
-         * merged with IfNewHostNotify
-         */
-        for (IDeviceListener listener : listeners) {
-            switch (update.change) {
-            case ADD:
-                listener.deviceAdded(update.device);
-                break;
-            case DELETE:
-                listener.deviceRemoved(update.device);
-                break;
-            case CHANGE:
-                for (DeviceField field : update.fieldsChanged) {
-                    switch (field) {
-                    case IPV4:
-                        listener.deviceIPV4AddrChanged(update.device);
-                        break;
-                    case SWITCHPORT:
-                        // listener.deviceMoved(update.device);
-                        break;
-                    case VLAN:
-                        listener.deviceVlanChanged(update.device);
-                        break;
-                    default:
-                        logger.debug("Unknown device field changed {}",
-                                update.fieldsChanged.toString());
-                        break;
-                    }
-                }
-                break;
-            }
-        }
-    }
-
-    /**
-     * Check if the entity e has all the keyFields set. Returns false if not
-     *
-     * @param e
-     *            entity to check
-     * @param keyFields
-     *            the key fields to check e against
-     * @return
-     */
-    protected boolean allKeyFieldsPresent(Entity e,
-            EnumSet<DeviceField> keyFields) {
-        for (DeviceField f : keyFields) {
-            switch (f) {
-            case MAC:
-                // MAC address is always present
-                break;
-            case IPV4:
-                if (e.getIpv4Address() == null)
-                    return false;
-                break;
-            case SWITCHPORT:
-                if (e.getPort() == null)
-                    return false;
-                break;
-            case VLAN:
-                // FIXME: vlan==null is ambiguous: it can mean: not present
-                // or untagged
-                // if (e.vlan == null) return false;
-                break;
-            default:
-                // we should never get here. unless somebody extended
-                // DeviceFields
-                throw new IllegalStateException();
-            }
-        }
-        return true;
-    }
-
-    private LinkedList<DeviceUpdate> updateUpdates(
-            LinkedList<DeviceUpdate> list, DeviceUpdate update) {
-        if (update == null)
-            return list;
-        if (list == null)
-            list = new LinkedList<DeviceUpdate>();
-        list.add(update);
-
-        return list;
-    }
-
-    /**
-     * Get the secondary index for a class. Will return null if the secondary
-     * index was created concurrently in another thread.
-     *
-     * @param clazz
-     *            the class for the index
-     * @return
-     */
-    private ClassState getClassState(IEntityClass clazz) {
-        ClassState classState = classStateMap.get(clazz.getName());
-        if (classState != null)
-            return classState;
-
-        classState = new ClassState(clazz);
-        ClassState r = classStateMap.putIfAbsent(clazz.getName(), classState);
-        if (r != null) {
-            // concurrent add
-            return r;
-        }
-        return classState;
-    }
-
-    /**
-     * Update both the primary and class indices for the provided device. If the
-     * update fails because of an concurrent update, will return false.
-     *
-     * @param device
-     *            the device to update
-     * @param deviceKey
-     *            the device key for the device
-     * @return true if the update succeeded, false otherwise.
-     */
-    private boolean updateIndices(Device device, Long deviceKey) {
-        if (!primaryIndex.updateIndex(device, deviceKey)) {
-            return false;
-        }
-        IEntityClass entityClass = device.getEntityClass();
-        ClassState classState = getClassState(entityClass);
-
-        if (classState.classIndex != null) {
-            if (!classState.classIndex.updateIndex(device, deviceKey))
-                return false;
-        }
-        return true;
-    }
-
-    /**
-     * Update the secondary indices for the given entity and associated entity
-     * classes
-     *
-     * @param entity
-     *            the entity to update
-     * @param entityClass
-     *            the entity class for the entity
-     * @param deviceKey
-     *            the device key to set up
-     */
-    private void updateSecondaryIndices(Entity entity,
-            IEntityClass entityClass, Long deviceKey) {
-        for (DeviceIndex index : secondaryIndexMap.values()) {
-            index.updateIndex(entity, deviceKey);
-        }
-        ClassState state = getClassState(entityClass);
-        for (DeviceIndex index : state.secondaryIndexMap.values()) {
-            index.updateIndex(entity, deviceKey);
-        }
-    }
-
-    /**
-     * Clean up expired entities/devices
-     */
-    protected void cleanupEntities() {
-        // debugCounters.updateCounter(CNT_CLEANUP_ENTITIES_RUNS);
-
-        Calendar c = Calendar.getInstance();
-        c.add(Calendar.MILLISECOND, -ENTITY_TIMEOUT);
-        Date cutoff = c.getTime();
-
-        ArrayList<Entity> toRemove = new ArrayList<Entity>();
-        ArrayList<Entity> toKeep = new ArrayList<Entity>();
-
-        Iterator<Device> diter = deviceMap.values().iterator();
-        LinkedList<DeviceUpdate> deviceUpdates = new LinkedList<DeviceUpdate>();
-
-        while (diter.hasNext()) {
-            Device d = diter.next();
-
-            while (true) {
-                deviceUpdates.clear();
-                toRemove.clear();
-                toKeep.clear();
-                for (Entity e : d.getEntities()) {
-                    if (e.getLastSeenTimestamp() != null
-                            && 0 > e.getLastSeenTimestamp().compareTo(cutoff)) {
-                        // individual entity needs to be removed
-                        toRemove.add(e);
-                    } else {
-                        toKeep.add(e);
-                    }
-                }
-                if (toRemove.size() == 0) {
-                    break;
-                }
-
-                // debugCounters.updateCounter(CNT_ENTITY_REMOVED_TIMEOUT);
-                for (Entity e : toRemove) {
-                    removeEntity(e, d.getEntityClass(), d.getDeviceKey(),
-                            toKeep);
-                }
-
-                if (toKeep.size() > 0) {
-                    Device newDevice = allocateDevice(d.getDeviceKey(),
-                            d.getDHCPClientName(), d.oldAPs,
-                            d.attachmentPoints, toKeep, d.getEntityClass());
-
-                    EnumSet<DeviceField> changedFields = EnumSet
-                            .noneOf(DeviceField.class);
-                    for (Entity e : toRemove) {
-                        changedFields.addAll(findChangedFields(newDevice, e));
-                    }
-                    DeviceUpdate update = null;
-                    if (changedFields.size() > 0) {
-                        update = new DeviceUpdate(d, CHANGE, changedFields);
-                    }
-
-                    if (!deviceMap.replace(newDevice.getDeviceKey(), d,
-                            newDevice)) {
-                        // concurrent modification; try again
-                        // need to use device that is the map now for the next
-                        // iteration
-                        d = deviceMap.get(d.getDeviceKey());
-                        if (null != d)
-                            continue;
-                    }
-                    if (update != null) {
-                        // need to count after all possibly continue stmts in
-                        // this branch
-                        // debugCounters.updateCounter(CNT_DEVICE_CHANGED);
-                        deviceUpdates.add(update);
-                    }
-                } else {
-                    DeviceUpdate update = new DeviceUpdate(d, DELETE, null);
-                    if (!deviceMap.remove(d.getDeviceKey(), d)) {
-                        // concurrent modification; try again
-                        // need to use device that is the map now for the next
-                        // iteration
-                        d = deviceMap.get(d.getDeviceKey());
-                        if (null != d)
-                            continue;
-                        // debugCounters.updateCounter(CNT_DEVICE_DELETED);
-                    }
-                    deviceUpdates.add(update);
-                }
-                processUpdates(deviceUpdates);
-                break;
-            }
-        }
-    }
-
-    protected void removeEntity(Entity removed, IEntityClass entityClass,
-            Long deviceKey, Collection<Entity> others) {
-        // Don't count in this method. This method CAN BE called to clean-up
-        // after concurrent device adds/updates and thus counting here
-        // is misleading
-        for (DeviceIndex index : secondaryIndexMap.values()) {
-            index.removeEntityIfNeeded(removed, deviceKey, others);
-        }
-        ClassState classState = getClassState(entityClass);
-        for (DeviceIndex index : classState.secondaryIndexMap.values()) {
-            index.removeEntityIfNeeded(removed, deviceKey, others);
-        }
-
-        primaryIndex.removeEntityIfNeeded(removed, deviceKey, others);
-
-        if (classState.classIndex != null) {
-            classState.classIndex.removeEntityIfNeeded(removed, deviceKey,
-                    others);
-        }
-    }
-
-    /**
-     * method to delete a given device, remove all entities first and then
-     * finally delete the device itself.
-     *
-     * @param device
-     */
-    protected void deleteDevice(Device device) {
-        // Don't count in this method. This method CAN BE called to clean-up
-        // after concurrent device adds/updates and thus counting here
-        // is misleading
-        ArrayList<Entity> emptyToKeep = new ArrayList<Entity>();
-        for (Entity entity : device.getEntities()) {
-            this.removeEntity(entity, device.getEntityClass(),
-                    device.getDeviceKey(), emptyToKeep);
-        }
-        if (!deviceMap.remove(device.getDeviceKey(), device)) {
-            if (logger.isDebugEnabled())
-                logger.debug("device map does not have this device -"
-                        + device.toString());
-        }
-    }
-
-    private EnumSet<DeviceField> getEntityKeys(Long macAddress, Short vlan,
-            Integer ipv4Address, NodeConnector port) {
-        // FIXME: vlan==null is a valid search. Need to handle this
-        // case correctly. Note that the code will still work correctly.
-        // But we might do a full device search instead of using an index.
-        EnumSet<DeviceField> keys = EnumSet.noneOf(DeviceField.class);
-        if (macAddress != null)
-            keys.add(DeviceField.MAC);
-        if (vlan != null)
-            keys.add(DeviceField.VLAN);
-        if (ipv4Address != null)
-            keys.add(DeviceField.IPV4);
-        if (port != null)
-            keys.add(DeviceField.SWITCHPORT);
-        return keys;
-    }
-
-    protected Iterator<Device> queryClassByEntity(IEntityClass clazz,
-            EnumSet<DeviceField> keyFields, Entity entity) {
-        ClassState classState = getClassState(clazz);
-        DeviceIndex index = classState.secondaryIndexMap.get(keyFields);
-        if (index == null)
-            return Collections.<Device> emptySet().iterator();
-        return new DeviceIndexInterator(this, index.queryByEntity(entity));
-    }
-
-    protected Device allocateDevice(Long deviceKey, Entity entity,
-            IEntityClass entityClass) {
-        return new Device(this, deviceKey, entity, entityClass);
-    }
-
-    // TODO: FIX THIS.
-    protected Device allocateDevice(Long deviceKey, String dhcpClientName,
-            List<AttachmentPoint> aps, List<AttachmentPoint> trueAPs,
-            Collection<Entity> entities, IEntityClass entityClass) {
-        return new Device(this, deviceKey, dhcpClientName, aps, trueAPs,
-                entities, entityClass);
-    }
-
-    protected Device allocateDevice(Device device, Entity entity,
-            int insertionpoint) {
-        return new Device(device, entity, insertionpoint);
-    }
-
-    // not used
-    protected Device allocateDevice(Device device, Set<Entity> entities) {
-        List<AttachmentPoint> newPossibleAPs = new ArrayList<AttachmentPoint>();
-        List<AttachmentPoint> newAPs = new ArrayList<AttachmentPoint>();
-        for (Entity entity : entities) {
-            if (entity.getPort() != null) {
-                AttachmentPoint aP = new AttachmentPoint(entity.getPort(), 0);
-                newPossibleAPs.add(aP);
-            }
-        }
-        if (device.attachmentPoints != null) {
-            for (AttachmentPoint oldAP : device.attachmentPoints) {
-                if (newPossibleAPs.contains(oldAP)) {
-                    newAPs.add(oldAP);
-                }
-            }
-        }
-        if (newAPs.isEmpty())
-            newAPs = null;
-        Device d = new Device(this, device.getDeviceKey(),
-                device.getDHCPClientName(), newAPs, null, entities,
-                device.getEntityClass());
-        d.updateAttachmentPoint();
-        return d;
-    }
-
-    // *********************
-    // ITopologyManagerAware
-    // *********************
-
-    @Override
-    public void edgeUpdate(List<TopoEdgeUpdate> topoedgeupdateList) {
-        Iterator<Device> diter = deviceMap.values().iterator();
-
-        while (diter.hasNext()) {
-            Device d = diter.next();
-            if (d.updateAttachmentPoint()) {
-                if (logger.isDebugEnabled()) {
-                    logger.debug("Attachment point changed for device: {}", d);
-                }
-                sendDeviceMovedNotification(d);
-            }
-        }
-    }
-
-    @Override
-    public void edgeOverUtilized(Edge edge) {
-        // nothing to do
-    }
-
-    @Override
-    public void edgeUtilBackToNormal(Edge edge) {
-        // nothing to do
-    }
-
-    // *********************
-    // IEntityClassListener
-    // *********************
-
-    @Override
-    public void entityClassChanged(Set<String> entityClassNames) {
-        /*
-         * iterate through the devices, reclassify the devices that belong to
-         * these entity class names
-         */
-        Iterator<Device> diter = deviceMap.values().iterator();
-        while (diter.hasNext()) {
-            Device d = diter.next();
-            if (d.getEntityClass() == null
-                    || entityClassNames.contains(d.getEntityClass().getName()))
-                reclassifyDevice(d);
-        }
-    }
-
-    // *************
-    // Local methods
-    // *************
-    /**
-     * Send update notifications to listeners
-     *
-     * @param updates
-     *            the updates to process.
-     */
-    protected void sendDeviceMovedNotification(Device d) {
-        // debugCounters.updateCounter(CNT_DEVICE_MOVED);
-        // deviceSyncManager.storeDevice(d);
-        List<IDeviceListener> listeners = deviceListeners.getOrderedListeners();
-        if (listeners != null) {
-            for (IDeviceListener listener : listeners) {
-                listener.deviceMoved(d);
-            }
-        }
-    }
-
-    /**
-     * Send update notifications to listeners. IfNewHostNotify listeners need to
-     * remove old device and add new device.
-     *
-     * @param device
-     * @param oldDevice
-     */
-    protected void sendDeviceMovedNotification(Device device, Device oldDevice) {
-        for (IfNewHostNotify notify : newHostNotify) {
-            notify.notifyHTClientHostRemoved(oldDevice.toHostNodeConnector());
-            notify.notifyHTClient(device.toHostNodeConnector());
-        }
-        sendDeviceMovedNotification(device);
-    }
-
-    /**
-     * this method will reclassify and reconcile a device - possibilities are -
-     * create new device(s), remove entities from this device. If the device
-     * entity class did not change then it returns false else true.
-     *
-     * @param device
-     */
-    protected boolean reclassifyDevice(Device device) {
-        // first classify all entities of this device
-        if (device == null) {
-            logger.debug("In reclassify for null device");
-            return false;
-        }
-        boolean needToReclassify = false;
-        for (Entity entity : device.entities) {
-            IEntityClass entityClass = this.entityClassifier
-                    .classifyEntity(entity);
-            if (entityClass == null || device.getEntityClass() == null) {
-                needToReclassify = true;
-                break;
-            }
-            if (!entityClass.getName()
-                    .equals(device.getEntityClass().getName())) {
-                needToReclassify = true;
-                break;
-            }
-        }
-        if (needToReclassify == false) {
-            return false;
-        }
-
-        // debugCounters.updateCounter(CNT_DEVICE_RECLASSIFY_DELETE);
-        LinkedList<DeviceUpdate> deviceUpdates = new LinkedList<DeviceUpdate>();
-        // delete this device and then re-learn all the entities
-        this.deleteDevice(device);
-        deviceUpdates.add(new DeviceUpdate(device, DeviceUpdate.Change.DELETE,
-                null));
-        if (!deviceUpdates.isEmpty())
-            processUpdates(deviceUpdates);
-        for (Entity entity : device.entities) {
-            this.learnDeviceByEntity(entity);
-        }
-        return true;
-    }
-
-
-    private long toLong(byte[] address) {
-        long mac = 0;
-        for (int i = 0; i < 6; i++) {
-            long t = (address[i] & 0xffL) << ((5 - i) * 8);
-            mac |= t;
-        }
-        return mac;
-    }
-
-     /**
-     * Accepts an IPv4 address in a byte array and returns the corresponding
-     * 32-bit integer value.
-     *
-     * @param ipAddress
-     * @return
-     */
-    private static int toIPv4Address(byte[] ipAddress) {
-        int ip = 0;
-        for (int i = 0; i < 4; i++) {
-            int t = (ipAddress[i] & 0xff) << ((3 - i) * 8);
-            ip |= t;
-        }
-        return ip;
-    }
-
-    private void registerDeviceManagerDebugCounters() {
-        /*
-         * XXX Missing functionality if (debugCounters == null) {
-         * logger.error("Debug Counter Service not found."); debugCounters = new
-         * NullDebugCounter(); return; }
-         * debugCounters.registerCounter(CNT_INCOMING,
-         * "All incoming packets seen by this module",
-         * CounterType.ALWAYS_COUNT);
-         * debugCounters.registerCounter(CNT_RECONCILE_REQUEST,
-         * "Number of flows that have been received for reconciliation by " +
-         * "this module", CounterType.ALWAYS_COUNT);
-         * debugCounters.registerCounter(CNT_RECONCILE_NO_SOURCE,
-         * "Number of flow reconcile events that failed because no source " +
-         * "device could be identified", CounterType.WARN); // is this really a
-         * warning debugCounters.registerCounter(CNT_RECONCILE_NO_DEST,
-         * "Number of flow reconcile events that failed because no " +
-         * "destination device could be identified", CounterType.WARN); // is
-         * this really a warning
-         * debugCounters.registerCounter(CNT_BROADCAST_SOURCE,
-         * "Number of packetIns that were discarded because the source " +
-         * "MAC was broadcast or multicast", CounterType.WARN);
-         * debugCounters.registerCounter(CNT_NO_SOURCE,
-         * "Number of packetIns that were discarded because the " +
-         * "could not identify a source device. This can happen if a " +
-         * "packet is not allowed, appears on an illegal port, does not " +
-         * "have a valid address space, etc.", CounterType.WARN);
-         * debugCounters.registerCounter(CNT_NO_DEST,
-         * "Number of packetIns that did not have an associated " +
-         * "destination device. E.g., because the destination MAC is " +
-         * "broadcast/multicast or is not yet known to the controller.",
-         * CounterType.ALWAYS_COUNT);
-         * debugCounters.registerCounter(CNT_DHCP_CLIENT_NAME_SNOOPED,
-         * "Number of times a DHCP client name was snooped from a " +
-         * "packetIn.", CounterType.ALWAYS_COUNT);
-         * debugCounters.registerCounter(CNT_DEVICE_ON_INTERAL_PORT_NOT_LEARNED,
-         * "Number of times packetIn was received on an internal port and" +
-         * "no source device is known for the source MAC. The packetIn is " +
-         * "discarded.", CounterType.WARN);
-         * debugCounters.registerCounter(CNT_PACKET_NOT_ALLOWED,
-         * "Number of times a packetIn was not allowed due to spoofing " +
-         * "protection configuration.", CounterType.WARN); // is this really a
-         * warning? debugCounters.registerCounter(CNT_NEW_DEVICE,
-         * "Number of times a new device was learned",
-         * CounterType.ALWAYS_COUNT); debugCounters.registerCounter(
-         * CNT_PACKET_ON_INTERNAL_PORT_FOR_KNOWN_DEVICE,
-         * "Number of times a packetIn was received on an internal port " +
-         * "for a known device.", CounterType.ALWAYS_COUNT);
-         * debugCounters.registerCounter(CNT_NEW_ENTITY,
-         * "Number of times a new entity was learned for an existing device",
-         * CounterType.ALWAYS_COUNT);
-         * debugCounters.registerCounter(CNT_DEVICE_CHANGED,
-         * "Number of times device properties have changed",
-         * CounterType.ALWAYS_COUNT);
-         * debugCounters.registerCounter(CNT_DEVICE_MOVED,
-         * "Number of times devices have moved", CounterType.ALWAYS_COUNT);
-         * debugCounters.registerCounter(CNT_CLEANUP_ENTITIES_RUNS,
-         * "Number of times the entity cleanup task has been run",
-         * CounterType.ALWAYS_COUNT);
-         * debugCounters.registerCounter(CNT_ENTITY_REMOVED_TIMEOUT,
-         * "Number of times entities have been removed due to timeout " +
-         * "(entity has been inactive for " + ENTITY_TIMEOUT/1000 + "s)",
-         * CounterType.ALWAYS_COUNT);
-         * debugCounters.registerCounter(CNT_DEVICE_DELETED,
-         * "Number of devices that have been removed due to inactivity",
-         * CounterType.ALWAYS_COUNT);
-         * debugCounters.registerCounter(CNT_DEVICE_RECLASSIFY_DELETE,
-         * "Number of devices that required reclassification and have been " +
-         * "temporarily delete for reclassification", CounterType.ALWAYS_COUNT);
-         * debugCounters.registerCounter(CNT_DEVICE_STORED,
-         * "Number of device entries written or updated to the sync store",
-         * CounterType.ALWAYS_COUNT);
-         * debugCounters.registerCounter(CNT_DEVICE_STORE_THROTTLED,
-         * "Number of times a device update to the sync store was " +
-         * "requested but not performed because the same device entities " +
-         * "have recently been updated already", CounterType.ALWAYS_COUNT);
-         * debugCounters.registerCounter(CNT_DEVICE_REMOVED_FROM_STORE,
-         * "Number of devices that were removed from the sync store " +
-         * "because the local controller removed the device due to " +
-         * "inactivity", CounterType.ALWAYS_COUNT);
-         * debugCounters.registerCounter(CNT_SYNC_EXCEPTION,
-         * "Number of times an operation on the sync store resulted in " +
-         * "sync exception", CounterType.WARN); // it this an error?
-         * debugCounters.registerCounter(CNT_DEVICES_FROM_STORE,
-         * "Number of devices that were read from the sync store after " +
-         * "the local controller transitioned from SLAVE to MASTER",
-         * CounterType.ALWAYS_COUNT);
-         * debugCounters.registerCounter(CNT_CONSOLIDATE_STORE_RUNS,
-         * "Number of times the task to consolidate entries in the " +
-         * "store witch live known devices has been run",
-         * CounterType.ALWAYS_COUNT);
-         * debugCounters.registerCounter(CNT_CONSOLIDATE_STORE_DEVICES_REMOVED,
-         * "Number of times a device has been removed from the sync " +
-         * "store because no corresponding live device is known. " +
-         * "This indicates a remote controller still writing device " +
-         * "entries despite the local controller being MASTER or an " +
-         * "incosistent store update from the local controller.",
-         * CounterType.WARN);
-         * debugCounters.registerCounter(CNT_TRANSITION_TO_MASTER,
-         * "Number of times this controller has transitioned from SLAVE " +
-         * "to MASTER role. Will be 0 or 1.", CounterType.ALWAYS_COUNT);
-         */
-    }
-
-    @Override
-    public HostNodeConnector hostFind(InetAddress networkAddress) {
-        // TODO Auto-generated method stub
-        return null;
-    }
-
-    @Override
-    public HostNodeConnector hostQuery(InetAddress networkAddress) {
-        // TODO Auto-generated method stub
-        return null;
-    }
-
-    @Override
-    public Future<HostNodeConnector> discoverHost(InetAddress networkAddress) {
-        // TODO Auto-generated method stub
-        return null;
-    }
-
-    @Override
-    public List<List<String>> getHostNetworkHierarchy(InetAddress hostAddress) {
-        // TODO Auto-generated method stub
-        return null;
-    }
-
-    @Override
-    public Set<HostNodeConnector> getAllHosts() {
-        Collection<Device> devices = Collections
-                .unmodifiableCollection(deviceMap.values());
-        Iterator<Device> i = devices.iterator();
-        Set<HostNodeConnector> nc = new HashSet<HostNodeConnector>();
-        while (i.hasNext()) {
-            Device device = i.next();
-            nc.add(device.toHostNodeConnector());
-        }
-        return nc;
-    }
-
-    @Override
-    public Set<HostNodeConnector> getActiveStaticHosts() {
-        Collection<Device> devices = Collections
-                .unmodifiableCollection(deviceMap.values());
-        Iterator<Device> i = devices.iterator();
-        Set<HostNodeConnector> nc = new HashSet<HostNodeConnector>();
-        while (i.hasNext()) {
-            Device device = i.next();
-            if (device.isStaticHost())
-                nc.add(device.toHostNodeConnector());
-        }
-        return nc;
-    }
-
-    @Override
-    public Set<HostNodeConnector> getInactiveStaticHosts() {
-        Collection<Entity> devices = Collections
-                .unmodifiableCollection(inactiveStaticDevices.values());
-        Iterator<Entity> i = devices.iterator();
-        Set<HostNodeConnector> nc = new HashSet<HostNodeConnector>();
-        while (i.hasNext()) {
-            Entity ent = i.next();
-                nc.add(ent.toHostNodeConnector());
-
-        }
-        return nc;
-    }
-
-    @Override
-    public Status addStaticHost(String networkAddress, String dataLayerAddress,
-            NodeConnector nc, String vlan) {
-        Long mac = HexEncode.stringToLong(dataLayerAddress);
-        try {
-            InetAddress addr = InetAddress.getByName(networkAddress);
-            int ip = toIPv4Address(addr.getAddress());
-            Entity e = new Entity(mac, Short.valueOf(vlan), ip, nc, new Date());
-
-            if (switchManager.isNodeConnectorEnabled(e.getPort())) {
-                Device d = this.learnDeviceByEntity(e);
-                d.setStaticHost(true);
-            } else {
-                logger.debug(
-                        "Switch or switchport is not up, adding host {} to inactive list",
-                        addr.getHostName());
-                 inactiveStaticDevices.put(e.getPort(), e);
-            }
-            return new Status(StatusCode.SUCCESS);
-        } catch (UnknownHostException e) {
-            return new Status(StatusCode.INTERNALERROR);
-        }
-    }
-
-    @Override
-    public Status removeStaticHost(String networkAddress) {
-        Integer addr;
-        try {
-            addr = toIPv4Address(InetAddress.getByName(networkAddress)
-                    .getAddress());
-        } catch (UnknownHostException e) {
-            return new Status(StatusCode.NOTFOUND, "Host does not exist");
-        }
-        Iterator<Device> di = this.getDeviceIteratorForQuery(null, null, addr,
-                null);
-        List<IDeviceListener> listeners = deviceListeners.getOrderedListeners();
-        while (di.hasNext()) {
-            Device d = di.next();
-            if (d.isStaticHost()) {
-                deleteDevice(d);
-                for (IfNewHostNotify notify : newHostNotify) {
-                    notify.notifyHTClientHostRemoved(d.toHostNodeConnector());
-                }
-                for (IDeviceListener listener : listeners) {
-                    listener.deviceRemoved(d);
-                }
-            }
-        }
-        //go through inactive entites.
-        Set<HostNodeConnector> inactive = this.getInactiveStaticHosts();
-        for(HostNodeConnector nc : inactive){
-            Integer ip =toIPv4Address(nc.getNetworkAddress().getAddress());
-            if(ip.equals(addr)){
-                this.inactiveStaticDevices.remove(nc.getnodeConnector());
-            }
-        }
-
-
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    @Override
-    public void notifyNode(Node node, UpdateType type,
-            Map<String, Property> propMap) {
-        if (node == null)
-            return;
-        List<IDeviceListener> listeners = deviceListeners.getOrderedListeners();
-        switch (type) {
-        case REMOVED:
-            logger.debug("Received removed node {}", node);
-            for (Entry<Long, Device> d : deviceMap.entrySet()) {
-                Device device = d.getValue();
-                HostNodeConnector host = device.toHostNodeConnector();
-                if (host.getnodeconnectorNode().equals(node)) {
-                    logger.debug("Node: {} is down, remove from Hosts_DB", node);
-                    deleteDevice(device);
-                    for (IfNewHostNotify notify : newHostNotify) {
-                        notify.notifyHTClientHostRemoved(host);
-                    }
-                    for (IDeviceListener listener : listeners) {
-                        listener.deviceRemoved(device);
-                    }
-                }
-            }
-            break;
-        default:
-            break;
-        }
-    }
-
-    @Override
-    public void notifyNodeConnector(NodeConnector nodeConnector,
-            UpdateType type, Map<String, Property> propMap) {
-        if (nodeConnector == null)
-            return;
-        List<IDeviceListener> listeners = deviceListeners.getOrderedListeners();
-        boolean up = false;
-        switch (type) {
-        case ADDED:
-            up = true;
-            break;
-        case REMOVED:
-            break;
-        case CHANGED:
-            State state = (State) propMap.get(State.StatePropName);
-            if ((state != null) && (state.getValue() == State.EDGE_UP)) {
-                up = true;
-            }
-            break;
-        default:
-            return;
-        }
-
-        if (up) {
-            logger.debug("handleNodeConnectorStatusUp {}", nodeConnector);
-
-            Entity ent = inactiveStaticDevices.get(nodeConnector);
-            Device device = this.learnDeviceByEntity(ent);
-            if(device!=null){
-                HostNodeConnector host = device.toHostNodeConnector();
-                if (host != null) {
-                    inactiveStaticDevices.remove(nodeConnector);
-                    for (IfNewHostNotify notify : newHostNotify) {
-                        notify.notifyHTClient(host);
-                    }
-                    for (IDeviceListener listener : listeners) {
-                        listener.deviceAdded(device);
-                    }
-                } else {
-                    logger.debug("handleNodeConnectorStatusDown {}", nodeConnector);
-                }
-            }
-        }else{
-                // remove all devices on the node that went down.
-                for (Entry<Long, Device> entry : deviceMap.entrySet()) {
-                    Device device = entry.getValue();
-                    HostNodeConnector host = device.toHostNodeConnector();
-                    if (host.getnodeConnector().equals(nodeConnector)) {
-                        deleteDevice(device);
-                        for (IfNewHostNotify notify : newHostNotify) {
-                            notify.notifyHTClientHostRemoved(host);
-                        }
-                        for (IDeviceListener listener : listeners) {
-                            listener.deviceRemoved(device);
-                        }
-                    }
-                }
-
-            }
-        }
-
-}
diff --git a/opendaylight/adsal/hosttracker_new/implementation/src/main/java/org/opendaylight/controller/hosttracker/internal/DeviceMultiIndex.java b/opendaylight/adsal/hosttracker_new/implementation/src/main/java/org/opendaylight/controller/hosttracker/internal/DeviceMultiIndex.java
deleted file mode 100644 (file)
index 85cb094..0000000
+++ /dev/null
@@ -1,126 +0,0 @@
-/*
- * Copyright (c) 2012 Big Switch Networks, Inc.
- *
- * Licensed under the Eclipse Public License, Version 1.0 (the
- * "License"); you may not use this file except in compliance with the
- * License. You may obtain a copy of the License at
- *
- *      http://www.eclipse.org/legal/epl-v10.html
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
- * implied. See the License for the specific language governing
- * permissions and limitations under the License.
- *
- * This file incorporates work covered by the following copyright and
- * permission notice:
- *
- *    Originally created by David Erickson, Stanford University
- *
- *    Licensed under the Apache License, Version 2.0 (the "License");
- *    you may not use this file except in compliance with the
- *    License. You may obtain a copy of the License at
- *
- *         http://www.apache.org/licenses/LICENSE-2.0
- *
- *    Unless required by applicable law or agreed to in writing,
- *    software distributed under the License is distributed on an "AS
- *    IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
- *    express or implied. See the License for the specific language
- *    governing permissions and limitations under the License.
- */
-
-package org.opendaylight.controller.hosttracker.internal;
-
-import java.util.Collection;
-import java.util.Collections;
-import java.util.EnumSet;
-import java.util.Iterator;
-import java.util.Map;
-import java.util.concurrent.ConcurrentHashMap;
-
-import org.opendaylight.controller.hosttracker.Entity;
-import org.opendaylight.controller.hosttracker.IDeviceService.DeviceField;
-import org.opendaylight.controller.sal.utils.IterableIterator;
-
-/**
- * An index that maps key fields of an entity to device keys, with multiple
- * device keys allowed per entity
- */
-public class DeviceMultiIndex extends DeviceIndex {
-    /**
-     * The index
-     */
-    private ConcurrentHashMap<IndexedEntity, Collection<Long>> index;
-
-    /**
-     * @param keyFields
-     */
-    public DeviceMultiIndex(EnumSet<DeviceField> keyFields) {
-        super(keyFields);
-        index = new ConcurrentHashMap<IndexedEntity, Collection<Long>>();
-    }
-
-    // ***********
-    // DeviceIndex
-    // ***********
-
-    @Override
-    public Iterator<Long> queryByEntity(Entity entity) {
-        IndexedEntity ie = new IndexedEntity(keyFields, entity);
-        Collection<Long> devices = index.get(ie);
-        if (devices != null)
-            return devices.iterator();
-
-        return Collections.<Long> emptySet().iterator();
-    }
-
-    @Override
-    public Iterator<Long> getAll() {
-        Iterator<Collection<Long>> iter = index.values().iterator();
-        return new IterableIterator<Long>(iter);
-    }
-
-    @Override
-    public boolean updateIndex(Device device, Long deviceKey) {
-        for (Entity e : device.entities) {
-            updateIndex(e, deviceKey);
-        }
-        return true;
-    }
-
-    @Override
-    public void updateIndex(Entity entity, Long deviceKey) {
-        Collection<Long> devices = null;
-
-        IndexedEntity ie = new IndexedEntity(keyFields, entity);
-        if (!ie.hasNonNullKeys())
-            return;
-
-        devices = index.get(ie);
-        if (devices == null) {
-            Map<Long, Boolean> chm = new ConcurrentHashMap<Long, Boolean>();
-            devices = Collections.newSetFromMap(chm);
-            Collection<Long> r = index.putIfAbsent(ie, devices);
-            if (r != null)
-                devices = r;
-        }
-
-        devices.add(deviceKey);
-    }
-
-    @Override
-    public void removeEntity(Entity entity) {
-        IndexedEntity ie = new IndexedEntity(keyFields, entity);
-        index.remove(ie);
-    }
-
-    @Override
-    public void removeEntity(Entity entity, Long deviceKey) {
-        IndexedEntity ie = new IndexedEntity(keyFields, entity);
-        Collection<Long> devices = index.get(ie);
-        if (devices != null)
-            devices.remove(deviceKey);
-    }
-}
diff --git a/opendaylight/adsal/hosttracker_new/implementation/src/main/java/org/opendaylight/controller/hosttracker/internal/DeviceUniqueIndex.java b/opendaylight/adsal/hosttracker_new/implementation/src/main/java/org/opendaylight/controller/hosttracker/internal/DeviceUniqueIndex.java
deleted file mode 100644 (file)
index 6ca0556..0000000
+++ /dev/null
@@ -1,139 +0,0 @@
-/*
- * Copyright (c) 2012 Big Switch Networks, Inc.
- *
- * Licensed under the Eclipse Public License, Version 1.0 (the
- * "License"); you may not use this file except in compliance with the
- * License. You may obtain a copy of the License at
- *
- *      http://www.eclipse.org/legal/epl-v10.html
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
- * implied. See the License for the specific language governing
- * permissions and limitations under the License.
- *
- * This file incorporates work covered by the following copyright and
- * permission notice:
- *
- *    Originally created by David Erickson, Stanford University
- *
- *    Licensed under the Apache License, Version 2.0 (the "License");
- *    you may not use this file except in compliance with the
- *    License. You may obtain a copy of the License at
- *
- *         http://www.apache.org/licenses/LICENSE-2.0
- *
- *    Unless required by applicable law or agreed to in writing,
- *    software distributed under the License is distributed on an "AS
- *    IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
- *    express or implied. See the License for the specific language
- *    governing permissions and limitations under the License.
- */
-
-package org.opendaylight.controller.hosttracker.internal;
-
-import java.util.Collections;
-import java.util.EnumSet;
-import java.util.Iterator;
-import java.util.concurrent.ConcurrentHashMap;
-
-import org.opendaylight.controller.hosttracker.Entity;
-import org.opendaylight.controller.hosttracker.IDeviceService;
-
-/**
- * An index that maps key fields of an entity uniquely to a device key
- */
-public class DeviceUniqueIndex extends DeviceIndex {
-    /**
-     * The index
-     */
-    private final ConcurrentHashMap<IndexedEntity, Long> index;
-
-    /**
-     * Construct a new device index using the provided key fields
-     *
-     * @param keyFields
-     *            the key fields to use
-     */
-    public DeviceUniqueIndex(EnumSet<IDeviceService.DeviceField> keyFields) {
-        super(keyFields);
-        index = new ConcurrentHashMap<IndexedEntity, Long>();
-    }
-
-    // ***********
-    // DeviceIndex
-    // ***********
-
-    @Override
-    public Iterator<Long> queryByEntity(Entity entity) {
-        final Long deviceKey = findByEntity(entity);
-        if (deviceKey != null)
-            return Collections.<Long> singleton(deviceKey).iterator();
-
-        return Collections.<Long> emptySet().iterator();
-    }
-
-    @Override
-    public Iterator<Long> getAll() {
-        return index.values().iterator();
-    }
-
-    @Override
-    public boolean updateIndex(Device device, Long deviceKey) {
-        for (Entity e : device.entities) {
-            IndexedEntity ie = new IndexedEntity(keyFields, e);
-            if (!ie.hasNonNullKeys())
-                continue;
-
-            Long ret = index.putIfAbsent(ie, deviceKey);
-            if (ret != null && !ret.equals(deviceKey)) {
-                // If the return value is non-null, then fail the insert
-                // (this implies that a device using this entity has
-                // already been created in another thread).
-                return false;
-            }
-        }
-        return true;
-    }
-
-    @Override
-    public void updateIndex(Entity entity, Long deviceKey) {
-        IndexedEntity ie = new IndexedEntity(keyFields, entity);
-        if (!ie.hasNonNullKeys())
-            return;
-        index.put(ie, deviceKey);
-    }
-
-    @Override
-    public void removeEntity(Entity entity) {
-        IndexedEntity ie = new IndexedEntity(keyFields, entity);
-        index.remove(ie);
-    }
-
-    @Override
-    public void removeEntity(Entity entity, Long deviceKey) {
-        IndexedEntity ie = new IndexedEntity(keyFields, entity);
-        index.remove(ie, deviceKey);
-    }
-
-    // **************
-    // Public Methods
-    // **************
-
-    /**
-     * Look up a {@link Device} based on the provided {@link Entity}.
-     *
-     * @param entity
-     *            the entity to search for
-     * @return The key for the {@link Device} object if found
-     */
-    public Long findByEntity(Entity entity) {
-        IndexedEntity ie = new IndexedEntity(keyFields, entity);
-        Long deviceKey = index.get(ie);
-        if (deviceKey == null)
-            return null;
-        return deviceKey;
-    }
-
-}
diff --git a/opendaylight/adsal/hosttracker_new/implementation/src/main/java/org/opendaylight/controller/hosttracker/internal/IndexedEntity.java b/opendaylight/adsal/hosttracker_new/implementation/src/main/java/org/opendaylight/controller/hosttracker/internal/IndexedEntity.java
deleted file mode 100644 (file)
index fa9fad8..0000000
+++ /dev/null
@@ -1,172 +0,0 @@
-/*
- * Copyright (c) 2013 Big Switch Networks, Inc.
- *
- * Licensed under the Eclipse Public License, Version 1.0 (the
- * "License"); you may not use this file except in compliance with the
- * License. You may obtain a copy of the License at
- *
- *      http://www.eclipse.org/legal/epl-v10.html
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
- * implied. See the License for the specific language governing
- * permissions and limitations under the License.
- */
-
-package org.opendaylight.controller.hosttracker.internal;
-
-import java.util.EnumSet;
-
-import org.opendaylight.controller.hosttracker.Entity;
-import org.opendaylight.controller.hosttracker.IDeviceService;
-import org.opendaylight.controller.hosttracker.IDeviceService.DeviceField;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * This is a thin wrapper around {@link Entity} that allows overriding the
- * behavior of {@link Object#hashCode()} and {@link Object#equals(Object)} so
- * that the keying behavior in a hash map can be changed dynamically
- *
- * @author readams
- */
-public class IndexedEntity {
-    protected EnumSet<DeviceField> keyFields;
-    protected Entity entity;
-    private int hashCode = 0;
-    protected static Logger logger = LoggerFactory
-            .getLogger(IndexedEntity.class);
-
-    /**
-     * Create a new {@link IndexedEntity} for the given {@link Entity} using the
-     * provided key fields.
-     *
-     * @param keyFields
-     *            The key fields that will be used for computing
-     *            {@link IndexedEntity#hashCode()} and
-     *            {@link IndexedEntity#equals(Object)}
-     * @param entity
-     *            the entity to wrap
-     */
-    public IndexedEntity(EnumSet<DeviceField> keyFields, Entity entity) {
-        super();
-        this.keyFields = keyFields;
-        this.entity = entity;
-    }
-
-    /**
-     * Check whether this entity has non-null values in any of its key fields
-     *
-     * @return true if any key fields have a non-null value
-     */
-    public boolean hasNonNullKeys() {
-        for (DeviceField f : keyFields) {
-            switch (f) {
-            case MAC:
-                return true;
-            case IPV4:
-                if (entity.getIpv4Address() != null)
-                    return true;
-                break;
-            case SWITCHPORT:
-                if (entity.getPort() != null)
-                    return true;
-                break;
-            case VLAN:
-                if (entity.getVlan() != null)
-                    return true;
-                break;
-            }
-        }
-        return false;
-    }
-
-    @Override
-    public int hashCode() {
-
-        if (hashCode != 0) {
-            return hashCode;
-        }
-
-        final int prime = 31;
-        hashCode = 1;
-        for (DeviceField f : keyFields) {
-            switch (f) {
-            case MAC:
-                hashCode = prime
-                        * hashCode
-                        + (int) (entity.getMacAddress() ^ (entity
-                                .getMacAddress() >>> 32));
-                break;
-            case IPV4:
-                hashCode = prime
-                        * hashCode
-                        + ((entity.getIpv4Address() == null) ? 0 : entity
-                                .getIpv4Address().hashCode());
-                break;
-            case SWITCHPORT:
-                hashCode = prime
-                        * hashCode
-                        + ((entity.getPort() == null) ? 0 : entity.getPort()
-                                .hashCode());
-                break;
-            case VLAN:
-                hashCode = prime
-                        * hashCode
-                        + ((entity.getVlan() == null) ? 0 : entity.getVlan()
-                                .hashCode());
-                break;
-            }
-        }
-        return hashCode;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj)
-            return true;
-        if (obj == null)
-            return false;
-        if (getClass() != obj.getClass())
-            return false;
-        IndexedEntity other = (IndexedEntity) obj;
-
-        if (!keyFields.equals(other.keyFields))
-            return false;
-
-        for (IDeviceService.DeviceField f : keyFields) {
-            switch (f) {
-            case MAC:
-                if (entity.getMacAddress() != other.entity.getMacAddress())
-                    return false;
-                break;
-            case IPV4:
-                if (entity.getIpv4Address() == null) {
-                    if (other.entity.getIpv4Address() != null)
-                        return false;
-                } else if (!entity.getIpv4Address().equals(
-                        other.entity.getIpv4Address()))
-                    return false;
-                break;
-            case SWITCHPORT:
-                if (entity.getPort() == null) {
-                    if (other.entity.getPort() != null)
-                        return false;
-                } else if (!entity.getPort().equals(other.entity.getPort()))
-                    return false;
-                break;
-            case VLAN:
-                if (entity.getVlan() == null) {
-                    if (other.entity.getVlan() != null)
-                        return false;
-                } else if (!entity.getVlan().equals(other.entity.getVlan()))
-                    return false;
-                break;
-            }
-        }
-
-        return true;
-    }
-
-}
diff --git a/opendaylight/adsal/hosttracker_new/implementation/src/test/java/org/opendaylight/controller/hosttracker/internal/DeviceManagerImplTest.java b/opendaylight/adsal/hosttracker_new/implementation/src/test/java/org/opendaylight/controller/hosttracker/internal/DeviceManagerImplTest.java
deleted file mode 100644 (file)
index 3bed3a5..0000000
+++ /dev/null
@@ -1,2644 +0,0 @@
-package org.opendaylight.controller.hosttracker.internal;
-
-///*
-// * Copyright (c) 2011,2013 Big Switch Networks, Inc.
-// *
-// * Licensed under the Eclipse Public License, Version 1.0 (the
-// * "License"); you may not use this file except in compliance with the
-// * License. You may obtain a copy of the License at
-// *
-// *      http://www.eclipse.org/legal/epl-v10.html
-// *
-// * Unless required by applicable law or agreed to in writing, software
-// * distributed under the License is distributed on an "AS IS" BASIS,
-// * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
-// * implied. See the License for the specific language governing
-// * permissions and limitations under the License.
-// *
-// * This file incorporates work covered by the following copyright and
-// * permission notice:
-// *
-// *    Originally created by David Erickson, Stanford University
-// *
-// *    Licensed under the Apache License, Version 2.0 (the "License");
-// *    you may not use this file except in compliance with the
-// *    License. You may obtain a copy of the License at
-// *
-// *         http://www.apache.org/licenses/LICENSE-2.0
-// *
-// *    Unless required by applicable law or agreed to in writing,
-// *    software distributed under the License is distributed on an "AS
-// *    IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
-// *    express or implied. See the License for the specific language
-// *    governing permissions and limitations under the License.
-// */
-//
-//package org.opendaylight.controller.hosttracker.internal;
-//
-//import static org.easymock.EasyMock.anyLong;
-//import static org.easymock.EasyMock.anyObject;
-//import static org.easymock.EasyMock.anyShort;
-//import static org.easymock.EasyMock.createMock;
-//import static org.easymock.EasyMock.createNiceMock;
-//import static org.easymock.EasyMock.eq;
-//import static org.easymock.EasyMock.expect;
-//import static org.easymock.EasyMock.expectLastCall;
-//import static org.easymock.EasyMock.isA;
-//import static org.easymock.EasyMock.or;
-//import static org.easymock.EasyMock.replay;
-//import static org.easymock.EasyMock.reset;
-//import static org.easymock.EasyMock.verify;
-//import static org.junit.Assert.*;
-//
-//import java.util.ArrayList;
-//import java.util.Arrays;
-//import java.util.Calendar;
-//import java.util.Collection;
-//import java.util.Collections;
-//import java.util.Date;
-//import java.util.EnumSet;
-//import java.util.HashMap;
-//import java.util.HashSet;
-//import java.util.Iterator;
-//import java.util.List;
-//import java.util.Map;
-//import java.util.Map.Entry;
-//import java.util.Set;
-//import java.util.concurrent.ConcurrentHashMap;
-//
-//import org.junit.Before;
-//import org.junit.Test;
-//
-//import org.slf4j.Logger;
-//import org.slf4j.LoggerFactory;
-//
-//public class DeviceManagerImplTest {
-//
-//    protected static Logger logger =
-//            LoggerFactory.getLogger(DeviceManagerImplTest.class);
-//
-//    protected OFPacketIn packetIn_1, packetIn_2, packetIn_3;
-//    protected IPacket testARPReplyPacket_1, testARPReplyPacket_2,
-//    testARPReplyPacket_3;
-//    protected IPacket testARPReqPacket_1, testARPReqPacket_2;
-//    protected byte[] testARPReplyPacket_1_Srld, testARPReplyPacket_2_Srld;
-//    private MockSyncService syncService;
-//    private IStoreClient<String, DeviceSyncRepresentation> storeClient;
-//
-//    DeviceManagerImpl deviceManager;
-//    MemoryStorageSource storageSource;
-//    FlowReconcileManager flowReconcileMgr;
-//
-//    private IOFSwitch makeSwitchMock(long id) {
-//        IOFSwitch mockSwitch = createMock(IOFSwitch.class);
-//        ImmutablePort port = ImmutablePort.create("p1", (short)1);
-//        expect(mockSwitch.getId()).andReturn(id).anyTimes();
-//        expect(mockSwitch.getStringId())
-//                .andReturn(HexString.toHexString(id, 6)).anyTimes();
-//        expect(mockSwitch.getPort(anyShort()))
-//                .andReturn(port).anyTimes();
-//        return mockSwitch;
-//    }
-//
-//    /*
-//     * return an EasyMock ITopologyService that's setup so that it will
-//     * answer all questions a device or device manager will ask
-//     * (isAttachmentPointPort, etc.) in a way so that every port is a
-//     * non-BD, attachment point port.
-//     * The returned mock is still in record mode
-//     */
-//    private ITopologyService makeMockTopologyAllPortsAp() {
-//        ITopologyService mockTopology = createMock(ITopologyService.class);
-//        mockTopology.isAttachmentPointPort(anyLong(), anyShort());
-//        expectLastCall().andReturn(true).anyTimes();
-//        mockTopology.getL2DomainId(anyLong());
-//        expectLastCall().andReturn(1L).anyTimes();
-//        mockTopology.isBroadcastDomainPort(anyLong(), anyShort());
-//        expectLastCall().andReturn(false).anyTimes();
-//        mockTopology.isConsistent(anyLong(), anyShort(), anyLong(), anyShort());
-//        expectLastCall().andReturn(false).anyTimes();
-//        mockTopology.isInSameBroadcastDomain(anyLong(), anyShort(),
-//                                             anyLong(), anyShort());
-//        expectLastCall().andReturn(false).anyTimes();
-//        return mockTopology;
-//    }
-//
-//    @Override
-//    @Before
-//    public void setUp() throws Exception {
-//        doSetUp(Role.MASTER);
-//    }
-//
-//    public void doSetUp(Role initialRole) throws Exception {
-//        super.setUp();
-//
-//        this.syncService = new MockSyncService();
-//
-//        FloodlightModuleContext fmc = new FloodlightModuleContext();
-//        RestApiServer restApi = new RestApiServer();
-//        MockThreadPoolService tp = new MockThreadPoolService();
-//        ITopologyService topology = createMock(ITopologyService.class);
-//        fmc.addService(IThreadPoolService.class, tp);
-//        mockFloodlightProvider = getMockFloodlightProvider();
-//        mockFloodlightProvider.setRole(initialRole, "");
-//
-//        deviceManager = new DeviceManagerImpl();
-//        flowReconcileMgr = new FlowReconcileManager();
-//        DefaultEntityClassifier entityClassifier = new DefaultEntityClassifier();
-//        fmc.addService(IDeviceService.class, deviceManager);
-//        storageSource = new MemoryStorageSource();
-//        fmc.addService(IStorageSourceService.class, storageSource);
-//        fmc.addService(IFloodlightProviderService.class, mockFloodlightProvider);
-//        fmc.addService(IRestApiService.class, restApi);
-//        fmc.addService(IFlowReconcileService.class, flowReconcileMgr);
-//        fmc.addService(IEntityClassifierService.class, entityClassifier);
-//        fmc.addService(ITopologyService.class, topology);
-//        fmc.addService(ISyncService.class, syncService);
-//        tp.init(fmc);
-//        restApi.init(fmc);
-//        storageSource.init(fmc);
-//        deviceManager.init(fmc);
-//        flowReconcileMgr.init(fmc);
-//        entityClassifier.init(fmc);
-//        syncService.init(fmc);
-//        storageSource.startUp(fmc);
-//        deviceManager.startUp(fmc);
-//        flowReconcileMgr.startUp(fmc);
-//        tp.startUp(fmc);
-//        entityClassifier.startUp(fmc);
-//        syncService.startUp(fmc);
-//
-//        this.storeClient =
-//                this.syncService.getStoreClient(DeviceManagerImpl.DEVICE_SYNC_STORE_NAME,
-//                            String.class, DeviceSyncRepresentation.class);
-//
-//        reset(topology);
-//        topology.addListener(deviceManager);
-//        expectLastCall().anyTimes();
-//        replay(topology);
-//
-//        IOFSwitch mockSwitch1 = makeSwitchMock(1L);
-//        IOFSwitch mockSwitch10 = makeSwitchMock(10L);
-//        IOFSwitch mockSwitch5 = makeSwitchMock(5L);
-//        IOFSwitch mockSwitch50 = makeSwitchMock(50L);
-//        Map<Long, IOFSwitch> switches = new HashMap<Long,IOFSwitch>();
-//        switches.put(1L, mockSwitch1);
-//        switches.put(10L, mockSwitch10);
-//        switches.put(5L, mockSwitch5);
-//        switches.put(50L, mockSwitch50);
-//        mockFloodlightProvider.setSwitches(switches);
-//
-//        replay(mockSwitch1, mockSwitch5, mockSwitch10, mockSwitch50);
-//
-//        // Build our test packet
-//        this.testARPReplyPacket_1 = new Ethernet()
-//        .setSourceMACAddress("00:44:33:22:11:01")
-//        .setDestinationMACAddress("00:11:22:33:44:55")
-//        .setEtherType(Ethernet.TYPE_ARP)
-//        .setVlanID((short)5)
-//        .setPayload(
-//                    new ARP()
-//                    .setHardwareType(ARP.HW_TYPE_ETHERNET)
-//                    .setProtocolType(ARP.PROTO_TYPE_IP)
-//                    .setHardwareAddressLength((byte) 6)
-//                    .setProtocolAddressLength((byte) 4)
-//                    .setOpCode(ARP.OP_REPLY)
-//                    .setSenderHardwareAddress(Ethernet.toMACAddress("00:44:33:22:11:01"))
-//                    .setSenderProtocolAddress(IPv4.toIPv4AddressBytes("192.168.1.1"))
-//                    .setTargetHardwareAddress(Ethernet.toMACAddress("00:11:22:33:44:55"))
-//                    .setTargetProtocolAddress(IPv4.toIPv4AddressBytes("192.168.1.2")));
-//        this.testARPReplyPacket_1_Srld = testARPReplyPacket_1.serialize();
-//
-//        // Another test packet with a different source IP
-//        this.testARPReplyPacket_2 = new Ethernet()
-//        .setSourceMACAddress("00:99:88:77:66:55")
-//        .setDestinationMACAddress("00:11:22:33:44:55")
-//        .setEtherType(Ethernet.TYPE_ARP)
-//        .setVlanID((short)5)
-//        .setPayload(
-//                    new ARP()
-//                    .setHardwareType(ARP.HW_TYPE_ETHERNET)
-//                    .setProtocolType(ARP.PROTO_TYPE_IP)
-//                    .setHardwareAddressLength((byte) 6)
-//                    .setProtocolAddressLength((byte) 4)
-//                    .setOpCode(ARP.OP_REPLY)
-//                    .setSenderHardwareAddress(Ethernet.toMACAddress("00:44:33:22:11:01"))
-//                    .setSenderProtocolAddress(IPv4.toIPv4AddressBytes("192.168.1.1"))
-//                    .setTargetHardwareAddress(Ethernet.toMACAddress("00:11:22:33:44:55"))
-//                    .setTargetProtocolAddress(IPv4.toIPv4AddressBytes("192.168.1.2")));
-//        this.testARPReplyPacket_2_Srld = testARPReplyPacket_2.serialize();
-//
-//        // Build the PacketIn
-//        this.packetIn_1 = ((OFPacketIn) mockFloodlightProvider.
-//                getOFMessageFactory().getMessage(OFType.PACKET_IN))
-//                .setBufferId(-1)
-//                .setInPort((short) 1)
-//                .setPacketData(this.testARPReplyPacket_1_Srld)
-//                .setReason(OFPacketInReason.NO_MATCH)
-//                .setTotalLength((short) this.testARPReplyPacket_1_Srld.length);
-//
-//        // Build the PacketIn
-//        this.packetIn_2 = ((OFPacketIn) mockFloodlightProvider.
-//                getOFMessageFactory().getMessage(OFType.PACKET_IN))
-//                .setBufferId(-1)
-//                .setInPort((short) 1)
-//                .setPacketData(this.testARPReplyPacket_2_Srld)
-//                .setReason(OFPacketInReason.NO_MATCH)
-//                .setTotalLength((short) this.testARPReplyPacket_2_Srld.length);
-//    }
-//
-//
-//
-//
-//
-//    @Test
-//    public void testLastSeen() throws Exception {
-//        Calendar c = Calendar.getInstance();
-//        Date d1 = c.getTime();
-//        Entity entity1 = new Entity(1L, null, null, null, null, d1);
-//        c.add(Calendar.SECOND, 1);
-//        Entity entity2 = new Entity(1L, null, 1, null, null, c.getTime());
-//
-//        IDevice d = deviceManager.learnDeviceByEntity(entity2);
-//        assertEquals(c.getTime(), d.getLastSeen());
-//        d = deviceManager.learnDeviceByEntity(entity1);
-//        assertEquals(c.getTime(), d.getLastSeen());
-//
-//        deviceManager.startUp(null);
-//        d = deviceManager.learnDeviceByEntity(entity1);
-//        assertEquals(d1, d.getLastSeen());
-//        d = deviceManager.learnDeviceByEntity(entity2);
-//        assertEquals(c.getTime(), d.getLastSeen());
-//    }
-//
-//    @Test
-//    public void testEntityLearning() throws Exception {
-//        IDeviceListener mockListener =
-//                createMock(IDeviceListener.class);
-//        expect(mockListener.getName()).andReturn("mockListener").atLeastOnce();
-//        expect(mockListener.isCallbackOrderingPostreq((String)anyObject(), (String)anyObject()))
-//        .andReturn(false).atLeastOnce();
-//        expect(mockListener.isCallbackOrderingPrereq((String)anyObject(), (String)anyObject()))
-//        .andReturn(false).atLeastOnce();
-//
-//        replay(mockListener);
-//        deviceManager.addListener(mockListener);
-//        verify(mockListener);
-//        reset(mockListener);
-//        deviceManager.entityClassifier= new MockEntityClassifier();
-//        deviceManager.startUp(null);
-//
-//        ITopologyService mockTopology = createMock(ITopologyService.class);
-//        expect(mockTopology.getL2DomainId(anyLong())).
-//        andReturn(1L).anyTimes();
-//        expect(mockTopology.isBroadcastDomainPort(anyLong(), anyShort())).
-//        andReturn(false).anyTimes();
-//
-//        expect(mockTopology.isAttachmentPointPort(anyLong(),
-//                                                  anyShort())).andReturn(true).anyTimes();
-//        expect(mockTopology.isConsistent(10L, (short)1, 10L, (short)1)).
-//        andReturn(true).anyTimes();
-//        expect(mockTopology.isConsistent(1L, (short)1, 1L, (short)1)).
-//        andReturn(true).anyTimes();
-//        expect(mockTopology.isConsistent(50L, (short)3, 50L, (short)3)).
-//        andReturn(true).anyTimes();
-//
-//        Date topologyUpdateTime = new Date();
-//        expect(mockTopology.getLastUpdateTime()).andReturn(topologyUpdateTime).
-//        anyTimes();
-//
-//        deviceManager.topology = mockTopology;
-//
-//        Entity entity1 = new Entity(1L, null, null, 1L, 1, new Date());
-//        Entity entity2 = new Entity(1L, null, null, 10L, 1, new Date());
-//        Entity entity3 = new Entity(1L, null, 1, 10L, 1, new Date());
-//        Entity entity4 = new Entity(1L, null, 1, 1L, 1, new Date());
-//        Entity entity5 = new Entity(2L, (short)4, 1, 5L, 2, new Date());
-//        Entity entity6 = new Entity(2L, (short)4, 1, 50L, 3, new Date());
-//        Entity entity7 = new Entity(2L, (short)4, 2, 50L, 3, new Date());
-//
-//        mockListener.deviceAdded(isA(IDevice.class));
-//        replay(mockListener, mockTopology);
-//
-//        Device d1 = deviceManager.learnDeviceByEntity(entity1);
-//        assertSame(d1, deviceManager.learnDeviceByEntity(entity1));
-//        assertSame(d1, deviceManager.findDeviceByEntity(entity1));
-//        assertEquals(DefaultEntityClassifier.entityClass ,
-//                          d1.getEntityClass());
-//        assertArrayEquals(new Short[] { -1 }, d1.getVlanId());
-//        assertArrayEquals(new Integer[] { }, d1.getIPv4Addresses());
-//
-//        assertEquals(1, deviceManager.getAllDevices().size());
-//        verify(mockListener);
-//
-//        reset(mockListener);
-//        mockListener.deviceAdded(isA(IDevice.class));
-//        replay(mockListener);
-//
-//        Device d2 = deviceManager.learnDeviceByEntity(entity2);
-//        assertFalse(d1.equals(d2));
-//        assertNotSame(d1, d2);
-//        assertNotSame(d1.getDeviceKey(), d2.getDeviceKey());
-//        assertEquals(MockEntityClassifier.testEC, d2.getEntityClass());
-//        assertArrayEquals(new Short[] { -1 }, d2.getVlanId());
-//        assertArrayEquals(new Integer[] { }, d2.getIPv4Addresses());
-//
-//        assertEquals(2, deviceManager.getAllDevices().size());
-//        verify(mockListener);
-//
-//        reset(mockListener);
-//        mockListener.deviceIPV4AddrChanged(isA(IDevice.class));
-//        replay(mockListener);
-//
-//        Device d3 = deviceManager.learnDeviceByEntity(entity3);
-//        assertNotSame(d2, d3);
-//        assertEquals(d2.getDeviceKey(), d3.getDeviceKey());
-//        assertEquals(MockEntityClassifier.testEC, d3.getEntityClass());
-//        assertArrayEquals(new Integer[] { 1 },
-//                          d3.getIPv4Addresses());
-//        assertArrayEquals(new SwitchPort[] { new SwitchPort(10L, 1) },
-//                          d3.getAttachmentPoints());
-//        assertArrayEquals(new SwitchPort[] { new SwitchPort(10L, 1) },
-//                          d3.getAttachmentPoints(true));
-//        assertArrayEquals(new Short[] { -1 },
-//                          d3.getVlanId());
-//
-//        assertEquals(2, deviceManager.getAllDevices().size());
-//        verify(mockListener);
-//
-//        reset(mockListener);
-//        mockListener.deviceIPV4AddrChanged(isA(IDevice.class));
-//        replay(mockListener);
-//
-//        Device d4 = deviceManager.learnDeviceByEntity(entity4);
-//        assertNotSame(d1, d4);
-//        assertEquals(d1.getDeviceKey(), d4.getDeviceKey());
-//        assertEquals(DefaultEntityClassifier.entityClass, d4.getEntityClass());
-//        assertArrayEquals(new Integer[] { 1 },
-//                          d4.getIPv4Addresses());
-//        assertArrayEquals(new SwitchPort[] { new SwitchPort(1L, 1) },
-//                          d4.getAttachmentPoints());
-//        assertArrayEquals(new Short[] { -1 },
-//                          d4.getVlanId());
-//
-//        assertEquals(2, deviceManager.getAllDevices().size());
-//        verify(mockListener);
-//
-//        reset(mockListener);
-//        mockListener.deviceAdded((isA(IDevice.class)));
-//        replay(mockListener);
-//
-//        Device d5 = deviceManager.learnDeviceByEntity(entity5);
-//        assertArrayEquals(new SwitchPort[] { new SwitchPort(5L, 2) },
-//                          d5.getAttachmentPoints());
-//        assertArrayEquals(new Short[] { (short) 4 },
-//                          d5.getVlanId());
-//        assertEquals(2L, d5.getMACAddress());
-//        assertEquals("00:00:00:00:00:02", d5.getMACAddressString());
-//        verify(mockListener);
-//
-//        reset(mockListener);
-//        mockListener.deviceAdded(isA(IDevice.class));
-//        replay(mockListener);
-//
-//        Device d6 = deviceManager.learnDeviceByEntity(entity6);
-//        assertArrayEquals(new SwitchPort[] { new SwitchPort(50L, 3) },
-//                          d6.getAttachmentPoints());
-//        assertArrayEquals(new Short[] { (short) 4 },
-//                          d6.getVlanId());
-//
-//        assertEquals(4, deviceManager.getAllDevices().size());
-//        verify(mockListener);
-//
-//        reset(mockListener);
-//        mockListener.deviceIPV4AddrChanged(isA(IDevice.class));
-//        replay(mockListener);
-//
-//        Device d7 = deviceManager.learnDeviceByEntity(entity7);
-//        assertNotSame(d6, d7);
-//        assertEquals(d6.getDeviceKey(), d7.getDeviceKey());
-//        assertArrayEquals(new SwitchPort[] { new SwitchPort(50L, 3) },
-//                          d7.getAttachmentPoints());
-//        assertArrayEquals(new Short[] { (short) 4 },
-//                          d7.getVlanId());
-//
-//        assertEquals(4, deviceManager.getAllDevices().size());
-//        verify(mockListener);
-//
-//
-//        reset(mockListener);
-//        replay(mockListener);
-//
-//        reset(deviceManager.topology);
-//        deviceManager.topology.addListener(deviceManager);
-//        expectLastCall().times(1);
-//        replay(deviceManager.topology);
-//
-//        deviceManager.entityClassifier = new MockEntityClassifierMac();
-//        deviceManager.startUp(null);
-//        Entity entityNoClass = new Entity(5L, (short)1, 5, -1L, 1, new Date());
-//        assertEquals(null, deviceManager.learnDeviceByEntity(entityNoClass));
-//
-//        verify(mockListener);
-//    }
-//
-//
-//    private void doTestEntityOrdering(boolean computeInsertionPoint) throws Exception {
-//        Entity e = new Entity(10L, null, null, null, null, null);
-//        IEntityClass ec = createNiceMock(IEntityClass.class);
-//        Device d = new Device(deviceManager, 1L, e, ec);
-//
-//        int expectedLength = 1;
-//        Long[] macs = new Long[] {  5L,  // new first element
-//                                   15L,  // new last element
-//                                    7L,  // insert in middle
-//                                   12L,  // insert in middle
-//                                    6L,  // insert at idx 1
-//                                   14L,  // insert at idx length-2
-//                                    1L,
-//                                   20L
-//                                  };
-//
-//        for (Long mac: macs) {
-//            e = new Entity(mac, null, null, null, null, null);
-//            int insertionPoint;
-//            if (computeInsertionPoint) {
-//                insertionPoint = -(Arrays.binarySearch(d.entities, e)+1);
-//            } else {
-//                insertionPoint = -1;
-//            }
-//            d = deviceManager.allocateDevice(d, e, insertionPoint);
-//            expectedLength++;
-//            assertEquals(expectedLength, d.entities.length);
-//            for (int i = 0; i < d.entities.length-1; i++)
-//                assertEquals(-1, d.entities[i].compareTo(d.entities[i+1]));
-//        }
-//    }
-//
-//    @Test
-//    public void testEntityOrderingExternal() throws Exception {
-//        doTestEntityOrdering(true);
-//    }
-//
-//    @Test
-//    public void testEntityOrderingInternal() throws Exception {
-//        doTestEntityOrdering(false);
-//    }
-//
-//    @Test
-//    public void testAttachmentPointLearning() throws Exception {
-//        IDeviceListener mockListener =
-//                createMock(IDeviceListener.class);
-//        expect(mockListener.getName()).andReturn("mockListener").atLeastOnce();
-//        expect(mockListener.isCallbackOrderingPostreq((String)anyObject(), (String)anyObject()))
-//        .andReturn(false).atLeastOnce();
-//        expect(mockListener.isCallbackOrderingPrereq((String)anyObject(), (String)anyObject()))
-//        .andReturn(false).atLeastOnce();
-//
-//        replay(mockListener);
-//        deviceManager.addListener(mockListener);
-//        verify(mockListener);
-//        reset(mockListener);
-//
-//        ITopologyService mockTopology = createMock(ITopologyService.class);
-//        expect(mockTopology.getL2DomainId(1L)).
-//        andReturn(1L).anyTimes();
-//        expect(mockTopology.getL2DomainId(5L)).
-//        andReturn(1L).anyTimes();
-//        expect(mockTopology.getL2DomainId(10L)).
-//        andReturn(10L).anyTimes();
-//        expect(mockTopology.getL2DomainId(50L)).
-//        andReturn(10L).anyTimes();
-//        expect(mockTopology.isBroadcastDomainPort(anyLong(), anyShort())).
-//        andReturn(false).anyTimes();
-//        expect(mockTopology.isInSameBroadcastDomain(anyLong(), anyShort(),
-//                                                    anyLong(), anyShort())).andReturn(false).anyTimes();
-//
-//        expect(mockTopology.isAttachmentPointPort(anyLong(),
-//                                                  anyShort())).andReturn(true).anyTimes();
-//        expect(mockTopology.isConsistent(1L, (short)1, 5L, (short)1)).
-//        andReturn(false).anyTimes();
-//        expect(mockTopology.isConsistent(5L, (short)1, 10L, (short)1)).
-//        andReturn(false).anyTimes();
-//        expect(mockTopology.isConsistent(10L, (short)1, 50L, (short)1)).
-//        andReturn(false).anyTimes();
-//
-//        Date topologyUpdateTime = new Date();
-//        expect(mockTopology.getLastUpdateTime()).andReturn(topologyUpdateTime).
-//        anyTimes();
-//
-//        replay(mockTopology);
-//
-//        deviceManager.topology = mockTopology;
-//
-//        Calendar c = Calendar.getInstance();
-//        Entity entity1 = new Entity(1L, null, 1, 1L, 1, c.getTime());
-//        Entity entity0 = new Entity(1L, null, null, null, null, c.getTime());
-//        c.add(Calendar.SECOND, 1);
-//        Entity entity2 = new Entity(1L, null, null, 5L, 1, c.getTime());
-//        c.add(Calendar.SECOND, 1);
-//        Entity entity3 = new Entity(1L, null, null, 10L, 1, c.getTime());
-//        c.add(Calendar.SECOND, 1);
-//        Entity entity4 = new Entity(1L, null, null, 50L, 1, c.getTime());
-//
-//        IDevice d;
-//        SwitchPort[] aps;
-//        Integer[] ips;
-//
-//        mockListener.deviceAdded(isA(IDevice.class));
-//        replay(mockListener);
-//
-//        deviceManager.learnDeviceByEntity(entity1);
-//        d = deviceManager.learnDeviceByEntity(entity0);
-//        assertEquals(1, deviceManager.getAllDevices().size());
-//        aps = d.getAttachmentPoints();
-//        assertArrayEquals(new SwitchPort[] { new SwitchPort(1L, 1) }, aps);
-//        ips = d.getIPv4Addresses();
-//        assertArrayEquals(new Integer[] { 1 }, ips);
-//        verify(mockListener);
-//
-//        reset(mockListener);
-//        mockListener.deviceMoved((isA(IDevice.class)));
-//        replay(mockListener);
-//
-//        d = deviceManager.learnDeviceByEntity(entity2);
-//        assertEquals(1, deviceManager.getAllDevices().size());
-//        aps = d.getAttachmentPoints();
-//
-//        assertArrayEquals(new SwitchPort[] { new SwitchPort(5L, 1) }, aps);
-//        ips = d.getIPv4Addresses();
-//        assertArrayEquals(new Integer[] { 1 }, ips);
-//        verify(mockListener);
-//
-//        reset(mockListener);
-//        mockListener.deviceMoved((isA(IDevice.class)));
-//        replay(mockListener);
-//
-//        d = deviceManager.learnDeviceByEntity(entity3);
-//        assertEquals(1, deviceManager.getAllDevices().size());
-//        aps = d.getAttachmentPoints();
-//        assertArrayEquals(new SwitchPort[] {new SwitchPort(5L, 1), new SwitchPort(10L, 1)}, aps);
-//        ips = d.getIPv4Addresses();
-//        assertArrayEquals(new Integer[] { 1 }, ips);
-//        verify(mockListener);
-//
-//        reset(mockListener);
-//        mockListener.deviceMoved((isA(IDevice.class)));
-//        replay(mockListener);
-//
-//        d = deviceManager.learnDeviceByEntity(entity4);
-//        assertEquals(1, deviceManager.getAllDevices().size());
-//        aps = d.getAttachmentPoints();
-//        assertArrayEquals(new SwitchPort[] { new SwitchPort(5L, 1),
-//                                             new SwitchPort(50L, 1) }, aps);
-//        ips = d.getIPv4Addresses();
-//        assertArrayEquals(new Integer[] { 1 }, ips);
-//        verify(mockListener);
-//    }
-//
-//    private void verifyEntityArray(Entity[] expected, Device d) {
-//        Arrays.sort(expected);
-//        assertArrayEquals(expected, d.entities);
-//    }
-//
-//    @Test
-//    public void testNoLearningOnInternalPorts() throws Exception {
-//        IDeviceListener mockListener =
-//                createMock(IDeviceListener.class);
-//
-//        expect(mockListener.getName()).andReturn("mockListener").anyTimes();
-//        expect(mockListener.isCallbackOrderingPostreq((String)anyObject(), (String)anyObject()))
-//        .andReturn(false).atLeastOnce();
-//        expect(mockListener.isCallbackOrderingPrereq((String)anyObject(), (String)anyObject()))
-//        .andReturn(false).atLeastOnce();
-//
-//        replay(mockListener);
-//        deviceManager.addListener(mockListener);
-//        verify(mockListener);
-//        reset(mockListener);
-//
-//        ITopologyService mockTopology = createMock(ITopologyService.class);
-//        expect(mockTopology.getL2DomainId(1L)).
-//        andReturn(1L).anyTimes();
-//        expect(mockTopology.getL2DomainId(2L)).
-//        andReturn(1L).anyTimes();
-//        expect(mockTopology.getL2DomainId(3L)).
-//        andReturn(1L).anyTimes();
-//        expect(mockTopology.getL2DomainId(4L)).
-//        andReturn(1L).anyTimes();
-//        expect(mockTopology.isBroadcastDomainPort(anyLong(), anyShort()))
-//                .andReturn(false).anyTimes();
-//        expect(mockTopology.isInSameBroadcastDomain(anyLong(), anyShort(),
-//                                                    anyLong(), anyShort()))
-//                .andReturn(false).anyTimes();
-//
-//        expect(mockTopology.isAttachmentPointPort(or(eq(1L), eq(3L)), anyShort()))
-//                .andReturn(true).anyTimes();
-//        // Switches 2 and 4 have only internal ports
-//        expect(mockTopology.isAttachmentPointPort(or(eq(2L), eq(4L)), anyShort()))
-//                .andReturn(false).anyTimes();
-//
-//        expect(mockTopology.isConsistent(1L, (short)1, 3L, (short)1))
-//                .andReturn(false).once();
-//
-//        Date topologyUpdateTime = new Date();
-//        expect(mockTopology.getLastUpdateTime()).andReturn(topologyUpdateTime).
-//        anyTimes();
-//
-//        replay(mockTopology);
-//
-//        deviceManager.topology = mockTopology;
-//
-//        Calendar c = Calendar.getInstance();
-//        Entity entity1 = new Entity(1L, null, 1, 1L, 1, c.getTime());
-//        c.add(Calendar.SECOND, 1);
-//        Entity entity2 = new Entity(1L, null, 2, 2L, 1, c.getTime());
-//        c.add(Calendar.SECOND, 1);
-//        Entity entity3 = new Entity(1L, null, 3, 3L, 1, c.getTime());
-//        c.add(Calendar.SECOND, 1);
-//        Entity entity4 = new Entity(1L, null, 4, 4L, 1, c.getTime());
-//
-//        IDevice d;
-//        SwitchPort[] aps;
-//        Integer[] ips;
-//
-//        mockListener.deviceAdded(isA(IDevice.class));
-//        expectLastCall().once();
-//        replay(mockListener);
-//
-//        // cannot learn device internal ports
-//        d = deviceManager.learnDeviceByEntity(entity2);
-//        assertNull(d);
-//        d = deviceManager.learnDeviceByEntity(entity4);
-//        assertNull(d);
-//
-//        d = deviceManager.learnDeviceByEntity(entity1);
-//        assertEquals(1, deviceManager.getAllDevices().size());
-//        aps = d.getAttachmentPoints();
-//        assertArrayEquals(new SwitchPort[] { new SwitchPort(1L, 1) }, aps);
-//        verifyEntityArray(new Entity[] { entity1 } , (Device)d);
-//        ips = d.getIPv4Addresses();
-//        assertArrayEquals(new Integer[] { 1 }, ips);
-//        verify(mockListener);
-//
-//        reset(mockListener);
-//        replay(mockListener);
-//
-//        // don't learn
-//        d = deviceManager.learnDeviceByEntity(entity2);
-//        assertEquals(1, deviceManager.getAllDevices().size());
-//        aps = d.getAttachmentPoints();
-//        assertArrayEquals(new SwitchPort[] { new SwitchPort(1L, 1) }, aps);
-//        verifyEntityArray(new Entity[] { entity1 } , (Device)d);
-//        ips = d.getIPv4Addresses();
-//        assertArrayEquals(new Integer[] { 1 }, ips);
-//        verify(mockListener);
-//
-//        reset(mockListener);
-//        mockListener.deviceMoved(isA(IDevice.class));
-//        mockListener.deviceIPV4AddrChanged(isA(IDevice.class));
-//        replay(mockListener);
-//
-//        // learn
-//        d = deviceManager.learnDeviceByEntity(entity3);
-//        assertEquals(1, deviceManager.getAllDevices().size());
-//        aps = d.getAttachmentPoints();
-//        assertArrayEquals(new SwitchPort[] { new SwitchPort(3L, 1) }, aps);
-//        verifyEntityArray(new Entity[] { entity1, entity3 } , (Device)d);
-//        ips = d.getIPv4Addresses();
-//        Arrays.sort(ips);
-//        assertArrayEquals(new Integer[] { 1, 3 }, ips);
-//        verify(mockListener);
-//
-//        reset(mockListener);
-//        replay(mockListener);
-//
-//        // don't learn
-//        d = deviceManager.learnDeviceByEntity(entity4);
-//        assertEquals(1, deviceManager.getAllDevices().size());
-//        aps = d.getAttachmentPoints();
-//        assertArrayEquals(new SwitchPort[] { new SwitchPort(3L, 1) }, aps);
-//        verifyEntityArray(new Entity[] { entity1, entity3 } , (Device)d);
-//        ips = d.getIPv4Addresses();
-//        Arrays.sort(ips);
-//        assertArrayEquals(new Integer[] { 1, 3 }, ips);
-//        verify(mockListener);
-//    }
-//
-//    @Test
-//    public void testAttachmentPointSuppression() throws Exception {
-//        IDeviceListener mockListener =
-//                createMock(IDeviceListener.class);
-//
-//        expect(mockListener.getName()).andReturn("mockListener").anyTimes();
-//        expect(mockListener.isCallbackOrderingPostreq((String)anyObject(), (String)anyObject()))
-//        .andReturn(false).atLeastOnce();
-//        expect(mockListener.isCallbackOrderingPrereq((String)anyObject(), (String)anyObject()))
-//        .andReturn(false).atLeastOnce();
-//
-//        replay(mockListener);
-//        deviceManager.addListener(mockListener);
-//        verify(mockListener);
-//        reset(mockListener);
-//
-//        ITopologyService mockTopology = createMock(ITopologyService.class);
-//        expect(mockTopology.getL2DomainId(1L)).
-//        andReturn(1L).anyTimes();
-//        expect(mockTopology.getL2DomainId(5L)).
-//        andReturn(1L).anyTimes();
-//        expect(mockTopology.getL2DomainId(10L)).
-//        andReturn(10L).anyTimes();
-//        expect(mockTopology.getL2DomainId(50L)).
-//        andReturn(10L).anyTimes();
-//        expect(mockTopology.isBroadcastDomainPort(anyLong(), anyShort()))
-//                .andReturn(false).anyTimes();
-//        expect(mockTopology.isInSameBroadcastDomain(anyLong(), anyShort(),
-//                                                    anyLong(), anyShort()))
-//                .andReturn(false).anyTimes();
-//
-//        expect(mockTopology.isAttachmentPointPort(anyLong(), anyShort()))
-//                .andReturn(true).anyTimes();
-//        expect(mockTopology.isConsistent(5L, (short)1, 50L, (short)1))
-//                .andReturn(false).anyTimes();
-//
-//        Date topologyUpdateTime = new Date();
-//        expect(mockTopology.getLastUpdateTime()).andReturn(topologyUpdateTime).
-//        anyTimes();
-//
-//        replay(mockTopology);
-//
-//        deviceManager.topology = mockTopology;
-//        // suppress (1L, 1) and (10L, 1)
-//        deviceManager.addSuppressAPs(1L, (short)1);
-//        deviceManager.addSuppressAPs(10L, (short)1);
-//
-//        Calendar c = Calendar.getInstance();
-//        Entity entity0 = new Entity(1L, null, null, null, null, c.getTime());
-//        // No attachment point should be learnt on 1L, 1
-//        Entity entity1 = new Entity(1L, null, 1, 1L, 1, c.getTime());
-//        c.add(Calendar.SECOND, 1);
-//        Entity entity2 = new Entity(1L, null, 1, 5L, 1, c.getTime());
-//        c.add(Calendar.SECOND, 1);
-//        Entity entity3 = new Entity(1L, null, null, 10L, 1, c.getTime());
-//        c.add(Calendar.SECOND, 1);
-//        Entity entity4 = new Entity(1L, null, null, 50L, 1, c.getTime());
-//
-//        IDevice d;
-//        SwitchPort[] aps;
-//        Integer[] ips;
-//
-//        mockListener.deviceAdded(isA(IDevice.class));
-//        mockListener.deviceIPV4AddrChanged((isA(IDevice.class)));
-//        replay(mockListener);
-//
-//        // TODO: we currently do learn entities on suppressed APs
-//        // // cannot learn device on suppressed AP
-//        // d = deviceManager.learnDeviceByEntity(entity1);
-//        // assertNull(d);
-//
-//        deviceManager.learnDeviceByEntity(entity0);
-//        d = deviceManager.learnDeviceByEntity(entity1);
-//        assertEquals(1, deviceManager.getAllDevices().size());
-//        aps = d.getAttachmentPoints();
-//        assertEquals(aps.length, 0);
-//        verifyEntityArray(new Entity[] { entity0, entity1} , (Device)d);
-//        ips = d.getIPv4Addresses();
-//        assertArrayEquals(new Integer[] { 1 }, ips);
-//        verify(mockListener);
-//
-//        reset(mockListener);
-//        mockListener.deviceMoved((isA(IDevice.class)));
-//        //mockListener.deviceIPV4AddrChanged((isA(IDevice.class)));
-//        replay(mockListener);
-//        d = deviceManager.learnDeviceByEntity(entity2);
-//        assertEquals(1, deviceManager.getAllDevices().size());
-//        aps = d.getAttachmentPoints();
-//        assertArrayEquals(new SwitchPort[] { new SwitchPort(5L, 1) }, aps);
-//        verifyEntityArray(new Entity[] { entity0, entity1, entity2 } , (Device)d);
-//        ips = d.getIPv4Addresses();
-//        assertArrayEquals(new Integer[] { 1 }, ips);
-//        verify(mockListener);
-//
-//        reset(mockListener);
-//        replay(mockListener);
-//
-//        d = deviceManager.learnDeviceByEntity(entity3);
-//        assertEquals(1, deviceManager.getAllDevices().size());
-//        aps = d.getAttachmentPoints();
-//        assertArrayEquals(new SwitchPort[] { new SwitchPort(5L, 1) }, aps);
-//        verifyEntityArray(new Entity[] { entity0, entity1, entity2, entity3 } , (Device)d);
-//        ips = d.getIPv4Addresses();
-//        assertArrayEquals(new Integer[] { 1 }, ips);
-//        verify(mockListener);
-//
-//        reset(mockListener);
-//        mockListener.deviceMoved((isA(IDevice.class)));
-//        replay(mockListener);
-//
-//        d = deviceManager.learnDeviceByEntity(entity4);
-//        assertEquals(1, deviceManager.getAllDevices().size());
-//        aps = d.getAttachmentPoints();
-//        assertArrayEquals(new SwitchPort[] { new SwitchPort(5L, 1),
-//                                             new SwitchPort(50L, 1) }, aps);
-//        verifyEntityArray(new Entity[] { entity0, entity1, entity2, entity3, entity4} , (Device)d);
-//        ips = d.getIPv4Addresses();
-//        assertArrayEquals(new Integer[] { 1 }, ips);
-//        verify(mockListener);
-//    }
-//
-//    @Test
-//    public void testBDAttachmentPointLearning() throws Exception {
-//        ITopologyService mockTopology = createMock(ITopologyService.class);
-//        expect(mockTopology.getL2DomainId(anyLong())).
-//        andReturn(1L).anyTimes();
-//        expect(mockTopology.isAttachmentPointPort(anyLong(), anyShort())).
-//        andReturn(true).anyTimes();
-//        expect(mockTopology.isBroadcastDomainPort(1L, (short)1)).
-//        andReturn(false).anyTimes();
-//        expect(mockTopology.isBroadcastDomainPort(1L, (short)2)).
-//        andReturn(true).anyTimes();
-//        expect(mockTopology.isInSameBroadcastDomain(1L, (short)1,
-//                                                    1L, (short)2)).andReturn(true).anyTimes();
-//        expect(mockTopology.isInSameBroadcastDomain(1L, (short)2,
-//                                                    1L, (short)1)).andReturn(true).anyTimes();
-//        expect(mockTopology.isConsistent(anyLong(), anyShort(), anyLong(), anyShort())).andReturn(false).anyTimes();
-//
-//        Date topologyUpdateTime = new Date();
-//        expect(mockTopology.getLastUpdateTime()).andReturn(topologyUpdateTime).
-//        anyTimes();
-//
-//        replay(mockTopology);
-//
-//        deviceManager.topology = mockTopology;
-//
-//        Calendar c = Calendar.getInstance();
-//        Entity entity1 = new Entity(1L, null, 1, 1L, 1, c.getTime());
-//        c.add(Calendar.MILLISECOND,
-//              (int)AttachmentPoint.OPENFLOW_TO_EXTERNAL_TIMEOUT/ 2);
-//        Entity entity2 = new Entity(1L, null, null, 1L, 2, c.getTime());
-//        c.add(Calendar.MILLISECOND,
-//              (int)AttachmentPoint.OPENFLOW_TO_EXTERNAL_TIMEOUT / 2 + 1);
-//        Entity entity3 = new Entity(1L, null, null, 1L, 2, c.getTime());
-//
-//        IDevice d;
-//        SwitchPort[] aps;
-//
-//        d = deviceManager.learnDeviceByEntity(entity1);
-//        assertEquals(1, deviceManager.getAllDevices().size());
-//        aps = d.getAttachmentPoints();
-//        assertArrayEquals(new SwitchPort[] { new SwitchPort(1L, 1) }, aps);
-//
-//        // this timestamp is too soon; don't switch
-//        d = deviceManager.learnDeviceByEntity(entity2);
-//        assertEquals(1, deviceManager.getAllDevices().size());
-//        aps = d.getAttachmentPoints();
-//        assertArrayEquals(new SwitchPort[] { new SwitchPort(1L, 1) }, aps);
-//
-//        // it should switch when we learn with a timestamp after the
-//        // timeout
-//        d = deviceManager.learnDeviceByEntity(entity3);
-//        assertEquals(1, deviceManager.getAllDevices().size());
-//        aps = d.getAttachmentPoints();
-//        assertArrayEquals(new SwitchPort[] { new SwitchPort(1L, 2) }, aps);
-//    }
-//
-//    /**
-//     * This test verifies that the learning behavior on OFPP_LOCAL ports.
-//     * Once a host is learned on OFPP_LOCAL, it is allowed to move only from
-//     * one OFPP_LOCAL to another OFPP_LOCAL port.
-//     * @throws Exception
-//     */
-//    @Test
-//    public void testLOCALAttachmentPointLearning() throws Exception {
-//        ITopologyService mockTopology = createMock(ITopologyService.class);
-//        expect(mockTopology.getL2DomainId(anyLong())).
-//        andReturn(1L).anyTimes();
-//        expect(mockTopology.isAttachmentPointPort(anyLong(), anyShort())).
-//        andReturn(true).anyTimes();
-//        expect(mockTopology.isBroadcastDomainPort(1L, (short)1)).
-//        andReturn(false).anyTimes();
-//        expect(mockTopology.isBroadcastDomainPort(1L, OFPort.OFPP_LOCAL.getValue())).
-//        andReturn(false).anyTimes();
-//        expect(mockTopology.isBroadcastDomainPort(1L, (short)2)).
-//        andReturn(true).anyTimes();
-//        expect(mockTopology.isInSameBroadcastDomain(1L, (short)1,
-//                                                    1L, OFPort.OFPP_LOCAL.getValue())).andReturn(true).anyTimes();
-//        expect(mockTopology.isInSameBroadcastDomain(1L, OFPort.OFPP_LOCAL.getValue(),
-//                                                    1L, (short)2)).andReturn(true).anyTimes();
-//        expect(mockTopology.isInSameBroadcastDomain(1L, (short)2,
-//                                                    1L, OFPort.OFPP_LOCAL.getValue())).andReturn(true).anyTimes();
-//        expect(mockTopology.isConsistent(anyLong(), anyShort(), anyLong(), anyShort())).andReturn(false).anyTimes();
-//
-//        Date topologyUpdateTime = new Date();
-//        expect(mockTopology.getLastUpdateTime()).andReturn(topologyUpdateTime).
-//        anyTimes();
-//
-//        replay(mockTopology);
-//
-//        deviceManager.topology = mockTopology;
-//
-//        Calendar c = Calendar.getInstance();
-//        Entity entity1 = new Entity(1L, null, 1, 1L, 1, c.getTime());
-//        c.add(Calendar.MILLISECOND,
-//              (int)AttachmentPoint.OPENFLOW_TO_EXTERNAL_TIMEOUT/ 2);
-//        Entity entity2 = new Entity(1L, null, null, 1L, (int)OFPort.OFPP_LOCAL.getValue(), c.getTime());
-//        c.add(Calendar.MILLISECOND,
-//              (int)AttachmentPoint.OPENFLOW_TO_EXTERNAL_TIMEOUT + 1);
-//        Entity entity3 = new Entity(1L, null, null, 1L, 2, c.getTime());
-//
-//        IDevice d;
-//        SwitchPort[] aps;
-//
-//        d = deviceManager.learnDeviceByEntity(entity1);
-//        assertEquals(1, deviceManager.getAllDevices().size());
-//        aps = d.getAttachmentPoints();
-//        assertArrayEquals(new SwitchPort[] { new SwitchPort(1L, 1) }, aps);
-//
-//        // Ensure that the attachment point changes to OFPP_LOCAL
-//        d = deviceManager.learnDeviceByEntity(entity2);
-//        assertEquals(1, deviceManager.getAllDevices().size());
-//        aps = d.getAttachmentPoints();
-//        assertArrayEquals(new SwitchPort[] { new SwitchPort(1L, OFPort.OFPP_LOCAL.getValue()) }, aps);
-//
-//        // Even though the new attachment point is consistent with old
-//        // and the time has elapsed, OFPP_LOCAL attachment point should
-//        // be maintained.
-//        d = deviceManager.learnDeviceByEntity(entity3);
-//        assertEquals(1, deviceManager.getAllDevices().size());
-//        aps = d.getAttachmentPoints();
-//        assertArrayEquals(new SwitchPort[] { new SwitchPort(1L, OFPort.OFPP_LOCAL.getValue()) }, aps);
-//    }
-//
-//    @Test
-//    public void testPacketInBasic(byte[] deviceMac, OFPacketIn packetIn) {
-//        // Mock up our expected behavior
-//        ITopologyService mockTopology = createMock(ITopologyService.class);
-//        deviceManager.topology = mockTopology;
-//        expect(mockTopology.isAttachmentPointPort(EasyMock.anyLong(),
-//                EasyMock.anyShort())).
-//                andReturn(true).anyTimes();
-//        expect(mockTopology.isConsistent(EasyMock.anyLong(),
-//                EasyMock.anyShort(),
-//                EasyMock.anyLong(),
-//                EasyMock.anyShort())).andReturn(false).
-//                anyTimes();
-//        expect(mockTopology.getL2DomainId(EasyMock.anyLong())).andReturn(1L).anyTimes();
-//        replay(mockTopology);
-//
-//        Date currentDate = new Date();
-//
-//        // build our expected Device
-//        Integer ipaddr = IPv4.toIPv4Address("192.168.1.1");
-//        Device device =
-//                new Device(deviceManager,
-//                        new Long(deviceManager.deviceKeyCounter),
-//                        new Entity(Ethernet.toLong(deviceMac),
-//                                (short)5,
-//                                ipaddr,
-//                                1L,
-//                                1,
-//                                currentDate),
-//                                DefaultEntityClassifier.entityClass);
-//
-//        // Get the listener and trigger the packet in
-//        IOFSwitch switch1 = mockFloodlightProvider.getSwitch(1L);
-//        mockFloodlightProvider.dispatchMessage(switch1, packetIn);
-//
-//        // Verify the replay matched our expectations
-//        // verify(mockTopology);
-//
-//        // Verify the device
-//        Device rdevice = (Device)
-//                deviceManager.findDevice(Ethernet.toLong(deviceMac),
-//                        (short)5, null, null, null);
-//
-//        assertEquals(device, rdevice);
-//        assertEquals(new Short((short)5), rdevice.getVlanId()[0]);
-//
-//        Device result = null;
-//        Iterator<? extends IDevice> dstiter =
-//                deviceManager.queryClassDevices(device.getEntityClass(),
-//                        null, null, ipaddr,
-//                        null, null);
-//        if (dstiter.hasNext()) {
-//            result = (Device)dstiter.next();
-//        }
-//
-//        assertEquals(device, result);
-//
-//        device =
-//                new Device(device,
-//                        new Entity(Ethernet.toLong(deviceMac),
-//                                (short)5,
-//                                ipaddr,
-//                                5L,
-//                                2,
-//                                currentDate),
-//                                -1);
-//
-//        reset(mockTopology);
-//        expect(mockTopology.isAttachmentPointPort(anyLong(),
-//                anyShort())).
-//                andReturn(true).
-//                anyTimes();
-//        expect(mockTopology.isConsistent(EasyMock.anyLong(),
-//                EasyMock.anyShort(),
-//                EasyMock.anyLong(),
-//                EasyMock.anyShort())).andReturn(false).
-//                anyTimes();
-//        expect(mockTopology.isBroadcastDomainPort(EasyMock.anyLong(),
-//                EasyMock.anyShort()))
-//                .andReturn(false)
-//                .anyTimes();
-//        expect(mockTopology.getL2DomainId(1L)).andReturn(1L).anyTimes();
-//        expect(mockTopology.getL2DomainId(5L)).andReturn(1L).anyTimes();
-//        expect(mockTopology.isInSameBroadcastDomain(1L, (short)1, 5L, (short)2)).
-//        andReturn(false).anyTimes();
-//
-//        // Start recording the replay on the mocks
-//        replay(mockTopology);
-//        // Get the listener and trigger the packet in
-//        IOFSwitch switch5 = mockFloodlightProvider.getSwitch(5L);
-//        mockFloodlightProvider.
-//        dispatchMessage(switch5, this.packetIn_1.setInPort((short)2));
-//
-//        // Verify the replay matched our expectations
-//        verify(mockTopology);
-//
-//        // Verify the device
-//        rdevice = (Device)
-//                deviceManager.findDevice(Ethernet.toLong(deviceMac),
-//                        (short)5, null, null, null);
-//        assertEquals(device, rdevice);
-//    }
-//
-//    @Test
-//    public void testPacketIn() throws Exception {
-//        byte[] deviceMac1 =
-//                ((Ethernet)this.testARPReplyPacket_1).getSourceMACAddress();
-//        testPacketInBasic(deviceMac1, packetIn_1);
-//    }
-//
-//    /**
-//     * This test ensures the device manager learns the source device
-//     * corresponding to the senderHardwareAddress and senderProtocolAddress
-//     * in an ARP response whenever the senderHardwareAddress is different
-//     * from the source MAC address of the Ethernet frame.
-//     *
-//     * This test is the same as testPacketIn method, except for the
-//     * packet-in that's used.
-//     * @throws Exception
-//     */
-//    @Test
-//    public void testDeviceLearningFromArpResponseData() throws Exception {
-//        ARP arp = (ARP)((Ethernet)this.testARPReplyPacket_2).getPayload();
-//        byte[] deviceMac2 = arp.getSenderHardwareAddress();
-//
-//        testPacketInBasic(deviceMac2, packetIn_2);
-//    }
-//
-//    /**
-//     * Note: Entity expiration does not result in device moved notification.
-//     * @throws Exception
-//     */
-//    public void doTestEntityExpiration() throws Exception {
-//        IDeviceListener mockListener =
-//                createMock(IDeviceListener.class);
-//        expect(mockListener.getName()).andReturn("mockListener").anyTimes();
-//        expect(mockListener.isCallbackOrderingPostreq((String)anyObject(), (String)anyObject()))
-//        .andReturn(false).atLeastOnce();
-//        expect(mockListener.isCallbackOrderingPrereq((String)anyObject(), (String)anyObject()))
-//        .andReturn(false).atLeastOnce();
-//
-//        ITopologyService mockTopology = createMock(ITopologyService.class);
-//        expect(mockTopology.isAttachmentPointPort(anyLong(),
-//                                                  anyShort())).
-//                                                  andReturn(true).anyTimes();
-//
-//        expect(mockTopology.isBroadcastDomainPort(1L, (short)1)).andReturn(false).anyTimes();
-//        expect(mockTopology.isBroadcastDomainPort(5L, (short)1)).andReturn(false).anyTimes();
-//        expect(mockTopology.getL2DomainId(1L)).andReturn(1L).anyTimes();
-//        expect(mockTopology.getL2DomainId(5L)).andReturn(5L).anyTimes();
-//        expect(mockTopology.isConsistent(1L, (short)1, 5L, (short)1)).
-//        andReturn(false).anyTimes();
-//
-//        Date topologyUpdateTime = new Date();
-//        expect(mockTopology.getLastUpdateTime()).andReturn(topologyUpdateTime).
-//        anyTimes();
-//
-//        replay(mockTopology);
-//        deviceManager.topology = mockTopology;
-//
-//        Calendar c = Calendar.getInstance();
-//        Entity entity1 = new Entity(1L, null, 2, 1L, 1, c.getTime());
-//        c.add(Calendar.MILLISECOND, -DeviceManagerImpl.ENTITY_TIMEOUT-1);
-//        Entity entity2 = new Entity(1L, null, 1, 5L, 1, c.getTime());
-//
-//        deviceManager.learnDeviceByEntity(entity1);
-//        IDevice d = deviceManager.learnDeviceByEntity(entity2);
-//        assertArrayEquals(new Integer[] { 1, 2 }, d.getIPv4Addresses());
-//        assertArrayEquals(new SwitchPort[] { new SwitchPort(1L, 1),
-//                                             new SwitchPort(5L, 1)},
-//                                             d.getAttachmentPoints());
-//        Iterator<? extends IDevice> diter =
-//                deviceManager.queryClassDevices(d.getEntityClass(),
-//                                                null, null, 1, null, null);
-//        assertTrue(diter.hasNext());
-//        assertEquals(d.getDeviceKey(), diter.next().getDeviceKey());
-//        diter = deviceManager.queryClassDevices(d.getEntityClass(),
-//                                                null, null, 2, null, null);
-//        assertTrue(diter.hasNext());
-//        assertEquals(d.getDeviceKey(), diter.next().getDeviceKey());
-//
-//        replay(mockListener);
-//        deviceManager.addListener(mockListener);
-//        verify(mockListener);
-//        reset(mockListener);
-//
-//        mockListener.deviceIPV4AddrChanged(isA(IDevice.class));
-//        replay(mockListener);
-//        deviceManager.entityCleanupTask.reschedule(0, null);
-//
-//        d = deviceManager.getDevice(d.getDeviceKey());
-//        assertArrayEquals(new Integer[] { 2 }, d.getIPv4Addresses());
-//
-//        // Attachment points are not removed, previous ones are still valid.
-//        assertArrayEquals(new SwitchPort[] { new SwitchPort(1L, 1),
-//                                             new SwitchPort(5L, 1) },
-//                          d.getAttachmentPoints());
-//        diter = deviceManager.queryClassDevices(d.getEntityClass(),
-//                                                null, null, 2, null, null);
-//        assertTrue(diter.hasNext());
-//        assertEquals(d.getDeviceKey(), diter.next().getDeviceKey());
-//        diter = deviceManager.queryClassDevices(d.getEntityClass(),
-//                                                null, null, 1, null, null);
-//        assertFalse(diter.hasNext());
-//
-//        d = deviceManager.findDevice(1L, null, null, null, null);
-//        assertArrayEquals(new Integer[] { 2 }, d.getIPv4Addresses());
-//
-//        // Attachment points are not removed, previous ones are still valid.
-//        assertArrayEquals(new SwitchPort[] { new SwitchPort(1L, 1),
-//                                             new SwitchPort(5L, 1) },
-//                          d.getAttachmentPoints());
-//
-//        verify(mockListener);
-//    }
-//
-//    public void doTestDeviceExpiration() throws Exception {
-//        IDeviceListener mockListener =
-//                createMock(IDeviceListener.class);
-//        expect(mockListener.getName()).andReturn("mockListener").anyTimes();
-//        expect(mockListener.isCallbackOrderingPostreq((String)anyObject(), (String)anyObject()))
-//        .andReturn(false).atLeastOnce();
-//        expect(mockListener.isCallbackOrderingPrereq((String)anyObject(), (String)anyObject()))
-//        .andReturn(false).atLeastOnce();
-//
-//        Calendar c = Calendar.getInstance();
-//        c.add(Calendar.MILLISECOND, -DeviceManagerImpl.ENTITY_TIMEOUT-1);
-//        Entity entity1 = new Entity(1L, null, 1, 1L, 1, c.getTime());
-//        Entity entity2 = new Entity(1L, null, 2, 5L, 1, c.getTime());
-//
-//        ITopologyService mockTopology = createMock(ITopologyService.class);
-//        deviceManager.topology = mockTopology;
-//
-//        expect(mockTopology.isAttachmentPointPort(EasyMock.anyLong(),
-//                                           EasyMock.anyShort())).
-//                                           andReturn(true).
-//                                           anyTimes();
-//        expect(mockTopology.getL2DomainId(1L)).andReturn(1L).anyTimes();
-//        expect(mockTopology.getL2DomainId(5L)).andReturn(1L).anyTimes();
-//        expect(mockTopology.isConsistent(EasyMock.anyLong(),
-//                                         EasyMock.anyShort(),
-//                                         EasyMock.anyLong(),
-//                                         EasyMock.anyShort())).andReturn(false).
-//                                         anyTimes();
-//        expect(mockTopology.isBroadcastDomainPort(EasyMock.anyLong(),
-//                                                  EasyMock.anyShort())).
-//                                                  andReturn(false).anyTimes();
-//        replay(mockTopology);
-//
-//        IDevice d = deviceManager.learnDeviceByEntity(entity2);
-//        d = deviceManager.learnDeviceByEntity(entity1);
-//        assertArrayEquals(new Integer[] { 1, 2 }, d.getIPv4Addresses());
-//
-//        replay(mockListener);
-//        deviceManager.addListener(mockListener);
-//        verify(mockListener);
-//        reset(mockListener);
-//
-//        mockListener.deviceRemoved(isA(IDevice.class));
-//        replay(mockListener);
-//        deviceManager.entityCleanupTask.reschedule(0, null);
-//
-//        IDevice r = deviceManager.getDevice(d.getDeviceKey());
-//        assertNull(r);
-//        Iterator<? extends IDevice> diter =
-//                deviceManager.queryClassDevices(d.getEntityClass(),
-//                                                null, null, 1, null, null);
-//        assertFalse(diter.hasNext());
-//
-//        r = deviceManager.findDevice(1L, null, null, null, null);
-//        assertNull(r);
-//
-//        verify(mockListener);
-//    }
-//
-//    /*
-//     * A ConcurrentHashMap for devices (deviceMap) that can be used to test
-//     * code that specially handles concurrent modification situations. In
-//     * particular, we overwrite values() and will replace / remove all the
-//     * elements returned by values.
-//     *
-//     * The remove flag in the constructor specifies if devices returned by
-//     * values() should be removed or replaced.
-//     */
-//    protected static class ConcurrentlyModifiedDeviceMap
-//                            extends ConcurrentHashMap<Long, Device> {
-//        private static final long serialVersionUID = 7784938535441180562L;
-//        protected boolean remove;
-//        public ConcurrentlyModifiedDeviceMap(boolean remove) {
-//            super();
-//            this.remove = remove;
-//        }
-//
-//        @Override
-//        public Collection<Device> values() {
-//            // Get the values from the real map and copy them since
-//            // the collection returned by values can reflect changed
-//            Collection<Device> devs = new ArrayList<Device>(super.values());
-//            for (Device d: devs) {
-//                if (remove) {
-//                    // We remove the device from the underlying map
-//                    super.remove(d.getDeviceKey());
-//                } else {
-//                    super.remove(d.getDeviceKey());
-//                    // We add a different Device instance with the same
-//                    // key to the map. We'll do some hackery so the device
-//                    // is different enough to compare differently in equals
-//                    // but otherwise looks the same.
-//                    // It's ugly but it works.
-//                    // clone entities
-//                    Device newDevice = d;
-//                    for (Entity e: d.getEntities()) {
-//                        Entity newEntity = new Entity (e.macAddress,
-//                                                       e.vlan,
-//                                                       e.ipv4Address,
-//                                                       e.switchDPID,
-//                                                       e.switchPort,
-//                                                       e.lastSeenTimestamp);
-//                        if (e.vlan == null)
-//                            newEntity.vlan = (short)1;
-//                        else
-//                             newEntity.vlan = (short)((e.vlan + 1 % 4095)+1);
-//                        newDevice = new Device(newDevice, newEntity, -1);
-//                    }
-//                    assertEquals(false, newDevice.equals(d));
-//                    super.put(newDevice.getDeviceKey(), newDevice);
-//                }
-//            }
-//            return devs;
-//        }
-//    }
-//
-//    @Test
-//    public void testEntityExpiration() throws Exception {
-//        doTestEntityExpiration();
-//    }
-//
-//    @Test
-//    public void testDeviceExpiration() throws Exception {
-//        doTestDeviceExpiration();
-//    }
-//
-//    /* Test correct entity cleanup behavior when a concurrent modification
-//     * occurs.
-//     */
-//    @Test
-//    public void testEntityExpirationConcurrentModification() throws Exception {
-//        deviceManager.deviceMap = new ConcurrentlyModifiedDeviceMap(false);
-//        doTestEntityExpiration();
-//    }
-//
-//    /* Test correct entity cleanup behavior when a concurrent remove
-//     * occurs.
-//     */
-//    @Test
-//    public void testDeviceExpirationConcurrentRemove() throws Exception {
-//        deviceManager.deviceMap = new ConcurrentlyModifiedDeviceMap(true);
-//        doTestDeviceExpiration();
-//    }
-//
-//    /* Test correct entity cleanup behavior when a concurrent modification
-//     * occurs.
-//     */
-//    @Test
-//    public void testDeviceExpirationConcurrentModification() throws Exception {
-//        deviceManager.deviceMap = new ConcurrentlyModifiedDeviceMap(false);
-//        doTestDeviceExpiration();
-//    }
-//
-//
-//    @Test
-//    public void testAttachmentPointFlapping() throws Exception {
-//        Calendar c = Calendar.getInstance();
-//
-//        ITopologyService mockTopology = createMock(ITopologyService.class);
-//        expect(mockTopology.isAttachmentPointPort(anyLong(),
-//                                                  anyShort())).andReturn(true).anyTimes();
-//        expect(mockTopology.isBroadcastDomainPort(anyLong(),
-//                                                  anyShort())).
-//                                                  andReturn(false).anyTimes();
-//        expect(mockTopology.isInSameBroadcastDomain(anyLong(), anyShort(),
-//                                                    anyLong(), anyShort())).andReturn(false).anyTimes();
-//        expect(mockTopology.getL2DomainId(anyLong())).
-//        andReturn(1L).anyTimes();
-//        expect(mockTopology.isConsistent(1L, (short)1, 1L, (short)1)).
-//        andReturn(true).anyTimes();
-//        expect(mockTopology.isConsistent(1L, (short)1, 5L, (short)1)).
-//        andReturn(false).anyTimes();
-//        expect(mockTopology.isConsistent(1L, (short)1, 10L, (short)1)).
-//        andReturn(false).anyTimes();
-//        expect(mockTopology.isConsistent(5L, (short)1, 10L, (short)1)).
-//        andReturn(false).anyTimes();
-//        expect(mockTopology.isConsistent(10L, (short)1, 1L, (short)1)).
-//        andReturn(false).anyTimes();
-//        expect(mockTopology.isConsistent(5L, (short)1, 1L, (short)1)).
-//        andReturn(false).anyTimes();
-//        expect(mockTopology.isConsistent(10L, (short)1, 5L, (short)1)).
-//        andReturn(false).anyTimes();
-//
-//        Date topologyUpdateTime = new Date();
-//        expect(mockTopology.getLastUpdateTime()).andReturn(topologyUpdateTime).
-//        anyTimes();
-//
-//
-//        replay(mockTopology);
-//        deviceManager.topology = mockTopology;
-//
-//        Entity entity1 = new Entity(1L, null, null, 1L, 1, c.getTime());
-//        Entity entity1a = new Entity(1L, null, 1, 1L, 1, c.getTime());
-//        Entity entity2 = new Entity(1L, null, null, 5L, 1, c.getTime());
-//        Entity entity3 = new Entity(1L, null, null, 10L, 1, c.getTime());
-//        entity1.setLastSeenTimestamp(c.getTime());
-//        c.add(Calendar.MILLISECOND, Entity.ACTIVITY_TIMEOUT/2);
-//        entity1a.setLastSeenTimestamp(c.getTime());
-//        c.add(Calendar.MILLISECOND, 1);
-//        entity2.setLastSeenTimestamp(c.getTime());
-//        c.add(Calendar.MILLISECOND, 1);
-//        entity3.setLastSeenTimestamp(c.getTime());
-//
-//
-//
-//        IDevice d;
-//        d = deviceManager.learnDeviceByEntity(entity1);
-//        d = deviceManager.learnDeviceByEntity(entity1a);
-//        d = deviceManager.learnDeviceByEntity(entity2);
-//        d = deviceManager.learnDeviceByEntity(entity3);
-//
-//        // all entities are active, so entity3 should win
-//        assertArrayEquals(new SwitchPort[] { new SwitchPort(10L, 1) },
-//                          d.getAttachmentPoints());
-//
-//        assertArrayEquals(new SwitchPort[] { new SwitchPort(10L, 1),},
-//                              d.getAttachmentPoints(true));
-//
-//        c.add(Calendar.MILLISECOND, Entity.ACTIVITY_TIMEOUT/4);
-//        entity1.setLastSeenTimestamp(c.getTime());
-//        d = deviceManager.learnDeviceByEntity(entity1);
-//
-//        // all are still active; entity3 should still win
-//        assertArrayEquals(new SwitchPort[] { new SwitchPort(1L, 1) },
-//                          d.getAttachmentPoints());
-//        assertArrayEquals(new SwitchPort[] { new SwitchPort(1L, 1),
-//                                             new SwitchPort(5L, 1,
-//                                                            ErrorStatus.DUPLICATE_DEVICE),
-//                                                            new SwitchPort(10L, 1,
-//                                                                           ErrorStatus.DUPLICATE_DEVICE) },
-//                                                                           d.getAttachmentPoints(true));
-//
-//        c.add(Calendar.MILLISECOND, Entity.ACTIVITY_TIMEOUT+2000);
-//        entity1.setLastSeenTimestamp(c.getTime());
-//        d = deviceManager.learnDeviceByEntity(entity1);
-//
-//        assertEquals(entity1.getActiveSince(), entity1.getLastSeenTimestamp());
-//        // entity1 should now be the only active entity
-//        assertArrayEquals(new SwitchPort[] { new SwitchPort(1L, 1) },
-//                          d.getAttachmentPoints());
-//        assertArrayEquals(new SwitchPort[] { new SwitchPort(1L, 1) },
-//                          d.getAttachmentPoints(true));
-//    }
-//
-//
-//    @Test
-//    public void testAttachmentPointFlappingTwoCluster() throws Exception {
-//        Calendar c = Calendar.getInstance();
-//
-//        ITopologyService mockTopology = createMock(ITopologyService.class);
-//        expect(mockTopology.isAttachmentPointPort(anyLong(),
-//                                                  anyShort())).andReturn(true).anyTimes();
-//        expect(mockTopology.isBroadcastDomainPort(anyLong(),
-//                                                  anyShort())).
-//                                                  andReturn(false).anyTimes();
-//        expect(mockTopology.isInSameBroadcastDomain(anyLong(), anyShort(),
-//                                                    anyLong(), anyShort())).andReturn(false).anyTimes();
-//        expect(mockTopology.getL2DomainId(1L)).
-//        andReturn(1L).anyTimes();
-//        expect(mockTopology.getL2DomainId(5L)).
-//        andReturn(5L).anyTimes();
-//        expect(mockTopology.isConsistent(1L, (short)1, 1L, (short)2)).
-//        andReturn(false).anyTimes();
-//        expect(mockTopology.isConsistent(1L, (short)2, 5L, (short)1)).
-//        andReturn(false).anyTimes();
-//        expect(mockTopology.isConsistent(5L, (short)1, 5L, (short)2)).
-//        andReturn(false).anyTimes();
-//        expect(mockTopology.isConsistent(1L, (short)2, 1L, (short)1)).
-//        andReturn(false).anyTimes();
-//        expect(mockTopology.isConsistent(1L, (short)1, 5L, (short)1)).
-//        andReturn(false).anyTimes();
-//        expect(mockTopology.isConsistent(1L, (short)1, 5L, (short)2)).
-//        andReturn(false).anyTimes();
-//        expect(mockTopology.isConsistent(5L, (short)2, 5L, (short)1)).
-//        andReturn(false).anyTimes();
-//
-//        Date topologyUpdateTime = new Date();
-//        expect(mockTopology.getLastUpdateTime()).andReturn(topologyUpdateTime).
-//        anyTimes();
-//
-//        replay(mockTopology);
-//        deviceManager.topology = mockTopology;
-//
-//        Entity entity1 = new Entity(1L, null, null, 1L, 1, c.getTime());
-//        Entity entity2 = new Entity(1L, null, null, 1L, 2, c.getTime());
-//        Entity entity3 = new Entity(1L, null, null, 5L, 1, c.getTime());
-//        Entity entity4 = new Entity(1L, null, null, 5L, 2, c.getTime());
-//        entity1.setLastSeenTimestamp(c.getTime());
-//        c.add(Calendar.MILLISECOND, Entity.ACTIVITY_TIMEOUT/2);
-//        c.add(Calendar.MILLISECOND, 1);
-//        entity2.setLastSeenTimestamp(c.getTime());
-//        c.add(Calendar.MILLISECOND, 1);
-//        entity3.setLastSeenTimestamp(c.getTime());
-//        c.add(Calendar.MILLISECOND, 1);
-//        entity4.setLastSeenTimestamp(c.getTime());
-//
-//        deviceManager.learnDeviceByEntity(entity1);
-//        deviceManager.learnDeviceByEntity(entity2);
-//        deviceManager.learnDeviceByEntity(entity3);
-//        IDevice d = deviceManager.learnDeviceByEntity(entity4);
-//
-//        // all entities are active, so entities 2,4 should win
-//        assertArrayEquals(new SwitchPort[] { new SwitchPort(1L, 2),
-//                                             new SwitchPort(5L, 2) },
-//                                             d.getAttachmentPoints());
-//        assertArrayEquals(new SwitchPort[] { new SwitchPort(1L, 2),
-//                                             new SwitchPort(5L, 2)},
-//                                             d.getAttachmentPoints(true));
-//
-//        c.add(Calendar.MILLISECOND, 1);
-//        entity1.setLastSeenTimestamp(c.getTime());
-//        d = deviceManager.learnDeviceByEntity(entity1);
-//
-//        // all entities are active, so entities 2,4 should win
-//        assertArrayEquals(new SwitchPort[] { new SwitchPort(1L, 1),
-//                                             new SwitchPort(5L, 2) },
-//                                             d.getAttachmentPoints());
-//        assertArrayEquals(new SwitchPort[] { new SwitchPort(1L, 1),
-//                                             new SwitchPort(5L, 2),
-//                                             new SwitchPort(1L, 2, ErrorStatus.DUPLICATE_DEVICE)},
-//                                             d.getAttachmentPoints(true));
-//
-//        c.add(Calendar.MILLISECOND, Entity.ACTIVITY_TIMEOUT+1);
-//        entity1.setLastSeenTimestamp(c.getTime());
-//        d = deviceManager.learnDeviceByEntity(entity1);
-//
-//        // entities 3,4 are still in conflict, but 1 should be resolved
-//        assertArrayEquals(new SwitchPort[] { new SwitchPort(1L, 1),
-//                                             new SwitchPort(5L, 2) },
-//                                             d.getAttachmentPoints());
-//        assertArrayEquals(new SwitchPort[] { new SwitchPort(1L, 1),
-//                                             new SwitchPort(5L, 2)},
-//                                             d.getAttachmentPoints(true));
-//
-//        entity3.setLastSeenTimestamp(c.getTime());
-//        d = deviceManager.learnDeviceByEntity(entity3);
-//
-//        // no conflicts, 1 and 3 will win
-//        assertArrayEquals(new SwitchPort[] { new SwitchPort(1L, 1),
-//                                             new SwitchPort(5L, 1) },
-//                                             d.getAttachmentPoints());
-//        assertArrayEquals(new SwitchPort[] { new SwitchPort(1L, 1),
-//                                             new SwitchPort(5L, 1) },
-//                                             d.getAttachmentPoints(true));
-//
-//    }
-//
-//    protected void doTestDeviceQuery() throws Exception {
-//        Entity entity1 = new Entity(1L, (short)1, 1, 1L, 1, new Date());
-//        Entity entity2 = new Entity(2L, (short)2, 2, 1L, 2, new Date());
-//        Entity entity3 = new Entity(3L, (short)3, 3, 5L, 1, new Date());
-//        Entity entity4 = new Entity(4L, (short)4, 3, 5L, 2, new Date());
-//        Entity entity5 = new Entity(1L, (short)4, 3, 5L, 2, new Date());
-//
-//        Device d1 = deviceManager.learnDeviceByEntity(entity1);
-//        deviceManager.learnDeviceByEntity(entity2);
-//        Device d3 = deviceManager.learnDeviceByEntity(entity3);
-//        Device d4 = deviceManager.learnDeviceByEntity(entity4);
-//
-//        IDevice d;
-//
-//        Iterator<? extends IDevice> iter =
-//                deviceManager.queryDevices(null, (short)1, 1, null, null);
-//        int count = 0;
-//        while (iter.hasNext()) {
-//            count += 1;
-//            d = iter.next();
-//            assertEquals(d1.getDeviceKey(), d.getDeviceKey());
-//        }
-//        assertEquals(1, count);
-//
-//        iter = deviceManager.queryDevices(null, (short)3, 3, null, null);
-//        count = 0;
-//        while (iter.hasNext()) {
-//            count += 1;
-//            d = iter.next();
-//            assertEquals(d3.getDeviceKey(), d.getDeviceKey());
-//        }
-//        assertEquals(1, count);
-//
-//        iter = deviceManager.queryDevices(null, (short)1, 3, null, null);
-//        count = 0;
-//        while (iter.hasNext()) {
-//            count += 1;
-//            iter.next();
-//        }
-//        assertEquals(0, count);
-//
-//        Device d5 = deviceManager.learnDeviceByEntity(entity5);
-//        iter = deviceManager.queryDevices(null, (short)4, 3, null, null);
-//        count = 0;
-//        Set<Long> deviceKeysFromIterator = new HashSet<Long>();
-//        while (iter.hasNext()) {
-//            count += 1;
-//            d = iter.next();
-//            deviceKeysFromIterator.add(d.getDeviceKey());
-//        }
-//        Set<Long> expectedDeviceKeys = new HashSet<Long>();
-//        expectedDeviceKeys.add(d4.getDeviceKey());
-//        expectedDeviceKeys.add(d5.getDeviceKey());
-//        assertEquals(expectedDeviceKeys, deviceKeysFromIterator);
-//        assertEquals(2, count);
-//
-//
-//        iter = deviceManager.queryDevices(1L, null, null, null, null);
-//        count = 0;
-//        deviceKeysFromIterator = new HashSet<Long>();
-//        while (iter.hasNext()) {
-//            count += 1;
-//            d = iter.next();
-//            deviceKeysFromIterator.add(d.getDeviceKey());
-//        }
-//        expectedDeviceKeys = new HashSet<Long>();
-//        expectedDeviceKeys.add(d1.getDeviceKey());
-//        expectedDeviceKeys.add(d5.getDeviceKey());
-//        assertEquals(expectedDeviceKeys, deviceKeysFromIterator);
-//        assertEquals(2, count);
-//    }
-//
-//    @Test
-//    public void testDeviceIndex() throws Exception {
-//        EnumSet<IDeviceService.DeviceField> indexFields =
-//                EnumSet.noneOf(IDeviceService.DeviceField.class);
-//        indexFields.add(IDeviceService.DeviceField.IPV4);
-//        indexFields.add(IDeviceService.DeviceField.VLAN);
-//        deviceManager.addIndex(false, indexFields);
-//
-//        indexFields = EnumSet.noneOf(IDeviceService.DeviceField.class);
-//        deviceManager.addIndex(false, indexFields);
-//
-//        ITopologyService mockTopology = createMock(ITopologyService.class);
-//        deviceManager.topology = mockTopology;
-//        expect(mockTopology.isAttachmentPointPort(anyLong(),
-//                                                  anyShort())).
-//                                                  andReturn(true).anyTimes();
-//        expect(mockTopology.getL2DomainId(EasyMock.anyLong())).andReturn(1L).anyTimes();
-//        replay(mockTopology);
-//        doTestDeviceQuery();
-//    }
-//
-//    @Test
-//    public void testDeviceQuery() throws Exception {
-//        ITopologyService mockTopology = createMock(ITopologyService.class);
-//        deviceManager.topology = mockTopology;
-//        expect(mockTopology.isAttachmentPointPort(anyLong(),
-//                                                  anyShort())).
-//                                                  andReturn(true).anyTimes();
-//        expect(mockTopology.getL2DomainId(EasyMock.anyLong())).andReturn(1L).anyTimes();
-//        replay(mockTopology);
-//
-//        doTestDeviceQuery();
-//    }
-//
-//    protected void doTestDeviceClassQuery() throws Exception {
-//        Entity entity1 = new Entity(1L, (short)1, 1, 1L, 1, new Date());
-//        Entity entity2 = new Entity(2L, (short)2, 2, 1L, 2, new Date());
-//        Entity entity3 = new Entity(3L, (short)3, 3, 5L, 1, new Date());
-//        Entity entity4 = new Entity(4L, (short)4, 3, 5L, 2, new Date());
-//        Entity entity5 = new Entity(1L, (short)4, 3, 5L, 2, new Date());
-//
-//        IDevice d1 = deviceManager.learnDeviceByEntity(entity1);
-//        IDevice d2 = deviceManager.learnDeviceByEntity(entity2);
-//        IDevice d3 = deviceManager.learnDeviceByEntity(entity3);
-//        IDevice d4 = deviceManager.learnDeviceByEntity(entity4);
-//        assertEquals(d1.getEntityClass(), d2.getEntityClass());
-//        assertEquals(d1.getEntityClass(), d3.getEntityClass());
-//        assertEquals(d1.getEntityClass(), d4.getEntityClass());
-//
-//        IDevice d;
-//
-//        Iterator<? extends IDevice> iter =
-//                deviceManager.queryClassDevices(d1.getEntityClass(), null,
-//                                                (short)1, 1, null, null);
-//        int count = 0;
-//        while (iter.hasNext()) {
-//            count += 1;
-//            d = iter.next();
-//            assertEquals(d1.getDeviceKey(), d.getDeviceKey());
-//        }
-//        assertEquals(1, count);
-//
-//        iter = deviceManager.queryClassDevices(d1.getEntityClass(), null,
-//                                               (short)3, 3, null, null);
-//        count = 0;
-//        while (iter.hasNext()) {
-//            count += 1;
-//            d = iter.next();
-//            assertEquals(d3.getDeviceKey(), d.getDeviceKey());
-//
-//        }
-//        assertEquals(1, count);
-//
-//        iter = deviceManager.queryClassDevices(d1.getEntityClass(), null,
-//                                               (short)1, 3, null, null);
-//        count = 0;
-//        while (iter.hasNext()) {
-//            count += 1;
-//            iter.next();
-//        }
-//        assertEquals(0, count);
-//
-//        IDevice d5 = deviceManager.learnDeviceByEntity(entity5);
-//        assertEquals(d1.getEntityClass(), d5.getEntityClass());
-//        iter = deviceManager.queryClassDevices(d1.getEntityClass(), null,
-//                                               (short)4, 3, null, null);
-//        count = 0;
-//        Set<Long> deviceKeysFromIterator = new HashSet<Long>();
-//        while (iter.hasNext()) {
-//            count += 1;
-//            d = iter.next();
-//            deviceKeysFromIterator.add(d.getDeviceKey());
-//        }
-//        Set<Long> expectedDeviceKeys = new HashSet<Long>();
-//        expectedDeviceKeys.add(d4.getDeviceKey());
-//        expectedDeviceKeys.add(d5.getDeviceKey());
-//        assertEquals(expectedDeviceKeys, deviceKeysFromIterator);
-//        assertEquals(2, count);
-//    }
-//
-//    @Test
-//    public void testDeviceClassIndex() throws Exception {
-//        EnumSet<IDeviceService.DeviceField> indexFields =
-//                EnumSet.noneOf(IDeviceService.DeviceField.class);
-//        indexFields.add(IDeviceService.DeviceField.IPV4);
-//        indexFields.add(IDeviceService.DeviceField.VLAN);
-//        deviceManager.addIndex(true, indexFields);
-//
-//        ITopologyService mockTopology = createMock(ITopologyService.class);
-//        deviceManager.topology = mockTopology;
-//        expect(mockTopology.isAttachmentPointPort(anyLong(),
-//                                                  anyShort())).
-//                                                  andReturn(true).anyTimes();
-//        expect(mockTopology.getL2DomainId(EasyMock.anyLong())).andReturn(1L).anyTimes();
-//        replay(mockTopology);
-//
-//        doTestDeviceClassQuery();
-//    }
-//
-//    @Test
-//    public void testDeviceClassQuery() throws Exception {
-//        ITopologyService mockTopology = createMock(ITopologyService.class);
-//        deviceManager.topology = mockTopology;
-//        expect(mockTopology.isAttachmentPointPort(anyLong(),
-//                                                  anyShort())).
-//                                                  andReturn(true).anyTimes();
-//        expect(mockTopology.getL2DomainId(EasyMock.anyLong())).andReturn(1L).anyTimes();
-//        replay(mockTopology);
-//
-//        doTestDeviceClassQuery();
-//    }
-//
-//    @Test
-//    public void testFindDevice() throws FloodlightModuleException {
-//        boolean exceptionCaught;
-//        deviceManager.entityClassifier= new MockEntityClassifierMac();
-//        deviceManager.startUp(null);
-//
-//        ITopologyService mockTopology = createMock(ITopologyService.class);
-//        deviceManager.topology = mockTopology;
-//        expect(mockTopology.isAttachmentPointPort(anyLong(),
-//                                                  anyShort())).
-//                                                  andReturn(true).anyTimes();
-//        expect(mockTopology.getL2DomainId(EasyMock.anyLong())).andReturn(1L).anyTimes();
-//        replay(mockTopology);
-//
-//        Entity entity1 = new Entity(1L, (short)1, 1, 1L, 1, new Date());
-//        Entity entity2 = new Entity(2L, (short)2, 2, 1L, 2, new Date());
-//        Entity entity2b = new Entity(22L, (short)2, 2, 1L, 2, new Date());
-//
-//        Entity entity3 = new Entity(3L, (short)1, 3, 2L, 1, new Date());
-//        Entity entity4 = new Entity(4L, (short)2, 4, 2L, 2, new Date());
-//
-//        Entity entity5 = new Entity(5L, (short)1, 5, 3L, 1, new Date());
-//
-//
-//        IDevice d1 = deviceManager.learnDeviceByEntity(entity1);
-//        IDevice d2 = deviceManager.learnDeviceByEntity(entity2);
-//        IDevice d3 = deviceManager.learnDeviceByEntity(entity3);
-//        IDevice d4 = deviceManager.learnDeviceByEntity(entity4);
-//        IDevice d5 = deviceManager.learnDeviceByEntity(entity5);
-//
-//        // Make sure the entity classifier worked as expected
-//        assertEquals(MockEntityClassifierMac.testECMac1, d1.getEntityClass());
-//        assertEquals(MockEntityClassifierMac.testECMac1, d2.getEntityClass());
-//        assertEquals(MockEntityClassifierMac.testECMac2, d3.getEntityClass());
-//        assertEquals(MockEntityClassifierMac.testECMac2, d4.getEntityClass());
-//        assertEquals(DefaultEntityClassifier.entityClass,
-//                     d5.getEntityClass());
-//
-//        // Look up the device using findDevice() which uses only the primary
-//        // index
-//        assertEquals(d1, deviceManager.findDevice(entity1.getMacAddress(),
-//                                                  entity1.getVlan(),
-//                                                  entity1.getIpv4Address(),
-//                                                  entity1.getSwitchDPID(),
-//                                                  entity1.getSwitchPort()));
-//        // port changed. Device will be found through class index
-//        assertEquals(d1, deviceManager.findDevice(entity1.getMacAddress(),
-//                                                  entity1.getVlan(),
-//                                                  entity1.getIpv4Address(),
-//                                                  entity1.getSwitchDPID(),
-//                                                  entity1.getSwitchPort()+1));
-//        // VLAN changed. No device matches
-//        assertEquals(null, deviceManager.findDevice(entity1.getMacAddress(),
-//                                                  (short)42,
-//                                                  entity1.getIpv4Address(),
-//                                                  entity1.getSwitchDPID(),
-//                                                  entity1.getSwitchPort()));
-//        assertEquals(null, deviceManager.findDevice(entity1.getMacAddress(),
-//                                                  null,
-//                                                  entity1.getIpv4Address(),
-//                                                  entity1.getSwitchDPID(),
-//                                                  entity1.getSwitchPort()));
-//        assertEquals(d2, deviceManager.findDeviceByEntity(entity2));
-//        assertEquals(null, deviceManager.findDeviceByEntity(entity2b));
-//        assertEquals(d3, deviceManager.findDevice(entity3.getMacAddress(),
-//                                                  entity3.getVlan(),
-//                                                  entity3.getIpv4Address(),
-//                                                  entity3.getSwitchDPID(),
-//                                                  entity3.getSwitchPort()));
-//        // switch and port not set. throws exception
-//        exceptionCaught = false;
-//        try {
-//            assertEquals(null, deviceManager.findDevice(entity3.getMacAddress(),
-//                                                        entity3.getVlan(),
-//                                                        entity3.getIpv4Address(),
-//                                                        null,
-//                                                        null));
-//        }
-//        catch (IllegalArgumentException e) {
-//            exceptionCaught = true;
-//        }
-//        if (!exceptionCaught)
-//            fail("findDevice() did not throw IllegalArgumentException");
-//        assertEquals(d4, deviceManager.findDeviceByEntity(entity4));
-//        assertEquals(d5, deviceManager.findDevice(entity5.getMacAddress(),
-//                                                  entity5.getVlan(),
-//                                                  entity5.getIpv4Address(),
-//                                                  entity5.getSwitchDPID(),
-//                                                  entity5.getSwitchPort()));
-//        // switch and port not set. throws exception (swith/port are key
-//        // fields of IEntityClassifier but not d5.entityClass
-//        exceptionCaught = false;
-//        try {
-//            assertEquals(d5, deviceManager.findDevice(entity5.getMacAddress(),
-//                                                      entity5.getVlan(),
-//                                                      entity5.getIpv4Address(),
-//                                                      null,
-//                                                      null));
-//        }
-//        catch (IllegalArgumentException e) {
-//            exceptionCaught = true;
-//        }
-//        if (!exceptionCaught)
-//            fail("findDevice() did not throw IllegalArgumentException");
-//
-//
-//        Entity entityNoClass = new Entity(5L, (short)1, 5, -1L, 1, new Date());
-//        assertEquals(null, deviceManager.findDeviceByEntity(entityNoClass));
-//
-//
-//        // Now look up destination devices
-//        assertEquals(d1, deviceManager.findClassDevice(d2.getEntityClass(),
-//                                                  entity1.getMacAddress(),
-//                                                  entity1.getVlan(),
-//                                                  entity1.getIpv4Address()));
-//        assertEquals(d1, deviceManager.findClassDevice(d2.getEntityClass(),
-//                                                  entity1.getMacAddress(),
-//                                                  entity1.getVlan(),
-//                                                  null));
-//        assertEquals(null, deviceManager.findClassDevice(d2.getEntityClass(),
-//                                                  entity1.getMacAddress(),
-//                                                  (short) -1,
-//                                                  0));
-//    }
-//
-//
-//
-//    @Test
-//    public void testGetIPv4Addresses() {
-//        // Looks like Date is only 1s granularity
-//
-//        ITopologyService mockTopology = createMock(ITopologyService.class);
-//        deviceManager.topology = mockTopology;
-//        expect(mockTopology.isAttachmentPointPort(anyLong(),
-//                                                  anyShort())).
-//                                                  andReturn(true).anyTimes();
-//        expect(mockTopology.getL2DomainId(anyLong())).andReturn(1L).anyTimes();
-//        expect(mockTopology.isConsistent(EasyMock.anyLong(),
-//                                         EasyMock.anyShort(),
-//                                         EasyMock.anyLong(),
-//                                         EasyMock.anyShort()))
-//                                         .andReturn(false)
-//                                         .anyTimes();
-//        expect(mockTopology.isBroadcastDomainPort(EasyMock.anyLong(),
-//                                                  EasyMock.anyShort()))
-//                                                  .andReturn(false)
-//                                                  .anyTimes();
-//        expect(mockTopology.isInSameBroadcastDomain(EasyMock.anyLong(),
-//                                                    EasyMock.anyShort(),
-//                                                    EasyMock.anyLong(),
-//                                                    EasyMock.anyShort())).
-//                                                    andReturn(false).anyTimes();
-//        replay(mockTopology);
-//
-//        Entity e1 = new Entity(1L, (short)1, null, null, null, new Date(2000));
-//        Device d1 = deviceManager.learnDeviceByEntity(e1);
-//        assertArrayEquals(new Integer[0], d1.getIPv4Addresses());
-//
-//
-//        Entity e2 = new Entity(2L, (short)2, 2, null, null, new Date(2000));
-//        Device d2 = deviceManager.learnDeviceByEntity(e2);
-//        d2 = deviceManager.learnDeviceByEntity(e2);
-//        assertArrayEquals(new Integer[] { 2 }, d2.getIPv4Addresses());
-//        // More than one entity
-//        Entity e2b = new Entity(2L, (short)2, null, 2L, 2, new Date(3000));
-//        d2 = deviceManager.learnDeviceByEntity(e2b);
-//        assertEquals(2, d2.entities.length);
-//        assertArrayEquals(new Integer[] { 2 }, d2.getIPv4Addresses());
-//        // and now add an entity with an IP
-//        Entity e2c = new Entity(2L, (short)2, 2, 2L, 3, new Date(3000));
-//        d2 = deviceManager.learnDeviceByEntity(e2c);
-//        assertArrayEquals(new Integer[] { 2 }, d2.getIPv4Addresses());
-//        assertEquals(3, d2.entities.length);
-//
-//        // Other devices with different IPs shouldn't interfere
-//        Entity e3 = new Entity(3L, (short)3, 3, null, null, new Date(4000));
-//        Entity e3b = new Entity(3L, (short)3, 3, 3L, 3, new Date(4400));
-//        Device d3 = deviceManager.learnDeviceByEntity(e3);
-//        d3 = deviceManager.learnDeviceByEntity(e3b);
-//        assertArrayEquals(new Integer[] { 2 }, d2.getIPv4Addresses());
-//        assertArrayEquals(new Integer[] { 3 }, d3.getIPv4Addresses());
-//
-//        // Add another IP to d3
-//        Entity e3c = new Entity(3L, (short)3, 33, 3L, 3, new Date(4400));
-//        d3 = deviceManager.learnDeviceByEntity(e3c);
-//        Integer[] ips = d3.getIPv4Addresses();
-//        Arrays.sort(ips);
-//        assertArrayEquals(new Integer[] { 3, 33 }, ips);
-//
-//        // Add another device that also claims IP2 but is older than e2
-//        Entity e4 = new Entity(4L, (short)4, 2, null, null, new Date(1000));
-//        Entity e4b = new Entity(4L, (short)4, null, 4L, 4, new Date(1000));
-//        Device d4 = deviceManager.learnDeviceByEntity(e4);
-//        assertArrayEquals(new Integer[] { 2 }, d2.getIPv4Addresses());
-//        assertArrayEquals(new Integer[0],  d4.getIPv4Addresses());
-//        // add another entity to d4
-//        d4 = deviceManager.learnDeviceByEntity(e4b);
-//        assertArrayEquals(new Integer[0], d4.getIPv4Addresses());
-//
-//        // Make e4 and e4a newer
-//        Entity e4c = new Entity(4L, (short)4, 2, null, null, new Date(5000));
-//        Entity e4d = new Entity(4L, (short)4, null, 4L, 5, new Date(5000));
-//        d4 = deviceManager.learnDeviceByEntity(e4c);
-//        d4 = deviceManager.learnDeviceByEntity(e4d);
-//        assertArrayEquals(new Integer[0], d2.getIPv4Addresses());
-//        // FIXME: d4 should not return IP4
-//        assertArrayEquals(new Integer[] { 2 }, d4.getIPv4Addresses());
-//
-//        // Add another newer entity to d2 but with different IP
-//        Entity e2d = new Entity(2L, (short)2, 22, 4L, 6, new Date(6000));
-//        d2 = deviceManager.learnDeviceByEntity(e2d);
-//        assertArrayEquals(new Integer[] { 22 }, d2.getIPv4Addresses());
-//        assertArrayEquals(new Integer[] { 2 }, d4.getIPv4Addresses());
-//
-//        // new IP for d2,d4 but with same timestamp. Both devices get the IP
-//        Entity e2e = new Entity(2L, (short)2, 42, 2L, 4, new Date(7000));
-//        d2 = deviceManager.learnDeviceByEntity(e2e);
-//        ips= d2.getIPv4Addresses();
-//        Arrays.sort(ips);
-//        assertArrayEquals(new Integer[] { 22, 42 }, ips);
-//        Entity e4e = new Entity(4L, (short)4, 42, 4L, 7, new Date(7000));
-//        d4 = deviceManager.learnDeviceByEntity(e4e);
-//        ips= d4.getIPv4Addresses();
-//        Arrays.sort(ips);
-//        assertArrayEquals(new Integer[] { 2, 42 }, ips);
-//
-//        // add a couple more IPs
-//        Entity e2f = new Entity(2L, (short)2, 4242, 2L, 5, new Date(8000));
-//        d2 = deviceManager.learnDeviceByEntity(e2f);
-//        ips= d2.getIPv4Addresses();
-//        Arrays.sort(ips);
-//        assertArrayEquals(new Integer[] { 22, 42, 4242 }, ips);
-//        Entity e4f = new Entity(4L, (short)4, 4242, 4L, 8, new Date(9000));
-//        d4 = deviceManager.learnDeviceByEntity(e4f);
-//        ips= d4.getIPv4Addresses();
-//        Arrays.sort(ips);
-//        assertArrayEquals(new Integer[] { 2, 42, 4242 }, ips);
-//    }
-//
-//    // TODO: this test should really go into a separate class that collects
-//    // unit tests for Device
-//    @Test
-//    public void testGetSwitchPortVlanId() {
-//            Entity entity1 = new Entity(1L, (short)1, null, 10L, 1, new Date());
-//            Entity entity2 = new Entity(1L, null, null, 10L, 1, new Date());
-//            Entity entity3 = new Entity(1L, (short)3, null,  1L, 1, new Date());
-//            Entity entity4 = new Entity(1L, (short)42, null,  1L, 1, new Date());
-//            Entity[] entities = new Entity[] { entity1, entity2,
-//                                               entity3, entity4
-//                                             };
-//            Device d = new Device(null,1L, null, null, null,
-//                                  Arrays.asList(entities), null);
-//            SwitchPort swp1x1 = new SwitchPort(1L, 1);
-//            SwitchPort swp1x2 = new SwitchPort(1L, 2);
-//            SwitchPort swp2x1 = new SwitchPort(2L, 1);
-//            SwitchPort swp10x1 = new SwitchPort(10L, 1);
-//            assertArrayEquals(new Short[] { -1, 1},
-//                              d.getSwitchPortVlanIds(swp10x1));
-//            assertArrayEquals(new Short[] { 3, 42},
-//                              d.getSwitchPortVlanIds(swp1x1));
-//            assertArrayEquals(new Short[0],
-//                              d.getSwitchPortVlanIds(swp1x2));
-//            assertArrayEquals(new Short[0],
-//                              d.getSwitchPortVlanIds(swp2x1));
-//    }
-//
-//    @Test
-//    public void testReclassifyDevice() throws FloodlightModuleException {
-//        MockFlexEntityClassifier flexClassifier =
-//                new MockFlexEntityClassifier();
-//        deviceManager.entityClassifier= flexClassifier;
-//        deviceManager.startUp(null);
-//
-//        ITopologyService mockTopology = createMock(ITopologyService.class);
-//        deviceManager.topology = mockTopology;
-//        expect(mockTopology.isAttachmentPointPort(anyLong(),
-//                                                  anyShort())).
-//                                                  andReturn(true).anyTimes();
-//        expect(mockTopology.getL2DomainId(anyLong())).andReturn(1L).anyTimes();
-//        expect(mockTopology.isConsistent(EasyMock.anyLong(),
-//                                         EasyMock.anyShort(),
-//                                         EasyMock.anyLong(),
-//                                         EasyMock.anyShort()))
-//                                         .andReturn(false)
-//                                         .anyTimes();
-//        expect(mockTopology.isBroadcastDomainPort(EasyMock.anyLong(),
-//                                                  EasyMock.anyShort()))
-//                                                  .andReturn(false)
-//                                                  .anyTimes();
-//        replay(mockTopology);
-//
-//        //flexClassifier.createTestEntityClass("Class1");
-//
-//        Entity entity1 = new Entity(1L, (short)1, 1, 1L, 1, new Date());
-//        Entity entity1b = new Entity(1L, (short)2, 1, 1L, 1, new Date());
-//        Entity entity2 = new Entity(2L, (short)1, 2, 2L, 2, new Date());
-//        Entity entity2b = new Entity(2L, (short)2, 2, 2L, 2, new Date());
-//
-//
-//        Device d1 = deviceManager.learnDeviceByEntity(entity1);
-//        Device d2 = deviceManager.learnDeviceByEntity(entity2);
-//        Device d1b = deviceManager.learnDeviceByEntity(entity1b);
-//        Device d2b = deviceManager.learnDeviceByEntity(entity2b);
-//
-//        d1 = deviceManager.getDeviceIteratorForQuery(entity1.getMacAddress(),
-//                        entity1.getVlan(), entity1.getIpv4Address(),
-//                        entity1.getSwitchDPID(), entity1.getSwitchPort())
-//                        .next();
-//        d1b = deviceManager.getDeviceIteratorForQuery(entity1b.getMacAddress(),
-//                entity1b.getVlan(), entity1b.getIpv4Address(),
-//                entity1b.getSwitchDPID(), entity1b.getSwitchPort()).next();
-//
-//        assertEquals(d1, d1b);
-//
-//        d2 = deviceManager.getDeviceIteratorForQuery(entity2.getMacAddress(),
-//                entity2.getVlan(), entity2.getIpv4Address(),
-//                entity2.getSwitchDPID(), entity2.getSwitchPort()).next();
-//        d2b = deviceManager.getDeviceIteratorForQuery(entity2b.getMacAddress(),
-//                entity2b.getVlan(), entity2b.getIpv4Address(),
-//                entity2b.getSwitchDPID(), entity2b.getSwitchPort()).next();
-//        assertEquals(d2, d2b);
-//
-//        IEntityClass eC1 = flexClassifier.createTestEntityClass("C1");
-//        IEntityClass eC2 = flexClassifier.createTestEntityClass("C2");
-//
-//        flexClassifier.addVlanEntities((short)1, eC1);
-//        flexClassifier.addVlanEntities((short)2, eC1);
-//
-//        deviceManager.reclassifyDevice(d1);
-//        deviceManager.reclassifyDevice(d2);
-//
-//        d1 = deviceManager.deviceMap.get(
-//                deviceManager.primaryIndex.findByEntity(entity1));
-//        d1b = deviceManager.deviceMap.get(
-//                deviceManager.primaryIndex.findByEntity(entity1b));
-//
-//        assertEquals(d1, d1b);
-//
-//        d2 = deviceManager.deviceMap.get(
-//                deviceManager.primaryIndex.findByEntity(entity2));
-//        d2b = deviceManager.deviceMap.get(
-//                deviceManager.primaryIndex.findByEntity(entity2b));
-//
-//        assertEquals(d2, d2b);
-//
-//        flexClassifier.addVlanEntities((short)1, eC2);
-//
-//        deviceManager.reclassifyDevice(d1);
-//        deviceManager.reclassifyDevice(d2);
-//        d1 = deviceManager.deviceMap.get(
-//                deviceManager.primaryIndex.findByEntity(entity1));
-//        d1b = deviceManager.deviceMap.get(
-//                deviceManager.primaryIndex.findByEntity(entity1b));
-//        d2 = deviceManager.deviceMap.get(
-//                deviceManager.primaryIndex.findByEntity(entity2));
-//        d2b = deviceManager.deviceMap.get(
-//                deviceManager.primaryIndex.findByEntity(entity2b));
-//
-//        assertNotSame(d1, d1b);
-//
-//        assertNotSame(d2, d2b);
-//
-//        flexClassifier.addVlanEntities((short)1, eC1);
-//        deviceManager.reclassifyDevice(d1);
-//        deviceManager.reclassifyDevice(d2);
-//        ClassState classState = deviceManager.classStateMap.get(eC1.getName());
-//
-//        Long deviceKey1 = null;
-//        Long deviceKey1b = null;
-//        Long deviceKey2 = null;
-//        Long deviceKey2b = null;
-//
-//        deviceKey1 =
-//                classState.classIndex.findByEntity(entity1);
-//        deviceKey1b =
-//                classState.classIndex.findByEntity(entity1b);
-//        deviceKey2 =
-//                classState.classIndex.findByEntity(entity2);
-//        deviceKey2b =
-//                classState.classIndex.findByEntity(entity2b);
-//
-//        assertEquals(deviceKey1, deviceKey1b);
-//
-//        assertEquals(deviceKey2, deviceKey2b);
-//    }
-//
-//    @Test
-//    public void testSyncEntity() {
-//        Date d1 = new Date();
-//        Date d2 = new Date(0);
-//        Entity e1 = new Entity(1L, (short)2, 3, 4L, 5, d1);
-//        e1.setActiveSince(d2);
-//        SyncEntity se1 = new SyncEntity(e1);
-//        assertEntityEquals(e1, se1);
-//        assertEquals(1L, se1.macAddress);
-//        assertEquals(Short.valueOf((short)2), se1.vlan);
-//        assertEquals(Integer.valueOf(3), se1.ipv4Address);
-//        assertEquals(Long.valueOf(4L), se1.switchDPID);
-//        assertEquals(Integer.valueOf(5), se1.switchPort);
-//        assertEquals(d1, se1.lastSeenTimestamp);
-//        assertEquals(d2, se1.activeSince);
-//        assertNotSame(d1, se1.lastSeenTimestamp);
-//        assertNotSame(d2, se1.activeSince);
-//
-//        Entity e2 = new Entity(42L, null, null, null, null, null);
-//        SyncEntity se2 = new SyncEntity(e2);
-//        assertEntityEquals(e2, se2);
-//
-//        SyncEntity se3 = new SyncEntity();
-//        SyncEntity se4 = new SyncEntity();
-//        se3.lastSeenTimestamp = new Date(1000);
-//        se4.lastSeenTimestamp = new Date(2000);
-//        assertTrue("", se3.compareTo(se4) < 0);
-//        assertTrue("", se4.compareTo(se3) > 0);
-//        se4.lastSeenTimestamp = new Date(1000);
-//        assertTrue("", se3.compareTo(se4) == 0);
-//        assertTrue("", se4.compareTo(se3) == 0);
-//        se4.lastSeenTimestamp = new Date(500);
-//        assertTrue("", se3.compareTo(se4) > 0);
-//        assertTrue("", se4.compareTo(se3) < 0);
-//    }
-//
-//    /* Test basic DeviceSyncRepresentation behavior */
-//    @Test
-//    public void testDeviceSyncRepresentationBasics() {
-//        DeviceSyncRepresentation dsr = new DeviceSyncRepresentation();
-//        assertNull(dsr.getKey());
-//        assertNull(dsr.getEntities());
-//        dsr.setKey("MyKey");
-//        assertEquals("MyKey", dsr.getKey());
-//        assertEquals("MyKey", dsr.toString());
-//
-//        List<SyncEntity> entities = new ArrayList<SyncEntity>();
-//        Entity e1a = new Entity(1L, (short)2, 3, 4L, 5, new Date(1000));
-//        Entity e1b = new Entity(1L, (short)2, null, 4L, 5, new Date(0));
-//        entities.add(new SyncEntity(e1a));
-//        entities.add(new SyncEntity(e1b));
-//        // e1b comes before e1 (lastSeen) but we add it after it to test
-//        // sorting
-//        dsr.setEntities(entities);
-//
-//        assertEquals(2, dsr.getEntities().size());
-//        // e1b has earlier time
-//        assertEquals(e1b, dsr.getEntities().get(0).asEntity());
-//        assertEquals(e1a, dsr.getEntities().get(1).asEntity());
-//
-//        dsr.setKey(null);
-//        dsr.setEntities(null);
-//        assertNull(dsr.getKey());
-//        assertNull(dsr.getEntities());
-//    }
-//
-//    @Test
-//    public void testDeviceSyncRepresentationFromDevice() {
-//        ITopologyService mockTopology = makeMockTopologyAllPortsAp();
-//        replay(mockTopology);
-//        deviceManager.topology = mockTopology;
-//
-//        deviceManager.entityClassifier = new MockEntityClassifier();
-//
-//        //**************************************
-//        // Test 1: a single entity
-//        Entity e1 = new Entity(1L, (short)2, 3, 4L, 5, new Date(1000));
-//        Device d1 = deviceManager.learnDeviceByEntity(e1);
-//        assertEquals("Sanity check failed. Device doesn't have the expected " +
-//                     "entity class. Something with the test setup is strange",
-//                     "DefaultEntityClass", d1.getEntityClass().getName());
-//        assertEquals("Sanity check failed. Device doesn't have the expected " +
-//                     "entity class. Something with the test setup is strange",
-//                     EnumSet.of(DeviceField.MAC, DeviceField.VLAN),
-//                     d1.getEntityClass().getKeyFields());
-//
-//        Long deviceKey = d1.getDeviceKey();
-//        DeviceSyncRepresentation dsr1 = new DeviceSyncRepresentation(d1);
-//        assertEquals("DefaultEntityClass::00:00:00:00:00:01::[2]::",
-//                     dsr1.getKey());
-//        assertEquals(1, dsr1.getEntities().size());
-//        assertEquals(e1, dsr1.getEntities().get(0).asEntity());
-//
-//        //**************************************
-//        // Test 1b: same device, now with a second entity (no IP).
-//        // this second entity has a lastSeen time that is earlier than the
-//        // first entity
-//        Entity e1b = new Entity(1L, (short)2, null, 4L, 5, new Date(0));
-//        d1 = deviceManager.learnDeviceByEntity(e1b);
-//        assertEquals("Sanity check failed. Should still be same device but " +
-//                     "deviceKeys differs", deviceKey, d1.getDeviceKey());
-//        dsr1 = new DeviceSyncRepresentation(d1);
-//        assertEquals("DefaultEntityClass::00:00:00:00:00:01::[2]::",
-//                     dsr1.getKey());
-//        assertEquals(2, dsr1.getEntities().size());
-//        // Entities are ordered by their lastSeen time. e1b should come
-//        // before e1.
-//        assertEquals(e1, dsr1.getEntities().get(1).asEntity());
-//        assertEquals(e1b, dsr1.getEntities().get(0).asEntity());
-//
-//        //**************************************
-//        // Test 1c: same device with a third entity that does not have a
-//        // switch port. It should be added to the DeviceSyncRepresentation
-//        Entity e1c = new Entity(1L, (short)2, 33, null, null, new Date(2000));
-//        d1 = deviceManager.learnDeviceByEntity(e1c);
-//        assertEquals("Sanity check failed. Should still be same device but " +
-//                     "deviceKeys differs", deviceKey, d1.getDeviceKey());
-//        dsr1 = new DeviceSyncRepresentation(d1);
-//        assertEquals("DefaultEntityClass::00:00:00:00:00:01::[2]::",
-//                     dsr1.getKey());
-//        assertEquals(3, dsr1.getEntities().size());
-//        // Entities are ordered by their lastSeen time
-//        assertEquals(e1c, dsr1.getEntities().get(2).asEntity());
-//        assertEquals(e1, dsr1.getEntities().get(1).asEntity());
-//        assertEquals(e1b, dsr1.getEntities().get(0).asEntity());
-//
-//        //**************************************
-//        // Test 1d: same device with a fourth entity that has a different
-//        // attachment point and that is newer. Device should move and
-//        // non-attachment point entities should be removed (e1b). Although
-//        // e1 is non-attachment point it will remain because it has an IP
-//        Entity e1d = new Entity(1L, (short)2, 33, 4L, 6, new Date(3000));
-//        d1 = deviceManager.learnDeviceByEntity(e1d);
-//        assertEquals("Sanity check failed. Should still be same device but " +
-//                     "deviceKeys differs", deviceKey, d1.getDeviceKey());
-//        dsr1 = new DeviceSyncRepresentation(d1);
-//        assertEquals("DefaultEntityClass::00:00:00:00:00:01::[2]::",
-//                     dsr1.getKey());
-//        assertEquals(3, dsr1.getEntities().size());
-//        assertEquals(e1, dsr1.getEntities().get(0).asEntity());
-//        assertEquals(e1c, dsr1.getEntities().get(1).asEntity());
-//        assertEquals(e1d, dsr1.getEntities().get(2).asEntity());
-//
-//        d1 = null;
-//
-//
-//        //**************************************
-//        // Test 2: a second device with a different entity class. The
-//        // mock entity classifier will return an entity class where all
-//        // fields are keys if the DPID is > 10L
-//        Entity e2 = new Entity(2L, (short)23, 24, 11L, 1, new Date(0));
-//        Device d2 = deviceManager.learnDeviceByEntity(e2);
-//        DeviceSyncRepresentation dsr2 = new DeviceSyncRepresentation(d2);
-//        assertEquals("Sanity check failed. Device doesn't have the expected " +
-//                     "entity class. Something with the test setup is strange",
-//                     "TestEntityClass", d2.getEntityClass().getName());
-//        assertEquals("Sanity check failed. Device doesn't have the expected " +
-//                     "entity class. Something with the test setup is strange",
-//                     EnumSet.of(DeviceField.MAC, DeviceField.VLAN,
-//                                DeviceField.SWITCH, DeviceField.PORT),
-//                     d2.getEntityClass().getKeyFields());
-//        SwitchPort swp = new SwitchPort(11L, 1, null);
-//        assertEquals("TestEntityClass::00:00:00:00:00:02::[23]::[" +
-//                     swp.toString() + "]::",
-//                     dsr2.getKey());
-//    }
-//
-//    /* interate through all entries in the sync store and return them as
-//     * list. We don't return the key from the store however, we assert
-//     * that the key from the store matches the key in the representation.
-//     * If we have a null value (tombstone) we simply add the null value to
-//     * the list to return.
-//     */
-//    private List<DeviceSyncRepresentation> getEntriesFromStore()
-//            throws Exception {
-//        List<DeviceSyncRepresentation> entries =
-//                new ArrayList<DeviceSyncRepresentation>();
-//        IClosableIterator<Entry<String, Versioned<DeviceSyncRepresentation>>> iter =
-//                storeClient.entries();
-//        try {
-//            while(iter.hasNext()) {
-//                Entry<String, Versioned<DeviceSyncRepresentation>> entry =
-//                        iter.next();
-//                DeviceSyncRepresentation dsr = entry.getValue().getValue();
-//                if (dsr != null)
-//                    assertEquals(entry.getKey(), dsr.getKey());
-//                entries.add(dsr);
-//            }
-//        } finally {
-//            if (iter != null)
-//                iter.close();
-//        }
-//        return entries;
-//    }
-//
-//    /*
-//     * assert whether the given Entity expected is equals to the given
-//     * SyncEntity actual. This method also compares the times (lastSeen,
-//     * activeSince). Entity.equals will not do that!
-//     */
-//    private static void assertEntityEquals(Entity expected, SyncEntity actual) {
-//        assertNotNull(actual);
-//        assertNotNull(expected);
-//        Entity actualEntity = actual.asEntity();
-//        assertEquals("entityFields", expected, actualEntity);
-//        assertEquals("lastSeenTimestamp",
-//                     expected.getLastSeenTimestamp(),
-//                     actualEntity.getLastSeenTimestamp());
-//        assertEquals("activeSince",
-//                     expected.getActiveSince(), actualEntity.getActiveSince());
-//    }
-//
-//    /* This test tests the normal operation as master when we write to the sync
-//     * store or delete from the store.
-//     */
-//    @Test
-//    public void testWriteToSyncStore() throws Exception {
-//        int syncStoreIntervalMs = 50;
-//        ITopologyService mockTopology = makeMockTopologyAllPortsAp();
-//        replay(mockTopology);
-//        deviceManager.topology = mockTopology;
-//        deviceManager.setSyncStoreWriteInterval(syncStoreIntervalMs);
-//
-//        Entity e1a = new Entity(1L, (short)2, 3, 4L, 5, new Date(1000));
-//        e1a.setActiveSince(new Date(0));
-//        deviceManager.learnDeviceByEntity(e1a);
-//
-//        //storeClient.put("FooBar", new DeviceSyncRepresentation());
-//
-//        List<DeviceSyncRepresentation> entries = getEntriesFromStore();
-//        assertEquals(1, entries.size());
-//        DeviceSyncRepresentation dsr1 = entries.get(0);
-//        assertEquals(1, dsr1.getEntities().size());
-//        assertEntityEquals(e1a, dsr1.getEntities().get(0));
-//
-//        // Same entity but newer timestamp. Since the device hasn't changed,
-//        // only the timestamp is updated and the write should be throttled.
-//        Entity e1b = new Entity(1L, (short)2, 3, 4L, 5, new Date(2000));
-//        e1b.setActiveSince(new Date(0));
-//        deviceManager.learnDeviceByEntity(e1a);
-//        entries = getEntriesFromStore();
-//        assertEquals(1, entries.size());
-//        dsr1 = entries.get(0);
-//        assertEquals(1, dsr1.getEntities().size());
-//        assertEntityEquals(e1a, dsr1.getEntities().get(0)); //e1a not e1b !!!
-//
-//        // Wait for the write interval to expire then write again.
-//        Thread.sleep(syncStoreIntervalMs+5);
-//        Entity e1c = new Entity(1L, (short)2, 3, 4L, 5, new Date(3000));
-//        e1c.setActiveSince(new Date(0));
-//        deviceManager.learnDeviceByEntity(e1c);
-//        entries = getEntriesFromStore();
-//        assertEquals(1, entries.size());
-//        dsr1 = entries.get(0);
-//        assertEquals(1, dsr1.getEntities().size());
-//        assertEntityEquals(e1c, dsr1.getEntities().get(0)); // e1c !!
-//
-//        // Entity for same device but with different IP. should be added
-//        // immediately
-//        Entity e1d = new Entity(1L, (short)2, 33, 4L, 5, new Date(4000));
-//        e1d.setActiveSince(new Date(0));
-//        deviceManager.learnDeviceByEntity(e1d);
-//        entries = getEntriesFromStore();
-//        assertEquals(1, entries.size());
-//        dsr1 = entries.get(0);
-//        assertEquals(2, dsr1.getEntities().size());
-//        assertEntityEquals(e1c, dsr1.getEntities().get(0)); // e1c !!
-//        assertEntityEquals(e1d, dsr1.getEntities().get(1)); // e1d !!
-//
-//        // Entity for same device with new switch port ==> moved ==> write
-//        // update immediately without throttle.
-//        // Note: the previous entities will still be there because they have
-//        // IPs (even though they aren't for the current attachment point)
-//        Entity e1e = new Entity(1L, (short)2, 33, 4L, 6, new Date(5000));
-//        e1e.setActiveSince(new Date(0));
-//        deviceManager.learnDeviceByEntity(e1e);
-//        entries = getEntriesFromStore();
-//        assertEquals(1, entries.size());
-//        dsr1 = entries.get(0);
-//        assertEquals(3, dsr1.getEntities().size());
-//        assertEntityEquals(e1c, dsr1.getEntities().get(0));
-//        assertEntityEquals(e1d, dsr1.getEntities().get(1));
-//        assertEntityEquals(e1e, dsr1.getEntities().get(2));
-//
-//        // Add a second device
-//        Entity e2 = new Entity(2L, null, null, 5L, 5, new Date());
-//        deviceManager.learnDeviceByEntity(e2);
-//        entries = getEntriesFromStore();
-//        assertEquals(2, entries.size());
-//        for (DeviceSyncRepresentation dsr: entries) {
-//            // This is a kinda ugly way to ensure we have the two
-//            // devices we need..... but it will work for now
-//            if (dsr.getKey().contains("::00:00:00:00:00:01::")) {
-//                assertEquals(3, dsr.getEntities().size());
-//                assertEntityEquals(e1c, dsr.getEntities().get(0));
-//                assertEntityEquals(e1d, dsr.getEntities().get(1));
-//                assertEntityEquals(e1e, dsr.getEntities().get(2));
-//            } else if (dsr.getKey().contains("::00:00:00:00:00:02::")) {
-//                assertEquals(1, dsr.getEntities().size());
-//                assertEntityEquals(e2, dsr.getEntities().get(0));
-//            } else {
-//                fail("Unknown entry in store: " + dsr);
-//            }
-//        }
-//
-//
-//        // Run entity cleanup. Since we've used phony time stamps for
-//        // device 1 its entities should be cleared and the device should be
-//        // removed from the store. Device 2 should remain in the store.
-//        deviceManager.cleanupEntities();
-//        entries = getEntriesFromStore();
-//        assertEquals(2, entries.size());
-//        for (DeviceSyncRepresentation dsr: entries) {
-//            if (dsr == null) {
-//                // pass
-//            } else if (dsr.getKey().contains("::00:00:00:00:00:02::")) {
-//                assertEquals(1, dsr.getEntities().size());
-//                assertEntityEquals(e2, dsr.getEntities().get(0));
-//            } else {
-//                fail("Unknown entry in store: " + dsr);
-//            }
-//        }
-//    }
-//
-//
-//    private void assertDeviceIps(Integer[] expected, IDevice d) {
-//        List<Integer> expectedList = Arrays.asList(expected);
-//        Collections.sort(expectedList);
-//        List<Integer> actualList = Arrays.asList(d.getIPv4Addresses());
-//        Collections.sort(actualList);
-//        assertEquals(expectedList, actualList);
-//    }
-//
-//    private IDevice getSingleDeviceFromDeviceManager(long mac) {
-//        Iterator<? extends IDevice> diter =
-//                deviceManager.queryDevices(mac, null, null, null, null);
-//        assertTrue("Query didn't return a device", diter.hasNext());
-//        IDevice d = diter.next();
-//        assertFalse("Query returned more than one device", diter.hasNext());
-//        return d;
-//    }
-//
-//    @Test
-//    public void testToMaster() throws Exception {
-//        int syncStoreWriteIntervalMs = 0;
-//        int initialSyncStoreConsolidateIntervalMs = 50;
-//        ITopologyService mockTopology = makeMockTopologyAllPortsAp();
-//        replay(mockTopology);
-//        deviceManager.topology = mockTopology;
-//        // We want an EntityClassifier that has switch/port as key fields
-//        deviceManager.entityClassifier = new MockEntityClassifier();
-//        deviceManager.setSyncStoreWriteInterval(syncStoreWriteIntervalMs);
-//        deviceManager.setInitialSyncStoreConsolidateMs(initialSyncStoreConsolidateIntervalMs);
-//
-//        // Add Device1 with two entities with two different IPs
-//        Entity e1a = new Entity(1L, null, 3, 4L, 5, new Date(1000));
-//        Entity e1b = new Entity(1L, null, 33,  4L, 5, new Date(2000));
-//        Device d1 = deviceManager.allocateDevice(1L, e1a,
-//                                                 DefaultEntityClassifier.entityClass);
-//        d1 = deviceManager.allocateDevice(d1, e1b, -1);
-//        DeviceSyncRepresentation dsr = new DeviceSyncRepresentation(d1);
-//        storeClient.put(dsr.getKey(), dsr);
-//
-//        // Add Device2 with different switch-ports. Only the most recent
-//        // one should be the attachment point
-//        Entity e2a = new Entity(2L, null, null, 4L, 4, new Date(1000));
-//        Entity e2b = new Entity(2L, null, null, 4L, 5, new Date(2000));
-//        Device d2 = deviceManager.allocateDevice(2L, e2a,
-//                                                 DefaultEntityClassifier.entityClass);
-//        d2 = deviceManager.allocateDevice(d2, e2b, -1);
-//        d2.updateAttachmentPoint(4L, (short)5,
-//                                 e2b.getLastSeenTimestamp().getTime());
-//        SwitchPort swp = new SwitchPort(4L, 5);
-//        SwitchPort[] aps = d2.getAttachmentPoints();
-//        // sanity check
-//        assertArrayEquals("Sanity check: should only have AP(4L,5)",
-//                          new SwitchPort[] {swp}, aps);
-//        dsr = new DeviceSyncRepresentation(d2);
-//        storeClient.put(dsr.getKey(), dsr);
-//
-//        // Add a tombstone entry to the store to make sure we don't trip a
-//        // NPE
-//        dsr = null;
-//        Versioned<DeviceSyncRepresentation> versionedDsr =
-//                storeClient.get("FooBar");
-//        storeClient.put("FooBar", versionedDsr);
-//
-//        deviceManager.getHAListener().transitionToMaster();
-//
-//        // Query for the Device1. Make sure we have the two IPs we stored.
-//        IDevice d = getSingleDeviceFromDeviceManager(1L);
-//        assertDeviceIps(new Integer[] {3, 33}, d);
-//        assertArrayEquals(new Short[] { Ethernet.VLAN_UNTAGGED }, d.getVlanId());
-//        swp = new SwitchPort(4L, 5);
-//        assertArrayEquals(new SwitchPort[] { swp }, d.getAttachmentPoints());
-//
-//        // Query for Device2. Make sure we only have the more recent AP
-//        // Query for the Device1. Make sure we have the two IPs we stored.
-//        d = getSingleDeviceFromDeviceManager(2L);
-//        assertArrayEquals(new Integer[0], d.getIPv4Addresses());
-//        assertArrayEquals(new Short[] { Ethernet.VLAN_UNTAGGED }, d.getVlanId());
-//        swp = new SwitchPort(4L, 5);
-//        assertArrayEquals(new SwitchPort[] { swp }, d.getAttachmentPoints());
-//
-//        //----------------------------
-//        // add another entry device to the store. since device manager is
-//        // already master we won't read this device and it should be
-//        // removed from the store by the consolidate task
-//        Entity e3 = new Entity(3L, null, null, 1L, 1, null);
-//        dsr = new DeviceSyncRepresentation();
-//        dsr.setKey("Device3");
-//        dsr.setEntities(Collections.singletonList(new SyncEntity(e3)));
-//        storeClient.put(dsr.getKey(), dsr);
-//
-//        // make sure it's in the store
-//        List<DeviceSyncRepresentation> entries = getEntriesFromStore();
-//        boolean found = false;
-//        for (DeviceSyncRepresentation entry: entries) {
-//            if (entry!=null && entry.getKey().equals("Device3"))
-//                found = true;
-//        }
-//        assertTrue("Device3 not in store. Entries in store: " + entries, found);
-//        // make sure it's not in DevManager
-//        Iterator<? extends IDevice> diter =
-//                deviceManager.queryDevices(3L, null, null, null, null);
-//        assertFalse("Device3 found in DeviceManager. Should be there",
-//                    diter.hasNext());
-//
-//        // Wait for consolidate
-//        Thread.sleep(initialSyncStoreConsolidateIntervalMs + 5);
-//        // make sure it's in NOT the store
-//        entries = getEntriesFromStore();
-//        found = false;
-//        for (DeviceSyncRepresentation entry: entries) {
-//            if (entry!=null && entry.getKey().equals("Device3"))
-//                found = true;
-//        }
-//        assertFalse("Device3 not is still in the store. Entries in store: "
-//                    + entries, found);
-//        // make sure it's not in DevManager
-//        diter = deviceManager.queryDevices(3L, null, null, null, null);
-//        assertFalse("Device3 found in DeviceManager. Should be there",
-//                    diter.hasNext());
-//    }
-//
-//
-//    @Test
-//    public void testConsolitateStore() throws Exception {
-//        int syncStoreInternalMs = 0;
-//        ITopologyService mockTopology = makeMockTopologyAllPortsAp();
-//        replay(mockTopology);
-//        deviceManager.topology = mockTopology;
-//        // We want an EntityClassifier that has switch/port as key fields
-//        deviceManager.entityClassifier = new MockEntityClassifier();
-//        deviceManager.setSyncStoreWriteInterval(syncStoreInternalMs);
-//
-//        // Add Device1 with two entities to store and let device manager
-//        // learn
-//        Entity e1a = new Entity(1L, null, null, 4L, 5, new Date(1000));
-//        Entity e1b = new Entity(1L, null, 3,  4L, 5, new Date(2000));
-//        Device d1 = deviceManager.learnDeviceByEntity(e1a);
-//        deviceManager.learnDeviceByEntity(e1b);
-//        String dev1Key = DeviceSyncRepresentation.computeKey(d1);
-//
-//
-//        // Add a second device to the store but do NOT add to device manager
-//        Entity e2 = new Entity(2L, null, null, 5L, 5, new Date());
-//        Device d2 = deviceManager.allocateDevice(42L, e2,
-//                                                 DefaultEntityClassifier.entityClass);
-//        DeviceSyncRepresentation dsr = new DeviceSyncRepresentation(d2);
-//        storeClient.put(dsr.getKey(), dsr);
-//        String dev2Key = DeviceSyncRepresentation.computeKey(d2);
-//
-//        // Make sure we have two devices in the store
-//        List<DeviceSyncRepresentation> entries = getEntriesFromStore();
-//        assertEquals(2, entries.size());
-//
-//        deviceManager.scheduleConsolidateStoreNow();
-//        Thread.sleep(25); // give the scheduler time to run the task
-//
-//        // We should still have two entries, however one of them will be a
-//        // tombstone
-//        entries = getEntriesFromStore();
-//        assertEquals(2, entries.size());
-//
-//        // Device 1 should still be in store
-//        Versioned<DeviceSyncRepresentation> versioned =
-//                storeClient.get(dev1Key);
-//        dsr = versioned.getValue();
-//        assertNotNull(dsr);
-//        assertEquals(2, dsr.getEntities().size());
-//        assertEntityEquals(e1a, dsr.getEntities().get(0));
-//        assertEntityEquals(e1b, dsr.getEntities().get(1));
-//
-//        // Device2 should be gone
-//        versioned = storeClient.get(dev2Key);
-//        assertNull(versioned.getValue());
-//
-//        // Run consolitate again. This time we check that tombstones in
-//        // the store are handled correctly
-//        deviceManager.scheduleConsolidateStoreNow();
-//        Thread.sleep(25); // give the scheduler time to run the task
-//
-//        // Now write a device to the store that doesn't have any switch-port
-//        // it should be removed
-//        Entity e3 = new Entity(3L, null, null, null, null, null);
-//        dsr.setKey("Device3");
-//        dsr.setEntities(Collections.singletonList(new SyncEntity(e3)));
-//        storeClient.put(dsr.getKey(), dsr);
-//
-//        // Run consolitate again. This time we check that tombstones in
-//        // the store are handled correctly
-//        deviceManager.scheduleConsolidateStoreNow();
-//        Thread.sleep(25); // give the scheduler time to run the task
-//        versioned = storeClient.get("Device3");
-//        assertNull(versioned.getValue());
-//
-//    }
-//
-// }
diff --git a/opendaylight/adsal/hosttracker_new/implementation/src/test/java/org/opendaylight/controller/hosttracker/internal/DeviceUniqueIndexTest.java b/opendaylight/adsal/hosttracker_new/implementation/src/test/java/org/opendaylight/controller/hosttracker/internal/DeviceUniqueIndexTest.java
deleted file mode 100644 (file)
index a2a1004..0000000
+++ /dev/null
@@ -1,175 +0,0 @@
-/*
- * Copyright (c) 2012 Big Switch Networks, Inc.
- *
- * Licensed under the Eclipse Public License, Version 1.0 (the
- * "License"); you may not use this file except in compliance with the
- * License. You may obtain a copy of the License at
- *
- *      http://www.eclipse.org/legal/epl-v10.html
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
- * implied. See the License for the specific language governing
- * permissions and limitations under the License.
- */
-
-package org.opendaylight.controller.hosttracker.internal;
-
-import java.util.ArrayList;
-import java.util.Collections;
-import java.util.Date;
-import java.util.EnumSet;
-import java.util.HashSet;
-import java.util.Iterator;
-import java.util.List;
-import java.util.Set;
-
-import junit.framework.TestCase;
-
-import org.junit.Test;
-import org.opendaylight.controller.hosttracker.Entity;
-import org.opendaylight.controller.hosttracker.IDeviceService.DeviceField;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.NodeConnector.NodeConnectorIDType;
-
-/**
- *
- * @author gregor
- *
- */
-public class DeviceUniqueIndexTest extends TestCase {
-    protected Entity e1a;
-    protected Entity e1b;
-    protected Device d1;
-    protected Entity e2;
-    protected Entity e2alt;
-    protected Entity e3;
-    protected Entity e3_ip;
-    protected Entity e4;
-
-    @Override
-    protected void setUp() throws Exception {
-        super.setUp();
-        Node n1 = new Node(Node.NodeIDType.OPENFLOW, Long.valueOf(1L));
-        NodeConnector n1_1 = new NodeConnector(NodeConnectorIDType.OPENFLOW,
-                Short.valueOf((short) 1), n1);
-        e1a = new Entity(1L, (short) 1, 1, n1_1, new Date());
-        e1b = new Entity(1L, (short) 2, 1, n1_1, new Date());
-        List<Entity> d1Entities = new ArrayList<Entity>(2);
-        d1Entities.add(e1a);
-        d1Entities.add(e1b);
-        d1 = new Device(null, Long.valueOf(1), null, null, null, d1Entities,
-                null);
-
-        Node n2 = new Node(Node.NodeIDType.OPENFLOW, Long.valueOf(2L));
-        NodeConnector n2_2 = new NodeConnector(NodeConnectorIDType.OPENFLOW,
-                Short.valueOf((short) 2), n2);
-        Node n3 = new Node(Node.NodeIDType.OPENFLOW, Long.valueOf(3L));
-        NodeConnector n3_3 = new NodeConnector(NodeConnectorIDType.OPENFLOW,
-                Short.valueOf((short) 3), n3);
-
-        // e2 and e2 alt match in MAC and VLAN
-        e2 = new Entity(2L, (short) 2, 2, n2_2, new Date());
-        e2alt = new Entity(2, (short) 2, null, null, null);
-
-        // IP is null
-        e3 = new Entity(3L, (short) 3, null, n3_3, new Date());
-        e3_ip = new Entity(3L, (short) 3, 3, n3_3, new Date());
-
-        // IP and switch and port are null
-        e4 = new Entity(4L, (short) 4, null, null, new Date());
-    }
-
-    /*
-     * Checks that the iterator it returns the elements in the Set expected
-     * Doesn't check how often an element is returned as long it's at least once
-     */
-    protected void verifyIterator(Set<Long> expected, Iterator<Long> it) {
-        HashSet<Long> actual = new HashSet<Long>();
-        while (it.hasNext()) {
-            actual.add(it.next());
-        }
-        assertEquals(expected, actual);
-    }
-
-    @Test
-    public void testDeviceUniqueIndex() {
-        DeviceUniqueIndex idx1 = new DeviceUniqueIndex(EnumSet.of(
-                DeviceField.MAC, DeviceField.VLAN));
-
-        idx1.updateIndex(d1, d1.getDeviceKey());
-        idx1.updateIndex(e2, 2L);
-
-        // -------------
-        // Test findByEntity lookups
-        assertEquals(Long.valueOf(1L), idx1.findByEntity(e1a));
-        assertEquals(Long.valueOf(1L), idx1.findByEntity(e1b));
-        assertEquals(Long.valueOf(2L), idx1.findByEntity(e2));
-        // we didn't add e2alt but since they key fields are the same we
-        // should find it
-        assertEquals(Long.valueOf(2L), idx1.findByEntity(e2alt));
-        assertEquals(null, idx1.findByEntity(e3));
-        assertEquals(null, idx1.findByEntity(e4));
-
-        // -------------
-        // Test getAll()
-        HashSet<Long> expectedKeys = new HashSet<Long>();
-        expectedKeys.add(1L);
-        expectedKeys.add(2L);
-        verifyIterator(expectedKeys, idx1.getAll());
-
-        // -------------
-        // Test queryByEntity()
-        verifyIterator(Collections.<Long> singleton(1L),
-                idx1.queryByEntity(e1a));
-        verifyIterator(Collections.<Long> singleton(1L),
-                idx1.queryByEntity(e1b));
-        verifyIterator(Collections.<Long> singleton(2L), idx1.queryByEntity(e2));
-        verifyIterator(Collections.<Long> singleton(2L),
-                idx1.queryByEntity(e2alt));
-        assertEquals(false, idx1.queryByEntity(e3).hasNext());
-        assertEquals(false, idx1.queryByEntity(e3).hasNext());
-
-        // -------------
-        // Test removal
-        idx1.removeEntity(e1a, 42L); // No-op. e1a isn't mapped to this key
-        assertEquals(Long.valueOf(1L), idx1.findByEntity(e1a));
-        idx1.removeEntity(e1a, 1L);
-        assertEquals(null, idx1.findByEntity(e1a));
-        assertEquals(Long.valueOf(1L), idx1.findByEntity(e1b));
-        assertEquals(Long.valueOf(2L), idx1.findByEntity(e2));
-        idx1.removeEntity(e2);
-        assertEquals(null, idx1.findByEntity(e2));
-        assertEquals(Long.valueOf(1L), idx1.findByEntity(e1b));
-
-        // -------------
-        // Test null keys
-        DeviceUniqueIndex idx2 = new DeviceUniqueIndex(EnumSet.of(
-                DeviceField.IPV4, DeviceField.SWITCHPORT));
-        // only one key field is null
-        idx2.updateIndex(e3, 3L);
-        assertEquals(Long.valueOf(3L), idx2.findByEntity(e3));
-        assertEquals(null, idx2.findByEntity(e3_ip));
-        // all key fields are null
-        idx2.updateIndex(e4, 4L);
-        assertEquals(null, idx2.findByEntity(e4));
-        Device d4 = new Device(null, 4L, null, null, null,
-                Collections.<Entity> singleton(e4), null);
-        idx2.updateIndex(d4, 4L);
-        assertEquals(null, idx2.findByEntity(e4));
-
-        // -------------
-        // entity already exists with different deviceKey
-        DeviceUniqueIndex idx3 = new DeviceUniqueIndex(EnumSet.of(
-                DeviceField.MAC, DeviceField.VLAN));
-        idx3.updateIndex(e1a, 42L);
-        assertEquals(false, idx3.updateIndex(d1, 1L));
-        // TODO: shouldn't this fail as well so that the behavior
-        // is consistent?
-        idx3.updateIndex(e1a, 1L);
-        // anyways. We can now add d1 ;-)
-        assertEquals(true, idx3.updateIndex(d1, 1L));
-    }
-}
diff --git a/opendaylight/adsal/hosttracker_new/implementation/src/test/java/org/opendaylight/controller/hosttracker/test/MockDevice.java b/opendaylight/adsal/hosttracker_new/implementation/src/test/java/org/opendaylight/controller/hosttracker/test/MockDevice.java
deleted file mode 100644 (file)
index 03f0598..0000000
+++ /dev/null
@@ -1,102 +0,0 @@
-/*
- * Copyright (c) 2011,2012 Big Switch Networks, Inc.
- *
- * Licensed under the Eclipse Public License, Version 1.0 (the
- * "License"); you may not use this file except in compliance with the
- * License. You may obtain a copy of the License at
- *
- *      http://www.eclipse.org/legal/epl-v10.html
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
- * implied. See the License for the specific language governing
- * permissions and limitations under the License.
- *
- * This file incorporates work covered by the following copyright and
- * permission notice:
- *
- *    Originally created by David Erickson, Stanford University
- *
- *    Licensed under the Apache License, Version 2.0 (the "License");
- *    you may not use this file except in compliance with the
- *    License. You may obtain a copy of the License at
- *
- *         http://www.apache.org/licenses/LICENSE-2.0
- *
- *    Unless required by applicable law or agreed to in writing,
- *    software distributed under the License is distributed on an "AS
- *    IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
- *    express or implied. See the License for the specific language
- *    governing permissions and limitations under the License.
- */
-
-package org.opendaylight.controller.hosttracker.test;
-
-import java.util.ArrayList;
-import java.util.Arrays;
-import java.util.Collection;
-import java.util.List;
-import java.util.TreeSet;
-
-import org.opendaylight.controller.hosttracker.Entity;
-import org.opendaylight.controller.hosttracker.IEntityClass;
-import org.opendaylight.controller.hosttracker.SwitchPort;
-import org.opendaylight.controller.hosttracker.internal.AttachmentPoint;
-import org.opendaylight.controller.hosttracker.internal.Device;
-import org.opendaylight.controller.hosttracker.internal.DeviceManagerImpl;
-
-/**
- * This mock device removes the dependency on topology and a parent device
- * manager and simply assumes all its entities are current and correct
- */
-public class MockDevice extends Device {
-
-    public MockDevice(DeviceManagerImpl deviceManager, Long deviceKey,
-            Entity entity, IEntityClass entityClass) {
-        super(deviceManager, deviceKey, entity, entityClass);
-    }
-
-    public MockDevice(Device device, Entity newEntity, int insertionpoint) {
-        super(device, newEntity, insertionpoint);
-    }
-
-    public MockDevice(DeviceManagerImpl deviceManager, Long deviceKey,
-            List<AttachmentPoint> aps, List<AttachmentPoint> trueAPs,
-            Collection<Entity> entities, IEntityClass entityClass) {
-        super(deviceManager, deviceKey, null, aps, trueAPs, entities,
-                entityClass);
-    }
-
-    @Override
-    public Integer[] getIPv4Addresses() {
-        TreeSet<Integer> vals = new TreeSet<Integer>();
-        for (Entity e : entities) {
-            if (e.getIpv4Address() == null)
-                continue;
-            vals.add(e.getIpv4Address());
-        }
-
-        return vals.toArray(new Integer[vals.size()]);
-    }
-
-    @Override
-    public SwitchPort[] getAttachmentPoints() {
-        ArrayList<SwitchPort> vals = new ArrayList<SwitchPort>(entities.length);
-        for (Entity e : entities) {
-            if (e.getPort() != null
-                    && deviceManager.isValidAttachmentPoint(e.getPort())) {
-                SwitchPort sp = new SwitchPort(e.getPort());
-                vals.add(sp);
-            }
-        }
-        return vals.toArray(new SwitchPort[vals.size()]);
-    }
-
-    @Override
-    public String toString() {
-        return "MockDevice [getEntityClass()=" + getEntityClass()
-                + ", getEntities()=" + Arrays.toString(getEntities()) + "]";
-    }
-
-}
diff --git a/opendaylight/adsal/hosttracker_new/implementation/src/test/java/org/opendaylight/controller/hosttracker/test/MockDeviceManager.java b/opendaylight/adsal/hosttracker_new/implementation/src/test/java/org/opendaylight/controller/hosttracker/test/MockDeviceManager.java
deleted file mode 100644 (file)
index af2feb1..0000000
+++ /dev/null
@@ -1,136 +0,0 @@
-/*
- * Copyright (c) 2013 Big Switch Networks, Inc.
- *
- * Licensed under the Eclipse Public License, Version 1.0 (the
- * "License"); you may not use this file except in compliance with the
- * License. You may obtain a copy of the License at
- *
- *      http://www.eclipse.org/legal/epl-v10.html
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
- * implied. See the License for the specific language governing
- * permissions and limitations under the License.
- */
-
-package org.opendaylight.controller.hosttracker.test;
-
-import java.util.Collection;
-import java.util.Date;
-import java.util.List;
-
-import org.opendaylight.controller.hosttracker.Entity;
-import org.opendaylight.controller.hosttracker.IDevice;
-import org.opendaylight.controller.hosttracker.IDeviceListener;
-import org.opendaylight.controller.hosttracker.IEntityClass;
-import org.opendaylight.controller.hosttracker.IEntityClassifierService;
-import org.opendaylight.controller.hosttracker.internal.AttachmentPoint;
-import org.opendaylight.controller.hosttracker.internal.Device;
-import org.opendaylight.controller.hosttracker.internal.DeviceManagerImpl;
-import org.opendaylight.controller.sal.core.NodeConnector;
-
-/**
- * Mock device manager useful for unit tests
- *
- * @author readams
- */
-public class MockDeviceManager extends DeviceManagerImpl {
-    /**
-     * Set a new IEntityClassifier Use this as a quick way to use a particular
-     * entity classifier in a single test without having to setup the full
-     * FloodlightModuleContext again.
-     *
-     * @param ecs
-     */
-    public void setEntityClassifier(IEntityClassifierService ecs) {
-        this.entityClassifier = ecs;
-        // setSyncServiceIfNotSet(new MockSyncService());
-        this.start();
-    }
-
-    /**
-     * Learn a device using the given characteristics.
-     *
-     * @param macAddress
-     *            the MAC
-     * @param vlan
-     *            the VLAN (can be null)
-     * @param ipv4Address
-     *            the IP (can be null)
-     * @param switchDPID
-     *            the attachment point switch DPID (can be null)
-     * @param switchPort
-     *            the attachment point switch port (can be null)
-     * @param processUpdates
-     *            if false, will not send updates. Note that this method is not
-     *            thread safe if this is false
-     * @return the device, either new or not
-     */
-    public IDevice learnEntity(long macAddress, Short vlan,
-            Integer ipv4Address, NodeConnector port, boolean processUpdates) {
-        List<IDeviceListener> listeners = deviceListeners.getOrderedListeners();
-        if (!processUpdates) {
-            deviceListeners.clearListeners();
-        }
-
-        if (vlan != null && vlan.shortValue() <= 0)
-            vlan = null;
-        if (ipv4Address != null && ipv4Address == 0)
-            ipv4Address = null;
-        IDevice res = learnDeviceByEntity(new Entity(macAddress, vlan,
-                ipv4Address, port, new Date()));
-        // Restore listeners
-        if (listeners != null) {
-            for (IDeviceListener listener : listeners) {
-                deviceListeners.addListener("device", listener);
-            }
-        }
-        return res;
-    }
-
-    @Override
-    public void deleteDevice(Device device) {
-        super.deleteDevice(device);
-    }
-
-    /**
-     * Learn a device using the given characteristics.
-     *
-     * @param macAddress
-     *            the MAC
-     * @param vlan
-     *            the VLAN (can be null)
-     * @param ipv4Address
-     *            the IP (can be null)
-     * @param switchDPID
-     *            the attachment point switch DPID (can be null)
-     * @param switchPort
-     *            the attachment point switch port (can be null)
-     * @return the device, either new or not
-     */
-    public IDevice learnEntity(long macAddress, Short vlan,
-            Integer ipv4Address, NodeConnector port) {
-        return learnEntity(macAddress, vlan, ipv4Address, port, true);
-    }
-
-    @Override
-    protected Device allocateDevice(Long deviceKey, Entity entity,
-            IEntityClass entityClass) {
-        return new MockDevice(this, deviceKey, entity, entityClass);
-    }
-
-    @Override
-    protected Device allocateDevice(Long deviceKey, String dhcpClientName,
-            List<AttachmentPoint> aps, List<AttachmentPoint> trueAPs,
-            Collection<Entity> entities, IEntityClass entityClass) {
-        return new MockDevice(this, deviceKey, aps, trueAPs, entities,
-                entityClass);
-    }
-
-    @Override
-    protected Device allocateDevice(Device device, Entity entity,
-            int insertionpoint) {
-        return new MockDevice(device, entity, insertionpoint);
-    }
-}
diff --git a/opendaylight/adsal/hosttracker_new/implementation/src/test/java/org/opendaylight/controller/hosttracker/test/MockEntityClassifier.java b/opendaylight/adsal/hosttracker_new/implementation/src/test/java/org/opendaylight/controller/hosttracker/test/MockEntityClassifier.java
deleted file mode 100644 (file)
index e9f919e..0000000
+++ /dev/null
@@ -1,63 +0,0 @@
-/*
- * Copyright (c) 2013 Big Switch Networks, Inc.
- *
- * Licensed under the Eclipse Public License, Version 1.0 (the
- * "License"); you may not use this file except in compliance with the
- * License. You may obtain a copy of the License at
- *
- *      http://www.eclipse.org/legal/epl-v10.html
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
- * implied. See the License for the specific language governing
- * permissions and limitations under the License.
- */
-
-package org.opendaylight.controller.hosttracker.test;
-
-import static org.opendaylight.controller.hosttracker.IDeviceService.DeviceField.MAC;
-import static org.opendaylight.controller.hosttracker.IDeviceService.DeviceField.SWITCHPORT;
-import static org.opendaylight.controller.hosttracker.IDeviceService.DeviceField.VLAN;
-
-import java.util.EnumSet;
-
-import org.opendaylight.controller.hosttracker.Entity;
-import org.opendaylight.controller.hosttracker.IDeviceService;
-import org.opendaylight.controller.hosttracker.IDeviceService.DeviceField;
-import org.opendaylight.controller.hosttracker.IEntityClass;
-import org.opendaylight.controller.hosttracker.internal.DefaultEntityClassifier;
-
-/**
- * A simple IEntityClassifier. Useful for tests that need IEntityClassifiers and
- * IEntityClass'es with switch and/or port key fields
- */
-public class MockEntityClassifier extends DefaultEntityClassifier {
-    public static class TestEntityClass implements IEntityClass {
-        @Override
-        public EnumSet<DeviceField> getKeyFields() {
-            return EnumSet.of(MAC, VLAN, SWITCHPORT);
-        }
-
-        @Override
-        public String getName() {
-            return "TestEntityClass";
-        }
-    }
-
-    public static IEntityClass testEC = new MockEntityClassifier.TestEntityClass();
-
-    @Override
-    public IEntityClass classifyEntity(Entity entity) {
-        if (((Long) entity.getPort().getNode().getID()) >= 10L) {
-            return testEC;
-        }
-        return DefaultEntityClassifier.entityClass;
-    }
-
-    @Override
-    public EnumSet<IDeviceService.DeviceField> getKeyFields() {
-        return EnumSet.of(MAC, VLAN, SWITCHPORT);
-    }
-
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/hosttracker_new/implementation/src/test/java/org/opendaylight/controller/hosttracker/test/MockEntityClassifierMac.java b/opendaylight/adsal/hosttracker_new/implementation/src/test/java/org/opendaylight/controller/hosttracker/test/MockEntityClassifierMac.java
deleted file mode 100644 (file)
index 436e6fa..0000000
+++ /dev/null
@@ -1,78 +0,0 @@
-/*
- * Copyright (c) 2013 Big Switch Networks, Inc.
- *
- * Licensed under the Eclipse Public License, Version 1.0 (the
- * "License"); you may not use this file except in compliance with the
- * License. You may obtain a copy of the License at
- *
- *      http://www.eclipse.org/legal/epl-v10.html
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
- * implied. See the License for the specific language governing
- * permissions and limitations under the License.
- */
-
-package org.opendaylight.controller.hosttracker.test;
-
-import static org.opendaylight.controller.hosttracker.IDeviceService.DeviceField.MAC;
-import static org.opendaylight.controller.hosttracker.IDeviceService.DeviceField.SWITCHPORT;
-import static org.opendaylight.controller.hosttracker.IDeviceService.DeviceField.VLAN;
-
-import java.util.EnumSet;
-
-import org.opendaylight.controller.hosttracker.Entity;
-import org.opendaylight.controller.hosttracker.IDeviceService;
-import org.opendaylight.controller.hosttracker.IDeviceService.DeviceField;
-import org.opendaylight.controller.hosttracker.IEntityClass;
-import org.opendaylight.controller.hosttracker.internal.DefaultEntityClassifier;
-
-/**
- * A simple IEntityClassifier. Useful for tests that need an IEntityClassifier
- * with switch/port as key fields.
- */
-public class MockEntityClassifierMac extends DefaultEntityClassifier {
-    public static class TestEntityClassMac implements IEntityClass {
-        protected String name;
-
-        public TestEntityClassMac(String name) {
-            this.name = name;
-        }
-
-        @Override
-        public EnumSet<DeviceField> getKeyFields() {
-            return EnumSet.of(MAC, VLAN);
-        }
-
-        @Override
-        public String getName() {
-            return name;
-        }
-    }
-
-    public static IEntityClass testECMac1 = new MockEntityClassifierMac.TestEntityClassMac(
-            "testECMac1");
-    public static IEntityClass testECMac2 = new MockEntityClassifierMac.TestEntityClassMac(
-            "testECMac2");
-
-    @Override
-    public IEntityClass classifyEntity(Entity entity) {
-        if (((Long) entity.getPort().getNode().getID()) == null) {
-            throw new IllegalArgumentException("Not all key fields specified."
-                    + " Required fields: " + getKeyFields());
-        } else if (((Long) entity.getPort().getNode().getID()) == 1L) {
-            return testECMac1;
-        } else if (((Long) entity.getPort().getNode().getID()) == 2L) {
-            return testECMac2;
-        } else if (((Long) entity.getPort().getNode().getID()) == -1L) {
-            return null;
-        }
-        return DefaultEntityClassifier.entityClass;
-    }
-
-    @Override
-    public EnumSet<IDeviceService.DeviceField> getKeyFields() {
-        return EnumSet.of(MAC, VLAN, SWITCHPORT);
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/hosttracker_new/implementation/src/test/java/org/opendaylight/controller/hosttracker/test/MockFlexEntityClassifier.java b/opendaylight/adsal/hosttracker_new/implementation/src/test/java/org/opendaylight/controller/hosttracker/test/MockFlexEntityClassifier.java
deleted file mode 100644 (file)
index fe2dd30..0000000
+++ /dev/null
@@ -1,102 +0,0 @@
-/*
- * Copyright (c) 2013 Big Switch Networks, Inc.
- *
- * Licensed under the Eclipse Public License, Version 1.0 (the
- * "License"); you may not use this file except in compliance with the
- * License. You may obtain a copy of the License at
- *
- *      http://www.eclipse.org/legal/epl-v10.html
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
- * implied. See the License for the specific language governing
- * permissions and limitations under the License.
- */
-
-package org.opendaylight.controller.hosttracker.test;
-
-import static org.opendaylight.controller.hosttracker.IDeviceService.DeviceField.MAC;
-import static org.opendaylight.controller.hosttracker.IDeviceService.DeviceField.SWITCHPORT;
-import static org.opendaylight.controller.hosttracker.IDeviceService.DeviceField.VLAN;
-
-import java.util.EnumSet;
-import java.util.HashMap;
-import java.util.Map;
-
-import org.opendaylight.controller.hosttracker.Entity;
-import org.opendaylight.controller.hosttracker.IDeviceService;
-import org.opendaylight.controller.hosttracker.IDeviceService.DeviceField;
-import org.opendaylight.controller.hosttracker.IEntityClass;
-import org.opendaylight.controller.hosttracker.internal.DefaultEntityClassifier;
-
-/**
- * Extension to simple entity classifier to help in unit tests to provide table
- * based multiple entity classification mock for reclassification tests
- *
- */
-public class MockFlexEntityClassifier extends DefaultEntityClassifier {
-    Map<Long, IEntityClass> switchEntities;
-    Map<Short, IEntityClass> vlanEntities;
-
-    public static class TestEntityClass implements IEntityClass {
-        String name;
-
-        public TestEntityClass(String name) {
-            this.name = name;
-        }
-
-        @Override
-        public EnumSet<DeviceField> getKeyFields() {
-            return EnumSet.of(MAC);
-        }
-
-        @Override
-        public String getName() {
-            return name;
-        }
-    }
-
-    public static IEntityClass defaultClass = new TestEntityClass("default");
-
-    public MockFlexEntityClassifier() {
-        switchEntities = new HashMap<Long, IEntityClass>();
-        vlanEntities = new HashMap<Short, IEntityClass>();
-    }
-
-    public IEntityClass createTestEntityClass(String name) {
-        return new TestEntityClass(name);
-    }
-
-    public void addSwitchEntity(Long dpid, IEntityClass entityClass) {
-        switchEntities.put(dpid, entityClass);
-    }
-
-    public void removeSwitchEntity(Long dpid) {
-        switchEntities.remove(dpid);
-    }
-
-    public void addVlanEntities(Short vlan, IEntityClass entityClass) {
-        vlanEntities.put(vlan, entityClass);
-    }
-
-    public void removeVlanEntities(Short vlan) {
-        vlanEntities.remove(vlan);
-    }
-
-    @Override
-    public IEntityClass classifyEntity(Entity entity) {
-        if (switchEntities.containsKey((Long) entity.getPort().getNode()
-                .getID()))
-            return switchEntities
-                    .get((Long) entity.getPort().getNode().getID());
-        if (vlanEntities.containsKey(entity.getVlan()))
-            return vlanEntities.get(entity.getVlan());
-        return defaultClass;
-    }
-
-    @Override
-    public EnumSet<IDeviceService.DeviceField> getKeyFields() {
-        return EnumSet.of(MAC, VLAN, SWITCHPORT);
-    }
-}
diff --git a/opendaylight/adsal/karaf-tomcat-security/pom.xml b/opendaylight/adsal/karaf-tomcat-security/pom.xml
deleted file mode 100644 (file)
index d40b7f5..0000000
+++ /dev/null
@@ -1,49 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>karaf-tomcat-security</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>orbit</groupId>
-      <artifactId>org.apache.catalina</artifactId>
-    </dependency>
-  </dependencies>
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Fragment-Host>org.apache.catalina</Fragment-Host>
-            <Import-Package>org.slf4j,
-              javax.servlet,
-              org.apache.catalina,
-              org.apache.catalina.connector,
-              org.apache.catalina.valves,
-              org.apache.catalina.realm
-            </Import-Package>
-            <Export-Package>org.opendaylight.controller.karafsecurity</Export-Package>
-          </instructions>
-          <manifestLocation>${project.basedir}/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/karaf-tomcat-security/src/main/java/org/opendaylight/controller/karafsecurity/ControllerCustomRealm.java b/opendaylight/adsal/karaf-tomcat-security/src/main/java/org/opendaylight/controller/karafsecurity/ControllerCustomRealm.java
deleted file mode 100644 (file)
index 316067c..0000000
+++ /dev/null
@@ -1,42 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.karafsecurity;
-
-import java.security.Principal;
-import java.util.ArrayList;
-import java.util.List;
-
-import org.apache.catalina.realm.GenericPrincipal;
-import org.apache.catalina.realm.RealmBase;
-
-public class ControllerCustomRealm  extends RealmBase {
-
-    private static final String name = "ControllerCustomRealm";
-
-    @Override
-    protected String getName() {
-        return name;
-    }
-
-    @Override
-    protected String getPassword(String username) {
-        return "admin";
-    }
-
-    @Override
-    protected Principal getPrincipal(String username) {
-        List<String> controllerRoles = new ArrayList<String>();
-        controllerRoles.add("System-Admin");
-        return new GenericPrincipal(username, "", controllerRoles);
-    }
-
-    @Override
-    public Principal authenticate(String username, String credentials) {
-        return this.getPrincipal(username);
-    }
-}
diff --git a/opendaylight/adsal/logging/bridge/pom.xml b/opendaylight/adsal/logging/bridge/pom.xml
deleted file mode 100644 (file)
index c9caabe..0000000
+++ /dev/null
@@ -1,65 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>logging.bridge</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-
-  <dependencies>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>org.eclipse.osgi</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.slf4j</groupId>
-      <artifactId>slf4j-api</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>ch.qos.logback</groupId>
-      <artifactId>logback-classic</artifactId>
-      <scope>test</scope>
-    </dependency>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-      <scope>test</scope>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.yangtools</groupId>
-      <artifactId>mockito-configuration</artifactId>
-      <scope>test</scope>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Import-Package>org.slf4j,
-                            org.osgi.framework,
-                            org.osgi.service.log</Import-Package>
-            <Bundle-Activator>org.opendaylight.controller.logging.bridge.internal.Activator</Bundle-Activator>
-          </instructions>
-          <manifestLocation>${project.basedir}/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/logging/bridge/src/main/java/org/opendaylight/controller/logging/bridge/internal/Activator.java b/opendaylight/adsal/logging/bridge/src/main/java/org/opendaylight/controller/logging/bridge/internal/Activator.java
deleted file mode 100644 (file)
index fcd27d9..0000000
+++ /dev/null
@@ -1,135 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.logging.bridge.internal;
-
-import org.osgi.service.log.LogEntry;
-
-import java.lang.Thread.UncaughtExceptionHandler;
-import java.util.Enumeration;
-
-import org.osgi.framework.BundleContext;
-import org.osgi.framework.BundleException;
-import org.osgi.framework.BundleActivator;
-import org.osgi.framework.ServiceReference;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-import org.slf4j.ILoggerFactory;
-import org.osgi.service.log.LogReaderService;
-
-public class Activator implements BundleActivator {
-    private static final String UNCAUGHT_EXCEPTION_POLICY_PROP = "controller.uncaughtExceptionPolicy";
-    private static final UncaughtExceptionPolicy DEFAULT_UNCAUGHT_EXCEPTION_POLICY = UncaughtExceptionPolicy.IGNORE;
-
-    private LogListenerImpl listener = null;
-    private ShutdownHandler shutdownHandler = null;
-    private Logger log = null;
-
-    @Override
-    public void start(BundleContext context) {
-        // Lets trigger the resolution of the slf4j logger factory
-        ILoggerFactory f = LoggerFactory.getILoggerFactory();
-
-        // Now retrieve a logger for the bridge
-        log = f
-                .getLogger("org.opendaylight.controller.logging.bridge.OSGI2SLF4J");
-
-        if (this.log != null) {
-            this.listener = new LogListenerImpl(log);
-
-            ServiceReference service = null;
-            service = context.getServiceReference(LogReaderService.class
-                    .getName());
-            if (service != null) {
-                LogReaderService reader = (LogReaderService) context
-                        .getService(service);
-                if (reader == null) {
-                    this.log.error("Cannot register the LogListener because "
-                            + "cannot retrieve LogReaderService");
-                } else {
-                    reader.addLogListener(this.listener);
-                    // Now lets walk all the exiting messages
-                    Enumeration<LogEntry> entries = reader.getLog();
-                    if (entries != null) {
-                        while (entries.hasMoreElements()) {
-                            LogEntry entry = entries.nextElement();
-                            this.listener.logged(entry);
-                        }
-                    }
-                }
-
-                /*
-                 * Install the default exception handler so that the uncaught
-                 * exceptions are handled by our customized handler. This new
-                 * handler will display the exceptions to OSGI console as well
-                 * as log to file.
-                 */
-                UncaughtExceptionHandler handler = DEFAULT_UNCAUGHT_EXCEPTION_POLICY;
-                final String policy = context.getProperty(UNCAUGHT_EXCEPTION_POLICY_PROP);
-                if (policy != null) {
-                    try {
-                        handler = UncaughtExceptionPolicy.valueOf(policy.toUpperCase());
-                    } catch (IllegalArgumentException ex) {
-                        log.warn("Invalid policy name \"{}\", defaulting to {}", policy, handler);
-                    }
-                }
-                log.trace("Setting uncaught exception policy to {}", handler);
-                Thread.setDefaultUncaughtExceptionHandler(handler);
-
-                /*
-                 * Install the Shutdown handler. This will intercept SIGTERM signal and
-                 * close the system bundle. This allows for a graceful  closing of OSGI
-                 * framework.
-                 */
-                shutdownHandler = new ShutdownHandler(context);
-                Runtime.getRuntime().addShutdownHook(shutdownHandler);
-            } else {
-                this.log.error("Cannot register the LogListener because "
-                        + "cannot retrieve LogReaderService");
-            }
-        } else {
-            System.err
-                    .println("Could not initialize the logging bridge subsytem");
-        }
-    }
-
-    @Override
-    public void stop(BundleContext context) {
-        ServiceReference serviceRef = context.getServiceReference(
-                LogReaderService.class.getName());
-        if (serviceRef != null) {
-            LogReaderService reader = (LogReaderService) context.getService(serviceRef);
-            reader.removeLogListener(this.listener);
-        }
-        if (this.shutdownHandler != null) {
-            Runtime.getRuntime().removeShutdownHook(this.shutdownHandler);
-        }
-        this.listener = null;
-        this.log = null;
-        this.shutdownHandler = null;
-    }
-
-    private class ShutdownHandler extends Thread {
-        BundleContext bundlecontext;
-        public ShutdownHandler(BundleContext ctxt) {
-                this.bundlecontext = ctxt;
-        }
-
-        @Override
-        public void run () {
-            try {
-                this.bundlecontext.getBundle(0).stop();
-                log.debug("shutdown handler thread called");
-            } catch (BundleException e) {
-                log.debug("Bundle couldn't be stopped");
-            } catch (Exception e) {
-                log.debug("Unhandled exception");
-            }
-        }
-    }
-
-}
diff --git a/opendaylight/adsal/logging/bridge/src/main/java/org/opendaylight/controller/logging/bridge/internal/LogListenerImpl.java b/opendaylight/adsal/logging/bridge/src/main/java/org/opendaylight/controller/logging/bridge/internal/LogListenerImpl.java
deleted file mode 100644 (file)
index 2f45c6f..0000000
+++ /dev/null
@@ -1,47 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.logging.bridge.internal;
-
-import org.osgi.service.log.LogEntry;
-import org.osgi.service.log.LogListener;
-import org.osgi.service.log.LogService;
-import org.slf4j.Logger;
-
-public class LogListenerImpl implements LogListener {
-    private Logger logger = null;
-
-    public LogListenerImpl(Logger l) {
-        this.logger = l;
-    }
-
-    @Override
-    public void logged(LogEntry entry) {
-        if (this.logger != null) {
-            switch (entry.getLevel()) {
-            case LogService.LOG_DEBUG:
-                this.logger.debug("Bundle:{} Message:{}", entry.getBundle()
-                        .getSymbolicName(), entry.getMessage(), entry.getException());
-                break;
-            case LogService.LOG_INFO:
-                this.logger.info("Bundle:{} Message:{}", entry.getBundle()
-                        .getSymbolicName(), entry.getMessage(), entry.getException());
-                break;
-            case LogService.LOG_WARNING:
-                this.logger.warn("Bundle:{} Message:{}", entry.getBundle()
-                        .getSymbolicName(), entry.getMessage(), entry.getException());
-                break;
-            case LogService.LOG_ERROR:
-                this.logger.error("Bundle:{} Message:{}", entry.getBundle()
-                        .getSymbolicName(), entry.getMessage(), entry.getException());
-                break;
-            }
-        }
-    }
-}
diff --git a/opendaylight/adsal/logging/bridge/src/main/java/org/opendaylight/controller/logging/bridge/internal/UncaughtExceptionPolicy.java b/opendaylight/adsal/logging/bridge/src/main/java/org/opendaylight/controller/logging/bridge/internal/UncaughtExceptionPolicy.java
deleted file mode 100644 (file)
index 0545578..0000000
+++ /dev/null
@@ -1,31 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.logging.bridge.internal;
-
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-enum UncaughtExceptionPolicy implements Thread.UncaughtExceptionHandler {
-    ABORT {
-        public static final int EXIT_CODE = 1;
-
-        @Override
-        public void uncaughtException(final Thread t, final Throwable e) {
-            log.error("Thread {} died because of an uncaught exception, forcing virtual machine shutdown", t, e);
-            System.exit(EXIT_CODE);
-        }
-    },
-    IGNORE {
-        @Override
-        public void uncaughtException(final Thread t, final Throwable e) {
-            log.error("Thread {} died because of an uncaught exception", t, e);
-        }
-    };
-
-    private static final Logger log = LoggerFactory.getLogger(UncaughtExceptionPolicy.class);
-}
diff --git a/opendaylight/adsal/logging/bridge/src/test/java/org/opendaylight/controller/logging/bridge/internal/LogListenerImplTest.java b/opendaylight/adsal/logging/bridge/src/test/java/org/opendaylight/controller/logging/bridge/internal/LogListenerImplTest.java
deleted file mode 100644 (file)
index 2490c39..0000000
+++ /dev/null
@@ -1,67 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.logging.bridge.internal;
-
-import org.junit.Test;
-import org.osgi.framework.Bundle;
-import org.osgi.framework.ServiceReference;
-import org.osgi.service.log.LogEntry;
-import org.osgi.service.log.LogService;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import static org.mockito.Mockito.doReturn;
-import static org.mockito.Mockito.mock;
-
-public class LogListenerImplTest {
-    private static final Logger logger = LoggerFactory.getLogger(LogListenerImplTest.class);
-
-    @Test
-    public void test() {
-        LogListenerImpl tested = new LogListenerImpl(logger);
-        tested.logged(getEntry("m1", null));
-        tested.logged(getEntry("m2", new RuntimeException()));
-    }
-
-    private LogEntry getEntry(final String message, final Exception e) {
-        return new LogEntry() {
-            @Override
-            public Bundle getBundle() {
-                Bundle mock = mock(Bundle.class);
-                doReturn(null).when(mock).getSymbolicName();
-                return mock;
-            }
-
-            @Override
-            public ServiceReference getServiceReference() {
-                return null;
-            }
-
-            @Override
-            public int getLevel() {
-                return LogService.LOG_INFO;
-            }
-
-            @Override
-            public String getMessage() {
-                return message;
-            }
-
-            @Override
-            public Throwable getException() {
-                return e;
-            }
-
-            @Override
-            public long getTime() {
-                return 0;
-            }
-        };
-    }
-
-}
diff --git a/opendaylight/adsal/northbound/archetype-app-northbound/pom.xml b/opendaylight/adsal/northbound/archetype-app-northbound/pom.xml
deleted file mode 100644 (file)
index cc49fc9..0000000
+++ /dev/null
@@ -1,30 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-
-  <groupId>org.opendaylight.controller</groupId>
-  <artifactId>app-northbound</artifactId>
-  <version>0.2.0-SNAPSHOT</version>
-  <packaging>maven-archetype</packaging>
-
-  <name>app-northbound</name>
-
-  <build>
-    <extensions>
-      <extension>
-        <groupId>org.apache.maven.archetype</groupId>
-        <artifactId>archetype-packaging</artifactId>
-        <version>2.2</version>
-      </extension>
-    </extensions>
-
-    <pluginManagement>
-      <plugins>
-        <plugin>
-          <artifactId>maven-archetype-plugin</artifactId>
-          <version>2.2</version>
-        </plugin>
-      </plugins>
-    </pluginManagement>
-  </build>
-</project>
diff --git a/opendaylight/adsal/northbound/archetype-app-northbound/src/main/resources/META-INF/maven/archetype-metadata.xml b/opendaylight/adsal/northbound/archetype-app-northbound/src/main/resources/META-INF/maven/archetype-metadata.xml
deleted file mode 100644 (file)
index 3c9223d..0000000
+++ /dev/null
@@ -1,32 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<archetype-descriptor xsi:schemaLocation="http://maven.apache.org/plugins/maven-archetype-plugin/archetype-descriptor/1.0.0 http://maven.apache.org/xsd/archetype-descriptor-1.0.0.xsd" name="app"
-    xmlns="http://maven.apache.org/plugins/maven-archetype-plugin/archetype-descriptor/1.0.0"
-    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
-  <fileSets>
-    <fileSet filtered="true" packaged="true" encoding="UTF-8">
-      <directory>src/main/java</directory>
-      <includes>
-        <include>**/*.java</include>
-      </includes>
-    </fileSet>
-    <fileSet filtered="true" encoding="UTF-8">
-      <directory>src/main/resources</directory>
-      <includes>
-        <include>**/*.xml</include>
-      </includes>
-    </fileSet>
-    <fileSet encoding="UTF-8">
-      <directory>.settings</directory>
-      <includes>
-        <include>**/*.prefs</include>
-      </includes>
-    </fileSet>
-    <fileSet filtered="true" encoding="UTF-8">
-      <directory></directory>
-      <includes>
-        <include>.classpath</include>
-        <include>.project</include>
-      </includes>
-    </fileSet>
-  </fileSets>
-</archetype-descriptor>
diff --git a/opendaylight/adsal/northbound/archetype-app-northbound/src/main/resources/archetype-resources/pom.xml b/opendaylight/adsal/northbound/archetype-app-northbound/src/main/resources/archetype-resources/pom.xml
deleted file mode 100644 (file)
index 5215846..0000000
+++ /dev/null
@@ -1,63 +0,0 @@
-#set( $dollar = '$' )
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>${artifactId}</artifactId>
-
-  <groupId>${groupId}</groupId>
-  <packaging>bundle</packaging>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <version>${bundle.plugin.version}</version>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Export-Package></Export-Package>
-            <Import-Package>org.opendaylight.controller.northbound.commons,
-              com.sun.jersey.spi.container.servlet,
-              com.fasterxml.jackson.annotation,
-              javax.ws.rs,
-              javax.ws.rs.core,
-              javax.xml.bind,
-              javax.xml.bind.annotation,
-              org.slf4j,
-              org.apache.catalina.filters,
-              com.fasterxml.jackson.jaxrs.base,
-              com.fasterxml.jackson.jaxrs.json,
-              !org.codehaus.enunciate.jaxrs</Import-Package>
-            <Web-ContextPath>/northbound/${artifactId}</Web-ContextPath>
-            <Jaxrs-Resources>,${dollar}{classes;ANNOTATION;javax.ws.rs.Path}</Jaxrs-Resources>
-          </instructions>
-          <manifestLocation>${project.basedir}/src/main/resources/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-
-  <version>${version}</version>
-  <dependencies>
-    <dependency>
-      <groupId>org.codehaus.enunciate</groupId>
-      <artifactId>enunciate-core-annotations</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>commons.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-    </dependency>
-  </dependencies>
-</project>
diff --git a/opendaylight/adsal/northbound/archetype-app-northbound/src/main/resources/archetype-resources/src/main/java/Northbound.java b/opendaylight/adsal/northbound/archetype-app-northbound/src/main/resources/archetype-resources/src/main/java/Northbound.java
deleted file mode 100644 (file)
index 788dec8..0000000
+++ /dev/null
@@ -1,70 +0,0 @@
-#set( $symbol_pound = '#' )
-#set( $symbol_dollar = '$' )
-#set( $symbol_escape = '\' )
-package ${package};
-
-import javax.ws.rs.GET;
-import javax.ws.rs.Path;
-import javax.ws.rs.Produces;
-import javax.ws.rs.core.Context;
-import javax.ws.rs.core.MediaType;
-import javax.ws.rs.core.SecurityContext;
-
-import org.codehaus.enunciate.jaxrs.StatusCodes;
-import org.codehaus.enunciate.jaxrs.TypeHint;
-
-/**
- * Northbound REST API
- *
- * <br>
- * <br>
- * Authentication scheme : <b>HTTP Basic</b><br>
- * Authentication realm : <b>opendaylight</b><br>
- * Transport : <b>HTTP and HTTPS</b><br>
- * <br>
- * HTTPS Authentication is disabled by default.
- */
-
-@Path("/")
-public class Northbound {
-
-    private String username;
-
-    @Context
-    public void setSecurityContext(SecurityContext context) {
-        if (context != null && context.getUserPrincipal() != null) {
-            username = context.getUserPrincipal().getName();
-        }
-    }
-
-    /**
-     *
-     * Sample REST API call
-     *
-     * @return A response string
-     *
-     *         <pre>
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/northbound/${artifactId}/api
-     *
-     * Response body in XML:
-     * &lt;?xml version="1.0" encoding="UTF-8" standalone="yes"?&gt;
-     * Sample Northbound API
-     *
-     * Response body in JSON:
-     * Sample Northbound API
-     * </pre>
-     */
-    @Path("/api")
-    @GET
-    @Produces({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @TypeHint(String.class)
-    @StatusCodes()
-    public String getWidget() {
-        String result = "Sample Northbound API - ${artifactId}";
-        return result;
-    }
-
-}
diff --git a/opendaylight/adsal/northbound/archetype-app-northbound/src/main/resources/archetype-resources/src/main/resources/WEB-INF/web.xml b/opendaylight/adsal/northbound/archetype-app-northbound/src/main/resources/archetype-resources/src/main/resources/WEB-INF/web.xml
deleted file mode 100644 (file)
index a1d8376..0000000
+++ /dev/null
@@ -1,92 +0,0 @@
-#set( $symbol_pound = '#' )
-#set( $symbol_dollar = '$' )
-#set( $symbol_escape = '\' )
-<?xml version="1.0" encoding="ISO-8859-1"?>
-<web-app xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
-  xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
-  version="3.0">
-  <servlet>
-    <servlet-name>JAXRS${artifactId}</servlet-name>
-    <servlet-class>com.sun.jersey.spi.container.servlet.ServletContainer</servlet-class>
-    <init-param>
-      <param-name>javax.ws.rs.Application</param-name>
-      <param-value>org.opendaylight.controller.northbound.commons.NorthboundApplication</param-value>
-    </init-param>
-    <load-on-startup>1</load-on-startup>
-  </servlet>
-
-  <servlet-mapping>
-    <servlet-name>JAXRS${artifactId}</servlet-name>
-    <url-pattern>/*</url-pattern>
-  </servlet-mapping>
-
-  <filter>
-    <filter-name>CorsFilter</filter-name>
-    <filter-class>org.apache.catalina.filters.CorsFilter</filter-class>
-    <init-param>
-      <param-name>cors.allowed.origins</param-name>
-      <param-value>*</param-value>
-    </init-param>
-    <init-param>
-      <param-name>cors.allowed.methods</param-name>
-      <param-value>GET,POST,HEAD,OPTIONS,PUT,DELETE</param-value>
-    </init-param>
-    <init-param>
-      <param-name>cors.allowed.headers</param-name>
-      <param-value>Content-Type,X-Requested-With,accept,authorization, origin,Origin,Access-Control-Request-Method,Access-Control-Request-Headers</param-value>
-    </init-param>
-    <init-param>
-      <param-name>cors.exposed.headers</param-name>
-      <param-value>Access-Control-Allow-Origin,Access-Control-Allow-Credentials</param-value>
-    </init-param>
-    <init-param>
-      <param-name>cors.support.credentials</param-name>
-      <param-value>true</param-value>
-    </init-param>
-    <init-param>
-      <param-name>cors.preflight.maxage</param-name>
-      <param-value>10</param-value>
-    </init-param>
-  </filter>
-  <filter-mapping>
-    <filter-name>CorsFilter</filter-name>
-    <url-pattern>/*</url-pattern>
-  </filter-mapping>
-
-  <security-constraint>
-    <web-resource-collection>
-      <web-resource-name>${artifactId}</web-resource-name>
-      <url-pattern>/*</url-pattern>
-      <http-method>POST</http-method>
-      <http-method>GET</http-method>
-      <http-method>PUT</http-method>
-      <http-method>PATCH</http-method>
-      <http-method>DELETE</http-method>
-      <http-method>HEAD</http-method>
-    </web-resource-collection>
-    <auth-constraint>
-      <role-name>System-Admin</role-name>
-      <role-name>Network-Admin</role-name>
-      <role-name>Network-Operator</role-name>
-      <role-name>Container-User</role-name>
-    </auth-constraint>
-  </security-constraint>
-
-  <security-role>
-    <role-name>System-Admin</role-name>
-  </security-role>
-  <security-role>
-    <role-name>Network-Admin</role-name>
-  </security-role>
-  <security-role>
-    <role-name>Network-Operator</role-name>
-  </security-role>
-  <security-role>
-    <role-name>Container-User</role-name>
-  </security-role>
-
-  <login-config>
-    <auth-method>BASIC</auth-method>
-    <realm-name>opendaylight</realm-name>
-  </login-config>
-</web-app>
diff --git a/opendaylight/adsal/northbound/archetype-app-northbound/src/test/resources/projects/basic/archetype.properties b/opendaylight/adsal/northbound/archetype-app-northbound/src/test/resources/projects/basic/archetype.properties
deleted file mode 100644 (file)
index 40d9d65..0000000
+++ /dev/null
@@ -1,5 +0,0 @@
-#Fri Mar 07 21:17:20 CST 2014
-package=it.pkg
-version=0.1-SNAPSHOT
-groupId=archetype.it
-artifactId=basic
diff --git a/opendaylight/adsal/northbound/archetype-app-northbound/src/test/resources/projects/basic/goal.txt b/opendaylight/adsal/northbound/archetype-app-northbound/src/test/resources/projects/basic/goal.txt
deleted file mode 100644 (file)
index e69de29..0000000
diff --git a/opendaylight/adsal/northbound/bundlescanner/api/pom.xml b/opendaylight/adsal/northbound/bundlescanner/api/pom.xml
deleted file mode 100644 (file)
index c0acffd..0000000
+++ /dev/null
@@ -1,49 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>bundlescanner</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-
-  <dependencies>
-    <dependency>
-      <groupId>org.osgi</groupId>
-      <artifactId>org.osgi.core</artifactId>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Import-Package>org.osgi.framework,
-              org.slf4j,
-              javax.ws.rs,
-              javax.ws.rs.core,
-              javax.xml.bind.annotation,
-              javax.xml.bind,</Import-Package>
-            <Export-Package>org.opendaylight.controller.northbound.bundlescanner</Export-Package>
-          </instructions>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/northbound/bundlescanner/api/src/main/java/org/opendaylight/controller/northbound/bundlescanner/IBundleScanService.java b/opendaylight/adsal/northbound/bundlescanner/api/src/main/java/org/opendaylight/controller/northbound/bundlescanner/IBundleScanService.java
deleted file mode 100644 (file)
index dde205a..0000000
+++ /dev/null
@@ -1,36 +0,0 @@
-/**
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.northbound.bundlescanner;
-
-import java.util.List;
-import java.util.Set;
-
-import org.osgi.framework.BundleContext;
-
-/**
- * The bundle scan service provides services which allow introspection of
- * bundle classes for detecting annotated classes. The scanning is performed
- * when a bundle is RESOLVED.
- */
-public interface IBundleScanService {
-    /**
-     * The list of annotations to be scanned
-     */
-    public final String[] ANNOTATIONS_TO_SCAN = {
-        "javax.xml.bind.annotation.*", // JAXB annotatinos
-        "javax.ws.rs.*"                // JAX-RS annotatinos
-    };
-
-
-    public List<Class<?>> getAnnotatedClasses(
-            BundleContext context,
-            String[] annotations,
-            Set<String> excludes,
-            boolean includeDependentBundleClasses);
-}
diff --git a/opendaylight/adsal/northbound/bundlescanner/implementation/pom.xml b/opendaylight/adsal/northbound/bundlescanner/implementation/pom.xml
deleted file mode 100644 (file)
index dbf2f9e..0000000
+++ /dev/null
@@ -1,70 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>bundlescanner.implementation</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-
-  <dependencies>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>bundlescanner</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.ow2.asm</groupId>
-      <artifactId>asm-all</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.springframework.osgi</groupId>
-      <artifactId>spring-osgi-mock</artifactId>
-      <scope>test</scope>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Import-Package>org.apache.felix.dm,
-              org.objectweb.asm,
-              org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.northbound.bundlescanner,
-              org.osgi.framework,
-              org.slf4j,
-              javax.ws.rs,
-              javax.ws.rs.core,
-              javax.xml.bind.annotation,
-              javax.xml.bind,</Import-Package>
-            <Bundle-Activator>org.opendaylight.controller.northbound.bundlescanner.internal.Activator</Bundle-Activator>
-          </instructions>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/northbound/bundlescanner/implementation/src/main/java/org/opendaylight/controller/northbound/bundlescanner/internal/Activator.java b/opendaylight/adsal/northbound/bundlescanner/implementation/src/main/java/org/opendaylight/controller/northbound/bundlescanner/internal/Activator.java
deleted file mode 100644 (file)
index abe8618..0000000
+++ /dev/null
@@ -1,50 +0,0 @@
-/**
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.northbound.bundlescanner.internal;
-
-import org.apache.felix.dm.Component;
-import org.opendaylight.controller.northbound.bundlescanner.IBundleScanService;
-import org.opendaylight.controller.sal.core.ComponentActivatorAbstractBase;
-import org.osgi.framework.BundleContext;
-import org.osgi.framework.FrameworkUtil;
-
-/**
- * The activator registers the BundleScanner.
- */
-public class Activator extends ComponentActivatorAbstractBase {
-
-    @Override
-    protected void init() {
-        BundleContext context = FrameworkUtil.getBundle(BundleScanner.class).getBundleContext();
-        context.addBundleListener(BundleScanner.getInstance());
-    }
-
-    @Override
-    public void destroy() {
-        BundleContext context = FrameworkUtil.getBundle(BundleScanner.class).getBundleContext();
-        context.removeBundleListener(BundleScanner.getInstance());
-    }
-
-    @Override
-    protected Object[] getGlobalImplementations() {
-        return new Object[] { BundleScanServiceImpl.class };
-    }
-
-    @Override
-    protected void configureGlobalInstance(Component c, Object imp) {
-        if (!imp.equals(BundleScanServiceImpl.class)) {
-            return;
-        }
-        // export service
-        c.setInterface(
-                new String[] { IBundleScanService.class.getName() },
-                null);
-    }
-
-}
diff --git a/opendaylight/adsal/northbound/bundlescanner/implementation/src/main/java/org/opendaylight/controller/northbound/bundlescanner/internal/BundleInfo.java b/opendaylight/adsal/northbound/bundlescanner/implementation/src/main/java/org/opendaylight/controller/northbound/bundlescanner/internal/BundleInfo.java
deleted file mode 100644 (file)
index 31c81da..0000000
+++ /dev/null
@@ -1,187 +0,0 @@
-/**
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.northbound.bundlescanner.internal;
-
-import java.util.ArrayList;
-import java.util.Collection;
-import java.util.Collections;
-import java.util.Dictionary;
-import java.util.HashSet;
-import java.util.List;
-import java.util.Map;
-import java.util.Set;
-import java.util.regex.Pattern;
-
-import org.osgi.framework.Bundle;
-import org.osgi.framework.Constants;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * BundleInfo holds information related to the bundle obtained during the
- * bundle scan process.
- */
-/*package*/ class BundleInfo {
-    private static final Logger LOGGER = LoggerFactory.getLogger(BundleInfo.class);
-
-    private final Bundle bundle;
-    private final Map<String, Set<String>> annotatedClasses;
-    private final Set<String> exportPkgs;
-    private final Set<String> importPkgs;
-
-    public BundleInfo(Bundle bundle, Map<String, Set<String>> classes) {
-        this.bundle = bundle;
-        this.annotatedClasses = classes;
-        Dictionary<String, String> dict = bundle.getHeaders();
-        this.importPkgs = parsePackages(dict.get(Constants.IMPORT_PACKAGE));
-        this.exportPkgs = parsePackages(dict.get(Constants.EXPORT_PACKAGE));
-    }
-
-    @Override
-    public String toString() {
-        StringBuilder sb = new StringBuilder(super.toString());
-        sb.append("{name:").append(bundle.getSymbolicName())
-          .append(" id:").append(getId())
-          .append(" annotated-classes:").append(annotatedClasses)
-          .append(" imports:").append(importPkgs)
-          .append(" exports:").append(exportPkgs).append("}");
-        return sb.toString();
-    }
-
-    public Bundle getBundle() {
-        return bundle;
-    }
-
-    public long getId() {
-        return bundle.getBundleId();
-    }
-
-    public List<Class<?>> getAnnotatedClasses(Pattern pattern, Set<String> excludes) {
-        List<String> result = new ArrayList<String>();
-        for (Map.Entry<String, Set<String>> entry : annotatedClasses.entrySet()) {
-            if (matches(pattern, entry.getValue())) {
-                result.add(entry.getKey());
-            }
-        }
-        return BundleScanner.loadClasses(result, bundle, excludes);
-    }
-
-    private boolean matches(Pattern pattern, Set<String> values) {
-        if (pattern == null) {
-            return true;
-        }
-        //LOGGER.debug("Matching: {} {}", pattern.toString(), values);
-        for (String s : values) {
-            if (pattern.matcher(s).find()) {
-                return true;
-            }
-        }
-        return false;
-    }
-
-    /**
-     * Get classes with annotations matching a pattern
-     *
-     * @param allbundles - all bundles
-     * @param pattern - annotation pattern to match
-     * @param initBundle - the bundle which initiated this call
-     * @param excludes - set of class names to be excluded
-     *
-     * @return list of annotated classes matching the pattern
-     */
-    public List<Class<?>> getAnnotatedClasses(
-            Collection<BundleInfo> allbundles,
-            Pattern pattern, Bundle initBundle,
-            Set<String> excludes)
-    {
-        List<Class<?>> classes = getAnnotatedClasses(pattern, excludes);
-        processAnnotatedClassesInternal(this, allbundles, pattern,
-                new HashSet<BundleInfo>(), classes, initBundle, excludes);
-        return classes;
-    }
-
-    private List<String> getExportedAnnotatedClasses(Pattern pattern) {
-        List<String> classes = new ArrayList<String>();
-        for (Map.Entry<String, Set<String>> entry : annotatedClasses.entrySet()) {
-            String cls = entry.getKey();
-            int idx = cls.lastIndexOf(".");
-            String pkg = (idx == -1 ? "" : cls.substring(0, idx));
-            // for a class to match, the package has to be exported and
-            // annotations should match the given pattern
-            if (exportPkgs.contains(pkg) && matches(pattern, entry.getValue())) {
-                classes.add(cls);
-            }
-        }
-        if (LOGGER.isDebugEnabled()) {
-            LOGGER.debug("Found in bundle:{} exported classes:[{}]",
-                    getBundle().getSymbolicName(), classes);
-        }
-        return classes;
-    }
-
-    private static void processAnnotatedClassesInternal(
-            BundleInfo target,
-            Collection<BundleInfo> bundlesToScan,
-            Pattern pattern,
-            Collection<BundleInfo> visited,
-            List<Class<?>> classes,
-            Bundle initBundle, Set<String> excludes)
-    {
-        for (BundleInfo other : bundlesToScan) {
-            if (other.getId() == target.getId()) {
-                continue;
-            }
-            if (target.isDependantOn(other)) {
-                if (!visited.contains(other)) {
-                    classes.addAll(BundleScanner.loadClasses(
-                            other.getExportedAnnotatedClasses(pattern),
-                            initBundle, excludes));
-                    visited.add(other);
-                    processAnnotatedClassesInternal(other, bundlesToScan,
-                            pattern, visited, classes, initBundle, excludes);
-                }
-            }
-        }
-    }
-
-    private boolean isDependantOn(BundleInfo other) {
-        for (String pkg : importPkgs) {
-            if (other.exportPkgs.contains(pkg)) {
-                return true;
-            }
-        }
-        return false;
-    }
-
-    public List<BundleInfo> getDependencies(Collection<BundleInfo> bundles) {
-        List<BundleInfo> result = new ArrayList<BundleInfo>();
-        for(BundleInfo bundle : bundles) {
-            if (isDependantOn(bundle)) {
-                result.add(bundle);
-            }
-        }
-        return result;
-    }
-
-
-    private static Set<String> parsePackages(String packageString) {
-        if (packageString == null) {
-            return Collections.emptySet();
-        }
-        String[] packages = packageString.split(",");
-        Set<String> result = new HashSet<String>();
-        for (int i=0; i<packages.length; i++) {
-            String[] nameAndAttrs = packages[i].split(";");
-            String packageName = nameAndAttrs[0].trim();
-            result.add(packageName);
-        }
-        return result;
-    }
-
-}
diff --git a/opendaylight/adsal/northbound/bundlescanner/implementation/src/main/java/org/opendaylight/controller/northbound/bundlescanner/internal/BundleScanServiceImpl.java b/opendaylight/adsal/northbound/bundlescanner/implementation/src/main/java/org/opendaylight/controller/northbound/bundlescanner/internal/BundleScanServiceImpl.java
deleted file mode 100644 (file)
index ec3f5ad..0000000
+++ /dev/null
@@ -1,31 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.northbound.bundlescanner.internal;
-
-import java.util.List;
-import java.util.Set;
-
-import org.opendaylight.controller.northbound.bundlescanner.IBundleScanService;
-import org.osgi.framework.BundleContext;
-
-public class BundleScanServiceImpl implements IBundleScanService {
-
-    public BundleScanServiceImpl() {}
-
-
-    @Override
-    public List<Class<?>> getAnnotatedClasses(BundleContext context,
-            String[] annotations,
-            Set<String> excludes,
-            boolean includeDependentBundleClasses)
-    {
-        return BundleScanner.getInstance().getAnnotatedClasses(
-                context, annotations, excludes, includeDependentBundleClasses);
-    }
-
-}
diff --git a/opendaylight/adsal/northbound/bundlescanner/implementation/src/main/java/org/opendaylight/controller/northbound/bundlescanner/internal/BundleScanner.java b/opendaylight/adsal/northbound/bundlescanner/implementation/src/main/java/org/opendaylight/controller/northbound/bundlescanner/internal/BundleScanner.java
deleted file mode 100644 (file)
index f6b604d..0000000
+++ /dev/null
@@ -1,330 +0,0 @@
-/**
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.northbound.bundlescanner.internal;
-
-import java.io.IOException;
-import java.io.InputStream;
-import java.net.URL;
-import java.util.ArrayList;
-import java.util.Collection;
-import java.util.Collections;
-import java.util.Enumeration;
-import java.util.HashMap;
-import java.util.HashSet;
-import java.util.List;
-import java.util.Map;
-import java.util.Set;
-import java.util.regex.Pattern;
-
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.objectweb.asm.AnnotationVisitor;
-import org.objectweb.asm.ClassReader;
-import org.objectweb.asm.ClassVisitor;
-import org.objectweb.asm.Opcodes;
-import org.opendaylight.controller.northbound.bundlescanner.IBundleScanService;
-import org.osgi.framework.Bundle;
-import org.osgi.framework.BundleContext;
-import org.osgi.framework.BundleEvent;
-import org.osgi.framework.FrameworkUtil;
-import org.osgi.framework.SynchronousBundleListener;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * The custom bundle scanner scans annotations on bundles and is used for
- * constructing JAXBContext instances. It listens for bundle events and updates
- * the metadata in realtime.
- */
-/*package*/ class BundleScanner implements SynchronousBundleListener {
-    private static final Logger LOGGER = LoggerFactory.getLogger(BundleScanner.class);
-    private static BundleScanner INSTANCE; // singleton
-
-    private final Pattern annotationPattern;
-    private final Map<Long,BundleInfo> bundleAnnotations =
-            new HashMap<Long, BundleInfo>();
-
-    public static synchronized BundleScanner getInstance() {
-        if (INSTANCE == null) {
-            INSTANCE = new BundleScanner();
-        }
-        return INSTANCE;
-    }
-
-    /*package*/ BundleScanner(Bundle[] bundles) {
-        annotationPattern = mergePatterns(IBundleScanService.ANNOTATIONS_TO_SCAN, true);
-        init(bundles);
-    }
-
-    /*package*/ BundleScanner() {
-        this(FrameworkUtil.getBundle(BundleScanner.class).getBundleContext().getBundles());
-    }
-
-    public List<Class<?>> getAnnotatedClasses(BundleContext context,
-            String[] annotations,
-            Set<String> excludes,
-            boolean includeDependentBundleClasses)
-    {
-        BundleInfo info = bundleAnnotations.get(context.getBundle().getBundleId());
-        if (info == null) {
-            return Collections.emptyList();
-        }
-        Pattern pattern = mergePatterns(annotations, false);
-        List<Class<?>> result = null;
-        if (includeDependentBundleClasses) {
-            result = info.getAnnotatedClasses(bundleAnnotations.values(),
-                    pattern, context.getBundle(), excludes);
-            // reverse the list to give precedence to the types loaded from the
-            // initiating bundle
-            Collections.reverse(result);
-            // validate for conflicts only when searching dependencies
-            validate(result);
-        } else {
-            result = info.getAnnotatedClasses(pattern, excludes);
-        }
-        LOGGER.debug("Annotated classes detected: {} matching: {}", result, pattern);
-        return result;
-    }
-
-    ////////////////////////////////////////////////////////////////
-    // SynchronousBundleListener implementation
-    ////////////////////////////////////////////////////////////////
-
-    @Override
-    public void bundleChanged(BundleEvent event) {
-        Bundle bundle = event.getBundle();
-        long id = bundle.getBundleId();
-        switch(event.getType()) {
-            case BundleEvent.RESOLVED :
-                scan(bundle);
-                return;
-            case BundleEvent.UNRESOLVED :
-            case BundleEvent.UNINSTALLED :
-                bundleAnnotations.remove(id);
-                return;
-        }
-    }
-
-
-    ////////////////////////////////////////////////////////////////
-    //  ClassVisitor implementation
-    ////////////////////////////////////////////////////////////////
-
-    private static class AnnotationDetector extends ClassVisitor {
-        private final Map<String, Set<String>> matchedClasses =
-                new HashMap<String, Set<String>>();
-
-        private final Pattern annotationsPattern;
-        private Set<String> annotations;
-        private String className;
-        private boolean accessible;
-        private boolean matchedAnnotation;
-
-        public AnnotationDetector(Pattern pattern) {
-            super(Opcodes.ASM4);
-            this.annotationsPattern = pattern;
-        }
-
-        public Map<String, Set<String>> getMatchedClasses() {
-            return new HashMap<String, Set<String>>(matchedClasses);
-        }
-
-        @Override
-        public void visit(int version, int access, String name, String signature,
-                String superName, String[] interfaces)
-        {
-            //LOGGER.debug("Visiting class:" + name);
-            className = name;
-            accessible = ((access & Opcodes.ACC_PUBLIC) == Opcodes.ACC_PUBLIC);
-            matchedAnnotation = false;
-            annotations = new HashSet<String>();
-        }
-
-        @Override
-        public AnnotationVisitor visitAnnotation(String desc, boolean visible) {
-            //LOGGER.debug("Visiting annotation:" + desc);
-            annotations.add(signature2class(desc));
-            if (!matchedAnnotation) {
-                matchedAnnotation = (annotationsPattern == null ||
-                        annotationsPattern.matcher(desc).find());
-            }
-            return null;
-        }
-
-        @Override
-        public void visitEnd() {
-            if (matchedAnnotation && accessible) {
-                className = path2class(className);
-                matchedClasses.put(className, new HashSet<String>(annotations));
-            }
-        }
-    }
-
-    ////////////////////////////////////////////////////////////////
-    // Helpers
-    ////////////////////////////////////////////////////////////////
-
-    private synchronized void init(Bundle[] bundles) {
-        for (Bundle bundle : bundles) {
-            int state = bundle.getState();
-            if (state == Bundle.RESOLVED ||
-                state == Bundle.STARTING ||
-                state == Bundle.ACTIVE)
-            {
-                scan(bundle);
-            }
-        }
-    }
-
-    private static String path2class(String path) {
-        return path.replace(".class", "").replaceAll("/", ".");
-    }
-
-    private static String class2path(String clz) {
-        return clz.replaceAll("\\.", "/");
-    }
-
-    @SuppressWarnings("unused")
-    private static String class2signature(String clz) {
-        return "L" + class2path(clz) + ";";
-    }
-
-    private static String signature2class(String sig) {
-        if (sig.startsWith("L") && sig.endsWith(";")) {
-            sig = sig.substring(1, sig.length()-1);
-        }
-        return path2class(sig);
-    }
-
-   private static List<URL> getBundleClasses(Bundle bundle, String[] pkgs) {
-        List<URL> result = new ArrayList<URL>();
-        boolean recurse = false;
-        if (pkgs == null) {
-            recurse = true;
-            pkgs = new String[] { "/" } ;
-        }
-        for (String pkg : pkgs) {
-            pkg = class2path(pkg);
-            final Enumeration<URL> e = bundle.findEntries(pkg, "*.class", recurse);
-            if (e != null) {
-                while (e.hasMoreElements()) {
-                    URL url = e.nextElement();
-                    result.add(url);
-                }
-            }
-        }
-        return result;
-    }
-
-    private synchronized void scan(Bundle bundle) {
-        AnnotationDetector detector = new AnnotationDetector(annotationPattern);
-        try {
-            for (URL u : getBundleClasses(bundle, null)) {
-                InputStream is = u.openStream();
-                new ClassReader(is).accept(detector, 0);
-                is.close();
-            }
-        } catch (IOException ioe) {
-            LOGGER.error("Error scanning classes in bundle: {}", bundle.getSymbolicName(), ioe);
-        }
-        Map<String, Set<String>> classes = detector.getMatchedClasses();
-        if (classes != null && classes.size() > 0) {
-            BundleInfo info = new BundleInfo(bundle, classes);
-            bundleAnnotations.put(bundle.getBundleId(),info);
-            if (LOGGER.isDebugEnabled()) {
-                LOGGER.debug("bindings found in bundle: {}[{}] " +
-                        "dependencies {} classes {}", bundle.getSymbolicName(),
-                        bundle.getBundleId(),
-                        info.getDependencies(bundleAnnotations.values()),
-                        classes);
-            }
-        }
-        // find bundle dependencies
-    }
-
-    public static List<Class<?>> loadClasses(
-            Collection<String> annotatedClasses,
-            Bundle initBundle, Set<String> excludes)
-    {
-        List<Class<?>> result = new ArrayList<Class<?>>();
-        StringBuilder errors = new StringBuilder();
-        for (String name : annotatedClasses) {
-            try {
-                if (excludes != null && excludes.contains(name)) {
-                    continue;
-                }
-                result.add(initBundle.loadClass(name));
-            } catch (ClassNotFoundException e) {
-                errors.append(name).append(", ");
-            }
-        }
-        if (LOGGER.isDebugEnabled() && errors.length() > 0) {
-            LOGGER.debug("Bundle: {} could not load classes: {}",
-                    initBundle.getSymbolicName(), errors.toString());
-        }
-        return result;
-    }
-
-    public static Pattern mergePatterns(String[] patterns, boolean convert2signature) {
-        if (patterns == null || patterns.length == 0) {
-            return null;
-        }
-        StringBuilder regex = new StringBuilder();
-        for (String c : patterns) {
-            if (c.endsWith("*")) {
-                c = c.substring(0, c.length() - 1);
-            }
-            if (regex.length() > 0) {
-                regex.append("|");
-            }
-            regex.append("^");
-            if (convert2signature) {
-                regex.append("L").append(c.replaceAll("\\.", "/"));
-            } else {
-                regex.append(c);
-            }
-        }
-        if (LOGGER.isDebugEnabled()) {
-            LOGGER.debug("Merged regex: [{}]", regex.toString());
-        }
-        return Pattern.compile(regex.toString());
-    }
-
-    private void validate(List<Class<?>> classes) {
-        if (classes == null || classes.size() == 0) {
-            return;
-        }
-        Map<String,String> names = new HashMap<String,String>();
-        StringBuilder conflictsMsg = new StringBuilder();
-        for (Class<?> c : classes) {
-            XmlRootElement root = c.getAnnotation(XmlRootElement.class);
-            if (root == null) {
-                continue;
-            }
-            String rootName = root.name();
-            if ("##default".equals(rootName)) {
-                String clsName = c.getSimpleName();
-                rootName = Character.toLowerCase(clsName.charAt(0)) + clsName.substring(1);
-            }
-            String other = names.get(rootName);
-            if (other != null && !other.equals(c.getName())) {
-                conflictsMsg.append(System.lineSeparator())
-                    .append("[").append(rootName).append(":")
-                    .append(c.getName()).append(",").append(other)
-                    .append("]");
-            } else {
-                names.put(rootName, c.getName());
-            }
-        }
-        if (conflictsMsg.length() > 0) {
-            LOGGER.warn("JAXB type conflicts detected : {}", conflictsMsg.toString());
-        }
-    }
-
-}
diff --git a/opendaylight/adsal/northbound/bundlescanner/implementation/src/test/java/bundle_base/Animal.java b/opendaylight/adsal/northbound/bundlescanner/implementation/src/test/java/bundle_base/Animal.java
deleted file mode 100644 (file)
index 693c6ae..0000000
+++ /dev/null
@@ -1,13 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package bundle_base;
-
-import javax.xml.bind.annotation.XmlRootElement;
-
-@XmlRootElement
-public abstract class Animal { }
diff --git a/opendaylight/adsal/northbound/bundlescanner/implementation/src/test/java/bundle_base/BasePerson.java b/opendaylight/adsal/northbound/bundlescanner/implementation/src/test/java/bundle_base/BasePerson.java
deleted file mode 100644 (file)
index bfb8b35..0000000
+++ /dev/null
@@ -1,14 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package bundle_base;
-
-import javax.xml.bind.annotation.XmlRootElement;
-
-
-@XmlRootElement
-public class BasePerson { }
diff --git a/opendaylight/adsal/northbound/bundlescanner/implementation/src/test/java/bundle_base/Mammal.java b/opendaylight/adsal/northbound/bundlescanner/implementation/src/test/java/bundle_base/Mammal.java
deleted file mode 100644 (file)
index d6162b6..0000000
+++ /dev/null
@@ -1,13 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package bundle_base;
-
-import javax.xml.bind.annotation.XmlRootElement;
-
-@XmlRootElement
-public class Mammal extends Animal { }
diff --git a/opendaylight/adsal/northbound/bundlescanner/implementation/src/test/java/bundle_base/NoAnnotation.java b/opendaylight/adsal/northbound/bundlescanner/implementation/src/test/java/bundle_base/NoAnnotation.java
deleted file mode 100644 (file)
index 7e9069b..0000000
+++ /dev/null
@@ -1,10 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package bundle_base;
-
-public class NoAnnotation { }
diff --git a/opendaylight/adsal/northbound/bundlescanner/implementation/src/test/java/bundle_base/NonRelevantAnnotation.java b/opendaylight/adsal/northbound/bundlescanner/implementation/src/test/java/bundle_base/NonRelevantAnnotation.java
deleted file mode 100644 (file)
index 4a04a3b..0000000
+++ /dev/null
@@ -1,13 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package bundle_base;
-
-@Deprecated
-public class NonRelevantAnnotation {
-
-}
diff --git a/opendaylight/adsal/northbound/bundlescanner/implementation/src/test/java/bundle_base/Person.java b/opendaylight/adsal/northbound/bundlescanner/implementation/src/test/java/bundle_base/Person.java
deleted file mode 100644 (file)
index edd3782..0000000
+++ /dev/null
@@ -1,34 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package bundle_base;
-
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-import javax.xml.bind.annotation.XmlTransient;
-
-@XmlTransient
-@Deprecated
-public class Person extends BasePerson {
-
-    @XmlElement
-    protected String name;
-
-    public String getName() {
-        return name;
-    }
-
-    public void setName(String name) {
-        this.name = name;
-    }
-
-    @XmlRootElement
-    public static class Info { }
-
-    @XmlRootElement
-    private static class PrivateInfo { }
-}
diff --git a/opendaylight/adsal/northbound/bundlescanner/implementation/src/test/java/bundle_misc/Misc.java b/opendaylight/adsal/northbound/bundlescanner/implementation/src/test/java/bundle_misc/Misc.java
deleted file mode 100644 (file)
index eb49eb0..0000000
+++ /dev/null
@@ -1,14 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package bundle_misc;
-import javax.xml.bind.annotation.XmlRootElement;
-
-@XmlRootElement
-public class Misc {
-
-}
diff --git a/opendaylight/adsal/northbound/bundlescanner/implementation/src/test/java/bundle_sub1/NoAnnotation.java b/opendaylight/adsal/northbound/bundlescanner/implementation/src/test/java/bundle_sub1/NoAnnotation.java
deleted file mode 100644 (file)
index 19f2b0d..0000000
+++ /dev/null
@@ -1,12 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package bundle_sub1;
-
-public class NoAnnotation {
-
-}
diff --git a/opendaylight/adsal/northbound/bundlescanner/implementation/src/test/java/bundle_sub1/Zoo.java b/opendaylight/adsal/northbound/bundlescanner/implementation/src/test/java/bundle_sub1/Zoo.java
deleted file mode 100644 (file)
index c44e48e..0000000
+++ /dev/null
@@ -1,33 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package bundle_sub1;
-
-import javax.xml.bind.annotation.XmlElementRef;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import bundle_base.Animal;
-import bundle_base.Mammal;
-
-
-@XmlRootElement
-public class Zoo {
-    private Animal creature;
-
-    @XmlElementRef
-    public Animal getCreature() {
-        return creature;
-    }
-
-    public void setCreature(Animal creature) {
-        this.creature = creature;
-    }
-
-    public Zoo() {
-        creature = new Mammal();
-    }
-}
diff --git a/opendaylight/adsal/northbound/bundlescanner/implementation/src/test/java/bundle_sub2/Agent.java b/opendaylight/adsal/northbound/bundlescanner/implementation/src/test/java/bundle_sub2/Agent.java
deleted file mode 100644 (file)
index 025f35a..0000000
+++ /dev/null
@@ -1,18 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package bundle_sub2;
-
-import javax.xml.bind.annotation.XmlRootElement;
-
-import bundle_base.Person;
-
-
-@XmlRootElement
-public class Agent extends Person {
-
-}
diff --git a/opendaylight/adsal/northbound/bundlescanner/implementation/src/test/java/bundle_sub2/Customer.java b/opendaylight/adsal/northbound/bundlescanner/implementation/src/test/java/bundle_sub2/Customer.java
deleted file mode 100644 (file)
index d822ce7..0000000
+++ /dev/null
@@ -1,63 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package bundle_sub2;
-
-import java.util.ArrayList;
-import java.util.List;
-
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlElementRef;
-import javax.xml.bind.annotation.XmlElementWrapper;
-import javax.xml.bind.annotation.XmlRootElement;
-import javax.xml.bind.annotation.XmlTransient;
-
-import bundle_base.BasePerson;
-import bundle_base.Person;
-
-
-@XmlRootElement
-public class Customer extends Person {
-
-    private String password;
-    private List<String> phoneNumbers;
-    @XmlElementRef
-    @XmlElementWrapper
-    private final List<BasePerson> agents = new ArrayList<BasePerson>();
-
-    @XmlTransient
-    public String getPassword() {
-        return password;
-    }
-
-    public void setPassword(String password) {
-        this.password = password;
-    }
-
-    @XmlElement(name = "phone-number")
-    public List<String> getPhoneNumbers() {
-        return phoneNumbers;
-    }
-
-    public void setPhoneNumbers(List<String> phoneNumbers) {
-        this.phoneNumbers = phoneNumbers;
-    }
-
-    public void addAgent(Person mgr) {
-        this.agents.add(mgr);
-    }
-
-    @Override
-    public String toString() {
-        StringBuilder sb = new StringBuilder(super.toString());
-        sb.append(" password:").append(password);
-        sb.append(" phoneNumbers:").append(phoneNumbers);
-        sb.append(" agents:").append(agents);
-        return sb.toString();
-    }
-}
-
diff --git a/opendaylight/adsal/northbound/bundlescanner/implementation/src/test/java/bundle_sub2/NoAnnotation.java b/opendaylight/adsal/northbound/bundlescanner/implementation/src/test/java/bundle_sub2/NoAnnotation.java
deleted file mode 100644 (file)
index e477e61..0000000
+++ /dev/null
@@ -1,12 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package bundle_sub2;
-
-public class NoAnnotation {
-
-}
diff --git a/opendaylight/adsal/northbound/bundlescanner/implementation/src/test/java/org/opendaylight/controller/northbound/bundlescanner/internal/BundleScannerTest.java b/opendaylight/adsal/northbound/bundlescanner/implementation/src/test/java/org/opendaylight/controller/northbound/bundlescanner/internal/BundleScannerTest.java
deleted file mode 100644 (file)
index c2efbe6..0000000
+++ /dev/null
@@ -1,228 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.northbound.bundlescanner.internal;
-
-import java.io.File;
-import java.io.FileFilter;
-import java.net.MalformedURLException;
-import java.net.URISyntaxException;
-import java.net.URL;
-import java.util.ArrayList;
-import java.util.Collections;
-import java.util.Dictionary;
-import java.util.Enumeration;
-import java.util.HashSet;
-import java.util.Hashtable;
-import java.util.List;
-import java.util.Set;
-import java.util.regex.Pattern;
-
-import org.junit.AfterClass;
-import org.junit.Before;
-import org.junit.BeforeClass;
-import org.junit.Rule;
-import org.junit.Test;
-import org.junit.rules.TestName;
-import org.osgi.framework.Bundle;
-import org.osgi.framework.BundleContext;
-import org.osgi.framework.BundleEvent;
-import org.osgi.framework.Constants;
-import org.springframework.osgi.mock.MockBundle;
-import org.springframework.osgi.mock.MockBundleContext;
-
-import static org.junit.Assert.assertFalse;
-import static org.junit.Assert.assertNotNull;
-import static org.junit.Assert.assertTrue;
-
-public class BundleScannerTest {
-
-    private static BundleScanner bundleScanner;
-    private static List<Bundle> bundles;
-    @Rule
-    public final TestName testName = new TestName();
-
-    @BeforeClass
-    public static void init() throws Exception {
-        bundles = makeMockBundles();
-        bundleScanner = new BundleScanner(bundles.toArray(new Bundle[bundles.size()]));
-    }
-
-    @AfterClass
-    public static void destroy() throws Exception {
-    }
-
-    @Before
-    public void setup() {
-        System.out.println("==== " + testName.getMethodName());
-    }
-
-    @Test
-    public void testValidateBundles() {
-        assertNotNull(bundleScanner);
-        BundleContext context = bundles.get(0).getBundleContext();
-        assertNotNull(context.getBundle());
-        assertNotNull(context.getBundles());
-        assertNotNull(context.getBundles().length >= 4);
-    }
-
-    @Test
-    public void testBundleEvents() throws Exception {
-        MockBundle newBundle = new TestMockBundle("misc", "", "bundle_misc");
-        assertTrue(bundleScanner.getAnnotatedClasses(
-                newBundle.getBundleContext(), null, null, false).size() == 0);
-        BundleEvent event = new BundleEvent(BundleEvent.RESOLVED, newBundle);
-        bundleScanner.bundleChanged(event);
-        assertTrue(bundleScanner.getAnnotatedClasses(
-                newBundle.getBundleContext(), null, null, false).size() == 1);
-    }
-
-    @Test
-    public void testAnnotatedClassesWithDependencies() throws Exception {
-        for (Bundle bundle : bundles) {
-            List<Class<?>> classes = bundleScanner.getAnnotatedClasses(
-                    bundle.getBundleContext(), null, null, true);
-            String name = bundle.getSymbolicName();
-            System.out.println("name:" + name + " classes:" + classes.size());
-            if ("misc".equals(name)) {
-                assertTrue(classes.size() == 1);
-            } else if ("base".equals(name)) {
-                assertTrue(classes.size() == 5);
-            } else if ("sub1".equals(name)) {
-                assertTrue(classes.size() == 6);
-            } else if ("sub2".equals(name)) {
-                assertTrue(classes.size() == 7);
-            }
-        }
-    }
-
-    @Test
-    public void testExactFiltering() {
-        Bundle bundle = findBundle("sub1");
-        String[] annos = { "javax.xml.bind.annotation.XmlTransient" };
-        List<Class<?>> classes = bundleScanner.getAnnotatedClasses(
-                bundle.getBundleContext(), annos, null, true);
-        assertTrue(classes.size() == 1);
-    }
-
-    @Test
-    public void testNonExactFiltering() {
-        Bundle bundle = findBundle("sub1");
-        String[] annos = { "javax.xml.bind.annotation.*" };
-        List<Class<?>> classes = bundleScanner.getAnnotatedClasses(
-                bundle.getBundleContext(), annos, null, true);
-        assertTrue(classes.size() == 6);
-    }
-
-    @Test
-    public void testFilteringUnmatched() {
-        Bundle bundle = findBundle("sub1");
-        String[] annos = { "non.existent.pkg" };
-        List<Class<?>> classes = bundleScanner.getAnnotatedClasses(
-                bundle.getBundleContext(), annos, null, true);
-        assertTrue(classes.size() == 0);
-    }
-
-    @Test
-    public void testRegexMerge() {
-        Pattern pattern = BundleScanner.mergePatterns(
-                new String[] {
-                        "javax.xml.bind.annotation.*",
-                        "javax.ws.rs.Path"
-                    },
-                true
-            );
-        assertTrue(pattern.matcher("Ljavax/xml/bind/annotation/FOO;").find());
-        assertFalse(pattern.matcher("Ljavax/servlet/FOO;").find());
-    }
-
-    @Test
-    public void testExclude() {
-        Set<String> excludes = new HashSet<String>();
-        excludes.add("bundle_base.Animal");
-        Bundle bundle = findBundle("sub1");
-        String[] annos = { "javax.xml.bind.annotation.*" };
-        List<Class<?>> classes = bundleScanner.getAnnotatedClasses(
-                bundle.getBundleContext(), annos, excludes, true);
-        assertTrue(classes.size() == 5);
-    }
-
-    private static Bundle findBundle(String symName) {
-        for (Bundle bundle : bundles) {
-            if (bundle.getSymbolicName().equals(symName)) return bundle;
-        }
-        return null;
-    }
-
-    private static List<Bundle> makeMockBundles() throws Exception {
-        List<Bundle> result = new ArrayList<Bundle>();
-        result.add(new MockBundle());
-        result.add(new TestMockBundle("base", "", "bundle_base"));
-        result.add(new TestMockBundle("sub1", "bundle_base", "bundle_sub1"));
-        result.add(new TestMockBundle("sub2", "bundle_base", "bundle_sub2"));
-        return result;
-    }
-
-    private static List<URL> findClasses(String pkg) throws URISyntaxException {
-        if (pkg == null) return Collections.EMPTY_LIST;
-        String npkg = pkg.replaceAll("\\.", "/");
-        URL dirUrl = BundleScannerTest.class.getClassLoader().getResource(npkg);
-        final List<URL> result = new ArrayList<URL>();
-        File dir = new File(dirUrl.toURI());
-        dir.listFiles(new FileFilter() {
-
-            @Override
-            public boolean accept(File file) {
-                if (file.isFile() && file.getName().endsWith(".class")) {
-                    try {
-                        result.add(file.toURI().toURL());
-                    } catch (MalformedURLException e) {
-                        throw new IllegalStateException(e);
-                    }
-                }
-                return false;
-            }
-
-        });
-        return result;
-    }
-
-    public static class TestMockBundle extends MockBundle {
-        List<URL> classes;
-        public TestMockBundle(String name, String imports, String exports) throws Exception {
-            super(name, makeHeaders(name, imports, exports), new MockBundleContext() {
-                @Override
-                public Bundle[] getBundles() {
-                    return bundles.toArray(new Bundle[bundles.size()]);
-                }
-            });
-            MockBundleContext ctx = (MockBundleContext) this.getBundleContext();
-            ctx.setBundle(this);
-            this.classes = findClasses(exports);
-        }
-
-        private static Dictionary<String,String> makeHeaders(
-                String name, String imports, String exports)
-        {
-            Dictionary<String,String> headers = new Hashtable<String,String>();
-            headers.put(Constants.IMPORT_PACKAGE, imports);
-            headers.put(Constants.EXPORT_PACKAGE, exports);
-            headers.put(Constants.BUNDLE_SYMBOLICNAME, name);
-            return headers;
-        }
-
-        @Override
-        public Enumeration<URL> findEntries(String path, String filePattern, boolean recurse) {
-            return Collections.enumeration(classes);
-        }
-
-        @Override
-        public long getBundleId() {
-            return hashCode();
-        }
-    }
-}
diff --git a/opendaylight/adsal/northbound/commons/pom.xml b/opendaylight/adsal/northbound/commons/pom.xml
deleted file mode 100644 (file)
index 6dfcff2..0000000
+++ /dev/null
@@ -1,156 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>commons.northbound</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>com.fasterxml.jackson.core</groupId>
-      <artifactId>jackson-databind</artifactId>
-    </dependency>
-
-    <dependency>
-      <groupId>com.fasterxml.jackson.jaxrs</groupId>
-      <artifactId>jackson-jaxrs-base</artifactId>
-    </dependency>
-
-    <dependency>
-      <groupId>com.fasterxml.jackson.jaxrs</groupId>
-      <artifactId>jackson-jaxrs-json-provider</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>com.sun.jersey</groupId>
-      <artifactId>jersey-client</artifactId>
-    </dependency>
-    <!-- Jersey for JAXRS -->
-    <dependency>
-      <groupId>com.sun.jersey</groupId>
-      <artifactId>jersey-core</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>com.sun.jersey</groupId>
-      <artifactId>jersey-server</artifactId>
-    </dependency>
-
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>bundlescanner</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>containermanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>switchmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>usermanager</artifactId>
-    </dependency>
-
-    <dependency>
-      <groupId>ch.qos.logback</groupId>
-      <artifactId>logback-classic</artifactId>
-      <scope>test</scope>
-    </dependency>
-
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Export-Package>org.opendaylight.controller.northbound.commons.exception,
-              org.opendaylight.controller.northbound.commons.types,
-              org.opendaylight.controller.northbound.commons.utils,
-              org.opendaylight.controller.northbound.commons.query,
-              org.opendaylight.controller.northbound.commons</Export-Package>
-            <Import-Package>javax.ws.rs,
-              javax.ws.rs.ext,
-              javax.ws.rs.core,
-              javax.xml.bind,
-              javax.xml.bind.annotation,
-              org.opendaylight.controller.sal.utils,
-              org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.sal.authorization,
-              org.opendaylight.controller.containermanager,
-              org.opendaylight.controller.usermanager,
-              org.opendaylight.controller.switchmanager,
-              org.opendaylight.controller.northbound.bundlescanner,
-              org.osgi.framework,
-              org.osgi.service.packageadmin,
-              org.osgi.util.tracker,
-              javax.servlet.http,
-              com.fasterxml.jackson.core,
-              com.fasterxml.jackson.databind,
-              com.fasterxml.jackson.jaxrs.base,
-              com.fasterxml.jackson.jaxrs.json,
-              org.slf4j</Import-Package>
-          </instructions>
-          <manifestLocation>${project.basedir}/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-
-      <plugin>
-        <groupId>org.codehaus.mojo</groupId>
-        <artifactId>build-helper-maven-plugin</artifactId>
-        <executions>
-          <execution>
-            <id>add-source</id>
-            <goals>
-              <goal>add-source</goal>
-            </goals>
-            <phase>generate-sources</phase>
-            <configuration>
-              <sources>
-                <source>${project.build.directory}/generated-sources/javacc</source>
-              </sources>
-            </configuration>
-          </execution>
-        </executions>
-      </plugin>
-
-      <plugin>
-        <groupId>org.codehaus.mojo</groupId>
-        <artifactId>javacc-maven-plugin</artifactId>
-        <version>2.6</version>
-        <executions>
-          <execution>
-            <id>javacc</id>
-            <goals>
-              <goal>javacc</goal>
-            </goals>
-          </execution>
-        </executions>
-      </plugin>
-
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/JacksonJsonProcessingExceptionMapper.java b/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/JacksonJsonProcessingExceptionMapper.java
deleted file mode 100644 (file)
index eb43920..0000000
+++ /dev/null
@@ -1,37 +0,0 @@
-/**
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.northbound.commons;
-
-import javax.ws.rs.Consumes;
-import javax.ws.rs.core.GenericEntity;
-import javax.ws.rs.core.MediaType;
-import javax.ws.rs.core.Response;
-import javax.ws.rs.ext.ExceptionMapper;
-import javax.ws.rs.ext.Provider;
-
-import com.fasterxml.jackson.core.JsonProcessingException;
-
-
-/**
- * A custom exception mapper for handling Jackson JsonProcessingException types
- */
-@Provider
-@Consumes({MediaType.APPLICATION_JSON})
-public class JacksonJsonProcessingExceptionMapper
-    implements ExceptionMapper<JsonProcessingException>
-{
-
-    @Override
-    public Response toResponse(JsonProcessingException exception) {
-        GenericEntity<String> entity =
-                new GenericEntity<String>(exception.getMessage()) {};
-        return Response.status(Response.Status.BAD_REQUEST).entity(entity).build();
-    }
-}
-
diff --git a/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/NorthboundApplication.java b/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/NorthboundApplication.java
deleted file mode 100644 (file)
index cf48729..0000000
+++ /dev/null
@@ -1,179 +0,0 @@
-/**
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.northbound.commons;
-
-import java.util.Dictionary;
-import java.util.HashSet;
-import java.util.List;
-import java.util.Set;
-
-import javax.ws.rs.core.Application;
-import javax.ws.rs.ext.ContextResolver;
-import javax.xml.bind.JAXBContext;
-import javax.xml.bind.JAXBException;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.northbound.bundlescanner.IBundleScanService;
-import org.opendaylight.controller.northbound.commons.exception.GenericExceptionMapper;
-import org.opendaylight.controller.northbound.commons.query.QueryContextProvider;
-import org.osgi.framework.Bundle;
-import org.osgi.framework.BundleContext;
-import org.osgi.framework.BundleReference;
-import org.osgi.framework.FrameworkUtil;
-import org.osgi.framework.ServiceException;
-import org.osgi.framework.ServiceReference;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import com.fasterxml.jackson.databind.DeserializationFeature;
-import com.fasterxml.jackson.jaxrs.json.JacksonJaxbJsonProvider;
-
-/**
- * Instance of javax.ws.rs.core.Application used to return the classes
- * that will be instantiated for JAXRS processing. This hooks onto the
- * bundle scanner service to provide JAXB classes to JAX-RS for prorcessing.
- */
-public class NorthboundApplication extends Application {
-    public static final String JAXRS_RESOURCES_MANIFEST_NAME = "Jaxrs-Resources";
-    public static final String JAXRS_EXCLUDES_MANIFEST_NAME = "Jaxrs-Exclude-Types";
-    private static final Logger LOGGER = LoggerFactory.getLogger(NorthboundApplication.class);
-    private final Set<Object> _singletons;
-
-    public NorthboundApplication() {
-        _singletons = new HashSet<Object>();
-        _singletons.add(new ContextResolver<JAXBContext>() {
-            JAXBContext jaxbContext;
-            @Override
-            public synchronized JAXBContext getContext(Class<?> type) {
-                if (jaxbContext == null) {
-                    jaxbContext = newJAXBContext();
-                }
-                return jaxbContext;
-            }
-
-        } );
-        _singletons.add(getJsonProvider());
-        _singletons.add(new JacksonJsonProcessingExceptionMapper());
-        _singletons.add(new QueryContextProvider());
-        _singletons.add(new GenericExceptionMapper());
-    }
-
-    ////////////////////////////////////////////////////////////////
-    //  Application overrides
-    ////////////////////////////////////////////////////////////////
-
-    @Override
-    public Set<Object> getSingletons() {
-        return _singletons;
-    }
-
-    @Override
-    public Set<Class<?>> getClasses() {
-        Set<Class<?>> result = new HashSet<Class<?>>();
-        result.addAll(findJAXRSResourceClasses());
-        return result;
-    }
-
-    private static final JacksonJaxbJsonProvider getJsonProvider() {
-        JacksonJaxbJsonProvider jsonProvider = new JacksonJaxbJsonProvider();
-        jsonProvider.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES,
-                false);
-        return jsonProvider;
-    }
-
-    private BundleContext getBundleContext() {
-        ClassLoader tlcl = Thread.currentThread().getContextClassLoader();
-        Bundle bundle = null;
-
-        if (tlcl instanceof BundleReference) {
-            bundle = ((BundleReference) tlcl).getBundle();
-        } else {
-            LOGGER.warn("Unable to determine the bundle context based on " +
-                        "thread context classloader.");
-            bundle = FrameworkUtil.getBundle(this.getClass());
-        }
-        return (bundle == null ? null : bundle.getBundleContext());
-    }
-
-    private static final IBundleScanService lookupBundleScanner(BundleContext ctx) {
-        ServiceReference<?> svcRef = ctx.getServiceReference(IBundleScanService.class);
-        if (svcRef == null) {
-            throw new ServiceException("Unable to lookup IBundleScanService");
-        }
-        return IBundleScanService.class.cast(ctx.getService(svcRef));
-    }
-
-    private final JAXBContext newJAXBContext() {
-        BundleContext ctx = getBundleContext();
-        IBundleScanService svc = lookupBundleScanner(ctx);
-        try {
-            List<Class<?>> cls = svc.getAnnotatedClasses(ctx,
-                    new String[] { XmlRootElement.class.getPackage().getName() },
-                    parseManifestEntry(ctx, JAXRS_EXCLUDES_MANIFEST_NAME),
-                    true);
-            return JAXBContext.newInstance(cls.toArray(new Class[cls.size()]));
-        } catch (JAXBException je) {
-            LOGGER.error("Error creating JAXBContext", je);
-            return null;
-        }
-    }
-
-    private final Set<Class<?>> findJAXRSResourceClasses() {
-        BundleContext ctx = getBundleContext();
-        String bundleName = ctx.getBundle().getSymbolicName();
-        Set<Class<?>> result = new HashSet<Class<?>>();
-        ServiceException recordException = null;
-        try {
-            IBundleScanService svc = lookupBundleScanner(ctx);
-            result.addAll(svc.getAnnotatedClasses(ctx,
-                    new String[] { javax.ws.rs.Path.class.getName() },
-                    null, false));
-        } catch (ServiceException se) {
-            recordException = se;
-            LOGGER.debug("Error finding JAXRS resource annotated classes in " +
-                    "bundle: {} error: {}.", bundleName, se.getMessage());
-            // the bundle scan service cannot be lookedup. Lets attempt to
-            // lookup the resources from the bundle manifest header
-            for (String c : parseManifestEntry(ctx, JAXRS_RESOURCES_MANIFEST_NAME)) {
-                try {
-                    result.add(ctx.getBundle().loadClass(c));
-                } catch (ClassNotFoundException cnfe) {
-                    LOGGER.error("Cannot load class: {} in bundle: {} " +
-                            "defined as MANIFEST JAX-RS resource", c, bundleName, cnfe);
-                }
-            }
-        }
-
-        if (result.size() == 0) {
-            if (recordException != null) {
-                throw recordException;
-            } else {
-                throw new ServiceException("No resource classes found in bundle:" +
-                        ctx.getBundle().getSymbolicName());
-            }
-        }
-        return result;
-    }
-
-    private final Set<String> parseManifestEntry(BundleContext ctx, String name) {
-        Set<String> result = new HashSet<String>();
-        Dictionary<String,String> headers = ctx.getBundle().getHeaders();
-        String header = headers.get(name);
-        if (header != null) {
-            for (String s : header.split(",")) {
-                s = s.trim();
-                if (s.length() > 0) {
-                    result.add(s);
-                }
-            }
-        }
-        return result;
-    }
-
-}
diff --git a/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/RestMessages.java b/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/RestMessages.java
deleted file mode 100644 (file)
index ba2476a..0000000
+++ /dev/null
@@ -1,33 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.northbound.commons;
-
-public enum RestMessages {
-    SUCCESS("Success"), NOCONTAINER("Container does not exist"), NOSUBNET("Subnet does not exist"), NOSTATICROUTE(
-            "Static Route does not exist"), NOHOST("Host does not exist"), NOFLOW("Flow does not exist"), NONODE(
-            "Node does not exist"), NOPOLICY("Policy does not exist"), NORESOURCE("Resource does not exist"), RESOURCECONFLICT(
-            "Operation failed due to Resource Conflict"), NODEFAULT("Container default is not a custom container"), DEFAULTDISABLED(
-            "Container(s) are configured. Container default is not operational"), NOTALLOWEDONDEFAULT(
-            "Container default is a static resource, no modification allowed on it"), UNKNOWNACTION("Unknown action"), INVALIDJSON(
-            "JSON message is invalid"), INVALIDADDRESS("Invalid InetAddress"), AVAILABLESOON(
-            "Resource is not implemented yet"), INTERNALERROR("Internal Error"), SERVICEUNAVAILABLE(
-            "Service is not available. Could be down for maintanence"), INVALIDDATA(
-            "Data is invalid or conflicts with URI");
-
-    private String message;
-
-    private RestMessages(String msg) {
-        message = msg;
-    }
-
-    @Override
-    public String toString() {
-        return message;
-    }
-}
diff --git a/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/BadRequestException.java b/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/BadRequestException.java
deleted file mode 100644 (file)
index c1b832d..0000000
+++ /dev/null
@@ -1,27 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.northbound.commons.exception;
-
-import javax.ws.rs.WebApplicationException;
-import javax.ws.rs.core.MediaType;
-import javax.ws.rs.core.Response;
-
-/**
- * Status Code 400 (Bad Request)
- *
- * The request could not be understood by the server due to malformed syntax.
- * The client SHOULD NOT repeat the request without modifications.
- */
-public class BadRequestException extends WebApplicationException {
-    private static final long serialVersionUID = 1L;
-
-    public BadRequestException(String string) {
-        super(Response.status(Response.Status.BAD_REQUEST).entity(string).type(MediaType.TEXT_PLAIN).build());
-    }
-}
diff --git a/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/GenericExceptionMapper.java b/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/GenericExceptionMapper.java
deleted file mode 100644 (file)
index d2bbfea..0000000
+++ /dev/null
@@ -1,24 +0,0 @@
-package org.opendaylight.controller.northbound.commons.exception;
-
-import javax.ws.rs.WebApplicationException;
-import javax.ws.rs.core.Response;
-import javax.ws.rs.ext.ExceptionMapper;
-import javax.ws.rs.ext.Provider;
-
-@Provider
-public class GenericExceptionMapper implements ExceptionMapper<Exception> {
-
-    @Override
-    public Response toResponse(Exception exception) {
-        //check if WebApplicationException and reuse status code
-        if (exception instanceof WebApplicationException) {
-            WebApplicationException ex = (WebApplicationException) exception;
-            return Response.status(ex.getResponse().getStatus()).
-                    entity(ex.getResponse().getEntity()).build();
-        }
-        // throw 500 for all other errors
-        return Response.status(Response.Status.INTERNAL_SERVER_ERROR).
-                entity(exception.getMessage()).build();
-    }
-
-}
diff --git a/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/InternalServerErrorException.java b/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/InternalServerErrorException.java
deleted file mode 100644 (file)
index aa47a33..0000000
+++ /dev/null
@@ -1,38 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.northbound.commons.exception;
-
-import javax.ws.rs.WebApplicationException;
-import javax.ws.rs.core.Response;
-import javax.ws.rs.core.MediaType;
-
-/**
- * Status Code 500 (Internal Server Error)
- *
- * The server encountered an unexpected condition which prevented
- * it from fulfilling the request.
- *
- *
- *
- */
-public class InternalServerErrorException extends WebApplicationException {
-    private static final long serialVersionUID = 1L;
-
-    /**
-     * Constructor for the INTERNAL_SERVER_ERROR custom handler
-     *
-     * @param string Error message to specify further the
-     * INTERNAL_SERVER_ERROR response
-     *
-     */
-    public InternalServerErrorException(String string) {
-        super(Response.status(Response.Status.INTERNAL_SERVER_ERROR).entity(
-                string).type(MediaType.TEXT_PLAIN).build());
-    }
-}
diff --git a/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/MethodNotAllowed.java b/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/MethodNotAllowed.java
deleted file mode 100644 (file)
index 2495bdc..0000000
+++ /dev/null
@@ -1,34 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.northbound.commons.exception;
-
-import javax.ws.rs.core.Response;
-
-/**
- * Implementation of StatusType for error 405 as in:
- * http://www.w3.org/Protocols/rfc2616/rfc2616-sec10.html#sec10.4.6
- *
- *
- */
-public class MethodNotAllowed implements Response.StatusType {
-    @Override
-    public int getStatusCode() {
-        return 405;
-    }
-
-    @Override
-    public String getReasonPhrase() {
-        return "Method Not Allowed";
-    }
-
-    @Override
-    public Response.Status.Family getFamily() {
-        return Response.Status.Family.CLIENT_ERROR;
-    }
-}
diff --git a/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/MethodNotAllowedException.java b/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/MethodNotAllowedException.java
deleted file mode 100644 (file)
index 8a7de2c..0000000
+++ /dev/null
@@ -1,33 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.northbound.commons.exception;
-
-import javax.ws.rs.WebApplicationException;
-import javax.ws.rs.core.Response;
-import javax.ws.rs.core.MediaType;
-
-/**
- * Status Code 405 (Method Not Allowed)
- *
- * The method specified in the Request-Line is not allowed for the
- * resource identified by the Request-URI. The response MUST include
- * an Allow header containing a list of valid methods for the
- * requested resource.
- *
- *
- *
- */
-public class MethodNotAllowedException extends WebApplicationException {
-    private static final long serialVersionUID = 1L;
-
-    public MethodNotAllowedException(String string) {
-        super(Response.status(new MethodNotAllowed()).entity(string).type(
-                MediaType.TEXT_PLAIN).build());
-    }
-}
diff --git a/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/NotAcceptableException.java b/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/NotAcceptableException.java
deleted file mode 100644 (file)
index 3b926d6..0000000
+++ /dev/null
@@ -1,32 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.northbound.commons.exception;
-
-import javax.ws.rs.WebApplicationException;
-import javax.ws.rs.core.Response;
-import javax.ws.rs.core.MediaType;
-
-/**
- * Status Code 406 (Not Acceptable)
- *
- * The resource identified by the request is only capable of
- * generating response entities which have content characteristics not
- * acceptable according to the accept headers sent in the request.
- *
- *
- *
- */
-public class NotAcceptableException extends WebApplicationException {
-    private static final long serialVersionUID = 1L;
-
-    public NotAcceptableException(String string) {
-        super(Response.status(Response.Status.NOT_ACCEPTABLE).entity(string)
-                .type(MediaType.TEXT_PLAIN).build());
-    }
-}
diff --git a/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/NotImplemented.java b/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/NotImplemented.java
deleted file mode 100644 (file)
index 16d0cd6..0000000
+++ /dev/null
@@ -1,32 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.northbound.commons.exception;
-
-import javax.ws.rs.core.Response;
-
-/**
- * Implementation of StatusType for error 501 as in:
- * http://www.w3.org/Protocols/rfc2616/rfc2616-sec10.html#sec10.4.6
- */
-public class NotImplemented implements Response.StatusType {
-    @Override
-    public int getStatusCode() {
-        return 501;
-    }
-
-    @Override
-    public String getReasonPhrase() {
-        return "Not Implemented";
-    }
-
-    @Override
-    public Response.Status.Family getFamily() {
-        return Response.Status.Family.SERVER_ERROR;
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/NotImplementedException.java b/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/NotImplementedException.java
deleted file mode 100644 (file)
index 5c931d2..0000000
+++ /dev/null
@@ -1,28 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.northbound.commons.exception;
-
-import javax.ws.rs.WebApplicationException;
-import javax.ws.rs.core.MediaType;
-import javax.ws.rs.core.Response;
-
-/**
- * Status Code 501 (Not Implemented)
- *
- * The server does not support the functionality required to fulfill the
- * request. This is the appropriate response when the server does not recognize
- * the request method and is not capable of supporting it for any resource.
- */
-public class NotImplementedException extends WebApplicationException {
-    private static final long serialVersionUID = 1L;
-
-    public NotImplementedException(String string) {
-        super(Response.status(new NotImplemented()).entity(string).type(MediaType.TEXT_PLAIN).build());
-    }
-}
diff --git a/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/ResourceConflictException.java b/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/ResourceConflictException.java
deleted file mode 100644 (file)
index 2f1754b..0000000
+++ /dev/null
@@ -1,37 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.northbound.commons.exception;
-
-import javax.ws.rs.WebApplicationException;
-import javax.ws.rs.core.Response;
-import javax.ws.rs.core.MediaType;
-
-/**
- * Status Code 409 (Conflict)
- *
- * The request could not be completed due to a conflict with the
- * current state of the resource. This code is only allowed in
- * situations where it is expected that the user might be able to
- * resolve the conflict and resubmit the request. The response body
- * SHOULD include enough information for the user to recognize the
- * source of the conflict. Ideally, the response entity would include
- * enough information for the user or user agent to fix the problem;
- * however, that might not be possible and is not required.
- *
- *
- *
- */
-public class ResourceConflictException extends WebApplicationException {
-    private static final long serialVersionUID = 1L;
-
-    public ResourceConflictException(String string) {
-        super(Response.status(Response.Status.CONFLICT).entity(string).type(
-                MediaType.TEXT_PLAIN).build());
-    }
-}
diff --git a/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/ResourceForbiddenException.java b/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/ResourceForbiddenException.java
deleted file mode 100644 (file)
index 5997935..0000000
+++ /dev/null
@@ -1,36 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.northbound.commons.exception;
-
-import javax.ws.rs.WebApplicationException;
-import javax.ws.rs.core.Response;
-import javax.ws.rs.core.MediaType;
-
-/**
- * Status Code 403 (Forbidden)
- *
- * The server understood the request, but is refusing to fulfill it.
- * Authorization will not help and the request SHOULD NOT be repeated.
- * If the request method was not HEAD and the server wishes to make public
- * why the request has not been fulfilled, it SHOULD describe the reason
- * for the refusal in the entity.
- * If the server does not wish to make this information available to
- * the client, the status code 404 (Not Found) can be used instead.
- *
- *
- *
- */
-public class ResourceForbiddenException extends WebApplicationException {
-    private static final long serialVersionUID = 1L;
-
-    public ResourceForbiddenException(String string) {
-        super(Response.status(Response.Status.FORBIDDEN).entity(string).type(
-                MediaType.TEXT_PLAIN).build());
-    }
-}
diff --git a/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/ResourceGoneException.java b/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/ResourceGoneException.java
deleted file mode 100644 (file)
index f38e8b3..0000000
+++ /dev/null
@@ -1,37 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.northbound.commons.exception;
-
-import javax.ws.rs.WebApplicationException;
-import javax.ws.rs.core.Response;
-import javax.ws.rs.core.MediaType;
-
-/**
- * Status Code 410 (Gone)
- *
- * The requested resource is no longer available at the server and no
- * forwarding address is known. This condition is expected to be
- * considered permanent. Clients with link editing capabilities SHOULD
- * delete references to the Request-URI after user approval. If the
- * server does not know, or has no facility to determine, whether or
- * not the condition is permanent, the status code 404 (Not Found)
- * SHOULD be used instead. This response is cacheable unless indicated
- * otherwise.
- *
- *
- *
- */
-public class ResourceGoneException extends WebApplicationException {
-    private static final long serialVersionUID = 1L;
-
-    public ResourceGoneException(String string) {
-        super(Response.status(Response.Status.GONE).entity(string).type(
-                MediaType.TEXT_PLAIN).build());
-    }
-}
diff --git a/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/ResourceNotFoundException.java b/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/ResourceNotFoundException.java
deleted file mode 100644 (file)
index 7bd09b7..0000000
+++ /dev/null
@@ -1,37 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.northbound.commons.exception;
-
-import javax.ws.rs.WebApplicationException;
-import javax.ws.rs.core.Response;
-import javax.ws.rs.core.MediaType;
-
-/**
- * Status Code 404 (Not Found)
- *
- * The server has not found anything matching the Request-URI.
- * No indication is given of whether the condition is temporary or permanent.
- * The 410 (Gone) status code SHOULD be used if the server knows,
- * through some internally configurable mechanism, that an old resource
- * is permanently unavailable and has no forwarding address.
- * This status code is commonly used when the server does not wish to
- * reveal exactly why the request has been refused, or when no other
- * response is applicable.
- *
- *
- *
- */
-public class ResourceNotFoundException extends WebApplicationException {
-    private static final long serialVersionUID = 1L;
-
-    public ResourceNotFoundException(String string) {
-        super(Response.status(Response.Status.NOT_FOUND).entity(string).type(
-                MediaType.TEXT_PLAIN).build());
-    }
-}
diff --git a/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/ServiceUnavailableException.java b/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/ServiceUnavailableException.java
deleted file mode 100644 (file)
index 74a8a94..0000000
+++ /dev/null
@@ -1,39 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.northbound.commons.exception;
-
-import javax.ws.rs.WebApplicationException;
-import javax.ws.rs.core.Response;
-import javax.ws.rs.core.MediaType;
-
-/**
- * Status Code 503 (Service Unavailable Error)
- *
- * The server is currently unable to handle the request due to a temporary
- * overloading or maintenance of the server.
- * The implication is that this is a temporary condition which will be alleviated
- * after some delay.
- *
- *
- */
-public class ServiceUnavailableException extends WebApplicationException {
-    private static final long serialVersionUID = 1L;
-
-    /**
-     * Constructor for the SERVICE_UNAVAILABLE custom handler
-     *
-     * @param string Error message to specify further the
-     * SERVICE_UNAVAILABLE response
-     *
-     */
-    public ServiceUnavailableException(String string) {
-        super(Response.status(Response.Status.SERVICE_UNAVAILABLE).entity(
-                string).type(MediaType.TEXT_PLAIN).build());
-    }
-}
diff --git a/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/UnauthorizedException.java b/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/UnauthorizedException.java
deleted file mode 100644 (file)
index c7cb900..0000000
+++ /dev/null
@@ -1,32 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.northbound.commons.exception;
-
-import javax.ws.rs.WebApplicationException;
-import javax.ws.rs.core.Response;
-import javax.ws.rs.core.MediaType;
-
-/**
- * Status Code 401 (Unauthorized)
- *
- * The request requires user authentication. The response MUST include
- * a WWW-Authenticate header field (section 14.47) containing a
- * challenge applicable to the requested resource.
- *
- *
- *
- */
-public class UnauthorizedException extends WebApplicationException {
-    private static final long serialVersionUID = 1L;
-
-    public UnauthorizedException(String string) {
-        super(Response.status(Response.Status.UNAUTHORIZED).entity(string)
-                .type(MediaType.TEXT_PLAIN).build());
-    }
-}
diff --git a/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/UnsupportedMediaTypeException.java b/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/UnsupportedMediaTypeException.java
deleted file mode 100644 (file)
index c54d2cf..0000000
+++ /dev/null
@@ -1,32 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.northbound.commons.exception;
-
-import javax.ws.rs.WebApplicationException;
-import javax.ws.rs.core.Response;
-import javax.ws.rs.core.MediaType;
-
-/**
- * Status Code 415 (Unsupported Media Type)
- *
- * The server is refusing to service the request because the entity of
- * the request is in a format not supported by the requested resource
- * for the requested method.
- *
- *
- *
- */
-public class UnsupportedMediaTypeException extends WebApplicationException {
-    private static final long serialVersionUID = 1L;
-
-    public UnsupportedMediaTypeException(String string) {
-        super(Response.status(Response.Status.UNSUPPORTED_MEDIA_TYPE).entity(
-                string).type(MediaType.TEXT_PLAIN).build());
-    }
-}
diff --git a/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/package-info.java b/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/exception/package-info.java
deleted file mode 100644 (file)
index d1f182b..0000000
+++ /dev/null
@@ -1,14 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * Provides the necessary class that represent exception in REST
- * API.
- *
- */
-package org.opendaylight.controller.northbound.commons.exception;
diff --git a/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/query/Accessor.java b/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/query/Accessor.java
deleted file mode 100644 (file)
index 2d910ed..0000000
+++ /dev/null
@@ -1,55 +0,0 @@
-package org.opendaylight.controller.northbound.commons.query;
-
-import java.lang.annotation.Annotation;
-import java.lang.reflect.AccessibleObject;
-import java.lang.reflect.Field;
-import java.lang.reflect.Method;
-import java.lang.reflect.Type;
-
-/*package*/ class Accessor {
-    protected final AccessibleObject _accessorObj;
-
-    public Accessor(AccessibleObject accessor) {
-        _accessorObj = accessor;
-        _accessorObj.setAccessible(true);
-    }
-
-    public AccessibleObject getAccessibleObject() {
-        return _accessorObj;
-    }
-
-    public Annotation[] getAnnotations() {
-        return _accessorObj.getAnnotations();
-    }
-
-    public Object getValue(Object parent) throws QueryException {
-        try {
-            if (_accessorObj instanceof Field) {
-                return ((Field)_accessorObj).get(parent);
-            } else {
-                // assume method
-                return ((Method)_accessorObj).invoke(parent);
-            }
-        } catch (Exception e) {
-            throw new QueryException("Failure in retrieving value", e);
-        }
-    }
-    public Type getGenericType() {
-        if (_accessorObj instanceof Field) {
-            return ((Field)_accessorObj).getGenericType();
-        } else {
-            // assume method
-            return ((Method)_accessorObj).getGenericReturnType();
-        }
-    }
-    public Class<?> getType() {
-
-        if (_accessorObj instanceof Field) {
-            return ((Field)_accessorObj).getType();
-        } else {
-            // assume method
-            return ((Method)_accessorObj).getReturnType();
-        }
-    }
-
-}
diff --git a/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/query/CompareExpression.java b/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/query/CompareExpression.java
deleted file mode 100644 (file)
index 6b972e6..0000000
+++ /dev/null
@@ -1,56 +0,0 @@
-/**
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.northbound.commons.query;
-
-/*package*/ class CompareExpression implements Expression {
-
-    public static enum OP { RE, EQ, NE, GT, GE, LT, LE };
-
-    private final OP _operation;
-    private final String _selector;
-    private final String _arg;
-
-    public CompareExpression(OP op, String selector, String arg) {
-        _operation = op;
-        _selector = selector;
-        _arg = unQuote(arg);
-    }
-
-
-    public OP getOperator() {
-        return _operation;
-    }
-
-    public String getSelector() {
-        return _selector;
-    }
-
-    public String getArgument() {
-        return _arg;
-    }
-
-    @Override
-    public boolean accept(Visitor visitor) throws QueryException {
-        return visitor.visit(this);
-    }
-
-    @Override
-    public String toString() {
-        return "[" + _selector + " " + _operation + " " + _arg + "]";
-    }
-
-    private static String unQuote(String s) {
-        if (s.startsWith("\"") && s.endsWith("\"")) {
-            s = s.substring(1, s.length()-1);
-        } else if (s.startsWith("\'") && s.endsWith("\'")) {
-            s = s.substring(1, s.length()-1);
-        }
-        return s;
-    }
-
-}
diff --git a/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/query/Expression.java b/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/query/Expression.java
deleted file mode 100644 (file)
index fbc22a0..0000000
+++ /dev/null
@@ -1,12 +0,0 @@
-/**
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.northbound.commons.query;
-
-/*package*/ interface Expression {
-    boolean accept(Visitor visitor) throws QueryException;
-}
diff --git a/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/query/ExpressionBuilder.java b/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/query/ExpressionBuilder.java
deleted file mode 100644 (file)
index f1b2999..0000000
+++ /dev/null
@@ -1,41 +0,0 @@
-/**
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.northbound.commons.query;
-
-import java.util.Stack;
-
-/*package*/ class ExpressionBuilder {
-    private final Stack<Expression> _stack = new Stack<Expression>();
-    private LogicalExpression.OP _lastOp = null;
-
-    public ExpressionBuilder() {}
-
-    public ExpressionBuilder withAnd() {
-        _lastOp = LogicalExpression.OP.AND;
-        return this;
-    }
-
-    public ExpressionBuilder withOr() {
-        _lastOp = LogicalExpression.OP.OR;
-        return this;
-    }
-
-    public ExpressionBuilder withTerm(Expression exp) {
-        if (_lastOp != null) {
-            exp = new LogicalExpression(_lastOp, _stack.pop(), exp);
-            _lastOp = null;
-        }
-        _stack.push(exp);
-        return this;
-    }
-
-    public Expression build() {
-        return _stack.pop();
-    }
-
-}
diff --git a/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/query/IteratableTypeInfo.java b/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/query/IteratableTypeInfo.java
deleted file mode 100644 (file)
index d0386ed..0000000
+++ /dev/null
@@ -1,71 +0,0 @@
-package org.opendaylight.controller.northbound.commons.query;
-
-import java.lang.reflect.ParameterizedType;
-import java.lang.reflect.Type;
-import java.util.ArrayList;
-import java.util.Collection;
-import java.util.Iterator;
-import java.util.List;
-
-/**
- */
-/*package*/ class IteratableTypeInfo extends TypeInfo {
-
-    public IteratableTypeInfo(String name, Accessor accessor) {
-        super(name, accessor.getType(), accessor);
-    }
-
-    @Override
-    public Object retrieve(Object target, String[] query, int index) throws QueryException {
-        if (LOGGER.isDebugEnabled()) {
-            LOGGER.debug("retrieve collection: {}/{} type:{}", index, query.length,
-                    target.getClass());
-        }
-        explore();
-        Collection<?> c = (Collection<?>) target;
-        Iterator<?> it = c.iterator();
-        List<Object> objects = new ArrayList<Object>();
-        while (it.hasNext()) {
-            Object item = it.next();
-            for (TypeInfo child : _types.values()) {
-                Object val = child.retrieve(item, query, index);
-                if (val != null) {
-                    objects.add(val);
-                }
-            }
-        }
-        return objects;
-
-    }
-
-    @Override
-    public synchronized void explore() {
-        if (_explored) {
-            return;
-        }
-        if (LOGGER.isDebugEnabled()) {
-            LOGGER.debug("exploring iteratable type: {} gtype: {}", _class,
-                    _accessor.getGenericType());
-        }
-        Type t = _accessor.getGenericType();
-        if (t instanceof ParameterizedType) {
-            Type[] pt = ((ParameterizedType) t).getActualTypeArguments();
-            // First type is a child, ignore rest
-            if (pt.length > 0) {
-                _types.put(_name, new TypeInfo(_name, (Class)pt[0], null));
-            }
-        }
-        _explored = true;
-    }
-
-    @Override
-    public TypeInfo getCollectionChild(Class<?> childType) {
-        explore();
-        for (TypeInfo ti : _types.values()) {
-            if (ti.getType().equals(childType)) {
-                return ti;
-            }
-        }
-        return null;
-    }
-}
diff --git a/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/query/LogicalExpression.java b/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/query/LogicalExpression.java
deleted file mode 100644 (file)
index 4e99820..0000000
+++ /dev/null
@@ -1,50 +0,0 @@
-/**
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.northbound.commons.query;
-
-/*package*/ class LogicalExpression implements Expression {
-
-    public static enum OP { AND, OR }
-
-    private final OP _op;
-    private final Expression _arg1;
-    private final Expression _arg2;
-
-    public LogicalExpression(OP op, Expression first, Expression second) {
-        _op = op;
-        _arg1 = first;
-        _arg2 = second;
-    }
-
-    public OP getOperator() {
-        return _op;
-    }
-
-    public Expression getFirst() {
-        return _arg1;
-    }
-
-    public Expression getSecond() {
-        return _arg2;
-    }
-
-    @Override
-    public boolean accept(Visitor visitor) throws QueryException {
-        return visitor.visit(this);
-    }
-
-    @Override
-    public String toString() {
-        StringBuilder sb = new StringBuilder();
-        sb.append(_arg1.toString())
-        .append(_op.toString())
-        .append(_arg2.toString());
-        return sb.toString();
-    }
-
-}
diff --git a/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/query/Query.java b/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/query/Query.java
deleted file mode 100644 (file)
index 15dcaeb..0000000
+++ /dev/null
@@ -1,52 +0,0 @@
-/**
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.northbound.commons.query;
-
-import java.util.Collection;
-import java.util.List;
-
-
-/**
- * Represents a parsed query used in filtering of collections.
- */
-public interface Query<T> {
-
-    /**
-     * Find items in the given collection and return them as a new list. The
-     * original collection is not changed.
-     *
-     * @param collection to search in.
-     * @return list of items which match the query.
-     * @throws QueryException
-     */
-    public List<T> find(Collection<T> collection) throws QueryException;
-
-    /**
-     * Apply the query on the given collection. Note that this method will modify
-     * the given object by removing any items which don't match the query criteria.
-     * If the collection is 'singleton' or unmodifiable, invocation will result in
-     * an exception.
-     *
-     * @param collection
-     * @return the number matched items
-     * @throws QueryException
-     */
-    public int filter(Collection<T> collection) throws QueryException;
-
-    /**
-     * Search the given root for a child collection and them apply the query on.
-     * Note that this method will modify the given object by removing any items
-     * which don't match the query criteria.
-     *
-     * @param root - top level object to search in
-     * @param childType - the child type which represents the collection.
-     * @return the number of matched items
-     * @throws QueryException
-     */
-    public int filter(T root, Class<?> childType) throws QueryException;
-}
diff --git a/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/query/QueryContext.java b/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/query/QueryContext.java
deleted file mode 100644 (file)
index 59a78ac..0000000
+++ /dev/null
@@ -1,25 +0,0 @@
-/**
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.northbound.commons.query;
-
-/**
- * Query context
- */
-public interface QueryContext {
-
-    /**
-     * Create a Query
-     * @param queryString - query string to parse
-     * @param clazz - The class which represents the top level jaxb object
-     * @return a query object
-     * @throws QueryException if the query cannot be parsed.
-     */
-    <T> Query<T> createQuery(String queryString, Class<T> clazz)
-            throws QueryException;
-
-}
diff --git a/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/query/QueryContextImpl.java b/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/query/QueryContextImpl.java
deleted file mode 100644 (file)
index 8f83c14..0000000
+++ /dev/null
@@ -1,41 +0,0 @@
-/**
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.northbound.commons.query;
-
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/*package*/ class QueryContextImpl implements QueryContext {
-
-    private static final Logger LOGGER = LoggerFactory.getLogger(QueryContext.class);
-
-    @Override
-    public <T> Query<T> createQuery(String queryString, Class<T> type) throws QueryException {
-        if (queryString == null || queryString.trim().length() == 0) {
-            return null;
-        }
-        try {
-            if (LOGGER.isDebugEnabled()) {
-                LOGGER.debug("Processing query: {}", queryString);
-            }
-            // FiqlParser is a parser generated by javacc
-            Expression expression = FiqlParser.parse(queryString);
-            if (LOGGER.isDebugEnabled()) {
-                LOGGER.debug("Query expression: {}", expression);
-            }
-            // create Query and return;
-            return new QueryImpl<T>(type, expression);
-        } catch (Exception ex) {
-            if (LOGGER.isDebugEnabled()) {
-                LOGGER.error("Query processing failed = {}",
-                    queryString, ex);
-            }
-            throw new QueryException("Unable to parse query.", ex);
-        }
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/query/QueryContextProvider.java b/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/query/QueryContextProvider.java
deleted file mode 100644 (file)
index 65a232c..0000000
+++ /dev/null
@@ -1,27 +0,0 @@
-/**
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.northbound.commons.query;
-
-import javax.ws.rs.ext.ContextResolver;
-import javax.ws.rs.ext.Provider;
-
-/**
- * A provider for getting hold of the QueryContext.
- */
-@Provider
-public class QueryContextProvider implements ContextResolver<QueryContext> {
-
-    // Singleton Query Context instance
-    private static final QueryContext queryContext = new QueryContextImpl();
-
-    @Override
-    public QueryContext getContext(Class<?> type) {
-        return queryContext;
-    }
-
-}
diff --git a/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/query/QueryException.java b/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/query/QueryException.java
deleted file mode 100644 (file)
index 9ff78ed..0000000
+++ /dev/null
@@ -1,30 +0,0 @@
-/**
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.northbound.commons.query;
-
-import javax.ws.rs.WebApplicationException;
-import javax.ws.rs.core.MediaType;
-import javax.ws.rs.core.Response;
-
-/**
- * Signals that an error happened during the parsing or processing of a query.
- */
-public class QueryException extends WebApplicationException {
-
-    private static final long serialVersionUID = 1L;
-
-    public QueryException(String msg) {
-        super(Response.status(Response.Status.BAD_REQUEST)
-                .entity(msg).type(MediaType.TEXT_PLAIN).build());
-    }
-
-    public QueryException(String msg, Throwable cause) {
-        super(cause, Response.status(Response.Status.BAD_REQUEST)
-                .entity(msg).type(MediaType.TEXT_PLAIN).build());
-    }
-}
diff --git a/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/query/QueryImpl.java b/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/query/QueryImpl.java
deleted file mode 100644 (file)
index cb77e04..0000000
+++ /dev/null
@@ -1,241 +0,0 @@
-/**
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.northbound.commons.query;
-
-import java.util.ArrayList;
-import java.util.Collection;
-import java.util.Iterator;
-import java.util.List;
-import java.util.regex.Pattern;
-
-import org.opendaylight.controller.northbound.commons.query.CompareExpression.OP;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- *
- */
-/*package*/ class QueryImpl<T> implements Query<T> {
-    public static final Logger LOGGER = LoggerFactory.getLogger(QueryImpl.class);
-    private static final boolean ALLOW_OBJECT_STRING_COMPARE = true;
-
-    private final Expression expression;
-    private final TypeInfo rootType ;
-    /**
-     * Set the expression and cache
-     * @param type
-     * @param expression
-     */
-    public QueryImpl(Class<T> type, Expression expression) {
-        this.expression = expression;
-        this.rootType = TypeInfo.createRoot(null, type);
-    }
-
-    @Override
-    public List<T> find(Collection<T> collection) throws QueryException {
-        // new arraylist for result
-        List<T> result = new ArrayList<T>();
-        for (T item : collection) {
-            if (match(item, rootType)) {
-                result.add(item);
-            }
-        }
-        return result;
-    }
-
-    @Override
-    public int filter(Collection<T> collection) throws QueryException {
-        // find items
-        List<T> matched = new ArrayList<T>();
-        for (T item : collection) {
-            if (match(item, rootType)) {
-                matched.add(item);
-            }
-        }
-        collection.clear();
-        collection.addAll(matched);
-        return matched.size();
-    }
-
-    @SuppressWarnings({ "rawtypes", "unchecked" })
-    @Override
-    public int filter(T rootObject, Class<?> childClass) throws QueryException {
-        // retrieve underlying collection
-        TypeInfo childType = rootType.getCollectionChild(childClass);
-        if (childType == null || !(childType instanceof IteratableTypeInfo)) {
-            return 0;
-        }
-        Collection collection = (Collection)
-                childType.getAccessor().getValue(rootObject);
-        // get the child type of the collection type
-        TypeInfo ti = childType.getCollectionChild(childClass);
-        List matched = new ArrayList();
-        for (Object item : collection) {
-            if (match(item, ti)) {
-                matched.add(item);
-            }
-        }
-        collection.clear();
-        collection.addAll(matched);
-        return matched.size();
-    }
-
-    private boolean match(final Object object, final TypeInfo rootType)
-            throws QueryException {
-        return expression.accept(new Visitor () {
-            @Override
-            public boolean visit(LogicalExpression le) throws QueryException {
-                if (LOGGER.isDebugEnabled()) {
-                    LOGGER.debug("Logical exp {}|{}|{}", le.getOperator(), le.getFirst(),
-                            le.getSecond());
-                }
-                return (le.getOperator() == LogicalExpression.OP.AND) ?
-                        le.getFirst().accept(this) && le.getSecond().accept(this) :
-                            le.getFirst().accept(this) || le.getSecond().accept(this);
-            }
-
-            @Override
-            public boolean visit(CompareExpression ce) throws QueryException {
-                boolean result = visitInternal(ce);
-                if (LOGGER.isDebugEnabled()) {
-                    LOGGER.debug("=== Compare exp {}|{}|{} == {}", ce.getOperator(),
-                            ce.getSelector(), ce.getArgument(), result);
-                }
-                return result;
-            }
-
-            public boolean visitInternal(CompareExpression ce) throws QueryException {
-                String[] selector = ce.getSelector().split("\\.");
-                if (!rootType.getName().equals(selector[0])) {
-                    if (LOGGER.isDebugEnabled()) {
-                        LOGGER.debug("Root name mismatch: {} != {}",
-                                rootType.getName(), selector[0]);
-                    }
-                    return false;
-                }
-                Object value = rootType.retrieve(object, selector, 1);
-                if(value == null){ // nothing to compare against
-                    return false;
-                }
-                if (LOGGER.isDebugEnabled()) {
-                    LOGGER.debug("Comparing [{}] {} [{}]", ce.getArgument(),
-                            ce.getOperator(), value.toString());
-                }
-                if (value instanceof Collection) {
-                    Collection<?> collection = (Collection<?>) value;
-                    if(collection.size() == 0 && ce.getOperator() == OP.NE) {
-                        // collection doesn't contain query string
-                        return true;
-                    }
-                    // If there are elements iterate
-                    Iterator<?> it = collection.iterator();
-                    OP operator = ce.getOperator();
-                    if (operator == OP.NE) {
-                        // negate the operator
-                        operator = OP.EQ;
-                    }
-                    while (it.hasNext()) {
-                        Object item = it.next();
-                        if (compare(parse(ce.getArgument(), item), item, operator)) {
-                            // if match found check the operator and return false for NE
-                            return (ce.getOperator() != OP.NE);
-                        }
-                    }
-                    // return true for NE and false for rest
-                    return (ce.getOperator() == OP.NE);
-                } else {
-                    return compare(parse(ce.getArgument(), value), value,
-                            ce.getOperator());
-                }
-            }
-
-        });
-    }
-
-    private boolean compare(Object valueToMatch, Object actualValue, OP operator) {
-        if (valueToMatch == null || actualValue == null) {
-            return false;
-        }
-        if (ALLOW_OBJECT_STRING_COMPARE && (valueToMatch instanceof String)
-                && !(actualValue instanceof String)) {
-            actualValue = actualValue.toString();
-        }
-
-        int compareResult = -1;
-        if (valueToMatch instanceof Comparable) {
-            compareResult = ((Comparable)actualValue).compareTo(valueToMatch);
-        } else {
-            if (LOGGER.isDebugEnabled()) {
-                LOGGER.debug("Not a comparable type: {} {}",
-                        valueToMatch.getClass().getName(),
-                        actualValue.getClass().getName());
-            }
-            return false;
-        }
-        switch(operator) {
-            case EQ :
-                return compareResult == 0;
-            case RE :
-                // Regex match,
-                if (valueToMatch instanceof String) {
-                    return Pattern.matches((String)valueToMatch, actualValue.toString());
-                } else {
-                    return compareResult == 0;
-                }
-            case NE:
-                return compareResult != 0;
-            case GT :
-                return compareResult > 0;
-            case GE :
-                return compareResult >= 0;
-            case LT :
-                return compareResult < 0;
-            case LE :
-                return compareResult <= 0;
-            default:
-                if (LOGGER.isDebugEnabled()) {
-                    LOGGER.debug("Unrecognized comparator - {}", operator);
-                }
-            return false;
-        }
-    }
-    private Object parse(String arg, Object value) {
-        if (value == null) {
-            return null;
-        }
-
-        try {
-            if (value instanceof String) {
-                return arg;
-            } else if (value instanceof Byte) {
-                return Byte.decode(arg);
-            } else if (value instanceof Double) {
-                return Double.parseDouble(arg);
-            } else if (value instanceof Float) {
-                return Float.parseFloat(arg);
-            } else if (value instanceof Integer) {
-                return Integer.parseInt(arg);
-            } else if (value instanceof Long) {
-                return Long.parseLong(arg);
-            } else if (value instanceof Short) {
-                return Short.parseShort(arg);
-            }
-        } catch (NumberFormatException ignore) {
-            if (LOGGER.isDebugEnabled()) {
-                LOGGER.debug("Exception parsing {}", arg, value);
-            }
-        }
-        if (LOGGER.isDebugEnabled()) {
-            LOGGER.debug("Using string comparision for type - {}",
-                    value.getClass().getName());
-        }
-        // Not a number or string. Convert to a string and compare as last resort
-        return ALLOW_OBJECT_STRING_COMPARE ? arg.toString() : null;
-    }
-
-}
diff --git a/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/query/TypeInfo.java b/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/query/TypeInfo.java
deleted file mode 100644 (file)
index 6c0c5dc..0000000
+++ /dev/null
@@ -1,316 +0,0 @@
-package org.opendaylight.controller.northbound.commons.query;
-
-import java.beans.BeanInfo;
-import java.beans.IntrospectionException;
-import java.beans.Introspector;
-import java.beans.PropertyDescriptor;
-import java.lang.annotation.Annotation;
-import java.lang.reflect.Field;
-import java.lang.reflect.Method;
-import java.lang.reflect.Modifier;
-import java.lang.reflect.ParameterizedType;
-import java.lang.reflect.Type;
-import java.util.Collection;
-import java.util.HashMap;
-import java.util.Map;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlAttribute;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlElementRef;
-import javax.xml.bind.annotation.XmlElementWrapper;
-import javax.xml.bind.annotation.XmlRootElement;
-import javax.xml.bind.annotation.XmlTransient;
-import javax.xml.bind.annotation.XmlType;
-
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * A wrapper over a JAXB type to allow traversal of the object graph and
- * search for specific values in the object tree.
- */
-/*package*/ class TypeInfo {
-
-    public static final Logger LOGGER = LoggerFactory.getLogger(TypeInfo.class);
-    public static final String DEFAULT_NAME = "##default";
-
-    protected final String _name; // the jaxb name
-    protected Class<?> _class; // jaxb type class
-    protected final XmlAccessType _accessType; // jaxb access type
-    protected final Accessor _accessor; // accessor to access object value
-    protected Map<String,TypeInfo> _types = new HashMap<String,TypeInfo>();
-    protected volatile boolean _explored = false;
-    /**
-     * Create a TypeInfo with a name and a class type. The accessor will be null
-     * for a root node.
-     */
-    protected TypeInfo(String name, Class<?> clz, Accessor accessor) {
-        _name = name;
-        _class = clz;
-        _accessor = accessor;
-        XmlAccessorType accessorType = null;
-        if(clz == null) {
-            throw new NullPointerException("Type class can not be null");
-        }
-        accessorType = clz.getAnnotation(XmlAccessorType.class);
-        _accessType = (accessorType == null ?
-                XmlAccessType.PUBLIC_MEMBER : accessorType.value());
-        if (LOGGER.isDebugEnabled()) {
-            LOGGER.debug("Created type info name:{} type:{}", _name, _class);
-        }
-    }
-
-    /**
-     * @return the Accessor to access the value
-     */
-    public final Accessor getAccessor() {
-        return _accessor;
-    }
-
-    /**
-     * @return get the child by name
-     */
-    public final TypeInfo getChild(String name) {
-        return _types.get(name);
-    }
-
-    public TypeInfo getCollectionChild(Class<?> childType) {
-        explore();
-        for (TypeInfo ti : _types.values()) {
-            if (Collection.class.isAssignableFrom(ti.getType())) {
-                ParameterizedType p = (ParameterizedType)
-                        ti.getAccessor().getGenericType();
-                Type[] pts = p.getActualTypeArguments();
-                if (pts.length == 1 && pts[0].equals(childType)) {
-                    return ti;
-                }
-            }
-        }
-        return null;
-    }
-
-    public Class getType() {
-        return _class;
-    }
-
-    public String getName() {
-        return _name;
-    }
-
-    /**
-     * @return the object value by a selector query
-     */
-    public Object retrieve(Object target, String[] query, int index)
-            throws QueryException {
-        if (LOGGER.isDebugEnabled()) {
-            LOGGER.debug("retrieve: {}/{} type:{}", index, query.length, target.getClass());
-        }
-        if (index >= query.length) {
-            return null;
-        }
-        explore();
-        if (!target.getClass().equals(_class)) {
-            if (_class.isAssignableFrom(target.getClass())) {
-                if (LOGGER.isDebugEnabled()) {
-                    LOGGER.debug("Handling subtype {} of {} ", target.getClass(), _class);
-                }
-                // explore the subtype
-                TypeInfo subTypeInfo = new TypeInfo(getRootName(target.getClass()),
-                        target.getClass(), _accessor);
-                return subTypeInfo.retrieve(target, query, index);
-            } else {
-                // non compatible object; bail out
-                return null;
-            }
-        }
-        TypeInfo child = getChild(query[index]);
-        if (child == null) {
-            return null;
-        }
-        target = child.getAccessor().getValue(target);
-        if (index+1 == query.length) {
-            // match found
-            return target;
-        }
-        return child.retrieve(target, query, index+1);
-    }
-
-    /**
-     * Explore the type info for children.
-     */
-    public synchronized void explore() {
-        if (_explored) {
-            return;
-        }
-        for (Class<?> c = _class; c != null; c = c.getSuperclass()) {
-            if (c.equals(Object.class)) {
-                break;
-            }
-            // Currently only fields and methods annotated with JAXB annotations are
-            // considered as valid for search purposes.
-            //check methods first
-            for (Method m : c.getDeclaredMethods()) {
-                String tn = getTypeName(m, _accessType);
-                if (tn != null) {
-                    if (LOGGER.isDebugEnabled()) {
-                        LOGGER.debug(
-                            "exploring type: {} name: {} method: {}",
-                            _class.getSimpleName(), tn, m);
-                    }
-                    _types.put(tn, createTypeInfo(tn, new Accessor(m)));
-                }
-            }
-            for (Field f : c.getDeclaredFields()) {
-                String tn = getTypeName(f, _accessType);
-                if (tn != null) {
-                    if (LOGGER.isDebugEnabled()) {
-                        LOGGER.debug(
-                            "exploring type: {} name: {} field: {}",
-                            _class.getSimpleName(), tn, f);
-                    }
-                    _types.put(tn, createTypeInfo(tn, new Accessor(f)));
-                }
-            }
-        }
-        _explored = true;
-    }
-
-    public static final String getTypeName(Field f, XmlAccessType access) {
-        // ignore static, transient and xmltransient fields
-        if (Modifier.isTransient(f.getModifiers()) ||
-                Modifier.isStatic(f.getModifiers()) ||
-                f.getAnnotation(XmlTransient.class) != null ) {
-            return null;
-        }
-        // try to read annotation
-        String name = getTypeName(f.getAnnotations(), f.getName());
-        if (name != null) return name;
-        // no annotation present check accesstype
-        else if (access == XmlAccessType.NONE) { // none return name
-            return name;
-        } else if (access == XmlAccessType.FIELD) {
-            // return field name if no annotation present
-            return f.getName();
-        } else if (access == XmlAccessType.PUBLIC_MEMBER
-                && Modifier.isPublic(f.getModifiers())) { // look for public access
-            return f.getName();
-        }
-        // return annotated name ( if any )
-        return null;
-    }
-
-    public static final String getTypeName(Method m, XmlAccessType access) {
-        // ignore static, transient and xmltransient fields
-        if (Modifier.isStatic(m.getModifiers()) ||
-                m.getAnnotation(XmlTransient.class) != null ) {
-            return null;
-        }
-        // try to read annotation
-        String name = getTypeName(m.getAnnotations(), m.getName());
-        if (name != null) return name;
-        //check acces type
-        else if (access == XmlAccessType.NONE) { // none return name
-            return name;
-        } else if (access == XmlAccessType.PROPERTY) {
-            // return bean property name if no annotation present
-            return getBeanPropertyName(m);
-        } else if (access == XmlAccessType.PUBLIC_MEMBER
-                && Modifier.isPublic(m.getModifiers())) { // look for public access
-            return getBeanPropertyName(m);
-        }
-        return null;
-    }
-
-    private static String getBeanPropertyName(Method m){
-        try
-        {
-            Class<?> clazz=m.getDeclaringClass();
-            BeanInfo info = Introspector.getBeanInfo(clazz);
-            PropertyDescriptor[] props = info.getPropertyDescriptors();
-            for (PropertyDescriptor pd : props)
-            {
-                if (m.equals(pd.getReadMethod())) {
-                    return pd.getName();
-                }
-            }
-        }
-        catch (IntrospectionException e)
-        {
-            LOGGER.error("Could not read bean property name for method = {}",
-                    m.getName(), e);
-        }
-        return null;
-    }
-
-    public static TypeInfo createRoot(String name, Class<?> clz) {
-        // root is always a composite type
-        // FIXME assert its a JAXB type
-        XmlRootElement root = clz.getAnnotation(XmlRootElement.class);
-        if (root == null) {
-            throw new IllegalArgumentException("Not a JAXB type: " + clz);
-        }
-        if (name == null) {
-            name = getRootName(clz);
-        }
-        return new TypeInfo(name, clz, null);
-    }
-
-    public static TypeInfo createTypeInfo(String name, Accessor accessor) {
-        if (accessor.getAccessibleObject().getAnnotation(XmlElementWrapper.class) != null) {
-            //XmlElementWrapperType
-            return new WrapperTypeInfo(name, accessor);
-        } else if (Collection.class.isAssignableFrom(accessor.getType())) {
-            // collection type
-            return new IteratableTypeInfo(name, accessor);
-        }
-        return new TypeInfo(name, accessor.getType(), accessor);
-    }
-
-    public static String getRootName(Class<?> cls) {
-        XmlRootElement root = cls.getAnnotation(XmlRootElement.class);
-        if (root == null) {
-            return null;
-        }
-        String rootName = root.name();
-        if (DEFAULT_NAME.equals(rootName)) {
-            String clsName = cls.getSimpleName();
-            rootName = Character.toLowerCase(clsName.charAt(0)) + clsName.substring(1);
-        }
-        return rootName;
-    }
-
-    protected static String getTypeName(Annotation[] annotations, String dflt) {
-        String name = null;
-        for (Annotation a : annotations) {
-            if (a.annotationType() == XmlAttribute.class) {
-                name = ((XmlAttribute)a).name();
-            } else if (a.annotationType() == XmlElement.class) {
-                name = ((XmlElement)a).name();
-            } else if (a.annotationType() == XmlElementRef.class) {
-                name = ((XmlElementRef)a).name();
-            } else if (a.annotationType() == XmlElementWrapper.class) {
-                name = ((XmlElementWrapper)a).name();
-                // break the loop as we don't want name to be overwritten by XmlElement
-                break;
-            } else if (a.annotationType() == XmlType.class) {
-                name = ((XmlType)a).name();
-            } else if (a.annotationType() == XmlTransient.class) {
-                // transient type
-                return null;
-            }
-        }
-        if (DEFAULT_NAME.equals(name)) {
-            return dflt;
-        }
-        return name;
-    }
-
-    @Override
-    public String toString() {
-        return " TypeInfo [_name=" + _name + ", _class=" + _class
-                + ", _accessType=" + _accessType + ", _accessor=" + _accessor
-                + ", _types=" + _types + ", _explored=" + _explored + " ] ";
-    }
-}
diff --git a/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/query/Visitor.java b/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/query/Visitor.java
deleted file mode 100644 (file)
index 0c1d2be..0000000
+++ /dev/null
@@ -1,16 +0,0 @@
-/**
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.northbound.commons.query;
-
-/*package*/ interface Visitor {
-
-    boolean visit(LogicalExpression exp) throws QueryException;
-
-    boolean visit(CompareExpression exp) throws QueryException;
-
-}
diff --git a/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/query/WrapperTypeInfo.java b/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/query/WrapperTypeInfo.java
deleted file mode 100644 (file)
index 156942c..0000000
+++ /dev/null
@@ -1,65 +0,0 @@
-/**
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.northbound.commons.query;
-
-import java.lang.reflect.AccessibleObject;
-import java.lang.reflect.Field;
-import java.lang.reflect.Method;
-
-import javax.xml.bind.annotation.XmlElement;
-
-public class WrapperTypeInfo extends TypeInfo {
-
-    protected WrapperTypeInfo(String name, Accessor accessor) {
-        super(name, accessor.getType(), accessor);
-    }
-
-    @Override
-    public Object retrieve(Object target, String[] query, int index) throws QueryException {
-        if (LOGGER.isDebugEnabled()) {
-            LOGGER.debug("retrieve collection: {}/{}", index, query.length);
-        }
-        if (index >= query.length) {
-            return null;
-        }
-        explore();
-        TypeInfo child = getChild(query[index]);
-        if (child == null) {
-            return null;
-        }
-        if (query.length == index+1) { // skipping this node
-            return target;
-        }else { // if list of list go to next node to get value
-            return child.retrieve(target, query, index+1);
-        }
-    }
-
-    @Override
-    public synchronized void explore() {
-        if (_explored) {
-            return;
-        }
-        if (LOGGER.isDebugEnabled()) {
-            LOGGER.debug("exploring wrapper type: {} gtype: {}", _class,
-                    _accessor.getGenericType());
-        }
-        String tn = null;
-        AccessibleObject accessibleObject = _accessor.getAccessibleObject();
-        XmlElement xmlElement = accessibleObject.getAnnotation(XmlElement.class);
-        if (accessibleObject instanceof Field) {
-            Field f = (Field) accessibleObject;
-            tn = DEFAULT_NAME.equals(xmlElement.name())?f.getName() : xmlElement.name();
-        }else if (accessibleObject instanceof Method) {
-            Method m = (Method) accessibleObject;
-            tn = DEFAULT_NAME.equals(xmlElement.name())?m.getName() : xmlElement.name();
-        }
-        this._types.put(tn, new IteratableTypeInfo(tn, this._accessor));
-        _explored = true;
-    }
-
-}
diff --git a/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/types/StringList.java b/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/types/StringList.java
deleted file mode 100644 (file)
index 62d1608..0000000
+++ /dev/null
@@ -1,38 +0,0 @@
-/**
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.northbound.commons.types;
-
-import java.util.List;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-/**
- * Represents a list of string values
- */
-@XmlRootElement(name = "list")
-@XmlAccessorType(XmlAccessType.NONE)
-public class StringList {
-    @XmlElement(name = "item")
-    private List<String> list;
-
-    public StringList() {
-    }
-
-    public StringList(List<String> list) {
-        this.list = list;
-    }
-
-    public List<String> getList() {
-        return list;
-    }
-
-}
diff --git a/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/utils/NorthboundUtils.java b/opendaylight/adsal/northbound/commons/src/main/java/org/opendaylight/controller/northbound/commons/utils/NorthboundUtils.java
deleted file mode 100644 (file)
index 4e78c20..0000000
+++ /dev/null
@@ -1,202 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.northbound.commons.utils;
-
-import java.util.HashMap;
-import java.util.Map;
-
-import javax.ws.rs.core.Response;
-
-import org.opendaylight.controller.containermanager.IContainerAuthorization;
-import org.opendaylight.controller.sal.authorization.Privilege;
-import org.opendaylight.controller.sal.authorization.UserLevel;
-import org.opendaylight.controller.sal.core.Description;
-import org.opendaylight.controller.sal.core.Name;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.utils.GlobalConstants;
-import org.opendaylight.controller.sal.utils.ServiceHelper;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.sal.utils.StatusCode;
-import org.opendaylight.controller.switchmanager.ISwitchManager;
-import org.opendaylight.controller.usermanager.IUserManager;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-public class NorthboundUtils {
-
-    private static final Map<StatusCode, Response.Status> ResponseStatusMapping = new HashMap<StatusCode, Response.Status>() {
-        private static final long serialVersionUID = 1L;
-        {
-            put(StatusCode.SUCCESS, Response.Status.OK);
-            put(StatusCode.BADREQUEST, Response.Status.BAD_REQUEST);
-            put(StatusCode.UNAUTHORIZED, Response.Status.UNAUTHORIZED);
-            put(StatusCode.FORBIDDEN, Response.Status.FORBIDDEN);
-            put(StatusCode.NOTFOUND, Response.Status.NOT_FOUND);
-            put(StatusCode.NOTALLOWED, Response.Status.FORBIDDEN);
-            put(StatusCode.NOTACCEPTABLE, Response.Status.NOT_ACCEPTABLE);
-            put(StatusCode.TIMEOUT, Response.Status.GONE);
-            put(StatusCode.CONFLICT, Response.Status.CONFLICT);
-            put(StatusCode.GONE, Response.Status.GONE);
-            put(StatusCode.UNSUPPORTED, Response.Status.BAD_REQUEST);
-            put(StatusCode.INTERNALERROR, Response.Status.INTERNAL_SERVER_ERROR);
-            put(StatusCode.NOTIMPLEMENTED, Response.Status.NOT_ACCEPTABLE);
-            put(StatusCode.NOSERVICE, Response.Status.SERVICE_UNAVAILABLE);
-            put(StatusCode.UNDEFINED, Response.Status.BAD_REQUEST);
-        }
-    };
-
-    private static final String AUDIT = "audit";
-
-    private static final Logger logger = LoggerFactory.getLogger(AUDIT);
-
-    // Suppress default constructor for noninstantiability
-    private NorthboundUtils() {
-    }
-
-    /**
-     * Returns Response.Status for a given status. If the status is null or if
-     * the corresponding StatusCode is not present in the ResponseStatusMapping,
-     * it returns null.
-     *
-     * @param status
-     *            The Status
-     * @return The Response.Status for a given status
-     */
-    public static Response.Status getResponseStatus(Status status) {
-        return ResponseStatusMapping.get(status.getCode());
-    }
-
-    /**
-     * Returns Response for a given status. If the status provided is null or if
-     * the corresponding StatusCode is not present in the ResponseStatusMapping,
-     * it returns Response with StatusType as INTERNAL_SERVER_ERROR.
-     *
-     * @param status
-     *            The Status
-     * @return The Response for a given status.
-     */
-    public static Response getResponse(Status status) {
-        if ((status == null) || (!ResponseStatusMapping.containsKey(status.getCode()))) {
-            return Response.status(Response.Status.INTERNAL_SERVER_ERROR).entity("Action Result Unknown").build();
-        }
-        return Response.status(ResponseStatusMapping.get(status.getCode())).entity(status.getDescription()).build();
-    }
-
-    /**
-     * Returns whether the current user has the required privilege on the
-     * specified container
-     *
-     * @param userName
-     *            The user name
-     * @param containerName
-     *            The container name
-     * @param required
-     *            Operation to be performed - READ/WRITE
-     * @param bundle
-     *            Class from where the function is invoked
-     * @return The Status of the request, either Success or Unauthorized
-     */
-    public static boolean isAuthorized(String userName, String containerName, Privilege required, Object bundle) {
-
-        if (containerName.equals(GlobalConstants.DEFAULT.toString())) {
-            IUserManager auth = (IUserManager) ServiceHelper.getGlobalInstance(IUserManager.class, bundle);
-
-            switch (required) {
-            case WRITE:
-                return (auth.getUserLevel(userName).ordinal() <= UserLevel.NETWORKADMIN.ordinal());
-            case READ:
-                return (auth.getUserLevel(userName).ordinal() <= UserLevel.NETWORKOPERATOR.ordinal());
-            default:
-                return false;
-            }
-
-        } else {
-            IContainerAuthorization auth = (IContainerAuthorization) ServiceHelper.getGlobalInstance(
-                    IContainerAuthorization.class, bundle);
-
-            if (auth == null) {
-                return false;
-            }
-
-            Privilege current = auth.getResourcePrivilege(userName, containerName);
-            if (required.ordinal() > current.ordinal()) {
-                return false;
-            }
-        }
-        return true;
-    }
-
-    public static void auditlog(String moduleName, String user, String action, String resource,
-            String containerName) {
-        String auditMsg = "";
-        String mode = "REST";
-        if (containerName != null) {
-            auditMsg = "Mode: " + mode + " User " + user + " "  + action + " " + moduleName + " " + resource + " in container "
-                    + containerName;
-        } else {
-            auditMsg = "Mode: " + mode + " User " + user + " "  + action + " " + moduleName + " " + resource;
-        }
-        logger.trace(auditMsg);
-    }
-
-    public static void auditlog(String moduleName, String user, String action, String resource) {
-        auditlog(moduleName, user, action, resource, null);
-    }
-
-    public static String getNodeDesc(Node node, ISwitchManager switchManager) {
-        Description desc = (Description) switchManager.getNodeProp(node,
-                Description.propertyName);
-        String description = (desc == null) ? "" : desc.getValue();
-        return (description.isEmpty() || description.equalsIgnoreCase("none")) ? node
-                .toString() : description;
-    }
-
-    public static String getNodeDesc(Node node, String containerName,
-            Object bundle) {
-        ISwitchManager switchManager = (ISwitchManager) ServiceHelper
-                .getInstance(ISwitchManager.class, containerName, bundle);
-        if (switchManager == null) {
-            return null;
-        }
-
-        return getNodeDesc(node, switchManager);
-    }
-
-    public static String getNodeDesc(Node node, Object bundle) {
-        ISwitchManager switchManager = (ISwitchManager) ServiceHelper
-                .getInstance(ISwitchManager.class,
-                        GlobalConstants.DEFAULT.toString(), bundle);
-        if (switchManager == null) {
-            return null;
-        }
-
-        return getNodeDesc(node, switchManager);
-    }
-
-    public static String getPortName(NodeConnector nodeConnector,
-            String container, Object bundle) {
-        ISwitchManager switchManager = (ISwitchManager) ServiceHelper
-                .getInstance(ISwitchManager.class, container, bundle);
-        return getPortName(nodeConnector, switchManager);
-    }
-
-    public static String getPortName(NodeConnector nodeConnector, Object bundle) {
-        return getPortName(nodeConnector, GlobalConstants.DEFAULT.toString(), bundle);
-    }
-
-    public static String getPortName(NodeConnector nodeConnector,
-            ISwitchManager switchManager) {
-        Name ncName = ((Name) switchManager.getNodeConnectorProp(nodeConnector,
-                Name.NamePropName));
-        String nodeConnectorName = (ncName != null) ? ncName.getValue() : nodeConnector.getNodeConnectorIdAsString();
-        nodeConnectorName = nodeConnectorName + "@"
-                + getNodeDesc(nodeConnector.getNode(), switchManager);
-        return nodeConnectorName.substring(0, nodeConnectorName.length());
-    }
-}
diff --git a/opendaylight/adsal/northbound/commons/src/main/javacc/fiql.jj b/opendaylight/adsal/northbound/commons/src/main/javacc/fiql.jj
deleted file mode 100644 (file)
index b447a32..0000000
+++ /dev/null
@@ -1,124 +0,0 @@
-
-options {
-  STATIC = false;
-}
-
-PARSER_BEGIN(FiqlParser)
-package org.opendaylight.controller.northbound.commons.query;
-
-import java.util.regex.*;
-
-/*package*/ class FiqlParser {
-  public static Expression parse(String query) throws ParseException {
-    FiqlParser parser = new FiqlParser(new java.io.StringReader(query));
-    return parser.START();
-  }
-}
-
-PARSER_END(FiqlParser)
-
-/* whitespace */
-SKIP :
-{
-  " " | "\t"
-}
-
-TOKEN : {
-  <#ALPHA  : ( ["a"-"z", "A"-"Z", "0"-"9"] )+ >
-}
-
-TOKEN : {
-  <NUM     : ("+"|"-")?(["0"-"9"])+"."(["0"-"9"])* >
-  |
-  <LPAREN  : "(" >
-  |
-  <RPAREN  : ")" >
-}
-
-/* comparision ops */
-TOKEN : {
-  <RE      : ("=") >
-  |
-  <EQ      : ("==" | "=eq=") >
-  |
-  <NE      : ("!=" | "=ne=") >
-  |
-  <LT      : ("=lt=" | "<") >
-  |
-  <LE      : ("=le=" | "<=") >
-  |
-  <GT      : ("=gt=" | ">") >
-  |
-  <GE      : ("=ge=" | ">=") >
-}
-
-/* ops */
-TOKEN : {
-  <AND     : (";" | "and") >
-  |
-  <OR      : ("," | "or") >
-}
-
-/* strings */
-TOKEN : {
-  <STRING : ( ~["\"", "'", "(", ")", ";", ",", "=", "<", ">", "!", "~", " "] )+ >
-  |
-  <DQ_STRING : ( "\"" ( ~["\""] )* "\"" ) >
-  |
-  <SQ_STRING : ( "'" ( ~["'"] )* "'" ) >
-}
-
-/* Root production */
-Expression START() :
-{
-  Expression e;
-}
-{
-  e = EXPR()
-  <EOF>
-  {
-    return e;
-  }
-}
-
-Expression EXPR():
-{
-  ExpressionBuilder builder = new ExpressionBuilder();
-  Expression t;
-}
-{
-  t = TERM() { builder.withTerm(t); }
-  (
-    (<AND> t = TERM()) { builder.withAnd().withTerm(t); }
-    |
-    (<OR> t = TERM() ) { builder.withOr().withTerm(t); }
-  )*
-  {
-    return builder.build();
-  }
-}
-
-Expression TERM() :
-{
-  Token selector, arg;
-  Expression exp;
-  CompareExpression.OP op;
-}
-{
-  selector = <STRING>
-  (
-    ( <EQ>  {op=CompareExpression.OP.EQ;} |
-      <RE>  {op=CompareExpression.OP.RE;} |
-      <NE>  {op=CompareExpression.OP.NE;} |
-      <LT>  {op=CompareExpression.OP.LT;} |
-      <LE>  {op=CompareExpression.OP.LE;} |
-      <GT>  {op=CompareExpression.OP.GT;} |
-      <GE>  {op=CompareExpression.OP.GE;}
-    )
-    ( arg = <STRING> | arg = <DQ_STRING> | arg = <SQ_STRING> | arg = <NUM>)
-  ) { return new CompareExpression(op, selector.image, arg.image); }
-  |
-  (
-    <LPAREN> exp = EXPR() <RPAREN>
-  ) { return exp; }
-}
diff --git a/opendaylight/adsal/northbound/commons/src/test/java/org/opendaylight/controller/northbound/commons/CommonsNorthboundTest.java b/opendaylight/adsal/northbound/commons/src/test/java/org/opendaylight/controller/northbound/commons/CommonsNorthboundTest.java
deleted file mode 100644 (file)
index ec9590b..0000000
+++ /dev/null
@@ -1,24 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.northbound.commons;
-
-import org.junit.Assert;
-import org.junit.Test;
-
-public class CommonsNorthboundTest {
-
-    @Test
-    public void testRestMessages() {
-        Assert.assertTrue(RestMessages.SUCCESS.toString().equals("Success"));
-        Assert.assertTrue(RestMessages.INTERNALERROR.toString().equals(
-                "Internal Error"));
-        Assert.assertTrue(RestMessages.INVALIDDATA.toString().equals(
-                "Data is invalid or conflicts with URI"));
-    }
-
-}
diff --git a/opendaylight/adsal/northbound/commons/src/test/java/org/opendaylight/controller/northbound/commons/exception/CommonsNorthboundExceptionTest.java b/opendaylight/adsal/northbound/commons/src/test/java/org/opendaylight/controller/northbound/commons/exception/CommonsNorthboundExceptionTest.java
deleted file mode 100644 (file)
index 8784950..0000000
+++ /dev/null
@@ -1,128 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.northbound.commons.exception;
-
-import javax.ws.rs.core.Response;
-
-import org.junit.Assert;
-import org.junit.Test;
-
-public class CommonsNorthboundExceptionTest {
-
-    @Test
-    public void testMethodNotAllowed() {
-        MethodNotAllowed mna = new MethodNotAllowed();
-        Assert.assertTrue(mna.getStatusCode() == 405);
-        Assert.assertTrue(mna.getReasonPhrase().equals("Method Not Allowed"));
-        Assert.assertTrue(mna.getFamily().equals(
-                Response.Status.Family.CLIENT_ERROR));
-    }
-
-    @Test
-    public void testInternalServerErrorException() {
-        try {
-            throw new InternalServerErrorException("Internal Server Exception");
-        } catch (InternalServerErrorException e) {
-            Assert.assertTrue(e.getResponse().getEntity()
-                    .equals("Internal Server Exception"));
-        }
-    }
-
-    @Test
-    public void testMethodNotAllowedException() {
-        try {
-            throw new MethodNotAllowedException("Method Not Allowed Exception");
-        } catch (MethodNotAllowedException e) {
-            Assert.assertTrue(e.getResponse().getEntity()
-                    .equals("Method Not Allowed Exception"));
-        }
-    }
-
-    @Test
-    public void testNotAcceptableException() {
-        try {
-            throw new NotAcceptableException("Not Acceptable Exception");
-        } catch (NotAcceptableException e) {
-            Assert.assertTrue(e.getResponse().getEntity()
-                    .equals("Not Acceptable Exception"));
-        }
-    }
-
-    @Test
-    public void testResourceConflictException() {
-        try {
-            throw new ResourceConflictException("Resource Conflict Exception");
-        } catch (ResourceConflictException e) {
-            Assert.assertTrue(e.getResponse().getEntity()
-                    .equals("Resource Conflict Exception"));
-        }
-    }
-
-    @Test
-    public void testResourceForbiddenException() {
-        try {
-            throw new ResourceForbiddenException("Resource Forbidden Exception");
-        } catch (ResourceForbiddenException e) {
-            Assert.assertTrue(e.getResponse().getEntity()
-                    .equals("Resource Forbidden Exception"));
-        }
-    }
-
-    @Test
-    public void testResourceGoneException() {
-        try {
-            throw new ResourceGoneException("Resource Gone Exception");
-        } catch (ResourceGoneException e) {
-            Assert.assertTrue(e.getResponse().getEntity()
-                    .equals("Resource Gone Exception"));
-        }
-    }
-
-    @Test
-    public void testResourceNotFoundException() {
-        try {
-            throw new ResourceNotFoundException("Resource Not Found Exception");
-        } catch (ResourceNotFoundException e) {
-            Assert.assertTrue(e.getResponse().getEntity()
-                    .equals("Resource Not Found Exception"));
-        }
-    }
-
-    @Test
-    public void testServiceUnavailableException() {
-        try {
-            throw new ServiceUnavailableException(
-                    "Service Unavailable Exception");
-        } catch (ServiceUnavailableException e) {
-            Assert.assertTrue(e.getResponse().getEntity()
-                    .equals("Service Unavailable Exception"));
-        }
-    }
-
-    @Test
-    public void testUnauthorizedException() {
-        try {
-            throw new UnauthorizedException("Unauthorized Exception");
-        } catch (UnauthorizedException e) {
-            Assert.assertTrue(e.getResponse().getEntity()
-                    .equals("Unauthorized Exception"));
-        }
-    }
-
-    @Test
-    public void testUnsupportedMediaTypeException() {
-        try {
-            throw new UnsupportedMediaTypeException(
-                    "Unsupported Media Type Exception");
-        } catch (UnsupportedMediaTypeException e) {
-            Assert.assertTrue(e.getResponse().getEntity()
-                    .equals("Unsupported Media Type Exception"));
-        }
-    }
-
-}
diff --git a/opendaylight/adsal/northbound/commons/src/test/java/org/opendaylight/controller/northbound/commons/query/BookBean.java b/opendaylight/adsal/northbound/commons/src/test/java/org/opendaylight/controller/northbound/commons/query/BookBean.java
deleted file mode 100644 (file)
index 5d518f6..0000000
+++ /dev/null
@@ -1,92 +0,0 @@
-package org.opendaylight.controller.northbound.commons.query;
-
-import java.util.ArrayList;
-import java.util.List;
-
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlElementWrapper;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.northbound.commons.types.StringList;
-
-/**
- */
-
-@XmlRootElement(name="book")
-public class BookBean {
-
-    @XmlElement(name="name")
-    private String _name; // simple type
-
-    private String _isbn; // method annotation
-
-    @XmlElement(name="author")
-    private PersonBean _author; // composite type
-
-    @XmlElementWrapper//for XMLWrapper iterative composite types
-    @XmlElement(name="review")
-    private final List<ReviewBean> reviews = new ArrayList<ReviewBean>();
-
-    @XmlElement
-    private List<String> soldBy; //Iterative Type
-
-    @XmlElementWrapper(name="test")
-    @XmlElement
-    private final List<StringList> testList = new ArrayList<StringList>(); //XMLWrapper list of list
-
-    @XmlElementWrapper(name="parent")
-    @XmlElement(name="child")
-    private final List<WrapperList> wrapperList = new ArrayList<WrapperList>(); // XMLWrapper of XMLWrapper
-
-    public BookBean(){}
-
-    public BookBean(String name, String id, PersonBean person) {
-        _name = name;
-        _isbn = id;
-        _author = person;
-        soldBy = new ArrayList<String>();
-    }
-
-    public BookBean addReview(ReviewBean review) {
-        reviews.add(review);
-        return this;
-    }
-
-    public void setSellerInfo(List<String> sellers) {
-        soldBy = new ArrayList<String>(sellers);
-    }
-
-    public void addWrapperList(WrapperList list){
-        wrapperList.add(list);
-    }
-
-    public void addToTestList(StringList testList){
-        this.testList.add(testList);
-    }
-    public String getName() {
-        return "1"+_name;
-    }
-
-    @XmlElement(name="isbn")
-    public String get_isbn() {
-        return "pre"+_isbn;
-    }
-
-    public PersonBean getauthor() {
-        return _author;
-    }
-
-    @Override
-    public String toString() {
-        return "BookBean [_name=" + _name + ", _isbn=" + _isbn + ", _author="
-                + _author + ", reviews=" + reviews + ", soldBy=" + soldBy
-                + ", testList=" + testList + ", wrapperList=" + wrapperList + "]";
-    }
-
-}
-
-class WrapperList {
-  @XmlElementWrapper(name="items")
-  @XmlElement
-  public List<String> item = new ArrayList<String>();
-}
diff --git a/opendaylight/adsal/northbound/commons/src/test/java/org/opendaylight/controller/northbound/commons/query/ExpresssionTest.java b/opendaylight/adsal/northbound/commons/src/test/java/org/opendaylight/controller/northbound/commons/query/ExpresssionTest.java
deleted file mode 100644 (file)
index 3e2e153..0000000
+++ /dev/null
@@ -1,207 +0,0 @@
-/**
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.northbound.commons.query;
-
-import java.lang.reflect.Field;
-import java.util.ArrayList;
-import java.util.Collection;
-import java.util.List;
-import java.util.regex.Pattern;
-
-import org.junit.Assert;
-import org.junit.BeforeClass;
-import org.junit.Test;
-import org.opendaylight.controller.northbound.commons.query.CompareExpression.OP;
-
-public class ExpresssionTest {
-
-    private static final List<PersonBean> people = new ArrayList<PersonBean>();
-    private static final ArrayList<BookBean> books = new ArrayList<BookBean>();
-
-    public static void p(String msg) {
-        //System.out.println("======= " + msg);
-    }
-
-    public static boolean matches(Expression exp, final PersonBean person) throws Exception {
-
-        boolean result = exp.accept(new Visitor() {
-            @Override
-            public boolean visit(LogicalExpression le) throws QueryException {
-                p("=== LE " + le.getOperator() + "|" + le.getFirst() + "|" + le.getSecond());
-                return (le.getOperator() == LogicalExpression.OP.AND) ?
-                        le.getFirst().accept(this) && le.getSecond().accept(this) :
-                            le.getFirst().accept(this) || le.getSecond().accept(this);
-            }
-
-            @Override
-            public boolean visit(CompareExpression ce) {
-                p("=== CE " + ce.getOperator() + "|" + ce.getSelector() + "|" + ce.getArgument());
-                if (person == null) {
-                    return false;
-                }
-                try {
-                    // check if the selector matches any of the fields
-                    Field field = PersonBean.class.getDeclaredField(ce.getSelector());
-                    if (field == null) {
-                        p("No field found by name : " + ce.getSelector());
-                        return false;
-                    }
-                    Object value = field.get(person);
-                    if (value instanceof String) {
-                        p("Comparing [" + ce.getArgument() + "] "+ ce.getOperator() + " [" + value.toString() + "]");
-                        if (ce.getOperator() == OP.EQ) {
-                            return ce.getArgument().equals(value.toString());
-                        } else if (ce.getOperator() == OP.RE) {
-                            return Pattern.matches(ce.getArgument(), value.toString());
-                        } else if (ce.getOperator() == OP.NE) {
-                            return !ce.getArgument().equals(value.toString());
-                        } else {
-                            p("Comparator : " + ce.getOperator() + " cannot apply to Strings");
-                            return false;
-                        }
-                    } else {
-                        // assume its a #
-                        int valToMatch = Integer.parseInt(ce.getArgument());
-                        int actualValue = (Integer)value;
-                        p("Comparing: " + valToMatch + " " + ce.getOperator() + " " + actualValue);
-                        switch(ce.getOperator()) {
-                        case EQ :
-                        case RE :
-                            return actualValue == valToMatch;
-                        case NE :
-                            return actualValue != valToMatch;
-                        case GT :
-                            return actualValue > valToMatch;
-                        case GE :
-                            return actualValue >= valToMatch;
-                        case LT :
-                            return actualValue < valToMatch;
-                        case LE :
-                            return actualValue <= valToMatch;
-                        default:
-                            p("Unrecognized compare operator: " + ce.getOperator());
-                            return false;
-                        }
-                    }
-                } catch (Exception e) {
-                    throw new IllegalStateException(e);
-                }
-            }
-        });
-        p("RESULT: " + result);
-        return result;
-    }
-
-    @BeforeClass
-    public static void load() {
-        System.setProperty("org.slf4j.simpleLogger.defaultLogLevel", "debug");
-
-        people.add(new PersonBean(100, "John", "Doe", "San Jose"));
-        people.add(new PersonBean(200, "Foo", "Bar", "San Francisco"));
-        people.add(new PersonBean(300, "A", "B", "San Francisco"));
-        people.add(new PersonBean(400, "X", "Y", "New York"));
-
-        books.add(new BookBean("Book1", "A001", people.get(0)));
-        books.add(new BookBean("Book2", "A002", people.get(1)));
-        books.add(new BookBean("Book3", "A003", people.get(2)));
-
-        ReviewBean review1 = new ReviewBean("cool", people.get(2));
-        ReviewBean review2 = new ReviewBean("kewl", people.get(3));
-        ReviewBean review3 = new ReviewBean("+++", people.get(0));
-        ReviewBean review4 = new ReviewBean("---", people.get(1));
-
-        books.get(0).addReview(review1).addReview(review2).addReview(review3).addReview(review4);
-        books.get(1).addReview(review1).addReview(review2).addReview(review3).addReview(review4);
-        books.get(2).addReview(review1).addReview(review2).addReview(review3).addReview(review4);
-    }
-
-    @Test
-    public void testCXFQueries() throws Exception {
-        // following queries copied from apache cxf
-        Assert.assertFalse(matches(parseQuery("id=gt=100;name=Fred"), null));
-        Assert.assertFalse(matches(parseQuery("id=gt=100;name==Fred"), null));
-        Assert.assertFalse(matches(parseQuery("id=lt=123"), null));
-        Assert.assertFalse(matches(parseQuery("date=le=2010-03-11"), null));
-        Assert.assertFalse(matches(parseQuery("time=le=2010-03-11T18:00:00"), null));
-        Assert.assertFalse(matches(parseQuery("name==CXF;version=ge=2.2"), null));
-        Assert.assertFalse(matches(parseQuery("(age=lt=25,age=gt=35);city==London"), null));
-        Assert.assertFalse(matches(parseQuery("date=lt=2000-01-01;date=gt=1999-01-01;(sub==math,sub==physics)"), null));
-    }
-
-    public Expression parseQuery(String query) throws Exception {
-        p("PARSING query: " + query);
-        // FiqlParser is a parser generated by javacc
-        Expression exp = FiqlParser.parse(query);
-        p(exp.toString());
-        return exp;
-    }
-
-    public int find(String query) throws Exception {
-        int found = 0;
-        Expression exp = parseQuery(query);
-        TypeInfo.createRoot("person", PersonBean.class);
-        for (PersonBean person : people) {
-            if (matches(exp, person)) found++;
-        }
-        return found;
-    }
-
-    @Test
-    public void testPeopleQueries() throws Exception {
-        Assert.assertTrue(find("id==200") == 1);
-        Assert.assertTrue(find("id!=100;(city='San.*')") == 2);
-        Assert.assertTrue(find("id>200;(city='San.*')") == 1);
-        Assert.assertTrue(find("city='San.*'") == 3);
-    }
-
-    @Test
-    public void testTypeTree() throws Exception {
-        TypeInfo bookType = TypeInfo.createRoot("book", BookBean.class);
-        Assert.assertEquals("John", bookType.retrieve(books.get(0),
-                "book.author.firstName".split("\\."), 1));
-        Object result = bookType.retrieve(books.get(0),
-                "book.reviews.review.comment".split("\\."), 1);
-        Assert.assertTrue( result instanceof List);
-        List<Object> commentList = (List<Object>) result;
-        Assert.assertTrue(commentList.contains("cool"));
-    }
-
-    @Test
-    public void testQueryAPI() throws Exception {
-        QueryContext qc = new QueryContextImpl();
-
-        // find all books written by author with firstName "John"
-        Query q1 = qc.createQuery("book.author.firstName==John", BookBean.class);
-        Collection<BookBean> r1 = q1.find(books);
-        p("Filtered books: " + r1.size());
-        Assert.assertEquals(1, r1.size());
-
-        // find all books reviewed by people in a city "San*"
-        Query q2 = qc.createQuery("book.reviews.review.reviewer.city=San.*", BookBean.class);
-        Collection<BookBean> r2 = q2.find(books);
-
-        p("Filtered books: " + r2.size());
-        Assert.assertEquals(3, r2.size());
-
-        // find all books reviewed by people in a city "San*"
-        Query q3 = qc.createQuery("book==foo", BookBean.class);
-        Collection<BookBean> r3 = q3.find(books);
-        Assert.assertEquals(0, r3.size());
-    }
-
-    @Test
-    public void testFilter() throws Exception {
-        Library library = new Library((List)books.clone());
-        QueryContext qc = new QueryContextImpl();
-        // find all books written by author with firstName "John"
-        Query q1 = qc.createQuery("book.author.firstName==John", Library.class);
-        int sizeBefore = library.getList().size();
-        System.out.println(q1.filter(library, BookBean.class));
-        Assert.assertEquals(1, library.getList().size());
-    }
-}
diff --git a/opendaylight/adsal/northbound/commons/src/test/java/org/opendaylight/controller/northbound/commons/query/Library.java b/opendaylight/adsal/northbound/commons/src/test/java/org/opendaylight/controller/northbound/commons/query/Library.java
deleted file mode 100644 (file)
index c54b0e7..0000000
+++ /dev/null
@@ -1,29 +0,0 @@
-/**
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.northbound.commons.query;
-
-import java.util.List;
-
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-@XmlRootElement(name="library")
-public class Library {
-
-    @XmlElement(name="book")
-    private final List<BookBean> _list;
-
-    public Library(List<BookBean> list) {
-        _list = list;
-    }
-
-    public List<BookBean> getList() {
-        return _list;
-    }
-
-}
diff --git a/opendaylight/adsal/northbound/commons/src/test/java/org/opendaylight/controller/northbound/commons/query/PersonBean.java b/opendaylight/adsal/northbound/commons/src/test/java/org/opendaylight/controller/northbound/commons/query/PersonBean.java
deleted file mode 100644 (file)
index b4b9ed5..0000000
+++ /dev/null
@@ -1,50 +0,0 @@
-/**
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.northbound.commons.query;
-
-import java.util.List;
-
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlElementWrapper;
-import javax.xml.bind.annotation.XmlRootElement;
-
-@XmlRootElement(name="person")
-
-public class PersonBean {
-
-    @XmlElement
-    public String firstName;
-    @XmlElement
-    public String lastName;
-    @XmlElement
-    public String city;
-    @XmlElement
-    public int id;
-
-    @XmlElementWrapper(name="emails") // ElementWrapper iteratable type
-    @XmlElement
-    public List<String> email;
-
-    public PersonBean(){}
-    public PersonBean(int n, String f, String l, String c) {
-        firstName = f;
-        lastName = l;
-        city = c;
-        id = n;
-    }
-
-    public void setEmail(List<String> emails){
-        email = emails;
-    }
-    @Override
-    public String toString() {
-        return "PersonBean [firstName=" + firstName + ", lastName=" + lastName
-                + ", city=" + city + ", id=" + id + "]";
-    }
-
-}
diff --git a/opendaylight/adsal/northbound/commons/src/test/java/org/opendaylight/controller/northbound/commons/query/QueryContextTest.java b/opendaylight/adsal/northbound/commons/src/test/java/org/opendaylight/controller/northbound/commons/query/QueryContextTest.java
deleted file mode 100644 (file)
index b6e582b..0000000
+++ /dev/null
@@ -1,269 +0,0 @@
-/**
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.northbound.commons.query;
-
-import java.io.ByteArrayOutputStream;
-import java.util.ArrayList;
-import java.util.List;
-
-import javax.xml.bind.JAXBContext;
-import javax.xml.bind.Marshaller;
-
-import org.junit.Assert;
-import org.junit.BeforeClass;
-import org.junit.Test;
-import org.opendaylight.controller.northbound.commons.types.StringList;
-
-public class QueryContextTest {
-
-    protected static final List<PersonBean> people = new ArrayList<PersonBean>();
-    protected static final List<BookBean> books = new ArrayList<BookBean>();
-
-    public static void p(String msg) {
-        System.out.println("=== " + msg);
-    }
-
-    @BeforeClass
-    public static void load() {
-        people.add(new PersonBean(100, "John", "Doe", "San Jose"));
-        people.add(new PersonBean(200, "Foo", "Bar", "San Francisco"));
-        people.add(new PersonBean(300, "A", "B", "San Francisco"));
-        people.add(new PersonBean(400, "X", "Y", "New York"));
-
-        books.add(new BookBean("Book1", "A001", people.get(0)));
-        books.add(new BookBean("Book2", "A002", people.get(1)));
-        books.add(new BookBean("Book3", "A003", people.get(2)));
-
-        ReviewBean review1 = new ReviewBean("cool", people.get(2));
-        ReviewBean review2 = new ReviewBean("kewl", people.get(3));
-
-        books.get(0).addReview(review1).addReview(review2);
-        books.get(1).addReview(review1);
-        books.get(2).addReview(review2).addReview(review1);
-
-    }
-
-    @Test
-    public void testQueryContext() {
-        QueryContext queryContext = new QueryContextImpl();
-        Assert.assertNotNull(queryContext);
-    }
-
-    @Test
-    public void testSimpleQuery() throws QueryException {
-        QueryContext queryContext = new QueryContextImpl();
-        Query<PersonBean> query = queryContext.createQuery(
-                "person.id==200", PersonBean.class);
-        Assert.assertNotNull(query);
-
-        List<PersonBean> found = query.find(people);
-        Assert.assertNotNull(found);
-        Assert.assertTrue(found.size() == 1);
-        Assert.assertEquals("Foo", found.get(0).firstName);
-    }
-
-    @Test
-    public void testAndQuery() throws QueryException {
-        QueryContext queryContext = new QueryContextImpl();
-        Query<PersonBean> query = queryContext.createQuery(
-                "person.id!=200;(person.city='San.*')", PersonBean.class);
-        Assert.assertNotNull(query);
-
-        List<PersonBean> found = query.find(people);
-        Assert.assertNotNull(found);
-        Assert.assertTrue(found.size() == 2);
-        Assert.assertEquals("John", found.get(0).firstName);
-        Assert.assertEquals("A", found.get(1).firstName);
-    }
-
-    @Test
-    public void testOrQuery() throws QueryException {
-        QueryContext queryContext = new QueryContextImpl();
-        Query<PersonBean> query = queryContext.createQuery(
-                "person.id==200,(person.city='San.*')", PersonBean.class);
-        Assert.assertNotNull(query);
-
-        List<PersonBean> found = query.find(people);
-        Assert.assertNotNull(found);
-        Assert.assertTrue(found.size() == 3);
-        Assert.assertEquals("John", found.get(0).firstName);
-        Assert.assertEquals("Foo", found.get(1).firstName);
-        Assert.assertEquals("A", found.get(2).firstName);
-    }
-
-    @Test
-    public void testXmlElementWrapper() throws QueryException {
-        List<String> emails = new ArrayList<String>();
-        emails.add("john@cisco.com");
-        emails.add("john@gmail.com");
-        people.get(0).setEmail(emails);
-
-        p(toXml(people.get(0)));
-        QueryContext queryContext = new QueryContextImpl();
-        Query<PersonBean> query = queryContext.createQuery(
-                "person.emails.email==john@cisco.com", PersonBean.class);
-        Assert.assertNotNull(query);
-
-        List<PersonBean> found = query.find(people);
-        Assert.assertNotNull(found);
-        Assert.assertEquals(1,found.size());
-        Assert.assertEquals("John", found.get(0).firstName);
-    }
-
-    @Test
-    public void testXmlWrapperOfWrapper() throws QueryException{
-        WrapperList wrapper = new WrapperList();
-        wrapper.item.add("Test1");
-        wrapper.item.add("Test2");
-
-        books.get(0).addWrapperList(wrapper);
-        books.get(1).addWrapperList(wrapper);
-
-        System.out.println(toXml(books.get(0)));
-        QueryContext queryContext = new QueryContextImpl();
-        Query<BookBean> query = queryContext.createQuery(
-                "book.parent.child.items.item==Test1", BookBean.class);
-        Assert.assertNotNull(query);
-    }
-
-    @Test
-    public void testXmlElementWrapperListofList() throws QueryException {
-        // create Stringlist
-        List<String> testList = new ArrayList<String>();
-        testList.add("A");
-        testList.add("B");
-        StringList itemList = new StringList(testList);
-        books.get(0).addToTestList(itemList);
-
-        System.out.println(toXml(books.get(0)));
-        QueryContext queryContext = new QueryContextImpl();
-        Query<BookBean> query = queryContext.createQuery(
-                "book.test.testList.item==A", BookBean.class);
-        Assert.assertNotNull(query);
-    }
-
-    @Test
-    public void testPrimitiveIteratableTypes() throws QueryException {
-        // Load data for this test
-        List<String> sellers = new ArrayList<String>();
-        sellers.add("Amazon");
-
-        books.get(0).setSellerInfo(sellers);
-        sellers.add("Barners & Nobles");
-        books.get(1).setSellerInfo(sellers);
-        sellers.add("Borders");
-        sellers.remove("Amazon");
-        sellers.add("BookShop");
-        books.get(2).setSellerInfo(sellers);
-
-        System.out.println(toXml(books.get(0)));
-
-        QueryContext queryContext = new QueryContextImpl();
-        Query<BookBean> query = queryContext.createQuery(
-                "book.soldBy==Amazon", BookBean.class);
-        Assert.assertNotNull(query);
-
-        List<BookBean> found = query.find(books);
-        Assert.assertNotNull(found);
-        Assert.assertEquals(2,found.size());
-        Assert.assertEquals("John", found.get(0).getauthor().firstName);
-
-        query = queryContext.createQuery(
-                "book.soldBy!=Amazon", BookBean.class);
-        Assert.assertNotNull(query);
-
-        found = query.find(books);
-        System.out.println("books" +found);
-        Assert.assertNotNull(found);
-        Assert.assertEquals(1,found.size());
-        Assert.assertEquals("A", found.get(0).getauthor().firstName);
-    }
-
-    @Test
-    public void testCompositeIteratableTypes() throws QueryException {
-        QueryContext queryContext = new QueryContextImpl();
-        Query<BookBean> query = queryContext.createQuery("book.reviews.review.reviewer.firstName==X",
-                BookBean.class);
-        Assert.assertNotNull(query);
-
-        List<BookBean> found = query.find(books);
-        Assert.assertNotNull(found);
-        Assert.assertEquals(2, found.size());
-        Assert.assertEquals("John", found.get(0).getauthor().firstName);
-
-        query = queryContext.createQuery("book.reviews.review.comment==kewl",
-                BookBean.class);
-        Assert.assertNotNull(query);
-
-        found = query.find(books);
-        Assert.assertNotNull(found);
-        Assert.assertEquals(2, found.size());
-        p("Book 0" + found.get(0));
-        Assert.assertEquals("John", found.get(0).getauthor().firstName);
-
-        query = queryContext.createQuery("book.reviews.review.reviewer.id>300",
-                BookBean.class);
-        Assert.assertNotNull(query);
-
-        found = query.find(books);
-        Assert.assertNotNull(found);
-        Assert.assertEquals(2, found.size());
-        p("Book 0" + found.get(0));
-        Assert.assertEquals("John", found.get(0).getauthor().firstName);
-
-        query = queryContext.createQuery("book.reviews.review.reviewer.firstName!=X",
-                BookBean.class);
-        Assert.assertNotNull(query);
-
-        found = query.find(books);
-        Assert.assertNotNull(found);
-        Assert.assertEquals(1, found.size());
-        p("Book 0" + found.get(0));
-        Assert.assertEquals("Foo", found.get(0).getauthor().firstName);
-    }
-
-    @Test
-    public void testXMLAccessorType() {
-        //Assert.fail("implement");
-    }
-
-    @Test
-    public void testMethodAnnotation() throws QueryException {
-        System.out.println(toXml(books.get(0)));
-        QueryContext queryContext = new QueryContextImpl();
-        Query<BookBean> query = queryContext.createQuery(
-                "book.isbn==preA003", BookBean.class);
-        Assert.assertNotNull(query);
-
-        List<BookBean> found = query.find(books);
-        Assert.assertNotNull(found);
-        Assert.assertEquals(1,found.size());
-        Assert.assertEquals("A", found.get(0).getauthor().firstName);
-    }
-
-    public static String toXml(Object element) {
-        try {
-            JAXBContext jc = JAXBContext.newInstance(element.getClass());
-            Marshaller marshaller = jc.createMarshaller();
-            marshaller.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT, Boolean.TRUE);
-
-            ByteArrayOutputStream baos = new ByteArrayOutputStream();
-            marshaller.marshal(element, baos);
-            return baos.toString();
-        } catch (Exception e) {
-            e.printStackTrace();
-        }
-        return "";
-    }
-
-    @Test
-    public void testXMLElementWrapperForCompositeTypes(){
-        //Assert.fail("implement");
-    }
-
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/northbound/commons/src/test/java/org/opendaylight/controller/northbound/commons/query/ReviewBean.java b/opendaylight/adsal/northbound/commons/src/test/java/org/opendaylight/controller/northbound/commons/query/ReviewBean.java
deleted file mode 100644 (file)
index ea2f873..0000000
+++ /dev/null
@@ -1,41 +0,0 @@
-package org.opendaylight.controller.northbound.commons.query;
-
-import java.util.Date;
-
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-/**
- */
-@XmlRootElement(name="review")
-public class ReviewBean {
-    @XmlElement(name="date")
-    private  Date _publishedDate;
-    @XmlElement(name="comment")
-    private  String _comment;
-    @XmlElement(name="reviewer")
-    private  PersonBean _reviewer;
-    @XmlElement
-    private int _upVotes;
-    @XmlElement
-    private int _downVotes;
-    public ReviewBean(){}
-
-    public ReviewBean(String comment, PersonBean user) {
-        _comment = comment;
-        _reviewer = user;
-        _publishedDate = new Date();
-    }
-
-    public void vote(int up, int down) {
-        _upVotes += up;
-        _downVotes += down;
-    }
-
-    @Override
-    public String toString() {
-        return "ReviewBean <publishedDate>" + _publishedDate + "</publishedDate> <comment>"
-                + _comment + "</comment> <reviewer>" + _reviewer + "</reviewer> <upVotes>" + _upVotes
-                + "</upVotes> <downVotes>" + _downVotes + "</downVotes>";
-    }
-}
diff --git a/opendaylight/adsal/northbound/commons/src/test/java/org/opendaylight/controller/northbound/commons/query/XMLAccessorTypeTest.java b/opendaylight/adsal/northbound/commons/src/test/java/org/opendaylight/controller/northbound/commons/query/XMLAccessorTypeTest.java
deleted file mode 100644 (file)
index 25cb692..0000000
+++ /dev/null
@@ -1,374 +0,0 @@
-package org.opendaylight.controller.northbound.commons.query;
-
-import java.util.ArrayList;
-import java.util.List;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-import javax.xml.bind.annotation.XmlTransient;
-
-import org.junit.Assert;
-import org.junit.Test;
-
-public class XMLAccessorTypeTest {
-
-    @Test
-    public void testPublicAccessType() throws Exception {
-        // create bean
-        List<PublicAccessBean> testList = new ArrayList<PublicAccessBean>();
-        testList.add(new PublicAccessBean("John", "Scott", "private", 1,
-                "transient", "elem1"));
-        testList.add(new PublicAccessBean("Foo", "Bar", "private1", 2,
-                "transient1", "elem2"));
-        QueryContextTest.p(QueryContextTest.toXml(testList.get(0)));
-
-        QueryContext queryContext = new QueryContextImpl();
-        Assert.assertNotNull(queryContext);
-        // search for public field
-        Query<PublicAccessBean> query = queryContext.createQuery(
-                "publicbean.firstName==Foo", PublicAccessBean.class);
-        Assert.assertNotNull(query);
-
-        List<PublicAccessBean> found = query.find(testList);
-        Assert.assertNotNull(found);
-        Assert.assertEquals(1, found.size());
-        Assert.assertEquals("Foo", found.get(0).firstName);
-
-        // search for public getter
-        query = queryContext.createQuery("publicbean.privateGetterField<2",
-                PublicAccessBean.class);
-        Assert.assertNotNull(query);
-
-        found = query.find(testList);
-        Assert.assertNotNull(found);
-        Assert.assertEquals(1, found.size());
-        Assert.assertEquals("John", found.get(0).firstName);
-
-        // test for transient field
-        query = queryContext.createQuery("publicbean.transientField='trans*'",
-                PublicAccessBean.class);
-        Assert.assertNotNull(query);
-
-        found = query.find(testList);
-        Assert.assertNotNull(found);
-        Assert.assertEquals(0, found.size());
-
-        // test for private field
-        query = queryContext.createQuery("publicbean.privateField==private",
-                PublicAccessBean.class);
-        Assert.assertNotNull(query);
-
-        found = query.find(testList);
-        Assert.assertNotNull(found);
-        Assert.assertEquals(0, found.size());
-
-        // test for XML Element
-        query = queryContext.createQuery("publicbean.element==elem1",
-                PublicAccessBean.class);
-        Assert.assertNotNull(query);
-
-        found = query.find(testList);
-        Assert.assertNotNull(found);
-        Assert.assertEquals(1, found.size());
-        Assert.assertEquals("John", found.get(0).firstName);
-    }
-
-    @Test
-    public void testFieldAccessType() throws QueryException {
-        // create bean
-        List<FieldAccessBean> testList = new ArrayList<FieldAccessBean>();
-        testList.add(new FieldAccessBean("John", "Scott", "private", 1, "elem1"));
-        testList.add(new FieldAccessBean("Foo", "Bar", "private1", 2, "elem2"));
-
-        QueryContextTest.p(QueryContextTest.toXml(testList.get(0)));
-        QueryContext queryContext = new QueryContextImpl();
-        Assert.assertNotNull(queryContext);
-        // test private field
-        Query<FieldAccessBean> query = queryContext.createQuery(
-                "field.privateField==private", FieldAccessBean.class);
-        Assert.assertNotNull(query);
-
-        List<FieldAccessBean> found = query.find(testList);
-        Assert.assertNotNull(found);
-        Assert.assertEquals(1, found.size());
-        Assert.assertEquals("John", found.get(0).firstName);
-
-        // test public field
-        query = queryContext.createQuery("field.firstName==Foo",
-                FieldAccessBean.class);
-        Assert.assertNotNull(query);
-
-        found = query.find(testList);
-        Assert.assertNotNull(found);
-        Assert.assertEquals(1, found.size());
-        Assert.assertEquals("Foo", found.get(0).firstName);
-
-        // test annotated field
-        query = queryContext.createQuery("field.element==elem2",
-                FieldAccessBean.class);
-        Assert.assertNotNull(query);
-
-        found = query.find(testList);
-        Assert.assertNotNull(found);
-        Assert.assertEquals(1, found.size());
-        Assert.assertEquals("Foo", found.get(0).firstName);
-
-        // test annotated method
-        query = queryContext.createQuery("field.privateGetterField==11",
-                FieldAccessBean.class);
-        Assert.assertNotNull(query);
-
-        found = query.find(testList);
-        Assert.assertNotNull(found);
-        Assert.assertEquals(1, found.size());
-        Assert.assertEquals("John", found.get(0).firstName);
-    }
-
-    @Test
-    public void testPropertyAccessType() throws QueryException {
-        // create bean
-        List<PropertyAccessBean> testList = new ArrayList<PropertyAccessBean>();
-        testList.add(new PropertyAccessBean("John", "Scott", "private", 1, "elem1",
-                "transient1"));
-        testList.add(new PropertyAccessBean("Foo", "Bar", "private1", 2, "elem2",
-                "transient2"));
-
-        QueryContextTest.p(QueryContextTest.toXml(testList.get(0)));
-        QueryContext queryContext = new QueryContextImpl();
-        Assert.assertNotNull(queryContext);
-        // test public getter public field
-        Query<PropertyAccessBean> query = queryContext.createQuery(
-                "property.firstName==John", PropertyAccessBean.class);
-        Assert.assertNotNull(query);
-
-        List<PropertyAccessBean> found = query.find(testList);
-        Assert.assertNotNull(found);
-        Assert.assertEquals(1, found.size());
-        Assert.assertEquals("John", found.get(0).firstName);
-
-        // test public field no getter
-        query = queryContext.createQuery("property.lastName==Bar",
-                PropertyAccessBean.class);
-        Assert.assertNotNull(query);
-
-        found = query.find(testList);
-        Assert.assertNotNull(found);
-        Assert.assertEquals(0, found.size());
-
-        // test annotated field
-        query = queryContext.createQuery("property.element==elem2",
-                PropertyAccessBean.class);
-        Assert.assertNotNull(query);
-
-        found = query.find(testList);
-        Assert.assertNotNull(found);
-        Assert.assertEquals(1, found.size());
-        Assert.assertEquals("Foo", found.get(0).firstName);
-
-        // test annotated method
-        query = queryContext.createQuery("property.field==private",
-                PropertyAccessBean.class);
-        Assert.assertNotNull(query);
-
-        found = query.find(testList);
-        Assert.assertNotNull(found);
-        Assert.assertEquals(1, found.size());
-        Assert.assertEquals("John", found.get(0).firstName);
-
-        // test transient method
-        query = queryContext.createQuery("property.transientField==transient1",
-                PropertyAccessBean.class);
-        Assert.assertNotNull(query);
-
-        found = query.find(testList);
-        Assert.assertNotNull(found);
-        Assert.assertEquals(0, found.size());
-    }
-
-    @Test
-    public void testNoneAccessType() throws QueryException {
-        // create bean
-        List<NoneAccessBean> testList = new ArrayList<NoneAccessBean>();
-        testList.add(new NoneAccessBean("John", "Scott", "private"));
-        testList.add(new NoneAccessBean("Foo", "Bar", "private1"));
-
-        QueryContextTest.p(QueryContextTest.toXml(testList.get(0)));
-        QueryContext queryContext = new QueryContextImpl();
-        Assert.assertNotNull(queryContext);
-        // test annotated field
-        Query<NoneAccessBean> query = queryContext.createQuery(
-                "test.firstName==John", NoneAccessBean.class);
-        Assert.assertNotNull(query);
-
-        List<NoneAccessBean> found = query.find(testList);
-        Assert.assertNotNull(found);
-        Assert.assertEquals(1, found.size());
-        Assert.assertEquals("John", found.get(0).getFirstName());
-        // test unannotated field
-        query = queryContext
-                .createQuery("test.lastName==Bar", NoneAccessBean.class);
-        Assert.assertNotNull(query);
-
-        found = query.find(testList);
-        Assert.assertNotNull(found);
-        Assert.assertEquals(0, found.size());
-        // test annotated method
-        query = queryContext.createQuery("test.testField==private",
-                NoneAccessBean.class);
-        Assert.assertNotNull(query);
-
-        found = query.find(testList);
-        Assert.assertNotNull(found);
-        Assert.assertEquals(1, found.size());
-        Assert.assertEquals("John", found.get(0).getFirstName());
-
-    }
-
-}
-
-// default ( public memeber )
-@XmlAccessorType(XmlAccessType.PUBLIC_MEMBER)
-@XmlRootElement(name = "publicbean")
-class PublicAccessBean {
-
-  public String firstName;
-  public String lastName;
-  private String privateField;
-  private int privateGetterField;
-  @XmlTransient
-  public String transientField;
-  @XmlElement(name = "element")
-  private String xmlElem;
-
-  public PublicAccessBean() {
-  }
-
-  public PublicAccessBean(String firstName, String lastName,
-      String privateField, int privateGetterField, String transientField,
-      String xmlElem) {
-    this.firstName = firstName;
-    this.lastName = lastName;
-    this.privateField = privateField;
-    this.privateGetterField = privateGetterField;
-    this.transientField = transientField;
-    this.xmlElem = xmlElem;
-  }
-
-  public int getPrivateGetterField() {
-    return privateGetterField;
-  }
-
-  public void setPrivateGetterField(int field) {
-    this.privateGetterField = field;
-  }
-}
-
-// default ( public memeber )
-@XmlAccessorType(XmlAccessType.FIELD)
-@XmlRootElement(name = "field")
-class FieldAccessBean {
-
-  public String firstName;
-  public String lastName;
-  private String privateField;
-  private int test;
-  @XmlElement(name = "element")
-  private String xmlElem;
-
-  public FieldAccessBean() {
-  }
-
-  public FieldAccessBean(String firstName, String lastName,
-      String privateField, int privateGetterField, String xmlElem) {
-    this.firstName = firstName;
-    this.lastName = lastName;
-    this.privateField = privateField;
-    this.xmlElem = xmlElem;
-    this.test = privateGetterField;
-  }
-
-  public String getPrivateField() {
-    return privateField;
-  }
-
-  @XmlElement(name = "privateGetterField")
-  public int getPrivateGetterField() {
-    return test + 10;
-  }
-}
-
-// default ( public memeber )
-@XmlAccessorType(XmlAccessType.PROPERTY)
-@XmlRootElement(name = "property")
-class PropertyAccessBean {
-
-  public String firstName;
-  public String lastName;
-  private String privateField;
-  private int privateGetterField;
-  @XmlElement(name = "element")
-  private String xmlElem;
-  private String transientField;
-
-  public PropertyAccessBean() {
-  }
-
-  public PropertyAccessBean(String firstName, String lastName,
-      String privateField, int privateGetterField, String xmlElem,
-      String transientField) {
-    this.firstName = firstName;
-    this.lastName = lastName;
-    this.privateField = privateField;
-    this.privateGetterField = privateGetterField;
-    this.xmlElem = xmlElem;
-    this.transientField = transientField;
-  }
-
-  public int getPrivateGetterField() {
-    return privateGetterField;
-  }
-
-  @XmlElement(name = "field")
-  public String getPrivateField() {
-    return privateField;
-  }
-
-  public String getFirstName() {
-    return firstName;
-  }
-
-  @XmlTransient
-  public String getTransientField() {
-    return transientField;
-  }
-}
-
-// default ( public memeber )
-@XmlAccessorType(XmlAccessType.NONE)
-@XmlRootElement(name = "test")
-class NoneAccessBean {
-  @XmlElement
-  private String firstName;
-  public String lastName;
-  private String testField;
-
-  public NoneAccessBean() {
-  }
-
-  public NoneAccessBean(String firstName, String lastName, String testField) {
-    this.firstName = firstName;
-    this.lastName = lastName;
-    this.testField = testField;
-  }
-
-  @XmlElement(name = "testField")
-  public String getTestField() {
-    return testField;
-  }
-
-  public String getFirstName() {
-    return firstName;
-  }
-}
diff --git a/opendaylight/adsal/northbound/commons/src/test/resources/logback.xml b/opendaylight/adsal/northbound/commons/src/test/resources/logback.xml
deleted file mode 100644 (file)
index 97e15de..0000000
+++ /dev/null
@@ -1,16 +0,0 @@
-<configuration scan="true">
-
-  <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
-    <encoder>
-      <pattern>%d{HH:mm:ss.SSS} %-5level %logger{36} - %msg%n
-      </pattern>
-    </encoder>
-  </appender>
-
-
-  <logger name="org.opendaylight.controller.northbound.commons.query" level="INFO"/>
-
-  <root level="error">
-    <appender-ref ref="STDOUT" />
-  </root>
-</configuration>
diff --git a/opendaylight/adsal/northbound/connectionmanager/enunciate.xml b/opendaylight/adsal/northbound/connectionmanager/enunciate.xml
deleted file mode 100644 (file)
index cb21d7c..0000000
+++ /dev/null
@@ -1,12 +0,0 @@
-<?xml version="1.0"?>
-<enunciate label="full" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
-    xsi:noNamespaceSchemaLocation="http://enunciate.codehaus.org/schemas/enunciate-1.28.xsd">
-
-  <services>
-    <rest defaultRestSubcontext="/controller/nb/v2/connectionmanager"/>
-  </services>
-
-  <modules>
-    <docs docsDir="rest" title="Connection Manager REST API" includeExampleXml="true" includeExampleJson="true"/>
-  </modules>
-</enunciate>
diff --git a/opendaylight/adsal/northbound/connectionmanager/pom.xml b/opendaylight/adsal/northbound/connectionmanager/pom.xml
deleted file mode 100644 (file)
index e1789bd..0000000
+++ /dev/null
@@ -1,86 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>adsal-enunciate-parent</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../adsal-enunciate-parent</relativePath>
-  </parent>
-
-  <artifactId>connectionmanager.northbound</artifactId>
-  <version>0.3.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>org.codehaus.enunciate</groupId>
-      <artifactId>enunciate-core-annotations</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>commons.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>connectionmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>containermanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal.connection</artifactId>
-    </dependency>
-  </dependencies>
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Export-Package></Export-Package>
-            <Import-Package>org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.sal.utils,
-              org.opendaylight.controller.containermanager,
-              org.opendaylight.controller.usermanager,
-              com.sun.jersey.spi.container.servlet,
-              org.opendaylight.controller.northbound.commons,
-              org.opendaylight.controller.northbound.commons.exception,
-              org.opendaylight.controller.northbound.commons.utils,
-              org.opendaylight.controller.northbound.commons.query,
-              org.opendaylight.controller.sal.authorization,
-              org.opendaylight.controller.connectionmanager,
-              org.opendaylight.controller.sal.connection,
-              org.slf4j,
-              javax.ws.rs,
-              javax.ws.rs.ext,
-              javax.ws.rs.core,
-              javax.xml.bind.annotation,
-              javax.xml.bind,
-              org.apache.catalina.filters,
-              com.fasterxml.jackson.jaxrs.base,
-              com.fasterxml.jackson.jaxrs.json,
-              !org.codehaus.enunciate.jaxrs</Import-Package>
-            <Export-Package></Export-Package>
-            <Web-ContextPath>/controller/nb/v2/connectionmanager</Web-ContextPath>
-            <Jaxrs-Resources>,${classes;ANNOTATION;javax.ws.rs.Path}</Jaxrs-Resources>
-          </instructions>
-          <manifestLocation>${project.basedir}/src/main/resources/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/northbound/connectionmanager/src/main/java/org/opendaylight/controller/connectionmanager/northbound/ConnectionManagerNorthbound.java b/opendaylight/adsal/northbound/connectionmanager/src/main/java/org/opendaylight/controller/connectionmanager/northbound/ConnectionManagerNorthbound.java
deleted file mode 100644 (file)
index 3f64b07..0000000
+++ /dev/null
@@ -1,364 +0,0 @@
-
-/*
- * Copyright (c) 2013 Red Hat, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.connectionmanager.northbound;
-
-import java.net.InetAddress;
-import java.net.UnknownHostException;
-import java.util.HashMap;
-import java.util.Map;
-import java.util.Set;
-
-import javax.ws.rs.DELETE;
-import javax.ws.rs.DefaultValue;
-import javax.ws.rs.GET;
-import javax.ws.rs.PUT;
-import javax.ws.rs.Path;
-import javax.ws.rs.PathParam;
-import javax.ws.rs.Produces;
-import javax.ws.rs.QueryParam;
-import javax.ws.rs.core.Context;
-import javax.ws.rs.core.MediaType;
-import javax.ws.rs.core.Response;
-import javax.ws.rs.core.SecurityContext;
-import javax.ws.rs.ext.ContextResolver;
-
-import org.codehaus.enunciate.jaxrs.ResponseCode;
-import org.codehaus.enunciate.jaxrs.StatusCodes;
-import org.codehaus.enunciate.jaxrs.TypeHint;
-import org.opendaylight.controller.connectionmanager.IConnectionManager;
-import org.opendaylight.controller.northbound.commons.exception.NotAcceptableException;
-import org.opendaylight.controller.northbound.commons.exception.ResourceNotFoundException;
-import org.opendaylight.controller.northbound.commons.exception.ServiceUnavailableException;
-import org.opendaylight.controller.northbound.commons.exception.UnauthorizedException;
-import org.opendaylight.controller.northbound.commons.query.QueryContext;
-import org.opendaylight.controller.northbound.commons.utils.NorthboundUtils;
-import org.opendaylight.controller.sal.authorization.Privilege;
-import org.opendaylight.controller.sal.connection.ConnectionConstants;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.utils.NetUtils;
-import org.opendaylight.controller.sal.utils.ServiceHelper;
-import org.opendaylight.controller.sal.utils.Status;
-
-/**
- * Connection Manager Northbound APIs
- */
-@Path("/")
-public class ConnectionManagerNorthbound {
-    private String username;
-    private QueryContext queryContext;
-
-    @Context
-    public void setQueryContext(ContextResolver<QueryContext> queryCtxResolver) {
-      if (queryCtxResolver != null) {
-        queryContext = queryCtxResolver.getContext(QueryContext.class);
-      }
-    }
-    @Context
-    public void setSecurityContext(SecurityContext context) {
-        if (context != null && context.getUserPrincipal() != null) {
-            username = context.getUserPrincipal().getName();
-        }
-    }
-    protected String getUserName() {
-        return username;
-    }
-
-    private IConnectionManager getConnectionManager() {
-        return (IConnectionManager) ServiceHelper
-                .getGlobalInstance(IConnectionManager.class, this);
-    }
-
-    /**
-     *
-     * Retrieve a list of all the nodes connected to a given controller in the cluster.
-     *
-     * @param controllerAddress Optional parameter to retrieve the nodes connected to another
-     *        controller in the cluster
-     * @return A list of Nodes {@link org.opendaylight.controller.sal.core.Node}
-     *
-     * <pre>
-     *
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/connectionmanager/nodes?controller=1.1.1.1
-     *
-     * Response body in XML:
-     *  &lt;list&gt;
-     *       &lt;node&gt;
-     *           &lt;id&gt;00:00:00:00:00:00:00:52&lt;/id&gt;
-     *           &lt;type&gt;OF&lt;/type&gt;
-     *       &lt;/node&gt;
-     *       &lt;node&gt;
-     *           &lt;id&gt;00:00:00:00:00:00:00:3e&lt;/id&gt;
-     *           &lt;type&gt;OF&lt;/type&gt;
-     *       &lt;/node&gt;
-     *   &lt;/list&gt;
-     *
-     *  Response body in JSON:
-     *  {
-     *       "node": [
-     *           {
-     *               "type": "OF",
-     *               "id": "00:00:00:00:00:00:00:52"
-     *           },
-     *           {
-     *               "type": "OF",
-     *               "id": "00:00:00:00:00:00:00:3e"
-     *           }
-     *       ]
-     *   }
-     * </pre>
-     */
-    @Path("/nodes")
-    @GET
-    @Produces({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @TypeHint(Nodes.class)
-    @StatusCodes( {
-        @ResponseCode(code = 401, condition = "User not authorized to perform this operation"),
-        @ResponseCode(code = 406, condition = "Invalid Controller IP Address passed."),
-        @ResponseCode(code = 503, condition = "Connection Manager Service not available")})
-
-    public Nodes getNodes(@DefaultValue("") @QueryParam("controller") String controllerAddress,
-        @QueryParam("_q") String queryString) {
-        if (!NorthboundUtils.isAuthorized(getUserName(), "default", Privilege.READ, this)) {
-            throw new UnauthorizedException("User is not authorized to perform this operation on container");
-        }
-
-        IConnectionManager connectionManager = getConnectionManager();
-        if (connectionManager == null) {
-            throw new ServiceUnavailableException("IConnectionManager not available.");
-        }
-
-        if ((controllerAddress != null) && (controllerAddress.trim().length() > 0) &&
-            !NetUtils.isIPv4AddressValid(controllerAddress)) {
-            throw new NotAcceptableException("Invalid ip address "+controllerAddress);
-        }
-        Set<Node> nodeSet = null;
-
-        if (controllerAddress != null) {
-            try {
-                nodeSet = connectionManager.getNodes(InetAddress.getByName(controllerAddress));
-            } catch (UnknownHostException e) {
-                throw new NotAcceptableException("Invalid ip address "+controllerAddress);
-            }
-        } else {
-            nodeSet = connectionManager.getLocalNodes();
-        }
-        Nodes nodes = new Nodes(nodeSet);
-        if (queryString != null) {
-            queryContext.createQuery(queryString, Nodes.class)
-                .filter(nodes, Node.class);
-        }
-        return nodes;
-    }
-
-    /**
-     * If a Network Configuration Service needs a Management Connection and if the
-     * Node Type is unknown, use this REST api to connect to the management session.
-     * <pre>
-     *
-     * Example :
-     *
-     * Request :
-     * PUT http://localhost:8080/controller/nb/v2/connectionmanager/node/mgmt1/address/1.1.1.1/port/6634
-     *
-     * Response :
-     * Node :
-     * xml :
-     * &lt;node&gt;
-     *    &lt;id&gt;mgmt1&lt;/id&gt;
-     *    &lt;type&gt;STUB&lt;/type&gt;
-     * &lt;/node&gt;
-     *
-     * json:
-     * {"id": "mgmt1","type": "STUB"}
-     *
-     *</pre>
-     * @param nodeId User-Defined name of the node to connect with. This can be any alpha numeric value
-     * @param ipAddress IP Address of the Node to connect with.
-     * @param port Layer4 Port of the management session to connect with.
-     * @return Node If the connection is successful, HTTP 404 otherwise.
-     */
-
-    @Path("/node/{nodeId}/address/{ipAddress}/port/{port}/")
-    @PUT
-    @Produces({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @TypeHint(Node.class)
-    @StatusCodes( {
-        @ResponseCode(code = 401, condition = "User not authorized to perform this operation"),
-        @ResponseCode(code = 404, condition = "Could not connect to the Node with the specified parameters"),
-        @ResponseCode(code = 406, condition = "Invalid IP Address or Port parameter passed."),
-        @ResponseCode(code = 503, condition = "Connection Manager Service not available")} )
-    public Node connect(
-            @PathParam(value = "nodeId") String nodeId,
-            @PathParam(value = "ipAddress") String ipAddress,
-            @PathParam(value = "port") String port) {
-
-        if (!NorthboundUtils.isAuthorized(getUserName(), "default", Privilege.WRITE, this)) {
-            throw new UnauthorizedException("User is not authorized to perform this operation on container");
-        }
-
-        IConnectionManager connectionManager = getConnectionManager();
-        if (connectionManager == null) {
-            throw new ServiceUnavailableException("IConnectionManager not available.");
-        }
-
-        if (!NetUtils.isIPv4AddressValid(ipAddress)) {
-            throw new NotAcceptableException("Invalid ip address "+ipAddress);
-        }
-
-        try {
-            Integer.parseInt(port);
-        } catch (Exception e) {
-            throw new NotAcceptableException("Invalid Layer4 Port "+port);
-        }
-
-        Map<ConnectionConstants, String> params = new HashMap<ConnectionConstants, String>();
-        params.put(ConnectionConstants.ADDRESS, ipAddress);
-        params.put(ConnectionConstants.PORT, port);
-
-        Node node = null;
-        try {
-            node = connectionManager.connect(nodeId, params);
-            if (node == null) {
-                throw new ResourceNotFoundException("Failed to connect to Node at "+ipAddress+":"+port);
-            }
-            return node;
-        } catch (Exception e) {
-            throw new ResourceNotFoundException("Failed to connect to Node with Exception "+e.getMessage());
-        }
-    }
-
-    /**
-     * If a Network Configuration Service needs a Management Connection, and if the
-     * node Type is known, the user can choose to use this REST api to connect to the management session.
-     * <pre>
-     *
-     * Example :
-     *
-     * Request :
-     * PUT http://localhost:8080/controller/nb/v2/connectionmanager/node/STUB/mgmt1/address/1.1.1.1/port/6634
-     *
-     * Response : Node :
-     * xml :
-     * &lt;node&gt;
-     *    &lt;id&gt;mgmt1&lt;/id&gt;
-     *    &lt;type&gt;STUB&lt;/type&gt;
-     * &lt;/node&gt;
-     *
-     * json:
-     * {"id": "mgmt1","type": "STUB"}
-     *
-     *</pre>
-     * @param nodeType Type of the Node the connection is made for.
-     * @param nodeId User-Defined name of the node to connect with. This can be any alpha numeric value
-     * @param ipAddress IP Address of the Node to connect with.
-     * @param port Layer4 Port of the management session to connect with.
-     * @return Node If the connection is successful, HTTP 404 otherwise.
-     */
-
-    @Path("/node/{nodeType}/{nodeId}/address/{ipAddress}/port/{port}/")
-    @PUT
-    @Produces({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @TypeHint(Node.class)
-    @StatusCodes( {
-        @ResponseCode(code = 401, condition = "User not authorized to perform this operation"),
-        @ResponseCode(code = 404, condition = "Could not connect to the Node with the specified parameters"),
-        @ResponseCode(code = 406, condition = "Invalid IP Address or Port parameter passed."),
-        @ResponseCode(code = 503, condition = "Connection Manager Service not available")} )
-    public Node connect(
-            @PathParam(value = "nodeType") String nodeType,
-            @PathParam(value = "nodeId") String nodeId,
-            @PathParam(value = "ipAddress") String ipAddress,
-            @PathParam(value = "port") String port) {
-
-        if (!NorthboundUtils.isAuthorized(getUserName(), "default", Privilege.WRITE, this)) {
-            throw new UnauthorizedException("User is not authorized to perform this operation on container");
-        }
-
-        IConnectionManager connectionManager = getConnectionManager();
-        if (connectionManager == null) {
-            throw new ServiceUnavailableException("IConnectionManager not available.");
-        }
-
-        if (!NetUtils.isIPv4AddressValid(ipAddress)) {
-            throw new NotAcceptableException("Invalid ip address "+ipAddress);
-        }
-
-        try {
-            Integer.parseInt(port);
-        } catch (Exception e) {
-            throw new NotAcceptableException("Invalid Layer4 Port "+port);
-        }
-
-        Map<ConnectionConstants, String> params = new HashMap<ConnectionConstants, String>();
-        params.put(ConnectionConstants.ADDRESS, ipAddress);
-        params.put(ConnectionConstants.PORT, port);
-
-        Node node = null;
-        try {
-            node = connectionManager.connect(nodeType, nodeId, params);
-            if (node == null) {
-                throw new ResourceNotFoundException("Failed to connect to Node at "+ipAddress+":"+port);
-            }
-            return node;
-        } catch (Exception e) {
-            throw new ResourceNotFoundException(e.getMessage());
-        }
-    }
-
-    /**
-     * Disconnect an existing Connection.
-     * <pre>
-     *
-     * Example :
-     *
-     * Request :
-     * DELETE http://localhost:8080/controller/nb/v2/connectionmanager/node/STUB/mgmt1
-     *
-     *</pre>
-     * @param nodeType Type of the Node
-     * @param nodeId Connection's NodeId.
-     */
-
-    @Path("/node/{nodeType}/{nodeId}/")
-    @DELETE
-    @Produces({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @TypeHint(Response.class)
-    @StatusCodes( {
-        @ResponseCode(code = 401, condition = "User not authorized to perform this operation"),
-        @ResponseCode(code = 200, condition = "Node disconnected successfully"),
-        @ResponseCode(code = 404, condition = "Could not find a connection with the specified Node identifier"),
-        @ResponseCode(code = 503, condition = "Connection Manager Service not available")} )
-    public Response disconnect(
-            @PathParam(value = "nodeType") String nodeType,
-            @PathParam(value = "nodeId") String nodeId) {
-
-        if (!NorthboundUtils.isAuthorized(getUserName(), "default", Privilege.WRITE, this)) {
-            throw new UnauthorizedException("User is not authorized to perform this operation on container");
-        }
-        IConnectionManager connectionManager = getConnectionManager();
-        if (connectionManager == null) {
-            throw new ServiceUnavailableException("IConnectionManager not available.");
-        }
-
-        try {
-            Node node = Node.fromString(nodeType, nodeId);
-            Status status = connectionManager.disconnect(node);
-            if (status.isSuccess()) {
-                return Response.ok().build();
-            }
-            return NorthboundUtils.getResponse(status);
-        } catch (Exception e) {
-            throw new ResourceNotFoundException(e.getMessage());
-        }
-    }
-}
diff --git a/opendaylight/adsal/northbound/connectionmanager/src/main/java/org/opendaylight/controller/connectionmanager/northbound/Nodes.java b/opendaylight/adsal/northbound/connectionmanager/src/main/java/org/opendaylight/controller/connectionmanager/northbound/Nodes.java
deleted file mode 100644 (file)
index aefd4b2..0000000
+++ /dev/null
@@ -1,40 +0,0 @@
-package org.opendaylight.controller.connectionmanager.northbound;
-/*
- * Copyright (c) 2013 Red Hat, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-import java.util.Set;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.sal.core.Node;
-
-@XmlRootElement(name="list")
-@XmlAccessorType(XmlAccessType.NONE)
-
-public class Nodes {
-    @XmlElement
-    Set<Node> node;
-    //To satisfy JAXB
-    private Nodes() {
-    }
-
-    public Nodes(Set<Node> nodes) {
-        this.node = nodes;
-    }
-
-    public Set<Node> getNode() {
-        return node;
-    }
-
-    public void setNode(Set<Node> nodes) {
-        this.node = nodes;
-    }
-}
diff --git a/opendaylight/adsal/northbound/connectionmanager/src/main/resources/WEB-INF/web.xml b/opendaylight/adsal/northbound/connectionmanager/src/main/resources/WEB-INF/web.xml
deleted file mode 100644 (file)
index f0b23aa..0000000
+++ /dev/null
@@ -1,83 +0,0 @@
-<?xml version="1.0" encoding="ISO-8859-1"?>
-<web-app xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
-        xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
-        version="3.0">
-  <servlet>
-    <servlet-name>ConnectionManager</servlet-name>
-    <servlet-class>com.sun.jersey.spi.container.servlet.ServletContainer</servlet-class>
-    <init-param>
-      <param-name>javax.ws.rs.Application</param-name>
-      <param-value>org.opendaylight.controller.northbound.commons.NorthboundApplication</param-value>
-    </init-param>
-    <load-on-startup>1</load-on-startup>
-  </servlet>
-  <servlet-mapping>
-    <servlet-name>ConnectionManager</servlet-name>
-    <url-pattern>/*</url-pattern>
-  </servlet-mapping>
-  <filter>
-    <filter-name>CorsFilter</filter-name>
-    <filter-class>org.apache.catalina.filters.CorsFilter</filter-class>
-    <init-param>
-      <param-name>cors.allowed.origins</param-name>
-      <param-value>*</param-value>
-    </init-param>
-    <init-param>
-      <param-name>cors.allowed.methods</param-name>
-      <param-value>GET,POST,HEAD,OPTIONS,PUT,DELETE</param-value>
-    </init-param>
-    <init-param>
-      <param-name>cors.allowed.headers</param-name>
-      <param-value>Content-Type,X-Requested-With,accept,authorization, origin,Origin,Access-Control-Request-Method,Access-Control-Request-Headers</param-value>
-    </init-param>
-    <init-param>
-      <param-name>cors.exposed.headers</param-name>
-      <param-value>Access-Control-Allow-Origin,Access-Control-Allow-Credentials</param-value>
-    </init-param>
-    <init-param>
-      <param-name>cors.support.credentials</param-name>
-      <param-value>true</param-value>
-    </init-param>
-    <init-param>
-      <param-name>cors.preflight.maxage</param-name>
-      <param-value>10</param-value>
-    </init-param>
-  </filter>
-  <filter-mapping>
-    <filter-name>CorsFilter</filter-name>
-    <url-pattern>/*</url-pattern>
-  </filter-mapping>
-
-  <security-constraint>
-    <web-resource-collection>
-      <web-resource-name>NB api</web-resource-name>
-      <url-pattern>/*</url-pattern>
-      <http-method>POST</http-method>
-      <http-method>GET</http-method>
-      <http-method>PUT</http-method>
-      <http-method>PATCH</http-method>
-      <http-method>DELETE</http-method>
-      <http-method>HEAD</http-method>
-    </web-resource-collection>
-    <auth-constraint>
-      <role-name>System-Admin</role-name>
-      <role-name>Network-Admin</role-name>
-      <role-name>Network-Operator</role-name>
-    </auth-constraint>
-  </security-constraint>
-
-  <security-role>
-    <role-name>System-Admin</role-name>
-  </security-role>
-  <security-role>
-    <role-name>Network-Admin</role-name>
-  </security-role>
-  <security-role>
-    <role-name>Network-Operator</role-name>
-  </security-role>
-
-  <login-config>
-    <auth-method>BASIC</auth-method>
-    <realm-name>opendaylight</realm-name>
-  </login-config>
-</web-app>
\ No newline at end of file
diff --git a/opendaylight/adsal/northbound/containermanager/enunciate.xml b/opendaylight/adsal/northbound/containermanager/enunciate.xml
deleted file mode 100644 (file)
index c4e08ae..0000000
+++ /dev/null
@@ -1,11 +0,0 @@
-<?xml version="1.0"?>
-<enunciate label="full" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
-    xsi:noNamespaceSchemaLocation="http://enunciate.codehaus.org/schemas/enunciate-1.28.xsd">
-  <services>
-    <rest defaultRestSubcontext="/controller/nb/v2/containermanager"/>
-  </services>
-
-  <modules>
-    <docs docsDir="rest" title="Container Manager REST API" includeExampleXml="true" includeExampleJson="true"/>
-  </modules>
-</enunciate>
diff --git a/opendaylight/adsal/northbound/containermanager/pom.xml b/opendaylight/adsal/northbound/containermanager/pom.xml
deleted file mode 100644 (file)
index 4c3cea1..0000000
+++ /dev/null
@@ -1,84 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>enunciate-parent</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/enunciate-parent</relativePath>
-  </parent>
-
-  <artifactId>containermanager.northbound</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>org.codehaus.enunciate</groupId>
-      <artifactId>enunciate-core-annotations</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>appauth</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>commons.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>containermanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>web</artifactId>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Export-Package></Export-Package>
-            <Import-Package>org.opendaylight.controller.appauth.authorization,
-              org.opendaylight.controller.sal.authorization,
-              org.opendaylight.controller.usermanager,
-              org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.sal.utils,
-              org.opendaylight.controller.containermanager,
-              org.opendaylight.controller.northbound.commons,
-              org.opendaylight.controller.northbound.commons.exception,
-              org.opendaylight.controller.northbound.commons.utils,
-              org.opendaylight.controller.northbound.commons.query,
-              com.sun.jersey.spi.container.servlet,
-              javax.ws.rs,
-              javax.ws.rs.ext,
-              javax.ws.rs.core,
-              javax.xml.bind.annotation,
-              javax.xml.bind,
-              org.slf4j,
-              org.apache.catalina.filters,
-              com.fasterxml.jackson.jaxrs.base,
-              com.fasterxml.jackson.jaxrs.json,
-              !org.codehaus.enunciate.jaxrs</Import-Package>
-            <Web-ContextPath>/controller/nb/v2/containermanager</Web-ContextPath>
-            <Jaxrs-Resources>,${classes;ANNOTATION;javax.ws.rs.Path}</Jaxrs-Resources>
-          </instructions>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/northbound/containermanager/src/main/java/org/opendaylight/controller/containermanager/northbound/ContainerConfigs.java b/opendaylight/adsal/northbound/containermanager/src/main/java/org/opendaylight/controller/containermanager/northbound/ContainerConfigs.java
deleted file mode 100644 (file)
index 582c076..0000000
+++ /dev/null
@@ -1,48 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-
-package org.opendaylight.controller.containermanager.northbound;
-
-import java.util.List;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.containermanager.ContainerConfig;
-
-
-@XmlRootElement(name = "containerConfig-list")
-@XmlAccessorType(XmlAccessType.NONE)
-public class ContainerConfigs {
-        @XmlElement(name = "containerConfig")
-    List<ContainerConfig> containerConfig;
-
-    //To satisfy JAXB
-    @SuppressWarnings("unused")
-    private ContainerConfigs() {
-
-    }
-
-
-    public ContainerConfigs(List<ContainerConfig> containerconfig) {
-        this.containerConfig = containerconfig;
-    }
-
-
-    public List<ContainerConfig> getcontainerConfig() {
-        return containerConfig;
-    }
-
-    public void setcontainerConfig(List<ContainerConfig> containerConfig) {
-        this.containerConfig = containerConfig;
-    }
-}
diff --git a/opendaylight/adsal/northbound/containermanager/src/main/java/org/opendaylight/controller/containermanager/northbound/ContainerManagerNorthbound.java b/opendaylight/adsal/northbound/containermanager/src/main/java/org/opendaylight/controller/containermanager/northbound/ContainerManagerNorthbound.java
deleted file mode 100644 (file)
index 7541678..0000000
+++ /dev/null
@@ -1,828 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.containermanager.northbound;
-
-import java.util.ArrayList;
-import java.util.HashSet;
-import java.util.List;
-import java.util.Set;
-
-import javax.ws.rs.Consumes;
-import javax.ws.rs.DELETE;
-import javax.ws.rs.GET;
-import javax.ws.rs.PUT;
-import javax.ws.rs.Path;
-import javax.ws.rs.PathParam;
-import javax.ws.rs.Produces;
-import javax.ws.rs.QueryParam;
-import javax.ws.rs.core.Context;
-import javax.ws.rs.core.MediaType;
-import javax.ws.rs.core.Response;
-import javax.ws.rs.core.SecurityContext;
-import javax.ws.rs.core.UriInfo;
-import javax.ws.rs.ext.ContextResolver;
-
-import org.codehaus.enunciate.jaxrs.ResponseCode;
-import org.codehaus.enunciate.jaxrs.StatusCodes;
-import org.codehaus.enunciate.jaxrs.TypeHint;
-import org.opendaylight.controller.containermanager.ContainerConfig;
-import org.opendaylight.controller.containermanager.ContainerFlowConfig;
-import org.opendaylight.controller.containermanager.IContainerAuthorization;
-import org.opendaylight.controller.containermanager.IContainerManager;
-import org.opendaylight.controller.northbound.commons.RestMessages;
-import org.opendaylight.controller.northbound.commons.exception.BadRequestException;
-import org.opendaylight.controller.northbound.commons.exception.InternalServerErrorException;
-import org.opendaylight.controller.northbound.commons.exception.ResourceConflictException;
-import org.opendaylight.controller.northbound.commons.exception.ResourceForbiddenException;
-import org.opendaylight.controller.northbound.commons.exception.ResourceNotFoundException;
-import org.opendaylight.controller.northbound.commons.exception.UnauthorizedException;
-import org.opendaylight.controller.northbound.commons.query.QueryContext;
-import org.opendaylight.controller.northbound.commons.utils.NorthboundUtils;
-import org.opendaylight.controller.sal.authorization.Privilege;
-import org.opendaylight.controller.sal.authorization.UserLevel;
-import org.opendaylight.controller.sal.utils.GlobalConstants;
-import org.opendaylight.controller.sal.utils.ServiceHelper;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.usermanager.IUserManager;
-
-/**
- * Container Manager Northbound API
- *
- * <br>
- * <br>
- * Authentication scheme : <b>HTTP Basic</b><br>
- * Authentication realm : <b>opendaylight</b><br>
- * Transport : <b>HTTP and HTTPS</b><br>
- * <br>
- * HTTPS Authentication is disabled by default. Administrator can enable it in
- * tomcat-server.xml after adding a proper keystore / SSL certificate from a
- * trusted authority.<br>
- * More info :
- * http://tomcat.apache.org/tomcat-7.0-doc/ssl-howto.html#Configuration
- *
- */
-@Path("/")
-public class ContainerManagerNorthbound {
-    private String username;
-    private QueryContext queryContext;
-
-    @Context
-    public void setQueryContext(ContextResolver<QueryContext> queryCtxResolver) {
-      if (queryCtxResolver != null) {
-        queryContext = queryCtxResolver.getContext(QueryContext.class);
-      }
-    }
-
-    @Context
-    public void setSecurityContext(SecurityContext context) {
-        if (context != null && context.getUserPrincipal() != null) {
-            username = context.getUserPrincipal().getName();
-        }
-    }
-
-    protected String getUserName() {
-        return username;
-    }
-
-    private IContainerManager getContainerManager() {
-        IContainerManager containerMgr = (IContainerManager) ServiceHelper.getGlobalInstance(IContainerManager.class, this);
-        if (containerMgr == null) {
-            throw new InternalServerErrorException(RestMessages.INTERNALERROR.toString());
-        }
-        return containerMgr;
-    }
-
-    private void handleNameMismatch(String name, String nameinURL) {
-        if (name == null || nameinURL == null) {
-            throw new BadRequestException(RestMessages.INVALIDJSON.toString());
-        }
-
-        if (name.equalsIgnoreCase(nameinURL)) {
-            return;
-        }
-        throw new BadRequestException(RestMessages.INVALIDJSON.toString());
-    }
-
-
-
-    /**
-     * Get all the containers configured in the system
-     *
-     * @return a List of all {@link org.opendaylight.controller.containermanager.ContainerConfig}
-     *
-     *         <pre>
-     *
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/containermanager/containers
-     *
-     * Response body in XML:
-     * &lt;containerConfig-list&gt;
-     *    &#x20;&#x20;&#x20;&lt;containerConfig&gt;
-     *    &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;container&gt;black&lt;/container&gt;
-     *    &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;staticVlan&gt;10&lt;/staticVlan&gt;
-     *    &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;nodeConnectors&gt;OF|1@OF|00:00:00:00:00:00:00:01&lt;/nodeConnectors&gt;
-     *    &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;nodeConnectors&gt;OF|23@OF|00:00:00:00:00:00:20:21&lt;/nodeConnectors&gt;
-     *    &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;flowSpecs&gt;
-     *    &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;name&gt;tcp&lt;/name&gt;
-     *    &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;protocol&gt;TCP&lt;/protocol&gt;
-     *    &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;/flowSpecs&gt;
-     *    &#x20;&#x20;&#x20;&#x20;&lt;/containerConfig&gt;
-     *    &#x20;&#x20;&#x20;&#x20;&lt;containerConfig&gt;
-     *    &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;container&gt;red&lt;/container&gt;
-     *    &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;staticVlan&gt;20&lt;/staticVlan&gt;
-     *    &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;nodeConnectors&gt;OF|1@OF|00:00:00:00:00:00:00:01&lt;/nodeConnectors&gt;
-     *    &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;nodeConnectors&gt;OF|23@OF|00:00:00:00:00:00:20:21&lt;/nodeConnectors&gt;
-     *    &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;flowSpecs&gt;
-     *    &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;name&gt;udp&lt;/name&gt;
-     *    &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;protocol&gt;UDP&lt;/protocol&gt;
-     *    &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;/flowSpecs&gt;
-     *  &#x20;&#x20;&#x20;&#x20;&lt;/containerConfig&gt;
-     * &lt;/containerConfig-list&gt;
-     *
-     * Response body in JSON:
-     * { "containerConfig" : [
-     *     { "container" : "black",
-     *       "nodeConnectors" : [
-     *          "OF|1@OF|00:00:00:00:00:00:00:01", "OF|23@OF|00:00:00:00:00:00:20:21"
-     *       ],
-     *       "staticVlan" : "10",
-     *       "flowSpecs : [
-     *          { "name": "udp",
-     *            "protocol": "UDP" }
-     *       ]
-     *     },
-     *     { "container" : "red",
-     *       "nodeConnectors" : [
-     *          "OF|1@OF|00:00:00:00:00:00:00:01",
-     *          "OF|23@OF|00:00:00:00:00:00:20:21"
-     *       ],
-     *       "staticVlan" : "20",
-     *       "flowSpecs": [
-     *          { "name": "tcp",
-     *            "protocol": "TCP"
-     *          }
-     *       ]
-     *     }
-     *   ]
-     * }
-     * </pre>
-     */
-    @Path("/containers")
-    @GET
-    @Produces({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @TypeHint(ContainerConfigs.class)
-    @StatusCodes({ @ResponseCode(code = 200, condition = "Operation successful"),
-            @ResponseCode(code = 401, condition = "User is not authorized to perform this operation"),
-            @ResponseCode(code = 503, condition = "One or more of Controller Services are unavailable") })
-    public ContainerConfigs viewAllContainers(@QueryParam("_q") String queryString) {
-
-        handleNetworkAuthorization(getUserName());
-
-        IContainerManager containerManager = getContainerManager();
-        ContainerConfigs result = new ContainerConfigs(
-                containerManager.getContainerConfigList());
-        if (queryString != null) {
-            queryContext.createQuery(queryString, ContainerConfigs.class)
-                .filter(result, ContainerConfig.class);
-        }
-        return result;
-    }
-
-    /**
-     * Get the container configuration for container name requested
-     *
-     * @param container
-     *            name of the Container (eg. blue)
-     * @return a List of {@link org.opendaylight.controller.containermanager.ContainerConfig}
-     *
-     *         <pre>
-     *
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/containermanager/container/blue
-     *
-     * Response body in XML:
-     * &lt;containerConfig&gt;
-     *  &#x20;&#x20;&#x20;&#x20;&lt;container&gt;blue&lt;/container&gt;
-     *  &#x20;&#x20;&#x20;&#x20;&lt;staticVlan&gt;10&lt;/staticVlan&gt;
-     *  &#x20;&#x20;&#x20;&#x20;&lt;nodeConnectors&gt;OF|1@OF|00:00:00:00:00:00:00:01&lt;/nodeConnectors&gt;
-     *  &#x20;&#x20;&#x20;&#x20;&lt;nodeConnectors&gt;OF|23@OF|00:00:00:00:00:00:20:21&lt;/nodeConnectors&gt;
-     * &lt;/containerConfig&gt;
-     *
-     * Response body in JSON:
-     * {
-     *    "containerConfig": [
-     *       {
-     *        "container": "yellow",
-     *        "staticVlan": "10",
-     *        "nodeConnectors": [
-     *           "OF|1@OF|00:00:00:00:00:00:00:01",
-     *           "OF|2@OF|00:00:00:00:00:00:00:02"
-     *        ],
-     *        "flowSpecs": []
-     *       }
-     *    ]
-     * }
-     * </pre>
-     */
-    @Path("/container/{container}")
-    @GET
-    @Produces({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @TypeHint(ContainerConfig.class)
-    @StatusCodes({ @ResponseCode(code = 200, condition = "Operation successful"),
-            @ResponseCode(code = 401, condition = "User is not authorized to perform this operation"),
-            @ResponseCode(code = 403, condition = "Operation forbidden on default"),
-            @ResponseCode(code = 404, condition = "The container is not found") })
-    public ContainerConfigs viewContainer(@PathParam(value = "container") String container) {
-
-        handleContainerAuthorization(container, getUserName());
-        handleForbiddenOnDefault(container);
-
-        handleContainerNotExists(container);
-
-        IContainerManager containerManager = getContainerManager();
-        List<ContainerConfig> containerConfigs = new ArrayList<ContainerConfig>();
-        containerConfigs.add(containerManager.getContainerConfig(container));
-        return new ContainerConfigs(containerConfigs);
-    }
-
-    /**
-     * Create a container
-     *
-     * @param uriInfo
-     * @param container
-     *            name of the Container (eg. yellow)
-     * @param containerConfig
-     *            details of the container as specified by:
-     *            {@link org.opendaylight.controller.containermanager.ContainerConfig}
-     * @return Response as dictated by the HTTP Response Status code
-     *
-     * <pre>
-     *
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/containermanager/container/yellow
-     *
-     * Request body in XML:
-     * &lt;containerConfig&gt;
-     *   &#x20;&#x20;&#x20;&#x20;&lt;container&gt;yellow&lt;/container&gt;
-     *   &#x20;&#x20;&#x20;&#x20;&lt;staticVlan&gt;10&lt;/staticVlan&gt;
-     *   &#x20;&#x20;&#x20;&#x20;&lt;nodeConnectors&gt;&lt;/nodeConnectors&gt;
-     * &lt;/containerConfig&gt;
-     *
-     * Request body in JSON:
-     * {
-     *    "container" : "yellow",
-     *    "nodeConnectors" : [
-     *       "OF|1@OF|00:00:00:00:00:00:00:01",
-     *       "OF|23@OF|00:00:00:00:00:00:20:21"
-     *    ],
-     *    "staticVlan" : "10"
-     * }
-     *
-     * </pre>
-     */
-    @Path("/container/{container}")
-    @PUT
-    @Consumes({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @StatusCodes({ @ResponseCode(code = 201, condition = "Container created successfully"),
-            @ResponseCode(code = 400, condition = "Invalid Container configuration."),
-            @ResponseCode(code = 401, condition = "User not authorized to perform this operation"),
-            @ResponseCode(code = 403, condition = "Operation forbidden on default"),
-            @ResponseCode(code = 404, condition = "Container Name is not found"),
-            @ResponseCode(code = 409, condition = "Failed to create Container due to Conflicting Name"),
-            @ResponseCode(code = 500, condition = "Failure Reason included in HTTP Error response") })
-    public Response createContainer(@Context UriInfo uriInfo,
-            @PathParam(value = "container") String container,
-            @TypeHint(ContainerConfig.class) ContainerConfig containerConfig) {
-
-        handleAdminAuthorization(getUserName());
-        handleContainerExists(container);
-
-        handleNameMismatch(containerConfig.getContainerName(), container);
-        handleForbiddenOnDefault(container);
-
-        IContainerManager containerManager = getContainerManager();
-        Status status = containerManager.addContainer(containerConfig);
-        if (status.isSuccess()) {
-            NorthboundUtils.auditlog("Container", username, "added", container);
-            return Response.created(uriInfo.getRequestUri()).build();
-        }
-        return NorthboundUtils.getResponse(status);
-    }
-
-    /**
-     * Delete a container
-     *
-     * @param container
-     *            name of the Container (eg. green)
-     * @return Response as dictated by the HTTP Response code
-     *
-     * <pre>
-     *
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/containermanager/container/green
-     *
-     * </pre>
-     */
-    @Path("/container/{container}")
-    @DELETE
-    @StatusCodes({
-            @ResponseCode(code = 204, condition = "Container deleted successfully"),
-            @ResponseCode(code = 401, condition = "User not authorized to perform this operation"),
-            @ResponseCode(code = 403, condition = "Operation forbidden on default"),
-            @ResponseCode(code = 404, condition = "The container is not found") })
-    public Response removeContainer(@PathParam(value = "container") String container) {
-
-        handleAdminAuthorization(getUserName());
-        handleForbiddenOnDefault(container);
-        handleContainerNotExists(container);
-        IContainerManager containerManager = getContainerManager();
-        Status status = containerManager.removeContainer(container);
-        if (status.isSuccess()) {
-            NorthboundUtils.auditlog("Container", username, "removed", container);
-            return Response.noContent().build();
-        }
-        return NorthboundUtils.getResponse(status);
-    }
-
-    /**
-     * Get flowspec within a given container
-     *
-     * @param container
-     *            name of the Container (eg. green)
-     * @param name
-     *            name of the flowspec (eg. ssh)
-     * @return flowspec detail as specified by:
-     *         {@link org.opendaylight.controller.containermanager.ContainerFlowConfig}
-     *
-     *         <pre>
-     *
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/containermanager/container/green/flowspec/ssh
-     *
-     * Response body in XML:
-     * &lt;flow-spec-config&gt;
-     *  &#x20;&#x20;&#x20;&#x20;&lt;name&gt;ssh&lt;/name&gt;
-     *  &#x20;&#x20;&#x20;&#x20;&lt;dlVlan&gt;52&lt;/dlVlan&gt;
-     *  &#x20;&#x20;&#x20;&#x20;&lt;nwSrc&gt;10.0.0.101&lt;/nwSrc&gt;
-     *  &#x20;&#x20;&#x20;&#x20;&lt;nwDst&gt;10.0.0.102&lt;/nwDst&gt;
-     *  &#x20;&#x20;&#x20;&#x20;&lt;protocol&gt;IPv4&lt;/protocol&gt;
-     *  &#x20;&#x20;&#x20;&#x20;&lt;tpSrc&gt;80&lt;/tpSrc&gt;
-     *  &#x20;&#x20;&#x20;&#x20;&lt;tpDst&gt;100&lt;/tpDst&gt;
-     * &lt;/flow-spec-config&gt;
-     *
-     * Response body in JSON:
-     * {
-     *    "protocol" : "IPv4",
-     *    "dlVlan" : "52",
-     *    "nwDst" : "10.0.0.102",
-     *    "name" : "ssh",
-     *    "nwSrc" : "10.0.0.101",
-     *    "tpSrc" : "80",
-     *    "tpDst" : "100"
-     * }
-     *
-     * </pre>
-     */
-    @Path("/container/{container}/flowspec/{flowspec}")
-    @GET
-    @Produces({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @TypeHint(ContainerFlowConfig.class)
-    @StatusCodes({ @ResponseCode(code = 200, condition = "Operation successful"),
-            @ResponseCode(code = 401, condition = "User not authorized to perform this operation"),
-            @ResponseCode(code = 404, condition = "The container is not found"),
-            @ResponseCode(code = 503, condition = "One or more of Controller Services are unavailable") })
-    public ContainerFlowConfig viewContainerFlowSpec(@PathParam(value = "container") String container,
-            @PathParam(value = "flowspec") String flowspec) {
-
-        handleContainerAuthorization(container, getUserName());
-        handleForbiddenOnDefault(container);
-
-        handleContainerNotExists(container);
-        IContainerManager containerManager = getContainerManager();
-        List<ContainerFlowConfig> flowSpecs = containerManager.getContainerFlows(container);
-
-        for (ContainerFlowConfig containerFlowConfig : flowSpecs) {
-            if (containerFlowConfig.equalsByName(flowspec)) {
-                return containerFlowConfig;
-            }
-        }
-        throw new ResourceNotFoundException("Flow Spec not found");
-    }
-
-    /**
-     * Get all the flowspec in a given container
-     *
-     * @param container
-     *            name of the Container (eg. red)
-     * @return list of all flowspec configured for a container. Flowspec as
-     *         specified by:
-     *         {@link org.opendaylight.controller.containermanager.ContainerFlowConfig}
-     *
-     *         <pre>
-     *
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/containermanager/container/red/flowspec
-     *
-     * Response body in XML:
-     * &lt;flow-spec-configs&gt;
-     *   &#x20;&#x20;&#x20;&#x20;&lt;flow-spec-config&gt;
-     *     &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;name&gt;ssh&lt;/name&gt;
-     *     &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;dlVlan&gt;52&lt;/dlVlan&gt;
-     *     &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;nwSrc&gt;10.0.0.101&lt;/nwSrc&gt;
-     *     &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;nwDst&gt;10.0.0.102&lt;/nwDst&gt;
-     *     &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;protocol&gt;IPv4&lt;/protocol&gt;
-     *     &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;tpSrc&gt;23&lt;/tpSrc&gt;
-     *     &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;tpDst&gt;100&lt;/tpDst&gt;
-     *   &#x20;&#x20;&#x20;&#x20;&lt;/flow-spec-config&gt;
-     *   &#x20;&#x20;&#x20;&#x20;&lt;flow-spec-config&gt;
-     *     &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;name&gt;http2&lt;/name&gt;
-     *     &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;dlVlan&gt;123&lt;/dlVlan&gt;
-     *     &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;nwSrc&gt;10.0.0.201&lt;/nwSrc&gt;
-     *     &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;nwDst&gt;10.0.0.202&lt;/nwDst&gt;
-     *     &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;protocol&gt;&lt;/protocol&gt;
-     *     &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;tpSrc&gt;80&lt;/tpSrc&gt;
-     *     &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;tpDst&gt;100&lt;/tpDst&gt;
-     *   &#x20;&#x20;&#x20;&#x20;&lt;/flow-spec-config&gt;
-     * &lt;/flow-spec-configs&gt;
-     *
-      * Response body in JSON:
-     * {
-     *   "flow-spec-config": [
-     *     {
-     *       "name": "http",
-     *       "dlVlan" : "52",
-     *       "nwSrc": "10.0.0.201",
-     *       "nwDst": "10.0.0.202",
-     *       "protocol": "",
-     *       "tpSrc": "80",
-     *       "tpDst": "100"
-     *     },
-     *     {
-     *       "name": "ssh",
-     *       "dlVlan" : "123",
-     *       "nwSrc": "10.0.0.101",
-     *       "nwDst": "10.0.0.102",
-     *       "protocol": "IPv4",
-     *       "tpSrc": "23",
-     *       "tpDst": "100"
-     *     }
-     *   ]
-     * }
-     *
-     * </pre>
-     */
-    @Path("/container/{container}/flowspecs")
-    @GET
-    @Produces({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @TypeHint(FlowSpecConfigs.class)
-    @StatusCodes({ @ResponseCode(code = 200, condition = "Operation successful"),
-            @ResponseCode(code = 404, condition = "The container is not found"),
-            @ResponseCode(code = 503, condition = "One or more of Controller Services are unavailable") })
-    public FlowSpecConfigs viewContainerFlowSpecs(@PathParam(value = "container") String container,
-        @QueryParam("_q") String queryString) {
-
-        handleContainerAuthorization(container, getUserName());
-        handleForbiddenOnDefault(container);
-
-        handleContainerNotExists(container);
-
-        IContainerManager containerManager = getContainerManager();
-        FlowSpecConfigs result = new FlowSpecConfigs(
-                containerManager.getContainerFlows(container));
-        if (queryString != null) {
-            queryContext.createQuery(queryString, FlowSpecConfigs.class)
-                .filter(result, ContainerFlowConfig.class);
-        }
-        return result;
-    }
-
-    /**
-     * Add flowspec to a container
-     *
-     * @param container
-     *            name of the container (eg. purple)
-     * @param name
-     *            name of the flowspec (eg. http)
-     * @param flowspec
-     *            configuration as specified by:
-     *            {@link org.opendaylight.controller.containermanager.ContainerFlowConfig}
-     *
-     * @return Response as dictated by the HTTP Response code
-     *
-     *         <pre>
-     *
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/containermanager/container/purple/flowspec/http
-     *
-     * Request body in XML:
-     *   &lt;flow-spec-config&gt;
-     *     &#x20;&#x20;&#x20;&#x20;&lt;name&gt;http&lt;/name&gt;
-     *     &#x20;&#x20;&#x20;&#x20;&lt;dlVlan&gt;25&lt;/dlVlan&gt;
-     *     &#x20;&#x20;&#x20;&#x20;&lt;nwSrc&gt;10.0.0.101&lt;/nwSrc&gt;
-     *     &#x20;&#x20;&#x20;&#x20;&lt;nwDst&gt;10.0.0.102&lt;/nwDst&gt;
-     *     &#x20;&#x20;&#x20;&#x20;&lt;protocol&gt;&lt;/protocol&gt;
-     *     &#x20;&#x20;&#x20;&#x20;&lt;tpSrc&gt;80&lt;/tpSrc&gt;
-     *     &#x20;&#x20;&#x20;&#x20;&lt;tpDst&gt;100&lt;/tpDst&gt;
-     *   &lt;/flow-spec-config&gt;
-     *
-     * Request body in JSON:
-     * {
-     *    "name" : "http",
-     *    "dlVlan" : "25",
-     *    "nwSrc" : "10.0.0.101",
-     *    "nwDst" : "10.0.0.102",
-     *    "protocol" : "",
-     *    "tpSrc" : "80",
-     *    "tpDst" : "100"
-     * }
-     *
-     * </pre>
-     */
-    @Path("/container/{container}/flowspec/{flowspec}")
-    @PUT
-    @Consumes({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @StatusCodes({
-            @ResponseCode(code = 201, condition = "FlowSpec created successfully"),
-            @ResponseCode(code = 400, condition = "Invalid flowspec configuration"),
-            @ResponseCode(code = 404, condition = "The container is not found"),
-            @ResponseCode(code = 409, condition = "Container Entry already exists"),
-            @ResponseCode(code = 500, condition = "Failed to create Flow specifications. Failure Reason included in HTTP Error response") })
-    public Response createFlowSpec(@Context UriInfo uriInfo,
-            @PathParam(value = "container") String container,
-            @PathParam(value = "flowspec") String flowspec,
-            @TypeHint(ContainerFlowConfig.class) ContainerFlowConfig containerFlowConfig) {
-
-        handleAdminAuthorization(getUserName());
-        handleForbiddenOnDefault(container);
-
-        handleContainerNotExists(container);
-        handleNameMismatch(containerFlowConfig.getName(), flowspec);
-
-        IContainerManager containerManager = getContainerManager();
-        List<ContainerFlowConfig> list = new ArrayList<ContainerFlowConfig>();
-        list.add(containerFlowConfig);
-        Status status = containerManager.addContainerFlows(container, list);
-        if (status.isSuccess()) {
-            NorthboundUtils.auditlog("Flow Spec", username, "added", containerFlowConfig.getName());
-            return Response.created(uriInfo.getRequestUri()).build();
-        }
-        return NorthboundUtils.getResponse(status);
-    }
-
-    /**
-     * Remove flowspec from a container
-     *
-     * @param name
-     *            name of the flowspec (eg. telnet)
-     * @param container
-     *            name of the Container (eg. black)
-     * @return Response as dictated by the HTTP Response code
-     *
-     * <pre>
-     *
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/containermanager/container/black/flowspec/telnet
-     *
-     * </pre>
-     */
-    @Path("/container/{container}/flowspec/{flowspec}")
-    @DELETE
-    @StatusCodes({
-            @ResponseCode(code = 204, condition = "Flow Spec deleted successfully"),
-            @ResponseCode(code = 400, condition = "Invalid flowspec configuration"),
-            @ResponseCode(code = 404, condition = "Container or Container Entry not found"),
-            @ResponseCode(code = 406, condition = "Cannot operate on Default Container when other Containers are active"),
-            @ResponseCode(code = 500, condition = "Failed to delete Flowspec. Failure Reason included in HTTP Error response"),
-            @ResponseCode(code = 503, condition = "One or more of Controller service is unavailable") })
-    public Response removeFlowSpec(@PathParam(value = "container") String container,
-            @PathParam(value = "flowspec") String flowspec) {
-
-        handleAdminAuthorization(getUserName());
-        handleForbiddenOnDefault(container);
-
-        handleContainerNotExists(container);
-
-        IContainerManager containerManager = getContainerManager();
-        Set<String> set = new HashSet<String>();
-        set.add(flowspec);
-        Status status = containerManager.removeContainerFlows(container, set);
-        if (status.isSuccess()) {
-            NorthboundUtils.auditlog("Flow Spec", username, "added", flowspec);
-            return Response.noContent().build();
-        }
-        return NorthboundUtils.getResponse(status);
-    }
-
-    /**
-     * Add node connectors to a container
-     *
-     * @param container
-     *            name of the container (eg. green)
-     * @param list
-     *            The list of strings each representing a node connector in the form "<Port Type>|<Port id>@<Node Type>|<Node id>", as "OF|1@OF|00:00:00:ab:00:00:00:01"
-     * @return response as dictated by the HTTP Status code
-     *
-     * <pre>
-     *
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/containermanager/container/green/nodeconnector
-     *
-     * Request body in XML:
-     * &lt;nodeConnectors&gt;
-     *     &lt;nodeConnectors&gt;OF|1@OF|00:00:00:00:00:00:00:01&lt;/nodeConnectors&gt;
-     *     &lt;nodeConnectors&gt;OF|2@OF|00:00:00:00:00:00:00:01&lt;/nodeConnectors&gt;
-     *     &lt;nodeConnectors&gt;OF|3@OF|00:00:00:00:00:00:00:22&lt;/nodeConnectors&gt;
-     *     &lt;nodeConnectors&gt;OF|4@OF|00:00:00:00:00:00:00:22&lt;/nodeConnectors&gt;
-     * &lt;/nodeConnectors&gt;
-     *
-     * Request body in JSON:
-     * {
-     *    "nodeConnectors" : [
-     *       "OF|1@OF|00:00:00:00:00:00:00:01",
-     *       "OF|2@OF|00:00:00:00:00:00:00:01",
-     *       "OF|3@OF|00:00:00:00:00:00:00:22",
-     *       "OF|4@OF|00:00:00:00:00:00:00:22"
-     *    ]
-     * }
-     *
-     * </pre>
-     */
-    @Path("/container/{container}/nodeconnector/")
-    @PUT
-    @Consumes({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @TypeHint(Response.class)
-    @StatusCodes({
-            @ResponseCode(code = 200, condition = "NodeConnectors added successfully"),
-            @ResponseCode(code = 401, condition = "User not authorized to perform this operation"),
-            @ResponseCode(code = 403, condition = "Operation forbidden on default"),
-            @ResponseCode(code = 404, condition = "The Container is not found"),
-            @ResponseCode(code = 409, condition = "Container Entry already exists"),
-            @ResponseCode(code = 500, condition = "Failed to create nodeconnectors. Failure Reason included in HTTP Error response") })
-    public Response addNodeConnectors(@PathParam(value = "container") String container,
-            @TypeHint(StringList.class) StringList list) {
-
-        handleAdminAuthorization(getUserName());
-        handleForbiddenOnDefault(container);
-        handleContainerNotExists(container);
-
-        IContainerManager containerManager = getContainerManager();
-        Status status = containerManager.addContainerEntry(container, list.getList());
-        if (status.isSuccess()) {
-            NorthboundUtils.auditlog("Node ", username, "added", " Ports:" + list.getList());
-        }
-        return NorthboundUtils.getResponse(status);
-    }
-
-    /**
-     * Remove node connectors from a container
-     *
-     * @param container
-     *            name of the container (eg. red)
-     * @param list
-     *            The list of strings each representing a node connector in the form "<Port Type>|<Port id>@<Node Type>|<Node id>", as "OF|1@OF|00:00:00:ab:00:00:00:01"
-     * @return response as dictated by the HTTP Status code
-     *
-     *         <pre>
-     *
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/containermanager/container/red/nodeconnector
-     *
-     * Request body in XML:
-     * &lt;nodeConnectors&gt;
-     *     &lt;nodeConnectors&gt;OF|1@OF|00:00:00:00:00:00:00:01&lt;/nodeConnectors&gt;
-     *     &lt;nodeConnectors&gt;OF|2@OF|00:00:00:00:00:00:00:01&lt;/nodeConnectors&gt;
-     *     &lt;nodeConnectors&gt;OF|3@OF|00:00:00:00:00:00:00:22&lt;/nodeConnectors&gt;
-     *     &lt;nodeConnectors&gt;OF|4@OF|00:00:00:00:00:00:00:22&lt;/nodeConnectors&gt;
-     * &lt;/nodeConnectors&gt;
-     *
-     * Request body in JSON:
-     * {
-     *    "nodeConnectors" : [
-     *       "OF|1@OF|00:00:00:00:00:00:00:01",
-     *       "OF|2@OF|00:00:00:00:00:00:00:01",
-     *       "OF|3@OF|00:00:00:00:00:00:00:22",
-     *       "OF|4@OF|00:00:00:00:00:00:00:22"
-     *       ]
-     * }
-     *
-     * </pre>
-     */
-    @Path("/container/{container}/nodeconnector/")
-    @DELETE
-    @Consumes({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @StatusCodes({
-            @ResponseCode(code = 204, condition = "Container Entry deleted successfully"),
-            @ResponseCode(code = 400, condition = "Invalid Container Entry configuration"),
-            @ResponseCode(code = 404, condition = "The Container is not found"),
-            @ResponseCode(code = 406, condition = "Cannot operate on Default Container when other Containers are active"),
-            @ResponseCode(code = 500, condition = "Failed to delete node connector. Failure Reason included in HTTP Error response") })
-    public Response removeNodeConnectors(@PathParam(value = "container") String container,
-            @TypeHint(StringList.class) StringList portList) {
-
-        handleAdminAuthorization(getUserName());
-        handleForbiddenOnDefault(container);
-        handleContainerNotExists(container);
-
-        IContainerManager containerManager = getContainerManager();
-        Status status = containerManager.removeContainerEntry(container, portList.getList());
-        if (status.isSuccess()) {
-            NorthboundUtils.auditlog("Node", username, "removed", " Ports:" + portList.getList());
-            return Response.noContent().build();
-        }
-        return NorthboundUtils.getResponse(status);
-    }
-
-    /*
-     * Check If the function is not allowed on default container, Throw a
-     * ResourceForbiddenException exception if forbidden
-     */
-    private void handleForbiddenOnDefault(String container) {
-        if (container.equalsIgnoreCase(GlobalConstants.DEFAULT.toString())) {
-            throw new ResourceForbiddenException(RestMessages.NODEFAULT.toString() + ": " + container);
-        }
-    }
-
-    /*
-     * Check if container exists, Throw a ResourceNotFoundException exception if it
-     * does not exist
-     */
-    private void handleContainerNotExists(String container) {
-        IContainerManager containerManager = getContainerManager();
-        if (!containerManager.doesContainerExist(container)) {
-            throw new ResourceNotFoundException(RestMessages.NOCONTAINER.toString() + ": " + container);
-        }
-    }
-
-    private void handleContainerExists(String container) {
-        IContainerManager containerManager = getContainerManager();
-        if (containerManager.doesContainerExist(container)) {
-            throw new ResourceConflictException(RestMessages.RESOURCECONFLICT.toString() + ": " + container);
-        }
-    }
-
-    private void handleAdminAuthorization(String userName) {
-        IUserManager usrMgr = (IUserManager) ServiceHelper.getGlobalInstance(IUserManager.class, this);
-
-        UserLevel level = usrMgr.getUserLevel(userName);
-        if (level.ordinal() <= UserLevel.NETWORKADMIN.ordinal()) {
-            return;
-        }
-
-        throw new UnauthorizedException("User is not authorized to perform this operation");
-    }
-
-    private void handleNetworkAuthorization(String userName) {
-        IUserManager usrMgr = (IUserManager) ServiceHelper.getGlobalInstance(IUserManager.class, this);
-
-        UserLevel level = usrMgr.getUserLevel(userName);
-        if (level.ordinal() <= UserLevel.NETWORKOPERATOR.ordinal()) {
-            return;
-        }
-        throw new UnauthorizedException("User is not authorized to perform this operation");
-    }
-
-    private void handleContainerAuthorization(String container, String userName) {
-        IContainerAuthorization auth = (IContainerAuthorization) ServiceHelper.getGlobalInstance(
-                IContainerAuthorization.class, this);
-
-        UserLevel level = auth.getUserLevel(userName);
-        if (level.ordinal() <= UserLevel.NETWORKOPERATOR.ordinal()) {
-            return;
-        }
-
-        Privilege current = (auth == null) ? Privilege.NONE : auth.getResourcePrivilege(userName, container);
-
-        if (current.ordinal() > Privilege.NONE.ordinal()) {
-            return;
-        }
-        throw new UnauthorizedException("User is not authorized to perform this operation");
-    }
-
-}
diff --git a/opendaylight/adsal/northbound/containermanager/src/main/java/org/opendaylight/controller/containermanager/northbound/ContainerManagerNorthboundRSApplication.java b/opendaylight/adsal/northbound/containermanager/src/main/java/org/opendaylight/controller/containermanager/northbound/ContainerManagerNorthboundRSApplication.java
deleted file mode 100644 (file)
index db3d543..0000000
+++ /dev/null
@@ -1,37 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.containermanager.northbound;
-
-import java.util.HashSet;
-import java.util.Set;
-
-import javax.ws.rs.core.Application;
-
-import org.opendaylight.controller.northbound.commons.query.QueryContextProvider;
-
-import com.fasterxml.jackson.jaxrs.json.JacksonJaxbJsonProvider;
-
-/**
- * Instance of javax.ws.rs.core.Application used to return the classes
- * that will be instantiated for JAXRS processing, this is necessary
- * because the package scanning in jersey doesn't yet work in OSGi
- * environment.
- *
- */
-public class ContainerManagerNorthboundRSApplication extends Application {
-    @Override
-    public Set<Class<?>> getClasses() {
-        Set<Class<?>> classes = new HashSet<Class<?>>();
-        classes.add(ContainerManagerNorthbound.class);
-        classes.add(JacksonJaxbJsonProvider.class);
-        classes.add(QueryContextProvider.class);
-        return classes;
-    }
-}
diff --git a/opendaylight/adsal/northbound/containermanager/src/main/java/org/opendaylight/controller/containermanager/northbound/FlowSpecConfigs.java b/opendaylight/adsal/northbound/containermanager/src/main/java/org/opendaylight/controller/containermanager/northbound/FlowSpecConfigs.java
deleted file mode 100644 (file)
index cc75055..0000000
+++ /dev/null
@@ -1,44 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.containermanager.northbound;
-
-import java.util.List;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.containermanager.ContainerFlowConfig;
-
-
-@XmlRootElement(name = "flow-spec-configs")
-@XmlAccessorType(XmlAccessType.NONE)
-public class FlowSpecConfigs {
-    @XmlElement(name = "flow-spec-config")
-    List<ContainerFlowConfig> containerFlowConfig;
-
-    // To satisfy JAXB
-    @SuppressWarnings("unused")
-    private FlowSpecConfigs() {
-
-    }
-
-    public FlowSpecConfigs(List<ContainerFlowConfig> containerFlowConfig) {
-        this.containerFlowConfig = containerFlowConfig;
-    }
-
-    public List<ContainerFlowConfig> getContainerFlowConfig() {
-        return containerFlowConfig;
-    }
-
-    public void setContainerFlowConfig(List<ContainerFlowConfig> containerFlowConfig) {
-        this.containerFlowConfig = containerFlowConfig;
-    }
-}
diff --git a/opendaylight/adsal/northbound/containermanager/src/main/java/org/opendaylight/controller/containermanager/northbound/StringList.java b/opendaylight/adsal/northbound/containermanager/src/main/java/org/opendaylight/controller/containermanager/northbound/StringList.java
deleted file mode 100644 (file)
index 7cba528..0000000
+++ /dev/null
@@ -1,38 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.containermanager.northbound;
-
-import java.util.List;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-//TODO: Remove this once StringList is provided by commons.northboud
-
-@XmlRootElement(name = "nodeConnectors")
-@XmlAccessorType(XmlAccessType.NONE)
-public class StringList {
-    @XmlElement(name = "nodeConnectors")
-    private List<String> list;
-
-    public StringList() {
-    }
-
-    public StringList(List<String> list) {
-        this.list = list;
-    }
-
-    public List<String> getList() {
-        return list;
-    }
-
-}
diff --git a/opendaylight/adsal/northbound/containermanager/src/main/resources/META-INF/spring.factories b/opendaylight/adsal/northbound/containermanager/src/main/resources/META-INF/spring.factories
deleted file mode 100644 (file)
index 93db02e..0000000
+++ /dev/null
@@ -1 +0,0 @@
-org.springframework.beans.BeanInfoFactory=org.springframework.beans.ExtendedBeanInfoFactory
diff --git a/opendaylight/adsal/northbound/containermanager/src/main/resources/META-INF/spring.handlers b/opendaylight/adsal/northbound/containermanager/src/main/resources/META-INF/spring.handlers
deleted file mode 100644 (file)
index 6aeb8ca..0000000
+++ /dev/null
@@ -1,10 +0,0 @@
-http\://www.springframework.org/schema/context=org.springframework.context.config.ContextNamespaceHandler
-http\://www.springframework.org/schema/jee=org.springframework.ejb.config.JeeNamespaceHandler
-http\://www.springframework.org/schema/lang=org.springframework.scripting.config.LangNamespaceHandler
-http\://www.springframework.org/schema/task=org.springframework.scheduling.config.TaskNamespaceHandler
-http\://www.springframework.org/schema/cache=org.springframework.cache.config.CacheNamespaceHandler
-http\://www.springframework.org/schema/c=org.springframework.beans.factory.xml.SimpleConstructorNamespaceHandler
-http\://www.springframework.org/schema/p=org.springframework.beans.factory.xml.SimplePropertyNamespaceHandler
-http\://www.springframework.org/schema/util=org.springframework.beans.factory.xml.UtilNamespaceHandler
-http\://www.springframework.org/schema/mvc=org.springframework.web.servlet.config.MvcNamespaceHandler
-
diff --git a/opendaylight/adsal/northbound/containermanager/src/main/resources/META-INF/spring.schemas b/opendaylight/adsal/northbound/containermanager/src/main/resources/META-INF/spring.schemas
deleted file mode 100644 (file)
index acf748a..0000000
+++ /dev/null
@@ -1,46 +0,0 @@
-http\://www.springframework.org/schema/beans/spring-beans-2.0.xsd=org/springframework/beans/factory/xml/spring-beans-2.0.xsd
-http\://www.springframework.org/schema/beans/spring-beans-2.5.xsd=org/springframework/beans/factory/xml/spring-beans-2.5.xsd
-http\://www.springframework.org/schema/beans/spring-beans-3.0.xsd=org/springframework/beans/factory/xml/spring-beans-3.0.xsd
-http\://www.springframework.org/schema/beans/spring-beans-3.1.xsd=org/springframework/beans/factory/xml/spring-beans-3.1.xsd
-http\://www.springframework.org/schema/beans/spring-beans-3.2.xsd=org/springframework/beans/factory/xml/spring-beans-3.2.xsd
-http\://www.springframework.org/schema/beans/spring-beans.xsd=org/springframework/beans/factory/xml/spring-beans-3.2.xsd
-http\://www.springframework.org/schema/tool/spring-tool-2.0.xsd=org/springframework/beans/factory/xml/spring-tool-2.0.xsd
-http\://www.springframework.org/schema/tool/spring-tool-2.5.xsd=org/springframework/beans/factory/xml/spring-tool-2.5.xsd
-http\://www.springframework.org/schema/tool/spring-tool-3.0.xsd=org/springframework/beans/factory/xml/spring-tool-3.0.xsd
-http\://www.springframework.org/schema/tool/spring-tool-3.1.xsd=org/springframework/beans/factory/xml/spring-tool-3.1.xsd
-http\://www.springframework.org/schema/tool/spring-tool-3.2.xsd=org/springframework/beans/factory/xml/spring-tool-3.2.xsd
-http\://www.springframework.org/schema/tool/spring-tool.xsd=org/springframework/beans/factory/xml/spring-tool-3.2.xsd
-http\://www.springframework.org/schema/util/spring-util-2.0.xsd=org/springframework/beans/factory/xml/spring-util-2.0.xsd
-http\://www.springframework.org/schema/util/spring-util-2.5.xsd=org/springframework/beans/factory/xml/spring-util-2.5.xsd
-http\://www.springframework.org/schema/util/spring-util-3.0.xsd=org/springframework/beans/factory/xml/spring-util-3.0.xsd
-http\://www.springframework.org/schema/util/spring-util-3.1.xsd=org/springframework/beans/factory/xml/spring-util-3.1.xsd
-http\://www.springframework.org/schema/util/spring-util-3.2.xsd=org/springframework/beans/factory/xml/spring-util-3.2.xsd
-http\://www.springframework.org/schema/util/spring-util.xsd=org/springframework/beans/factory/xml/spring-util-3.2.xsd
-http\://www.springframework.org/schema/context/spring-context-2.5.xsd=org/springframework/context/config/spring-context-2.5.xsd
-http\://www.springframework.org/schema/context/spring-context-3.0.xsd=org/springframework/context/config/spring-context-3.0.xsd
-http\://www.springframework.org/schema/context/spring-context-3.1.xsd=org/springframework/context/config/spring-context-3.1.xsd
-http\://www.springframework.org/schema/context/spring-context-3.2.xsd=org/springframework/context/config/spring-context-3.2.xsd
-http\://www.springframework.org/schema/context/spring-context.xsd=org/springframework/context/config/spring-context-3.2.xsd
-http\://www.springframework.org/schema/jee/spring-jee-2.0.xsd=org/springframework/ejb/config/spring-jee-2.0.xsd
-http\://www.springframework.org/schema/jee/spring-jee-2.5.xsd=org/springframework/ejb/config/spring-jee-2.5.xsd
-http\://www.springframework.org/schema/jee/spring-jee-3.0.xsd=org/springframework/ejb/config/spring-jee-3.0.xsd
-http\://www.springframework.org/schema/jee/spring-jee-3.1.xsd=org/springframework/ejb/config/spring-jee-3.1.xsd
-http\://www.springframework.org/schema/jee/spring-jee-3.2.xsd=org/springframework/ejb/config/spring-jee-3.2.xsd
-http\://www.springframework.org/schema/jee/spring-jee.xsd=org/springframework/ejb/config/spring-jee-3.2.xsd
-http\://www.springframework.org/schema/lang/spring-lang-2.0.xsd=org/springframework/scripting/config/spring-lang-2.0.xsd
-http\://www.springframework.org/schema/lang/spring-lang-2.5.xsd=org/springframework/scripting/config/spring-lang-2.5.xsd
-http\://www.springframework.org/schema/lang/spring-lang-3.0.xsd=org/springframework/scripting/config/spring-lang-3.0.xsd
-http\://www.springframework.org/schema/lang/spring-lang-3.1.xsd=org/springframework/scripting/config/spring-lang-3.1.xsd
-http\://www.springframework.org/schema/lang/spring-lang-3.2.xsd=org/springframework/scripting/config/spring-lang-3.2.xsd
-http\://www.springframework.org/schema/lang/spring-lang.xsd=org/springframework/scripting/config/spring-lang-3.2.xsd
-http\://www.springframework.org/schema/task/spring-task-3.0.xsd=org/springframework/scheduling/config/spring-task-3.0.xsd
-http\://www.springframework.org/schema/task/spring-task-3.1.xsd=org/springframework/scheduling/config/spring-task-3.1.xsd
-http\://www.springframework.org/schema/task/spring-task-3.2.xsd=org/springframework/scheduling/config/spring-task-3.2.xsd
-http\://www.springframework.org/schema/task/spring-task.xsd=org/springframework/scheduling/config/spring-task-3.2.xsd
-http\://www.springframework.org/schema/cache/spring-cache-3.1.xsd=org/springframework/cache/config/spring-cache-3.1.xsd
-http\://www.springframework.org/schema/cache/spring-cache-3.2.xsd=org/springframework/cache/config/spring-cache-3.2.xsd
-http\://www.springframework.org/schema/cache/spring-cache.xsd=org/springframework/cache/config/spring-cache-3.2.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd=org/springframework/web/servlet/config/spring-mvc-3.0.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc-3.1.xsd=org/springframework/web/servlet/config/spring-mvc-3.1.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc-3.2.xsd=org/springframework/web/servlet/config/spring-mvc-3.2.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc.xsd=org/springframework/web/servlet/config/spring-mvc-3.2.xsd
diff --git a/opendaylight/adsal/northbound/containermanager/src/main/resources/META-INF/spring.tooling b/opendaylight/adsal/northbound/containermanager/src/main/resources/META-INF/spring.tooling
deleted file mode 100644 (file)
index 057d834..0000000
+++ /dev/null
@@ -1,39 +0,0 @@
-# Tooling related information for the beans namespace
-http\://www.springframework.org/schema/beans@name=beans Namespace
-http\://www.springframework.org/schema/beans@prefix=beans
-http\://www.springframework.org/schema/beans@icon=org/springframework/beans/factory/xml/spring-beans.gif
-
-# Tooling related information for the util namespace
-http\://www.springframework.org/schema/util@name=util Namespace
-http\://www.springframework.org/schema/util@prefix=util
-http\://www.springframework.org/schema/util@icon=org/springframework/beans/factory/xml/spring-util.gif
-
-# Tooling related information for the context namespace
-http\://www.springframework.org/schema/context@name=context Namespace
-http\://www.springframework.org/schema/context@prefix=context
-http\://www.springframework.org/schema/context@icon=org/springframework/context/config/spring-context.gif
-
-# Tooling related information for the jee namespace
-http\://www.springframework.org/schema/jee@name=jee Namespace
-http\://www.springframework.org/schema/jee@prefix=jee
-http\://www.springframework.org/schema/jee@icon=org/springframework/ejb/config/spring-jee.gif
-
-# Tooling related information for the scheduling namespace
-http\://www.springframework.org/schema/task@name=task Namespace
-http\://www.springframework.org/schema/task@prefix=task
-http\://www.springframework.org/schema/task@icon=org/springframework/scheduling/config/spring-task.gif
-
-# Tooling related information for the lang namespace
-http\://www.springframework.org/schema/lang@name=lang Namespace
-http\://www.springframework.org/schema/lang@prefix=lang
-http\://www.springframework.org/schema/lang@icon=org/springframework/scripting/config/spring-lang.gif
-
-# Tooling related information for the cache namespace
-http\://www.springframework.org/schema/cache@name=cache Namespace
-http\://www.springframework.org/schema/cache@prefix=cache
-http\://www.springframework.org/schema/cache@icon=org/springframework/cache/config/spring-cache.gif
-
-# Tooling related information for the mvc namespace
-http\://www.springframework.org/schema/mvc@name=mvc Namespace
-http\://www.springframework.org/schema/mvc@prefix=mvc
-http\://www.springframework.org/schema/mvc@icon=org/springframework/web/servlet/config/spring-mvc.gif
diff --git a/opendaylight/adsal/northbound/containermanager/src/main/resources/WEB-INF/web.xml b/opendaylight/adsal/northbound/containermanager/src/main/resources/WEB-INF/web.xml
deleted file mode 100644 (file)
index 5f74a44..0000000
+++ /dev/null
@@ -1,88 +0,0 @@
-<?xml version="1.0" encoding="ISO-8859-1"?>
-<web-app xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
-  xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee
-http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd"
-  version="2.4">
-<servlet>
-      <servlet-name>JAXRSContainerManager</servlet-name>
-      <servlet-class>com.sun.jersey.spi.container.servlet.ServletContainer</servlet-class>
-      <init-param>
-        <param-name>javax.ws.rs.Application</param-name>
-        <param-value>org.opendaylight.controller.containermanager.northbound.ContainerManagerNorthboundRSApplication</param-value>
-      </init-param>
-      <load-on-startup>1</load-on-startup>
-</servlet>
-    <servlet-mapping>
-      <servlet-name>JAXRSContainerManager</servlet-name>
-      <url-pattern>/*</url-pattern>
-    </servlet-mapping>
-    <filter>
-      <filter-name>CorsFilter</filter-name>
-      <filter-class>org.apache.catalina.filters.CorsFilter</filter-class>
-      <init-param>
-        <param-name>cors.allowed.origins</param-name>
-        <param-value>*</param-value>
-      </init-param>
-      <init-param>
-        <param-name>cors.allowed.methods</param-name>
-        <param-value>GET,POST,HEAD,OPTIONS,PUT,DELETE</param-value>
-      </init-param>
-      <init-param>
-        <param-name>cors.allowed.headers</param-name>
-        <param-value>Content-Type,X-Requested-With,accept,authorization, origin,Origin,Access-Control-Request-Method,Access-Control-Request-Headers</param-value>
-      </init-param>
-      <init-param>
-        <param-name>cors.exposed.headers</param-name>
-        <param-value>Access-Control-Allow-Origin,Access-Control-Allow-Credentials</param-value>
-      </init-param>
-      <init-param>
-        <param-name>cors.support.credentials</param-name>
-        <param-value>true</param-value>
-      </init-param>
-      <init-param>
-        <param-name>cors.preflight.maxage</param-name>
-        <param-value>10</param-value>
-      </init-param>
-    </filter>
-    <filter-mapping>
-      <filter-name>CorsFilter</filter-name>
-      <url-pattern>/*</url-pattern>
-    </filter-mapping>
-
-    <security-constraint>
-        <web-resource-collection>
-            <web-resource-name>NB api</web-resource-name>
-            <url-pattern>/*</url-pattern>
-            <http-method>POST</http-method>
-            <http-method>GET</http-method>
-            <http-method>PUT</http-method>
-            <http-method>PATCH</http-method>
-            <http-method>DELETE</http-method>
-            <http-method>HEAD</http-method>
-        </web-resource-collection>
-        <auth-constraint>
-            <role-name>System-Admin</role-name>
-            <role-name>Network-Admin</role-name>
-            <role-name>Network-Operator</role-name>
-            <role-name>Container-User</role-name>
-        </auth-constraint>
-    </security-constraint>
-
-    <security-role>
-        <role-name>System-Admin</role-name>
-    </security-role>
-    <security-role>
-        <role-name>Network-Admin</role-name>
-    </security-role>
-    <security-role>
-        <role-name>Network-Operator</role-name>
-    </security-role>
-    <security-role>
-        <role-name>Container-User</role-name>
-    </security-role>
-
-    <login-config>
-        <auth-method>BASIC</auth-method>
-        <realm-name>opendaylight</realm-name>
-    </login-config>
-</web-app>
diff --git a/opendaylight/adsal/northbound/controllermanager/enunciate.xml b/opendaylight/adsal/northbound/controllermanager/enunciate.xml
deleted file mode 100644 (file)
index 5382d54..0000000
+++ /dev/null
@@ -1,12 +0,0 @@
-<?xml version="1.0"?>
-<enunciate label="full" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
-    xsi:noNamespaceSchemaLocation="http://enunciate.codehaus.org/schemas/enunciate-1.28.xsd">
-
-  <services>
-    <rest defaultRestSubcontext="/controller/nb/v2/controllermanager"/>
-  </services>
-
-  <modules>
-    <docs docsDir="rest" title="Controller Manager REST API" includeExampleXml="true" includeExampleJson="true"/>
-  </modules>
-</enunciate>
diff --git a/opendaylight/adsal/northbound/controllermanager/pom.xml b/opendaylight/adsal/northbound/controllermanager/pom.xml
deleted file mode 100644 (file)
index 20c0886..0000000
+++ /dev/null
@@ -1,97 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>adsal-enunciate-parent</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../adsal-enunciate-parent</relativePath>
-  </parent>
-  <artifactId>controllermanager.northbound</artifactId>
-  <version>0.2.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.codehaus.enunciate</groupId>
-      <artifactId>enunciate-core-annotations</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>commons.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>containermanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>switchmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller.thirdparty</groupId>
-      <artifactId>com.sun.jersey.jersey-servlet</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller.thirdparty</groupId>
-      <artifactId>org.apache.catalina.filters.CorsFilter</artifactId>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Bundle-SymbolicName>${project.artifactId}</Bundle-SymbolicName>
-            <Import-Package>org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.sal.utils,
-              org.opendaylight.controller.configuration,
-              org.opendaylight.controller.containermanager,
-              org.opendaylight.controller.switchmanager,
-              org.opendaylight.controller.usermanager,
-              org.apache.commons.lang3.tuple,
-              org.apache.commons.logging,
-              com.sun.jersey.spi.container.servlet,
-              org.opendaylight.controller.northbound.commons,
-              org.opendaylight.controller.northbound.commons.exception,
-              org.opendaylight.controller.northbound.commons.utils,
-              org.opendaylight.controller.northbound.commons.query,
-              org.opendaylight.controller.sal.authorization,
-              javax.ws.rs,
-              javax.ws.rs.ext,
-              javax.ws.rs.core,
-              javax.xml.bind.annotation,
-              javax.xml.bind,
-              org.slf4j,
-              org.apache.catalina.filters,
-              com.fasterxml.jackson.annotation,
-              com.fasterxml.jackson.jaxrs.base,
-              com.fasterxml.jackson.jaxrs.json,
-              !org.codehaus.enunciate.jaxrs</Import-Package>
-            <Web-ContextPath>/controller/nb/v2/controllermanager</Web-ContextPath>
-            <Jaxrs-Resources>,${classes;ANNOTATION;javax.ws.rs.Path}</Jaxrs-Resources>
-          </instructions>
-          <manifestLocation>${project.basedir}/src/main/resources/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/northbound/controllermanager/src/main/java/org/opendaylight/controller/controllermanager/northbound/ControllerManagerNorthbound.java b/opendaylight/adsal/northbound/controllermanager/src/main/java/org/opendaylight/controller/controllermanager/northbound/ControllerManagerNorthbound.java
deleted file mode 100644 (file)
index aaf93d1..0000000
+++ /dev/null
@@ -1,326 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.controllermanager.northbound;
-
-import java.util.HashSet;
-import java.util.Map;
-import java.util.Set;
-
-import javax.ws.rs.Consumes;
-import javax.ws.rs.DELETE;
-import javax.ws.rs.GET;
-import javax.ws.rs.PUT;
-import javax.ws.rs.Path;
-import javax.ws.rs.PathParam;
-import javax.ws.rs.Produces;
-import javax.ws.rs.QueryParam;
-import javax.ws.rs.core.Context;
-import javax.ws.rs.core.MediaType;
-import javax.ws.rs.core.Response;
-import javax.ws.rs.core.SecurityContext;
-import javax.ws.rs.core.UriInfo;
-import javax.ws.rs.ext.ContextResolver;
-
-import org.codehaus.enunciate.jaxrs.ResponseCode;
-import org.codehaus.enunciate.jaxrs.StatusCodes;
-import org.codehaus.enunciate.jaxrs.TypeHint;
-import org.opendaylight.controller.configuration.IConfigurationService;
-import org.opendaylight.controller.containermanager.IContainerManager;
-import org.opendaylight.controller.northbound.commons.RestMessages;
-import org.opendaylight.controller.northbound.commons.exception.BadRequestException;
-import org.opendaylight.controller.northbound.commons.exception.ResourceNotFoundException;
-import org.opendaylight.controller.northbound.commons.exception.ServiceUnavailableException;
-import org.opendaylight.controller.northbound.commons.exception.UnauthorizedException;
-import org.opendaylight.controller.northbound.commons.query.QueryContext;
-import org.opendaylight.controller.northbound.commons.utils.NorthboundUtils;
-import org.opendaylight.controller.sal.authorization.Privilege;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.utils.GlobalConstants;
-import org.opendaylight.controller.sal.utils.ServiceHelper;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.switchmanager.ISwitchManager;
-
-/**
- * The class provides Northbound REST APIs to manager the controller. Currently
- * it supports getting controller property(ies), setting a property, and
- * removing a property
- *
- */
-
-@Path("/")
-public class ControllerManagerNorthbound {
-
-    private String username;
-    private QueryContext queryContext;
-
-    @Context
-    public void setQueryContext(ContextResolver<QueryContext> queryCtxResolver) {
-      if (queryCtxResolver != null) {
-        queryContext = queryCtxResolver.getContext(QueryContext.class);
-      }
-    }
-
-    @Context
-    public void setSecurityContext(SecurityContext context) {
-        if (context != null && context.getUserPrincipal() != null) {
-            username = context.getUserPrincipal().getName();
-        }
-    }
-
-    protected String getUserName() {
-        return username;
-    }
-
-    private ISwitchManager getISwitchManagerService(String containerName) {
-        ISwitchManager switchManager = (ISwitchManager) ServiceHelper.getInstance(ISwitchManager.class, containerName,
-                this);
-
-        if (switchManager == null) {
-            throw new ServiceUnavailableException("Switch Manager " + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        return switchManager;
-    }
-
-    /**
-     * Retrieve a property or all properties for the controller in the network
-     *
-     * @param containerName
-     *            Name of the Container (Eg. 'default')
-     * @param propertyName
-     *            Name of the Property specified by
-     *            {@link org.opendaylight.controller.sal.core.Property} and its
-     *            extended classes
-     *
-     *            Example:
-     *
-     *            Request URL:
-     *            http://localhost:8080/controller/nb/v2/controllermanager/default/properties/?propertyName=macAddress
-     *
-     *            Response Body in XML:
-     *            <?xml version="1.0" encoding="UTF-8" standalone="yes"?>
-     *            <controllerProperties>
-     *                  <properties>
-     *                           <macAddress>
-     *                                   <value>3e:04:ef:11:13:80</value>
-     *                          </macAddress>
-     *                   </properties>
-     *            </controllerProperties>
-     *
-     *            Response Body in JSON:
-     *            { "controllerProperties":
-     *                  {"properties":
-     *                          { "macAddress":
-     *                                  { "value": "3e:04:ef:11:13:80" }
-     *                           }
-     *                   }
-     *            }
-     *
-     */
-    @Path("/{containerName}/properties/")
-    @GET
-    @TypeHint(Property.class)
-    @Produces({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @StatusCodes({ @ResponseCode(code = 200, condition = "Operation successful"),
-            @ResponseCode(code = 401, condition = "User not authorized to perform this operation"),
-            @ResponseCode(code = 404, condition = "The containerName or property is not found"),
-            @ResponseCode(code = 503, condition = "One or more of Controller Services are unavailable") })
-    public ControllerProperties getControllerProperties(@PathParam("containerName") String containerName,
-            @QueryParam("propertyName") String propertyName,
-            @QueryParam("_q") String queryString) {
-
-        if (!isValidContainer(containerName)) {
-            throw new ResourceNotFoundException("Container " + containerName + " does not exist.");
-        }
-
-        if (!NorthboundUtils.isAuthorized(getUserName(), containerName, Privilege.READ, this)) {
-            throw new UnauthorizedException("User is not authorized to perform this operation on container "
-                    + containerName);
-        }
-
-        ISwitchManager switchManager = getISwitchManagerService(containerName);
-
-        if (propertyName == null) {
-            Map<String, Property> propertyMap = switchManager.getControllerProperties();
-            Set<Property> properties = new HashSet<Property>(propertyMap.values());
-            return new ControllerProperties(properties);
-        }
-
-        Set<Property> properties = new HashSet<Property>();
-        Property property = switchManager.getControllerProperty(propertyName);
-        if (property == null) {
-            throw new ResourceNotFoundException("Unable to find property with name: " + propertyName);
-        }
-        properties.add(property);
-        ControllerProperties result = new ControllerProperties(properties);
-        if (queryString != null) {
-            queryContext.createQuery(queryString, ControllerProperties.class)
-                .filter(result, Property.class);
-        }
-        return result;
-
-    }
-
-    /**
-     * Add a controller property to the controller. This method overrides
-     * previously set property values if the property already exist.
-     *
-     * @param containerName
-     *            Name of the Container (Eg. 'default')
-     * @param propertyName
-     *            Name of the Property specified by
-     *            {@link org.opendaylight.controller.sal.core.Property} and its
-     *            extended classes
-     * @param propertyValue
-     *            Value of the Property specified by
-     *            {@link org.opendaylight.controller.sal.core.Property} and its
-     *            extended classes
-     * @return Response as dictated by the HTTP Response Status code
-     *
-     *         Example:
-     *
-     *         Request URL:
-     *         http://localhost:8080/controller/nb/v2/controllermanager/default/properties/description/defaultController
-     */
-    @Path("/{containerName}/properties/{propertyName}/{propertyValue}")
-    @PUT
-    @Consumes({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @StatusCodes({ @ResponseCode(code = 201, condition = "Operation successful"),
-            @ResponseCode(code = 400, condition = "Invalid property parameters"),
-            @ResponseCode(code = 401, condition = "User not authorized to perform this operation"),
-            @ResponseCode(code = 404, condition = "The containerName or property is not found"),
-            @ResponseCode(code = 503, condition = "One or more of Controller Services are unavailable") })
-    public Response setControllerProperty(@Context UriInfo uriInfo, @PathParam("containerName") String containerName,
-            @PathParam("propertyName") String propertyName, @PathParam("propertyValue") String propertyValue) {
-
-        if (!isValidContainer(containerName)) {
-            throw new ResourceNotFoundException("Container " + containerName + " does not exist.");
-        }
-
-        if (!NorthboundUtils.isAuthorized(getUserName(), containerName, Privilege.READ, this)) {
-            throw new UnauthorizedException("User is not authorized to perform this operation on container "
-                    + containerName);
-        }
-
-        ISwitchManager switchManager = getISwitchManagerService(containerName);
-
-        Property prop = switchManager.createProperty(propertyName, propertyValue);
-        if (prop == null) {
-            throw new BadRequestException("Property with name " + propertyName + " cannot be created.");
-        }
-
-        Status status = switchManager.setControllerProperty(prop);
-
-        if (status.isSuccess()) {
-            NorthboundUtils.auditlog("Controller Property", username, "updated", propertyName);
-            return Response.created(uriInfo.getRequestUri()).build();
-        }
-        return NorthboundUtils.getResponse(status);
-    }
-
-    /**
-     * Delete a property of the controller
-     *
-     * @param containerName
-     *            Name of the Container (Eg. 'default')
-     * @param propertyName
-     *            Name of the Property specified by
-     *            {@link org.opendaylight.controller.sal.core.Property} and its
-     *            extended classes
-     * @return Response as dictated by the HTTP Response Status code
-     *
-     *         Example:
-     *
-     *         Request URL:
-     *         http://localhost:8080/controller/nb/v2/controllermanager/default/properties/description
-     */
-    @Path("/{containerName}/properties/{propertyName}")
-    @DELETE
-    @StatusCodes({ @ResponseCode(code = 204, condition = "Property removed successfully"),
-            @ResponseCode(code = 401, condition = "User not authorized to perform this operation"),
-            @ResponseCode(code = 404, condition = "The containerName is not found"),
-            @ResponseCode(code = 503, condition = "One or more of Controller Services are unavailable") })
-    public Response removeControllerProperty(@PathParam("containerName") String containerName,
-            @PathParam("propertyName") String propertyName) {
-
-        if (!isValidContainer(containerName)) {
-            throw new ResourceNotFoundException("Container " + containerName + " does not exist.");
-        }
-
-        if (!NorthboundUtils.isAuthorized(getUserName(), containerName, Privilege.READ, this)) {
-            throw new UnauthorizedException("User is not authorized to perform this operation on container "
-                    + containerName);
-        }
-
-        ISwitchManager switchManager = getISwitchManagerService(containerName);
-
-        Status status = switchManager.removeControllerProperty(propertyName);
-
-        if (status.isSuccess()) {
-            NorthboundUtils.auditlog("Controller Property", username, "removed", propertyName);
-
-            return Response.noContent().build();
-        }
-        return NorthboundUtils.getResponse(status);
-    }
-
-    /**
-     * Save controller configuration
-     *
-     * Request URL:
-     *  http://localhost:8080/controller/nb/v2/controllermanager/configuration
-     *
-     * Request body is empty
-     */
-    @Path("/configuration")
-    @PUT
-    @Consumes({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @StatusCodes({
-            @ResponseCode(code = 204, condition = "Operation successful"),
-            @ResponseCode(code = 401, condition = "User not authorized to perform this operation"),
-            @ResponseCode(code = 503, condition = "Configuration service is unavailable.")
-    })
-    public Response saveConfiguration() {
-
-        if (!NorthboundUtils.isAuthorized(getUserName(), "default", Privilege.WRITE, this)) {
-            throw new UnauthorizedException("User is not authorized to perform this operation");
-        }
-
-        IConfigurationService configService = (IConfigurationService)
-                ServiceHelper.getGlobalInstance(IConfigurationService.class, this);
-
-        if (configService == null) {
-            throw new ServiceUnavailableException("Configuration Service " +
-                    RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-        Status status = configService.saveConfigurations();
-        if (status.isSuccess()) {
-            NorthboundUtils.auditlog("Controller Configuration", username,
-                    "save", "configuration");
-            return Response.noContent().build();
-        }
-        return NorthboundUtils.getResponse(status);
-    }
-
-    private boolean isValidContainer(String containerName) {
-        if (containerName.equals(GlobalConstants.DEFAULT.toString())) {
-            return true;
-        }
-        IContainerManager containerManager = (IContainerManager) ServiceHelper.getGlobalInstance(
-                IContainerManager.class, this);
-        if (containerManager == null) {
-            throw new ServiceUnavailableException("Container Manager " + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-        if (containerManager.getContainerNames().contains(containerName)) {
-            return true;
-        }
-        return false;
-    }
-
-}
diff --git a/opendaylight/adsal/northbound/controllermanager/src/main/java/org/opendaylight/controller/controllermanager/northbound/ControllerProperties.java b/opendaylight/adsal/northbound/controllermanager/src/main/java/org/opendaylight/controller/controllermanager/northbound/ControllerProperties.java
deleted file mode 100644 (file)
index cec5a93..0000000
+++ /dev/null
@@ -1,71 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.controllermanager.northbound;
-
-import java.util.HashMap;
-import java.util.HashSet;
-import java.util.Map;
-import java.util.Set;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlElementWrapper;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.sal.core.Property;
-
-import com.fasterxml.jackson.annotation.JsonIgnore;
-import com.fasterxml.jackson.annotation.JsonProperty;
-
-/**
- * The class describes set of properties attached to a controller
- */
-
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-public class ControllerProperties {
-
-    /**
-     * Set to store the controller properties
-     */
-    @XmlElement(name="property")
-    @XmlElementWrapper
-    @JsonIgnore
-    private Set<Property> properties;
-
-    // JAXB required constructor
-    private ControllerProperties() {
-        this.properties = null;
-    }
-
-    public ControllerProperties(Set<Property> properties) {
-        this.properties = properties;
-    }
-
-    @JsonProperty(value="properties")
-    public Map<String, Property> getMapProperties() {
-        Map<String, Property> map = new HashMap<String, Property>();
-        for (Property p : properties) {
-            map.put(p.getName(), p);
-        }
-        return map;
-    }
-
-    public void setMapProperties(Map<String, Property> propertiesMap) {
-        this.properties = new HashSet<Property>(propertiesMap.values());
-    }
-
-    public Set<Property> getProperties() {
-        return properties;
-    }
-
-    public void setProperties(Set<Property> properties) {
-        this.properties = properties;
-    }
-}
diff --git a/opendaylight/adsal/northbound/controllermanager/src/main/resources/WEB-INF/web.xml b/opendaylight/adsal/northbound/controllermanager/src/main/resources/WEB-INF/web.xml
deleted file mode 100644 (file)
index 2efd81c..0000000
+++ /dev/null
@@ -1,89 +0,0 @@
-<?xml version="1.0" encoding="ISO-8859-1"?>
-<web-app xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
-        xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
-        version="3.0">
-  <servlet>
-    <servlet-name>JAXRSSwitchManager</servlet-name>
-    <servlet-class>com.sun.jersey.spi.container.servlet.ServletContainer</servlet-class>
-    <init-param>
-      <param-name>javax.ws.rs.Application</param-name>
-      <param-value>org.opendaylight.controller.northbound.commons.NorthboundApplication</param-value>
-    </init-param>
-    <load-on-startup>1</load-on-startup>
-  </servlet>
-
-  <servlet-mapping>
-    <servlet-name>JAXRSSwitchManager</servlet-name>
-    <url-pattern>/*</url-pattern>
-  </servlet-mapping>
-
-        <filter>
-          <filter-name>CorsFilter</filter-name>
-          <filter-class>org.apache.catalina.filters.CorsFilter</filter-class>
-          <init-param>
-            <param-name>cors.allowed.origins</param-name>
-            <param-value>*</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.allowed.methods</param-name>
-            <param-value>GET,POST,HEAD,OPTIONS,PUT,DELETE</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.allowed.headers</param-name>
-            <param-value>Content-Type,X-Requested-With,accept,authorization, origin,Origin,Access-Control-Request-Method,Access-Control-Request-Headers</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.exposed.headers</param-name>
-            <param-value>Access-Control-Allow-Origin,Access-Control-Allow-Credentials</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.support.credentials</param-name>
-            <param-value>true</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.preflight.maxage</param-name>
-            <param-value>10</param-value>
-          </init-param>
-        </filter>
-        <filter-mapping>
-          <filter-name>CorsFilter</filter-name>
-          <url-pattern>/*</url-pattern>
-        </filter-mapping>
-
-        <security-constraint>
-          <web-resource-collection>
-            <web-resource-name>NB api</web-resource-name>
-            <url-pattern>/*</url-pattern>
-            <http-method>POST</http-method>
-            <http-method>GET</http-method>
-            <http-method>PUT</http-method>
-            <http-method>PATCH</http-method>
-            <http-method>DELETE</http-method>
-            <http-method>HEAD</http-method>
-          </web-resource-collection>
-          <auth-constraint>
-            <role-name>System-Admin</role-name>
-            <role-name>Network-Admin</role-name>
-            <role-name>Network-Operator</role-name>
-            <role-name>Container-User</role-name>
-          </auth-constraint>
-        </security-constraint>
-
-        <security-role>
-                <role-name>System-Admin</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Network-Admin</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Network-Operator</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Container-User</role-name>
-        </security-role>
-
-        <login-config>
-                <auth-method>BASIC</auth-method>
-                <realm-name>opendaylight</realm-name>
-        </login-config>
-</web-app>
\ No newline at end of file
diff --git a/opendaylight/adsal/northbound/controllermanager/src/test/java/org/opendaylight/controller/controllermanager/northbound/ControllerManagerNorthboundTest.java b/opendaylight/adsal/northbound/controllermanager/src/test/java/org/opendaylight/controller/controllermanager/northbound/ControllerManagerNorthboundTest.java
deleted file mode 100644 (file)
index a25c759..0000000
+++ /dev/null
@@ -1,29 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.controllermanager.northbound;
-
-import java.util.HashSet;
-import java.util.Set;
-
-import org.junit.Assert;
-import org.junit.Test;
-import org.opendaylight.controller.sal.core.Property;
-
-public class ControllerManagerNorthboundTest {
-
-    @Test
-    public void testControllerProperties() {
-        ControllerProperties controllerProperties = new ControllerProperties(null);
-        Assert.assertTrue(controllerProperties.getProperties() == null);
-
-        Set<Property> properties = new HashSet<Property>();
-        controllerProperties.setProperties(properties);
-        Assert.assertTrue(controllerProperties.getProperties().equals(properties));
-    }
-
-}
diff --git a/opendaylight/adsal/northbound/flowprogrammer/enunciate.xml b/opendaylight/adsal/northbound/flowprogrammer/enunciate.xml
deleted file mode 100644 (file)
index 8a87876..0000000
+++ /dev/null
@@ -1,12 +0,0 @@
-<?xml version="1.0"?>
-<enunciate label="full" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
-    xsi:noNamespaceSchemaLocation="http://enunciate.codehaus.org/schemas/enunciate-1.28.xsd">
-
-  <services>
-    <rest defaultRestSubcontext="/controller/nb/v2/flowprogrammer"/>
-  </services>
-
-  <modules>
-    <docs docsDir="rest" title="Flow Programmer REST API" includeExampleXml="true" includeExampleJson="true"/>
-  </modules>
-</enunciate>
diff --git a/opendaylight/adsal/northbound/flowprogrammer/pom.xml b/opendaylight/adsal/northbound/flowprogrammer/pom.xml
deleted file mode 100644 (file)
index e97816f..0000000
+++ /dev/null
@@ -1,89 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>adsal-enunciate-parent</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../adsal-enunciate-parent</relativePath>
-  </parent>
-
-  <artifactId>flowprogrammer.northbound</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.codehaus.enunciate</groupId>
-      <artifactId>enunciate-core-annotations</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>commons.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>containermanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>forwardingrulesmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>switchmanager</artifactId>
-    </dependency>
-  </dependencies>
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Import-Package>org.opendaylight.controller.forwardingrulesmanager,
-              org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.sal.utils,
-              org.opendaylight.controller.containermanager,
-              org.opendaylight.controller.switchmanager,
-              org.opendaylight.controller.northbound.commons,
-              org.opendaylight.controller.northbound.commons.exception,
-              org.opendaylight.controller.northbound.commons.utils,
-              org.opendaylight.controller.northbound.commons.query,
-              org.opendaylight.controller.sal.authorization,
-              org.opendaylight.controller.usermanager,
-              com.sun.jersey.spi.container.servlet,
-              org.apache.catalina.filters,
-              javax.ws.rs,
-              javax.ws.rs.ext,
-              javax.ws.rs.core,
-              javax.xml.bind.annotation,
-              javax.xml.bind,
-              org.slf4j,
-              com.fasterxml.jackson.jaxrs.base,
-              com.fasterxml.jackson.jaxrs.json,
-              !org.codehaus.enunciate.jaxrs</Import-Package>
-            <Export-Package></Export-Package>
-            <Web-ContextPath>/controller/nb/v2/flowprogrammer</Web-ContextPath>
-            <Jaxrs-Resources>,${classes;ANNOTATION;javax.ws.rs.Path}</Jaxrs-Resources>
-          </instructions>
-          <manifestLocation>${project.basedir}/src/main/resources/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/northbound/flowprogrammer/src/main/java/org/opendaylight/controller/flowprogrammer/northbound/FlowConfigs.java b/opendaylight/adsal/northbound/flowprogrammer/src/main/java/org/opendaylight/controller/flowprogrammer/northbound/FlowConfigs.java
deleted file mode 100644 (file)
index e05aa10..0000000
+++ /dev/null
@@ -1,42 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.flowprogrammer.northbound;
-
-import java.util.List;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.forwardingrulesmanager.FlowConfig;
-
-@XmlRootElement (name = "list")
-@XmlAccessorType(XmlAccessType.NONE)
-
-public class FlowConfigs {
-        @XmlElement
-        List<FlowConfig> flowConfig;
-        //To satisfy JAXB
-        private FlowConfigs() {
-
-        }
-
-        public FlowConfigs(List<FlowConfig> flowConfig) {
-                this.flowConfig = flowConfig;
-        }
-
-        public List<FlowConfig> getFlowConfig() {
-                return flowConfig;
-        }
-
-        public void setFlowConfig(List<FlowConfig> flowConfig) {
-                this.flowConfig = flowConfig;
-        }
-}
diff --git a/opendaylight/adsal/northbound/flowprogrammer/src/main/java/org/opendaylight/controller/flowprogrammer/northbound/FlowProgrammerNorthbound.java b/opendaylight/adsal/northbound/flowprogrammer/src/main/java/org/opendaylight/controller/flowprogrammer/northbound/FlowProgrammerNorthbound.java
deleted file mode 100644 (file)
index 42bd59e..0000000
+++ /dev/null
@@ -1,676 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.flowprogrammer.northbound;
-
-import java.util.ArrayList;
-import java.util.List;
-
-import javax.ws.rs.Consumes;
-import javax.ws.rs.DELETE;
-import javax.ws.rs.GET;
-import javax.ws.rs.POST;
-import javax.ws.rs.PUT;
-import javax.ws.rs.Path;
-import javax.ws.rs.PathParam;
-import javax.ws.rs.Produces;
-import javax.ws.rs.QueryParam;
-import javax.ws.rs.core.Context;
-import javax.ws.rs.core.MediaType;
-import javax.ws.rs.core.Response;
-import javax.ws.rs.core.SecurityContext;
-import javax.ws.rs.ext.ContextResolver;
-
-import org.codehaus.enunciate.jaxrs.ResponseCode;
-import org.codehaus.enunciate.jaxrs.StatusCodes;
-import org.codehaus.enunciate.jaxrs.TypeHint;
-import org.opendaylight.controller.containermanager.IContainerManager;
-import org.opendaylight.controller.forwardingrulesmanager.FlowConfig;
-import org.opendaylight.controller.forwardingrulesmanager.IForwardingRulesManager;
-import org.opendaylight.controller.northbound.commons.RestMessages;
-import org.opendaylight.controller.northbound.commons.exception.InternalServerErrorException;
-import org.opendaylight.controller.northbound.commons.exception.MethodNotAllowedException;
-import org.opendaylight.controller.northbound.commons.exception.NotAcceptableException;
-import org.opendaylight.controller.northbound.commons.exception.ResourceNotFoundException;
-import org.opendaylight.controller.northbound.commons.exception.ServiceUnavailableException;
-import org.opendaylight.controller.northbound.commons.exception.UnauthorizedException;
-import org.opendaylight.controller.northbound.commons.query.QueryContext;
-import org.opendaylight.controller.northbound.commons.utils.NorthboundUtils;
-import org.opendaylight.controller.sal.authorization.Privilege;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.utils.GlobalConstants;
-import org.opendaylight.controller.sal.utils.ServiceHelper;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.switchmanager.ISwitchManager;
-
-/**
- * Flow Configuration Northbound API provides capabilities to program flows.
- *
- * <br>
- * <br>
- * Authentication scheme : <b>HTTP Basic</b><br>
- * Authentication realm : <b>opendaylight</b><br>
- * Transport : <b>HTTP and HTTPS</b><br>
- * <br>
- * HTTPS Authentication is disabled by default.
- *
- */
-@Path("/")
-public class FlowProgrammerNorthbound {
-
-    private String username;
-
-    private QueryContext queryContext;
-    @Context
-    public void setQueryContext(ContextResolver<QueryContext> queryCtxResolver) {
-      if (queryCtxResolver != null) {
-        queryContext = queryCtxResolver.getContext(QueryContext.class);
-      }
-    }
-
-    @Context
-    public void setSecurityContext(SecurityContext context) {
-        if (context != null && context.getUserPrincipal() != null) {
-            username = context.getUserPrincipal().getName();
-        }
-    }
-
-    protected String getUserName() {
-        return username;
-    }
-
-    private IForwardingRulesManager getForwardingRulesManagerService(String containerName) {
-        IContainerManager containerManager = (IContainerManager) ServiceHelper.getGlobalInstance(
-                IContainerManager.class, this);
-        if (containerManager == null) {
-            throw new ServiceUnavailableException("Container " + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        boolean found = false;
-        List<String> containerNames = containerManager.getContainerNames();
-        for (String cName : containerNames) {
-            if (cName.trim().equalsIgnoreCase(containerName.trim())) {
-                found = true;
-            }
-        }
-
-        if (found == false) {
-            throw new ResourceNotFoundException(containerName + " " + RestMessages.NOCONTAINER.toString());
-        }
-
-        IForwardingRulesManager frm = (IForwardingRulesManager) ServiceHelper.getInstance(
-                IForwardingRulesManager.class, containerName, this);
-
-        if (frm == null) {
-            throw new ServiceUnavailableException("Flow Programmer " + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        return frm;
-    }
-
-    private List<FlowConfig> getStaticFlowsInternal(String containerName, Node node) {
-        IForwardingRulesManager frm = getForwardingRulesManagerService(containerName);
-
-        if (frm == null) {
-            throw new ServiceUnavailableException("Flow Programmer " + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        List<FlowConfig> flows = new ArrayList<FlowConfig>();
-
-        if (node == null) {
-            for (FlowConfig flow : frm.getStaticFlows()) {
-                flows.add(flow);
-            }
-        } else {
-            ISwitchManager sm = (ISwitchManager) ServiceHelper.getInstance(ISwitchManager.class, containerName, this);
-
-            if (sm == null) {
-                throw new ServiceUnavailableException("Switch Manager " + RestMessages.SERVICEUNAVAILABLE.toString());
-            }
-
-            if (!sm.getNodes().contains(node)) {
-                throw new ResourceNotFoundException(node.toString() + " : " + RestMessages.NONODE.toString());
-            }
-
-            for (FlowConfig flow : frm.getStaticFlows(node)) {
-                flows.add(flow);
-            }
-        }
-        return flows;
-    }
-
-    /**
-     * Returns a list of Flows configured on the given container
-     *
-     * @param containerName
-     *            Name of the Container (Eg. 'default')
-     * @return List of flows configured on a given container
-     *
-     *         <pre>
-     *
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/flowprogrammer/default
-     *
-     * Response body in XML:
-     * &lt;?xml version="1.0" encoding="UTF-8" standalone="yes"?&gt;
-     * &lt;list&gt;
-     *     &#x20;&#x20;&#x20;&lt;flowConfig&gt;
-     *         &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;installInHw&gt;true&lt;/installInHw&gt;
-     *         &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;name&gt;flow1&lt;/name&gt;
-     *         &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;node&gt;
-     *             &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;id&gt;00:00:00:00:00:00:00:01&lt;/id&gt;
-     *             &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;type&gt;OF&lt;/type&gt;
-     *         &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;/node&gt;
-     *         &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;ingressPort&gt;1&lt;/ingressPort&gt;
-     *         &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;priority&gt;500&lt;/priority&gt;
-     *         &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;etherType&gt;0x800&lt;/etherType&gt;
-     *         &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;nwSrc&gt;9.9.1.1&lt;/nwSrc&gt;
-     *         &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;actions&gt;OUTPUT=2&lt;/actions&gt;
-     *     &#x20;&#x20;&#x20;&lt;/flowConfig&gt;
-     * &lt;/list&gt;
-     *
-     * Response body in JSON:
-     * {
-     *   "flowConfig": [
-     *      {
-     *         "installInHw": "true",
-     *         "name": "flow1",
-     *         "node": {
-     *            "type": "OF",
-     *            "id": "00:00:00:00:00:00:00:01"
-     *         },
-     *         "ingressPort": "1",
-     *         "priority": "500",
-     *         "etherType": "0x800",
-     *         "nwSrc":"9.9.1.1",
-     *         "actions": [
-     *           "OUTPUT=2"
-     *         ]
-     *      }
-     *    ]
-     * }
-     * </pre>
-     */
-    @Path("/{containerName}")
-    @GET
-    @Produces({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @TypeHint(FlowConfigs.class)
-    @StatusCodes({ @ResponseCode(code = 200, condition = "Operation successful"),
-        @ResponseCode(code = 401, condition = "User not authorized to perform this operation"),
-        @ResponseCode(code = 404, condition = "The containerName is not found"),
-        @ResponseCode(code = 503, condition = "One or more of Controller Services are unavailable"),
-        @ResponseCode(code = 400, condition = "Incorrect query syntex")})
-    public FlowConfigs getStaticFlows(@PathParam("containerName") String containerName,
-                   @QueryParam("_q") String queryString) {
-        if (!NorthboundUtils.isAuthorized(getUserName(), containerName, Privilege.READ, this)) {
-            throw new UnauthorizedException("User is not authorized to perform this operation on container "
-                    + containerName);
-        }
-
-        FlowConfigs result = new FlowConfigs(getStaticFlowsInternal(containerName, null));
-        if (queryString != null) {
-            queryContext.createQuery(queryString, FlowConfigs.class)
-                .filter(result, FlowConfig.class);
-        }
-        return result;
-    }
-
-    /**
-     * Returns a list of Flows configured on a Node in a given container
-     *
-     * @param containerName
-     *            Name of the Container (Eg. 'default')
-     * @param nodeType
-     *            Type of the node being programmed (Eg. 'OF')
-     * @param nodeId
-     *            Node Identifier (Eg. '00:00:00:00:00:00:00:01')
-     * @return List of flows configured on a Node in a container
-     *
-     *         <pre>
-     *
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/flowprogrammer/default/node/OF/00:00:00:00:00:00:00:01
-     *
-     * Response body in XML:
-     * &lt;?xml version="1.0" encoding="UTF-8" standalone="yes"?&gt;
-     * &lt;list&gt;
-     *     &#x20;&#x20;&#x20;&lt;flowConfig&gt;
-     *         &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;installInHw&gt;true&lt;/installInHw&gt;
-     *         &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;name&gt;flow1&lt;/name&gt;
-     *         &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;node&gt;
-     *             &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;id&gt;00:00:00:00:00:00:00:01&lt;/id&gt;
-     *             &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;type&gt;OF&lt;/type&gt;
-     *         &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;/node&gt;
-     *         &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;ingressPort&gt;1&lt;/ingressPort&gt;
-     *         &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;priority&gt;500&lt;/priority&gt;
-     *         &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;etherType&gt;0x800&lt;/etherType&gt;
-     *         &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;nwSrc&gt;9.9.1.1&lt;/nwSrc&gt;
-     *         &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;actions&gt;OUTPUT=2&lt;/actions&gt;
-     *     &#x20;&#x20;&#x20;&lt;/flowConfig&gt;
-     * &lt;/list&gt;
-     *
-    * Response body in JSON:
-     * {
-     *   "flowConfig": [
-     *      {
-     *         "installInHw": "true",
-     *         "name": "flow1",
-     *         "node": {
-     *            "type": "OF",
-     *            "id": "00:00:00:00:00:00:00:01"
-     *         },
-     *         "ingressPort": "1",
-     *         "priority": "500",
-     *         "etherType": "0x800",
-     *         "nwSrc":"9.9.1.1",
-     *         "actions": [
-     *           "OUTPUT=2"
-     *         ]
-     *       }
-     *    ]
-     * }
-     * </pre>
-     */
-    @Path("/{containerName}/node/{nodeType}/{nodeId}")
-    @GET
-    @Produces({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @TypeHint(FlowConfigs.class)
-    @StatusCodes({ @ResponseCode(code = 200, condition = "Operation successful"),
-        @ResponseCode(code = 401, condition = "User not authorized to perform this operation"),
-        @ResponseCode(code = 404, condition = "The containerName or nodeId is not found"),
-        @ResponseCode(code = 503, condition = "One or more of Controller Services are unavailable") })
-    public FlowConfigs getStaticFlows(@PathParam("containerName") String containerName,
-            @PathParam("nodeType") String nodeType, @PathParam("nodeId") String nodeId,
-            @QueryParam("_q") String queryString) {
-        if (!NorthboundUtils.isAuthorized(getUserName(), containerName, Privilege.READ, this)) {
-            throw new UnauthorizedException("User is not authorized to perform this operation on container "
-                    + containerName);
-        }
-        Node node = Node.fromString(nodeType, nodeId);
-        if (node == null) {
-            throw new ResourceNotFoundException(nodeId + " : " + RestMessages.NONODE.toString());
-        }
-        FlowConfigs flows = new FlowConfigs(getStaticFlowsInternal(containerName, node));
-        if (queryString != null) {
-            queryContext.createQuery(queryString, FlowConfigs.class)
-                .filter(flows, FlowConfig.class);
-        }
-        return flows;
-    }
-
-    /**
-     * Returns the flow configuration matching a human-readable name and nodeId
-     * on a given Container.
-     *
-     * @param containerName
-     *            Name of the Container (Eg. 'default')
-     * @param nodeType
-     *            Type of the node being programmed (Eg. 'OF')
-     * @param nodeId
-     *            Node Identifier (Eg. '00:00:00:00:00:00:00:01')
-     * @param name
-     *            Human-readable name for the configured flow (Eg. 'Flow1')
-     * @return Flow configuration matching the name and nodeId on a Container
-     *
-     *         <pre>
-     *
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/flowprogrammer/default/node/OF/00:00:00:00:00:00:00:01/staticFlow/flow1
-     *
-     * Response body in XML:
-     * &lt;?xml version="1.0" encoding="UTF-8" standalone="yes"?&gt;
-     * &lt;flowConfig&gt;
-     *     &#x20;&#x20;&#x20;&lt;installInHw&gt;true&lt;/installInHw&gt;
-     *     &#x20;&#x20;&#x20;&lt;name&gt;flow1&lt;/name&gt;
-     *     &#x20;&#x20;&#x20;&lt;node&gt;
-     *         &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;id&gt;00:00:00:00:00:00:00:01&lt;/id&gt;
-     *         &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;type&gt;OF&lt;/type&gt;
-     *     &#x20;&#x20;&#x20;&lt;/node&gt;
-     *     &#x20;&#x20;&#x20;&lt;ingressPort&gt;1&lt;/ingressPort&gt;
-     *     &#x20;&#x20;&#x20;&lt;priority&gt;500&lt;/priority&gt;
-     *     &#x20;&#x20;&#x20;&lt;etherType&gt;0x800&lt;/etherType&gt;
-     *     &#x20;&#x20;&#x20;&lt;nwSrc&gt;9.9.1.1&lt;/nwSrc&gt;
-     *     &#x20;&#x20;&#x20;&lt;actions&gt;OUTPUT=2&lt;/actions&gt;
-     * &lt;/flowConfig&gt;
-     *
-    * Response body in JSON:
-     * {
-     *    "installInHw":"true",
-     *    "name":"flow1",
-     *    "node":{
-     *       "id":"00:00:00:00:00:00:00:01",
-     *       "type":"OF"
-     *    },
-     *    "ingressPort":"1",
-     *    "priority":"500",
-     *    "etherType":"0x800",
-     *    "nwSrc":"9.9.1.1",
-     *    "actions":[
-     *       "OUTPUT=2"
-     *    ]
-     * }
-     *
-     * </pre>
-     */
-    @Path("/{containerName}/node/{nodeType}/{nodeId}/staticFlow/{name}")
-    @GET
-    @Produces({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @TypeHint(FlowConfig.class)
-    @StatusCodes({ @ResponseCode(code = 200, condition = "Operation successful"),
-        @ResponseCode(code = 401, condition = "User not authorized to perform this operation"),
-        @ResponseCode(code = 404, condition = "The containerName or NodeId or Configuration name is not found"),
-        @ResponseCode(code = 503, condition = "One or more of Controller Services are unavailable") })
-    public FlowConfig getStaticFlow(@PathParam("containerName") String containerName,
-            @PathParam("nodeType") String nodeType, @PathParam("nodeId") String nodeId, @PathParam("name") String name) {
-        if (!NorthboundUtils.isAuthorized(getUserName(), containerName, Privilege.READ, this)) {
-            throw new UnauthorizedException("User is not authorized to perform this operation on container "
-                    + containerName);
-        }
-        IForwardingRulesManager frm = getForwardingRulesManagerService(containerName);
-
-        if (frm == null) {
-            throw new ServiceUnavailableException("Flow Programmer " + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        Node node = handleNodeAvailability(containerName, nodeType, nodeId);
-
-        FlowConfig staticFlow = frm.getStaticFlow(name, node);
-        if (staticFlow == null) {
-            throw new ResourceNotFoundException(RestMessages.NOFLOW.toString());
-        }
-
-        return new FlowConfig(staticFlow);
-    }
-
-    /**
-     * Add or Modify a flow configuration. If the flow exists already, it will replace the current flow.
-     *
-     * @param containerName
-     *            Name of the Container (Eg. 'default')
-     * @param nodeType
-     *            Type of the node being programmed (Eg. 'OF')
-     * @param nodeId
-     *            Node Identifier (Eg. '00:00:00:00:00:00:00:01')
-     * @param name
-     *            Name of the Static Flow configuration (Eg. 'Flow2')
-     * @param FlowConfig
-     *            Flow Configuration in JSON or XML format
-     * @return Response as dictated by the HTTP Response Status code
-     *
-     *         <pre>
-     *
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/flowprogrammer/default/node/OF/00:00:00:00:00:00:00:01/staticFlow/flow1
-     *
-     * Request body in XML:
-     * &lt;flowConfig&gt;
-     *         &#x20;&#x20;&#x20;&lt;installInHw&gt;true&lt;/installInHw&gt;
-     *         &#x20;&#x20;&#x20;&lt;name&gt;flow1&lt;/name&gt;
-     *         &#x20;&#x20;&#x20;&lt;node&gt;
-     *             &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;id&gt;00:00:00:00:00:00:00:01&lt;/id&gt;
-     *             &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;type&gt;OF&lt;/type&gt;
-     *         &#x20;&#x20;&#x20;&lt;/node&gt;
-     *         &#x20;&#x20;&#x20;&lt;ingressPort&gt;1&lt;/ingressPort&gt;
-     *         &#x20;&#x20;&#x20;&lt;priority&gt;500&lt;/priority&gt;
-     *         &#x20;&#x20;&#x20;&lt;etherType&gt;0x800&lt;/etherType&gt;
-     *         &#x20;&#x20;&#x20;&lt;nwSrc&gt;9.9.1.1&lt;/nwSrc&gt;
-     *         &#x20;&#x20;&#x20;&lt;actions&gt;OUTPUT=2&lt;/actions&gt;
-     * &lt;/flowConfig&gt;
-     *
-     * Request body in JSON:
-      * {
-     *    "installInHw":"true",
-     *    "name":"flow1",
-     *    "node":{
-     *       "id":"00:00:00:00:00:00:00:01",
-     *       "type":"OF"
-     *    },
-     *    "ingressPort":"1",
-     *    "priority":"500",
-     *    "etherType":"0x800",
-     *    "nwSrc":"9.9.1.1",
-     *    "actions":[
-     *       "OUTPUT=2"
-     *    ]
-     * }
-     * </pre>
-     */
-
-    @Path("/{containerName}/node/{nodeType}/{nodeId}/staticFlow/{name}")
-    @PUT
-    @Consumes({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @StatusCodes({
-        @ResponseCode(code = 200, condition = "Static Flow modified successfully"),
-        @ResponseCode(code = 201, condition = "Flow Config processed successfully"),
-        @ResponseCode(code = 400, condition = "Failed to create Static Flow entry due to invalid flow configuration"),
-        @ResponseCode(code = 401, condition = "User not authorized to perform this operation"),
-        @ResponseCode(code = 404, condition = "The Container Name or nodeId is not found"),
-        @ResponseCode(code = 406, condition = "Cannot operate on Default Container when other Containers are active"),
-        @ResponseCode(code = 409, condition = "Failed to create Static Flow entry due to Conflicting Name or configuration"),
-        @ResponseCode(code = 500, condition = "Failed to create Static Flow entry. Failure Reason included in HTTP Error response"),
-        @ResponseCode(code = 503, condition = "One or more of Controller services are unavailable") })
-    public Response addOrModifyFlow(@PathParam(value = "containerName") String containerName,
-            @PathParam(value = "name") String name, @PathParam("nodeType") String nodeType,
-            @PathParam(value = "nodeId") String nodeId, @TypeHint(FlowConfig.class) FlowConfig flowConfig) {
-
-        if (!NorthboundUtils.isAuthorized(getUserName(), containerName, Privilege.WRITE, this)) {
-            throw new UnauthorizedException("User is not authorized to perform this operation on container "
-                    + containerName);
-        }
-
-        if (flowConfig.getNode() == null) {
-            return Response.status(Response.Status.BAD_REQUEST).entity("Invalid Configuration. Node is null or empty")
-                    .build();
-        }
-        handleResourceCongruence(name, flowConfig.getName());
-        handleResourceCongruence(nodeType, flowConfig.getNode().getType());
-        handleResourceCongruence(nodeId, flowConfig.getNode().getID() == null ? null : flowConfig.getNode().getNodeIDString());
-        handleDefaultDisabled(containerName);
-
-        IForwardingRulesManager frm = getForwardingRulesManagerService(containerName);
-
-        if (frm == null) {
-            throw new ServiceUnavailableException("Flow Programmer " + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        Node node = handleNodeAvailability(containerName, nodeType, nodeId);
-        Status status;
-
-        FlowConfig staticFlow = frm.getStaticFlow(name, node);
-
-        if (staticFlow == null) {
-          status = frm.addStaticFlow(flowConfig);
-          if(status.isSuccess()){
-              NorthboundUtils.auditlog("Flow Entry", username, "added",
-                      name + " on Node " + NorthboundUtils.getNodeDesc(node, containerName, this), containerName);
-              return Response.status(Response.Status.CREATED).entity("Success").build();
-          }
-        } else {
-          status = frm.modifyStaticFlow(flowConfig);
-          if(status.isSuccess()){
-              NorthboundUtils.auditlog("Flow Entry", username, "updated",
-                      name + " on Node " + NorthboundUtils.getNodeDesc(node, containerName, this), containerName);
-              return NorthboundUtils.getResponse(status);
-          }
-        }
-        return NorthboundUtils.getResponse(status);
-    }
-
-    /**
-     * Delete a Flow configuration
-     *
-     * @param containerName
-     *            Name of the Container (Eg. 'default')
-     * @param nodeType
-     *            Type of the node being programmed (Eg. 'OF')
-     * @param nodeId
-     *            Node Identifier (Eg. '00:00:00:00:00:00:00:01')
-     * @param name
-     *            Name of the Static Flow configuration (Eg. 'Flow1')
-     * @return Response as dictated by the HTTP Response code
-     *
-     *         <pre>
-     *
-     * Example:
-     *
-     * RequestURL:
-     * http://localhost:8080/controller/nb/v2/flowprogrammer/default/node/OF/00:00:00:00:00:00:00:01/staticFlow/flow1
-     *
-     * </pre>
-     */
-
-    @Path("/{containerName}/node/{nodeType}/{nodeId}/staticFlow/{name}")
-    @DELETE
-    @StatusCodes({
-        @ResponseCode(code = 204, condition = "Flow Config deleted successfully"),
-        @ResponseCode(code = 401, condition = "User not authorized to perform this operation"),
-        @ResponseCode(code = 404, condition = "The Container Name or Node-id or Flow Name passed is not found"),
-        @ResponseCode(code = 406, condition = "Failed to delete Flow config due to invalid operation. Failure details included in HTTP Error response"),
-        @ResponseCode(code = 500, condition = "Failed to delete Flow config. Failure Reason included in HTTP Error response"),
-        @ResponseCode(code = 503, condition = "One or more of Controller service is unavailable") })
-    public Response deleteFlow(@PathParam(value = "containerName") String containerName,
-            @PathParam(value = "name") String name, @PathParam("nodeType") String nodeType,
-            @PathParam(value = "nodeId") String nodeId) {
-
-        if (!NorthboundUtils.isAuthorized(getUserName(), containerName, Privilege.WRITE, this)) {
-            throw new UnauthorizedException("User is not authorized to perform this operation on container "
-                    + containerName);
-        }
-        handleDefaultDisabled(containerName);
-
-        IForwardingRulesManager frm = getForwardingRulesManagerService(containerName);
-
-        if (frm == null) {
-            throw new ServiceUnavailableException("Flow Programmer " + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        Node node = handleNodeAvailability(containerName, nodeType, nodeId);
-
-        FlowConfig staticFlow = frm.getStaticFlow(name, node);
-        if (staticFlow == null) {
-            throw new ResourceNotFoundException(name + " : " + RestMessages.NOFLOW.toString());
-        }
-
-        Status status = frm.removeStaticFlow(name, node);
-        if (status.isSuccess()) {
-            NorthboundUtils.auditlog("Flow Entry", username, "removed",
-                    name + " from Node " + NorthboundUtils.getNodeDesc(node, containerName, this), containerName);
-            return Response.noContent().build();
-        }
-        return NorthboundUtils.getResponse(status);
-    }
-
-    /**
-     * Toggle a Flow configuration
-     *
-     * @param containerName
-     *            Name of the Container (Eg. 'default')
-     * @param nodeType
-     *            Type of the node being programmed (Eg. 'OF')
-     * @param nodeId
-     *            Node Identifier (Eg. '00:00:00:00:00:00:00:01')
-     * @param name
-     *            Name of the Static Flow configuration (Eg. 'Flow1')
-     * @return Response as dictated by the HTTP Response code
-     *
-     *         <pre>
-     *
-     * Example:
-     *
-     * RequestURL:
-     * http://localhost:8080/controller/nb/v2/flowprogrammer/default/node/OF/00:00:00:00:00:00:00:01/staticFlow/flow1
-     *
-     * </pre>
-     */
-    @Path("/{containerName}/node/{nodeType}/{nodeId}/staticFlow/{name}")
-    @POST
-    @Consumes({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @StatusCodes({
-        @ResponseCode(code = 200, condition = "Flow Config processed successfully"),
-        @ResponseCode(code = 401, condition = "User not authorized to perform this operation"),
-        @ResponseCode(code = 404, condition = "The Container Name or Node-id or Flow Name passed is not found"),
-        @ResponseCode(code = 406, condition = "Failed to delete Flow config due to invalid operation. Failure details included in HTTP Error response"),
-        @ResponseCode(code = 500, condition = "Failed to delete Flow config. Failure Reason included in HTTP Error response"),
-        @ResponseCode(code = 503, condition = "One or more of Controller service is unavailable") })
-    public Response toggleFlow(@PathParam(value = "containerName") String containerName,
-            @PathParam("nodeType") String nodeType, @PathParam(value = "nodeId") String nodeId,
-            @PathParam(value = "name") String name) {
-
-        if (!NorthboundUtils.isAuthorized(getUserName(), containerName, Privilege.WRITE, this)) {
-            throw new UnauthorizedException("User is not authorized to perform this operation on container "
-                    + containerName);
-        }
-
-        handleDefaultDisabled(containerName);
-
-        IForwardingRulesManager frm = getForwardingRulesManagerService(containerName);
-
-        if (frm == null) {
-            throw new ServiceUnavailableException("Flow Programmer " + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        Node node = handleNodeAvailability(containerName, nodeType, nodeId);
-
-        FlowConfig staticFlow = frm.getStaticFlow(name, node);
-        if (staticFlow == null) {
-            throw new ResourceNotFoundException(name + " : " + RestMessages.NOFLOW.toString());
-        }
-
-        Status status = frm.toggleStaticFlowStatus(staticFlow);
-        if (status.isSuccess()) {
-            NorthboundUtils.auditlog("Flow Entry", username, "toggled",
-                    name + " on Node " + NorthboundUtils.getNodeDesc(node, containerName, this), containerName);
-        }
-        return NorthboundUtils.getResponse(status);
-    }
-
-    private Node handleNodeAvailability(String containerName, String nodeType, String nodeId) {
-
-        Node node = Node.fromString(nodeType, nodeId);
-        if (node == null) {
-            throw new ResourceNotFoundException(nodeId + " : " + RestMessages.NONODE.toString());
-        }
-
-        ISwitchManager sm = (ISwitchManager) ServiceHelper.getInstance(ISwitchManager.class, containerName, this);
-
-        if (sm == null) {
-            throw new ServiceUnavailableException("Switch Manager " + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        if (!sm.getNodes().contains(node)) {
-            throw new ResourceNotFoundException(node.toString() + " : " + RestMessages.NONODE.toString());
-        }
-        return node;
-    }
-
-    private void handleDefaultDisabled(String containerName) {
-        IContainerManager containerManager = (IContainerManager) ServiceHelper.getGlobalInstance(
-                IContainerManager.class, this);
-        if (containerManager == null) {
-            throw new InternalServerErrorException(RestMessages.INTERNALERROR.toString());
-        }
-        if (containerName.equals(GlobalConstants.DEFAULT.toString()) && containerManager.hasNonDefaultContainer()) {
-            throw new NotAcceptableException(RestMessages.DEFAULTDISABLED.toString());
-        }
-    }
-
-    private void handleResourceCongruence(String resource, String configured) {
-        if (!resource.equals(configured)) {
-            throw new MethodNotAllowedException("Path's resource name conflicts with payload's resource name");
-        }
-    }
-
-}
diff --git a/opendaylight/adsal/northbound/flowprogrammer/src/main/resources/META-INF/spring.factories b/opendaylight/adsal/northbound/flowprogrammer/src/main/resources/META-INF/spring.factories
deleted file mode 100644 (file)
index 93db02e..0000000
+++ /dev/null
@@ -1 +0,0 @@
-org.springframework.beans.BeanInfoFactory=org.springframework.beans.ExtendedBeanInfoFactory
diff --git a/opendaylight/adsal/northbound/flowprogrammer/src/main/resources/META-INF/spring.handlers b/opendaylight/adsal/northbound/flowprogrammer/src/main/resources/META-INF/spring.handlers
deleted file mode 100644 (file)
index 957af91..0000000
+++ /dev/null
@@ -1,10 +0,0 @@
-http\://www.springframework.org/schema/context=org.springframework.context.config.ContextNamespaceHandler
-http\://www.springframework.org/schema/jee=org.springframework.ejb.config.JeeNamespaceHandler
-http\://www.springframework.org/schema/lang=org.springframework.scripting.config.LangNamespaceHandler
-http\://www.springframework.org/schema/task=org.springframework.scheduling.config.TaskNamespaceHandler
-http\://www.springframework.org/schema/cache=org.springframework.cache.config.CacheNamespaceHandler
-http\://www.springframework.org/schema/c=org.springframework.beans.factory.xml.SimpleConstructorNamespaceHandler
-http\://www.springframework.org/schema/p=org.springframework.beans.factory.xml.SimplePropertyNamespaceHandler
-http\://www.springframework.org/schema/util=org.springframework.beans.factory.xml.UtilNamespaceHandler
-http\://www.springframework.org/schema/mvc=org.springframework.web.servlet.config.MvcNamespaceHandler
-http\://www.springframework.org/schema/security=org.springframework.security.config.SecurityNamespaceHandler
diff --git a/opendaylight/adsal/northbound/flowprogrammer/src/main/resources/META-INF/spring.schemas b/opendaylight/adsal/northbound/flowprogrammer/src/main/resources/META-INF/spring.schemas
deleted file mode 100644 (file)
index d865edc..0000000
+++ /dev/null
@@ -1,49 +0,0 @@
-http\://www.springframework.org/schema/beans/spring-beans-2.0.xsd=org/springframework/beans/factory/xml/spring-beans-2.0.xsd
-http\://www.springframework.org/schema/beans/spring-beans-2.5.xsd=org/springframework/beans/factory/xml/spring-beans-2.5.xsd
-http\://www.springframework.org/schema/beans/spring-beans-3.0.xsd=org/springframework/beans/factory/xml/spring-beans-3.0.xsd
-http\://www.springframework.org/schema/beans/spring-beans-3.1.xsd=org/springframework/beans/factory/xml/spring-beans-3.1.xsd
-http\://www.springframework.org/schema/beans/spring-beans-3.2.xsd=org/springframework/beans/factory/xml/spring-beans-3.2.xsd
-http\://www.springframework.org/schema/beans/spring-beans.xsd=org/springframework/beans/factory/xml/spring-beans-3.2.xsd
-http\://www.springframework.org/schema/tool/spring-tool-2.0.xsd=org/springframework/beans/factory/xml/spring-tool-2.0.xsd
-http\://www.springframework.org/schema/tool/spring-tool-2.5.xsd=org/springframework/beans/factory/xml/spring-tool-2.5.xsd
-http\://www.springframework.org/schema/tool/spring-tool-3.0.xsd=org/springframework/beans/factory/xml/spring-tool-3.0.xsd
-http\://www.springframework.org/schema/tool/spring-tool-3.1.xsd=org/springframework/beans/factory/xml/spring-tool-3.1.xsd
-http\://www.springframework.org/schema/tool/spring-tool-3.2.xsd=org/springframework/beans/factory/xml/spring-tool-3.2.xsd
-http\://www.springframework.org/schema/tool/spring-tool.xsd=org/springframework/beans/factory/xml/spring-tool-3.2.xsd
-http\://www.springframework.org/schema/util/spring-util-2.0.xsd=org/springframework/beans/factory/xml/spring-util-2.0.xsd
-http\://www.springframework.org/schema/util/spring-util-2.5.xsd=org/springframework/beans/factory/xml/spring-util-2.5.xsd
-http\://www.springframework.org/schema/util/spring-util-3.0.xsd=org/springframework/beans/factory/xml/spring-util-3.0.xsd
-http\://www.springframework.org/schema/util/spring-util-3.1.xsd=org/springframework/beans/factory/xml/spring-util-3.1.xsd
-http\://www.springframework.org/schema/util/spring-util-3.2.xsd=org/springframework/beans/factory/xml/spring-util-3.2.xsd
-http\://www.springframework.org/schema/util/spring-util.xsd=org/springframework/beans/factory/xml/spring-util-3.2.xsd
-http\://www.springframework.org/schema/context/spring-context-2.5.xsd=org/springframework/context/config/spring-context-2.5.xsd
-http\://www.springframework.org/schema/context/spring-context-3.0.xsd=org/springframework/context/config/spring-context-3.0.xsd
-http\://www.springframework.org/schema/context/spring-context-3.1.xsd=org/springframework/context/config/spring-context-3.1.xsd
-http\://www.springframework.org/schema/context/spring-context-3.2.xsd=org/springframework/context/config/spring-context-3.2.xsd
-http\://www.springframework.org/schema/context/spring-context.xsd=org/springframework/context/config/spring-context-3.2.xsd
-http\://www.springframework.org/schema/jee/spring-jee-2.0.xsd=org/springframework/ejb/config/spring-jee-2.0.xsd
-http\://www.springframework.org/schema/jee/spring-jee-2.5.xsd=org/springframework/ejb/config/spring-jee-2.5.xsd
-http\://www.springframework.org/schema/jee/spring-jee-3.0.xsd=org/springframework/ejb/config/spring-jee-3.0.xsd
-http\://www.springframework.org/schema/jee/spring-jee-3.1.xsd=org/springframework/ejb/config/spring-jee-3.1.xsd
-http\://www.springframework.org/schema/jee/spring-jee-3.2.xsd=org/springframework/ejb/config/spring-jee-3.2.xsd
-http\://www.springframework.org/schema/jee/spring-jee.xsd=org/springframework/ejb/config/spring-jee-3.2.xsd
-http\://www.springframework.org/schema/lang/spring-lang-2.0.xsd=org/springframework/scripting/config/spring-lang-2.0.xsd
-http\://www.springframework.org/schema/lang/spring-lang-2.5.xsd=org/springframework/scripting/config/spring-lang-2.5.xsd
-http\://www.springframework.org/schema/lang/spring-lang-3.0.xsd=org/springframework/scripting/config/spring-lang-3.0.xsd
-http\://www.springframework.org/schema/lang/spring-lang-3.1.xsd=org/springframework/scripting/config/spring-lang-3.1.xsd
-http\://www.springframework.org/schema/lang/spring-lang-3.2.xsd=org/springframework/scripting/config/spring-lang-3.2.xsd
-http\://www.springframework.org/schema/lang/spring-lang.xsd=org/springframework/scripting/config/spring-lang-3.2.xsd
-http\://www.springframework.org/schema/task/spring-task-3.0.xsd=org/springframework/scheduling/config/spring-task-3.0.xsd
-http\://www.springframework.org/schema/task/spring-task-3.1.xsd=org/springframework/scheduling/config/spring-task-3.1.xsd
-http\://www.springframework.org/schema/task/spring-task-3.2.xsd=org/springframework/scheduling/config/spring-task-3.2.xsd
-http\://www.springframework.org/schema/task/spring-task.xsd=org/springframework/scheduling/config/spring-task-3.2.xsd
-http\://www.springframework.org/schema/cache/spring-cache-3.1.xsd=org/springframework/cache/config/spring-cache-3.1.xsd
-http\://www.springframework.org/schema/cache/spring-cache-3.2.xsd=org/springframework/cache/config/spring-cache-3.2.xsd
-http\://www.springframework.org/schema/cache/spring-cache.xsd=org/springframework/cache/config/spring-cache-3.2.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd=org/springframework/web/servlet/config/spring-mvc-3.0.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc-3.1.xsd=org/springframework/web/servlet/config/spring-mvc-3.1.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc-3.2.xsd=org/springframework/web/servlet/config/spring-mvc-3.2.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc.xsd=org/springframework/web/servlet/config/spring-mvc-3.2.xsd
-http\://www.springframework.org/schema/security/spring-security-3.1.xsd=org/springframework/security/config/spring-security-3.1.xsd
-http\://www.springframework.org/schema/security/spring-security-3.2.xsd=org/springframework/security/config/spring-security-3.2.xsd
-
diff --git a/opendaylight/adsal/northbound/flowprogrammer/src/main/resources/META-INF/spring.tooling b/opendaylight/adsal/northbound/flowprogrammer/src/main/resources/META-INF/spring.tooling
deleted file mode 100644 (file)
index 057d834..0000000
+++ /dev/null
@@ -1,39 +0,0 @@
-# Tooling related information for the beans namespace
-http\://www.springframework.org/schema/beans@name=beans Namespace
-http\://www.springframework.org/schema/beans@prefix=beans
-http\://www.springframework.org/schema/beans@icon=org/springframework/beans/factory/xml/spring-beans.gif
-
-# Tooling related information for the util namespace
-http\://www.springframework.org/schema/util@name=util Namespace
-http\://www.springframework.org/schema/util@prefix=util
-http\://www.springframework.org/schema/util@icon=org/springframework/beans/factory/xml/spring-util.gif
-
-# Tooling related information for the context namespace
-http\://www.springframework.org/schema/context@name=context Namespace
-http\://www.springframework.org/schema/context@prefix=context
-http\://www.springframework.org/schema/context@icon=org/springframework/context/config/spring-context.gif
-
-# Tooling related information for the jee namespace
-http\://www.springframework.org/schema/jee@name=jee Namespace
-http\://www.springframework.org/schema/jee@prefix=jee
-http\://www.springframework.org/schema/jee@icon=org/springframework/ejb/config/spring-jee.gif
-
-# Tooling related information for the scheduling namespace
-http\://www.springframework.org/schema/task@name=task Namespace
-http\://www.springframework.org/schema/task@prefix=task
-http\://www.springframework.org/schema/task@icon=org/springframework/scheduling/config/spring-task.gif
-
-# Tooling related information for the lang namespace
-http\://www.springframework.org/schema/lang@name=lang Namespace
-http\://www.springframework.org/schema/lang@prefix=lang
-http\://www.springframework.org/schema/lang@icon=org/springframework/scripting/config/spring-lang.gif
-
-# Tooling related information for the cache namespace
-http\://www.springframework.org/schema/cache@name=cache Namespace
-http\://www.springframework.org/schema/cache@prefix=cache
-http\://www.springframework.org/schema/cache@icon=org/springframework/cache/config/spring-cache.gif
-
-# Tooling related information for the mvc namespace
-http\://www.springframework.org/schema/mvc@name=mvc Namespace
-http\://www.springframework.org/schema/mvc@prefix=mvc
-http\://www.springframework.org/schema/mvc@icon=org/springframework/web/servlet/config/spring-mvc.gif
diff --git a/opendaylight/adsal/northbound/flowprogrammer/src/main/resources/WEB-INF/web.xml b/opendaylight/adsal/northbound/flowprogrammer/src/main/resources/WEB-INF/web.xml
deleted file mode 100644 (file)
index 3154030..0000000
+++ /dev/null
@@ -1,90 +0,0 @@
-<?xml version="1.0" encoding="ISO-8859-1"?>
-<web-app xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
-        xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
-        version="3.0">
-
-        <servlet>
-          <servlet-name>JAXRSFlowProgrammer</servlet-name>
-          <servlet-class>com.sun.jersey.spi.container.servlet.ServletContainer</servlet-class>
-          <init-param>
-            <param-name>javax.ws.rs.Application</param-name>
-            <param-value>org.opendaylight.controller.northbound.commons.NorthboundApplication</param-value>
-          </init-param>
-          <load-on-startup>1</load-on-startup>
-        </servlet>
-
-        <servlet-mapping>
-          <servlet-name>JAXRSFlowProgrammer</servlet-name>
-          <url-pattern>/*</url-pattern>
-        </servlet-mapping>
-
-        <filter>
-          <filter-name>CorsFilter</filter-name>
-          <filter-class>org.apache.catalina.filters.CorsFilter</filter-class>
-          <init-param>
-            <param-name>cors.allowed.origins</param-name>
-            <param-value>*</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.allowed.methods</param-name>
-            <param-value>GET,POST,HEAD,OPTIONS,PUT,DELETE</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.allowed.headers</param-name>
-            <param-value>Content-Type,X-Requested-With,accept,authorization, origin,Origin,Access-Control-Request-Method,Access-Control-Request-Headers</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.exposed.headers</param-name>
-            <param-value>Access-Control-Allow-Origin,Access-Control-Allow-Credentials</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.support.credentials</param-name>
-            <param-value>true</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.preflight.maxage</param-name>
-            <param-value>10</param-value>
-          </init-param>
-        </filter>
-        <filter-mapping>
-          <filter-name>CorsFilter</filter-name>
-          <url-pattern>/*</url-pattern>
-        </filter-mapping>
-
-        <security-constraint>
-          <web-resource-collection>
-            <web-resource-name>NB api</web-resource-name>
-            <url-pattern>/*</url-pattern>
-            <http-method>POST</http-method>
-            <http-method>GET</http-method>
-            <http-method>PUT</http-method>
-            <http-method>PATCH</http-method>
-            <http-method>DELETE</http-method>
-            <http-method>HEAD</http-method>
-          </web-resource-collection>
-          <auth-constraint>
-            <role-name>System-Admin</role-name>
-            <role-name>Network-Admin</role-name>
-            <role-name>Network-Operator</role-name>
-            <role-name>Container-User</role-name>
-          </auth-constraint>
-        </security-constraint>
-
-    <security-role>
-                <role-name>System-Admin</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Network-Admin</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Network-Operator</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Container-User</role-name>
-        </security-role>
-
-        <login-config>
-                <auth-method>BASIC</auth-method>
-                <realm-name>opendaylight</realm-name>
-        </login-config>
-</web-app>
diff --git a/opendaylight/adsal/northbound/flowprogrammer/src/test/java/org/opendaylight/controller/flowprogrammer/northbound/FlowProgrammerNorthboundTest.java b/opendaylight/adsal/northbound/flowprogrammer/src/test/java/org/opendaylight/controller/flowprogrammer/northbound/FlowProgrammerNorthboundTest.java
deleted file mode 100644 (file)
index 10767e8..0000000
+++ /dev/null
@@ -1,40 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.flowprogrammer.northbound;
-
-import java.util.ArrayList;
-
-import org.junit.Assert;
-import org.junit.Test;
-import org.opendaylight.controller.forwardingrulesmanager.FlowConfig;
-
-public class FlowProgrammerNorthboundTest {
-
-    @Test
-    public void testFlowConfigs() {
-        FlowConfigs fc = new FlowConfigs(null);
-        Assert.assertNull(fc.getFlowConfig());
-
-        FlowConfig conf = new FlowConfig();
-        FlowConfig conf2 = new FlowConfig();
-        ArrayList<FlowConfig> list = new ArrayList<FlowConfig>();
-
-        list.add(conf);
-        list.add(conf2);
-        FlowConfigs fc2 = new FlowConfigs(list);
-        Assert.assertTrue(fc2.getFlowConfig().equals(list));
-
-        fc.setFlowConfig(list);
-        Assert.assertTrue(fc.getFlowConfig().equals(fc2.getFlowConfig()));
-
-        fc.setFlowConfig(null);
-        Assert.assertNull(fc.getFlowConfig());
-
-    }
-
-}
diff --git a/opendaylight/adsal/northbound/hosttracker/enunciate.xml b/opendaylight/adsal/northbound/hosttracker/enunciate.xml
deleted file mode 100644 (file)
index a8be00a..0000000
+++ /dev/null
@@ -1,12 +0,0 @@
-<?xml version="1.0"?>
-<enunciate label="full" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
-    xsi:noNamespaceSchemaLocation="http://enunciate.codehaus.org/schemas/enunciate-1.28.xsd">
-
-  <services>
-    <rest defaultRestSubcontext="/controller/nb/v2/hosttracker"/>
-  </services>
-
-  <modules>
-    <docs docsDir="rest" title="Host Tracker REST API" includeExampleXml="true" includeExampleJson="true"/>
-  </modules>
-</enunciate>
diff --git a/opendaylight/adsal/northbound/hosttracker/pom.xml b/opendaylight/adsal/northbound/hosttracker/pom.xml
deleted file mode 100644 (file)
index 9acd664..0000000
+++ /dev/null
@@ -1,91 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>adsal-enunciate-parent</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../adsal-enunciate-parent</relativePath>
-  </parent>
-  <artifactId>hosttracker.northbound</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.codehaus.enunciate</groupId>
-      <artifactId>enunciate-core-annotations</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>commons.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>containermanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>hosttracker</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>switchmanager</artifactId>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Import-Package>org.opendaylight.controller.hosttracker,
-              org.opendaylight.controller.hosttracker.hostAware,
-              org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.sal.utils,
-              org.opendaylight.controller.containermanager,
-              org.opendaylight.controller.switchmanager,
-              org.opendaylight.controller.usermanager,
-              org.apache.commons.logging,
-              com.sun.jersey.spi.container.servlet,
-              org.opendaylight.controller.northbound.commons,
-              org.opendaylight.controller.northbound.commons.exception,
-              org.opendaylight.controller.northbound.commons.query,
-              org.opendaylight.controller.northbound.commons.utils,
-              org.opendaylight.controller.sal.authorization,
-              org.opendaylight.controller.sal.packet.address,
-              javax.ws.rs,
-              javax.ws.rs.core,
-              javax.ws.rs.ext,
-              javax.xml.bind.annotation,
-              javax.xml.bind,
-              org.slf4j,
-              org.apache.catalina.filters,
-              com.fasterxml.jackson.jaxrs.base,
-              com.fasterxml.jackson.jaxrs.json,
-              !org.codehaus.enunciate.jaxrs</Import-Package>
-            <Web-ContextPath>/controller/nb/v2/hosttracker</Web-ContextPath>
-            <Jaxrs-Resources>,${classes;ANNOTATION;javax.ws.rs.Path}</Jaxrs-Resources>
-          </instructions>
-          <manifestLocation>${project.basedir}/src/main/resources/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/northbound/hosttracker/src/main/java/org/opendaylight/controller/hosttracker/northbound/HostConfig.java b/opendaylight/adsal/northbound/hosttracker/src/main/java/org/opendaylight/controller/hosttracker/northbound/HostConfig.java
deleted file mode 100644 (file)
index b66da34..0000000
+++ /dev/null
@@ -1,113 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.hosttracker.northbound;
-
-import java.io.Serializable;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.hosttracker.hostAware.HostNodeConnector;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.packet.address.DataLinkAddress;
-import org.opendaylight.controller.sal.packet.address.EthernetAddress;
-
-/**
- * Configuration Java Object which represents a Host configuration information
- * for HostTracker.
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-public class HostConfig implements Serializable {
-    private static final long serialVersionUID = 1L;
-
-    @XmlElement
-    public String dataLayerAddress;
-    @XmlElement
-    private String nodeType;
-    @XmlElement
-    private String nodeId;
-    @XmlElement
-    private String nodeConnectorType;
-    @XmlElement
-    private String nodeConnectorId;
-    @XmlElement
-    private String vlan;
-    @XmlElement
-    private boolean staticHost;
-    @XmlElement
-    private String networkAddress;
-
-    public HostConfig() {
-
-    }
-
-    protected String getDataLayerAddress() {
-        return this.dataLayerAddress;
-    }
-
-    protected String getNodeType() {
-        return this.nodeType;
-    }
-
-    protected String getNodeId() {
-        return this.nodeId;
-    }
-
-    protected String getNodeConnectorType() {
-        return this.nodeConnectorType;
-    }
-
-    protected String getNodeConnectorId() {
-        return this.nodeConnectorId;
-    }
-
-    protected String getVlan() {
-        return this.vlan;
-    }
-
-    protected boolean isStaticHost() {
-        return staticHost;
-    }
-
-    protected String getNetworkAddress() {
-        return networkAddress;
-    }
-
-    public static HostConfig convert(HostNodeConnector hnc) {
-        if(hnc == null) {
-            return null;
-        }
-        HostConfig hc = new HostConfig();
-        DataLinkAddress dl = hnc.getDataLayerAddress();
-        if(dl instanceof EthernetAddress) {
-            EthernetAddress et = (EthernetAddress) dl;
-            hc.dataLayerAddress = et.getMacAddress();
-        } else {
-            hc.dataLayerAddress = dl.getName();
-        }
-        NodeConnector nc = hnc.getnodeConnector();
-        if(nc != null) {
-            hc.nodeConnectorType = nc.getType();
-            hc.nodeConnectorId = nc.getNodeConnectorIDString();
-            Node n = hnc.getnodeconnectorNode();
-            if(n != null) {
-                hc.nodeType = n.getType();
-                hc.nodeId = n.getNodeIDString();
-            }
-        }
-        hc.vlan = String.valueOf(hnc.getVlan());
-        hc.staticHost = hnc.isStaticHost();
-        hc.networkAddress = hnc.getNetworkAddressAsString();
-        return hc;
-    }
-}
diff --git a/opendaylight/adsal/northbound/hosttracker/src/main/java/org/opendaylight/controller/hosttracker/northbound/HostTrackerNorthbound.java b/opendaylight/adsal/northbound/hosttracker/src/main/java/org/opendaylight/controller/hosttracker/northbound/HostTrackerNorthbound.java
deleted file mode 100644 (file)
index 3769cc7..0000000
+++ /dev/null
@@ -1,569 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.hosttracker.northbound;
-
-import java.net.InetAddress;
-import java.net.UnknownHostException;
-import java.util.HashSet;
-import java.util.List;
-import java.util.Set;
-
-import javax.ws.rs.Consumes;
-import javax.ws.rs.DELETE;
-import javax.ws.rs.GET;
-import javax.ws.rs.PUT;
-import javax.ws.rs.Path;
-import javax.ws.rs.PathParam;
-import javax.ws.rs.Produces;
-import javax.ws.rs.QueryParam;
-import javax.ws.rs.core.Context;
-import javax.ws.rs.core.MediaType;
-import javax.ws.rs.core.Response;
-import javax.ws.rs.core.SecurityContext;
-import javax.ws.rs.core.UriInfo;
-import javax.ws.rs.ext.ContextResolver;
-
-import org.codehaus.enunciate.jaxrs.ResponseCode;
-import org.codehaus.enunciate.jaxrs.StatusCodes;
-import org.codehaus.enunciate.jaxrs.TypeHint;
-import org.opendaylight.controller.containermanager.IContainerManager;
-import org.opendaylight.controller.hosttracker.IfIptoHost;
-import org.opendaylight.controller.hosttracker.hostAware.HostNodeConnector;
-import org.opendaylight.controller.northbound.commons.RestMessages;
-import org.opendaylight.controller.northbound.commons.exception.BadRequestException;
-import org.opendaylight.controller.northbound.commons.exception.ResourceConflictException;
-import org.opendaylight.controller.northbound.commons.exception.ResourceNotFoundException;
-import org.opendaylight.controller.northbound.commons.exception.ServiceUnavailableException;
-import org.opendaylight.controller.northbound.commons.exception.UnauthorizedException;
-import org.opendaylight.controller.northbound.commons.query.QueryContext;
-import org.opendaylight.controller.northbound.commons.utils.NorthboundUtils;
-import org.opendaylight.controller.sal.authorization.Privilege;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.utils.GlobalConstants;
-import org.opendaylight.controller.sal.utils.ServiceHelper;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.switchmanager.ISwitchManager;
-
-/**
- * Host Tracker Northbound REST APIs.<br>
- * This class provides REST APIs to track host location in a network. Host
- * Location is represented by Host node connector which is essentially a logical
- * entity that represents a Switch/Port. A host is represented by it's
- * IP-address and mac-address.
- *
- * <br>
- * <br>
- * Authentication scheme : <b>HTTP Basic</b><br>
- * Authentication realm : <b>opendaylight</b><br>
- * Transport : <b>HTTP and HTTPS</b><br>
- * <br>
- * HTTPS Authentication is disabled by default.
- *
- */
-
-@Path("/")
-public class HostTrackerNorthbound {
-
-    private String username;
-    private QueryContext queryContext;
-
-    @Context
-    public void setQueryContext(ContextResolver<QueryContext> queryCtxResolver) {
-      if (queryCtxResolver != null) {
-        queryContext = queryCtxResolver.getContext(QueryContext.class);
-      }
-    }
-
-    @Context
-    public void setSecurityContext(SecurityContext context) {
-        if (context != null && context.getUserPrincipal() != null) {
-            username = context.getUserPrincipal().getName();
-        }
-    }
-
-    protected String getUserName() {
-        return username;
-    }
-
-    private IfIptoHost getIfIpToHostService(String containerName) {
-        IContainerManager containerManager = (IContainerManager) ServiceHelper.getGlobalInstance(
-                IContainerManager.class, this);
-        if (containerManager == null) {
-            throw new ServiceUnavailableException("Container " + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        boolean found = false;
-        List<String> containerNames = containerManager.getContainerNames();
-        for (String cName : containerNames) {
-            if (cName.trim().equalsIgnoreCase(containerName.trim())) {
-                found = true;
-                break;
-            }
-        }
-
-        if (!found) {
-            throw new ResourceNotFoundException(containerName + " " + RestMessages.NOCONTAINER.toString());
-        }
-
-        IfIptoHost hostTracker = (IfIptoHost) ServiceHelper.getInstance(IfIptoHost.class, containerName, this);
-        if (hostTracker == null) {
-            throw new ServiceUnavailableException("Host Tracker " + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        return hostTracker;
-    }
-
-    private Set<HostConfig> convertHosts(Set<HostNodeConnector> hostNodeConnectors) {
-        if(hostNodeConnectors == null) {
-            return null;
-        }
-        Set<HostConfig> hosts = new HashSet<HostConfig>();
-        for(HostNodeConnector hnc : hostNodeConnectors) {
-            hosts.add(HostConfig.convert(hnc));
-        }
-        return hosts;
-    }
-
-    /**
-     * Returns a list of all Hosts : both configured via PUT API and dynamically
-     * learnt on the network.
-     *
-     * @param containerName
-     *            Name of the Container. The Container name for the base
-     *            controller is "default".
-     * @return List of Active Hosts.
-     * <pre>
-     *
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/hosttracker/default/hosts/active
-     *
-     * Response body in XML
-     *
-     * &lt;list&gt;
-     * &#x20;&lt;hostConfig&gt;
-     * &#x20;&#x20;&lt;dataLayerAddress&gt;00:00:00:00:01:01&lt;/dataLayerAddress&gt;
-     * &#x20;&#x20;&lt;networkAddress&gt;1.1.1.1&lt;/networkAddress&gt;
-     * &#x20;&#x20;&lt;nodeType&gt;OF&lt;/nodeType&gt;
-     * &#x20;&#x20;&lt;nodeId&gt;00:00:00:00:00:00:00:01&lt;/nodeId&gt;
-     * &#x20;&#x20;&lt;nodeConnectorType&gt;OF&lt;/nodeConnectorType&gt;
-     * &#x20;&#x20;&lt;nodeConnectorId&gt;9&lt;/nodeConnectorId&gt;
-     * &#x20;&#x20;&lt;vlan&gt;0&lt;/vlan&gt;
-     * &#x20;&#x20;&lt;staticHost&gt;false&lt;/staticHost&gt;
-     * &#x20;&lt;/hostConfig&gt;
-     * &#x20;&lt;hostConfig&gt;
-     * &#x20;&#x20;&lt;dataLayerAddress&gt;00:00:00:00:02:02&lt;/dataLayerAddress&gt;
-     * &#x20;&#x20;&lt;networkAddress&gt;2.2.2.2&lt;/networkAddress&gt;
-     * &#x20;&#x20;&lt;nodeType&gt;OF&lt;/nodeType&gt;
-     * &#x20;&#x20;&lt;nodeId&gt;00:00:00:00:00:00:00:02&lt;/nodeId&gt;
-     * &#x20;&#x20;&lt;nodeConnectorType&gt;OF&lt;/nodeConnectorType&gt;
-     * &#x20;&#x20;&lt;nodeConnectorId&gt;5&lt;/nodeConnectorId&gt;
-     * &#x20;&#x20;&lt;vlan&gt;0&lt;/vlan&gt;
-     * &#x20;&#x20;&lt;staticHost&gt;false&lt;/staticHost&gt;
-     * &#x20;&lt;/hostConfig&gt;
-     * &lt;/list&gt;
-     *
-     * Response body in JSON:
-     *
-     * {
-     * &#x20;"hostConfig":[
-     * &#x20;&#x20;{
-     * &#x20;&#x20;&#x20;"dataLayerAddress":"00:00:00:00:01:01",
-     * &#x20;&#x20;&#x20;"nodeType":"OF",
-     * &#x20;&#x20;&#x20;"nodeId":"00:00:00:00:00:00:00:01",
-     * &#x20;&#x20;&#x20;"nodeConnectorType":"OF",
-     * &#x20;&#x20;&#x20;"nodeConnectorId":"9",
-     * &#x20;&#x20;&#x20;"vlan":"0",
-     * &#x20;&#x20;&#x20;"staticHost":"false",
-     * &#x20;&#x20;&#x20;"networkAddress":"1.1.1.1"
-     * &#x20;&#x20;},
-     * &#x20;&#x20;{
-     * &#x20;&#x20;&#x20;"dataLayerAddress":"00:00:00:00:02:02",
-     * &#x20;&#x20;&#x20;"nodeType":"OF",
-     * &#x20;&#x20;&#x20;"nodeId":"00:00:00:00:00:00:00:02",
-     * &#x20;&#x20;&#x20;"nodeConnectorType":"OF",
-     * &#x20;&#x20;&#x20;"nodeConnectorId":"5",
-     * &#x20;&#x20;&#x20;"vlan":"0",
-     * &#x20;&#x20;&#x20;"staticHost":"false",
-     * &#x20;&#x20;&#x20;"networkAddress":"2.2.2.2"
-     * &#x20;&#x20;}
-     * &#x20;]
-     * }
-     * </pre>
-     */
-    @Path("/{containerName}/hosts/active")
-    @GET
-    @Produces({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @TypeHint(Hosts.class)
-    @StatusCodes({
-            @ResponseCode(code = 200, condition = "Operation successful"),
-            @ResponseCode(code = 404, condition = "The containerName is not found"),
-            @ResponseCode(code = 503, condition = "One or more of Controller Services are unavailable") })
-    public Hosts getActiveHosts(@PathParam("containerName") String containerName,
-        @QueryParam("_q") String queryString) {
-
-        if (!NorthboundUtils.isAuthorized(getUserName(), containerName, Privilege.READ, this)) {
-            throw new UnauthorizedException("User is not authorized to perform this operation on container "
-                    + containerName);
-        }
-        IfIptoHost hostTracker = getIfIpToHostService(containerName);
-        Hosts hosts = new Hosts(convertHosts(hostTracker.getAllHosts()));
-        if (queryString != null) {
-            queryContext.createQuery(queryString, Hosts.class)
-                .filter(hosts, HostConfig.class);
-        }
-        return hosts;
-    }
-
-    /**
-     * Returns a list of Hosts that are statically configured and are connected
-     * to a NodeConnector that is down.
-     *
-     * @param containerName
-     *            Name of the Container. The Container name for the base
-     *            controller is "default".
-     * @return List of inactive Hosts.
-     * <pre>
-     *
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/hosttracker/default/hosts/inactive
-     *
-     * Response body in XML
-     *
-     * &lt;list&gt;
-     * &#x20;&lt;hostConfig&gt;
-     * &#x20;&#x20;&lt;dataLayerAddress&gt;00:00:00:00:01:01&lt;/dataLayerAddress&gt;
-     * &#x20;&#x20;&lt;networkAddress&gt;1.1.1.1&lt;/networkAddress&gt;
-     * &#x20;&#x20;&lt;nodeType&gt;OF&lt;/nodeType&gt;
-     * &#x20;&#x20;&lt;nodeId&gt;00:00:00:00:00:00:00:01&lt;/nodeId&gt;
-     * &#x20;&#x20;&lt;nodeConnectorType&gt;OF&lt;/nodeConnectorType&gt;
-     * &#x20;&#x20;&lt;nodeConnectorId&gt;9&lt;/nodeConnectorId&gt;
-     * &#x20;&#x20;&lt;vlan&gt;0&lt;/vlan&gt;
-     * &#x20;&#x20;&lt;staticHost&gt;false&lt;/staticHost&gt;
-     * &#x20;&lt;/hostConfig&gt;
-     * &#x20;&lt;hostConfig&gt;
-     * &#x20;&#x20;&lt;dataLayerAddress&gt;00:00:00:00:02:02&lt;/dataLayerAddress&gt;
-     * &#x20;&#x20;&lt;networkAddress&gt;2.2.2.2&lt;/networkAddress&gt;
-     * &#x20;&#x20;&lt;nodeType&gt;OF&lt;/nodeType&gt;
-     * &#x20;&#x20;&lt;nodeId&gt;00:00:00:00:00:00:00:02&lt;/nodeId&gt;
-     * &#x20;&#x20;&lt;nodeConnectorType&gt;OF&lt;/nodeConnectorType&gt;
-     * &#x20;&#x20;&lt;nodeConnectorId&gt;5&lt;/nodeConnectorId&gt;
-     * &#x20;&#x20;&lt;vlan&gt;0&lt;/vlan&gt;
-     * &#x20;&#x20;&lt;staticHost&gt;false&lt;/staticHost&gt;
-     * &#x20;&lt;/hostConfig&gt;
-     * &lt;/list&gt;
-     *
-     * Response body in JSON:
-     *
-     * {
-     * &#x20;"hostConfig":[
-     * &#x20;&#x20;{
-     * &#x20;&#x20;&#x20;"dataLayerAddress":"00:00:00:00:01:01",
-     * &#x20;&#x20;&#x20;"nodeType":"OF",
-     * &#x20;&#x20;&#x20;"nodeId":"00:00:00:00:00:00:00:01",
-     * &#x20;&#x20;&#x20;"nodeConnectorType":"OF",
-     * &#x20;&#x20;&#x20;"nodeConnectorId":"9",
-     * &#x20;&#x20;&#x20;"vlan":"0",
-     * &#x20;&#x20;&#x20;"staticHost":"false",
-     * &#x20;&#x20;&#x20;"networkAddress":"1.1.1.1"
-     * &#x20;&#x20;},
-     * &#x20;&#x20;{
-     * &#x20;&#x20;&#x20;"dataLayerAddress":"00:00:00:00:02:02",
-     * &#x20;&#x20;&#x20;"nodeType":"OF",
-     * &#x20;&#x20;&#x20;"nodeId":"00:00:00:00:00:00:00:02",
-     * &#x20;&#x20;&#x20;"nodeConnectorType":"OF",
-     * &#x20;&#x20;&#x20;"nodeConnectorId":"5",
-     * &#x20;&#x20;&#x20;"vlan":"0",
-     * &#x20;&#x20;&#x20;"staticHost":"false",
-     * &#x20;&#x20;&#x20;"networkAddress":"2.2.2.2"
-     * &#x20;&#x20;}
-     * &#x20;]
-     * }
-     * </pre>
-     */
-    @Path("/{containerName}/hosts/inactive")
-    @GET
-    @Produces({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @TypeHint(Hosts.class)
-    @StatusCodes({
-            @ResponseCode(code = 200, condition = "Operation successful"),
-            @ResponseCode(code = 404, condition = "The containerName is not found"),
-            @ResponseCode(code = 503, condition = "One or more of Controller Services are unavailable") })
-    public Hosts getInactiveHosts(
-            @PathParam("containerName") String containerName,
-            @QueryParam("_q") String queryString) {
-        if (!NorthboundUtils.isAuthorized(getUserName(), containerName, Privilege.READ, this)) {
-            throw new UnauthorizedException("User is not authorized to perform this operation on container "
-                    + containerName);
-        }
-        IfIptoHost hostTracker = getIfIpToHostService(containerName);
-        Hosts hosts = new Hosts(convertHosts(hostTracker.getInactiveStaticHosts()));
-        if (queryString != null) {
-            queryContext.createQuery(queryString, Hosts.class)
-                .filter(hosts, HostConfig.class);
-        }
-        return hosts;
-    }
-
-    /**
-     * Returns a host that matches the IP Address value passed as parameter.
-     *
-     * @param containerName
-     *            Name of the Container. The Container name for the base
-     *            controller is "default".
-     * @param networkAddress
-     *            IP Address being looked up
-     * @return host that matches the IP Address
-     * <pre>
-     *
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/hosttracker/default/address/1.1.1.1
-     *
-     * Response body in XML
-     *
-     * &lt;hostConfig&gt;
-     * &#x20;&lt;dataLayerAddress&gt;00:00:00:00:01:01&lt;/dataLayerAddress&gt;
-     * &#x20;&lt;networkAddress&gt;1.1.1.1&lt;/networkAddress&gt;
-     * &#x20;&lt;nodeType&gt;OF&lt;/nodeType&gt;
-     * &#x20;&lt;nodeId&gt;00:00:00:00:00:00:00:01&lt;/nodeId&gt;
-     * &#x20;&lt;nodeConnectorType&gt;OF&lt;/nodeConnectorType&gt;
-     * &#x20;&lt;nodeConnectorId&gt;9&lt;/nodeConnectorId&gt;
-     * &#x20;&lt;vlan&gt;0&lt;/vlan&gt;
-     * &#x20;&lt;staticHost&gt;false&lt;/staticHost&gt;
-     * &lt;/hostConfig&gt;
-     *
-     * Response body in JSON:
-     *
-     * {
-     * &#x20;"dataLayerAddress":"00:00:00:00:01:01",
-     * &#x20;"nodeType":"OF",
-     * &#x20;"nodeId":"00:00:00:00:00:00:00:01",
-     * &#x20;"nodeConnectorType":"OF",
-     * &#x20;"nodeConnectorId":"9",
-     * &#x20;"vlan":"0",
-     * &#x20;"staticHost":"false",
-     * &#x20;"networkAddress":"1.1.1.1"
-     * }
-     * </pre>
-     */
-    @Path("/{containerName}/address/{networkAddress}")
-    @GET
-    @Produces({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @TypeHint(HostConfig.class)
-    @StatusCodes({
-            @ResponseCode(code = 200, condition = "Operation successful"),
-            @ResponseCode(code = 400, condition = "Invalid IP specified in networkAddress parameter"),
-            @ResponseCode(code = 404, condition = "The containerName is not found"),
-            @ResponseCode(code = 503, condition = "One or more of Controller Services are unavailable") })
-    public HostConfig getHostDetails(
-            @PathParam("containerName") String containerName,
-            @PathParam("networkAddress") String networkAddress) {
-        if (!NorthboundUtils.isAuthorized(getUserName(), containerName, Privilege.READ, this)) {
-            throw new UnauthorizedException("User is not authorized to perform this operation on container "
-                    + containerName);
-        }
-        IfIptoHost hostTracker = getIfIpToHostService(containerName);
-
-        InetAddress ip;
-        try {
-            ip = InetAddress.getByName(networkAddress);
-        } catch (UnknownHostException e) {
-            throw new BadRequestException(RestMessages.INVALIDADDRESS.toString() + " " + networkAddress);
-        }
-        for (HostNodeConnector host : hostTracker.getAllHosts()) {
-            if (host.getNetworkAddress().equals(ip)) {
-                return HostConfig.convert(host);
-            }
-        }
-        throw new ResourceNotFoundException(RestMessages.NOHOST.toString());
-    }
-
-    /**
-     * Add a Static Host configuration. If a host by the given address already
-     * exists, this method will respond with a non-successful status response.
-     *
-     * @param containerName
-     *            Name of the Container. The Container name for the base
-     *            controller is "default".
-     * @param networkAddress
-     *            Host IP Address
-     * @param hostConfig
-     *            Host Config Details
-     * @return Response as dictated by the HTTP Response Status code
-     *
-     * <pre>
-     *
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/hosttracker/default/address/1.1.1.1
-     *
-     * Request body in XML
-     *
-     * &lt;hostConfig&gt;
-     * &#x20;&lt;dataLayerAddress&gt;00:00:00:00:01:01&lt;/dataLayerAddress&gt;
-     * &#x20;&lt;networkAddress&gt;1.1.1.1&lt;/networkAddress&gt;
-     * &#x20;&lt;nodeType&gt;OF&lt;/nodeType&gt;
-     * &#x20;&lt;nodeId&gt;00:00:00:00:00:00:00:01&lt;/nodeId&gt;
-     * &#x20;&lt;nodeConnectorType&gt;OF&lt;/nodeConnectorType&gt;
-     * &#x20;&lt;nodeConnectorId&gt;9&lt;/nodeConnectorId&gt;
-     * &#x20;&lt;vlan&gt;1&lt;/vlan&gt;
-     * &#x20;&lt;staticHost&gt;true&lt;/staticHost&gt;
-     * &lt;/hostConfig&gt;
-     *
-     * Request body in JSON:
-     *
-     * {
-     * &#x20;"dataLayerAddress":"00:00:00:00:01:01",
-     * &#x20;"nodeType":"OF",
-     * &#x20;"nodeId":"00:00:00:00:00:00:00:01",
-     * &#x20;"nodeConnectorType":"OF",
-     * &#x20;"nodeConnectorId":"9",
-     * &#x20;"vlan":"1",
-     * &#x20;"staticHost":"true",
-     * &#x20;"networkAddress":"1.1.1.1"
-     * }
-     * </pre>
-     */
-
-    @Path("/{containerName}/address/{networkAddress}")
-    @PUT
-    @Consumes({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @StatusCodes({
-            @ResponseCode(code = 201, condition = "Static host created successfully"),
-            @ResponseCode(code = 400, condition = "Invalid parameters specified, see response body for details"),
-            @ResponseCode(code = 404, condition = "The container or resource is not found"),
-            @ResponseCode(code = 409, condition = "Resource conflict, see response body for details"),
-            @ResponseCode(code = 503, condition = "One or more of Controller services are unavailable") })
-    public Response addHost(@Context UriInfo uriInfo, @PathParam("containerName") String containerName,
-            @PathParam("networkAddress") String networkAddress,
-            @TypeHint(HostConfig.class) HostConfig hostConfig) {
-
-        if (!NorthboundUtils.isAuthorized(getUserName(), containerName, Privilege.WRITE, this)) {
-            return Response.status(Response.Status.UNAUTHORIZED)
-                    .entity("User is not authorized to perform this operation on container " + containerName)
-                    .build();
-        }
-        handleDefaultDisabled(containerName);
-
-        IfIptoHost hostTracker = getIfIpToHostService(containerName);
-
-        HostConfig hc = hostConfig;
-        if (!networkAddress.equals(hc.getNetworkAddress())) {
-            return Response.status(Response.Status.CONFLICT)
-                    .entity("Resource name in config object doesn't match URI")
-                    .build();
-        }
-        if (!hc.isStaticHost()) {
-            return Response.status(Response.Status.BAD_REQUEST)
-                    .entity("Can only add static host.")
-                    .build();
-        }
-        Node node = handleNodeAvailability(containerName, hc.getNodeType(), hc.getNodeId());
-        NodeConnector nc = NodeConnector.fromStringNoNode(hc.getNodeConnectorType(), hc.getNodeConnectorId(), node);
-
-        Status status = hostTracker.addStaticHost(networkAddress, hc.getDataLayerAddress(), nc, hc.getVlan());
-        if (status.isSuccess()) {
-            NorthboundUtils.auditlog("Static Host", username, "added", networkAddress, containerName);
-            return Response.created(uriInfo.getRequestUri()).build();
-        }
-
-        return NorthboundUtils.getResponse(status);
-    }
-
-    /**
-     * Delete a Static Host configuration
-     *
-     * @param containerName
-     *            Name of the Container. The Container name for the base
-     *            controller is "default".
-     * @param networkAddress
-     *            IP Address
-     * @return Response as dictated by the HTTP Response code.
-     *
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/hosttracker/default/address/1.1.1.1
-     *
-     */
-
-    @Path("/{containerName}/address/{networkAddress}")
-    @DELETE
-    @Consumes({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @StatusCodes({
-            @ResponseCode(code = 204, condition = "Static host deleted successfully"),
-            @ResponseCode(code = 404, condition = "The container or a specified resource was not found"),
-            @ResponseCode(code = 406, condition = "Cannot operate on Default Container when other Containers are active"),
-            @ResponseCode(code = 503, condition = "One or more of Controller service is unavailable") })
-    public Response deleteHost(
-            @PathParam(value = "containerName") String containerName,
-            @PathParam(value = "networkAddress") String networkAddress) {
-
-        if (!NorthboundUtils.isAuthorized(getUserName(), containerName, Privilege.WRITE, this)) {
-            return Response.status(Response.Status.UNAUTHORIZED)
-                    .entity("User is not authorized to perform this operation on container " + containerName)
-                    .build();
-        }
-        handleDefaultDisabled(containerName);
-        IfIptoHost hostTracker = getIfIpToHostService(containerName);
-
-        Status status = hostTracker.removeStaticHost(networkAddress);
-        if (status.isSuccess()) {
-            NorthboundUtils.auditlog("Static Host", username, "removed", networkAddress, containerName);
-            return Response.noContent().build();
-        }
-        return NorthboundUtils.getResponse(status);
-
-    }
-
-    private void handleDefaultDisabled(String containerName) {
-        IContainerManager containerManager = (IContainerManager) ServiceHelper
-                .getGlobalInstance(IContainerManager.class, this);
-        if (containerManager == null) {
-            throw new ServiceUnavailableException(
-                    RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-        if (containerName.equals(GlobalConstants.DEFAULT.toString())
-                && containerManager.hasNonDefaultContainer()) {
-            throw new ResourceConflictException(
-                    RestMessages.DEFAULTDISABLED.toString());
-        }
-    }
-
-    private Node handleNodeAvailability(String containerName, String nodeType, String nodeId) {
-
-        Node node = Node.fromString(nodeType, nodeId);
-        if (node == null) {
-            throw new ResourceNotFoundException(nodeId + " : "
-                    + RestMessages.NONODE.toString());
-        }
-
-        ISwitchManager sm = (ISwitchManager) ServiceHelper.getInstance(
-                ISwitchManager.class, containerName, this);
-
-        if (sm == null) {
-            throw new ServiceUnavailableException("Switch Manager "
-                    + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        if (!sm.getNodes().contains(node)) {
-            throw new ResourceNotFoundException(node.toString() + " : "
-                    + RestMessages.NONODE.toString());
-        }
-        return node;
-    }
-
-}
diff --git a/opendaylight/adsal/northbound/hosttracker/src/main/java/org/opendaylight/controller/hosttracker/northbound/Hosts.java b/opendaylight/adsal/northbound/hosttracker/src/main/java/org/opendaylight/controller/hosttracker/northbound/Hosts.java
deleted file mode 100644 (file)
index dec5a35..0000000
+++ /dev/null
@@ -1,36 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.hosttracker.northbound;
-
-import java.util.Set;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-@XmlRootElement(name="list")
-@XmlAccessorType(XmlAccessType.NONE)
-
-public class Hosts {
-        @XmlElement
-        Set<HostConfig> hostConfig;
-
-        public Hosts() {
-        }
-        public Hosts (Set<HostConfig> hostConfig) {
-                this.hostConfig = hostConfig;
-        }
-        public Set<HostConfig> getHostConfig() {
-                return hostConfig;
-        }
-        public void setHostConfig(Set<HostConfig> hostConfig) {
-                this.hostConfig = hostConfig;
-        }
-}
diff --git a/opendaylight/adsal/northbound/hosttracker/src/main/resources/META-INF/spring.factories b/opendaylight/adsal/northbound/hosttracker/src/main/resources/META-INF/spring.factories
deleted file mode 100644 (file)
index 93db02e..0000000
+++ /dev/null
@@ -1 +0,0 @@
-org.springframework.beans.BeanInfoFactory=org.springframework.beans.ExtendedBeanInfoFactory
diff --git a/opendaylight/adsal/northbound/hosttracker/src/main/resources/META-INF/spring.handlers b/opendaylight/adsal/northbound/hosttracker/src/main/resources/META-INF/spring.handlers
deleted file mode 100644 (file)
index 957af91..0000000
+++ /dev/null
@@ -1,10 +0,0 @@
-http\://www.springframework.org/schema/context=org.springframework.context.config.ContextNamespaceHandler
-http\://www.springframework.org/schema/jee=org.springframework.ejb.config.JeeNamespaceHandler
-http\://www.springframework.org/schema/lang=org.springframework.scripting.config.LangNamespaceHandler
-http\://www.springframework.org/schema/task=org.springframework.scheduling.config.TaskNamespaceHandler
-http\://www.springframework.org/schema/cache=org.springframework.cache.config.CacheNamespaceHandler
-http\://www.springframework.org/schema/c=org.springframework.beans.factory.xml.SimpleConstructorNamespaceHandler
-http\://www.springframework.org/schema/p=org.springframework.beans.factory.xml.SimplePropertyNamespaceHandler
-http\://www.springframework.org/schema/util=org.springframework.beans.factory.xml.UtilNamespaceHandler
-http\://www.springframework.org/schema/mvc=org.springframework.web.servlet.config.MvcNamespaceHandler
-http\://www.springframework.org/schema/security=org.springframework.security.config.SecurityNamespaceHandler
diff --git a/opendaylight/adsal/northbound/hosttracker/src/main/resources/META-INF/spring.schemas b/opendaylight/adsal/northbound/hosttracker/src/main/resources/META-INF/spring.schemas
deleted file mode 100644 (file)
index d865edc..0000000
+++ /dev/null
@@ -1,49 +0,0 @@
-http\://www.springframework.org/schema/beans/spring-beans-2.0.xsd=org/springframework/beans/factory/xml/spring-beans-2.0.xsd
-http\://www.springframework.org/schema/beans/spring-beans-2.5.xsd=org/springframework/beans/factory/xml/spring-beans-2.5.xsd
-http\://www.springframework.org/schema/beans/spring-beans-3.0.xsd=org/springframework/beans/factory/xml/spring-beans-3.0.xsd
-http\://www.springframework.org/schema/beans/spring-beans-3.1.xsd=org/springframework/beans/factory/xml/spring-beans-3.1.xsd
-http\://www.springframework.org/schema/beans/spring-beans-3.2.xsd=org/springframework/beans/factory/xml/spring-beans-3.2.xsd
-http\://www.springframework.org/schema/beans/spring-beans.xsd=org/springframework/beans/factory/xml/spring-beans-3.2.xsd
-http\://www.springframework.org/schema/tool/spring-tool-2.0.xsd=org/springframework/beans/factory/xml/spring-tool-2.0.xsd
-http\://www.springframework.org/schema/tool/spring-tool-2.5.xsd=org/springframework/beans/factory/xml/spring-tool-2.5.xsd
-http\://www.springframework.org/schema/tool/spring-tool-3.0.xsd=org/springframework/beans/factory/xml/spring-tool-3.0.xsd
-http\://www.springframework.org/schema/tool/spring-tool-3.1.xsd=org/springframework/beans/factory/xml/spring-tool-3.1.xsd
-http\://www.springframework.org/schema/tool/spring-tool-3.2.xsd=org/springframework/beans/factory/xml/spring-tool-3.2.xsd
-http\://www.springframework.org/schema/tool/spring-tool.xsd=org/springframework/beans/factory/xml/spring-tool-3.2.xsd
-http\://www.springframework.org/schema/util/spring-util-2.0.xsd=org/springframework/beans/factory/xml/spring-util-2.0.xsd
-http\://www.springframework.org/schema/util/spring-util-2.5.xsd=org/springframework/beans/factory/xml/spring-util-2.5.xsd
-http\://www.springframework.org/schema/util/spring-util-3.0.xsd=org/springframework/beans/factory/xml/spring-util-3.0.xsd
-http\://www.springframework.org/schema/util/spring-util-3.1.xsd=org/springframework/beans/factory/xml/spring-util-3.1.xsd
-http\://www.springframework.org/schema/util/spring-util-3.2.xsd=org/springframework/beans/factory/xml/spring-util-3.2.xsd
-http\://www.springframework.org/schema/util/spring-util.xsd=org/springframework/beans/factory/xml/spring-util-3.2.xsd
-http\://www.springframework.org/schema/context/spring-context-2.5.xsd=org/springframework/context/config/spring-context-2.5.xsd
-http\://www.springframework.org/schema/context/spring-context-3.0.xsd=org/springframework/context/config/spring-context-3.0.xsd
-http\://www.springframework.org/schema/context/spring-context-3.1.xsd=org/springframework/context/config/spring-context-3.1.xsd
-http\://www.springframework.org/schema/context/spring-context-3.2.xsd=org/springframework/context/config/spring-context-3.2.xsd
-http\://www.springframework.org/schema/context/spring-context.xsd=org/springframework/context/config/spring-context-3.2.xsd
-http\://www.springframework.org/schema/jee/spring-jee-2.0.xsd=org/springframework/ejb/config/spring-jee-2.0.xsd
-http\://www.springframework.org/schema/jee/spring-jee-2.5.xsd=org/springframework/ejb/config/spring-jee-2.5.xsd
-http\://www.springframework.org/schema/jee/spring-jee-3.0.xsd=org/springframework/ejb/config/spring-jee-3.0.xsd
-http\://www.springframework.org/schema/jee/spring-jee-3.1.xsd=org/springframework/ejb/config/spring-jee-3.1.xsd
-http\://www.springframework.org/schema/jee/spring-jee-3.2.xsd=org/springframework/ejb/config/spring-jee-3.2.xsd
-http\://www.springframework.org/schema/jee/spring-jee.xsd=org/springframework/ejb/config/spring-jee-3.2.xsd
-http\://www.springframework.org/schema/lang/spring-lang-2.0.xsd=org/springframework/scripting/config/spring-lang-2.0.xsd
-http\://www.springframework.org/schema/lang/spring-lang-2.5.xsd=org/springframework/scripting/config/spring-lang-2.5.xsd
-http\://www.springframework.org/schema/lang/spring-lang-3.0.xsd=org/springframework/scripting/config/spring-lang-3.0.xsd
-http\://www.springframework.org/schema/lang/spring-lang-3.1.xsd=org/springframework/scripting/config/spring-lang-3.1.xsd
-http\://www.springframework.org/schema/lang/spring-lang-3.2.xsd=org/springframework/scripting/config/spring-lang-3.2.xsd
-http\://www.springframework.org/schema/lang/spring-lang.xsd=org/springframework/scripting/config/spring-lang-3.2.xsd
-http\://www.springframework.org/schema/task/spring-task-3.0.xsd=org/springframework/scheduling/config/spring-task-3.0.xsd
-http\://www.springframework.org/schema/task/spring-task-3.1.xsd=org/springframework/scheduling/config/spring-task-3.1.xsd
-http\://www.springframework.org/schema/task/spring-task-3.2.xsd=org/springframework/scheduling/config/spring-task-3.2.xsd
-http\://www.springframework.org/schema/task/spring-task.xsd=org/springframework/scheduling/config/spring-task-3.2.xsd
-http\://www.springframework.org/schema/cache/spring-cache-3.1.xsd=org/springframework/cache/config/spring-cache-3.1.xsd
-http\://www.springframework.org/schema/cache/spring-cache-3.2.xsd=org/springframework/cache/config/spring-cache-3.2.xsd
-http\://www.springframework.org/schema/cache/spring-cache.xsd=org/springframework/cache/config/spring-cache-3.2.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd=org/springframework/web/servlet/config/spring-mvc-3.0.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc-3.1.xsd=org/springframework/web/servlet/config/spring-mvc-3.1.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc-3.2.xsd=org/springframework/web/servlet/config/spring-mvc-3.2.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc.xsd=org/springframework/web/servlet/config/spring-mvc-3.2.xsd
-http\://www.springframework.org/schema/security/spring-security-3.1.xsd=org/springframework/security/config/spring-security-3.1.xsd
-http\://www.springframework.org/schema/security/spring-security-3.2.xsd=org/springframework/security/config/spring-security-3.2.xsd
-
diff --git a/opendaylight/adsal/northbound/hosttracker/src/main/resources/META-INF/spring.tooling b/opendaylight/adsal/northbound/hosttracker/src/main/resources/META-INF/spring.tooling
deleted file mode 100644 (file)
index 057d834..0000000
+++ /dev/null
@@ -1,39 +0,0 @@
-# Tooling related information for the beans namespace
-http\://www.springframework.org/schema/beans@name=beans Namespace
-http\://www.springframework.org/schema/beans@prefix=beans
-http\://www.springframework.org/schema/beans@icon=org/springframework/beans/factory/xml/spring-beans.gif
-
-# Tooling related information for the util namespace
-http\://www.springframework.org/schema/util@name=util Namespace
-http\://www.springframework.org/schema/util@prefix=util
-http\://www.springframework.org/schema/util@icon=org/springframework/beans/factory/xml/spring-util.gif
-
-# Tooling related information for the context namespace
-http\://www.springframework.org/schema/context@name=context Namespace
-http\://www.springframework.org/schema/context@prefix=context
-http\://www.springframework.org/schema/context@icon=org/springframework/context/config/spring-context.gif
-
-# Tooling related information for the jee namespace
-http\://www.springframework.org/schema/jee@name=jee Namespace
-http\://www.springframework.org/schema/jee@prefix=jee
-http\://www.springframework.org/schema/jee@icon=org/springframework/ejb/config/spring-jee.gif
-
-# Tooling related information for the scheduling namespace
-http\://www.springframework.org/schema/task@name=task Namespace
-http\://www.springframework.org/schema/task@prefix=task
-http\://www.springframework.org/schema/task@icon=org/springframework/scheduling/config/spring-task.gif
-
-# Tooling related information for the lang namespace
-http\://www.springframework.org/schema/lang@name=lang Namespace
-http\://www.springframework.org/schema/lang@prefix=lang
-http\://www.springframework.org/schema/lang@icon=org/springframework/scripting/config/spring-lang.gif
-
-# Tooling related information for the cache namespace
-http\://www.springframework.org/schema/cache@name=cache Namespace
-http\://www.springframework.org/schema/cache@prefix=cache
-http\://www.springframework.org/schema/cache@icon=org/springframework/cache/config/spring-cache.gif
-
-# Tooling related information for the mvc namespace
-http\://www.springframework.org/schema/mvc@name=mvc Namespace
-http\://www.springframework.org/schema/mvc@prefix=mvc
-http\://www.springframework.org/schema/mvc@icon=org/springframework/web/servlet/config/spring-mvc.gif
diff --git a/opendaylight/adsal/northbound/hosttracker/src/main/resources/WEB-INF/web.xml b/opendaylight/adsal/northbound/hosttracker/src/main/resources/WEB-INF/web.xml
deleted file mode 100644 (file)
index 2e9d9d0..0000000
+++ /dev/null
@@ -1,89 +0,0 @@
-<?xml version="1.0" encoding="ISO-8859-1"?>
-<web-app xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
-        xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
-        version="3.0">
-  <servlet>
-    <servlet-name>JAXRSHostTracker</servlet-name>
-    <servlet-class>com.sun.jersey.spi.container.servlet.ServletContainer</servlet-class>
-    <init-param>
-      <param-name>javax.ws.rs.Application</param-name>
-      <param-value>org.opendaylight.controller.northbound.commons.NorthboundApplication</param-value>
-    </init-param>
-    <load-on-startup>1</load-on-startup>
-  </servlet>
-
-  <servlet-mapping>
-    <servlet-name>JAXRSHostTracker</servlet-name>
-    <url-pattern>/*</url-pattern>
-  </servlet-mapping>
-
-        <filter>
-          <filter-name>CorsFilter</filter-name>
-          <filter-class>org.apache.catalina.filters.CorsFilter</filter-class>
-          <init-param>
-            <param-name>cors.allowed.origins</param-name>
-            <param-value>*</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.allowed.methods</param-name>
-            <param-value>GET,POST,HEAD,OPTIONS,PUT,DELETE</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.allowed.headers</param-name>
-            <param-value>Content-Type,X-Requested-With,accept,authorization, origin,Origin,Access-Control-Request-Method,Access-Control-Request-Headers</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.exposed.headers</param-name>
-            <param-value>Access-Control-Allow-Origin,Access-Control-Allow-Credentials</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.support.credentials</param-name>
-            <param-value>true</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.preflight.maxage</param-name>
-            <param-value>10</param-value>
-          </init-param>
-        </filter>
-        <filter-mapping>
-          <filter-name>CorsFilter</filter-name>
-          <url-pattern>/*</url-pattern>
-        </filter-mapping>
-
-        <security-constraint>
-          <web-resource-collection>
-            <web-resource-name>NB api</web-resource-name>
-            <url-pattern>/*</url-pattern>
-            <http-method>POST</http-method>
-            <http-method>GET</http-method>
-            <http-method>PUT</http-method>
-            <http-method>PATCH</http-method>
-            <http-method>DELETE</http-method>
-            <http-method>HEAD</http-method>
-          </web-resource-collection>
-          <auth-constraint>
-            <role-name>System-Admin</role-name>
-            <role-name>Network-Admin</role-name>
-            <role-name>Network-Operator</role-name>
-            <role-name>Container-User</role-name>
-          </auth-constraint>
-        </security-constraint>
-
-        <security-role>
-                <role-name>System-Admin</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Network-Admin</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Network-Operator</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Container-User</role-name>
-        </security-role>
-
-        <login-config>
-                <auth-method>BASIC</auth-method>
-                <realm-name>opendaylight</realm-name>
-        </login-config>
-</web-app>
\ No newline at end of file
diff --git a/opendaylight/adsal/northbound/hosttracker/src/test/java/org/opendaylight/controller/hosttracker/northbound/HostTrackerNorthboundTest.java b/opendaylight/adsal/northbound/hosttracker/src/test/java/org/opendaylight/controller/hosttracker/northbound/HostTrackerNorthboundTest.java
deleted file mode 100644 (file)
index 14d6cf7..0000000
+++ /dev/null
@@ -1,43 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.hosttracker.northbound;
-
-import java.net.InetAddress;
-import java.net.UnknownHostException;
-import java.util.HashSet;
-import java.util.Set;
-
-import org.junit.Assert;
-import org.junit.Test;
-import org.opendaylight.controller.hosttracker.hostAware.HostNodeConnector;
-import org.opendaylight.controller.sal.core.ConstructionException;
-
-public class HostTrackerNorthboundTest {
-
-    @Test
-    public void testHosts() throws UnknownHostException, ConstructionException {
-        Hosts h1 = new Hosts();
-        Assert.assertNull(h1.getHostConfig());
-
-        Hosts h2 = new Hosts(null);
-        Assert.assertNull(h2.getHostConfig());
-
-        Set<HostConfig> conn = new HashSet<HostConfig>();
-        InetAddress addr = InetAddress.getByName("10.1.1.1");
-        HostNodeConnector c1 = new HostNodeConnector(addr);
-        conn.add(HostConfig.convert(c1));
-        h1.setHostConfig(conn);
-        Assert.assertTrue(h1.getHostConfig().equals(conn));
-
-        Hosts h3 = new Hosts(conn);
-        Assert.assertTrue(h3.getHostConfig().equals(conn));
-        h3.setHostConfig(null);
-        Assert.assertNull(h3.getHostConfig());
-
-    }
-}
diff --git a/opendaylight/adsal/northbound/httpservice-bridge/pom.xml b/opendaylight/adsal/northbound/httpservice-bridge/pom.xml
deleted file mode 100644 (file)
index edd6964..0000000
+++ /dev/null
@@ -1,39 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>httpservice-bridge</artifactId>
-  <version>0.2.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <description>HttpService bridge web application</description>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Export-Package></Export-Package>
-            <Import-Package>javax.servlet,
-                javax.servlet.http,
-                org.eclipse.equinox.http.servlet,
-                org.opendaylight.controller.web,
-                org.osgi.framework,
-                org.osgi.service.http,
-                org.slf4j,</Import-Package>
-            <Web-ContextPath>/controller/osgi</Web-ContextPath>
-          </instructions>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-</project>
diff --git a/opendaylight/adsal/northbound/httpservice-bridge/src/main/resources/WEB-INF/web.xml b/opendaylight/adsal/northbound/httpservice-bridge/src/main/resources/WEB-INF/web.xml
deleted file mode 100644 (file)
index 0622e90..0000000
+++ /dev/null
@@ -1,43 +0,0 @@
-<?xml version="1.0" encoding="ISO-8859-1"?>
-<web-app
-  xmlns="http://java.sun.com/xml/ns/javaee"
-  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
-  xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
-  version="3.0">
-
-  <servlet>
-    <servlet-name>BridgeServlet</servlet-name>
-    <servlet-class>org.eclipse.equinox.http.servlet.HttpServiceServlet</servlet-class>
-    <load-on-startup>1</load-on-startup>
-  </servlet>
-
-  <servlet-mapping>
-    <servlet-name>BridgeServlet</servlet-name>
-    <url-pattern>/*</url-pattern>
-  </servlet-mapping>
-
-  <security-constraint>
-    <web-resource-collection>
-      <web-resource-name>HttpService</web-resource-name>
-      <url-pattern>/*</url-pattern>
-    </web-resource-collection>
-    <auth-constraint>
-      <role-name>System-Admin</role-name>
-      <role-name>Network-Admin</role-name>
-    </auth-constraint>
-  </security-constraint>
-
-  <security-role>
-    <role-name>System-Admin</role-name>
-  </security-role>
-
-  <security-role>
-    <role-name>Network-Admin</role-name>
-  </security-role>
-
-  <login-config>
-    <auth-method>BASIC</auth-method>
-    <realm-name>opendaylight</realm-name>
-  </login-config>
-
-</web-app>
diff --git a/opendaylight/adsal/northbound/integrationtest/pom.xml b/opendaylight/adsal/northbound/integrationtest/pom.xml
deleted file mode 100644 (file)
index 59eec0e..0000000
+++ /dev/null
@@ -1,571 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.integrationtest</artifactId>
-    <version>0.7.0-SNAPSHOT</version>
-    <relativePath>../../commons/integrationtest</relativePath>
-  </parent>
-
-  <artifactId>northbound.integrationtest</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <dependencies>
-    <dependency>
-      <groupId>ch.qos.logback</groupId>
-      <artifactId>logback-classic</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>ch.qos.logback</groupId>
-      <artifactId>logback-core</artifactId>
-    </dependency>
-
-    <dependency>
-      <groupId>com.fasterxml.jackson.core</groupId>
-      <artifactId>jackson-annotations</artifactId>
-    </dependency>
-
-    <dependency>
-      <groupId>com.fasterxml.jackson.core</groupId>
-      <artifactId>jackson-core</artifactId>
-    </dependency>
-
-    <dependency>
-      <groupId>com.fasterxml.jackson.core</groupId>
-      <artifactId>jackson-databind</artifactId>
-    </dependency>
-
-    <dependency>
-      <groupId>com.fasterxml.jackson.jaxrs</groupId>
-      <artifactId>jackson-jaxrs-json-provider</artifactId>
-    </dependency>
-
-    <dependency>
-      <groupId>com.fasterxml.jackson.module</groupId>
-      <artifactId>jackson-module-jaxb-annotations</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>com.google.code.gson</groupId>
-      <artifactId>gson</artifactId>
-      <scope>compile</scope>
-    </dependency>
-    <dependency>
-      <groupId>com.sun.jersey</groupId>
-      <artifactId>jersey-client</artifactId>
-    </dependency>
-    <!-- Jersey for JAXRS -->
-    <dependency>
-      <groupId>com.sun.jersey</groupId>
-      <artifactId>jersey-core</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>com.sun.jersey</groupId>
-      <artifactId>jersey-server</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>commons-codec</groupId>
-      <artifactId>commons-codec</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>commons-fileupload</groupId>
-      <artifactId>commons-fileupload</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>commons-io</groupId>
-      <artifactId>commons-io</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>eclipselink</groupId>
-      <artifactId>javax.persistence</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>eclipselink</groupId>
-      <artifactId>javax.resource</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>javax.servlet</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>javax.servlet.jsp</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>org.apache.felix.gogo.command</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>org.apache.felix.gogo.runtime</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>org.apache.felix.gogo.shell</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>org.eclipse.equinox.cm</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>org.eclipse.equinox.console</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>org.eclipse.equinox.ds</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>org.eclipse.equinox.launcher</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>org.eclipse.equinox.util</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>org.eclipse.osgi</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>org.eclipse.osgi.services</artifactId>
-    </dependency>
-    <!-- Gemini Web -->
-    <dependency>
-      <groupId>geminiweb</groupId>
-      <artifactId>org.eclipse.gemini.web.core</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>geminiweb</groupId>
-      <artifactId>org.eclipse.gemini.web.extender</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>geminiweb</groupId>
-      <artifactId>org.eclipse.gemini.web.tomcat</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>geminiweb</groupId>
-      <artifactId>org.eclipse.virgo.kernel.equinox.extensions</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>geminiweb</groupId>
-      <artifactId>org.eclipse.virgo.util.common</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>geminiweb</groupId>
-      <artifactId>org.eclipse.virgo.util.io</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>geminiweb</groupId>
-      <artifactId>org.eclipse.virgo.util.math</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>geminiweb</groupId>
-      <artifactId>org.eclipse.virgo.util.osgi</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>geminiweb</groupId>
-      <artifactId>org.eclipse.virgo.util.osgi.manifest</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>geminiweb</groupId>
-      <artifactId>org.eclipse.virgo.util.parser.manifest</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>orbit</groupId>
-      <artifactId>javax.activation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>orbit</groupId>
-      <artifactId>javax.annotation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>orbit</groupId>
-      <artifactId>javax.ejb</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>orbit</groupId>
-      <artifactId>javax.el</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>orbit</groupId>
-      <artifactId>javax.mail.glassfish</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>orbit</groupId>
-      <artifactId>javax.servlet.jsp.jstl</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>orbit</groupId>
-      <artifactId>javax.servlet.jsp.jstl.impl</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>orbit</groupId>
-      <artifactId>javax.xml.rpc</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>orbit</groupId>
-      <artifactId>org.apache.catalina</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>orbit</groupId>
-      <artifactId>org.apache.catalina.ha</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>orbit</groupId>
-      <artifactId>org.apache.catalina.tribes</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>orbit</groupId>
-      <artifactId>org.apache.coyote</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>orbit</groupId>
-      <artifactId>org.apache.el</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>orbit</groupId>
-      <artifactId>org.apache.jasper</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>orbit</groupId>
-      <artifactId>org.apache.juli.extras</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>orbit</groupId>
-      <artifactId>org.apache.tomcat.api</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>orbit</groupId>
-      <artifactId>org.apache.tomcat.util</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.aopalliance</groupId>
-      <artifactId>com.springsource.org.aopalliance</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.apache.commons</groupId>
-      <artifactId>commons-lang3</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.apache.felix</groupId>
-      <artifactId>org.apache.felix.dependencymanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.apache.felix</groupId>
-      <artifactId>org.apache.felix.dependencymanager.shell</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.apache.felix</groupId>
-      <artifactId>org.apache.felix.fileinstall</artifactId>
-    </dependency>
-
-    <dependency>
-      <groupId>org.codehaus.enunciate</groupId>
-      <artifactId>enunciate-core-annotations</artifactId>
-    </dependency>
-
-    <dependency>
-      <groupId>org.codehaus.jettison</groupId>
-      <artifactId>jettison</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.jboss.spec.javax.transaction</groupId>
-      <artifactId>jboss-transaction-api_1.1_spec</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>arphandler</artifactId>
-    </dependency>
-
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>bundlescanner</artifactId>
-    </dependency>
-
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>bundlescanner.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>clustering.services</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>clustering.services-implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>commons.httpclient</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>commons.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>configuration</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>configuration.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>connectionmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>connectionmanager.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>containermanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>containermanager.it.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>flowprogrammer.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>forwarding.staticrouting</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>forwarding.staticrouting.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>forwardingrulesmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>forwardingrulesmanager.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>hosttracker</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>hosttracker.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>hosttracker.northbound</artifactId>
-    </dependency>
-
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>logging.bridge</artifactId>
-    </dependency>
-
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>protocol_plugins.stub</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>routing.dijkstra_implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal.connection</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal.connection.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>security</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>statistics.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>statisticsmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>statisticsmanager.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>subnets.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>switchmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>switchmanager.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>switchmanager.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>topology.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>topologymanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>usermanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>usermanager.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller.thirdparty</groupId>
-      <artifactId>com.sun.jersey.jersey-servlet</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller.thirdparty</groupId>
-      <artifactId>org.apache.catalina.filters.CorsFilter</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.ow2.asm</groupId>
-      <artifactId>asm-all</artifactId>
-    </dependency>
-    <!-- Visual VM hook -->
-    <dependency>
-      <groupId>org.ow2.chameleon.management</groupId>
-      <artifactId>chameleon-mbeans</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.slf4j</groupId>
-      <artifactId>jcl-over-slf4j</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.slf4j</groupId>
-      <artifactId>log4j-over-slf4j</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.slf4j</groupId>
-      <artifactId>slf4j-api</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.springframework</groupId>
-      <artifactId>org.springframework.aop</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.springframework</groupId>
-      <artifactId>org.springframework.asm</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.springframework</groupId>
-      <artifactId>org.springframework.beans</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.springframework</groupId>
-      <artifactId>org.springframework.context</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.springframework</groupId>
-      <artifactId>org.springframework.context.support</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.springframework</groupId>
-      <artifactId>org.springframework.core</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.springframework</groupId>
-      <artifactId>org.springframework.expression</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.springframework</groupId>
-      <artifactId>org.springframework.transaction</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.springframework</groupId>
-      <artifactId>org.springframework.web</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.springframework</groupId>
-      <artifactId>org.springframework.web.servlet</artifactId>
-    </dependency>
-    <!-- Spring security -->
-    <dependency>
-      <groupId>org.springframework.security</groupId>
-      <artifactId>spring-security-config</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.springframework.security</groupId>
-      <artifactId>spring-security-core</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.springframework.security</groupId>
-      <artifactId>spring-security-taglibs</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.springframework.security</groupId>
-      <artifactId>spring-security-web</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>virgomirror</groupId>
-      <artifactId>org.eclipse.jdt.core.compiler.batch</artifactId>
-    </dependency>
-    <!-- Add Pax Exam -->
-    <dependency>
-      <groupId>org.ops4j.pax.exam</groupId>
-      <artifactId>pax-exam-container-native</artifactId>
-      <scope>test</scope>
-    </dependency>
-    <dependency>
-      <groupId>org.ops4j.pax.exam</groupId>
-      <artifactId>pax-exam-junit4</artifactId>
-      <scope>test</scope>
-    </dependency>
-    <dependency>
-      <groupId>org.ops4j.pax.exam</groupId>
-      <artifactId>pax-exam-link-mvn</artifactId>
-      <scope>test</scope>
-    </dependency>
-    <dependency>
-      <groupId>org.ops4j.pax.url</groupId>
-      <artifactId>pax-url-aether</artifactId>
-      <scope>test</scope>
-    </dependency>
-  </dependencies>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-  <pluginRepositories>
-    <pluginRepository>
-      <releases>
-        <enabled>true</enabled>
-      </releases>
-      <snapshots>
-        <enabled>false</enabled>
-      </snapshots>
-      <id>central</id>
-      <name>maven repo1</name>
-      <url>http://repo1.maven.org/maven2</url>
-    </pluginRepository>
-  </pluginRepositories>
-</project>
diff --git a/opendaylight/adsal/northbound/integrationtest/src/test/java/org/opendaylight/controller/northbound/integrationtest/NorthboundIT.java b/opendaylight/adsal/northbound/integrationtest/src/test/java/org/opendaylight/controller/northbound/integrationtest/NorthboundIT.java
deleted file mode 100644 (file)
index d2b354b..0000000
+++ /dev/null
@@ -1,1505 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.northbound.integrationtest;
-
-import static org.junit.Assert.assertFalse;
-import static org.junit.Assert.assertNotNull;
-import static org.ops4j.pax.exam.CoreOptions.junitBundles;
-import static org.ops4j.pax.exam.CoreOptions.mavenBundle;
-import static org.ops4j.pax.exam.CoreOptions.options;
-import static org.ops4j.pax.exam.CoreOptions.systemPackages;
-import static org.ops4j.pax.exam.CoreOptions.systemProperty;
-import java.util.ArrayList;
-import java.util.Arrays;
-import java.util.HashMap;
-import java.util.HashSet;
-import java.util.List;
-import java.util.Map;
-import java.util.Set;
-import javax.inject.Inject;
-import org.apache.commons.codec.binary.Base64;
-import org.codehaus.jettison.json.JSONArray;
-import org.codehaus.jettison.json.JSONException;
-import org.codehaus.jettison.json.JSONObject;
-import org.codehaus.jettison.json.JSONTokener;
-import org.junit.Assert;
-import org.junit.Before;
-import org.junit.Test;
-import org.junit.runner.RunWith;
-import org.opendaylight.controller.commons.httpclient.HTTPClient;
-import org.opendaylight.controller.commons.httpclient.HTTPRequest;
-import org.opendaylight.controller.commons.httpclient.HTTPResponse;
-import org.opendaylight.controller.hosttracker.IfIptoHost;
-import org.opendaylight.controller.sal.core.Bandwidth;
-import org.opendaylight.controller.sal.core.ConstructionException;
-import org.opendaylight.controller.sal.core.Edge;
-import org.opendaylight.controller.sal.core.Latency;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.core.State;
-import org.opendaylight.controller.sal.core.UpdateType;
-import org.opendaylight.controller.sal.topology.IListenTopoUpdates;
-import org.opendaylight.controller.sal.topology.TopoEdgeUpdate;
-import org.opendaylight.controller.switchmanager.IInventoryListener;
-import org.opendaylight.controller.usermanager.IUserManager;
-import org.ops4j.pax.exam.Configuration;
-import org.ops4j.pax.exam.Option;
-import org.ops4j.pax.exam.junit.PaxExam;
-import org.ops4j.pax.exam.util.PathUtils;
-import org.osgi.framework.Bundle;
-import org.osgi.framework.BundleContext;
-import org.osgi.framework.ServiceReference;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-@RunWith(PaxExam.class)
-public class NorthboundIT {
-    private final Logger log = LoggerFactory.getLogger(NorthboundIT.class);
-    // get the OSGI bundle context
-    @Inject
-    private BundleContext bc;
-    private IUserManager userManager = null;
-    private IInventoryListener invtoryListener = null;
-    private IListenTopoUpdates topoUpdates = null;
-    private static final String baseUrlPrefix = "http://127.0.0.1:8180/controller/nb/v2/";
-    private final Boolean debugMsg = false;
-
-    private String stateToString(int state) {
-        switch (state) {
-        case Bundle.ACTIVE:
-            return "ACTIVE";
-        case Bundle.INSTALLED:
-            return "INSTALLED";
-        case Bundle.RESOLVED:
-            return "RESOLVED";
-        case Bundle.UNINSTALLED:
-            return "UNINSTALLED";
-        default:
-            return "Not CONVERTED";
-        }
-    }
-
-    @Before
-    public void areWeReady() {
-        assertNotNull(bc);
-        boolean debugit = false;
-        Bundle b[] = bc.getBundles();
-        for (Bundle element : b) {
-            int state = element.getState();
-            if (state != Bundle.ACTIVE && state != Bundle.RESOLVED) {
-                log.debug("Bundle:" + element.getSymbolicName() + " state:" + stateToString(state));
-                debugit = true;
-            }
-        }
-        if (debugit) {
-            log.debug("Do some debugging because some bundle is " + "unresolved");
-        }
-        // Assert if true, if false we are good to go!
-        assertFalse(debugit);
-
-        ServiceReference r = bc.getServiceReference(IUserManager.class.getName());
-        if (r != null) {
-            this.userManager = (IUserManager) bc.getService(r);
-        }
-        // If UserManager is null, cannot login to run tests.
-        assertNotNull(this.userManager);
-
-        r = bc.getServiceReference(IfIptoHost.class.getName());
-        if (r != null) {
-            this.invtoryListener = (IInventoryListener) bc.getService(r);
-        }
-
-        // If inventoryListener is null, cannot run hosttracker tests.
-        assertNotNull(this.invtoryListener);
-
-        r = bc.getServiceReference(IListenTopoUpdates.class.getName());
-        if (r != null) {
-            this.topoUpdates = (IListenTopoUpdates) bc.getService(r);
-        }
-
-        // If topologyManager is null, cannot run topology North tests.
-        assertNotNull(this.topoUpdates);
-
-    }
-
-    // static variable to pass response code from getJsonResult()
-    private static Integer httpResponseCode = null;
-
-    private String getJsonResult(String restUrl) {
-        return getJsonResult(restUrl, "GET", null);
-    }
-
-    private String getJsonResult(String restUrl, String method) {
-        return getJsonResult(restUrl, method, null);
-    }
-
-    private String getJsonResult(String restUrl, String method, String body) {
-        // initialize response code to indicate error
-        httpResponseCode = 400;
-
-        if (debugMsg) {
-            System.out.println("HTTP method: " + method + " url: " + restUrl.toString());
-            if (body != null) {
-                System.out.println("body: " + body);
-            }
-        }
-
-        try {
-            this.userManager.getAuthorizationList();
-            this.userManager.authenticate("admin", "admin");
-            HTTPRequest request = new HTTPRequest();
-
-            request.setUri(restUrl);
-            request.setMethod(method);
-            request.setTimeout(0);  // HostTracker doesn't respond
-                                    // within default timeout during
-                                    // IT so setting an indefinite
-                                    // timeout till the issue is
-                                    // sorted out
-
-            Map<String, List<String>> headers = new HashMap<String, List<String>>();
-            String authString = "admin:admin";
-            byte[] authEncBytes = Base64.encodeBase64(authString.getBytes());
-            String authStringEnc = new String(authEncBytes);
-            List<String> header = new ArrayList<String>();
-            header.add("Basic "+authStringEnc);
-            headers.put("Authorization", header);
-            header = new ArrayList<String>();
-            header.add("application/json");
-            headers.put("Accept", header);
-            request.setHeaders(headers);
-            request.setContentType("application/json");
-            if (body != null) {
-                request.setEntity(body);
-            }
-
-            HTTPResponse response = HTTPClient.sendRequest(request);
-
-            // Response code for success should be 2xx
-            httpResponseCode = response.getStatus();
-            if (httpResponseCode > 299) {
-                return httpResponseCode.toString();
-            }
-
-            if (debugMsg) {
-                System.out.println("HTTP response code: " + response.getStatus());
-                System.out.println("HTTP response message: " + response.getEntity());
-            }
-            return response.getEntity();
-        } catch (Exception e) {
-            if (debugMsg) {
-                e.printStackTrace();
-            }
-            return null;
-        }
-    }
-
-    private void testNodeProperties(JSONObject node, Integer nodeId, String nodeType, Integer timestamp,
-            String timestampName, Integer actionsValue, Integer capabilitiesValue, Integer tablesValue,
-            Integer buffersValue) throws JSONException {
-
-        JSONObject nodeInfo = node.getJSONObject("node");
-        Assert.assertEquals(nodeId, (Integer) nodeInfo.getInt("id"));
-        Assert.assertEquals(nodeType, nodeInfo.getString("type"));
-
-        JSONObject properties = node.getJSONObject("properties");
-
-        if (timestamp == null || timestampName == null) {
-            Assert.assertFalse(properties.has("timeStamp"));
-        } else {
-            Assert.assertEquals(timestamp, (Integer) properties.getJSONObject("timeStamp").getInt("value"));
-            Assert.assertEquals(timestampName, properties.getJSONObject("timeStamp").getString("name"));
-        }
-        if (actionsValue == null) {
-            Assert.assertFalse(properties.has("actions"));
-        } else {
-            Assert.assertEquals(actionsValue, (Integer) properties.getJSONObject("actions").getInt("value"));
-        }
-        if (capabilitiesValue == null) {
-            Assert.assertFalse(properties.has("capabilities"));
-        } else {
-            Assert.assertEquals(capabilitiesValue,
-                    (Integer) properties.getJSONObject("capabilities").getInt("value"));
-        }
-        if (tablesValue == null) {
-            Assert.assertFalse(properties.has("tables"));
-        } else {
-            Assert.assertEquals(tablesValue, (Integer) properties.getJSONObject("tables").getInt("value"));
-        }
-        if (buffersValue == null) {
-            Assert.assertFalse(properties.has("buffers"));
-        } else {
-            Assert.assertEquals(buffersValue, (Integer) properties.getJSONObject("buffers").getInt("value"));
-        }
-    }
-
-    private void testNodeConnectorProperties(JSONObject nodeConnectorProperties, Integer ncId, String ncType,
-            Integer nodeId, String nodeType, Integer state, Integer capabilities, Integer bandwidth)
-            throws JSONException {
-
-        JSONObject nodeConnector = nodeConnectorProperties.getJSONObject("nodeconnector");
-        JSONObject node = nodeConnector.getJSONObject("node");
-        JSONObject properties = nodeConnectorProperties.getJSONObject("properties");
-
-        Assert.assertEquals(ncId, (Integer) nodeConnector.getInt("id"));
-        Assert.assertEquals(ncType, nodeConnector.getString("type"));
-        Assert.assertEquals(nodeId, (Integer) node.getInt("id"));
-        Assert.assertEquals(nodeType, node.getString("type"));
-        if (state == null) {
-            Assert.assertFalse(properties.has("state"));
-        } else {
-            Assert.assertEquals(state, (Integer) properties.getJSONObject("state").getInt("value"));
-        }
-        if (capabilities == null) {
-            Assert.assertFalse(properties.has("capabilities"));
-        } else {
-            Assert.assertEquals(capabilities,
-                    (Integer) properties.getJSONObject("capabilities").getInt("value"));
-        }
-        if (bandwidth == null) {
-            Assert.assertFalse(properties.has("bandwidth"));
-        } else {
-            Assert.assertEquals(bandwidth, (Integer) properties.getJSONObject("bandwidth").getInt("value"));
-        }
-    }
-
-    @Test
-    public void testSubnetsNorthbound() throws JSONException, ConstructionException {
-        System.out.println("Starting Subnets JAXB client.");
-        String baseURL = baseUrlPrefix + "subnetservice/";
-
-        String name1 = "testSubnet1";
-        String subnet1 = "1.1.1.1/24";
-
-        String name2 = "testSubnet2";
-        String subnet2 = "2.2.2.2/24";
-
-        String name3 = "testSubnet3";
-        String subnet3 = "3.3.3.3/24";
-
-        /*
-         * Create the node connector string list for the two subnets as:
-         * portList2 = {"OF|1@OF|00:00:00:00:00:00:00:02", "OF|2@OF|00:00:00:00:00:00:00:02", "OF|3@OF|00:00:00:00:00:00:00:02", "OF|4@OF|00:00:00:00:00:00:00:02"};
-         * portList3 = {"OF|1@OF|00:00:00:00:00:00:00:03", "OF|2@OF|00:00:00:00:00:00:00:03", "OF|3@OF|00:00:00:00:00:00:00:03"};
-         */
-        Node node2 = new Node(Node.NodeIDType.OPENFLOW, 2L);
-        List<String> portList2 = new ArrayList<String>();
-        NodeConnector nc21 = new NodeConnector(NodeConnector.NodeConnectorIDType.OPENFLOW, (short)1, node2);
-        NodeConnector nc22 = new NodeConnector(NodeConnector.NodeConnectorIDType.OPENFLOW, (short)2, node2);
-        NodeConnector nc23 = new NodeConnector(NodeConnector.NodeConnectorIDType.OPENFLOW, (short)3, node2);
-        NodeConnector nc24 = new NodeConnector(NodeConnector.NodeConnectorIDType.OPENFLOW, (short)3, node2);
-        portList2.add(nc21.toString());
-        portList2.add(nc22.toString());
-        portList2.add(nc23.toString());
-        portList2.add(nc24.toString());
-
-        List<String> portList3 = new ArrayList<String>();
-        Node node3 = new Node(Node.NodeIDType.OPENFLOW, 3L);
-        NodeConnector nc31 = new NodeConnector(NodeConnector.NodeConnectorIDType.OPENFLOW, (short)1, node3);
-        NodeConnector nc32 = new NodeConnector(NodeConnector.NodeConnectorIDType.OPENFLOW, (short)2, node3);
-        NodeConnector nc33 = new NodeConnector(NodeConnector.NodeConnectorIDType.OPENFLOW, (short)3, node3);
-        portList3.add(nc31.toString());
-        portList3.add(nc32.toString());
-        portList3.add(nc33.toString());
-
-        // Test GET subnets in default container
-        String result = getJsonResult(baseURL + "default/subnets");
-        JSONTokener jt = new JSONTokener(result);
-        JSONObject json = new JSONObject(jt);
-        JSONArray subnetConfigs = json.getJSONArray("subnetConfig");
-        Assert.assertEquals(subnetConfigs.length(), 1); // should only get the default subnet
-
-        // Test GET subnet1 expecting 404
-        result = getJsonResult(baseURL + "default/subnet/" + name1);
-        Assert.assertEquals(404, httpResponseCode.intValue());
-
-        // Test POST subnet1
-        JSONObject jo = new JSONObject().put("name", name1).put("subnet", subnet1);
-        // execute HTTP request and verify response code
-        result = getJsonResult(baseURL + "default/subnet/" + name1, "PUT", jo.toString());
-        Assert.assertTrue(httpResponseCode == 201);
-
-        // Test GET subnet1
-        result = getJsonResult(baseURL + "default/subnet/" + name1);
-        jt = new JSONTokener(result);
-        json = new JSONObject(jt);
-        Assert.assertEquals(200, httpResponseCode.intValue());
-        Assert.assertEquals(name1, json.getString("name"));
-        Assert.assertEquals(subnet1, json.getString("subnet"));
-
-        // Test PUT subnet2
-        JSONObject jo2 = new JSONObject().put("name", name2).put("subnet", subnet2).put("nodeConnectors", portList2);
-        // execute HTTP request and verify response code
-        result = getJsonResult(baseURL + "default/subnet/" + name2, "PUT", jo2.toString());
-        Assert.assertEquals(201, httpResponseCode.intValue());
-        // Test PUT subnet3
-        JSONObject jo3 = new JSONObject().put("name", name3).put("subnet", subnet3);
-        // execute HTTP request and verify response code
-        result = getJsonResult(baseURL + "default/subnet/" + name3, "PUT", jo3.toString());
-        Assert.assertEquals(201, httpResponseCode.intValue());
-        // Test POST subnet3 (modify port list: add)
-        JSONObject jo3New = new JSONObject().put("name", name3).put("subnet", subnet3).put("nodeConnectors", portList3);
-        // execute HTTP request and verify response code
-        result = getJsonResult(baseURL + "default/subnet/" + name3, "POST", jo3New.toString());
-        Assert.assertEquals(200, httpResponseCode.intValue());
-
-        // Test GET all subnets in default container
-        result = getJsonResult(baseURL + "default/subnets");
-        jt = new JSONTokener(result);
-        json = new JSONObject(jt);
-        JSONArray subnetConfigArray = json.getJSONArray("subnetConfig");
-        JSONObject subnetConfig;
-        Assert.assertEquals(3, subnetConfigArray.length());
-        for (int i = 0; i < subnetConfigArray.length(); i++) {
-            subnetConfig = subnetConfigArray.getJSONObject(i);
-            if (subnetConfig.getString("name").equals(name1)) {
-                Assert.assertEquals(subnet1, subnetConfig.getString("subnet"));
-            } else if (subnetConfig.getString("name").equals(name2)) {
-                Assert.assertEquals(subnet2, subnetConfig.getString("subnet"));
-                JSONArray portListGet = subnetConfig.getJSONArray("nodeConnectors");
-                Assert.assertEquals(portList2.get(0), portListGet.get(0));
-                Assert.assertEquals(portList2.get(1), portListGet.get(1));
-                Assert.assertEquals(portList2.get(2), portListGet.get(2));
-                Assert.assertEquals(portList2.get(3), portListGet.get(3));
-            } else if (subnetConfig.getString("name").equals(name3)) {
-                Assert.assertEquals(subnet3, subnetConfig.getString("subnet"));
-                JSONArray portListGet = subnetConfig.getJSONArray("nodeConnectors");
-                Assert.assertEquals(portList3.get(0), portListGet.get(0));
-                Assert.assertEquals(portList3.get(1), portListGet.get(1));
-                Assert.assertEquals(portList3.get(2), portListGet.get(2));
-            } else {
-                // Unexpected config name
-                Assert.assertTrue(false);
-            }
-        }
-
-        // Test POST subnet2 (modify port list: remove one port only)
-        List<String> newPortList2 = new ArrayList<String>(portList2);
-        newPortList2.remove(3);
-        JSONObject jo2New = new JSONObject().put("name", name2).put("subnet", subnet2).put("nodeConnectors", newPortList2);
-        // execute HTTP request and verify response code
-        result = getJsonResult(baseURL + "default/subnet/" + name2, "POST", jo2New.toString());
-        Assert.assertEquals(200, httpResponseCode.intValue());
-
-        // Test GET subnet2: verify contains only the first three ports
-        result = getJsonResult(baseURL + "default/subnet/" + name2);
-        jt = new JSONTokener(result);
-        subnetConfig = new JSONObject(jt);
-        Assert.assertEquals(200, httpResponseCode.intValue());
-        JSONArray portListGet2 = subnetConfig.getJSONArray("nodeConnectors");
-        Assert.assertEquals(portList2.get(0), portListGet2.get(0));
-        Assert.assertEquals(portList2.get(1), portListGet2.get(1));
-        Assert.assertEquals(portList2.get(2), portListGet2.get(2));
-        Assert.assertTrue(portListGet2.length() == 3);
-
-        // Test DELETE subnet1
-        result = getJsonResult(baseURL + "default/subnet/" + name1, "DELETE");
-        Assert.assertEquals(204, httpResponseCode.intValue());
-
-        // Test GET deleted subnet1
-        result = getJsonResult(baseURL + "default/subnet/" + name1);
-        Assert.assertEquals(404, httpResponseCode.intValue());
-
-        // TEST PUT bad subnet, expect 400, validate JSON exception mapper
-        JSONObject joBad = new JSONObject().put("foo", "bar");
-        result = getJsonResult(baseURL + "default/subnet/foo", "PUT", joBad.toString());
-        Assert.assertEquals(400, httpResponseCode.intValue());
-  }
-
-    @Test
-    public void testStaticRoutingNorthbound() throws JSONException {
-        System.out.println("Starting StaticRouting JAXB client.");
-        String baseURL = baseUrlPrefix + "staticroute/";
-
-        String name1 = "testRoute1";
-        String prefix1 = "192.168.1.1/24";
-        String nextHop1 = "0.0.0.0";
-        String name2 = "testRoute2";
-        String prefix2 = "192.168.1.1/16";
-        String nextHop2 = "1.1.1.1";
-
-        // Test GET static routes in default container, expecting no results
-        String result = getJsonResult(baseURL + "default/routes");
-        JSONTokener jt = new JSONTokener(result);
-        JSONObject json = new JSONObject(jt);
-        JSONArray staticRoutes = json.getJSONArray("staticRoute");
-        Assert.assertEquals(staticRoutes.length(), 0);
-
-        // Test insert static route
-        String requestBody = "{\"name\":\"" + name1 + "\", \"prefix\":\"" + prefix1 + "\", \"nextHop\":\"" + nextHop1
-                + "\"}";
-        result = getJsonResult(baseURL + "default/route/" + name1, "PUT", requestBody);
-        Assert.assertEquals(201, httpResponseCode.intValue());
-
-        requestBody = "{\"name\":\"" + name2 + "\", \"prefix\":\"" + prefix2 + "\", \"nextHop\":\"" + nextHop2 + "\"}";
-        result = getJsonResult(baseURL + "default/route/" + name2, "PUT", requestBody);
-        Assert.assertEquals(201, httpResponseCode.intValue());
-
-        // Test Get all static routes
-        result = getJsonResult(baseURL + "default/routes");
-        jt = new JSONTokener(result);
-        json = new JSONObject(jt);
-        JSONArray staticRouteArray = json.getJSONArray("staticRoute");
-        Assert.assertEquals(2, staticRouteArray.length());
-        JSONObject route;
-        for (int i = 0; i < staticRoutes.length(); i++) {
-            route = staticRoutes.getJSONObject(i);
-            if (route.getString("name").equals(name1)) {
-                Assert.assertEquals(prefix1, route.getString("prefix"));
-                Assert.assertEquals(nextHop1, route.getString("nextHop"));
-            } else if (route.getString("name").equals(name2)) {
-                Assert.assertEquals(prefix2, route.getString("prefix"));
-                Assert.assertEquals(nextHop2, route.getString("nextHop"));
-            } else {
-                // static route has unknown name
-                Assert.assertTrue(false);
-            }
-        }
-
-        // Test get specific static route
-        result = getJsonResult(baseURL + "default/route/" + name1);
-        jt = new JSONTokener(result);
-        json = new JSONObject(jt);
-
-        Assert.assertEquals(name1, json.getString("name"));
-        Assert.assertEquals(prefix1, json.getString("prefix"));
-        Assert.assertEquals(nextHop1, json.getString("nextHop"));
-
-        result = getJsonResult(baseURL + "default/route/" + name2);
-        jt = new JSONTokener(result);
-        json = new JSONObject(jt);
-
-        Assert.assertEquals(name2, json.getString("name"));
-        Assert.assertEquals(prefix2, json.getString("prefix"));
-        Assert.assertEquals(nextHop2, json.getString("nextHop"));
-
-        // Test delete static route
-        result = getJsonResult(baseURL + "default/route/" + name1, "DELETE");
-        Assert.assertEquals(204, httpResponseCode.intValue());
-
-        result = getJsonResult(baseURL + "default/routes");
-        jt = new JSONTokener(result);
-        json = new JSONObject(jt);
-
-        staticRouteArray = json.getJSONArray("staticRoute");
-        JSONObject singleStaticRoute = staticRouteArray.getJSONObject(0);
-        Assert.assertEquals(name2, singleStaticRoute.getString("name"));
-
-    }
-
-    @Test
-    public void testSwitchManager() throws JSONException {
-        System.out.println("Starting SwitchManager JAXB client.");
-        String baseURL = baseUrlPrefix + "switchmanager/default/";
-
-        // define Node/NodeConnector attributes for test
-        int nodeId_1 = 51966;
-        int nodeId_2 = 3366;
-        int nodeId_3 = 4477;
-        int nodeConnectorId_1 = 51966;
-        int nodeConnectorId_2 = 12;
-        int nodeConnectorId_3 = 34;
-        String nodeType = "STUB";
-        String ncType = "STUB";
-        int timestamp_1 = 100000;
-        String timestampName_1 = "connectedSince";
-        int actionsValue_1 = 2;
-        int capabilitiesValue_1 = 3;
-        int tablesValue_1 = 1;
-        int buffersValue_1 = 1;
-        int ncState = 1;
-        int ncCapabilities = 1;
-        int ncBandwidth = 1000000000;
-
-        // Test GET all nodes
-
-        String result = getJsonResult(baseURL + "nodes");
-        JSONTokener jt = new JSONTokener(result);
-        JSONObject json = new JSONObject(jt);
-
-        // Test for first node
-        JSONObject node = getJsonInstance(json, "nodeProperties", nodeId_1);
-        Assert.assertNotNull(node);
-        testNodeProperties(node, nodeId_1, nodeType, timestamp_1, timestampName_1, actionsValue_1, capabilitiesValue_1,
-                tablesValue_1, buffersValue_1);
-
-        // Test 2nd node, properties of 2nd node same as first node
-        node = getJsonInstance(json, "nodeProperties", nodeId_2);
-        Assert.assertNotNull(node);
-        testNodeProperties(node, nodeId_2, nodeType, timestamp_1, timestampName_1, actionsValue_1, capabilitiesValue_1,
-                tablesValue_1, buffersValue_1);
-
-        // Test 3rd node, properties of 3rd node same as first node
-        node = getJsonInstance(json, "nodeProperties", nodeId_3);
-        Assert.assertNotNull(node);
-        testNodeProperties(node, nodeId_3, nodeType, timestamp_1, timestampName_1, actionsValue_1, capabilitiesValue_1,
-                tablesValue_1, buffersValue_1);
-
-        // Test GET nodeConnectors of a node
-        // Test first node
-        result = getJsonResult(baseURL + "node/STUB/" + nodeId_1);
-        jt = new JSONTokener(result);
-        json = new JSONObject(jt);
-        JSONArray nodeConnectorPropertiesArray = json.getJSONArray("nodeConnectorProperties");
-        JSONObject nodeConnectorProperties = nodeConnectorPropertiesArray.getJSONObject(0);
-
-        testNodeConnectorProperties(nodeConnectorProperties, nodeConnectorId_1, ncType, nodeId_1, nodeType, ncState,
-                ncCapabilities, ncBandwidth);
-
-        // Test second node
-        result = getJsonResult(baseURL + "node/STUB/" + nodeId_2);
-        jt = new JSONTokener(result);
-        json = new JSONObject(jt);
-
-        nodeConnectorPropertiesArray = json.getJSONArray("nodeConnectorProperties");
-        nodeConnectorProperties = nodeConnectorPropertiesArray.getJSONObject(0);
-
-
-        testNodeConnectorProperties(nodeConnectorProperties, nodeConnectorId_2, ncType, nodeId_2, nodeType, ncState,
-                ncCapabilities, ncBandwidth);
-
-        // Test third node
-        result = getJsonResult(baseURL + "node/STUB/" + nodeId_3);
-        jt = new JSONTokener(result);
-        json = new JSONObject(jt);
-
-        nodeConnectorPropertiesArray = json.getJSONArray("nodeConnectorProperties");
-        nodeConnectorProperties = nodeConnectorPropertiesArray.getJSONObject(0);
-        testNodeConnectorProperties(nodeConnectorProperties, nodeConnectorId_3, ncType, nodeId_3, nodeType, ncState,
-                ncCapabilities, ncBandwidth);
-
-        // Test add property to node
-        // Add Tier and Description property to node1
-        result = getJsonResult(baseURL + "node/STUB/" + nodeId_1 + "/property/tier/1001", "PUT");
-        Assert.assertEquals(201, httpResponseCode.intValue());
-        result = getJsonResult(baseURL + "node/STUB/" + nodeId_1 + "/property/description/node1", "PUT");
-        Assert.assertEquals(201, httpResponseCode.intValue());
-
-        // Test for first node
-        result = getJsonResult(baseURL + "nodes");
-        jt = new JSONTokener(result);
-        json = new JSONObject(jt);
-        node = getJsonInstance(json, "nodeProperties", nodeId_1);
-        Assert.assertNotNull(node);
-        Assert.assertEquals(1001, node.getJSONObject("properties").getJSONObject("tier").getInt("value"));
-        Assert.assertEquals("node1", node.getJSONObject("properties").getJSONObject("description").getString("value"));
-
-        // Test delete nodeConnector property
-        // Delete state property of nodeconnector1
-        result = getJsonResult(baseURL + "nodeconnector/STUB/" + nodeId_1 + "/STUB/" + nodeConnectorId_1
-                + "/property/state", "DELETE");
-        Assert.assertEquals(204, httpResponseCode.intValue());
-
-        result = getJsonResult(baseURL + "node/STUB/" + nodeId_1);
-        jt = new JSONTokener(result);
-        json = new JSONObject(jt);
-        nodeConnectorPropertiesArray = json.getJSONArray("nodeConnectorProperties");
-        nodeConnectorProperties = nodeConnectorPropertiesArray.getJSONObject(0);
-
-        testNodeConnectorProperties(nodeConnectorProperties, nodeConnectorId_1, ncType, nodeId_1, nodeType, null,
-                ncCapabilities, ncBandwidth);
-
-        // Delete capabilities property of nodeconnector2
-        result = getJsonResult(baseURL + "nodeconnector/STUB/" + nodeId_2 + "/STUB/" + nodeConnectorId_2
-                + "/property/capabilities", "DELETE");
-        Assert.assertEquals(204, httpResponseCode.intValue());
-
-        result = getJsonResult(baseURL + "node/STUB/" + nodeId_2);
-        jt = new JSONTokener(result);
-        json = new JSONObject(jt);
-        nodeConnectorPropertiesArray = json.getJSONArray("nodeConnectorProperties");
-        nodeConnectorProperties = nodeConnectorPropertiesArray.getJSONObject(0);
-
-        testNodeConnectorProperties(nodeConnectorProperties, nodeConnectorId_2, ncType, nodeId_2, nodeType, ncState,
-                null, ncBandwidth);
-
-        // Test PUT nodeConnector property
-        int newBandwidth = 1001;
-
-        // Add Name/Bandwidth property to nodeConnector1
-        result = getJsonResult(baseURL + "nodeconnector/STUB/" + nodeId_1 + "/STUB/" + nodeConnectorId_1
-                + "/property/bandwidth/" + newBandwidth, "PUT");
-        Assert.assertEquals(201, httpResponseCode.intValue());
-
-        result = getJsonResult(baseURL + "node/STUB/" + nodeId_1);
-        jt = new JSONTokener(result);
-        json = new JSONObject(jt);
-        nodeConnectorPropertiesArray = json.getJSONArray("nodeConnectorProperties");
-        nodeConnectorProperties = nodeConnectorPropertiesArray.getJSONObject(0);
-
-        // Check for new bandwidth value, state value removed from previous
-        // test
-        testNodeConnectorProperties(nodeConnectorProperties, nodeConnectorId_1, ncType, nodeId_1, nodeType, null,
-                ncCapabilities, newBandwidth);
-
-    }
-
-    @Test
-    public void testStatistics() throws JSONException {
-        final String actionTypes[] = { "DROP", "LOOPBACK", "FLOOD", "FLOOD_ALL", "CONTROLLER", "SW_PATH", "HW_PATH", "OUTPUT",
-                "SET_DL_SRC", "SET_DL_DST", "SET_DL_TYPE", "SET_VLAN_ID", "SET_VLAN_PCP", "SET_VLAN_CFI", "POP_VLAN", "PUSH_VLAN",
-                "SET_NW_SRC", "SET_NW_DST", "SET_NW_TOS", "SET_TP_SRC", "SET_TP_DST" };
-        System.out.println("Starting Statistics JAXB client.");
-
-        String baseURL = baseUrlPrefix + "statistics/default/";
-
-        String result = getJsonResult(baseURL + "flow");
-        JSONTokener jt = new JSONTokener(result);
-        JSONObject json = new JSONObject(jt);
-        JSONObject flowStatistics = getJsonInstance(json, "flowStatistics", 0xCAFE);
-        JSONObject node = flowStatistics.getJSONObject("node");
-        // test that node was returned properly
-        Assert.assertTrue(node.getInt("id") == 0xCAFE);
-        Assert.assertEquals(node.getString("type"), "STUB");
-
-        // test that flow statistics results are correct
-        JSONArray flowStats = flowStatistics.getJSONArray("flowStatistic");
-        for (int i = 0; i < flowStats.length(); i++) {
-
-            JSONObject flowStat = flowStats.getJSONObject(i);
-            testFlowStat(flowStat, actionTypes[i], i);
-
-        }
-
-        // for /controller/nb/v2/statistics/default/port
-        result = getJsonResult(baseURL + "port");
-        jt = new JSONTokener(result);
-        json = new JSONObject(jt);
-        JSONObject portStatistics = getJsonInstance(json, "portStatistics", 0xCAFE);
-        JSONObject node2 = portStatistics.getJSONObject("node");
-        // test that node was returned properly
-        Assert.assertTrue(node2.getInt("id") == 0xCAFE);
-        Assert.assertEquals(node2.getString("type"), "STUB");
-
-        // test that port statistic results are correct
-        JSONArray portStatArray = portStatistics.getJSONArray("portStatistic");
-        JSONObject portStat = portStatArray.getJSONObject(0);
-        Assert.assertTrue(portStat.getInt("receivePackets") == 250);
-        Assert.assertTrue(portStat.getInt("transmitPackets") == 500);
-        Assert.assertTrue(portStat.getInt("receiveBytes") == 1000);
-        Assert.assertTrue(portStat.getInt("transmitBytes") == 5000);
-        Assert.assertTrue(portStat.getInt("receiveDrops") == 2);
-        Assert.assertTrue(portStat.getInt("transmitDrops") == 50);
-        Assert.assertTrue(portStat.getInt("receiveErrors") == 3);
-        Assert.assertTrue(portStat.getInt("transmitErrors") == 10);
-        Assert.assertTrue(portStat.getInt("receiveFrameError") == 5);
-        Assert.assertTrue(portStat.getInt("receiveOverRunError") == 6);
-        Assert.assertTrue(portStat.getInt("receiveCrcError") == 1);
-        Assert.assertTrue(portStat.getInt("collisionCount") == 4);
-
-        // test for getting one specific node's stats
-        result = getJsonResult(baseURL + "flow/node/STUB/51966");
-        jt = new JSONTokener(result);
-        json = new JSONObject(jt);
-        node = json.getJSONObject("node");
-        // test that node was returned properly
-        Assert.assertTrue(node.getInt("id") == 0xCAFE);
-        Assert.assertEquals(node.getString("type"), "STUB");
-
-        // test that flow statistics results are correct
-        flowStats = json.getJSONArray("flowStatistic");
-        for (int i = 0; i < flowStats.length(); i++) {
-            JSONObject flowStat = flowStats.getJSONObject(i);
-            testFlowStat(flowStat, actionTypes[i], i);
-        }
-
-        result = getJsonResult(baseURL + "port/node/STUB/51966");
-        jt = new JSONTokener(result);
-        json = new JSONObject(jt);
-        node2 = json.getJSONObject("node");
-        // test that node was returned properly
-        Assert.assertTrue(node2.getInt("id") == 0xCAFE);
-        Assert.assertEquals(node2.getString("type"), "STUB");
-
-        // test that port statistic results are correct
-        portStatArray = json.getJSONArray("portStatistic");
-        portStat = portStatArray.getJSONObject(0);
-
-        Assert.assertTrue(portStat.getInt("receivePackets") == 250);
-        Assert.assertTrue(portStat.getInt("transmitPackets") == 500);
-        Assert.assertTrue(portStat.getInt("receiveBytes") == 1000);
-        Assert.assertTrue(portStat.getInt("transmitBytes") == 5000);
-        Assert.assertTrue(portStat.getInt("receiveDrops") == 2);
-        Assert.assertTrue(portStat.getInt("transmitDrops") == 50);
-        Assert.assertTrue(portStat.getInt("receiveErrors") == 3);
-        Assert.assertTrue(portStat.getInt("transmitErrors") == 10);
-        Assert.assertTrue(portStat.getInt("receiveFrameError") == 5);
-        Assert.assertTrue(portStat.getInt("receiveOverRunError") == 6);
-        Assert.assertTrue(portStat.getInt("receiveCrcError") == 1);
-        Assert.assertTrue(portStat.getInt("collisionCount") == 4);
-    }
-
-    private void testFlowStat(JSONObject flowStat, String actionType, int actIndex) throws JSONException {
-        Assert.assertTrue(flowStat.getInt("tableId") == 1);
-        Assert.assertTrue(flowStat.getInt("durationSeconds") == 40);
-        Assert.assertTrue(flowStat.getInt("durationNanoseconds") == 400);
-        Assert.assertTrue(flowStat.getInt("packetCount") == 200);
-        Assert.assertTrue(flowStat.getInt("byteCount") == 100);
-
-        // test that flow information is correct
-        JSONObject flow = flowStat.getJSONObject("flow");
-        Assert.assertTrue(flow.getInt("priority") == (3500 + actIndex));
-        Assert.assertTrue(flow.getInt("idleTimeout") == 1000);
-        Assert.assertTrue(flow.getInt("hardTimeout") == 2000);
-        Assert.assertTrue(flow.getInt("id") == 12345);
-
-        JSONArray matches = (flow.getJSONObject("match").getJSONArray("matchField"));
-        Assert.assertEquals(matches.length(), 1);
-        JSONObject match = matches.getJSONObject(0);
-        Assert.assertTrue(match.getString("type").equals("NW_DST"));
-        Assert.assertTrue(match.getString("value").equals("1.1.1.1"));
-
-        JSONArray actionsArray = flow.getJSONArray("actions");
-        Assert.assertEquals(actionsArray.length(), 1);
-        JSONObject act = actionsArray.getJSONObject(0);
-        Assert.assertTrue(act.getString("type").equals(actionType));
-
-        if (act.getString("type").equals("OUTPUT")) {
-            JSONObject port = act.getJSONObject("port");
-            JSONObject port_node = port.getJSONObject("node");
-            Assert.assertTrue(port.getInt("id") == 51966);
-            Assert.assertTrue(port.getString("type").equals("STUB"));
-            Assert.assertTrue(port_node.getInt("id") == 51966);
-            Assert.assertTrue(port_node.getString("type").equals("STUB"));
-        }
-
-        if (act.getString("type").equals("SET_DL_SRC")) {
-            byte srcMatch[] = { (byte) 5, (byte) 4, (byte) 3, (byte) 2, (byte) 1 };
-            String src = act.getString("address");
-            byte srcBytes[] = new byte[5];
-            srcBytes[0] = Byte.parseByte(src.substring(0, 2));
-            srcBytes[1] = Byte.parseByte(src.substring(2, 4));
-            srcBytes[2] = Byte.parseByte(src.substring(4, 6));
-            srcBytes[3] = Byte.parseByte(src.substring(6, 8));
-            srcBytes[4] = Byte.parseByte(src.substring(8, 10));
-            Assert.assertTrue(Arrays.equals(srcBytes, srcMatch));
-        }
-
-        if (act.getString("type").equals("SET_DL_DST")) {
-            byte dstMatch[] = { (byte) 1, (byte) 2, (byte) 3, (byte) 4, (byte) 5 };
-            String dst = act.getString("address");
-            byte dstBytes[] = new byte[5];
-            dstBytes[0] = Byte.parseByte(dst.substring(0, 2));
-            dstBytes[1] = Byte.parseByte(dst.substring(2, 4));
-            dstBytes[2] = Byte.parseByte(dst.substring(4, 6));
-            dstBytes[3] = Byte.parseByte(dst.substring(6, 8));
-            dstBytes[4] = Byte.parseByte(dst.substring(8, 10));
-            Assert.assertTrue(Arrays.equals(dstBytes, dstMatch));
-        }
-        if (act.getString("type").equals("SET_DL_TYPE")) {
-            Assert.assertTrue(act.getInt("dlType") == 10);
-        }
-        if (act.getString("type").equals("SET_VLAN_ID")) {
-            Assert.assertTrue(act.getInt("vlanId") == 2);
-        }
-        if (act.getString("type").equals("SET_VLAN_PCP")) {
-            Assert.assertTrue(act.getInt("pcp") == 3);
-        }
-        if (act.getString("type").equals("SET_VLAN_CFI")) {
-            Assert.assertTrue(act.getInt("cfi") == 1);
-        }
-
-        if (act.getString("type").equals("SET_NW_SRC")) {
-            Assert.assertTrue(act.getString("address").equals("2.2.2.2"));
-        }
-        if (act.getString("type").equals("SET_NW_DST")) {
-            Assert.assertTrue(act.getString("address").equals("1.1.1.1"));
-        }
-
-        if (act.getString("type").equals("PUSH_VLAN")) {
-            int head = act.getInt("VlanHeader");
-            // parsing vlan header
-            int id = head & 0xfff;
-            int cfi = (head >> 12) & 0x1;
-            int pcp = (head >> 13) & 0x7;
-            int tag = (head >> 16) & 0xffff;
-            Assert.assertTrue(id == 1234);
-            Assert.assertTrue(cfi == 1);
-            Assert.assertTrue(pcp == 1);
-            Assert.assertTrue(tag == 0x8100);
-        }
-        if (act.getString("type").equals("SET_NW_TOS")) {
-            Assert.assertTrue(act.getInt("tos") == 16);
-        }
-        if (act.getString("type").equals("SET_TP_SRC")) {
-            Assert.assertTrue(act.getInt("port") == 4201);
-        }
-        if (act.getString("type").equals("SET_TP_DST")) {
-            Assert.assertTrue(act.getInt("port") == 8080);
-        }
-    }
-
-    @Test
-    public void testFlowProgrammer() throws JSONException {
-        System.out.println("Starting FlowProgrammer JAXB client.");
-        String baseURL = baseUrlPrefix + "flowprogrammer/default/";
-        // Attempt to get a flow that doesn't exit. Should return 404
-        // status.
-        String result = getJsonResult(baseURL + "node/STUB/51966/staticFlow/test1", "GET");
-        Assert.assertTrue(result.equals("404"));
-
-        // test add flow1
-        String fc = "{\"name\":\"test1\", \"node\":{\"id\":\"51966\",\"type\":\"STUB\"}, \"actions\":[\"DROP\"]}";
-        result = getJsonResult(baseURL + "node/STUB/51966/staticFlow/test1", "PUT", fc);
-        Assert.assertTrue(httpResponseCode == 201);
-
-        // test get returns flow that was added.
-        result = getJsonResult(baseURL + "node/STUB/51966/staticFlow/test1", "GET");
-        // check that result came out fine.
-        Assert.assertTrue(httpResponseCode == 200);
-        JSONTokener jt = new JSONTokener(result);
-        JSONObject json = new JSONObject(jt);
-        Assert.assertEquals(json.getString("name"), "test1");
-        JSONArray actionsArray = json.getJSONArray("actions");
-        Assert.assertEquals(actionsArray.getString(0), "DROP");
-        Assert.assertEquals(json.getString("installInHw"), "true");
-        JSONObject node = json.getJSONObject("node");
-        Assert.assertEquals(node.getString("type"), "STUB");
-        Assert.assertEquals(node.getString("id"), "51966");
-        // test adding same flow again succeeds with a change in any field ..return Success
-        // code
-        fc = "{\"name\":\"test1\", \"node\":{\"id\":\"51966\",\"type\":\"STUB\"}, \"actions\":[\"LOOPBACK\"]}";
-        result = getJsonResult(baseURL + "node/STUB/51966/staticFlow/test1", "PUT", fc);
-        Assert.assertTrue(result.contains("Success"));
-
-        fc = "{\"name\":\"test2\", \"node\":{\"id\":\"51966\",\"type\":\"STUB\"}, \"actions\":[\"DROP\"]}";
-        result = getJsonResult(baseURL + "node/STUB/51966/staticFlow/test2", "PUT", fc);
-        // test should return 409 for error due to same flow being added.
-        Assert.assertTrue(result.equals("409"));
-
-        // add second flow that's different
-        fc = "{\"name\":\"test2\", \"nwSrc\":\"1.1.1.1\", \"node\":{\"id\":\"51966\",\"type\":\"STUB\"}, \"actions\":[\"DROP\"]}";
-        result = getJsonResult(baseURL + "node/STUB/51966/staticFlow/test2", "PUT", fc);
-        Assert.assertTrue(httpResponseCode == 201);
-
-        // check that request returns both flows given node.
-        result = getJsonResult(baseURL + "node/STUB/51966/", "GET");
-        jt = new JSONTokener(result);
-        json = new JSONObject(jt);
-        Assert.assertTrue(json.get("flowConfig") instanceof JSONArray);
-        JSONArray ja = json.getJSONArray("flowConfig");
-        Integer count = ja.length();
-        Assert.assertTrue(count == 2);
-
-        // check that request returns both flows given just container.
-        result = getJsonResult(baseURL);
-        jt = new JSONTokener(result);
-        json = new JSONObject(jt);
-        Assert.assertTrue(json.get("flowConfig") instanceof JSONArray);
-        ja = json.getJSONArray("flowConfig");
-        count = ja.length();
-        Assert.assertTrue(count == 2);
-
-        // delete a flow, check that it's no longer in list.
-        result = getJsonResult(baseURL + "node/STUB/51966/staticFlow/test2", "DELETE");
-        Assert.assertTrue(httpResponseCode == 204);
-
-        result = getJsonResult(baseURL + "node/STUB/51966/staticFlow/test2", "GET");
-        Assert.assertTrue(result.equals("404"));
-    }
-
-    // method to extract a JSONObject with specified node ID from a JSONObject
-    // that may contain an array of JSONObjects
-    // This is specifically written for statistics manager northbound REST
-    // interface
-    // array_name should be either "flowStatistics" or "portStatistics"
-    private JSONObject getJsonInstance(JSONObject json, String array_name, Integer nodeId) throws JSONException {
-        JSONObject result = null;
-        if (json.get(array_name) instanceof JSONArray) {
-            JSONArray json_array = json.getJSONArray(array_name);
-            for (int i = 0; i < json_array.length(); i++) {
-                result = json_array.getJSONObject(i);
-                Integer nid = result.getJSONObject("node").getInt("id");
-                if (nid.equals(nodeId)) {
-                    break;
-                }
-            }
-        } else {
-            result = json.getJSONObject(array_name);
-            Integer nid = result.getJSONObject("node").getInt("id");
-            if (!nid.equals(nodeId)) {
-                result = null;
-            }
-        }
-        return result;
-    }
-
-    // a class to construct query parameter for HTTP request
-    private class QueryParameter {
-        StringBuilder queryString = null;
-
-        // constructor
-        QueryParameter(String key, String value) {
-            queryString = new StringBuilder();
-            queryString.append("?").append(key).append("=").append(value);
-        }
-
-        // method to add more query parameter
-        QueryParameter add(String key, String value) {
-            this.queryString.append("&").append(key).append("=").append(value);
-            return this;
-        }
-
-        // method to get the query parameter string
-        String getString() {
-            return this.queryString.toString();
-        }
-
-    }
-
-    @Test
-    public void testHostTracker() throws JSONException {
-
-        System.out.println("Starting HostTracker JAXB client.");
-
-        // setup 2 host models for @POST method
-        // 1st host
-        String networkAddress_1 = "192.168.0.8";
-        String dataLayerAddress_1 = "11:22:33:44:55:66";
-        String nodeType_1 = "STUB";
-        Integer nodeId_1 = 3366;
-        String nodeConnectorType_1 = "STUB";
-        Integer nodeConnectorId_1 = 12;
-        String vlan_1 = "";
-
-        // 2nd host
-        String networkAddress_2 = "10.1.1.1";
-        String dataLayerAddress_2 = "1A:2B:3C:4D:5E:6F";
-        String nodeType_2 = "STUB";
-        Integer nodeId_2 = 4477;
-        String nodeConnectorType_2 = "STUB";
-        Integer nodeConnectorId_2 = 34;
-        String vlan_2 = "123";
-
-        String baseURL = baseUrlPrefix + "hosttracker/default";
-
-        // test PUT method: addHost()
-        JSONObject fc_json = new JSONObject();
-        fc_json.put("dataLayerAddress", dataLayerAddress_1);
-        fc_json.put("nodeType", nodeType_1);
-        fc_json.put("nodeId", nodeId_1);
-        fc_json.put("nodeConnectorType", nodeType_1);
-        fc_json.put("nodeConnectorId", nodeConnectorId_1.toString());
-        fc_json.put("vlan", vlan_1);
-        fc_json.put("staticHost", "true");
-        fc_json.put("networkAddress", networkAddress_1);
-
-        String result = getJsonResult(baseURL + "/address/" + networkAddress_1, "PUT", fc_json.toString());
-        Assert.assertTrue(httpResponseCode == 201);
-
-        fc_json = new JSONObject();
-        fc_json.put("dataLayerAddress", dataLayerAddress_2);
-        fc_json.put("nodeType", nodeType_2);
-        fc_json.put("nodeId", nodeId_2);
-        fc_json.put("nodeConnectorType", nodeType_2);
-        fc_json.put("nodeConnectorId", nodeConnectorId_2.toString());
-        fc_json.put("vlan", vlan_2);
-        fc_json.put("staticHost", "true");
-        fc_json.put("networkAddress", networkAddress_2);
-
-        result = getJsonResult(baseURL + "/address/" + networkAddress_2 , "PUT", fc_json.toString());
-        Assert.assertTrue(httpResponseCode == 201);
-
-        // define variables for decoding returned strings
-        String networkAddress;
-        JSONObject host_jo;
-
-        // the two hosts should be in inactive host DB
-        // test GET method: getInactiveHosts()
-        result = getJsonResult(baseURL + "/hosts/inactive", "GET");
-        Assert.assertTrue(httpResponseCode == 200);
-
-        JSONTokener jt = new JSONTokener(result);
-        JSONObject json = new JSONObject(jt);
-        // there should be at least two hosts in the DB
-        Assert.assertTrue(json.get("hostConfig") instanceof JSONArray);
-        JSONArray ja = json.getJSONArray("hostConfig");
-        Integer count = ja.length();
-        Assert.assertTrue(count == 2);
-
-        for (int i = 0; i < count; i++) {
-            host_jo = ja.getJSONObject(i);
-            networkAddress = host_jo.getString("networkAddress");
-            if (networkAddress.equalsIgnoreCase(networkAddress_1)) {
-                Assert.assertTrue(host_jo.getString("dataLayerAddress").equalsIgnoreCase(dataLayerAddress_1));
-                Assert.assertTrue(host_jo.getString("nodeConnectorType").equalsIgnoreCase(nodeConnectorType_1));
-                Assert.assertTrue(host_jo.getInt("nodeConnectorId") == nodeConnectorId_1);
-                Assert.assertTrue(host_jo.getString("nodeType").equalsIgnoreCase(nodeType_1));
-                Assert.assertTrue(host_jo.getInt("nodeId") == nodeId_1);
-                Assert.assertTrue(host_jo.getString("vlan").equals("0"));
-                Assert.assertTrue(host_jo.getBoolean("staticHost"));
-            } else if (networkAddress.equalsIgnoreCase(networkAddress_2)) {
-                Assert.assertTrue(host_jo.getString("dataLayerAddress").equalsIgnoreCase(dataLayerAddress_2));
-                Assert.assertTrue(host_jo.getString("nodeConnectorType").equalsIgnoreCase(nodeConnectorType_2));
-                Assert.assertTrue(host_jo.getInt("nodeConnectorId") == nodeConnectorId_2);
-                Assert.assertTrue(host_jo.getString("nodeType").equalsIgnoreCase(nodeType_2));
-                Assert.assertTrue(host_jo.getInt("nodeId") == nodeId_2);
-                Assert.assertTrue(host_jo.getString("vlan").equalsIgnoreCase(vlan_2));
-                Assert.assertTrue(host_jo.getBoolean("staticHost"));
-            } else {
-                Assert.assertTrue(false);
-            }
-        }
-
-        // test GET method: getActiveHosts() - no host expected
-        result = getJsonResult(baseURL + "/hosts/active", "GET");
-        Assert.assertTrue(httpResponseCode == 200);
-
-        jt = new JSONTokener(result);
-        json = new JSONObject(jt);
-        Assert.assertFalse(hostInJson(json, networkAddress_1));
-        Assert.assertFalse(hostInJson(json, networkAddress_2));
-
-        // put the 1st host into active host DB
-        Node nd;
-        NodeConnector ndc;
-        try {
-            nd = new Node(nodeType_1, nodeId_1);
-            ndc = new NodeConnector(nodeConnectorType_1, nodeConnectorId_1, nd);
-            this.invtoryListener.notifyNodeConnector(ndc, UpdateType.ADDED, null);
-        } catch (ConstructionException e) {
-            ndc = null;
-            nd = null;
-        }
-
-        // verify the host shows up in active host DB
-
-        result = getJsonResult(baseURL + "/hosts/active", "GET");
-        Assert.assertTrue(httpResponseCode == 200);
-
-        jt = new JSONTokener(result);
-        json = new JSONObject(jt);
-
-        Assert.assertTrue(hostInJson(json, networkAddress_1));
-
-        // test GET method for getHostDetails()
-
-        result = getJsonResult(baseURL + "/address/" + networkAddress_1, "GET");
-        Assert.assertTrue(httpResponseCode == 200);
-
-        jt = new JSONTokener(result);
-        json = new JSONObject(jt);
-
-        Assert.assertFalse(json.length() == 0);
-
-        Assert.assertTrue(json.getString("dataLayerAddress").equalsIgnoreCase(dataLayerAddress_1));
-        Assert.assertTrue(json.getString("nodeConnectorType").equalsIgnoreCase(nodeConnectorType_1));
-        Assert.assertTrue(json.getInt("nodeConnectorId") == nodeConnectorId_1);
-        Assert.assertTrue(json.getString("nodeType").equalsIgnoreCase(nodeType_1));
-        Assert.assertTrue(json.getInt("nodeId") == nodeId_1);
-        Assert.assertTrue(json.getString("vlan").equals("0"));
-        Assert.assertTrue(json.getBoolean("staticHost"));
-
-        // test DELETE method for deleteFlow()
-
-        result = getJsonResult(baseURL + "/address/" + networkAddress_1, "DELETE");
-        Assert.assertTrue(httpResponseCode == 204);
-
-        // verify host_1 removed from active host DB
-        // test GET method: getActiveHosts() - no host expected
-
-        result = getJsonResult(baseURL + "/hosts/active", "GET");
-        Assert.assertTrue(httpResponseCode == 200);
-
-        jt = new JSONTokener(result);
-        json = new JSONObject(jt);
-
-        Assert.assertFalse(hostInJson(json, networkAddress_1));
-
-    }
-
-    private Boolean hostInJson(JSONObject json, String hostIp) throws JSONException {
-        // input JSONObject may be empty
-        if (json.length() == 0) {
-            return false;
-        }
-        if (json.get("hostConfig") instanceof JSONArray) {
-            JSONArray ja = json.getJSONArray("hostConfig");
-            for (int i = 0; i < ja.length(); i++) {
-                String na = ja.getJSONObject(i).getString("networkAddress");
-                if (na.equalsIgnoreCase(hostIp)) {
-                    return true;
-                }
-            }
-            return false;
-        } else {
-            JSONObject ja = json.getJSONObject("hostConfig");
-            String na = ja.getString("networkAddress");
-            return na.equalsIgnoreCase(hostIp);
-        }
-    }
-
-    @Test
-    public void testTopology() throws JSONException, ConstructionException {
-        System.out.println("Starting Topology JAXB client.");
-        String baseURL = baseUrlPrefix + "topology/default";
-
-        // === test GET method for getTopology()
-        short state_1 = State.EDGE_UP, state_2 = State.EDGE_DOWN;
-        long bw_1 = Bandwidth.BW10Gbps, bw_2 = Bandwidth.BW100Mbps;
-        long lat_1 = Latency.LATENCY100ns, lat_2 = Latency.LATENCY1ms;
-        String nodeType = "STUB";
-        String nodeConnType = "STUB";
-        int headNC1_nodeId = 1, headNC1_nodeConnId = 11;
-        int tailNC1_nodeId = 2, tailNC1_nodeConnId = 22;
-        int headNC2_nodeId = 2, headNC2_nodeConnId = 21;
-        int tailNC2_nodeId = 1, tailNC2_nodeConnId = 12;
-
-        List<TopoEdgeUpdate> topoedgeupdateList = new ArrayList<TopoEdgeUpdate>();
-        NodeConnector headnc1 = new NodeConnector(nodeConnType, headNC1_nodeConnId, new Node(nodeType, headNC1_nodeId));
-        NodeConnector tailnc1 = new NodeConnector(nodeConnType, tailNC1_nodeConnId, new Node(nodeType, tailNC1_nodeId));
-        Edge e1 = new Edge(tailnc1, headnc1);
-        Set<Property> props_1 = new HashSet<Property>();
-        props_1.add(new State(state_1));
-        props_1.add(new Bandwidth(bw_1));
-        props_1.add(new Latency(lat_1));
-        TopoEdgeUpdate teu1 = new TopoEdgeUpdate(e1, props_1, UpdateType.ADDED);
-        topoedgeupdateList.add(teu1);
-
-        NodeConnector headnc2 = new NodeConnector(nodeConnType, headNC2_nodeConnId, new Node(nodeType, headNC2_nodeId));
-        NodeConnector tailnc2 = new NodeConnector(nodeConnType, tailNC2_nodeConnId, new Node(nodeType, tailNC2_nodeId));
-        Edge e2 = new Edge(tailnc2, headnc2);
-        Set<Property> props_2 = new HashSet<Property>();
-        props_2.add(new State(state_2));
-        props_2.add(new Bandwidth(bw_2));
-        props_2.add(new Latency(lat_2));
-
-        TopoEdgeUpdate teu2 = new TopoEdgeUpdate(e2, props_2, UpdateType.ADDED);
-        topoedgeupdateList.add(teu2);
-
-        topoUpdates.edgeUpdate(topoedgeupdateList);
-
-        // HTTP request
-        String result = getJsonResult(baseURL, "GET");
-        Assert.assertTrue(httpResponseCode == 200);
-        if (debugMsg) {
-            System.out.println("Get Topology: " + result);
-        }
-
-        // returned data must be an array of edges
-        JSONTokener jt = new JSONTokener(result);
-        JSONObject json = new JSONObject(jt);
-        Assert.assertTrue(json.get("edgeProperties") instanceof JSONArray);
-        JSONArray ja = json.getJSONArray("edgeProperties");
-
-        for (int i = 0; i < ja.length(); i++) {
-            JSONObject edgeProp = ja.getJSONObject(i);
-            JSONObject edge = edgeProp.getJSONObject("edge");
-            JSONObject tailNC = edge.getJSONObject("tailNodeConnector");
-            JSONObject tailNode = tailNC.getJSONObject("node");
-
-            JSONObject headNC = edge.getJSONObject("headNodeConnector");
-            JSONObject headNode = headNC.getJSONObject("node");
-            JSONObject Props = edgeProp.getJSONObject("properties");
-            JSONObject bandw = Props.getJSONObject("bandwidth");
-            JSONObject stt = Props.getJSONObject("state");
-            JSONObject ltc = Props.getJSONObject("latency");
-
-            if (headNC.getInt("id") == headNC1_nodeConnId) {
-                Assert.assertEquals(headNode.getString("type"), nodeType);
-                Assert.assertEquals(headNode.getLong("id"), headNC1_nodeId);
-                Assert.assertEquals(headNC.getString("type"), nodeConnType);
-                Assert.assertEquals(tailNode.getString("type"),nodeType);
-                Assert.assertEquals(tailNode.getString("type"), nodeConnType);
-                Assert.assertEquals(tailNC.getLong("id"), tailNC1_nodeConnId);
-                Assert.assertEquals(bandw.getLong("value"), bw_1);
-                Assert.assertTrue((short) stt.getInt("value") == state_1);
-                Assert.assertEquals(ltc.getLong("value"), lat_1);
-            } else if (headNC.getInt("id") == headNC2_nodeConnId) {
-                Assert.assertEquals(headNode.getString("type"),nodeType);
-                Assert.assertEquals(headNode.getLong("id"), headNC2_nodeId);
-                Assert.assertEquals(headNC.getString("type"), nodeConnType);
-                Assert.assertEquals(tailNode.getString("type"), nodeType);
-                Assert.assertTrue(tailNode.getInt("id") == tailNC2_nodeId);
-                Assert.assertEquals(tailNC.getString("type"), nodeConnType);
-                Assert.assertEquals(tailNC.getLong("id"), tailNC2_nodeConnId);
-                Assert.assertEquals(bandw.getLong("value"), bw_2);
-                Assert.assertTrue((short) stt.getInt("value") == state_2);
-                Assert.assertEquals(ltc.getLong("value"), lat_2);
-            }
-        }
-
-        // === test POST method for addUserLink()
-        // define 2 sample nodeConnectors for user link configuration tests
-        String nodeType_1 = "STUB";
-        Integer nodeId_1 = 3366;
-        String nodeConnectorType_1 = "STUB";
-        Integer nodeConnectorId_1 = 12;
-        String nodeType_2 = "STUB";
-        Integer nodeId_2 = 4477;
-        String nodeConnectorType_2 = "STUB";
-        Integer nodeConnectorId_2 = 34;
-
-        JSONObject jo = new JSONObject()
-                .put("name", "userLink_1")
-                .put("srcNodeConnector",
-                        nodeConnectorType_1 + "|" + nodeConnectorId_1 + "@" + nodeType_1 + "|" + nodeId_1)
-                .put("dstNodeConnector",
-                        nodeConnectorType_2 + "|" + nodeConnectorId_2 + "@" + nodeType_2 + "|" + nodeId_2);
-        // execute HTTP request and verify response code
-        result = getJsonResult(baseURL + "/userLink/userLink_1", "PUT", jo.toString());
-        Assert.assertTrue(httpResponseCode == 201);
-
-        // === test GET method for getUserLinks()
-        result = getJsonResult(baseURL + "/userLinks", "GET");
-        Assert.assertTrue(httpResponseCode == 200);
-        if (debugMsg) {
-            System.out.println("result:" + result);
-        }
-
-        jt = new JSONTokener(result);
-        json = new JSONObject(jt);
-
-        // should have at least one object returned
-        Assert.assertFalse(json.length() == 0);
-        JSONObject userlink = new JSONObject();
-
-        if (json.get("userLinks") instanceof JSONArray) {
-            ja = json.getJSONArray("userLinks");
-            int i;
-            for (i = 0; i < ja.length(); i++) {
-                userlink = ja.getJSONObject(i);
-                if (userlink.getString("name").equalsIgnoreCase("userLink_1")) {
-                    break;
-                }
-            }
-            Assert.assertFalse(i == ja.length());
-        } else {
-            userlink = json.getJSONObject("userLinks");
-            Assert.assertTrue(userlink.getString("name").equalsIgnoreCase("userLink_1"));
-        }
-
-        String[] level_1, level_2;
-        level_1 = userlink.getString("srcNodeConnector").split("\\@");
-        level_2 = level_1[0].split("\\|");
-        Assert.assertTrue(level_2[0].equalsIgnoreCase(nodeConnectorType_1));
-        Assert.assertTrue(Integer.parseInt(level_2[1]) == nodeConnectorId_1);
-        level_2 = level_1[1].split("\\|");
-        Assert.assertTrue(level_2[0].equalsIgnoreCase(nodeType_1));
-        Assert.assertTrue(Integer.parseInt(level_2[1]) == nodeId_1);
-        level_1 = userlink.getString("dstNodeConnector").split("\\@");
-        level_2 = level_1[0].split("\\|");
-        Assert.assertTrue(level_2[0].equalsIgnoreCase(nodeConnectorType_2));
-        Assert.assertTrue(Integer.parseInt(level_2[1]) == nodeConnectorId_2);
-        level_2 = level_1[1].split("\\|");
-        Assert.assertTrue(level_2[0].equalsIgnoreCase(nodeType_2));
-        Assert.assertTrue(Integer.parseInt(level_2[1]) == nodeId_2);
-
-        // === test DELETE method for deleteUserLink()
-        String userName = "userLink_1";
-        result = getJsonResult(baseURL + "/userLink/" + userName, "DELETE");
-        Assert.assertTrue(httpResponseCode == 204);
-
-        // execute another getUserLinks() request to verify that userLink_1 is
-        // removed
-        result = getJsonResult(baseURL + "/userLinks", "GET");
-        Assert.assertTrue(httpResponseCode == 200);
-        if (debugMsg) {
-            System.out.println("result:" + result);
-        }
-        jt = new JSONTokener(result);
-        json = new JSONObject(jt);
-
-        if (json.length() != 0) {
-            if (json.get("userLinks") instanceof JSONArray) {
-                ja = json.getJSONArray("userLinks");
-                for (int i = 0; i < ja.length(); i++) {
-                    userlink = ja.getJSONObject(i);
-                    Assert.assertFalse(userlink.getString("name").equalsIgnoreCase("userLink_1"));
-                }
-            } else {
-                userlink = json.getJSONObject("userLinks");
-                Assert.assertFalse(userlink.getString("name").equalsIgnoreCase("userLink_1"));
-            }
-        }
-    }
-    // Configure the OSGi container
-    @Configuration
-    public Option[] config() {
-        return options(
-                //
-                systemProperty("logback.configurationFile").value(
-                        "file:" + PathUtils.getBaseDir() + "/src/test/resources/logback.xml"),
-                // To start OSGi console for inspection remotely
-                systemProperty("osgi.console").value("2401"),
-                systemProperty("org.eclipse.gemini.web.tomcat.config.path").value(
-                        PathUtils.getBaseDir() + "/src/test/resources/tomcat-server.xml"),
-
-                // setting default level. Jersey bundles will need to be started
-                // earlier.
-                systemProperty("osgi.bundles.defaultStartLevel").value("4"),
-
-                // Set the systemPackages (used by clustering)
-                systemPackages("sun.reflect", "sun.reflect.misc", "sun.misc"),
-                mavenBundle("org.slf4j", "jcl-over-slf4j").versionAsInProject(),
-                mavenBundle("org.slf4j", "slf4j-api").versionAsInProject(),
-                mavenBundle("org.slf4j", "log4j-over-slf4j").versionAsInProject(),
-                mavenBundle("ch.qos.logback", "logback-core").versionAsInProject(),
-                mavenBundle("ch.qos.logback", "logback-classic").versionAsInProject(),
-                mavenBundle("org.apache.commons", "commons-lang3").versionAsInProject(),
-                mavenBundle("org.apache.felix", "org.apache.felix.dependencymanager").versionAsInProject(),
-
-                // the plugin stub to get data for the tests
-                mavenBundle("org.opendaylight.controller", "protocol_plugins.stub").versionAsInProject(),
-
-                // List all the opendaylight modules
-                mavenBundle("org.opendaylight.controller", "configuration").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "configuration.implementation").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "containermanager").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "containermanager.it.implementation").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "clustering.services").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "clustering.services-implementation").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "security").versionAsInProject().noStart(),
-                mavenBundle("org.opendaylight.controller", "sal").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "sal.implementation").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "sal.connection").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "sal.connection.implementation").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "switchmanager").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "connectionmanager").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "connectionmanager.implementation").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "switchmanager.implementation").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "forwardingrulesmanager").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller",
-                            "forwardingrulesmanager.implementation").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "statisticsmanager").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "statisticsmanager.implementation").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "arphandler").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "hosttracker").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "hosttracker.implementation").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "arphandler").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "routing.dijkstra_implementation").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "topologymanager").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "usermanager").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "usermanager.implementation").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "logging.bridge").versionAsInProject(),
-//                mavenBundle("org.opendaylight.controller", "clustering.test").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "forwarding.staticrouting").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "bundlescanner").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "bundlescanner.implementation").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "commons.httpclient").versionAsInProject(),
-
-                // Northbound bundles
-                mavenBundle("org.opendaylight.controller", "commons.northbound").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "forwarding.staticrouting.northbound").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "statistics.northbound").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "topology.northbound").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "hosttracker.northbound").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "switchmanager.northbound").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "flowprogrammer.northbound").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "subnets.northbound").versionAsInProject(),
-
-                mavenBundle("com.fasterxml.jackson.core", "jackson-annotations").versionAsInProject(),
-                mavenBundle("com.fasterxml.jackson.core", "jackson-core").versionAsInProject(),
-                mavenBundle("com.fasterxml.jackson.core", "jackson-databind").versionAsInProject(),
-                mavenBundle("com.fasterxml.jackson.jaxrs", "jackson-jaxrs-json-provider").versionAsInProject(),
-                mavenBundle("com.fasterxml.jackson.jaxrs", "jackson-jaxrs-base").versionAsInProject(),
-                mavenBundle("com.fasterxml.jackson.module", "jackson-module-jaxb-annotations").versionAsInProject(),
-
-                mavenBundle("org.codehaus.jettison", "jettison").versionAsInProject(),
-
-                mavenBundle("commons-io", "commons-io").versionAsInProject(),
-
-                mavenBundle("commons-fileupload", "commons-fileupload").versionAsInProject(),
-
-                mavenBundle("equinoxSDK381", "javax.servlet").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "javax.servlet.jsp").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "org.eclipse.equinox.ds").versionAsInProject(),
-                mavenBundle("orbit", "javax.xml.rpc").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "org.eclipse.equinox.util").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "org.eclipse.osgi.services").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "org.apache.felix.gogo.command").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "org.apache.felix.gogo.runtime").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "org.apache.felix.gogo.shell").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "org.eclipse.equinox.cm").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "org.eclipse.equinox.console").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "org.eclipse.equinox.launcher").versionAsInProject(),
-
-                mavenBundle("geminiweb", "org.eclipse.gemini.web.core").versionAsInProject(),
-                mavenBundle("geminiweb", "org.eclipse.gemini.web.extender").versionAsInProject(),
-                mavenBundle("geminiweb", "org.eclipse.gemini.web.tomcat").versionAsInProject(),
-                mavenBundle("geminiweb", "org.eclipse.virgo.kernel.equinox.extensions").versionAsInProject().noStart(),
-                mavenBundle("geminiweb", "org.eclipse.virgo.util.common").versionAsInProject(),
-                mavenBundle("geminiweb", "org.eclipse.virgo.util.io").versionAsInProject(),
-                mavenBundle("geminiweb", "org.eclipse.virgo.util.math").versionAsInProject(),
-                mavenBundle("geminiweb", "org.eclipse.virgo.util.osgi").versionAsInProject(),
-                mavenBundle("geminiweb", "org.eclipse.virgo.util.osgi.manifest").versionAsInProject(),
-                mavenBundle("geminiweb", "org.eclipse.virgo.util.parser.manifest").versionAsInProject(),
-
-                mavenBundle("org.apache.felix", "org.apache.felix.dependencymanager").versionAsInProject(),
-                mavenBundle("org.apache.felix", "org.apache.felix.dependencymanager.shell").versionAsInProject(),
-
-                mavenBundle("com.google.code.gson", "gson").versionAsInProject(),
-                mavenBundle("org.jboss.spec.javax.transaction", "jboss-transaction-api_1.1_spec").versionAsInProject(),
-                mavenBundle("org.apache.felix", "org.apache.felix.fileinstall").versionAsInProject(),
-                mavenBundle("org.apache.commons", "commons-lang3").versionAsInProject(),
-                mavenBundle("commons-codec", "commons-codec").versionAsInProject(),
-                mavenBundle("virgomirror", "org.eclipse.jdt.core.compiler.batch").versionAsInProject(),
-                mavenBundle("eclipselink", "javax.persistence").versionAsInProject(),
-                mavenBundle("eclipselink", "javax.resource").versionAsInProject(),
-
-                mavenBundle("orbit", "javax.activation").versionAsInProject(),
-                mavenBundle("orbit", "javax.annotation").versionAsInProject(),
-                mavenBundle("orbit", "javax.ejb").versionAsInProject(),
-                mavenBundle("orbit", "javax.el").versionAsInProject(),
-                mavenBundle("orbit", "javax.mail.glassfish").versionAsInProject(),
-                mavenBundle("orbit", "javax.xml.rpc").versionAsInProject(),
-                mavenBundle("orbit", "org.apache.catalina").versionAsInProject(),
-                // these are bundle fragments that can't be started on its own
-                mavenBundle("orbit", "org.apache.catalina.ha").versionAsInProject().noStart(),
-                mavenBundle("orbit", "org.apache.catalina.tribes").versionAsInProject().noStart(),
-                mavenBundle("orbit", "org.apache.coyote").versionAsInProject().noStart(),
-                mavenBundle("orbit", "org.apache.jasper").versionAsInProject().noStart(),
-
-                mavenBundle("orbit", "org.apache.el").versionAsInProject(),
-                mavenBundle("orbit", "org.apache.juli.extras").versionAsInProject(),
-                mavenBundle("orbit", "org.apache.tomcat.api").versionAsInProject(),
-                mavenBundle("orbit", "org.apache.tomcat.util").versionAsInProject().noStart(),
-                mavenBundle("orbit", "javax.servlet.jsp.jstl").versionAsInProject(),
-                mavenBundle("orbit", "javax.servlet.jsp.jstl.impl").versionAsInProject(),
-
-                mavenBundle("org.ops4j.pax.exam", "pax-exam-container-native").versionAsInProject(),
-                mavenBundle("org.ops4j.pax.exam", "pax-exam-junit4").versionAsInProject(),
-                mavenBundle("org.ops4j.pax.exam", "pax-exam-link-mvn").versionAsInProject(),
-                mavenBundle("org.ops4j.pax.url", "pax-url-aether").versionAsInProject(),
-
-                mavenBundle("org.ow2.asm", "asm-all").versionAsInProject(),
-
-                mavenBundle("org.springframework", "org.springframework.asm").versionAsInProject(),
-                mavenBundle("org.springframework", "org.springframework.aop").versionAsInProject(),
-                mavenBundle("org.springframework", "org.springframework.context").versionAsInProject(),
-                mavenBundle("org.springframework", "org.springframework.context.support").versionAsInProject(),
-                mavenBundle("org.springframework", "org.springframework.core").versionAsInProject(),
-                mavenBundle("org.springframework", "org.springframework.beans").versionAsInProject(),
-                mavenBundle("org.springframework", "org.springframework.expression").versionAsInProject(),
-                mavenBundle("org.springframework", "org.springframework.web").versionAsInProject(),
-
-                mavenBundle("org.aopalliance", "com.springsource.org.aopalliance").versionAsInProject(),
-                mavenBundle("org.springframework", "org.springframework.web.servlet").versionAsInProject(),
-                mavenBundle("org.springframework.security", "spring-security-config").versionAsInProject(),
-                mavenBundle("org.springframework.security", "spring-security-core").versionAsInProject(),
-                mavenBundle("org.springframework.security", "spring-security-web").versionAsInProject(),
-                mavenBundle("org.springframework.security", "spring-security-taglibs").versionAsInProject(),
-                mavenBundle("org.springframework", "org.springframework.transaction").versionAsInProject(),
-
-                mavenBundle("org.ow2.chameleon.management", "chameleon-mbeans").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller.thirdparty", "net.sf.jung2").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller.thirdparty", "com.sun.jersey.jersey-servlet")
-                .versionAsInProject(),
-                mavenBundle("org.opendaylight.controller.thirdparty", "org.apache.catalina.filters.CorsFilter")
-                .versionAsInProject().noStart(),
-
-                // Jersey needs to be started before the northbound application
-                // bundles, using a lower start level
-                mavenBundle("com.sun.jersey", "jersey-client").versionAsInProject(),
-                mavenBundle("com.sun.jersey", "jersey-server").versionAsInProject().startLevel(2),
-                mavenBundle("com.sun.jersey", "jersey-core").versionAsInProject().startLevel(2),
-                junitBundles());
-    }
-
-}
diff --git a/opendaylight/adsal/northbound/integrationtest/src/test/resources/exam.properties b/opendaylight/adsal/northbound/integrationtest/src/test/resources/exam.properties
deleted file mode 100644 (file)
index d5f9ae1..0000000
+++ /dev/null
@@ -1,4 +0,0 @@
-#pax.exam.system = default
-pax.exam.logging = none
-pax.exam.service.timeout = 5000
-
diff --git a/opendaylight/adsal/northbound/integrationtest/src/test/resources/logback.xml b/opendaylight/adsal/northbound/integrationtest/src/test/resources/logback.xml
deleted file mode 100644 (file)
index 2d63ce5..0000000
+++ /dev/null
@@ -1,13 +0,0 @@
-<configuration scan="true">
-
-  <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
-    <encoder>
-      <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n
-      </pattern>
-    </encoder>
-  </appender>
-
-  <root level="error">
-    <appender-ref ref="STDOUT" />
-  </root>
-</configuration>
diff --git a/opendaylight/adsal/northbound/integrationtest/src/test/resources/tomcat-server.xml b/opendaylight/adsal/northbound/integrationtest/src/test/resources/tomcat-server.xml
deleted file mode 100644 (file)
index ee88f23..0000000
+++ /dev/null
@@ -1,62 +0,0 @@
-<?xml version='1.0' encoding='utf-8'?>
-<!--
-  Licensed to the Apache Software Foundation (ASF) under one or more
-  contributor license agreements.  See the NOTICE file distributed with
-  this work for additional information regarding copyright ownership.
-  The ASF licenses this file to You under the Apache License, Version 2.0
-  (the "License"); you may not use this file except in compliance with
-  the License.  You may obtain a copy of the License at
-
-      http://www.apache.org/licenses/LICENSE-2.0
-
-  Unless required by applicable law or agreed to in writing, software
-  distributed under the License is distributed on an "AS IS" BASIS,
-  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-  See the License for the specific language governing permissions and
-  limitations under the License.
--->
-<Server>
-  <!--APR library loader. Documentation at /docs/apr.html -->
-  <Listener className="org.apache.catalina.core.AprLifecycleListener" SSLEngine="on" />
-  <!--Initialize Jasper prior to webapps are loaded. Documentation at /docs/jasper-howto.html -->
-  <Listener className="org.apache.catalina.core.JasperListener" />
-  <!-- Prevent memory leaks due to use of particular java/javax APIs-->
-  <Listener className="org.apache.catalina.core.JreMemoryLeakPreventionListener" />
-  <Listener className="org.apache.catalina.mbeans.GlobalResourcesLifecycleListener" />
-  <Listener className="org.apache.catalina.core.ThreadLocalLeakPreventionListener" />
-
-  <Service name="Catalina">
-    <Connector port="8180" protocol="HTTP/1.1"
-               connectionTimeout="20000"
-               redirectPort="8443" />
-
-<!--
-        Please remove the comments around the following Connector tag to enable HTTPS Authentication support.
-        Remember to add a valid keystore in the configuration folder.
-        More info : http://tomcat.apache.org/tomcat-7.0-doc/ssl-howto.html#Configuration
--->
-
- <!--
-    <Connector port="8443" protocol="HTTP/1.1" SSLEnabled="true"
-               maxThreads="150" scheme="https" secure="true"
-               clientAuth="false" sslProtocol="TLS"
-               keystoreFile="configuration/keystore"
-               keystorePass="changeit"/>
- -->
-
-    <Engine name="Catalina" defaultHost="localhost">
-      <Host name="localhost" appBase=""
-            unpackWARs="false" autoDeploy="false"
-            deployOnStartup="false" createDirs="false">
-        <Realm className="org.opendaylight.controller.security.ControllerCustomRealm" />
-            <Valve className="org.apache.catalina.authenticator.SingleSignOn" />
-
-        <Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
-                        prefix="web_access_log_" suffix=".txt" resolveHosts="false"
-                        rotatable="true" fileDateFormat="yyyy-MM"
-                        pattern="%{yyyy-MM-dd HH:mm:ss.SSS z}t - [%a] - %r"/>
-
-      </Host>
-    </Engine>
-  </Service>
-</Server>
diff --git a/opendaylight/adsal/northbound/java-client/enunciate.xml b/opendaylight/adsal/northbound/java-client/enunciate.xml
deleted file mode 100644 (file)
index c782437..0000000
+++ /dev/null
@@ -1,32 +0,0 @@
-<?xml version="1.0"?>
-<enunciate label="full" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
-    xsi:noNamespaceSchemaLocation="http://enunciate.codehaus.org/schemas/enunciate-1.28.xsd">
-
-  <services> </services>
-
-  <modules>
-    <!-- Disable doc generation -->
-    <docs disabled="true"/>
-    <swagger disabled="true"/>
-    <!-- Disable all the client generation tools -->
-    <basic-app disabled="true" />
-    <c disabled="true" />
-    <csharp disabled="true" />
-    <jaxws-client disabled="true" />
-    <jaxws-ri disabled="true" />
-    <jaxws-support disabled="true" />
-    <obj-c disabled="true" />
-    <ruby disabled="true"/>
-    <php disabled="true"/>
-
-    <!-- enable only the java clients -->
-    <xml disabled="false" />
-    <java-client disabled="false"/>
-  </modules>
-
-  <api-classes>
-    <include pattern="org.opendaylight.controller.**"/>
-  </api-classes>
-
-  <api-import pattern="org.opendaylight.controller.**"/>
-</enunciate>
diff --git a/opendaylight/adsal/northbound/java-client/pom.xml b/opendaylight/adsal/northbound/java-client/pom.xml
deleted file mode 100644 (file)
index 46f8e90..0000000
+++ /dev/null
@@ -1,194 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>enunciate-parent</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/enunciate-parent</relativePath>
-  </parent>
-
-  <artifactId>northbound.client</artifactId>
-  <version>0.2.0-SNAPSHOT</version>
-  <packaging>pom</packaging>
-
-  <properties>
-    <docs.output.dir>${project.build.directory}/rest-api-docs</docs.output.dir>
-    <java-client>${project.build.directory}/enunciate/build/java-client/full-client.jar</java-client>
-    <java-client-sources>${project.build.directory}/enunciate/build/java-client/full-client-sources.jar</java-client-sources>
-  </properties>
-
-  <dependencies>
-    <dependency>
-      <groupId>org.codehaus.enunciate</groupId>
-      <artifactId>enunciate-core-annotations</artifactId>
-    </dependency>
-
-    <!-- add dependency on all northbound bundles -->
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>connectionmanager.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>controllermanager.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>flowprogrammer.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>forwarding.staticrouting.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>hosttracker.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>networkconfig.bridgedomain.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>statistics.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>subnets.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>switchmanager.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>topology.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>usermanager.northbound</artifactId>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-
-      <plugin>
-        <groupId>org.apache.maven.plugins</groupId>
-        <artifactId>maven-antrun-plugin</artifactId>
-        <configuration>
-          <target>
-            <taskdef classpathref="maven.plugin.classpath" resource="net/sf/antcontrib/antcontrib.properties"></taskdef>
-            <patternset id="rest.paths">
-              <include name="**/target/site/wsdocs/**"></include>
-              <exclude name="**/java-client/**"></exclude>
-            </patternset>
-
-            <echo message="======== Assembling enunciate docs ========"></echo>
-            <!-- cleanup existing generated files -->
-            <delete dir="${docs.output.dir}"></delete>
-            <delete file="${docs.output.dir}.zip"></delete>
-            <mkdir dir="${docs.output.dir}"></mkdir>
-            <!-- copy enunciate docs to stage -->
-            <copy todir="${docs.output.dir}">
-              <fileset dir="${basedir}/../../..">
-                <patternset refid="rest.paths"></patternset>
-              </fileset>
-              <mapper from="^(.*)/([^/]+)/target/site/wsdocs/(.*)$$" to="\2/\3" type="regexp"></mapper>
-            </copy>
-            <!-- Remove Swagger doc link from enunciate generated index.html -->
-            <replaceregexp byline="false" match="&lt;h2&gt;Swagger&lt;/h2&gt;${line.separator}\s*&lt;p&gt;${line.separator}.*${line.separator}\s*&lt;/p&gt;" replace="">
-              <fileset dir="${docs.output.dir}">
-                <include name="**/index.html"></include>
-              </fileset>
-            </replaceregexp>
-            <!-- generate index.html -->
-            <!-- append header -->
-            <echo append="true" file="${docs.output.dir}/index.html">&lt;![CDATA[
-              &lt;html&gt;
-              &lt;head&gt;
-              &lt;title&gt; OpenDaylight REST API Documentation &lt;/title&gt;
-              &lt;/head&gt;
-              &lt;body&gt;
-              &lt;h2&gt;OpenDaylight REST API Documentation&lt;/h2&gt;
-              &lt;p&gt; OpenDaylight supports the following &lt;a href="http://en.wikipedia.org/wiki/Representational_State_Transfer"&gt;Representational State Transfer (REST)&lt;/a&gt; APIs: &lt;/p&gt;
-              &lt;h4&gt;
-              ]]&gt;</echo>
-            <dirset dir="${docs.output.dir}" id="nbset">
-              <include name="*"></include>
-            </dirset>
-            <pathconvert pathsep="&amp;#36;{line.separator}" property="nbs" refid="nbset"></pathconvert>
-            <echo append="true" file="${docs.output.dir}/index.html" message="${nbs}"></echo>
-            <replaceregexp byline="true" file="${docs.output.dir}/index.html" match="^\${docs.output.dir}/(.*)$" replace="&amp;lt;li&amp;gt;&amp;lt;a href=\1/index.html&amp;gt; \1 &amp;lt;/a&amp;gt;&amp;lt;/li&amp;gt;"></replaceregexp>
-
-            <!-- append footer -->
-            <echo append="true" file="${docs.output.dir}/index.html">&lt;![CDATA[
-              &lt;/h4&gt;
-              &lt;i&gt;---&lt;/i&gt;
-              &lt;/body&gt;
-              &lt;/html&gt;
-              ]]&gt;</echo>
-            <!-- archive all the docs excluding whatever is not needed -->
-            <echo message="======== Archiving enunciate docs ========"></echo>
-            <zip destfile="${docs.output.dir}.zip">
-              <zipfileset dir="${docs.output.dir}"></zipfileset>
-            </zip>
-
-            <echo message="======== Build successful ========"></echo>
-            <echo message="REST docs archive: ${docs.output.dir}.zip"></echo>
-          </target>
-        </configuration>
-        <dependencies>
-          <dependency>
-            <groupId>ant-contrib</groupId>
-            <artifactId>ant-contrib</artifactId>
-            <version>20020829</version>
-          </dependency>
-        </dependencies>
-        <executions>
-          <execution>
-            <goals>
-              <goal>run</goal>
-            </goals>
-            <phase>package</phase>
-          </execution>
-        </executions>
-      </plugin>
-
-      <plugin>
-        <groupId>org.codehaus.mojo</groupId>
-        <artifactId>build-helper-maven-plugin</artifactId>
-        <executions>
-          <execution>
-            <id>attach-artifacts</id>
-            <goals>
-              <goal>attach-artifact</goal>
-            </goals>
-            <phase>package</phase>
-            <configuration>
-              <artifacts>
-                <artifact>
-                  <file>${java-client}</file>
-                  <type>jar</type>
-                  <classifier>full-java-client</classifier>
-                </artifact>
-                <artifact>
-                  <file>${java-client-sources}</file>
-                  <type>jar</type>
-                  <classifier>full-java-client-sources</classifier>
-                </artifact>
-              </artifacts>
-            </configuration>
-          </execution>
-        </executions>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/northbound/jolokia/pom.xml b/opendaylight/adsal/northbound/jolokia/pom.xml
deleted file mode 100644 (file)
index 158003a..0000000
+++ /dev/null
@@ -1,40 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>jolokia-bridge</artifactId>
-  <version>0.2.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <description>Jolokia bridge web application</description>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Export-Package></Export-Package>
-            <Import-Package>javax.servlet,
-                javax.servlet.http,
-                org.eclipse.equinox.http.servlet,
-                org.opendaylight.controller.web,
-                org.osgi.framework,
-                org.jolokia.osgi.servlet,
-                org.apache.catalina.filters,
-                org.slf4j,</Import-Package>
-            <Web-ContextPath>/controller/nb/v2/jolokia</Web-ContextPath>
-          </instructions>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-</project>
diff --git a/opendaylight/adsal/northbound/jolokia/src/main/resources/WEB-INF/web.xml b/opendaylight/adsal/northbound/jolokia/src/main/resources/WEB-INF/web.xml
deleted file mode 100644 (file)
index 126396d..0000000
+++ /dev/null
@@ -1,75 +0,0 @@
-<?xml version="1.0" encoding="ISO-8859-1"?>
-<web-app
-  xmlns="http://java.sun.com/xml/ns/javaee"
-  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
-  xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
-  version="3.0">
-
-  <servlet>
-    <servlet-name>JolokiaServlet</servlet-name>
-    <servlet-class>org.jolokia.osgi.servlet.JolokiaServlet</servlet-class>
-    <load-on-startup>1</load-on-startup>
-  </servlet>
-
-  <servlet-mapping>
-    <servlet-name>JolokiaServlet</servlet-name>
-    <url-pattern>/*</url-pattern>
-  </servlet-mapping>
-
-  <filter>
-    <filter-name>CorsFilter</filter-name>
-    <filter-class>org.apache.catalina.filters.CorsFilter</filter-class>
-    <init-param>
-      <param-name>cors.allowed.origins</param-name>
-      <param-value>*</param-value>
-    </init-param>
-    <init-param>
-      <param-name>cors.allowed.methods</param-name>
-      <param-value>GET,POST,HEAD,OPTIONS,PUT,DELETE</param-value>
-    </init-param>
-    <init-param>
-      <param-name>cors.allowed.headers</param-name>
-      <param-value>Content-Type,X-Requested-With,accept,authorization, origin,Origin,Access-Control-Request-Method,Access-Control-Request-Headers</param-value>
-    </init-param>
-    <init-param>
-      <param-name>cors.exposed.headers</param-name>
-      <param-value>Access-Control-Allow-Origin,Access-Control-Allow-Credentials</param-value>
-    </init-param>
-    <init-param>
-      <param-name>cors.support.credentials</param-name>
-      <param-value>true</param-value>
-    </init-param>
-    <init-param>
-      <param-name>cors.preflight.maxage</param-name>
-      <param-value>10</param-value>
-    </init-param>
-  </filter>
-  <filter-mapping>
-    <filter-name>CorsFilter</filter-name>
-    <url-pattern>/*</url-pattern>
-  </filter-mapping>
-
-  <security-constraint>
-    <web-resource-collection>
-      <web-resource-name>JolokiaService</web-resource-name>
-      <url-pattern>/*</url-pattern>
-    </web-resource-collection>
-    <auth-constraint>
-      <role-name>System-Admin</role-name>
-      <role-name>Network-Admin</role-name>
-    </auth-constraint>
-  </security-constraint>
-
-  <security-role>
-    <role-name>System-Admin</role-name>
-  </security-role>
-
-  <security-role>
-    <role-name>Network-Admin</role-name>
-  </security-role>
-
-  <login-config>
-    <auth-method>BASIC</auth-method>
-    <realm-name>opendaylight</realm-name>
-  </login-config>
-</web-app>
diff --git a/opendaylight/adsal/northbound/networkconfiguration/bridgedomain/enunciate.xml b/opendaylight/adsal/northbound/networkconfiguration/bridgedomain/enunciate.xml
deleted file mode 100644 (file)
index 1555743..0000000
+++ /dev/null
@@ -1,12 +0,0 @@
-<?xml version="1.0"?>
-<enunciate label="full" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
-    xsi:noNamespaceSchemaLocation="http://enunciate.codehaus.org/schemas/enunciate-1.28.xsd">
-
-  <services>
-    <rest defaultRestSubcontext="/controller/nb/v2/networkconfig/bridgedomain"/>
-  </services>
-
-  <modules>
-    <docs docsDir="rest" title="Bridge Domain Configuration REST API" includeExampleXml="true" includeExampleJson="true"/>
-   </modules>
-</enunciate>
diff --git a/opendaylight/adsal/northbound/networkconfiguration/bridgedomain/pom.xml b/opendaylight/adsal/northbound/networkconfiguration/bridgedomain/pom.xml
deleted file mode 100644 (file)
index df2ba4e..0000000
+++ /dev/null
@@ -1,89 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>adsal-enunciate-parent</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../adsal-enunciate-parent</relativePath>
-  </parent>
-
-  <artifactId>networkconfig.bridgedomain.northbound</artifactId>
-  <version>0.2.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>org.codehaus.enunciate</groupId>
-      <artifactId>enunciate-core-annotations</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>commons.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>connectionmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>containermanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal.connection</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal.networkconfiguration</artifactId>
-    </dependency>
-  </dependencies>
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Export-Package></Export-Package>
-            <Import-Package>org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.sal.utils,
-              org.opendaylight.controller.sal.networkconfig.bridgedomain,
-              org.opendaylight.controller.containermanager,
-              org.opendaylight.controller.usermanager,
-              com.sun.jersey.spi.container.servlet,
-              org.opendaylight.controller.northbound.commons,
-              org.opendaylight.controller.northbound.commons.exception,
-              org.opendaylight.controller.northbound.commons.utils,
-              org.opendaylight.controller.sal.authorization,
-              org.opendaylight.controller.connectionmanager,
-              org.opendaylight.controller.sal.connection,
-              org.slf4j,
-              javax.ws.rs,
-              javax.ws.rs.core,
-              javax.xml.bind.annotation,
-              javax.xml.bind,
-              org.apache.catalina.filters,
-              com.fasterxml.jackson.jaxrs.base,
-              com.fasterxml.jackson.jaxrs.json,
-              !org.codehaus.enunciate.jaxrs</Import-Package>
-            <Export-Package></Export-Package>
-            <Web-ContextPath>/controller/nb/v2/networkconfig/bridgedomain</Web-ContextPath>
-            <Jaxrs-Resources>,${classes;ANNOTATION;javax.ws.rs.Path}</Jaxrs-Resources>
-          </instructions>
-          <manifestLocation>${project.basedir}/src/main/resources/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/northbound/networkconfiguration/bridgedomain/src/main/java/org/opendaylight/controller/networkconfig/bridgedomain/northbound/BridgeDomainNorthbound.java b/opendaylight/adsal/northbound/networkconfiguration/bridgedomain/src/main/java/org/opendaylight/controller/networkconfig/bridgedomain/northbound/BridgeDomainNorthbound.java
deleted file mode 100644 (file)
index 8aea7e5..0000000
+++ /dev/null
@@ -1,342 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.networkconfig.bridgedomain.northbound;
-
-import java.util.HashMap;
-import java.util.Map;
-
-import javax.ws.rs.Consumes;
-import javax.ws.rs.DELETE;
-import javax.ws.rs.POST;
-import javax.ws.rs.Path;
-import javax.ws.rs.PathParam;
-import javax.ws.rs.core.Context;
-import javax.ws.rs.core.MediaType;
-import javax.ws.rs.core.Response;
-import javax.ws.rs.core.SecurityContext;
-
-import org.codehaus.enunciate.jaxrs.ResponseCode;
-import org.codehaus.enunciate.jaxrs.StatusCodes;
-import org.opendaylight.controller.connectionmanager.IConnectionManager;
-import org.opendaylight.controller.northbound.commons.exception.NotAcceptableException;
-import org.opendaylight.controller.northbound.commons.exception.ResourceNotFoundException;
-import org.opendaylight.controller.northbound.commons.exception.ServiceUnavailableException;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.networkconfig.bridgedomain.BridgeDomainConfigServiceException;
-import org.opendaylight.controller.sal.networkconfig.bridgedomain.ConfigConstants;
-import org.opendaylight.controller.sal.networkconfig.bridgedomain.IBridgeDomainConfigService;
-import org.opendaylight.controller.sal.utils.ServiceHelper;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.sal.utils.StatusCode;
-
-/**
- * BridgeDomain Configuration Northbound APIs
- *
- * <br><br>
- * Authentication scheme : <b>HTTP Basic</b><br>
- * Authentication realm : <b>opendaylight</b><br>
- * Transport : <b>HTTP and HTTPS</b><br>
- * <br>
- * HTTPS Authentication is disabled by default. Administrator can enable it in tomcat-server.xml after adding
- * a proper keystore / SSL certificate from a trusted authority.<br>
- * More info : http://tomcat.apache.org/tomcat-7.0-doc/ssl-howto.html#Configuration
- */
-@Path("/")
-public class BridgeDomainNorthbound {
-    private String username;
-
-    @Context
-    public void setSecurityContext(SecurityContext context) {
-        if (context != null && context.getUserPrincipal() != null) {
-          username = context.getUserPrincipal().getName();
-        }
-    }
-    protected String getUserName() {
-        return username;
-    }
-
-    private IBridgeDomainConfigService getConfigurationService() {
-        return (IBridgeDomainConfigService) ServiceHelper
-                .getGlobalInstance(IBridgeDomainConfigService.class, this);
-    }
-
-    private IConnectionManager getConnectionManager() {
-        return (IConnectionManager) ServiceHelper
-                .getGlobalInstance(IConnectionManager.class, this);
-    }
-
-    /**
-     * Create a Bridge.
-     * <pre>
-     *
-     * Example :
-     *
-     * Request :
-     * http://localhost:8080/controller/nb/v2/networkconfig/bridgedomain/bridge/STUB/mgmt1/bridge1
-     *
-     *</pre>
-     * @param nodeType Node Type of the node with the management session.
-     * @param nodeId Node Identifier of the node with the management session.
-     * @param bridgeName Name / Identifier for a bridge to be created.
-     * @param bridgeConfigs Additional Bridge Configurations.
-     *        It takes in complex structures under the ConfigConstants.CUSTOM key.
-     *        The use-cases are documented under wiki.opendaylight.org project pages:
-     *        https://wiki.opendaylight.org/view/OVSDB_Integration:Mininet_OVSDB_Tutorial
-     */
-
-   @Path("/bridge/{nodeType}/{nodeId}/{bridgeName}")
-   @POST
-   @StatusCodes( { @ResponseCode(code = 201, condition = "Bridge created successfully"),
-       @ResponseCode(code = 404, condition = "Could not create Bridge"),
-       @ResponseCode(code = 412, condition = "Failed to create Bridge due to an exception"),
-       @ResponseCode(code = 503, condition = "Bridge Domain Configuration Service not available")} )
-
-   public Response createBridge(
-           @PathParam(value = "nodeType") String nodeType,
-           @PathParam(value = "nodeId") String nodeId,
-           @PathParam(value = "bridgeName") String name,
-           Map<String, Object> bridgeConfigs) {
-
-       IBridgeDomainConfigService configurationService = getConfigurationService();
-       if (configurationService == null) {
-           throw new ServiceUnavailableException("IBridgeDomainConfigService not available.");
-       }
-
-       Node node = Node.fromString(nodeType, nodeId);
-       Status status = null;
-       try {
-           Map<ConfigConstants, Object> configs = this.buildConfig(bridgeConfigs);
-           status = configurationService.createBridgeDomain(node, name, configs);
-           if (status.getCode().equals(StatusCode.SUCCESS)) {
-               return Response.status(Response.Status.CREATED).build();
-           }
-       } catch (BridgeDomainConfigServiceException e) {
-           return Response.status(Response.Status.PRECONDITION_FAILED).build();
-       }
-       throw new ResourceNotFoundException(status.getDescription());
-   }
-
-
-   /**
-    * Remove a Bridge.
-    * <pre>
-    *
-    * Example :
-    *
-    * Request :
-    * DELETE
-    * http://localhost:8080/controller/nb/v2/networkconfig/bridgedomain/bridge/STUB/mgmt1/bridge1
-    *
-    *</pre>
-    * @param nodeType Node Type of the node with the management session.
-    * @param nodeId Node Identifier of the node with the management session.
-    * @param bridgeName Name / Identifier for a bridge to be deleted.
-    */
-
-  @Path("/bridge/{nodeType}/{nodeId}/{bridgeName}")
-  @DELETE
-  @StatusCodes( { @ResponseCode(code = 200, condition = "Bridge deleted successfully"),
-      @ResponseCode(code = 404, condition = "Could not delete Bridge"),
-      @ResponseCode(code = 412, condition = "Failed to delete Bridge due to an exception"),
-      @ResponseCode(code = 503, condition = "Bridge Domain Configuration Service not available")} )
-
-  public Response deleteBridge(
-          @PathParam(value = "nodeType") String nodeType,
-          @PathParam(value = "nodeId") String nodeId,
-          @PathParam(value = "bridgeName") String name) {
-
-      IBridgeDomainConfigService configurationService = getConfigurationService();
-      if (configurationService == null) {
-          throw new ServiceUnavailableException("IBridgeDomainConfigService not available.");
-      }
-
-      Node node = Node.fromString(nodeType, nodeId);
-      Status status = null;
-      try {
-          status = configurationService.deleteBridgeDomain(node, name);
-          if (status.getCode().equals(StatusCode.SUCCESS)) {
-              return Response.status(Response.Status.OK).build();
-          }
-      } catch (Exception t) {
-          return Response.status(Response.Status.PRECONDITION_FAILED).build();
-      }
-      throw new ResourceNotFoundException(status.getDescription());
-  }
-
-   /**
-    * Add a Port to a Bridge
-    * <pre>
-    *
-    * Example :
-    *
-    * Request :
-    * http://localhost:8080/controller/nb/v2/networkconfig/bridgedomain/port/STUB/mgmt1/bridge1/port1
-    *
-    *</pre>
-    * @param nodeType Node Type of the node with the management session.
-    * @param nodeId Node Identifier of the node with the management session.
-    * @param bridgeName Name / Identifier of the bridge to which a Port is being added.
-    * @param portName Name / Identifier of a Port that is being added to a bridge.
-    * @param portConfigs Additional Port Configurations.
-    *        It takes in complex structures under the ConfigConstants.CUSTOM key.
-    *        The use-cases are documented under wiki.opendaylight.org project pages :
-    *        https://wiki.opendaylight.org/view/OVSDB_Integration:Mininet_OVSDB_Tutorial
-    */
-
-   @Path("/port/{nodeType}/{nodeId}/{bridgeName}/{portName}")
-   @POST
-   @Consumes({MediaType.APPLICATION_XML, MediaType.APPLICATION_JSON})
-   @StatusCodes( { @ResponseCode(code = 201, condition = "Port added successfully"),
-       @ResponseCode(code = 404, condition = "Could not add Port to the Bridge"),
-       @ResponseCode(code = 412, condition = "Failed to add Port due to an exception"),
-       @ResponseCode(code = 503, condition = "Bridge Domain Configuration Service not available")} )
-
-   public Response addPort(
-           @PathParam(value = "nodeType") String nodeType,
-           @PathParam(value = "nodeId") String nodeId,
-           @PathParam(value = "bridgeName") String bridge,
-           @PathParam(value = "portName") String port,
-           Map<String, Object> portConfigs) {
-
-       IBridgeDomainConfigService configurationService = getConfigurationService();
-       if (configurationService == null) {
-           throw new ServiceUnavailableException("IBridgeDomainConfigService not available.");
-       }
-
-       Node node = Node.fromString(nodeType, nodeId);
-       Status status = null;
-       try {
-           Map<ConfigConstants, Object> configs = this.buildConfig(portConfigs);
-           status = configurationService.addPort(node, bridge, port, configs);
-           if (status.getCode().equals(StatusCode.SUCCESS)) {
-               return Response.status(Response.Status.CREATED).build();
-           }
-       } catch (Exception t) {
-           return Response.status(Response.Status.PRECONDITION_FAILED).build();
-       }
-       throw new ResourceNotFoundException(status.getDescription());
-   }
-
-   /**
-    * Remove a Port from a Bridge
-    * <pre>
-    *
-    * Example :
-    *
-    * Request :
-    * DELETE
-    * http://localhost:8080/controller/nb/v2/networkconfig/bridgedomain/port/STUB/mgmt1/bridge1/port1
-    *
-    *</pre>
-    * @param nodeType Node Type of the node with the management session.
-    * @param nodeId Node Identifier of the node with the management session.
-    * @param bridgeName Name / Identifier of the bridge to which a Port is being added.
-    * @param portName Name / Identifier of a Port that is being deleted from a bridge.
-    */
-
-   @Path("/port/{nodeType}/{nodeId}/{bridgeName}/{portName}")
-   @DELETE
-   @Consumes({MediaType.APPLICATION_XML, MediaType.APPLICATION_JSON})
-   @StatusCodes( { @ResponseCode(code = 200, condition = "Port deleted successfully"),
-       @ResponseCode(code = 404, condition = "Could not delete Port to the Bridge"),
-       @ResponseCode(code = 412, condition = "Failed to delete Port due to an exception"),
-       @ResponseCode(code = 503, condition = "Bridge Domain Configuration Service not available")} )
-
-   public Response deletePort(
-           @PathParam(value = "nodeType") String nodeType,
-           @PathParam(value = "nodeId") String nodeId,
-           @PathParam(value = "bridgeName") String bridge,
-           @PathParam(value = "portName") String port) {
-
-       IBridgeDomainConfigService configurationService = getConfigurationService();
-       if (configurationService == null) {
-           throw new ServiceUnavailableException("IBridgeDomainConfigService not available.");
-       }
-
-       Node node = Node.fromString(nodeType, nodeId);
-       Status status = null;
-       try {
-           status = configurationService.deletePort(node, bridge, port);
-           if (status.getCode().equals(StatusCode.SUCCESS)) {
-               return Response.status(Response.Status.OK).build();
-           }
-       } catch (Exception t) {
-           return Response.status(Response.Status.PRECONDITION_FAILED).build();
-       }
-       throw new ResourceNotFoundException(status.getDescription());
-   }
-
-   private Map<ConfigConstants, Object> buildConfig(Map<String, Object> rawConfigs) {
-       if (rawConfigs == null) return null;
-       Map<ConfigConstants, Object> configs = new HashMap<ConfigConstants, Object>();
-       for (String key : rawConfigs.keySet()) {
-           ConfigConstants cc = ConfigConstants.valueOf(key.toUpperCase());
-           configs.put(cc, rawConfigs.get(key));
-       }
-       return configs;
-   }
-/**
-    * Add a Port,Vlan to a Bridge
-    * <pre>
-    *
-    * Example :
-    * Request :
-    * http://localhost:8080/controller/nb/v2/networkconfig/bridgedomain/port/STUB/mgmt1/bridge1/port2/200
-    *
-    * </pre>
-    * @param nodeType Node Type of the node with the management session.
-    * @param nodeId Node Identifier of the node with the management session.
-    * @param bridgeName Name / Identifier of the bridge to which a Port is being added.
-    * @param portName Name / Identifier of a Port that is being added to a bridge.
-    * @param vlan Vlan Id.
-    */
-
-   @Path("/port/{nodeType}/{nodeId}/{bridgeName}/{portName}/{vlan}")
-   @POST
-   @StatusCodes( { @ResponseCode(code = 201, condition = "Created Port with Vlan tag successfully"),
-       @ResponseCode(code = 404, condition = "Could not add Port,Vlan to the Bridge"),
-       @ResponseCode(code = 406, condition = "Invalid Vlan parameter passed."),
-       @ResponseCode(code = 412, condition = "Failed to add Port,Vlan due to an exception"),
-       @ResponseCode(code = 503, condition = "Bridge Domain Configuration Service not available")} )
-
-   public Response addPort(
-           @PathParam(value = "nodeType") String nodeType,
-           @PathParam(value = "nodeId") String nodeId,
-           @PathParam(value = "bridgeName") String bridge,
-           @PathParam(value = "portName") String port,
-           @PathParam(value = "vlan") String vlan) {
-
-       IBridgeDomainConfigService configurationService = getConfigurationService();
-       if (configurationService == null) {
-           throw new ServiceUnavailableException("IBridgeDomainConfigService not available.");
-       }
-       try {
-           Integer.parseInt(vlan);
-       } catch (Exception e) {
-           throw new NotAcceptableException("Incorrect Vlan :"+vlan);
-       }
-
-       Node node = Node.fromString(nodeType, nodeId);
-       Map<ConfigConstants, Object> configs = new HashMap<ConfigConstants, Object>();
-       configs.put(ConfigConstants.TYPE, ConfigConstants.VLAN.name());
-       configs.put(ConfigConstants.VLAN, vlan);
-
-       Status status = null;
-       try {
-       status = configurationService.addPort(node, bridge, port, configs);
-       if (status.getCode().equals(StatusCode.SUCCESS)) {
-           return Response.status(Response.Status.CREATED).build();
-       }
-       } catch (Exception e) {
-           return Response.status(Response.Status.PRECONDITION_FAILED).build();
-       }
-       throw new ResourceNotFoundException(status.getDescription());
-   }
-}
diff --git a/opendaylight/adsal/northbound/networkconfiguration/bridgedomain/src/main/resources/WEB-INF/web.xml b/opendaylight/adsal/northbound/networkconfiguration/bridgedomain/src/main/resources/WEB-INF/web.xml
deleted file mode 100644 (file)
index 455fbdd..0000000
+++ /dev/null
@@ -1,90 +0,0 @@
-<?xml version="1.0" encoding="ISO-8859-1"?>
-<web-app xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
-        xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
-        version="3.0">
-  <servlet>
-    <servlet-name>BridgeDomainConfiguration</servlet-name>
-    <servlet-class>com.sun.jersey.spi.container.servlet.ServletContainer</servlet-class>
-    <init-param>
-      <param-name>javax.ws.rs.Application</param-name>
-      <param-value>org.opendaylight.controller.northbound.commons.NorthboundApplication</param-value>
-    </init-param>
-    <load-on-startup>1</load-on-startup>
-  </servlet>
-
-        <servlet-mapping>
-                <servlet-name>BridgeDomainConfiguration</servlet-name>
-                <url-pattern>/*</url-pattern>
-        </servlet-mapping>
-
-        <filter>
-          <filter-name>CorsFilter</filter-name>
-          <filter-class>org.apache.catalina.filters.CorsFilter</filter-class>
-          <init-param>
-            <param-name>cors.allowed.origins</param-name>
-            <param-value>*</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.allowed.methods</param-name>
-            <param-value>GET,POST,DELETE,HEAD,OPTIONS,PUT</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.allowed.headers</param-name>
-            <param-value>Content-Type,X-Requested-With,accept,authorization, origin,Origin,Access-Control-Request-Method,Access-Control-Request-Headers</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.exposed.headers</param-name>
-            <param-value>Access-Control-Allow-Origin,Access-Control-Allow-Credentials</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.support.credentials</param-name>
-            <param-value>true</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.preflight.maxage</param-name>
-            <param-value>10</param-value>
-          </init-param>
-        </filter>
-        <filter-mapping>
-          <filter-name>CorsFilter</filter-name>
-          <url-pattern>/*</url-pattern>
-        </filter-mapping>
-
-        <security-constraint>
-          <web-resource-collection>
-            <web-resource-name>NB api</web-resource-name>
-            <url-pattern>/*</url-pattern>
-            <http-method>POST</http-method>
-            <http-method>GET</http-method>
-            <http-method>PUT</http-method>
-            <http-method>PATCH</http-method>
-            <http-method>DELETE</http-method>
-            <http-method>HEAD</http-method>
-          </web-resource-collection>
-          <auth-constraint>
-            <role-name>System-Admin</role-name>
-            <role-name>Network-Admin</role-name>
-            <role-name>Network-Operator</role-name>
-            <role-name>Container-User</role-name>
-          </auth-constraint>
-        </security-constraint>
-
-        <security-role>
-                <role-name>System-Admin</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Network-Admin</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Network-Operator</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Container-User</role-name>
-        </security-role>
-
-        <login-config>
-                <auth-method>BASIC</auth-method>
-                <realm-name>opendaylight</realm-name>
-        </login-config>
-
-</web-app>
\ No newline at end of file
diff --git a/opendaylight/adsal/northbound/staticrouting/enunciate.xml b/opendaylight/adsal/northbound/staticrouting/enunciate.xml
deleted file mode 100644 (file)
index 4d2f1cb..0000000
+++ /dev/null
@@ -1,12 +0,0 @@
-<?xml version="1.0"?>
-<enunciate label="full" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
-    xsi:noNamespaceSchemaLocation="http://enunciate.codehaus.org/schemas/enunciate-1.28.xsd">
-
-  <services>
-    <rest defaultRestSubcontext="/controller/nb/v2/staticroute"/>
-  </services>
-
-  <modules>
-    <docs docsDir="rest" title="Static Routing REST API" includeExampleXml="true" includeExampleJson="true"/>
-  </modules>
-</enunciate>
diff --git a/opendaylight/adsal/northbound/staticrouting/pom.xml b/opendaylight/adsal/northbound/staticrouting/pom.xml
deleted file mode 100644 (file)
index c65f036..0000000
+++ /dev/null
@@ -1,85 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>adsal-enunciate-parent</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../adsal-enunciate-parent</relativePath>
-  </parent>
-
-  <artifactId>forwarding.staticrouting.northbound</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.codehaus.enunciate</groupId>
-      <artifactId>enunciate-core-annotations</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>commons.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>containermanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>forwarding.staticrouting</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-  </dependencies>
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Export-Package></Export-Package>
-            <Import-Package>org.opendaylight.controller.forwarding.staticrouting,
-              org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.sal.utils,
-              org.opendaylight.controller.containermanager,
-              org.opendaylight.controller.usermanager,
-              com.sun.jersey.spi.container.servlet,
-              org.opendaylight.controller.northbound.commons,
-              org.opendaylight.controller.northbound.commons.exception,
-              org.opendaylight.controller.northbound.commons.utils,
-              org.opendaylight.controller.northbound.commons.query,
-              org.opendaylight.controller.sal.authorization,
-              org.slf4j,
-              javax.ws.rs,
-              javax.ws.rs.ext,
-              javax.ws.rs.core,
-              javax.xml.bind.annotation,
-              javax.xml.bind,
-              org.apache.catalina.filters,
-              com.fasterxml.jackson.jaxrs.base,
-              com.fasterxml.jackson.jaxrs.json,
-              !org.codehaus.enunciate.jaxrs</Import-Package>
-            <Export-Package></Export-Package>
-            <Web-ContextPath>/controller/nb/v2/staticroute</Web-ContextPath>
-            <Jaxrs-Resources>,${classes;ANNOTATION;javax.ws.rs.Path}</Jaxrs-Resources>
-          </instructions>
-          <manifestLocation>${project.basedir}/src/main/resources/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/northbound/staticrouting/src/main/java/org/opendaylight/controller/forwarding/staticrouting/northbound/StaticRoute.java b/opendaylight/adsal/northbound/staticrouting/src/main/java/org/opendaylight/controller/forwarding/staticrouting/northbound/StaticRoute.java
deleted file mode 100644 (file)
index 573a081..0000000
+++ /dev/null
@@ -1,77 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.forwarding.staticrouting.northbound;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-/**
- * StaticRoute represents the static route data that is returned as a response to
- * the NorthBound GET request.
- *
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-public class StaticRoute {
-    /**
-     * The name of the static route.
-     */
-    @XmlElement
-    private String name;
-
-    /**
-     * The prefix for the route.
-     * Format: A.B.C.D/MM  Where A.B.C.D is the Default Gateway IP (L3) or ARP Querier IP (L2)
-     */
-    @XmlElement
-    private String prefix;
-
-    /**
-     * NextHop IP-Address (or) datapath ID/port list: xx:xx:xx:xx:xx:xx:xx:xx/a,b,c-m,r-t,y
-     */
-    @XmlElement
-    private String nextHop;
-
-    public StaticRoute() {
-    }
-
-    public StaticRoute(String name, String prefix, String nextHop) {
-        super();
-        this.name = name;
-        this.prefix = prefix;
-        this.nextHop = nextHop;
-    }
-
-    public String getName() {
-        return name;
-    }
-
-    public void setName(String name) {
-        this.name = name;
-    }
-
-    public String getPrefix() {
-        return prefix;
-    }
-
-    public void setPrefix(String prefix) {
-        this.prefix = prefix;
-    }
-
-    public String getNextHop() {
-        return nextHop;
-    }
-
-    public void setNextHop(String nextHop) {
-        this.nextHop = nextHop;
-    }
-}
diff --git a/opendaylight/adsal/northbound/staticrouting/src/main/java/org/opendaylight/controller/forwarding/staticrouting/northbound/StaticRoutes.java b/opendaylight/adsal/northbound/staticrouting/src/main/java/org/opendaylight/controller/forwarding/staticrouting/northbound/StaticRoutes.java
deleted file mode 100644 (file)
index d6d0995..0000000
+++ /dev/null
@@ -1,43 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.forwarding.staticrouting.northbound;
-
-import java.util.List;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-
-/**
- * This class represents a list of static routes.
- */
-@XmlRootElement(name = "list")
-@XmlAccessorType(XmlAccessType.NONE)
-public class StaticRoutes {
-        @XmlElement
-        List<StaticRoute> staticRoute;
-        //To satisfy JAXB
-        private StaticRoutes() {
-
-        }
-
-        public StaticRoutes(List<StaticRoute> staticRoute) {
-                this.staticRoute = staticRoute;
-        }
-
-        public List<StaticRoute> getFlowConfig() {
-                return staticRoute;
-        }
-
-        public void setFlowConfig(List<StaticRoute> staticRoute) {
-                this.staticRoute = staticRoute;
-        }
-}
diff --git a/opendaylight/adsal/northbound/staticrouting/src/main/java/org/opendaylight/controller/forwarding/staticrouting/northbound/StaticRoutingNorthbound.java b/opendaylight/adsal/northbound/staticrouting/src/main/java/org/opendaylight/controller/forwarding/staticrouting/northbound/StaticRoutingNorthbound.java
deleted file mode 100644 (file)
index de291d6..0000000
+++ /dev/null
@@ -1,376 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.forwarding.staticrouting.northbound;
-
-import java.util.ArrayList;
-import java.util.List;
-
-import javax.ws.rs.Consumes;
-import javax.ws.rs.DELETE;
-import javax.ws.rs.GET;
-import javax.ws.rs.PUT;
-import javax.ws.rs.Path;
-import javax.ws.rs.PathParam;
-import javax.ws.rs.Produces;
-import javax.ws.rs.QueryParam;
-import javax.ws.rs.core.Context;
-import javax.ws.rs.core.MediaType;
-import javax.ws.rs.core.Response;
-import javax.ws.rs.core.SecurityContext;
-import javax.ws.rs.core.UriInfo;
-import javax.ws.rs.ext.ContextResolver;
-
-import org.codehaus.enunciate.jaxrs.ResponseCode;
-import org.codehaus.enunciate.jaxrs.StatusCodes;
-import org.codehaus.enunciate.jaxrs.TypeHint;
-import org.opendaylight.controller.containermanager.IContainerManager;
-import org.opendaylight.controller.forwarding.staticrouting.IForwardingStaticRouting;
-import org.opendaylight.controller.forwarding.staticrouting.StaticRouteConfig;
-import org.opendaylight.controller.northbound.commons.RestMessages;
-import org.opendaylight.controller.northbound.commons.exception.InternalServerErrorException;
-import org.opendaylight.controller.northbound.commons.exception.NotAcceptableException;
-import org.opendaylight.controller.northbound.commons.exception.ResourceConflictException;
-import org.opendaylight.controller.northbound.commons.exception.ResourceNotFoundException;
-import org.opendaylight.controller.northbound.commons.exception.UnauthorizedException;
-import org.opendaylight.controller.northbound.commons.query.QueryContext;
-import org.opendaylight.controller.northbound.commons.utils.NorthboundUtils;
-import org.opendaylight.controller.sal.authorization.Privilege;
-import org.opendaylight.controller.sal.utils.GlobalConstants;
-import org.opendaylight.controller.sal.utils.ServiceHelper;
-import org.opendaylight.controller.sal.utils.Status;
-
-/**
- * <p>Static Routing Northbound API allows for the management of the static
- * routes.</p>
- * </br>
- * An example request/response for retrieving the static routes may look like this: </br>
- * <pre>
- * GET http://localhost:8080/controller/nb/v2/staticroute/default HTTP/1.1
- * Accept: application/json
- *
- * HTTP/1.1 200 OK
- * Content-Type: application/json
- *
- * { "staticRoute":[
- *       "name":"route-1",
- *       "prefix":"10.10.1.0/24",
- *       "nextHop":"1.1.1.1"
- *   ]
- * }
- *
- * </pre>
- *
- * <br><br>
- * Authentication scheme : <b>HTTP Basic</b><br>
- * Authentication realm : <b>opendaylight</b><br>
- * Transport : <b>HTTP and HTTPS</b><br>
- * <br>
- */
-@Path("/")
-public class StaticRoutingNorthbound {
-
-    private String username;
-    private QueryContext queryContext;
-
-    @Context
-    public void setQueryContext(ContextResolver<QueryContext> queryCtxResolver) {
-      if (queryCtxResolver != null) {
-        queryContext = queryCtxResolver.getContext(QueryContext.class);
-      }
-    }
-
-    @Context
-    public void setSecurityContext(SecurityContext context) {
-        if (context != null && context.getUserPrincipal() != null) {
-            username = context.getUserPrincipal().getName();
-        }
-    }
-    protected String getUserName() {
-        return username;
-    }
-
-
-
-    private List<StaticRoute> getStaticRoutesInternal(String containerName) {
-
-        IForwardingStaticRouting staticRouting = (IForwardingStaticRouting) ServiceHelper
-                .getInstance(IForwardingStaticRouting.class, containerName,
-                        this);
-
-        if (staticRouting == null) {
-            throw new ResourceNotFoundException(RestMessages.NOCONTAINER
-                    .toString());
-        }
-
-        List<StaticRoute> routes = new ArrayList<StaticRoute>();
-
-        for (StaticRouteConfig conf : staticRouting.getStaticRouteConfigs()
-                .values()) {
-            StaticRoute route = new StaticRoute(conf.getName(), conf
-                    .getStaticRoute(), conf.getNextHop());
-            routes.add(route);
-        }
-        return routes;
-    }
-
-    /**
-     * Get a list of static routes present on the given container.
-     *
-     * @param containerName Name of the Container. The Container name for the base controller is "default".
-     * @return List of configured static routes on the given container
-     *
-     * <pre>
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/staticroute/default/routes
-     *
-     * Response body in XML:
-     *  &lt;list&gt;
-     *   &lt;staticRoute&gt;
-     *     &lt;name&gt;route-1&lt;/name&gt;
-     *     &lt;prefix&gt;10.10.1.0/24&lt;/prefix&gt;
-     *     &lt;nextHop&gt;1.1.1.1&lt;/nextHop&gt;
-     *   &lt;/staticRoute&gt;
-     *  &lt;/list&gt;
-     *
-     * Response body in JSON:
-     * {
-     *    "staticRoute": [
-     *      {
-     *       "name": "route-1",
-     *       "prefix": "10.10.1.0/24",
-     *       "nextHop": "1.1.1.1"
-     *      }
-     *    ]
-     * }
-     * </pre>
-     */
-    @Path("/{containerName}/routes")
-    @GET
-    @Produces( { MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @TypeHint(StaticRoutes.class)
-    @StatusCodes( {
-            @ResponseCode(code = 200, condition = "Operation successful"),
-            @ResponseCode(code = 404, condition = "The containerName passed was not found") })
-    public StaticRoutes getStaticRoutes(
-            @PathParam("containerName") String containerName,
-            @QueryParam("_q") String queryString) {
-
-        if(!NorthboundUtils.isAuthorized(getUserName(), containerName,
-                Privilege.WRITE, this)){
-            throw new
-                UnauthorizedException("User is not authorized to perform this operation on container "
-                            + containerName);
-        }
-        StaticRoutes result = new StaticRoutes(getStaticRoutesInternal(containerName));
-        if (queryString != null) {
-            queryContext.createQuery(queryString, StaticRoutes.class)
-                .filter(result, StaticRoute.class);
-        }
-        return result;
-    }
-
-    /**
-     * Returns the static route for the provided configuration name on a given container
-     *
-     * @param containerName Name of the Container. The Container name for the base controller is "default".
-     * @param route Name of the Static Route configuration
-     * @return Static route configured with the supplied Name.
-     *
-     * <pre>
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/staticroute/default/route/route-1
-     *
-     * Response body in XML:
-     *
-     *   &lt;staticRoute&gt;
-     *     &lt;name&gt;route-1&lt;/name&gt;
-     *     &lt;prefix&gt;10.10.1.0/24&lt;/prefix&gt;
-     *     &lt;nextHop&gt;1.1.1.1&lt;/nextHop&gt;
-     *   &lt;/staticRoute&gt;
-     *
-     * Response body in JSON:
-     * {
-     *    "name":"route-1",
-     *    "prefix":"10.10.1.0/24",
-     *    "nextHop":"1.1.1.1"
-     * }
-     *
-     * </pre>
-     */
-    @Path("/{containerName}/route/{route}")
-    @GET
-    @Produces( { MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @TypeHint(StaticRoute.class)
-    @StatusCodes( {
-            @ResponseCode(code = 200, condition = "Operation successful"),
-            @ResponseCode(code = 404, condition = "The Container Name or Static Route Configuration name passed was not found") })
-    public StaticRoute getStaticRoute(
-            @PathParam("containerName") String containerName,
-            @PathParam("route") String route) {
-
-        if(!NorthboundUtils.isAuthorized(getUserName(), containerName,
-                Privilege.WRITE, this)){
-            throw new
-                UnauthorizedException("User is not authorized to perform this operation on container "
-                            + containerName);
-        }
-        List<StaticRoute> routes = this.getStaticRoutesInternal(containerName);
-        for (StaticRoute r : routes) {
-            if (r.getName().equalsIgnoreCase(route)) {
-                return r;
-            }
-        }
-
-        throw new ResourceNotFoundException(RestMessages.NOSTATICROUTE
-                .toString());
-    }
-
-    /**
-     *
-     * Add a new Static Route. If a route by the given name already exists, this
-     * method will return a non-successful status response.
-     *
-     * @param containerName Name of the Container. The Container name for the base controller is "default".
-     * @param route Name of the Static Route configuration
-     * @return Response as dictated by the HTTP Response code
-     *
-     * <pre>
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/staticroute/default/route/route-1
-     *
-     * Request body in XML:
-     * &lt;staticRoute&gt;
-     *   &lt;name&gt;route-1&lt;/name&gt;
-     *   &lt;prefix>10.10.1.0/24&lt;/prefix&gt;
-     *   &lt;nextHop&gt;1.1.1.1&lt;/nextHop&gt;
-     *   &lt;/staticRoute&gt;
-     * Request body in JSON:
-     * {
-     *    "name":"route-1",
-     *    "prefix":"10.10.1.0/24",
-     *    "nextHop":"1.1.1.1"
-     * }
-     * </pre>
-     */
-    @Path("/{containerName}/route/{route}")
-    @PUT
-    @Consumes( { MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @StatusCodes( {
-            @ResponseCode(code = 201, condition = "Created Static Route successfully"),
-            @ResponseCode(code = 404, condition = "The Container Name passed is not found"),
-            @ResponseCode(code = 406, condition = "Cannot operate on Default Container when other Containers are active"),
-            @ResponseCode(code = 409, condition = "Failed to create Static Route entry due to Conflicting Name or Prefix."), })
-    public Response addStaticRoute(
-            @Context UriInfo uriInfo,
-            @PathParam(value = "containerName") String containerName,
-            @PathParam(value = "route") String route,
-            @TypeHint(StaticRoute.class) StaticRoute staticRouteData) {
-
-
-        if(!NorthboundUtils.isAuthorized(getUserName(), containerName,
-                Privilege.WRITE, this)){
-            throw new
-                UnauthorizedException("User is not authorized to perform this operation on container "
-                            + containerName);
-        }
-        handleDefaultDisabled(containerName);
-
-        IForwardingStaticRouting staticRouting = (IForwardingStaticRouting) ServiceHelper
-                .getInstance(IForwardingStaticRouting.class, containerName,
-                        this);
-
-        if (staticRouting == null) {
-            throw new ResourceNotFoundException(RestMessages.NOCONTAINER
-                    .toString());
-        }
-
-        StaticRoute sRoute = staticRouteData;
-        StaticRouteConfig cfgObject = new StaticRouteConfig(sRoute.getName(),
-                sRoute.getPrefix(), sRoute.getNextHop());
-        Status response = staticRouting.addStaticRoute(cfgObject);
-        if (response.isSuccess()) {
-            NorthboundUtils.auditlog("Static Route", username, "added", route, containerName);
-            return Response.created(uriInfo.getRequestUri()).build();
-        }
-        throw new ResourceConflictException(response.getDescription());
-    }
-
-    /**
-     *
-     * Delete a Static Route
-     *
-     * @param containerName Name of the Container. The Container name for the base controller is "default".
-     * @param route Name of the Static Route configuration to be removed
-     *
-     * @return Response as dictated by the HTTP Response code
-     *
-     * <pre>
-     * Example:
-     *
-     * Request URL:
-     * DELETE http://localhost:8080/controller/nb/v2/staticroute/default/route/route-1
-     *
-     * </pre>
-     */
-    @Path("/{containerName}/route/{route}")
-    @DELETE
-    @StatusCodes( {
-            @ResponseCode(code = 204, condition = "Static route removed successfully"),
-            @ResponseCode(code = 404, condition = "Container Name or Configuration Name not found"),
-            @ResponseCode(code = 406, condition = "Cannot operate on Default Container when other Containers are active") })
-    public Response removeStaticRoute(
-            @PathParam(value = "containerName") String containerName,
-            @PathParam(value = "route") String route) {
-
-        if(!NorthboundUtils.isAuthorized(getUserName(), containerName,
-                Privilege.WRITE, this)){
-            throw new
-                UnauthorizedException("User is not authorized to perform this operation on container "
-                            + containerName);
-        }
-        handleDefaultDisabled(containerName);
-
-        IForwardingStaticRouting staticRouting = (IForwardingStaticRouting) ServiceHelper
-                .getInstance(IForwardingStaticRouting.class, containerName,
-                        this);
-
-        if (staticRouting == null) {
-            throw new ResourceNotFoundException(RestMessages.NOCONTAINER
-                    .toString());
-        }
-
-        Status status = staticRouting.removeStaticRoute(route);
-        if (status.isSuccess()) {
-            NorthboundUtils.auditlog("Static Route", username, "removed", route, containerName);
-            return Response.noContent().build();
-        }
-        return NorthboundUtils.getResponse(status);
-    }
-
-    private void handleDefaultDisabled(String containerName) {
-        IContainerManager containerManager = (IContainerManager) ServiceHelper
-                .getGlobalInstance(IContainerManager.class, this);
-        if (containerManager == null) {
-            throw new InternalServerErrorException(RestMessages.INTERNALERROR
-                    .toString());
-        }
-        if (containerName.equals(GlobalConstants.DEFAULT.toString())
-                && containerManager.hasNonDefaultContainer()) {
-            throw new NotAcceptableException(RestMessages.DEFAULTDISABLED
-                    .toString());
-        }
-    }
-}
diff --git a/opendaylight/adsal/northbound/staticrouting/src/main/resources/META-INF/spring.factories b/opendaylight/adsal/northbound/staticrouting/src/main/resources/META-INF/spring.factories
deleted file mode 100644 (file)
index 93db02e..0000000
+++ /dev/null
@@ -1 +0,0 @@
-org.springframework.beans.BeanInfoFactory=org.springframework.beans.ExtendedBeanInfoFactory
diff --git a/opendaylight/adsal/northbound/staticrouting/src/main/resources/META-INF/spring.handlers b/opendaylight/adsal/northbound/staticrouting/src/main/resources/META-INF/spring.handlers
deleted file mode 100644 (file)
index 957af91..0000000
+++ /dev/null
@@ -1,10 +0,0 @@
-http\://www.springframework.org/schema/context=org.springframework.context.config.ContextNamespaceHandler
-http\://www.springframework.org/schema/jee=org.springframework.ejb.config.JeeNamespaceHandler
-http\://www.springframework.org/schema/lang=org.springframework.scripting.config.LangNamespaceHandler
-http\://www.springframework.org/schema/task=org.springframework.scheduling.config.TaskNamespaceHandler
-http\://www.springframework.org/schema/cache=org.springframework.cache.config.CacheNamespaceHandler
-http\://www.springframework.org/schema/c=org.springframework.beans.factory.xml.SimpleConstructorNamespaceHandler
-http\://www.springframework.org/schema/p=org.springframework.beans.factory.xml.SimplePropertyNamespaceHandler
-http\://www.springframework.org/schema/util=org.springframework.beans.factory.xml.UtilNamespaceHandler
-http\://www.springframework.org/schema/mvc=org.springframework.web.servlet.config.MvcNamespaceHandler
-http\://www.springframework.org/schema/security=org.springframework.security.config.SecurityNamespaceHandler
diff --git a/opendaylight/adsal/northbound/staticrouting/src/main/resources/META-INF/spring.schemas b/opendaylight/adsal/northbound/staticrouting/src/main/resources/META-INF/spring.schemas
deleted file mode 100644 (file)
index d865edc..0000000
+++ /dev/null
@@ -1,49 +0,0 @@
-http\://www.springframework.org/schema/beans/spring-beans-2.0.xsd=org/springframework/beans/factory/xml/spring-beans-2.0.xsd
-http\://www.springframework.org/schema/beans/spring-beans-2.5.xsd=org/springframework/beans/factory/xml/spring-beans-2.5.xsd
-http\://www.springframework.org/schema/beans/spring-beans-3.0.xsd=org/springframework/beans/factory/xml/spring-beans-3.0.xsd
-http\://www.springframework.org/schema/beans/spring-beans-3.1.xsd=org/springframework/beans/factory/xml/spring-beans-3.1.xsd
-http\://www.springframework.org/schema/beans/spring-beans-3.2.xsd=org/springframework/beans/factory/xml/spring-beans-3.2.xsd
-http\://www.springframework.org/schema/beans/spring-beans.xsd=org/springframework/beans/factory/xml/spring-beans-3.2.xsd
-http\://www.springframework.org/schema/tool/spring-tool-2.0.xsd=org/springframework/beans/factory/xml/spring-tool-2.0.xsd
-http\://www.springframework.org/schema/tool/spring-tool-2.5.xsd=org/springframework/beans/factory/xml/spring-tool-2.5.xsd
-http\://www.springframework.org/schema/tool/spring-tool-3.0.xsd=org/springframework/beans/factory/xml/spring-tool-3.0.xsd
-http\://www.springframework.org/schema/tool/spring-tool-3.1.xsd=org/springframework/beans/factory/xml/spring-tool-3.1.xsd
-http\://www.springframework.org/schema/tool/spring-tool-3.2.xsd=org/springframework/beans/factory/xml/spring-tool-3.2.xsd
-http\://www.springframework.org/schema/tool/spring-tool.xsd=org/springframework/beans/factory/xml/spring-tool-3.2.xsd
-http\://www.springframework.org/schema/util/spring-util-2.0.xsd=org/springframework/beans/factory/xml/spring-util-2.0.xsd
-http\://www.springframework.org/schema/util/spring-util-2.5.xsd=org/springframework/beans/factory/xml/spring-util-2.5.xsd
-http\://www.springframework.org/schema/util/spring-util-3.0.xsd=org/springframework/beans/factory/xml/spring-util-3.0.xsd
-http\://www.springframework.org/schema/util/spring-util-3.1.xsd=org/springframework/beans/factory/xml/spring-util-3.1.xsd
-http\://www.springframework.org/schema/util/spring-util-3.2.xsd=org/springframework/beans/factory/xml/spring-util-3.2.xsd
-http\://www.springframework.org/schema/util/spring-util.xsd=org/springframework/beans/factory/xml/spring-util-3.2.xsd
-http\://www.springframework.org/schema/context/spring-context-2.5.xsd=org/springframework/context/config/spring-context-2.5.xsd
-http\://www.springframework.org/schema/context/spring-context-3.0.xsd=org/springframework/context/config/spring-context-3.0.xsd
-http\://www.springframework.org/schema/context/spring-context-3.1.xsd=org/springframework/context/config/spring-context-3.1.xsd
-http\://www.springframework.org/schema/context/spring-context-3.2.xsd=org/springframework/context/config/spring-context-3.2.xsd
-http\://www.springframework.org/schema/context/spring-context.xsd=org/springframework/context/config/spring-context-3.2.xsd
-http\://www.springframework.org/schema/jee/spring-jee-2.0.xsd=org/springframework/ejb/config/spring-jee-2.0.xsd
-http\://www.springframework.org/schema/jee/spring-jee-2.5.xsd=org/springframework/ejb/config/spring-jee-2.5.xsd
-http\://www.springframework.org/schema/jee/spring-jee-3.0.xsd=org/springframework/ejb/config/spring-jee-3.0.xsd
-http\://www.springframework.org/schema/jee/spring-jee-3.1.xsd=org/springframework/ejb/config/spring-jee-3.1.xsd
-http\://www.springframework.org/schema/jee/spring-jee-3.2.xsd=org/springframework/ejb/config/spring-jee-3.2.xsd
-http\://www.springframework.org/schema/jee/spring-jee.xsd=org/springframework/ejb/config/spring-jee-3.2.xsd
-http\://www.springframework.org/schema/lang/spring-lang-2.0.xsd=org/springframework/scripting/config/spring-lang-2.0.xsd
-http\://www.springframework.org/schema/lang/spring-lang-2.5.xsd=org/springframework/scripting/config/spring-lang-2.5.xsd
-http\://www.springframework.org/schema/lang/spring-lang-3.0.xsd=org/springframework/scripting/config/spring-lang-3.0.xsd
-http\://www.springframework.org/schema/lang/spring-lang-3.1.xsd=org/springframework/scripting/config/spring-lang-3.1.xsd
-http\://www.springframework.org/schema/lang/spring-lang-3.2.xsd=org/springframework/scripting/config/spring-lang-3.2.xsd
-http\://www.springframework.org/schema/lang/spring-lang.xsd=org/springframework/scripting/config/spring-lang-3.2.xsd
-http\://www.springframework.org/schema/task/spring-task-3.0.xsd=org/springframework/scheduling/config/spring-task-3.0.xsd
-http\://www.springframework.org/schema/task/spring-task-3.1.xsd=org/springframework/scheduling/config/spring-task-3.1.xsd
-http\://www.springframework.org/schema/task/spring-task-3.2.xsd=org/springframework/scheduling/config/spring-task-3.2.xsd
-http\://www.springframework.org/schema/task/spring-task.xsd=org/springframework/scheduling/config/spring-task-3.2.xsd
-http\://www.springframework.org/schema/cache/spring-cache-3.1.xsd=org/springframework/cache/config/spring-cache-3.1.xsd
-http\://www.springframework.org/schema/cache/spring-cache-3.2.xsd=org/springframework/cache/config/spring-cache-3.2.xsd
-http\://www.springframework.org/schema/cache/spring-cache.xsd=org/springframework/cache/config/spring-cache-3.2.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd=org/springframework/web/servlet/config/spring-mvc-3.0.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc-3.1.xsd=org/springframework/web/servlet/config/spring-mvc-3.1.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc-3.2.xsd=org/springframework/web/servlet/config/spring-mvc-3.2.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc.xsd=org/springframework/web/servlet/config/spring-mvc-3.2.xsd
-http\://www.springframework.org/schema/security/spring-security-3.1.xsd=org/springframework/security/config/spring-security-3.1.xsd
-http\://www.springframework.org/schema/security/spring-security-3.2.xsd=org/springframework/security/config/spring-security-3.2.xsd
-
diff --git a/opendaylight/adsal/northbound/staticrouting/src/main/resources/META-INF/spring.tooling b/opendaylight/adsal/northbound/staticrouting/src/main/resources/META-INF/spring.tooling
deleted file mode 100644 (file)
index 057d834..0000000
+++ /dev/null
@@ -1,39 +0,0 @@
-# Tooling related information for the beans namespace
-http\://www.springframework.org/schema/beans@name=beans Namespace
-http\://www.springframework.org/schema/beans@prefix=beans
-http\://www.springframework.org/schema/beans@icon=org/springframework/beans/factory/xml/spring-beans.gif
-
-# Tooling related information for the util namespace
-http\://www.springframework.org/schema/util@name=util Namespace
-http\://www.springframework.org/schema/util@prefix=util
-http\://www.springframework.org/schema/util@icon=org/springframework/beans/factory/xml/spring-util.gif
-
-# Tooling related information for the context namespace
-http\://www.springframework.org/schema/context@name=context Namespace
-http\://www.springframework.org/schema/context@prefix=context
-http\://www.springframework.org/schema/context@icon=org/springframework/context/config/spring-context.gif
-
-# Tooling related information for the jee namespace
-http\://www.springframework.org/schema/jee@name=jee Namespace
-http\://www.springframework.org/schema/jee@prefix=jee
-http\://www.springframework.org/schema/jee@icon=org/springframework/ejb/config/spring-jee.gif
-
-# Tooling related information for the scheduling namespace
-http\://www.springframework.org/schema/task@name=task Namespace
-http\://www.springframework.org/schema/task@prefix=task
-http\://www.springframework.org/schema/task@icon=org/springframework/scheduling/config/spring-task.gif
-
-# Tooling related information for the lang namespace
-http\://www.springframework.org/schema/lang@name=lang Namespace
-http\://www.springframework.org/schema/lang@prefix=lang
-http\://www.springframework.org/schema/lang@icon=org/springframework/scripting/config/spring-lang.gif
-
-# Tooling related information for the cache namespace
-http\://www.springframework.org/schema/cache@name=cache Namespace
-http\://www.springframework.org/schema/cache@prefix=cache
-http\://www.springframework.org/schema/cache@icon=org/springframework/cache/config/spring-cache.gif
-
-# Tooling related information for the mvc namespace
-http\://www.springframework.org/schema/mvc@name=mvc Namespace
-http\://www.springframework.org/schema/mvc@prefix=mvc
-http\://www.springframework.org/schema/mvc@icon=org/springframework/web/servlet/config/spring-mvc.gif
diff --git a/opendaylight/adsal/northbound/staticrouting/src/main/resources/WEB-INF/web.xml b/opendaylight/adsal/northbound/staticrouting/src/main/resources/WEB-INF/web.xml
deleted file mode 100644 (file)
index ef58aab..0000000
+++ /dev/null
@@ -1,89 +0,0 @@
-<?xml version="1.0" encoding="ISO-8859-1"?>
-<web-app xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
-        xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
-        version="3.0">
-  <servlet>
-    <servlet-name>JAXRSStaticRouting</servlet-name>
-    <servlet-class>com.sun.jersey.spi.container.servlet.ServletContainer</servlet-class>
-    <init-param>
-      <param-name>javax.ws.rs.Application</param-name>
-      <param-value>org.opendaylight.controller.northbound.commons.NorthboundApplication</param-value>
-    </init-param>
-    <load-on-startup>1</load-on-startup>
-  </servlet>
-
-        <servlet-mapping>
-          <servlet-name>JAXRSStaticRouting</servlet-name>
-          <url-pattern>/*</url-pattern>
-        </servlet-mapping>
-
-        <filter>
-          <filter-name>CorsFilter</filter-name>
-          <filter-class>org.apache.catalina.filters.CorsFilter</filter-class>
-          <init-param>
-            <param-name>cors.allowed.origins</param-name>
-            <param-value>*</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.allowed.methods</param-name>
-            <param-value>GET,POST,HEAD,OPTIONS,PUT,DELETE</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.allowed.headers</param-name>
-            <param-value>Content-Type,X-Requested-With,accept,authorization, origin,Origin,Access-Control-Request-Method,Access-Control-Request-Headers</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.exposed.headers</param-name>
-            <param-value>Access-Control-Allow-Origin,Access-Control-Allow-Credentials</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.support.credentials</param-name>
-            <param-value>true</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.preflight.maxage</param-name>
-            <param-value>10</param-value>
-          </init-param>
-        </filter>
-        <filter-mapping>
-          <filter-name>CorsFilter</filter-name>
-          <url-pattern>/*</url-pattern>
-        </filter-mapping>
-
-        <security-constraint>
-          <web-resource-collection>
-            <web-resource-name>NB api</web-resource-name>
-            <url-pattern>/*</url-pattern>
-            <http-method>POST</http-method>
-            <http-method>GET</http-method>
-            <http-method>PUT</http-method>
-            <http-method>PATCH</http-method>
-            <http-method>DELETE</http-method>
-            <http-method>HEAD</http-method>
-          </web-resource-collection>
-          <auth-constraint>
-            <role-name>System-Admin</role-name>
-            <role-name>Network-Admin</role-name>
-            <role-name>Network-Operator</role-name>
-            <role-name>Container-User</role-name>
-          </auth-constraint>
-        </security-constraint>
-
-        <security-role>
-                <role-name>System-Admin</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Network-Admin</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Network-Operator</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Container-User</role-name>
-        </security-role>
-
-        <login-config>
-                <auth-method>BASIC</auth-method>
-                <realm-name>opendaylight</realm-name>
-        </login-config>
-</web-app>
\ No newline at end of file
diff --git a/opendaylight/adsal/northbound/staticrouting/src/test/java/org/opendaylight/controller/forwarding/staticrouting/northbound/StaticRoutingNorthboundTest.java b/opendaylight/adsal/northbound/staticrouting/src/test/java/org/opendaylight/controller/forwarding/staticrouting/northbound/StaticRoutingNorthboundTest.java
deleted file mode 100644 (file)
index 5a5da4e..0000000
+++ /dev/null
@@ -1,48 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.forwarding.staticrouting.northbound;
-
-import java.util.ArrayList;
-import java.util.List;
-
-import org.junit.Assert;
-import org.junit.Test;
-
-public class StaticRoutingNorthboundTest {
-
-    @Test
-    public void testStaticRoute() {
-        StaticRoute sr = new StaticRoute();
-        Assert.assertTrue(sr.getName() == null);
-        Assert.assertTrue(sr.getPrefix() == null);
-        Assert.assertTrue(sr.getNextHop() == null);
-
-        sr = new StaticRoute("Static Route 1", "192.168.100.0/24", "170.0.0.1");
-        Assert.assertTrue(sr.getName().equals("Static Route 1"));
-        Assert.assertTrue(sr.getPrefix().equals("192.168.100.0/24"));
-        Assert.assertTrue(sr.getNextHop().equals("170.0.0.1"));
-
-        sr.setName("Static Route 2");
-        Assert.assertTrue(sr.getName().equals("Static Route 2"));
-        sr.setPrefix("192.168.100.0/26");
-        Assert.assertTrue(sr.getPrefix().equals("192.168.100.0/26"));
-        sr.setNextHop("170.0.2.1");
-        Assert.assertTrue(sr.getNextHop().equals("170.0.2.1"));
-    }
-
-    @Test
-    public void testStaticRoutes() {
-        StaticRoutes srs = new StaticRoutes(null);
-        Assert.assertTrue(srs.getFlowConfig() == null);
-
-        List<StaticRoute> srl = new ArrayList<StaticRoute>();
-        srs.setFlowConfig(srl);
-        Assert.assertTrue(srs.getFlowConfig().equals(srl));
-    }
-
-}
diff --git a/opendaylight/adsal/northbound/statistics/enunciate.xml b/opendaylight/adsal/northbound/statistics/enunciate.xml
deleted file mode 100644 (file)
index c5f9140..0000000
+++ /dev/null
@@ -1,12 +0,0 @@
-<?xml version="1.0"?>
-<enunciate label="full" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
-    xsi:noNamespaceSchemaLocation="http://enunciate.codehaus.org/schemas/enunciate-1.28.xsd">
-
-  <services>
-    <rest defaultRestSubcontext="/controller/nb/v2/statistics"/>
-  </services>
-
-  <modules>
-    <docs docsDir="rest" title="Statistics REST API" includeExampleXml="true" includeExampleJson="true"/>
-  </modules>
-</enunciate>
diff --git a/opendaylight/adsal/northbound/statistics/pom.xml b/opendaylight/adsal/northbound/statistics/pom.xml
deleted file mode 100644 (file)
index 8b54a98..0000000
+++ /dev/null
@@ -1,93 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>adsal-enunciate-parent</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../adsal-enunciate-parent</relativePath>
-  </parent>
-
-  <artifactId>statistics.northbound</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.codehaus.enunciate</groupId>
-      <artifactId>enunciate-core-annotations</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>commons.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>containermanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>statisticsmanager</artifactId>
-    </dependency>
-  </dependencies>
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Export-Package></Export-Package>
-            <Import-Package>org.opendaylight.controller.forwardingrulesmanager,
-                org.opendaylight.controller.sal.action,
-                org.opendaylight.controller.sal.core,
-                org.opendaylight.controller.sal.flowprogrammer,
-                org.opendaylight.controller.sal.match,
-                org.opendaylight.controller.sal.packet,
-                org.opendaylight.controller.sal.reader,
-                org.opendaylight.controller.sal.utils,
-                org.opendaylight.controller.containermanager,
-                org.opendaylight.controller.statisticsmanager,
-                org.opendaylight.controller.usermanager,
-                org.opendaylight.controller.switchmanager,
-                org.opendaylight.controller.sal.authorization,
-                org.apache.commons.logging,
-                com.sun.jersey.spi.container.servlet,
-                org.opendaylight.controller.northbound.commons,
-                org.opendaylight.controller.northbound.commons.exception,
-                org.opendaylight.controller.northbound.commons.utils,
-                org.opendaylight.controller.northbound.commons.query,
-                javax.ws.rs,
-                javax.ws.rs.ext,
-                javax.ws.rs.core,
-                javax.xml.bind.annotation,
-                javax.xml.bind,
-                org.slf4j,
-                org.apache.catalina.filters,
-                com.fasterxml.jackson.jaxrs.base,
-                com.fasterxml.jackson.jaxrs.json,
-                !org.codehaus.enunciate.jaxrs</Import-Package>
-            <Export-Package></Export-Package>
-            <Web-ContextPath>/controller/nb/v2/statistics</Web-ContextPath>
-            <Jaxrs-Resources>,${classes;ANNOTATION;javax.ws.rs.Path}</Jaxrs-Resources>
-          </instructions>
-          <manifestLocation>${project.basedir}/src/main/resources/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/northbound/statistics/src/main/java/org/opendaylight/controller/statistics/northbound/AllFlowStatistics.java b/opendaylight/adsal/northbound/statistics/src/main/java/org/opendaylight/controller/statistics/northbound/AllFlowStatistics.java
deleted file mode 100644 (file)
index 1862728..0000000
+++ /dev/null
@@ -1,39 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.statistics.northbound;
-
-import java.util.List;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-@XmlRootElement(name = "list")
-@XmlAccessorType(XmlAccessType.NONE)
-public class AllFlowStatistics {
-        @XmlElement
-        List<FlowStatistics> flowStatistics;
-        //To satisfy JAXB
-        @SuppressWarnings("unused")
-        private AllFlowStatistics() {}
-
-        public AllFlowStatistics(List<FlowStatistics> flowStatistics) {
-                this.flowStatistics = flowStatistics;
-        }
-
-        public List<FlowStatistics> getFlowStatistics() {
-                return flowStatistics;
-        }
-
-        public void setFlowStatistics(List<FlowStatistics> flowStatistics) {
-                this.flowStatistics = flowStatistics;
-        }
-
-}
diff --git a/opendaylight/adsal/northbound/statistics/src/main/java/org/opendaylight/controller/statistics/northbound/AllPortStatistics.java b/opendaylight/adsal/northbound/statistics/src/main/java/org/opendaylight/controller/statistics/northbound/AllPortStatistics.java
deleted file mode 100644 (file)
index 2117690..0000000
+++ /dev/null
@@ -1,39 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.statistics.northbound;
-
-import java.util.List;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-@XmlRootElement(name = "list")
-@XmlAccessorType(XmlAccessType.NONE)
-public class AllPortStatistics {
-        @XmlElement
-        List<PortStatistics> portStatistics;
-        //To satisfy JAXB
-        @SuppressWarnings("unused")
-        private AllPortStatistics() {}
-
-        public AllPortStatistics(List<PortStatistics> portStatistics) {
-                this.portStatistics = portStatistics;
-        }
-
-        public List<PortStatistics> getPortStatistics() {
-                return portStatistics;
-        }
-
-        public void setPortStatistics(List<PortStatistics> portStatistics) {
-                this.portStatistics = portStatistics;
-        }
-
-}
diff --git a/opendaylight/adsal/northbound/statistics/src/main/java/org/opendaylight/controller/statistics/northbound/AllTableStatistics.java b/opendaylight/adsal/northbound/statistics/src/main/java/org/opendaylight/controller/statistics/northbound/AllTableStatistics.java
deleted file mode 100644 (file)
index 4a10eb4..0000000
+++ /dev/null
@@ -1,38 +0,0 @@
-/*
- * Copyright (c) 2013 Big Switch Networks, Inc.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.statistics.northbound;
-
-import java.util.List;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-@XmlRootElement(name = "list")
-@XmlAccessorType(XmlAccessType.NONE)
-public class AllTableStatistics {
-    @XmlElement
-    List<TableStatistics> tableStatistics;
-    //To satisfy JAXB
-    @SuppressWarnings("unused")
-    private AllTableStatistics() {}
-
-    public AllTableStatistics(List<TableStatistics> tableStatistics) {
-        this.tableStatistics = tableStatistics;
-    }
-
-    public List<TableStatistics> getTableStatistics() {
-        return tableStatistics;
-    }
-
-    public void setTableStatistics(List<TableStatistics> tableStatistics) {
-        this.tableStatistics = tableStatistics;
-    }
-
-}
diff --git a/opendaylight/adsal/northbound/statistics/src/main/java/org/opendaylight/controller/statistics/northbound/FlowStatistics.java b/opendaylight/adsal/northbound/statistics/src/main/java/org/opendaylight/controller/statistics/northbound/FlowStatistics.java
deleted file mode 100644 (file)
index 9b31b91..0000000
+++ /dev/null
@@ -1,55 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.statistics.northbound;
-
-import java.util.List;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.reader.FlowOnNode;
-
-@XmlRootElement(name = "nodeFlowStatistics")
-@XmlAccessorType(XmlAccessType.NONE)
-public class FlowStatistics {
-    @XmlElement
-    private Node node;
-    @XmlElement
-    private List<FlowOnNode> flowStatistic;
-
-    // To satisfy JAXB
-    @SuppressWarnings("unused")
-    private FlowStatistics() {
-    }
-
-    public FlowStatistics(Node node, List<FlowOnNode> flowStat) {
-        super();
-        this.node = node;
-        this.flowStatistic = flowStat;
-    }
-
-    public Node getNode() {
-        return node;
-    }
-
-    public void setNode(Node node) {
-        this.node = node;
-    }
-
-    public List<FlowOnNode> getFlowStats() {
-        return flowStatistic;
-    }
-
-    public void setFlowStats(List<FlowOnNode> flowStats) {
-        this.flowStatistic = flowStats;
-    }
-}
diff --git a/opendaylight/adsal/northbound/statistics/src/main/java/org/opendaylight/controller/statistics/northbound/PortStatistics.java b/opendaylight/adsal/northbound/statistics/src/main/java/org/opendaylight/controller/statistics/northbound/PortStatistics.java
deleted file mode 100644 (file)
index e519472..0000000
+++ /dev/null
@@ -1,56 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.statistics.northbound;
-
-import java.util.List;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.reader.NodeConnectorStatistics;
-
-@XmlRootElement(name = "nodePortStatistics")
-@XmlAccessorType(XmlAccessType.NONE)
-public class PortStatistics {
-    @XmlElement
-    private Node node;
-    @XmlElement
-    private List<NodeConnectorStatistics> portStatistic;
-
-    // To satisfy JAXB
-    @SuppressWarnings("unused")
-        private PortStatistics() {
-    }
-
-    public PortStatistics(Node node, List<NodeConnectorStatistics> portStats) {
-        super();
-        this.node = node;
-        this.portStatistic = portStats;
-    }
-
-    public Node getNode() {
-        return node;
-    }
-
-    public void setNode(Node node) {
-        this.node = node;
-    }
-
-    public List<NodeConnectorStatistics> getPortStats() {
-        return portStatistic;
-    }
-
-    public void setFlowStats(List<NodeConnectorStatistics> portStats) {
-        this.portStatistic = portStats;
-    }
-
-}
diff --git a/opendaylight/adsal/northbound/statistics/src/main/java/org/opendaylight/controller/statistics/northbound/StatisticsNorthbound.java b/opendaylight/adsal/northbound/statistics/src/main/java/org/opendaylight/controller/statistics/northbound/StatisticsNorthbound.java
deleted file mode 100644 (file)
index ad9d126..0000000
+++ /dev/null
@@ -1,1171 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.statistics.northbound;
-
-import java.util.ArrayList;
-import java.util.List;
-
-import javax.ws.rs.GET;
-import javax.ws.rs.Path;
-import javax.ws.rs.PathParam;
-import javax.ws.rs.Produces;
-import javax.ws.rs.QueryParam;
-import javax.ws.rs.core.Context;
-import javax.ws.rs.core.MediaType;
-import javax.ws.rs.core.SecurityContext;
-import javax.ws.rs.ext.ContextResolver;
-
-import org.codehaus.enunciate.jaxrs.ResponseCode;
-import org.codehaus.enunciate.jaxrs.StatusCodes;
-import org.codehaus.enunciate.jaxrs.TypeHint;
-import org.opendaylight.controller.containermanager.IContainerManager;
-import org.opendaylight.controller.northbound.commons.RestMessages;
-import org.opendaylight.controller.northbound.commons.exception.InternalServerErrorException;
-import org.opendaylight.controller.northbound.commons.exception.ResourceConflictException;
-import org.opendaylight.controller.northbound.commons.exception.ResourceNotFoundException;
-import org.opendaylight.controller.northbound.commons.exception.ServiceUnavailableException;
-import org.opendaylight.controller.northbound.commons.exception.UnauthorizedException;
-import org.opendaylight.controller.northbound.commons.query.QueryContext;
-import org.opendaylight.controller.northbound.commons.utils.NorthboundUtils;
-import org.opendaylight.controller.sal.authorization.Privilege;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.reader.FlowOnNode;
-import org.opendaylight.controller.sal.reader.NodeConnectorStatistics;
-import org.opendaylight.controller.sal.reader.NodeTableStatistics;
-import org.opendaylight.controller.sal.utils.GlobalConstants;
-import org.opendaylight.controller.sal.utils.ServiceHelper;
-import org.opendaylight.controller.statisticsmanager.IStatisticsManager;
-import org.opendaylight.controller.switchmanager.ISwitchManager;
-
-/**
- * Northbound APIs that returns various Statistics exposed by the Southbound
- * protocol plugins such as Openflow.
- *
- * <br>
- * <br>
- * Authentication scheme : <b>HTTP Basic</b><br>
- * Authentication realm : <b>opendaylight</b><br>
- * Transport : <b>HTTP and HTTPS</b><br>
- * <br>
- * HTTPS Authentication is disabled by default.
- *
- */
-@Path("/")
-public class StatisticsNorthbound {
-
-    private String username;
-    private QueryContext queryContext;
-
-    @Context
-    public void setQueryContext(ContextResolver<QueryContext> queryCtxResolver) {
-      if (queryCtxResolver != null) {
-        queryContext = queryCtxResolver.getContext(QueryContext.class);
-      }
-    }
-    @Context
-    public void setSecurityContext(SecurityContext context) {
-        if (context != null && context.getUserPrincipal() != null) {
-            username = context.getUserPrincipal().getName();
-        }
-    }
-
-    protected String getUserName() {
-        return username;
-    }
-
-    private IStatisticsManager getStatisticsService(String containerName) {
-        IContainerManager containerManager = (IContainerManager) ServiceHelper
-                .getGlobalInstance(IContainerManager.class, this);
-        if (containerManager == null) {
-            throw new ServiceUnavailableException("Container "
-                    + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        boolean found = false;
-        List<String> containerNames = containerManager.getContainerNames();
-        for (String cName : containerNames) {
-            if (cName.trim().equalsIgnoreCase(containerName.trim())) {
-                found = true;
-            }
-        }
-
-        if (found == false) {
-            throw new ResourceNotFoundException(containerName + " "
-                    + RestMessages.NOCONTAINER.toString());
-        }
-
-        IStatisticsManager statsManager = (IStatisticsManager) ServiceHelper
-                .getInstance(IStatisticsManager.class, containerName, this);
-
-        if (statsManager == null) {
-            throw new ServiceUnavailableException("Statistics "
-                    + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        return statsManager;
-    }
-
-    /**
-     * Returns a list of all Flow Statistics from all the Nodes.
-     *
-     * @param containerName
-     *            Name of the Container. The Container name for the base
-     *            controller is "default".
-     * @return List of FlowStatistics from all the Nodes
-     *
-     * <pre>
-     *
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/statistics/default/flow
-     *
-     * Response body in JSON:
-     * {
-     *     "flowStatistics": [
-     *         {
-     *             "node": {
-     *                 "id":"00:00:00:00:00:00:00:02",
-     *                 "type":"OF"
-     *             },
-     *             "flowStatistic": [
-     *                 {
-     *                     "flow": {
-     *                         "match": {
-     *                             "matchField": [
-     *                                 {
-     *                                     "type": "DL_TYPE",
-     *                                     "value": "2048"
-     *                                 },
-     *                                 {
-     *                                     "mask": "255.255.255.255",
-     *                                     "type": "NW_DST",
-     *                                     "value": "1.1.1.1"
-     *                                 }
-     *                             ]
-     *                         },
-     *                         "actions": {
-     *                             "@type": "output",
-     *                             "port": {
-     *                                 "node":{
-     *                                     "id":"00:00:00:00:00:00:00:02",
-     *                                     "type":"OF"
-     *                                 },
-     *                                 "id":"3",
-     *                                 "type":"OF"
-     *                             }
-     *                         },
-     *                         "priority": "1",
-     *                         "idleTimeout": "0",
-     *                         "hardTimeout": "0",
-     *                         "id": "0"
-     *                     },
-     *                     "tableId": "0",
-     *                     "durationSeconds": "1828",
-     *                     "durationNanoseconds": "397000000",
-     *                     "packetCount": "0",
-     *                     "byteCount": "0"
-     *                 }
-     *             ]
-     *         },
-     *         {   flow statistics of another node
-     *             ............
-     *             ................
-     *             ......................
-     *         }
-     *
-     *     ]
-     * }
-     *
-     * Response body in XML:
-     * &lt;?xml version=&quot;1.0&quot; encoding=&quot;UTF-8&quot; standalone=&quot;yes&quot;?&gt;
-     * &lt;list&gt;
-     *     &lt;flowStatistics&gt;
-     *         &lt;node&gt;
-     *             &lt;id&gt;00:00:00:00:00:00:00:02&lt;/id&gt;
-     *             &lt;type&gt;OF&lt;/type&gt;
-     *         &lt;/node&gt;
-     *         &lt;flowStatistic&gt;
-     *             &lt;flow&gt;
-     *                 &lt;match&gt;
-     *                     &lt;matchField&gt;
-     *                         &lt;type&gt;DL_TYPE&lt;/type&gt;
-     *                         &lt;value&gt;2048&lt;/value&gt;
-     *                     &lt;/matchField&gt;
-     *                     &lt;matchField&gt;
-     *                         &lt;mask&gt;255.255.255.255&lt;/mask&gt;
-     *                         &lt;type&gt;NW_DST&lt;/type&gt;
-     *                         &lt;value&gt;1.1.1.2&lt;/value&gt;
-     *                     &lt;/matchField&gt;
-     *                 &lt;/match&gt;
-     *                 &lt;actions
-     *                     xmlns:xsi=&quot;http://www.w3.org/2001/XMLSchema-instance&quot; xsi:type=&quot;output&quot;&gt;
-     *                     &lt;port&gt;
-     *                         &lt;node&gt;
-     *                             &lt;id&gt;00:00:00:00:00:00:00:02&lt;/id&gt;
-     *                             &lt;type&gt;OF&lt;/type&gt;
-     *                         &lt;/node&gt;
-     *                         &lt;id&gt;3&lt;/id&gt;
-     *                         &lt;type&gt;OF&lt;/type&gt;
-     *                     &lt;/port&gt;
-     *                 &lt;/actions&gt;
-     *                 &lt;priority&gt;1&lt;/priority&gt;
-     *                 &lt;idleTimeout&gt;0&lt;/idleTimeout&gt;
-     *                 &lt;hardTimeout&gt;0&lt;/hardTimeout&gt;
-     *                 &lt;id&gt;0&lt;/id&gt;
-     *             &lt;/flow&gt;
-     *             &lt;tableId&gt;0&lt;/tableId&gt;
-     *             &lt;durationSeconds&gt;337&lt;/durationSeconds&gt;
-     *             &lt;durationNanoseconds&gt;149000000&lt;/durationNanoseconds&gt;
-     *             &lt;packetCount&gt;0&lt;/packetCount&gt;
-     *             &lt;byteCount&gt;0&lt;/byteCount&gt;
-     *         &lt;/flowStatistic&gt;
-     *     &lt;/flowStatistics&gt;
-     *     &lt;flowStatistics&gt;
-     *          flow statistics for another node
-     *          ..........
-     *          ................
-     *          .....................
-     *     &lt;/flowStatistics&gt;
-     * &lt;/list&gt;
-     * </pre>
-     */
-
-    @Path("/{containerName}/flow")
-    @GET
-    @Produces({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @TypeHint(AllFlowStatistics.class)
-    @StatusCodes({
-        @ResponseCode(code = 200, condition = "Operation successful"),
-        @ResponseCode(code = 404, condition = "The containerName is not found"),
-        @ResponseCode(code = 503, condition = "One or more of Controller Services are unavailable") })
-    public AllFlowStatistics getFlowStatistics(
-            @PathParam("containerName") String containerName,
-            @QueryParam("_q") String queryString) {
-        if (!NorthboundUtils.isAuthorized(
-                getUserName(), containerName, Privilege.READ, this)) {
-            throw new UnauthorizedException(
-                    "User is not authorized to perform this operation on container "
-                            + containerName);
-        }
-        IStatisticsManager statisticsManager = getStatisticsService(containerName);
-        if (statisticsManager == null) {
-            throw new ServiceUnavailableException("Statistics "
-                    + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        ISwitchManager switchManager = (ISwitchManager) ServiceHelper
-                .getInstance(ISwitchManager.class, containerName, this);
-        if (switchManager == null) {
-            throw new ServiceUnavailableException("Switch manager "
-                    + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        List<FlowStatistics> statistics = new ArrayList<FlowStatistics>();
-        for (Node node : switchManager.getNodes()) {
-            List<FlowOnNode> flowStats = new ArrayList<FlowOnNode>();
-
-            List<FlowOnNode> flows = statisticsManager.getFlows(node);
-            for (FlowOnNode flowOnSwitch : flows) {
-                flowStats.add(flowOnSwitch);
-            }
-            FlowStatistics stat = new FlowStatistics(node, flowStats);
-            statistics.add(stat);
-        }
-        AllFlowStatistics result = new AllFlowStatistics(statistics);
-        if (queryString != null) {
-            queryContext.createQuery(queryString, AllFlowStatistics.class)
-                .filter(result, FlowStatistics.class);
-        }
-        return result;
-    }
-
-    /**
-     * Returns a list of Flow Statistics for a given Node.
-     *
-     * @param containerName
-     *            Name of the Container. The Container name for the base
-     *            controller is "default".
-     * @param nodeType
-     *            Node Type as specifid in {@link org.opendaylight.controller.sal.core.Node} class
-     * @param nodeId
-     *            Node Identifier
-     * @return List of Flow Statistics for a given Node. *
-     *
-     * <pre>
-     *
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/statistics/default/flow/node/OF/00:00:00:00:00:00:00:01
-     *
-     * Response body in JSON:
-     * {
-     *     "node": {
-     *         "id":"00:00:00:00:00:00:00:01",
-     *         "type":"OF"
-     *     },
-     *     "flowStatistic": [
-     *         {
-     *             "flow": {
-     *                 "match": {
-     *                     "matchField": [
-     *                         {
-     *                             "type": "DL_TYPE",
-     *                             "value": "2048"
-     *                         },
-     *                         {
-     *                             "mask": "255.255.255.255",
-     *                             "type": "NW_DST",
-     *                             "value": "1.1.1.2"
-     *                         }
-     *                     ]
-     *                 },
-     *                 "actions": [
-     *                     {
-     *                         "@type": "setDlDst",
-     *                         "address": "52d28b0f76ec"
-     *                     },
-     *                     {
-     *                         "@type": "output",
-     *                         "port":{
-     *                             "node":{
-     *                                 "id":"00:00:00:00:00:00:00:01",
-     *                                 "type":"OF"
-     *                              },
-     *                              "id":"5",
-     *                              "type":"OF"
-     *                         }
-     *                     }
-     *                 ],
-     *                 "priority": "1",
-     *                 "idleTimeout": "0",
-     *                 "hardTimeout": "0",
-     *                 "id": "0"
-     *             },
-     *             "tableId": "0",
-     *             "durationSeconds": "2089",
-     *             "durationNanoseconds": "538000000",
-     *             "packetCount": "0",
-     *             "byteCount": "0"
-     *         }
-     *     ]
-     * }
-     *
-     * Response body in XML:
-     * &lt;?xml version=&quot;1.0&quot; encoding=&quot;UTF-8&quot; standalone=&quot;yes&quot;?&gt;
-     *     &lt;nodeFlowStatistics&gt;
-     *         &lt;node&gt;
-     *             &lt;id&gt;00:00:00:00:00:00:00:02&lt;/id&gt;
-     *             &lt;type&gt;OF&lt;/type&gt;
-     *         &lt;/node&gt;
-     *         &lt;flowStatistic&gt;
-     *             &lt;flow&gt;
-     *                 &lt;match&gt;
-     *                     &lt;matchField&gt;
-     *                         &lt;type&gt;DL_TYPE&lt;/type&gt;
-     *                         &lt;value&gt;2048&lt;/value&gt;
-     *                     &lt;/matchField&gt;
-     *                     &lt;matchField&gt;
-     *                         &lt;mask&gt;255.255.255.255&lt;/mask&gt;
-     *                         &lt;type&gt;NW_DST&lt;/type&gt;
-     *                         &lt;value&gt;1.1.1.2&lt;/value&gt;
-     *                     &lt;/matchField&gt;
-     *                 &lt;/match&gt;
-     *                 &lt;actions
-     *                     xmlns:xsi=&quot;http://www.w3.org/2001/XMLSchema-instance&quot; xsi:type=&quot;output&quot;&gt;
-     *                     &lt;port&gt;
-     *                         &lt;node&gt;
-     *                             &lt;id&gt;00:00:00:00:00:00:00:02&lt;/id&gt;
-     *                             &lt;type&gt;OF&lt;/type&gt;
-     *                         &lt;/node&gt;
-     *                         &lt;id&gt;3&lt;/id&gt;
-     *                         &lt;type&gt;OF&lt;/type&gt;
-     *                     &lt;/port&gt;
-     *                 &lt;/actions&gt;
-     *                 &lt;priority&gt;1&lt;/priority&gt;
-     *                 &lt;idleTimeout&gt;0&lt;/idleTimeout&gt;
-     *                 &lt;hardTimeout&gt;0&lt;/hardTimeout&gt;
-     *                 &lt;id&gt;0&lt;/id&gt;
-     *             &lt;/flow&gt;
-     *             &lt;tableId&gt;0&lt;/tableId&gt;
-     *             &lt;durationSeconds&gt;337&lt;/durationSeconds&gt;
-     *             &lt;durationNanoseconds&gt;149000000&lt;/durationNanoseconds&gt;
-     *             &lt;packetCount&gt;0&lt;/packetCount&gt;
-     *             &lt;byteCount&gt;0&lt;/byteCount&gt;
-     *         &lt;/flowStatistic&gt;
-     *         &lt;flowStatistic&gt;
-     *             &lt;flow&gt;
-     *                 &lt;match&gt;
-     *                     &lt;matchField&gt;
-     *                         &lt;type&gt;DL_TYPE&lt;/type&gt;
-     *                         &lt;value&gt;2048&lt;/value&gt;
-     *                     &lt;/matchField&gt;
-     *                     &lt;matchField&gt;
-     *                         &lt;mask&gt;255.255.255.255&lt;/mask&gt;
-     *                         &lt;type&gt;NW_DST&lt;/type&gt;
-     *                         &lt;value&gt;1.1.1.1&lt;/value&gt;
-     *                     &lt;/matchField&gt;
-     *                 &lt;/match&gt;
-     *                 &lt;actions
-     *                     xmlns:xsi=&quot;http://www.w3.org/2001/XMLSchema-instance&quot; xsi:type=&quot;output&quot;&gt;
-     *                     &lt;port&gt;
-     *                         &lt;node&gt;
-     *                             &lt;id&gt;00:00:00:00:00:00:00:02&lt;/id&gt;
-     *                             &lt;type&gt;OF&lt;/type&gt;
-     *                         &lt;/node&gt;
-     *                         &lt;id&gt;3&lt;/id&gt;
-     *                         &lt;type&gt;OF&lt;/type&gt;
-     *                     &lt;/port&gt;
-     *                 &lt;/actions&gt;
-     *                 &lt;priority&gt;1&lt;/priority&gt;
-     *                 &lt;idleTimeout&gt;0&lt;/idleTimeout&gt;
-     *                 &lt;hardTimeout&gt;0&lt;/hardTimeout&gt;
-     *                 &lt;id&gt;0&lt;/id&gt;
-     *             &lt;/flow&gt;
-     *             &lt;tableId&gt;0&lt;/tableId&gt;
-     *             &lt;durationSeconds&gt;337&lt;/durationSeconds&gt;
-     *             &lt;durationNanoseconds&gt;208000000&lt;/durationNanoseconds&gt;
-     *             &lt;packetCount&gt;0&lt;/packetCount&gt;
-     *             &lt;byteCount&gt;0&lt;/byteCount&gt;
-     *         &lt;/flowStatistic&gt;
-     *     &lt;/nodeFlowStatistics&gt;
-     * </pre>
-     */
-    @Path("/{containerName}/flow/node/{nodeType}/{nodeId}")
-    @GET
-    @Produces({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @TypeHint(FlowStatistics.class)
-    @StatusCodes({
-        @ResponseCode(code = 200, condition = "Operation successful"),
-        @ResponseCode(code = 404, condition = "The containerName is not found"),
-        @ResponseCode(code = 503, condition = "One or more of Controller Services are unavailable") })
-    public FlowStatistics getFlowStatistics(
-            @PathParam("containerName") String containerName,
-            @PathParam("nodeType") String nodeType,
-            @PathParam("nodeId") String nodeId) {
-        if (!NorthboundUtils.isAuthorized(
-                getUserName(), containerName, Privilege.READ, this)) {
-            throw new UnauthorizedException(
-                    "User is not authorized to perform this operation on container "
-                            + containerName);
-        }
-        handleDefaultDisabled(containerName);
-
-        IStatisticsManager statisticsManager = getStatisticsService(containerName);
-        if (statisticsManager == null) {
-            throw new ServiceUnavailableException("Statistics "
-                    + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        ISwitchManager switchManager = (ISwitchManager) ServiceHelper
-                .getInstance(ISwitchManager.class, containerName, this);
-        if (switchManager == null) {
-            throw new ServiceUnavailableException("Switch manager "
-                    + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        Node node = handleNodeAvailability(containerName, nodeType, nodeId);
-        return new FlowStatistics(node, statisticsManager.getFlows(node));
-    }
-
-    /**
-     * Returns a list of all the Port Statistics across all the NodeConnectors
-     * on all the Nodes.
-     *
-     * @param containerName
-     *            Name of the Container. The Container name for the base
-     *            controller is "default".
-     * @return List of all the Port Statistics across all the NodeConnectors on
-     *         all the Nodes.
-     *
-     * <pre>
-     *
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/statistics/default/port
-     *
-     * Response body in JSON:
-     * {
-     *     "portStatistics": [
-     *         {
-     *             "node": {
-     *                  "id":"00:00:00:00:00:00:00:02",
-     *                  "type":"OF"
-     *             },
-     *             "portStatistic": [
-     *                 {
-     *                     "nodeConnector":{
-     *                          "node":{
-     *                                 "id":"00:00:00:00:00:00:00:02",
-     *                                 "type":"OF"
-     *                           },
-     *                           "id":"3",
-     *                           "type":"OF"
-     *                     },
-     *                     "receivePackets": "182",
-     *                     "transmitPackets": "173",
-     *                     "receiveBytes": "12740",
-     *                     "transmitBytes": "12110",
-     *                     "receiveDrops": "0",
-     *                     "transmitDrops": "0",
-     *                     "receiveErrors": "0",
-     *                     "transmitErrors": "0",
-     *                     "receiveFrameError": "0",
-     *                     "receiveOverRunError": "0",
-     *                     "receiveCrcError": "0",
-     *                     "collisionCount": "0"
-     *                 },
-     *                 {
-     *                     "nodeConnector": {
-     *                          "node":{
-     *                                  "id":"00:00:00:00:00:00:00:02",
-     *                                  "type":"OF"
-     *                           },
-     *                           "id":"2",
-     *                           "type":"OF"
-     *                     },
-     *                     "receivePackets": "174",
-     *                     "transmitPackets": "181",
-     *                     "receiveBytes": "12180",
-     *                     "transmitBytes": "12670",
-     *                     "receiveDrops": "0",
-     *                     "transmitDrops": "0",
-     *                     "receiveErrors": "0",
-     *                     "transmitErrors": "0",
-     *                     "receiveFrameError": "0",
-     *                     "receiveOverRunError": "0",
-     *                     "receiveCrcError": "0",
-     *                     "collisionCount": "0"
-     *                 },
-     *
-     *             ]
-     *         },
-     *         {
-     *             "node": {
-     *                  "id":"00:00:00:00:00:00:00:03",
-     *                  "type":"OF"
-     *             },
-     *             "portStatistic": [
-     *                  ..................
-     *                  .......................
-     *                  ..........................
-     *             ]
-     *         }
-     *     ]
-     * }
-     *
-     * Response body in XML:
-     * &lt;?xml version=&quot;1.0&quot; encoding=&quot;UTF-8&quot; standalone=&quot;yes&quot;?&gt;
-     * &lt;list&gt;
-     *     &lt;portStatistics&gt;
-     *          &lt;node&gt;
-     *             &lt;id&gt;00:00:00:00:00:00:00:02&lt;/id&gt;
-     *             &lt;type&gt;OF&lt;/type&gt;
-     *          &lt;/node&gt;
-     *          &lt;portStatistic&gt;
-     *             &lt;nodeConnector&gt;
-     *                &lt;node&gt;
-     *                   &lt;id&gt;00:00:00:00:00:00:00:02&lt;/id&gt;
-     *                   &lt;type&gt;OF&lt;/type&gt;
-     *                &lt;/node&gt;
-     *                &lt;id&gt;3&lt;/id&gt;
-     *                &lt;type&gt;OF&lt;/type&gt;
-     *             &lt;/nodeConnector&gt;
-     *             &lt;receivePackets&gt;181&lt;/receivePackets&gt;
-     *             &lt;transmitPackets&gt;172&lt;/transmitPackets&gt;
-     *             &lt;receiveBytes&gt;12670&lt;/receiveBytes&gt;
-     *             &lt;transmitBytes&gt;12040&lt;/transmitBytes&gt;
-     *             &lt;receiveDrops&gt;0&lt;/receiveDrops&gt;
-     *             &lt;transmitDrops&gt;0&lt;/transmitDrops&gt;
-     *             &lt;receiveErrors&gt;0&lt;/receiveErrors&gt;
-     *             &lt;transmitErrors&gt;0&lt;/transmitErrors&gt;
-     *             &lt;receiveFrameError&gt;0&lt;/receiveFrameError&gt;
-     *             &lt;receiveOverRunError&gt;0&lt;/receiveOverRunError&gt;
-     *             &lt;receiveCrcError&gt;0&lt;/receiveCrcError&gt;
-     *             &lt;collisionCount&gt;0&lt;/collisionCount&gt;
-     *         &lt;/portStatistic&gt;
-     *         &lt;portStatistic&gt;
-     *             &lt;nodeConnector&gt;
-     *                &lt;node&gt;
-     *                   &lt;id&gt;00:00:00:00:00:00:00:02&lt;/id&gt;
-     *                   &lt;type&gt;OF&lt;/type&gt;
-     *                &lt;/node&gt;
-     *                &lt;id&gt;2&lt;/id&gt;
-     *                &lt;type&gt;OF&lt;/type&gt;
-     *             &lt;/nodeConnector&gt;
-     *             &lt;receivePackets&gt;173&lt;/receivePackets&gt;
-     *             &lt;transmitPackets&gt;180&lt;/transmitPackets&gt;
-     *             &lt;receiveBytes&gt;12110&lt;/receiveBytes&gt;
-     *             &lt;transmitBytes&gt;12600&lt;/transmitBytes&gt;
-     *             &lt;receiveDrops&gt;0&lt;/receiveDrops&gt;
-     *             &lt;transmitDrops&gt;0&lt;/transmitDrops&gt;
-     *             &lt;receiveErrors&gt;0&lt;/receiveErrors&gt;
-     *             &lt;transmitErrors&gt;0&lt;/transmitErrors&gt;
-     *             &lt;receiveFrameError&gt;0&lt;/receiveFrameError&gt;
-     *             &lt;receiveOverRunError&gt;0&lt;/receiveOverRunError&gt;
-     *             &lt;receiveCrcError&gt;0&lt;/receiveCrcError&gt;
-     *             &lt;collisionCount&gt;0&lt;/collisionCount&gt;
-     *         &lt;/portStatistic&gt;
-     *     &lt;/portStatistics&gt;
-     * &lt;/list&gt;
-     * </pre>
-     */
-
-    @Path("/{containerName}/port")
-    @GET
-    @Produces({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @TypeHint(AllPortStatistics.class)
-    @StatusCodes({
-        @ResponseCode(code = 200, condition = "Operation successful"),
-        @ResponseCode(code = 404, condition = "The containerName is not found"),
-        @ResponseCode(code = 503, condition = "One or more of Controller Services are unavailable") })
-    public AllPortStatistics getPortStatistics(
-            @PathParam("containerName") String containerName,
-            @QueryParam("_q") String queryString) {
-
-        if (!NorthboundUtils.isAuthorized(
-                getUserName(), containerName, Privilege.READ, this)) {
-            throw new UnauthorizedException(
-                    "User is not authorized to perform this operation on container "
-                            + containerName);
-        }
-        IStatisticsManager statisticsManager = getStatisticsService(containerName);
-        if (statisticsManager == null) {
-            throw new ServiceUnavailableException("Statistics "
-                    + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        ISwitchManager switchManager = (ISwitchManager) ServiceHelper
-                .getInstance(ISwitchManager.class, containerName, this);
-        if (switchManager == null) {
-            throw new ServiceUnavailableException("Switch manager "
-                    + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        List<PortStatistics> statistics = new ArrayList<PortStatistics>();
-        for (Node node : switchManager.getNodes()) {
-            List<NodeConnectorStatistics> stat = statisticsManager
-                    .getNodeConnectorStatistics(node);
-            PortStatistics portStat = new PortStatistics(node, stat);
-            statistics.add(portStat);
-        }
-
-        AllPortStatistics result = new AllPortStatistics(statistics);
-        if (queryString != null) {
-            queryContext.createQuery(queryString, AllPortStatistics.class)
-                .filter(result, PortStatistics.class);
-        }
-        return result;
-    }
-
-    /**
-     * Returns a list of all the Port Statistics across all the NodeConnectors
-     * in a given Node.
-     *
-     * @param containerName
-     *            Name of the Container. The Container name for the base
-     *            controller is "default".
-     * @param nodeType
-     *            Node Type as specifid in {@link org.opendaylight.controller.sal.core.Node} class
-     * @param Node
-     *            Identifier (e.g. MAC address)
-     * @return Returns a list of all the Port Statistics across all the
-     *         NodeConnectors in a given Node.
-     *
-     * <pre>
-     *
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/statistics/default/port/node/OF/00:00:00:00:00:00:00:01
-     *
-     * Response body in JSON:
-     * {
-     *     "node": {
-     *         "id":"00:00:00:00:00:00:00:01",
-     *         "type":"OF"
-     *     },
-     *     "portStatistic": [
-     *         {
-     *             "nodeConnector": {
-     *                 "node":{
-     *                     "id":"00:00:00:00:00:00:00:01",
-     *                     "type":"OF"
-     *                 },
-     *                 "id":"3",
-     *                 "type":"OF"
-     *             },
-     *             "receivePackets": "171",
-     *             "transmitPackets": "2451",
-     *             "receiveBytes": "11970",
-     *             "transmitBytes": "235186",
-     *             "receiveDrops": "0",
-     *             "transmitDrops": "0",
-     *             "receiveErrors": "0",
-     *             "transmitErrors": "0",
-     *             "receiveFrameError": "0",
-     *             "receiveOverRunError": "0",
-     *             "receiveCrcError": "0",
-     *             "collisionCount": "0"
-     *         },
-     *         {
-     *             "nodeConnector": {
-     *                 "node":{
-     *                     "id":"00:00:00:00:00:00:00:01",
-     *                     "type":"OF"
-     *                 },
-     *                 "id":"2",
-     *                 "type":"OF"
-     *             },
-     *             "receivePackets": "179",
-     *             "transmitPackets": "2443",
-     *             "receiveBytes": "12530",
-     *             "transmitBytes": "234626",
-     *             "receiveDrops": "0",
-     *             "transmitDrops": "0",
-     *             "receiveErrors": "0",
-     *             "transmitErrors": "0",
-     *             "receiveFrameError": "0",
-     *             "receiveOverRunError": "0",
-     *             "receiveCrcError": "0",
-     *             "collisionCount": "0"
-     *         }
-     *     ]
-     * }
-     *
-     * Response body in XML:
-     * &lt;?xml version=&quot;1.0&quot; encoding=&quot;UTF-8&quot; standalone=&quot;yes&quot;?&gt;
-     * &lt;nodePortStatistics&gt;
-     *     &lt;node&gt;
-     *         &lt;id&gt;00:00:00:00:00:00:00:01&lt;/id&gt;
-     *         &lt;type&gt;OF&lt;/type&gt;
-     *     &lt;/node&gt;
-     *     &lt;portStatistic&gt;
-     *         &lt;nodeConnector&gt;
-     *             &lt;node&gt;
-     *                 &lt;id&gt;00:00:00:00:00:00:00:01&lt;/id&gt;
-     *                 &lt;type&gt;OF&lt;/type&gt;
-     *             &lt;/node&gt;
-     *             &lt;id&gt;2&lt;/id&gt;
-     *             &lt;type&gt;OF&lt;/type&gt;
-     *         &lt;/nodeConnector&gt;
-     *         &lt;receivePackets&gt;180&lt;/receivePackets&gt;
-     *         &lt;transmitPackets&gt;2594&lt;/transmitPackets&gt;
-     *         &lt;receiveBytes&gt;12600&lt;/receiveBytes&gt;
-     *         &lt;transmitBytes&gt;249396&lt;/transmitBytes&gt;
-     *         &lt;receiveDrops&gt;0&lt;/receiveDrops&gt;
-     *         &lt;transmitDrops&gt;0&lt;/transmitDrops&gt;
-     *         &lt;receiveErrors&gt;0&lt;/receiveErrors&gt;
-     *         &lt;transmitErrors&gt;0&lt;/transmitErrors&gt;
-     *         &lt;receiveFrameError&gt;0&lt;/receiveFrameError&gt;
-     *         &lt;receiveOverRunError&gt;0&lt;/receiveOverRunError&gt;
-     *         &lt;receiveCrcError&gt;0&lt;/receiveCrcError&gt;
-     *         &lt;collisionCount&gt;0&lt;/collisionCount&gt;
-     *     &lt;/portStatistic&gt;
-     *     &lt;portStatistic&gt;
-     *         &lt;nodeConnector&gt;
-     *             &lt;node&gt;
-     *                 &lt;id&gt;00:00:00:00:00:00:00:01&lt;/id&gt;
-     *                 &lt;type&gt;OF&lt;/type&gt;
-     *             &lt;/node&gt;
-     *             &lt;id&gt;5&lt;/id&gt;
-     *             &lt;type&gt;OF&lt;/type&gt;
-     *         &lt;/nodeConnector&gt;
-     *         &lt;receivePackets&gt;2542&lt;/receivePackets&gt;
-     *         &lt;transmitPackets&gt;2719&lt;/transmitPackets&gt;
-     *         &lt;receiveBytes&gt;243012&lt;/receiveBytes&gt;
-     *         &lt;transmitBytes&gt;255374&lt;/transmitBytes&gt;
-     *         &lt;receiveDrops&gt;0&lt;/receiveDrops&gt;
-     *         &lt;transmitDrops&gt;0&lt;/transmitDrops&gt;
-     *         &lt;receiveErrors&gt;0&lt;/receiveErrors&gt;
-     *         &lt;transmitErrors&gt;0&lt;/transmitErrors&gt;
-     *         &lt;receiveFrameError&gt;0&lt;/receiveFrameError&gt;
-     *         &lt;receiveOverRunError&gt;0&lt;/receiveOverRunError&gt;
-     *         &lt;receiveCrcError&gt;0&lt;/receiveCrcError&gt;
-     *         &lt;collisionCount&gt;0&lt;/collisionCount&gt;
-     *     &lt;/portStatistic&gt;
-     * &lt;/nodePortStatistics&gt;
-     * </pre>
-     */
-    @Path("/{containerName}/port/node/{nodeType}/{nodeId}")
-    @GET
-    @Produces({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @TypeHint(PortStatistics.class)
-    @StatusCodes({
-        @ResponseCode(code = 200, condition = "Operation successful"),
-        @ResponseCode(code = 404, condition = "The containerName is not found"),
-        @ResponseCode(code = 503, condition = "One or more of Controller Services are unavailable") })
-    public PortStatistics getPortStatistics(
-            @PathParam("containerName") String containerName,
-            @PathParam("nodeType") String nodeType,
-            @PathParam("nodeId") String nodeId) {
-
-        if (!NorthboundUtils.isAuthorized(
-                getUserName(), containerName, Privilege.READ, this)) {
-            throw new UnauthorizedException(
-                    "User is not authorized to perform this operation on container "
-                            + containerName);
-        }
-        handleDefaultDisabled(containerName);
-
-        IStatisticsManager statisticsManager = getStatisticsService(containerName);
-        if (statisticsManager == null) {
-            throw new ServiceUnavailableException("Statistics "
-                    + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        ISwitchManager switchManager = (ISwitchManager) ServiceHelper
-                .getInstance(ISwitchManager.class, containerName, this);
-        if (switchManager == null) {
-            throw new ServiceUnavailableException("Switch manager "
-                    + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        Node node = handleNodeAvailability(containerName, nodeType, nodeId);
-        return new PortStatistics(node,
-                statisticsManager.getNodeConnectorStatistics(node));
-    }
-
-    /**
-     * Returns a list of all the Table Statistics on all Nodes.
-     *
-     * @param containerName
-     *            Name of the Container. The Container name for the base
-     *            controller is "default".
-     *
-     * @return Returns a list of all the Table Statistics in a given Node.
-     *
-     * <pre>
-     *
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/statistics/default/table
-     *
-     * Response body in JSON:
-     * {
-     *     "tableStatistics": [
-     *         {
-     *             "node": {
-     *                 "id":"00:00:00:00:00:00:00:02",
-     *                 "type":"OF"
-     *             },
-     *             "tableStatistic": [
-     *                 {
-     *                     "nodeTable": {
-     *                        "node":{
-     *                           "id":"00:00:00:00:00:00:00:02",
-     *                           "type":"OF"
-     *                         },
-     *                         "id":"0"
-     *                     },
-     *                     "activeCount": "11",
-     *                     "lookupCount": "816",
-     *                     "matchedCount": "220",
-     *                     "maximumEntries": "1000"
-     *                 },
-     *                 {
-     *                     ...another table
-     *                     .....
-     *                     ........
-     *                 }
-     *
-     *             ]
-     *         }
-     *     ]
-     * }
-     *
-     *  Response body in XML:
-     *  &lt;?xml version=&quot;1.0&quot; encoding=&quot;UTF-8&quot; standalone=&quot;yes&quot;?&gt;
-     *  &lt;list&gt;
-     *  &lt;tableStatistics&gt;
-     *      &lt;node&gt;
-     *          &lt;id&gt;00:00:00:00:00:00:00:01&lt;/id&gt;
-     *          &lt;type&gt;OF&lt;/type&gt;
-     *      &lt;/node&gt;
-     *      &lt;tableStatistic&gt;
-     *          &lt;nodeTable&gt;
-     *              &lt;node&gt;
-     *                  &lt;id&gt;00:00:00:00:00:00:00:01&lt;/id&gt;
-     *                  &lt;type&gt;OF&lt;/type&gt;
-     *              &lt;/node&gt;
-     *              &lt;id&gt;0&lt;/id&gt;
-     *          &lt;/nodeTable&gt;
-     *          &lt;activeCount&gt;12&lt;/activeCount&gt;
-     *          &lt;lookupCount&gt;10935&lt;/lookupCount&gt;
-     *          &lt;matchedCount&gt;10084&lt;/matchedCount&gt;
-     *          &lt;maximumEntries&gt;1000&lt;/maximumEntries&gt;
-     *      &lt;/tableStatistic&gt;
-     *      &lt;tableStatistic&gt;
-     *          &lt;nodeTable&gt;
-     *              &lt;node&gt;
-     *                  &lt;id&gt;00:00:00:00:00:00:00:01&lt;/id&gt;
-     *                  &lt;type&gt;OF&lt;/type&gt;
-     *              &lt;/node&gt;
-     *              &lt;id&gt;1&lt;/id&gt;
-     *          &lt;/nodeTable&gt;
-     *          &lt;activeCount&gt;0&lt;/activeCount&gt;
-     *          &lt;lookupCount&gt;0&lt;/lookupCount&gt;
-     *          &lt;matchedCount&gt;0&lt;/matchedCount&gt;
-     *          &lt;maximumEntries&gt;0&lt;/maximumEntries&gt;
-     *      &lt;/tableStatistic&gt;
-     *      &lt;tableStatistic&gt;
-     *          &lt;nodeTable&gt;
-     *              &lt;node&gt;
-     *                  &lt;id&gt;00:00:00:00:00:00:00:01&lt;/id&gt;
-     *                  &lt;type&gt;OF&lt;/type&gt;
-     *              &lt;/node&gt;
-     *              &lt;id&gt;2&lt;/id&gt;
-     *          &lt;/nodeTable&gt;
-     *          &lt;activeCount&gt;0&lt;/activeCount&gt;
-     *          &lt;lookupCount&gt;0&lt;/lookupCount&gt;
-     *          &lt;matchedCount&gt;0&lt;/matchedCount&gt;
-     *          &lt;maximumEntries&gt;0&lt;/maximumEntries&gt;
-     *      &lt;/tableStatistic&gt;
-     *  &lt;/tableStatistics&gt;
-     *  &lt;tableStatistics&gt;
-     *  ...
-     *  ......
-     *  ........
-     *  &lt;/tableStatistics&gt;
-     *  &lt;/list&gt;
-     *
-     * </pre>
-     */
-    @Path("/{containerName}/table")
-    @GET
-    @Produces({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @TypeHint(AllTableStatistics.class)
-    @StatusCodes({
-        @ResponseCode(code = 200, condition = "Operation successful"),
-        @ResponseCode(code = 404, condition = "The containerName is not found"),
-        @ResponseCode(code = 503, condition = "One or more of Controller Services are unavailable") })
-    public AllTableStatistics getTableStatistics(
-            @PathParam("containerName") String containerName,
-            @QueryParam("_q") String queryString) {
-
-        if (!NorthboundUtils.isAuthorized(getUserName(), containerName, Privilege.READ, this)) {
-            throw new UnauthorizedException("User is not authorized to perform this operation on container "
-                    + containerName);
-        }
-        handleDefaultDisabled(containerName);
-
-        IStatisticsManager statisticsManager = getStatisticsService(containerName);
-        if (statisticsManager == null) {
-            throw new ServiceUnavailableException("Statistics manager"
-                    + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        ISwitchManager switchManager = (ISwitchManager) ServiceHelper
-                .getInstance(ISwitchManager.class, containerName, this);
-        if (switchManager == null) {
-            throw new ServiceUnavailableException("Switch manager "
-                    + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        List<TableStatistics> statistics = new ArrayList<TableStatistics>();
-        for (Node node : switchManager.getNodes()) {
-            List<NodeTableStatistics> stat = statisticsManager
-                    .getNodeTableStatistics(node);
-            TableStatistics tableStat = new TableStatistics(node, stat);
-            statistics.add(tableStat);
-        }
-        AllTableStatistics allstats = new AllTableStatistics(statistics);
-        if (queryString != null) {
-            queryContext.createQuery(queryString, AllTableStatistics.class)
-                .filter(allstats, TableStatistics.class);
-        }
-        return allstats;
-    }
-
-    /**
-     * Returns a list of all the Table Statistics on a specific node.
-     *
-     * @param containerName
-     *            Name of the Container. The Container name for the base
-     *            controller is "default".
-     * @param nodeType
-     *            Node Type as specified in {@link org.opendaylight.controller.sal.core.Node} class (e.g. OF for Openflow)
-     * @param Node
-     *            Identifier (e.g. MAC address)
-     * @return Returns a list of all the Table Statistics in a given Node.
-     *
-     * <pre>
-     *
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/statistics/default/table/node/OF/00:00:00:00:00:00:00:01
-     *
-     * Response body in JSON:
-     * {
-     *     "node": {
-     *         "id":"00:00:00:00:00:00:00:01",
-     *         "type":"OF"
-     *     },
-     *     "tableStatistic": [
-     *         {
-     *             "nodeTable": {
-     *                 "node":{
-     *                     "id":"00:00:00:00:00:00:00:01",
-     *                     "type":"OF"
-     *                 },
-     *                 "id":"0"
-     *             },
-     *             "activeCount": "12",
-     *             "lookupCount": "11382",
-     *             "matchedCount": "10524",
-     *             "maximumEntries": "1000"
-     *         },
-     *         {
-     *             "nodeTable": {
-     *                 "node":{
-     *                     "id":"00:00:00:00:00:00:00:01",
-     *                     "type":"OF"
-     *                 },
-     *                 "id":"1"
-     *             },
-     *             "activeCount": "0",
-     *             "lookupCount": "0",
-     *             "matchedCount": "0",
-     *             "maximumEntries": "0"
-     *         }
-     *    ]
-     * }
-     *
-     * Response body in XML:
-     * &lt;?xml version=&quot;1.0&quot; encoding=&quot;UTF-8&quot; standalone=&quot;yes&quot;?&gt;
-     * &lt;nodeTableStatistics&gt;
-     *     &lt;node&gt;
-     *          &lt;id&gt;00:00:00:00:00:00:00:01&lt;/id&gt;
-     *          &lt;type&gt;OF&lt;/type&gt;
-     *     &lt;/node&gt;
-     *     &lt;tableStatistic&gt;
-     *         &lt;nodeTable&gt;
-     *             &lt;node&gt;
-     *                 &lt;id&gt;00:00:00:00:00:00:00:01&lt;/id&gt;
-     *                 &lt;type&gt;OF&lt;/type&gt;
-     *             &lt;/node&gt;
-     *             &lt;id&gt;0&lt;/id&gt;
-     *         &lt;/nodeTable&gt;
-     *         &lt;activeCount&gt;12&lt;/activeCount&gt;
-     *         &lt;lookupCount&gt;10935&lt;/lookupCount&gt;
-     *         &lt;matchedCount&gt;10084&lt;/matchedCount&gt;
-     *         &lt;maximumEntries&gt;1000&lt;/maximumEntries&gt;
-     *     &lt;/tableStatistic&gt;
-     *     &lt;tableStatistic&gt;
-     *         &lt;nodeTable&gt;
-     *             &lt;node&gt;
-     *                 &lt;id&gt;00:00:00:00:00:00:00:01&lt;/id&gt;
-     *                 &lt;type&gt;OF&lt;/type&gt;
-     *             &lt;/node&gt;
-     *             &lt;id&gt;1&lt;/id&gt;
-     *         &lt;/nodeTable&gt;
-     *         &lt;activeCount&gt;0&lt;/activeCount&gt;
-     *         &lt;lookupCount&gt;0&lt;/lookupCount&gt;
-     *         &lt;matchedCount&gt;0&lt;/matchedCount&gt;
-     *         &lt;maximumEntries&gt;0&lt;/maximumEntries&gt;
-     *     &lt;/tableStatistic&gt;
-     *     &lt;tableStatistic&gt;
-     *         &lt;nodeTable&gt;
-     *             &lt;node&gt;
-     *                 &lt;id&gt;00:00:00:00:00:00:00:01&lt;/id&gt;
-     *                 &lt;type&gt;OF&lt;/type&gt;
-     *             &lt;/node&gt;
-     *             &lt;id&gt;2&lt;/id&gt;
-     *         &lt;/nodeTable&gt;
-     *         &lt;activeCount&gt;0&lt;/activeCount&gt;
-     *         &lt;lookupCount&gt;0&lt;/lookupCount&gt;
-     *         &lt;matchedCount&gt;0&lt;/matchedCount&gt;
-     *         &lt;maximumEntries&gt;0&lt;/maximumEntries&gt;
-     *     &lt;/tableStatistic&gt;
-     * &lt;/nodeTableStatistics&gt;
-     *
-     * </pre>
-     */
-    @Path("/{containerName}/table/node/{nodeType}/{nodeId}")
-    @GET
-    @Produces({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @TypeHint(TableStatistics.class)
-    @StatusCodes({
-        @ResponseCode(code = 200, condition = "Operation successful"),
-        @ResponseCode(code = 404, condition = "The containerName is not found"),
-        @ResponseCode(code = 503, condition = "One or more of Controller Services are unavailable") })
-    public TableStatistics getTableStatistics(
-            @PathParam("containerName") String containerName,
-            @PathParam("nodeType") String nodeType,
-            @PathParam("nodeId") String nodeId) {
-
-        if (!NorthboundUtils.isAuthorized(
-                getUserName(), containerName, Privilege.READ, this)) {
-            throw new UnauthorizedException(
-                    "User is not authorized to perform this operation on container "
-                            + containerName);
-        }
-        handleDefaultDisabled(containerName);
-
-        IStatisticsManager statisticsManager = getStatisticsService(containerName);
-        if (statisticsManager == null) {
-            throw new ServiceUnavailableException("Statistics "
-                    + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        ISwitchManager switchManager = (ISwitchManager) ServiceHelper
-                .getInstance(ISwitchManager.class, containerName, this);
-        if (switchManager == null) {
-            throw new ServiceUnavailableException("Switch manager "
-                    + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        Node node = handleNodeAvailability(containerName, nodeType, nodeId);
-        return new TableStatistics(node,
-                statisticsManager.getNodeTableStatistics(node));
-    }
-
-    private void handleDefaultDisabled(String containerName) {
-        IContainerManager containerManager = (IContainerManager) ServiceHelper
-                .getGlobalInstance(IContainerManager.class, this);
-        if (containerManager == null) {
-            throw new InternalServerErrorException(
-                    RestMessages.INTERNALERROR.toString());
-        }
-        if (containerName.equals(GlobalConstants.DEFAULT.toString())
-                && containerManager.hasNonDefaultContainer()) {
-            throw new ResourceConflictException(
-                    RestMessages.DEFAULTDISABLED.toString());
-        }
-    }
-
-    private Node handleNodeAvailability(String containerName, String nodeType,
-            String nodeId) {
-
-        Node node = Node.fromString(nodeType, nodeId);
-        if (node == null) {
-            throw new ResourceNotFoundException(nodeId + " : "
-                    + RestMessages.NONODE.toString());
-        }
-
-        ISwitchManager sm = (ISwitchManager) ServiceHelper.getInstance(
-                ISwitchManager.class, containerName, this);
-
-        if (sm == null) {
-            throw new ServiceUnavailableException("Switch Manager "
-                    + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        if (!sm.getNodes().contains(node)) {
-            throw new ResourceNotFoundException(node.toString() + " : "
-                    + RestMessages.NONODE.toString());
-        }
-        return node;
-    }
-
-}
diff --git a/opendaylight/adsal/northbound/statistics/src/main/java/org/opendaylight/controller/statistics/northbound/TableStatistics.java b/opendaylight/adsal/northbound/statistics/src/main/java/org/opendaylight/controller/statistics/northbound/TableStatistics.java
deleted file mode 100644 (file)
index 552e707..0000000
+++ /dev/null
@@ -1,56 +0,0 @@
-/*
- * Copyright (c) 2013 Big Switch Networks, Inc.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.statistics.northbound;
-
-import java.util.List;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.reader.NodeTableStatistics;
-
-@XmlRootElement(name = "nodeTableStatistics")
-@XmlAccessorType(XmlAccessType.NONE)
-public class TableStatistics {
-    @XmlElement
-    private Node node;
-    @XmlElement
-    private List<NodeTableStatistics> tableStatistic;
-
-    // To satisfy JAXB
-    @SuppressWarnings("unused")
-    private TableStatistics() {
-    }
-
-    public TableStatistics(Node node, List<NodeTableStatistics> tableStats) {
-        super();
-        this.node = node;
-        this.tableStatistic = tableStats;
-    }
-
-    public Node getNode() {
-        return node;
-    }
-
-    public void setNode(Node node) {
-        this.node = node;
-    }
-
-    public List<NodeTableStatistics> getTableStats() {
-        return tableStatistic;
-    }
-
-    public void setTableStats(List<NodeTableStatistics> tableStats) {
-        this.tableStatistic = tableStats;
-    }
-
-}
diff --git a/opendaylight/adsal/northbound/statistics/src/main/resources/META-INF/spring.factories b/opendaylight/adsal/northbound/statistics/src/main/resources/META-INF/spring.factories
deleted file mode 100644 (file)
index 93db02e..0000000
+++ /dev/null
@@ -1 +0,0 @@
-org.springframework.beans.BeanInfoFactory=org.springframework.beans.ExtendedBeanInfoFactory
diff --git a/opendaylight/adsal/northbound/statistics/src/main/resources/META-INF/spring.handlers b/opendaylight/adsal/northbound/statistics/src/main/resources/META-INF/spring.handlers
deleted file mode 100644 (file)
index 957af91..0000000
+++ /dev/null
@@ -1,10 +0,0 @@
-http\://www.springframework.org/schema/context=org.springframework.context.config.ContextNamespaceHandler
-http\://www.springframework.org/schema/jee=org.springframework.ejb.config.JeeNamespaceHandler
-http\://www.springframework.org/schema/lang=org.springframework.scripting.config.LangNamespaceHandler
-http\://www.springframework.org/schema/task=org.springframework.scheduling.config.TaskNamespaceHandler
-http\://www.springframework.org/schema/cache=org.springframework.cache.config.CacheNamespaceHandler
-http\://www.springframework.org/schema/c=org.springframework.beans.factory.xml.SimpleConstructorNamespaceHandler
-http\://www.springframework.org/schema/p=org.springframework.beans.factory.xml.SimplePropertyNamespaceHandler
-http\://www.springframework.org/schema/util=org.springframework.beans.factory.xml.UtilNamespaceHandler
-http\://www.springframework.org/schema/mvc=org.springframework.web.servlet.config.MvcNamespaceHandler
-http\://www.springframework.org/schema/security=org.springframework.security.config.SecurityNamespaceHandler
diff --git a/opendaylight/adsal/northbound/statistics/src/main/resources/META-INF/spring.schemas b/opendaylight/adsal/northbound/statistics/src/main/resources/META-INF/spring.schemas
deleted file mode 100644 (file)
index d865edc..0000000
+++ /dev/null
@@ -1,49 +0,0 @@
-http\://www.springframework.org/schema/beans/spring-beans-2.0.xsd=org/springframework/beans/factory/xml/spring-beans-2.0.xsd
-http\://www.springframework.org/schema/beans/spring-beans-2.5.xsd=org/springframework/beans/factory/xml/spring-beans-2.5.xsd
-http\://www.springframework.org/schema/beans/spring-beans-3.0.xsd=org/springframework/beans/factory/xml/spring-beans-3.0.xsd
-http\://www.springframework.org/schema/beans/spring-beans-3.1.xsd=org/springframework/beans/factory/xml/spring-beans-3.1.xsd
-http\://www.springframework.org/schema/beans/spring-beans-3.2.xsd=org/springframework/beans/factory/xml/spring-beans-3.2.xsd
-http\://www.springframework.org/schema/beans/spring-beans.xsd=org/springframework/beans/factory/xml/spring-beans-3.2.xsd
-http\://www.springframework.org/schema/tool/spring-tool-2.0.xsd=org/springframework/beans/factory/xml/spring-tool-2.0.xsd
-http\://www.springframework.org/schema/tool/spring-tool-2.5.xsd=org/springframework/beans/factory/xml/spring-tool-2.5.xsd
-http\://www.springframework.org/schema/tool/spring-tool-3.0.xsd=org/springframework/beans/factory/xml/spring-tool-3.0.xsd
-http\://www.springframework.org/schema/tool/spring-tool-3.1.xsd=org/springframework/beans/factory/xml/spring-tool-3.1.xsd
-http\://www.springframework.org/schema/tool/spring-tool-3.2.xsd=org/springframework/beans/factory/xml/spring-tool-3.2.xsd
-http\://www.springframework.org/schema/tool/spring-tool.xsd=org/springframework/beans/factory/xml/spring-tool-3.2.xsd
-http\://www.springframework.org/schema/util/spring-util-2.0.xsd=org/springframework/beans/factory/xml/spring-util-2.0.xsd
-http\://www.springframework.org/schema/util/spring-util-2.5.xsd=org/springframework/beans/factory/xml/spring-util-2.5.xsd
-http\://www.springframework.org/schema/util/spring-util-3.0.xsd=org/springframework/beans/factory/xml/spring-util-3.0.xsd
-http\://www.springframework.org/schema/util/spring-util-3.1.xsd=org/springframework/beans/factory/xml/spring-util-3.1.xsd
-http\://www.springframework.org/schema/util/spring-util-3.2.xsd=org/springframework/beans/factory/xml/spring-util-3.2.xsd
-http\://www.springframework.org/schema/util/spring-util.xsd=org/springframework/beans/factory/xml/spring-util-3.2.xsd
-http\://www.springframework.org/schema/context/spring-context-2.5.xsd=org/springframework/context/config/spring-context-2.5.xsd
-http\://www.springframework.org/schema/context/spring-context-3.0.xsd=org/springframework/context/config/spring-context-3.0.xsd
-http\://www.springframework.org/schema/context/spring-context-3.1.xsd=org/springframework/context/config/spring-context-3.1.xsd
-http\://www.springframework.org/schema/context/spring-context-3.2.xsd=org/springframework/context/config/spring-context-3.2.xsd
-http\://www.springframework.org/schema/context/spring-context.xsd=org/springframework/context/config/spring-context-3.2.xsd
-http\://www.springframework.org/schema/jee/spring-jee-2.0.xsd=org/springframework/ejb/config/spring-jee-2.0.xsd
-http\://www.springframework.org/schema/jee/spring-jee-2.5.xsd=org/springframework/ejb/config/spring-jee-2.5.xsd
-http\://www.springframework.org/schema/jee/spring-jee-3.0.xsd=org/springframework/ejb/config/spring-jee-3.0.xsd
-http\://www.springframework.org/schema/jee/spring-jee-3.1.xsd=org/springframework/ejb/config/spring-jee-3.1.xsd
-http\://www.springframework.org/schema/jee/spring-jee-3.2.xsd=org/springframework/ejb/config/spring-jee-3.2.xsd
-http\://www.springframework.org/schema/jee/spring-jee.xsd=org/springframework/ejb/config/spring-jee-3.2.xsd
-http\://www.springframework.org/schema/lang/spring-lang-2.0.xsd=org/springframework/scripting/config/spring-lang-2.0.xsd
-http\://www.springframework.org/schema/lang/spring-lang-2.5.xsd=org/springframework/scripting/config/spring-lang-2.5.xsd
-http\://www.springframework.org/schema/lang/spring-lang-3.0.xsd=org/springframework/scripting/config/spring-lang-3.0.xsd
-http\://www.springframework.org/schema/lang/spring-lang-3.1.xsd=org/springframework/scripting/config/spring-lang-3.1.xsd
-http\://www.springframework.org/schema/lang/spring-lang-3.2.xsd=org/springframework/scripting/config/spring-lang-3.2.xsd
-http\://www.springframework.org/schema/lang/spring-lang.xsd=org/springframework/scripting/config/spring-lang-3.2.xsd
-http\://www.springframework.org/schema/task/spring-task-3.0.xsd=org/springframework/scheduling/config/spring-task-3.0.xsd
-http\://www.springframework.org/schema/task/spring-task-3.1.xsd=org/springframework/scheduling/config/spring-task-3.1.xsd
-http\://www.springframework.org/schema/task/spring-task-3.2.xsd=org/springframework/scheduling/config/spring-task-3.2.xsd
-http\://www.springframework.org/schema/task/spring-task.xsd=org/springframework/scheduling/config/spring-task-3.2.xsd
-http\://www.springframework.org/schema/cache/spring-cache-3.1.xsd=org/springframework/cache/config/spring-cache-3.1.xsd
-http\://www.springframework.org/schema/cache/spring-cache-3.2.xsd=org/springframework/cache/config/spring-cache-3.2.xsd
-http\://www.springframework.org/schema/cache/spring-cache.xsd=org/springframework/cache/config/spring-cache-3.2.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd=org/springframework/web/servlet/config/spring-mvc-3.0.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc-3.1.xsd=org/springframework/web/servlet/config/spring-mvc-3.1.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc-3.2.xsd=org/springframework/web/servlet/config/spring-mvc-3.2.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc.xsd=org/springframework/web/servlet/config/spring-mvc-3.2.xsd
-http\://www.springframework.org/schema/security/spring-security-3.1.xsd=org/springframework/security/config/spring-security-3.1.xsd
-http\://www.springframework.org/schema/security/spring-security-3.2.xsd=org/springframework/security/config/spring-security-3.2.xsd
-
diff --git a/opendaylight/adsal/northbound/statistics/src/main/resources/META-INF/spring.tooling b/opendaylight/adsal/northbound/statistics/src/main/resources/META-INF/spring.tooling
deleted file mode 100644 (file)
index 057d834..0000000
+++ /dev/null
@@ -1,39 +0,0 @@
-# Tooling related information for the beans namespace
-http\://www.springframework.org/schema/beans@name=beans Namespace
-http\://www.springframework.org/schema/beans@prefix=beans
-http\://www.springframework.org/schema/beans@icon=org/springframework/beans/factory/xml/spring-beans.gif
-
-# Tooling related information for the util namespace
-http\://www.springframework.org/schema/util@name=util Namespace
-http\://www.springframework.org/schema/util@prefix=util
-http\://www.springframework.org/schema/util@icon=org/springframework/beans/factory/xml/spring-util.gif
-
-# Tooling related information for the context namespace
-http\://www.springframework.org/schema/context@name=context Namespace
-http\://www.springframework.org/schema/context@prefix=context
-http\://www.springframework.org/schema/context@icon=org/springframework/context/config/spring-context.gif
-
-# Tooling related information for the jee namespace
-http\://www.springframework.org/schema/jee@name=jee Namespace
-http\://www.springframework.org/schema/jee@prefix=jee
-http\://www.springframework.org/schema/jee@icon=org/springframework/ejb/config/spring-jee.gif
-
-# Tooling related information for the scheduling namespace
-http\://www.springframework.org/schema/task@name=task Namespace
-http\://www.springframework.org/schema/task@prefix=task
-http\://www.springframework.org/schema/task@icon=org/springframework/scheduling/config/spring-task.gif
-
-# Tooling related information for the lang namespace
-http\://www.springframework.org/schema/lang@name=lang Namespace
-http\://www.springframework.org/schema/lang@prefix=lang
-http\://www.springframework.org/schema/lang@icon=org/springframework/scripting/config/spring-lang.gif
-
-# Tooling related information for the cache namespace
-http\://www.springframework.org/schema/cache@name=cache Namespace
-http\://www.springframework.org/schema/cache@prefix=cache
-http\://www.springframework.org/schema/cache@icon=org/springframework/cache/config/spring-cache.gif
-
-# Tooling related information for the mvc namespace
-http\://www.springframework.org/schema/mvc@name=mvc Namespace
-http\://www.springframework.org/schema/mvc@prefix=mvc
-http\://www.springframework.org/schema/mvc@icon=org/springframework/web/servlet/config/spring-mvc.gif
diff --git a/opendaylight/adsal/northbound/statistics/src/main/resources/WEB-INF/web.xml b/opendaylight/adsal/northbound/statistics/src/main/resources/WEB-INF/web.xml
deleted file mode 100644 (file)
index 3fa41fe..0000000
+++ /dev/null
@@ -1,89 +0,0 @@
-<?xml version="1.0" encoding="ISO-8859-1"?>
-<web-app xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
-        xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
-        version="3.0">
-  <servlet>
-    <servlet-name>JAXRSStatistics</servlet-name>
-    <servlet-class>com.sun.jersey.spi.container.servlet.ServletContainer</servlet-class>
-    <init-param>
-      <param-name>javax.ws.rs.Application</param-name>
-      <param-value>org.opendaylight.controller.northbound.commons.NorthboundApplication</param-value>
-    </init-param>
-    <load-on-startup>1</load-on-startup>
-  </servlet>
-
-  <servlet-mapping>
-    <servlet-name>JAXRSStatistics</servlet-name>
-    <url-pattern>/*</url-pattern>
-  </servlet-mapping>
-
-        <filter>
-          <filter-name>CorsFilter</filter-name>
-          <filter-class>org.apache.catalina.filters.CorsFilter</filter-class>
-          <init-param>
-            <param-name>cors.allowed.origins</param-name>
-            <param-value>*</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.allowed.methods</param-name>
-            <param-value>GET,POST,HEAD,OPTIONS,PUT,DELETE</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.allowed.headers</param-name>
-            <param-value>Content-Type,X-Requested-With,accept,authorization, origin,Origin,Access-Control-Request-Method,Access-Control-Request-Headers</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.exposed.headers</param-name>
-            <param-value>Access-Control-Allow-Origin,Access-Control-Allow-Credentials</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.support.credentials</param-name>
-            <param-value>true</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.preflight.maxage</param-name>
-            <param-value>10</param-value>
-          </init-param>
-        </filter>
-        <filter-mapping>
-          <filter-name>CorsFilter</filter-name>
-          <url-pattern>/*</url-pattern>
-        </filter-mapping>
-
-        <security-constraint>
-          <web-resource-collection>
-            <web-resource-name>NB api</web-resource-name>
-            <url-pattern>/*</url-pattern>
-            <http-method>POST</http-method>
-            <http-method>GET</http-method>
-            <http-method>PUT</http-method>
-            <http-method>PATCH</http-method>
-            <http-method>DELETE</http-method>
-            <http-method>HEAD</http-method>
-          </web-resource-collection>
-          <auth-constraint>
-            <role-name>System-Admin</role-name>
-            <role-name>Network-Admin</role-name>
-            <role-name>Network-Operator</role-name>
-            <role-name>Container-User</role-name>
-          </auth-constraint>
-        </security-constraint>
-
-        <security-role>
-                <role-name>System-Admin</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Network-Admin</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Network-Operator</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Container-User</role-name>
-        </security-role>
-
-        <login-config>
-                <auth-method>BASIC</auth-method>
-                <realm-name>opendaylight</realm-name>
-        </login-config>
-</web-app>
\ No newline at end of file
diff --git a/opendaylight/adsal/northbound/statistics/src/test/java/org/opendaylight/controller/statistics/northbound/StatisticsNorthboundTest.java b/opendaylight/adsal/northbound/statistics/src/test/java/org/opendaylight/controller/statistics/northbound/StatisticsNorthboundTest.java
deleted file mode 100644 (file)
index d09ff04..0000000
+++ /dev/null
@@ -1,99 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.statistics.northbound;
-
-import java.util.ArrayList;
-import java.util.List;
-
-import org.junit.Assert;
-import org.junit.Test;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.reader.FlowOnNode;
-import org.opendaylight.controller.sal.reader.NodeConnectorStatistics;
-import org.opendaylight.controller.sal.reader.NodeTableStatistics;
-import org.opendaylight.controller.sal.utils.NodeCreator;
-
-public class StatisticsNorthboundTest {
-
-    @Test
-    public void testFlowStatistics() {
-        List<FlowOnNode> fon = new ArrayList<FlowOnNode>();
-        Node node = NodeCreator.createOFNode(1L);
-        FlowStatistics fs = new FlowStatistics(node, fon);
-        Assert.assertTrue(fs.getNode().equals(node));
-        Assert.assertTrue(fs.getFlowStats().equals(fon));
-
-        Node node2 = NodeCreator.createOFNode(2L);
-        fs.setNode(node2);
-        Assert.assertTrue(fs.getNode().equals(node2));
-        fs.setNode(node2);
-        Assert.assertTrue(fs.getNode().equals(node2));
-        fs.setFlowStats(null);
-        Assert.assertTrue(fs.getFlowStats() == null);
-    }
-
-    @Test
-    public void testAllFlowStatistics() {
-        List<FlowStatistics> fs = new ArrayList<FlowStatistics>();
-        AllFlowStatistics afs = new AllFlowStatistics(fs);
-        Assert.assertTrue(afs.getFlowStatistics().equals(fs));
-        afs.setFlowStatistics(null);
-        Assert.assertTrue(afs.getFlowStatistics() == null);
-    }
-
-    @Test
-    public void testPortStatistics() {
-        List<NodeConnectorStatistics> ncs = new ArrayList<NodeConnectorStatistics>();
-        Node node = NodeCreator.createOFNode(1L);
-        PortStatistics ps = new PortStatistics(node, ncs);
-
-        Assert.assertTrue(ps.getNode().equals(node));
-        Assert.assertTrue(ps.getPortStats().equals(ncs));
-        Node node2 = NodeCreator.createOFNode(2L);
-        ps.setNode(node2);
-        Assert.assertTrue(ps.getNode().equals(node2));
-        ps.setFlowStats(null);
-        Assert.assertTrue(ps.getPortStats() == null);
-    }
-
-    @Test
-    public void testAllPortStatistics() {
-        List<PortStatistics> ps = new ArrayList<PortStatistics>();
-        AllPortStatistics aps = new AllPortStatistics(ps);
-        Assert.assertTrue(aps.getPortStatistics().equals(ps));
-        aps.setPortStatistics(null);
-        Assert.assertTrue(aps.getPortStatistics() == null);
-    }
-
-    @Test
-    public void testTableStatistics() {
-        List<NodeTableStatistics> nts = new ArrayList<NodeTableStatistics>();
-        Node node = NodeCreator.createOFNode(1L);
-        TableStatistics ts = new TableStatistics(node, nts);
-
-        Assert.assertTrue(ts.getNode().equals(node));
-        Assert.assertTrue(ts.getTableStats().equals(nts));
-        Node node2 = NodeCreator.createOFNode(2L);
-        ts.setNode(node2);
-        Assert.assertTrue(ts.getNode().equals(node2));
-        ts.setTableStats(null);
-        Assert.assertTrue(ts.getTableStats() == null);
-    }
-
-    @Test
-    public void testAllTableStatistics() {
-        List<TableStatistics> ts = new ArrayList<TableStatistics>();
-        AllTableStatistics ats = new AllTableStatistics(ts);
-        Assert.assertTrue(ats.getTableStatistics().equals(ts));
-        ats.setTableStatistics(null);
-        Assert.assertTrue(ats.getTableStatistics() == null);
-    }
-
-}
diff --git a/opendaylight/adsal/northbound/subnets/enunciate.xml b/opendaylight/adsal/northbound/subnets/enunciate.xml
deleted file mode 100644 (file)
index e75daf9..0000000
+++ /dev/null
@@ -1,12 +0,0 @@
-<?xml version="1.0"?>
-<enunciate label="full" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
-    xsi:noNamespaceSchemaLocation="http://enunciate.codehaus.org/schemas/enunciate-1.28.xsd">
-
-  <services>
-    <rest defaultRestSubcontext="/controller/nb/v2/subnetservice"/>
-  </services>
-
-  <modules>
-    <docs docsDir="rest" title="Subnet Service REST API" includeExampleXml="true" includeExampleJson="true"/>
-  </modules>
-</enunciate>
diff --git a/opendaylight/adsal/northbound/subnets/pom.xml b/opendaylight/adsal/northbound/subnets/pom.xml
deleted file mode 100644 (file)
index 5c3228b..0000000
+++ /dev/null
@@ -1,116 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>adsal-enunciate-parent</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../adsal-enunciate-parent</relativePath>
-  </parent>
-
-  <artifactId>subnets.northbound</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>org.codehaus.enunciate</groupId>
-      <artifactId>enunciate-core-annotations</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>commons.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>containermanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>switchmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-      <scope>test</scope>
-    </dependency>
-  </dependencies>
-  <build>
-    <pluginManagement>
-      <plugins>
-        <plugin>
-          <groupId>org.codehaus.enunciate</groupId>
-          <artifactId>maven-enunciate-plugin</artifactId>
-          <dependencies>
-            <dependency>
-              <groupId>org.opendaylight.controller</groupId>
-              <artifactId>clustering.services</artifactId>
-              <version>${clustering.services.version}</version>
-            </dependency>
-            <dependency>
-              <groupId>org.opendaylight.controller</groupId>
-              <artifactId>configuration</artifactId>
-              <version>${configuration.version}</version>
-            </dependency>
-            <dependency>
-              <groupId>org.opendaylight.controller</groupId>
-              <artifactId>sal</artifactId>
-              <version>${sal.version}</version>
-            </dependency>
-            <dependency>
-              <groupId>org.opendaylight.controller</groupId>
-              <artifactId>switchmanager</artifactId>
-              <version>${switchmanager.api.version}</version>
-            </dependency>
-          </dependencies>
-        </plugin>
-      </plugins>
-    </pluginManagement>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Export-Package></Export-Package>
-            <Import-Package>org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.sal.utils,
-              org.opendaylight.controller.containermanager,
-              org.opendaylight.controller.switchmanager,
-              org.opendaylight.controller.northbound.commons,
-              org.opendaylight.controller.northbound.commons.exception,
-              org.opendaylight.controller.northbound.commons.query,
-              org.opendaylight.controller.northbound.commons.utils,
-              com.sun.jersey.spi.container.servlet,
-              org.opendaylight.controller.sal.authorization,
-              org.opendaylight.controller.usermanager,
-              javax.ws.rs,
-              javax.ws.rs.core,
-              javax.ws.rs.ext,
-              javax.xml.bind,
-              javax.xml.bind.annotation,
-              org.slf4j,
-              org.apache.catalina.filters,
-              com.fasterxml.jackson.jaxrs.base,
-              com.fasterxml.jackson.jaxrs.json,
-              !org.codehaus.enunciate.jaxrs</Import-Package>
-            <Export-Package></Export-Package>
-            <Web-ContextPath>/controller/nb/v2/subnetservice</Web-ContextPath>
-            <Jaxrs-Resources>,${classes;ANNOTATION;javax.ws.rs.Path}</Jaxrs-Resources>
-          </instructions>
-          <manifestLocation>${project.basedir}/src/main/resources/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/northbound/subnets/src/main/java/org/opendaylight/controller/subnets/northbound/SubnetConfigs.java b/opendaylight/adsal/northbound/subnets/src/main/java/org/opendaylight/controller/subnets/northbound/SubnetConfigs.java
deleted file mode 100644 (file)
index 31dd76f..0000000
+++ /dev/null
@@ -1,43 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.subnets.northbound;
-
-import java.util.List;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.switchmanager.SubnetConfig;
-
-@XmlRootElement (name = "list")
-@XmlAccessorType(XmlAccessType.NONE)
-
-public class SubnetConfigs {
-        @XmlElement
-        List<SubnetConfig> subnetConfig;
-        //To satisfy JAXB
-        @SuppressWarnings("unused")
-        private SubnetConfigs() {
-
-        }
-
-        public SubnetConfigs(List<SubnetConfig> subnetConfig) {
-                this.subnetConfig = subnetConfig;
-        }
-
-        public List<SubnetConfig> getSubnetConfig() {
-                return subnetConfig;
-        }
-
-        public void setSubnetConfig(List<SubnetConfig> subnetConfig) {
-                this.subnetConfig = subnetConfig;
-        }
-}
diff --git a/opendaylight/adsal/northbound/subnets/src/main/java/org/opendaylight/controller/subnets/northbound/SubnetsNorthbound.java b/opendaylight/adsal/northbound/subnets/src/main/java/org/opendaylight/controller/subnets/northbound/SubnetsNorthbound.java
deleted file mode 100644 (file)
index b627479..0000000
+++ /dev/null
@@ -1,498 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.subnets.northbound;
-
-import java.util.HashSet;
-import java.util.List;
-import java.util.Set;
-
-import javax.ws.rs.Consumes;
-import javax.ws.rs.DELETE;
-import javax.ws.rs.GET;
-import javax.ws.rs.POST;
-import javax.ws.rs.PUT;
-import javax.ws.rs.Path;
-import javax.ws.rs.PathParam;
-import javax.ws.rs.Produces;
-import javax.ws.rs.QueryParam;
-import javax.ws.rs.core.Context;
-import javax.ws.rs.core.MediaType;
-import javax.ws.rs.core.Response;
-import javax.ws.rs.core.SecurityContext;
-import javax.ws.rs.core.UriInfo;
-import javax.ws.rs.ext.ContextResolver;
-
-import org.codehaus.enunciate.jaxrs.ResponseCode;
-import org.codehaus.enunciate.jaxrs.StatusCodes;
-import org.codehaus.enunciate.jaxrs.TypeHint;
-import org.opendaylight.controller.containermanager.IContainerManager;
-import org.opendaylight.controller.northbound.commons.RestMessages;
-import org.opendaylight.controller.northbound.commons.exception.BadRequestException;
-import org.opendaylight.controller.northbound.commons.exception.ResourceConflictException;
-import org.opendaylight.controller.northbound.commons.exception.ResourceNotFoundException;
-import org.opendaylight.controller.northbound.commons.exception.ServiceUnavailableException;
-import org.opendaylight.controller.northbound.commons.exception.UnauthorizedException;
-import org.opendaylight.controller.northbound.commons.query.QueryContext;
-import org.opendaylight.controller.northbound.commons.utils.NorthboundUtils;
-import org.opendaylight.controller.sal.authorization.Privilege;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.utils.ServiceHelper;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.switchmanager.ISwitchManager;
-import org.opendaylight.controller.switchmanager.SubnetConfig;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * This class provides REST APIs to manage subnets.
- *
- * <br>
- * <br>
- * Authentication scheme : <b>HTTP Basic</b><br>
- * Authentication realm : <b>opendaylight</b><br>
- * Transport : <b>HTTP and HTTPS</b><br>
- * <br>
- * HTTPS Authentication is disabled by default.
- *
- */
-
-@Path("/")
-public class SubnetsNorthbound {
-    protected static final Logger logger = LoggerFactory.getLogger(SubnetsNorthbound.class);
-
-    private String username;
-    private QueryContext queryContext;
-
-    @Context
-    public void setQueryContext(ContextResolver<QueryContext> queryCtxResolver) {
-      if (queryCtxResolver != null) {
-        queryContext = queryCtxResolver.getContext(QueryContext.class);
-      }
-    }
-
-    @Context
-    public void setSecurityContext(SecurityContext context) {
-        if (context != null && context.getUserPrincipal() != null) {
-            username = context.getUserPrincipal().getName();
-        }
-    }
-
-    protected String getUserName() {
-        return username;
-    }
-
-    private void handleContainerDoesNotExist(String containerName) {
-        IContainerManager containerManager = (IContainerManager) ServiceHelper.getGlobalInstance(
-                IContainerManager.class, this);
-        if (containerManager == null) {
-            throw new ServiceUnavailableException("Container " + RestMessages.NOCONTAINER.toString());
-        }
-
-        List<String> containerNames = containerManager.getContainerNames();
-        for (String cName : containerNames) {
-            if (cName.trim().equalsIgnoreCase(containerName.trim())) {
-                return;
-            }
-        }
-
-        throw new ResourceNotFoundException(containerName + " " + RestMessages.NOCONTAINER.toString());
-    }
-
-    private void handleNameMismatch(String name, String nameinURL) {
-        if (name == null || nameinURL == null) {
-            throw new BadRequestException(RestMessages.INVALIDDATA.toString() + " : Name is null");
-        }
-
-        if (name.equals(nameinURL)) {
-            return;
-        }
-        throw new ResourceConflictException(RestMessages.INVALIDDATA.toString()
-                + " : Name in URL does not match the name in request body");
-    }
-
-    /**
-     * List all the subnets in a given container
-     *
-     * @param containerName
-     *            container in which we want to query the subnets
-     *
-     * @return a List of SubnetConfig
-     *
-     * <pre>
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/subnetservice/default/subnets
-     *
-     * Response body in XML:
-     * &lt;list&gt;
-     * &lt;subnetConfig&gt;
-     *    &lt;name&gt;marketingdepartment&lt;/name&gt;
-     *    &lt;subnet&gt;30.31.54.254/24&lt;/subnet&gt;
-     * &lt;/subnetConfig&gt;
-     * &lt;subnetConfig&gt;
-     *    &lt;name&gt;salesdepartment&lt;/name&gt;
-     *    &lt;subnet&gt;20.18.1.254/16&lt;/subnet&gt;
-     *    &lt;nodeConnectors&gt;OF|11@OF|00:00:00:aa:bb:cc:dd:ee&lt;/nodeConnectors&gt;
-     *    &lt;nodeConnectors&gt;OF|13@OF|00:00:00:aa:bb:cc:dd:ee&lt;/nodeConnectors&gt;
-     * &lt;/subnetConfig&gt;
-     * &lt;/list&gt;
-     * Response body in JSON:
-     * {
-     *   "subnetConfig": [
-     *     {
-     *       "name": "marketingdepartment",
-     *       "subnet": "30.31.54.254/24",
-     *       "nodeConnectors": [
-     *           "OF|04@OF|00:00:00:00:00:00:00:04",
-     *           "OF|07@OF|00:00:00:00:00:00:00:07"
-     *       ]
-     *     },
-     *     {
-     *       "name":"salesdepartment",
-     *       "subnet":"20.18.1.254/16",
-     *       "nodeConnectors": [
-     *            "OF|11@OF|00:00:00:aa:bb:cc:dd:ee",
-     *            "OF|13@OF|00:00:00:aa:bb:cc:dd:ee"
-     *        ]
-     *      }
-     *   ]
-     * }
-     *
-     * </pre>
-     */
-    @Path("/{containerName}/subnets")
-    @GET
-    @Produces({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @StatusCodes({ @ResponseCode(code = 401, condition = "User not authorized to perform this operation"),
-        @ResponseCode(code = 404, condition = "The containerName passed was not found"),
-        @ResponseCode(code = 503, condition = "Service unavailable"),
-        @ResponseCode(code = 400, condition = "Incorrect query syntex") })
-    @TypeHint(SubnetConfigs.class)
-    public SubnetConfigs listSubnets(@PathParam("containerName") String containerName,
-        @QueryParam("_q") String queryString) {
-
-        handleContainerDoesNotExist(containerName);
-        if (!NorthboundUtils.isAuthorized(getUserName(), containerName, Privilege.READ, this)) {
-            throw new UnauthorizedException("User is not authorized to perform this operation on container "
-                    + containerName);
-        }
-        ISwitchManager switchManager = (ISwitchManager) ServiceHelper.getInstance(ISwitchManager.class, containerName,
-                this);
-        if (switchManager == null) {
-            throw new ServiceUnavailableException("SwitchManager " + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-        List<SubnetConfig> subnets = switchManager.getSubnetsConfigList();
-        if (queryString != null) {
-            subnets = queryContext.createQuery(queryString, SubnetConfig.class)
-                    .find(subnets);
-
-        }
-        return new SubnetConfigs(subnets);
-    }
-
-    /**
-     * List the configuration of a subnet in a given container
-     *
-     * @param containerName
-     *            container in which we want to query the subnet
-     * @param subnetName
-     *            of the subnet being queried
-     *
-     * @return SubnetConfig
-     *
-     *         <pre>
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/subnetservice/default/subnet/marketingdepartment
-     *
-     * Response body in XML:
-     * &lt;subnetConfig&gt;
-     *    &lt;name&gt;marketingdepartment&lt;/name&gt;
-     *    &lt;subnet&gt;30.0.0.1/24&lt;/subnet&gt;
-     *    &lt;nodeConnectors&gt;OF|1@OF|00:00:00:00:00:00:00:01&lt;/nodePorts&gt;
-     *    &lt;nodeConnectors&gt;OF|3@OF|00:00:00:00:00:00:00:03&lt;/nodePorts&gt;
-     * &lt;/subnetConfig&gt;
-     *
-     * Response body in JSON:
-     * {
-     *  "name":"marketingdepartment",
-     *  "subnet":"30.0.0.1/24",
-     *  "nodeConnectors":[
-     *       "OF|1@OF|00:00:00:00:00:00:00:01",
-     *       "OF|3@OF|00:00:00:00:00:00:00:03"
-     *   ]
-     * }
-     * </pre>
-     */
-    @Path("/{containerName}/subnet/{subnetName}")
-    @GET
-    @Produces({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @StatusCodes({ @ResponseCode(code = 401, condition = "User not authorized to perform this operation"),
-        @ResponseCode(code = 404, condition = "The containerName or subnetName passed was not found"),
-        @ResponseCode(code = 503, condition = "Service unavailable") })
-    @TypeHint(SubnetConfig.class)
-    public SubnetConfig listSubnet(@PathParam("containerName") String containerName,
-            @PathParam("subnetName") String subnetName) {
-
-        handleContainerDoesNotExist(containerName);
-
-        if (!NorthboundUtils.isAuthorized(getUserName(), containerName, Privilege.READ, this)) {
-            throw new UnauthorizedException("User is not authorized to perform this operation on container "
-                    + containerName);
-        }
-        ISwitchManager switchManager = (ISwitchManager) ServiceHelper.getInstance(ISwitchManager.class, containerName,
-                this);
-        if (switchManager == null) {
-            throw new ServiceUnavailableException("SwitchManager " + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-        SubnetConfig res = switchManager.getSubnetConfig(subnetName);
-        if (res == null) {
-            throw new ResourceNotFoundException(RestMessages.NOSUBNET.toString());
-        }
-        return res;
-    }
-
-    /**
-     * Add a subnet into the specified container context, node connectors are
-     * optional
-     *
-     * @param containerName
-     *            name of the container context in which the subnet needs to be
-     *            added
-     * @param subnetName
-     *            name of new subnet to be added
-     * @param subnetConfigData
-     *            the {@link SubnetConfig} structure in request body
-     *
-     * @return Response as dictated by the HTTP Response Status code
-     *
-     *         <pre>
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/subnetservice/default/subnet/salesdepartment
-     *
-     * Request body in XML:
-     *  &lt;subnetConfig&gt;
-     *      &lt;name&gt;salesdepartment&lt;/name&gt;
-     *      &lt;subnet&gt;172.173.174.254/24&lt;/subnet&gt;
-     *      &lt;nodeConnectors&gt;OF|22@OF|00:00:11:22:33:44:55:66&lt;/nodeConnectors&gt;
-     *      &lt;nodeConnectors&gt;OF|39@OF|00:00:ab:cd:33:44:55:66&lt;/nodeConnectors&gt;
-     *  &lt;/subnetConfig&gt;
-     *
-     * Request body in JSON:
-     * {
-     *  "name":"salesdepartment",
-     *  "subnet":"172.173.174.254/24",
-     *  "nodeConnectors":[
-     *       "OF|22@OF|00:00:11:22:33:44:55:66",
-     *       "OF|39@OF|00:00:ab:cd:33:44:55:66"
-     *       ]
-     * }
-     * </pre>
-     */
-
-    @Path("/{containerName}/subnet/{subnetName}")
-    @PUT
-    @StatusCodes({ @ResponseCode(code = 201, condition = "Subnet created successfully"),
-        @ResponseCode(code = 400, condition = "Invalid data passed"),
-        @ResponseCode(code = 401, condition = "User not authorized to perform this operation"),
-        @ResponseCode(code = 409, condition = "Subnet name in url conflicts with name in request body"),
-        @ResponseCode(code = 404, condition = "Container name passed was not found or subnet config is null"),
-        @ResponseCode(code = 500, condition = "Internal Server Error: Addition of subnet failed"),
-        @ResponseCode(code = 503, condition = "Service unavailable") })
-    public Response addSubnet(@PathParam("containerName") String containerName,
-            @PathParam("subnetName") String subnetName, @TypeHint(SubnetConfig.class) SubnetConfig subnetConfigData) {
-
-        handleContainerDoesNotExist(containerName);
-
-        if (!NorthboundUtils.isAuthorized(getUserName(), containerName, Privilege.WRITE, this)) {
-            throw new UnauthorizedException("User is not authorized to perform this operation on container "
-                    + containerName);
-        }
-        SubnetConfig cfgObject = subnetConfigData;
-        handleNameMismatch(cfgObject.getName(), subnetName);
-
-        ISwitchManager switchManager = (ISwitchManager) ServiceHelper.getInstance(ISwitchManager.class, containerName,
-                this);
-        if (switchManager == null) {
-            throw new ServiceUnavailableException("SwitchManager " + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-        Status status = switchManager.addSubnet(cfgObject);
-        if (status.isSuccess()) {
-            NorthboundUtils.auditlog("Subnet Gateway", username, "added", subnetName, containerName);
-            if (subnetConfigData.getNodeConnectors() != null) {
-                for (NodeConnector port : subnetConfigData.getNodeConnectors()) {
-                    NorthboundUtils.auditlog("Port", getUserName(), "added",
-                            NorthboundUtils.getPortName(port, switchManager) + " to Subnet Gateway " + subnetName,
-                            containerName);
-                }
-            }
-            return Response.status(Response.Status.CREATED).build();
-        }
-        return NorthboundUtils.getResponse(status);
-    }
-
-    /**
-     * Delete a subnet from the specified container context
-     *
-     * @param containerName
-     *            name of the container in which subnet needs to be removed
-     * @param subnetName
-     *            name of new subnet to be deleted
-     * @return Response as dictated by the HTTP Response Status code
-     *
-     * <pre>
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/subnetservice/default/subnet/engdepartment
-     *
-     * </pre>
-     */
-    @Path("/{containerName}/subnet/{subnetName}")
-    @DELETE
-    @StatusCodes({ @ResponseCode(code = 204, condition = "No Content"),
-        @ResponseCode(code = 401, condition = "User not authorized to perform this operation"),
-        @ResponseCode(code = 404, condition = "The containerName passed was not found"),
-        @ResponseCode(code = 500, condition = "Internal Server Error : Removal of subnet failed"),
-        @ResponseCode(code = 503, condition = "Service unavailable") })
-    public Response removeSubnet(@PathParam("containerName") String containerName,
-            @PathParam("subnetName") String subnetName) {
-
-        handleContainerDoesNotExist(containerName);
-
-        if (!NorthboundUtils.isAuthorized(getUserName(), containerName, Privilege.WRITE, this)) {
-            throw new UnauthorizedException("User is not authorized to perform this operation on container "
-                    + containerName);
-        }
-
-        ISwitchManager switchManager = (ISwitchManager) ServiceHelper.getInstance(ISwitchManager.class, containerName,
-                this);
-        if (switchManager == null) {
-            throw new ServiceUnavailableException("SwitchManager " + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-        Status status = switchManager.removeSubnet(subnetName);
-        if (status.isSuccess()) {
-            NorthboundUtils.auditlog("Subnet Gateway", username, "removed", subnetName, containerName);
-            return Response.status(Response.Status.NO_CONTENT).build();
-        }
-        return NorthboundUtils.getResponse(status);
-    }
-
-    /**
-     * Modify a subnet. Replace the existing subnet with the new specified one.
-     * For now only port list modification is allowed. If the respective subnet
-     * configuration does not exist this call is equivalent to a subnet
-     * creation.
-     *
-     * @param containerName
-     *            Name of the Container context
-     * @param subnetName
-     *            Name of the subnet to be modified
-     * @param subnetConfigData
-     *            the {@link SubnetConfig} structure in request body parameter
-     * @return Response as dictated by the HTTP Response Status code
-     *
-     *         <pre>
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/subnetservice/default/subnet/salesdepartment
-     *
-     *  Request body in XML:
-     *  &lt;subnetConfig&gt;
-     *      &lt;name&gt;salesdepartment&lt;/name&gt;
-     *      &lt;subnet&gt;172.173.174.254/24&lt;/subnet&gt;
-     *      &lt;nodeConnectors&gt;OF|22@OF|00:00:11:22:33:44:55:66&lt;/nodeConnectors&gt;
-     *      &lt;nodeConnectors&gt;OF|39@OF|00:00:ab:cd:33:44:55:66&lt;/nodeConnectors&gt;
-     *  &lt;/subnetConfig&gt;
-     *
-     * Request body in JSON:
-     * {
-     *  "name":"salesdepartment",
-     *  "subnet":"172.173.174.254/24",
-     *  "nodeConnectors":[
-     *      "OF|22@OF|00:00:11:22:33:44:55:66",
-     *      "OF|39@OF|00:00:ab:cd:33:44:55:66"
-     *  ]
-     * }
-     * </pre>
-     */
-    @Path("/{containerName}/subnet/{subnetName}")
-    @POST
-    @Consumes({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @StatusCodes({ @ResponseCode(code = 200, condition = "Configuration replaced successfully"),
-        @ResponseCode(code = 401, condition = "User not authorized to perform this operation"),
-        @ResponseCode(code = 409, condition = "Subnet name in url conflicts with name in request body"),
-        @ResponseCode(code = 404, condition = "The containerName or subnetName is not found"),
-        @ResponseCode(code = 500, condition = "Internal server error: Modify subnet failed"),
-        @ResponseCode(code = 503, condition = "Service unavailable") })
-    public Response modifySubnet(@Context UriInfo uriInfo, @PathParam("containerName") String containerName,
-            @PathParam("subnetName") String subnetName, @TypeHint(SubnetConfig.class) SubnetConfig subnetConfigData) {
-
-        handleContainerDoesNotExist(containerName);
-
-        if (!NorthboundUtils.isAuthorized(getUserName(), containerName, Privilege.WRITE, this)) {
-            throw new UnauthorizedException("User is not authorized to perform this operation on container "
-                    + containerName);
-        }
-        handleNameMismatch(subnetConfigData.getName(), subnetName);
-
-        ISwitchManager switchManager = (ISwitchManager) ServiceHelper.getInstance(ISwitchManager.class, containerName,
-                this);
-        if (switchManager == null) {
-            throw new ServiceUnavailableException("SwitchManager " + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        // Need to check this until Status does not return a CREATED status code
-        SubnetConfig existingConf = switchManager.getSubnetConfig(subnetName);
-
-        Status status = switchManager.modifySubnet(subnetConfigData);
-
-        if (status.isSuccess()) {
-            if (existingConf == null) {
-                NorthboundUtils.auditlog("Subnet Gateway", username, "added", subnetName, containerName);
-                if (subnetConfigData.getNodeConnectors() != null) {
-                    for (NodeConnector port : subnetConfigData.getNodeConnectors()) {
-                        NorthboundUtils.auditlog("Port", getUserName(), "added",
-                                NorthboundUtils.getPortName(port, switchManager) + " to Subnet Gateway" + subnetName,
-                                containerName);
-                    }
-                }
-                return Response.created(uriInfo.getRequestUri()).build();
-            } else {
-                Set<NodeConnector> existingNCList = existingConf.getNodeConnectors();
-
-                if (existingNCList == null) {
-                    existingNCList = new HashSet<NodeConnector>(0);
-                }
-                if (subnetConfigData.getNodeConnectors() != null) {
-                    for (NodeConnector port : subnetConfigData.getNodeConnectors()) {
-                        if (!existingNCList.contains(port)) {
-                            NorthboundUtils.auditlog("Port", getUserName(), "added",
-                                    NorthboundUtils.getPortName(port, switchManager) + " to Subnet Gateway "
-                                            + subnetName, containerName);
-                        }
-                    }
-                }
-                for (NodeConnector port : existingNCList) {
-                    if (!subnetConfigData.getNodeConnectors().contains(port)) {
-                        NorthboundUtils
-                                .auditlog("Port", getUserName(), "removed",
-                                        NorthboundUtils.getPortName(port, switchManager) + " from Subnet Gateway "
-                                                + subnetName, containerName);
-                    }
-                }
-            }
-        }
-        return NorthboundUtils.getResponse(status);
-    }
-}
diff --git a/opendaylight/adsal/northbound/subnets/src/main/resources/META-INF/spring.factories b/opendaylight/adsal/northbound/subnets/src/main/resources/META-INF/spring.factories
deleted file mode 100644 (file)
index 93db02e..0000000
+++ /dev/null
@@ -1 +0,0 @@
-org.springframework.beans.BeanInfoFactory=org.springframework.beans.ExtendedBeanInfoFactory
diff --git a/opendaylight/adsal/northbound/subnets/src/main/resources/META-INF/spring.handlers b/opendaylight/adsal/northbound/subnets/src/main/resources/META-INF/spring.handlers
deleted file mode 100644 (file)
index 957af91..0000000
+++ /dev/null
@@ -1,10 +0,0 @@
-http\://www.springframework.org/schema/context=org.springframework.context.config.ContextNamespaceHandler
-http\://www.springframework.org/schema/jee=org.springframework.ejb.config.JeeNamespaceHandler
-http\://www.springframework.org/schema/lang=org.springframework.scripting.config.LangNamespaceHandler
-http\://www.springframework.org/schema/task=org.springframework.scheduling.config.TaskNamespaceHandler
-http\://www.springframework.org/schema/cache=org.springframework.cache.config.CacheNamespaceHandler
-http\://www.springframework.org/schema/c=org.springframework.beans.factory.xml.SimpleConstructorNamespaceHandler
-http\://www.springframework.org/schema/p=org.springframework.beans.factory.xml.SimplePropertyNamespaceHandler
-http\://www.springframework.org/schema/util=org.springframework.beans.factory.xml.UtilNamespaceHandler
-http\://www.springframework.org/schema/mvc=org.springframework.web.servlet.config.MvcNamespaceHandler
-http\://www.springframework.org/schema/security=org.springframework.security.config.SecurityNamespaceHandler
diff --git a/opendaylight/adsal/northbound/subnets/src/main/resources/META-INF/spring.schemas b/opendaylight/adsal/northbound/subnets/src/main/resources/META-INF/spring.schemas
deleted file mode 100644 (file)
index d865edc..0000000
+++ /dev/null
@@ -1,49 +0,0 @@
-http\://www.springframework.org/schema/beans/spring-beans-2.0.xsd=org/springframework/beans/factory/xml/spring-beans-2.0.xsd
-http\://www.springframework.org/schema/beans/spring-beans-2.5.xsd=org/springframework/beans/factory/xml/spring-beans-2.5.xsd
-http\://www.springframework.org/schema/beans/spring-beans-3.0.xsd=org/springframework/beans/factory/xml/spring-beans-3.0.xsd
-http\://www.springframework.org/schema/beans/spring-beans-3.1.xsd=org/springframework/beans/factory/xml/spring-beans-3.1.xsd
-http\://www.springframework.org/schema/beans/spring-beans-3.2.xsd=org/springframework/beans/factory/xml/spring-beans-3.2.xsd
-http\://www.springframework.org/schema/beans/spring-beans.xsd=org/springframework/beans/factory/xml/spring-beans-3.2.xsd
-http\://www.springframework.org/schema/tool/spring-tool-2.0.xsd=org/springframework/beans/factory/xml/spring-tool-2.0.xsd
-http\://www.springframework.org/schema/tool/spring-tool-2.5.xsd=org/springframework/beans/factory/xml/spring-tool-2.5.xsd
-http\://www.springframework.org/schema/tool/spring-tool-3.0.xsd=org/springframework/beans/factory/xml/spring-tool-3.0.xsd
-http\://www.springframework.org/schema/tool/spring-tool-3.1.xsd=org/springframework/beans/factory/xml/spring-tool-3.1.xsd
-http\://www.springframework.org/schema/tool/spring-tool-3.2.xsd=org/springframework/beans/factory/xml/spring-tool-3.2.xsd
-http\://www.springframework.org/schema/tool/spring-tool.xsd=org/springframework/beans/factory/xml/spring-tool-3.2.xsd
-http\://www.springframework.org/schema/util/spring-util-2.0.xsd=org/springframework/beans/factory/xml/spring-util-2.0.xsd
-http\://www.springframework.org/schema/util/spring-util-2.5.xsd=org/springframework/beans/factory/xml/spring-util-2.5.xsd
-http\://www.springframework.org/schema/util/spring-util-3.0.xsd=org/springframework/beans/factory/xml/spring-util-3.0.xsd
-http\://www.springframework.org/schema/util/spring-util-3.1.xsd=org/springframework/beans/factory/xml/spring-util-3.1.xsd
-http\://www.springframework.org/schema/util/spring-util-3.2.xsd=org/springframework/beans/factory/xml/spring-util-3.2.xsd
-http\://www.springframework.org/schema/util/spring-util.xsd=org/springframework/beans/factory/xml/spring-util-3.2.xsd
-http\://www.springframework.org/schema/context/spring-context-2.5.xsd=org/springframework/context/config/spring-context-2.5.xsd
-http\://www.springframework.org/schema/context/spring-context-3.0.xsd=org/springframework/context/config/spring-context-3.0.xsd
-http\://www.springframework.org/schema/context/spring-context-3.1.xsd=org/springframework/context/config/spring-context-3.1.xsd
-http\://www.springframework.org/schema/context/spring-context-3.2.xsd=org/springframework/context/config/spring-context-3.2.xsd
-http\://www.springframework.org/schema/context/spring-context.xsd=org/springframework/context/config/spring-context-3.2.xsd
-http\://www.springframework.org/schema/jee/spring-jee-2.0.xsd=org/springframework/ejb/config/spring-jee-2.0.xsd
-http\://www.springframework.org/schema/jee/spring-jee-2.5.xsd=org/springframework/ejb/config/spring-jee-2.5.xsd
-http\://www.springframework.org/schema/jee/spring-jee-3.0.xsd=org/springframework/ejb/config/spring-jee-3.0.xsd
-http\://www.springframework.org/schema/jee/spring-jee-3.1.xsd=org/springframework/ejb/config/spring-jee-3.1.xsd
-http\://www.springframework.org/schema/jee/spring-jee-3.2.xsd=org/springframework/ejb/config/spring-jee-3.2.xsd
-http\://www.springframework.org/schema/jee/spring-jee.xsd=org/springframework/ejb/config/spring-jee-3.2.xsd
-http\://www.springframework.org/schema/lang/spring-lang-2.0.xsd=org/springframework/scripting/config/spring-lang-2.0.xsd
-http\://www.springframework.org/schema/lang/spring-lang-2.5.xsd=org/springframework/scripting/config/spring-lang-2.5.xsd
-http\://www.springframework.org/schema/lang/spring-lang-3.0.xsd=org/springframework/scripting/config/spring-lang-3.0.xsd
-http\://www.springframework.org/schema/lang/spring-lang-3.1.xsd=org/springframework/scripting/config/spring-lang-3.1.xsd
-http\://www.springframework.org/schema/lang/spring-lang-3.2.xsd=org/springframework/scripting/config/spring-lang-3.2.xsd
-http\://www.springframework.org/schema/lang/spring-lang.xsd=org/springframework/scripting/config/spring-lang-3.2.xsd
-http\://www.springframework.org/schema/task/spring-task-3.0.xsd=org/springframework/scheduling/config/spring-task-3.0.xsd
-http\://www.springframework.org/schema/task/spring-task-3.1.xsd=org/springframework/scheduling/config/spring-task-3.1.xsd
-http\://www.springframework.org/schema/task/spring-task-3.2.xsd=org/springframework/scheduling/config/spring-task-3.2.xsd
-http\://www.springframework.org/schema/task/spring-task.xsd=org/springframework/scheduling/config/spring-task-3.2.xsd
-http\://www.springframework.org/schema/cache/spring-cache-3.1.xsd=org/springframework/cache/config/spring-cache-3.1.xsd
-http\://www.springframework.org/schema/cache/spring-cache-3.2.xsd=org/springframework/cache/config/spring-cache-3.2.xsd
-http\://www.springframework.org/schema/cache/spring-cache.xsd=org/springframework/cache/config/spring-cache-3.2.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd=org/springframework/web/servlet/config/spring-mvc-3.0.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc-3.1.xsd=org/springframework/web/servlet/config/spring-mvc-3.1.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc-3.2.xsd=org/springframework/web/servlet/config/spring-mvc-3.2.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc.xsd=org/springframework/web/servlet/config/spring-mvc-3.2.xsd
-http\://www.springframework.org/schema/security/spring-security-3.1.xsd=org/springframework/security/config/spring-security-3.1.xsd
-http\://www.springframework.org/schema/security/spring-security-3.2.xsd=org/springframework/security/config/spring-security-3.2.xsd
-
diff --git a/opendaylight/adsal/northbound/subnets/src/main/resources/META-INF/spring.tooling b/opendaylight/adsal/northbound/subnets/src/main/resources/META-INF/spring.tooling
deleted file mode 100644 (file)
index 057d834..0000000
+++ /dev/null
@@ -1,39 +0,0 @@
-# Tooling related information for the beans namespace
-http\://www.springframework.org/schema/beans@name=beans Namespace
-http\://www.springframework.org/schema/beans@prefix=beans
-http\://www.springframework.org/schema/beans@icon=org/springframework/beans/factory/xml/spring-beans.gif
-
-# Tooling related information for the util namespace
-http\://www.springframework.org/schema/util@name=util Namespace
-http\://www.springframework.org/schema/util@prefix=util
-http\://www.springframework.org/schema/util@icon=org/springframework/beans/factory/xml/spring-util.gif
-
-# Tooling related information for the context namespace
-http\://www.springframework.org/schema/context@name=context Namespace
-http\://www.springframework.org/schema/context@prefix=context
-http\://www.springframework.org/schema/context@icon=org/springframework/context/config/spring-context.gif
-
-# Tooling related information for the jee namespace
-http\://www.springframework.org/schema/jee@name=jee Namespace
-http\://www.springframework.org/schema/jee@prefix=jee
-http\://www.springframework.org/schema/jee@icon=org/springframework/ejb/config/spring-jee.gif
-
-# Tooling related information for the scheduling namespace
-http\://www.springframework.org/schema/task@name=task Namespace
-http\://www.springframework.org/schema/task@prefix=task
-http\://www.springframework.org/schema/task@icon=org/springframework/scheduling/config/spring-task.gif
-
-# Tooling related information for the lang namespace
-http\://www.springframework.org/schema/lang@name=lang Namespace
-http\://www.springframework.org/schema/lang@prefix=lang
-http\://www.springframework.org/schema/lang@icon=org/springframework/scripting/config/spring-lang.gif
-
-# Tooling related information for the cache namespace
-http\://www.springframework.org/schema/cache@name=cache Namespace
-http\://www.springframework.org/schema/cache@prefix=cache
-http\://www.springframework.org/schema/cache@icon=org/springframework/cache/config/spring-cache.gif
-
-# Tooling related information for the mvc namespace
-http\://www.springframework.org/schema/mvc@name=mvc Namespace
-http\://www.springframework.org/schema/mvc@prefix=mvc
-http\://www.springframework.org/schema/mvc@icon=org/springframework/web/servlet/config/spring-mvc.gif
diff --git a/opendaylight/adsal/northbound/subnets/src/main/resources/WEB-INF/web.xml b/opendaylight/adsal/northbound/subnets/src/main/resources/WEB-INF/web.xml
deleted file mode 100644 (file)
index 7e0d465..0000000
+++ /dev/null
@@ -1,88 +0,0 @@
-<?xml version="1.0" encoding="ISO-8859-1"?>
-<web-app xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
-        xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
-        version="3.0">
-  <servlet>
-    <servlet-name>JAXRSSubnets</servlet-name>
-    <servlet-class>com.sun.jersey.spi.container.servlet.ServletContainer</servlet-class>
-    <init-param>
-      <param-name>javax.ws.rs.Application</param-name>
-      <param-value> org.opendaylight.controller.northbound.commons.NorthboundApplication</param-value>
-    </init-param>
-    <load-on-startup>1</load-on-startup>
-  </servlet>
-
-  <servlet-mapping>
-    <servlet-name>JAXRSSubnets</servlet-name>
-    <url-pattern>/*</url-pattern>
-  </servlet-mapping>
-        <filter>
-          <filter-name>CorsFilter</filter-name>
-          <filter-class>org.apache.catalina.filters.CorsFilter</filter-class>
-          <init-param>
-            <param-name>cors.allowed.origins</param-name>
-            <param-value>*</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.allowed.methods</param-name>
-            <param-value>GET,POST,HEAD,OPTIONS,PUT,DELETE</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.allowed.headers</param-name>
-            <param-value>Content-Type,X-Requested-With,accept,authorization, origin,Origin,Access-Control-Request-Method,Access-Control-Request-Headers</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.exposed.headers</param-name>
-            <param-value>Access-Control-Allow-Origin,Access-Control-Allow-Credentials</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.support.credentials</param-name>
-            <param-value>true</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.preflight.maxage</param-name>
-            <param-value>10</param-value>
-          </init-param>
-        </filter>
-        <filter-mapping>
-          <filter-name>CorsFilter</filter-name>
-          <url-pattern>/*</url-pattern>
-        </filter-mapping>
-
-        <security-constraint>
-          <web-resource-collection>
-            <web-resource-name>NB api</web-resource-name>
-            <url-pattern>/*</url-pattern>
-            <http-method>POST</http-method>
-            <http-method>GET</http-method>
-            <http-method>PUT</http-method>
-            <http-method>PATCH</http-method>
-            <http-method>DELETE</http-method>
-            <http-method>HEAD</http-method>
-          </web-resource-collection>
-          <auth-constraint>
-            <role-name>System-Admin</role-name>
-            <role-name>Network-Admin</role-name>
-            <role-name>Network-Operator</role-name>
-            <role-name>Container-User</role-name>
-          </auth-constraint>
-        </security-constraint>
-
-        <security-role>
-                <role-name>System-Admin</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Network-Admin</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Network-Operator</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Container-User</role-name>
-        </security-role>
-
-        <login-config>
-                <auth-method>BASIC</auth-method>
-                <realm-name>opendaylight</realm-name>
-        </login-config>
-</web-app>
diff --git a/opendaylight/adsal/northbound/subnets/src/test/java/org/opendaylight/controller/subnets/northbound/SubnetsNorthboundTest.java b/opendaylight/adsal/northbound/subnets/src/test/java/org/opendaylight/controller/subnets/northbound/SubnetsNorthboundTest.java
deleted file mode 100644 (file)
index 833b5d4..0000000
+++ /dev/null
@@ -1,33 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.subnets.northbound;
-
-import java.util.ArrayList;
-
-import org.junit.Assert;
-import org.junit.Test;
-import org.opendaylight.controller.switchmanager.SubnetConfig;
-
-public class SubnetsNorthboundTest {
-
-    @Test
-    public void testSubnetConfigs() {
-        SubnetConfigs sc1 = new SubnetConfigs(null);
-        Assert.assertNull(sc1.getSubnetConfig());
-
-        ArrayList<SubnetConfig> list = new ArrayList<SubnetConfig>();
-        SubnetConfig s1 = new SubnetConfig();
-        list.add(s1);
-        sc1.setSubnetConfig(list);
-        Assert.assertTrue(sc1.getSubnetConfig().equals(list));
-
-        sc1.setSubnetConfig(null);
-        Assert.assertNull(sc1.getSubnetConfig());
-    }
-
-}
diff --git a/opendaylight/adsal/northbound/swagger-ui/pom.xml b/opendaylight/adsal/northbound/swagger-ui/pom.xml
deleted file mode 100644 (file)
index e25a28c..0000000
+++ /dev/null
@@ -1,219 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>swagger-ui</artifactId>
-  <version>0.2.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-
-  <properties>
-    <api.dir>${resource.dir}/apis</api.dir>
-    <resource.dir>${project.build.directory}/classes</resource.dir>
-  </properties>
-
-  <dependencies>
-    <dependency>
-      <groupId>com.google.code.gson</groupId>
-      <artifactId>gson</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>javax.servlet</artifactId>
-    </dependency>
-    <!-- add dependency on all northbound bundles -->
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>connectionmanager.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>controllermanager.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>flowprogrammer.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>forwarding.staticrouting.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>hosttracker.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>networkconfig.bridgedomain.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>statistics.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>subnets.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>switchmanager.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>topology.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>usermanager.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.slf4j</groupId>
-      <artifactId>slf4j-api</artifactId>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Export-Package></Export-Package>
-            <Import-Package>org.slf4j,
-              javax.annotation,
-              javax.naming,
-              javax.servlet,
-              javax.servlet.annotation,
-              javax.servlet.http,
-              com.google.gson,</Import-Package>
-            <Export-Package></Export-Package>
-            <Include-Resource>apis=target/classes/apis,
-                index.html=target/classes/index.html,
-                apilist.json=target/classes/apilist.json,
-                css=target/classes/css,
-                lib=target/classes/lib,
-                swagger-ui.min.js=target/classes/swagger-ui.min.js,
-                swagger-ui.js=target/classes/swagger-ui.js,
-                images=target/classes/images,
-                WEB-INF/web.xml=target/classes/WEB-INF/web.xml</Include-Resource>
-            <Web-ContextPath>/swagger</Web-ContextPath>
-          </instructions>
-        </configuration>
-      </plugin>
-      <plugin>
-        <groupId>org.apache.maven.plugins</groupId>
-        <artifactId>maven-antrun-plugin</artifactId>
-        <version>1.7</version>
-        <dependencies>
-          <dependency>
-            <groupId>ant-contrib</groupId>
-            <artifactId>ant-contrib</artifactId>
-            <version>1.0b3</version>
-            <exclusions>
-              <exclusion>
-                <groupId>ant</groupId>
-                <artifactId>ant</artifactId>
-              </exclusion>
-            </exclusions>
-          </dependency>
-        </dependencies>
-        <executions>
-          <execution>
-            <goals>
-              <goal>run</goal>
-            </goals>
-            <phase>generate-sources</phase>
-            <configuration>
-              <target>
-                <taskdef classpathref="maven.plugin.classpath" resource="net/sf/antcontrib/antlib.xml"></taskdef>
-                <patternset id="rest.paths">
-                  <include name="**/enunciate/generate/swagger/ui/*.json"></include>
-                  <exclude name="**/java-client/**"></exclude>
-                  <exclude name="**/swagger-ui/**"></exclude>
-                </patternset>
-
-                <echo message="======== Assembling swagger docs ========"></echo>
-                <!-- make api directory -->
-                <mkdir dir="${api.dir}"></mkdir>
-                <!--  copy swagger libs -->
-                <copy todir="${resource.dir}">
-                  <fileset dir="../subnets/target/enunciate/generate/swagger/ui">
-                    <exclude name="**/*.json"></exclude>
-                    <exclude name="**/*.png"></exclude>
-                    <exclude name="**/index.html"></exclude>
-                  </fileset>
-                </copy>
-                <!--  Copy NorthBound json files into ui directory-->
-                <copy todir="${api.dir}">
-                  <fileset dir="${basedir}/../../..">
-                    <patternset refid="rest.paths"></patternset>
-                  </fileset>
-                  <mapper>
-                    <regexpmapper from="^(.*)/([^/]+)/*/target/enunciate/generate/swagger/ui/(.*Northbound).*$$" to="\3"></regexpmapper>
-                    <regexpmapper from="^(.*)/([^/]+)/*/target/enunciate/generate/swagger/ui/(.*resource-list.json)$$" to="\2-\3"></regexpmapper>
-                  </mapper>
-                </copy>
-
-                <!--  Correct base path -->
-                <replaceregexp match="/full" replace="">
-                  <fileset dir="${api.dir}">
-                    <include name="**/*Northbound"></include>
-                  </fileset>
-                </replaceregexp>
-                <!--  Merge Resource list -->
-                <echo append="false" file="${resource.dir}/apilist.json">{
-  "swaggerVersion": "1.1",
-  "basePath": "http://localhost:8080/swagger/apis",
-  "apis": [</echo>
-                <for param="file">
-                  <path>
-                    <fileset dir="${api.dir}">
-                      <include name="**/*resource-list.json"></include>
-                    </fileset>
-                  </path>
-                  <sequential>
-                    <echo message="Processing json resource @{file}"></echo>
-                    <loadfile property="jsoncontent" srcfile="@{file}">
-                      <filterchain>
-                        <headfilter lines="10"></headfilter>
-                        <tailfilter lines="6"></tailfilter>
-                      </filterchain>
-                    </loadfile>
-                    <echo append="true" file="${resource.dir}/apilist.json" message="${jsoncontent},"></echo>
-                    <var name="jsoncontent" unset="true"></var>
-                  </sequential>
-                </for>
-                <echo append="true" file="${resource.dir}/apilist.json">{ }
-  ]
-}</echo>
-
-                <!-- Remove .json from api paths -->
-                <replaceregexp file="${resource.dir}/apilist.json" flags="g" match=".json" replace=""></replaceregexp>
-                <replaceregexp file="${resource.dir}/apilist.json" flags="g" match="JAXRS" replace=""></replaceregexp>
-
-                <!-- cleanup resource files as we don't need them -->
-                <delete>
-                  <fileset dir="${api.dir}" includes="**/*resource-list.json"></fileset>
-                </delete>
-                <echo message="======== Build successful ========"></echo>
-              </target>
-            </configuration>
-          </execution>
-        </executions>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/northbound/swagger-ui/src/main/java/org/opendaylight/controller/swaggerui/BasePathModifierServlet.java b/opendaylight/adsal/northbound/swagger-ui/src/main/java/org/opendaylight/controller/swaggerui/BasePathModifierServlet.java
deleted file mode 100644 (file)
index 083a50c..0000000
+++ /dev/null
@@ -1,101 +0,0 @@
-package org.opendaylight.controller.swaggerui;
-
-import java.io.BufferedReader;
-import java.io.IOException;
-import java.io.InputStream;
-import java.io.InputStreamReader;
-import java.io.PrintWriter;
-
-import javax.servlet.ServletException;
-import javax.servlet.http.HttpServlet;
-import javax.servlet.http.HttpServletRequest;
-import javax.servlet.http.HttpServletResponse;
-
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import com.google.gson.JsonElement;
-import com.google.gson.JsonObject;
-import com.google.gson.JsonParser;
-
-/**
- * Servlet implementation class BasePathModifierServlet
- */
-public class BasePathModifierServlet extends HttpServlet {
-    private static final long serialVersionUID = 1L;
-    private static final Logger logger = LoggerFactory
-            .getLogger(BasePathModifierServlet.class);
-
-    private static final String API_BASE_PATH_SUFFIX = "/swagger/apis";
-    private static final String BASE_PATH_KEY = "basePath";
-
-    /**
-     * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse
-     *      response)
-     */
-    @Override
-    protected void doGet(HttpServletRequest request,
-            HttpServletResponse response) throws ServletException, IOException {
-        String resourcePath = request.getRequestURI().substring(
-                request.getContextPath().length());
-        logger.debug("Locating resource : {}.", resourcePath);
-        JsonObject jsonObject = null;
-        try {
-
-            InputStream stream = this.getServletContext().getResourceAsStream(
-                    resourcePath);
-            if (stream == null) {
-                response.sendError(HttpServletResponse.SC_NOT_FOUND,
-                        "API / API Listing not found");
-                return;
-            }
-            BufferedReader streamReader = new BufferedReader(
-                    new InputStreamReader(stream, "UTF-8"));
-            StringBuilder responseStrBuilder = new StringBuilder();
-
-            String inputStr;
-            while ((inputStr = streamReader.readLine()) != null)
-                responseStrBuilder.append(inputStr);
-
-            JsonElement jelement = new JsonParser().parse(responseStrBuilder
-                    .toString());
-            jsonObject = jelement.getAsJsonObject();
-
-            String basePath = jsonObject.get(BASE_PATH_KEY).getAsString();
-
-            // construct base path
-            StringBuilder requestURL = new StringBuilder();
-
-            requestURL.append(request.isSecure() ? "https://" : "http://")
-                    .append(request.getServerName()).append(":")
-                    .append(request.getServerPort());
-            if (!basePath.contains(requestURL)) {
-                String endPath = "";
-                if (basePath.contains(API_BASE_PATH_SUFFIX)) {
-                    endPath = basePath.substring(basePath
-                            .indexOf(API_BASE_PATH_SUFFIX));
-                }
-                basePath = requestURL + endPath;
-                logger.debug("Modified Base Path is {}", basePath);
-                jsonObject.addProperty(BASE_PATH_KEY, basePath);
-            }
-        } catch (Exception ex) {
-            logger.error("Error processing JSON data", ex);
-            response.sendError(HttpServletResponse.SC_INTERNAL_SERVER_ERROR,
-                    "Could not read API Listing or APIs");
-            return;
-        }
-
-        try {
-            response.setContentType("application/json");
-            PrintWriter out = response.getWriter();
-            out.print(jsonObject);
-            out.flush();
-        } catch (Exception ex) {
-            logger.error("Error while writing response", ex);
-            response.sendError(HttpServletResponse.SC_INTERNAL_SERVER_ERROR,
-                    "Internal Error while writing resposne");
-        }
-    }
-
-}
diff --git a/opendaylight/adsal/northbound/swagger-ui/src/main/resources/WEB-INF/web.xml b/opendaylight/adsal/northbound/swagger-ui/src/main/resources/WEB-INF/web.xml
deleted file mode 100644 (file)
index 6d02390..0000000
+++ /dev/null
@@ -1,23 +0,0 @@
-<?xml version="1.0" encoding="ISO-8859-1"?>
-<web-app xmlns="http://java.sun.com/xml/ns/javaee"
-         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
-         xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
-         version="3.0">
-  <servlet>
-     <servlet-name>BasePathModifierServlet</servlet-name>
-     <servlet-class>org.opendaylight.controller.swaggerui.BasePathModifierServlet</servlet-class>
-  </servlet>
-  <!-- Mapping for all northbound json files aka apis-->
-  <servlet-mapping>
-    <servlet-name>BasePathModifierServlet</servlet-name>
-    <url-pattern>/apis/*</url-pattern>
-  </servlet-mapping>
-  <!-- Mapping to get list of available NB apis -->
-  <servlet-mapping>
-    <servlet-name>BasePathModifierServlet</servlet-name>
-    <url-pattern>/apilist.json</url-pattern>
-  </servlet-mapping>
-  <welcome-file-list>
-    <welcome-file>index.html</welcome-file>
-  </welcome-file-list>
-</web-app>
diff --git a/opendaylight/adsal/northbound/swagger-ui/src/main/resources/css/custom.css b/opendaylight/adsal/northbound/swagger-ui/src/main/resources/css/custom.css
deleted file mode 100644 (file)
index e393943..0000000
+++ /dev/null
@@ -1,12 +0,0 @@
-body #header a#logo {
-    font-size: 1.5em;
-    font-weight: bold;
-    text-decoration: none;
-    background: transparent url(../images/logo.png) no-repeat left center;
-    padding: 20px 0 20px 70px;
-    color: white;
-}
-
-div.footer {
-    display: none;
-}
diff --git a/opendaylight/adsal/northbound/swagger-ui/src/main/resources/images/logo.png b/opendaylight/adsal/northbound/swagger-ui/src/main/resources/images/logo.png
deleted file mode 100644 (file)
index d49fb86..0000000
Binary files a/opendaylight/adsal/northbound/swagger-ui/src/main/resources/images/logo.png and /dev/null differ
diff --git a/opendaylight/adsal/northbound/swagger-ui/src/main/resources/index.html b/opendaylight/adsal/northbound/swagger-ui/src/main/resources/index.html
deleted file mode 100644 (file)
index bb5126c..0000000
+++ /dev/null
@@ -1,77 +0,0 @@
-<!DOCTYPE html>
-<html>
-<head>
-    <title>Swagger UI</title>
-    <link href='//fonts.googleapis.com/css?family=Droid+Sans:400,700' rel='stylesheet' type='text/css'/>
-    <link href='css/highlight.default.css' media='screen' rel='stylesheet' type='text/css'/>
-    <link href='css/screen.css' media='screen' rel='stylesheet' type='text/css'/>
-    <link href='css/custom.css' media='screen' rel='stylesheet' type='text/css'/>
-    <script src='lib/jquery-1.8.0.min.js' type='text/javascript'></script>
-    <script src='lib/jquery.slideto.min.js' type='text/javascript'></script>
-    <script src='lib/jquery.wiggle.min.js' type='text/javascript'></script>
-    <script src='lib/jquery.ba-bbq.min.js' type='text/javascript'></script>
-    <script src='lib/handlebars-1.0.rc.1.js' type='text/javascript'></script>
-    <script src='lib/underscore-min.js' type='text/javascript'></script>
-    <script src='lib/backbone-min.js' type='text/javascript'></script>
-    <script src='lib/swagger.js' type='text/javascript'></script>
-    <script src='swagger-ui.js' type='text/javascript'></script>
-    <script src='lib/highlight.7.3.pack.js' type='text/javascript'></script>
-
-    <script type="text/javascript">
-    $(function () {
-        window.swaggerUi = new SwaggerUi({
-                discoveryUrl:"./apilist.json",
-                apiKey:"",
-                dom_id:"swagger-ui-container",
-                supportHeaderParams: false,
-                supportedSubmitMethods: ['get', 'post', 'put', 'delete'],
-                onComplete: function(swaggerApi, swaggerUi){
-                    if(console) {
-                        console.log("Loaded SwaggerUI")
-                        console.log(swaggerApi);
-                        console.log(swaggerUi);
-                    }
-                  $('pre code').each(function(i, e) {hljs.highlightBlock(e)});
-                },
-                onFailure: function(data) {
-                    if(console) {
-                        console.log("Unable to Load SwaggerUI");
-                        console.log(data);
-                    }
-                },
-                docExpansion: "none"
-            });
-
-            window.swaggerUi.load();
-        });
-
-    </script>
-</head>
-
-<body>
-  <div id='header'>
-    <div class="swagger-ui-wrap">
-      <a id="logo" href="http://www.opendaylight.org/">ODL NB API</a>
-      <form id='api_selector'>
-        <div class='input'>
-          <input placeholder="http://example.com/api" id="input_baseUrl" name="baseUrl" type="text"/>
-        </div>
-        <div class='input'>
-          <input placeholder="api_key" id="input_apiKey" name="apiKey" type="text"/>
-        </div>
-        <div class='input'><a id="explore" href="#">Explore</a></div>
-      </form>
-    </div>
-  </div>
-
-  <div id="message-bar" class="swagger-ui-wrap">
-      &nbsp;
-  </div>
-
-  <div id="swagger-ui-container" class="swagger-ui-wrap">
-
-  </div>
-
-</body>
-
-</html>
diff --git a/opendaylight/adsal/northbound/switchmanager/enunciate.xml b/opendaylight/adsal/northbound/switchmanager/enunciate.xml
deleted file mode 100644 (file)
index 3db309d..0000000
+++ /dev/null
@@ -1,12 +0,0 @@
-<?xml version="1.0"?>
-<enunciate label="full" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
-    xsi:noNamespaceSchemaLocation="http://enunciate.codehaus.org/schemas/enunciate-1.28.xsd">
-
-  <services>
-    <rest defaultRestSubcontext="/controller/nb/v2/switchmanager"/>
-  </services>
-
-  <modules>
-    <docs docsDir="rest" title="Switch Manager REST API" includeExampleXml="true" includeExampleJson="true"/>
-  </modules>
-</enunciate>
diff --git a/opendaylight/adsal/northbound/switchmanager/pom.xml b/opendaylight/adsal/northbound/switchmanager/pom.xml
deleted file mode 100644 (file)
index 4710fea..0000000
+++ /dev/null
@@ -1,86 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>adsal-enunciate-parent</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../adsal-enunciate-parent</relativePath>
-  </parent>
-  <artifactId>switchmanager.northbound</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.codehaus.enunciate</groupId>
-      <artifactId>enunciate-core-annotations</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>commons.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>containermanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>switchmanager</artifactId>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Import-Package>org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.sal.utils,
-              org.opendaylight.controller.containermanager,
-              org.opendaylight.controller.switchmanager,
-              org.opendaylight.controller.usermanager,
-              org.apache.commons.lang3.tuple,
-              org.apache.commons.logging,
-              com.sun.jersey.spi.container.servlet,
-              org.opendaylight.controller.northbound.commons,
-              org.opendaylight.controller.northbound.commons.exception,
-              org.opendaylight.controller.northbound.commons.utils,
-              org.opendaylight.controller.sal.authorization,
-              org.opendaylight.controller.northbound.commons.query,
-              javax.ws.rs,
-              javax.ws.rs.ext,
-              javax.ws.rs.core,
-              javax.xml.bind.annotation,
-              javax.xml.bind,
-              org.slf4j,
-              org.apache.catalina.filters,
-              com.fasterxml.jackson.annotation,
-              com.fasterxml.jackson.databind,
-              !org.codehaus.enunciate.jaxrs</Import-Package>
-            <Web-ContextPath>/controller/nb/v2/switchmanager</Web-ContextPath>
-            <Jaxrs-Resources>,${classes;ANNOTATION;javax.ws.rs.Path}</Jaxrs-Resources>
-          </instructions>
-          <manifestLocation>${project.basedir}/src/main/resources/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/northbound/switchmanager/src/main/java/org/opendaylight/controller/switchmanager/northbound/NodeConnectorProperties.java b/opendaylight/adsal/northbound/switchmanager/src/main/java/org/opendaylight/controller/switchmanager/northbound/NodeConnectorProperties.java
deleted file mode 100644 (file)
index bb3fc0c..0000000
+++ /dev/null
@@ -1,83 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.switchmanager.northbound;
-
-import java.util.HashMap;
-import java.util.HashSet;
-import java.util.Map;
-import java.util.Set;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlElementWrapper;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.Property;
-
-import com.fasterxml.jackson.annotation.JsonIgnore;
-import com.fasterxml.jackson.annotation.JsonProperty;
-
-/**
- * The class describes set of properties attached to a node connector
- */
-
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-public class NodeConnectorProperties {
-    @XmlElement
-    private NodeConnector nodeconnector;
-
-    @XmlElement(name="property")
-    @XmlElementWrapper
-    @JsonIgnore
-    private Set<Property> properties;
-
-    // JAXB required constructor
-    private NodeConnectorProperties() {
-        this.nodeconnector = null;
-        this.properties = null;
-    }
-
-    public NodeConnectorProperties(NodeConnector nodeconnector, Set<Property> properties) {
-        this.nodeconnector = nodeconnector;
-        this.properties = properties;
-    }
-
-    @JsonProperty(value="properties")
-    public Map<String, Property> getMapProperties() {
-        Map<String, Property> map = new HashMap<String, Property>();
-        for (Property p : properties) {
-            map.put(p.getName(), p);
-        }
-        return map;
-    }
-
-    public void setMapProperties(Map<String, Property> propertiesMap) {
-        this.properties = new HashSet<Property>(propertiesMap.values());
-    }
-
-    public Set<Property> getProperties() {
-        return properties;
-    }
-
-    public void setProperties(Set<Property> properties) {
-        this.properties = properties;
-    }
-
-    public NodeConnector getNodeConnector() {
-        return nodeconnector;
-    }
-
-    public void setNodeConnector(NodeConnector nodeconnector) {
-        this.nodeconnector = nodeconnector;
-    }
-}
diff --git a/opendaylight/adsal/northbound/switchmanager/src/main/java/org/opendaylight/controller/switchmanager/northbound/NodeConnectors.java b/opendaylight/adsal/northbound/switchmanager/src/main/java/org/opendaylight/controller/switchmanager/northbound/NodeConnectors.java
deleted file mode 100644 (file)
index 32e1002..0000000
+++ /dev/null
@@ -1,40 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.switchmanager.northbound;
-
-import java.util.List;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-@XmlRootElement(name="list")
-@XmlAccessorType(XmlAccessType.NONE)
-
-public class NodeConnectors {
-        @XmlElement
-        List<NodeConnectorProperties> nodeConnectorProperties;
-        //To satisfy JAXB
-        private NodeConnectors() {
-
-        }
-
-        public NodeConnectors(List<NodeConnectorProperties> nodeConnectorProperties) {
-                this.nodeConnectorProperties = nodeConnectorProperties;
-        }
-
-        public List<NodeConnectorProperties> getNodeConnectorProperties() {
-                return nodeConnectorProperties;
-        }
-
-        public void setNodeConnectorProperties(List<NodeConnectorProperties> nodeConnectorProperties) {
-                this.nodeConnectorProperties = nodeConnectorProperties;
-        }
-}
diff --git a/opendaylight/adsal/northbound/switchmanager/src/main/java/org/opendaylight/controller/switchmanager/northbound/NodeProperties.java b/opendaylight/adsal/northbound/switchmanager/src/main/java/org/opendaylight/controller/switchmanager/northbound/NodeProperties.java
deleted file mode 100644 (file)
index 380d759..0000000
+++ /dev/null
@@ -1,83 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.switchmanager.northbound;
-
-import java.util.HashMap;
-import java.util.HashSet;
-import java.util.Map;
-import java.util.Set;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlElementWrapper;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.Property;
-
-import com.fasterxml.jackson.annotation.JsonIgnore;
-import com.fasterxml.jackson.annotation.JsonProperty;
-
-/**
- * The class describes set of properties attached to a node
- */
-
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-public class NodeProperties {
-    @XmlElement
-    private Node node;
-
-    @XmlElement(name="property")
-    @XmlElementWrapper
-    @JsonIgnore
-    private Set<Property> properties;
-
-    // JAXB required constructor
-    private NodeProperties() {
-        this.node = null;
-        this.properties = null;
-    }
-
-    public NodeProperties(Node node, Set<Property> properties) {
-        this.node = node;
-        this.properties = properties;
-    }
-
-    @JsonProperty(value="properties")
-    public Map<String, Property> getMapProperties() {
-        Map<String, Property> map = new HashMap<String, Property>();
-        for (Property p : properties) {
-            map.put(p.getName(), p);
-        }
-        return map;
-    }
-
-    public void setMapProperties(Map<String, Property> propertiesMap) {
-        this.properties = new HashSet<Property>(propertiesMap.values());
-    }
-
-    public Set<Property> getProperties() {
-        return properties;
-    }
-
-    public void setProperties(Set<Property> properties) {
-        this.properties = properties;
-    }
-
-    public Node getNode() {
-        return node;
-    }
-
-    public void setNode(Node node) {
-        this.node = node;
-    }
-}
diff --git a/opendaylight/adsal/northbound/switchmanager/src/main/java/org/opendaylight/controller/switchmanager/northbound/Nodes.java b/opendaylight/adsal/northbound/switchmanager/src/main/java/org/opendaylight/controller/switchmanager/northbound/Nodes.java
deleted file mode 100644 (file)
index 061e517..0000000
+++ /dev/null
@@ -1,40 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.switchmanager.northbound;
-
-import java.util.List;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-@XmlRootElement(name="list")
-@XmlAccessorType(XmlAccessType.NONE)
-
-public class Nodes {
-        @XmlElement
-        List<NodeProperties> nodeProperties;
-        //To satisfy JAXB
-        private Nodes() {
-
-        }
-
-        public Nodes(List<NodeProperties> nodeProperties) {
-                this.nodeProperties = nodeProperties;
-        }
-
-        public List<NodeProperties> getNodeProperties() {
-                return nodeProperties;
-        }
-
-        public void setNodeProperties(List<NodeProperties> nodeProperties) {
-                this.nodeProperties = nodeProperties;
-        }
-}
diff --git a/opendaylight/adsal/northbound/switchmanager/src/main/java/org/opendaylight/controller/switchmanager/northbound/SwitchNorthbound.java b/opendaylight/adsal/northbound/switchmanager/src/main/java/org/opendaylight/controller/switchmanager/northbound/SwitchNorthbound.java
deleted file mode 100644 (file)
index dab5d7d..0000000
+++ /dev/null
@@ -1,896 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.switchmanager.northbound;
-
-import java.util.ArrayList;
-import java.util.HashMap;
-import java.util.HashSet;
-import java.util.List;
-import java.util.Map;
-import java.util.Set;
-
-import javax.ws.rs.Consumes;
-import javax.ws.rs.DELETE;
-import javax.ws.rs.GET;
-import javax.ws.rs.POST;
-import javax.ws.rs.PUT;
-import javax.ws.rs.Path;
-import javax.ws.rs.PathParam;
-import javax.ws.rs.Produces;
-import javax.ws.rs.QueryParam;
-import javax.ws.rs.core.Context;
-import javax.ws.rs.core.MediaType;
-import javax.ws.rs.core.Response;
-import javax.ws.rs.core.SecurityContext;
-import javax.ws.rs.core.UriInfo;
-import javax.ws.rs.ext.ContextResolver;
-
-import org.codehaus.enunciate.jaxrs.ResponseCode;
-import org.codehaus.enunciate.jaxrs.StatusCodes;
-import org.codehaus.enunciate.jaxrs.TypeHint;
-import org.opendaylight.controller.containermanager.IContainerManager;
-import org.opendaylight.controller.northbound.commons.RestMessages;
-import org.opendaylight.controller.northbound.commons.exception.InternalServerErrorException;
-import org.opendaylight.controller.northbound.commons.exception.ResourceNotFoundException;
-import org.opendaylight.controller.northbound.commons.exception.ServiceUnavailableException;
-import org.opendaylight.controller.northbound.commons.exception.UnauthorizedException;
-import org.opendaylight.controller.northbound.commons.query.QueryContext;
-import org.opendaylight.controller.northbound.commons.utils.NorthboundUtils;
-import org.opendaylight.controller.sal.authorization.Privilege;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.utils.GlobalConstants;
-import org.opendaylight.controller.sal.utils.ServiceHelper;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.sal.utils.StatusCode;
-import org.opendaylight.controller.switchmanager.ISwitchManager;
-import org.opendaylight.controller.switchmanager.SwitchConfig;
-
-/**
- * The class provides Northbound REST APIs to access the nodes, node connectors
- * and their properties.
- *
- */
-
-@Path("/")
-public class SwitchNorthbound {
-
-    private String username;
-    private QueryContext queryContext;
-
-    @Context
-    public void setQueryContext(ContextResolver<QueryContext> queryCtxResolver) {
-      if (queryCtxResolver != null) {
-        queryContext = queryCtxResolver.getContext(QueryContext.class);
-      }
-    }
-
-    @Context
-    public void setSecurityContext(SecurityContext context) {
-        if (context != null && context.getUserPrincipal() != null) {
-            username = context.getUserPrincipal().getName();
-        }
-    }
-
-    protected String getUserName() {
-        return username;
-    }
-
-    private ISwitchManager getIfSwitchManagerService(String containerName) {
-        IContainerManager containerManager = (IContainerManager) ServiceHelper.getGlobalInstance(
-                IContainerManager.class, this);
-        if (containerManager == null) {
-            throw new ServiceUnavailableException("Container " + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        boolean found = false;
-        List<String> containerNames = containerManager.getContainerNames();
-        for (String cName : containerNames) {
-            if (cName.trim().equalsIgnoreCase(containerName.trim())) {
-                found = true;
-                break;
-            }
-        }
-
-        if (found == false) {
-            throw new ResourceNotFoundException(containerName + " " + RestMessages.NOCONTAINER.toString());
-        }
-
-        ISwitchManager switchManager = (ISwitchManager) ServiceHelper.getInstance(ISwitchManager.class, containerName,
-                this);
-
-        if (switchManager == null) {
-            throw new ServiceUnavailableException("Switch Manager " + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        return switchManager;
-    }
-
-    /**
-     *
-     * Retrieve a list of all the nodes and their properties in the network
-     *
-     * @param containerName
-     *            Name of the Container (Eg. 'default')
-     * @return A list of Pair each pair represents a
-     *         {@link org.opendaylight.controller.sal.core.Node} and Set of
-     *         {@link org.opendaylight.controller.sal.core.Property} attached to
-     *         it.
-     *
-     *         <pre>
-     *
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/switchmanager/default/nodes
-     *
-     * Response body in XML:
-     * &lt;?xml version="1.0" encoding="UTF-8" standalone="yes"?&gt;
-     * &lt;list&gt;
-     *     &#x20;&#x20;&#x20;&lt;nodeProperties&gt;
-     *         &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;node&gt;
-     *             &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;id&gt;00:00:00:00:00:00:00:02&lt;/id&gt;
-     *             &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;type&gt;OF&lt;/type&gt;
-     *         &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;/node&gt;
-     *         &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;properties&gt;
-     *             &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;tables&gt;
-     *                 &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;value&gt;-1&lt;/value&gt;
-     *             &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;/tables&gt;
-     *             &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;description&gt;
-     *                 &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;value&gt;Switch2&lt;/value&gt;
-     *             &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;/description&gt;
-     *             &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;actions&gt;
-     *                 &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;value&gt;4095&lt;/value&gt;
-     *             &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;/actions&gt;
-     *             &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;macAddress&gt;
-     *                 &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;value&gt;00:00:00:00:00:02&lt;/value&gt;
-     *             &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;/macAddress&gt;
-     *             &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;capabilities&gt;
-     *                 &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;value&gt;199&lt;/value&gt;
-     *             &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;/capabilities&gt;
-     *             &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;timeStamp&gt;
-     *                 &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;value&gt;1377291227877&lt;/value&gt;
-     *                 &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;name&gt;connectedSince&lt;/name&gt;
-     *             &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;/timeStamp&gt;
-     *             &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;buffers&gt;
-     *                 &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;value&gt;256&lt;/value&gt;
-     *             &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;/buffers&gt;
-     *         &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;/properties&gt;
-     *     &#x20;&#x20;&#x20;&lt;/nodeProperties&gt;
-     * &lt;/list&gt;
-     *
-     * Response body in JSON:
-     * {
-     *    "nodeProperties":[
-     *       {
-     *          "node":{
-     *             "id":"00:00:00:00:00:00:00:02",
-     *             "type":"OF"
-     *          },
-     *          "properties":{
-     *             "tables":{
-     *                "value":"-1"
-     *             },
-     *             "description":{
-     *                "value":"None"
-     *             },
-     *             "actions":{
-     *                "value":"4095"
-     *             },
-     *             "macAddress":{
-     *                "value":"00:00:00:00:00:02"
-     *             },
-     *             "capabilities":{
-     *                "value":"199"
-     *             },
-     *             "timeStamp":{
-     *                "value":"1377291227877",
-     *                "name":"connectedSince"
-     *             },
-     *             "buffers":{
-     *                "value":"256"
-     *             }
-     *          }
-     *       }
-     *    ]
-     * }
-     *
-     * </pre>
-     */
-    @Path("/{containerName}/nodes")
-    @GET
-    @Produces({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @TypeHint(Nodes.class)
-    @StatusCodes({ @ResponseCode(code = 200, condition = "Operation successful"),
-        @ResponseCode(code = 401, condition = "User not authorized to perform this operation"),
-        @ResponseCode(code = 404, condition = "The containerName is not found"),
-        @ResponseCode(code = 503, condition = "One or more of Controller Services are unavailable"),
-        @ResponseCode(code = 400, condition = "Incorrect query syntex") })
-    public Nodes getNodes(@PathParam("containerName") String containerName, @QueryParam("_q") String queryString) {
-
-        if (!isValidContainer(containerName)) {
-            throw new ResourceNotFoundException("Container " + containerName + " does not exist.");
-        }
-
-        if (!NorthboundUtils.isAuthorized(getUserName(), containerName, Privilege.READ, this)) {
-            throw new UnauthorizedException("User is not authorized to perform this operation on container "
-                    + containerName);
-        }
-
-        ISwitchManager switchManager = getIfSwitchManagerService(containerName);
-        if (switchManager == null) {
-            throw new ServiceUnavailableException("Switch Manager " + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        List<NodeProperties> res = new ArrayList<NodeProperties>();
-        Set<Node> nodes = switchManager.getNodes();
-        if (nodes == null) {
-            return new Nodes(res);
-        }
-
-        for (Node node : nodes) {
-            Map<String, Property> propMap = switchManager.getNodeProps(node);
-            if (propMap == null) {
-                continue;
-            }
-            Set<Property> props = new HashSet<Property>(propMap.values());
-
-            NodeProperties nodeProps = new NodeProperties(node, props);
-            res.add(nodeProps);
-        }
-        Nodes result = new Nodes(res);
-        if (queryString != null) {
-            queryContext.createQuery(queryString, Nodes.class)
-                .filter(result, NodeProperties.class);
-        }
-        return result;
-    }
-
-    /**
-     * Add a Description, Tier and Forwarding mode property to a node. This
-     * method returns a non-successful response if a node by that name already
-     * exists.
-     *
-     * @param containerName
-     *            Name of the Container (Eg. 'default')
-     * @param nodeType
-     *            Type of the node being programmed (Eg. 'OF')
-     * @param nodeId
-     *            Node Identifier as specified by
-     *            {@link org.opendaylight.controller.sal.core.Node} (Eg.
-     *            '00:00:00:00:00:00:00:03')
-     * @param propertyName
-     *            Name of the Property. Properties that can be configured are:
-     *            description, forwarding(only for default container) and tier
-     * @param propertyValue
-     *            Value of the Property. Description can be any string (Eg.
-     *            'Node1'), valid values for tier are non negative numbers, and
-     *            valid values for forwarding are 0 for reactive and 1 for
-     *            proactive forwarding.
-     * @return Response as dictated by the HTTP Response Status code
-     *
-     *         <pre>
-     *
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/switchmanager/default/node/OF/00:00:00:00:00:00:00:03/property/description/Switch3
-     *
-     * </pre>
-     */
-
-    @Path("/{containerName}/node/{nodeType}/{nodeId}/property/{propertyName}/{propertyValue}")
-    @PUT
-    @Consumes({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @TypeHint(Response.class)
-    @StatusCodes({
-        @ResponseCode(code = 201, condition = "Operation successful"),
-        @ResponseCode(code = 400, condition = "The nodeId or configuration is invalid"),
-        @ResponseCode(code = 401, condition = "User not authorized to perform this operation"),
-        @ResponseCode(code = 404, condition = "The Container Name or node or configuration name is not found"),
-        @ResponseCode(code = 406, condition = "The property cannot be configured in non-default container"),
-        @ResponseCode(code = 409, condition = "Unable to update configuration due to cluster conflict or conflicting description property"),
-        @ResponseCode(code = 503, condition = "One or more of Controller services are unavailable") })
-    public Response addNodeProperty(@Context UriInfo uriInfo, @PathParam("containerName") String containerName,
-            @PathParam("nodeType") String nodeType, @PathParam("nodeId") String nodeId,
-            @PathParam("propertyName") String propertyName, @PathParam("propertyValue") String propertyValue) {
-
-        if (!isValidContainer(containerName)) {
-            throw new ResourceNotFoundException("Container " + containerName + " does not exist.");
-        }
-        if (!NorthboundUtils.isAuthorized(getUserName(), containerName, Privilege.WRITE, this)) {
-            throw new UnauthorizedException("User is not authorized to perform this operation on container "
-                    + containerName);
-        }
-        ISwitchManager switchManager = getIfSwitchManagerService(containerName);
-        if (switchManager == null) {
-            throw new ServiceUnavailableException("Switch Manager " + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        handleNodeAvailability(containerName, nodeType, nodeId);
-        Node node = Node.fromString(nodeType, nodeId);
-        Property prop = switchManager.createProperty(propertyName, propertyValue);
-        if (prop == null) {
-            throw new ResourceNotFoundException("Property with name " + propertyName + " does not exist.");
-        }
-        SwitchConfig switchConfig = switchManager.getSwitchConfig(node.toString());
-        Map<String, Property> nodeProperties = (switchConfig == null) ? new HashMap<String, Property>()
-                : new HashMap<String, Property>(switchConfig.getNodeProperties());
-        nodeProperties.put(prop.getName(), prop);
-        SwitchConfig newSwitchConfig = new SwitchConfig(node.toString(), nodeProperties);
-        Status status = switchManager.updateNodeConfig(newSwitchConfig);
-        if (status.isSuccess()) {
-            NorthboundUtils.auditlog("Property " + propertyName, username, "updated",
-                    "of Node " + NorthboundUtils.getNodeDesc(node, switchManager), containerName);
-
-            return Response.created(uriInfo.getRequestUri()).build();
-        }
-        return NorthboundUtils.getResponse(status);
-    }
-
-    /**
-     * Delete a property of a node
-     *
-     * @param containerName
-     *            Name of the Container (Eg. 'SliceRed')
-     * @param nodeType
-     *            Type of the node being programmed (Eg. 'OF')
-     * @param nodeId
-     *            Node Identifier as specified by
-     *            {@link org.opendaylight.controller.sal.core.Node} (Eg.
-     *            '00:00:00:00:00:03:01:02')
-     * @param propertyName
-     *            Name of the Property. Properties that can be deleted are
-     *            description, forwarding(only in default container) and tier.
-     * @return Response as dictated by the HTTP Response Status code
-     *
-     *         <pre>
-     *
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/switchmanager/default/node/OF/00:00:00:00:00:00:00:03/property/forwarding
-     *
-     * </pre>
-     */
-
-    @Path("/{containerName}/node/{nodeType}/{nodeId}/property/{propertyName}")
-    @DELETE
-    @Consumes({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @StatusCodes({ @ResponseCode(code = 204, condition = "Property removed successfully"),
-        @ResponseCode(code = 400, condition = "The nodeId or configuration is invalid"),
-        @ResponseCode(code = 401, condition = "User not authorized to perform this operation"),
-        @ResponseCode(code = 404, condition = "The Container Name or nodeId or configuration name is not found"),
-        @ResponseCode(code = 409, condition = "Unable to delete property due to cluster conflict"),
-        @ResponseCode(code = 503, condition = "One or more of Controller services are unavailable") })
-    public Response deleteNodeProperty(@PathParam("containerName") String containerName,
-            @PathParam("nodeType") String nodeType, @PathParam("nodeId") String nodeId,
-            @PathParam("propertyName") String propertyName) {
-
-        if (!isValidContainer(containerName)) {
-            throw new ResourceNotFoundException("Container " + containerName + " does not exist.");
-        }
-        if (!NorthboundUtils.isAuthorized(getUserName(), containerName, Privilege.WRITE, this)) {
-            throw new UnauthorizedException("User is not authorized to perform this operation on container "
-                    + containerName);
-        }
-        ISwitchManager switchManager = getIfSwitchManagerService(containerName);
-        if (switchManager == null) {
-            throw new ServiceUnavailableException("Switch Manager " + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        handleNodeAvailability(containerName, nodeType, nodeId);
-        Node node = Node.fromString(nodeType, nodeId);
-
-        SwitchConfig switchConfig = switchManager.getSwitchConfig(node.toString());
-        Status status;
-        if (switchConfig == null) {
-            status = new Status(StatusCode.NOTFOUND, "Switch Configuration does not exist");
-        } else {
-            Map<String, Property> nodeProperties = new HashMap<String, Property>(switchConfig.getNodeProperties());
-            if (!nodeProperties.containsKey(propertyName.toLowerCase())) {
-                String msg = "Property " + propertyName + " does not exist or not configured for switch " + nodeId;
-                status = new Status(StatusCode.NOTFOUND, msg);
-            } else {
-                nodeProperties.remove(propertyName.toLowerCase());
-                SwitchConfig newSwitchConfig = new SwitchConfig(node.toString(), nodeProperties);
-                status = switchManager.updateNodeConfig(newSwitchConfig);
-                if (status.isSuccess()) {
-                    NorthboundUtils.auditlog("Property " + propertyName, username, "removed", "of Node "
-                            + NorthboundUtils.getNodeDesc(node, switchManager), containerName);
-                    return Response.noContent().build();
-                }
-            }
-        }
-        return NorthboundUtils.getResponse(status);
-    }
-
-    /**
-     * Get a property of a node
-     *
-     * @param containerName
-     *            Name of the Container (Eg. 'SliceRed')
-     * @param nodeType
-     *            Type of the node being programmed (Eg. 'OF')
-     * @param nodeId
-     *            Node Identifier as specified by
-     *            {@link org.opendaylight.controller.sal.core.Node} (Eg.
-     *            '00:00:00:00:00:03:01:02')
-     * @param propertyName
-     *            Name of the Property. Properties that can be deleted are
-     *            description, forwarding(only in default container) and tier.
-     * @return Property value of the property
-     *
-     *         <pre>
-     *
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/switchmanager/default/node/OF/00:00:00:00:00:00:00:01/property/description
-     *
-     * Response body in XML
-     * &lt;description&gt;
-     *     &#x20;&#x20;&lt;value&gt;switch1&lt;/value&gt;
-     * &lt;/description&gt;
-     *
-     * Response body in JSON
-     * {
-     *     &#x20;&#x20;"value": "switch1"
-     * }
-     * </pre>
-     */
-
-    @Path("/{containerName}/node/{nodeType}/{nodeId}/property/{propertyName}")
-    @GET
-    @Produces({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @TypeHint(String.class)
-    @StatusCodes({ @ResponseCode(code = 200, condition = "Operation successful"),
-        @ResponseCode(code = 401, condition = "User not authorized to perform this operation"),
-        @ResponseCode(code = 404, condition = "The containerName is not found"),
-        @ResponseCode(code = 503, condition = "One or more of Controller Services are unavailable") })
-    public Property getNodeProperty(@PathParam("containerName") String containerName,
-            @PathParam("nodeType") String nodeType, @PathParam("nodeId") String nodeId,
-            @PathParam("propertyName") String propertyName) {
-
-        if (!isValidContainer(containerName)) {
-            throw new ResourceNotFoundException("Container " + containerName + " does not exist.");
-        }
-        if (!NorthboundUtils.isAuthorized(getUserName(), containerName, Privilege.READ, this)) {
-            throw new UnauthorizedException("User is not authorized to perform this operation on container "
-                    + containerName);
-        }
-        ISwitchManager switchManager = getIfSwitchManagerService(containerName);
-        if (switchManager == null) {
-            throw new ServiceUnavailableException("Switch Manager " + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        handleNodeAvailability(containerName, nodeType, nodeId);
-        Node node = Node.fromString(nodeType, nodeId);
-        if (node == null) {
-            throw new ResourceNotFoundException(nodeId + " : " + RestMessages.NONODE.toString());
-        }
-        SwitchConfig switchConfig = switchManager.getSwitchConfig(node.toString());
-        if (switchConfig == null) {
-            throw new ResourceNotFoundException(nodeId + " : " + "Config Not Found" );
-        } else {
-            Map<String, Property> nodeProperties = new HashMap<String, Property>(switchConfig.getNodeProperties());
-            if (!nodeProperties.containsKey(propertyName.toLowerCase())) {
-                String msg = "Property " + propertyName + " does not exist or not "
-                        + "configured for switch " + nodeId;
-                throw new ResourceNotFoundException(msg);
-            } else {
-                return nodeProperties.get(propertyName.toLowerCase());
-            }
-        }
-    }
-
-    /**
-     *
-     * Retrieve a list of all the nodeconnectors and their properties in a given
-     * node
-     *
-     * @param containerName
-     *            The container for which we want to retrieve the list (Eg.
-     *            'default')
-     * @param nodeType
-     *            Type of the node being programmed (Eg. 'OF')
-     * @param nodeId
-     *            Node Identifier as specified by
-     *            {@link org.opendaylight.controller.sal.core.Node} (Eg.
-     *            '00:00:00:00:00:00:00:03')
-     * @return A List of Pair each pair represents a
-     *         {@link org.opendaylight.controller.sal.core.NodeConnector} and
-     *         its corresponding
-     *         {@link org.opendaylight.controller.sal.core.Property} attached to
-     *         it.
-     *
-     * <pre>
-     *
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/switchmanager/default/node/OF/00:00:00:00:00:00:00:01
-     *
-     * Response body in XML:
-     * &lt;?xml version="1.0" encoding="UTF-8" standalone="yes"?&gt;
-     * &lt;list&gt;
-     *     &#x20;&#x20;&#x20;&lt;nodeConnectorProperties&gt;
-     *         &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;nodeconnector&gt;
-     *             &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;node&gt;
-     *                 &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;id&gt;00:00:00:00:00:00:00:01&lt;/id&gt;
-     *                 &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;type&gt;OF&lt;/type&gt;
-     *             &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;/node&gt;
-     *             &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;id&gt;2&lt;/id&gt;
-     *             &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;type&gt;OF&lt;/type&gt;
-     *         &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;/nodeconnector&gt;
-     *         &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;properties&gt;
-     *             &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;state&gt;
-     *                 &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;value&gt;1&lt;/value&gt;
-     *             &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;/state&gt;
-     *             &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;config&gt;
-     *                 &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;value&gt;1&lt;/value&gt;
-     *             &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;/config&gt;
-     *             &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;name&gt;
-     *                 &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;value&gt;L1_2-C2_1&lt;/value&gt;
-     *             &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;/name&gt;
-     *         &#x20;&#x20;&#x20;&#x20;&#x20;&#x20;&lt;/properties&gt;
-     *     &#x20;&#x20;&#x20;&lt;/nodeConnectorProperties&gt;
-     * &lt;/list&gt;
-     *
-     * Response body in JSON:
-     * {
-     *    "nodeConnectorProperties":[
-     *       {
-     *          "nodeconnector":{
-     *             "node":{
-     *                "id":"00:00:00:00:00:00:00:01",
-     *                "type":"OF"
-     *             },
-     *             "id":"2",
-     *             "type":"OF"
-     *          },
-     *          "properties":{
-     *             "state":{
-     *                "value":"1"
-     *             },
-     *             "config":{
-     *                "value":"1"
-     *             },
-     *             "name":{
-     *                "value":"L1_2-C2_1"
-     *             }
-     *          }
-     *       }
-     *    ]
-     * }
-     *
-     * </pre>
-     */
-    @Path("/{containerName}/node/{nodeType}/{nodeId}")
-    @GET
-    @Produces({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @TypeHint(NodeConnectors.class)
-    @StatusCodes({ @ResponseCode(code = 200, condition = "Operation successful"),
-        @ResponseCode(code = 401, condition = "User not authorized to perform this operation"),
-        @ResponseCode(code = 404, condition = "The containerName is not found"),
-        @ResponseCode(code = 503, condition = "One or more of Controller Services are unavailable"),
-        @ResponseCode(code = 400, condition = "Incorrect query syntex") })
-    public NodeConnectors getNodeConnectors(@PathParam("containerName") String containerName,
-            @PathParam("nodeType") String nodeType, @PathParam("nodeId") String nodeId,
-            @QueryParam("_q") String queryString) {
-
-        if (!isValidContainer(containerName)) {
-            throw new ResourceNotFoundException("Container " + containerName + " does not exist.");
-        }
-        if (!NorthboundUtils.isAuthorized(getUserName(), containerName, Privilege.READ, this)) {
-            throw new UnauthorizedException("User is not authorized to perform this operation on container "
-                    + containerName);
-        }
-
-        ISwitchManager switchManager = getIfSwitchManagerService(containerName);
-        if (switchManager == null) {
-            throw new ServiceUnavailableException("Switch Manager " + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        handleNodeAvailability(containerName, nodeType, nodeId);
-        Node node = Node.fromString(nodeType, nodeId);
-        List<NodeConnectorProperties> res = new ArrayList<NodeConnectorProperties>();
-        Set<NodeConnector> ncs = switchManager.getNodeConnectors(node);
-        if (ncs == null) {
-            return null;
-        }
-
-        for (NodeConnector nc : ncs) {
-            Map<String, Property> propMap = switchManager.getNodeConnectorProps(nc);
-            if (propMap == null) {
-                continue;
-            }
-            Set<Property> props = new HashSet<Property>(propMap.values());
-            NodeConnectorProperties ncProps = new NodeConnectorProperties(nc, props);
-            res.add(ncProps);
-        }
-        NodeConnectors result = new NodeConnectors(res);
-        if (queryString != null) {
-            queryContext.createQuery(queryString, NodeConnectors.class)
-                .filter(result, NodeConnectorProperties.class);
-        }
-        return result;
-    }
-
-    /**
-     * Add node-connector property to a node connector. This method returns a
-     * non-successful response if a node connector by the given name already
-     * exists.
-     *
-     * @param containerName
-     *            Name of the Container (Eg. 'default')
-     * @param nodeType
-     *            Type of the node being programmed (Eg. 'OF')
-     * @param nodeId
-     *            Node Identifier as specified by
-     *            {@link org.opendaylight.controller.sal.core.Node} (Eg.
-     *            '00:00:00:00:00:00:00:03')
-     * @param nodeConnectorType
-     *            Type of the node connector being programmed (Eg. 'OF')
-     * @param nodeConnectorId
-     *            NodeConnector Identifier as specified by
-     *            {@link org.opendaylight.controller.sal.core.NodeConnector}.
-     *            (Eg. '2'). If nodeConnecterId contains forward slash(/),
-     *            replace forward slash with underscore(_) in the URL. (Eg. for
-     *            Ethernet1/2, use Ethernet1_2)
-     * @param propertyName
-     *            Name of the Property specified by
-     *            {@link org.opendaylight.controller.sal.core.Property} and its
-     *            extended classes Property that can be configured is bandwidth
-     * @param propertyValue
-     *            Value of the Property specified by
-     *            {@link org.opendaylight.controller.sal.core.Property} and its
-     *            extended classes
-     * @return Response as dictated by the HTTP Response Status code
-     *
-     * <pre>
-     *
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/switchmanager/default/nodeconnector/OF/00:00:00:00:00:00:00:01/OF/2/property/bandwidth/1
-     *
-     * </pre>
-     */
-
-    @Path("/{containerName}/nodeconnector/{nodeType}/{nodeId}/{nodeConnectorType}/{nodeConnectorId}/property/{propertyName}/{propertyValue}")
-    @PUT
-    @Consumes({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @StatusCodes({ @ResponseCode(code = 201, condition = "Operation successful"),
-        @ResponseCode(code = 401, condition = "User not authorized to perform this operation"),
-        @ResponseCode(code = 404, condition = "The Container Name or nodeId or configuration name is not found"),
-        @ResponseCode(code = 409, condition = "Unable to add property due to cluster conflict"),
-        @ResponseCode(code = 503, condition = "One or more of Controller services are unavailable") })
-    public Response addNodeConnectorProperty(@Context UriInfo uriInfo,
-            @PathParam("containerName") String containerName, @PathParam("nodeType") String nodeType,
-            @PathParam("nodeId") String nodeId, @PathParam("nodeConnectorType") String nodeConnectorType,
-            @PathParam("nodeConnectorId") String nodeConnectorId, @PathParam("propertyName") String propertyName,
-            @PathParam("propertyValue") String propertyValue) {
-
-        if (!isValidContainer(containerName)) {
-            throw new ResourceNotFoundException("Container " + containerName + " does not exist.");
-        }
-        if (!NorthboundUtils.isAuthorized(getUserName(), containerName, Privilege.WRITE, this)) {
-            throw new UnauthorizedException("User is not authorized to perform this operation on container "
-                    + containerName);
-        }
-
-        ISwitchManager switchManager = getIfSwitchManagerService(containerName);
-        if (switchManager == null) {
-            throw new ServiceUnavailableException("Switch Manager " + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        handleNodeAvailability(containerName, nodeType, nodeId);
-        Node node = Node.fromString(nodeType, nodeId);
-
-        if (nodeConnectorId.contains("_")) {
-            nodeConnectorId = nodeConnectorId.replace("_", "/");
-        }
-
-        handleNodeConnectorAvailability(containerName, node, nodeConnectorType, nodeConnectorId);
-        NodeConnector nc = NodeConnector.fromStringNoNode(nodeConnectorType, nodeConnectorId, node);
-
-        Property prop = switchManager.createProperty(propertyName, propertyValue);
-        if (prop == null) {
-            throw new ResourceNotFoundException(RestMessages.INVALIDDATA.toString());
-        }
-
-        Status ret = switchManager.addNodeConnectorProp(nc, prop);
-        if (ret.isSuccess()) {
-            NorthboundUtils.auditlog("Property " + propertyName, username, "updated", "of Node Connector "
-                    + NorthboundUtils.getPortName(nc, switchManager), containerName);
-            return Response.created(uriInfo.getRequestUri()).build();
-        }
-        throw new InternalServerErrorException(ret.getDescription());
-    }
-
-    /**
-     * Delete a property of a node connector
-     *
-     * @param containerName
-     *            Name of the Container (Eg. 'default')
-     * @param nodeType
-     *            Type of the node being programmed (Eg. 'OF')
-     * @param nodeId
-     *            Node Identifier as specified by
-     *            {@link org.opendaylight.controller.sal.core.Node} (Eg.
-     *            '00:00:00:00:00:00:00:01')
-     * @param nodeConnectorType
-     *            Type of the node connector being programmed (Eg. 'OF')
-     * @param nodeConnectorId
-     *            NodeConnector Identifier as specified by
-     *            {@link org.opendaylight.controller.sal.core.NodeConnector}
-     *            (Eg. '1'). If nodeConnecterId contains forward slash(/),
-     *            replace forward slash with underscore(_) in the URL. (Eg. for
-     *            Ethernet1/2, use Ethernet1_2)
-     * @param propertyName
-     *            Name of the Property specified by
-     *            {@link org.opendaylight.controller.sal.core.Property} and its
-     *            extended classes. Property that can be deleted is bandwidth
-     * @return Response as dictated by the HTTP Response Status code
-     *
-     * <pre>
-     *
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/switchmanager/default/nodeconnector/OF/00:00:00:00:00:00:00:01/OF/2/property/bandwidth
-     *
-     * </pre>
-     */
-
-    @Path("/{containerName}/nodeconnector/{nodeType}/{nodeId}/{nodeConnectorType}/{nodeConnectorId}/property/{propertyName}")
-    @DELETE
-    @Consumes({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @StatusCodes({ @ResponseCode(code = 204, condition = "Property removed successfully"),
-        @ResponseCode(code = 401, condition = "User not authorized to perform this operation"),
-        @ResponseCode(code = 404, condition = "The Container Name or nodeId or configuration name is not found"),
-        @ResponseCode(code = 503, condition = "One or more of Controller services are unavailable") })
-    public Response deleteNodeConnectorProperty(@PathParam("containerName") String containerName,
-            @PathParam("nodeType") String nodeType, @PathParam("nodeId") String nodeId,
-            @PathParam("nodeConnectorType") String nodeConnectorType,
-            @PathParam("nodeConnectorId") String nodeConnectorId, @PathParam("propertyName") String propertyName) {
-
-        if (!isValidContainer(containerName)) {
-            throw new ResourceNotFoundException("Container " + containerName + " does not exist.");
-        }
-        if (!NorthboundUtils.isAuthorized(getUserName(), containerName, Privilege.WRITE, this)) {
-            throw new UnauthorizedException("User is not authorized to perform this operation on container "
-                    + containerName);
-        }
-
-        ISwitchManager switchManager = getIfSwitchManagerService(containerName);
-        if (switchManager == null) {
-            throw new ServiceUnavailableException("Switch Manager " + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        handleNodeAvailability(containerName, nodeType, nodeId);
-        Node node = Node.fromString(nodeType, nodeId);
-
-        if (nodeConnectorId.contains("_")) {
-            nodeConnectorId = nodeConnectorId.replace("_", "/");
-        }
-
-        handleNodeConnectorAvailability(containerName, node, nodeConnectorType, nodeConnectorId);
-        NodeConnector nc = NodeConnector.fromStringNoNode(nodeConnectorType, nodeConnectorId, node);
-        Status ret = switchManager.removeNodeConnectorProp(nc, propertyName);
-        if (ret.isSuccess()) {
-            NorthboundUtils.auditlog("Property " + propertyName, username, "removed", "of Node Connector "
-                    + NorthboundUtils.getPortName(nc, switchManager), containerName);
-            return Response.noContent().build();
-        }
-        throw new ResourceNotFoundException(ret.getDescription());
-    }
-
-    /**
-     * Save the current switch configurations
-     *
-     * @param containerName
-     *            Name of the Container (Eg. 'default')
-     * @return Response as dictated by the HTTP Response Status code
-     *
-     *         <pre>
-     *
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/switchmanager/default/save
-     *
-     * </pre>
-     */
-    @Path("/{containerName}/save")
-    @POST
-    @Produces({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @StatusCodes({
-        @ResponseCode(code = 200, condition = "Operation successful"),
-        @ResponseCode(code = 401, condition = "User not authorized to perform this operation"),
-        @ResponseCode(code = 404, condition = "The containerName is not found"),
-        @ResponseCode(code = 500, condition = "Failed to save switch configuration. Failure Reason included in HTTP Error response"),
-        @ResponseCode(code = 503, condition = "One or more of Controller Services are unavailable") })
-    public Response saveSwitchConfig(@PathParam("containerName") String containerName) {
-
-        if (!isValidContainer(containerName)) {
-            throw new ResourceNotFoundException("Container " + containerName + " does not exist.");
-        }
-        if (!NorthboundUtils.isAuthorized(getUserName(), containerName, Privilege.WRITE, this)) {
-            throw new UnauthorizedException("User is not authorized to perform this operation on container "
-                    + containerName);
-        }
-        ISwitchManager switchManager = getIfSwitchManagerService(containerName);
-        if (switchManager == null) {
-            throw new ServiceUnavailableException("Switch Manager " + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        Status ret = switchManager.saveSwitchConfig();
-        if (ret.isSuccess()) {
-            return Response.ok().build();
-        }
-        throw new InternalServerErrorException(ret.getDescription());
-    }
-
-    private Node handleNodeAvailability(String containerName, String nodeType, String nodeId) {
-
-        Node node = Node.fromString(nodeType, nodeId);
-        if (node == null) {
-            throw new ResourceNotFoundException(nodeId + " : " + RestMessages.NONODE.toString());
-        }
-
-        ISwitchManager sm = (ISwitchManager) ServiceHelper.getInstance(ISwitchManager.class, containerName, this);
-
-        if (sm == null) {
-            throw new ServiceUnavailableException("Switch Manager " + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        if (!sm.getNodes().contains(node)) {
-            throw new ResourceNotFoundException(node.toString() + " : " + RestMessages.NONODE.toString());
-        }
-        return node;
-    }
-
-    private void handleNodeConnectorAvailability(String containerName, Node node, String nodeConnectorType,
-            String nodeConnectorId) {
-
-        NodeConnector nc = NodeConnector.fromStringNoNode(nodeConnectorType, nodeConnectorId, node);
-        if (nc == null) {
-            throw new ResourceNotFoundException(nc + " : " + RestMessages.NORESOURCE.toString());
-        }
-
-        ISwitchManager sm = (ISwitchManager) ServiceHelper.getInstance(ISwitchManager.class, containerName, this);
-
-        if (sm == null) {
-            throw new ServiceUnavailableException("Switch Manager " + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        if (!sm.getNodeConnectors(node).contains(nc)) {
-            throw new ResourceNotFoundException(nc.toString() + " : " + RestMessages.NORESOURCE.toString());
-        }
-    }
-
-    private boolean isValidContainer(String containerName) {
-        if (containerName.equals(GlobalConstants.DEFAULT.toString())) {
-            return true;
-        }
-        IContainerManager containerManager = (IContainerManager) ServiceHelper.getGlobalInstance(
-                IContainerManager.class, this);
-        if (containerManager == null) {
-            throw new InternalServerErrorException(RestMessages.INTERNALERROR.toString());
-        }
-        if (containerManager.getContainerNames().contains(containerName)) {
-            return true;
-        }
-        return false;
-    }
-
-}
diff --git a/opendaylight/adsal/northbound/switchmanager/src/main/resources/META-INF/spring.factories b/opendaylight/adsal/northbound/switchmanager/src/main/resources/META-INF/spring.factories
deleted file mode 100644 (file)
index 93db02e..0000000
+++ /dev/null
@@ -1 +0,0 @@
-org.springframework.beans.BeanInfoFactory=org.springframework.beans.ExtendedBeanInfoFactory
diff --git a/opendaylight/adsal/northbound/switchmanager/src/main/resources/META-INF/spring.handlers b/opendaylight/adsal/northbound/switchmanager/src/main/resources/META-INF/spring.handlers
deleted file mode 100644 (file)
index 957af91..0000000
+++ /dev/null
@@ -1,10 +0,0 @@
-http\://www.springframework.org/schema/context=org.springframework.context.config.ContextNamespaceHandler
-http\://www.springframework.org/schema/jee=org.springframework.ejb.config.JeeNamespaceHandler
-http\://www.springframework.org/schema/lang=org.springframework.scripting.config.LangNamespaceHandler
-http\://www.springframework.org/schema/task=org.springframework.scheduling.config.TaskNamespaceHandler
-http\://www.springframework.org/schema/cache=org.springframework.cache.config.CacheNamespaceHandler
-http\://www.springframework.org/schema/c=org.springframework.beans.factory.xml.SimpleConstructorNamespaceHandler
-http\://www.springframework.org/schema/p=org.springframework.beans.factory.xml.SimplePropertyNamespaceHandler
-http\://www.springframework.org/schema/util=org.springframework.beans.factory.xml.UtilNamespaceHandler
-http\://www.springframework.org/schema/mvc=org.springframework.web.servlet.config.MvcNamespaceHandler
-http\://www.springframework.org/schema/security=org.springframework.security.config.SecurityNamespaceHandler
diff --git a/opendaylight/adsal/northbound/switchmanager/src/main/resources/META-INF/spring.schemas b/opendaylight/adsal/northbound/switchmanager/src/main/resources/META-INF/spring.schemas
deleted file mode 100644 (file)
index d865edc..0000000
+++ /dev/null
@@ -1,49 +0,0 @@
-http\://www.springframework.org/schema/beans/spring-beans-2.0.xsd=org/springframework/beans/factory/xml/spring-beans-2.0.xsd
-http\://www.springframework.org/schema/beans/spring-beans-2.5.xsd=org/springframework/beans/factory/xml/spring-beans-2.5.xsd
-http\://www.springframework.org/schema/beans/spring-beans-3.0.xsd=org/springframework/beans/factory/xml/spring-beans-3.0.xsd
-http\://www.springframework.org/schema/beans/spring-beans-3.1.xsd=org/springframework/beans/factory/xml/spring-beans-3.1.xsd
-http\://www.springframework.org/schema/beans/spring-beans-3.2.xsd=org/springframework/beans/factory/xml/spring-beans-3.2.xsd
-http\://www.springframework.org/schema/beans/spring-beans.xsd=org/springframework/beans/factory/xml/spring-beans-3.2.xsd
-http\://www.springframework.org/schema/tool/spring-tool-2.0.xsd=org/springframework/beans/factory/xml/spring-tool-2.0.xsd
-http\://www.springframework.org/schema/tool/spring-tool-2.5.xsd=org/springframework/beans/factory/xml/spring-tool-2.5.xsd
-http\://www.springframework.org/schema/tool/spring-tool-3.0.xsd=org/springframework/beans/factory/xml/spring-tool-3.0.xsd
-http\://www.springframework.org/schema/tool/spring-tool-3.1.xsd=org/springframework/beans/factory/xml/spring-tool-3.1.xsd
-http\://www.springframework.org/schema/tool/spring-tool-3.2.xsd=org/springframework/beans/factory/xml/spring-tool-3.2.xsd
-http\://www.springframework.org/schema/tool/spring-tool.xsd=org/springframework/beans/factory/xml/spring-tool-3.2.xsd
-http\://www.springframework.org/schema/util/spring-util-2.0.xsd=org/springframework/beans/factory/xml/spring-util-2.0.xsd
-http\://www.springframework.org/schema/util/spring-util-2.5.xsd=org/springframework/beans/factory/xml/spring-util-2.5.xsd
-http\://www.springframework.org/schema/util/spring-util-3.0.xsd=org/springframework/beans/factory/xml/spring-util-3.0.xsd
-http\://www.springframework.org/schema/util/spring-util-3.1.xsd=org/springframework/beans/factory/xml/spring-util-3.1.xsd
-http\://www.springframework.org/schema/util/spring-util-3.2.xsd=org/springframework/beans/factory/xml/spring-util-3.2.xsd
-http\://www.springframework.org/schema/util/spring-util.xsd=org/springframework/beans/factory/xml/spring-util-3.2.xsd
-http\://www.springframework.org/schema/context/spring-context-2.5.xsd=org/springframework/context/config/spring-context-2.5.xsd
-http\://www.springframework.org/schema/context/spring-context-3.0.xsd=org/springframework/context/config/spring-context-3.0.xsd
-http\://www.springframework.org/schema/context/spring-context-3.1.xsd=org/springframework/context/config/spring-context-3.1.xsd
-http\://www.springframework.org/schema/context/spring-context-3.2.xsd=org/springframework/context/config/spring-context-3.2.xsd
-http\://www.springframework.org/schema/context/spring-context.xsd=org/springframework/context/config/spring-context-3.2.xsd
-http\://www.springframework.org/schema/jee/spring-jee-2.0.xsd=org/springframework/ejb/config/spring-jee-2.0.xsd
-http\://www.springframework.org/schema/jee/spring-jee-2.5.xsd=org/springframework/ejb/config/spring-jee-2.5.xsd
-http\://www.springframework.org/schema/jee/spring-jee-3.0.xsd=org/springframework/ejb/config/spring-jee-3.0.xsd
-http\://www.springframework.org/schema/jee/spring-jee-3.1.xsd=org/springframework/ejb/config/spring-jee-3.1.xsd
-http\://www.springframework.org/schema/jee/spring-jee-3.2.xsd=org/springframework/ejb/config/spring-jee-3.2.xsd
-http\://www.springframework.org/schema/jee/spring-jee.xsd=org/springframework/ejb/config/spring-jee-3.2.xsd
-http\://www.springframework.org/schema/lang/spring-lang-2.0.xsd=org/springframework/scripting/config/spring-lang-2.0.xsd
-http\://www.springframework.org/schema/lang/spring-lang-2.5.xsd=org/springframework/scripting/config/spring-lang-2.5.xsd
-http\://www.springframework.org/schema/lang/spring-lang-3.0.xsd=org/springframework/scripting/config/spring-lang-3.0.xsd
-http\://www.springframework.org/schema/lang/spring-lang-3.1.xsd=org/springframework/scripting/config/spring-lang-3.1.xsd
-http\://www.springframework.org/schema/lang/spring-lang-3.2.xsd=org/springframework/scripting/config/spring-lang-3.2.xsd
-http\://www.springframework.org/schema/lang/spring-lang.xsd=org/springframework/scripting/config/spring-lang-3.2.xsd
-http\://www.springframework.org/schema/task/spring-task-3.0.xsd=org/springframework/scheduling/config/spring-task-3.0.xsd
-http\://www.springframework.org/schema/task/spring-task-3.1.xsd=org/springframework/scheduling/config/spring-task-3.1.xsd
-http\://www.springframework.org/schema/task/spring-task-3.2.xsd=org/springframework/scheduling/config/spring-task-3.2.xsd
-http\://www.springframework.org/schema/task/spring-task.xsd=org/springframework/scheduling/config/spring-task-3.2.xsd
-http\://www.springframework.org/schema/cache/spring-cache-3.1.xsd=org/springframework/cache/config/spring-cache-3.1.xsd
-http\://www.springframework.org/schema/cache/spring-cache-3.2.xsd=org/springframework/cache/config/spring-cache-3.2.xsd
-http\://www.springframework.org/schema/cache/spring-cache.xsd=org/springframework/cache/config/spring-cache-3.2.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd=org/springframework/web/servlet/config/spring-mvc-3.0.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc-3.1.xsd=org/springframework/web/servlet/config/spring-mvc-3.1.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc-3.2.xsd=org/springframework/web/servlet/config/spring-mvc-3.2.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc.xsd=org/springframework/web/servlet/config/spring-mvc-3.2.xsd
-http\://www.springframework.org/schema/security/spring-security-3.1.xsd=org/springframework/security/config/spring-security-3.1.xsd
-http\://www.springframework.org/schema/security/spring-security-3.2.xsd=org/springframework/security/config/spring-security-3.2.xsd
-
diff --git a/opendaylight/adsal/northbound/switchmanager/src/main/resources/META-INF/spring.tooling b/opendaylight/adsal/northbound/switchmanager/src/main/resources/META-INF/spring.tooling
deleted file mode 100644 (file)
index 057d834..0000000
+++ /dev/null
@@ -1,39 +0,0 @@
-# Tooling related information for the beans namespace
-http\://www.springframework.org/schema/beans@name=beans Namespace
-http\://www.springframework.org/schema/beans@prefix=beans
-http\://www.springframework.org/schema/beans@icon=org/springframework/beans/factory/xml/spring-beans.gif
-
-# Tooling related information for the util namespace
-http\://www.springframework.org/schema/util@name=util Namespace
-http\://www.springframework.org/schema/util@prefix=util
-http\://www.springframework.org/schema/util@icon=org/springframework/beans/factory/xml/spring-util.gif
-
-# Tooling related information for the context namespace
-http\://www.springframework.org/schema/context@name=context Namespace
-http\://www.springframework.org/schema/context@prefix=context
-http\://www.springframework.org/schema/context@icon=org/springframework/context/config/spring-context.gif
-
-# Tooling related information for the jee namespace
-http\://www.springframework.org/schema/jee@name=jee Namespace
-http\://www.springframework.org/schema/jee@prefix=jee
-http\://www.springframework.org/schema/jee@icon=org/springframework/ejb/config/spring-jee.gif
-
-# Tooling related information for the scheduling namespace
-http\://www.springframework.org/schema/task@name=task Namespace
-http\://www.springframework.org/schema/task@prefix=task
-http\://www.springframework.org/schema/task@icon=org/springframework/scheduling/config/spring-task.gif
-
-# Tooling related information for the lang namespace
-http\://www.springframework.org/schema/lang@name=lang Namespace
-http\://www.springframework.org/schema/lang@prefix=lang
-http\://www.springframework.org/schema/lang@icon=org/springframework/scripting/config/spring-lang.gif
-
-# Tooling related information for the cache namespace
-http\://www.springframework.org/schema/cache@name=cache Namespace
-http\://www.springframework.org/schema/cache@prefix=cache
-http\://www.springframework.org/schema/cache@icon=org/springframework/cache/config/spring-cache.gif
-
-# Tooling related information for the mvc namespace
-http\://www.springframework.org/schema/mvc@name=mvc Namespace
-http\://www.springframework.org/schema/mvc@prefix=mvc
-http\://www.springframework.org/schema/mvc@icon=org/springframework/web/servlet/config/spring-mvc.gif
diff --git a/opendaylight/adsal/northbound/switchmanager/src/main/resources/WEB-INF/web.xml b/opendaylight/adsal/northbound/switchmanager/src/main/resources/WEB-INF/web.xml
deleted file mode 100644 (file)
index 2efd81c..0000000
+++ /dev/null
@@ -1,89 +0,0 @@
-<?xml version="1.0" encoding="ISO-8859-1"?>
-<web-app xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
-        xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
-        version="3.0">
-  <servlet>
-    <servlet-name>JAXRSSwitchManager</servlet-name>
-    <servlet-class>com.sun.jersey.spi.container.servlet.ServletContainer</servlet-class>
-    <init-param>
-      <param-name>javax.ws.rs.Application</param-name>
-      <param-value>org.opendaylight.controller.northbound.commons.NorthboundApplication</param-value>
-    </init-param>
-    <load-on-startup>1</load-on-startup>
-  </servlet>
-
-  <servlet-mapping>
-    <servlet-name>JAXRSSwitchManager</servlet-name>
-    <url-pattern>/*</url-pattern>
-  </servlet-mapping>
-
-        <filter>
-          <filter-name>CorsFilter</filter-name>
-          <filter-class>org.apache.catalina.filters.CorsFilter</filter-class>
-          <init-param>
-            <param-name>cors.allowed.origins</param-name>
-            <param-value>*</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.allowed.methods</param-name>
-            <param-value>GET,POST,HEAD,OPTIONS,PUT,DELETE</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.allowed.headers</param-name>
-            <param-value>Content-Type,X-Requested-With,accept,authorization, origin,Origin,Access-Control-Request-Method,Access-Control-Request-Headers</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.exposed.headers</param-name>
-            <param-value>Access-Control-Allow-Origin,Access-Control-Allow-Credentials</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.support.credentials</param-name>
-            <param-value>true</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.preflight.maxage</param-name>
-            <param-value>10</param-value>
-          </init-param>
-        </filter>
-        <filter-mapping>
-          <filter-name>CorsFilter</filter-name>
-          <url-pattern>/*</url-pattern>
-        </filter-mapping>
-
-        <security-constraint>
-          <web-resource-collection>
-            <web-resource-name>NB api</web-resource-name>
-            <url-pattern>/*</url-pattern>
-            <http-method>POST</http-method>
-            <http-method>GET</http-method>
-            <http-method>PUT</http-method>
-            <http-method>PATCH</http-method>
-            <http-method>DELETE</http-method>
-            <http-method>HEAD</http-method>
-          </web-resource-collection>
-          <auth-constraint>
-            <role-name>System-Admin</role-name>
-            <role-name>Network-Admin</role-name>
-            <role-name>Network-Operator</role-name>
-            <role-name>Container-User</role-name>
-          </auth-constraint>
-        </security-constraint>
-
-        <security-role>
-                <role-name>System-Admin</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Network-Admin</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Network-Operator</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Container-User</role-name>
-        </security-role>
-
-        <login-config>
-                <auth-method>BASIC</auth-method>
-                <realm-name>opendaylight</realm-name>
-        </login-config>
-</web-app>
\ No newline at end of file
diff --git a/opendaylight/adsal/northbound/switchmanager/src/test/java/org/opendaylight/controller/switchmanager/northbound/SwitchManagerNorthboundTest.java b/opendaylight/adsal/northbound/switchmanager/src/test/java/org/opendaylight/controller/switchmanager/northbound/SwitchManagerNorthboundTest.java
deleted file mode 100644 (file)
index 89a5c96..0000000
+++ /dev/null
@@ -1,80 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.switchmanager.northbound;
-
-
-import java.util.ArrayList;
-import java.util.HashSet;
-import java.util.List;
-import java.util.Set;
-
-import org.junit.Assert;
-import org.junit.Test;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.utils.NodeConnectorCreator;
-import org.opendaylight.controller.sal.utils.NodeCreator;
-
-public class SwitchManagerNorthboundTest {
-
-        @Test
-        public void testNodes() {
-                List<NodeProperties> nodeProperties = new ArrayList<NodeProperties>();
-                Nodes nodes = new Nodes(nodeProperties);
-                Assert.assertTrue(nodes.getNodeProperties().equals(nodeProperties));
-                nodes.setNodeProperties(null);
-                Assert.assertTrue(nodes.getNodeProperties() == null);
-        }
-
-        @Test
-        public void testNodeProperties() {
-                Node node = NodeCreator.createOFNode(1L);
-                NodeProperties np= new NodeProperties(node, null);
-                Assert.assertTrue(np.getNode().equals(node));
-                Assert.assertTrue(np.getProperties() == null);
-
-                Node node2 = NodeCreator.createOFNode(2L);
-                np.setNode(node2);
-                Assert.assertTrue(np.getNode().equals(node2));
-
-                Set<Property> props = new HashSet<Property>();
-                np.setProperties(props);
-                Assert.assertTrue(np.getProperties().equals(props));
-        }
-
-        @Test
-        public void testNodeConnectors() {
-                List<NodeConnectorProperties> nodeConnectorProperties = new ArrayList<NodeConnectorProperties>();
-                NodeConnectors ncs = new NodeConnectors(nodeConnectorProperties);
-                Assert.assertTrue(ncs.getNodeConnectorProperties().equals(nodeConnectorProperties));
-                ncs.setNodeConnectorProperties(null);
-                Assert.assertTrue(ncs.getNodeConnectorProperties() == null);
-        }
-
-        @Test
-        public void testNodeConnectorProperties() {
-                Node node = NodeCreator.createOFNode(1L);
-        NodeConnector port = NodeConnectorCreator.createOFNodeConnector(
-                (short) 24, node);
-
-        NodeConnectorProperties ncp= new NodeConnectorProperties(port, null);
-                Assert.assertTrue(ncp.getProperties() == null);
-                Assert.assertTrue(ncp.getNodeConnector().equals(port));
-
-        NodeConnector port2 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 33, node);
-                ncp.setNodeConnector(port2);
-                Assert.assertTrue(ncp.getNodeConnector().equals(port2));
-
-                Set<Property> props = new HashSet<Property>();
-                ncp.setProperties(props);
-                Assert.assertTrue(ncp.getProperties().equals(props));
-        }
-
-}
diff --git a/opendaylight/adsal/northbound/topology/enunciate.xml b/opendaylight/adsal/northbound/topology/enunciate.xml
deleted file mode 100644 (file)
index b70ea74..0000000
+++ /dev/null
@@ -1,12 +0,0 @@
-<?xml version="1.0"?>
-<enunciate label="full" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
-    xsi:noNamespaceSchemaLocation="http://enunciate.codehaus.org/schemas/enunciate-1.28.xsd">
-
-  <services>
-    <rest defaultRestSubcontext="/controller/nb/v2/topology"/>
-  </services>
-
-  <modules>
-    <docs docsDir="rest" title="Topology REST API" includeExampleXml="true" includeExampleJson="true"/>
-  </modules>
-</enunciate>
diff --git a/opendaylight/adsal/northbound/topology/pom.xml b/opendaylight/adsal/northbound/topology/pom.xml
deleted file mode 100644 (file)
index 21f73d5..0000000
+++ /dev/null
@@ -1,89 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>adsal-enunciate-parent</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../adsal-enunciate-parent</relativePath>
-  </parent>
-
-  <artifactId>topology.northbound</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.codehaus.enunciate</groupId>
-      <artifactId>enunciate-core-annotations</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>commons.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>containermanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>topologymanager</artifactId>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Export-Package></Export-Package>
-            <Import-Package>org.opendaylight.controller.containermanager,
-              org.opendaylight.controller.northbound.commons,
-              org.opendaylight.controller.northbound.commons.exception,
-              org.opendaylight.controller.northbound.commons.utils,
-              org.opendaylight.controller.northbound.commons.query,
-              org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.sal.packet,
-              org.opendaylight.controller.sal.authorization,
-              org.opendaylight.controller.sal.packet.address,
-              org.opendaylight.controller.sal.utils,
-              org.opendaylight.controller.switchmanager,
-              org.opendaylight.controller.usermanager,
-              org.opendaylight.controller.topologymanager,
-              com.sun.jersey.spi.container.servlet,
-              com.fasterxml.jackson.annotation,
-              javax.ws.rs,
-              javax.ws.rs.ext,
-              javax.ws.rs.core,
-              javax.xml.bind,
-              javax.xml.bind.annotation,
-              org.slf4j,
-              org.apache.catalina.filters,
-              com.fasterxml.jackson.jaxrs.base,
-              com.fasterxml.jackson.jaxrs.json,
-              !org.codehaus.enunciate.jaxrs</Import-Package>
-            <Web-ContextPath>/controller/nb/v2/topology</Web-ContextPath>
-            <Jaxrs-Resources>,${classes;ANNOTATION;javax.ws.rs.Path}</Jaxrs-Resources>
-          </instructions>
-          <manifestLocation>${project.basedir}/src/main/resources/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/northbound/topology/src/main/java/org/opendaylight/controller/topology/northbound/EdgeProperties.java b/opendaylight/adsal/northbound/topology/src/main/java/org/opendaylight/controller/topology/northbound/EdgeProperties.java
deleted file mode 100644 (file)
index d43b9bc..0000000
+++ /dev/null
@@ -1,78 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.topology.northbound;
-
-import java.util.HashMap;
-import java.util.HashSet;
-import java.util.Map;
-import java.util.Set;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlElementWrapper;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.sal.core.Edge;
-import org.opendaylight.controller.sal.core.Property;
-
-import com.fasterxml.jackson.annotation.JsonIgnore;
-import com.fasterxml.jackson.annotation.JsonProperty;
-
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-public class EdgeProperties {
-    @XmlElement
-    private Edge edge;
-
-    @XmlElement(name="property")
-    @XmlElementWrapper
-    @JsonIgnore
-    private Set<Property> properties;
-
-    // JAXB required constructor
-    private EdgeProperties() {
-        this.edge = null;
-        this.properties = null;
-    }
-
-    public EdgeProperties(Edge e, Set<Property> properties) {
-        this.edge = e;
-        this.properties = properties;
-    }
-
-    @JsonProperty(value="properties")
-    public Map<String, Property> getMapProperties() {
-        Map<String, Property> map = new HashMap<String, Property>();
-        for (Property p : properties) {
-            map.put(p.getName(), p);
-        }
-        return map;
-    }
-
-    public void setMapProperties(Map<String, Property> propertiesMap) {
-        this.properties = new HashSet<Property>(propertiesMap.values());
-    }
-
-    public Set<Property> getProperties() {
-        return properties;
-    }
-    public void setProperties(Set<Property> properties) {
-        this.properties = properties;
-    }
-
-    public Edge getEdge() {
-        return edge;
-    }
-
-    public void setEdge(Edge edge) {
-        this.edge = edge;
-    }
-}
diff --git a/opendaylight/adsal/northbound/topology/src/main/java/org/opendaylight/controller/topology/northbound/Topology.java b/opendaylight/adsal/northbound/topology/src/main/java/org/opendaylight/controller/topology/northbound/Topology.java
deleted file mode 100644 (file)
index 15548d9..0000000
+++ /dev/null
@@ -1,40 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.topology.northbound;
-
-import java.util.List;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-
-public class Topology {
-        @XmlElement
-        List<EdgeProperties> edgeProperties;
-        //To satisfy JAXB
-        private Topology() {
-
-        }
-
-        public Topology(List<EdgeProperties> edgeProperties) {
-                this.edgeProperties = edgeProperties;
-        }
-
-        public List<EdgeProperties> getEdgeProperties() {
-                return edgeProperties;
-        }
-
-        public void setEdgeProperties(List<EdgeProperties> edgeProperties) {
-                this.edgeProperties = edgeProperties;
-        }
-}
diff --git a/opendaylight/adsal/northbound/topology/src/main/java/org/opendaylight/controller/topology/northbound/TopologyNorthboundJAXRS.java b/opendaylight/adsal/northbound/topology/src/main/java/org/opendaylight/controller/topology/northbound/TopologyNorthboundJAXRS.java
deleted file mode 100644 (file)
index 3773070..0000000
+++ /dev/null
@@ -1,475 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.topology.northbound;
-
-import java.util.ArrayList;
-import java.util.List;
-import java.util.Map;
-import java.util.Set;
-import java.util.concurrent.ConcurrentMap;
-
-import javax.ws.rs.Consumes;
-import javax.ws.rs.DELETE;
-import javax.ws.rs.GET;
-import javax.ws.rs.PUT;
-import javax.ws.rs.Path;
-import javax.ws.rs.PathParam;
-import javax.ws.rs.Produces;
-import javax.ws.rs.QueryParam;
-import javax.ws.rs.core.Context;
-import javax.ws.rs.core.MediaType;
-import javax.ws.rs.core.Response;
-import javax.ws.rs.core.SecurityContext;
-import javax.ws.rs.ext.ContextResolver;
-
-import org.codehaus.enunciate.jaxrs.ResponseCode;
-import org.codehaus.enunciate.jaxrs.StatusCodes;
-import org.codehaus.enunciate.jaxrs.TypeHint;
-import org.opendaylight.controller.northbound.commons.RestMessages;
-import org.opendaylight.controller.northbound.commons.exception.InternalServerErrorException;
-import org.opendaylight.controller.northbound.commons.exception.ResourceNotFoundException;
-import org.opendaylight.controller.northbound.commons.exception.UnauthorizedException;
-import org.opendaylight.controller.northbound.commons.query.QueryContext;
-import org.opendaylight.controller.northbound.commons.utils.NorthboundUtils;
-import org.opendaylight.controller.sal.authorization.Privilege;
-import org.opendaylight.controller.sal.core.Edge;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.utils.ServiceHelper;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.topologymanager.ITopologyManager;
-import org.opendaylight.controller.topologymanager.TopologyUserLinkConfig;
-
-/**
- * Topology Northbound REST API
- *
- * <br>
- * <br>
- * Authentication scheme : <b>HTTP Basic</b><br>
- * Authentication realm : <b>opendaylight</b><br>
- * Transport : <b>HTTP and HTTPS</b><br>
- * <br>
- * HTTPS Authentication is disabled by default.
- */
-
-@Path("/")
-public class TopologyNorthboundJAXRS {
-
-    private String username;
-    private QueryContext queryContext;
-
-    @Context
-    public void setQueryContext(ContextResolver<QueryContext> queryCtxResolver) {
-      if (queryCtxResolver != null) {
-        queryContext = queryCtxResolver.getContext(QueryContext.class);
-      }
-    }
-    @Context
-    public void setSecurityContext(SecurityContext context) {
-        if (context != null && context.getUserPrincipal() != null) {
-            username = context.getUserPrincipal().getName();
-        }
-    }
-
-    protected String getUserName() {
-        return username;
-    }
-
-    /**
-     *
-     * Retrieve the Topology
-     *
-     * @param containerName
-     *            The container for which we want to retrieve the topology (Eg.
-     *            'default')
-     *
-     * @return A List of EdgeProps each EdgeProp represent an Edge of the graph
-     *         with the corresponding properties attached to it.
-     *
-     *         <pre>
-     *
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/topology/default
-     *
-     * Response body in XML:
-     * &lt;?xml version="1.0" encoding="UTF-8" standalone="yes"?&gt;
-     * &lt;topology&gt;
-     *     &lt;edgeProperties&gt;
-     *         &lt;edge&gt;
-     *             &lt;tailNodeConnector&gt;
-     *                 &lt;node&gt;
-     *                     &lt;id&gt;00:00:00:00:00:00:00:02&lt;/id&gt;
-     *                     &lt;type&gt;OF&lt;/type&gt;
-     *                 &lt;/node&gt;
-     *                 &lt;id&gt;2&lt;/id&gt;
-     *                 &lt;type&gt;OF&lt;/type&gt;
-     *             &lt;/tailNodeConnector&gt;
-     *             &lt;headNodeConnector&gt;
-     *                 &lt;node&gt;
-     *                     &lt;id&gt;00:00:00:00:00:00:00:51&lt;/id&gt;
-     *                     &lt;type&gt;OF&lt;/type&gt;
-     *                 &lt;/node&gt;
-     *                 &lt;id&gt;2&lt;/id&gt;
-     *                 &lt;type&gt;OF&lt;/type&gt;
-     *             &lt;/headNodeConnector&gt;
-     *         &lt;/edge&gt;
-     *         &lt;properties&gt;
-     *             &lt;state&gt;
-     *                 &lt;value&gt;1&lt;/value&gt;
-     *             &lt;/state&gt;
-     *             &lt;config&gt;
-     *                 &lt;value&gt;1&lt;/value&gt;
-     *             &lt;/config&gt;
-     *             &lt;name&gt;
-     *                 &lt;value&gt;C1_2-L2_2&lt;/value&gt;
-     *             &lt;/name&gt;
-     *             &lt;timeStamp&gt;
-     *                 &lt;value&gt;1377279422032&lt;/value&gt;
-     *                 &lt;name&gt;creation&lt;/name&gt;
-     *             &lt;/timeStamp&gt;
-     *         &lt;/properties&gt;
-     *     &lt;/edgeProperties&gt;
-     *     &lt;edgeProperties&gt;
-     *         &lt;edge&gt;
-     *             &lt;tailNodeConnector&gt;
-     *                 &lt;node&gt;
-     *                     &lt;id&gt;00:00:00:00:00:00:00:51&lt;/id&gt;
-     *                     &lt;type&gt;OF&lt;/type&gt;
-     *                 &lt;/node&gt;
-     *                 &lt;id&gt;2&lt;/id&gt;
-     *                 &lt;type&gt;OF&lt;/type&gt;
-     *             &lt;/tailNodeConnector&gt;
-     *             &lt;headNodeConnector&gt;
-     *                 &lt;node&gt;
-     *                     &lt;id&gt;00:00:00:00:00:00:00:02&lt;/id&gt;
-     *                     &lt;type&gt;OF&lt;/type&gt;
-     *                 &lt;/node&gt;
-     *                 &lt;id&gt;2&lt;/id&gt;
-     *                 &lt;type&gt;OF&lt;/type&gt;
-     *             &lt;/headNodeConnector&gt;
-     *         &lt;/edge&gt;
-     *         &lt;properties&gt;
-     *             &lt;state&gt;
-     *                 &lt;value&gt;1&lt;/value&gt;
-     *             &lt;/state&gt;
-     *             &lt;name&gt;
-     *                 &lt;value&gt;L2_2-C1_2&lt;/value&gt;
-     *             &lt;/name&gt;
-     *             &lt;config&gt;
-     *                 &lt;value&gt;1&lt;/value&gt;
-     *             &lt;/config&gt;
-     *             &lt;timeStamp&gt;
-     *                 &lt;value&gt;1377279423564&lt;/value&gt;
-     *                 &lt;name&gt;creation&lt;/name&gt;
-     *             &lt;/timeStamp&gt;
-     *         &lt;/properties&gt;
-     *     &lt;/edgeProperties&gt;
-     * &lt;/topology&gt;
-     *
-     * Response body in JSON:
-     * {
-     *    "edgeProperties":[
-     *       {
-     *          "edge":{
-     *             "tailNodeConnector":{
-     *                "node":{
-     *                   "id":"00:00:00:00:00:00:00:02",
-     *                   "type":"OF"
-     *                },
-     *                "id":"2",
-     *                "type":"OF"
-     *             },
-     *             "headNodeConnector":{
-     *                "node":{
-     *                   "id":"00:00:00:00:00:00:00:51",
-     *                   "type":"OF"
-     *                },
-     *                "id":"2",
-     *                "type":"OF"
-     *             }
-     *          },
-     *          "properties":{
-     *             "timeStamp": {
-     *                "value": 1379527162648,
-     *                "name": "creation",
-     *             },
-     *             "name": {
-     *                "value": "s2-eth3"
-     *             },
-     *             "state": {
-     *                "value": 1
-     *             },
-     *             "config": {
-     *                "value": 1
-     *             },
-     *             "bandwidth": {
-     *                "value": 10000000000
-     *             }
-     *          }
-     *       },
-     *       {
-     *          "edge":{
-     *             "tailNodeConnector":{
-     *                "node":{
-     *                   "id":"00:00:00:00:00:00:00:51",
-     *                   "type":"OF"
-     *                },
-     *                "id":"2",
-     *                "type":"OF"
-     *             },
-     *             "headNodeConnector":{
-     *                "node":{
-     *                   "id":"00:00:00:00:00:00:00:02",
-     *                   "type":"OF"
-     *                },
-     *                "id":"2",
-     *                "type":"OF"
-     *             }
-     *           },
-     *           "properties":{
-     *             "timeStamp": {
-     *                "value": 1379527162648,
-     *                "name": "creation",
-     *             }
-     *          }
-     *        }
-     *     ]
-     *  }
-     * </pre>
-     */
-    @Path("/{containerName}")
-    @GET
-    @Produces({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @TypeHint(Topology.class)
-    @StatusCodes({ @ResponseCode(code = 404, condition = "The Container Name was not found") })
-    public Topology getTopology(@PathParam("containerName") String containerName,
-        @QueryParam("_q") String queryString) {
-
-        if (!NorthboundUtils.isAuthorized(getUserName(), containerName, Privilege.READ, this)) {
-            throw new UnauthorizedException("User is not authorized to perform this operation on container "
-                    + containerName);
-        }
-        ITopologyManager topologyManager = (ITopologyManager) ServiceHelper.getInstance(ITopologyManager.class,
-                containerName, this);
-        if (topologyManager == null) {
-            throw new ResourceNotFoundException(RestMessages.NOCONTAINER.toString());
-        }
-
-        Map<Edge, Set<Property>> topo = topologyManager.getEdges();
-        if (topo == null) {
-            return null;
-        }
-        List<EdgeProperties> res = new ArrayList<EdgeProperties>();
-        for (Map.Entry<Edge, Set<Property>> entry : topo.entrySet()) {
-            EdgeProperties el = new EdgeProperties(entry.getKey(), entry.getValue());
-            res.add(el);
-        }
-        Topology result = new Topology(res);
-
-        if (queryString != null) {
-            queryContext.createQuery(queryString, Topology.class)
-                .filter(result, EdgeProperties.class);
-        }
-        return result;
-    }
-
-    /**
-     * Retrieve the user configured links
-     *
-     * @param containerName
-     *            The container for which we want to retrieve the user links
-     *            (Eg. 'default')
-     *
-     * @return A List of user configured links
-     *
-     *         <pre>
-     *
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/topology/default/userLinks
-     *
-     * Response body in XML:
-     * &lt;?xml version="1.0" encoding="UTF-8" standalone="yes"?&gt;
-     * &lt;list&gt;
-     * &lt;userLinks&gt;
-     * &lt;status&gt;Success&lt;/status&gt;
-     * &lt;name&gt;link1&lt;/name&gt;
-     * &lt;srcNodeConnector&gt;OF|2@OF|00:00:00:00:00:00:00:02&lt;/srcNodeConnector&gt;
-     * &lt;dstNodeConnector&gt;OF|2@OF|00:00:00:00:00:00:00:51&lt;/dstNodeConnector&gt;
-     * &lt;/userLinks&gt;
-     * &lt;/list&gt;
-     *
-     * Response body in JSON:
-    * {
-     *   "userLinks": [
-     *    {
-     *      "status": "Success",
-     *      "name": "link1",
-     *      "srcNodeConnector": "OF|2@OF|00:00:00:00:00:00:00:02",
-     *      "dstNodeConnector": "OF|5@OF|00:00:00:00:00:00:00:05"
-     *    }
-     *  ]
-     * }
-     *
-     * </pre>
-     */
-    @Path("/{containerName}/userLinks")
-    @GET
-    @Produces({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @TypeHint(TopologyUserLinks.class)
-    @StatusCodes({ @ResponseCode(code = 404, condition = "The Container Name was not found") })
-    public TopologyUserLinks getUserLinks(@PathParam("containerName") String containerName,
-        @QueryParam("_q") String queryString) {
-
-        if (!NorthboundUtils.isAuthorized(getUserName(), containerName, Privilege.READ, this)) {
-            throw new UnauthorizedException("User is not authorized to perform this operation on container "
-                    + containerName);
-        }
-        ITopologyManager topologyManager = (ITopologyManager) ServiceHelper.getInstance(ITopologyManager.class,
-                containerName, this);
-        if (topologyManager == null) {
-            throw new ResourceNotFoundException(RestMessages.NOCONTAINER.toString());
-        }
-
-        ConcurrentMap<String, TopologyUserLinkConfig> userLinks = topologyManager.getUserLinks();
-        if ((userLinks == null) || (userLinks.values() == null)) {
-            return null;
-        }
-        TopologyUserLinks result = new TopologyUserLinks(
-                new ArrayList<TopologyUserLinkConfig>(userLinks.values()));
-        if (queryString != null) {
-            queryContext.createQuery(queryString, TopologyUserLinks.class)
-                .filter(result, TopologyUserLinkConfig.class);
-        }
-        return result;
-    }
-
-    /**
-     * Add an User Link
-     *
-     * @param containerName
-     *            Name of the Container (Eg. 'default')
-     * @param name
-     *            Name of the user link
-     * @param TopologyUserLinkConfig
-     *            in JSON or XML format
-     * @return Response as dictated by the HTTP Response Status code
-     *
-     *         <pre>
-     *
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/topology/default/userLink/link1
-     *
-     * Request body in XML:
-     * &lt;?xml version="1.0" encoding="UTF-8" standalone="yes"?&gt;
-     * &lt;topologyUserLinkConfig&gt;
-     * &lt;status&gt;Success&lt;/status&gt;
-     * &lt;name&gt;link1&lt;/name&gt;
-     * &lt;srcNodeConnector&gt;OF|2@OF|00:00:00:00:00:00:00:02&lt;/srcNodeConnector&gt;
-     * &lt;dstNodeConnector&gt;OF|2@OF|00:00:00:00:00:00:00:51&lt;/dstNodeConnector&gt;
-     * &lt;/topologyUserLinkConfig&gt;
-     *
-     * Request body in JSON:
-     * {
-     *    "status":"Success",
-     *    "name":"link1",
-     *    "srcNodeConnector":"OF|2@OF|00:00:00:00:00:00:00:02",
-     *    "dstNodeConnector":"OF|2@OF|00:00:00:00:00:00:00:51"
-     * }
-     *
-     * </pre>
-     */
-    @Path("/{containerName}/userLink/{name}")
-    @PUT
-    @Consumes({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @Produces({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @StatusCodes({
-        @ResponseCode(code = 201, condition = "User Link added successfully"),
-        @ResponseCode(code = 404, condition = "The Container Name was not found"),
-        @ResponseCode(code = 409, condition = "Failed to add User Link due to Conflicting Name"),
-        @ResponseCode(code = 500, condition = "Failed to add User Link. Failure Reason included in HTTP Error response"),
-        @ResponseCode(code = 503, condition = "One or more of Controller services are unavailable") })
-    public Response addUserLink(@PathParam(value = "containerName") String containerName,
-            @PathParam(value = "name") String name,
-            @TypeHint(TopologyUserLinkConfig.class) TopologyUserLinkConfig userLinkConfig) {
-
-        if (!NorthboundUtils.isAuthorized(getUserName(), containerName, Privilege.WRITE, this)) {
-            throw new UnauthorizedException("User is not authorized to perform this operation on container "
-                    + containerName);
-        }
-        ITopologyManager topologyManager = (ITopologyManager) ServiceHelper.getInstance(ITopologyManager.class,
-                containerName, this);
-        if (topologyManager == null) {
-            throw new ResourceNotFoundException(RestMessages.NOCONTAINER.toString());
-        }
-
-        Status status = topologyManager.addUserLink(userLinkConfig);
-        if (status.isSuccess()) {
-            NorthboundUtils
-            .auditlog(
-                    "User Link",username,"added", userLinkConfig.getName() + " from " + NorthboundUtils.getPortName(
-                            NodeConnector.fromString(userLinkConfig.getSrcNodeConnector()),
-                            containerName, this) + " to "
-                            + NorthboundUtils.getPortName(NodeConnector.fromString
-                                    (userLinkConfig.getDstNodeConnector()),containerName, this), containerName);
-            return Response.status(Response.Status.CREATED).build();
-        }
-        throw new InternalServerErrorException(status.getDescription());
-    }
-
-    /**
-     * Delete an User Link
-     *
-     * @param containerName
-     *            Name of the Container (Eg. 'default')
-     * @param name
-     *            Name of the Link Configuration (Eg. 'config1')
-     * @return Response as dictated by the HTTP Response Status code
-     *
-     *         <pre>
-     *
-     * Example:
-     *
-     * Request URL:
-     * http://localhost:8080/controller/nb/v2/topology/default/userLink/config1
-     *
-     * </pre>
-     */
-    @Path("/{containerName}/userLink/{name}")
-    @DELETE
-    @Consumes({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @Produces({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @StatusCodes({ @ResponseCode(code = 204, condition = "User link removed successfully"),
-        @ResponseCode(code = 404, condition = "The Container Name or Link Configuration Name was not found"),
-        @ResponseCode(code = 503, condition = "One or more of Controller services are unavailable") })
-    public Response deleteUserLink(@PathParam("containerName") String containerName, @PathParam("name") String name) {
-
-        if (!NorthboundUtils.isAuthorized(getUserName(), containerName, Privilege.WRITE, this)) {
-            throw new UnauthorizedException("User is not authorized to perform this operation on container "
-                    + containerName);
-        }
-        ITopologyManager topologyManager = (ITopologyManager) ServiceHelper.getInstance(ITopologyManager.class,
-                containerName, this);
-        if (topologyManager == null) {
-            throw new ResourceNotFoundException(RestMessages.NOCONTAINER.toString());
-        }
-
-        Status ret = topologyManager.deleteUserLink(name);
-        if (ret.isSuccess()) {
-            NorthboundUtils.auditlog("User Link", username, "removed", name, containerName);
-            return Response.noContent().build();
-        }
-        return NorthboundUtils.getResponse(ret);
-    }
-}
diff --git a/opendaylight/adsal/northbound/topology/src/main/java/org/opendaylight/controller/topology/northbound/TopologyUserLinks.java b/opendaylight/adsal/northbound/topology/src/main/java/org/opendaylight/controller/topology/northbound/TopologyUserLinks.java
deleted file mode 100644 (file)
index dee2e24..0000000
+++ /dev/null
@@ -1,44 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.topology.northbound;
-
-import java.util.ArrayList;
-import java.util.List;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.topologymanager.TopologyUserLinkConfig;
-
-@XmlRootElement (name = "list")
-@XmlAccessorType(XmlAccessType.NONE)
-
-public class TopologyUserLinks {
-        @XmlElement
-        List<TopologyUserLinkConfig> userLinks;
-
-        //To satisfy JAXB
-        private TopologyUserLinks() {
-
-        }
-
-        public List<TopologyUserLinkConfig> getUserLinks() {
-                return userLinks;
-        }
-
-        public void setUserLinks(List<TopologyUserLinkConfig> userLinks) {
-                this.userLinks = userLinks;
-        }
-
-        public TopologyUserLinks(List<TopologyUserLinkConfig> userLinks) {
-                this.userLinks = new ArrayList<TopologyUserLinkConfig>(userLinks);
-        }
-}
diff --git a/opendaylight/adsal/northbound/topology/src/main/resources/META-INF/spring.factories b/opendaylight/adsal/northbound/topology/src/main/resources/META-INF/spring.factories
deleted file mode 100644 (file)
index 93db02e..0000000
+++ /dev/null
@@ -1 +0,0 @@
-org.springframework.beans.BeanInfoFactory=org.springframework.beans.ExtendedBeanInfoFactory
diff --git a/opendaylight/adsal/northbound/topology/src/main/resources/META-INF/spring.handlers b/opendaylight/adsal/northbound/topology/src/main/resources/META-INF/spring.handlers
deleted file mode 100644 (file)
index 957af91..0000000
+++ /dev/null
@@ -1,10 +0,0 @@
-http\://www.springframework.org/schema/context=org.springframework.context.config.ContextNamespaceHandler
-http\://www.springframework.org/schema/jee=org.springframework.ejb.config.JeeNamespaceHandler
-http\://www.springframework.org/schema/lang=org.springframework.scripting.config.LangNamespaceHandler
-http\://www.springframework.org/schema/task=org.springframework.scheduling.config.TaskNamespaceHandler
-http\://www.springframework.org/schema/cache=org.springframework.cache.config.CacheNamespaceHandler
-http\://www.springframework.org/schema/c=org.springframework.beans.factory.xml.SimpleConstructorNamespaceHandler
-http\://www.springframework.org/schema/p=org.springframework.beans.factory.xml.SimplePropertyNamespaceHandler
-http\://www.springframework.org/schema/util=org.springframework.beans.factory.xml.UtilNamespaceHandler
-http\://www.springframework.org/schema/mvc=org.springframework.web.servlet.config.MvcNamespaceHandler
-http\://www.springframework.org/schema/security=org.springframework.security.config.SecurityNamespaceHandler
diff --git a/opendaylight/adsal/northbound/topology/src/main/resources/META-INF/spring.schemas b/opendaylight/adsal/northbound/topology/src/main/resources/META-INF/spring.schemas
deleted file mode 100644 (file)
index d865edc..0000000
+++ /dev/null
@@ -1,49 +0,0 @@
-http\://www.springframework.org/schema/beans/spring-beans-2.0.xsd=org/springframework/beans/factory/xml/spring-beans-2.0.xsd
-http\://www.springframework.org/schema/beans/spring-beans-2.5.xsd=org/springframework/beans/factory/xml/spring-beans-2.5.xsd
-http\://www.springframework.org/schema/beans/spring-beans-3.0.xsd=org/springframework/beans/factory/xml/spring-beans-3.0.xsd
-http\://www.springframework.org/schema/beans/spring-beans-3.1.xsd=org/springframework/beans/factory/xml/spring-beans-3.1.xsd
-http\://www.springframework.org/schema/beans/spring-beans-3.2.xsd=org/springframework/beans/factory/xml/spring-beans-3.2.xsd
-http\://www.springframework.org/schema/beans/spring-beans.xsd=org/springframework/beans/factory/xml/spring-beans-3.2.xsd
-http\://www.springframework.org/schema/tool/spring-tool-2.0.xsd=org/springframework/beans/factory/xml/spring-tool-2.0.xsd
-http\://www.springframework.org/schema/tool/spring-tool-2.5.xsd=org/springframework/beans/factory/xml/spring-tool-2.5.xsd
-http\://www.springframework.org/schema/tool/spring-tool-3.0.xsd=org/springframework/beans/factory/xml/spring-tool-3.0.xsd
-http\://www.springframework.org/schema/tool/spring-tool-3.1.xsd=org/springframework/beans/factory/xml/spring-tool-3.1.xsd
-http\://www.springframework.org/schema/tool/spring-tool-3.2.xsd=org/springframework/beans/factory/xml/spring-tool-3.2.xsd
-http\://www.springframework.org/schema/tool/spring-tool.xsd=org/springframework/beans/factory/xml/spring-tool-3.2.xsd
-http\://www.springframework.org/schema/util/spring-util-2.0.xsd=org/springframework/beans/factory/xml/spring-util-2.0.xsd
-http\://www.springframework.org/schema/util/spring-util-2.5.xsd=org/springframework/beans/factory/xml/spring-util-2.5.xsd
-http\://www.springframework.org/schema/util/spring-util-3.0.xsd=org/springframework/beans/factory/xml/spring-util-3.0.xsd
-http\://www.springframework.org/schema/util/spring-util-3.1.xsd=org/springframework/beans/factory/xml/spring-util-3.1.xsd
-http\://www.springframework.org/schema/util/spring-util-3.2.xsd=org/springframework/beans/factory/xml/spring-util-3.2.xsd
-http\://www.springframework.org/schema/util/spring-util.xsd=org/springframework/beans/factory/xml/spring-util-3.2.xsd
-http\://www.springframework.org/schema/context/spring-context-2.5.xsd=org/springframework/context/config/spring-context-2.5.xsd
-http\://www.springframework.org/schema/context/spring-context-3.0.xsd=org/springframework/context/config/spring-context-3.0.xsd
-http\://www.springframework.org/schema/context/spring-context-3.1.xsd=org/springframework/context/config/spring-context-3.1.xsd
-http\://www.springframework.org/schema/context/spring-context-3.2.xsd=org/springframework/context/config/spring-context-3.2.xsd
-http\://www.springframework.org/schema/context/spring-context.xsd=org/springframework/context/config/spring-context-3.2.xsd
-http\://www.springframework.org/schema/jee/spring-jee-2.0.xsd=org/springframework/ejb/config/spring-jee-2.0.xsd
-http\://www.springframework.org/schema/jee/spring-jee-2.5.xsd=org/springframework/ejb/config/spring-jee-2.5.xsd
-http\://www.springframework.org/schema/jee/spring-jee-3.0.xsd=org/springframework/ejb/config/spring-jee-3.0.xsd
-http\://www.springframework.org/schema/jee/spring-jee-3.1.xsd=org/springframework/ejb/config/spring-jee-3.1.xsd
-http\://www.springframework.org/schema/jee/spring-jee-3.2.xsd=org/springframework/ejb/config/spring-jee-3.2.xsd
-http\://www.springframework.org/schema/jee/spring-jee.xsd=org/springframework/ejb/config/spring-jee-3.2.xsd
-http\://www.springframework.org/schema/lang/spring-lang-2.0.xsd=org/springframework/scripting/config/spring-lang-2.0.xsd
-http\://www.springframework.org/schema/lang/spring-lang-2.5.xsd=org/springframework/scripting/config/spring-lang-2.5.xsd
-http\://www.springframework.org/schema/lang/spring-lang-3.0.xsd=org/springframework/scripting/config/spring-lang-3.0.xsd
-http\://www.springframework.org/schema/lang/spring-lang-3.1.xsd=org/springframework/scripting/config/spring-lang-3.1.xsd
-http\://www.springframework.org/schema/lang/spring-lang-3.2.xsd=org/springframework/scripting/config/spring-lang-3.2.xsd
-http\://www.springframework.org/schema/lang/spring-lang.xsd=org/springframework/scripting/config/spring-lang-3.2.xsd
-http\://www.springframework.org/schema/task/spring-task-3.0.xsd=org/springframework/scheduling/config/spring-task-3.0.xsd
-http\://www.springframework.org/schema/task/spring-task-3.1.xsd=org/springframework/scheduling/config/spring-task-3.1.xsd
-http\://www.springframework.org/schema/task/spring-task-3.2.xsd=org/springframework/scheduling/config/spring-task-3.2.xsd
-http\://www.springframework.org/schema/task/spring-task.xsd=org/springframework/scheduling/config/spring-task-3.2.xsd
-http\://www.springframework.org/schema/cache/spring-cache-3.1.xsd=org/springframework/cache/config/spring-cache-3.1.xsd
-http\://www.springframework.org/schema/cache/spring-cache-3.2.xsd=org/springframework/cache/config/spring-cache-3.2.xsd
-http\://www.springframework.org/schema/cache/spring-cache.xsd=org/springframework/cache/config/spring-cache-3.2.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd=org/springframework/web/servlet/config/spring-mvc-3.0.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc-3.1.xsd=org/springframework/web/servlet/config/spring-mvc-3.1.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc-3.2.xsd=org/springframework/web/servlet/config/spring-mvc-3.2.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc.xsd=org/springframework/web/servlet/config/spring-mvc-3.2.xsd
-http\://www.springframework.org/schema/security/spring-security-3.1.xsd=org/springframework/security/config/spring-security-3.1.xsd
-http\://www.springframework.org/schema/security/spring-security-3.2.xsd=org/springframework/security/config/spring-security-3.2.xsd
-
diff --git a/opendaylight/adsal/northbound/topology/src/main/resources/META-INF/spring.tooling b/opendaylight/adsal/northbound/topology/src/main/resources/META-INF/spring.tooling
deleted file mode 100644 (file)
index 057d834..0000000
+++ /dev/null
@@ -1,39 +0,0 @@
-# Tooling related information for the beans namespace
-http\://www.springframework.org/schema/beans@name=beans Namespace
-http\://www.springframework.org/schema/beans@prefix=beans
-http\://www.springframework.org/schema/beans@icon=org/springframework/beans/factory/xml/spring-beans.gif
-
-# Tooling related information for the util namespace
-http\://www.springframework.org/schema/util@name=util Namespace
-http\://www.springframework.org/schema/util@prefix=util
-http\://www.springframework.org/schema/util@icon=org/springframework/beans/factory/xml/spring-util.gif
-
-# Tooling related information for the context namespace
-http\://www.springframework.org/schema/context@name=context Namespace
-http\://www.springframework.org/schema/context@prefix=context
-http\://www.springframework.org/schema/context@icon=org/springframework/context/config/spring-context.gif
-
-# Tooling related information for the jee namespace
-http\://www.springframework.org/schema/jee@name=jee Namespace
-http\://www.springframework.org/schema/jee@prefix=jee
-http\://www.springframework.org/schema/jee@icon=org/springframework/ejb/config/spring-jee.gif
-
-# Tooling related information for the scheduling namespace
-http\://www.springframework.org/schema/task@name=task Namespace
-http\://www.springframework.org/schema/task@prefix=task
-http\://www.springframework.org/schema/task@icon=org/springframework/scheduling/config/spring-task.gif
-
-# Tooling related information for the lang namespace
-http\://www.springframework.org/schema/lang@name=lang Namespace
-http\://www.springframework.org/schema/lang@prefix=lang
-http\://www.springframework.org/schema/lang@icon=org/springframework/scripting/config/spring-lang.gif
-
-# Tooling related information for the cache namespace
-http\://www.springframework.org/schema/cache@name=cache Namespace
-http\://www.springframework.org/schema/cache@prefix=cache
-http\://www.springframework.org/schema/cache@icon=org/springframework/cache/config/spring-cache.gif
-
-# Tooling related information for the mvc namespace
-http\://www.springframework.org/schema/mvc@name=mvc Namespace
-http\://www.springframework.org/schema/mvc@prefix=mvc
-http\://www.springframework.org/schema/mvc@icon=org/springframework/web/servlet/config/spring-mvc.gif
diff --git a/opendaylight/adsal/northbound/topology/src/main/resources/WEB-INF/web.xml b/opendaylight/adsal/northbound/topology/src/main/resources/WEB-INF/web.xml
deleted file mode 100644 (file)
index dac8cf6..0000000
+++ /dev/null
@@ -1,89 +0,0 @@
-<?xml version="1.0" encoding="ISO-8859-1"?>
-<web-app xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
-        xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
-        version="3.0">
-  <servlet>
-    <servlet-name>JAXRSTopology</servlet-name>
-    <servlet-class>com.sun.jersey.spi.container.servlet.ServletContainer</servlet-class>
-    <init-param>
-      <param-name>javax.ws.rs.Application</param-name>
-      <param-value>org.opendaylight.controller.northbound.commons.NorthboundApplication</param-value>
-    </init-param>
-    <load-on-startup>1</load-on-startup>
-  </servlet>
-
-  <servlet-mapping>
-    <servlet-name>JAXRSTopology</servlet-name>
-    <url-pattern>/*</url-pattern>
-  </servlet-mapping>
-
-        <filter>
-          <filter-name>CorsFilter</filter-name>
-          <filter-class>org.apache.catalina.filters.CorsFilter</filter-class>
-          <init-param>
-            <param-name>cors.allowed.origins</param-name>
-            <param-value>*</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.allowed.methods</param-name>
-            <param-value>GET,POST,HEAD,OPTIONS,PUT,DELETE</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.allowed.headers</param-name>
-            <param-value>Content-Type,X-Requested-With,accept,authorization, origin,Origin,Access-Control-Request-Method,Access-Control-Request-Headers</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.exposed.headers</param-name>
-            <param-value>Access-Control-Allow-Origin,Access-Control-Allow-Credentials</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.support.credentials</param-name>
-            <param-value>true</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.preflight.maxage</param-name>
-            <param-value>10</param-value>
-          </init-param>
-        </filter>
-        <filter-mapping>
-          <filter-name>CorsFilter</filter-name>
-          <url-pattern>/*</url-pattern>
-        </filter-mapping>
-
-        <security-constraint>
-          <web-resource-collection>
-            <web-resource-name>NB api</web-resource-name>
-            <url-pattern>/*</url-pattern>
-            <http-method>POST</http-method>
-            <http-method>GET</http-method>
-            <http-method>PUT</http-method>
-            <http-method>PATCH</http-method>
-            <http-method>DELETE</http-method>
-            <http-method>HEAD</http-method>
-          </web-resource-collection>
-          <auth-constraint>
-            <role-name>System-Admin</role-name>
-            <role-name>Network-Admin</role-name>
-            <role-name>Network-Operator</role-name>
-            <role-name>Container-User</role-name>
-          </auth-constraint>
-        </security-constraint>
-
-        <security-role>
-                <role-name>System-Admin</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Network-Admin</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Network-Operator</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Container-User</role-name>
-        </security-role>
-
-        <login-config>
-                <auth-method>BASIC</auth-method>
-                <realm-name>opendaylight</realm-name>
-        </login-config>
-</web-app>
diff --git a/opendaylight/adsal/northbound/topology/src/test/java/org/opendaylight/controller/topology/northbound/TopologyTest.java b/opendaylight/adsal/northbound/topology/src/test/java/org/opendaylight/controller/topology/northbound/TopologyTest.java
deleted file mode 100644 (file)
index bcfa2a9..0000000
+++ /dev/null
@@ -1,124 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.topology.northbound;
-
-import org.junit.Test;
-import org.opendaylight.controller.sal.core.Bandwidth;
-import org.opendaylight.controller.sal.core.ConstructionException;
-import org.opendaylight.controller.sal.core.Edge;
-import org.opendaylight.controller.sal.core.Latency;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.core.State;
-import org.opendaylight.controller.sal.utils.NodeConnectorCreator;
-import org.opendaylight.controller.sal.utils.NodeCreator;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import java.util.ArrayList;
-import java.util.HashSet;
-import java.util.List;
-import java.util.Set;
-
-import static org.junit.Assert.assertEquals;
-import static org.junit.Assert.fail;
-
-public class TopologyTest {
-        protected static final Logger logger = LoggerFactory
-            .getLogger(TopologyTest.class);
-
-    @Test
-    public void edgePropertiesTopologyTest() {
-
-        //Create 3 nodes and edges between them
-        Node n1 = NodeCreator.createOFNode((long)1);
-        Node n2 = NodeCreator.createOFNode((long)2);
-        Node n3 = NodeCreator.createOFNode((long)3);
-
-        NodeConnector nc11 = NodeConnectorCreator.createOFNodeConnector((short) 1, n1);
-        NodeConnector nc12 = NodeConnectorCreator.createOFNodeConnector((short) 2, n1);
-        NodeConnector nc21 = NodeConnectorCreator.createOFNodeConnector((short) 1, n2);
-        NodeConnector nc22 = NodeConnectorCreator.createOFNodeConnector((short) 2, n2);
-        NodeConnector nc23 = NodeConnectorCreator.createOFNodeConnector((short) 2, n3);
-        NodeConnector nc32 = NodeConnectorCreator.createOFNodeConnector((short) 3, n2);
-        NodeConnector nc33 = NodeConnectorCreator.createOFNodeConnector((short) 3, n3);
-
-        Edge e12 = null;
-        Edge e23 = null;
-
-        try {
-            e12 = new Edge(nc12, nc21);
-        } catch (ConstructionException e) {
-            fail("Failed to construct edge " + e.getMessage());
-        }
-        try {
-            e23 = new Edge(nc23, nc32);
-        } catch (ConstructionException e) {
-            fail("Failed to construct edge " + e.getMessage());
-        }
-
-        Set<Property> props = new HashSet<Property>();
-        State state = new State(State.EDGE_UP);
-        Bandwidth bw = new Bandwidth(Bandwidth.BW100Gbps);
-        Latency l = new Latency(Latency.LATENCY100ns);
-        props.add(state);
-        props.add(bw);
-        props.add(l);
-
-        //Check get methods for edge and properties
-        EdgeProperties edgeProp = new EdgeProperties(e12, props);
-
-        Edge getEdge = edgeProp.getEdge();
-        assertEquals(e12, getEdge);
-        assertEquals(nc12, getEdge.getTailNodeConnector());
-        assertEquals(n1, getEdge.getTailNodeConnector().getNode());
-        assertEquals((long)1, getEdge.getTailNodeConnector().getNode().getID());
-        assertEquals(nc21, getEdge.getHeadNodeConnector());
-        assertEquals(n2, getEdge.getHeadNodeConnector().getNode());
-        assertEquals((long)2, getEdge.getHeadNodeConnector().getNode().getID());
-
-        Set<Property> getProp = edgeProp.getProperties();
-        assertEquals(props, getProp);
-        assertEquals(props.size(), getProp.size());
-
-        //Use set methods
-        edgeProp.setEdge(e23);
-        getEdge = edgeProp.getEdge();
-        assertEquals(e23, getEdge);
-        assertEquals(nc23, getEdge.getTailNodeConnector());
-        assertEquals(nc32, getEdge.getHeadNodeConnector());
-
-        props.remove(state);
-        edgeProp.setProperties(props);
-        assertEquals(props, getProp);
-        assertEquals(props.size(), getProp.size());
-
-
-        //Create and check topology
-        List<EdgeProperties> edgePropList= new ArrayList<EdgeProperties>();
-        edgePropList.add(edgeProp);
-
-        Topology t = new Topology(edgePropList);
-
-        List<EdgeProperties> getEdgePropList = t.getEdgeProperties();
-        assertEquals(edgePropList, getEdgePropList);
-        assertEquals(1, getEdgePropList.size());
-
-        EdgeProperties edgeProp2 = new EdgeProperties(e23, props);
-        edgePropList.add(edgeProp2);
-        t.setEdgeProperties(edgePropList);
-
-        getEdgePropList = t.getEdgeProperties();
-        assertEquals(edgePropList, getEdgePropList);
-        assertEquals(2, getEdgePropList.size());
-
-    }
-
-
-}
diff --git a/opendaylight/adsal/northbound/usermanager/enunciate.xml b/opendaylight/adsal/northbound/usermanager/enunciate.xml
deleted file mode 100644 (file)
index 0386c75..0000000
+++ /dev/null
@@ -1,12 +0,0 @@
-<?xml version="1.0"?>
-<enunciate label="full" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
-    xsi:noNamespaceSchemaLocation="http://enunciate.codehaus.org/schemas/enunciate-1.28.xsd">
-
-  <services>
-    <rest defaultRestSubcontext="/controller/nb/v2/usermanager"/>
-  </services>
-
-  <modules>
-    <docs docsDir="rest" title="User Management  REST API" includeExampleXml="true" includeExampleJson="true"/>
-  </modules>
-</enunciate>
diff --git a/opendaylight/adsal/northbound/usermanager/pom.xml b/opendaylight/adsal/northbound/usermanager/pom.xml
deleted file mode 100644 (file)
index b13b746..0000000
+++ /dev/null
@@ -1,77 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>enunciate-parent</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/enunciate-parent</relativePath>
-  </parent>
-
-  <artifactId>usermanager.northbound</artifactId>
-  <version>0.2.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>org.codehaus.enunciate</groupId>
-      <artifactId>enunciate-core-annotations</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>commons.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>usermanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-      <scope>test</scope>
-    </dependency>
-  </dependencies>
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Export-Package></Export-Package>
-            <Import-Package>org.opendaylight.controller.sal.utils,
-              org.opendaylight.controller.northbound.commons,
-              org.opendaylight.controller.northbound.commons.exception,
-              org.opendaylight.controller.northbound.commons.utils,
-              com.sun.jersey.spi.container.servlet,
-              org.opendaylight.controller.sal.authorization,
-              org.opendaylight.controller.usermanager,
-              javax.ws.rs,
-              javax.ws.rs.core,
-              javax.xml.bind,
-              javax.xml.bind.annotation,
-              org.slf4j,
-              org.apache.catalina.filters,
-              com.fasterxml.jackson.jaxrs.base,
-              com.fasterxml.jackson.jaxrs.json,
-              !org.codehaus.enunciate.jaxrs</Import-Package>
-            <Export-Package></Export-Package>
-            <Web-ContextPath>/controller/nb/v2/usermanager</Web-ContextPath>
-            <Jaxrs-Resources>,${classes;ANNOTATION;javax.ws.rs.Path}</Jaxrs-Resources>
-          </instructions>
-          <manifestLocation>${project.basedir}/src/main/resources/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/northbound/usermanager/src/main/java/org/opendaylight/controller/usermanager/northbound/UserManagerNorthbound.java b/opendaylight/adsal/northbound/usermanager/src/main/java/org/opendaylight/controller/usermanager/northbound/UserManagerNorthbound.java
deleted file mode 100644 (file)
index 3f384f4..0000000
+++ /dev/null
@@ -1,198 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.usermanager.northbound;
-
-import java.net.URI;
-
-import javax.ws.rs.Consumes;
-import javax.ws.rs.DELETE;
-import javax.ws.rs.POST;
-import javax.ws.rs.Path;
-import javax.ws.rs.PathParam;
-import javax.ws.rs.core.Context;
-import javax.ws.rs.core.MediaType;
-import javax.ws.rs.core.Response;
-import javax.ws.rs.core.SecurityContext;
-import javax.ws.rs.core.UriInfo;
-
-import org.codehaus.enunciate.jaxrs.ResponseCode;
-import org.codehaus.enunciate.jaxrs.StatusCodes;
-import org.codehaus.enunciate.jaxrs.TypeHint;
-import org.opendaylight.controller.northbound.commons.RestMessages;
-import org.opendaylight.controller.northbound.commons.exception.BadRequestException;
-import org.opendaylight.controller.northbound.commons.exception.ResourceConflictException;
-import org.opendaylight.controller.northbound.commons.exception.ServiceUnavailableException;
-import org.opendaylight.controller.northbound.commons.exception.UnauthorizedException;
-import org.opendaylight.controller.northbound.commons.utils.NorthboundUtils;
-import org.opendaylight.controller.sal.authorization.UserLevel;
-import org.opendaylight.controller.sal.utils.ServiceHelper;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.usermanager.IUserManager;
-import org.opendaylight.controller.usermanager.UserConfig;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * This class provides REST APIs to manage users.
- * This API will only be availalbe via HTTPS.
- * <br>
- * <br>
- * Authentication scheme : <b>HTTP Basic</b><br>
- * Authentication realm : <b>opendaylight</b><br>
- * Transport : <b> HTTPS </b><br>
- * <br>
- * HTTPS Authentication is disabled by default so to
- * use UserManager APIs turn on HTTPS on Web Server
- */
-
-@Path("/")
-public class UserManagerNorthbound {
-
-    protected static final Logger logger = LoggerFactory.getLogger(UserManagerNorthbound.class);
-
-    private String username;
-    @Context
-    UriInfo uriInfo;
-
-    @Context
-    public void setSecurityContext(SecurityContext context) {
-        if (context != null && context.getUserPrincipal() != null) {
-            username = context.getUserPrincipal().getName();
-        }
-    }
-
-    protected String getUserName() {
-        return username;
-    }
-
-    private void handleNameMismatch(String name, String nameinURL) {
-        if (name == null || nameinURL == null) {
-            throw new BadRequestException(RestMessages.INVALIDDATA.toString() + " : Name is null");
-        }
-
-        if (name.equals(nameinURL)) {
-            return;
-        }
-        throw new ResourceConflictException(RestMessages.INVALIDDATA.toString()
-                + " : Name in URL does not match the name in request body");
-    }
-
-    /**
-     * Add a user
-     *
-     * @param userConfigData
-     *            the {@link UserConfig} user config structure in request body
-     *
-     * @return Response as dictated by the HTTP Response Status code
-     *
-     *         <pre>
-     * Example:
-     *
-     * Request URL:
-     * https://localhost/controller/nb/v2/usermanager/users
-     *
-     * Request body in XML:
-     *  &lt;userConfig&gt;
-     *      &lt;user&gt;testuser&lt;/user&gt;
-     *      &lt;roles&gt;Network-Admin&lt;/roles&gt;
-     *      &lt;password&gt;pass!23&lt;/password&gt;
-     *  &lt;/userConfig&gt;
-     *
-     * Request body in JSON:
-     * {
-     *  "user":"testuser",
-     *  "password":"pass!23",
-     *  "roles":[
-     *       "Network-Admin"
-     *       ]
-     * }
-     * </pre>
-     */
-
-    @Path("/users")
-    @POST
-    @StatusCodes({ @ResponseCode(code = 201, condition = "User created successfully"),
-        @ResponseCode(code = 400, condition = "Invalid data passed"),
-        @ResponseCode(code = 401, condition = "User not authorized to perform this operation"),
-        @ResponseCode(code = 409, condition = "User name in url conflicts with name in request body"),
-        @ResponseCode(code = 404, condition = "User config is null"),
-        @ResponseCode(code = 500, condition = "Internal Server Error: Addition of user failed"),
-        @ResponseCode(code = 503, condition = "Service unavailable") })
-    @Consumes({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    public Response addLocalUser(@TypeHint(UserConfig.class) UserConfig userConfigData) {
-
-        if (!isAdminUser()) {
-            throw new UnauthorizedException("User is not authorized to perform user management operations ");
-        }
-
-        // Reconstructing the object so password can be hashed in userConfig
-        UserConfig userCfgObject = new UserConfig(userConfigData.getUser(),userConfigData.getPassword(),
-                 userConfigData.getRoles());
-
-        IUserManager userManager = (IUserManager) ServiceHelper.getGlobalInstance(IUserManager.class, this);
-        if (userManager == null) {
-            throw new ServiceUnavailableException("UserManager " + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-        Status status = userManager.addLocalUser(userCfgObject);
-        if (status.isSuccess()) {
-
-            NorthboundUtils.auditlog("User", username, "added", userCfgObject.getUser());
-            URI uri = uriInfo.getAbsolutePathBuilder().path("/"+userCfgObject.getUser()).build();
-            return Response.created(uri).build();
-        }
-        return NorthboundUtils.getResponse(status);
-    }
-
-    /**
-     * Delete a user
-     *
-     * @param userName
-     *            name of user to be deleted
-     * @return Response as dictated by the HTTP Response Status code
-     *
-     * <pre>
-     * Example:
-     *
-     * Request URL:
-     * https://localhost/controller/nb/v2/usermanager/users/testuser
-     *
-     * </pre>
-     */
-    @Path("/users/{userName}")
-    @DELETE
-    @StatusCodes({ @ResponseCode(code = 204, condition = "User Deleted Successfully"),
-        @ResponseCode(code = 401, condition = "User not authorized to perform this operation"),
-        @ResponseCode(code = 404, condition = "The userName passed was not found"),
-        @ResponseCode(code = 500, condition = "Internal Server Error : Removal of user failed"),
-        @ResponseCode(code = 503, condition = "Service unavailable") })
-    public Response removeLocalUser(@PathParam("userName") String userToBeRemoved) {
-
-        if (!isAdminUser()) {
-            throw new UnauthorizedException("User is not authorized to perform user management operations ");
-        }
-
-        IUserManager userManager = (IUserManager) ServiceHelper.getGlobalInstance(IUserManager.class, this);
-        if (userManager == null) {
-            throw new ServiceUnavailableException("UserManager " + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-        Status status = userManager.removeLocalUser(userToBeRemoved);
-        if (status.isSuccess()) {
-            NorthboundUtils.auditlog("User", username, "removed", userToBeRemoved);
-            return Response.noContent().build();
-        }
-        return NorthboundUtils.getResponse(status);
-    }
-
-    private boolean isAdminUser(){
-        // get UserManager's instance
-        IUserManager auth = (IUserManager) ServiceHelper.getGlobalInstance(IUserManager.class, this);
-        // check if logged in user has privileges of NETWORK_ADMIN or SYSTEM_ADMIN, if so return true
-        return auth.getUserLevel(getUserName()).ordinal() <= UserLevel.NETWORKADMIN.ordinal();
-    }
-
-}
diff --git a/opendaylight/adsal/northbound/usermanager/src/main/resources/WEB-INF/web.xml b/opendaylight/adsal/northbound/usermanager/src/main/resources/WEB-INF/web.xml
deleted file mode 100644 (file)
index 9a191ac..0000000
+++ /dev/null
@@ -1,85 +0,0 @@
-<?xml version="1.0" encoding="ISO-8859-1"?>
-<web-app xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
-        xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
-        version="3.0">
-  <servlet>
-    <servlet-name>JAXRSUserManager</servlet-name>
-    <servlet-class>com.sun.jersey.spi.container.servlet.ServletContainer</servlet-class>
-    <init-param>
-      <param-name>javax.ws.rs.Application</param-name>
-      <param-value> org.opendaylight.controller.northbound.commons.NorthboundApplication</param-value>
-    </init-param>
-    <load-on-startup>1</load-on-startup>
-  </servlet>
-
-  <servlet-mapping>
-    <servlet-name>JAXRSUserManager</servlet-name>
-    <url-pattern>/*</url-pattern>
-  </servlet-mapping>
-        <filter>
-          <filter-name>CorsFilter</filter-name>
-          <filter-class>org.apache.catalina.filters.CorsFilter</filter-class>
-          <init-param>
-            <param-name>cors.allowed.origins</param-name>
-            <param-value>*</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.allowed.methods</param-name>
-            <param-value>GET,POST,HEAD,OPTIONS,PUT,DELETE</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.allowed.headers</param-name>
-            <param-value>Content-Type,X-Requested-With,accept,authorization, origin,Origin,Access-Control-Request-Method,Access-Control-Request-Headers</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.exposed.headers</param-name>
-            <param-value>Access-Control-Allow-Origin,Access-Control-Allow-Credentials</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.support.credentials</param-name>
-            <param-value>true</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.preflight.maxage</param-name>
-            <param-value>10</param-value>
-          </init-param>
-        </filter>
-        <filter-mapping>
-          <filter-name>CorsFilter</filter-name>
-          <url-pattern>/*</url-pattern>
-        </filter-mapping>
-
-        <security-constraint>
-          <web-resource-collection>
-            <web-resource-name>NB api</web-resource-name>
-            <url-pattern>/*</url-pattern>
-            <http-method>POST</http-method>
-            <http-method>GET</http-method>
-            <http-method>PUT</http-method>
-            <http-method>PATCH</http-method>
-            <http-method>DELETE</http-method>
-            <http-method>HEAD</http-method>
-          </web-resource-collection>
-          <auth-constraint>
-            <role-name>System-Admin</role-name>
-            <role-name>Network-Admin</role-name>
-          </auth-constraint>
-          <!--  To enable SSL only access for this bundle, with this setting UserManager
-          northbound APIs will only be available over HTTPS-->
-          <user-data-constraint>
-            <transport-guarantee>CONFIDENTIAL</transport-guarantee>
-          </user-data-constraint>
-        </security-constraint>
-
-        <security-role>
-                <role-name>System-Admin</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Network-Admin</role-name>
-        </security-role>
-
-        <login-config>
-                <auth-method>BASIC</auth-method>
-                <realm-name>opendaylight</realm-name>
-        </login-config>
-</web-app>
diff --git a/opendaylight/adsal/northbound/usermanager/src/test/java/org/opendaylight/controller/subnets/northbound/UserManagerNorthboundTest.java b/opendaylight/adsal/northbound/usermanager/src/test/java/org/opendaylight/controller/subnets/northbound/UserManagerNorthboundTest.java
deleted file mode 100644 (file)
index ac0307a..0000000
+++ /dev/null
@@ -1,40 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.subnets.northbound;
-
-import java.util.ArrayList;
-import java.util.List;
-
-import org.junit.Assert;
-import org.junit.Test;
-import org.opendaylight.controller.sal.authorization.AuthResultEnum;
-import org.opendaylight.controller.usermanager.AuthResponse;
-import org.opendaylight.controller.usermanager.UserConfig;
-
-public class UserManagerNorthboundTest {
-
-    @Test
-    public void testUserConfigs() {
-       List<String> roles = new ArrayList<String>();
-       roles.add("Network-Admin");
-
-       UserConfig userConfig = new UserConfig("test","testPass",roles);
-
-        Assert.assertNotNull(userConfig);
-        Assert.assertNotNull(userConfig.getUser());
-        Assert.assertNotNull(userConfig.getPassword());
-        Assert.assertTrue(userConfig.getRoles().equals(roles));
-
-
-        AuthResponse authResponse = userConfig.authenticate("testPass");
-        Assert.assertNotNull(authResponse);
-
-        Assert.assertEquals(AuthResultEnum.AUTH_ACCEPT_LOC,authResponse.getStatus());
-    }
-
-}
diff --git a/opendaylight/adsal/northboundtest/unit_test_suite/pom.xml b/opendaylight/adsal/northboundtest/unit_test_suite/pom.xml
deleted file mode 100644 (file)
index 3047bdd..0000000
+++ /dev/null
@@ -1,55 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-        <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../../opendaylight/commons/opendaylight</relativePath>
-  </parent>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-
-
-        <groupId>org.opendaylight.controller</groupId>
-        <artifactId>northboundtest</artifactId>
-        <version>0.6.0-SNAPSHOT</version>
-        <packaging>bundle</packaging>
-
-        <build>
-                <plugins>
-                        <plugin>
-                                <groupId>org.apache.felix</groupId>
-                                <artifactId>maven-bundle-plugin</artifactId>
-                                <version>${bundle.plugin.version}</version>
-                                <extensions>true</extensions>
-                                <configuration>
-                                        <instructions>
-                                                <Import-Package>
-                                                        org.opendaylight.controller.sal.core,
-                                                        org.eclipse.osgi.framework.console,
-                                                        org.osgi.framework,
-                                        org.apache.felix.dm
-                                                </Import-Package>
-                                                <Export-Package>
-                                                </Export-Package>
-                                                <Bundle-Activator>
-                                          org.opendaylight.controller.northboundtest.unittestsuite.internal.Activator
-                                        </Bundle-Activator>
-                                                <Service-Component>
-                                                </Service-Component>
-                                        </instructions>
-                                </configuration>
-                        </plugin>
-                </plugins>
-        </build>
-        <dependencies>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-  </dependencies>
-</project>
diff --git a/opendaylight/adsal/northboundtest/unit_test_suite/src/main/java/org/opendaylight/controller/northboundtest/unittestsuite/internal/API3UnitTest.java b/opendaylight/adsal/northboundtest/unit_test_suite/src/main/java/org/opendaylight/controller/northboundtest/unittestsuite/internal/API3UnitTest.java
deleted file mode 100644 (file)
index aef2540..0000000
+++ /dev/null
@@ -1,210 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.northboundtest.unittestsuite.internal;
-
-import java.io.BufferedReader;
-import java.io.IOException;
-import java.io.InputStream;
-import java.io.InputStreamReader;
-
-import org.eclipse.osgi.framework.console.CommandInterpreter;
-import org.eclipse.osgi.framework.console.CommandProvider;
-import org.osgi.framework.BundleContext;
-import org.osgi.framework.FrameworkUtil;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * This java class provides the osgi console with the commands for running the unit test scripts for the API3
- *
- *
- *
- */
-public class API3UnitTest implements CommandProvider {
-    private static Logger log = LoggerFactory
-         .getLogger(API3UnitTest.class);
-
-    private static final String python = "/usr/bin/python";
-
-    /**
-     * Function called by the dependency manager when all the required
-     * dependencies are satisfied
-     *
-     */
-    void init() {
-        BundleContext bundleContext = FrameworkUtil.getBundle(this.getClass())
-                .getBundleContext();
-        bundleContext.registerService(CommandProvider.class.getName(), this,
-                null);
-    }
-
-    /**
-     * Function called by the dependency manager when at least one
-     * dependency become unsatisfied or when the component is shutting
-     * down because for example bundle is being stopped.
-     *
-     */
-    void destroy() {
-    }
-
-    /**
-     * Function called by dependency manager after "init ()" is called
-     * and after the services provided by the class are registered in
-     * the service registry
-     *
-     */
-    void start() {
-    }
-
-    /**
-     * Function called by the dependency manager before the services
-     * exported by the component are unregistered, this will be
-     * followed by a "destroy ()" calls
-     *
-     */
-    void stop() {
-    }
-
-    @Override
-    public String getHelp() {
-        StringBuffer help = new StringBuffer();
-        help.append("---API3 Unit Test---\n");
-        help
-                .append("\t api3ut             - run the python script for the specified northbound module\n");
-        help.append("\t GET <uri>");
-        help.append("\t PUT <uri>  data1==x1 data2==x2 ...");
-        help.append("\t POST <uri>  data1==x1 data2==x2 ...");
-        help.append("\t DELETE <uri>");
-        return help.toString();
-    }
-
-    public void _api3ut(CommandInterpreter ci) {
-        boolean custom = false;
-        String target = null;
-        String module = null;
-
-        module = ci.nextArgument();
-        if (module == null) {
-            printUsage(ci);
-            return;
-        }
-
-        if (module.equals("custom")) {
-            target = ci.nextArgument();
-            custom = true;
-        } else if (module.equals("flows")) {
-            target = "flowsUnitTest.py";
-        } else if (module.equals("subnets")) {
-            target = "subnetsUnitTest.py";
-        } else if (module.equals("hosts")) {
-            target = "hostsUnitTest.py";
-        } else if (module.equals("slices")) {
-            target = "slicesUnitTest.py";
-        } else if (module.equals("tif")) {
-            target = "tifUnitTest.py";
-        } else {
-            ci.println("ERROR: Coming soon");
-        }
-
-        if (target != null) {
-            executeScript(target, custom);
-        }
-    }
-
-    private void printUsage(CommandInterpreter ci) {
-        ci.println("Usage: api3ut [<module> | custom <target>]");
-        ci
-                .println("<module>: [flows, hosts, subnets, slices, tif] (You need python-httplib2 installed)");
-        ci.println("<target>: your linux script (w/ absolute path)");
-    }
-
-    private void printStream(InputStream stream) throws IOException {
-        String line;
-        BufferedReader reader = new BufferedReader(
-                new InputStreamReader(stream));
-
-        while ((line = reader.readLine()) != null) {
-            System.out.println(line);
-        }
-    }
-
-    public void executeScript(String target, boolean custom)
-            throws RuntimeException {
-        String script = (custom) ? target : "SCRIPTS/python/" + target;
-        try {
-            Runtime runTime = Runtime.getRuntime();
-            Process process = runTime.exec(python + " " + script);
-            printStream(process.getInputStream());
-            printStream(process.getErrorStream());
-        } catch (Exception e) {
-            System.out.println("Exception!");
-            log.error("",e);
-        }
-    }
-
-    public void _GET(CommandInterpreter ci) {
-        parseRestRequest("GET", ci);
-    }
-
-    public void _PUT(CommandInterpreter ci) {
-        parseRestRequest("PUT", ci);
-    }
-
-    public void _DELETE(CommandInterpreter ci) {
-        parseRestRequest("DELETE", ci);
-    }
-
-    public void _POST(CommandInterpreter ci) {
-        parseRestRequest("POST", ci);
-    }
-
-    private void parseRestRequest(String action, CommandInterpreter ci) {
-        String uri, resource;
-        StringBuffer resources = new StringBuffer(" ");
-
-        uri = ci.nextArgument();
-        if (uri == null) {
-            printRestUsage(ci);
-            return;
-        }
-
-        resource = ci.nextArgument();
-        while (resource != null) {
-            resources.append(resource);
-            resources.append(" ");
-            resource = ci.nextArgument();
-        }
-
-        executeRestCall(action, uri, resources.toString());
-
-    }
-
-    private void executeRestCall(String action, String uri, String resources) {
-        String script = "SCRIPTS/python/rest_call.py";
-
-        try {
-            Runtime runTime = Runtime.getRuntime();
-            Process process = runTime.exec(python + " " + script + " " + action
-                    + " " + uri + " " + resources);
-            printStream(process.getInputStream());
-            printStream(process.getErrorStream());
-        } catch (Exception e) {
-            System.out.println("Exception!");
-            log.error("",e);
-        }
-    }
-
-    private void printRestUsage(CommandInterpreter ci) {
-        ci.println("Usage: GET/PUT/POST/DELETE <uri>  [<resources>]");
-        ci.println("<uri>: ex: slices/red or slices/red/flowspecs");
-        ci
-                .println("<resources>: resource==<value>,... ex: switchId==2 port==3-7");
-    }
-}
diff --git a/opendaylight/adsal/northboundtest/unit_test_suite/src/main/java/org/opendaylight/controller/northboundtest/unittestsuite/internal/Activator.java b/opendaylight/adsal/northboundtest/unit_test_suite/src/main/java/org/opendaylight/controller/northboundtest/unittestsuite/internal/Activator.java
deleted file mode 100644 (file)
index 471a440..0000000
+++ /dev/null
@@ -1,79 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.northboundtest.unittestsuite.internal;
-
-import org.opendaylight.controller.sal.core.ComponentActivatorAbstractBase;
-
-import org.apache.felix.dm.Component;
-
-public class Activator extends ComponentActivatorAbstractBase {
-
-
-    /**
-     * Function that is used to communicate to dependency manager the
-     * list of known implementations for services inside a container
-     *
-     *
-     * @return An array containing all the CLASS objects that will be
-     * instantiated in order to get an fully working implementation
-     * Object
-     */
-    public Object[] getImplementations() {
-        return null;
-    }
-
-    /**
-     * Function that is called when configuration of the dependencies
-     * is required.
-     *
-     * @param c dependency manager Component object, used for
-     * configuring the dependencies exported and imported
-     * @param imp Implementation class that is being configured,
-     * needed as long as the same routine can configure multiple
-     * implementations
-     * @param containerName The containerName being configured, this allow
-     * also optional per-container different behavior if needed, usually
-     * should not be the case though.
-     */
-    public void configureInstance(Component c, Object imp, String containerName) {
-    }
-
-    /**
-     * Method which tells how many Global implementations are
-     * supported by the bundle. This way we can tune the number of
-     * components created. This components will be created ONLY at the
-     * time of bundle startup and will be destroyed only at time of
-     * bundle destruction, this is the major difference with the
-     * implementation retrieved via getImplementations where all of
-     * them are assumed to be in a Container!
-     *
-     *
-     * @return The list of implementations the bundle will support,
-     * in Global version
-     */
-    protected Object[] getGlobalImplementations() {
-        Object[] res = { API3UnitTest.class };
-        return res;
-    }
-
-    /**
-     * Configure the dependency for a given instance Global
-     *
-     * @param c Component assigned for this instance, this will be
-     * what will be used for configuration
-     * @param imp implementation to be configured
-     * @param containerName container on which the configuration happens
-     */
-    protected void configureGlobalInstance(Component c, Object imp) {
-        if (imp.equals(API3UnitTest.class)) {
-            // Nothing to initialize
-        }
-    }
-}
diff --git a/opendaylight/adsal/pom.xml b/opendaylight/adsal/pom.xml
deleted file mode 100644 (file)
index 91f4ddd..0000000
+++ /dev/null
@@ -1,141 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.parent</artifactId>
-    <version>1.2.0-SNAPSHOT</version>
-    <relativePath>../commons/parent</relativePath>
-  </parent>
-
-  <artifactId>adsal-parent</artifactId>
-  <packaging>pom</packaging>
-  <modules>
-    <module>forwarding/staticrouting</module>
-    <module>clustering/services</module>
-    <module>clustering/services_implementation</module>
-    <module>clustering/stub</module>
-    <module>clustering/test</module>
-    <module>configuration/api</module>
-    <module>configuration/implementation</module>
-    <module>routing/dijkstra_implementation</module>
-    <module>arphandler</module>
-    <module>forwardingrulesmanager/api</module>
-    <module>forwardingrulesmanager/implementation</module>
-    <module>hosttracker/api</module>
-    <module>hosttracker/implementation</module>
-    <module>hosttracker/shell</module>
-    <module>hosttracker_new/api</module>
-    <module>hosttracker_new/implementation</module>
-    <module>containermanager/api</module>
-    <module>containermanager/implementation</module>
-    <module>containermanager/shell</module>
-    <module>appauth</module>
-    <module>switchmanager/api</module>
-    <module>switchmanager/implementation</module>
-    <module>statisticsmanager/api</module>
-    <module>statisticsmanager/implementation</module>
-    <module>topologymanager/implementation</module>
-    <module>topologymanager/shell</module>
-    <module>usermanager/api</module>
-    <module>usermanager/implementation</module>
-    <module>connectionmanager/api</module>
-    <module>connectionmanager/implementation</module>
-    <module>security</module>
-    <module>karaf-tomcat-security</module>
-
-    <!-- SAL bundles -->
-    <module>sal/api</module>
-    <module>sal/implementation</module>
-
-    <!-- SAL Extension bundles -->
-    <module>sal/connection/api</module>
-    <module>sal/connection/implementation</module>
-    <module>sal/networkconfiguration/api</module>
-    <module>sal/networkconfiguration/implementation</module>
-
-    <!--  Web bundles -->
-    <module>web/root</module>
-    <module>web/flows</module>
-    <module>web/devices</module>
-    <module>web/troubleshoot</module>
-    <module>web/topology</module>
-    <module>web/osgi-brandfragment</module>
-
-    <!-- Northbound bundles -->
-    <module>northbound/commons</module>
-    <module>northbound/bundlescanner/api</module>
-    <module>northbound/bundlescanner/implementation</module>
-    <module>northbound/topology</module>
-    <module>northbound/staticrouting</module>
-    <module>northbound/statistics</module>
-    <module>northbound/flowprogrammer</module>
-    <module>northbound/hosttracker</module>
-    <module>northbound/subnets</module>
-    <module>northbound/switchmanager</module>
-    <module>northbound/containermanager</module>
-    <module>northbound/networkconfiguration/bridgedomain</module>
-    <module>northbound/httpservice-bridge</module>
-    <module>northbound/jolokia</module>
-    <module>northbound/connectionmanager</module>
-    <module>northbound/usermanager</module>
-    <module>northbound/controllermanager</module>
-
-    <!-- Debug and logging -->
-    <module>logging/bridge</module>
-
-    <!-- Southbound bundles -->
-    <module>protocol_plugins/openflow</module>
-    <module>protocol_plugins/stub</module>
-
-    <!-- Samples -->
-    <module>samples/simpleforwarding</module>
-    <module>samples/loadbalancer</module>
-    <module>samples/northbound/loadbalancer</module>
-
-    <module>dummy-console</module>
-    <module>adsal-enunciate-parent</module>
-
-    <!-- features -->
-    <module>features/base</module>
-    <module>features/controller</module>
-    <module>features/adsal</module>
-    <module>features/nsf</module>
-    <module>features/extras</module>
-  </modules>
-  <profiles>
-    <profile>
-      <id>integrationtests</id>
-      <activation>
-        <activeByDefault>false</activeByDefault>
-      </activation>
-      <modules>
-        <module>clustering/integrationtest</module>
-        <module>configuration/integrationtest</module>
-        <module>forwardingrulesmanager/integrationtest</module>
-        <module>hosttracker/integrationtest</module>
-        <module>switchmanager/integrationtest</module>
-        <module>topologymanager/integrationtest</module>
-        <!-- Northbound integration tests -->
-        <module>northbound/integrationtest</module>
-        <module>statisticsmanager/integrationtest</module>
-        <module>containermanager/it.implementation</module>
-        <module>commons/integrationtest</module>
-
-        <module>commons/httpclient</module>
-      </modules>
-    </profile>
-    <profile>
-      <id>docs-java7</id>
-      <activation>
-        <activeByDefault>false</activeByDefault>
-        <jdk>1.7</jdk>
-      </activation>
-      <modules>
-        <module>northbound/java-client</module>
-        <module>northbound/swagger-ui</module>
-      </modules>
-    </profile>
-  </profiles>
-</project>
diff --git a/opendaylight/adsal/protocol_plugins/openflow/pom.xml b/opendaylight/adsal/protocol_plugins/openflow/pom.xml
deleted file mode 100644 (file)
index 91cf49a..0000000
+++ /dev/null
@@ -1,79 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>protocol_plugins.openflow</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>org.eclipse.osgi</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal.connection</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller.thirdparty</groupId>
-      <artifactId>org.openflow.openflowj</artifactId>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Import-Package>org.opendaylight.controller.sal.packet,
-              org.opendaylight.controller.sal.action,
-              org.opendaylight.controller.sal.discovery,
-              org.opendaylight.controller.sal.topology,
-              org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.sal.flowprogrammer,
-              org.opendaylight.controller.sal.reader,
-              org.opendaylight.controller.sal.inventory,
-              org.opendaylight.controller.sal.match,
-              org.opendaylight.controller.sal.utils,
-              org.opendaylight.controller.sal.connection,
-              org.apache.commons.lang3.builder,
-              org.apache.commons.lang3.tuple,
-              org.apache.felix.dm,
-              org.slf4j,
-              org.eclipse.osgi.framework.console,
-              org.osgi.framework,
-              javax.net.ssl</Import-Package>
-            <Export-Package>org.opendaylight.controller.protocol_plugin.openflow.internal</Export-Package>
-            <Embed-Dependency>org.openflow.openflowj</Embed-Dependency>
-            <Embed-Transitive>false</Embed-Transitive>
-            <Bundle-Activator>org.opendaylight.controller.protocol_plugin.openflow.internal.Activator</Bundle-Activator>
-          </instructions>
-          <manifestLocation>${project.basedir}/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/IDataPacketListen.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/IDataPacketListen.java
deleted file mode 100644 (file)
index 300967e..0000000
+++ /dev/null
@@ -1,39 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * @file   IDataPacketListen.java
- *
- * @brief  Interface to dispatch locally in the protocol plugin the
- * data packets, intended especially for Discovery, main difference
- * here with the analogous of SAL is that this is Global
- * inherently
- *
- */
-package org.opendaylight.controller.protocol_plugin.openflow;
-
-import org.opendaylight.controller.sal.packet.RawPacket;
-import org.opendaylight.controller.sal.packet.PacketResult;
-
-/**
- * Interface to dispatch locally in the protocol plugin the
- * data packets, intended especially for Discovery, main difference
- * here with the analogous of SAL is that this is Global
- * inherently.
- */
-public interface IDataPacketListen {
-    /**
-     * Dispatch received data packet
-     *
-     * @param inPkt
-     *            The incoming raw packet
-     * @return Possible results for Data packet processing handler
-     */
-    public PacketResult receiveDataPacket(RawPacket inPkt);
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/IDataPacketMux.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/IDataPacketMux.java
deleted file mode 100644 (file)
index 747a8fb..0000000
+++ /dev/null
@@ -1,31 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow;
-
-/**
- * @file   IDataPacketMux.java
- *
- * @brief  Simple wrapped interface for the IPluginInDataPacketService
- * which will be only exported by DataPacketServices mux/demux
- * component and will be only accessible by the openflow protocol
- * plugin
- */
-
-import org.opendaylight.controller.sal.packet.IPluginInDataPacketService;
-
-/**
- * Simple wrapped interface for the IPluginInDataPacketService
- * which will be only exported by DataPacketServices mux/demux
- * component and will be only accessible by the openflow protocol
- * plugin
- */
-public interface IDataPacketMux extends IPluginInDataPacketService {
-
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/IDiscoveryListener.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/IDiscoveryListener.java
deleted file mode 100644 (file)
index ecc5d6e..0000000
+++ /dev/null
@@ -1,19 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow;
-
-import org.opendaylight.controller.sal.discovery.IDiscoveryService;
-
-/**
- * The interface provides method to notify the local plugin listener when an
- * edge is discovered or removed.
- */
-public interface IDiscoveryListener extends IDiscoveryService {
-
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/IFlowProgrammerNotifier.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/IFlowProgrammerNotifier.java
deleted file mode 100644 (file)
index 3071765..0000000
+++ /dev/null
@@ -1,22 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow;
-
-import org.opendaylight.controller.sal.flowprogrammer.IPluginOutFlowProgrammerService;
-
-/**
- * Interface which defines the methods exposed by the Flow Programmer Notifier.
- * Their implementation relays the asynchronous messages received from the
- * network nodes to the the SAL Flow Programmer Notifier Service on the proper
- * container.
- */
-public interface IFlowProgrammerNotifier extends
-        IPluginOutFlowProgrammerService {
-
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/IInventoryProvider.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/IInventoryProvider.java
deleted file mode 100644 (file)
index 6b2ea30..0000000
+++ /dev/null
@@ -1,18 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow;
-
-import org.opendaylight.controller.sal.inventory.IPluginInInventoryService;
-
-/**
- * The Interface provides inventory service to the local plugin modules
- */
-public interface IInventoryProvider extends IPluginInInventoryService {
-
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/IInventoryShimExternalListener.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/IInventoryShimExternalListener.java
deleted file mode 100644 (file)
index df03a04..0000000
+++ /dev/null
@@ -1,18 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow;
-
-/**
- * Wrapper of Interface that provides inventory updates locally in the protocol
- * plugin.
- */
-public interface IInventoryShimExternalListener extends
-        IInventoryShimInternalListener {
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/IInventoryShimInternalListener.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/IInventoryShimInternalListener.java
deleted file mode 100644 (file)
index 3c698b6..0000000
+++ /dev/null
@@ -1,56 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow;
-
-import java.util.Set;
-
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.core.UpdateType;
-
-/**
- * The Interface provides inventory updates to inventory listeners within the
- * protocol plugin
- */
-public interface IInventoryShimInternalListener {
-    /**
-     * Updates node and its properties
-     *
-     * @param node
-     *            {@link org.opendaylight.controller.sal.core.Node} being
-     *            updated
-     * @param type
-     *            update type {@link org.opendaylight.controller.sal.core.UpdateType}
-     * @param props
-     *            set of {@link org.opendaylight.controller.sal.core.Property}
-     *            such as
-     *            {@link org.opendaylight.controller.sal.core.Description}
-     *            and/or {@link org.opendaylight.controller.sal.core.Tier} etc.
-     */
-    public void updateNode(Node node, UpdateType type, Set<Property> props);
-
-    /**
-     * Updates node connector and its properties
-     *
-     * @param nodeConnector
-     *            {@link org.opendaylight.controller.sal.core.NodeConnector}
-     *            being updated
-     * @param type
-     *            update type {@link org.opendaylight.controller.sal.core.UpdateType}
-     * @param props
-     *            set of {@link org.opendaylight.controller.sal.core.Property}
-     *            such as
-     *            {@link org.opendaylight.controller.sal.core.Description}
-     *            and/or {@link org.opendaylight.controller.sal.core.State} etc.
-     */
-    public void updateNodeConnector(NodeConnector nodeConnector,
-            UpdateType type, Set<Property> props);
-
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/IOFStatisticsListener.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/IOFStatisticsListener.java
deleted file mode 100644 (file)
index 9a2d4ff..0000000
+++ /dev/null
@@ -1,63 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.protocol_plugin.openflow;
-
-import java.util.List;
-
-import org.openflow.protocol.statistics.OFStatistics;
-
-/**
- * Interface which defines the notification functions which will get called when
- * the information contained in the OF statistics reply message received from a
- * network node is different from the cached one.
- */
-public interface IOFStatisticsListener {
-    /**
-     * Notifies that a new list of description statistics objects for the given
-     * switch is available
-     *
-     * @param switchId
-     *            The datapath id of the openflow switch
-     * @param description
-     *            The new list of description statistics objects
-     */
-    public void descriptionStatisticsRefreshed(Long switchId, List<OFStatistics> description);
-
-    /**
-     * Notifies that a new list of flows statistics objects for the given switch
-     * is available
-     *
-     * @param switchId
-     *            The datapath id of the openflow switch
-     * @param flows
-     *            The new list of flow statistics objects
-     */
-    public void flowStatisticsRefreshed(Long switchId, List<OFStatistics> flows);
-
-    /**
-     * Notifies that a new list of port statistics objects for the given switch
-     * is available
-     *
-     * @param switchId
-     *            The datapath id of the openflow switch
-     * @param flows
-     *            The new list of port statistics objects
-     */
-    public void portStatisticsRefreshed(Long switchId, List<OFStatistics> ports);
-
-    /**
-     * Notifies that a new list of table statistics objects for the given switch
-     * is available
-     *
-     * @param switchId
-     *            The datapath id of the openflow switch
-     * @param flows
-     *            The new list of table statistics objects
-     */
-    public void tableStatisticsRefreshed(Long switchId, List<OFStatistics> tables);
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/IOFStatisticsManager.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/IOFStatisticsManager.java
deleted file mode 100644 (file)
index fa225a8..0000000
+++ /dev/null
@@ -1,118 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow;
-
-import java.util.List;
-
-import org.openflow.protocol.OFMatch;
-import org.openflow.protocol.statistics.OFStatistics;
-import org.openflow.protocol.statistics.OFStatisticsType;
-
-/**
- * Interface to expose the openflow statistics collected on the switches
- */
-public interface IOFStatisticsManager {
-    /**
-     * Return all the statistics for all the flows present on the specified switch
-     *
-     * @param switchId the openflow datapath id
-     * @return the list of openflow statistics
-     */
-    List<OFStatistics> getOFFlowStatistics(Long switchId);
-
-    /**
-     * Return all the statistics for all the flows present on the specified switch
-     *
-     * @param switchId the openflow datapath id
-     * @param ofMatch the openflow match to query. If null, the query is intended for all the flows
-     * @param priority Priority of the wanted flow
-     * @return the list of openflow statistics
-     */
-    List<OFStatistics> getOFFlowStatistics(Long switchId, OFMatch ofMatch, short priority);
-
-    /**
-     * Return the description statistics for the specified switch.
-     *
-     * @param switchId the openflow datapath id
-     * @return the list of openflow statistics
-     */
-    List<OFStatistics> getOFDescStatistics(Long switchId);
-
-    /**
-     * Returns the statistics for all the ports on the specified switch
-     *
-     * @param switchId the openflow datapath id
-     * @return the list of openflow statistics
-     */
-    List<OFStatistics> getOFPortStatistics(Long switchId);
-
-    /**
-     * Returns the statistics for the specified switch port
-     *
-     * @param switchId the openflow datapath id
-     * @param portId the openflow switch port id
-     * @return the list of openflow statistics
-     */
-    List<OFStatistics> getOFPortStatistics(Long switchId, short portId);
-
-    /**
-     * Returns the number of flows installed on the switch
-     *
-     * @param switchId the openflow datapath id
-     * @return the number of flows installed on the switch
-     */
-    int getFlowsNumber(long switchId);
-
-    /**
-     * Send a statistics request message to the specified switch and returns
-     * the switch response. It blocks the caller until the response has arrived
-     * from the switch or the request has timed out
-     *
-     * @param switchId the openflow datapath id of the target switch
-     * @param statType the openflow statistics type
-     * @param target the target object. For flow statistics it is the OFMatch.
-     *                                  For port statistics, it is the port id. If null the query
-     *                                  will be performed for all the targets for the specified
-     *                                  statistics type.
-     *
-     * @param timeout the timeout in milliseconds the system will wait for a response
-     *                  from the switch, before declaring failure
-     * @return the list of openflow statistics
-     */
-    List<OFStatistics> queryStatistics(Long switchId,
-            OFStatisticsType statType, Object target);
-
-    /**
-     * Returns the averaged transmit rate for the passed switch port
-     *
-     * @param switchId the openflow datapath id of the target switch
-     * @param portId the openflow switch port id
-     * @return the median transmit rate in bits per second
-     */
-    long getTransmitRate(Long switchId, Short port);
-
-    /**
-     * Returns the statistics for the specified switch table
-     *
-     * @param switchId the openflow datapath id
-     * @param tableId the openflow switch table id
-     * @return the list of openflow statistics
-     */
-    List<OFStatistics> getOFTableStatistics(Long switchId, Byte tableId);
-
-    /**
-     * Returns all the table statistics for the node specified
-     *
-     * @param switchId the openflow datapath id
-     * @return the list of openflow statistics
-     */
-    List<OFStatistics> getOFTableStatistics(Long switchId);
-
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/IReadFilterInternalListener.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/IReadFilterInternalListener.java
deleted file mode 100644 (file)
index eb46c60..0000000
+++ /dev/null
@@ -1,60 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.protocol_plugin.openflow;
-
-import java.util.List;
-
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.reader.FlowOnNode;
-import org.opendaylight.controller.sal.reader.NodeConnectorStatistics;
-import org.opendaylight.controller.sal.reader.NodeDescription;
-import org.opendaylight.controller.sal.reader.NodeTableStatistics;
-
-/**
- * The Interface provides notification of statistics (hardware view) updates to
- * ReaderFilter listeners within the protocol plugin
- */
-public interface IReadFilterInternalListener {
-
-    /**
-     * Notifies the hardware view of all the flow installed on the specified
-     * network node was updated
-     *
-     * @param node
-     *            the network node
-     * @param flowStatsList
-     */
-    public void nodeFlowStatisticsUpdated(Node node, List<FlowOnNode> flowStatsList);
-
-    /**
-     * Notifies the hardware view of the specified network node connectors was
-     * updated
-     *
-     * @param node
-     *            the network node
-     */
-    public void nodeConnectorStatisticsUpdated(Node node, List<NodeConnectorStatistics> ncStatsList);
-
-    /**
-     * Notifies the hardware view of the specified network node tables was
-     * updated
-     *
-     * @param node
-     *            the network node
-     */
-    public void nodeTableStatisticsUpdated(Node node, List<NodeTableStatistics> tableStatsList);
-
-    /**
-     * Notifies the hardware view of all the flow installed on the specified
-     * network node was updated
-     *
-     * @param node
-     *            the network node
-     */
-    public void nodeDescriptionStatisticsUpdated(Node node, NodeDescription nodeDescription);
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/IReadServiceFilter.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/IReadServiceFilter.java
deleted file mode 100644 (file)
index 9ba67e3..0000000
+++ /dev/null
@@ -1,158 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow;
-
-import java.util.List;
-
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.NodeTable;
-import org.opendaylight.controller.sal.flowprogrammer.Flow;
-import org.opendaylight.controller.sal.reader.FlowOnNode;
-import org.opendaylight.controller.sal.reader.NodeConnectorStatistics;
-import org.opendaylight.controller.sal.reader.NodeDescription;
-import org.opendaylight.controller.sal.reader.NodeTableStatistics;
-
-/**
- * Interface to serve the hardware information requests coming from SAL It is
- * implemented by the respective OF1.0 plugin component
- *
- */
-public interface IReadServiceFilter {
-    /**
-     * Returns the hardware image for the specified flow on the specified
-     * network node for the passed container
-     *
-     * @param container
-     *            the container for which the request is originated
-     * @param node
-     *            the network node
-     * @param flow
-     *            the target flow
-     * @param cached
-     *            specify if entry has to be queried from the cached hardware
-     *            information maintained in the protocol plugin or directly from
-     *            the network node.
-     * @return The FlowOnNode object containing the information present in
-     *         hardware for the passed flow on the specified network node
-     */
-    public FlowOnNode readFlow(String container, Node node, Flow flow, boolean cached);
-
-    /**
-     * Returns the hardware view of all the flow installed on the specified
-     * network node for the passed container
-     *
-     * @param container
-     *            the container for which the request is originated
-     * @param node
-     *            the network node
-     * @param cached
-     *            specify if entries have to be queried from the cached hardware
-     *            information maintained in the protocol plugin or directly from
-     *            the network node.
-     * @return The list of FlowOnNode objects containing the information present
-     *         in hardware on the specified network node for all its flows
-     */
-    public List<FlowOnNode> readAllFlow(String container, Node node, boolean cached);
-
-    /**
-     * Returns the description of the network node as provided by the node
-     * itself
-     *
-     * @param node
-     *            the network node
-     * @param cached
-     *            specify if entry has to be queried from the cached hardware
-     *            information maintained in the protocol plugin or directly from
-     *            the network node.
-     * @return The NodeDescription object containing the description information
-     *         for the specified network node
-     */
-    public NodeDescription readDescription(Node node, boolean cached);
-
-    /**
-     * Returns the hardware view of the specified network node connector for the
-     * given container
-     *
-     * @param container
-     *            the container for which the request is originated
-     * @param nodeConnector
-     *            the target nodeConnector
-     * @param cached
-     *            specify if entry has to be queried from the cached hardware
-     *            information maintained in the protocol plugin or directly from
-     *            the corresponding network node.
-     * @return The NodeConnectorStatistics object containing the statistics
-     *         present in hardware for the corresponding network node port
-     */
-    public NodeConnectorStatistics readNodeConnector(String container, NodeConnector nodeConnector, boolean cached);
-
-    /**
-     * Returns the hardware info for all the node connectors on the specified
-     * network node for the given container
-     *
-     * @param container
-     *            the container for which the request is originated
-     * @param node
-     *            the target node
-     * @param cached
-     *            specify if entries have to be queried from the cached hardware
-     *            information maintained in the protocol plugin or directly from
-     *            the corresponding network node.
-     * @return The list of NodeConnectorStatistics objects containing the
-     *         statistics present in hardware for all the network node ports
-     */
-    public List<NodeConnectorStatistics> readAllNodeConnector(String container, Node node, boolean cached);
-
-    /**
-     * Returns the table statistics of the node as specified by the given
-     * container
-     *
-     * @param container
-     *            the container for which the request is originated
-     * @param nodeTable
-     *            the target network node table
-     * @param cached
-     *            specify if entry has to be queried from the cached hardware
-     *            information maintained in the protocol plugin or directly from
-     *            the corresponding network node.
-     * @return The NodeTableStatistics object containing the statistics present
-     *         in hardware for the corresponding network node table
-     */
-    public NodeTableStatistics readNodeTable(String container, NodeTable nodeTable, boolean cached);
-
-    /**
-     * Returns the table statistics of all the tables for the specified node
-     *
-     * @param container
-     *            the container for which the request is originated
-     * @param node
-     *            the target node
-     * @param cached
-     *            specify if entries have to be queried from the cached hardware
-     *            information maintained in the protocol plugin or directly from
-     *            the corresponding network node.
-     * @return The list of NodeTableStatistics objects containing the statistics
-     *         present in hardware for all the network node tables
-     */
-    public List<NodeTableStatistics> readAllNodeTable(String containerName, Node node, boolean cached);
-
-    /**
-     * Returns the average transmit rate for the specified node connector on the
-     * given container. If the node connector does not belong to the passed
-     * container a zero value is returned
-     *
-     * @param container
-     *            the container for which the request is originated
-     * @param nodeConnector
-     *            the target node connector
-     * @return The average tx rate in bps
-     */
-    public long getTransmitRate(String container, NodeConnector nodeConnector);
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/IRefreshInternalProvider.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/IRefreshInternalProvider.java
deleted file mode 100644 (file)
index 506d170..0000000
+++ /dev/null
@@ -1,34 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow;
-
-/**
- * @file        IRefreshInternalProvider.java
- *
- * @brief       Topology refresh notifications requested by application
- *                      to be fetched from the plugin
- *
- * For example, an application that has been started late, will want to
- * be up to date with the latest topology. Hence, it requests for a
- * topology refresh from the plugin.
- */
-
-/**
- * Topology refresh requested by the application from the plugin
- *
- */
-
-public interface IRefreshInternalProvider {
-
-    /**
-     * @param containerName
-     *            Name of the container for the topology
-     */
-    public void requestRefresh(String containerName);
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/ITopologyServiceShimListener.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/ITopologyServiceShimListener.java
deleted file mode 100644 (file)
index 35ed2e6..0000000
+++ /dev/null
@@ -1,44 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow;
-
-import java.util.List;
-
-import org.opendaylight.controller.sal.core.Edge;
-import org.opendaylight.controller.sal.topology.TopoEdgeUpdate;
-
-/**
- * The Interface provides Edge updates to the topology listeners
- */
-public interface ITopologyServiceShimListener {
-    /**
-     * Called to update on Edge in the topology graph
-     *
-     * @param topoedgeupdateList
-     *            List of topoedgeupdates Each topoedgeupdate includes edge, its
-     *            Properties ( BandWidth and/or Latency etc) and update type.
-     */
-    public void edgeUpdate(List<TopoEdgeUpdate> topoedgeupdateList);
-
-    /**
-     * Called when an Edge utilization is above the safe threshold configured on
-     * the controller
-     *
-     * @param {@link org.opendaylight.controller.sal.core.Edge}
-     */
-    public void edgeOverUtilized(Edge edge);
-
-    /**
-     * Called when the Edge utilization is back to normal, below the safety
-     * threshold level configured on the controller
-     *
-     * @param {@link org.opendaylight.controller.sal.core.Edge}
-     */
-    public void edgeUtilBackToNormal(Edge edge);
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/core/IController.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/core/IController.java
deleted file mode 100644 (file)
index 9e3c21c..0000000
+++ /dev/null
@@ -1,62 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow.core;
-
-import java.util.Map;
-
-import org.openflow.protocol.OFType;
-
-/**
- * This interface defines an abstraction of the Open Flow Controller that allows applications to control and manage the Open Flow switches.
- *
- */
-public interface IController {
-
-    /**
-     * Allows application to start receiving OF messages received from switches.
-     * @param type the type of OF message that applications want to receive
-     * @param listener: Object that implements the IMessageListener
-     */
-    public void addMessageListener(OFType type, IMessageListener listener);
-
-    /**
-     * Allows application to stop receiving OF message received from switches.
-     * @param type The type of OF message that applications want to stop receiving
-     * @param listener The object that implements the IMessageListener
-     */
-    public void removeMessageListener(OFType type, IMessageListener listener);
-
-    /**
-     * Allows application to start receiving switch state change events.
-     * @param listener The object that implements the ISwitchStateListener
-     */
-    public void addSwitchStateListener(ISwitchStateListener listener);
-
-    /**
-     * Allows application to stop receiving switch state change events.
-     * @param listener The object that implements the ISwitchStateListener
-     */
-    public void removeSwitchStateListener(ISwitchStateListener listener);
-
-    /**
-     * Returns a map containing all the OF switches that are currently connected to the Controller.
-     * @return Map of ISwitch
-     */
-    public Map<Long, ISwitch> getSwitches();
-
-    /**
-     * Returns the ISwitch of the given switchId.
-     *
-     * @param switchId The switch ID
-     * @return ISwitch if present, null otherwise
-     */
-    public ISwitch getSwitch(Long switchId);
-
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/core/IMessageListener.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/core/IMessageListener.java
deleted file mode 100644 (file)
index aed19db..0000000
+++ /dev/null
@@ -1,26 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow.core;
-
-import org.openflow.protocol.OFMessage;
-
-/**
- * Interface to be implemented by applications that want to receive OF messages.
- *
- */
-public interface IMessageListener {
-    /**
-     * This method is called by the Controller when a message is received from a switch.
-     * Application who is interested in receiving OF Messages needs to implement this method.
-     * @param sw The ISwitch which sent the OF message
-     * @param msg The OF message
-     */
-    public void receive(ISwitch sw, OFMessage msg);
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/core/IMessageReadWrite.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/core/IMessageReadWrite.java
deleted file mode 100644 (file)
index ce91e1f..0000000
+++ /dev/null
@@ -1,53 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow.core;
-
-import java.util.List;
-
-import org.openflow.protocol.OFMessage;
-
-/**
- * This interface defines low level routines to read/write messages on an open
- * socket channel. If secure communication is desired, these methods also perform
- * encryption and decryption of the network data.
- */
-public interface IMessageReadWrite {
-        /**
-         * Sends the OF message out over the socket channel. For secure
-         * communication, the data will be encrypted.
-         *
-         * @param msg OF message to be sent
-         * @throws Exception
-         */
-        public void asyncSend(OFMessage msg) throws Exception;
-
-        /**
-         * Resumes sending the remaining messages in the outgoing buffer
-         * @throws Exception
-         */
-        public void resumeSend() throws Exception;
-
-        /**
-         * Reads the incoming network data from the socket and retrieves the OF
-         * messages. For secure communication, the data will be decrypted first.
-         *
-         * @return list of OF messages
-         * @throws Exception
-         */
-    public List<OFMessage> readMessages() throws Exception;
-
-        /**
-         * Proper clean up when the switch connection is closed
-         *
-         * @return
-         * @throws Exception
-         */
-    public void stop() throws Exception;
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/core/ISwitch.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/core/ISwitch.java
deleted file mode 100644 (file)
index d924b66..0000000
+++ /dev/null
@@ -1,240 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow.core;
-
-import java.util.Date;
-import java.util.List;
-import java.util.Map;
-import java.util.Set;
-
-import org.openflow.protocol.OFMessage;
-import org.openflow.protocol.OFPhysicalPort;
-import org.openflow.protocol.OFStatisticsRequest;
-
-/**
- * This interface defines an abstraction of an Open Flow Switch.
- *
- */
-public interface ISwitch {
-    /**
-     * Gets a unique XID.
-     *
-     * @return XID
-     */
-    public int getNextXid();
-
-    /**
-     * Returns the Switch's ID.
-     *
-     * @return the Switch's ID
-     */
-    public Long getId();
-
-    /**
-     * Returns the Switch's table numbers supported by datapath
-     *
-     * @return the tables
-     */
-    public Byte getTables();
-
-    /**
-     * Returns the Switch's bitmap of supported ofp_action_type
-     *
-     * @return the actions
-     */
-    public Integer getActions();
-
-    /**
-     * Returns the Switch's bitmap of supported ofp_capabilities
-     *
-     * @return the capabilities
-     */
-    public Integer getCapabilities();
-
-    /**
-     * Returns the Switch's buffering capacity in Number of Pkts
-     *
-     * @return the buffers
-     */
-    public Integer getBuffers();
-
-    /**
-     * Returns the Date when the switch was connected.
-     *
-     * @return Date The date when the switch was connected
-     */
-    public Date getConnectedDate();
-
-    /**
-     * This method puts the message in an outgoing priority queue with normal
-     * priority. It will be served after high priority messages. The method
-     * should be used for non-critical messages such as statistics request,
-     * discovery packets, etc. An unique XID is generated automatically and
-     * inserted into the message.
-     *
-     * @param msg
-     *            The OF message to be sent
-     * @return The XID used
-     */
-    public Integer asyncSend(OFMessage msg);
-
-    /**
-     * This method puts the message in an outgoing priority queue with normal
-     * priority. It will be served after high priority messages. The method
-     * should be used for non-critical messages such as statistics request,
-     * discovery packets, etc. The specified XID is inserted into the message.
-     *
-     * @param msg
-     *            The OF message to be Sent
-     * @param xid
-     *            The XID to be used in the message
-     * @return The XID used
-     */
-    public Integer asyncSend(OFMessage msg, int xid);
-
-    /**
-     * This method puts the message in an outgoing priority queue with high
-     * priority. It will be served first before normal priority messages. The
-     * method should be used for critical messages such as hello, echo reply
-     * etc. An unique XID is generated automatically and inserted into the
-     * message.
-     *
-     * @param msg
-     *            The OF message to be sent
-     * @return The XID used
-     */
-    public Integer asyncFastSend(OFMessage msg);
-
-    /**
-     * This method puts the message in an outgoing priority queue with high
-     * priority. It will be served first before normal priority messages. The
-     * method should be used for critical messages such as hello, echo reply
-     * etc. The specified XID is inserted into the message.
-     *
-     * @param msg
-     *            The OF message to be sent
-     * @param xid
-     *            The XID to be used in the message
-     * @return The XID used
-     */
-    public Integer asyncFastSend(OFMessage msg, int xid);
-
-    /**
-     * Sends the OF message followed by a Barrier Request with a unique XID
-     * which is automatically generated, and waits for a result from the switch.
-     *
-     * @param msg
-     *            The message to be sent
-     * @return An Object which has one of the followings instances/values:
-     *         Boolean with value true to indicate the message has been
-     *         successfully processed and acknowledged by the switch; Boolean
-     *         with value false to indicate the message has failed to be
-     *         processed by the switch within a period of time or OFError to
-     *         indicate that the message has been denied by the switch which
-     *         responded with OFError.
-     */
-    public Object syncSend(OFMessage msg);
-
-    /**
-     * Returns a map containing all OFPhysicalPorts of this switch.
-     *
-     * @return The Map of OFPhysicalPort
-     */
-    public Map<Short, OFPhysicalPort> getPhysicalPorts();
-
-    /**
-     * Returns a Set containing all port IDs of this switch.
-     *
-     * @return The Set of port ID
-     */
-    public Set<Short> getPorts();
-
-    /**
-     * Returns OFPhysicalPort of the specified portNumber of this switch.
-     *
-     * @param portNumber
-     *            The port ID
-     * @return OFPhysicalPort for the specified PortNumber
-     */
-    public OFPhysicalPort getPhysicalPort(Short portNumber);
-
-    /**
-     * Returns the bandwidth of the specified portNumber of this switch.
-     *
-     * @param portNumber
-     *            the port ID
-     * @return bandwidth
-     */
-    public Integer getPortBandwidth(Short portNumber);
-
-    /**
-     * Returns True if the port is enabled,
-     *
-     * @param portNumber
-     *            the port ID
-     * @return True if the port is enabled
-     */
-    public boolean isPortEnabled(short portNumber);
-
-    /**
-     * Returns True if the port is enabled.
-     *
-     * @param port
-     *            the OpenFlow port
-     * @return True if the port is enabled
-     */
-    public boolean isPortEnabled(OFPhysicalPort port);
-
-    /**
-     * Returns a list containing all enabled ports of this switch.
-     *
-     * @return: List containing all enabled ports of this switch
-     */
-    public List<OFPhysicalPort> getEnabledPorts();
-
-    /**
-     * Sends OFStatisticsRequest with a unique XID generated automatically and
-     * waits for a result from the switch.
-     *
-     * @param req
-     *            the OF Statistic Request to be sent
-     * @return Object has one of the following instances/values::
-     *         List<OFStatistics>, a list of statistics records received from
-     *         the switch as response from the request; OFError if the switch
-     *         failed handle the request or NULL if timeout has occurred while
-     *         waiting for the response.
-     */
-    public Object getStatistics(OFStatisticsRequest req);
-
-    /**
-     * Returns true if the switch has reached the operational state (has sent
-     * FEATURE_REPLY to the controller).
-     *
-     * @return true if the switch is operational
-     */
-    public boolean isOperational();
-
-    /**
-     * Send Barrier message synchronously. The caller will be blocked until the
-     * Barrier reply arrives.
-     */
-    public Object syncSendBarrierMessage();
-
-    /**
-     * Send Barrier message asynchronously. The caller is not blocked. The
-     * Barrier message will be sent in a transmit thread which will be blocked
-     * until the Barrier reply arrives.
-     */
-    public Object asyncSendBarrierMessage();
-
-    /**
-     * Send a FLOW_MOD message with a wildcard match and action=DELETE.
-     */
-    public void deleteAllFlows();
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/core/ISwitchStateListener.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/core/ISwitchStateListener.java
deleted file mode 100644 (file)
index 608b6f5..0000000
+++ /dev/null
@@ -1,31 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow.core;
-
-/**
- * Interface to be implemented by applications that want to receive switch state event changes.
- *
- */
-public interface ISwitchStateListener {
-    /**
-     * This method is invoked by Controller when a switch has been connected to the Controller.
-     * Application who wants to receive this event needs to implement this method.
-     * @param sw The switch that has just connected.
-     */
-    public void switchAdded(ISwitch sw);
-
-    /**
-     * This method is invoked by Controller when a switch has been disconnected from the Controller.
-     * Application who wants to receive this event needs to implement this method.
-     * @param sw The switch that has just disconnected.
-     */
-    public void switchDeleted(ISwitch sw);
-
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/core/internal/Controller.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/core/internal/Controller.java
deleted file mode 100644 (file)
index 63dd0bc..0000000
+++ /dev/null
@@ -1,430 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow.core.internal;
-
-import java.io.IOException;
-import java.nio.channels.SelectionKey;
-import java.nio.channels.Selector;
-import java.nio.channels.ServerSocketChannel;
-import java.nio.channels.SocketChannel;
-import java.util.Comparator;
-import java.util.Date;
-import java.util.Iterator;
-import java.util.Map;
-import java.util.Map.Entry;
-import java.util.Set;
-import java.util.concurrent.ConcurrentHashMap;
-import java.util.concurrent.ConcurrentMap;
-import java.util.concurrent.PriorityBlockingQueue;
-import java.util.concurrent.atomic.AtomicInteger;
-
-import org.eclipse.osgi.framework.console.CommandInterpreter;
-import org.eclipse.osgi.framework.console.CommandProvider;
-import org.opendaylight.controller.protocol_plugin.openflow.core.IController;
-import org.opendaylight.controller.protocol_plugin.openflow.core.IMessageListener;
-import org.opendaylight.controller.protocol_plugin.openflow.core.ISwitch;
-import org.opendaylight.controller.protocol_plugin.openflow.core.ISwitchStateListener;
-import org.opendaylight.controller.sal.connection.ConnectionConstants;
-import org.opendaylight.controller.sal.connection.IPluginInConnectionService;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.sal.utils.StatusCode;
-import org.openflow.protocol.OFMessage;
-import org.openflow.protocol.OFType;
-import org.openflow.util.HexString;
-import org.osgi.framework.BundleContext;
-import org.osgi.framework.FrameworkUtil;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-public class Controller implements IController, CommandProvider, IPluginInConnectionService {
-    private static final Logger logger = LoggerFactory
-            .getLogger(Controller.class);
-    private ControllerIO controllerIO;
-    private Thread switchEventThread;
-    private volatile boolean shutdownSwitchEventThread;// default to false
-    private ConcurrentHashMap<Long, ISwitch> switches;
-    private PriorityBlockingQueue<SwitchEvent> switchEvents;
-    // only 1 message listener per OFType
-    private ConcurrentMap<OFType, IMessageListener> messageListeners;
-    // only 1 switch state listener
-    private ISwitchStateListener switchStateListener;
-    private AtomicInteger switchInstanceNumber;
-    private int MAXQUEUESIZE = 50000;
-
-    private static enum SwitchEventPriority { LOW, NORMAL, HIGH }
-
-    /*
-     * this thread monitors the switchEvents queue for new incoming events from
-     * switch
-     */
-    private class EventHandler implements Runnable {
-        @Override
-        public void run() {
-
-            while (true) {
-                try {
-                    if(shutdownSwitchEventThread) {
-                        // break out of the infinite loop
-                        // if you are shutting down
-                        logger.info("Switch Event Thread is shutting down");
-                        break;
-                    }
-                    SwitchEvent ev = switchEvents.take();
-                    SwitchEvent.SwitchEventType eType = ev.getEventType();
-                    ISwitch sw = ev.getSwitch();
-                    switch (eType) {
-                    case SWITCH_ADD:
-                        Long sid = sw.getId();
-                        ISwitch existingSwitch = switches.get(sid);
-                        if (existingSwitch != null) {
-                            logger.info("Replacing existing {} with New {}",
-                                    existingSwitch, sw);
-                            disconnectSwitch(existingSwitch);
-                        }
-                        switches.put(sid, sw);
-                        notifySwitchAdded(sw);
-                        break;
-                    case SWITCH_DELETE:
-                        disconnectSwitch(sw);
-                        break;
-                    case SWITCH_ERROR:
-                        disconnectSwitch(sw);
-                        break;
-                    case SWITCH_MESSAGE:
-                        OFMessage msg = ev.getMsg();
-                        if (msg != null) {
-                            IMessageListener listener = messageListeners
-                                    .get(msg.getType());
-                            if (listener != null) {
-                                listener.receive(sw, msg);
-                            }
-                        }
-                        break;
-                    default:
-                        logger.error("Unknown switch event {}", eType.ordinal());
-                    }
-                } catch (InterruptedException e) {
-                    // nothing to do except retry
-                } catch (Exception e) {
-                    // log the exception and retry
-                    logger.warn("Exception in Switch Event Thread is {}" ,e);
-                }
-            }
-            switchEvents.clear();
-        }
-    }
-
-    /**
-     * Function called by the dependency manager when all the required
-     * dependencies are satisfied
-     *
-     */
-    public void init() {
-        logger.debug("Initializing!");
-        this.switches = new ConcurrentHashMap<Long, ISwitch>();
-        this.switchEvents = new PriorityBlockingQueue<SwitchEvent>(MAXQUEUESIZE, new Comparator<SwitchEvent>() {
-            @Override
-            public int compare(SwitchEvent p1, SwitchEvent p2) {
-                return p2.getPriority() - p1.getPriority();
-            }
-        });
-        this.messageListeners = new ConcurrentHashMap<OFType, IMessageListener>();
-        this.switchStateListener = null;
-        this.switchInstanceNumber = new AtomicInteger(0);
-        registerWithOSGIConsole();
-    }
-
-    /**
-     * Function called by dependency manager after "init ()" is called and after
-     * the services provided by the class are registered in the service registry
-     *
-     */
-    public void start() {
-        logger.debug("Starting!");
-        /*
-         * start a thread to handle event coming from the switch
-         */
-        switchEventThread = new Thread(new EventHandler(), "SwitchEvent Thread");
-        switchEventThread.start();
-
-        // spawn a thread to start to listen on the open flow port
-        controllerIO = new ControllerIO(this);
-        try {
-            controllerIO.start();
-        } catch (IOException ex) {
-            logger.error("Caught exception while starting:", ex);
-        }
-    }
-
-    /**
-     * Function called by the dependency manager before the services exported by
-     * the component are unregistered, this will be followed by a "destroy ()"
-     * calls
-     *
-     */
-    public void stop() {
-        for (Iterator<Entry<Long, ISwitch>> it = switches.entrySet().iterator(); it
-                .hasNext();) {
-            Entry<Long, ISwitch> entry = it.next();
-            ((SwitchHandler) entry.getValue()).stop();
-            it.remove();
-        }
-        shutdownSwitchEventThread = true;
-        switchEventThread.interrupt();
-        try {
-            controllerIO.shutDown();
-        } catch (IOException ex) {
-            logger.error("Caught exception while stopping:", ex);
-        }
-    }
-
-    /**
-     * Function called by the dependency manager when at least one dependency
-     * become unsatisfied or when the component is shutting down because for
-     * example bundle is being stopped.
-     *
-     */
-    public void destroy() {
-    }
-
-    @Override
-    public void addMessageListener(OFType type, IMessageListener listener) {
-        IMessageListener currentListener = this.messageListeners.get(type);
-        if (currentListener != null) {
-            logger.warn("{} is already listened by {}", type,
-                    currentListener);
-        }
-        this.messageListeners.put(type, listener);
-        logger.debug("{} is now listened by {}", type, listener);
-    }
-
-    @Override
-    public void removeMessageListener(OFType type, IMessageListener listener) {
-        IMessageListener currentListener = this.messageListeners.get(type);
-        if ((currentListener != null) && (currentListener == listener)) {
-            logger.debug("{} listener {} is Removed", type, listener);
-            this.messageListeners.remove(type);
-        }
-    }
-
-    @Override
-    public void addSwitchStateListener(ISwitchStateListener listener) {
-        if (this.switchStateListener != null) {
-            logger.warn("Switch events are already listened by {}",
-                    this.switchStateListener);
-        }
-        this.switchStateListener = listener;
-        logger.debug("Switch events are now listened by {}", listener);
-    }
-
-    @Override
-    public void removeSwitchStateListener(ISwitchStateListener listener) {
-        if ((this.switchStateListener != null)
-                && (this.switchStateListener == listener)) {
-            logger.debug("SwitchStateListener {} is Removed", listener);
-            this.switchStateListener = null;
-        }
-    }
-
-    public void handleNewConnection(Selector selector,
-            SelectionKey serverSelectionKey) {
-        ServerSocketChannel ssc = (ServerSocketChannel) serverSelectionKey
-                .channel();
-        SocketChannel sc = null;
-        try {
-            sc = ssc.accept();
-            // create new switch
-            int i = this.switchInstanceNumber.addAndGet(1);
-            String instanceName = "SwitchHandler-" + i;
-            SwitchHandler switchHandler = new SwitchHandler(this, sc, instanceName);
-            switchHandler.start();
-            if (sc.isConnected()) {
-                logger.info("Switch:{} is connected to the Controller",
-                        sc.socket().getRemoteSocketAddress()
-                        .toString().split("/")[1]);
-            }
-
-        } catch (IOException e) {
-            return;
-        }
-    }
-
-    private void disconnectSwitch(ISwitch sw) {
-        if (((SwitchHandler) sw).isOperational()) {
-            Long sid = sw.getId();
-            if (this.switches.remove(sid, sw)) {
-                logger.info("{} is removed", sw);
-                notifySwitchDeleted(sw);
-            }
-        }
-        ((SwitchHandler) sw).stop();
-        sw = null;
-    }
-
-    private void notifySwitchAdded(ISwitch sw) {
-        if (switchStateListener != null) {
-            switchStateListener.switchAdded(sw);
-        }
-    }
-
-    private void notifySwitchDeleted(ISwitch sw) {
-        if (switchStateListener != null) {
-            switchStateListener.switchDeleted(sw);
-        }
-    }
-
-    private synchronized void addSwitchEvent(SwitchEvent event) {
-        this.switchEvents.put(event);
-    }
-
-    public void takeSwitchEventAdd(ISwitch sw) {
-        SwitchEvent ev = new SwitchEvent(SwitchEvent.SwitchEventType.SWITCH_ADD, sw, null,
-                SwitchEventPriority.HIGH.ordinal());
-        addSwitchEvent(ev);
-    }
-
-    public void takeSwitchEventDelete(ISwitch sw) {
-        SwitchEvent ev = new SwitchEvent(SwitchEvent.SwitchEventType.SWITCH_DELETE, sw, null,
-                SwitchEventPriority.HIGH.ordinal());
-        addSwitchEvent(ev);
-    }
-
-    public void takeSwitchEventError(ISwitch sw) {
-        SwitchEvent ev = new SwitchEvent(SwitchEvent.SwitchEventType.SWITCH_ERROR, sw, null,
-                SwitchEventPriority.NORMAL.ordinal());
-        addSwitchEvent(ev);
-    }
-
-    public void takeSwitchEventMsg(ISwitch sw, OFMessage msg) {
-        if (messageListeners.get(msg.getType()) != null) {
-            SwitchEvent ev = new SwitchEvent(SwitchEvent.SwitchEventType.SWITCH_MESSAGE, sw, msg,
-                    SwitchEventPriority.LOW.ordinal());
-            addSwitchEvent(ev);
-        }
-    }
-
-    @Override
-    public Map<Long, ISwitch> getSwitches() {
-        return this.switches;
-    }
-
-    @Override
-    public ISwitch getSwitch(Long switchId) {
-        return this.switches.get(switchId);
-    }
-
-    public void _controllerShowQueueSize(CommandInterpreter ci) {
-        ci.print("switchEvents queue size: " + switchEvents.size() + "\n");
-    }
-
-    public void _controllerShowSwitches(CommandInterpreter ci) {
-        Set<Long> sids = switches.keySet();
-        StringBuffer s = new StringBuffer();
-        int size = sids.size();
-        if (size == 0) {
-            ci.print("switches: empty");
-            return;
-        }
-        Iterator<Long> iter = sids.iterator();
-        s.append("Total: " + size + " switches\n");
-        while (iter.hasNext()) {
-            Long sid = iter.next();
-            Date date = switches.get(sid).getConnectedDate();
-            String switchInstanceName = ((SwitchHandler) switches.get(sid))
-                    .getInstanceName();
-            s.append(switchInstanceName + "/" + HexString.toHexString(sid)
-                    + " connected since " + date.toString() + "\n");
-        }
-        ci.print(s.toString());
-        return;
-    }
-
-    public void _controllerReset(CommandInterpreter ci) {
-        ci.print("...Disconnecting the communication to all switches...\n");
-        stop();
-        try {
-            Thread.sleep(1000);
-        } catch (InterruptedException ie) {
-        } finally {
-            ci.print("...start to accept connections from switches...\n");
-            start();
-        }
-    }
-
-    public void _controllerShowConnConfig(CommandInterpreter ci) {
-        String str = System.getProperty("secureChannelEnabled");
-        if ((str != null) && (str.trim().equalsIgnoreCase("true"))) {
-            ci.print("The Controller and Switch should communicate through TLS connetion.\n");
-
-            String keyStoreFile = System.getProperty("controllerKeyStore");
-            String trustStoreFile = System.getProperty("controllerTrustStore");
-            if ((keyStoreFile == null) || keyStoreFile.trim().isEmpty()) {
-                ci.print("controllerKeyStore not specified\n");
-            } else {
-                ci.print("controllerKeyStore=" + keyStoreFile + "\n");
-            }
-            if ((trustStoreFile == null) || trustStoreFile.trim().isEmpty()) {
-                ci.print("controllerTrustStore not specified\n");
-            } else {
-                ci.print("controllerTrustStore=" + trustStoreFile + "\n");
-            }
-        } else {
-            ci.print("The Controller and Switch should communicate through TCP connetion.\n");
-        }
-    }
-
-    private void registerWithOSGIConsole() {
-        BundleContext bundleContext = FrameworkUtil.getBundle(this.getClass())
-                .getBundleContext();
-        bundleContext.registerService(CommandProvider.class.getName(), this,
-                null);
-    }
-
-    @Override
-    public String getHelp() {
-        StringBuffer help = new StringBuffer();
-        help.append("---Open Flow Controller---\n");
-        help.append("\t controllerShowSwitches\n");
-        help.append("\t controllerReset\n");
-        help.append("\t controllerShowConnConfig\n");
-        help.append("\t controllerShowQueueSize\n");
-        return help.toString();
-    }
-
-    @Override
-    public Status disconnect(Node node) {
-        ISwitch sw = getSwitch((Long) node.getID());
-        if (sw != null) disconnectSwitch(sw);
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    @Override
-    public Node connect(String connectionIdentifier, Map<ConnectionConstants, String> params) {
-        return null;
-    }
-
-    /**
-     * View Change notification
-     */
-    public void notifyClusterViewChanged() {
-        for (ISwitch sw : switches.values()) {
-            notifySwitchAdded(sw);
-        }
-    }
-
-    /**
-     * Node Disconnected from the node's master controller.
-     */
-    @Override
-    public void notifyNodeDisconnectFromMaster(Node node) {
-        ISwitch sw = switches.get((Long)node.getID());
-        if (sw != null) notifySwitchAdded(sw);
-    }
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/core/internal/ControllerIO.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/core/internal/ControllerIO.java
deleted file mode 100644 (file)
index 47461f4..0000000
+++ /dev/null
@@ -1,191 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow.core.internal;
-
-import java.io.IOException;
-import java.net.InetAddress;
-import java.net.NetworkInterface;
-import java.net.SocketException;
-import java.nio.channels.SelectionKey;
-import java.nio.channels.Selector;
-import java.nio.channels.ServerSocketChannel;
-import java.nio.channels.spi.SelectorProvider;
-import java.util.Iterator;
-
-import org.opendaylight.controller.protocol_plugin.openflow.core.IController;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-public class ControllerIO {
-    private static final Logger logger = LoggerFactory
-            .getLogger(ControllerIO.class);
-    private static Short defaultOpenFlowPort = 6633;
-    private Short openFlowPort;
-    private InetAddress controllerIP;
-    private NetworkInterface netInt;
-    private SelectionKey serverSelectionKey;
-    private IController listener;
-    private ServerSocketChannel serverSocket;
-    private Selector selector;
-    private boolean running;
-    private Thread controllerIOThread;
-
-    public ControllerIO(IController l) {
-        this.listener = l;
-        this.openFlowPort = defaultOpenFlowPort;
-        String portString = System.getProperty("of.listenPort");
-        if (portString != null) {
-            try {
-                openFlowPort = Short.decode(portString).shortValue();
-            } catch (NumberFormatException e) {
-                logger.warn("Invalid port:{}, use default({})", portString,
-                        openFlowPort);
-            }
-        }
-        String addressString = System.getProperty("of.address");
-        if (addressString != null) {
-            try {
-                controllerIP = InetAddress.getByName(addressString);
-            } catch (Exception e) {
-                controllerIP = null;
-                logger.warn("Invalid IP: {}, use wildcard *", addressString);
-            }
-        } else {
-            controllerIP = null;
-        }
-    }
-
-    public void start() throws IOException {
-        this.running = true;
-        this.netInt = null;
-        controllerIOThread = new Thread(new Runnable() {
-            @Override
-            public void run() {
-                waitUntilInterfaceUp();
-                if (!startAcceptConnections()) {
-                    return;
-                }
-                logger.info("Controller is now listening on {}:{}",
-                        (controllerIP == null) ? "any" : controllerIP.getHostAddress(),
-                        openFlowPort);
-                boolean netInterfaceUp = true;
-                while (running) {
-                    try {
-                        // wait for an incoming connection
-                        // check interface state every 5sec
-                        selector.select(5000);
-                        Iterator<SelectionKey> selectedKeys = selector
-                                .selectedKeys().iterator();
-                        netInterfaceUp = isNetInterfaceUp(netInterfaceUp);
-                        while (selectedKeys.hasNext()) {
-                            SelectionKey skey = selectedKeys.next();
-                            selectedKeys.remove();
-                            if (skey.isValid() && skey.isAcceptable()) {
-                                ((Controller) listener).handleNewConnection(
-                                        selector, serverSelectionKey);
-                            }
-                        }
-                    } catch (Exception e) {
-                        continue;
-                    }
-                }
-            }
-        }, "ControllerI/O Thread");
-        controllerIOThread.start();
-    }
-
-    private boolean startAcceptConnections() {
-        if (running) {
-            try {
-                // obtain a selector
-                selector = SelectorProvider.provider().openSelector();
-                // create the listening socket
-                serverSocket = ServerSocketChannel.open();
-                serverSocket.configureBlocking(false);
-                serverSocket.socket().bind(
-                        new java.net.InetSocketAddress(controllerIP,
-                                openFlowPort));
-                serverSocket.socket().setReuseAddress(true);
-                // register this socket for accepting incoming
-                // connections
-                serverSelectionKey = serverSocket.register(selector,
-                        SelectionKey.OP_ACCEPT);
-            } catch (IOException e) {
-                logger.error(
-                        "Failed to listen on {}:{}, exit",
-                        (controllerIP == null) ? "" : controllerIP
-                                .getHostAddress(), openFlowPort);
-                return false;
-            }
-            return true;
-        }
-        return false;
-    }
-
-    private boolean isNetInterfaceUp(boolean currentlyUp) {
-        if (controllerIP == null) {
-            // for wildcard address, return since there is always an "up"
-            // interface (such as loopback)
-            return true;
-        }
-        boolean up;
-        try {
-            if (netInt == null) {
-                logger.warn("Can't find any operational interface for address {}",
-                        controllerIP.getHostAddress());
-                return false;
-            }
-            up = netInt.isUp();
-            if (!up) {
-                // always generate log if the interface is down
-                logger.warn("Interface {} with address {} is DOWN!",
-                        netInt.getDisplayName(),
-                        controllerIP.getHostAddress());
-            } else {
-                if (!currentlyUp) {
-                    // only generate log if the interface changes from down to up
-                    logger.trace("Interface {} with address {} is UP!",
-                            netInt.getDisplayName(),
-                            controllerIP.getHostAddress());
-                }
-            }
-        } catch (SocketException e) {
-            logger.warn("Interface {} with address {} is DOWN!",
-                    netInt.getDisplayName(),
-                    controllerIP.getHostAddress());
-           up = false;
-        }
-        return up;
-    }
-
-    private void waitUntilInterfaceUp() {
-        if (controllerIP == null) {
-            // for wildcard address, return since there is always an "up"
-            // interface (such as loopback)
-            return;
-        }
-        boolean isUp = false;
-        do {
-            try {
-                // get the network interface from the address
-                netInt = NetworkInterface.getByInetAddress(controllerIP);
-                isUp = isNetInterfaceUp(isUp);
-                if (!isUp) {
-                    Thread.sleep(5000);
-                }
-            } catch (Exception e) {
-            }
-        } while ((!isUp) && (running));
-    }
-    public void shutDown() throws IOException {
-        this.running = false;
-        this.selector.wakeup();
-        this.serverSocket.close();
-    }
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/core/internal/MessageReadWriteService.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/core/internal/MessageReadWriteService.java
deleted file mode 100644 (file)
index 9041004..0000000
+++ /dev/null
@@ -1,155 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow.core.internal;
-
-import java.nio.ByteBuffer;
-import java.nio.channels.AsynchronousCloseException;
-import java.nio.channels.ClosedChannelException;
-import java.nio.channels.SelectionKey;
-import java.nio.channels.Selector;
-import java.nio.channels.SocketChannel;
-import java.util.List;
-
-import org.opendaylight.controller.protocol_plugin.openflow.core.IMessageReadWrite;
-import org.openflow.protocol.OFMessage;
-import org.openflow.protocol.factory.BasicFactory;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * This class implements methods to read/write messages over an established
- * socket channel. The data exchange is in clear text format.
- */
-public class MessageReadWriteService implements IMessageReadWrite {
-    private static final Logger logger = LoggerFactory
-            .getLogger(MessageReadWriteService.class);
-    private static final int bufferSize = 1024 * 1024;
-
-    private Selector selector;
-    private SelectionKey clientSelectionKey;
-    private SocketChannel socket;
-    private ByteBuffer inBuffer;
-    private ByteBuffer outBuffer;
-    private BasicFactory factory;
-
-    public MessageReadWriteService(SocketChannel socket, Selector selector)
-            throws ClosedChannelException {
-        this.socket = socket;
-        this.selector = selector;
-        this.factory = new BasicFactory();
-        this.inBuffer = ByteBuffer.allocateDirect(bufferSize);
-        this.outBuffer = ByteBuffer.allocateDirect(bufferSize);
-        this.clientSelectionKey = this.socket.register(this.selector,
-                SelectionKey.OP_READ);
-    }
-
-    /**
-     * Sends the OF message out over the socket channel.
-     *
-     * @param msg
-     *            OF message to be sent
-     * @throws Exception
-     */
-    @Override
-    public void asyncSend(OFMessage msg) throws Exception {
-        synchronized (outBuffer) {
-            int msgLen = msg.getLengthU();
-            if (outBuffer.remaining() < msgLen) {
-                // increase the buffer size so that it can contain this message
-                ByteBuffer newBuffer = ByteBuffer.allocateDirect(outBuffer
-                        .capacity() + msgLen);
-                outBuffer.flip();
-                newBuffer.put(outBuffer);
-                outBuffer = newBuffer;
-            }
-        }
-        synchronized (outBuffer) {
-            msg.writeTo(outBuffer);
-
-            if (!socket.isOpen()) {
-                return;
-            }
-
-            outBuffer.flip();
-            socket.write(outBuffer);
-            outBuffer.compact();
-            if (outBuffer.position() > 0) {
-                this.clientSelectionKey = this.socket.register(this.selector,
-                        SelectionKey.OP_WRITE, this);
-            }
-            logger.trace("Message sent: {}", msg);
-        }
-    }
-
-    /**
-     * Resumes sending the remaining messages in the outgoing buffer
-     *
-     * @throws Exception
-     */
-    @Override
-    public void resumeSend() throws Exception {
-        synchronized (outBuffer) {
-            if (!socket.isOpen()) {
-                return;
-            }
-
-            outBuffer.flip();
-            socket.write(outBuffer);
-            outBuffer.compact();
-            if (outBuffer.position() > 0) {
-                this.clientSelectionKey = this.socket.register(this.selector,
-                        SelectionKey.OP_WRITE, this);
-            } else {
-                this.clientSelectionKey = this.socket.register(this.selector,
-                        SelectionKey.OP_READ, this);
-            }
-        }
-    }
-
-    /**
-     * Reads the incoming network data from the socket and retrieves the OF
-     * messages.
-     *
-     * @return list of OF messages
-     * @throws Exception
-     */
-    @Override
-    public List<OFMessage> readMessages() throws Exception {
-        if (!socket.isOpen()) {
-            return null;
-        }
-
-        List<OFMessage> msgs = null;
-        int bytesRead = -1;
-        bytesRead = socket.read(inBuffer);
-        if (bytesRead < 0) {
-            throw new AsynchronousCloseException();
-        }
-
-        try {
-            inBuffer.flip();
-            msgs = factory.parseMessages(inBuffer);
-            if (inBuffer.hasRemaining()) {
-                inBuffer.compact();
-            } else {
-                inBuffer.clear();
-            }
-        } catch (Exception e) {
-            inBuffer.clear();
-            logger.debug("Caught exception: ", e);
-        }
-        return msgs;
-    }
-
-    @Override
-    public void stop() {
-        inBuffer = null;
-        outBuffer = null;
-    }
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/core/internal/PriorityMessage.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/core/internal/PriorityMessage.java
deleted file mode 100644 (file)
index 7893ae0..0000000
+++ /dev/null
@@ -1,92 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow.core.internal;
-
-import java.util.concurrent.atomic.AtomicLong;
-
-import org.openflow.protocol.OFMessage;
-
-/**
- * This class describes an OpenFlow message with priority
- */
-class PriorityMessage {
-    OFMessage msg;
-    int priority;
-    final static AtomicLong seq = new AtomicLong();
-    final long seqNum;
-    boolean syncReply; // set to true if we want to be blocked until the response arrives
-
-    public PriorityMessage(OFMessage msg, int priority) {
-        this.msg = msg;
-        this.priority = priority;
-        this.seqNum = seq.getAndIncrement();
-        this.syncReply = false;
-    }
-
-    public PriorityMessage(OFMessage msg, int priority, boolean syncReply) {
-        this(msg, priority);
-        this.syncReply = syncReply;
-    }
-
-    public OFMessage getMsg() {
-        return msg;
-    }
-
-    public void setMsg(OFMessage msg) {
-        this.msg = msg;
-    }
-
-    public int getPriority() {
-        return priority;
-    }
-
-    public void setPriority(int priority) {
-        this.priority = priority;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + ((msg == null) ? 0 : msg.hashCode());
-        result = prime * result + priority;
-        result = prime * result + (int) (seqNum ^ (seqNum >>> 32));
-        result = prime * result + (syncReply ? 1231 : 1237);
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj)
-            return true;
-        if (obj == null)
-            return false;
-        if (getClass() != obj.getClass())
-            return false;
-        PriorityMessage other = (PriorityMessage) obj;
-        if (msg == null) {
-            if (other.msg != null)
-                return false;
-        } else if (!msg.equals(other.msg))
-            return false;
-        if (priority != other.priority)
-            return false;
-        if (seqNum != other.seqNum)
-            return false;
-        if (syncReply != other.syncReply)
-            return false;
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        return "PriorityMessage [msg=" + msg + ", priority=" + priority
-                + ", seqNum=" + seqNum + ", syncReply=" + syncReply + "]";
-    }
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/core/internal/SecureMessageReadWriteService.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/core/internal/SecureMessageReadWriteService.java
deleted file mode 100644 (file)
index f27d30e..0000000
+++ /dev/null
@@ -1,451 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow.core.internal;
-
-import java.io.FileInputStream;
-import java.io.FileNotFoundException;
-import java.io.IOException;
-import java.nio.ByteBuffer;
-import java.nio.channels.AsynchronousCloseException;
-import java.nio.channels.SelectionKey;
-import java.nio.channels.Selector;
-import java.nio.channels.SocketChannel;
-import java.security.KeyStore;
-import java.security.SecureRandom;
-import java.util.List;
-
-import javax.net.ssl.KeyManagerFactory;
-import javax.net.ssl.SSLContext;
-import javax.net.ssl.SSLEngine;
-import javax.net.ssl.SSLEngineResult;
-import javax.net.ssl.SSLEngineResult.HandshakeStatus;
-import javax.net.ssl.SSLSession;
-import javax.net.ssl.TrustManagerFactory;
-
-import org.opendaylight.controller.protocol_plugin.openflow.core.IMessageReadWrite;
-import org.openflow.protocol.OFMessage;
-import org.openflow.protocol.factory.BasicFactory;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * This class implements methods to read/write messages over an established
- * socket channel. The data exchange is encrypted/decrypted by SSLEngine.
- */
-public class SecureMessageReadWriteService implements IMessageReadWrite {
-    private static final Logger logger = LoggerFactory
-            .getLogger(SecureMessageReadWriteService.class);
-
-    private Selector selector;
-    private SocketChannel socket;
-    private BasicFactory factory;
-
-    private SSLEngine sslEngine;
-    private SSLEngineResult sslEngineResult; // results from sslEngine last operation
-    private ByteBuffer myAppData; // clear text message to be sent
-    private ByteBuffer myNetData; // encrypted message to be sent
-    private ByteBuffer peerAppData; // clear text message received from the
-                                    // switch
-    private ByteBuffer peerNetData; // encrypted message from the switch
-    private FileInputStream kfd = null, tfd = null;
-    private final String keyStoreFileDefault = "./configuration/tlsKeyStore";
-    private final String trustStoreFileDefault = "./configuration/tlsTrustStore";
-    private final String keyStorePasswordPropName = "controllerKeyStorePassword";
-    private final String trustStorePasswordPropName = "controllerTrustStorePassword";
-    private static String keyStorePassword = null;
-    private static String trustStorePassword = null;
-
-    public SecureMessageReadWriteService(SocketChannel socket, Selector selector)
-            throws Exception {
-        this.socket = socket;
-        this.selector = selector;
-        this.factory = new BasicFactory();
-
-        try {
-            createSecureChannel(socket);
-            createBuffers(sslEngine);
-        } catch (Exception e) {
-            logger.warn("Failed to setup TLS connection {} {}", socket, e);
-            stop();
-            throw e;
-        }
-    }
-
-    /**
-     * Bring up secure channel using SSL Engine
-     *
-     * @param socket
-     *            TCP socket channel
-     * @throws Exception
-     */
-    private void createSecureChannel(SocketChannel socket) throws Exception {
-        String keyStoreFile = System.getProperty("controllerKeyStore");
-        String trustStoreFile = System.getProperty("controllerTrustStore");
-        String keyStorePasswordProp = System.getProperty(keyStorePasswordPropName);
-        String trustStorePasswordProp = System.getProperty(trustStorePasswordPropName);
-
-        if (keyStoreFile != null) {
-            keyStoreFile = keyStoreFile.trim();
-        } else {
-            keyStoreFile = keyStoreFileDefault;
-        }
-        if ((keyStoreFile == null) || keyStoreFile.isEmpty()) {
-            throw new FileNotFoundException("TLS KeyStore file not found.");
-        }
-
-        if ((keyStorePassword == null) || ((keyStorePasswordProp != null) && !keyStorePasswordProp.isEmpty())) {
-            keyStorePassword = keyStorePasswordProp;
-        }
-        if (keyStorePassword != null) {
-            keyStorePassword = keyStorePassword.trim();
-            System.setProperty(keyStorePasswordPropName, "");
-        }
-        if ((keyStorePassword == null) || keyStorePassword.isEmpty()) {
-            throw new FileNotFoundException("TLS KeyStore Password not provided.");
-        }
-        if (trustStoreFile != null) {
-            trustStoreFile = trustStoreFile.trim();
-        } else {
-            trustStoreFile = trustStoreFileDefault;
-        }
-        if ((trustStoreFile == null) || trustStoreFile.isEmpty()) {
-            throw new FileNotFoundException("TLS TrustStore file not found");
-        }
-
-        if ((trustStorePassword == null) || ((trustStorePasswordProp != null) && !trustStorePasswordProp.isEmpty())) {
-            trustStorePassword = trustStorePasswordProp;
-        }
-        if (trustStorePassword != null) {
-            trustStorePassword = trustStorePassword.trim();
-            System.setProperty(trustStorePasswordPropName, "");
-        }
-        if ((trustStorePassword == null) || trustStorePassword.isEmpty()) {
-            throw new FileNotFoundException("TLS TrustStore Password not provided.");
-        }
-
-        KeyStore ks = KeyStore.getInstance("JKS");
-        KeyStore ts = KeyStore.getInstance("JKS");
-        KeyManagerFactory kmf = KeyManagerFactory.getInstance(KeyManagerFactory.getDefaultAlgorithm());
-        TrustManagerFactory tmf = TrustManagerFactory.getInstance(KeyManagerFactory.getDefaultAlgorithm());
-        kfd = new FileInputStream(keyStoreFile);
-        tfd = new FileInputStream(trustStoreFile);
-        ks.load(kfd, keyStorePassword.toCharArray());
-        ts.load(tfd, trustStorePassword.toCharArray());
-        kmf.init(ks, keyStorePassword.toCharArray());
-        tmf.init(ts);
-
-        SecureRandom random = new SecureRandom();
-        random.nextInt();
-
-        SSLContext sslContext = SSLContext.getInstance("TLS");
-        sslContext.init(kmf.getKeyManagers(), tmf.getTrustManagers(), random);
-        sslEngine = sslContext.createSSLEngine();
-        sslEngine.setUseClientMode(false);
-        sslEngine.setNeedClientAuth(true);
-        sslEngine.setEnabledCipherSuites(new String[] {
-                "SSL_RSA_WITH_RC4_128_MD5",
-                "SSL_RSA_WITH_RC4_128_SHA",
-                "TLS_RSA_WITH_AES_128_CBC_SHA",
-                "TLS_DHE_RSA_WITH_AES_128_CBC_SHA",
-                "TLS_DHE_DSS_WITH_AES_128_CBC_SHA",
-                "SSL_RSA_WITH_3DES_EDE_CBC_SHA",
-                "SSL_DHE_RSA_WITH_3DES_EDE_CBC_SHA",
-                "SSL_DHE_DSS_WITH_3DES_EDE_CBC_SHA",
-                "SSL_RSA_WITH_DES_CBC_SHA",
-                "SSL_DHE_RSA_WITH_DES_CBC_SHA",
-                "SSL_DHE_DSS_WITH_DES_CBC_SHA",
-                "SSL_RSA_EXPORT_WITH_RC4_40_MD5",
-                "SSL_RSA_EXPORT_WITH_DES40_CBC_SHA",
-                "SSL_DHE_RSA_EXPORT_WITH_DES40_CBC_SHA",
-                "SSL_DHE_DSS_EXPORT_WITH_DES40_CBC_SHA",
-                "TLS_EMPTY_RENEGOTIATION_INFO_SCSV"});
-
-        // Do initial handshake
-        doHandshake(socket, sslEngine);
-
-        this.socket.register(this.selector, SelectionKey.OP_READ);
-    }
-
-    /**
-     * Sends the OF message out over the socket channel. The message is
-     * encrypted by SSL Engine.
-     *
-     * @param msg
-     *            OF message to be sent
-     * @throws Exception
-     */
-    @Override
-    public void asyncSend(OFMessage msg) throws Exception {
-        synchronized (myAppData) {
-            int msgLen = msg.getLengthU();
-            if (myAppData.remaining() < msgLen) {
-                // increase the buffer size so that it can contain this message
-                ByteBuffer newBuffer = ByteBuffer.allocateDirect(myAppData
-                        .capacity() + msgLen);
-                myAppData.flip();
-                newBuffer.put(myAppData);
-                myAppData = newBuffer;
-            }
-        }
-        synchronized (myAppData) {
-            msg.writeTo(myAppData);
-            myAppData.flip();
-            sslEngineResult = sslEngine.wrap(myAppData, myNetData);
-            logger.trace("asyncSend sslEngine wrap: {}", sslEngineResult);
-            runDelegatedTasks(sslEngineResult, sslEngine);
-
-            if (!socket.isOpen()) {
-                return;
-            }
-
-            myNetData.flip();
-            socket.write(myNetData);
-            if (myNetData.hasRemaining()) {
-                myNetData.compact();
-            } else {
-                myNetData.clear();
-            }
-
-            if (myAppData.hasRemaining()) {
-                myAppData.compact();
-                this.socket.register(this.selector, SelectionKey.OP_WRITE, this);
-            } else {
-                myAppData.clear();
-                this.socket.register(this.selector, SelectionKey.OP_READ, this);
-            }
-
-            logger.trace("Message sent: {}", msg);
-        }
-    }
-
-    /**
-     * Resumes sending the remaining messages in the outgoing buffer
-     *
-     * @throws Exception
-     */
-    @Override
-    public void resumeSend() throws Exception {
-        synchronized (myAppData) {
-            myAppData.flip();
-            sslEngineResult = sslEngine.wrap(myAppData, myNetData);
-            logger.trace("resumeSend sslEngine wrap: {}", sslEngineResult);
-            runDelegatedTasks(sslEngineResult, sslEngine);
-
-            if (!socket.isOpen()) {
-                return;
-            }
-
-            myNetData.flip();
-            socket.write(myNetData);
-            if (myNetData.hasRemaining()) {
-                myNetData.compact();
-            } else {
-                myNetData.clear();
-            }
-
-            if (myAppData.hasRemaining()) {
-                myAppData.compact();
-                this.socket.register(this.selector, SelectionKey.OP_WRITE, this);
-            } else {
-                myAppData.clear();
-                this.socket.register(this.selector, SelectionKey.OP_READ, this);
-            }
-        }
-    }
-
-    /**
-     * Reads the incoming network data from the socket, decryptes them and then
-     * retrieves the OF messages.
-     *
-     * @return list of OF messages
-     * @throws Exception
-     */
-    @Override
-    public List<OFMessage> readMessages() throws Exception {
-        if (!socket.isOpen()) {
-            return null;
-        }
-
-        List<OFMessage> msgs = null;
-        int bytesRead = -1;
-        int countDown = 50;
-
-        bytesRead = socket.read(peerNetData);
-        if (bytesRead < 0) {
-            logger.debug("Message read operation failed");
-            throw new AsynchronousCloseException();
-        }
-
-        do {
-            peerNetData.flip();
-            sslEngineResult = sslEngine.unwrap(peerNetData, peerAppData);
-            if (peerNetData.hasRemaining()) {
-                peerNetData.compact();
-            } else {
-                peerNetData.clear();
-            }
-            logger.trace("sslEngine unwrap result: {}", sslEngineResult);
-            runDelegatedTasks(sslEngineResult, sslEngine);
-        } while ((sslEngineResult.getStatus() == SSLEngineResult.Status.OK)
-                && peerNetData.hasRemaining() && (--countDown > 0));
-
-        if (countDown == 0) {
-            logger.trace("countDown reaches 0. peerNetData pos {} lim {}",
-                    peerNetData.position(), peerNetData.limit());
-        }
-
-        try {
-            peerAppData.flip();
-            msgs = factory.parseMessages(peerAppData);
-            if (peerAppData.hasRemaining()) {
-                peerAppData.compact();
-            } else {
-                peerAppData.clear();
-            }
-        } catch (Exception e) {
-            peerAppData.clear();
-            logger.debug("Caught exception: ", e);
-        }
-
-        this.socket.register(this.selector, SelectionKey.OP_READ, this);
-
-        return msgs;
-    }
-
-    /**
-     * If the result indicates that we have outstanding tasks to do, go ahead
-     * and run them in this thread.
-     */
-    private void runDelegatedTasks(SSLEngineResult result, SSLEngine engine)
-            throws Exception {
-
-        if (result.getHandshakeStatus() == HandshakeStatus.NEED_TASK) {
-            Runnable runnable;
-            while ((runnable = engine.getDelegatedTask()) != null) {
-                logger.debug("\trunning delegated task...");
-                runnable.run();
-            }
-            HandshakeStatus hsStatus = engine.getHandshakeStatus();
-            if (hsStatus == HandshakeStatus.NEED_TASK) {
-                throw new Exception("handshake shouldn't need additional tasks");
-            }
-            logger.debug("\tnew HandshakeStatus: {}", hsStatus);
-        }
-    }
-
-    private void doHandshake(SocketChannel socket, SSLEngine engine)
-            throws Exception {
-        SSLSession session = engine.getSession();
-        ByteBuffer myAppData = ByteBuffer.allocate(session
-                .getApplicationBufferSize());
-        ByteBuffer peerAppData = ByteBuffer.allocate(session
-                .getApplicationBufferSize());
-        ByteBuffer myNetData = ByteBuffer.allocate(session
-                .getPacketBufferSize());
-        ByteBuffer peerNetData = ByteBuffer.allocate(session
-                .getPacketBufferSize());
-
-        // Begin handshake
-        engine.beginHandshake();
-        SSLEngineResult.HandshakeStatus hs = engine.getHandshakeStatus();
-
-        // Process handshaking message
-        while (hs != SSLEngineResult.HandshakeStatus.FINISHED
-                && hs != SSLEngineResult.HandshakeStatus.NOT_HANDSHAKING) {
-            switch (hs) {
-            case NEED_UNWRAP:
-                // Receive handshaking data from peer
-                if (socket.read(peerNetData) < 0) {
-                    throw new AsynchronousCloseException();
-                }
-
-                // Process incoming handshaking data
-                peerNetData.flip();
-                SSLEngineResult res = engine.unwrap(peerNetData, peerAppData);
-                peerNetData.compact();
-                hs = res.getHandshakeStatus();
-
-                // Check status
-                switch (res.getStatus()) {
-                case OK:
-                    // Handle OK status
-                    break;
-                }
-                break;
-
-            case NEED_WRAP:
-                // Empty the local network packet buffer.
-                myNetData.clear();
-
-                // Generate handshaking data
-                res = engine.wrap(myAppData, myNetData);
-                hs = res.getHandshakeStatus();
-
-                // Check status
-                switch (res.getStatus()) {
-                case OK:
-                    myNetData.flip();
-
-                    // Send the handshaking data to peer
-                    while (myNetData.hasRemaining()) {
-                        if (socket.write(myNetData) < 0) {
-                            throw new AsynchronousCloseException();
-                        }
-                    }
-                    break;
-                }
-                break;
-
-            case NEED_TASK:
-                // Handle blocking tasks
-                Runnable runnable;
-                while ((runnable = engine.getDelegatedTask()) != null) {
-                    logger.debug("\trunning delegated task...");
-                    runnable.run();
-                }
-                hs = engine.getHandshakeStatus();
-                if (hs == HandshakeStatus.NEED_TASK) {
-                    throw new Exception(
-                            "handshake shouldn't need additional tasks");
-                }
-                logger.debug("\tnew HandshakeStatus: {}", hs);
-                break;
-            }
-        }
-    }
-
-    private void createBuffers(SSLEngine engine) {
-        SSLSession session = engine.getSession();
-        this.myAppData = ByteBuffer
-                .allocate(session.getApplicationBufferSize());
-        this.peerAppData = ByteBuffer.allocate(session
-                .getApplicationBufferSize() * 20);
-        this.myNetData = ByteBuffer.allocate(session.getPacketBufferSize());
-        this.peerNetData = ByteBuffer.allocate(session.getPacketBufferSize() * 20);
-    }
-
-    @Override
-    public void stop() throws IOException {
-        this.sslEngine = null;
-        this.sslEngineResult = null;
-        this.myAppData = null;
-        this.myNetData = null;
-        this.peerAppData = null;
-        this.peerNetData = null;
-
-        if (this.kfd != null) {
-            this.kfd.close();
-            this.kfd = null;
-        }
-        if (this.tfd != null) {
-            this.tfd.close();
-            this.tfd = null;
-        }
-    }
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/core/internal/StatisticsCollector.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/core/internal/StatisticsCollector.java
deleted file mode 100644 (file)
index 0eaecc5..0000000
+++ /dev/null
@@ -1,82 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow.core.internal;
-
-import java.util.List;
-import java.util.concurrent.Callable;
-import java.util.concurrent.CopyOnWriteArrayList;
-import java.util.concurrent.CountDownLatch;
-
-import org.opendaylight.controller.protocol_plugin.openflow.core.ISwitch;
-import org.openflow.protocol.OFError;
-import org.openflow.protocol.OFStatisticsReply;
-import org.openflow.protocol.OFStatisticsRequest;
-import org.openflow.protocol.statistics.OFStatistics;
-
-public class StatisticsCollector implements Callable<Object> {
-
-    private ISwitch sw;
-    private Integer xid;
-    private OFStatisticsRequest request;
-    private CountDownLatch latch;
-    private Object result;
-    private List<OFStatistics> stats;
-
-    public StatisticsCollector(ISwitch sw, int xid, OFStatisticsRequest request) {
-        this.sw = sw;
-        this.xid = xid;
-        this.request = request;
-        latch = new CountDownLatch(1);
-        result = new Object();
-        stats = new CopyOnWriteArrayList<OFStatistics>();
-    }
-
-    /*
-     * accumulate the stats records in result
-     * Returns: true: if this is the last record
-     *                 false: more to come
-     */
-    public boolean collect(OFStatisticsReply reply) {
-        synchronized (result) {
-            stats.addAll(reply.getStatistics());
-            if ((reply.getFlags() & 0x01) == 0) {
-                // all stats are collected, done
-                result = stats;
-                return true;
-            } else {
-                // still waiting for more to come
-                return false;
-            }
-        }
-    }
-
-    @Override
-    public Object call() throws Exception {
-        sw.asyncSend(request, xid);
-        // free up the request as it is no longer needed
-        request = null;
-        // wait until all stats replies are received or timeout
-        latch.await();
-        return result;
-    }
-
-    public Integer getXid() {
-        return this.xid;
-    }
-
-    public void wakeup() {
-        this.latch.countDown();
-    }
-
-    public void wakeup(OFError errorMsg) {
-        result = errorMsg;
-        wakeup();
-    }
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/core/internal/SwitchEvent.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/core/internal/SwitchEvent.java
deleted file mode 100644 (file)
index 785be9b..0000000
+++ /dev/null
@@ -1,74 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow.core.internal;
-
-import org.opendaylight.controller.protocol_plugin.openflow.core.ISwitch;
-import org.openflow.protocol.OFMessage;
-
-public class SwitchEvent {
-
-    public static enum SwitchEventType {
-        SWITCH_ADD, SWITCH_DELETE, SWITCH_ERROR, SWITCH_MESSAGE,
-    }
-
-    private SwitchEventType eventType;
-    private ISwitch sw;
-    private OFMessage msg;
-    private int priority;
-
-    public SwitchEvent(SwitchEventType type, ISwitch sw, OFMessage msg, int priority) {
-        this.eventType = type;
-        this.sw = sw;
-        this.msg = msg;
-        this.priority = priority;
-    }
-
-    public SwitchEventType getEventType() {
-        return this.eventType;
-    }
-
-    public ISwitch getSwitch() {
-        return this.sw;
-    }
-
-    public OFMessage getMsg() {
-        return this.msg;
-    }
-
-    public int getPriority() {
-        return priority;
-    }
-
-    public void setPriority(int priority) {
-        this.priority = priority;
-    }
-
-    @Override
-    public String toString() {
-        String s;
-        switch (this.eventType) {
-        case SWITCH_ADD:
-            s = "SWITCH_ADD";
-            break;
-        case SWITCH_DELETE:
-            s = "SWITCH_DELETE";
-            break;
-        case SWITCH_ERROR:
-            s = "SWITCH_ERROR";
-            break;
-        case SWITCH_MESSAGE:
-            s = "SWITCH_MESSAGE";
-            break;
-        default:
-            s = "?" + this.eventType.ordinal() + "?";
-        }
-        return "Switch Event: " + s;
-    }
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/core/internal/SwitchHandler.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/core/internal/SwitchHandler.java
deleted file mode 100644 (file)
index 7a177fa..0000000
+++ /dev/null
@@ -1,949 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow.core.internal;
-
-import java.nio.channels.SelectionKey;
-import java.nio.channels.Selector;
-import java.nio.channels.SocketChannel;
-import java.nio.channels.spi.SelectorProvider;
-import java.util.ArrayList;
-import java.util.Comparator;
-import java.util.Date;
-import java.util.HashMap;
-import java.util.Iterator;
-import java.util.List;
-import java.util.Map;
-import java.util.Set;
-import java.util.Timer;
-import java.util.TimerTask;
-import java.util.concurrent.Callable;
-import java.util.concurrent.ConcurrentHashMap;
-import java.util.concurrent.ExecutorService;
-import java.util.concurrent.Executors;
-import java.util.concurrent.Future;
-import java.util.concurrent.PriorityBlockingQueue;
-import java.util.concurrent.RejectedExecutionException;
-import java.util.concurrent.TimeUnit;
-import java.util.concurrent.atomic.AtomicInteger;
-
-import org.opendaylight.controller.protocol_plugin.openflow.core.IController;
-import org.opendaylight.controller.protocol_plugin.openflow.core.IMessageReadWrite;
-import org.opendaylight.controller.protocol_plugin.openflow.core.ISwitch;
-import org.openflow.protocol.OFBarrierReply;
-import org.openflow.protocol.OFBarrierRequest;
-import org.openflow.protocol.OFEchoReply;
-import org.openflow.protocol.OFEchoRequest;
-import org.openflow.protocol.OFError;
-import org.openflow.protocol.OFFeaturesReply;
-import org.openflow.protocol.OFFlowMod;
-import org.openflow.protocol.OFGetConfigReply;
-import org.openflow.protocol.OFMatch;
-import org.openflow.protocol.OFMessage;
-import org.openflow.protocol.OFPhysicalPort;
-import org.openflow.protocol.OFPhysicalPort.OFPortConfig;
-import org.openflow.protocol.OFPhysicalPort.OFPortFeatures;
-import org.openflow.protocol.OFPhysicalPort.OFPortState;
-import org.openflow.protocol.OFPort;
-import org.openflow.protocol.OFPortStatus;
-import org.openflow.protocol.OFPortStatus.OFPortReason;
-import org.openflow.protocol.OFSetConfig;
-import org.openflow.protocol.OFStatisticsReply;
-import org.openflow.protocol.OFStatisticsRequest;
-import org.openflow.protocol.OFType;
-import org.openflow.protocol.factory.BasicFactory;
-import org.openflow.util.HexString;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-
-public class SwitchHandler implements ISwitch {
-    private static final Logger logger = LoggerFactory.getLogger(SwitchHandler.class);
-    private static final int SWITCH_LIVENESS_TIMER = 5000;
-    private static final int switchLivenessTimeout = getSwitchLivenessTimeout();
-    private final int MESSAGE_RESPONSE_TIMER = 2000;
-
-    private final String instanceName;
-    private final ISwitch thisISwitch;
-    private final IController core;
-    private Long sid;
-    private Integer buffers;
-    private Integer capabilities;
-    private Byte tables;
-    private Integer actions;
-    private Selector selector;
-    private final SocketChannel socket;
-    private final BasicFactory factory;
-    private final AtomicInteger xid;
-    private SwitchState state;
-    private Timer periodicTimer;
-    private final Map<Short, OFPhysicalPort> physicalPorts;
-    private final Map<Short, Integer> portBandwidth;
-    private final Date connectedDate;
-    private Long lastMsgReceivedTimeStamp;
-    private Boolean probeSent;
-    private final ExecutorService executor;
-    private final ConcurrentHashMap<Integer, Callable<Object>> messageWaitingDone;
-    private boolean running;
-    private IMessageReadWrite msgReadWriteService;
-    private Thread switchHandlerThread;
-    private Integer responseTimerValue;
-    private PriorityBlockingQueue<PriorityMessage> transmitQ;
-    private Thread transmitThread;
-
-    private enum SwitchState {
-        NON_OPERATIONAL(0), WAIT_FEATURES_REPLY(1), WAIT_CONFIG_REPLY(2), OPERATIONAL(3);
-
-        private int value;
-
-        private SwitchState(int value) {
-            this.value = value;
-        }
-
-        @SuppressWarnings("unused")
-        public int value() {
-            return this.value;
-        }
-    }
-
-    public SwitchHandler(Controller core, SocketChannel sc, String name) {
-        this.instanceName = name;
-        this.thisISwitch = this;
-        this.sid = (long) 0;
-        this.buffers = (int) 0;
-        this.capabilities = (int) 0;
-        this.tables = (byte) 0;
-        this.actions = (int) 0;
-        this.core = core;
-        this.socket = sc;
-        this.factory = new BasicFactory();
-        this.connectedDate = new Date();
-        this.lastMsgReceivedTimeStamp = connectedDate.getTime();
-        this.physicalPorts = new HashMap<Short, OFPhysicalPort>();
-        this.portBandwidth = new HashMap<Short, Integer>();
-        this.state = SwitchState.NON_OPERATIONAL;
-        this.probeSent = false;
-        this.xid = new AtomicInteger(this.socket.hashCode());
-        this.periodicTimer = null;
-        this.executor = Executors.newFixedThreadPool(4);
-        this.messageWaitingDone = new ConcurrentHashMap<Integer, Callable<Object>>();
-        this.responseTimerValue = MESSAGE_RESPONSE_TIMER;
-        String rTimer = System.getProperty("of.messageResponseTimer");
-        if (rTimer != null) {
-            try {
-                responseTimerValue = Integer.decode(rTimer);
-            } catch (NumberFormatException e) {
-                logger.warn("Invalid of.messageResponseTimer: {} use default({})", rTimer, MESSAGE_RESPONSE_TIMER);
-            }
-        }
-    }
-
-    public void start() {
-        try {
-            startTransmitThread();
-            setupCommChannel();
-            sendFirstHello();
-            startHandlerThread();
-        } catch (Exception e) {
-            reportError(e);
-        }
-    }
-
-    private void startHandlerThread() {
-        switchHandlerThread = new Thread(new Runnable() {
-            @Override
-            public void run() {
-                running = true;
-                while (running) {
-                    try {
-                        // wait for an incoming connection
-                        selector.select(0);
-                        Iterator<SelectionKey> selectedKeys = selector.selectedKeys().iterator();
-                        while (selectedKeys.hasNext()) {
-                            SelectionKey skey = selectedKeys.next();
-                            selectedKeys.remove();
-                            if (skey.isValid() && skey.isWritable()) {
-                                resumeSend();
-                            }
-                            if (skey.isValid() && skey.isReadable()) {
-                                handleMessages();
-                            }
-                        }
-                    } catch (Exception e) {
-                        reportError(e);
-                    }
-                }
-            }
-        }, instanceName);
-        switchHandlerThread.start();
-    }
-
-    private void stopInternal() {
-        logger.debug("{} receives stop signal",
-                (isOperational() ? HexString.toHexString(sid) : "unknown"));
-        running = false;
-        cancelSwitchTimer();
-        try {
-            selector.wakeup();
-            selector.close();
-        } catch (Exception e) {
-        }
-        try {
-            socket.close();
-        } catch (Exception e) {
-        }
-        try {
-            msgReadWriteService.stop();
-        } catch (Exception e) {
-        }
-        logger.debug("executor shutdown now");
-        executor.shutdownNow();
-
-        msgReadWriteService = null;
-    }
-
-    public void stop() {
-        stopInternal();
-
-        if (switchHandlerThread != null) {
-            switchHandlerThread.interrupt();
-        }
-        if (transmitThread != null) {
-            transmitThread.interrupt();
-        }
-    }
-
-    @Override
-    public int getNextXid() {
-        return this.xid.incrementAndGet();
-    }
-
-    /**
-     * This method puts the message in an outgoing priority queue with normal
-     * priority. It will be served after high priority messages. The method
-     * should be used for non-critical messages such as statistics request,
-     * discovery packets, etc. An unique XID is generated automatically and
-     * inserted into the message.
-     *
-     * @param msg
-     *            The OF message to be sent
-     * @return The XID used
-     */
-    @Override
-    public Integer asyncSend(OFMessage msg) {
-        return asyncSend(msg, getNextXid());
-    }
-
-    private Object syncSend(OFMessage msg, int xid) {
-        return syncMessageInternal(msg, xid, true);
-    }
-
-    /**
-     * This method puts the message in an outgoing priority queue with normal
-     * priority. It will be served after high priority messages. The method
-     * should be used for non-critical messages such as statistics request,
-     * discovery packets, etc. The specified XID is inserted into the message.
-     *
-     * @param msg
-     *            The OF message to be Sent
-     * @param xid
-     *            The XID to be used in the message
-     * @return The XID used
-     */
-    @Override
-    public Integer asyncSend(OFMessage msg, int xid) {
-        msg.setXid(xid);
-        if (transmitQ != null) {
-            transmitQ.add(new PriorityMessage(msg, 0));
-        }
-        return xid;
-    }
-
-    /**
-     * This method puts the message in an outgoing priority queue with high
-     * priority. It will be served first before normal priority messages. The
-     * method should be used for critical messages such as hello, echo reply
-     * etc. An unique XID is generated automatically and inserted into the
-     * message.
-     *
-     * @param msg
-     *            The OF message to be sent
-     * @return The XID used
-     */
-    @Override
-    public Integer asyncFastSend(OFMessage msg) {
-        return asyncFastSend(msg, getNextXid());
-    }
-
-    /**
-     * This method puts the message in an outgoing priority queue with high
-     * priority. It will be served first before normal priority messages. The
-     * method should be used for critical messages such as hello, echo reply
-     * etc. The specified XID is inserted into the message.
-     *
-     * @param msg
-     *            The OF message to be sent
-     * @return The XID used
-     */
-    @Override
-    public Integer asyncFastSend(OFMessage msg, int xid) {
-        msg.setXid(xid);
-        if (transmitQ != null) {
-            transmitQ.add(new PriorityMessage(msg, 1));
-        }
-        return xid;
-    }
-
-    public void resumeSend() {
-        try {
-            if (msgReadWriteService != null) {
-                msgReadWriteService.resumeSend();
-            }
-        } catch (Exception e) {
-            reportError(e);
-        }
-    }
-
-    /**
-     * This method bypasses the transmit queue and sends the message over the
-     * socket directly. If the input xid is not null, the specified xid is
-     * inserted into the message. Otherwise, an unique xid is generated
-     * automatically and inserted into the message.
-     *
-     * @param msg
-     *            Message to be sent
-     * @param xid
-     *            Message xid
-     */
-    private void asyncSendNow(OFMessage msg, Integer xid) {
-        if (xid == null) {
-            xid = getNextXid();
-        }
-        msg.setXid(xid);
-
-        asyncSendNow(msg);
-    }
-
-    /**
-     * This method bypasses the transmit queue and sends the message over the
-     * socket directly.
-     *
-     * @param msg
-     *            Message to be sent
-     */
-    private void asyncSendNow(OFMessage msg) {
-        if (msgReadWriteService == null) {
-            logger.warn("asyncSendNow: {} is not sent because Message ReadWrite Service is not available.", msg);
-            return;
-        }
-
-        try {
-            msgReadWriteService.asyncSend(msg);
-        } catch (Exception e) {
-            reportError(e);
-        }
-    }
-
-    public void handleMessages() {
-        List<OFMessage> msgs = null;
-
-        try {
-            if (msgReadWriteService != null) {
-                msgs = msgReadWriteService.readMessages();
-            }
-        } catch (Exception e) {
-            reportError(e);
-        }
-
-        if (msgs == null) {
-            return;
-        }
-        for (OFMessage msg : msgs) {
-            logger.trace("Message received: {}", msg);
-            this.lastMsgReceivedTimeStamp = System.currentTimeMillis();
-            OFType type = msg.getType();
-            switch (type) {
-            case HELLO:
-                sendFeaturesRequest();
-                break;
-            case ECHO_REQUEST:
-                OFEchoReply echoReply = (OFEchoReply) factory.getMessage(OFType.ECHO_REPLY);
-
-                byte []payload = ((OFEchoRequest)msg).getPayload();
-                if (payload != null && payload.length != 0 ) {
-                    // the response must have the same payload as the request
-                    echoReply.setPayload(payload);
-                    echoReply.setLength( (short)(echoReply.getLength() + payload.length) );
-                }
-
-                // respond immediately
-                asyncSendNow(echoReply, msg.getXid());
-
-                // send features request if not sent yet
-                sendFeaturesRequest();
-                break;
-            case ECHO_REPLY:
-                this.probeSent = false;
-                break;
-            case FEATURES_REPLY:
-                processFeaturesReply((OFFeaturesReply) msg);
-                break;
-            case GET_CONFIG_REPLY:
-                // make sure that the switch can send the whole packet to the
-                // controller
-                if (((OFGetConfigReply) msg).getMissSendLength() == (short) 0xffff) {
-                    this.state = SwitchState.OPERATIONAL;
-                }
-                break;
-            case BARRIER_REPLY:
-                processBarrierReply((OFBarrierReply) msg);
-                break;
-            case ERROR:
-                processErrorReply((OFError) msg);
-                break;
-            case PORT_STATUS:
-                processPortStatusMsg((OFPortStatus) msg);
-                break;
-            case STATS_REPLY:
-                processStatsReply((OFStatisticsReply) msg);
-                break;
-            case PACKET_IN:
-                break;
-            default:
-                break;
-            } // end of switch
-            if (isOperational()) {
-                ((Controller) core).takeSwitchEventMsg(thisISwitch, msg);
-            }
-        } // end of for
-    }
-
-    private void processPortStatusMsg(OFPortStatus msg) {
-        OFPhysicalPort port = msg.getDesc();
-        if (msg.getReason() == (byte) OFPortReason.OFPPR_MODIFY.ordinal()) {
-            updatePhysicalPort(port);
-        } else if (msg.getReason() == (byte) OFPortReason.OFPPR_ADD.ordinal()) {
-            updatePhysicalPort(port);
-        } else if (msg.getReason() == (byte) OFPortReason.OFPPR_DELETE.ordinal()) {
-            deletePhysicalPort(port);
-        }
-
-    }
-
-    private void startSwitchTimer() {
-        this.periodicTimer = new Timer();
-        this.periodicTimer.scheduleAtFixedRate(new TimerTask() {
-            @Override
-            public void run() {
-                try {
-                    Long now = System.currentTimeMillis();
-                    if ((now - lastMsgReceivedTimeStamp) > switchLivenessTimeout) {
-                        if (probeSent) {
-                            // switch failed to respond to our probe, consider
-                            // it down
-                            logger.warn("{} sid {} is idle for too long, disconnect", socket.socket()
-                                    .getRemoteSocketAddress().toString().split("/")[1], (sid == 0) ? "unknown"
-                                    : HexString.toHexString(sid));
-                            reportSwitchStateChange(false);
-                        } else {
-                            // send a probe to see if the switch is still alive
-                            logger.debug("Send idle probe (Echo Request) to {}", this);
-                            probeSent = true;
-                            OFMessage echo = factory.getMessage(OFType.ECHO_REQUEST);
-                            asyncFastSend(echo);
-                        }
-                    } else {
-                        if (state == SwitchState.WAIT_FEATURES_REPLY) {
-                            // send another features request
-                            OFMessage request = factory.getMessage(OFType.FEATURES_REQUEST);
-                            asyncFastSend(request);
-                        } else {
-                            if (state == SwitchState.WAIT_CONFIG_REPLY) {
-                                // send another config request
-                                OFSetConfig config = (OFSetConfig) factory.getMessage(OFType.SET_CONFIG);
-                                config.setMissSendLength((short) 0xffff).setLengthU(OFSetConfig.MINIMUM_LENGTH);
-                                asyncFastSend(config);
-                                OFMessage getConfig = factory.getMessage(OFType.GET_CONFIG_REQUEST);
-                                asyncFastSend(getConfig);
-                            }
-                        }
-                    }
-                } catch (Exception e) {
-                    reportError(e);
-                }
-            }
-        }, SWITCH_LIVENESS_TIMER, SWITCH_LIVENESS_TIMER);
-    }
-
-    private void cancelSwitchTimer() {
-        if (this.periodicTimer != null) {
-            this.periodicTimer.cancel();
-        }
-    }
-
-    private void reportError(Exception e) {
-        if (!running) {
-            logger.debug("Caught exception {} while switch {} is shutting down. Skip", e.getMessage(),
-                    (isOperational() ? HexString.toHexString(sid) : "unknown"));
-            return;
-        }
-        logger.debug("Caught exception: ", e);
-
-        // notify core of this error event and disconnect the switch
-        ((Controller) core).takeSwitchEventError(this);
-
-        // clean up some internal states immediately
-        stopInternal();
-    }
-
-    private void reportSwitchStateChange(boolean added) {
-        if (added) {
-            ((Controller) core).takeSwitchEventAdd(this);
-        } else {
-            ((Controller) core).takeSwitchEventDelete(this);
-        }
-    }
-
-    @Override
-    public Long getId() {
-        return this.sid;
-    }
-
-    private void sendFeaturesRequest() {
-        if (!isOperational() && (this.state != SwitchState.WAIT_FEATURES_REPLY)) {
-            // send feature request
-            OFMessage featureRequest = factory.getMessage(OFType.FEATURES_REQUEST);
-            asyncFastSend(featureRequest);
-            this.state = SwitchState.WAIT_FEATURES_REPLY;
-            startSwitchTimer();
-        }
-    }
-
-    private void processFeaturesReply(OFFeaturesReply reply) {
-        if (this.state == SwitchState.WAIT_FEATURES_REPLY) {
-            this.sid = reply.getDatapathId();
-            this.buffers = reply.getBuffers();
-            this.capabilities = reply.getCapabilities();
-            this.tables = reply.getTables();
-            this.actions = reply.getActions();
-            // notify core of this error event
-            for (OFPhysicalPort port : reply.getPorts()) {
-                updatePhysicalPort(port);
-            }
-            // config the switch to send full data packet
-            OFSetConfig config = (OFSetConfig) factory.getMessage(OFType.SET_CONFIG);
-            config.setMissSendLength((short) 0xffff).setLengthU(OFSetConfig.MINIMUM_LENGTH);
-            asyncFastSend(config);
-            // send config request to make sure the switch can handle the set
-            // config
-            OFMessage getConfig = factory.getMessage(OFType.GET_CONFIG_REQUEST);
-            asyncFastSend(getConfig);
-            this.state = SwitchState.WAIT_CONFIG_REPLY;
-            // inform core that a new switch is now operational
-            reportSwitchStateChange(true);
-        }
-    }
-
-    private void updatePhysicalPort(OFPhysicalPort port) {
-        Short portNumber = port.getPortNumber();
-        physicalPorts.put(portNumber, port);
-        portBandwidth
-                .put(portNumber,
-                        port.getCurrentFeatures()
-                                & (OFPortFeatures.OFPPF_10MB_FD.getValue() | OFPortFeatures.OFPPF_10MB_HD.getValue()
-                                        | OFPortFeatures.OFPPF_100MB_FD.getValue()
-                                        | OFPortFeatures.OFPPF_100MB_HD.getValue()
-                                        | OFPortFeatures.OFPPF_1GB_FD.getValue()
-                                        | OFPortFeatures.OFPPF_1GB_HD.getValue() | OFPortFeatures.OFPPF_10GB_FD
-                                            .getValue()));
-    }
-
-    private void deletePhysicalPort(OFPhysicalPort port) {
-        Short portNumber = port.getPortNumber();
-        physicalPorts.remove(portNumber);
-        portBandwidth.remove(portNumber);
-    }
-
-    @Override
-    public boolean isOperational() {
-        return ((this.state == SwitchState.WAIT_CONFIG_REPLY) || (this.state == SwitchState.OPERATIONAL));
-    }
-
-    @Override
-    public String toString() {
-        try {
-            return ("Switch:" + socket.socket().getRemoteSocketAddress().toString().split("/")[1] + " SWID:" + (isOperational() ? HexString
-                    .toHexString(this.sid) : "unknown"));
-        } catch (Exception e) {
-            return (isOperational() ? HexString.toHexString(this.sid) : "unknown");
-        }
-
-    }
-
-    @Override
-    public Date getConnectedDate() {
-        return this.connectedDate;
-    }
-
-    public String getInstanceName() {
-        return instanceName;
-    }
-
-    @Override
-    public Object getStatistics(OFStatisticsRequest req) {
-        int xid = getNextXid();
-        StatisticsCollector worker = new StatisticsCollector(this, xid, req);
-        messageWaitingDone.put(xid, worker);
-        Future<Object> submit;
-        Object result = null;
-        try {
-            submit = executor.submit(worker);
-        } catch (RejectedExecutionException re) {
-            messageWaitingDone.remove(xid);
-            return result;
-        }
-        try {
-            result = submit.get(responseTimerValue, TimeUnit.MILLISECONDS);
-            return result;
-        } catch (Exception e) {
-            logger.warn("Timeout while waiting for {} replies from {}",
-                    req.getType(), (isOperational() ? HexString.toHexString(sid) : "unknown"));
-            result = null; // to indicate timeout has occurred
-            worker.wakeup();
-            return result;
-        }
-    }
-
-    @Override
-    public Object syncSend(OFMessage msg) {
-        if (!running) {
-            logger.debug("Switch is going down, ignore syncSend");
-            return null;
-        }
-        int xid = getNextXid();
-        return syncSend(msg, xid);
-    }
-
-    /*
-     * Either a BarrierReply or a OFError is received. If this is a reply for an
-     * outstanding sync message, wake up associated task so that it can continue
-     */
-    private void processBarrierReply(OFBarrierReply msg) {
-        Integer xid = msg.getXid();
-        SynchronousMessage worker = (SynchronousMessage) messageWaitingDone.remove(xid);
-        if (worker == null) {
-            return;
-        }
-        worker.wakeup();
-    }
-
-    private void processErrorReply(OFError errorMsg) {
-        OFMessage offendingMsg = errorMsg.getOffendingMsg();
-        Integer xid;
-        if (offendingMsg != null) {
-            xid = offendingMsg.getXid();
-        } else {
-            xid = errorMsg.getXid();
-        }
-        /*
-         * the error can be a reply to a synchronous message or to a statistic
-         * request message
-         */
-        Callable<?> worker = messageWaitingDone.remove(xid);
-        if (worker == null) {
-            return;
-        }
-        if (worker instanceof SynchronousMessage) {
-            ((SynchronousMessage) worker).wakeup(errorMsg);
-        } else {
-            ((StatisticsCollector) worker).wakeup(errorMsg);
-        }
-    }
-
-    private void processStatsReply(OFStatisticsReply reply) {
-        Integer xid = reply.getXid();
-        StatisticsCollector worker = (StatisticsCollector) messageWaitingDone.get(xid);
-        if (worker == null) {
-            return;
-        }
-        if (worker.collect(reply)) {
-            // if all the stats records are received (collect() returns true)
-            // then we are done.
-            messageWaitingDone.remove(xid);
-            worker.wakeup();
-        }
-    }
-
-    @Override
-    public Map<Short, OFPhysicalPort> getPhysicalPorts() {
-        return this.physicalPorts;
-    }
-
-    @Override
-    public OFPhysicalPort getPhysicalPort(Short portNumber) {
-        return this.physicalPorts.get(portNumber);
-    }
-
-    @Override
-    public Integer getPortBandwidth(Short portNumber) {
-        return this.portBandwidth.get(portNumber);
-    }
-
-    @Override
-    public Set<Short> getPorts() {
-        return this.physicalPorts.keySet();
-    }
-
-    @Override
-    public Byte getTables() {
-        return this.tables;
-    }
-
-    @Override
-    public Integer getActions() {
-        return this.actions;
-    }
-
-    @Override
-    public Integer getCapabilities() {
-        return this.capabilities;
-    }
-
-    @Override
-    public Integer getBuffers() {
-        return this.buffers;
-    }
-
-    @Override
-    public boolean isPortEnabled(short portNumber) {
-        return isPortEnabled(physicalPorts.get(portNumber));
-    }
-
-    @Override
-    public boolean isPortEnabled(OFPhysicalPort port) {
-        if (port == null) {
-            return false;
-        }
-        int portConfig = port.getConfig();
-        int portState = port.getState();
-        if ((portConfig & OFPortConfig.OFPPC_PORT_DOWN.getValue()) > 0) {
-            return false;
-        }
-        if ((portState & OFPortState.OFPPS_LINK_DOWN.getValue()) > 0) {
-            return false;
-        }
-        if ((portState & OFPortState.OFPPS_STP_MASK.getValue()) == OFPortState.OFPPS_STP_BLOCK.getValue()) {
-            return false;
-        }
-        return true;
-    }
-
-    @Override
-    public List<OFPhysicalPort> getEnabledPorts() {
-        List<OFPhysicalPort> result = new ArrayList<OFPhysicalPort>();
-        synchronized (this.physicalPorts) {
-            for (OFPhysicalPort port : physicalPorts.values()) {
-                if (isPortEnabled(port)) {
-                    result.add(port);
-                }
-            }
-        }
-        return result;
-    }
-
-    /*
-     * Transmit thread polls the message out of the priority queue and invokes
-     * messaging service to transmit it over the socket channel
-     */
-    class PriorityMessageTransmit implements Runnable {
-        @Override
-        public void run() {
-            running = true;
-            while (running) {
-                try {
-                    PriorityMessage pmsg = transmitQ.take();
-                    msgReadWriteService.asyncSend(pmsg.msg);
-                    /*
-                     * If syncReply is set to true, wait for the response back.
-                     */
-                    if (pmsg.syncReply) {
-                        syncMessageInternal(pmsg.msg, pmsg.msg.getXid(), false);
-                    }
-                } catch (InterruptedException ie) {
-                    reportError(new InterruptedException("PriorityMessageTransmit thread interrupted"));
-                } catch (Exception e) {
-                    reportError(e);
-                }
-            }
-            transmitQ = null;
-        }
-    }
-
-    /*
-     * Setup and start the transmit thread
-     */
-    private void startTransmitThread() {
-        this.transmitQ = new PriorityBlockingQueue<PriorityMessage>(11, new Comparator<PriorityMessage>() {
-            @Override
-            public int compare(PriorityMessage p1, PriorityMessage p2) {
-                if (p2.priority != p1.priority) {
-                    return p2.priority - p1.priority;
-                } else {
-                    return (p2.seqNum < p1.seqNum) ? 1 : -1;
-                }
-            }
-        });
-        this.transmitThread = new Thread(new PriorityMessageTransmit());
-        this.transmitThread.start();
-    }
-
-    /*
-     * Setup communication services
-     */
-    private void setupCommChannel() throws Exception {
-        this.selector = SelectorProvider.provider().openSelector();
-        this.socket.configureBlocking(false);
-        this.socket.socket().setTcpNoDelay(true);
-        this.msgReadWriteService = getMessageReadWriteService();
-    }
-
-    private void sendFirstHello() {
-        try {
-            OFMessage msg = factory.getMessage(OFType.HELLO);
-            asyncFastSend(msg);
-        } catch (Exception e) {
-            reportError(e);
-        }
-    }
-
-    private IMessageReadWrite getMessageReadWriteService() throws Exception {
-        String str = System.getProperty("secureChannelEnabled");
-        return ((str != null) && (str.trim().equalsIgnoreCase("true"))) ? new SecureMessageReadWriteService(socket,
-                selector) : new MessageReadWriteService(socket, selector);
-    }
-
-    /**
-     * Send Barrier message synchronously. The caller will be blocked until the
-     * Barrier reply is received.
-     */
-    @Override
-    public Object syncSendBarrierMessage() {
-        OFBarrierRequest barrierMsg = new OFBarrierRequest();
-        return syncSend(barrierMsg);
-    }
-
-    /**
-     * Send Barrier message asynchronously. The caller is not blocked. The
-     * Barrier message will be sent in a transmit thread which will be blocked
-     * until the Barrier reply is received.
-     */
-    @Override
-    public Object asyncSendBarrierMessage() {
-        if (transmitQ == null) {
-            return Boolean.FALSE;
-        }
-
-        OFBarrierRequest barrierMsg = new OFBarrierRequest();
-        int xid = getNextXid();
-
-        barrierMsg.setXid(xid);
-        transmitQ.add(new PriorityMessage(barrierMsg, 0, true));
-
-        return Boolean.TRUE;
-    }
-
-    /**
-     * This method returns the switch liveness timeout value. If controller did
-     * not receive any message from the switch for such a long period,
-     * controller will tear down the connection to the switch.
-     *
-     * @return The timeout value
-     */
-    private static int getSwitchLivenessTimeout() {
-        String timeout = System.getProperty("of.switchLivenessTimeout");
-        int rv = 60500;
-
-        try {
-            if (timeout != null) {
-                rv = Integer.parseInt(timeout);
-            }
-        } catch (Exception e) {
-        }
-
-        return rv;
-    }
-
-    /**
-     * This method performs synchronous operations for a given message. If
-     * syncRequest is set to true, the message will be sent out followed by a
-     * Barrier request message. Then it's blocked until the Barrier rely arrives
-     * or timeout. If syncRequest is false, it simply skips the message send and
-     * just waits for the response back.
-     *
-     * @param msg
-     *            Message to be sent
-     * @param xid
-     *            Message XID
-     * @param request
-     *            If set to true, the message the message will be sent out
-     *            followed by a Barrier request message. If set to false, it
-     *            simply skips the sending and just waits for the Barrier reply.
-     * @return the result
-     */
-    private Object syncMessageInternal(OFMessage msg, int xid, boolean syncRequest) {
-        SynchronousMessage worker = new SynchronousMessage(this, xid, msg, syncRequest);
-        messageWaitingDone.put(xid, worker);
-        Object result = null;
-        Boolean status = false;
-        Future<Object> submit;
-        try {
-           submit = executor.submit(worker);
-        } catch (RejectedExecutionException re) {
-            messageWaitingDone.remove(xid);
-            return result;
-        }
-        try {
-            result = submit.get(responseTimerValue, TimeUnit.MILLISECONDS);
-            messageWaitingDone.remove(xid);
-            if (result == null) {
-                // if result is null, then it means the switch can handle this
-                // message successfully
-                // convert the result into a Boolean with value true
-                status = true;
-                // logger.debug("Successfully send " +
-                // msg.getType().toString());
-                result = status;
-            } else {
-                // if result is not null, this means the switch can't handle
-                // this message
-                // the result if OFError already
-                if (logger.isDebugEnabled()) {
-                    logger.debug("Send {} failed --> {}", msg.getType(), (result));
-                }
-            }
-            return result;
-        } catch (Exception e) {
-            logger.warn("Timeout while waiting for {} reply", msg.getType().toString());
-            // convert the result into a Boolean with value false
-            status = false;
-            result = status;
-            worker.wakeup();
-            return result;
-        }
-    }
-
-    @Override
-    public void deleteAllFlows() {
-        logger.trace("deleteAllFlows on switch {}", HexString.toHexString(this.sid));
-        OFMatch match = new OFMatch().setWildcards(OFMatch.OFPFW_ALL);
-        OFFlowMod flowMod = (OFFlowMod) factory.getMessage(OFType.FLOW_MOD);
-        flowMod.setMatch(match).setCommand(OFFlowMod.OFPFC_DELETE).setOutPort(OFPort.OFPP_NONE)
-                .setLength((short) OFFlowMod.MINIMUM_LENGTH);
-        asyncFastSend(flowMod);
-    }
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/core/internal/SynchronousMessage.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/core/internal/SynchronousMessage.java
deleted file mode 100644 (file)
index bb94d4b..0000000
+++ /dev/null
@@ -1,78 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow.core.internal;
-
-import java.util.concurrent.Callable;
-import java.util.concurrent.CountDownLatch;
-
-import org.opendaylight.controller.protocol_plugin.openflow.core.ISwitch;
-import org.openflow.protocol.OFBarrierRequest;
-import org.openflow.protocol.OFError;
-import org.openflow.protocol.OFMessage;
-
-/**
- * This class implements synchronous operations on message send to a switch. If
- * syncRequest is set to true, it sends the requested message to the switch
- * followed by a Barrier request message. It returns the result once it gets the
- * reply from the switch or after a timeout. If the protocol does not dictate
- * the switch to reply the processing status for a particular message, the
- * Barrier request forces the switch to reply saying whether or not the message
- * processing was successful for messages sent to the switch up to this point.
- * If syncRequest is false, it simply skips the message send and just waits for
- * the response back.
- */
-public class SynchronousMessage implements Callable<Object> {
-    private ISwitch sw;
-    private Integer xid;
-    private OFMessage syncMsg;
-    protected CountDownLatch latch;
-    private Object result;
-    private boolean syncRequest;
-
-    public SynchronousMessage(ISwitch sw, Integer xid, OFMessage msg,
-            boolean syncRequest) {
-        this.sw = sw;
-        this.xid = xid;
-        syncMsg = msg;
-        latch = new CountDownLatch(1);
-        result = null;
-        this.syncRequest = syncRequest;
-    }
-
-    @Override
-    public Object call() throws Exception {
-        /*
-         * Send out message only if syncRequest is set to true. Otherwise, just
-         * wait for the Barrier response back.
-         */
-        if (syncRequest) {
-            sw.asyncSend(syncMsg, xid);
-            if (!(syncMsg instanceof OFBarrierRequest)) {
-                OFBarrierRequest barrierMsg = new OFBarrierRequest();
-                sw.asyncSend(barrierMsg, xid);
-            }
-        }
-        latch.await();
-        return result;
-    }
-
-    public Integer getXid() {
-        return this.xid;
-    }
-
-    public void wakeup() {
-        this.latch.countDown();
-    }
-
-    public void wakeup(OFError e) {
-        result = e;
-        wakeup();
-    }
-
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/Activator.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/Activator.java
deleted file mode 100644 (file)
index d92c57b..0000000
+++ /dev/null
@@ -1,451 +0,0 @@
-/*
- * Copyright (c) 2013-2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow.internal;
-
-import java.util.Dictionary;
-import java.util.Hashtable;
-
-import org.apache.felix.dm.Component;
-import org.opendaylight.controller.protocol_plugin.openflow.IDataPacketListen;
-import org.opendaylight.controller.protocol_plugin.openflow.IDataPacketMux;
-import org.opendaylight.controller.protocol_plugin.openflow.IDiscoveryListener;
-import org.opendaylight.controller.protocol_plugin.openflow.IFlowProgrammerNotifier;
-import org.opendaylight.controller.protocol_plugin.openflow.IInventoryProvider;
-import org.opendaylight.controller.protocol_plugin.openflow.IInventoryShimExternalListener;
-import org.opendaylight.controller.protocol_plugin.openflow.IInventoryShimInternalListener;
-import org.opendaylight.controller.protocol_plugin.openflow.IOFStatisticsListener;
-import org.opendaylight.controller.protocol_plugin.openflow.IOFStatisticsManager;
-import org.opendaylight.controller.protocol_plugin.openflow.IReadFilterInternalListener;
-import org.opendaylight.controller.protocol_plugin.openflow.IReadServiceFilter;
-import org.opendaylight.controller.protocol_plugin.openflow.IRefreshInternalProvider;
-import org.opendaylight.controller.protocol_plugin.openflow.ITopologyServiceShimListener;
-import org.opendaylight.controller.protocol_plugin.openflow.core.IController;
-import org.opendaylight.controller.protocol_plugin.openflow.core.IMessageListener;
-import org.opendaylight.controller.protocol_plugin.openflow.core.internal.Controller;
-import org.opendaylight.controller.sal.connection.IPluginInConnectionService;
-import org.opendaylight.controller.sal.connection.IPluginOutConnectionService;
-import org.opendaylight.controller.sal.core.ComponentActivatorAbstractBase;
-import org.opendaylight.controller.sal.core.IContainerAware;
-import org.opendaylight.controller.sal.core.IContainerListener;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.flowprogrammer.IPluginInFlowProgrammerService;
-import org.opendaylight.controller.sal.flowprogrammer.IPluginOutFlowProgrammerService;
-import org.opendaylight.controller.sal.inventory.IPluginInInventoryService;
-import org.opendaylight.controller.sal.inventory.IPluginOutInventoryService;
-import org.opendaylight.controller.sal.packet.IPluginInDataPacketService;
-import org.opendaylight.controller.sal.packet.IPluginOutDataPacketService;
-import org.opendaylight.controller.sal.reader.IPluginInReadService;
-import org.opendaylight.controller.sal.reader.IPluginOutReadService;
-import org.opendaylight.controller.sal.topology.IPluginInTopologyService;
-import org.opendaylight.controller.sal.topology.IPluginOutTopologyService;
-import org.opendaylight.controller.sal.utils.GlobalConstants;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * Openflow protocol plugin Activator
- *
- *
- */
-public class Activator extends ComponentActivatorAbstractBase {
-    protected static final Logger logger = LoggerFactory
-            .getLogger(Activator.class);
-
-    /**
-     * Priority to determine whether to override existing protocol service.
-     */
-    private static final int  PLUGIN_PRIORITY = 10;
-
-    /**
-     * Function that is used to communicate to dependency manager the list of
-     * known implementations for services inside a container
-     *
-     *
-     * @return An array containing all the CLASS objects that will be
-     *         instantiated in order to get an fully working implementation
-     *         Object
-     */
-    @Override
-    public Object[] getImplementations() {
-        Object[] res = { TopologyServices.class, DataPacketServices.class,
-                InventoryService.class, ReadService.class,
-                FlowProgrammerNotifier.class };
-        return res;
-    }
-
-    /**
-     * Function that is called when configuration of the dependencies is
-     * required.
-     *
-     * @param c
-     *            dependency manager Component object, used for configuring the
-     *            dependencies exported and imported
-     * @param imp
-     *            Implementation class that is being configured, needed as long
-     *            as the same routine can configure multiple implementations
-     * @param containerName
-     *            The containerName being configured, this allow also optional
-     *            per-container different behavior if needed, usually should not
-     *            be the case though.
-     */
-    @Override
-    public void configureInstance(Component c, Object imp, String containerName) {
-        if (imp.equals(TopologyServices.class)) {
-            // export the service to be used by SAL
-            c.setInterface(
-                    new String[] { IPluginInTopologyService.class.getName(),
-                            ITopologyServiceShimListener.class.getName() }, null);
-            // Hook the services coming in from SAL, as optional in
-            // case SAL is not yet there, could happen
-            c.add(createContainerServiceDependency(containerName)
-                    .setService(IPluginOutTopologyService.class)
-                    .setCallbacks("setPluginOutTopologyService",
-                            "unsetPluginOutTopologyService").setRequired(false));
-            c.add(createServiceDependency()
-                    .setService(IRefreshInternalProvider.class)
-                    .setCallbacks("setRefreshInternalProvider",
-                            "unsetRefreshInternalProvider").setRequired(false));
-        }
-
-        if (imp.equals(InventoryService.class)) {
-            // export the service
-            c.setInterface(
-                    new String[] {
-                            IPluginInInventoryService.class.getName(),
-                            IInventoryShimInternalListener.class.getName(),
-                            IInventoryProvider.class.getName() }, null);
-
-            // Now lets add a service dependency to make sure the
-            // provider of service exists
-            c.add(createServiceDependency()
-                    .setService(IController.class, "(name=Controller)")
-                    .setCallbacks("setController", "unsetController")
-                    .setRequired(true));
-            c.add(createContainerServiceDependency(containerName)
-                    .setService(IPluginOutInventoryService.class)
-                    .setCallbacks("setPluginOutInventoryServices",
-                            "unsetPluginOutInventoryServices")
-                    .setRequired(false));
-        }
-
-        if (imp.equals(DataPacketServices.class)) {
-            // export the service to be used by SAL
-            Dictionary<String, Object> props = new Hashtable<String, Object>();
-            // Set the protocolPluginType property which will be used
-            // by SAL
-            props.put(GlobalConstants.PROTOCOLPLUGINTYPE.toString(), Node.NodeIDType.OPENFLOW);
-            props.put(GlobalConstants.PROTOCOLPLUGINPRIORITY.toString(),
-                      Integer.valueOf(PLUGIN_PRIORITY));
-            c.setInterface(IPluginInDataPacketService.class.getName(), props);
-            // Hook the services coming in from SAL, as optional in
-            // case SAL is not yet there, could happen
-            c.add(createServiceDependency()
-                    .setService(IController.class, "(name=Controller)")
-                    .setCallbacks("setController", "unsetController")
-                    .setRequired(true));
-            // This is required for the transmission to happen properly
-            c.add(createServiceDependency().setService(IDataPacketMux.class)
-                    .setCallbacks("setIDataPacketMux", "unsetIDataPacketMux")
-                    .setRequired(true));
-            c.add(createContainerServiceDependency(containerName)
-                    .setService(IPluginOutDataPacketService.class)
-                    .setCallbacks("setPluginOutDataPacketService",
-                            "unsetPluginOutDataPacketService")
-                    .setRequired(false));
-            c.add(createServiceDependency()
-                    .setService(IPluginOutConnectionService.class)
-                    .setCallbacks("setIPluginOutConnectionService",
-                            "unsetIPluginOutConnectionService")
-                    .setRequired(true));
-        }
-
-        if (imp.equals(ReadService.class)) {
-            // export the service to be used by SAL
-            Dictionary<String, Object> props = new Hashtable<String, Object>();
-            // Set the protocolPluginType property which will be used
-            // by SAL
-            props.put(GlobalConstants.PROTOCOLPLUGINTYPE.toString(), Node.NodeIDType.OPENFLOW);
-            props.put(GlobalConstants.PROTOCOLPLUGINPRIORITY.toString(),
-                      Integer.valueOf(PLUGIN_PRIORITY));
-            c.setInterface(new String[] {
-                    IReadFilterInternalListener.class.getName(),
-                    IPluginInReadService.class.getName() }, props);
-
-            c.add(createServiceDependency()
-                    .setService(IReadServiceFilter.class)
-                    .setCallbacks("setService", "unsetService")
-                    .setRequired(true));
-
-            c.add(createContainerServiceDependency(containerName)
-                    .setService(IPluginOutReadService.class)
-                    .setCallbacks("setPluginOutReadServices",
-                            "unsetPluginOutReadServices")
-                    .setRequired(false));
-
-            c.add(createServiceDependency()
-                    .setService(IPluginOutConnectionService.class)
-                    .setCallbacks("setIPluginOutConnectionService",
-                            "unsetIPluginOutConnectionService")
-                    .setRequired(true));
-        }
-
-        if (imp.equals(FlowProgrammerNotifier.class)) {
-            // export the service to be used by SAL
-            Dictionary<String, Object> props = new Hashtable<String, Object>();
-            // Set the protocolPluginType property which will be used
-            // by SAL
-            props.put(GlobalConstants.PROTOCOLPLUGINTYPE.toString(), Node.NodeIDType.OPENFLOW);
-            c.setInterface(IFlowProgrammerNotifier.class.getName(), props);
-
-            c.add(createContainerServiceDependency(containerName)
-                    .setService(IPluginOutFlowProgrammerService.class)
-                    .setCallbacks("setPluginOutFlowProgrammerService",
-                            "unsetPluginOutFlowProgrammerService")
-                    .setRequired(true));
-            c.add(createServiceDependency()
-                    .setService(IPluginOutConnectionService.class)
-                    .setCallbacks("setIPluginOutConnectionService",
-                            "unsetIPluginOutConnectionService")
-                    .setRequired(true));
-        }
-    }
-
-    /**
-     * Function that is used to communicate to dependency manager the list of
-     * known implementations for services that are container independent.
-     *
-     *
-     * @return An array containing all the CLASS objects that will be
-     *         instantiated in order to get an fully working implementation
-     *         Object
-     */
-    @Override
-    public Object[] getGlobalImplementations() {
-        Object[] res = { Controller.class, OFStatisticsManager.class,
-                FlowProgrammerService.class, ReadServiceFilter.class,
-                DiscoveryService.class, DataPacketMuxDemux.class, InventoryService.class,
-                InventoryServiceShim.class, TopologyServiceShim.class };
-        return res;
-    }
-
-    /**
-     * Function that is called when configuration of the dependencies is
-     * required.
-     *
-     * @param c
-     *            dependency manager Component object, used for configuring the
-     *            dependencies exported and imported
-     * @param imp
-     *            Implementation class that is being configured, needed as long
-     *            as the same routine can configure multiple implementations
-     */
-    @Override
-    public void configureGlobalInstance(Component c, Object imp) {
-
-        if (imp.equals(Controller.class)) {
-            logger.debug("Activator configureGlobalInstance( ) is called");
-            Dictionary<String, Object> props = new Hashtable<String, Object>();
-            props.put("name", "Controller");
-            props.put(GlobalConstants.PROTOCOLPLUGINTYPE.toString(), Node.NodeIDType.OPENFLOW);
-            c.setInterface(new String[] { IController.class.getName(),
-                                          IPluginInConnectionService.class.getName()},
-                                          props);
-        }
-
-        if (imp.equals(FlowProgrammerService.class)) {
-            // export the service to be used by SAL
-            Dictionary<String, Object> props = new Hashtable<String, Object>();
-            // Set the protocolPluginType property which will be used
-            // by SAL
-            props.put(GlobalConstants.PROTOCOLPLUGINTYPE.toString(), Node.NodeIDType.OPENFLOW);
-            props.put(GlobalConstants.PROTOCOLPLUGINPRIORITY.toString(),
-                      Integer.valueOf(PLUGIN_PRIORITY));
-            c.setInterface(
-                    new String[] { IPluginInFlowProgrammerService.class.getName(), IMessageListener.class.getName(),
-                            IContainerListener.class.getName(), IInventoryShimExternalListener.class.getName(),
-                            IContainerAware.class.getName() }, props);
-
-            c.add(createServiceDependency()
-                    .setService(IController.class, "(name=Controller)")
-                    .setCallbacks("setController", "unsetController")
-                    .setRequired(true));
-
-            c.add(createServiceDependency()
-                    .setService(IFlowProgrammerNotifier.class)
-                    .setCallbacks("setFlowProgrammerNotifier",
-                            "unsetFlowProgrammerNotifier")
-                    .setRequired(false));
-
-            c.add(createServiceDependency()
-                    .setService(IPluginOutConnectionService.class)
-                    .setCallbacks("setIPluginOutConnectionService",
-                            "unsetIPluginOutConnectionService")
-                    .setRequired(true));
-        }
-
-        if (imp.equals(ReadServiceFilter.class)) {
-
-            c.setInterface(new String[] { IReadServiceFilter.class.getName(), IContainerListener.class.getName(),
-                    IOFStatisticsListener.class.getName(), IContainerAware.class.getName() }, null);
-
-            c.add(createServiceDependency()
-                    .setService(IController.class, "(name=Controller)")
-                    .setCallbacks("setController", "unsetController")
-                    .setRequired(true));
-            c.add(createServiceDependency()
-                    .setService(IOFStatisticsManager.class)
-                    .setCallbacks("setService", "unsetService")
-                    .setRequired(true));
-            c.add(createServiceDependency()
-                    .setService(IReadFilterInternalListener.class)
-                    .setCallbacks("setReadFilterInternalListener",
-                            "unsetReadFilterInternalListener")
-                    .setRequired(false));
-        }
-
-        if (imp.equals(OFStatisticsManager.class)) {
-
-            c.setInterface(new String[] { IOFStatisticsManager.class.getName(),
-                    IInventoryShimExternalListener.class.getName() }, null);
-
-            c.add(createServiceDependency()
-                    .setService(IController.class, "(name=Controller)")
-                    .setCallbacks("setController", "unsetController")
-                    .setRequired(true));
-            c.add(createServiceDependency()
-                    .setService(IOFStatisticsListener.class)
-                    .setCallbacks("setStatisticsListener",
-                            "unsetStatisticsListener").setRequired(false));
-        }
-
-        if (imp.equals(DiscoveryService.class)) {
-            // export the service
-            c.setInterface(
-                    new String[] { IInventoryShimExternalListener.class.getName(), IDataPacketListen.class.getName(),
-                            IContainerListener.class.getName() }, null);
-
-            c.add(createServiceDependency()
-                    .setService(IController.class, "(name=Controller)")
-                    .setCallbacks("setController", "unsetController")
-                    .setRequired(true));
-            c.add(createContainerServiceDependency(
-                    GlobalConstants.DEFAULT.toString())
-                    .setService(IInventoryProvider.class)
-                    .setCallbacks("setInventoryProvider",
-                    "unsetInventoryProvider").setRequired(true));
-            c.add(createServiceDependency().setService(IDataPacketMux.class)
-                    .setCallbacks("setIDataPacketMux", "unsetIDataPacketMux")
-                    .setRequired(true));
-            c.add(createServiceDependency()
-                    .setService(IDiscoveryListener.class)
-                    .setCallbacks("setDiscoveryListener",
-                            "unsetDiscoveryListener").setRequired(true));
-            c.add(createServiceDependency()
-                    .setService(IPluginOutConnectionService.class)
-                    .setCallbacks("setIPluginOutConnectionService",
-                            "unsetIPluginOutConnectionService")
-                    .setRequired(true));
-        }
-
-        // DataPacket mux/demux services, which is teh actual engine
-        // doing the packet switching
-        if (imp.equals(DataPacketMuxDemux.class)) {
-            c.setInterface(new String[] { IDataPacketMux.class.getName(), IContainerListener.class.getName(),
-                    IInventoryShimExternalListener.class.getName(), IContainerAware.class.getName() }, null);
-
-            c.add(createServiceDependency()
-                    .setService(IController.class, "(name=Controller)")
-                    .setCallbacks("setController", "unsetController")
-                    .setRequired(true));
-            c.add(createServiceDependency()
-                    .setService(IPluginOutDataPacketService.class)
-                    .setCallbacks("setPluginOutDataPacketService",
-                            "unsetPluginOutDataPacketService")
-                    .setRequired(false));
-            // See if there is any local packet dispatcher
-            c.add(createServiceDependency()
-                    .setService(IDataPacketListen.class)
-                    .setCallbacks("setIDataPacketListen",
-                            "unsetIDataPacketListen").setRequired(false));
-            c.add(createServiceDependency()
-                    .setService(IPluginOutConnectionService.class)
-                    .setCallbacks("setIPluginOutConnectionService",
-                            "unsetIPluginOutConnectionService")
-                    .setRequired(true));
-        }
-
-        if (imp.equals(InventoryService.class)) {
-            // export the service
-            Dictionary<String, Object> props = new Hashtable<String, Object>();
-            props.put("scope", "Global");
-
-            c.setInterface(
-                    new String[] { IPluginInInventoryService.class.getName(),
-                            IInventoryShimInternalListener.class.getName(),
-                            IInventoryProvider.class.getName() }, props);
-
-            // Now lets add a service dependency to make sure the
-            // provider of service exists
-            c.add(createServiceDependency()
-                    .setService(IController.class, "(name=Controller)")
-                    .setCallbacks("setController", "unsetController")
-                    .setRequired(true));
-            c.add(createServiceDependency()
-                    .setService(IPluginOutInventoryService.class, "(scope=Global)")
-                    .setCallbacks("setPluginOutInventoryServices",
-                            "unsetPluginOutInventoryServices")
-                    .setRequired(true));
-        }
-
-        if (imp.equals(InventoryServiceShim.class)) {
-            c.setInterface(new String[] { IContainerListener.class.getName(),
-                    IOFStatisticsListener.class.getName(), IContainerAware.class.getName() }, null);
-
-            c.add(createServiceDependency()
-                    .setService(IController.class, "(name=Controller)")
-                    .setCallbacks("setController", "unsetController")
-                    .setRequired(true));
-            c.add(createServiceDependency()
-                    .setService(IInventoryShimInternalListener.class, "(!(scope=Global))")
-                    .setCallbacks("setInventoryShimInternalListener",
-                            "unsetInventoryShimInternalListener")
-                    .setRequired(true));
-            c.add(createServiceDependency()
-                    .setService(IInventoryShimInternalListener.class, "(scope=Global)")
-                    .setCallbacks("setInventoryShimGlobalInternalListener",
-                            "unsetInventoryShimGlobalInternalListener")
-                    .setRequired(true));
-            c.add(createServiceDependency()
-                    .setService(IInventoryShimExternalListener.class)
-                    .setCallbacks("setInventoryShimExternalListener",
-                            "unsetInventoryShimExternalListener")
-                    .setRequired(false));
-            c.add(createServiceDependency()
-                    .setService(IPluginOutConnectionService.class)
-                    .setCallbacks("setIPluginOutConnectionService",
-                            "unsetIPluginOutConnectionService")
-                    .setRequired(true));
-        }
-
-        if (imp.equals(TopologyServiceShim.class)) {
-            c.setInterface(new String[] { IDiscoveryListener.class.getName(), IContainerListener.class.getName(),
-                    IRefreshInternalProvider.class.getName(), IInventoryShimExternalListener.class.getName(),
-                    IContainerAware.class.getName() }, null);
-          c.add(createServiceDependency()
-                    .setService(ITopologyServiceShimListener.class)
-                    .setCallbacks("setTopologyServiceShimListener",
-                            "unsetTopologyServiceShimListener")
-                    .setRequired(true));
-            c.add(createServiceDependency()
-                    .setService(IOFStatisticsManager.class)
-                    .setCallbacks("setStatisticsManager",
-                            "unsetStatisticsManager").setRequired(false));
-        }
-    }
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/DataPacketMuxDemux.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/DataPacketMuxDemux.java
deleted file mode 100644 (file)
index 932ac4e..0000000
+++ /dev/null
@@ -1,494 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow.internal;
-
-import java.util.Collections;
-import java.util.HashSet;
-import java.util.List;
-import java.util.Map;
-import java.util.Set;
-import java.util.concurrent.ConcurrentHashMap;
-import java.util.concurrent.ConcurrentMap;
-import java.util.concurrent.CopyOnWriteArrayList;
-
-import org.opendaylight.controller.protocol_plugin.openflow.IDataPacketListen;
-import org.opendaylight.controller.protocol_plugin.openflow.IDataPacketMux;
-import org.opendaylight.controller.protocol_plugin.openflow.IInventoryShimExternalListener;
-import org.opendaylight.controller.protocol_plugin.openflow.core.IController;
-import org.opendaylight.controller.protocol_plugin.openflow.core.IMessageListener;
-import org.opendaylight.controller.protocol_plugin.openflow.core.ISwitch;
-import org.opendaylight.controller.sal.connection.IPluginOutConnectionService;
-import org.opendaylight.controller.sal.core.ConstructionException;
-import org.opendaylight.controller.sal.core.ContainerFlow;
-import org.opendaylight.controller.sal.core.IContainerAware;
-import org.opendaylight.controller.sal.core.IContainerListener;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.core.UpdateType;
-import org.opendaylight.controller.sal.match.Match;
-import org.opendaylight.controller.sal.packet.Ethernet;
-import org.opendaylight.controller.sal.packet.IPluginOutDataPacketService;
-import org.opendaylight.controller.sal.packet.PacketException;
-import org.opendaylight.controller.sal.packet.PacketResult;
-import org.opendaylight.controller.sal.packet.RawPacket;
-import org.opendaylight.controller.sal.utils.GlobalConstants;
-import org.opendaylight.controller.sal.utils.HexEncode;
-import org.opendaylight.controller.sal.utils.NetUtils;
-import org.openflow.protocol.OFMessage;
-import org.openflow.protocol.OFPacketIn;
-import org.openflow.protocol.OFPacketOut;
-import org.openflow.protocol.OFPort;
-import org.openflow.protocol.OFType;
-import org.openflow.protocol.action.OFAction;
-import org.openflow.protocol.action.OFActionOutput;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-public class DataPacketMuxDemux implements IContainerListener,
-        IMessageListener, IDataPacketMux, IInventoryShimExternalListener, IContainerAware {
-    protected static final Logger logger = LoggerFactory
-            .getLogger(DataPacketMuxDemux.class);
-    private IController controller = null;
-    private ConcurrentMap<Long, ISwitch> swID2ISwitch = new ConcurrentHashMap<Long, ISwitch>();
-    // Gives a map between a Container and all the DataPacket listeners on SAL
-    private ConcurrentMap<String, IPluginOutDataPacketService> pluginOutDataPacketServices = new ConcurrentHashMap<String, IPluginOutDataPacketService>();
-    // Gives a map between a NodeConnector and the containers to which it
-    // belongs
-    private ConcurrentMap<NodeConnector, List<String>> nc2Container = new ConcurrentHashMap<NodeConnector, List<String>>();
-    // Gives a map between a Container and the FlowSpecs on it
-    private ConcurrentMap<String, List<ContainerFlow>> container2FlowSpecs = new ConcurrentHashMap<String, List<ContainerFlow>>();
-    // Track local data packet listener
-    private List<IDataPacketListen> iDataPacketListen = new CopyOnWriteArrayList<IDataPacketListen>();
-    private IPluginOutConnectionService connectionOutService;
-
-    void setIDataPacketListen(IDataPacketListen s) {
-        if (this.iDataPacketListen != null) {
-            if (!this.iDataPacketListen.contains(s)) {
-                logger.debug("Added new IDataPacketListen");
-                this.iDataPacketListen.add(s);
-            }
-        }
-    }
-
-    void unsetIDataPacketListen(IDataPacketListen s) {
-        if (this.iDataPacketListen != null) {
-            if (this.iDataPacketListen.contains(s)) {
-                logger.debug("Removed IDataPacketListen");
-                this.iDataPacketListen.remove(s);
-            }
-        }
-    }
-
-    void setPluginOutDataPacketService(Map<String, Object> props,
-            IPluginOutDataPacketService s) {
-        if (props == null) {
-            logger.error("Didn't receive the service properties");
-            return;
-        }
-        String containerName = (String) props.get("containerName");
-        if (containerName == null) {
-            logger.error("containerName not supplied");
-            return;
-        }
-        if (this.pluginOutDataPacketServices != null) {
-            // It's expected only one SAL per container as long as the
-            // replication is done in the SAL implementation toward
-            // the different APPS
-            this.pluginOutDataPacketServices.put(containerName, s);
-            logger.debug("New outService for container: {}", containerName);
-        }
-    }
-
-    void unsetPluginOutDataPacketService(Map<String, Object> props,
-            IPluginOutDataPacketService s) {
-        if (props == null) {
-            logger.error("Didn't receive the service properties");
-            return;
-        }
-        String containerName = (String) props.get("containerName");
-        if (containerName == null) {
-            logger.error("containerName not supplied");
-            return;
-        }
-        if (this.pluginOutDataPacketServices != null) {
-            this.pluginOutDataPacketServices.remove(containerName);
-            logger.debug("Removed outService for container: {}", containerName);
-        }
-    }
-
-    void setController(IController s) {
-        logger.debug("Controller provider set in DATAPACKET SERVICES");
-        this.controller = s;
-    }
-
-    void unsetController(IController s) {
-        if (this.controller == s) {
-            logger.debug("Controller provider UNset in DATAPACKET SERVICES");
-            this.controller = null;
-        }
-    }
-
-    void setIPluginOutConnectionService(IPluginOutConnectionService s) {
-        connectionOutService = s;
-    }
-
-    void unsetIPluginOutConnectionService(IPluginOutConnectionService s) {
-        if (connectionOutService == s) {
-            connectionOutService = null;
-        }
-    }
-
-    /**
-     * Function called by the dependency manager when all the required
-     * dependencies are satisfied
-     *
-     */
-    void init() {
-        this.controller.addMessageListener(OFType.PACKET_IN, this);
-    }
-
-    /**
-     * Function called by the dependency manager when at least one dependency
-     * become unsatisfied or when the component is shutting down because for
-     * example bundle is being stopped.
-     *
-     */
-    void destroy() {
-        this.controller.removeMessageListener(OFType.PACKET_IN, this);
-
-        // Clear state that may need to be reused on component restart
-        this.pluginOutDataPacketServices.clear();
-        this.nc2Container.clear();
-        this.container2FlowSpecs.clear();
-        this.controller = null;
-        this.swID2ISwitch.clear();
-    }
-
-    @Override
-    public void receive(ISwitch sw, OFMessage msg) {
-        if (sw == null || msg == null || this.pluginOutDataPacketServices == null) {
-            // Something fishy, we cannot do anything
-            logger.debug("sw: {} and/or msg: {} and/or pluginOutDataPacketServices: {} is null!", new Object[] { sw,
-                    msg, this.pluginOutDataPacketServices });
-            return;
-        }
-
-        Long ofSwitchID = Long.valueOf(sw.getId());
-        try {
-            Node n = new Node(Node.NodeIDType.OPENFLOW, ofSwitchID);
-            if (!connectionOutService.isLocal(n)) {
-                logger.debug("Connection service refused DataPacketMuxDemux receive {} {}", sw, msg);
-                return;
-            }
-        } catch (Exception e) {
-            return;
-        }
-
-        if (msg instanceof OFPacketIn) {
-            OFPacketIn ofPacket = (OFPacketIn) msg;
-            Short ofPortID = Short.valueOf(ofPacket.getInPort());
-
-            try {
-                Node n = new Node(Node.NodeIDType.OPENFLOW, ofSwitchID);
-                NodeConnector p = PortConverter.toNodeConnector(ofPortID, n);
-                RawPacket dataPacket = new RawPacket(ofPacket.getPacketData());
-                dataPacket.setIncomingNodeConnector(p);
-
-                // Try to dispatch the packet locally, in here we will
-                // pass the parsed packet simply because once the
-                // packet infra is settled all the packets will passed
-                // around as parsed and read-only
-                for (IDataPacketListen s : this.iDataPacketListen) {
-                      if (s.receiveDataPacket(dataPacket).equals(PacketResult.CONSUME)) {
-                        logger.trace("Consumed locally data packet");
-                        return;
-                    }
-                }
-
-                boolean dispatched_to_container = false;
-
-                // Now check the mapping between nodeConnector and
-                // Container and later on optimally filter based on
-                // flowSpec
-                List<String> containersRX = this.nc2Container.get(p);
-                if (containersRX != null) {
-                    Ethernet frame = new Ethernet();
-                    byte data[] = dataPacket.getPacketData();
-                    frame.deserialize(data, 0, data.length * NetUtils.NumBitsInAByte);
-                    Match packetMatch = frame.getMatch();
-                    for (String container : containersRX) {
-                        boolean notify = true;
-                        List<ContainerFlow> containerFlows = this.container2FlowSpecs.get(container);
-                        if (containerFlows != null) {
-                            notify = false;
-                            for (ContainerFlow cFlow : containerFlows) {
-                                if (cFlow.allowsMatch(packetMatch)) {
-                                    notify = true;
-                                    break;
-                                }
-                            }
-                            if (notify) {
-                                IPluginOutDataPacketService s = this.pluginOutDataPacketServices.get(container);
-                                if (s != null) {
-                                    s.receiveDataPacket(dataPacket);
-                                    if (logger.isTraceEnabled()) {
-                                        logger.trace(
-                                                "Dispatched to apps a frame of size: {}" + " on container: {}: {}",
-                                                new Object[] { ofPacket.getPacketData().length, container,
-                                                        HexEncode.bytesToHexString(dataPacket.getPacketData()) });
-                                    }
-                                }
-                                dispatched_to_container = true;
-                            }
-                        }
-                    }
-                }
-                if (!dispatched_to_container) {
-                    // Now dispatch the packet toward SAL for default container
-                    IPluginOutDataPacketService defaultOutService = this.pluginOutDataPacketServices
-                        .get(GlobalConstants.DEFAULT.toString());
-                    if (defaultOutService != null) {
-                        defaultOutService.receiveDataPacket(dataPacket);
-                        if (logger.isTraceEnabled()) {
-                            logger.trace("Dispatched to apps a frame of size: {} on " + "container: {}: {}",
-                                         new Object[] { ofPacket.getPacketData().length,
-                                                        GlobalConstants.DEFAULT.toString(),
-                                                        HexEncode.bytesToHexString(dataPacket.getPacketData()) });
-                        }
-                    }
-                }
-                // This is supposed to be the catch all for all the
-                // DataPacket hence we will assume it has been handled
-                return;
-            } catch (ConstructionException cex) {
-            } catch (PacketException e) {
-                logger.debug("Failed to deserialize raw packet: ", e.getMessage());
-            }
-            // If we reach this point something went wrong.
-            return;
-        } else {
-            // We don't care about non-data packets
-            return;
-        }
-    }
-
-    @Override
-    public void transmitDataPacket(RawPacket outPkt) {
-        // Sanity check area
-        if (outPkt == null) {
-            logger.debug("outPkt is null!");
-            return;
-        }
-
-        NodeConnector outPort = outPkt.getOutgoingNodeConnector();
-        if (outPort == null) {
-            logger.debug("outPort is null! outPkt: {}", outPkt);
-            return;
-        }
-
-        if (!connectionOutService.isLocal(outPort.getNode())) {
-            logger.debug("data packets will not be sent to {} in a non-master controller", outPort.toString());
-            return;
-        }
-
-
-        if (!outPort.getType().equals(
-                NodeConnector.NodeConnectorIDType.OPENFLOW)) {
-            // The output Port is not of type OpenFlow
-            logger.debug("outPort is not OF Type! outPort: {}", outPort);
-            return;
-        }
-
-        Short port = (Short) outPort.getID();
-        Long swID = (Long) outPort.getNode().getID();
-        ISwitch sw = this.swID2ISwitch.get(swID);
-
-        if (sw == null) {
-            // If we cannot get the controller descriptor we cannot even
-            // send out the frame
-            logger.debug("swID: {} - sw is null!", swID);
-            return;
-        }
-
-        byte[] data = outPkt.getPacketData();
-        // build action
-        OFActionOutput action = new OFActionOutput().setPort(port);
-        // build packet out
-        OFPacketOut po = new OFPacketOut()
-                .setBufferId(OFPacketOut.BUFFER_ID_NONE)
-                .setActions(Collections.singletonList((OFAction) action))
-                .setActionsLength((short) OFActionOutput.MINIMUM_LENGTH);
-        if(outPkt.getIncomingNodeConnector() != null) {
-            po.setInPort((Short)outPkt.getIncomingNodeConnector().getID());
-        } else {
-            po.setInPort(OFPort.OFPP_NONE);
-        }
-
-        po.setLengthU(OFPacketOut.MINIMUM_LENGTH + po.getActionsLength()
-                + data.length);
-        po.setPacketData(data);
-
-        // send PACKET_OUT at high priority
-        sw.asyncFastSend(po);
-        logger.trace("Transmitted a frame of size: {}", data.length);
-    }
-
-    public void addNode(Node node, Set<Property> props) {
-        if (node == null) {
-            logger.debug("node is null!");
-            return;
-        }
-
-        long sid = (Long) node.getID();
-        ISwitch sw = controller.getSwitches().get(sid);
-        if (sw == null) {
-            logger.debug("sid: {} - sw is null!", sid);
-            return;
-        }
-        this.swID2ISwitch.put(sw.getId(), sw);
-    }
-
-    public void removeNode(Node node) {
-        if (node == null) {
-            logger.debug("node is null!");
-            return;
-        }
-
-        long sid = (Long) node.getID();
-        ISwitch sw = controller.getSwitches().get(sid);
-        if (sw == null) {
-            logger.debug("sid: {} - sw is null!", sid);
-            return;
-        }
-        this.swID2ISwitch.remove(sw.getId());
-    }
-
-    @Override
-    public void tagUpdated(String containerName, Node n, short oldTag,
-            short newTag, UpdateType t) {
-        // Do nothing
-    }
-
-    @Override
-    public void containerFlowUpdated(String containerName,
-            ContainerFlow previousFlow, ContainerFlow currentFlow, UpdateType t) {
-        if (this.container2FlowSpecs == null) {
-            logger.error("container2FlowSpecs is NULL");
-            return;
-        }
-        List<ContainerFlow> fSpecs = this.container2FlowSpecs
-                .get(containerName);
-        if (fSpecs == null) {
-            fSpecs = new CopyOnWriteArrayList<ContainerFlow>();
-        }
-        switch (t) {
-        case ADDED:
-            if (!fSpecs.contains(currentFlow)) {
-                fSpecs.add(currentFlow);
-            }
-            container2FlowSpecs.put(containerName, fSpecs);
-            break;
-        case REMOVED:
-            fSpecs.remove(currentFlow);
-            break;
-        case CHANGED:
-            break;
-        }
-    }
-
-    @Override
-    public void nodeConnectorUpdated(String containerName, NodeConnector p,
-            UpdateType t) {
-        if (this.nc2Container == null) {
-            logger.error("nc2Container is NULL");
-            return;
-        }
-        List<String> containers = this.nc2Container.get(p);
-        if (containers == null) {
-            containers = new CopyOnWriteArrayList<String>();
-        }
-        boolean updateMap = false;
-        switch (t) {
-        case ADDED:
-            if (!containers.contains(containerName)) {
-                containers.add(containerName);
-                updateMap = true;
-            }
-            break;
-        case REMOVED:
-            if (containers.contains(containerName)) {
-                containers.remove(containerName);
-                updateMap = true;
-            }
-            break;
-        case CHANGED:
-            break;
-        }
-        if (updateMap) {
-            if (containers.isEmpty()) {
-                // Do cleanup to reduce memory footprint if no
-                // elements to be tracked
-                this.nc2Container.remove(p);
-            } else {
-                this.nc2Container.put(p, containers);
-            }
-        }
-    }
-
-    @Override
-    public void containerModeUpdated(UpdateType t) {
-        // do nothing
-    }
-
-    @Override
-    public void updateNode(Node node, UpdateType type, Set<Property> props) {
-        switch (type) {
-        case ADDED:
-            addNode(node, props);
-            break;
-        case REMOVED:
-            removeNode(node);
-            break;
-        default:
-            break;
-        }
-    }
-
-    @Override
-    public void updateNodeConnector(NodeConnector nodeConnector,
-            UpdateType type, Set<Property> props) {
-        // do nothing
-    }
-
-    @Override
-    public void containerCreate(String containerName) {
-        // do nothing
-    }
-
-    @Override
-    public void containerDestroy(String containerName) {
-        Set<NodeConnector> removeNodeConnectorSet = new HashSet<NodeConnector>();
-        for (Map.Entry<NodeConnector, List<String>> entry : nc2Container.entrySet()) {
-            List<String> ncContainers = entry.getValue();
-            if (ncContainers.contains(containerName)) {
-                NodeConnector nodeConnector = entry.getKey();
-                removeNodeConnectorSet.add(nodeConnector);
-            }
-        }
-        for (NodeConnector nodeConnector : removeNodeConnectorSet) {
-            List<String> ncContainers = nc2Container.get(nodeConnector);
-            ncContainers.remove(containerName);
-            if (ncContainers.isEmpty()) {
-                nc2Container.remove(nodeConnector);
-            }
-        }
-        container2FlowSpecs.remove(containerName);
-    }
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/DataPacketServices.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/DataPacketServices.java
deleted file mode 100644 (file)
index 4c65645..0000000
+++ /dev/null
@@ -1,55 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow.internal;
-
-import org.opendaylight.controller.protocol_plugin.openflow.IDataPacketMux;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-import org.opendaylight.controller.sal.connection.IPluginOutConnectionService;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.packet.IPluginInDataPacketService;
-import org.opendaylight.controller.sal.packet.RawPacket;
-
-public class DataPacketServices implements IPluginInDataPacketService {
-    protected static final Logger logger = LoggerFactory
-            .getLogger(DataPacketServices.class);
-    private IDataPacketMux iDataPacketMux = null;
-    private IPluginOutConnectionService connectionOutService;
-
-    void setIDataPacketMux(IDataPacketMux s) {
-        this.iDataPacketMux = s;
-    }
-
-    void unsetIDataPacketMux(IDataPacketMux s) {
-        if (this.iDataPacketMux == s) {
-            this.iDataPacketMux = null;
-        }
-    }
-
-    void setIPluginOutConnectionService(IPluginOutConnectionService s) {
-        connectionOutService = s;
-    }
-
-    void unsetIPluginOutConnectionService(IPluginOutConnectionService s) {
-        if (connectionOutService == s) {
-            connectionOutService = null;
-        }
-    }
-
-    @Override
-    public void transmitDataPacket(RawPacket outPkt) {
-        NodeConnector nc = outPkt.getOutgoingNodeConnector();
-        if (connectionOutService != null && connectionOutService.isLocal(nc.getNode())) {
-            this.iDataPacketMux.transmitDataPacket(outPkt);
-        } else {
-            logger.debug("{} is dropped in the controller "+outPkt);
-        }
-    }
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/DescStatisticsConverter.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/DescStatisticsConverter.java
deleted file mode 100644 (file)
index 28c3dd6..0000000
+++ /dev/null
@@ -1,53 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow.internal;
-
-import java.util.List;
-
-import org.opendaylight.controller.sal.reader.NodeDescription;
-import org.openflow.protocol.statistics.OFDescriptionStatistics;
-import org.openflow.protocol.statistics.OFStatistics;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * Utility class for converting openflow description statistics into SAL
- * NodeDescription object
- */
-public class DescStatisticsConverter {
-    private static final Logger log = LoggerFactory
-            .getLogger(DescStatisticsConverter.class);
-    NodeDescription hwDesc;
-    OFDescriptionStatistics ofDesc;
-
-    public DescStatisticsConverter(List<OFStatistics> statsList) {
-        this.hwDesc = null;
-        this.ofDesc = (statsList == null || statsList.isEmpty())?
-                null : (OFDescriptionStatistics) statsList.get(0);
-    }
-    public DescStatisticsConverter(OFDescriptionStatistics desc) {
-        this.hwDesc = null;
-        this.ofDesc = desc;
-    }
-
-    public NodeDescription getHwDescription() {
-        if (hwDesc == null && ofDesc != null) {
-            hwDesc = new NodeDescription();
-            hwDesc.setManufacturer(ofDesc.getManufacturerDescription());
-            hwDesc.setHardware(ofDesc.getHardwareDescription());
-            hwDesc.setSoftware(ofDesc.getSoftwareDescription());
-            hwDesc.setDescription(ofDesc.getDatapathDescription());
-            hwDesc.setSerialNumber(ofDesc.getSerialNumber());
-        }
-        log.trace("OFDescriptionStatistics: {}", ofDesc);
-        log.trace("NodeDescription: {}", hwDesc);
-        return hwDesc;
-    }
-
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/DiscoveryService.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/DiscoveryService.java
deleted file mode 100644 (file)
index 1a59a32..0000000
+++ /dev/null
@@ -1,1715 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow.internal;
-
-import java.nio.charset.Charset;
-import java.util.ArrayList;
-import java.util.Collection;
-import java.util.Collections;
-import java.util.HashSet;
-import java.util.List;
-import java.util.Map;
-import java.util.Set;
-import java.util.Timer;
-import java.util.TimerTask;
-import java.util.concurrent.BlockingQueue;
-import java.util.concurrent.ConcurrentHashMap;
-import java.util.concurrent.ConcurrentMap;
-import java.util.concurrent.CopyOnWriteArrayList;
-import java.util.concurrent.LinkedBlockingQueue;
-
-import org.eclipse.osgi.framework.console.CommandInterpreter;
-import org.eclipse.osgi.framework.console.CommandProvider;
-import org.opendaylight.controller.protocol_plugin.openflow.IDataPacketListen;
-import org.opendaylight.controller.protocol_plugin.openflow.IDataPacketMux;
-import org.opendaylight.controller.protocol_plugin.openflow.IDiscoveryListener;
-import org.opendaylight.controller.protocol_plugin.openflow.IInventoryProvider;
-import org.opendaylight.controller.protocol_plugin.openflow.IInventoryShimExternalListener;
-import org.opendaylight.controller.protocol_plugin.openflow.core.IController;
-import org.opendaylight.controller.protocol_plugin.openflow.core.ISwitch;
-import org.opendaylight.controller.sal.connection.IPluginOutConnectionService;
-import org.opendaylight.controller.sal.core.Config;
-import org.opendaylight.controller.sal.core.ConstructionException;
-import org.opendaylight.controller.sal.core.ContainerFlow;
-import org.opendaylight.controller.sal.core.Edge;
-import org.opendaylight.controller.sal.core.IContainerListener;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.core.State;
-import org.opendaylight.controller.sal.core.UpdateType;
-import org.opendaylight.controller.sal.packet.Ethernet;
-import org.opendaylight.controller.sal.packet.LLDP;
-import org.opendaylight.controller.sal.packet.LLDPTLV;
-import org.opendaylight.controller.sal.packet.LinkEncap;
-import org.opendaylight.controller.sal.packet.PacketResult;
-import org.opendaylight.controller.sal.packet.RawPacket;
-import org.opendaylight.controller.sal.utils.EtherTypes;
-import org.opendaylight.controller.sal.utils.HexEncode;
-import org.opendaylight.controller.sal.utils.NetUtils;
-import org.opendaylight.controller.sal.utils.NodeConnectorCreator;
-import org.opendaylight.controller.sal.utils.NodeCreator;
-import org.openflow.protocol.OFPhysicalPort;
-import org.osgi.framework.BundleContext;
-import org.osgi.framework.FrameworkUtil;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * The class describes neighbor discovery service for an OpenFlow network.
- */
-public class DiscoveryService implements IInventoryShimExternalListener, IDataPacketListen, IContainerListener,
-        CommandProvider {
-    private static Logger logger = LoggerFactory.getLogger(DiscoveryService.class);
-    private IController controller = null;
-    private IDiscoveryListener discoveryListener = null;
-    private IInventoryProvider inventoryProvider = null;
-    private IDataPacketMux iDataPacketMux = null;
-    // High priority list containing newly added ports which will be served first
-    private List<NodeConnector> readyListHi = null;
-    // List containing all the ports which will be served periodically
-    private List<NodeConnector> readyListLo = null;
-    // Staging area during quiet period
-    private List<NodeConnector> stagingList = null;
-    // Wait for next discovery packet. The map contains the time elapsed since
-    // the last received LLDP frame on each node connector
-    private ConcurrentMap<NodeConnector, Integer> holdTime = null;
-    // Allow one more retry for newly added ports. This map contains the time
-    // period elapsed since last discovery pkt transmission on the port.
-    private ConcurrentMap<NodeConnector, Integer> elapsedTime = null;
-    // OpenFlow edges keyed by head connector
-    private ConcurrentMap<NodeConnector, Edge> edgeMap = null;
-    // The map contains aging entry keyed by head connector of Production edge
-    private ConcurrentMap<NodeConnector, Integer> agingMap = null;
-    // Production edges keyed by head connector
-    private ConcurrentMap<NodeConnector, Edge> prodMap = null;
-
-    private Timer discoveryTimer;
-    private DiscoveryTimerTask discoveryTimerTask;
-    private final static long discoveryTimerTick = 2L * 1000; // per tick in msec
-    private int discoveryTimerTickCount = 0; // main tick counter
-    // Max # of ports handled in one batch
-    private int discoveryBatchMaxPorts;
-    // Periodically restart batching process
-    private int discoveryBatchRestartTicks;
-    private int discoveryBatchPausePeriod = 2;
-    // Pause after this point
-    private int discoveryBatchPauseTicks;
-    private int discoveryTimeoutTicks;
-    private int discoveryThresholdTicks;
-    private int discoveryAgeoutTicks;
-    // multiple of discoveryBatchRestartTicks
-    private int discoveryConsistencyCheckMultiple = 2;
-    // CC tick counter
-    private int discoveryConsistencyCheckTickCount;
-    // # of times CC gets called
-    private int discoveryConsistencyCheckCallingTimes = 0;
-    // # of cases CC corrected
-    private int discoveryConsistencyCheckCorrected = 0;
-    // Enable or disable CC
-    private boolean discoveryConsistencyCheckEnabled = true;
-    // Enable or disable aging
-    private boolean discoveryAgingEnabled = true;
-    // Global flag to enable or disable LLDP snooping
-    private boolean discoverySnoopingEnabled = true;
-    // The list of ports that will not do LLDP snooping
-    private List<NodeConnector> discoverySnoopingDisableList;
-    private BlockingQueue<NodeConnector> transmitQ;
-    private Thread transmitThread;
-    private Boolean throttling = false; // if true, no more batching.
-    private volatile Boolean shuttingDown = false;
-
-    private LLDPTLV chassisIdTlv, systemNameTlv, portIdTlv, ttlTlv, customTlv;
-    private IPluginOutConnectionService connectionOutService;
-
-    class DiscoveryTransmit implements Runnable {
-        private final BlockingQueue<NodeConnector> transmitQ;
-        private int count = 0;
-
-        DiscoveryTransmit(BlockingQueue<NodeConnector> transmitQ) {
-            this.transmitQ = transmitQ;
-        }
-
-        @Override
-        public void run() {
-            while (true) {
-                try {
-                    NodeConnector nodeConnector = transmitQ.take();
-                    RawPacket outPkt = createDiscoveryPacket(nodeConnector);
-                    sendDiscoveryPacket(nodeConnector, outPkt);
-                    nodeConnector = null;
-                    if ((++count & 0x7f) == 0) {
-                        Thread.sleep(10);
-                    }
-                } catch (InterruptedException e1) {
-                    logger.trace("DiscoveryTransmit interupted", e1.getMessage());
-                    if (shuttingDown) {
-                        return;
-                    }
-                } catch (Exception e2) {
-                    logger.error("", e2);
-                }
-            }
-        }
-    }
-
-    class DiscoveryTimerTask extends TimerTask {
-        @Override
-        public void run() {
-            checkTimeout();
-            checkAging();
-            doConsistencyCheck();
-            doDiscovery();
-        }
-    }
-
-    public enum DiscoveryPeriod {
-        INTERVAL        (300),
-        AGEOUT          (120),
-        THRESHOLD       (30);
-
-        private int time;   // sec
-        private int tick;   // tick
-
-        DiscoveryPeriod(int time) {
-            this.time = time;
-            this.tick = time2Tick(time);
-        }
-
-        public int getTime() {
-            return time;
-        }
-
-        public void setTime(int time) {
-            this.time = time;
-            this.tick = time2Tick(time);
-        }
-
-        public int getTick() {
-            return tick;
-        }
-
-        public void setTick(int tick) {
-            this.time = tick2Time(tick);
-            this.tick = tick;
-        }
-
-        private int time2Tick(int time) {
-            return (int) (time / (discoveryTimerTick / 1000));
-        }
-
-        private int tick2Time(int tick) {
-            return (int) (tick * (discoveryTimerTick / 1000));
-        }
-    }
-
-    private RawPacket createDiscoveryPacket(NodeConnector nodeConnector) {
-        String nodeId = HexEncode.longToHexString((Long) nodeConnector.getNode().getID());
-
-        // Create LLDP ChassisID TLV
-        byte[] cidValue = LLDPTLV.createChassisIDTLVValue(nodeId);
-        chassisIdTlv.setType(LLDPTLV.TLVType.ChassisID.getValue()).setLength((short) cidValue.length)
-                .setValue(cidValue);
-
-        // Create LLDP SystemName TLV
-        byte[] snValue = LLDPTLV.createSystemNameTLVValue(nodeConnector.getNode().toString());
-        systemNameTlv.setType(LLDPTLV.TLVType.SystemName.getValue()).setLength((short) snValue.length)
-                .setValue(snValue);
-
-        // Create LLDP PortID TLV
-        String portId = nodeConnector.getNodeConnectorIDString();
-        byte[] pidValue = LLDPTLV.createPortIDTLVValue(portId);
-        portIdTlv.setType(LLDPTLV.TLVType.PortID.getValue()).setLength((short) pidValue.length).setValue(pidValue);
-
-        // Create LLDP Custom TLV
-        byte[] customValue = LLDPTLV.createCustomTLVValue(nodeConnector.toString());
-        customTlv.setType(LLDPTLV.TLVType.Custom.getValue()).setLength((short) customValue.length)
-                .setValue(customValue);
-
-        // Create LLDP Custom Option list
-        List<LLDPTLV> customList = new ArrayList<LLDPTLV>();
-        customList.add(customTlv);
-
-        // Create discovery pkt
-        LLDP discoveryPkt = new LLDP();
-        discoveryPkt.setChassisId(chassisIdTlv).setPortId(portIdTlv).setTtl(ttlTlv).setSystemNameId(systemNameTlv)
-                .setOptionalTLVList(customList);
-
-        RawPacket rawPkt = null;
-        try {
-            // Create ethernet pkt
-            byte[] sourceMac = getSourceMACFromNodeID(nodeId);
-            Ethernet ethPkt = new Ethernet();
-            ethPkt.setSourceMACAddress(sourceMac).setDestinationMACAddress(LLDP.LLDPMulticastMac)
-                    .setEtherType(EtherTypes.LLDP.shortValue()).setPayload(discoveryPkt);
-
-            byte[] data = ethPkt.serialize();
-            rawPkt = new RawPacket(data);
-            rawPkt.setOutgoingNodeConnector(nodeConnector);
-        } catch (ConstructionException cex) {
-            logger.warn("RawPacket creation caught exception {}", cex.getMessage());
-        } catch (Exception e) {
-            logger.error("Failed to serialize the LLDP packet: " + e);
-        }
-
-        return rawPkt;
-    }
-
-    private void sendDiscoveryPacket(NodeConnector nodeConnector, RawPacket outPkt) {
-        if (nodeConnector == null) {
-            logger.debug("Can not send discovery packet out since nodeConnector is null");
-            return;
-        }
-
-        if (!connectionOutService.isLocal(nodeConnector.getNode())) {
-            logger.debug("Discoery packets will not be sent to {} in a non-master controller", nodeConnector.toString());
-            return;
-        }
-
-        if (outPkt == null) {
-            logger.debug("Can not send discovery packet out since outPkt is null");
-            return;
-        }
-
-        long sid = (Long) nodeConnector.getNode().getID();
-        ISwitch sw = controller.getSwitches().get(sid);
-
-        if (sw == null) {
-            logger.debug("Can not send discovery packet out since switch {} is null", sid);
-            return;
-        }
-
-        if (!sw.isOperational()) {
-            logger.debug("Can not send discovery packet out since switch {} is not operational", sw);
-            return;
-        }
-
-        if (this.iDataPacketMux == null) {
-            logger.debug("Can not send discovery packet out since DataPacket service is not available");
-            return;
-        }
-
-        logger.trace("Sending topology discovery pkt thru {}", nodeConnector);
-        this.iDataPacketMux.transmitDataPacket(outPkt);
-    }
-
-    @Override
-    public PacketResult receiveDataPacket(RawPacket inPkt) {
-        if (inPkt == null) {
-            logger.debug("Ignoring null packet");
-            return PacketResult.IGNORED;
-        }
-
-        byte[] data = inPkt.getPacketData();
-        if (data.length <= 0) {
-            logger.trace("Ignoring zero length packet");
-            return PacketResult.IGNORED;
-        }
-
-        if (!inPkt.getEncap().equals(LinkEncap.ETHERNET)) {
-            logger.trace("Ignoring non ethernet packet");
-            return PacketResult.IGNORED;
-        }
-
-        NodeConnector nodeConnector = inPkt.getIncomingNodeConnector();
-        if (((Short) nodeConnector.getID()).equals(NodeConnector.SPECIALNODECONNECTORID)) {
-            logger.trace("Ignoring ethernet packet received on special port: "
-                    + inPkt.getIncomingNodeConnector().toString());
-            return PacketResult.IGNORED;
-        }
-
-        if (!connectionOutService.isLocal(nodeConnector.getNode())) {
-            logger.debug("Discoery packets will not be processed from {} in a non-master controller", nodeConnector.toString());
-            return PacketResult.IGNORED;
-        }
-
-        Ethernet ethPkt = new Ethernet();
-        try {
-            ethPkt.deserialize(data, 0, data.length * NetUtils.NumBitsInAByte);
-        } catch (Exception e) {
-            logger.warn("Failed to decode LLDP packet from {}: {}", inPkt.getIncomingNodeConnector(), e);
-            return PacketResult.IGNORED;
-        }
-
-        if (ethPkt.getPayload() instanceof LLDP) {
-            NodeConnector dst = inPkt.getIncomingNodeConnector();
-            if (isEnabled(dst)) {
-                if (!processDiscoveryPacket(dst, ethPkt)) {
-                    // Snoop the discovery pkt if not generated from us
-                    snoopDiscoveryPacket(dst, ethPkt);
-                }
-                return PacketResult.CONSUME;
-            }
-        }
-        return PacketResult.IGNORED;
-    }
-
-    /*
-     * Snoop incoming discovery frames generated by the production network
-     * neighbor switch
-     */
-    private void snoopDiscoveryPacket(NodeConnector dstNodeConnector, Ethernet ethPkt) {
-        if (!this.discoverySnoopingEnabled || discoverySnoopingDisableList.contains(dstNodeConnector)) {
-            logger.trace("Discarded received discovery packet on {} since snooping is turned off", dstNodeConnector);
-            return;
-        }
-
-        if ((dstNodeConnector == null) || (ethPkt == null)) {
-            logger.trace("Quit snooping discovery packet: Null node connector or packet");
-            return;
-        }
-
-        LLDP lldp = (LLDP) ethPkt.getPayload();
-
-        try {
-            String nodeId = LLDPTLV.getHexStringValue(lldp.getChassisId().getValue(), lldp.getChassisId().getLength());
-            String portId = LLDPTLV.getStringValue(lldp.getPortId().getValue(), lldp.getPortId().getLength());
-            byte[] systemNameBytes = null;
-            // get system name if present in the LLDP pkt
-            for (LLDPTLV lldptlv : lldp.getOptionalTLVList()) {
-                if (lldptlv.getType() == LLDPTLV.TLVType.SystemName.getValue()) {
-                    systemNameBytes = lldptlv.getValue();
-                    break;
-                }
-            }
-            String nodeName = (systemNameBytes == null) ? nodeId
-                    : new String(systemNameBytes, Charset.defaultCharset());
-            Node srcNode = new Node(Node.NodeIDType.PRODUCTION, nodeName);
-            NodeConnector srcNodeConnector = NodeConnectorCreator.createNodeConnector(
-                    NodeConnector.NodeConnectorIDType.PRODUCTION, portId, srcNode);
-
-            Edge edge = null;
-            Set<Property> props = null;
-            edge = new Edge(srcNodeConnector, dstNodeConnector);
-            props = getProps(dstNodeConnector);
-
-            updateProdEdge(edge, props);
-        } catch (Exception e) {
-            if (logger.isDebugEnabled()) {
-                logger.debug(
-                        "Caught exception while attempting to snoop non controller generated or malformed LLDP frame sent by {} and received on {}: {}",
-                        HexEncode.bytesToHexStringFormat(ethPkt.getSourceMACAddress()), dstNodeConnector,
-                        e.getMessage());
-            }
-        }
-    }
-
-    /*
-     * Handle discovery frames generated by our controller
-     *
-     * @return true if it's a success
-     */
-    private boolean processDiscoveryPacket(NodeConnector dstNodeConnector, Ethernet ethPkt) {
-        if ((dstNodeConnector == null) || (ethPkt == null)) {
-            logger.trace("Ignoring processing of discovery packet: Null node connector or packet");
-            return false;
-        }
-
-        logger.trace("Handle discovery packet {} from {}", ethPkt, dstNodeConnector);
-
-        LLDP lldp = (LLDP) ethPkt.getPayload();
-
-        List<LLDPTLV> optionalTLVList = lldp.getOptionalTLVList();
-        if (optionalTLVList == null) {
-            logger.warn("The discovery packet with null custom option from {}", dstNodeConnector);
-            return false;
-        }
-
-        Node srcNode = null;
-        NodeConnector srcNodeConnector = null;
-        for (LLDPTLV lldptlv : lldp.getOptionalTLVList()) {
-            if (lldptlv.getType() == LLDPTLV.TLVType.Custom.getValue()) {
-                String ncString = LLDPTLV.getCustomString(lldptlv.getValue(), lldptlv.getLength());
-                srcNodeConnector = NodeConnector.fromString(ncString);
-                if (srcNodeConnector != null) {
-                    srcNode = srcNodeConnector.getNode();
-                }
-            }
-        }
-
-        if ((srcNode == null) || (srcNodeConnector == null)) {
-            logger.trace("Received non-controller generated discovery packet from {}", dstNodeConnector);
-            return false;
-        }
-
-        // push it out to Topology
-        Edge edge = null;
-        Set<Property> props = null;
-        try {
-            edge = new Edge(srcNodeConnector, dstNodeConnector);
-            props = getProps(dstNodeConnector);
-        } catch (ConstructionException e) {
-            logger.error("Caught exception ", e);
-        }
-        addEdge(edge, props);
-
-        logger.trace("Received discovery packet for Edge {}", edge);
-
-        return true;
-    }
-
-    public Map<String, Property> getPropMap(NodeConnector nodeConnector) {
-        if (nodeConnector == null) {
-            return null;
-        }
-
-        if (inventoryProvider == null) {
-            return null;
-        }
-
-        Map<NodeConnector, Map<String, Property>> props = inventoryProvider.getNodeConnectorProps(false);
-        if (props == null) {
-            return null;
-        }
-
-        return props.get(nodeConnector);
-    }
-
-    public Property getProp(NodeConnector nodeConnector, String propName) {
-        Map<String, Property> propMap = getPropMap(nodeConnector);
-        if (propMap == null) {
-            return null;
-        }
-
-        Property prop = propMap.get(propName);
-        return prop;
-    }
-
-    public Set<Property> getProps(NodeConnector nodeConnector) {
-        Map<String, Property> propMap = getPropMap(nodeConnector);
-        if (propMap == null) {
-            return null;
-        }
-
-        Set<Property> props = new HashSet<Property>(propMap.values());
-        return props;
-    }
-
-    private boolean isEnabled(NodeConnector nodeConnector) {
-        if (nodeConnector == null) {
-            return false;
-        }
-
-        Config config = (Config) getProp(nodeConnector, Config.ConfigPropName);
-        State state = (State) getProp(nodeConnector, State.StatePropName);
-        return ((config != null) && (config.getValue() == Config.ADMIN_UP) && (state != null) && (state.getValue() == State.EDGE_UP));
-    }
-
-    private boolean isTracked(NodeConnector nodeConnector) {
-        if (readyListHi.contains(nodeConnector)) {
-            return true;
-        }
-
-        if (readyListLo.contains(nodeConnector)) {
-            return true;
-        }
-
-        if (holdTime.keySet().contains(nodeConnector)) {
-            return true;
-        }
-
-        if (stagingList.contains(nodeConnector)) {
-            return true;
-        }
-
-        return false;
-    }
-
-    private Set<NodeConnector> getWorkingSet() {
-        Set<NodeConnector> workingSet = new HashSet<NodeConnector>();
-        Set<NodeConnector> removeSet = new HashSet<NodeConnector>();
-
-        for (NodeConnector nodeConnector : readyListHi) {
-            if (isOverLimit(workingSet.size())) {
-                break;
-            }
-
-            workingSet.add(nodeConnector);
-            removeSet.add(nodeConnector);
-
-            // Put it in the map and start the timer. It may need retry.
-            elapsedTime.put(nodeConnector, 0);
-        }
-        readyListHi.removeAll(removeSet);
-
-        removeSet.clear();
-        for (NodeConnector nodeConnector : readyListLo) {
-            if (isOverLimit(workingSet.size())) {
-                break;
-            }
-
-            workingSet.add(nodeConnector);
-            removeSet.add(nodeConnector);
-        }
-        readyListLo.removeAll(removeSet);
-
-        return workingSet;
-    }
-
-    private Boolean isOverLimit(int size) {
-        return ((size >= discoveryBatchMaxPorts) && !throttling);
-    }
-
-    private void addDiscovery() {
-        Map<Long, ISwitch> switches = controller.getSwitches();
-        Set<Long> sidSet = switches.keySet();
-        if (sidSet == null) {
-            return;
-        }
-        for (Long sid : sidSet) {
-            Node node = NodeCreator.createOFNode(sid);
-            addDiscovery(node);
-        }
-    }
-
-    private void addDiscovery(Node node) {
-        Map<Long, ISwitch> switches = controller.getSwitches();
-        ISwitch sw = switches.get(node.getID());
-        if (sw == null) {
-            //switch could be removed by now, stop propagation
-            return;
-        }
-        List<OFPhysicalPort> ports = sw.getEnabledPorts();
-        for (OFPhysicalPort port : ports) {
-            NodeConnector nodeConnector = NodeConnectorCreator.createOFNodeConnector(port.getPortNumber(), node);
-            if (!readyListHi.contains(nodeConnector)) {
-                readyListHi.add(nodeConnector);
-            }
-        }
-    }
-
-    private void addDiscovery(NodeConnector nodeConnector) {
-        if (isTracked(nodeConnector)) {
-            return;
-        }
-
-        readyListHi.add(nodeConnector);
-    }
-
-    private void removeNodeConnector(NodeConnector nodeConnector) {
-        readyListLo.remove(nodeConnector);
-        readyListHi.remove(nodeConnector);
-        stagingList.remove(nodeConnector);
-        holdTime.remove(nodeConnector);
-        elapsedTime.remove(nodeConnector);
-    }
-
-    private Set<NodeConnector> getRemoveSet(Collection<NodeConnector> c, Node node) {
-        Set<NodeConnector> removeSet = new HashSet<NodeConnector>();
-        if (c == null) {
-            return removeSet;
-        }
-        for (NodeConnector nodeConnector : c) {
-            if (node.equals(nodeConnector.getNode())) {
-                removeSet.add(nodeConnector);
-            }
-        }
-        return removeSet;
-    }
-
-    private void removeDiscovery(Node node) {
-        Set<NodeConnector> removeSet;
-
-        removeSet = getRemoveSet(edgeMap.keySet(), node);
-        NodeConnector peerConnector;
-        Edge edge1, edge2;
-        for (NodeConnector nodeConnector : removeSet) {
-            // get the peer for fast removal of the edge in reverse direction
-            peerConnector = null;
-            edge1 = edgeMap.get(nodeConnector);
-            if (edge1 != null) {
-                edge2 = edgeMap.get(edge1.getTailNodeConnector());
-                if ((edge2 != null) && node.equals(edge2.getTailNodeConnector().getNode())) {
-                    peerConnector = edge2.getHeadNodeConnector();
-                }
-            }
-
-            removeEdge(nodeConnector, false);
-            removeEdge(peerConnector, isEnabled(peerConnector));
-        }
-
-        removeSet = getRemoveSet(prodMap.keySet(), node);
-        for (NodeConnector nodeConnector : removeSet) {
-            removeProdEdge(nodeConnector);
-        }
-
-        removeSet = getRemoveSet(readyListHi, node);
-        readyListHi.removeAll(removeSet);
-
-        removeSet = getRemoveSet(readyListLo, node);
-        readyListLo.removeAll(removeSet);
-
-        removeSet = getRemoveSet(stagingList, node);
-        stagingList.removeAll(removeSet);
-
-        removeSet = getRemoveSet(holdTime.keySet(), node);
-        for (NodeConnector nodeConnector : removeSet) {
-            holdTime.remove(nodeConnector);
-        }
-
-        removeSet = getRemoveSet(elapsedTime.keySet(), node);
-        for (NodeConnector nodeConnector : removeSet) {
-            elapsedTime.remove(nodeConnector);
-        }
-    }
-
-    private void removeDiscovery(NodeConnector nodeConnector) {
-        removeNodeConnector(nodeConnector);
-        removeEdge(nodeConnector, false);
-        removeProdEdge(nodeConnector);
-    }
-
-    private void checkTimeout() {
-        Set<NodeConnector> removeSet = new HashSet<NodeConnector>();
-        int ticks;
-
-        Set<NodeConnector> monitorSet = holdTime.keySet();
-        if (monitorSet != null) {
-            for (NodeConnector nodeConnector : monitorSet) {
-                ticks = holdTime.get(nodeConnector);
-                holdTime.put(nodeConnector, ++ticks);
-                if (ticks >= discoveryTimeoutTicks) {
-                    // timeout the edge
-                    removeSet.add(nodeConnector);
-                    logger.trace("Discovery timeout {}", nodeConnector);
-                }
-            }
-        }
-
-        for (NodeConnector nodeConnector : removeSet) {
-            removeEdge(nodeConnector);
-        }
-
-        Set<NodeConnector> retrySet = new HashSet<NodeConnector>();
-        Set<NodeConnector> ncSet = elapsedTime.keySet();
-        if ((ncSet != null) && (ncSet.size() > 0)) {
-            for (NodeConnector nodeConnector : ncSet) {
-                ticks = elapsedTime.get(nodeConnector);
-                elapsedTime.put(nodeConnector, ++ticks);
-                if (ticks >= discoveryThresholdTicks) {
-                    retrySet.add(nodeConnector);
-                }
-            }
-
-            for (NodeConnector nodeConnector : retrySet) {
-                // Allow one more retry
-                elapsedTime.remove(nodeConnector);
-                if (connectionOutService.isLocal(nodeConnector.getNode())) {
-                    transmitQ.add(nodeConnector);
-                }
-            }
-        }
-    }
-
-    private void checkAging() {
-        if (!discoveryAgingEnabled) {
-            return;
-        }
-
-        Set<NodeConnector> removeSet = new HashSet<NodeConnector>();
-        int ticks;
-
-        Set<NodeConnector> agingSet = agingMap.keySet();
-        if (agingSet != null) {
-            for (NodeConnector nodeConnector : agingSet) {
-                ticks = agingMap.get(nodeConnector);
-                agingMap.put(nodeConnector, ++ticks);
-                if (ticks > discoveryAgeoutTicks) {
-                    // age out the edge
-                    removeSet.add(nodeConnector);
-                    logger.trace("Discovery age out {}", nodeConnector);
-                }
-            }
-        }
-
-        for (NodeConnector nodeConnector : removeSet) {
-            removeProdEdge(nodeConnector);
-        }
-    }
-
-    private void doDiscovery() {
-        if (++discoveryTimerTickCount <= discoveryBatchPauseTicks) {
-            for (NodeConnector nodeConnector : getWorkingSet()) {
-                if (connectionOutService.isLocal(nodeConnector.getNode())) {
-                    transmitQ.add(nodeConnector);
-                    // Move to staging area after it's served
-                    if (!stagingList.contains(nodeConnector)) {
-                        stagingList.add(nodeConnector);
-                    }
-                }
-            }
-        } else if (discoveryTimerTickCount >= discoveryBatchRestartTicks) {
-            discoveryTimerTickCount = 0;
-            for (NodeConnector nodeConnector : stagingList) {
-                if (!readyListLo.contains(nodeConnector)) {
-                    readyListLo.add(nodeConnector);
-                }
-            }
-            stagingList.removeAll(readyListLo);
-        }
-    }
-
-    private void doConsistencyCheck() {
-        if (!discoveryConsistencyCheckEnabled) {
-            return;
-        }
-
-        if (++discoveryConsistencyCheckTickCount % getDiscoveryConsistencyCheckInterval() != 0) {
-            return;
-        }
-
-        discoveryConsistencyCheckCallingTimes++;
-
-        Set<NodeConnector> removeSet = new HashSet<NodeConnector>();
-        Set<NodeConnector> ncSet = edgeMap.keySet();
-        if (ncSet == null) {
-            return;
-        }
-        for (NodeConnector nodeConnector : ncSet) {
-            if (!isEnabled(nodeConnector)) {
-                removeSet.add(nodeConnector);
-                discoveryConsistencyCheckCorrected++;
-                logger.debug("ConsistencyChecker: remove disabled {}", nodeConnector);
-                continue;
-            }
-
-            if (!isTracked(nodeConnector)) {
-                stagingList.add(nodeConnector);
-                discoveryConsistencyCheckCorrected++;
-                logger.debug("ConsistencyChecker: add back untracked {}", nodeConnector);
-                continue;
-            }
-        }
-
-        for (NodeConnector nodeConnector : removeSet) {
-            removeEdge(nodeConnector, false);
-        }
-
-        // remove stale entries
-        removeSet.clear();
-        for (NodeConnector nodeConnector : stagingList) {
-            if (!isEnabled(nodeConnector)) {
-                removeSet.add(nodeConnector);
-                discoveryConsistencyCheckCorrected++;
-                logger.debug("ConsistencyChecker: remove disabled {}", nodeConnector);
-            }
-        }
-        stagingList.removeAll(removeSet);
-
-        // Get a snapshot of all the existing switches
-        Map<Long, ISwitch> switches = this.controller.getSwitches();
-        for (ISwitch sw : switches.values()) {
-            for (OFPhysicalPort port : sw.getEnabledPorts()) {
-                Node node = NodeCreator.createOFNode(sw.getId());
-                NodeConnector nodeConnector = NodeConnectorCreator.createOFNodeConnector(port.getPortNumber(), node);
-                if (!isTracked(nodeConnector)) {
-                    stagingList.add(nodeConnector);
-                    discoveryConsistencyCheckCorrected++;
-                    logger.debug("ConsistencyChecker: add back untracked {}", nodeConnector);
-                }
-            }
-        }
-    }
-
-    private void addEdge(Edge edge, Set<Property> props) {
-        if (edge == null) {
-            return;
-        }
-
-        NodeConnector src = edge.getTailNodeConnector();
-        NodeConnector dst = edge.getHeadNodeConnector();
-        if (!src.getType().equals(NodeConnector.NodeConnectorIDType.PRODUCTION)) {
-            holdTime.put(dst, 0);
-        } else {
-            agingMap.put(dst, 0);
-        }
-        elapsedTime.remove(src);
-
-        // fast discovery of the edge in reverse direction
-        if (!edgeMap.containsKey(dst) && !readyListHi.contains(dst) && !elapsedTime.keySet().contains(dst)) {
-            moveToReadyListHi(dst);
-        }
-
-        //checking only OF map, since production edge discovery always overwrites any existing edge
-        UpdateType ut = edgeMap.containsKey(dst) ? UpdateType.CHANGED : UpdateType.ADDED;
-        // notify
-        updateEdge(edge, ut, props);
-        logger.trace("Add edge {}", edge);
-    }
-
-    /**
-     * Update Production Edge
-     *
-     * @param edge
-     *            The Production Edge
-     * @param props
-     *            Properties associated with the edge
-     */
-    private void updateProdEdge(Edge edge, Set<Property> props) {
-        NodeConnector edgePort = edge.getHeadNodeConnector();
-
-        /* Do not update in case there is an existing OpenFlow link */
-        if (edgeMap.get(edgePort) != null) {
-            logger.trace("Discarded edge {} since there is an existing OF link {}", edge, edgeMap.get(edgePort));
-            return;
-        }
-
-        /* Look for any existing Production Edge */
-        Edge oldEdge = prodMap.get(edgePort);
-        if (oldEdge == null) {
-            /* Let's add a new one */
-            addEdge(edge, props);
-        } else if (!edge.equals(oldEdge)) {
-            /* Remove the old one first */
-            removeProdEdge(oldEdge.getHeadNodeConnector());
-            /* Then add the new one */
-            addEdge(edge, props);
-        } else {
-            /* o/w, just reset the aging timer */
-            NodeConnector dst = edge.getHeadNodeConnector();
-            agingMap.put(dst, 0);
-        }
-    }
-
-    /**
-     * Remove Production Edge for a given edge port
-     *
-     * @param edgePort
-     *            The OF edge port
-     */
-    private void removeProdEdge(NodeConnector edgePort) {
-        agingMap.remove(edgePort);
-
-        Edge edge = null;
-        Set<NodeConnector> prodKeySet = prodMap.keySet();
-        if ((prodKeySet != null) && (prodKeySet.contains(edgePort))) {
-            edge = prodMap.get(edgePort);
-            prodMap.remove(edgePort);
-        }
-
-        // notify Topology
-        if (this.discoveryListener != null) {
-            this.discoveryListener.notifyEdge(edge, UpdateType.REMOVED, null);
-        }
-        logger.trace("Remove edge {}", edge);
-    }
-
-    /*
-     * Remove OpenFlow edge
-     */
-    private void removeEdge(NodeConnector nodeConnector, boolean stillEnabled) {
-        if (nodeConnector == null) {
-            return;
-        }
-
-        removeNodeConnector(nodeConnector);
-
-        if (stillEnabled) {
-            // keep discovering
-            stagingList.add(nodeConnector);
-        }
-
-        Edge edge = null;
-        Set<NodeConnector> edgeKeySet = edgeMap.keySet();
-        if ((edgeKeySet != null) && (edgeKeySet.contains(nodeConnector))) {
-            edge = edgeMap.get(nodeConnector);
-            edgeMap.remove(nodeConnector);
-        }
-
-        // notify Topology
-        if (this.discoveryListener != null) {
-            this.discoveryListener.notifyEdge(edge, UpdateType.REMOVED, null);
-        }
-        logger.trace("Remove {}", nodeConnector);
-    }
-
-    private void removeEdge(NodeConnector nodeConnector) {
-        removeEdge(nodeConnector, isEnabled(nodeConnector));
-    }
-
-    private void updateEdge(Edge edge, UpdateType type, Set<Property> props) {
-        if (discoveryListener == null) {
-            return;
-        }
-
-
-        this.discoveryListener.notifyEdge(edge, type, props);
-
-        NodeConnector src = edge.getTailNodeConnector(), dst = edge.getHeadNodeConnector();
-        if (!src.getType().equals(NodeConnector.NodeConnectorIDType.PRODUCTION)) {
-            if (type == UpdateType.ADDED) {
-                edgeMap.put(dst, edge);
-            } else if (type == UpdateType.REMOVED) {
-                edgeMap.remove(dst);
-            }
-        } else {
-            /*
-             * Save Production edge into different DB keyed by the Edge port
-             */
-            if (type == UpdateType.ADDED) {
-                prodMap.put(dst, edge);
-            } else if (type == UpdateType.REMOVED) {
-                prodMap.remove(dst);
-            }
-        }
-    }
-
-    private void moveToReadyListHi(NodeConnector nodeConnector) {
-        if (readyListLo.contains(nodeConnector)) {
-            readyListLo.remove(nodeConnector);
-        } else if (stagingList.contains(nodeConnector)) {
-            stagingList.remove(nodeConnector);
-        }
-        readyListHi.add(nodeConnector);
-    }
-
-    private void registerWithOSGIConsole() {
-        BundleContext bundleContext = FrameworkUtil.getBundle(this.getClass()).getBundleContext();
-        bundleContext.registerService(CommandProvider.class.getName(), this, null);
-    }
-
-    private int getDiscoveryConsistencyCheckInterval() {
-        return discoveryConsistencyCheckMultiple * discoveryBatchRestartTicks;
-    }
-
-    @Override
-    public String getHelp() {
-        StringBuffer help = new StringBuffer();
-        help.append("---Topology Discovery---\n");
-        help.append("\t prlh                            - Print readyListHi entries\n");
-        help.append("\t prll                            - Print readyListLo entries\n");
-        help.append("\t psl                             - Print stagingList entries\n");
-        help.append("\t pht                             - Print hold time\n");
-        help.append("\t pet                             - Print elapsed time\n");
-        help.append("\t ptick                           - Print tick time in msec\n");
-        help.append("\t pcc                             - Print CC info\n");
-        help.append("\t psize                           - Print sizes of all the lists\n");
-        help.append("\t ptm                             - Print timeout info\n");
-        help.append("\t ecc                             - Enable CC\n");
-        help.append("\t dcc                             - Disable CC\n");
-        help.append("\t scc [multiple]                  - Set/show CC multiple and interval\n");
-        help.append("\t sports [ports]                  - Set/show max ports per batch\n");
-        help.append("\t spause [ticks]                  - Set/show pause period\n");
-        help.append("\t sdi [ticks]                     - Set/show discovery interval in ticks\n");
-        help.append("\t addsw <swid>                    - Add a switch\n");
-        help.append("\t remsw <swid>                    - Remove a switch\n");
-        help.append("\t page                            - Print aging info\n");
-        help.append("\t sage                            - Set/Show aging time limit\n");
-        help.append("\t eage                            - Enable aging\n");
-        help.append("\t dage                            - Disable aging\n");
-        help.append("\t pthrot                          - Print throttling\n");
-        help.append("\t ethrot                          - Enable throttling\n");
-        help.append("\t dthrot                          - Disable throttling\n");
-        help.append("\t psnp                            - Print LLDP snooping\n");
-        help.append("\t esnp <all|nodeConnector>        - Enable LLDP snooping\n");
-        help.append("\t dsnp <all|nodeConnector>        - Disable LLDP snooping\n");
-        return help.toString();
-    }
-
-    private List<NodeConnector> sortList(Collection<NodeConnector> ncs) {
-        List<String> ncStrArray = new ArrayList<String>();
-        for (NodeConnector nc : ncs) {
-            ncStrArray.add(nc.toString());
-        }
-        Collections.sort(ncStrArray);
-
-        List<NodeConnector> sortedNodeConnectors = new ArrayList<NodeConnector>();
-        for (String ncStr : ncStrArray) {
-            sortedNodeConnectors.add(NodeConnector.fromString(ncStr));
-        }
-
-        return sortedNodeConnectors;
-    }
-
-    public void _prlh(CommandInterpreter ci) {
-        ci.println("readyListHi\n");
-        for (NodeConnector nodeConnector : sortList(readyListHi)) {
-            if (nodeConnector == null) {
-                continue;
-            }
-            ci.println(nodeConnector);
-        }
-        ci.println("Total number of Node Connectors: " + readyListHi.size());
-    }
-
-    public void _prll(CommandInterpreter ci) {
-        ci.println("readyListLo\n");
-        for (NodeConnector nodeConnector : sortList(readyListLo)) {
-            if (nodeConnector == null) {
-                continue;
-            }
-            ci.println(nodeConnector);
-        }
-        ci.println("Total number of Node Connectors: " + readyListLo.size());
-    }
-
-    public void _psl(CommandInterpreter ci) {
-        ci.println("stagingList\n");
-        for (NodeConnector nodeConnector : sortList(stagingList)) {
-            if (nodeConnector == null) {
-                continue;
-            }
-            ci.println(nodeConnector);
-        }
-        ci.println("Total number of Node Connectors: " + stagingList.size());
-    }
-
-    public void _pht(CommandInterpreter ci) {
-        ci.println("          NodeConnector            Last rx LLDP (sec)");
-        for (ConcurrentMap.Entry<NodeConnector, Integer> entry: holdTime.entrySet()) {
-            ci.println(entry.getKey() + "\t\t" + entry.getValue() * (discoveryTimerTick / 1000));
-        }
-        ci.println("\nSize: " + holdTime.size() + "\tTimeout: " + discoveryTimeoutTicks * (discoveryTimerTick / 1000)
-                + " sec");
-    }
-
-    public void _pet(CommandInterpreter ci) {
-        ci.println("          NodeConnector            Elapsed Time (sec)");
-        for (ConcurrentMap.Entry<NodeConnector, Integer> entry: elapsedTime.entrySet()) {
-            ci.println(entry.getKey() + "\t\t" + entry.getValue() * (discoveryTimerTick / 1000));
-        }
-        ci.println("\nSize: " + elapsedTime.size() + "\tThreshold: " + DiscoveryPeriod.THRESHOLD.getTime() + " sec");
-    }
-
-    public void _ptick(CommandInterpreter ci) {
-        ci.println("Current timer is " + discoveryTimerTick + " msec per tick");
-    }
-
-    public void _pcc(CommandInterpreter ci) {
-        if (discoveryConsistencyCheckEnabled) {
-            ci.println("ConsistencyChecker is currently enabled");
-        } else {
-            ci.println("ConsistencyChecker is currently disabled");
-        }
-        ci.println("Interval " + getDiscoveryConsistencyCheckInterval());
-        ci.println("Multiple " + discoveryConsistencyCheckMultiple);
-        ci.println("Number of times called " + discoveryConsistencyCheckCallingTimes);
-        ci.println("Corrected count " + discoveryConsistencyCheckCorrected);
-    }
-
-    public void _ptm(CommandInterpreter ci) {
-        ci.println("Timeout " + discoveryTimeoutTicks + " ticks, " + discoveryTimerTick / 1000 + " sec per tick.");
-    }
-
-    public void _psize(CommandInterpreter ci) {
-        ci.println("readyListLo size " + readyListLo.size() + "\n" + "readyListHi size " + readyListHi.size() + "\n"
-                + "stagingList size " + stagingList.size() + "\n" + "holdTime size " + holdTime.size() + "\n"
-                + "edgeMap size " + edgeMap.size() + "\n" + "prodMap size " + prodMap.size() + "\n" + "agingMap size "
-                + agingMap.size() + "\n" + "elapsedTime size " + elapsedTime.size());
-    }
-
-    public void _page(CommandInterpreter ci) {
-        if (this.discoveryAgingEnabled) {
-            ci.println("Aging is enabled");
-        } else {
-            ci.println("Aging is disabled");
-        }
-        ci.println("Current aging time limit " + this.discoveryAgeoutTicks);
-        ci.println("\n");
-        ci.println("                           Edge                                 Aging ");
-        Collection<Edge> prodSet = prodMap.values();
-        if (prodSet == null) {
-            return;
-        }
-        for (Edge edge : prodSet) {
-            Integer aging = agingMap.get(edge.getHeadNodeConnector());
-            if (aging != null) {
-                ci.println(edge + "      " + aging);
-            }
-        }
-        ci.println("\n");
-        ci.println("              NodeConnector                                                 Edge ");
-        Set<NodeConnector> keySet = prodMap.keySet();
-        if (keySet == null) {
-            return;
-        }
-        for (NodeConnector nc : keySet) {
-            ci.println(nc + "      " + prodMap.get(nc));
-        }
-        return;
-    }
-
-    public void _sage(CommandInterpreter ci) {
-        String val = ci.nextArgument();
-        if (val == null) {
-            ci.println("Please enter aging time limit. Current value " + this.discoveryAgeoutTicks);
-            return;
-        }
-        try {
-            this.discoveryAgeoutTicks = Integer.parseInt(val);
-        } catch (Exception e) {
-            ci.println("Please enter a valid number");
-        }
-        return;
-    }
-
-    public void _eage(CommandInterpreter ci) {
-        this.discoveryAgingEnabled = true;
-        ci.println("Aging is enabled");
-        return;
-    }
-
-    public void _dage(CommandInterpreter ci) {
-        this.discoveryAgingEnabled = false;
-        ci.println("Aging is disabled");
-        return;
-    }
-
-    public void _scc(CommandInterpreter ci) {
-        String val = ci.nextArgument();
-        if (val == null) {
-            ci.println("Please enter CC multiple. Current multiple " + discoveryConsistencyCheckMultiple
-                    + " (interval " + getDiscoveryConsistencyCheckInterval() + ") calling times "
-                    + discoveryConsistencyCheckCallingTimes);
-            return;
-        }
-        try {
-            discoveryConsistencyCheckMultiple = Integer.parseInt(val);
-        } catch (Exception e) {
-            ci.println("Please enter a valid number");
-        }
-        return;
-    }
-
-    public void _ecc(CommandInterpreter ci) {
-        this.discoveryConsistencyCheckEnabled = true;
-        ci.println("ConsistencyChecker is enabled");
-        return;
-    }
-
-    public void _dcc(CommandInterpreter ci) {
-        this.discoveryConsistencyCheckEnabled = false;
-        ci.println("ConsistencyChecker is disabled");
-        return;
-    }
-
-    public void _psnp(CommandInterpreter ci) {
-        if (this.discoverySnoopingEnabled) {
-            ci.println("Discovery snooping is globally enabled");
-        } else {
-            ci.println("Discovery snooping is globally disabled");
-        }
-
-        ci.println("\nDiscovery snooping is locally disabled on these ports");
-        for (NodeConnector nodeConnector : discoverySnoopingDisableList) {
-            ci.println(nodeConnector);
-        }
-        return;
-    }
-
-    public void _esnp(CommandInterpreter ci) {
-        String val = ci.nextArgument();
-
-        if (val == null) {
-            ci.println("Usage: esnp <all|nodeConnector>");
-        } else if (val.equalsIgnoreCase("all")) {
-            this.discoverySnoopingEnabled = true;
-            ci.println("Discovery snooping is globally enabled");
-        } else {
-            NodeConnector nodeConnector = NodeConnector.fromString(val);
-            if (nodeConnector != null) {
-                discoverySnoopingDisableList.remove(nodeConnector);
-                ci.println("Discovery snooping is locally enabled on port " + nodeConnector);
-            } else {
-                ci.println("Entered invalid NodeConnector " + val);
-            }
-        }
-        return;
-    }
-
-    public void _dsnp(CommandInterpreter ci) {
-        String val = ci.nextArgument();
-
-        if (val == null) {
-            ci.println("Usage: dsnp <all|nodeConnector>");
-        } else if (val.equalsIgnoreCase("all")) {
-            this.discoverySnoopingEnabled = false;
-            ci.println("Discovery snooping is globally disabled");
-        } else {
-            NodeConnector nodeConnector = NodeConnector.fromString(val);
-            if (nodeConnector != null) {
-                discoverySnoopingDisableList.add(nodeConnector);
-                ci.println("Discovery snooping is locally disabled on port " + nodeConnector);
-            } else {
-                ci.println("Entered invalid NodeConnector " + val);
-            }
-        }
-        return;
-    }
-
-    public void _spause(CommandInterpreter ci) {
-        String val = ci.nextArgument();
-        String out = "Please enter pause period less than " + discoveryBatchRestartTicks + ". Current pause period is "
-                + discoveryBatchPausePeriod + " ticks, pause at " + discoveryBatchPauseTicks + " ticks, "
-                + discoveryTimerTick / 1000 + " sec per tick.";
-
-        if (val != null) {
-            try {
-                int pause = Integer.parseInt(val);
-                if (pause < discoveryBatchRestartTicks) {
-                    discoveryBatchPausePeriod = pause;
-                    discoveryBatchPauseTicks = getDiscoveryPauseInterval();
-                    return;
-                }
-            } catch (Exception e) {
-            }
-        }
-
-        ci.println(out);
-    }
-
-    public void _sdi(CommandInterpreter ci) {
-        String val = ci.nextArgument();
-        String out = "Please enter discovery interval in ticks. Current value is " + discoveryBatchRestartTicks + " ticks, "
-                + discoveryTimerTick / 1000 + " sec per tick.";
-
-        if (val != null) {
-            try {
-                int ticks;
-                Set<NodeConnector> monitorSet = holdTime.keySet();
-                if (monitorSet != null) {
-                    for (NodeConnector nodeConnector : monitorSet) {
-                        holdTime.put(nodeConnector, 0);
-                    }
-                }
-
-                ticks = Integer.parseInt(val);
-                DiscoveryPeriod.INTERVAL.setTick(ticks);
-                discoveryBatchRestartTicks = getDiscoveryInterval();
-                discoveryBatchPauseTicks = getDiscoveryPauseInterval();
-                discoveryTimeoutTicks = getDiscoveryTimeout();
-                return;
-            } catch (Exception e) {
-            }
-        }
-        ci.println(out);
-    }
-
-    public void _sports(CommandInterpreter ci) {
-        String val = ci.nextArgument();
-        if (val == null) {
-            ci.println("Please enter max ports per batch. Current value is " + discoveryBatchMaxPorts);
-            return;
-        }
-        try {
-            discoveryBatchMaxPorts = Integer.parseInt(val);
-        } catch (Exception e) {
-            ci.println("Please enter a valid number");
-        }
-        return;
-    }
-
-    public void _addsw(CommandInterpreter ci) {
-        String val = ci.nextArgument();
-        Long sid;
-        try {
-            sid = Long.parseLong(val);
-            Node node = NodeCreator.createOFNode(sid);
-            addDiscovery(node);
-        } catch (Exception e) {
-            ci.println("Please enter a valid number");
-        }
-        return;
-    }
-
-    public void _remsw(CommandInterpreter ci) {
-        String val = ci.nextArgument();
-        Long sid;
-        try {
-            sid = Long.parseLong(val);
-            Node node = NodeCreator.createOFNode(sid);
-            removeDiscovery(node);
-        } catch (Exception e) {
-            ci.println("Please enter a valid number");
-        }
-        return;
-    }
-
-    public void _pthrot(CommandInterpreter ci) {
-        if (this.throttling) {
-            ci.println("Throttling is enabled");
-        } else {
-            ci.println("Throttling is disabled");
-        }
-    }
-
-    public void _ethrot(CommandInterpreter ci) {
-        this.throttling = true;
-        ci.println("Throttling is enabled");
-        return;
-    }
-
-    public void _dthrot(CommandInterpreter ci) {
-        this.throttling = false;
-        ci.println("Throttling is disabled");
-        return;
-    }
-
-    @Override
-    public void updateNode(Node node, UpdateType type, Set<Property> props) {
-        switch (type) {
-        case ADDED:
-            addNode(node, props);
-            break;
-        case REMOVED:
-            removeNode(node);
-            break;
-        default:
-            break;
-        }
-    }
-
-    @Override
-    public void updateNodeConnector(NodeConnector nodeConnector, UpdateType type, Set<Property> props) {
-        Config config = null;
-        State state = null;
-        boolean enabled = false;
-
-        for (Property prop : props) {
-            if (prop.getName().equals(Config.ConfigPropName)) {
-                config = (Config) prop;
-            } else if (prop.getName().equals(State.StatePropName)) {
-                state = (State) prop;
-            }
-        }
-        enabled = ((config != null) && (config.getValue() == Config.ADMIN_UP) && (state != null) && (state.getValue() == State.EDGE_UP));
-
-        switch (type) {
-        case ADDED:
-            if (enabled) {
-                addDiscovery(nodeConnector);
-                logger.trace("ADDED enabled {}", nodeConnector);
-            } else {
-                logger.trace("ADDED disabled {}", nodeConnector);
-            }
-            break;
-        case CHANGED:
-            if (enabled) {
-                addDiscovery(nodeConnector);
-                logger.trace("CHANGED enabled {}", nodeConnector);
-            } else {
-                removeDiscovery(nodeConnector);
-                logger.trace("CHANGED disabled {}", nodeConnector);
-            }
-            break;
-        case REMOVED:
-            removeDiscovery(nodeConnector);
-            logger.trace("REMOVED enabled {}", nodeConnector);
-            break;
-        default:
-            return;
-        }
-    }
-
-    public void addNode(Node node, Set<Property> props) {
-        if (node == null) {
-            return;
-        }
-
-        addDiscovery(node);
-    }
-
-    public void removeNode(Node node) {
-        if (node == null) {
-            return;
-        }
-
-        removeDiscovery(node);
-    }
-
-    void setController(IController s) {
-        this.controller = s;
-    }
-
-    void unsetController(IController s) {
-        if (this.controller == s) {
-            this.controller = null;
-        }
-    }
-
-    public void setInventoryProvider(IInventoryProvider service) {
-        this.inventoryProvider = service;
-    }
-
-    public void unsetInventoryProvider(IInventoryProvider service) {
-        this.inventoryProvider = null;
-    }
-
-    public void setIDataPacketMux(IDataPacketMux service) {
-        this.iDataPacketMux = service;
-    }
-
-    public void unsetIDataPacketMux(IDataPacketMux service) {
-        if (this.iDataPacketMux == service) {
-            this.iDataPacketMux = null;
-        }
-    }
-
-    void setDiscoveryListener(IDiscoveryListener s) {
-        this.discoveryListener = s;
-    }
-
-    void unsetDiscoveryListener(IDiscoveryListener s) {
-        if (this.discoveryListener == s) {
-            this.discoveryListener = null;
-        }
-    }
-
-    void setIPluginOutConnectionService(IPluginOutConnectionService s) {
-        connectionOutService = s;
-    }
-
-    void unsetIPluginOutConnectionService(IPluginOutConnectionService s) {
-        if (connectionOutService == s) {
-            connectionOutService = null;
-        }
-    }
-
-    private void initDiscoveryPacket() {
-        // Create LLDP ChassisID TLV
-        chassisIdTlv = new LLDPTLV();
-        chassisIdTlv.setType(LLDPTLV.TLVType.ChassisID.getValue());
-
-        // Create LLDP SystemName TLV
-        systemNameTlv = new LLDPTLV();
-        systemNameTlv.setType(LLDPTLV.TLVType.SystemName.getValue());
-
-        // Create LLDP PortID TLV
-        portIdTlv = new LLDPTLV();
-        portIdTlv.setType(LLDPTLV.TLVType.PortID.getValue());
-
-        // Create LLDP TTL TLV
-        byte[] ttl = new byte[] { (byte) 0, (byte) 120 };
-        ttlTlv = new LLDPTLV();
-        ttlTlv.setType(LLDPTLV.TLVType.TTL.getValue()).setLength((short) ttl.length).setValue(ttl);
-
-        customTlv = new LLDPTLV();
-    }
-
-    /**
-     * Function called by the dependency manager when all the required
-     * dependencies are satisfied
-     *
-     */
-    void init() {
-        logger.trace("Init called");
-
-        transmitQ = new LinkedBlockingQueue<NodeConnector>();
-
-        readyListHi = new CopyOnWriteArrayList<NodeConnector>();
-        readyListLo = new CopyOnWriteArrayList<NodeConnector>();
-        stagingList = new CopyOnWriteArrayList<NodeConnector>();
-        holdTime = new ConcurrentHashMap<NodeConnector, Integer>();
-        elapsedTime = new ConcurrentHashMap<NodeConnector, Integer>();
-        edgeMap = new ConcurrentHashMap<NodeConnector, Edge>();
-        agingMap = new ConcurrentHashMap<NodeConnector, Integer>();
-        prodMap = new ConcurrentHashMap<NodeConnector, Edge>();
-        discoverySnoopingDisableList = new CopyOnWriteArrayList<NodeConnector>();
-
-        discoveryBatchRestartTicks = getDiscoveryInterval();
-        discoveryBatchPauseTicks = getDiscoveryPauseInterval();
-        discoveryTimeoutTicks = getDiscoveryTimeout();
-        discoveryThresholdTicks = getDiscoveryThreshold();
-        discoveryAgeoutTicks = getDiscoveryAgeout();
-        discoveryConsistencyCheckTickCount = discoveryBatchPauseTicks;
-        discoveryBatchMaxPorts = getDiscoveryBatchMaxPorts();
-
-        discoveryTimer = new Timer("DiscoveryService");
-        discoveryTimerTask = new DiscoveryTimerTask();
-
-        transmitThread = new Thread(new DiscoveryTransmit(transmitQ));
-
-        initDiscoveryPacket();
-
-        registerWithOSGIConsole();
-    }
-
-    /**
-     * Function called by the dependency manager when at least one dependency
-     * become unsatisfied or when the component is shutting down because for
-     * example bundle is being stopped.
-     *
-     */
-    void destroy() {
-        transmitQ = null;
-        readyListHi = null;
-        readyListLo = null;
-        stagingList = null;
-        holdTime = null;
-        edgeMap = null;
-        agingMap = null;
-        prodMap = null;
-        discoveryTimer = null;
-        discoveryTimerTask = null;
-        transmitThread = null;
-    }
-
-    /**
-     * Function called by dependency manager after "init ()" is called and after
-     * the services provided by the class are registered in the service registry
-     *
-     */
-    void start() {
-        discoveryTimer.schedule(discoveryTimerTask, discoveryTimerTick, discoveryTimerTick);
-        transmitThread.start();
-    }
-
-    /**
-     * Function called after registering the service in OSGi service registry.
-     */
-    void started() {
-        /* get a snapshot of all the existing switches */
-        addDiscovery();
-    }
-
-    /**
-     * Function called by the dependency manager before the services exported by
-     * the component are unregistered, this will be followed by a "destroy ()"
-     * calls
-     *
-     */
-    void stop() {
-        shuttingDown = true;
-        discoveryTimer.cancel();
-        transmitThread.interrupt();
-    }
-
-    @Override
-    public void tagUpdated(String containerName, Node n, short oldTag, short newTag, UpdateType t) {
-    }
-
-    @Override
-    public void containerFlowUpdated(String containerName, ContainerFlow previousFlow, ContainerFlow currentFlow,
-            UpdateType t) {
-    }
-
-    @Override
-    public void nodeConnectorUpdated(String containerName, NodeConnector p, UpdateType t) {
-        switch (t) {
-        case ADDED:
-            moveToReadyListHi(p);
-            break;
-        default:
-            break;
-        }
-    }
-
-    @Override
-    public void containerModeUpdated(UpdateType t) {
-        // do nothing
-    }
-
-    private byte[] getSourceMACFromNodeID(String nodeId) {
-        byte[] cid = HexEncode.bytesFromHexString(nodeId);
-        byte[] sourceMac = new byte[6];
-        int pos = cid.length - sourceMac.length;
-
-        if (pos >= 0) {
-            System.arraycopy(cid, pos, sourceMac, 0, sourceMac.length);
-        }
-
-        return sourceMac;
-    }
-
-    private int getDiscoveryTicks(DiscoveryPeriod dp, String val) {
-        if (dp == null) {
-            return 0;
-        }
-
-        if (val != null) {
-            try {
-                dp.setTime(Integer.parseInt(val));
-            } catch (Exception e) {
-            }
-        }
-
-        return dp.getTick();
-    }
-
-    /**
-     * This method returns the interval which determines how often the discovery
-     * packets will be sent.
-     *
-     * @return The discovery interval in ticks
-     */
-    private int getDiscoveryInterval() {
-        String intvl = System.getProperty("of.discoveryInterval");
-        return getDiscoveryTicks(DiscoveryPeriod.INTERVAL, intvl);
-    }
-
-    /**
-     * This method returns the timeout value in receiving subsequent discovery packets on a port.
-     *
-     * @return The discovery timeout in ticks
-     */
-    private int getDiscoveryTimeout() {
-        String val = System.getProperty("of.discoveryTimeoutMultiple");
-        int multiple = 2;
-
-        if (val != null) {
-            try {
-                multiple = Integer.parseInt(val);
-            } catch (Exception e) {
-            }
-        }
-        return getDiscoveryInterval() * multiple + 3;
-    }
-
-    /**
-     * This method returns the user configurable threshold value
-     *
-     * @return The discovery threshold value in ticks
-     */
-    private int getDiscoveryThreshold() {
-        String val = System.getProperty("of.discoveryThreshold");
-        return getDiscoveryTicks(DiscoveryPeriod.THRESHOLD, val);
-    }
-
-    /**
-     * This method returns the discovery entry aging time in ticks.
-     *
-     * @return The aging time in ticks
-     */
-    private int getDiscoveryAgeout() {
-        return getDiscoveryTicks(DiscoveryPeriod.AGEOUT, null);
-    }
-
-    /**
-     * This method returns the pause interval
-     *
-     * @return The pause interval in ticks
-     */
-    private int getDiscoveryPauseInterval() {
-        if (discoveryBatchRestartTicks > discoveryBatchPausePeriod) {
-            return discoveryBatchRestartTicks - discoveryBatchPausePeriod;
-        } else {
-            return discoveryBatchRestartTicks - 1;
-        }
-    }
-
-    /**
-     * This method returns the user configurable maximum number of ports handled
-     * in one discovery batch.
-     *
-     * @return The maximum number of ports
-     */
-    private int getDiscoveryBatchMaxPorts() {
-        String val = System.getProperty("of.discoveryBatchMaxPorts");
-        int ports = 512;
-
-        if (val != null) {
-            try {
-                ports = Integer.parseInt(val);
-            } catch (Exception e) {
-            }
-        }
-        return ports;
-    }
-
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/FlowConverter.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/FlowConverter.java
deleted file mode 100644 (file)
index 8893762..0000000
+++ /dev/null
@@ -1,815 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow.internal;
-
-import java.math.BigInteger;
-import java.net.InetAddress;
-import java.net.UnknownHostException;
-import java.util.ArrayList;
-import java.util.HashMap;
-import java.util.List;
-import java.util.Map;
-
-import org.opendaylight.controller.protocol_plugin.openflow.vendorextension.v6extension.V6FlowMod;
-import org.opendaylight.controller.protocol_plugin.openflow.vendorextension.v6extension.V6Match;
-import org.opendaylight.controller.sal.action.Action;
-import org.opendaylight.controller.sal.action.ActionType;
-import org.opendaylight.controller.sal.action.Controller;
-import org.opendaylight.controller.sal.action.Drop;
-import org.opendaylight.controller.sal.action.Enqueue;
-import org.opendaylight.controller.sal.action.Flood;
-import org.opendaylight.controller.sal.action.FloodAll;
-import org.opendaylight.controller.sal.action.HwPath;
-import org.opendaylight.controller.sal.action.Loopback;
-import org.opendaylight.controller.sal.action.Output;
-import org.opendaylight.controller.sal.action.PopVlan;
-import org.opendaylight.controller.sal.action.SetDlDst;
-import org.opendaylight.controller.sal.action.SetDlSrc;
-import org.opendaylight.controller.sal.action.SetNwDst;
-import org.opendaylight.controller.sal.action.SetNwSrc;
-import org.opendaylight.controller.sal.action.SetNwTos;
-import org.opendaylight.controller.sal.action.SetTpDst;
-import org.opendaylight.controller.sal.action.SetTpSrc;
-import org.opendaylight.controller.sal.action.SetVlanId;
-import org.opendaylight.controller.sal.action.SetVlanPcp;
-import org.opendaylight.controller.sal.action.SwPath;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.flowprogrammer.Flow;
-import org.opendaylight.controller.sal.match.Match;
-import org.opendaylight.controller.sal.match.MatchField;
-import org.opendaylight.controller.sal.match.MatchType;
-import org.opendaylight.controller.sal.utils.NetUtils;
-import org.opendaylight.controller.sal.utils.NodeConnectorCreator;
-import org.openflow.protocol.OFFlowMod;
-import org.openflow.protocol.OFMatch;
-import org.openflow.protocol.OFMessage;
-import org.openflow.protocol.OFPacketOut;
-import org.openflow.protocol.OFPort;
-import org.openflow.protocol.OFVendor;
-import org.openflow.protocol.action.OFAction;
-import org.openflow.protocol.action.OFActionDataLayer;
-import org.openflow.protocol.action.OFActionDataLayerDestination;
-import org.openflow.protocol.action.OFActionDataLayerSource;
-import org.openflow.protocol.action.OFActionEnqueue;
-import org.openflow.protocol.action.OFActionNetworkLayerAddress;
-import org.openflow.protocol.action.OFActionNetworkLayerDestination;
-import org.openflow.protocol.action.OFActionNetworkLayerSource;
-import org.openflow.protocol.action.OFActionNetworkTypeOfService;
-import org.openflow.protocol.action.OFActionOutput;
-import org.openflow.protocol.action.OFActionStripVirtualLan;
-import org.openflow.protocol.action.OFActionTransportLayer;
-import org.openflow.protocol.action.OFActionTransportLayerDestination;
-import org.openflow.protocol.action.OFActionTransportLayerSource;
-import org.openflow.protocol.action.OFActionVirtualLanIdentifier;
-import org.openflow.protocol.action.OFActionVirtualLanPriorityCodePoint;
-import org.openflow.util.U16;
-import org.openflow.util.U32;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * Utility class for converting a SAL Flow into the OF flow and vice-versa
- */
-public class FlowConverter {
-    protected static final Logger logger = LoggerFactory
-            .getLogger(FlowConverter.class);
-
-    /*
-     * The value 0xffff (OFP_VLAN_NONE) is used to indicate
-     * that no VLAN ID is set for OF Flow.
-     */
-    private static final short OFP_VLAN_NONE = (short) 0xffff;
-
-    private Flow flow; // SAL Flow
-    private OFMatch ofMatch; // OF 1.0 match or OF 1.0 + IPv6 extension match
-    private List<OFAction> actionsList; // OF 1.0 actions
-    private int actionsLength;
-    private boolean isIPv6;
-
-    public FlowConverter(OFMatch ofMatch, List<OFAction> actionsList) {
-        this.ofMatch = ofMatch;
-        this.actionsList = actionsList;
-        this.actionsLength = 0;
-        this.flow = null;
-        this.isIPv6 = ofMatch instanceof V6Match;
-    }
-
-    public FlowConverter(Flow flow) {
-        this.ofMatch = null;
-        this.actionsList = null;
-        this.actionsLength = 0;
-        this.flow = flow;
-        this.isIPv6 = flow.isIPv6();
-    }
-
-    /**
-     * Returns the match in OF 1.0 (OFMatch) form or OF 1.0 + IPv6 extensions
-     * form (V6Match)
-     *
-     * @return
-     */
-    public OFMatch getOFMatch() {
-        if (ofMatch == null) {
-            Match match = flow.getMatch();
-            ofMatch = (isIPv6) ? new V6Match() : new OFMatch();
-
-            int wildcards = OFMatch.OFPFW_ALL;
-            if (match.isPresent(MatchType.IN_PORT)) {
-                short port = (Short) ((NodeConnector) match.getField(
-                        MatchType.IN_PORT).getValue()).getID();
-                if (!isIPv6) {
-                    ofMatch.setInputPort(port);
-                    wildcards &= ~OFMatch.OFPFW_IN_PORT;
-                } else {
-                    ((V6Match) ofMatch).setInputPort(port, (short) 0);
-                }
-            }
-            if (match.isPresent(MatchType.DL_SRC)) {
-                byte[] srcMac = (byte[]) match.getField(MatchType.DL_SRC)
-                        .getValue();
-                if (!isIPv6) {
-                    ofMatch.setDataLayerSource(srcMac.clone());
-                    wildcards &= ~OFMatch.OFPFW_DL_SRC;
-                } else {
-                    ((V6Match) ofMatch).setDataLayerSource(srcMac, null);
-                }
-            }
-            if (match.isPresent(MatchType.DL_DST)) {
-                byte[] dstMac = (byte[]) match.getField(MatchType.DL_DST)
-                        .getValue();
-                if (!isIPv6) {
-                    ofMatch.setDataLayerDestination(dstMac.clone());
-                    wildcards &= ~OFMatch.OFPFW_DL_DST;
-                } else {
-                    ((V6Match) ofMatch).setDataLayerDestination(dstMac, null);
-                }
-            }
-            if (match.isPresent(MatchType.DL_VLAN)) {
-                short vlan = (Short) match.getField(MatchType.DL_VLAN)
-                        .getValue();
-                if (vlan == MatchType.DL_VLAN_NONE) {
-                    vlan = OFP_VLAN_NONE;
-                }
-                if (!isIPv6) {
-                    ofMatch.setDataLayerVirtualLan(vlan);
-                    wildcards &= ~OFMatch.OFPFW_DL_VLAN;
-                } else {
-                    ((V6Match) ofMatch).setDataLayerVirtualLan(vlan, (short) 0);
-                }
-            }
-            if (match.isPresent(MatchType.DL_VLAN_PR)) {
-                byte vlanPr = (Byte) match.getField(MatchType.DL_VLAN_PR)
-                        .getValue();
-                if (!isIPv6) {
-                    ofMatch.setDataLayerVirtualLanPriorityCodePoint(vlanPr);
-                    wildcards &= ~OFMatch.OFPFW_DL_VLAN_PCP;
-                } else {
-                    ((V6Match) ofMatch)
-                            .setDataLayerVirtualLanPriorityCodePoint(vlanPr,
-                                    (byte) 0);
-                }
-            }
-            if (match.isPresent(MatchType.DL_TYPE)) {
-                short ethType = (Short) match.getField(MatchType.DL_TYPE)
-                        .getValue();
-                if (!isIPv6) {
-                    ofMatch.setDataLayerType(ethType);
-                    wildcards &= ~OFMatch.OFPFW_DL_TYPE;
-                } else {
-                    ((V6Match) ofMatch).setDataLayerType(ethType, (short) 0);
-                }
-            }
-            if (match.isPresent(MatchType.NW_TOS)) {
-                /*
-                 * OF 1.0 switch expects the TOS as the 6 msb in the byte. it is
-                 * actually the DSCP field followed by a zero ECN
-                 */
-                byte tos = (Byte) match.getField(MatchType.NW_TOS).getValue();
-                byte dscp = (byte) (tos << 2);
-                if (!isIPv6) {
-                    ofMatch.setNetworkTypeOfService(dscp);
-                    wildcards &= ~OFMatch.OFPFW_NW_TOS;
-                } else {
-                    ((V6Match) ofMatch).setNetworkTypeOfService(dscp, (byte) 0);
-                }
-            }
-            if (match.isPresent(MatchType.NW_PROTO)) {
-                byte proto = (Byte) match.getField(MatchType.NW_PROTO)
-                        .getValue();
-                if (!isIPv6) {
-                    ofMatch.setNetworkProtocol(proto);
-                    wildcards &= ~OFMatch.OFPFW_NW_PROTO;
-                } else {
-                    ((V6Match) ofMatch).setNetworkProtocol(proto, (byte) 0);
-                }
-            }
-            if (match.isPresent(MatchType.NW_SRC)) {
-                InetAddress address = (InetAddress) match.getField(MatchType.NW_SRC).getValue();
-                InetAddress mask = (InetAddress) match.getField(MatchType.NW_SRC).getMask();
-                if (!isIPv6) {
-                    ofMatch.setNetworkSource(NetUtils.byteArray4ToInt(address.getAddress()));
-                    int maskLength = (mask == null) ? 32 : NetUtils.getSubnetMaskLength(mask);
-                    wildcards = (wildcards & ~OFMatch.OFPFW_NW_SRC_MASK) | ((32 - maskLength) << OFMatch.OFPFW_NW_SRC_SHIFT);
-                } else {
-                    ((V6Match) ofMatch).setNetworkSource(address, mask);
-                }
-            }
-            if (match.isPresent(MatchType.NW_DST)) {
-                InetAddress address = (InetAddress) match.getField(MatchType.NW_DST).getValue();
-                InetAddress mask = (InetAddress) match.getField(MatchType.NW_DST).getMask();
-                if (!isIPv6) {
-                    ofMatch.setNetworkDestination(NetUtils.byteArray4ToInt(address.getAddress()));
-                    int maskLength = (mask == null) ? 32 : NetUtils.getSubnetMaskLength(mask);
-                    wildcards = (wildcards & ~OFMatch.OFPFW_NW_DST_MASK) | ((32 - maskLength) << OFMatch.OFPFW_NW_DST_SHIFT);
-                } else {
-                    ((V6Match) ofMatch).setNetworkDestination(address, mask);
-                }
-            }
-            if (match.isPresent(MatchType.TP_SRC)) {
-                short port = (Short) match.getField(MatchType.TP_SRC)
-                        .getValue();
-                if (!isIPv6) {
-                    ofMatch.setTransportSource(port);
-                    wildcards &= ~OFMatch.OFPFW_TP_SRC;
-                } else {
-                    ((V6Match) ofMatch).setTransportSource(port, (short) 0);
-                }
-            }
-            if (match.isPresent(MatchType.TP_DST)) {
-                short port = (Short) match.getField(MatchType.TP_DST)
-                        .getValue();
-                if (!isIPv6) {
-                    ofMatch.setTransportDestination(port);
-                    wildcards &= ~OFMatch.OFPFW_TP_DST;
-                } else {
-                    ((V6Match) ofMatch)
-                            .setTransportDestination(port, (short) 0);
-                }
-            }
-
-            if (!isIPv6) {
-                ofMatch.setWildcards(U32.t(Long.valueOf(wildcards)));
-            }
-        }
-        logger.trace("SAL Match: {} Openflow Match: {}", flow.getMatch(),
-                ofMatch);
-        return ofMatch;
-    }
-
-    /**
-     * Returns the list of actions in OF 1.0 form
-     *
-     * @return
-     */
-    public List<OFAction> getOFActions() {
-        if (this.actionsList == null) {
-            actionsList = new ArrayList<OFAction>();
-            for (Action action : flow.getActions()) {
-                if (action.getType() == ActionType.OUTPUT) {
-                    Output a = (Output) action;
-                    OFActionOutput ofAction = new OFActionOutput();
-                    ofAction.setMaxLength((short) 0xffff);
-                    ofAction.setPort(PortConverter.toOFPort(a.getPort()));
-                    actionsList.add(ofAction);
-                    actionsLength += OFActionOutput.MINIMUM_LENGTH;
-                    continue;
-                }
-                if (action.getType() == ActionType.ENQUEUE) {
-                    Enqueue a = (Enqueue) action;
-                    OFActionEnqueue ofAction = new OFActionEnqueue();
-                    ofAction.setPort(PortConverter.toOFPort(a.getPort()));
-                    ofAction.setQueueId(a.getQueue());
-                    actionsList.add(ofAction);
-                    actionsLength += OFActionEnqueue.MINIMUM_LENGTH;
-                    continue;
-                }
-                if (action.getType() == ActionType.DROP) {
-                    continue;
-                }
-                if (action.getType() == ActionType.LOOPBACK) {
-                    OFActionOutput ofAction = new OFActionOutput();
-                    ofAction.setPort(OFPort.OFPP_IN_PORT.getValue());
-                    actionsList.add(ofAction);
-                    actionsLength += OFActionOutput.MINIMUM_LENGTH;
-                    continue;
-                }
-                if (action.getType() == ActionType.FLOOD) {
-                    OFActionOutput ofAction = new OFActionOutput();
-                    ofAction.setPort(OFPort.OFPP_FLOOD.getValue());
-                    actionsList.add(ofAction);
-                    actionsLength += OFActionOutput.MINIMUM_LENGTH;
-                    continue;
-                }
-                if (action.getType() == ActionType.FLOOD_ALL) {
-                    OFActionOutput ofAction = new OFActionOutput();
-                    ofAction.setPort(OFPort.OFPP_ALL.getValue());
-                    actionsList.add(ofAction);
-                    actionsLength += OFActionOutput.MINIMUM_LENGTH;
-                    continue;
-                }
-                if (action.getType() == ActionType.CONTROLLER) {
-                    OFActionOutput ofAction = new OFActionOutput();
-                    ofAction.setPort(OFPort.OFPP_CONTROLLER.getValue());
-                    // We want the whole frame hitting the match be sent to the
-                    // controller
-                    ofAction.setMaxLength((short) 0xffff);
-                    actionsList.add(ofAction);
-                    actionsLength += OFActionOutput.MINIMUM_LENGTH;
-                    continue;
-                }
-                if (action.getType() == ActionType.SW_PATH) {
-                    OFActionOutput ofAction = new OFActionOutput();
-                    ofAction.setPort(OFPort.OFPP_LOCAL.getValue());
-                    actionsList.add(ofAction);
-                    actionsLength += OFActionOutput.MINIMUM_LENGTH;
-                    continue;
-                }
-                if (action.getType() == ActionType.HW_PATH) {
-                    OFActionOutput ofAction = new OFActionOutput();
-                    ofAction.setPort(OFPort.OFPP_NORMAL.getValue());
-                    actionsList.add(ofAction);
-                    actionsLength += OFActionOutput.MINIMUM_LENGTH;
-                    continue;
-                }
-                if (action.getType() == ActionType.SET_VLAN_ID) {
-                    SetVlanId a = (SetVlanId) action;
-                    OFActionVirtualLanIdentifier ofAction = new OFActionVirtualLanIdentifier();
-                    ofAction.setVirtualLanIdentifier((short) a.getVlanId());
-                    actionsList.add(ofAction);
-                    actionsLength += OFActionVirtualLanIdentifier.MINIMUM_LENGTH;
-                    continue;
-                }
-                if (action.getType() == ActionType.SET_VLAN_PCP) {
-                    SetVlanPcp a = (SetVlanPcp) action;
-                    OFActionVirtualLanPriorityCodePoint ofAction = new OFActionVirtualLanPriorityCodePoint();
-                    ofAction.setVirtualLanPriorityCodePoint(Integer.valueOf(
-                            a.getPcp()).byteValue());
-                    actionsList.add(ofAction);
-                    actionsLength += OFActionVirtualLanPriorityCodePoint.MINIMUM_LENGTH;
-                    continue;
-                }
-                if (action.getType() == ActionType.POP_VLAN) {
-                    OFActionStripVirtualLan ofAction = new OFActionStripVirtualLan();
-                    actionsList.add(ofAction);
-                    actionsLength += OFActionStripVirtualLan.MINIMUM_LENGTH;
-                    continue;
-                }
-                if (action.getType() == ActionType.SET_DL_SRC) {
-                    SetDlSrc a = (SetDlSrc) action;
-                    OFActionDataLayerSource ofAction = new OFActionDataLayerSource();
-                    ofAction.setDataLayerAddress(a.getDlAddress());
-                    actionsList.add(ofAction);
-                    actionsLength += OFActionDataLayer.MINIMUM_LENGTH;
-                    continue;
-                }
-                if (action.getType() == ActionType.SET_DL_DST) {
-                    SetDlDst a = (SetDlDst) action;
-                    OFActionDataLayerDestination ofAction = new OFActionDataLayerDestination();
-                    ofAction.setDataLayerAddress(a.getDlAddress());
-                    actionsList.add(ofAction);
-                    actionsLength += OFActionDataLayer.MINIMUM_LENGTH;
-                    continue;
-                }
-                if (action.getType() == ActionType.SET_NW_SRC) {
-                    SetNwSrc a = (SetNwSrc) action;
-                    OFActionNetworkLayerSource ofAction = new OFActionNetworkLayerSource();
-                    ofAction.setNetworkAddress(NetUtils.byteArray4ToInt(a
-                            .getAddress().getAddress()));
-                    actionsList.add(ofAction);
-                    actionsLength += OFActionNetworkLayerAddress.MINIMUM_LENGTH;
-                    continue;
-                }
-                if (action.getType() == ActionType.SET_NW_DST) {
-                    SetNwDst a = (SetNwDst) action;
-                    OFActionNetworkLayerDestination ofAction = new OFActionNetworkLayerDestination();
-                    ofAction.setNetworkAddress(NetUtils.byteArray4ToInt(a
-                            .getAddress().getAddress()));
-                    actionsList.add(ofAction);
-                    actionsLength += OFActionNetworkLayerAddress.MINIMUM_LENGTH;
-                    continue;
-                }
-                if (action.getType() == ActionType.SET_NW_TOS) {
-                    SetNwTos a = (SetNwTos) action;
-                    OFActionNetworkTypeOfService ofAction = new OFActionNetworkTypeOfService();
-                    ofAction.setNetworkTypeOfService(Integer.valueOf(
-                            a.getNwTos()).byteValue());
-                    actionsList.add(ofAction);
-                    actionsLength += OFActionNetworkTypeOfService.MINIMUM_LENGTH;
-                    continue;
-                }
-                if (action.getType() == ActionType.SET_TP_SRC) {
-                    SetTpSrc a = (SetTpSrc) action;
-                    OFActionTransportLayerSource ofAction = new OFActionTransportLayerSource();
-                    ofAction.setTransportPort(Integer.valueOf(a.getPort())
-                            .shortValue());
-                    actionsList.add(ofAction);
-                    actionsLength += OFActionTransportLayer.MINIMUM_LENGTH;
-                    continue;
-                }
-                if (action.getType() == ActionType.SET_TP_DST) {
-                    SetTpDst a = (SetTpDst) action;
-                    OFActionTransportLayerDestination ofAction = new OFActionTransportLayerDestination();
-                    ofAction.setTransportPort(Integer.valueOf(a.getPort())
-                            .shortValue());
-                    actionsList.add(ofAction);
-                    actionsLength += OFActionTransportLayer.MINIMUM_LENGTH;
-                    continue;
-                }
-                if (action.getType() == ActionType.SET_NEXT_HOP) {
-                    logger.warn("Unsupported action: {}", action);
-                    continue;
-                }
-            }
-        }
-        logger.trace("SAL Actions: {} Openflow Actions: {}", flow.getActions(),
-                actionsList);
-        return actionsList;
-    }
-
-    /**
-     * Utility to convert a SAL flow to an OF 1.0 (OFFlowMod) or to an OF 1.0 +
-     * IPv6 extension (V6FlowMod) Flow modifier Message
-     *
-     * @param sw
-     * @param command
-     * @param port
-     * @return
-     */
-    public OFMessage getOFFlowMod(short command, OFPort port) {
-        OFMessage fm = (isIPv6) ? new V6FlowMod() : new OFFlowMod();
-        if (this.ofMatch == null) {
-            getOFMatch();
-        }
-        if (this.actionsList == null) {
-            getOFActions();
-        }
-        if (!isIPv6) {
-            ((OFFlowMod) fm).setMatch(this.ofMatch);
-            ((OFFlowMod) fm).setActions(this.actionsList);
-            ((OFFlowMod) fm).setPriority(flow.getPriority());
-            ((OFFlowMod) fm).setCookie(flow.getId());
-            ((OFFlowMod) fm).setBufferId(OFPacketOut.BUFFER_ID_NONE);
-            ((OFFlowMod) fm).setLength(U16.t(OFFlowMod.MINIMUM_LENGTH
-                    + actionsLength));
-            ((OFFlowMod) fm).setIdleTimeout(flow.getIdleTimeout());
-            ((OFFlowMod) fm).setHardTimeout(flow.getHardTimeout());
-            ((OFFlowMod) fm).setCommand(command);
-            if (port != null) {
-                ((OFFlowMod) fm).setOutPort(port);
-            }
-            if (command == OFFlowMod.OFPFC_ADD || command == OFFlowMod.OFPFC_MODIFY
-                    || command == OFFlowMod.OFPFC_MODIFY_STRICT) {
-                // Instruct switch to let controller know when flow is removed
-                ((OFFlowMod) fm).setFlags((short) 1);
-            }
-        } else {
-            ((V6FlowMod) fm).setVendor();
-            ((V6FlowMod) fm).setMatch((V6Match) ofMatch);
-            ((V6FlowMod) fm).setActions(this.actionsList);
-            ((V6FlowMod) fm).setPriority(flow.getPriority());
-            ((V6FlowMod) fm).setCookie(flow.getId());
-            ((V6FlowMod) fm).setLength(U16.t(OFVendor.MINIMUM_LENGTH
-                    + ((V6Match) ofMatch).getIPv6ExtMinHdrLen()
-                    + ((V6Match) ofMatch).getIPv6MatchLen()
-                    + ((V6Match) ofMatch).getPadSize() + actionsLength));
-            ((V6FlowMod) fm).setIdleTimeout(flow.getIdleTimeout());
-            ((V6FlowMod) fm).setHardTimeout(flow.getHardTimeout());
-            ((V6FlowMod) fm).setCommand(command);
-            if (port != null) {
-                ((V6FlowMod) fm).setOutPort(port);
-            }
-            if (command == OFFlowMod.OFPFC_ADD || command == OFFlowMod.OFPFC_MODIFY
-                    || command == OFFlowMod.OFPFC_MODIFY_STRICT) {
-                // Instruct switch to let controller know when flow is removed
-                ((V6FlowMod) fm).setFlags((short) 1);
-            }
-        }
-        logger.trace("Openflow Match: {} Openflow Actions: {}", ofMatch,
-                actionsList);
-        logger.trace("Openflow Mod Message: {}", fm);
-        return fm;
-    }
-
-    public Flow getFlow(Node node) {
-        if (this.flow == null) {
-            Match salMatch = new Match();
-
-            /*
-             * Installed flow may not have a Match defined like in case of a
-             * drop all flow
-             */
-            if (ofMatch != null) {
-                if (!isIPv6) {
-                    // Compute OF1.0 Match
-                    if (ofMatch.getInputPort() != 0 && ofMatch.getInputPort() != OFPort.OFPP_LOCAL.getValue()) {
-                        salMatch.setField(new MatchField(MatchType.IN_PORT,
-                                NodeConnectorCreator.createNodeConnector(
-                                        ofMatch.getInputPort(), node)));
-                    }
-                    if (ofMatch.getDataLayerSource() != null
-                            && !NetUtils
-                                    .isZeroMAC(ofMatch.getDataLayerSource())) {
-                        byte srcMac[] = ofMatch.getDataLayerSource();
-                        salMatch.setField(new MatchField(MatchType.DL_SRC,
-                                srcMac.clone()));
-                    }
-                    if (ofMatch.getDataLayerDestination() != null
-                            && !NetUtils.isZeroMAC(ofMatch
-                                    .getDataLayerDestination())) {
-                        byte dstMac[] = ofMatch.getDataLayerDestination();
-                        salMatch.setField(new MatchField(MatchType.DL_DST,
-                                dstMac.clone()));
-                    }
-                    if (ofMatch.getDataLayerType() != 0) {
-                        salMatch.setField(new MatchField(MatchType.DL_TYPE,
-                                ofMatch.getDataLayerType()));
-                    }
-                    short vlan = ofMatch.getDataLayerVirtualLan();
-                    if (vlan != 0) {
-                        if (vlan == OFP_VLAN_NONE) {
-                            vlan = MatchType.DL_VLAN_NONE;
-                        }
-                        salMatch.setField(new MatchField(MatchType.DL_VLAN,
-                                vlan));
-                    }
-                    if ((ofMatch.getWildcards() & OFMatch.OFPFW_DL_VLAN_PCP) == 0) {
-                        salMatch.setField(MatchType.DL_VLAN_PR, ofMatch
-                                .getDataLayerVirtualLanPriorityCodePoint());
-                    }
-                    if (ofMatch.getNetworkSource() != 0) {
-                        salMatch.setField(MatchType.NW_SRC, NetUtils
-                                .getInetAddress(ofMatch.getNetworkSource()),
-                                NetUtils.getInetNetworkMask(
-                                        ofMatch.getNetworkSourceMaskLen(),
-                                        false));
-                    }
-                    if (ofMatch.getNetworkDestination() != 0) {
-                        salMatch.setField(MatchType.NW_DST,
-                                NetUtils.getInetAddress(ofMatch
-                                        .getNetworkDestination()),
-                                NetUtils.getInetNetworkMask(
-                                        ofMatch.getNetworkDestinationMaskLen(),
-                                        false));
-                    }
-                    if (ofMatch.getNetworkTypeOfService() != 0) {
-                        int dscp = NetUtils.getUnsignedByte(ofMatch
-                                .getNetworkTypeOfService());
-                        byte tos = (byte) (dscp >> 2);
-                        salMatch.setField(MatchType.NW_TOS, tos);
-                    }
-                    //TODO: NW protocol 0 is a valid protocol
-                    if (ofMatch.getNetworkProtocol() != 0) {
-                        salMatch.setField(MatchType.NW_PROTO,
-                                ofMatch.getNetworkProtocol());
-                    }
-                    if (ofMatch.getTransportSource() != 0) {
-                        salMatch.setField(MatchType.TP_SRC,
-                                ofMatch.getTransportSource());
-                    }
-                    if (ofMatch.getTransportDestination() != 0) {
-                        salMatch.setField(MatchType.TP_DST,
-                                ofMatch.getTransportDestination());
-                    }
-                } else {
-                    // Compute OF1.0 + IPv6 extensions Match
-                    V6Match v6Match = (V6Match) ofMatch;
-                    if (v6Match.getInputPort() != 0 && v6Match.getInputPort() != OFPort.OFPP_LOCAL.getValue()) {
-                        // Mask on input port is not defined
-                        salMatch.setField(new MatchField(MatchType.IN_PORT,
-                                NodeConnectorCreator.createOFNodeConnector(
-                                        v6Match.getInputPort(), node)));
-                    }
-                    if (v6Match.getDataLayerSource() != null
-                            && !NetUtils
-                                    .isZeroMAC(ofMatch.getDataLayerSource())) {
-                        byte srcMac[] = v6Match.getDataLayerSource();
-                        salMatch.setField(new MatchField(MatchType.DL_SRC,
-                                srcMac.clone()));
-                    }
-                    if (v6Match.getDataLayerDestination() != null
-                            && !NetUtils.isZeroMAC(ofMatch
-                                    .getDataLayerDestination())) {
-                        byte dstMac[] = v6Match.getDataLayerDestination();
-                        salMatch.setField(new MatchField(MatchType.DL_DST,
-                                dstMac.clone()));
-                    }
-                    if (v6Match.getDataLayerType() != 0) {
-                        salMatch.setField(new MatchField(MatchType.DL_TYPE,
-                                v6Match.getDataLayerType()));
-                    }
-                    short vlan = v6Match.getDataLayerVirtualLan();
-                    if (vlan != 0) {
-                        if (vlan == OFP_VLAN_NONE) {
-                            vlan = MatchType.DL_VLAN_NONE;
-                        }
-                        salMatch.setField(new MatchField(MatchType.DL_VLAN,
-                                vlan));
-                    }
-                    if ((v6Match.getWildcards() & OFMatch.OFPFW_DL_VLAN_PCP) == 0) {
-                        salMatch.setField(MatchType.DL_VLAN_PR, v6Match
-                                .getDataLayerVirtualLanPriorityCodePoint());
-                    }
-                    // V6Match may carry IPv4 address
-                    if (v6Match.getNetworkSrc() != null) {
-                        salMatch.setField(MatchType.NW_SRC,
-                                v6Match.getNetworkSrc(),
-                                v6Match.getNetworkSourceMask());
-                    } else if (v6Match.getNetworkSource() != 0) {
-                        salMatch.setField(MatchType.NW_SRC, NetUtils
-                                .getInetAddress(v6Match.getNetworkSource()),
-                                NetUtils.getInetNetworkMask(
-                                        v6Match.getNetworkSourceMaskLen(),
-                                        false));
-                    }
-                    // V6Match may carry IPv4 address
-                    if (v6Match.getNetworkDest() != null) {
-                        salMatch.setField(MatchType.NW_DST,
-                                v6Match.getNetworkDest(),
-                                v6Match.getNetworkDestinationMask());
-                    } else if (v6Match.getNetworkDestination() != 0) {
-                        salMatch.setField(MatchType.NW_DST,
-                                NetUtils.getInetAddress(v6Match
-                                        .getNetworkDestination()),
-                                NetUtils.getInetNetworkMask(
-                                        v6Match.getNetworkDestinationMaskLen(),
-                                        false));
-                    }
-                    if (v6Match.getNetworkTypeOfService() != 0) {
-                        int dscp = NetUtils.getUnsignedByte(v6Match
-                                .getNetworkTypeOfService());
-                        byte tos = (byte) (dscp >> 2);
-                        salMatch.setField(MatchType.NW_TOS, tos);
-                    }
-                    if (v6Match.getNetworkProtocol() != 0) {
-                        salMatch.setField(MatchType.NW_PROTO,
-                                v6Match.getNetworkProtocol());
-                    }
-                    if (v6Match.getTransportSource() != 0) {
-                        salMatch.setField(MatchType.TP_SRC,
-                                (v6Match.getTransportSource()));
-                    }
-                    if (v6Match.getTransportDestination() != 0) {
-                        salMatch.setField(MatchType.TP_DST,
-                                (v6Match.getTransportDestination()));
-                    }
-                }
-            }
-
-            // Convert actions
-            Action salAction = null;
-            List<Action> salActionList = new ArrayList<Action>();
-            if (actionsList == null) {
-                salActionList.add(new Drop());
-            } else {
-                for (OFAction ofAction : actionsList) {
-                    if (ofAction instanceof OFActionOutput) {
-                        short ofPort = ((OFActionOutput) ofAction).getPort();
-                        if (ofPort == OFPort.OFPP_CONTROLLER.getValue()) {
-                            salAction = new Controller();
-                        } else if (ofPort == OFPort.OFPP_NONE.getValue()) {
-                            salAction = new Drop();
-                        } else if (ofPort == OFPort.OFPP_IN_PORT.getValue()) {
-                            salAction = new Loopback();
-                        } else if (ofPort == OFPort.OFPP_FLOOD.getValue()) {
-                            salAction = new Flood();
-                        } else if (ofPort == OFPort.OFPP_ALL.getValue()) {
-                            salAction = new FloodAll();
-                        } else if (ofPort == OFPort.OFPP_LOCAL.getValue()) {
-                            salAction = new SwPath();
-                        } else if (ofPort == OFPort.OFPP_NORMAL.getValue()) {
-                            salAction = new HwPath();
-                        } else if (ofPort == OFPort.OFPP_TABLE.getValue()) {
-                            salAction = new HwPath(); // TODO: we do not handle
-                                                      // table in sal for now
-                        } else {
-                            salAction = new Output(
-                                    NodeConnectorCreator.createOFNodeConnector(
-                                            ofPort, node));
-                        }
-                    } else if (ofAction instanceof OFActionEnqueue) {
-                        salAction = new Enqueue(NodeConnectorCreator.createOFNodeConnector(
-                                ((OFActionEnqueue) ofAction).getPort(), node),
-                                ((OFActionEnqueue) ofAction).getQueueId());
-                    } else if (ofAction instanceof OFActionVirtualLanIdentifier) {
-                        salAction = new SetVlanId(
-                                ((OFActionVirtualLanIdentifier) ofAction)
-                                        .getVirtualLanIdentifier());
-                    } else if (ofAction instanceof OFActionStripVirtualLan) {
-                        salAction = new PopVlan();
-                    } else if (ofAction instanceof OFActionVirtualLanPriorityCodePoint) {
-                        salAction = new SetVlanPcp(
-                                ((OFActionVirtualLanPriorityCodePoint) ofAction)
-                                        .getVirtualLanPriorityCodePoint());
-                    } else if (ofAction instanceof OFActionDataLayerSource) {
-                        salAction = new SetDlSrc(
-                                ((OFActionDataLayerSource) ofAction)
-                                        .getDataLayerAddress().clone());
-                    } else if (ofAction instanceof OFActionDataLayerDestination) {
-                        salAction = new SetDlDst(
-                                ((OFActionDataLayerDestination) ofAction)
-                                        .getDataLayerAddress().clone());
-                    } else if (ofAction instanceof OFActionNetworkLayerSource) {
-                        byte addr[] = BigInteger.valueOf(
-                                ((OFActionNetworkLayerSource) ofAction)
-                                        .getNetworkAddress()).toByteArray();
-                        InetAddress ip = null;
-                        try {
-                            ip = InetAddress.getByAddress(addr);
-                        } catch (UnknownHostException e) {
-                            logger.error("", e);
-                        }
-                        salAction = new SetNwSrc(ip);
-                    } else if (ofAction instanceof OFActionNetworkLayerDestination) {
-                        byte addr[] = BigInteger.valueOf(
-                                ((OFActionNetworkLayerDestination) ofAction)
-                                        .getNetworkAddress()).toByteArray();
-                        InetAddress ip = null;
-                        try {
-                            ip = InetAddress.getByAddress(addr);
-                        } catch (UnknownHostException e) {
-                            logger.error("", e);
-                        }
-                        salAction = new SetNwDst(ip);
-                    } else if (ofAction instanceof OFActionNetworkTypeOfService) {
-                        salAction = new SetNwTos(
-                                ((OFActionNetworkTypeOfService) ofAction)
-                                        .getNetworkTypeOfService());
-                    } else if (ofAction instanceof OFActionTransportLayerSource) {
-                        Short port = ((OFActionTransportLayerSource) ofAction)
-                                .getTransportPort();
-                        int intPort = NetUtils.getUnsignedShort(port);
-                        salAction = new SetTpSrc(intPort);
-                    } else if (ofAction instanceof OFActionTransportLayerDestination) {
-                        Short port = ((OFActionTransportLayerDestination) ofAction)
-                                .getTransportPort();
-                        int intPort = NetUtils.getUnsignedShort(port);
-                        salAction = new SetTpDst(intPort);
-                    }
-                    salActionList.add(salAction);
-                }
-            }
-            // Create Flow
-            flow = new Flow(salMatch, salActionList);
-        }
-        logger.trace("Openflow Match: {} Openflow Actions: {}", ofMatch,
-                actionsList);
-        logger.trace("SAL Flow: {}", flow);
-        return flow;
-    }
-
-    private static final Map<Integer, Class<? extends Action>> actionMap = new HashMap<Integer, Class<? extends Action>>() {
-        private static final long serialVersionUID = 1L;
-        {
-            put(1 << 0, Output.class);
-            put(1 << 1, SetVlanId.class);
-            put(1 << 2, SetVlanPcp.class);
-            put(1 << 3, PopVlan.class);
-            put(1 << 4, SetDlSrc.class);
-            put(1 << 5, SetDlDst.class);
-            put(1 << 6, SetNwSrc.class);
-            put(1 << 7, SetNwDst.class);
-            put(1 << 8, SetNwTos.class);
-            put(1 << 9, SetTpSrc.class);
-            put(1 << 10, SetTpDst.class);
-            put(1 << 11, Enqueue.class);
-        }
-    };
-
-    /**
-     * Returns the supported flow actions for the netwrok node given the bitmask
-     * representing the actions the Openflow 1.0 switch supports
-     *
-     * @param ofActionBitmask
-     *            OF 1.0 action bitmask
-     * @return The correspondent list of SAL Action classes
-     */
-    public static List<Class<? extends Action>> getFlowActions(int ofActionBitmask) {
-        List<Class<? extends Action>> list = new ArrayList<Class<? extends Action>>();
-
-        for (int i = 0; i < Integer.SIZE; i++) {
-            int index = 1 << i;
-            if ((index & ofActionBitmask) > 0) {
-                if (actionMap.containsKey(index)) {
-                    list.add(actionMap.get(index));
-                }
-            }
-        }
-        // Add implicit SAL actions
-        list.add(Controller.class);
-        list.add(SwPath.class);
-        list.add(HwPath.class);
-        list.add(Drop.class);
-        list.add(Flood.class);
-        list.add(FloodAll.class);
-
-        return list;
-    }
-
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/FlowProgrammerNotifier.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/FlowProgrammerNotifier.java
deleted file mode 100644 (file)
index dfa2026..0000000
+++ /dev/null
@@ -1,117 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow.internal;
-
-import org.apache.felix.dm.Component;
-import org.opendaylight.controller.protocol_plugin.openflow.IFlowProgrammerNotifier;
-import org.opendaylight.controller.sal.connection.IPluginOutConnectionService;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.flowprogrammer.Flow;
-import org.opendaylight.controller.sal.flowprogrammer.IPluginOutFlowProgrammerService;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * Flow Programmer Notifier class for relaying asynchronous messages received
- * from the network node to the listeners on the proper container
- */
-public class FlowProgrammerNotifier implements IFlowProgrammerNotifier {
-    protected static final Logger logger = LoggerFactory
-            .getLogger(FlowProgrammerNotifier.class);
-    private IPluginOutFlowProgrammerService salNotifier;
-    private IPluginOutConnectionService connectionOutService;
-
-    public FlowProgrammerNotifier() {
-        salNotifier = null;
-    }
-
-    void init(Component c) {
-        logger.debug("INIT called!");
-    }
-
-    /**
-     * Function called by the dependency manager when at least one dependency
-     * become unsatisfied or when the component is shutting down because for
-     * example bundle is being stopped.
-     *
-     */
-    void destroy() {
-        logger.debug("DESTROY called!");
-    }
-
-    /**
-     * Function called by dependency manager after "init ()" is called and after
-     * the services provided by the class are registered in the service registry
-     *
-     */
-    void start() {
-        logger.debug("START called!");
-    }
-
-    /**
-     * Function called by the dependency manager before the services exported by
-     * the component are unregistered, this will be followed by a "destroy ()"
-     * calls
-     *
-     */
-    void stop() {
-        logger.debug("STOP called!");
-    }
-
-    public void setPluginOutFlowProgrammerService(
-            IPluginOutFlowProgrammerService s) {
-        this.salNotifier = s;
-    }
-
-    public void unsetPluginOutFlowProgrammerService(
-            IPluginOutFlowProgrammerService s) {
-        if (this.salNotifier == s) {
-            this.salNotifier = null;
-        }
-    }
-
-    @Override
-    public void flowRemoved(Node node, Flow flow) {
-        if (!connectionOutService.isLocal(node)) {
-            logger.debug("flow removed will not be notified in a non-master controller for node "+node);
-            return;
-        }
-
-        if (salNotifier != null) {
-            salNotifier.flowRemoved(node, flow);
-        } else {
-            logger.warn("Unable to relay switch message to upper layer");
-        }
-    }
-
-    @Override
-    public void flowErrorReported(Node node, long rid, Object err) {
-        if (!connectionOutService.isLocal(node)) {
-            logger.debug("flow error will not be notified in a non-master controller for node "+node);
-            return;
-        }
-
-        if (salNotifier != null) {
-            salNotifier.flowErrorReported(node, rid, err);
-        } else {
-            logger.warn("Unable to relay switch error message to upper layer");
-        }
-    }
-
-    void setIPluginOutConnectionService(IPluginOutConnectionService s) {
-        connectionOutService = s;
-    }
-
-    void unsetIPluginOutConnectionService(IPluginOutConnectionService s) {
-        if (connectionOutService == s) {
-            connectionOutService = null;
-        }
-    }
-
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/FlowProgrammerService.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/FlowProgrammerService.java
deleted file mode 100644 (file)
index e2fa8d5..0000000
+++ /dev/null
@@ -1,858 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow.internal;
-
-import java.util.ArrayList;
-import java.util.HashMap;
-import java.util.HashSet;
-import java.util.Map;
-import java.util.Set;
-import java.util.concurrent.ConcurrentHashMap;
-import java.util.concurrent.ConcurrentMap;
-
-import org.eclipse.osgi.framework.console.CommandInterpreter;
-import org.eclipse.osgi.framework.console.CommandProvider;
-import org.opendaylight.controller.protocol_plugin.openflow.IFlowProgrammerNotifier;
-import org.opendaylight.controller.protocol_plugin.openflow.IInventoryShimExternalListener;
-import org.opendaylight.controller.protocol_plugin.openflow.core.IController;
-import org.opendaylight.controller.protocol_plugin.openflow.core.IMessageListener;
-import org.opendaylight.controller.protocol_plugin.openflow.core.ISwitch;
-import org.opendaylight.controller.sal.connection.IPluginOutConnectionService;
-import org.opendaylight.controller.sal.core.ContainerFlow;
-import org.opendaylight.controller.sal.core.IContainerAware;
-import org.opendaylight.controller.sal.core.IContainerListener;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.Node.NodeIDType;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.core.UpdateType;
-import org.opendaylight.controller.sal.flowprogrammer.Flow;
-import org.opendaylight.controller.sal.flowprogrammer.IPluginInFlowProgrammerService;
-import org.opendaylight.controller.sal.match.Match;
-import org.opendaylight.controller.sal.match.MatchType;
-import org.opendaylight.controller.sal.utils.EtherTypes;
-import org.opendaylight.controller.sal.utils.GlobalConstants;
-import org.opendaylight.controller.sal.utils.HexEncode;
-import org.opendaylight.controller.sal.utils.NodeCreator;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.sal.utils.StatusCode;
-import org.openflow.protocol.OFError;
-import org.openflow.protocol.OFFlowMod;
-import org.openflow.protocol.OFFlowRemoved;
-import org.openflow.protocol.OFMessage;
-import org.openflow.protocol.OFPort;
-import org.openflow.protocol.OFType;
-import org.openflow.protocol.action.OFAction;
-import org.osgi.framework.BundleContext;
-import org.osgi.framework.FrameworkUtil;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * Represents the openflow plugin component in charge of programming the flows
- * the flow programming and relay them to functional modules above SAL.
- */
-public class FlowProgrammerService implements IPluginInFlowProgrammerService,
-        IMessageListener, IContainerListener, IInventoryShimExternalListener,
-        CommandProvider, IContainerAware {
-    private static final Logger log = LoggerFactory
-            .getLogger(FlowProgrammerService.class);
-    private IController controller;
-    private ConcurrentMap<String, IFlowProgrammerNotifier> flowProgrammerNotifiers;
-    private Map<String, Set<NodeConnector>> containerToNc;
-    private ConcurrentMap<Long, Map<Integer, Long>> xid2rid;
-    private int barrierMessagePriorCount = getBarrierMessagePriorCount();
-    private IPluginOutConnectionService connectionOutService;
-
-    public FlowProgrammerService() {
-        controller = null;
-        flowProgrammerNotifiers = new ConcurrentHashMap<String, IFlowProgrammerNotifier>();
-        containerToNc = new HashMap<String, Set<NodeConnector>>();
-        xid2rid = new ConcurrentHashMap<Long, Map<Integer, Long>>();
-    }
-
-    public void setController(IController core) {
-        this.controller = core;
-    }
-
-    public void unsetController(IController core) {
-        if (this.controller == core) {
-            this.controller = null;
-        }
-    }
-
-    void setIPluginOutConnectionService(IPluginOutConnectionService s) {
-        connectionOutService = s;
-    }
-
-    void unsetIPluginOutConnectionService(IPluginOutConnectionService s) {
-        if (connectionOutService == s) {
-            connectionOutService = null;
-        }
-    }
-
-    public void setFlowProgrammerNotifier(Map<String, ?> props,
-            IFlowProgrammerNotifier s) {
-        if (props == null || props.get("containerName") == null) {
-            log.error("Didn't receive the service correct properties");
-            return;
-        }
-        String containerName = (String) props.get("containerName");
-        this.flowProgrammerNotifiers.put(containerName, s);
-    }
-
-    public void unsetFlowProgrammerNotifier(Map<String, ?> props,
-            IFlowProgrammerNotifier s) {
-        if (props == null || props.get("containerName") == null) {
-            log.error("Didn't receive the service correct properties");
-            return;
-        }
-        String containerName = (String) props.get("containerName");
-        if (this.flowProgrammerNotifiers != null
-                && this.flowProgrammerNotifiers.containsKey(containerName)
-                && this.flowProgrammerNotifiers.get(containerName) == s) {
-            this.flowProgrammerNotifiers.remove(containerName);
-        }
-    }
-
-    /**
-     * Function called by the dependency manager when all the required
-     * dependencies are satisfied
-     *
-     */
-    void init() {
-        this.controller.addMessageListener(OFType.FLOW_REMOVED, this);
-        this.controller.addMessageListener(OFType.ERROR, this);
-        registerWithOSGIConsole();
-    }
-
-    /**
-     * Function called by the dependency manager when at least one dependency
-     * become unsatisfied or when the component is shutting down because for
-     * example bundle is being stopped.
-     *
-     */
-    void destroy() {
-    }
-
-    /**
-     * Function called by dependency manager after "init ()" is called and after
-     * the services provided by the class are registered in the service registry
-     *
-     */
-    void start() {
-    }
-
-    /**
-     * Function called by the dependency manager before the services exported by
-     * the component are unregistered, this will be followed by a "destroy ()"
-     * calls
-     *
-     */
-    void stop() {
-    }
-
-    @Override
-    public Status addFlow(Node node, Flow flow) {
-        if (!connectionOutService.isLocal(node)) {
-            log.debug("Add flow will not be processed in a non-master controller for node " + node);
-            return new Status(StatusCode.NOTALLOWED, "This is not the master controller for " + node);
-        }
-
-        return addFlowInternal(node, flow, 0);
-    }
-
-    @Override
-    public Status modifyFlow(Node node, Flow oldFlow, Flow newFlow) {
-        if (!connectionOutService.isLocal(node)) {
-            log.debug("Modify flow will not be processed in a non-master controller for node " + node);
-            return new Status(StatusCode.NOTALLOWED, "This is not the master controller for " + node);
-        }
-
-        return modifyFlowInternal(node, oldFlow, newFlow, 0);
-    }
-
-    @Override
-    public Status removeFlow(Node node, Flow flow) {
-        if (!connectionOutService.isLocal(node)) {
-            log.debug("Remove flow will not be processed in a non-master controller for node " + node);
-            return new Status(StatusCode.NOTALLOWED, "This is not the master controller for " + node);
-        }
-
-        return removeFlowInternal(node, flow, 0);
-    }
-
-    @Override
-    public Status addFlowAsync(Node node, Flow flow, long rid) {
-        if (!connectionOutService.isLocal(node)) {
-            log.debug("Add flow Async will not be processed in a non-master controller for node " + node);
-            return new Status(StatusCode.NOTALLOWED, "This is not the master controller for " + node);
-        }
-
-        return addFlowInternal(node, flow, rid);
-    }
-
-    @Override
-    public Status modifyFlowAsync(Node node, Flow oldFlow, Flow newFlow,
-            long rid) {
-        if (!connectionOutService.isLocal(node)) {
-            log.debug("Modify flow async will not be processed in a non-master controller for node " + node);
-            return new Status(StatusCode.NOTALLOWED, "This is not the master controller for " + node);
-        }
-
-        return modifyFlowInternal(node, oldFlow, newFlow, rid);
-    }
-
-    @Override
-    public Status removeFlowAsync(Node node, Flow flow, long rid) {
-        if (!connectionOutService.isLocal(node)) {
-            log.debug("Remove flow async will not be processed in a non-master controller for node " + node);
-            return new Status(StatusCode.NOTALLOWED, "This is not the master controller for " + node);
-        }
-
-        return removeFlowInternal(node, flow, rid);
-    }
-
-    private Status addFlowInternal(Node node, Flow flow, long rid) {
-        String action = "add";
-        if (!node.getType().equals(NodeIDType.OPENFLOW)) {
-            return new Status(StatusCode.NOTACCEPTABLE, errorString("send",
-                    action, "Invalid node type"));
-        }
-
-        Status status = validateFlow(flow);
-        if (!status.isSuccess()) {
-            return status;
-        }
-
-        if (controller != null) {
-            ISwitch sw = controller.getSwitch((Long) node.getID());
-            if (sw != null) {
-                FlowConverter x = new FlowConverter(flow);
-                OFMessage msg = x.getOFFlowMod(OFFlowMod.OFPFC_ADD, null);
-
-                Object result;
-                if (rid == 0) {
-                    /*
-                     * Synchronous message send. Each message is followed by a
-                     * Barrier message.
-                     */
-                    result = sw.syncSend(msg);
-                } else {
-                    /*
-                     * Message will be sent asynchronously. A Barrier message
-                     * will be inserted automatically to synchronize the
-                     * progression.
-                     */
-                    result = asyncMsgSend(node, sw, msg, rid);
-                }
-                return getStatusInternal(result, action, rid);
-            } else {
-                return new Status(StatusCode.GONE, errorString("send", action,
-                        "Switch is not available"));
-            }
-        }
-        return new Status(StatusCode.INTERNALERROR, errorString("send", action,
-                "Internal plugin error"));
-    }
-
-    /*
-     * Method which runs openflow 1.0 specific validation on the requested flow
-     * This validation is needed because the openflow switch will silently accept
-     * the request and install only the applicable match fields
-     */
-    private Status validateFlow(Flow flow) {
-        Match m = flow.getMatch();
-        boolean isIPEthertypeSet = m.isPresent(MatchType.DL_TYPE)
-                && (m.getField(MatchType.DL_TYPE).getValue().equals(EtherTypes.IPv4.shortValue()) || m
-                        .getField(MatchType.DL_TYPE).getValue().equals(EtherTypes.IPv6.shortValue()));
-
-        // network address check
-        if ((m.isPresent(MatchType.NW_SRC) || m.isPresent(MatchType.NW_DST)) && !isIPEthertypeSet) {
-            return new Status(StatusCode.NOTACCEPTABLE,
-                    "The match on network source or destination address cannot be accepted if the match "
-                     + "on proper ethertype is missing");
-        }
-
-        // transport protocol check
-        if (m.isPresent(MatchType.NW_PROTO) && !isIPEthertypeSet) {
-            return new Status(StatusCode.NOTACCEPTABLE,
-                    "The match on network protocol cannot be accepted if the match on proper ethertype is missing");
-        }
-
-        // transport ports check
-        if ((m.isPresent(MatchType.TP_SRC) || m.isPresent(MatchType.TP_DST))
-                && (!isIPEthertypeSet || m.isAny(MatchType.NW_PROTO))) {
-            return new Status(
-                    StatusCode.NOTACCEPTABLE,
-                    "The match on transport source or destination port cannot be accepted if the match on network protocol and match on IP ethertype are missing");
-        }
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    private Status modifyFlowInternal(Node node, Flow oldFlow, Flow newFlow, long rid) {
-        String action = "modify";
-        if (!node.getType().equals(NodeIDType.OPENFLOW)) {
-            return new Status(StatusCode.NOTACCEPTABLE, errorString("send",
-                    action, "Invalid node type"));
-        }
-
-        Status status = validateFlow(newFlow);
-        if (!status.isSuccess()) {
-            return status;
-        }
-
-        if (controller != null) {
-            ISwitch sw = controller.getSwitch((Long) node.getID());
-            if (sw != null) {
-                OFMessage msg1 = null, msg2 = null;
-
-                // If priority and match portion are the same, send a
-                // modification message
-                if (oldFlow.getPriority() != newFlow.getPriority()
-                        || !oldFlow.getMatch().equals(newFlow.getMatch())) {
-                    msg1 = new FlowConverter(oldFlow).getOFFlowMod(
-                            OFFlowMod.OFPFC_DELETE_STRICT, OFPort.OFPP_NONE);
-                    msg2 = new FlowConverter(newFlow).getOFFlowMod(
-                            OFFlowMod.OFPFC_ADD, null);
-                } else {
-                    msg1 = new FlowConverter(newFlow).getOFFlowMod(
-                            OFFlowMod.OFPFC_MODIFY_STRICT, null);
-                }
-                /*
-                 * Synchronous message send
-                 */
-                action = (msg2 == null) ? "modify" : "delete";
-                Object result;
-                if (rid == 0) {
-                    /*
-                     * Synchronous message send. Each message is followed by a
-                     * Barrier message.
-                     */
-                    result = sw.syncSend(msg1);
-                } else {
-                    /*
-                     * Message will be sent asynchronously. A Barrier message
-                     * will be inserted automatically to synchronize the
-                     * progression.
-                     */
-                    result = asyncMsgSend(node, sw, msg1, rid);
-                }
-
-                Status rv = getStatusInternal(result, action, rid);
-                if ((msg2 == null) || !rv.isSuccess()) {
-                    return rv;
-                }
-
-                action = "add";
-                if (rid == 0) {
-                    /*
-                     * Synchronous message send. Each message is followed by a
-                     * Barrier message.
-                     */
-                    result = sw.syncSend(msg2);
-                } else {
-                    /*
-                     * Message will be sent asynchronously. A Barrier message
-                     * will be inserted automatically to synchronize the
-                     * progression.
-                     */
-                    result = asyncMsgSend(node, sw, msg2, rid);
-                }
-                return getStatusInternal(result, action, rid);
-            } else {
-                return new Status(StatusCode.GONE, errorString("send", action,
-                        "Switch is not available"));
-            }
-        }
-        return new Status(StatusCode.INTERNALERROR, errorString("send", action,
-                "Internal plugin error"));
-    }
-
-    private Status removeFlowInternal(Node node, Flow flow, long rid) {
-        String action = "remove";
-        if (!node.getType().equals(NodeIDType.OPENFLOW)) {
-            return new Status(StatusCode.NOTACCEPTABLE, errorString("send",
-                    action, "Invalid node type"));
-        }
-        if (controller != null) {
-            ISwitch sw = controller.getSwitch((Long) node.getID());
-            if (sw != null) {
-                OFMessage msg = new FlowConverter(flow).getOFFlowMod(
-                        OFFlowMod.OFPFC_DELETE_STRICT, OFPort.OFPP_NONE);
-                Object result;
-                if (rid == 0) {
-                    /*
-                     * Synchronous message send. Each message is followed by a
-                     * Barrier message.
-                     */
-                    result = sw.syncSend(msg);
-                } else {
-                    /*
-                     * Message will be sent asynchronously. A Barrier message
-                     * will be inserted automatically to synchronize the
-                     * progression.
-                     */
-                    result = asyncMsgSend(node, sw, msg, rid);
-                }
-                return getStatusInternal(result, action, rid);
-            } else {
-                return new Status(StatusCode.GONE, errorString("send", action,
-                        "Switch is not available"));
-            }
-        }
-        return new Status(StatusCode.INTERNALERROR, errorString("send", action,
-                "Internal plugin error"));
-    }
-
-    @Override
-    public Status removeAllFlows(Node node) {
-        if (!connectionOutService.isLocal(node)) {
-            log.debug("Remove all flows will not be processed in a non-master controller for node " + node);
-            return new Status(StatusCode.NOTALLOWED, "This is not the master controller for " + node);
-        }
-
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    private String errorString(String phase, String action, String cause) {
-        return "Failed to "
-                + ((phase != null) ? phase + " the " + action
-                        + " flow message: " : action + " the flow: ") + cause;
-    }
-
-    @Override
-    public void receive(ISwitch sw, OFMessage msg) {
-        if (msg instanceof OFFlowRemoved) {
-            handleFlowRemovedMessage(sw, (OFFlowRemoved) msg);
-        } else if (msg instanceof OFError) {
-            handleErrorMessage(sw, (OFError) msg);
-        }
-    }
-
-    private void handleFlowRemovedMessage(ISwitch sw, OFFlowRemoved msg) {
-        Node node = NodeCreator.createOFNode(sw.getId());
-        Flow flow = new FlowConverter(msg.getMatch(),
-                new ArrayList<OFAction>(0)).getFlow(node);
-        flow.setPriority(msg.getPriority());
-        flow.setIdleTimeout(msg.getIdleTimeout());
-        flow.setId(msg.getCookie());
-
-        Match match = flow.getMatch();
-        NodeConnector inPort = match.isPresent(MatchType.IN_PORT) ? (NodeConnector) match
-                .getField(MatchType.IN_PORT).getValue() : null;
-
-        for (Map.Entry<String, IFlowProgrammerNotifier> containerNotifier : flowProgrammerNotifiers
-                .entrySet()) {
-            String container = containerNotifier.getKey();
-            IFlowProgrammerNotifier notifier = containerNotifier.getValue();
-            /*
-             * Switch only provide us with the match information. For now let's
-             * try to identify the container membership only from the input port
-             * match field. In any case, upper layer consumers can derive
-             * whether the notification was not for them. More sophisticated
-             * filtering can be added later on.
-             */
-            if (inPort == null
-                    || container.equals(GlobalConstants.DEFAULT.toString())
-                    || (containerToNc.containsKey(container) && containerToNc.get(container).contains(inPort))) {
-                notifier.flowRemoved(node, flow);
-            }
-        }
-    }
-
-    private void handleErrorMessage(ISwitch sw, OFError errorMsg) {
-        Node node = NodeCreator.createOFNode(sw.getId());
-        OFMessage offendingMsg = errorMsg.getOffendingMsg();
-        Integer xid;
-        if (offendingMsg != null) {
-            xid = offendingMsg.getXid();
-        } else {
-            xid = errorMsg.getXid();
-        }
-
-        Long rid = getMessageRid(sw.getId(), xid);
-        /*
-         * Null or zero requestId indicates that the error message is meant for
-         * a sync message. It will be handled by the sync message worker thread.
-         * Hence we are done here.
-         */
-        if ((rid == null) || (rid == 0)) {
-            return;
-        }
-
-        /*
-         * Notifies the caller that error has been reported for a previous flow
-         * programming request
-         */
-        for (Map.Entry<String, IFlowProgrammerNotifier> containerNotifier : flowProgrammerNotifiers
-                .entrySet()) {
-            IFlowProgrammerNotifier notifier = containerNotifier.getValue();
-            notifier.flowErrorReported(node, rid, Utils.getOFErrorString(errorMsg));
-        }
-    }
-
-    @Override
-    public void tagUpdated(String containerName, Node n, short oldTag,
-            short newTag, UpdateType t) {
-
-    }
-
-    @Override
-    public void containerFlowUpdated(String containerName,
-            ContainerFlow previousFlow, ContainerFlow currentFlow, UpdateType t) {
-    }
-
-    @Override
-    public void nodeConnectorUpdated(String containerName, NodeConnector p,
-            UpdateType type) {
-        switch (type) {
-        case ADDED:
-            if (!containerToNc.containsKey(containerName)) {
-                containerToNc.put(containerName, new HashSet<NodeConnector>());
-            }
-            containerToNc.get(containerName).add(p);
-            break;
-        case CHANGED:
-            break;
-        case REMOVED:
-            Set<NodeConnector> target = containerToNc.get(containerName);
-            if (target != null) {
-                target.remove(p);
-            }
-            break;
-        default:
-        }
-    }
-
-    @Override
-    public void containerModeUpdated(UpdateType t) {
-
-    }
-
-    @Override
-    public Status syncSendBarrierMessage(Node node) {
-        if (!connectionOutService.isLocal(node)) {
-            log.debug("Sync Send Barrier will not be processed in a non-master controller for node " + node);
-            return new Status(StatusCode.NOTALLOWED, "This is not the master controller for " + node);
-        }
-
-        if (!node.getType().equals(NodeIDType.OPENFLOW)) {
-            return new Status(StatusCode.NOTACCEPTABLE,
-                    "The node does not support Barrier message.");
-        }
-
-        if (controller != null) {
-            long swid = (Long) node.getID();
-            ISwitch sw = controller.getSwitch(swid);
-            if (sw != null) {
-                sw.syncSendBarrierMessage();
-                clearXid2Rid(swid);
-                return (new Status(StatusCode.SUCCESS));
-            } else {
-                return new Status(StatusCode.GONE,
-                        "The node does not have a valid Switch reference.");
-            }
-        }
-        return new Status(StatusCode.INTERNALERROR,
-                "Failed to send Barrier message.");
-    }
-
-    @Override
-    public Status asyncSendBarrierMessage(Node node) {
-        if (!connectionOutService.isLocal(node)) {
-            log.debug("ASync Send Barrier will not be processed in a non-master controller for node " + node);
-            return new Status(StatusCode.NOTALLOWED, "This is not the master controller for " + node);
-        }
-
-        if (!node.getType().equals(NodeIDType.OPENFLOW)) {
-            return new Status(StatusCode.NOTACCEPTABLE,
-                    "The node does not support Barrier message.");
-        }
-
-        if (controller != null) {
-            long swid = (Long) node.getID();
-            ISwitch sw = controller.getSwitch(swid);
-            if (sw != null) {
-                sw.asyncSendBarrierMessage();
-                clearXid2Rid(swid);
-                return (new Status(StatusCode.SUCCESS));
-            } else {
-                return new Status(StatusCode.GONE,
-                        "The node does not have a valid Switch reference.");
-            }
-        }
-        return new Status(StatusCode.INTERNALERROR,
-                "Failed to send Barrier message.");
-    }
-
-    /**
-     * This method sends the message asynchronously until the number of messages
-     * sent reaches a threshold. Then a Barrier message is sent automatically
-     * for sync purpose. An unique Request ID associated with the message is
-     * passed down by the caller. The Request ID will be returned to the caller
-     * when an error message is received from the switch.
-     *
-     * @param node
-     *            The node
-     * @param msg
-     *            The switch
-     * @param msg
-     *            The OF message to be sent
-     * @param rid
-     *            The Request Id
-     * @return result
-     */
-    private Object asyncMsgSend(Node node, ISwitch sw, OFMessage msg, long rid) {
-        Object result = Boolean.TRUE;
-        long swid = (Long) node.getID();
-        int xid;
-
-        xid = sw.asyncSend(msg);
-        addXid2Rid(swid, xid, rid);
-
-        Map<Integer, Long> swxid2rid = this.xid2rid.get(swid);
-        if (swxid2rid == null) {
-            return result;
-        }
-
-        int size = swxid2rid.size();
-        if (size % barrierMessagePriorCount == 0) {
-            result = asyncSendBarrierMessage(node);
-        }
-
-        return result;
-    }
-
-    /**
-     * A number of async messages are sent followed by a synchronous Barrier
-     * message. This method returns the maximum async messages that can be sent
-     * before the Barrier message.
-     *
-     * @return The max count of async messages sent prior to Barrier message
-     */
-    private int getBarrierMessagePriorCount() {
-        String count = System.getProperty("of.barrierMessagePriorCount");
-        int rv = 100;
-
-        if (count != null) {
-            try {
-                rv = Integer.parseInt(count);
-            } catch (Exception e) {
-            }
-        }
-
-        return rv;
-    }
-
-    /**
-     * This method returns the message Request ID previously assigned by the
-     * caller for a given OF message xid
-     *
-     * @param swid
-     *            The switch id
-     * @param xid
-     *            The OF message xid
-     * @return The Request ID
-     */
-    private Long getMessageRid(long swid, Integer xid) {
-        Long rid = null;
-
-        if (xid == null) {
-            return rid;
-        }
-
-        Map<Integer, Long> swxid2rid = this.xid2rid.get(swid);
-        if (swxid2rid != null) {
-            rid = swxid2rid.get(xid);
-        }
-        return rid;
-    }
-
-    /**
-     * This method returns a copy of outstanding xid to rid mappings.for a given
-     * switch
-     *
-     * @param swid
-     *            The switch id
-     * @return a copy of xid2rid mappings
-     */
-    public Map<Integer, Long> getSwXid2Rid(long swid) {
-        Map<Integer, Long> swxid2rid = this.xid2rid.get(swid);
-
-        if (swxid2rid != null) {
-            return new HashMap<Integer, Long>(swxid2rid);
-        } else {
-            return new HashMap<Integer, Long>();
-        }
-    }
-
-    /**
-     * Adds xid to rid mapping to the local DB
-     *
-     * @param swid
-     *            The switch id
-     * @param xid
-     *            The OF message xid
-     * @param rid
-     *            The message Request ID
-     */
-    private void addXid2Rid(long swid, int xid, long rid) {
-        Map<Integer, Long> swxid2rid = this.xid2rid.get(swid);
-        if (swxid2rid != null) {
-            swxid2rid.put(xid, rid);
-        }
-    }
-
-    /**
-     * When an Error message is received, this method will be invoked to remove
-     * the offending xid from the local DB.
-     *
-     * @param swid
-     *            The switch id
-     * @param xid
-     *            The OF message xid
-     */
-    private void removeXid2Rid(long swid, int xid) {
-        Map<Integer, Long> swxid2rid = this.xid2rid.get(swid);
-        if (swxid2rid != null) {
-            swxid2rid.remove(xid);
-        }
-    }
-
-    /**
-     * Convert various result into Status
-     *
-     * @param result
-     *            The returned result from previous action
-     * @param action
-     *            add/modify/delete flow action
-     * @param rid
-     *            The Request ID associated with the flow message
-     * @return Status
-     */
-    private Status getStatusInternal(Object result, String action, long rid) {
-        if (result instanceof Boolean) {
-            return ((Boolean) result == Boolean.TRUE) ? new Status(
-                    StatusCode.SUCCESS, rid) : new Status(
-                    StatusCode.TIMEOUT, errorString(null, action,
-                            "Request Timed Out"));
-        } else if (result instanceof Status) {
-            return (Status) result;
-        } else if (result instanceof OFError) {
-            OFError res = (OFError) result;
-            return new Status(StatusCode.INTERNALERROR, errorString(
-                    "program", action, Utils.getOFErrorString(res)));
-        } else {
-            return new Status(StatusCode.INTERNALERROR, errorString(
-                    "send", action, "Internal Error"));
-        }
-    }
-
-    /**
-     * When a Barrier reply is received, this method will be invoked to clear
-     * the local DB
-     *
-     * @param swid
-     *            The switch id
-     */
-    private void clearXid2Rid(long swid) {
-        Map<Integer, Long> swxid2rid = this.xid2rid.get(swid);
-        if (swxid2rid != null) {
-            swxid2rid.clear();
-        }
-    }
-
-    @Override
-    public void updateNode(Node node, UpdateType type, Set<Property> props) {
-        long swid = (Long)node.getID();
-
-        switch (type) {
-        case ADDED:
-            Map<Integer, Long> swxid2rid = new HashMap<Integer, Long>();
-            this.xid2rid.put(swid, swxid2rid);
-            break;
-        case CHANGED:
-            break;
-        case REMOVED:
-            this.xid2rid.remove(swid);
-            break;
-        default:
-        }
-    }
-
-    @Override
-    public void updateNodeConnector(NodeConnector nodeConnector,
-            UpdateType type, Set<Property> props) {
-    }
-
-    private void registerWithOSGIConsole() {
-        BundleContext bundleContext = FrameworkUtil.getBundle(this.getClass())
-                .getBundleContext();
-        bundleContext.registerService(CommandProvider.class.getName(), this,
-                null);
-    }
-
-    @Override
-    public String getHelp() {
-        StringBuffer help = new StringBuffer();
-        help.append("-- Flow Programmer Service --\n");
-        help.append("\t px2r <node id>          - Print outstanding xid2rid mappings for a given node id\n");
-        help.append("\t px2rc                   - Print max num of async msgs prior to the Barrier\n");
-        return help.toString();
-    }
-
-    public void _px2r(CommandInterpreter ci) {
-        String st = ci.nextArgument();
-        if (st == null) {
-            ci.println("Please enter a valid node id");
-            return;
-        }
-
-        long sid;
-        try {
-            sid = HexEncode.stringToLong(st);
-        } catch (NumberFormatException e) {
-            ci.println("Please enter a valid node id");
-            return;
-        }
-
-        Map<Integer, Long> swxid2rid = this.xid2rid.get(sid);
-        if (swxid2rid == null) {
-            ci.println("The node id entered does not exist");
-            return;
-        }
-
-        ci.println("xid             rid");
-
-        Set<Integer> xidSet = swxid2rid.keySet();
-        if (xidSet == null) {
-            return;
-        }
-
-        for (Integer xid : xidSet) {
-            ci.println(xid + "       " + swxid2rid.get(xid));
-        }
-    }
-
-    public void _px2rc(CommandInterpreter ci) {
-        ci.println("Max num of async messages sent prior to the Barrier message is "
-                + barrierMessagePriorCount);
-    }
-
-    @Override
-    public void containerCreate(String containerName) {
-        // do nothing
-    }
-
-    @Override
-    public void containerDestroy(String containerName) {
-        containerToNc.remove(containerName);
-    }
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/FlowStatisticsConverter.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/FlowStatisticsConverter.java
deleted file mode 100644 (file)
index 74af3db..0000000
+++ /dev/null
@@ -1,96 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow.internal;
-
-import java.util.ArrayList;
-import java.util.Collections;
-import java.util.List;
-
-import org.opendaylight.controller.protocol_plugin.openflow.vendorextension.v6extension.V6StatsReply;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.flowprogrammer.Flow;
-import org.opendaylight.controller.sal.reader.FlowOnNode;
-import org.openflow.protocol.statistics.OFFlowStatisticsReply;
-import org.openflow.protocol.statistics.OFStatistics;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * Converts an openflow list of flow statistics in a SAL list of FlowOnNode
- * objects
- *
- *
- *
- */
-public class FlowStatisticsConverter {
-    private static final Logger log = LoggerFactory
-            .getLogger(FlowStatisticsConverter.class);
-    private List<OFStatistics> ofStatsList;
-    private List<FlowOnNode> flowOnNodeList;
-
-    public FlowStatisticsConverter(List<OFStatistics> statsList) {
-        if (statsList == null) {
-            this.ofStatsList = Collections.emptyList();
-        } else {
-            this.ofStatsList = statsList;
-        }
-        this.flowOnNodeList = null;
-    }
-
-    public List<FlowOnNode> getFlowOnNodeList(Node node) {
-        if (ofStatsList != null && flowOnNodeList == null) {
-            flowOnNodeList = new ArrayList<FlowOnNode>();
-            FlowConverter flowConverter = null;
-            OFFlowStatisticsReply ofFlowStat;
-            V6StatsReply v6StatsReply;
-            for (OFStatistics ofStat : ofStatsList) {
-                FlowOnNode flowOnNode = null;
-                if (ofStat instanceof OFFlowStatisticsReply) {
-                    ofFlowStat = (OFFlowStatisticsReply) ofStat;
-                    flowConverter = new FlowConverter(ofFlowStat.getMatch(),
-                            ofFlowStat.getActions());
-                    Flow flow = flowConverter.getFlow(node);
-                    flow.setPriority(ofFlowStat.getPriority());
-                    flow.setIdleTimeout(ofFlowStat.getIdleTimeout());
-                    flow.setHardTimeout(ofFlowStat.getHardTimeout());
-                    flow.setId(ofFlowStat.getCookie());
-                    flowOnNode = new FlowOnNode(flow);
-                    flowOnNode.setByteCount(ofFlowStat.getByteCount());
-                    flowOnNode.setPacketCount(ofFlowStat.getPacketCount());
-                    flowOnNode.setDurationSeconds(ofFlowStat
-                            .getDurationSeconds());
-                    flowOnNode.setDurationNanoseconds(ofFlowStat
-                            .getDurationNanoseconds());
-                } else if (ofStat instanceof V6StatsReply) {
-                    v6StatsReply = (V6StatsReply) ofStat;
-                    flowConverter = new FlowConverter(v6StatsReply.getMatch(),
-                            v6StatsReply.getActions());
-                    Flow flow = flowConverter.getFlow(node);
-                    flow.setPriority(v6StatsReply.getPriority());
-                    flow.setIdleTimeout(v6StatsReply.getIdleTimeout());
-                    flow.setHardTimeout(v6StatsReply.getHardTimeout());
-                    flow.setId(v6StatsReply.getCookie());
-                    flowOnNode = new FlowOnNode(flow);
-                    flowOnNode.setByteCount(v6StatsReply.getByteCount());
-                    flowOnNode.setPacketCount(v6StatsReply.getPacketCount());
-                    flowOnNode.setDurationSeconds(v6StatsReply
-                            .getDurationSeconds());
-                    flowOnNode.setDurationNanoseconds(v6StatsReply
-                            .getDurationNanoseconds());
-                } else {
-                    continue;
-                }
-                flowOnNodeList.add(flowOnNode);
-            }
-        }
-        log.trace("OFStatistics: {} FlowOnNode: {}", ofStatsList,
-                flowOnNodeList);
-        return flowOnNodeList;
-    }
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/InventoryService.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/InventoryService.java
deleted file mode 100644 (file)
index 39bbecf..0000000
+++ /dev/null
@@ -1,304 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow.internal;
-
-import java.util.Collections;
-import java.util.Dictionary;
-import java.util.HashMap;
-import java.util.HashSet;
-import java.util.Map;
-import java.util.Set;
-import java.util.concurrent.ConcurrentHashMap;
-import java.util.concurrent.ConcurrentMap;
-import java.util.concurrent.CopyOnWriteArraySet;
-
-import org.apache.felix.dm.Component;
-import org.opendaylight.controller.protocol_plugin.openflow.IInventoryProvider;
-import org.opendaylight.controller.protocol_plugin.openflow.IInventoryShimInternalListener;
-import org.opendaylight.controller.protocol_plugin.openflow.core.IController;
-import org.opendaylight.controller.protocol_plugin.openflow.core.ISwitch;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.core.UpdateType;
-import org.opendaylight.controller.sal.inventory.IPluginInInventoryService;
-import org.opendaylight.controller.sal.inventory.IPluginOutInventoryService;
-import org.opendaylight.controller.sal.utils.GlobalConstants;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * The class describes inventory service protocol plugin. One instance per
- * container of the network. Each instance gets container specific inventory
- * events from InventoryServiceShim. It interacts with SAL to pass inventory
- * data to the upper application.
- *
- *
- */
-public class InventoryService implements IInventoryShimInternalListener,
-        IPluginInInventoryService, IInventoryProvider {
-    protected static final Logger logger = LoggerFactory
-            .getLogger(InventoryService.class);
-    private final Set<IPluginOutInventoryService> pluginOutInventoryServices =
-            new CopyOnWriteArraySet<IPluginOutInventoryService>();
-    private IController controller = null;
-    private ConcurrentMap<Node, Map<String, Property>> nodeProps;
-    private ConcurrentMap<NodeConnector, Map<String, Property>> nodeConnectorProps;
-    private boolean isDefaultContainer = false;
-    private String containerName = null;
-
-    void setController(IController s) {
-        this.controller = s;
-    }
-
-    void unsetController(IController s) {
-        if (this.controller == s) {
-            this.controller = null;
-        }
-    }
-
-    /**
-     * Function called by the dependency manager when all the required
-     * dependencies are satisfied
-     *
-     */
-    @SuppressWarnings("rawtypes")
-    void init(Component c) {
-        logger.trace("INIT called!");
-
-        Dictionary props = c.getServiceProperties();
-        if (props != null) {
-            containerName = (String) props.get("containerName");
-            if (containerName != null) {
-                isDefaultContainer = containerName.equals(GlobalConstants.DEFAULT
-                        .toString());
-            }
-        }
-
-        nodeProps = new ConcurrentHashMap<Node, Map<String, Property>>();
-        nodeConnectorProps = new ConcurrentHashMap<NodeConnector, Map<String, Property>>();
-    }
-
-    /**
-     * Function called by the dependency manager when at least one dependency
-     * become unsatisfied or when the component is shutting down because for
-     * example bundle is being stopped.
-     *
-     */
-    void destroy() {
-        logger.trace("DESTROY called!");
-    }
-
-    /**
-     * Function called by dependency manager after "init ()" is called and after
-     * the services provided by the class are registered in the service registry
-     *
-     */
-    void start() {
-        logger.trace("START called!");
-    }
-
-    /**
-     * Function called by the dependency manager before the services exported by
-     * the component are unregistered, this will be followed by a "destroy ()"
-     * calls
-     *
-     */
-    void stop() {
-        logger.trace("STOP called!");
-        pluginOutInventoryServices.clear();
-    }
-
-    public void setPluginOutInventoryServices(IPluginOutInventoryService service) {
-        logger.trace("Got a service set request {}", service);
-        if (this.pluginOutInventoryServices != null) {
-            this.pluginOutInventoryServices.add(service);
-        }
-    }
-
-    public void unsetPluginOutInventoryServices(
-            IPluginOutInventoryService service) {
-        logger.trace("Got a service UNset request");
-        if (this.pluginOutInventoryServices != null) {
-            this.pluginOutInventoryServices.remove(service);
-        }
-    }
-
-    /**
-     * Retrieve nodes from openflow
-     */
-    @Override
-    public ConcurrentMap<Node, Map<String, Property>> getNodeProps() {
-        logger.debug("getNodePros for container {}", containerName);
-        return nodeProps;
-    }
-
-    // nothing to return
-    @Override
-    public Set<Node> getConfiguredNotConnectedNodes() {
-        return Collections.emptySet();
-    }
-
-    @Override
-    public ConcurrentMap<NodeConnector, Map<String, Property>> getNodeConnectorProps(
-            Boolean refresh) {
-        if (nodeConnectorProps == null) {
-            return null;
-        }
-
-        if (isDefaultContainer && refresh) {
-            Map<Long, ISwitch> switches = controller.getSwitches();
-            for (ISwitch sw : switches.values()) {
-                Map<NodeConnector, Set<Property>> ncProps = InventoryServiceHelper
-                        .OFSwitchToProps(sw);
-                for (Map.Entry<NodeConnector, Set<Property>> entry : ncProps
-                        .entrySet()) {
-                    updateNodeConnector(entry.getKey(), UpdateType.ADDED,
-                            entry.getValue());
-                }
-            }
-        }
-
-        return nodeConnectorProps;
-    }
-
-    @Override
-    public void updateNodeConnector(NodeConnector nodeConnector,
-            UpdateType type, Set<Property> props) {
-        logger.trace("updateNodeConnector {} type {}", nodeConnector,
-                type.getName());
-        if (nodeConnectorProps == null) {
-            logger.trace("nodeConnectorProps is null");
-            return;
-        }
-
-        Map<String, Property> propMap = nodeConnectorProps.get(nodeConnector);
-        switch (type) {
-        case ADDED:
-        case CHANGED:
-            if (propMap == null) {
-                propMap = new HashMap<String, Property>();
-            }
-            if (props != null) {
-                for (Property prop : props) {
-                    propMap.put(prop.getName(), prop);
-                }
-            }
-            nodeConnectorProps.put(nodeConnector, propMap);
-            break;
-        case REMOVED:
-            nodeConnectorProps.remove(nodeConnector);
-            break;
-        default:
-            return;
-        }
-
-        // update sal and discovery
-        for (IPluginOutInventoryService service : pluginOutInventoryServices) {
-            service.updateNodeConnector(nodeConnector, type, props);
-        }
-
-    }
-
-    private void addNode(Node node, Set<Property> props) {
-        if (nodeProps == null) {
-            return;
-        }
-
-        logger.trace("addNode: {} added, props: {} for container {}",
-                new Object[] { node, props, containerName });
-
-        // update local cache
-        Map<String, Property> propMap = nodeProps.get(node);
-        if (propMap == null) {
-            propMap = new HashMap<String, Property>();
-        }
-
-        if (props != null) {
-            for (Property prop : props) {
-                propMap.put(prop.getName(), prop);
-            }
-        }
-        nodeProps.put(node, propMap);
-
-        // update sal
-        for (IPluginOutInventoryService service : pluginOutInventoryServices) {
-            service.updateNode(node, UpdateType.ADDED, props);
-        }
-    }
-
-    private void removeNode(Node node) {
-        logger.trace("{} removed", node);
-        if (nodeProps == null) {
-            return;
-        }
-
-        // update local cache
-        nodeProps.remove(node);
-
-        Set<NodeConnector> removeSet = new HashSet<NodeConnector>();
-        for (NodeConnector nodeConnector : nodeConnectorProps.keySet()) {
-            if (nodeConnector.getNode().equals(node)) {
-                removeSet.add(nodeConnector);
-            }
-        }
-        for (NodeConnector nodeConnector : removeSet) {
-            nodeConnectorProps.remove(nodeConnector);
-        }
-
-        // update sal
-        for (IPluginOutInventoryService service : pluginOutInventoryServices) {
-            service.updateNode(node, UpdateType.REMOVED, null);
-        }
-    }
-
-    private void updateNode(Node node, Set<Property> properties) {
-        logger.trace("{} updated, props: {}", node, properties);
-        if ((nodeProps == null) || !nodeProps.containsKey(node) ||
-                (properties == null) || properties.isEmpty()) {
-            return;
-        }
-
-        // Update local cache with new properties
-        Set<Property> newProperties = new HashSet<Property>(properties.size());
-        Map<String, Property> propertyMap = nodeProps.get(node);
-        for (Property property : properties) {
-            String name = property.getName();
-            Property currentProperty = propertyMap.get(name);
-            if (!property.equals(currentProperty)) {
-                propertyMap.put(name, property);
-                newProperties.add(property);
-            }
-        }
-
-        // Update SAL if we got new properties
-        if (!newProperties.isEmpty()) {
-            for (IPluginOutInventoryService service : pluginOutInventoryServices) {
-                service.updateNode(node, UpdateType.CHANGED, newProperties);
-            }
-        }
-    }
-
-    @Override
-    public void updateNode(Node node, UpdateType type, Set<Property> props) {
-        switch (type) {
-        case ADDED:
-            addNode(node, props);
-            break;
-        case REMOVED:
-            removeNode(node);
-            break;
-        case CHANGED:
-            updateNode(node, props);
-            break;
-        default:
-            break;
-        }
-    }
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/InventoryServiceHelper.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/InventoryServiceHelper.java
deleted file mode 100644 (file)
index 5e5f056..0000000
+++ /dev/null
@@ -1,167 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow.internal;
-
-import java.util.HashMap;
-import java.util.HashSet;
-import java.util.Map;
-import java.util.Set;
-
-import org.opendaylight.controller.sal.core.Bandwidth;
-import org.opendaylight.controller.sal.core.AdvertisedBandwidth;
-import org.opendaylight.controller.sal.core.SupportedBandwidth;
-import org.opendaylight.controller.sal.core.PeerBandwidth;
-import org.opendaylight.controller.sal.core.Config;
-import org.opendaylight.controller.sal.core.Name;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.core.State;
-
-import org.opendaylight.controller.sal.utils.NodeCreator;
-
-import org.opendaylight.controller.protocol_plugin.openflow.core.ISwitch;
-import org.openflow.protocol.OFPhysicalPort;
-import org.openflow.protocol.OFPhysicalPort.OFPortConfig;
-import org.openflow.protocol.OFPhysicalPort.OFPortFeatures;
-import org.openflow.protocol.OFPhysicalPort.OFPortState;
-
-/**
- * The class provides helper functions to retrieve inventory properties from
- * OpenFlow messages
- */
-public class InventoryServiceHelper {
-    /*
-     * Returns BandWidth property from OpenFlow OFPhysicalPort features
-     */
-    public static Bandwidth OFPortToBandWidth(int portFeatures) {
-        Bandwidth bw = null;
-        int value = portFeatures
-                & (OFPortFeatures.OFPPF_10MB_FD.getValue()
-                        | OFPortFeatures.OFPPF_10MB_HD.getValue()
-                        | OFPortFeatures.OFPPF_100MB_FD.getValue()
-                        | OFPortFeatures.OFPPF_100MB_HD.getValue()
-                        | OFPortFeatures.OFPPF_1GB_FD.getValue()
-                        | OFPortFeatures.OFPPF_1GB_HD.getValue() | OFPortFeatures.OFPPF_10GB_FD
-                        .getValue());
-
-        switch (value) {
-        case 1:
-        case 2:
-            bw = new Bandwidth(Bandwidth.BW10Mbps);
-            break;
-        case 4:
-        case 8:
-            bw = new Bandwidth(Bandwidth.BW100Mbps);
-            break;
-        case 16:
-        case 32:
-            bw = new Bandwidth(Bandwidth.BW1Gbps);
-            break;
-        case 64:
-            bw = new Bandwidth(Bandwidth.BW10Gbps);
-            break;
-        default:
-            break;
-        }
-        return bw;
-    }
-
-    /*
-     * Returns Config property from OpenFLow OFPhysicalPort config
-     */
-    public static Config OFPortToConfig(int portConfig) {
-        Config config;
-        if ((OFPortConfig.OFPPC_PORT_DOWN.getValue() & portConfig) != 0)
-            config = new Config(Config.ADMIN_DOWN);
-        else
-            config = new Config(Config.ADMIN_UP);
-        return config;
-    }
-
-    /*
-     * Returns State property from OpenFLow OFPhysicalPort state
-     */
-    public static State OFPortToState(int portState) {
-        State state;
-        if ((OFPortState.OFPPS_LINK_DOWN.getValue() & portState) != 0)
-            state = new State(State.EDGE_DOWN);
-        else
-            state = new State(State.EDGE_UP);
-        return state;
-    }
-
-    /*
-     * Returns set of properties from OpenFLow OFPhysicalPort
-     */
-    public static Set<Property> OFPortToProps(OFPhysicalPort port) {
-        Set<Property> props = new HashSet<Property>();
-        Bandwidth bw = InventoryServiceHelper.OFPortToBandWidth(port
-                .getCurrentFeatures());
-        if (bw != null) {
-            props.add(bw);
-        }
-
-        Bandwidth abw = InventoryServiceHelper.OFPortToBandWidth(port.getAdvertisedFeatures());
-        if (abw != null) {
-                AdvertisedBandwidth a = new AdvertisedBandwidth(abw.getValue());
-                if (a != null) {
-                        props.add(a);
-                }
-        }
-        Bandwidth sbw = InventoryServiceHelper.OFPortToBandWidth(port.getSupportedFeatures());
-        if (sbw != null) {
-                SupportedBandwidth s = new SupportedBandwidth(sbw.getValue());
-                if (s != null) {
-                        props.add(s);
-                }
-        }
-        Bandwidth pbw = InventoryServiceHelper.OFPortToBandWidth(port.getPeerFeatures());
-        if (pbw != null) {
-                PeerBandwidth p = new PeerBandwidth(pbw.getValue());
-                if (p != null) {
-                        props.add(p);
-                }
-        }
-        props.add(new Name(port.getName()));
-        props.add(InventoryServiceHelper.OFPortToConfig(port.getConfig()));
-        props.add(InventoryServiceHelper.OFPortToState(port.getState()));
-        return props;
-    }
-
-    /*
-     * Returns set of properties for each nodeConnector in an OpenFLow switch
-     */
-    public static Map<NodeConnector, Set<Property>> OFSwitchToProps(ISwitch sw) {
-        Map<NodeConnector, Set<Property>> ncProps = new HashMap<NodeConnector, Set<Property>>();
-
-        if (sw == null) {
-            return ncProps;
-        }
-
-        Node node = NodeCreator.createOFNode(sw.getId());
-        if (node == null) {
-            return ncProps;
-        }
-
-        Set<Property> props;
-        NodeConnector nodeConnector;
-        OFPhysicalPort port;
-        Map<Short, OFPhysicalPort> ports = sw.getPhysicalPorts();
-        for (Map.Entry<Short, OFPhysicalPort> entry : ports.entrySet()) {
-            nodeConnector = PortConverter.toNodeConnector(entry.getKey(), node);
-            port = entry.getValue();
-            props = InventoryServiceHelper.OFPortToProps(port);
-            ncProps.put(nodeConnector, props);
-        }
-
-        return ncProps;
-    }
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/InventoryServiceShim.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/InventoryServiceShim.java
deleted file mode 100644 (file)
index 2b26ecb..0000000
+++ /dev/null
@@ -1,643 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow.internal;
-
-import java.util.ArrayList;
-import java.util.Collections;
-import java.util.Date;
-import java.util.HashSet;
-import java.util.List;
-import java.util.Map;
-import java.util.Set;
-import java.util.concurrent.ConcurrentHashMap;
-import java.util.concurrent.ConcurrentMap;
-import java.util.concurrent.CopyOnWriteArrayList;
-import java.util.concurrent.CopyOnWriteArraySet;
-
-import org.opendaylight.controller.protocol_plugin.openflow.IInventoryShimExternalListener;
-import org.opendaylight.controller.protocol_plugin.openflow.IInventoryShimInternalListener;
-import org.opendaylight.controller.protocol_plugin.openflow.IOFStatisticsListener;
-import org.opendaylight.controller.protocol_plugin.openflow.core.IController;
-import org.opendaylight.controller.protocol_plugin.openflow.core.IMessageListener;
-import org.opendaylight.controller.protocol_plugin.openflow.core.ISwitch;
-import org.opendaylight.controller.protocol_plugin.openflow.core.ISwitchStateListener;
-import org.opendaylight.controller.sal.action.SupportedFlowActions;
-import org.opendaylight.controller.sal.connection.ConnectionLocality;
-import org.opendaylight.controller.sal.connection.IPluginOutConnectionService;
-import org.opendaylight.controller.sal.core.Buffers;
-import org.opendaylight.controller.sal.core.Capabilities;
-import org.opendaylight.controller.sal.core.ContainerFlow;
-import org.opendaylight.controller.sal.core.Description;
-import org.opendaylight.controller.sal.core.IContainerAware;
-import org.opendaylight.controller.sal.core.IContainerListener;
-import org.opendaylight.controller.sal.core.MacAddress;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.core.Tables;
-import org.opendaylight.controller.sal.core.TimeStamp;
-import org.opendaylight.controller.sal.core.UpdateType;
-import org.opendaylight.controller.sal.utils.GlobalConstants;
-import org.opendaylight.controller.sal.utils.NodeCreator;
-import org.openflow.protocol.OFMessage;
-import org.openflow.protocol.OFPortStatus;
-import org.openflow.protocol.OFPortStatus.OFPortReason;
-import org.openflow.protocol.OFType;
-import org.openflow.protocol.statistics.OFDescriptionStatistics;
-import org.openflow.protocol.statistics.OFStatistics;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * The class describes a shim layer that bridges inventory events from Openflow
- * core to various listeners. The notifications are filtered based on container
- * configurations.
- *
- *
- */
-public class InventoryServiceShim implements IContainerListener,
-        IMessageListener, ISwitchStateListener, IOFStatisticsListener, IContainerAware {
-    protected static final Logger logger = LoggerFactory
-            .getLogger(InventoryServiceShim.class);
-    private IController controller = null;
-    private final ConcurrentMap<String, IInventoryShimInternalListener> inventoryShimInternalListeners = new ConcurrentHashMap<String, IInventoryShimInternalListener>();
-    private final Set<IInventoryShimInternalListener> globalInventoryShimInternalListeners = new HashSet<IInventoryShimInternalListener>();
-    private final List<IInventoryShimExternalListener> inventoryShimExternalListeners = new CopyOnWriteArrayList<IInventoryShimExternalListener>();
-    private final ConcurrentMap<NodeConnector, Set<String>> nodeConnectorContainerMap = new ConcurrentHashMap<NodeConnector, Set<String>>();
-    private final ConcurrentMap<Node, Set<String>> nodeContainerMap = new ConcurrentHashMap<Node, Set<String>>();
-    private final ConcurrentMap<NodeConnector, Set<Property>> nodeConnectorProps = new ConcurrentHashMap<NodeConnector, Set<Property>>();
-    private final ConcurrentMap<Node, Set<Property>> nodeProps = new ConcurrentHashMap<Node, Set<Property>>();
-    private IPluginOutConnectionService connectionOutService;
-
-    void setController(IController s) {
-        this.controller = s;
-    }
-
-    void unsetController(IController s) {
-        if (this.controller == s) {
-            this.controller = null;
-        }
-    }
-
-    void setInventoryShimGlobalInternalListener(Map<?, ?> props,
-            IInventoryShimInternalListener s) {
-        if ((this.globalInventoryShimInternalListeners != null)) {
-            this.globalInventoryShimInternalListeners.add(s);
-        }
-    }
-
-    void unsetInventoryShimGlobalInternalListener(Map<?, ?> props,
-            IInventoryShimInternalListener s) {
-        if ((this.globalInventoryShimInternalListeners != null)) {
-            this.globalInventoryShimInternalListeners.remove(s);
-        }
-    }
-
-    void setInventoryShimInternalListener(Map<?, ?> props,
-            IInventoryShimInternalListener s) {
-        if (props == null) {
-            logger.error("setInventoryShimInternalListener property is null");
-            return;
-        }
-        String containerName = (String) props.get("containerName");
-        if (containerName == null) {
-            logger.error("setInventoryShimInternalListener containerName not supplied");
-            return;
-        }
-        if ((this.inventoryShimInternalListeners != null)
-                && !this.inventoryShimInternalListeners.containsValue(s)) {
-            this.inventoryShimInternalListeners.put(containerName, s);
-            logger.trace(
-                    "Added inventoryShimInternalListener for container {}",
-                    containerName);
-        }
-    }
-
-    void unsetInventoryShimInternalListener(Map<?, ?> props,
-            IInventoryShimInternalListener s) {
-        if (props == null) {
-            logger.error("unsetInventoryShimInternalListener property is null");
-            return;
-        }
-        String containerName = (String) props.get("containerName");
-        if (containerName == null) {
-            logger.error("setInventoryShimInternalListener containerName not supplied");
-            return;
-        }
-        if ((this.inventoryShimInternalListeners != null)
-                && this.inventoryShimInternalListeners.get(containerName) != null
-                && this.inventoryShimInternalListeners.get(containerName)
-                        .equals(s)) {
-            this.inventoryShimInternalListeners.remove(containerName);
-            logger.trace(
-                    "Removed inventoryShimInternalListener for container {}",
-                    containerName);
-        }
-    }
-
-    void setInventoryShimExternalListener(IInventoryShimExternalListener s) {
-        logger.trace("Set inventoryShimExternalListener {}", s);
-        if ((this.inventoryShimExternalListeners != null)
-                && !this.inventoryShimExternalListeners.contains(s)) {
-            this.inventoryShimExternalListeners.add(s);
-        }
-    }
-
-    void unsetInventoryShimExternalListener(IInventoryShimExternalListener s) {
-        logger.trace("Unset inventoryShimExternalListener {}", s);
-        if ((this.inventoryShimExternalListeners != null)
-                && this.inventoryShimExternalListeners.contains(s)) {
-            this.inventoryShimExternalListeners.remove(s);
-        }
-    }
-
-    void setIPluginOutConnectionService(IPluginOutConnectionService s) {
-        connectionOutService = s;
-    }
-
-    void unsetIPluginOutConnectionService(IPluginOutConnectionService s) {
-        if (connectionOutService == s) {
-            connectionOutService = null;
-        }
-    }
-
-    /**
-     * Function called by the dependency manager when all the required
-     * dependencies are satisfied
-     *
-     */
-    void init() {
-        this.controller.addMessageListener(OFType.PORT_STATUS, this);
-        this.controller.addSwitchStateListener(this);
-    }
-
-    /**
-     * Function called after registering the service in OSGi service registry.
-     */
-    void started() {
-        /* Start with existing switches */
-        startService();
-    }
-
-    /**
-     * Function called by the dependency manager when at least one dependency
-     * become unsatisfied or when the component is shutting down because for
-     * example bundle is being stopped.
-     *
-     */
-    void destroy() {
-        this.controller.removeMessageListener(OFType.PACKET_IN, this);
-        this.controller.removeSwitchStateListener(this);
-
-        this.inventoryShimInternalListeners.clear();
-        this.nodeConnectorContainerMap.clear();
-        this.nodeContainerMap.clear();
-        this.globalInventoryShimInternalListeners.clear();
-        this.controller = null;
-    }
-
-    @Override
-    public void receive(ISwitch sw, OFMessage msg) {
-        if (msg instanceof OFPortStatus) {
-            handlePortStatusMessage(sw, (OFPortStatus) msg);
-        }
-        return;
-    }
-
-    protected void handlePortStatusMessage(ISwitch sw, OFPortStatus m) {
-        Node node = NodeCreator.createOFNode(sw.getId());
-        NodeConnector nodeConnector = PortConverter.toNodeConnector(
-            m.getDesc().getPortNumber(), node);
-        // get node connector properties
-        Set<Property> props = InventoryServiceHelper.OFPortToProps(m.getDesc());
-
-        UpdateType type = null;
-        if (m.getReason() == (byte) OFPortReason.OFPPR_ADD.ordinal()) {
-            type = UpdateType.ADDED;
-            nodeConnectorProps.put(nodeConnector, props);
-        } else if (m.getReason() == (byte) OFPortReason.OFPPR_DELETE.ordinal()) {
-            type = UpdateType.REMOVED;
-            nodeConnectorProps.remove(nodeConnector);
-        } else if (m.getReason() == (byte) OFPortReason.OFPPR_MODIFY.ordinal()) {
-            type = UpdateType.CHANGED;
-            nodeConnectorProps.put(nodeConnector, props);
-        }
-
-        logger.trace("handlePortStatusMessage {} type {}", nodeConnector, type);
-
-        if (type != null) {
-            notifyInventoryShimListener(nodeConnector, type, props);
-        }
-    }
-
-    @Override
-    public void switchAdded(ISwitch sw) {
-        if (sw == null) {
-            logger.debug("Ignore null switch addition");
-            return;
-        }
-        Node node = NodeCreator.createOFNode(sw.getId());
-        if ((nodeProps.get(node) != null)  && (connectionOutService.isLocal(node))) {
-            logger.debug("Ignore switchAdded {}", sw);
-            return;
-        }
-
-        // Add all the nodeConnectors of this switch if any
-        Map<NodeConnector, Set<Property>> ncProps = InventoryServiceHelper.OFSwitchToProps(sw);
-        if (!ncProps.isEmpty()) {
-            for (Map.Entry<NodeConnector, Set<Property>> entry : ncProps.entrySet()) {
-                Set<Property> props = new HashSet<Property>();
-                Set<Property> prop = entry.getValue();
-                if (prop != null) {
-                    props.addAll(prop);
-                }
-                nodeConnectorProps.put(entry.getKey(), props);
-                notifyInventoryShimListener(entry.getKey(), UpdateType.ADDED, entry.getValue());
-            }
-        } else {
-            /*
-             * If no node connector is present, publish the node addition itself
-             * in order to let Connection Manager properly set the node locality
-             */
-            this.notifyInventoryShimListener(node, UpdateType.ADDED, Collections.<Property>emptySet());
-        }
-
-        // Add this node
-        if (connectionOutService.getLocalityStatus(node) != ConnectionLocality.NOT_CONNECTED) {
-            addNode(sw);
-        } else {
-            logger.debug("Skipping node addition due to Connectivity Status : {}", connectionOutService.getLocalityStatus(node).name());
-        }
-    }
-
-    @Override
-    public void switchDeleted(ISwitch sw) {
-        if (sw == null) {
-            return;
-        }
-
-        removeNode(sw);
-    }
-
-    @Override
-    public void containerModeUpdated(UpdateType t) {
-        // do nothing
-    }
-
-    @Override
-    public void tagUpdated(String containerName, Node n, short oldTag,
-            short newTag, UpdateType t) {
-        logger.debug("tagUpdated: {} type {} for container {}", new Object[] {
-                n, t, containerName });
-    }
-
-    @Override
-    public void containerFlowUpdated(String containerName,
-            ContainerFlow previousFlow, ContainerFlow currentFlow, UpdateType t) {
-    }
-
-    @Override
-    public void nodeConnectorUpdated(String containerName, NodeConnector nc, UpdateType t) {
-        logger.debug("nodeConnectorUpdated: {} type {} for container {}", new Object[] { nc, t, containerName });
-        Node node = nc.getNode();
-        Set<String> ncContainers = this.nodeConnectorContainerMap.get(nc);
-        Set<String> nodeContainers = this.nodeContainerMap.get(node);
-        if (ncContainers == null) {
-            ncContainers = new CopyOnWriteArraySet<String>();
-        }
-        if (nodeContainers == null) {
-            nodeContainers = new CopyOnWriteArraySet<String>();
-        }
-        boolean notifyNodeUpdate = false;
-
-        switch (t) {
-        case ADDED:
-            if (ncContainers.add(containerName)) {
-                this.nodeConnectorContainerMap.put(nc, ncContainers);
-            }
-            if (nodeContainers.add(containerName)) {
-                this.nodeContainerMap.put(node, nodeContainers);
-                notifyNodeUpdate = true;
-            }
-            break;
-        case REMOVED:
-            if (ncContainers.remove(containerName)) {
-                if (ncContainers.isEmpty()) {
-                    // Do cleanup to reduce memory footprint if no
-                    // elements to be tracked
-                    this.nodeConnectorContainerMap.remove(nc);
-                } else {
-                    this.nodeConnectorContainerMap.put(nc, ncContainers);
-                }
-            }
-            boolean nodeContainerUpdate = true;
-            for (NodeConnector ncContainer : nodeConnectorContainerMap.keySet()) {
-                if ((ncContainer.getNode().equals(node)) && (nodeConnectorContainerMap.get(ncContainer).contains(containerName))) {
-                    nodeContainerUpdate = false;
-                    break;
-                }
-            }
-            if (nodeContainerUpdate) {
-                nodeContainers.remove(containerName);
-                notifyNodeUpdate = true;
-                if (nodeContainers.isEmpty()) {
-                    this.nodeContainerMap.remove(node);
-                } else {
-                    this.nodeContainerMap.put(node, nodeContainers);
-                }
-            }
-            break;
-        case CHANGED:
-            break;
-        }
-
-        Set<Property> nodeProp = nodeProps.get(node);
-        if (nodeProp == null) {
-            return;
-        }
-        Set<Property> ncProp = nodeConnectorProps.get(nc);
-        // notify InventoryService
-        notifyInventoryShimInternalListener(containerName, nc, t, ncProp);
-
-        if (notifyNodeUpdate) {
-            notifyInventoryShimInternalListener(containerName, node, t, nodeProp);
-        }
-    }
-
-    private void notifyInventoryShimExternalListener(Node node, UpdateType type, Set<Property> props) {
-        for (IInventoryShimExternalListener s : this.inventoryShimExternalListeners) {
-            s.updateNode(node, type, props);
-        }
-    }
-
-    private void notifyInventoryShimExternalListener(NodeConnector nodeConnector, UpdateType type, Set<Property> props) {
-        for (IInventoryShimExternalListener s : this.inventoryShimExternalListeners) {
-            s.updateNodeConnector(nodeConnector, type, props);
-        }
-    }
-
-    private void notifyInventoryShimInternalListener(String container,
-            NodeConnector nodeConnector, UpdateType type, Set<Property> props) {
-        IInventoryShimInternalListener inventoryShimInternalListener = inventoryShimInternalListeners.get(container);
-        if (inventoryShimInternalListener != null) {
-            inventoryShimInternalListener.updateNodeConnector(nodeConnector, type, props);
-            logger.trace("notifyInventoryShimInternalListener {} type {} for container {}", new Object[] {
-                    nodeConnector, type, container });
-        }
-    }
-
-    /*
-     * Notify all internal and external listeners
-     */
-    private void notifyInventoryShimListener(NodeConnector nodeConnector, UpdateType type, Set<Property> props) {
-
-        //establish locality before notifying
-        boolean isNodeLocal;
-        if (type == UpdateType.REMOVED){
-            //if removing get the locality first
-            isNodeLocal = connectionOutService.isLocal(nodeConnector.getNode());
-            notifyGlobalInventoryShimInternalListener(nodeConnector, type, props);
-        } else {
-            notifyGlobalInventoryShimInternalListener(nodeConnector, type, props);
-            isNodeLocal = connectionOutService.isLocal(nodeConnector.getNode());
-        }
-
-        if (isNodeLocal) {
-            // notify other containers
-            Set<String> containers = (nodeConnectorContainerMap.get(nodeConnector) == null) ? new HashSet<String>()
-                    : new HashSet<String>(nodeConnectorContainerMap.get(nodeConnector));
-            containers.add(GlobalConstants.DEFAULT.toString());
-            for (String container : containers) {
-                notifyInventoryShimInternalListener(container, nodeConnector, type, props);
-            }
-
-            // Notify plugin listeners (Discovery, DataPacket, OFstats etc.)
-            notifyInventoryShimExternalListener(nodeConnector, type, props);
-
-            logger.debug("Connection service accepted the inventory notification for {} {}", nodeConnector, type);
-        } else {
-            logger.debug("Connection service dropped the inventory notification for {} {}", nodeConnector, type);
-        }
-    }
-
-    /*
-     * Notify all internal and external listeners
-     */
-    private void notifyInventoryShimListener(Node node, UpdateType type, Set<Property> props) {
-
-        //establish locality before notifying
-        boolean isNodeLocal;
-        if (type == UpdateType.REMOVED){
-            //if removing get the locality first
-            isNodeLocal = connectionOutService.isLocal(node);
-            notifyGlobalInventoryShimInternalListener(node, type, props);
-        } else {
-            notifyGlobalInventoryShimInternalListener(node, type, props);
-            isNodeLocal = connectionOutService.isLocal(node);
-        }
-
-        if (isNodeLocal) {
-            // Now notify other containers
-            Set<String> containers = (nodeContainerMap.get(node) == null) ? new HashSet<String>()
-                    : new HashSet<String>(nodeContainerMap.get(node));
-            containers.add(GlobalConstants.DEFAULT.toString());
-            for (String container : containers) {
-                notifyInventoryShimInternalListener(container, node, type, props);
-            }
-
-            // Notify plugin listeners (Discovery, DataPacket, OFstats etc.)
-            notifyInventoryShimExternalListener(node, type, props);
-
-            logger.debug("Connection service accepted the inventory notification for {} {}", node, type);
-        } else {
-            logger.debug("Connection service dropped the inventory notification for {} {}", node, type);
-        }
-    }
-
-    private void notifyGlobalInventoryShimInternalListener(Node node, UpdateType type, Set<Property> props) {
-        for (IInventoryShimInternalListener globalListener : globalInventoryShimInternalListeners) {
-            globalListener.updateNode(node, type, props);
-            logger.trace("notifyGlobalInventoryShimInternalListener {} type {}", new Object[] { node, type });
-        }
-    }
-
-    private void notifyGlobalInventoryShimInternalListener(NodeConnector nodeConnector, UpdateType type, Set<Property> props) {
-        for (IInventoryShimInternalListener globalListener : globalInventoryShimInternalListeners) {
-            globalListener.updateNodeConnector(nodeConnector, type, props);
-            logger.trace(
-                    "notifyGlobalInventoryShimInternalListener {} type {}",
-                    new Object[] { nodeConnector, type });
-        }
-    }
-
-    private void notifyInventoryShimInternalListener(String container,
-            Node node, UpdateType type, Set<Property> props) {
-        IInventoryShimInternalListener inventoryShimInternalListener = inventoryShimInternalListeners
-                .get(container);
-        if (inventoryShimInternalListener != null) {
-            inventoryShimInternalListener.updateNode(node, type, props);
-            logger.trace(
-                    "notifyInventoryShimInternalListener {} type {} for container {}",
-                    new Object[] { node, type, container });
-        }
-    }
-
-    private void addNode(ISwitch sw) {
-        Node node = NodeCreator.createOFNode(sw.getId());
-        UpdateType type = UpdateType.ADDED;
-
-        Set<Property> props = new HashSet<Property>();
-        Long sid = (Long) node.getID();
-
-        Date connectedSince = sw.getConnectedDate();
-        Long connectedSinceTime = (connectedSince == null) ? 0 : connectedSince
-                .getTime();
-        props.add(new TimeStamp(connectedSinceTime, "connectedSince"));
-        props.add(new MacAddress(deriveMacAddress(sid)));
-
-        byte tables = sw.getTables();
-        Tables t = new Tables(tables);
-        if (t != null) {
-            props.add(t);
-        }
-        int cap = sw.getCapabilities();
-        Capabilities c = new Capabilities(cap);
-        if (c != null) {
-            props.add(c);
-        }
-        int act = sw.getActions();
-        SupportedFlowActions a = new SupportedFlowActions(FlowConverter.getFlowActions(act));
-        if (a != null) {
-            props.add(a);
-        }
-        int buffers = sw.getBuffers();
-        Buffers b = new Buffers(buffers);
-        if (b != null) {
-            props.add(b);
-        }
-
-        if ((nodeProps.get(node) == null) &&  (connectionOutService.isLocal(node)))  {
-            // The switch is connected for the first time, flush all flows
-            // that may exist on this switch
-            sw.deleteAllFlows();
-       }
-        nodeProps.put(node, props);
-        // Notify all internal and external listeners
-        notifyInventoryShimListener(node, type, props);
-    }
-
-    private void removeNode(ISwitch sw) {
-        Node node = NodeCreator.createOFNode(sw.getId());
-        if(node == null) {
-            return;
-        }
-        removeNodeConnectorProps(node);
-        nodeProps.remove(node);
-        UpdateType type = UpdateType.REMOVED;
-        // Notify all internal and external listeners
-        notifyInventoryShimListener(node, type, null);
-    }
-
-    private void startService() {
-        // Get a snapshot of all the existing switches
-        Map<Long, ISwitch> switches = this.controller.getSwitches();
-        for (ISwitch sw : switches.values()) {
-            switchAdded(sw);
-        }
-    }
-
-    private void removeNodeConnectorProps(Node node) {
-        List<NodeConnector> ncList = new ArrayList<NodeConnector>();
-        for (NodeConnector nc : nodeConnectorProps.keySet()) {
-            if (nc.getNode().equals(node)) {
-                ncList.add(nc);
-            }
-        }
-        for (NodeConnector nc : ncList) {
-            nodeConnectorProps.remove(nc);
-        }
-    }
-
-    @Override
-    public void descriptionStatisticsRefreshed(Long switchId, List<OFStatistics> descriptionStats) {
-        Node node = NodeCreator.createOFNode(switchId);
-        Set<Property> properties = new HashSet<Property>(1);
-        OFDescriptionStatistics ofDesc = (OFDescriptionStatistics) descriptionStats.get(0);
-        Description desc = new Description(ofDesc.getDatapathDescription());
-        properties.add(desc);
-
-        // Notify all internal and external listeners
-        notifyInventoryShimListener(node, UpdateType.CHANGED, properties);
-    }
-
-    private byte[] deriveMacAddress(long dpid) {
-        byte[] mac = new byte[] { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 };
-
-        for (short i = 0; i < 6; i++) {
-            mac[5 - i] = (byte) dpid;
-            dpid >>= 8;
-        }
-
-        return mac;
-    }
-
-    @Override
-    public void flowStatisticsRefreshed(Long switchId, List<OFStatistics> flows) {
-        // Nothing to do
-    }
-
-    @Override
-    public void portStatisticsRefreshed(Long switchId, List<OFStatistics> ports) {
-        // Nothing to do
-    }
-
-    @Override
-    public void tableStatisticsRefreshed(Long switchId, List<OFStatistics> tables) {
-        // Nothing to do
-    }
-
-    @Override
-    public void containerCreate(String containerName) {
-        // Nothing to do
-    }
-
-    @Override
-    public void containerDestroy(String containerName) {
-        Set<NodeConnector> removeNodeConnectorSet = new HashSet<NodeConnector>();
-        Set<Node> removeNodeSet = new HashSet<Node>();
-        for (Map.Entry<NodeConnector, Set<String>> entry : nodeConnectorContainerMap.entrySet()) {
-            Set<String> ncContainers = entry.getValue();
-            if (ncContainers.contains(containerName)) {
-                NodeConnector nodeConnector = entry.getKey();
-                removeNodeConnectorSet.add(nodeConnector);
-            }
-        }
-        for (Map.Entry<Node, Set<String>> entry : nodeContainerMap.entrySet()) {
-            Set<String> nodeContainers = entry.getValue();
-            if (nodeContainers.contains(containerName)) {
-                Node node = entry.getKey();
-                removeNodeSet.add(node);
-            }
-        }
-        for (NodeConnector nodeConnector : removeNodeConnectorSet) {
-            Set<String> ncContainers = nodeConnectorContainerMap.get(nodeConnector);
-            ncContainers.remove(containerName);
-            if (ncContainers.isEmpty()) {
-                nodeConnectorContainerMap.remove(nodeConnector);
-            }
-        }
-        for (Node node : removeNodeSet) {
-            Set<String> nodeContainers = nodeContainerMap.get(node);
-            nodeContainers.remove(containerName);
-            if (nodeContainers.isEmpty()) {
-                nodeContainerMap.remove(node);
-            }
-        }
-    }
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/OFStatisticsManager.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/OFStatisticsManager.java
deleted file mode 100644 (file)
index e5883d6..0000000
+++ /dev/null
@@ -1,1216 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow.internal;
-
-import java.nio.ByteBuffer;
-import java.util.ArrayList;
-import java.util.Collections;
-import java.util.Deque;
-import java.util.HashMap;
-import java.util.List;
-import java.util.Map;
-import java.util.Map.Entry;
-import java.util.Set;
-import java.util.Timer;
-import java.util.TimerTask;
-import java.util.concurrent.BlockingQueue;
-import java.util.concurrent.ConcurrentHashMap;
-import java.util.concurrent.ConcurrentMap;
-import java.util.concurrent.CopyOnWriteArraySet;
-import java.util.concurrent.LinkedBlockingDeque;
-import java.util.concurrent.LinkedBlockingQueue;
-
-import org.eclipse.osgi.framework.console.CommandInterpreter;
-import org.eclipse.osgi.framework.console.CommandProvider;
-import org.opendaylight.controller.protocol_plugin.openflow.IInventoryShimExternalListener;
-import org.opendaylight.controller.protocol_plugin.openflow.IOFStatisticsListener;
-import org.opendaylight.controller.protocol_plugin.openflow.IOFStatisticsManager;
-import org.opendaylight.controller.protocol_plugin.openflow.core.IController;
-import org.opendaylight.controller.protocol_plugin.openflow.core.ISwitch;
-import org.opendaylight.controller.protocol_plugin.openflow.vendorextension.v6extension.V6Match;
-import org.opendaylight.controller.protocol_plugin.openflow.vendorextension.v6extension.V6StatsReply;
-import org.opendaylight.controller.protocol_plugin.openflow.vendorextension.v6extension.V6StatsRequest;
-import org.opendaylight.controller.sal.connection.IPluginOutConnectionService;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.core.UpdateType;
-import org.opendaylight.controller.sal.utils.HexEncode;
-import org.openflow.protocol.OFError;
-import org.openflow.protocol.OFMatch;
-import org.openflow.protocol.OFPort;
-import org.openflow.protocol.OFStatisticsRequest;
-import org.openflow.protocol.statistics.OFAggregateStatisticsRequest;
-import org.openflow.protocol.statistics.OFFlowStatisticsReply;
-import org.openflow.protocol.statistics.OFFlowStatisticsRequest;
-import org.openflow.protocol.statistics.OFPortStatisticsReply;
-import org.openflow.protocol.statistics.OFPortStatisticsRequest;
-import org.openflow.protocol.statistics.OFQueueStatisticsRequest;
-import org.openflow.protocol.statistics.OFStatistics;
-import org.openflow.protocol.statistics.OFStatisticsType;
-import org.openflow.protocol.statistics.OFTableStatistics;
-import org.openflow.protocol.statistics.OFVendorStatistics;
-import org.openflow.util.HexString;
-import org.osgi.framework.BundleContext;
-import org.osgi.framework.FrameworkUtil;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * Periodically polls the different OF statistics from the OF switches, caches
- * them, and publishes results towards SAL. It also provides an API to directly
- * query the switch for any specific statistics.
- */
-public class OFStatisticsManager implements IOFStatisticsManager, IInventoryShimExternalListener, CommandProvider {
-    private static final Logger log = LoggerFactory.getLogger(OFStatisticsManager.class);
-    private static final int INITIAL_SIZE = 64;
-    private static final long FLOW_STATS_PERIOD = 10000;
-    private static final long DESC_STATS_PERIOD = 60000;
-    private static final long PORT_STATS_PERIOD = 5000;
-    private static final long TABLE_STATS_PERIOD = 10000;
-    private static final long TICK = 1000;
-    private static short statisticsTickNumber = (short) (FLOW_STATS_PERIOD / TICK);
-    private static short descriptionTickNumber = (short) (DESC_STATS_PERIOD / TICK);
-    private static short portTickNumber = (short) (PORT_STATS_PERIOD / TICK);
-    private static short tableTickNumber = (short) (TABLE_STATS_PERIOD / TICK);
-    private static short factoredSamples = (short) 2;
-    private static short counter = 1;
-    private IController controller = null;
-    private ConcurrentMap<Long, List<OFStatistics>> flowStatistics;
-    private ConcurrentMap<Long, List<OFStatistics>> descStatistics;
-    private ConcurrentMap<Long, List<OFStatistics>> portStatistics;
-    private ConcurrentMap<Long, List<OFStatistics>> tableStatistics;
-    private ConcurrentMap<Long, StatisticsTicks> statisticsTimerTicks;
-    protected BlockingQueue<StatsRequest> pendingStatsRequests;
-    protected BlockingQueue<Long> switchPortStatsUpdated;
-    private Thread statisticsCollector;
-    private Thread txRatesUpdater;
-    private Timer statisticsTimer;
-    private TimerTask statisticsTimerTask;
-    private ConcurrentMap<Long, Boolean> switchSupportsVendorExtStats;
-    // Per port sampled (every portStatsPeriod) transmit rate
-    private Map<Long, Map<Short, TxRates>> txRates;
-    private Set<IOFStatisticsListener> statisticsListeners = new CopyOnWriteArraySet<IOFStatisticsListener>();
-
-    /**
-     * The object containing the latest factoredSamples tx rate samples for a
-     * given switch port
-     */
-    protected class TxRates {
-        // contains the latest factoredSamples sampled transmitted bytes
-        Deque<Long> sampledTxBytes;
-
-        public TxRates() {
-            sampledTxBytes = new LinkedBlockingDeque<Long>();
-        }
-
-        public void update(Long txBytes) {
-            /*
-             * Based on how many samples our average works on, we might have to
-             * remove the oldest sample
-             */
-            if (sampledTxBytes.size() == factoredSamples) {
-                sampledTxBytes.removeLast();
-            }
-
-            // Add the latest sample to the top of the queue
-            sampledTxBytes.addFirst(txBytes);
-        }
-
-        /**
-         * Returns the average transmit rate in bps
-         *
-         * @return the average transmit rate [bps]
-         */
-        public long getAverageTxRate() {
-            long average = 0;
-            /*
-             * If we cannot provide the value for the time window length set
-             */
-            if (sampledTxBytes.size() < factoredSamples) {
-                return average;
-            }
-            long increment = sampledTxBytes.getFirst() - sampledTxBytes
-                    .getLast();
-            long timePeriod = factoredSamples * PORT_STATS_PERIOD / TICK;
-            average = (8L * increment) / timePeriod;
-            return average;
-        }
-    }
-
-    public void setController(IController core) {
-        this.controller = core;
-    }
-
-    public void unsetController(IController core) {
-        if (this.controller == core) {
-            this.controller = null;
-        }
-    }
-
-    private short getStatsQueueSize() {
-        String statsQueueSizeStr = System.getProperty("of.statsQueueSize");
-        short statsQueueSize = INITIAL_SIZE;
-        if (statsQueueSizeStr != null) {
-            try {
-                statsQueueSize = Short.parseShort(statsQueueSizeStr);
-                if (statsQueueSize <= 0) {
-                    statsQueueSize = INITIAL_SIZE;
-                }
-            } catch (Exception e) {
-            }
-        }
-        return statsQueueSize;
-    }
-
-    IPluginOutConnectionService connectionPluginOutService;
-    void setIPluginOutConnectionService(IPluginOutConnectionService s) {
-        connectionPluginOutService = s;
-    }
-
-    void unsetIPluginOutConnectionService(IPluginOutConnectionService s) {
-        if (connectionPluginOutService == s) {
-            connectionPluginOutService = null;
-        }
-    }
-
-    /**
-     * Function called by the dependency manager when all the required
-     * dependencies are satisfied
-     *
-     */
-    void init() {
-        flowStatistics = new ConcurrentHashMap<Long, List<OFStatistics>>();
-        descStatistics = new ConcurrentHashMap<Long, List<OFStatistics>>();
-        portStatistics = new ConcurrentHashMap<Long, List<OFStatistics>>();
-        tableStatistics = new ConcurrentHashMap<Long, List<OFStatistics>>();
-        pendingStatsRequests = new LinkedBlockingQueue<StatsRequest>(getStatsQueueSize());
-        statisticsTimerTicks = new ConcurrentHashMap<Long, StatisticsTicks>(INITIAL_SIZE);
-        switchPortStatsUpdated = new LinkedBlockingQueue<Long>(INITIAL_SIZE);
-        switchSupportsVendorExtStats = new ConcurrentHashMap<Long, Boolean>(INITIAL_SIZE);
-        txRates = new HashMap<Long, Map<Short, TxRates>>(INITIAL_SIZE);
-
-        configStatsPollIntervals();
-
-        // Initialize managed timers
-        statisticsTimer = new Timer("Statistics Timer Ticks");
-        statisticsTimerTask = new TimerTask() {
-            @Override
-            public void run() {
-                decrementTicks();
-            }
-        };
-
-        // Initialize Statistics collector thread
-        statisticsCollector = new Thread(new Runnable() {
-            @Override
-            public void run() {
-                while (true) {
-                    try {
-                        StatsRequest req = pendingStatsRequests.take();
-                        queryStatisticsInternal(req.switchId, req.type);
-                    } catch (InterruptedException e) {
-                        log.warn("Flow Statistics Collector thread "
-                                + "interrupted", e);
-                        return;
-                    }
-                }
-            }
-        }, "Statistics Collector");
-
-        // Initialize Tx Rate Updater thread
-        txRatesUpdater = new Thread(new Runnable() {
-            @Override
-            public void run() {
-                while (true) {
-                    try {
-                        long switchId = switchPortStatsUpdated.take();
-                        updatePortsTxRate(switchId);
-                    } catch (InterruptedException e) {
-                        log.warn("TX Rate Updater thread interrupted", e);
-                        return;
-                    }
-                }
-            }
-        }, "TX Rate Updater");
-    }
-
-    /**
-     * Function called by the dependency manager when at least one dependency
-     * become unsatisfied or when the component is shutting down because for
-     * example bundle is being stopped.
-     *
-     */
-    void destroy() {
-        statisticsListeners.clear();
-    }
-
-    /**
-     * Function called by dependency manager after "init ()" is called and after
-     * the services provided by the class are registered in the service registry
-     *
-     */
-    void start() {
-        // Start managed timers
-        statisticsTimer.scheduleAtFixedRate(statisticsTimerTask, 0, TICK);
-
-        // Start statistics collector thread
-        statisticsCollector.start();
-
-        // Start bandwidth utilization computer thread
-        txRatesUpdater.start();
-
-        // OSGI console
-        registerWithOSGIConsole();
-    }
-
-    /**
-     * Function called by the dependency manager before the services exported by
-     * the component are unregistered, this will be followed by a "destroy ()"
-     * calls
-     *
-     */
-    void stop() {
-        // Stop managed timers
-        statisticsTimer.cancel();
-    }
-
-    public void setStatisticsListener(IOFStatisticsListener s) {
-        this.statisticsListeners.add(s);
-    }
-
-    public void unsetStatisticsListener(IOFStatisticsListener s) {
-        if (s != null) {
-            this.statisticsListeners.remove(s);
-        }
-    }
-
-    private void registerWithOSGIConsole() {
-        BundleContext bundleContext = FrameworkUtil.getBundle(this.getClass()).getBundleContext();
-        bundleContext.registerService(CommandProvider.class.getName(), this, null);
-    }
-
-    private static class StatsRequest {
-        protected Long switchId;
-        protected OFStatisticsType type;
-
-        public StatsRequest(Long d, OFStatisticsType t) {
-            switchId = d;
-            type = t;
-        }
-
-        @Override
-        public String toString() {
-            return "SReq = {switchId=" + switchId + ", type=" + type + "}";
-        }
-
-        @Override
-        public int hashCode() {
-            final int prime = 31;
-            int result = 1;
-            result = prime * result
-                    + ((switchId == null) ? 0 : switchId.hashCode());
-            result = prime * result + ((type == null) ? 0 : type.ordinal());
-            return result;
-        }
-
-        @Override
-        public boolean equals(Object obj) {
-            if (this == obj) {
-                return true;
-            }
-            if (obj == null) {
-                return false;
-            }
-            if (getClass() != obj.getClass()) {
-                return false;
-            }
-            StatsRequest other = (StatsRequest) obj;
-            if (switchId == null) {
-                if (other.switchId != null) {
-                    return false;
-                }
-            } else if (!switchId.equals(other.switchId)) {
-                return false;
-            }
-            if (type != other.type) {
-                return false;
-            }
-            return true;
-        }
-    }
-
-    private void addStatisticsTicks(Long switchId) {
-        switchSupportsVendorExtStats.put(switchId, Boolean.TRUE); // Assume
-                                                                  // switch
-                                                                  // supports
-                                                                  // Vendor
-                                                                  // extension
-                                                                  // stats
-        statisticsTimerTicks.put(switchId, new StatisticsTicks(true));
-        log.debug("Added Switch {} to target pool",
-                HexString.toHexString(switchId.longValue()));
-    }
-
-    protected static class StatisticsTicks {
-        private short flowStatisticsTicks;
-        private short descriptionTicks;
-        private short portStatisticsTicks;
-        private short tableStatisticsTicks;
-
-        public StatisticsTicks(boolean scattered) {
-            if (scattered) {
-                // scatter bursts by statisticsTickPeriod
-                if (++counter < 0) {
-                    counter = 0;
-                } // being paranoid here
-                flowStatisticsTicks = (short) (1 + counter
-                        % statisticsTickNumber);
-                descriptionTicks = (short) (1 + counter % descriptionTickNumber);
-                portStatisticsTicks = (short) (1 + counter % portTickNumber);
-                tableStatisticsTicks = (short) (1 + counter % tableTickNumber);
-            } else {
-                flowStatisticsTicks = statisticsTickNumber;
-                descriptionTicks = descriptionTickNumber;
-                portStatisticsTicks = portTickNumber;
-                tableStatisticsTicks = tableTickNumber;
-            }
-        }
-
-        public boolean decrementFlowTicksIsZero() {
-            // Please ensure no code is inserted between the if check and the
-            // flowStatisticsTicks reset
-            if (--flowStatisticsTicks == 0) {
-                flowStatisticsTicks = statisticsTickNumber;
-                return true;
-            }
-            return false;
-        }
-
-        public boolean decrementDescTicksIsZero() {
-            // Please ensure no code is inserted between the if check and the
-            // descriptionTicks reset
-            if (--descriptionTicks == 0) {
-                descriptionTicks = descriptionTickNumber;
-                return true;
-            }
-            return false;
-        }
-
-        public boolean decrementPortTicksIsZero() {
-            // Please ensure no code is inserted between the if check and the
-            // descriptionTicks reset
-            if (--portStatisticsTicks == 0) {
-                portStatisticsTicks = portTickNumber;
-                return true;
-            }
-            return false;
-        }
-
-        public boolean decrementTableTicksIsZero() {
-            // Please ensure no code is inserted between the if check and the
-            // descriptionTicks reset
-            if(--tableStatisticsTicks == 0) {
-                tableStatisticsTicks = tableTickNumber;
-                return true;
-            }
-            return false;
-        }
-
-        @Override
-        public String toString() {
-            return "{fT=" + flowStatisticsTicks + ",dT=" + descriptionTicks
-                    + ",pT=" + portStatisticsTicks + ",tT=" + tableStatisticsTicks + "}";
-        }
-    }
-
-    private void printInfoMessage(String type, StatsRequest request) {
-        log.trace("{} stats request not inserted for switch: {}. Queue size: {}. Collector state: {}.",
-                new Object[] {type, HexString.toHexString(request.switchId), pendingStatsRequests.size(),
-                statisticsCollector.getState().toString() });
-    }
-
-    protected void decrementTicks() {
-        StatsRequest request = null;
-        for (Map.Entry<Long, StatisticsTicks> entry : statisticsTimerTicks
-                .entrySet()) {
-            StatisticsTicks clock = entry.getValue();
-            Long switchId = entry.getKey();
-            if (clock.decrementFlowTicksIsZero()) {
-                request = (switchSupportsVendorExtStats.get(switchId) == Boolean.TRUE) ?
-                        new StatsRequest(switchId, OFStatisticsType.VENDOR) :
-                        new StatsRequest(switchId, OFStatisticsType.FLOW);
-                // If a request for this switch is already in the queue, skip to
-                // add this new request
-                if (!pendingStatsRequests.contains(request)
-                        && false == pendingStatsRequests.offer(request)) {
-                    printInfoMessage("Flow", request);
-                }
-            }
-
-            if (clock.decrementDescTicksIsZero()) {
-                request = new StatsRequest(switchId, OFStatisticsType.DESC);
-                // If a request for this switch is already in the queue, skip to
-                // add this new request
-                if (!pendingStatsRequests.contains(request)
-                        && false == pendingStatsRequests.offer(request)) {
-                    printInfoMessage("Description", request);
-                }
-            }
-
-            if (clock.decrementPortTicksIsZero()) {
-                request = new StatsRequest(switchId, OFStatisticsType.PORT);
-                // If a request for this switch is already in the queue, skip to
-                // add this new request
-                if (!pendingStatsRequests.contains(request)
-                        && false == pendingStatsRequests.offer(request)) {
-                    printInfoMessage("Port", request);
-                }
-            }
-
-            if(clock.decrementTableTicksIsZero()) {
-                request = new StatsRequest(switchId, OFStatisticsType.TABLE);
-                // If a request for this switch is already in the queue, skip to
-                // add this new request
-                if (!pendingStatsRequests.contains(request)
-                        && false == pendingStatsRequests.offer(request)) {
-                    printInfoMessage("Table", request);
-                }
-            }
-        }
-    }
-
-    private void removeStatsRequestTasks(Long switchId) {
-        log.debug("Cleaning Statistics database for switch {}",
-                HexEncode.longToHexString(switchId));
-        // To be safe, let's attempt removal of both VENDOR and FLOW request. It
-        // does not hurt
-        pendingStatsRequests.remove(new StatsRequest(switchId,
-                OFStatisticsType.VENDOR));
-        pendingStatsRequests.remove(new StatsRequest(switchId,
-                OFStatisticsType.FLOW));
-        pendingStatsRequests.remove(new StatsRequest(switchId,
-                OFStatisticsType.DESC));
-        pendingStatsRequests.remove(new StatsRequest(switchId,
-                OFStatisticsType.PORT));
-        pendingStatsRequests.remove(new StatsRequest(switchId,
-                OFStatisticsType.TABLE));
-        // Take care of the TX rate databases
-        switchPortStatsUpdated.remove(switchId);
-        txRates.remove(switchId);
-    }
-
-    private void clearFlowStatsAndTicks(Long switchId) {
-        statisticsTimerTicks.remove(switchId);
-        removeStatsRequestTasks(switchId);
-        flowStatistics.remove(switchId);
-        log.debug("Statistics removed for switch {}",
-                HexString.toHexString(switchId));
-    }
-
-    private void queryStatisticsInternal(Long switchId, OFStatisticsType statType) {
-
-        // Query the switch on all matches
-        List<OFStatistics> values = this.fetchStatisticsFromSwitch(switchId, statType, null);
-
-        // If got a valid response update local cache and notify listeners
-        if (!values.isEmpty()) {
-            switch (statType) {
-                case FLOW:
-                case VENDOR:
-                    flowStatistics.put(switchId, values);
-                    notifyFlowUpdate(switchId, values);
-                    break;
-                case DESC:
-                    // Overwrite cache
-                    descStatistics.put(switchId, values);
-                    // Notify who may be interested in a description change
-                    notifyDescriptionUpdate(switchId, values);
-                    break;
-                case PORT:
-                    // Overwrite cache with new port statistics for this switch
-                    portStatistics.put(switchId, values);
-
-                    // Wake up the thread which maintains the TX byte counters for
-                    // each port
-                    switchPortStatsUpdated.offer(switchId);
-                    notifyPortUpdate(switchId, values);
-                    break;
-                case TABLE:
-                    // Overwrite cache
-                    tableStatistics.put(switchId, values);
-                    notifyTableUpdate(switchId, values);
-                    break;
-                default:
-            }
-        }
-    }
-
-    private void notifyDescriptionUpdate(Long switchId, List<OFStatistics> values) {
-        for (IOFStatisticsListener l : this.statisticsListeners) {
-            l.descriptionStatisticsRefreshed(switchId, values);
-        }
-    }
-
-    private void notifyFlowUpdate(Long switchId, List<OFStatistics> values) {
-        if (values.get(0) instanceof OFVendorStatistics) {
-            values = this.v6StatsListToOFStatsList(values);
-        }
-
-        for (IOFStatisticsListener l : this.statisticsListeners) {
-            l.flowStatisticsRefreshed(switchId, values);
-        }
-
-    }
-
-    private void notifyPortUpdate(Long switchId, List<OFStatistics> values) {
-        for (IOFStatisticsListener l : this.statisticsListeners) {
-            l.portStatisticsRefreshed(switchId, values);
-        }
-    }
-
-    private void notifyTableUpdate(Long switchId, List<OFStatistics> values) {
-        for (IOFStatisticsListener l : this.statisticsListeners) {
-            l.tableStatisticsRefreshed(switchId, values);
-        }
-    }
-
-    /*
-     * Generic function to get the statistics form an OF switch
-     */
-    @SuppressWarnings("unchecked")
-    private List<OFStatistics> fetchStatisticsFromSwitch(Long switchId,
-            OFStatisticsType statsType, Object target) {
-        List<OFStatistics> values = Collections.emptyList();
-        String type = null;
-        ISwitch sw = controller.getSwitch(switchId);
-
-        if (sw != null) {
-            OFStatisticsRequest req = new OFStatisticsRequest();
-            req.setStatisticType(statsType);
-            int requestLength = req.getLengthU();
-
-            if (statsType == OFStatisticsType.FLOW) {
-                OFMatch match = null;
-                if (target == null) {
-                    // All flows request
-                    match = new OFMatch();
-                    match.setWildcards(0xffffffff);
-                } else if (!(target instanceof OFMatch)) {
-                    // Malformed request
-                    log.warn("Invalid target type for Flow stats request: {}",
-                            target.getClass());
-                    return Collections.emptyList();
-                } else {
-                    // Specific flow request
-                    match = (OFMatch) target;
-                }
-                OFFlowStatisticsRequest specificReq = new OFFlowStatisticsRequest();
-                specificReq.setMatch(match);
-                specificReq.setOutPort(OFPort.OFPP_NONE.getValue());
-                specificReq.setTableId((byte) 0xff);
-                req.setStatistics(Collections
-                        .singletonList((OFStatistics) specificReq));
-                requestLength += specificReq.getLength();
-                type = "FLOW";
-            } else if (statsType == OFStatisticsType.VENDOR) {
-                V6StatsRequest specificReq = new V6StatsRequest();
-                specificReq.setOutPort(OFPort.OFPP_NONE.getValue());
-                specificReq.setTableId((byte) 0xff);
-                req.setStatistics(Collections
-                        .singletonList((OFStatistics) specificReq));
-                requestLength += specificReq.getLength();
-                type = "VENDOR";
-            } else if (statsType == OFStatisticsType.AGGREGATE) {
-                OFAggregateStatisticsRequest specificReq = new OFAggregateStatisticsRequest();
-                OFMatch match = new OFMatch();
-                match.setWildcards(0xffffffff);
-                specificReq.setMatch(match);
-                specificReq.setOutPort(OFPort.OFPP_NONE.getValue());
-                specificReq.setTableId((byte) 0xff);
-                req.setStatistics(Collections
-                        .singletonList((OFStatistics) specificReq));
-                requestLength += specificReq.getLength();
-                type = "AGGREGATE";
-            } else if (statsType == OFStatisticsType.PORT) {
-                short targetPort;
-                if (target == null) {
-                    // All ports request
-                    targetPort = OFPort.OFPP_NONE.getValue();
-                } else if (!(target instanceof Short)) {
-                    // Malformed request
-                    log.warn("Invalid target type for Port stats request: {}",
-                            target.getClass());
-                    return Collections.emptyList();
-                } else {
-                    // Specific port request
-                    targetPort = (Short) target;
-                }
-                OFPortStatisticsRequest specificReq = new OFPortStatisticsRequest();
-                specificReq.setPortNumber(targetPort);
-                req.setStatistics(Collections
-                        .singletonList((OFStatistics) specificReq));
-                requestLength += specificReq.getLength();
-                type = "PORT";
-            } else if (statsType == OFStatisticsType.QUEUE) {
-                OFQueueStatisticsRequest specificReq = new OFQueueStatisticsRequest();
-                specificReq.setPortNumber(OFPort.OFPP_ALL.getValue());
-                specificReq.setQueueId(0xffffffff);
-                req.setStatistics(Collections
-                        .singletonList((OFStatistics) specificReq));
-                requestLength += specificReq.getLength();
-                type = "QUEUE";
-            } else if (statsType == OFStatisticsType.DESC) {
-                type = "DESC";
-            } else if (statsType == OFStatisticsType.TABLE) {
-                if(target != null){
-                    if (!(target instanceof Byte)) {
-                        // Malformed request
-                        log.warn("Invalid table id for table stats request: {}",
-                                target.getClass());
-                        return Collections.emptyList();
-                    }
-                    byte targetTable = (Byte) target;
-                    OFTableStatistics specificReq = new OFTableStatistics();
-                    specificReq.setTableId(targetTable);
-                    req.setStatistics(Collections
-                            .singletonList((OFStatistics) specificReq));
-                    requestLength += specificReq.getLength();
-                }
-                type = "TABLE";
-            }
-            req.setLengthU(requestLength);
-            Object result = sw.getStatistics(req);
-
-            if (result == null) {
-                log.warn("Request Timed Out for ({}) from switch {}", type,
-                        HexString.toHexString(switchId));
-            } else if (result instanceof OFError) {
-                log.warn("Switch {} failed to handle ({}) stats request: {}",
-                        new Object[] { HexString.toHexString(switchId), type,
-                        Utils.getOFErrorString((OFError) result) });
-                if (this.switchSupportsVendorExtStats.get(switchId) == Boolean.TRUE) {
-                    log.warn(
-                            "Switching back to regular Flow stats requests for switch {}",
-                            HexString.toHexString(switchId));
-                    this.switchSupportsVendorExtStats.put(switchId,
-                            Boolean.FALSE);
-                }
-            } else {
-                values = (List<OFStatistics>) result;
-            }
-        }
-        return values;
-    }
-
-    @Override
-    public List<OFStatistics> getOFFlowStatistics(Long switchId) {
-        List<OFStatistics> list = flowStatistics.get(switchId);
-
-        /*
-         * Check on emptiness as interference between add and get is still
-         * possible on the inner list (the concurrentMap entry's value)
-         */
-        return (list == null || list.isEmpty()) ? Collections.<OFStatistics>emptyList()
-                : (list.get(0) instanceof OFVendorStatistics) ? this
-                        .v6StatsListToOFStatsList(list) : list;
-    }
-
-    @Override
-    public List<OFStatistics> getOFFlowStatistics(Long switchId, OFMatch ofMatch, short priority) {
-        List<OFStatistics> statsList = flowStatistics.get(switchId);
-
-        /*
-         * Check on emptiness as interference between add and get is still
-         * possible on the inner list (the concurrentMap entry's value)
-         */
-        if (statsList == null || statsList.isEmpty()) {
-            return Collections.emptyList();
-        }
-
-        if (statsList.get(0) instanceof OFVendorStatistics) {
-            /*
-             * Caller could provide regular OF match when we instead pull the
-             * vendor statistics from this node Caller is not supposed to know
-             * whether this switch supports vendor extensions statistics
-             * requests
-             */
-            V6Match targetMatch = (ofMatch instanceof V6Match) ? (V6Match) ofMatch
-                    : new V6Match(ofMatch);
-
-            List<OFStatistics> targetList = v6StatsListToOFStatsList(statsList);
-            for (OFStatistics stats : targetList) {
-                V6StatsReply v6Stats = (V6StatsReply) stats;
-                V6Match v6Match = v6Stats.getMatch();
-                if (v6Stats.getPriority() == priority && targetMatch.equals(v6Match)) {
-                    List<OFStatistics> list = new ArrayList<OFStatistics>();
-                    list.add(stats);
-                    return list;
-                }
-            }
-        } else {
-            for (OFStatistics stats : statsList) {
-                OFFlowStatisticsReply flowStats = (OFFlowStatisticsReply) stats;
-                if (flowStats.getPriority() == priority && ofMatch.equals(flowStats.getMatch())) {
-                    List<OFStatistics> list = new ArrayList<OFStatistics>();
-                    list.add(stats);
-                    return list;
-                }
-            }
-        }
-        return Collections.emptyList();
-    }
-
-    /*
-     * Converts the v6 vendor statistics to the OFStatistics
-     */
-    private List<OFStatistics> v6StatsListToOFStatsList(List<OFStatistics> statistics) {
-        if (statistics == null || statistics.isEmpty()) {
-            return Collections.emptyList();
-        }
-        List<OFStatistics> v6statistics = new ArrayList<OFStatistics>();
-        for (OFStatistics stats : statistics) {
-            if (stats instanceof OFVendorStatistics) {
-                List<OFStatistics> r = getV6ReplyStatistics((OFVendorStatistics) stats);
-                if (r != null) {
-                    v6statistics.addAll(r);
-                }
-            }
-        }
-        return v6statistics;
-    }
-
-    private static List<OFStatistics> getV6ReplyStatistics(
-            OFVendorStatistics stat) {
-        int length = stat.getLength();
-        List<OFStatistics> results = new ArrayList<OFStatistics>();
-        if (length < 12) {
-            // Nicira Hdr is 12 bytes. We need at least that much
-            return Collections.emptyList();
-        }
-        ByteBuffer data = ByteBuffer.allocate(length);
-        stat.writeTo(data);
-        data.rewind();
-        if (log.isTraceEnabled()) {
-            log.trace("getV6ReplyStatistics: Buffer BYTES ARE {}",
-                    HexString.toHexString(data.array()));
-        }
-
-        int vendor = data.getInt(); // first 4 bytes is vendor id.
-        if (vendor != V6StatsRequest.NICIRA_VENDOR_ID) {
-            log.warn("Unexpected vendor id: 0x{}", Integer.toHexString(vendor));
-            return Collections.emptyList();
-        } else {
-            // go ahead by 8 bytes which is 8 bytes of 0
-            data.getLong(); // should be all 0's
-            length -= 12; // 4 bytes Nicira Hdr + 8 bytes from above line have
-                          // been consumed
-        }
-
-        V6StatsReply v6statsreply;
-        int min_len;
-        while (length > 0) {
-            v6statsreply = new V6StatsReply();
-            min_len = v6statsreply.getLength();
-            if (length < v6statsreply.getLength()) {
-                break;
-            }
-            v6statsreply.setActionFactory(stat.getActionFactory());
-            v6statsreply.readFrom(data);
-            if (v6statsreply.getLength() < min_len) {
-                break;
-            }
-            v6statsreply.setVendorId(vendor);
-            log.trace("V6StatsReply: {}", v6statsreply);
-            length -= v6statsreply.getLength();
-            results.add(v6statsreply);
-        }
-        return results;
-    }
-
-    @Override
-    public List<OFStatistics> queryStatistics(Long switchId,
-            OFStatisticsType statType, Object target) {
-        /*
-         * Caller does not know and it is not supposed to know whether this
-         * switch supports vendor extension. We adjust the target for him
-         */
-        if (statType == OFStatisticsType.FLOW) {
-            if (switchSupportsVendorExtStats.get(switchId) == Boolean.TRUE) {
-                statType = OFStatisticsType.VENDOR;
-            }
-        }
-
-        List<OFStatistics> list = this.fetchStatisticsFromSwitch(switchId, statType, target);
-
-        return (statType == OFStatisticsType.VENDOR) ? v6StatsListToOFStatsList(list) : list;
-    }
-
-    @Override
-    public List<OFStatistics> getOFDescStatistics(Long switchId) {
-        if (!descStatistics.containsKey(switchId)) {
-            return Collections.emptyList();
-        }
-
-        return descStatistics.get(switchId);
-    }
-
-    @Override
-    public List<OFStatistics> getOFPortStatistics(Long switchId) {
-        if (!portStatistics.containsKey(switchId)) {
-            return Collections.emptyList();
-        }
-
-        return portStatistics.get(switchId);
-    }
-
-    @Override
-    public List<OFStatistics> getOFPortStatistics(Long switchId, short portId) {
-        if (!portStatistics.containsKey(switchId)) {
-            return Collections.emptyList();
-        }
-        List<OFStatistics> list = new ArrayList<OFStatistics>(1);
-        for (OFStatistics stats : portStatistics.get(switchId)) {
-            if (((OFPortStatisticsReply) stats).getPortNumber() == portId) {
-                list.add(stats);
-                break;
-            }
-        }
-        return list;
-    }
-
-    @Override
-    public List<OFStatistics> getOFTableStatistics(Long switchId) {
-        if (!tableStatistics.containsKey(switchId)) {
-            return Collections.emptyList();
-        }
-
-        return tableStatistics.get(switchId);
-    }
-
-    @Override
-    public List<OFStatistics> getOFTableStatistics(Long switchId, Byte tableId) {
-        if (!tableStatistics.containsKey(switchId)) {
-            return Collections.emptyList();
-        }
-
-        List<OFStatistics> list = new ArrayList<OFStatistics>(1);
-        for (OFStatistics stats : tableStatistics.get(switchId)) {
-            if (((OFTableStatistics) stats).getTableId() == tableId) {
-                list.add(stats);
-                break;
-            }
-        }
-        return list;
-    }
-
-    @Override
-    public int getFlowsNumber(long switchId) {
-        return this.flowStatistics.get(switchId).size();
-    }
-
-    /*
-     * InventoryShim replay for us all the switch addition which happened before
-     * we were brought up
-     */
-    @Override
-    public void updateNode(Node node, UpdateType type, Set<Property> props) {
-        Long switchId = (Long) node.getID();
-        switch (type) {
-        case ADDED:
-            addStatisticsTicks(switchId);
-            break;
-        case REMOVED:
-            clearFlowStatsAndTicks(switchId);
-        default:
-        }
-    }
-
-    @Override
-    public void updateNodeConnector(NodeConnector nodeConnector,
-            UpdateType type, Set<Property> props) {
-        // No action
-    }
-
-    /**
-     * Update the cached port rates for this switch with the latest retrieved
-     * port transmit byte count
-     *
-     * @param switchId
-     */
-    private synchronized void updatePortsTxRate(long switchId) {
-        List<OFStatistics> newPortStatistics = this.portStatistics.get(switchId);
-        if (newPortStatistics == null) {
-            return;
-        }
-        Map<Short, TxRates> rates = this.txRates.get(switchId);
-        if (rates == null) {
-            // First time rates for this switch are added
-            rates = new HashMap<Short, TxRates>();
-            txRates.put(switchId, rates);
-        }
-        for (OFStatistics stats : newPortStatistics) {
-            OFPortStatisticsReply newPortStat = (OFPortStatisticsReply) stats;
-            short port = newPortStat.getPortNumber();
-            TxRates portRatesHolder = rates.get(port);
-            if (portRatesHolder == null) {
-                // First time rates for this port are added
-                portRatesHolder = new TxRates();
-                rates.put(port, portRatesHolder);
-            }
-            // Get and store the number of transmitted bytes for this port
-            // And handle the case where agent does not support the counter
-            long transmitBytes = newPortStat.getTransmitBytes();
-            long value = (transmitBytes < 0) ? 0 : transmitBytes;
-            portRatesHolder.update(value);
-        }
-    }
-
-    @Override
-    public synchronized long getTransmitRate(Long switchId, Short port) {
-        long average = 0;
-        if (switchId == null || port == null) {
-            return average;
-        }
-        Map<Short, TxRates> perSwitch = txRates.get(switchId);
-        if (perSwitch == null) {
-            return average;
-        }
-        TxRates portRates = perSwitch.get(port);
-        if (portRates == null) {
-            return average;
-        }
-        return portRates.getAverageTxRate();
-    }
-
-    /*
-     * Manual switch name configuration code
-     */
-    @Override
-    public String getHelp() {
-        StringBuffer help = new StringBuffer();
-        help.append("---OF Statistics Manager utilities---\n");
-        help.append("\t ofdumpstatsmgr         - "
-                + "Print Internal Stats Mgr db\n");
-        help.append("\t ofstatsmgrintervals <fP> <pP> <dP> <tP> (all in seconds) - "
-                + "Set/Show flow/port/dedscription stats poll intervals\n");
-        return help.toString();
-    }
-
-    private boolean isValidSwitchId(String switchId) {
-        String regexDatapathID = "^([0-9a-fA-F]{1,2}[:-]){7}[0-9a-fA-F]{1,2}$";
-        String regexDatapathIDLong = "^[0-9a-fA-F]{1,16}$";
-
-        return (switchId != null && (switchId.matches(regexDatapathID) || switchId
-                .matches(regexDatapathIDLong)));
-    }
-
-    public long getSwitchIDLong(String switchId) {
-        int radix = 16;
-        String switchString = "0";
-
-        if (isValidSwitchId(switchId)) {
-            if (switchId.contains(":")) {
-                // Handle the 00:00:AA:BB:CC:DD:EE:FF notation
-                switchString = switchId.replace(":", "");
-            } else if (switchId.contains("-")) {
-                // Handle the 00-00-AA-BB-CC-DD-EE-FF notation
-                switchString = switchId.replace("-", "");
-            } else {
-                // Handle the 0123456789ABCDEF notation
-                switchString = switchId;
-            }
-        }
-        return Long.parseLong(switchString, radix);
-    }
-
-    /*
-     * Internal information dump code
-     */
-    private String prettyPrintSwitchMap(ConcurrentMap<Long, StatisticsTicks> map) {
-        StringBuffer buffer = new StringBuffer();
-        buffer.append("{");
-        for (Entry<Long, StatisticsTicks> entry : map.entrySet()) {
-            buffer.append(HexString.toHexString(entry.getKey()) + "="
-                    + entry.getValue().toString() + " ");
-        }
-        buffer.append("}");
-        return buffer.toString();
-    }
-
-    public void _ofdumpstatsmgr(CommandInterpreter ci) {
-        ci.println("Global Counter: " + counter);
-        ci.println("Timer Ticks: " + prettyPrintSwitchMap(statisticsTimerTicks));
-        ci.println("PendingStatsQueue: " + pendingStatsRequests);
-        ci.println("PendingStatsQueue size: " + pendingStatsRequests.size());
-        ci.println("Stats Collector alive: " + statisticsCollector.isAlive());
-        ci.println("Stats Collector State: "
-                + statisticsCollector.getState().toString());
-        ci.println("StatsTimer: " + statisticsTimer.toString());
-        ci.println("Flow Stats Period: " + statisticsTickNumber + " s");
-        ci.println("Desc Stats Period: " + descriptionTickNumber + " s");
-        ci.println("Port Stats Period: " + portTickNumber + " s");
-        ci.println("Table Stats Period: " + tableTickNumber + " s");
-    }
-
-    public void _resetSwitchCapability(CommandInterpreter ci) {
-        String sidString = ci.nextArgument();
-        Long sid = null;
-        if (sidString == null) {
-            ci.println("Insert the switch id (numeric value)");
-            return;
-        }
-        try {
-            sid = Long.valueOf(sidString);
-            this.switchSupportsVendorExtStats.put(sid, Boolean.TRUE);
-            ci.println("Vendor capability for switch " + sid + " set to "
-                    + this.switchSupportsVendorExtStats.get(sid));
-        } catch (NumberFormatException e) {
-            ci.println("Invalid switch id. Has to be numeric.");
-        }
-
-    }
-
-    public void _ofbw(CommandInterpreter ci) {
-        String sidString = ci.nextArgument();
-        Long sid = null;
-        if (sidString == null) {
-            ci.println("Insert the switch id (numeric value)");
-            return;
-        }
-        try {
-            sid = Long.valueOf(sidString);
-        } catch (NumberFormatException e) {
-            ci.println("Invalid switch id. Has to be numeric.");
-        }
-        if (sid != null) {
-            Map<Short, TxRates> thisSwitchRates = txRates.get(sid);
-            ci.println("Bandwidth utilization (" + factoredSamples
-                    * portTickNumber + " sec average) for switch "
-                    + HexEncode.longToHexString(sid) + ":");
-            if (thisSwitchRates == null) {
-                ci.println("Not available");
-            } else {
-                for (Entry<Short, TxRates> entry : thisSwitchRates.entrySet()) {
-                    ci.println("Port: " + entry.getKey() + ": "
-                            + entry.getValue().getAverageTxRate() + " bps");
-                }
-            }
-        }
-    }
-
-    public void _txratewindow(CommandInterpreter ci) {
-        String averageWindow = ci.nextArgument();
-        short seconds = 0;
-        if (averageWindow == null) {
-            ci.println("Insert the length in seconds of the median "
-                    + "window for tx rate");
-            ci.println("Current: " + factoredSamples * portTickNumber + " secs");
-            return;
-        }
-        try {
-            seconds = Short.valueOf(averageWindow);
-        } catch (NumberFormatException e) {
-            ci.println("Invalid period.");
-        }
-        OFStatisticsManager.factoredSamples = (short) (seconds / portTickNumber);
-        ci.println("New: " + factoredSamples * portTickNumber + " secs");
-    }
-
-    public void _ofstatsmgrintervals(CommandInterpreter ci) {
-        String flowStatsInterv = ci.nextArgument();
-        String portStatsInterv = ci.nextArgument();
-        String descStatsInterv = ci.nextArgument();
-        String tableStatsInterv = ci.nextArgument();
-
-        if (flowStatsInterv == null || portStatsInterv == null
-                || descStatsInterv == null) {
-            ci.println("Usage: ofstatsmgrintervals <fP> <pP> <dP> <tP> (all in seconds)");
-            ci.println("Current Values: fP=" + statisticsTickNumber + "sec pP="
-                    + portTickNumber + "sec dP=" + descriptionTickNumber + "sec tP=" + tableTickNumber + " sec");
-            return;
-        }
-        Short fP, pP, dP, tP;
-        try {
-            fP = Short.parseShort(flowStatsInterv);
-            pP = Short.parseShort(portStatsInterv);
-            dP = Short.parseShort(descStatsInterv);
-            tP = Short.parseShort(tableStatsInterv);
-        } catch (Exception e) {
-            ci.println("Invalid format values: " + e.getMessage());
-            return;
-        }
-
-        if (pP <= 1 || fP <= 1 || dP <= 1 || tP <= 1) {
-            ci.println("Invalid values. fP, pP, dP, tP have to be greater than 1.");
-            return;
-        }
-
-        statisticsTickNumber = fP;
-        portTickNumber = pP;
-        descriptionTickNumber = dP;
-        tableTickNumber = tP;
-
-        ci.println("New Values: fP=" + statisticsTickNumber + "s pP="
-                + portTickNumber + "s dP=" + descriptionTickNumber + "s tP="
-                + tableTickNumber + "s");
-    }
-
-    /**
-     * This method retrieves user configurations from config.ini and updates
-     * statisticsTickNumber/portTickNumber/descriptionTickNumber accordingly.
-     */
-    private void configStatsPollIntervals() {
-        String fsStr = System.getProperty("of.flowStatsPollInterval");
-        String psStr = System.getProperty("of.portStatsPollInterval");
-        String dsStr = System.getProperty("of.descStatsPollInterval");
-        String tsStr = System.getProperty("of.tableStatsPollInterval");
-        Short fs, ps, ds, ts;
-
-        if (fsStr != null) {
-            try {
-                fs = Short.parseShort(fsStr);
-                if (fs > 0) {
-                    statisticsTickNumber = fs;
-                }
-            } catch (Exception e) {
-            }
-        }
-
-        if (psStr != null) {
-            try {
-                ps = Short.parseShort(psStr);
-                if (ps > 0) {
-                    portTickNumber = ps;
-                }
-            } catch (Exception e) {
-            }
-        }
-
-        if (dsStr != null) {
-            try {
-                ds = Short.parseShort(dsStr);
-                if (ds > 0) {
-                    descriptionTickNumber = ds;
-                }
-            } catch (Exception e) {
-            }
-        }
-
-        if (tsStr != null) {
-            try{
-                ts = Short.parseShort(tsStr);
-                if (ts > 0) {
-                    tableTickNumber = ts;
-                }
-            } catch (Exception e) {
-            }
-        }
-    }
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/PortConverter.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/PortConverter.java
deleted file mode 100644 (file)
index 0b605ab..0000000
+++ /dev/null
@@ -1,73 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow.internal;
-
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.NodeConnector.NodeConnectorIDType;
-import org.opendaylight.controller.sal.utils.NetUtils;
-import org.opendaylight.controller.sal.utils.NodeConnectorCreator;
-import org.openflow.protocol.OFPort;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * Abstract class which provides the utilities for converting the Openflow port
- * number to the equivalent NodeConnector and vice versa
- *
- *
- *
- */
-public abstract class PortConverter {
-    private static final Logger log = LoggerFactory
-            .getLogger(PortConverter.class);
-    private static final int maxOFPhysicalPort = NetUtils
-            .getUnsignedShort(OFPort.OFPP_MAX.getValue());
-
-    /**
-     * Converts the Openflow port number to the equivalent NodeConnector.
-     */
-    public static NodeConnector toNodeConnector(short ofPort, Node node) {
-        // Restore original OF unsigned 16 bits value for the comparison
-        int unsignedOFPort = NetUtils.getUnsignedShort(ofPort);
-        log.trace("Openflow port number signed: {} unsigned: {}", ofPort,
-                unsignedOFPort);
-        if (unsignedOFPort > maxOFPhysicalPort) {
-            if (ofPort == OFPort.OFPP_LOCAL.getValue()) {
-                return NodeConnectorCreator.createNodeConnector(
-                        NodeConnectorIDType.SWSTACK,
-                        NodeConnector.SPECIALNODECONNECTORID, node);
-            } else if (ofPort == OFPort.OFPP_NORMAL.getValue()) {
-                return NodeConnectorCreator.createNodeConnector(
-                        NodeConnectorIDType.HWPATH,
-                        NodeConnector.SPECIALNODECONNECTORID, node);
-            } else if (ofPort == OFPort.OFPP_CONTROLLER.getValue()) {
-                return NodeConnectorCreator.createNodeConnector(
-                        NodeConnectorIDType.CONTROLLER,
-                        NodeConnector.SPECIALNODECONNECTORID, node);
-            }
-        }
-        return NodeConnectorCreator.createNodeConnector(ofPort, node);
-    }
-
-    /**
-     * Converts the NodeConnector to the equivalent Openflow port number
-     */
-    public static short toOFPort(NodeConnector salPort) {
-        log.trace("SAL Port", salPort);
-        if (salPort.getType().equals(NodeConnectorIDType.SWSTACK)) {
-            return OFPort.OFPP_LOCAL.getValue();
-        } else if (salPort.getType().equals(NodeConnectorIDType.HWPATH)) {
-            return OFPort.OFPP_NORMAL.getValue();
-        } else if (salPort.getType().equals(NodeConnectorIDType.CONTROLLER)) {
-            return OFPort.OFPP_CONTROLLER.getValue();
-        }
-        return (Short) salPort.getID();
-    }
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/PortStatisticsConverter.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/PortStatisticsConverter.java
deleted file mode 100644 (file)
index 0fe1c72..0000000
+++ /dev/null
@@ -1,79 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow.internal;
-
-import java.util.ArrayList;
-import java.util.Collections;
-import java.util.List;
-
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.reader.NodeConnectorStatistics;
-import org.opendaylight.controller.sal.utils.NodeCreator;
-import org.openflow.protocol.statistics.OFPortStatisticsReply;
-import org.openflow.protocol.statistics.OFStatistics;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * Converts an openflow list of port statistics in a SAL list of
- * NodeConnectorStatistics objects
- *
- *
- *
- */
-public class PortStatisticsConverter {
-    private static final Logger log = LoggerFactory
-            .getLogger(PortStatisticsConverter.class);
-    private long switchId;
-    private List<OFStatistics> ofStatsList;
-    private List<NodeConnectorStatistics> ncStatsList;
-
-    public PortStatisticsConverter(long switchId, List<OFStatistics> statsList) {
-        this.switchId = switchId;
-        if (statsList == null || statsList.isEmpty()) {
-            this.ofStatsList = Collections.emptyList();
-        } else {
-            this.ofStatsList = new ArrayList<OFStatistics>(statsList);
-        }
-        this.ncStatsList = null;
-    }
-
-    public List<NodeConnectorStatistics> getNodeConnectorStatsList() {
-        if (this.ofStatsList != null && this.ncStatsList == null) {
-            this.ncStatsList = new ArrayList<NodeConnectorStatistics>();
-            OFPortStatisticsReply ofPortStat;
-            Node node = NodeCreator.createOFNode(switchId);
-            for (OFStatistics ofStat : this.ofStatsList) {
-                ofPortStat = (OFPortStatisticsReply) ofStat;
-                NodeConnectorStatistics NCStat = new NodeConnectorStatistics();
-                NCStat.setNodeConnector(PortConverter.toNodeConnector(
-                        ofPortStat.getPortNumber(), node));
-                NCStat.setReceivePacketCount(ofPortStat.getreceivePackets());
-                NCStat.setTransmitPacketCount(ofPortStat.getTransmitPackets());
-                NCStat.setReceiveByteCount(ofPortStat.getReceiveBytes());
-                NCStat.setTransmitByteCount(ofPortStat.getTransmitBytes());
-                NCStat.setReceiveDropCount(ofPortStat.getReceiveDropped());
-                NCStat.setTransmitDropCount(ofPortStat.getTransmitDropped());
-                NCStat.setReceiveErrorCount(ofPortStat.getreceiveErrors());
-                NCStat.setTransmitErrorCount(ofPortStat.getTransmitErrors());
-                NCStat.setReceiveFrameErrorCount(ofPortStat
-                        .getReceiveFrameErrors());
-                NCStat.setReceiveOverRunErrorCount(ofPortStat
-                        .getReceiveOverrunErrors());
-                NCStat.setReceiveCRCErrorCount(ofPortStat.getReceiveCRCErrors());
-                NCStat.setCollisionCount(ofPortStat.getCollisions());
-                this.ncStatsList.add(NCStat);
-            }
-        }
-        log.trace("OFStatistics: {} NodeConnectorStatistics: {}", ofStatsList,
-                ncStatsList);
-        return this.ncStatsList;
-    }
-
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/ReadService.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/ReadService.java
deleted file mode 100644 (file)
index f1f5944..0000000
+++ /dev/null
@@ -1,285 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow.internal;
-
-import java.util.Collections;
-import java.util.Dictionary;
-import java.util.List;
-import java.util.Set;
-import java.util.concurrent.CopyOnWriteArraySet;
-
-import org.apache.felix.dm.Component;
-import org.opendaylight.controller.protocol_plugin.openflow.IReadFilterInternalListener;
-import org.opendaylight.controller.protocol_plugin.openflow.IReadServiceFilter;
-import org.opendaylight.controller.sal.connection.IPluginOutConnectionService;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.Node.NodeIDType;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.NodeTable;
-import org.opendaylight.controller.sal.flowprogrammer.Flow;
-import org.opendaylight.controller.sal.reader.FlowOnNode;
-import org.opendaylight.controller.sal.reader.IPluginInReadService;
-import org.opendaylight.controller.sal.reader.IPluginOutReadService;
-import org.opendaylight.controller.sal.reader.NodeConnectorStatistics;
-import org.opendaylight.controller.sal.reader.NodeDescription;
-import org.opendaylight.controller.sal.reader.NodeTableStatistics;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * Container Instance of IPluginInReadService implementation class
- */
-public class ReadService implements IPluginInReadService, IReadFilterInternalListener {
-    private static final Logger logger = LoggerFactory
-            .getLogger(ReadService.class);
-    private IReadServiceFilter filter;
-    private Set<IPluginOutReadService> pluginOutReadServices = new CopyOnWriteArraySet<IPluginOutReadService>();
-    private String containerName;
-    private IPluginOutConnectionService connectionOutService;
-
-    /**
-     * Function called by the dependency manager when all the required
-     * dependencies are satisfied
-     *
-     */
-    @SuppressWarnings("unchecked")
-    void init(Component c) {
-        Dictionary<Object, Object> props = c.getServiceProperties();
-        containerName = (props != null) ? (String) props.get("containerName") : null;
-    }
-
-    /**
-     * Function called by the dependency manager when at least one
-     * dependency become unsatisfied or when the component is shutting
-     * down because for example bundle is being stopped.
-     *
-     */
-    void destroy() {
-        pluginOutReadServices.clear();
-    }
-
-    /**
-     * Function called by dependency manager after "init ()" is called
-     * and after the services provided by the class are registered in
-     * the service registry
-     *
-     */
-    void start() {
-    }
-
-    /**
-     * Function called by the dependency manager before the services
-     * exported by the component are unregistered, this will be
-     * followed by a "destroy ()" calls
-     *
-     */
-    void stop() {
-    }
-
-    public void setService(IReadServiceFilter filter) {
-        this.filter = filter;
-    }
-
-    public void unsetService(IReadServiceFilter filter) {
-        this.filter = null;
-    }
-
-    public void setPluginOutReadServices(IPluginOutReadService service) {
-        logger.trace("Got a service set request {}", service);
-        if (this.pluginOutReadServices != null) {
-            this.pluginOutReadServices.add(service);
-        }
-    }
-
-    public void unsetPluginOutReadServices(
-            IPluginOutReadService service) {
-        logger.trace("Got a service UNset request");
-        if (this.pluginOutReadServices != null) {
-            this.pluginOutReadServices.remove(service);
-        }
-    }
-    @Override
-    public FlowOnNode readFlow(Node node, Flow flow, boolean cached) {
-        if (!node.getType().equals(NodeIDType.OPENFLOW)) {
-            logger.error("Invalid node type");
-            return null;
-        }
-
-        if (!connectionOutService.isLocal(node)) {
-            logger.debug("This Controller is not the master for the node : " + node);
-            return null;
-        }
-        return filter.readFlow(containerName, node, flow, cached);
-    }
-
-    @Override
-    public List<FlowOnNode> readAllFlow(Node node, boolean cached) {
-        if (!node.getType().equals(NodeIDType.OPENFLOW)) {
-            logger.error("Invalid node type");
-            return Collections.emptyList();
-        }
-
-        if (!connectionOutService.isLocal(node)) {
-            logger.debug("This Controller is not the master for the node : " + node);
-            return Collections.emptyList();
-        }
-
-        return filter.readAllFlow(containerName, node, cached);
-    }
-
-    @Override
-    public NodeDescription readDescription(Node node, boolean cached) {
-        if (!node.getType().equals(NodeIDType.OPENFLOW)) {
-            logger.error("Invalid node type");
-            return null;
-        }
-
-        if (!connectionOutService.isLocal(node)) {
-            logger.debug("This Controller is not the master for the node : " + node);
-            return null;
-        }
-
-        return filter.readDescription(node, cached);
-    }
-
-    @Override
-    public NodeConnectorStatistics readNodeConnector(NodeConnector connector,
-            boolean cached) {
-        if (!connector.getNode().getType()
-            .equals(NodeIDType.OPENFLOW)) {
-            logger.error("Invalid node type");
-            return null;
-        }
-
-        if (!connectionOutService.isLocal(connector.getNode())) {
-            logger.debug("This Controller is not the master for connector : "+connector);
-            return null;
-        }
-
-        return filter.readNodeConnector(containerName, connector, cached);
-    }
-
-    @Override
-    public List<NodeConnectorStatistics> readAllNodeConnector(Node node,
-            boolean cached) {
-        if (!node.getType().equals(NodeIDType.OPENFLOW)) {
-            logger.error("Invalid node type");
-            return Collections.emptyList();
-        }
-
-        if (!connectionOutService.isLocal(node)) {
-            logger.debug("This Controller is not the master for node : " + node);
-            return Collections.emptyList();
-        }
-
-        return filter.readAllNodeConnector(containerName, node, cached);
-    }
-
-    @Override
-    public long getTransmitRate(NodeConnector connector) {
-        if (!connector.getNode().getType()
-            .equals(NodeIDType.OPENFLOW)) {
-            logger.error("Invalid node type");
-            return 0;
-        }
-
-        if (!connectionOutService.isLocal(connector.getNode())) {
-            logger.debug("This Controller is not the master for connector : "+connector);
-            return 0;
-        }
-
-        return filter.getTransmitRate(containerName, connector);
-    }
-
-    @Override
-    public NodeTableStatistics readNodeTable(NodeTable table, boolean cached) {
-        if (!table.getNode().getType()
-                .equals(NodeIDType.OPENFLOW)) {
-            logger.error("Invalid node type");
-            return null;
-        }
-
-        if (!connectionOutService.isLocal(table.getNode())) {
-            logger.debug("This Controller is not the master for connector : "+table);
-            return null;
-        }
-
-        return filter.readNodeTable(containerName, table, cached);
-    }
-
-    @Override
-    public List<NodeTableStatistics> readAllNodeTable(Node node, boolean cached) {
-        if (!node.getType().equals(NodeIDType.OPENFLOW)) {
-            logger.error("Invalid node type");
-            return Collections.emptyList();
-        }
-
-        if (!connectionOutService.isLocal(node)) {
-            logger.debug("This Controller is not the master for node : " + node);
-            return Collections.emptyList();
-        }
-
-        return filter.readAllNodeTable(containerName, node, cached);
-    }
-
-    @Override
-    public void nodeFlowStatisticsUpdated(Node node, List<FlowOnNode> flowStatsList) {
-        if (!connectionOutService.isLocal(node)) {
-            logger.debug("This Controller is not the master for node : " + node);
-            return;
-        }
-        for (IPluginOutReadService service : pluginOutReadServices) {
-            service.nodeFlowStatisticsUpdated(node, flowStatsList);
-        }
-    }
-
-    @Override
-    public void nodeConnectorStatisticsUpdated(Node node, List<NodeConnectorStatistics> ncStatsList) {
-        if (!connectionOutService.isLocal(node)) {
-            logger.debug("This Controller is not the master for node : " + node);
-            return;
-        }
-        for (IPluginOutReadService service : pluginOutReadServices) {
-            service.nodeConnectorStatisticsUpdated(node, ncStatsList);
-        }
-    }
-
-    @Override
-    public void nodeTableStatisticsUpdated(Node node, List<NodeTableStatistics> tableStatsList) {
-        if (!connectionOutService.isLocal(node)) {
-            logger.debug("This Controller is not the master for node : " + node);
-            return;
-        }
-        for (IPluginOutReadService service : pluginOutReadServices) {
-            service.nodeTableStatisticsUpdated(node, tableStatsList);
-        }
-    }
-
-    @Override
-    public void nodeDescriptionStatisticsUpdated(Node node, NodeDescription nodeDescription) {
-        if (!connectionOutService.isLocal(node)) {
-            logger.debug("This Controller is not the master for node : " + node);
-            return;
-        }
-        for (IPluginOutReadService service : pluginOutReadServices) {
-            service.descriptionStatisticsUpdated(node, nodeDescription);
-        }
-    }
-
-    void setIPluginOutConnectionService(IPluginOutConnectionService s) {
-        connectionOutService = s;
-    }
-
-    void unsetIPluginOutConnectionService(IPluginOutConnectionService s) {
-        if (connectionOutService == s) {
-            connectionOutService = null;
-        }
-    }
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/ReadServiceFilter.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/ReadServiceFilter.java
deleted file mode 100644 (file)
index e1b244f..0000000
+++ /dev/null
@@ -1,647 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow.internal;
-
-import java.util.ArrayList;
-import java.util.Collections;
-import java.util.HashSet;
-import java.util.List;
-import java.util.Map;
-import java.util.Set;
-import java.util.concurrent.ConcurrentHashMap;
-import java.util.concurrent.ConcurrentMap;
-
-import org.opendaylight.controller.protocol_plugin.openflow.IOFStatisticsListener;
-import org.opendaylight.controller.protocol_plugin.openflow.IOFStatisticsManager;
-import org.opendaylight.controller.protocol_plugin.openflow.IReadFilterInternalListener;
-import org.opendaylight.controller.protocol_plugin.openflow.IReadServiceFilter;
-import org.opendaylight.controller.protocol_plugin.openflow.core.IController;
-import org.opendaylight.controller.sal.action.Action;
-import org.opendaylight.controller.sal.action.ActionType;
-import org.opendaylight.controller.sal.action.Output;
-import org.opendaylight.controller.sal.core.ContainerFlow;
-import org.opendaylight.controller.sal.core.IContainerAware;
-import org.opendaylight.controller.sal.core.IContainerListener;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.NodeTable;
-import org.opendaylight.controller.sal.core.UpdateType;
-import org.opendaylight.controller.sal.flowprogrammer.Flow;
-import org.opendaylight.controller.sal.match.Match;
-import org.opendaylight.controller.sal.match.MatchType;
-import org.opendaylight.controller.sal.reader.FlowOnNode;
-import org.opendaylight.controller.sal.reader.NodeConnectorStatistics;
-import org.opendaylight.controller.sal.reader.NodeDescription;
-import org.opendaylight.controller.sal.reader.NodeTableStatistics;
-import org.opendaylight.controller.sal.utils.GlobalConstants;
-import org.opendaylight.controller.sal.utils.NodeConnectorCreator;
-import org.opendaylight.controller.sal.utils.NodeCreator;
-import org.opendaylight.controller.sal.utils.NodeTableCreator;
-import org.openflow.protocol.OFMatch;
-import org.openflow.protocol.statistics.OFFlowStatisticsReply;
-import org.openflow.protocol.statistics.OFPortStatisticsReply;
-import org.openflow.protocol.statistics.OFStatistics;
-import org.openflow.protocol.statistics.OFStatisticsType;
-import org.openflow.protocol.statistics.OFTableStatistics;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-/**
- * Read Service shim layer which is in charge of filtering the flow statistics
- * based on container. It is a Global instance.
- */
-public class ReadServiceFilter implements IReadServiceFilter, IContainerListener, IOFStatisticsListener, IContainerAware {
-    private static final Logger logger = LoggerFactory
-            .getLogger(ReadServiceFilter.class);
-    private IController controller = null;
-    private IOFStatisticsManager statsMgr = null;
-    private ConcurrentMap<String, Set<NodeConnector>> containerToNc;
-    private ConcurrentMap<String, Set<Node>> containerToNode;
-    private ConcurrentMap<String, Set<NodeTable>> containerToNt;
-    private ConcurrentMap<String, Set<ContainerFlow>> containerFlows;
-    private ConcurrentMap<String, IReadFilterInternalListener> readFilterInternalListeners =
-        new ConcurrentHashMap<String, IReadFilterInternalListener>();
-
-    public void setController(IController core) {
-        this.controller = core;
-    }
-
-    public void unsetController(IController core) {
-        if (this.controller == core) {
-            this.controller = null;
-        }
-    }
-
-    public void setReadFilterInternalListener(Map<?, ?> props, IReadFilterInternalListener s) {
-        if (props == null) {
-            logger.error("Failed setting Read Filter Listener, property map is null.");
-            return;
-        }
-        String containerName = (String) props.get("containerName");
-        if (containerName == null) {
-            logger.error("Failed setting Read Filter Listener, container name not supplied.");
-            return;
-        }
-        if ((this.readFilterInternalListeners != null) && !this.readFilterInternalListeners.containsValue(s)) {
-            this.readFilterInternalListeners.put(containerName, s);
-            logger.trace("Added Read Filter Listener for container {}", containerName);
-        }
-    }
-
-    public void unsetReadFilterInternalListener(Map<?, ?> props, IReadFilterInternalListener s) {
-        if (props == null) {
-            logger.error("Failed unsetting Read Filter Listener, property map is null.");
-            return;
-        }
-        String containerName = (String) props.get("containerName");
-        if (containerName == null) {
-            logger.error("Failed unsetting Read Filter Listener, containerName not supplied");
-            return;
-        }
-        if ((this.readFilterInternalListeners != null) && this.readFilterInternalListeners.get(containerName) != null
-                && this.readFilterInternalListeners.get(containerName).equals(s)) {
-            this.readFilterInternalListeners.remove(containerName);
-            logger.trace("Removed Read Filter Listener for container {}", containerName);
-        }
-    }
-
-    /**
-     * Function called by the dependency manager when all the required
-     * dependencies are satisfied
-     *
-     */
-    void init() {
-        containerToNc = new ConcurrentHashMap<String, Set<NodeConnector>>();
-        containerToNt = new ConcurrentHashMap<String, Set<NodeTable>>();
-        containerToNode = new ConcurrentHashMap<String, Set<Node>>();
-        containerFlows = new ConcurrentHashMap<String, Set<ContainerFlow>>();
-    }
-
-    /**
-     * Function called by the dependency manager when at least one
-     * dependency become unsatisfied or when the component is shutting
-     * down because for example bundle is being stopped.
-     *
-     */
-    void destroy() {
-        readFilterInternalListeners.clear();
-    }
-
-    /**
-     * Function called by dependency manager after "init ()" is called
-     * and after the services provided by the class are registered in
-     * the service registry
-     *
-     */
-    void start() {
-    }
-
-    /**
-     * Function called by the dependency manager before the services
-     * exported by the component are unregistered, this will be
-     * followed by a "destroy ()" calls
-     *
-     */
-    void stop() {
-    }
-
-    public void setService(IOFStatisticsManager service) {
-        this.statsMgr = service;
-    }
-
-    public void unsetService(IOFStatisticsManager service) {
-        this.statsMgr = null;
-    }
-
-    @Override
-    public FlowOnNode readFlow(String container, Node node, Flow flow, boolean cached) {
-
-        if (controller == null) {
-            // Avoid to provide cached statistics if controller went down.
-            // They are not valid anymore anyway
-            logger.error("Internal plugin error");
-            return null;
-        }
-
-        long sid = (Long) node.getID();
-        OFMatch ofMatch = new FlowConverter(flow).getOFMatch();
-        List<OFStatistics> ofList;
-        if (cached == true){
-            ofList = statsMgr.getOFFlowStatistics(sid, ofMatch, flow.getPriority());
-        } else {
-            ofList = statsMgr.queryStatistics(sid, OFStatisticsType.FLOW, ofMatch);
-            for (OFStatistics ofStat : ofList) {
-                if (((OFFlowStatisticsReply)ofStat).getPriority() == flow.getPriority()){
-                    ofList = new ArrayList<OFStatistics>(1);
-                    ofList.add(ofStat);
-                    break;
-                }
-            }
-        }
-
-        // Convert and filter the statistics per container
-        List<FlowOnNode> flowOnNodeList = new FlowStatisticsConverter(ofList).getFlowOnNodeList(node);
-        List<FlowOnNode> filteredList = filterFlowListPerContainer(container, node, flowOnNodeList);
-
-        return (filteredList.isEmpty()) ? null : filteredList.get(0);
-    }
-
-    @Override
-    public List<FlowOnNode> readAllFlow(String container, Node node,
-            boolean cached) {
-
-        long sid = (Long) node.getID();
-        List<OFStatistics> ofList = (cached == true) ? statsMgr
-                .getOFFlowStatistics(sid) : statsMgr.queryStatistics(sid,
-                OFStatisticsType.FLOW, null);
-
-        // Convert and filter the statistics per container
-        List<FlowOnNode> flowOnNodeList = new FlowStatisticsConverter(ofList).getFlowOnNodeList(node);
-
-        return filterFlowListPerContainer(container, node, flowOnNodeList);
-    }
-
-    @Override
-    public NodeDescription readDescription(Node node, boolean cached) {
-
-        if (controller == null) {
-            logger.error("Internal plugin error");
-            return null;
-        }
-
-        long sid = (Long) node.getID();
-        List<OFStatistics> ofList = (cached == true) ? statsMgr
-                .getOFDescStatistics(sid) : statsMgr.queryStatistics(sid,
-                        OFStatisticsType.DESC, null);
-
-        return new DescStatisticsConverter(ofList).getHwDescription();
-    }
-
-    /**
-     * Filters a list of FlowOnNode elements based on the container
-     *
-     * @param container
-     * @param nodeId
-     * @param list
-     * @return
-     */
-    private List<FlowOnNode> filterFlowListPerContainer(String container,
-            Node nodeId, List<FlowOnNode> list) {
-        if (list == null) {
-            return Collections.emptyList();
-        }
-
-        // Create new filtered list of flows
-        List<FlowOnNode> newList = new ArrayList<FlowOnNode>();
-
-        for (FlowOnNode target : list) {
-            // Check whether the described flow (match + actions) belongs to this container
-            if (flowBelongToContainer(container, nodeId, target.getFlow())) {
-                newList.add(target);
-            }
-        }
-
-        return newList;
-    }
-
-    /**
-     * Filters a list of OFStatistics elements based on the container
-     *
-     * @param container
-     * @param nodeId
-     * @param list
-     * @return
-     */
-    private List<OFStatistics> filterPortListPerContainer(String container, long switchId, List<OFStatistics> list) {
-        if (list == null) {
-            return Collections.emptyList();
-        }
-
-        // Create new filtered list of flows
-        List<OFStatistics> newList = new ArrayList<OFStatistics>();
-
-        for (OFStatistics stat : list) {
-            OFPortStatisticsReply target = (OFPortStatisticsReply) stat;
-            NodeConnector nc = NodeConnectorCreator.createOFNodeConnector(
-                    target.getPortNumber(), NodeCreator.createOFNode(switchId));
-            if (containerOwnsNodeConnector(container, nc)) {
-                newList.add(target);
-            }
-        }
-
-        return newList;
-    }
-
-
-    private List<OFStatistics> filterTableListPerContainer(
-            String container, long switchId, List<OFStatistics> list) {
-        if (list == null) {
-            return Collections.emptyList();
-        }
-
-        // Create new filtered list of node tables
-        List<OFStatistics> newList = new ArrayList<OFStatistics>();
-
-        for (OFStatistics stat : list) {
-            OFTableStatistics target = (OFTableStatistics) stat;
-            NodeTable nt = NodeTableCreator.createOFNodeTable(target.getTableId(), NodeCreator.createOFNode(switchId));
-            if (containerOwnsNodeTable(container, nt)) {
-                newList.add(target);
-            }
-        }
-
-        return newList;
-    }
-
-    /**
-     * Returns whether the specified flow (flow match + actions)
-     * belongs to the container
-     *
-     * @param container
-     * @param node
-     * @param flow
-     * @return true if it belongs
-     */
-    public boolean flowBelongToContainer(String container, Node node, Flow flow) {
-        // All flows belong to the default container
-        if (container.equals(GlobalConstants.DEFAULT.toString())) {
-            return true;
-        }
-        return (flowPortsBelongToContainer(container, node, flow) &&
-                flowVlanBelongsToContainer(container, node, flow) &&
-                isFlowAllowedByContainer(container, flow));
-    }
-
-    /**
-     * Returns whether the passed NodeConnector belongs to the container
-     *
-     * @param container container name
-     * @param p     node connector to test
-     * @return          true if belongs false otherwise
-     */
-    public boolean containerOwnsNodeConnector(String container, NodeConnector p) {
-        // All node connectors belong to the default container
-        if (container.equals(GlobalConstants.DEFAULT.toString())) {
-            return true;
-        }
-        Set<NodeConnector> portSet = containerToNc.get(container);
-        return (portSet == null) ? false : portSet.contains(p);
-    }
-
-    /**
-     * Returns whether the passed NodeConnector belongs to the container
-     *
-     * @param container container name
-     * @param table     node table to test
-     * @return          true if belongs false otherwise
-     */
-    public boolean containerOwnsNodeTable(String container, NodeTable table) {
-        // All node table belong to the default container
-        if (container.equals(GlobalConstants.DEFAULT.toString())) {
-            return true;
-        }
-        Set<NodeTable> tableSet = containerToNt.get(container);
-        return (tableSet == null) ? false : tableSet.contains(table);
-    }
-
-    /**
-     * Returns whether the container flows allow the passed flow
-     *
-     * @param container
-     * @param match
-     * @return
-     */
-    private boolean isFlowAllowedByContainer(String container, Flow flow) {
-        Set<ContainerFlow> cFlowSet = this.containerFlows.get(container);
-        if (cFlowSet == null || cFlowSet.isEmpty()) {
-            return true;
-        }
-        for (ContainerFlow cFlow : cFlowSet) {
-            if (cFlow.allowsFlow(flow)) {
-                return true;
-            }
-        }
-        return false;
-    }
-
-    /**
-     * Check whether the vlan field in the flow match is the same
-     * of the static vlan configured for the container
-     *
-     * @param container
-     * @param node
-     * @param flow
-     * @return
-     */
-    private boolean flowVlanBelongsToContainer(String container, Node node, Flow flow) {
-        return true; // Always true for now
-    }
-
-    /**
-     * Check whether the ports in the flow match and flow actions for
-     * the specified node belong to the container
-     *
-     * @param container
-     * @param node
-     * @param flow
-     * @return
-     */
-    private boolean flowPortsBelongToContainer(String container, Node node,
-            Flow flow) {
-        Match m = flow.getMatch();
-        if (m.isPresent(MatchType.IN_PORT)) {
-            NodeConnector inPort = (NodeConnector) m.getField(MatchType.IN_PORT).getValue();
-            // If the incoming port is specified, check if it belongs to
-            if (!containerOwnsNodeConnector(container, inPort)) {
-                return false;
-            }
-        }
-
-        // If an outgoing port is specified, it must belong to this container
-        for (Action action : flow.getActions()) {
-            if (action.getType() == ActionType.OUTPUT) {
-                NodeConnector outPort = ((Output) action).getPort();
-                if (!containerOwnsNodeConnector(container, outPort)) {
-                    return false;
-                }
-            }
-        }
-        return true;
-    }
-
-    @Override
-    public void containerFlowUpdated(String containerName, ContainerFlow previousFlow,
-            ContainerFlow currentFlow, UpdateType t) {
-        Set<ContainerFlow> cFlowSet = containerFlows.get(containerName);
-        switch (t) {
-        case ADDED:
-            if (cFlowSet == null) {
-                cFlowSet = new HashSet<ContainerFlow>();
-                containerFlows.put(containerName, cFlowSet);
-            }
-            cFlowSet.add(currentFlow);
-        case CHANGED:
-            break;
-        case REMOVED:
-            if (cFlowSet != null) {
-                cFlowSet.remove(currentFlow);
-            }
-            break;
-        default:
-            break;
-        }
-    }
-
-    @Override
-    public void nodeConnectorUpdated(String containerName, NodeConnector p, UpdateType type) {
-
-        switch (type) {
-        case ADDED:
-            if (!containerToNc.containsKey(containerName)) {
-                containerToNc.put(containerName,
-                    Collections.newSetFromMap(new ConcurrentHashMap<NodeConnector,Boolean>()));
-            }
-            containerToNc.get(containerName).add(p);
-            if (!containerToNode.containsKey(containerName)) {
-                containerToNode.put(containerName, new HashSet<Node>());
-            }
-            containerToNode.get(containerName).add(p.getNode());
-            break;
-        case REMOVED:
-            Set<NodeConnector> ncSet = containerToNc.get(containerName);
-            if (ncSet != null) {
-                //remove this nc from container map
-                ncSet.remove(p);
-
-                //check if there are still ports of this node in this container
-                //and if not, remove its mapping
-                boolean nodeInContainer = false;
-                Node node = p.getNode();
-                for (NodeConnector nodeConnector : ncSet) {
-                    if (nodeConnector.getNode().equals(node)){
-                        nodeInContainer = true;
-                        break;
-                    }
-                }
-                if (! nodeInContainer) {
-                    Set<Node> nodeSet = containerToNode.get(containerName);
-                    if (nodeSet != null) {
-                        nodeSet.remove(node);
-                    }
-                }
-            }
-            break;
-        case CHANGED:
-        default:
-        }
-    }
-
-    @Override
-    public void tagUpdated(String containerName, Node n, short oldTag, short newTag, UpdateType t) {
-        // Not interested in this event
-    }
-
-    @Override
-    public void containerModeUpdated(UpdateType t) {
-        // Not interested in this event
-    }
-
-    @Override
-    public NodeConnectorStatistics readNodeConnector(String containerName, NodeConnector connector, boolean cached) {
-        if (!containerOwnsNodeConnector(containerName, connector)) {
-            return null;
-        }
-        Node node = connector.getNode();
-        long sid = (Long) node.getID();
-        short portId = (Short) connector.getID();
-        List<OFStatistics> ofList = (cached == true) ? statsMgr
-                .getOFPortStatistics(sid, portId) : statsMgr.queryStatistics(
-                        sid, OFStatisticsType.PORT, portId);
-
-        List<NodeConnectorStatistics> ncStatistics = new PortStatisticsConverter(sid, ofList)
-                .getNodeConnectorStatsList();
-        return (ncStatistics.isEmpty()) ? new NodeConnectorStatistics() : ncStatistics.get(0);
-    }
-
-    @Override
-    public List<NodeConnectorStatistics> readAllNodeConnector(String containerName, Node node, boolean cached) {
-
-        long sid = (Long) node.getID();
-        List<OFStatistics> ofList = (cached == true) ? statsMgr
-                .getOFPortStatistics(sid) : statsMgr.queryStatistics(sid,
-                        OFStatisticsType.PORT, null);
-
-        List<OFStatistics> filteredList = filterPortListPerContainer(containerName, sid, ofList);
-
-        return new PortStatisticsConverter(sid, filteredList).getNodeConnectorStatsList();
-    }
-
-    @Override
-    public long getTransmitRate(String containerName, NodeConnector connector) {
-        if (!containerOwnsNodeConnector(containerName, connector)) {
-            return 0;
-        }
-
-        long switchId = (Long) connector.getNode().getID();
-        short port = (Short) connector.getID();
-
-        return statsMgr.getTransmitRate(switchId, port);
-    }
-
-    @Override
-    public NodeTableStatistics readNodeTable(String containerName,
-            NodeTable table, boolean cached) {
-        if (!containerOwnsNodeTable(containerName, table)) {
-            return null;
-        }
-        Node node = table.getNode();
-        long sid = (Long) node.getID();
-        Byte tableId = (Byte) table.getID();
-        List<OFStatistics> ofList = (cached == true) ? statsMgr.getOFTableStatistics(sid, tableId) :
-            statsMgr.queryStatistics(sid, OFStatisticsType.TABLE, tableId);
-
-        List<NodeTableStatistics> ntStatistics = new TableStatisticsConverter(sid, ofList).getNodeTableStatsList();
-
-        return (ntStatistics.isEmpty()) ? new NodeTableStatistics() : ntStatistics.get(0);
-    }
-
-    @Override
-    public List<NodeTableStatistics> readAllNodeTable(String containerName, Node node, boolean cached) {
-        long sid = (Long) node.getID();
-        List<OFStatistics> ofList = (cached == true) ?
-                statsMgr.getOFTableStatistics(sid) : statsMgr.queryStatistics(sid, OFStatisticsType.TABLE, null);
-
-        List<OFStatistics> filteredList = filterTableListPerContainer(containerName, sid, ofList);
-
-        return new TableStatisticsConverter(sid, filteredList).getNodeTableStatsList();
-    }
-
-    @Override
-    public void descriptionStatisticsRefreshed(Long switchId, List<OFStatistics> description) {
-        String container;
-        IReadFilterInternalListener listener;
-        Node node = NodeCreator.createOFNode(switchId);
-        NodeDescription nodeDescription = new DescStatisticsConverter(description).getHwDescription();
-        for (Map.Entry<String, IReadFilterInternalListener> l : readFilterInternalListeners.entrySet()) {
-            container = l.getKey();
-            listener = l.getValue();
-            if (container == GlobalConstants.DEFAULT.toString()
-                    || (containerToNode.containsKey(container) && containerToNode.get(container).contains(node))) {
-                listener.nodeDescriptionStatisticsUpdated(node, nodeDescription);
-            }
-        }
-    }
-
-    @Override
-    public void flowStatisticsRefreshed(Long switchId, List<OFStatistics> flows) {
-        String container;
-        IReadFilterInternalListener listener;
-        Node node = NodeCreator.createOFNode(switchId);
-        for (Map.Entry<String, IReadFilterInternalListener> l : readFilterInternalListeners.entrySet()) {
-            container = l.getKey();
-            listener = l.getValue();
-
-            // Convert and filter the statistics per container
-            List<FlowOnNode> flowOnNodeList = new FlowStatisticsConverter(flows).getFlowOnNodeList(node);
-            flowOnNodeList = filterFlowListPerContainer(container, node, flowOnNodeList);
-
-            // notify listeners
-            listener.nodeFlowStatisticsUpdated(node, flowOnNodeList);
-        }
-    }
-
-    @Override
-    public void portStatisticsRefreshed(Long switchId, List<OFStatistics> ports) {
-        String container;
-        IReadFilterInternalListener listener;
-        Node node = NodeCreator.createOFNode(switchId);
-        for (Map.Entry<String, IReadFilterInternalListener> l : readFilterInternalListeners.entrySet()) {
-            container = l.getKey();
-            listener = l.getValue();
-
-            // Convert and filter the statistics per container
-            List<OFStatistics> filteredPorts = filterPortListPerContainer(container, switchId, ports);
-            List<NodeConnectorStatistics> ncStatsList = new PortStatisticsConverter(switchId, filteredPorts)
-                    .getNodeConnectorStatsList();
-
-            // notify listeners
-            listener.nodeConnectorStatisticsUpdated(node, ncStatsList);
-        }
-    }
-
-    @Override
-    public void tableStatisticsRefreshed(Long switchId, List<OFStatistics> tables) {
-        String container;
-        Node node = NodeCreator.createOFNode(switchId);
-        for (Map.Entry<String, IReadFilterInternalListener> l : readFilterInternalListeners.entrySet()) {
-            container = l.getKey();
-
-            // Convert and filter the statistics per container
-            List<OFStatistics> filteredList = filterTableListPerContainer(container, switchId, tables);
-            List<NodeTableStatistics> tableStatsList = new TableStatisticsConverter(switchId, filteredList)
-                    .getNodeTableStatsList();
-
-            // notify listeners
-            l.getValue().nodeTableStatisticsUpdated(node, tableStatsList);
-        }
-    }
-
-    @Override
-    public void containerCreate(String containerName) {
-        // do nothing
-    }
-
-    @Override
-    public void containerDestroy(String containerName) {
-        containerToNc.remove(containerName);
-        containerToNode.remove(containerName);
-        containerToNt.remove(containerName);
-        containerFlows.remove(containerName);
-    }
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/TableConverter.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/TableConverter.java
deleted file mode 100644 (file)
index 0b53284..0000000
+++ /dev/null
@@ -1,30 +0,0 @@
-/*
- * Copyright (c) 2013 Big Switch Networks, Inc.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow.internal;
-
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeTable;
-import org.opendaylight.controller.sal.utils.NodeTableCreator;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-public class TableConverter {
-    private static final Logger log = LoggerFactory
-            .getLogger(TableConverter.class);
-
-    public static NodeTable toNodeTable(byte tableId, Node node) {
-        log.trace("Openflow table ID: {}", Byte.toString(tableId));
-        return NodeTableCreator.createNodeTable(tableId, node);
-    }
-
-    public static byte toOFTable(NodeTable salTable) {
-        log.trace("SAL Table: {}", salTable);
-        return (Byte) salTable.getID();
-    }
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/TableStatisticsConverter.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/TableStatisticsConverter.java
deleted file mode 100644 (file)
index 35a7638..0000000
+++ /dev/null
@@ -1,65 +0,0 @@
-/*
- * Copyright (c) 2013 Big Switch Networks, Inc.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.protocol_plugin.openflow.internal;
-
-import java.util.ArrayList;
-import java.util.Collections;
-import java.util.List;
-
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.reader.NodeTableStatistics;
-import org.opendaylight.controller.sal.utils.NodeCreator;
-import org.openflow.protocol.statistics.OFStatistics;
-import org.openflow.protocol.statistics.OFTableStatistics;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * Converts an openflow list of table statistics in a SAL list of
- * NodeTableStatistics objects
- */
-public class TableStatisticsConverter {
-    private static final Logger log = LoggerFactory
-            .getLogger(TableStatisticsConverter.class);
-
-    private final long switchId;
-    private List<OFStatistics> ofStatsList;
-    private List<NodeTableStatistics> ntStatsList;
-
-    public TableStatisticsConverter(long switchId, List<OFStatistics> statsList) {
-        this.switchId = switchId;
-        if (statsList == null || statsList.isEmpty()) {
-            this.ofStatsList = Collections.emptyList();
-        } else {
-            this.ofStatsList = new ArrayList<OFStatistics>(statsList);
-        }
-        this.ntStatsList = null;
-    }
-
-    public List<NodeTableStatistics> getNodeTableStatsList() {
-        if (this.ofStatsList != null && this.ntStatsList == null) {
-            this.ntStatsList = new ArrayList<NodeTableStatistics>();
-            OFTableStatistics ofTableStat;
-            Node node = NodeCreator.createOFNode(switchId);
-            for (OFStatistics ofStat : this.ofStatsList) {
-                ofTableStat = (OFTableStatistics) ofStat;
-                NodeTableStatistics ntStat = new NodeTableStatistics();
-                ntStat.setNodeTable(TableConverter.toNodeTable(
-                        ofTableStat.getTableId(), node));
-                ntStat.setActiveCount(ofTableStat.getActiveCount());
-                ntStat.setLookupCount(ofTableStat.getLookupCount());
-                ntStat.setMatchedCount(ofTableStat.getMatchedCount());
-                ntStat.setMaximumEntries(ofTableStat.getMaximumEntries());
-                this.ntStatsList.add(ntStat);
-            }
-        }
-        log.trace("OFStatistics: {} NodeTableStatistics: {}", ofStatsList,
-                ntStatsList);
-        return this.ntStatsList;
-    }
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/TopologyServiceShim.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/TopologyServiceShim.java
deleted file mode 100644 (file)
index 08ddbde..0000000
+++ /dev/null
@@ -1,959 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow.internal;
-
-import java.util.ArrayList;
-import java.util.Collection;
-import java.util.HashMap;
-import java.util.HashSet;
-import java.util.List;
-import java.util.Map;
-import java.util.Set;
-import java.util.Timer;
-import java.util.TimerTask;
-import java.util.concurrent.BlockingQueue;
-import java.util.concurrent.ConcurrentHashMap;
-import java.util.concurrent.ConcurrentMap;
-import java.util.concurrent.CopyOnWriteArrayList;
-import java.util.concurrent.LinkedBlockingQueue;
-
-import org.apache.commons.lang3.tuple.ImmutablePair;
-import org.apache.commons.lang3.tuple.Pair;
-import org.eclipse.osgi.framework.console.CommandInterpreter;
-import org.eclipse.osgi.framework.console.CommandProvider;
-import org.opendaylight.controller.protocol_plugin.openflow.IDiscoveryListener;
-import org.opendaylight.controller.protocol_plugin.openflow.IInventoryShimExternalListener;
-import org.opendaylight.controller.protocol_plugin.openflow.IOFStatisticsManager;
-import org.opendaylight.controller.protocol_plugin.openflow.IRefreshInternalProvider;
-import org.opendaylight.controller.protocol_plugin.openflow.ITopologyServiceShimListener;
-import org.opendaylight.controller.sal.core.Bandwidth;
-import org.opendaylight.controller.sal.core.Config;
-import org.opendaylight.controller.sal.core.ContainerFlow;
-import org.opendaylight.controller.sal.core.Edge;
-import org.opendaylight.controller.sal.core.IContainerAware;
-import org.opendaylight.controller.sal.core.IContainerListener;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.core.State;
-import org.opendaylight.controller.sal.core.UpdateType;
-import org.opendaylight.controller.sal.topology.TopoEdgeUpdate;
-import org.opendaylight.controller.sal.utils.GlobalConstants;
-import org.osgi.framework.BundleContext;
-import org.osgi.framework.FrameworkUtil;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * The class describes a shim layer that relays the topology events from
- * OpenFlow core to various listeners. The notifications are filtered based on
- * container configurations.
- */
-public class TopologyServiceShim implements IDiscoveryListener,
-        IContainerListener, CommandProvider, IRefreshInternalProvider,
-        IInventoryShimExternalListener, IContainerAware {
-    protected static final Logger logger = LoggerFactory
-            .getLogger(TopologyServiceShim.class);
-    private ConcurrentMap<String, ITopologyServiceShimListener> topologyServiceShimListeners = new ConcurrentHashMap<String, ITopologyServiceShimListener>();
-    private ConcurrentMap<NodeConnector, List<String>> containerMap = new ConcurrentHashMap<NodeConnector, List<String>>();
-    private ConcurrentMap<String, ConcurrentMap<NodeConnector, Pair<Edge, Set<Property>>>> edgeMap = new ConcurrentHashMap<String, ConcurrentMap<NodeConnector, Pair<Edge, Set<Property>>>>();
-
-    private BlockingQueue<NotifyEntry> notifyQ;
-    private Thread notifyThread;
-    private BlockingQueue<String> bulkNotifyQ;
-    private Thread ofPluginTopoBulkUpdate;
-    private volatile Boolean shuttingDown = false;
-    private IOFStatisticsManager statsMgr;
-    private Timer pollTimer;
-    private TimerTask txRatePoller;
-    private Thread bwUtilNotifyThread;
-    private BlockingQueue<UtilizationUpdate> bwUtilNotifyQ;
-    private List<NodeConnector> connectorsOverUtilized;
-    private float bwThresholdFactor = (float) 0.8; // Threshold = 80% of link
-                                                   // bandwidth
-
-    class NotifyEntry {
-        String container;
-        List<TopoEdgeUpdate> teuList;
-
-        public NotifyEntry(String container, TopoEdgeUpdate teu) {
-            this.container = container;
-            this.teuList = new ArrayList<TopoEdgeUpdate>();
-            if (teu != null) {
-                this.teuList.add(teu);
-            }
-        }
-
-        public NotifyEntry(String container, List<TopoEdgeUpdate> teuList) {
-            this.container = container;
-            this.teuList = new ArrayList<TopoEdgeUpdate>();
-            if (teuList != null) {
-                this.teuList.addAll(teuList);
-            }
-        }
-    }
-
-    class TopologyNotify implements Runnable {
-        private final BlockingQueue<NotifyEntry> notifyQ;
-        private NotifyEntry entry;
-        private Map<String, List<TopoEdgeUpdate>> teuMap = new HashMap<String, List<TopoEdgeUpdate>>();
-        private List<TopoEdgeUpdate> teuList;
-        private boolean notifyListeners;
-
-        TopologyNotify(BlockingQueue<NotifyEntry> notifyQ) {
-            this.notifyQ = notifyQ;
-        }
-
-        @Override
-        public void run() {
-            while (true) {
-                try {
-                    teuMap.clear();
-                    notifyListeners = false;
-                    while (!notifyQ.isEmpty()) {
-                        entry = notifyQ.take();
-                        teuList = teuMap.get(entry.container);
-                        if (teuList == null) {
-                            teuList = new ArrayList<TopoEdgeUpdate>();
-                        }
-                        // group all the updates together
-                        teuList.addAll(entry.teuList);
-                        teuMap.put(entry.container, teuList);
-                        notifyListeners = true;
-                    }
-
-                    if (notifyListeners) {
-                        for (String container : teuMap.keySet()) {
-                            // notify the listener
-                            ITopologyServiceShimListener l = topologyServiceShimListeners.get(container);
-                            // container topology service may not have come up yet
-                            if (l != null) {
-                                l.edgeUpdate(teuMap.get(container));
-                            }
-                        }
-                    }
-
-                    Thread.sleep(100);
-                } catch (InterruptedException e1) {
-                    logger.trace("TopologyNotify interrupted {}",
-                            e1.getMessage());
-                    if (shuttingDown) {
-                        return;
-                    }
-                } catch (Exception e2) {
-                    logger.error("", e2);
-                }
-            }
-        }
-    }
-
-    class UtilizationUpdate {
-        NodeConnector connector;
-        UpdateType type;
-
-        UtilizationUpdate(NodeConnector connector, UpdateType type) {
-            this.connector = connector;
-            this.type = type;
-        }
-    }
-
-    class BwUtilizationNotify implements Runnable {
-        private final BlockingQueue<UtilizationUpdate> notifyQ;
-
-        BwUtilizationNotify(BlockingQueue<UtilizationUpdate> notifyQ) {
-            this.notifyQ = notifyQ;
-        }
-
-        @Override
-        public void run() {
-            while (true) {
-                try {
-                    UtilizationUpdate update = notifyQ.take();
-                    NodeConnector connector = update.connector;
-                    Set<String> containerList = edgeMap.keySet();
-                    for (String container : containerList) {
-                        Map<NodeConnector, Pair<Edge, Set<Property>>> edgePropsMap = edgeMap
-                                .get(container);
-                        // the edgePropsMap for a particular container may not have
-                        // the connector.
-                        // so check for null
-                        Pair<Edge, Set<Property>> edgeProp = edgePropsMap.get(connector);
-                        if(edgeProp != null) {
-                            Edge edge = edgeProp.getLeft();
-                            if (edge.getTailNodeConnector().equals(connector)) {
-                                ITopologyServiceShimListener topologServiceShimListener = topologyServiceShimListeners
-                                        .get(container);
-                                if (update.type == UpdateType.ADDED) {
-                                    topologServiceShimListener
-                                    .edgeOverUtilized(edge);
-                                } else {
-                                    topologServiceShimListener
-                                    .edgeUtilBackToNormal(edge);
-                                }
-                            }
-                        }
-                    }
-                } catch (InterruptedException e1) {
-                    logger.trace(
-                            "Edge Bandwidth Utilization Notify Thread interrupted {}",
-                            e1.getMessage());
-                    if (shuttingDown) {
-                        return;
-                    }
-                } catch (Exception e2) {
-                    logger.error("", e2);
-                }
-            }
-        }
-    }
-
-    /**
-     * Function called by the dependency manager when all the required
-     * dependencies are satisfied
-     *
-     */
-    void init() {
-        logger.trace("Init called");
-        connectorsOverUtilized = new ArrayList<NodeConnector>();
-        notifyQ = new LinkedBlockingQueue<NotifyEntry>();
-        notifyThread = new Thread(new TopologyNotify(notifyQ));
-        bwUtilNotifyQ = new LinkedBlockingQueue<UtilizationUpdate>();
-        bwUtilNotifyThread = new Thread(new BwUtilizationNotify(bwUtilNotifyQ));
-        bulkNotifyQ = new LinkedBlockingQueue<String>();
-        ofPluginTopoBulkUpdate = new Thread(new Runnable() {
-            @Override
-            public void run() {
-                while (true) {
-                    try {
-                        String containerName = bulkNotifyQ.take();
-                        logger.debug("Bulk Notify container:{}", containerName);
-                        TopologyBulkUpdate(containerName);
-                    } catch (InterruptedException e) {
-                        logger.trace("Topology Bulk update thread interrupted");
-                        if (shuttingDown) {
-                            return;                        }
-                    }
-                }
-            }
-        }, "Topology Bulk Update");
-
-        // Initialize node connector tx bit rate poller timer
-        pollTimer = new Timer();
-        txRatePoller = new TimerTask() {
-            @Override
-            public void run() {
-                pollTxBitRates();
-            }
-        };
-
-        registerWithOSGIConsole();
-    }
-
-    /**
-     * Continuously polls the transmit bit rate for all the node connectors from
-     * statistics manager and trigger the warning notification upward when the
-     * transmit rate is above a threshold which is a percentage of the edge
-     * bandwidth
-     */
-    protected void pollTxBitRates() {
-        Map<NodeConnector, Pair<Edge, Set<Property>>> globalContainerEdges = edgeMap
-                .get(GlobalConstants.DEFAULT.toString());
-        if (shuttingDown) {
-            logger.trace("Getting out the pollTxBitRates because bundle going down");
-            return;
-        }
-        if (globalContainerEdges == null) {
-            return;
-        }
-
-        for (NodeConnector connector : globalContainerEdges.keySet()) {
-            // Skip if node connector belongs to production switch
-            if (connector.getType().equals(
-                    NodeConnector.NodeConnectorIDType.PRODUCTION)) {
-                continue;
-            }
-
-            // Get edge for which this node connector is head
-            Pair<Edge, Set<Property>> props = this.edgeMap.get(
-                    GlobalConstants.DEFAULT.toString()).get(connector);
-            // On switch mgr restart the props get reset
-            if (props == null) {
-                continue;
-            }
-            Set<Property> propSet = props.getRight();
-            if (propSet == null) {
-                continue;
-            }
-
-            float bw = 0;
-            for (Property prop : propSet) {
-                if (prop instanceof Bandwidth) {
-                    bw = ((Bandwidth) prop).getValue();
-                    break;
-                }
-            }
-
-            // Skip if agent did not provide a bandwidth info for the edge
-            if (bw == 0) {
-                continue;
-            }
-
-            // Compare bandwidth usage
-            Long switchId = (Long) connector.getNode().getID();
-            Short port = (Short) connector.getID();
-            if (statsMgr != null) {
-                float rate = statsMgr.getTransmitRate(switchId, port);
-                if (rate > bwThresholdFactor * bw) {
-                    if (!connectorsOverUtilized.contains(connector)) {
-                        connectorsOverUtilized.add(connector);
-                        this.bwUtilNotifyQ.add(new UtilizationUpdate(connector, UpdateType.ADDED));
-                    }
-                } else {
-                    if (connectorsOverUtilized.contains(connector)) {
-                        connectorsOverUtilized.remove(connector);
-                        this.bwUtilNotifyQ.add(new UtilizationUpdate(connector, UpdateType.REMOVED));
-                    }
-                }
-            }
-        }
-
-    }
-
-    /**
-     * Function called by the dependency manager when at least one dependency
-     * become unsatisfied or when the component is shutting down because for
-     * example bundle is being stopped.
-     *
-     */
-    void destroy() {
-        logger.trace("DESTROY called!");
-        notifyQ = null;
-        notifyThread = null;
-    }
-
-    /**
-     * Function called by dependency manager after "init ()" is called and after
-     * the services provided by the class are registered in the service registry
-     *
-     */
-    void start() {
-        logger.trace("START called!");
-        notifyThread.start();
-        bwUtilNotifyThread.start();
-        ofPluginTopoBulkUpdate.start();
-        pollTimer.scheduleAtFixedRate(txRatePoller, 10000, 5000);
-    }
-
-    /**
-     * Function called by the dependency manager before the services exported by
-     * the component are unregistered, this will be followed by a "destroy ()"
-     * calls
-     *
-     */
-    void stop() {
-        logger.trace("STOP called!");
-        shuttingDown = true;
-        notifyThread.interrupt();
-        bwUtilNotifyThread.interrupt();
-        ofPluginTopoBulkUpdate.interrupt();
-        pollTimer.cancel();
-    }
-
-    void setTopologyServiceShimListener(Map<?, ?> props,
-            ITopologyServiceShimListener s) {
-        if (props == null) {
-            logger.error("Didn't receive the service properties");
-            return;
-        }
-        String containerName = (String) props.get("containerName");
-        if (containerName == null) {
-            logger.error("containerName not supplied");
-            return;
-        }
-        if ((this.topologyServiceShimListeners != null)
-                && !this.topologyServiceShimListeners
-                        .containsKey(containerName)) {
-            this.topologyServiceShimListeners.put(containerName, s);
-            logger.trace("Added topologyServiceShimListener for container: {}",
-                    containerName);
-        }
-    }
-
-    void unsetTopologyServiceShimListener(Map<?, ?> props,
-            ITopologyServiceShimListener s) {
-        if (props == null) {
-            logger.error("Didn't receive the service properties");
-            return;
-        }
-        String containerName = (String) props.get("containerName");
-        if (containerName == null) {
-            logger.error("containerName not supplied");
-            return;
-        }
-        if ((this.topologyServiceShimListeners != null)
-                && this.topologyServiceShimListeners.containsKey(containerName)
-                && this.topologyServiceShimListeners.get(containerName).equals(
-                        s)) {
-            this.topologyServiceShimListeners.remove(containerName);
-            logger.trace(
-                    "Removed topologyServiceShimListener for container: {}",
-                    containerName);
-        }
-    }
-
-    void setStatisticsManager(IOFStatisticsManager s) {
-        this.statsMgr = s;
-    }
-
-    void unsetStatisticsManager(IOFStatisticsManager s) {
-        if (this.statsMgr == s) {
-            this.statsMgr = null;
-        }
-    }
-
-    private void updateContainerMap(List<String> containers, NodeConnector p) {
-        if (containers.isEmpty()) {
-            // Do cleanup to reduce memory footprint if no
-            // elements to be tracked
-            this.containerMap.remove(p);
-        } else {
-            this.containerMap.put(p, containers);
-        }
-    }
-
-    /**
-     * From a given edge map, retrieve the edge sourced by the port and update
-     * the local cache in the container
-     *
-     * @param container
-     *            the container name
-     * @param nodeConnector
-     *            the node connector
-     * @param edges
-     *            the given edge map
-     * @return the found edge
-     */
-    private Edge addEdge(String container, NodeConnector nodeConnector,
-            Map<NodeConnector, Pair<Edge, Set<Property>>> edges) {
-        logger.debug("Search edge sourced by port {} in container {}", nodeConnector, container);
-
-        // Retrieve the associated edge
-        Pair<Edge, Set<Property>> edgeProps = edges.get(nodeConnector);
-        if (edgeProps == null) {
-            logger.debug("edgePros is null for port {} in container {}", nodeConnector, container);
-            return null;
-        }
-
-        Edge edge = edgeProps.getLeft();
-        if (edge == null) {
-            logger.debug("edge is null for port {} in container {}", nodeConnector, container);
-            return null;
-        }
-
-        // Make sure the peer port is in the same container
-        NodeConnector peerConnector = edge.getHeadNodeConnector();
-        List<String> containers = this.containerMap.get(peerConnector);
-        if ((containers == null) || !containers.contains(container)) {
-            logger.debug("peer port {} of edge {} is not part of the container {}", new Object[] { peerConnector, edge,
-                    container });
-            return null;
-        }
-
-        // Update the local cache
-        updateLocalEdgeMap(container, edge, UpdateType.ADDED, edgeProps.getRight());
-        logger.debug("Added edge {} to local cache in container {}", edge, container);
-
-        return edge;
-    }
-
-    private void addNodeConnector(String container,
-            NodeConnector nodeConnector) {
-        // Use the global edge map for the newly added port in a container
-        Map<NodeConnector, Pair<Edge, Set<Property>>> globalEdgeMap = edgeMap.get(GlobalConstants.DEFAULT
-                .toString());
-        if (globalEdgeMap == null) {
-            return;
-        }
-
-        // Get the edge and update local cache in the container
-        Edge edge1, edge2;
-        edge1 = addEdge(container, nodeConnector, globalEdgeMap);
-        if (edge1 == null) {
-            return;
-        }
-
-        // Get the edge in reverse direction and update local cache in the container
-        NodeConnector peerConnector = edge1.getHeadNodeConnector();
-        edge2 = addEdge(container, peerConnector, globalEdgeMap);
-
-        // Send notification upwards in one shot
-        List<TopoEdgeUpdate> teuList = new ArrayList<TopoEdgeUpdate>();
-        teuList.add(new TopoEdgeUpdate(edge1, null, UpdateType.ADDED));
-        logger.debug("Notify edge1: {} in container {}", edge1, container);
-        if (edge2 != null) {
-            teuList.add(new TopoEdgeUpdate(edge2, null, UpdateType.ADDED));
-            logger.debug("Notify edge2: {} in container {}", edge2, container);
-        }
-        notifyEdge(container, teuList);
-    }
-
-    private void removeNodeConnector(String container,
-            NodeConnector nodeConnector) {
-        List<TopoEdgeUpdate> teuList = new ArrayList<TopoEdgeUpdate>();
-        Map<NodeConnector, Pair<Edge, Set<Property>>> edgePropsMap = edgeMap
-                .get(container);
-        if (edgePropsMap == null) {
-            return;
-        }
-
-        // Remove edge in one direction
-        Pair<Edge, Set<Property>> edgeProps = edgePropsMap.get(nodeConnector);
-        if (edgeProps == null) {
-            return;
-        }
-        teuList.add(new TopoEdgeUpdate(edgeProps.getLeft(), null,
-                UpdateType.REMOVED));
-
-        // Remove edge in another direction
-        edgeProps = edgePropsMap
-                .get(edgeProps.getLeft().getHeadNodeConnector());
-        if (edgeProps == null) {
-            return;
-        }
-        teuList.add(new TopoEdgeUpdate(edgeProps.getLeft(), null,
-                UpdateType.REMOVED));
-
-        // Update in one shot
-        notifyEdge(container, teuList);
-    }
-
-    /**
-     * Update local cache and return true if it needs to notify upper layer
-     * Topology listeners.
-     *
-     * @param container
-     *            The network container
-     * @param edge
-     *            The edge
-     * @param type
-     *            The update type
-     * @param props
-     *            The edge properties
-     * @return true if it needs to notify upper layer Topology listeners
-     */
-    private boolean updateLocalEdgeMap(String container, Edge edge,
-            UpdateType type, Set<Property> props) {
-        ConcurrentMap<NodeConnector, Pair<Edge, Set<Property>>> edgePropsMap = edgeMap
-                .get(container);
-        NodeConnector src = edge.getTailNodeConnector();
-        Pair<Edge, Set<Property>> edgeProps = new ImmutablePair<Edge, Set<Property>>(
-                edge, props);
-        boolean rv = false;
-
-        switch (type) {
-        case ADDED:
-        case CHANGED:
-            if (edgePropsMap == null) {
-                edgePropsMap = new ConcurrentHashMap<NodeConnector, Pair<Edge, Set<Property>>>();
-                rv = true;
-            } else {
-                if (edgePropsMap.containsKey(src)
-                        && edgePropsMap.get(src).equals(edgeProps)) {
-                    // Entry already exists. No update.
-                    rv = false;
-                } else {
-                    rv = true;
-                }
-            }
-            if (rv) {
-                edgePropsMap.put(src, edgeProps);
-                edgeMap.put(container, edgePropsMap);
-            }
-            break;
-        case REMOVED:
-            if ((edgePropsMap != null) && edgePropsMap.containsKey(src)) {
-                edgePropsMap.remove(src);
-                if (edgePropsMap.isEmpty()) {
-                    edgeMap.remove(container);
-                } else {
-                    edgeMap.put(container, edgePropsMap);
-                }
-                rv = true;
-            }
-            break;
-        default:
-            logger.debug(
-                    "notifyLocalEdgeMap: invalid {} for Edge {} in container {}",
-                    new Object[] { type.getName(), edge, container });
-        }
-
-        if (rv) {
-            logger.debug(
-                    "notifyLocalEdgeMap: {} for Edge {} in container {}",
-                    new Object[] { type.getName(), edge, container });
-        }
-
-        return rv;
-    }
-
-    private void notifyEdge(String container, Edge edge, UpdateType type,
-            Set<Property> props) {
-        boolean notifyListeners;
-
-        // Update local cache
-        notifyListeners = updateLocalEdgeMap(container, edge, type, props);
-
-        // Prepare to update TopologyService
-        if (notifyListeners) {
-            notifyQ.add(new NotifyEntry(container, new TopoEdgeUpdate(edge, props,
-                    type)));
-            logger.debug("notifyEdge: {} Edge {} in container {}",
-                    new Object[] { type.getName(), edge, container });
-        }
-    }
-
-    private void notifyEdge(String container, List<TopoEdgeUpdate> etuList) {
-        if (etuList == null) {
-            return;
-        }
-
-        Edge edge;
-        UpdateType type;
-        List<TopoEdgeUpdate> etuNotifyList = new ArrayList<TopoEdgeUpdate>();
-        boolean notifyListeners = false, rv;
-
-        for (TopoEdgeUpdate etu : etuList) {
-            edge = etu.getEdge();
-            type = etu.getUpdateType();
-
-            // Update local cache
-            rv = updateLocalEdgeMap(container, edge, type, etu.getProperty());
-            if (rv) {
-                if (!notifyListeners) {
-                    notifyListeners = true;
-                }
-                etuNotifyList.add(etu);
-                logger.debug(
-                        "notifyEdge(TopoEdgeUpdate): {} Edge {} in container {}",
-                        new Object[] { type.getName(), edge, container });
-            }
-        }
-
-        // Prepare to update TopologyService
-        if (notifyListeners) {
-            notifyQ.add(new NotifyEntry(container, etuNotifyList));
-            logger.debug("notifyEdge(TopoEdgeUpdate): add notifyQ");
-        }
-    }
-
-    @Override
-    public void notifyEdge(Edge edge, UpdateType type, Set<Property> props) {
-        if ((edge == null) || (type == null)) {
-            return;
-        }
-
-        // Notify default container
-        notifyEdge(GlobalConstants.DEFAULT.toString(), edge, type, props);
-
-        // Notify the corresponding containers
-        List<String> containers = getEdgeContainers(edge);
-        if (containers != null) {
-            for (String container : containers) {
-                notifyEdge(container, edge, type, props);
-            }
-        }
-    }
-
-    /*
-     * Return a list of containers the edge associated with
-     */
-    private List<String> getEdgeContainers(Edge edge) {
-        NodeConnector src = edge.getTailNodeConnector(), dst = edge
-                .getHeadNodeConnector();
-
-        if (!src.getType().equals(NodeConnector.NodeConnectorIDType.PRODUCTION)) {
-            /* Find the common containers for both ends */
-            List<String> srcContainers = this.containerMap.get(src), dstContainers = this.containerMap
-                    .get(dst), cmnContainers = null;
-            if ((srcContainers != null) && (dstContainers != null)) {
-                cmnContainers = new ArrayList<String>(srcContainers);
-                cmnContainers.retainAll(dstContainers);
-            }
-            return cmnContainers;
-        } else {
-            /*
-             * If the neighbor is part of a monitored production network, get
-             * the containers that the edge port belongs to
-             */
-            return this.containerMap.get(dst);
-        }
-    }
-
-    @Override
-    public void tagUpdated(String containerName, Node n, short oldTag,
-            short newTag, UpdateType t) {
-    }
-
-    @Override
-    public void containerFlowUpdated(String containerName,
-            ContainerFlow previousFlow, ContainerFlow currentFlow, UpdateType t) {
-    }
-
-    @Override
-    public void nodeConnectorUpdated(String containerName, NodeConnector p,
-            UpdateType t) {
-        if (this.containerMap == null) {
-            logger.error("containerMap is NULL");
-            return;
-        }
-        List<String> containers = this.containerMap.get(p);
-        if (containers == null) {
-            containers = new CopyOnWriteArrayList<String>();
-        }
-        switch (t) {
-        case ADDED:
-            if (!containers.contains(containerName)) {
-                containers.add(containerName);
-                updateContainerMap(containers, p);
-                addNodeConnector(containerName, p);
-            }
-            break;
-        case REMOVED:
-            if (containers.contains(containerName)) {
-                containers.remove(containerName);
-                updateContainerMap(containers, p);
-                removeNodeConnector(containerName, p);
-            }
-            break;
-        case CHANGED:
-            break;
-        }
-    }
-
-    @Override
-    public void containerModeUpdated(UpdateType t) {
-        // do nothing
-    }
-
-    private void registerWithOSGIConsole() {
-        BundleContext bundleContext = FrameworkUtil.getBundle(this.getClass())
-                .getBundleContext();
-        bundleContext.registerService(CommandProvider.class.getName(), this,
-                null);
-    }
-
-    @Override
-    public String getHelp() {
-        StringBuffer help = new StringBuffer();
-        help.append("---Topology Service Shim---\n");
-        help.append("\t pem [container]               - Print edgeMap entries");
-        help.append(" for a given container\n");
-        return help.toString();
-    }
-
-    public void _pem(CommandInterpreter ci) {
-        String container = ci.nextArgument();
-        if (container == null) {
-            container = GlobalConstants.DEFAULT.toString();
-        }
-
-        ci.println("Container: " + container);
-        ci.println("                             Edge                                          Bandwidth");
-
-        Map<NodeConnector, Pair<Edge, Set<Property>>> edgePropsMap = edgeMap
-                .get(container);
-        if (edgePropsMap == null) {
-            return;
-        }
-        int count = 0;
-        for (Pair<Edge, Set<Property>> edgeProps : edgePropsMap.values()) {
-            if (edgeProps == null) {
-                continue;
-            }
-
-            long bw = 0;
-            Set<Property> props = edgeProps.getRight();
-            if (props != null) {
-                for (Property prop : props) {
-                    if (prop.getName().equals(Bandwidth.BandwidthPropName)) {
-                        bw = ((Bandwidth) prop).getValue();
-                    }
-                }
-            }
-            count++;
-            ci.println(edgeProps.getLeft() + "          " + bw);
-        }
-        ci.println("Total number of Edges: " + count);
-    }
-
-    public void _bwfactor(CommandInterpreter ci) {
-        String factorString = ci.nextArgument();
-        if (factorString == null) {
-            ci.println("Bw threshold: " + this.bwThresholdFactor);
-            ci.println("Insert a non null bw threshold");
-            return;
-        }
-        bwThresholdFactor = Float.parseFloat(factorString);
-        ci.println("New Bw threshold: " + this.bwThresholdFactor);
-    }
-
-    /**
-     * This method will trigger topology updates to be sent toward SAL. SAL then
-     * pushes the updates to ALL the applications that have registered as
-     * listeners for this service. SAL has no way of knowing which application
-     * requested for the refresh.
-     *
-     * As an example of this case, is stopping and starting the Topology
-     * Manager. When the topology Manager is stopped, and restarted, it will no
-     * longer have the latest topology. Hence, a request is sent here.
-     *
-     * @param containerName
-     * @return void
-     */
-    @Override
-    public void requestRefresh(String containerName) {
-        // wake up a bulk update thread and exit
-        // the thread will execute the bulkUpdate()
-        bulkNotifyQ.add(containerName);
-    }
-
-    /**
-     * Retrieve the edges for a given container
-     *
-     * @param containerName
-     *            the container name
-     * @return the edges and their properties
-     */
-    private Collection<Pair<Edge, Set<Property>>> getEdgeProps(String containerName) {
-        Map<NodeConnector, Pair<Edge, Set<Property>>> edgePropMap = null;
-        edgePropMap = edgeMap.get(containerName);
-        if (edgePropMap == null) {
-            return null;
-        }
-        return edgePropMap.values();
-    }
-
-    /**
-     * Reading the current topology database, the method will replay all the
-     * edge updates for the ITopologyServiceShimListener instance in the given
-     * container, which will in turn publish them toward SAL.
-     *
-     * @param containerName
-     *            the container name
-     */
-    private void TopologyBulkUpdate(String containerName) {
-        Collection<Pair<Edge, Set<Property>>> edgeProps = null;
-
-        logger.debug("Try bulk update for container:{}", containerName);
-        edgeProps = getEdgeProps(containerName);
-        if (edgeProps == null) {
-            logger.debug("No edges known for container:{}", containerName);
-            return;
-        }
-        ITopologyServiceShimListener topologServiceShimListener = topologyServiceShimListeners
-                .get(containerName);
-        if (topologServiceShimListener == null) {
-            logger.debug("No topology service shim listener for container:{}",
-                    containerName);
-            return;
-        }
-        int i = 0;
-        List<TopoEdgeUpdate> teuList = new ArrayList<TopoEdgeUpdate>();
-        for (Pair<Edge, Set<Property>> edgeProp : edgeProps) {
-            if (edgeProp != null) {
-                i++;
-                teuList.add(new TopoEdgeUpdate(edgeProp.getLeft(), edgeProp
-                        .getRight(), UpdateType.ADDED));
-                logger.trace("Add edge {}", edgeProp.getLeft());
-            }
-        }
-        if (i > 0) {
-            topologServiceShimListener.edgeUpdate(teuList);
-        }
-        logger.debug("Sent {} updates", i);
-    }
-
-    @Override
-    public void updateNode(Node node, UpdateType type, Set<Property> props) {
-    }
-
-    @Override
-    public void updateNodeConnector(NodeConnector nodeConnector,
-            UpdateType type, Set<Property> props) {
-        List<String> containers = new ArrayList<String>();
-        List<String> conList = this.containerMap.get(nodeConnector);
-
-        containers.add(GlobalConstants.DEFAULT.toString());
-        if (conList != null) {
-            containers.addAll(conList);
-        }
-
-        switch (type) {
-        case ADDED:
-            break;
-        case CHANGED:
-            if (props == null) {
-                break;
-            }
-
-            boolean rmEdge = false;
-            for (Property prop : props) {
-                if (((prop instanceof Config) && (((Config) prop).getValue() != Config.ADMIN_UP))
-                        || ((prop instanceof State) && (((State) prop)
-                                .getValue() != State.EDGE_UP))) {
-                    /*
-                     * If port admin down or link down, remove the edges
-                     * associated with the port
-                     */
-                    rmEdge = true;
-                    break;
-                }
-            }
-
-            if (rmEdge) {
-                for (String cName : containers) {
-                    removeNodeConnector(cName, nodeConnector);
-                }
-            }
-            break;
-        case REMOVED:
-            for (String cName : containers) {
-                removeNodeConnector(cName, nodeConnector);
-            }
-            break;
-        default:
-            break;
-        }
-    }
-
-    @Override
-    public void containerCreate(String containerName) {
-        // do nothing
-    }
-
-    @Override
-    public void containerDestroy(String containerName) {
-        Set<NodeConnector> removeNodeConnectorSet = new HashSet<NodeConnector>();
-        for (Map.Entry<NodeConnector, List<String>> entry : containerMap.entrySet()) {
-            List<String> ncContainers = entry.getValue();
-            if (ncContainers.contains(containerName)) {
-                NodeConnector nodeConnector = entry.getKey();
-                removeNodeConnectorSet.add(nodeConnector);
-            }
-        }
-        for (NodeConnector nodeConnector : removeNodeConnectorSet) {
-            List<String> ncContainers = containerMap.get(nodeConnector);
-            ncContainers.remove(containerName);
-            if (ncContainers.isEmpty()) {
-                containerMap.remove(nodeConnector);
-            }
-        }
-        edgeMap.remove(containerName);
-    }
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/TopologyServices.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/TopologyServices.java
deleted file mode 100644 (file)
index 68572fb..0000000
+++ /dev/null
@@ -1,153 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow.internal;
-
-import java.util.Dictionary;
-import java.util.List;
-import org.apache.felix.dm.Component;
-import org.opendaylight.controller.protocol_plugin.openflow.IRefreshInternalProvider;
-import org.opendaylight.controller.protocol_plugin.openflow.ITopologyServiceShimListener;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import org.opendaylight.controller.sal.core.Edge;
-import org.opendaylight.controller.sal.topology.IPluginInTopologyService;
-import org.opendaylight.controller.sal.topology.IPluginOutTopologyService;
-import org.opendaylight.controller.sal.topology.TopoEdgeUpdate;
-
-public class TopologyServices implements ITopologyServiceShimListener,
-        IPluginInTopologyService {
-    protected static final Logger logger = LoggerFactory
-            .getLogger(TopologyServices.class);
-    private IPluginOutTopologyService salTopoService = null;
-    private IRefreshInternalProvider topoRefreshService = null;
-    private String containerName;
-
-    /**
-     * Function called by the dependency manager when all the required
-     * dependencies are satisfied
-     *
-     */
-    @SuppressWarnings("unchecked")
-    void init(Component c) {
-        logger.trace("INIT called!");
-        Dictionary<Object, Object> props = c.getServiceProperties();
-        containerName = (props != null) ? (String) props.get("containerName")
-                : null;
-    }
-
-    /**
-     * Function called by the dependency manager when at least one dependency
-     * become unsatisfied or when the component is shutting down because for
-     * example bundle is being stopped.
-     *
-     */
-    void destroy() {
-        logger.trace("DESTROY called!");
-    }
-
-    /**
-     * Function called by dependency manager after "init ()" is called and after
-     * the services provided by the class are registered in the service registry
-     *
-     */
-    void start() {
-        logger.trace("START called!");
-    }
-
-    /**
-     * Function called by the dependency manager before the services exported by
-     * the component are unregistered, this will be followed by a "destroy ()"
-     * calls
-     *
-     */
-    void stop() {
-        logger.trace("STOP called!");
-    }
-
-    /**
-     * Retrieve SAL service IPluginOutTopologyService
-     *
-     * @param s
-     *            Called by Dependency Manager as soon as the SAL service is
-     *            available
-     */
-    public void setPluginOutTopologyService(IPluginOutTopologyService s) {
-        logger.trace("Setting IPluginOutTopologyService to: {}", s);
-        this.salTopoService = s;
-    }
-
-    /**
-     * called when SAL service IPluginOutTopologyService is no longer available
-     *
-     * @param s
-     *            Called by Dependency Manager as soon as the SAL service is
-     *            unavailable
-     */
-    public void unsetPluginOutTopologyService(IPluginOutTopologyService s) {
-        if (this.salTopoService == s) {
-            logger.trace("UNSetting IPluginOutTopologyService from: {}", s);
-            this.salTopoService = null;
-        }
-    }
-
-    /**
-     * Retrieve OF protocol_plugin service IRefreshInternalProvider
-     *
-     * @param s
-     *            Called by Dependency Manager as soon as the SAL service is
-     *            available
-     */
-    public void setRefreshInternalProvider(IRefreshInternalProvider s) {
-        logger.trace("Setting IRefreshInternalProvider to: {}", s);
-        this.topoRefreshService = s;
-    }
-
-    /**
-     * called when OF protocol_plugin service IRefreshInternalProvider is no
-     * longer available
-     *
-     * @param s
-     *            Called by Dependency Manager as soon as the SAL service is
-     *            unavailable
-     */
-    public void unsetRefreshInternalProvider(IRefreshInternalProvider s) {
-        if (this.topoRefreshService == s) {
-            logger.trace("UNSetting IRefreshInternalProvider from: {}", s);
-            this.topoRefreshService = null;
-        }
-    }
-
-    @Override
-    public void edgeUpdate(List<TopoEdgeUpdate> topoedgeupdateList) {
-        if (this.salTopoService != null) {
-            this.salTopoService.edgeUpdate(topoedgeupdateList);
-        }
-    }
-
-    @Override
-    public void sollicitRefresh() {
-        logger.debug("Got a request to refresh topology");
-        topoRefreshService.requestRefresh(containerName);
-    }
-
-    @Override
-    public void edgeOverUtilized(Edge edge) {
-        if (this.salTopoService != null) {
-            this.salTopoService.edgeOverUtilized(edge);
-        }
-    }
-
-    @Override
-    public void edgeUtilBackToNormal(Edge edge) {
-        if (this.salTopoService != null) {
-            this.salTopoService.edgeUtilBackToNormal(edge);
-        }
-    }
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/Utils.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/internal/Utils.java
deleted file mode 100644 (file)
index 8d2ca87..0000000
+++ /dev/null
@@ -1,80 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow.internal;
-
-import java.nio.ByteBuffer;
-
-import org.opendaylight.controller.protocol_plugin.openflow.vendorextension.v6extension.V6Error;
-import org.openflow.protocol.OFError;
-import org.openflow.protocol.OFError.OFBadActionCode;
-import org.openflow.protocol.OFError.OFBadRequestCode;
-import org.openflow.protocol.OFError.OFErrorType;
-import org.openflow.protocol.OFError.OFFlowModFailedCode;
-import org.openflow.protocol.OFError.OFHelloFailedCode;
-import org.openflow.protocol.OFError.OFPortModFailedCode;
-import org.openflow.protocol.OFError.OFQueueOpFailedCode;
-
-public final class Utils {
-
-    private Utils() { //prevent instantiation
-        throw new AssertionError();
-    }
-    static String getOFErrorString(OFError error) {
-        // Handle VENDOR extension errors here
-        if (error.getErrorType() == V6Error.NICIRA_VENDOR_ERRORTYPE) {
-            V6Error er = new V6Error(error);
-            byte[] b = error.getError();
-            ByteBuffer bb = ByteBuffer.allocate(b.length);
-            bb.put(b);
-            bb.rewind();
-            er.readFrom(bb);
-            return er.toString();
-        }
-
-        // Handle OF1.0 errors here
-        OFErrorType et = OFErrorType.values()[0xffff & error.getErrorType()];
-        String errorStr = "Error : " + et.toString();
-        switch (et) {
-        case OFPET_HELLO_FAILED:
-            OFHelloFailedCode hfc = OFHelloFailedCode.values()[0xffff & error
-                    .getErrorCode()];
-            errorStr += " " + hfc.toString();
-            break;
-        case OFPET_BAD_REQUEST:
-            OFBadRequestCode brc = OFBadRequestCode.values()[0xffff & error
-                    .getErrorCode()];
-            errorStr += " " + brc.toString();
-            break;
-        case OFPET_BAD_ACTION:
-            OFBadActionCode bac = OFBadActionCode.values()[0xffff & error
-                    .getErrorCode()];
-            errorStr += " " + bac.toString();
-            break;
-        case OFPET_FLOW_MOD_FAILED:
-            OFFlowModFailedCode fmfc = OFFlowModFailedCode.values()[0xffff & error
-                    .getErrorCode()];
-            errorStr += " " + fmfc.toString();
-            break;
-        case OFPET_PORT_MOD_FAILED:
-            OFPortModFailedCode pmfc = OFPortModFailedCode.values()[0xffff & error
-                    .getErrorCode()];
-            errorStr += " " + pmfc.toString();
-            break;
-        case OFPET_QUEUE_OP_FAILED:
-            OFQueueOpFailedCode qofc = OFQueueOpFailedCode.values()[0xffff & error
-                    .getErrorCode()];
-            errorStr += " " + qofc.toString();
-            break;
-        default:
-            break;
-        }
-        return errorStr;
-    }
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/vendorextension/v6extension/V6Error.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/vendorextension/v6extension/V6Error.java
deleted file mode 100644 (file)
index dfe931f..0000000
+++ /dev/null
@@ -1,113 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.protocol_plugin.openflow.vendorextension.v6extension;
-
-import java.nio.ByteBuffer;
-import java.util.Arrays;
-
-import org.openflow.protocol.OFError;
-
-public class V6Error extends OFError {
-        private static final long serialVersionUID = 1L;
-        public static int MINIMUM_LENGTH = 20;//OfHdr(8) + NXET_VENDOR(2) + NXEC_VENDOR_ERROR(2) + struct nx_vendor_error(8)
-        public static final short NICIRA_VENDOR_ERRORTYPE = (short)0xb0c2;
-        protected int V6VendorId;
-    protected short V6VendorErrorType;
-    protected short V6VendorErrorCode;
-    protected byte[] V6ErrorData;
-
-    public V6Error(OFError e) {
-        this.length = (short)e.getLengthU();
-        this.errorType = e.getErrorType();
-        this.errorCode = e.getErrorCode();
-        this.xid = e.getXid();
-    }
-
-    @Override
-    public void readFrom(ByteBuffer data) {
-        this.V6VendorId = data.getInt();
-        this.V6VendorErrorType = data.getShort();
-        this.V6VendorErrorCode = data.getShort();
-        int dataLength = this.getLengthU() - MINIMUM_LENGTH;
-        if (dataLength > 0) {
-            this.V6ErrorData = new byte[dataLength];
-            data.get(this.V6ErrorData);
-        }
-    }
-
-    /**
-     * @return the V6VendorId
-     */
-    public int getVendorId() {
-        return V6VendorId;
-    }
-
-    /**
-     * @return the V6VendorErrorType
-     */
-    public short getVendorErrorType() {
-        return V6VendorErrorType;
-    }
-
-    /**
-     * @return the VendorErrorType
-     */
-    public short getVendorErrorCode() {
-        return V6VendorErrorCode;
-    }
-
-    /**
-     * @return the Error Bytes
-     */
-    public byte[] getError() {
-        return V6ErrorData;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = super.hashCode();
-        result = prime * result + Arrays.hashCode(V6ErrorData);
-        result = prime * result + V6VendorErrorCode;
-        result = prime * result + V6VendorErrorType;
-        result = prime * result + V6VendorId;
-        return result;
-    }
-
-    @Override
-    public String toString() {
-        return "V6Error [V6VendorId=" + V6VendorId + ", V6VendorErrorType="
-                + V6VendorErrorType + ", V6VendorErrorCode="
-                + V6VendorErrorCode + ", V6ErrorData="
-                + Arrays.toString(V6ErrorData) + ", errorType=" + errorType
-                + ", errorCode=" + errorCode + ", factory=" + factory
-                + ", error=" + Arrays.toString(error) + ", errorIsAscii="
-                + errorIsAscii + ", version=" + version + ", type=" + type
-                + ", length=" + length + ", xid=" + xid + "]";
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj)
-            return true;
-        if (!super.equals(obj))
-            return false;
-        if (getClass() != obj.getClass())
-            return false;
-        V6Error other = (V6Error) obj;
-        if (!Arrays.equals(V6ErrorData, other.V6ErrorData))
-            return false;
-        if (V6VendorErrorCode != other.V6VendorErrorCode)
-            return false;
-        if (V6VendorErrorType != other.V6VendorErrorType)
-            return false;
-        if (V6VendorId != other.V6VendorId)
-            return false;
-        return true;
-    }
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/vendorextension/v6extension/V6FlowMod.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/vendorextension/v6extension/V6FlowMod.java
deleted file mode 100644 (file)
index 73cdd98..0000000
+++ /dev/null
@@ -1,243 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow.vendorextension.v6extension;
-
-import java.nio.ByteBuffer;
-import java.util.LinkedList;
-import java.util.List;
-
-import org.openflow.protocol.OFPacketOut;
-import org.openflow.protocol.OFPort;
-import org.openflow.protocol.OFVendor;
-import org.openflow.protocol.action.OFAction;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * This class is used to create IPv6 Vendor Extension messages. Specfically, It
- * defines the methods used in creation of Vendor specific IPv6 Flow Mod message.
- *
- *
- */
-public class V6FlowMod extends OFVendor implements Cloneable {
-    private static final Logger logger = LoggerFactory
-            .getLogger(V6FlowMod.class);
-    private static final long serialVersionUID = 1L;
-    protected V6Match match;
-    protected long cookie;
-    protected short command;
-    protected short idleTimeout;
-    protected short hardTimeout;
-    protected short priority;
-    protected int bufferId;
-    protected short outPort;
-    protected short flags;
-    protected List<OFAction> actions;
-    short match_len;
-    short actions_len;
-    short pad_size;
-
-    private static int IPV6EXT_ADD_FLOW_MSG_TYPE = 13;
-    private static int IPV6_EXT_MIN_HDR_LEN = 36;
-
-    /**
-     * Constructor for the V6FlowMod class. Initializes OFVendor (parent class)
-     * fields by calling the parent class' constructor.
-     */
-    public V6FlowMod() {
-        super();
-    }
-
-    /**
-     * This method sets the match fields of V6FlowMod object
-     * @param match     V6Match object for this V6FlowMod message
-     */
-    public void setMatch(V6Match match) {
-        this.match = match;
-    }
-
-    /**
-     * Sets the list of actions V6FlowMod message
-     * @param actions   a list of ordered OFAction objects
-     */
-    public void setActions(List<OFAction> actions) {
-        this.actions = actions;
-    }
-
-    /**
-     * Sets the priority field of V6FlowMod message
-     * @param priority  Priority of the message
-     */
-    public void setPriority(short priority) {
-        this.priority = priority;
-    }
-
-    /**
-     * Sets the cookie field of V6FlowMod message
-     * @param cookie    Cookie of the message
-     */
-    public void setCookie(long cookie) {
-        this.cookie = cookie;
-    }
-
-    /**
-     * Sets the command field of V6FlowMod message
-     * @param command   Command type of the message (ADD or DELETE)
-     */
-    public V6FlowMod setCommand(short command) {
-        this.command = command;
-        return this;
-    }
-
-    /**
-     * Sets the outPort field of V6FlowMod message
-     * @param outPort   outPort of the message
-     */
-    public V6FlowMod setOutPort(OFPort port) {
-        this.outPort = port.getValue();
-        return this;
-    }
-
-    /**
-     * Sets the idle_timeout of V6FlowMod message
-     * @param idleTimeout   idle timeout for this message
-     */
-    public void setIdleTimeout(short idleTimeout) {
-        this.idleTimeout = idleTimeout;
-    }
-
-    /**
-     * Sets the hardTimeout field of V6FlowMod message
-     * @param hardTimeout       hard timeout of the message
-     */
-    public void setHardTimeout(short hardTimeout) {
-        this.hardTimeout = hardTimeout;
-    }
-
-    /**
-     * Returns the Flow Mod message subtype for V6FlowMod message
-     * @return          message subtype
-     */
-    private int getIPv6ExtensionFlowModAddSubType() {
-        return IPV6EXT_ADD_FLOW_MSG_TYPE;
-    }
-
-    /**
-     * Returns the minimum header size for V6Flow Message type
-     * @return      minimum header size
-     */
-
-    public int getV6FlowModMinHdrSize() {
-        return IPV6_EXT_MIN_HDR_LEN;
-    }
-
-    /**
-     * Sets the Vendor type in OFVendor message
-     */
-
-    public void setVendor() {
-        super.setVendor(V6StatsRequest.NICIRA_VENDOR_ID);
-    }
-
-    /**
-     * Get flags
-     * @return
-     */
-    public short getFlags() {
-        return flags;
-    }
-
-    /**
-     * Set flags
-     * @param flags
-     */
-    public void setFlags(short flags) {
-        this.flags = flags;
-    }
-
-    /**
-     * This method forms the Vendor extension IPv6 Flow Mod message.It uses the
-     * fields in V6FlowMod class, and writes the data according to vendor
-     * extension format. The fields include flow properties (cookie, timeout,
-     * priority, etc), flow match, and action list. It also takes care of
-     * required padding.
-     */
-
-    @Override
-    public void writeTo(ByteBuffer data) {
-        super.writeTo(data);
-        data.putInt(getIPv6ExtensionFlowModAddSubType());
-        data.putLong(this.cookie);
-        data.putShort(command); /* should be OFPFC_ADD, OFPFC_DELETE_STRICT, etc*/
-        data.putShort(this.idleTimeout);
-        data.putShort(this.hardTimeout);
-        data.putShort(this.priority);
-        data.putInt(OFPacketOut.BUFFER_ID_NONE);
-        data.putShort(outPort); /* output_port */
-        data.putShort(flags); /* flags */
-        match_len = this.match.getIPv6MatchLen();
-        data.putShort(match_len);
-        byte[] pad = new byte[6];
-        data.put(pad);
-        this.match.writeTo(data);
-
-        pad_size = (short) (((match_len + 7) / 8) * 8 - match_len);
-
-        /*
-         * action list should be preceded by a padding of 0 to 7 bytes based upon
-         * above formula.
-         */
-
-        byte[] pad2 = new byte[pad_size];
-        data.put(pad2);
-        if (actions != null) {
-            for (OFAction action : actions) {
-                actions_len += action.getLength();
-                action.writeTo(data);
-            }
-        }
-        logger.trace("{}", this);
-    }
-
-    /**
-     * Forms the clone of V6FlowMod Object. If Object is returned
-     * successfully, then returns the cloned object. Throws an
-     * exception if cloning is not supported.
-     */
-    @Override
-    public V6FlowMod clone() {
-        try {
-            V6Match neoMatch = match.clone();
-            V6FlowMod v6flowMod = (V6FlowMod) super.clone();
-            v6flowMod.setMatch(neoMatch);
-            List<OFAction> neoActions = new LinkedList<OFAction>();
-            for (OFAction action : this.actions) {
-                neoActions.add((OFAction) action.clone());
-            }
-            v6flowMod.setActions(neoActions);
-            return v6flowMod;
-        } catch (CloneNotSupportedException e) {
-            // Won't happen
-            throw new RuntimeException(e);
-        }
-    }
-
-    @Override
-    public String toString() {
-        return "V6FlowMod [match=" + match + ", cookie=" + cookie
-                + ", command=" + command + ", idleTimeout=" + idleTimeout
-                + ", hardTimeout=" + hardTimeout + ", priority=" + priority
-                + ", bufferId=" + bufferId + ", outPort=" + outPort
-                + ", flags=" + flags + ", actions=" + actions + ", match_len="
-                + match_len + ", actions_len=" + actions_len + ", pad_size="
-                + pad_size + "]";
-    }
-
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/vendorextension/v6extension/V6Match.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/vendorextension/v6extension/V6Match.java
deleted file mode 100644 (file)
index 4b8966c..0000000
+++ /dev/null
@@ -1,1672 +0,0 @@
-/*
- * Copyright (c) 2013-2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow.vendorextension.v6extension;
-
-import java.net.Inet6Address;
-import java.net.InetAddress;
-import java.net.UnknownHostException;
-import java.nio.ByteBuffer;
-import java.util.Arrays;
-
-import org.opendaylight.controller.sal.utils.HexEncode;
-import org.opendaylight.controller.sal.utils.NetUtils;
-import org.openflow.protocol.OFMatch;
-import org.openflow.util.U16;
-import org.openflow.util.U8;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * This Class forms the vendor specific IPv6 Flow Match messages as well as
- * processes the vendor specific IPv6 Stats Reply message.
- *
- * For message creation, it parses the user entered IPv6 match fields, creates a
- * sub-message for each field which are later used to form the complete message.
- *
- * For message processing, it parses the incoming message and reads each field
- * of the message and stores in appropriate field of V6Match object.
- *
- *
- */
-public class V6Match extends OFMatch implements Cloneable {
-    private static final Logger logger = LoggerFactory.getLogger(V6Match.class);
-    private static final long serialVersionUID = 1L;
-    protected Inet6Address nwSrc;
-    protected Inet6Address nwDst;
-    protected short inputPortMask;
-    protected byte[] dataLayerSourceMask;
-    protected byte[] dataLayerDestinationMask;
-    protected int dataLayerVirtualLanTCIMask;
-    protected short dataLayerTypeMask;
-    protected byte networkTypeOfServiceMask;
-    protected byte networkProtocolMask;
-    protected short transportSourceMask;
-    protected short transportDestinationMask;
-    protected short srcIPv6SubnetMaskbits;
-    protected short dstIPv6SubnetMaskbits;
-
-    protected MatchFieldState inputPortState;
-    protected MatchFieldState dlSourceState;
-    protected MatchFieldState dlDestState;
-    protected MatchFieldState dlVlanIDState;
-    protected MatchFieldState dlVlanPCPState;
-    protected MatchFieldState dlVlanTCIState;
-    protected MatchFieldState ethTypeState;
-    protected MatchFieldState nwTosState;
-    protected MatchFieldState nwProtoState;
-    protected MatchFieldState nwSrcState;
-    protected MatchFieldState nwDstState;
-    protected MatchFieldState tpSrcState;
-    protected MatchFieldState tpDstState;
-    protected short match_len = 0;
-    protected short pad_size = 0;
-
-    private static int IPV6_EXT_MIN_HDR_LEN = 36;
-
-    /**
-     * CFI bit in VLAN TCI field.
-     */
-    private static final int  VLAN_TCI_CFI = 1 << 12;
-
-    /**
-     * Value of OFP_VLAN_NONE defined by OpenFlow 1.0.
-     */
-    private static final short  OFP_VLAN_NONE = (short) 0xffff;
-
-    private enum MatchFieldState {
-        MATCH_ABSENT, MATCH_FIELD_ONLY, MATCH_FIELD_WITH_MASK
-    }
-
-    private enum OF_Match_Types {
-        MATCH_OF_IN_PORT(0), MATCH_OF_ETH_DST(1), MATCH_OF_ETH_SRC(2), MATCH_OF_ETH_TYPE(
-                3), MATCH_OF_VLAN_TCI(4), MATCH_OF_IP_TOS(5), MATCH_OF_IP_PROTO(
-                6), MATCH_OF_IP_SRC(7), MATCH_OF_IP_DST(8), MATCH_OF_TCP_SRC(9), MATCH_OF_TCP_DST(
-                10), MATCH_OF_UDP_SRC(11), MATCH_OF_UDP_DST(12), MATCH_OF_ICMTP_TYPE(
-                13), MATCH_OF_ICMP_CODE(14), MATCH_OF_ARP_OP(15);
-
-        private int value;
-
-        private OF_Match_Types(int value) {
-            this.value = value;
-        }
-
-        public int getValue() {
-            return this.value;
-        }
-    }
-
-    private enum IPv6Extension_Match_Types {
-        MATCH_IPV6EXT_TUN_ID(16), MATCH_IPV6EXT_ARP_SHA(17), MATCH_IPV6EXT_ARP_THA(
-                18), MATCH_IPV6EXT_IPV6_SRC(19), MATCH_IPV6EXT_IPV6_DST(20);
-
-        private int value;
-
-        private IPv6Extension_Match_Types(int value) {
-            this.value = value;
-        }
-
-        public int getValue() {
-            return value;
-        }
-    }
-
-    public enum Extension_Types {
-        OF_10(0), IPV6EXT(1);
-
-        protected int value;
-
-        private Extension_Types(int value) {
-            this.value = value;
-        }
-
-        public int getValue() {
-            return value;
-        }
-    }
-
-    public V6Match() {
-        super();
-
-        this.nwSrc = null;
-        this.nwDst = null;
-
-        this.inputPortMask = 0;
-        this.dataLayerSourceMask = null;
-        this.dataLayerDestinationMask = null;
-        this.dataLayerTypeMask = 0;
-        this.dataLayerVirtualLanTCIMask = 0;
-        this.networkTypeOfServiceMask = 0;
-        this.networkProtocolMask = 0;
-        this.transportSourceMask = 0;
-        this.transportDestinationMask = 0;
-
-        this.inputPortState = MatchFieldState.MATCH_ABSENT;
-        this.dlSourceState = MatchFieldState.MATCH_ABSENT;
-        this.dlDestState = MatchFieldState.MATCH_ABSENT;
-        this.dlVlanIDState = MatchFieldState.MATCH_ABSENT;
-        this.dlVlanPCPState = MatchFieldState.MATCH_ABSENT;
-        this.dlVlanTCIState = MatchFieldState.MATCH_ABSENT;
-        this.ethTypeState = MatchFieldState.MATCH_ABSENT;
-        this.nwTosState = MatchFieldState.MATCH_ABSENT;
-        this.nwProtoState = MatchFieldState.MATCH_ABSENT;
-        this.nwSrcState = MatchFieldState.MATCH_ABSENT;
-        this.nwDstState = MatchFieldState.MATCH_ABSENT;
-        this.tpSrcState = MatchFieldState.MATCH_ABSENT;
-        this.tpDstState = MatchFieldState.MATCH_ABSENT;
-
-        this.match_len = 0;
-        this.pad_size = 0;
-    }
-
-    public V6Match(OFMatch match) {
-        super();
-        this.match_len = 0;
-        this.pad_size = 0;
-
-        if (match.getNetworkSource() != 0) {
-            InetAddress address = NetUtils.getInetAddress(match.getNetworkSource());
-            InetAddress mask = NetUtils.getInetNetworkMask(match.getNetworkSourceMaskLen(), false);
-            this.setNetworkSource(address, mask);
-        } else {
-            this.nwSrcState = MatchFieldState.MATCH_ABSENT;
-        }
-
-        if (match.getNetworkDestination() != 0) {
-            InetAddress address = NetUtils.getInetAddress(match.getNetworkDestination());
-            InetAddress mask = NetUtils.getInetNetworkMask(match.getNetworkDestinationMaskLen(), false);
-            this.setNetworkDestination(address, mask);
-        } else {
-            this.nwDstState = MatchFieldState.MATCH_ABSENT;
-        }
-
-        this.inputPortMask = 0;
-        if (match.getInputPort() != 0) {
-            this.setInputPort(match.getInputPort(), (short) 0);
-        } else {
-            this.inputPortMask = 0;
-            this.inputPortState = MatchFieldState.MATCH_ABSENT;
-        }
-
-        this.dataLayerSourceMask = null;
-        if (match.getDataLayerSource() != null
-                && !NetUtils.isZeroMAC(match.getDataLayerSource())) {
-            this.setDataLayerSource(match.getDataLayerSource(), null);
-        } else {
-            this.dlSourceState = MatchFieldState.MATCH_ABSENT;
-        }
-        this.dataLayerDestinationMask = null;
-        if (match.getDataLayerDestination() != null
-                && !NetUtils.isZeroMAC(match.getDataLayerDestination())) {
-            this.setDataLayerDestination(match.getDataLayerDestination(), null);
-        } else {
-            this.dlDestState = MatchFieldState.MATCH_ABSENT;
-        }
-
-        this.dataLayerTypeMask = 0;
-        if (match.getDataLayerType() != 0) {
-            this.setDataLayerType(match.getDataLayerType(), (short) 0);
-        } else {
-            this.dataLayerType = 0;
-            this.ethTypeState = MatchFieldState.MATCH_ABSENT;
-        }
-
-        this.dataLayerVirtualLanTCIMask = 0;
-        this.dlVlanTCIState = MatchFieldState.MATCH_ABSENT;
-        if (match.getDataLayerVirtualLan() != 0) {
-            this.setDataLayerVirtualLan(match.getDataLayerVirtualLan(),
-                    (short) 0);
-        } else {
-            this.dataLayerVirtualLan = 0;
-            this.dlVlanIDState = MatchFieldState.MATCH_ABSENT;
-        }
-
-        if ((match.getWildcards() & OFMatch.OFPFW_DL_VLAN_PCP) == 0) {
-            this.setDataLayerVirtualLanPriorityCodePoint(
-                    match.getDataLayerVirtualLanPriorityCodePoint(), (byte) 0);
-        } else {
-            this.dataLayerVirtualLanPriorityCodePoint = 0;
-            this.dlVlanPCPState = MatchFieldState.MATCH_ABSENT;
-        }
-
-        this.networkProtocolMask = 0;
-        if (match.getNetworkProtocol() != 0) {
-            this.setNetworkProtocol(
-                    this.networkProtocol = match.getNetworkProtocol(), (byte) 0);
-        } else {
-            this.networkProtocol = 0;
-            this.nwProtoState = MatchFieldState.MATCH_ABSENT;
-        }
-
-        this.networkTypeOfServiceMask = 0;
-        if (match.getNetworkTypeOfService() != 0) {
-            this.setNetworkTypeOfService(
-                    this.networkTypeOfService = match.getNetworkTypeOfService(),
-                    (byte) 0);
-        } else {
-            this.networkTypeOfService = match.getNetworkTypeOfService();
-            this.nwTosState = MatchFieldState.MATCH_ABSENT;
-        }
-
-        this.transportSourceMask = 0;
-        if (match.getTransportSource() != 0) {
-            this.setTransportSource(match.getTransportSource(), (short) 0);
-        } else {
-            this.transportSource = 0;
-            this.tpSrcState = MatchFieldState.MATCH_ABSENT;
-        }
-
-        this.transportDestinationMask = 0;
-        if (match.getTransportDestination() != 0) {
-            this.setTransportDestination(match.getTransportDestination(),
-                    (short) 0);
-        } else {
-            this.transportDestination = 0;
-            this.tpDstState = MatchFieldState.MATCH_ABSENT;
-        }
-
-        this.setWildcards(match.getWildcards());
-    }
-
-    private enum IPProtocols {
-        ICMP(1), TCP(6), UDP(17), ICMPV6(58);
-
-        private int protocol;
-
-        private IPProtocols(int value) {
-            this.protocol = value;
-        }
-
-        private byte getValue() {
-            return (byte) this.protocol;
-        }
-    }
-
-    public short getIPv6MatchLen() {
-        return match_len;
-    }
-
-    public int getIPv6ExtMinHdrLen() {
-        return IPV6_EXT_MIN_HDR_LEN;
-    }
-
-    public short getPadSize() {
-        return (short) (((match_len + 7) / 8) * 8 - match_len);
-    }
-
-    private int getIPv6ExtensionMatchHeader(Extension_Types extType, int field,
-            int has_mask, int length) {
-        return (((extType.getValue() & 0x0000ffff) << 16)
-                | ((field & 0x0000007f) << 9) | ((has_mask & 0x00000001) << 8) | (length & 0x000000ff));
-    }
-
-    private byte[] getIPv6ExtensionPortMatchMsg(short port) {
-        ByteBuffer ipv6ext_port_msg = ByteBuffer.allocate(6);
-        int nxm_header = getIPv6ExtensionMatchHeader(Extension_Types.OF_10,
-                OF_Match_Types.MATCH_OF_IN_PORT.getValue(), 0, 2);
-        ipv6ext_port_msg.putInt(nxm_header);
-        ipv6ext_port_msg.putShort(port);
-        return (ipv6ext_port_msg.array());
-    }
-
-    private byte[] getIPv6ExtensionDestMacMatchMsg(byte[] destMac) {
-        ByteBuffer ipv6ext_destmac_msg = ByteBuffer.allocate(10);
-        int nxm_header = getIPv6ExtensionMatchHeader(Extension_Types.OF_10,
-                OF_Match_Types.MATCH_OF_ETH_DST.getValue(), 0, 6);
-        ipv6ext_destmac_msg.putInt(nxm_header);
-        ipv6ext_destmac_msg.put(destMac);
-        return (ipv6ext_destmac_msg.array());
-    }
-
-    private byte[] getIPv6ExtensionSrcMacMatchMsg(byte[] srcMac) {
-        ByteBuffer ipv6ext_srcmac_msg = ByteBuffer.allocate(10);
-        int nxm_header = getIPv6ExtensionMatchHeader(Extension_Types.OF_10,
-                OF_Match_Types.MATCH_OF_ETH_SRC.getValue(), 0, 6);
-        ipv6ext_srcmac_msg.putInt(nxm_header);
-        ipv6ext_srcmac_msg.put(srcMac);
-        return (ipv6ext_srcmac_msg.array());
-    }
-
-    private byte[] getIPv6ExtensionEtherTypeMatchMsg(short EtherType) {
-        ByteBuffer ipv6ext_etype_msg = ByteBuffer.allocate(6);
-        int nxm_header = getIPv6ExtensionMatchHeader(Extension_Types.OF_10,
-                OF_Match_Types.MATCH_OF_ETH_TYPE.getValue(), 0, 2);
-        ipv6ext_etype_msg.putInt(nxm_header);
-        ipv6ext_etype_msg.putShort(EtherType);
-        return (ipv6ext_etype_msg.array());
-    }
-
-    private byte[] getVlanTCI(short dataLayerVirtualLanID,
-            byte dataLayerVirtualLanPriorityCodePoint) {
-        ByteBuffer vlan_tci = ByteBuffer.allocate(2);
-        int vlan_tci_int;
-        if (dataLayerVirtualLanID == OFP_VLAN_NONE) {
-            // Match only packets without VLAN tag.
-            vlan_tci_int = 0;
-        } else {
-             // the pcp fields have to move by 13
-            int pcp = dataLayerVirtualLanPriorityCodePoint << 13;
-            vlan_tci_int = pcp + VLAN_TCI_CFI + dataLayerVirtualLanID;
-        }
-        vlan_tci.put((byte) (vlan_tci_int >> 8)); // bits 8 to 15
-        vlan_tci.put((byte) vlan_tci_int); // bits 0 to 7
-        return vlan_tci.array();
-    }
-
-    private byte[] getIPv6ExtensionVlanTCIMatchMsg(short dataLayerVirtualLanID,
-            byte dataLayerVirtualLanPriorityCodePoint) {
-        ByteBuffer ipv6ext_vlan_tci_msg = ByteBuffer.allocate(6);
-        int nxm_header = getIPv6ExtensionMatchHeader(Extension_Types.OF_10,
-                OF_Match_Types.MATCH_OF_VLAN_TCI.getValue(), 0, 2);
-        ipv6ext_vlan_tci_msg.putInt(nxm_header);
-        ipv6ext_vlan_tci_msg.put(getVlanTCI(dataLayerVirtualLanID,
-                dataLayerVirtualLanPriorityCodePoint));
-        return (ipv6ext_vlan_tci_msg.array());
-    }
-
-    private byte[] getIPv6ExtensionVlanTCIMatchWithMaskMsg(
-            short dataLayerVirtualLan,
-            byte dataLayerVirtualLanPriorityCodePoint,
-            int dataLayerVirtualLanTCIMask) {
-        ByteBuffer ipv6ext_vlan_tci_msg = ByteBuffer.allocate(8);
-        int nxm_header = getIPv6ExtensionMatchHeader(Extension_Types.OF_10,
-                OF_Match_Types.MATCH_OF_VLAN_TCI.getValue(), 1, 4);
-        ipv6ext_vlan_tci_msg.putInt(nxm_header);
-        ipv6ext_vlan_tci_msg.put(getVlanTCI(dataLayerVirtualLan,
-                dataLayerVirtualLanPriorityCodePoint));
-        ipv6ext_vlan_tci_msg.put((byte) (dataLayerVirtualLanTCIMask >> 8)); // bits
-                                                                            // 8
-                                                                            // to
-                                                                            // 15
-        ipv6ext_vlan_tci_msg.put((byte) (dataLayerVirtualLanTCIMask)); // bits 0
-                                                                       // to 7
-        return (ipv6ext_vlan_tci_msg.array());
-    }
-
-    private byte[] getIPv6ExtensionSrcIPv6MatchMsg(byte[] srcIpv6) {
-        ByteBuffer ipv6ext_ipv6_msg = ByteBuffer.allocate(20);
-        int nxm_header = getIPv6ExtensionMatchHeader(Extension_Types.IPV6EXT,
-                IPv6Extension_Match_Types.MATCH_IPV6EXT_IPV6_SRC.getValue(), 0,
-                16);
-        ipv6ext_ipv6_msg.putInt(nxm_header);
-        ipv6ext_ipv6_msg.put(srcIpv6);
-        return (ipv6ext_ipv6_msg.array());
-    }
-
-    private byte[] getIPv6ExtensionSrcIPv6MatchwithMaskMsg(byte[] srcIpv6,
-            short masklen) {
-        ByteBuffer ipv6ext_ipv6_msg = ByteBuffer.allocate(36);
-        int nxm_header = getIPv6ExtensionMatchHeader(Extension_Types.IPV6EXT,
-                IPv6Extension_Match_Types.MATCH_IPV6EXT_IPV6_SRC.getValue(), 1,
-                32);
-        ipv6ext_ipv6_msg.putInt(nxm_header);
-        ipv6ext_ipv6_msg.put(srcIpv6);
-        byte[] ipv6_mask = getIPv6NetworkMaskinBytes(masklen);
-        ipv6ext_ipv6_msg.put(ipv6_mask);
-        return (ipv6ext_ipv6_msg.array());
-    }
-
-    private byte[] getIPv6ExtensionDstIPv6MatchMsg(byte[] dstIpv6) {
-        ByteBuffer ipv6ext_ipv6_msg = ByteBuffer.allocate(20);
-        int nxm_header = getIPv6ExtensionMatchHeader(Extension_Types.IPV6EXT,
-                IPv6Extension_Match_Types.MATCH_IPV6EXT_IPV6_DST.getValue(), 0,
-                16);
-        ipv6ext_ipv6_msg.putInt(nxm_header);
-        ipv6ext_ipv6_msg.put(dstIpv6);
-        return (ipv6ext_ipv6_msg.array());
-    }
-
-    private byte[] getIPv6ExtensionDstIPv6MatchwithMaskMsg(byte[] dstIpv6,
-            short masklen) {
-        ByteBuffer ipv6ext_ipv6_msg = ByteBuffer.allocate(36);
-        int nxm_header = getIPv6ExtensionMatchHeader(Extension_Types.IPV6EXT,
-                IPv6Extension_Match_Types.MATCH_IPV6EXT_IPV6_DST.getValue(), 1,
-                32);
-        ipv6ext_ipv6_msg.putInt(nxm_header);
-        ipv6ext_ipv6_msg.put(dstIpv6);
-        byte[] ipv6_mask = getIPv6NetworkMaskinBytes(masklen);
-        ipv6ext_ipv6_msg.put(ipv6_mask);
-        return (ipv6ext_ipv6_msg.array());
-    }
-
-    private byte[] getIPv6ExtensionProtocolMatchMsg(byte protocol) {
-        ByteBuffer ipv6ext_proto_msg = ByteBuffer.allocate(5);
-        int nxm_header = getIPv6ExtensionMatchHeader(Extension_Types.OF_10,
-                OF_Match_Types.MATCH_OF_IP_PROTO.getValue(), 0, 1);
-        if (protocol == 0) {
-            return null;
-        }
-        ipv6ext_proto_msg.putInt(nxm_header);
-        if (protocol == IPProtocols.ICMP.getValue()) {
-            /*
-             * The front end passes the same protocol type values for IPv4 and
-             * IPv6 flows. For the Protocol types we allow in our GUI (ICMP,
-             * TCP, UDP), ICMP is the only one which is different for IPv6. It
-             * is 1 for v4 and 58 for v6 Therefore, we overwrite it here.
-             */
-            protocol = IPProtocols.ICMPV6.getValue();
-        }
-        ipv6ext_proto_msg.put(protocol);
-        return (ipv6ext_proto_msg.array());
-    }
-
-    private byte[] getIPv6ExtensionTOSMatchMsg(byte tos) {
-        ByteBuffer ipv6ext_tos_msg = ByteBuffer.allocate(5);
-        int nxm_header = getIPv6ExtensionMatchHeader(Extension_Types.OF_10,
-                OF_Match_Types.MATCH_OF_IP_TOS.getValue(), 0, 1);
-        ipv6ext_tos_msg.putInt(nxm_header);
-        ipv6ext_tos_msg.put(tos);
-        return (ipv6ext_tos_msg.array());
-    }
-
-    private byte[] getIPv6ExtensionTCPSrcPortMatchMsg(short src_port) {
-        ByteBuffer ipv6ext_tcp_srcport_msg = ByteBuffer.allocate(6);
-        int nxm_header = getIPv6ExtensionMatchHeader(Extension_Types.OF_10,
-                OF_Match_Types.MATCH_OF_TCP_SRC.getValue(), 0, 2);
-        ipv6ext_tcp_srcport_msg.putInt(nxm_header);
-        ipv6ext_tcp_srcport_msg.putShort(src_port);
-        return (ipv6ext_tcp_srcport_msg.array());
-    }
-
-    private byte[] getIPv6ExtensionTCPDstPortMatchMsg(short dst_port) {
-        ByteBuffer ipv6ext_tcp_dstport_msg = ByteBuffer.allocate(6);
-        int nxm_header = getIPv6ExtensionMatchHeader(Extension_Types.OF_10,
-                OF_Match_Types.MATCH_OF_TCP_DST.getValue(), 0, 2);
-        ipv6ext_tcp_dstport_msg.putInt(nxm_header);
-        ipv6ext_tcp_dstport_msg.putShort(dst_port);
-        return (ipv6ext_tcp_dstport_msg.array());
-    }
-
-    private byte[] getIPv6ExtensionUDPSrcPortMatchMsg(short src_port) {
-        ByteBuffer ipv6ext_udp_srcport_msg = ByteBuffer.allocate(6);
-        int nxm_header = getIPv6ExtensionMatchHeader(Extension_Types.OF_10,
-                OF_Match_Types.MATCH_OF_UDP_SRC.getValue(), 0, 2);
-        ipv6ext_udp_srcport_msg.putInt(nxm_header);
-        ipv6ext_udp_srcport_msg.putShort(src_port);
-        return (ipv6ext_udp_srcport_msg.array());
-    }
-
-    private byte[] getIPv6ExtensionUDPDstPortMatchMsg(short dst_port) {
-        ByteBuffer ipv6ext_udp_dstport_msg = ByteBuffer.allocate(6);
-        int nxm_header = getIPv6ExtensionMatchHeader(Extension_Types.OF_10,
-                OF_Match_Types.MATCH_OF_UDP_DST.getValue(), 0, 2);
-        ipv6ext_udp_dstport_msg.putInt(nxm_header);
-        ipv6ext_udp_dstport_msg.putShort(dst_port);
-        return (ipv6ext_udp_dstport_msg.array());
-    }
-
-    /**
-     * Sets this (V6Match) object's member variables based on a comma-separated
-     * key=value pair similar to OFMatch's fromString.
-     *
-     * @param match
-     *            a key=value comma separated string.
-     */
-    @Override
-    public void fromString(String match) throws IllegalArgumentException {
-        if (match.equals("") || match.equalsIgnoreCase("any")
-                || match.equalsIgnoreCase("all") || match.equals("[]")) {
-            match = "OFMatch[]";
-        }
-        String[] tokens = match.split("[\\[,\\]]");
-        String[] values;
-        int initArg = 0;
-        if (tokens[0].equals("OFMatch")) {
-            initArg = 1;
-        }
-        this.wildcards = OFPFW_ALL;
-        int i;
-        for (i = initArg; i < tokens.length; i++) {
-            values = tokens[i].split("=");
-            if (values.length != 2) {
-                throw new IllegalArgumentException("Token " + tokens[i]
-                        + " does not have form 'key=value' parsing " + match);
-            }
-            values[0] = values[0].toLowerCase(); // try to make this case insens
-            if (values[0].equals(STR_IN_PORT) || values[0].equals("input_port")) {
-                this.inputPort = U16.t(Integer.valueOf(values[1]));
-                inputPortState = MatchFieldState.MATCH_FIELD_ONLY;
-                match_len += 6;
-            } else if (values[0].equals(STR_DL_DST)
-                    || values[0].equals("eth_dst")) {
-                this.dataLayerDestination = HexEncode
-                        .bytesFromHexString(values[1]);
-                dlDestState = MatchFieldState.MATCH_FIELD_ONLY;
-                match_len += 10;
-            } else if (values[0].equals(STR_DL_SRC)
-                    || values[0].equals("eth_src")) {
-                this.dataLayerSource = HexEncode.bytesFromHexString(values[1]);
-                dlSourceState = MatchFieldState.MATCH_FIELD_ONLY;
-                match_len += 10;
-                this.wildcards &= ~OFPFW_DL_SRC;
-            } else if (values[0].equals(STR_DL_TYPE)
-                    || values[0].equals("eth_type")) {
-                if (values[1].startsWith("0x")) {
-                    this.dataLayerType = U16.t(Integer.valueOf(values[1]
-                            .replaceFirst("0x", ""), 16));
-                } else {
-
-                    this.dataLayerType = U16.t(Integer.valueOf(values[1]));
-                }
-                ethTypeState = MatchFieldState.MATCH_FIELD_ONLY;
-                match_len += 6;
-            } else if (values[0].equals(STR_DL_VLAN)) {
-                short vlan = U16.t(Integer.valueOf(values[1]));
-                if (this.dlVlanPCPState != MatchFieldState.MATCH_ABSENT &&
-                    vlan == OFP_VLAN_NONE) {
-                    throw new IllegalArgumentException("DL_VLAN_PCP is set.");
-                }
-                this.dataLayerVirtualLan = vlan;
-                this.dlVlanIDState = MatchFieldState.MATCH_FIELD_ONLY;
-                // the variable dlVlanIDState is not really used as a flag
-                // for serializing and deserializing. Rather it is used as a
-                // flag
-                // to check if the vlan id is being set so that we can set the
-                // dlVlanTCIState appropriately.
-                if (this.dlVlanPCPState != MatchFieldState.MATCH_ABSENT) {
-                    this.dlVlanTCIState = MatchFieldState.MATCH_FIELD_ONLY;
-                    match_len -= 2;
-                } else if (this.dataLayerVirtualLan == OFP_VLAN_NONE) {
-                    this.dlVlanTCIState = MatchFieldState.MATCH_FIELD_ONLY;
-                    match_len += 6;
-                } else {
-                    this.dlVlanTCIState = MatchFieldState.MATCH_FIELD_WITH_MASK;
-                    this.dataLayerVirtualLanTCIMask = 0x1fff;
-                    match_len += 8;
-                }
-                this.wildcards &= ~OFPFW_DL_VLAN;
-            } else if (values[0].equals(STR_DL_VLAN_PCP)) {
-                if (this.dlVlanIDState != MatchFieldState.MATCH_ABSENT &&
-                    this.dataLayerVirtualLan == OFP_VLAN_NONE) {
-                    throw new IllegalArgumentException
-                        ("OFP_VLAN_NONE is specified to DL_VLAN.");
-                }
-                this.dataLayerVirtualLanPriorityCodePoint = U8.t(Short
-                        .valueOf(values[1]));
-                this.dlVlanPCPState = MatchFieldState.MATCH_FIELD_ONLY;
-                // the variable dlVlanPCPState is not really used as a flag
-                // for serializing and deserializing. Rather it is used as a
-                // flag
-                // to check if the vlan pcp is being set so that we can set the
-                // dlVlanTCIState appropriately.
-                if (this.dlVlanIDState != MatchFieldState.MATCH_ABSENT) {
-                    this.dlVlanTCIState = MatchFieldState.MATCH_FIELD_ONLY;
-                    match_len -= 2;
-                } else {
-                    this.dlVlanTCIState = MatchFieldState.MATCH_FIELD_WITH_MASK;
-                    this.dataLayerVirtualLanTCIMask = 0xf000;
-                    match_len += 8;
-                }
-                this.wildcards &= ~OFPFW_DL_VLAN_PCP;
-            } else if (values[0].equals(STR_NW_DST)
-                    || values[0].equals("ip_dst")) {
-                try {
-                    InetAddress address = null;
-                    InetAddress mask = null;
-                    if (values[1].contains("/")) {
-                        String addressString[] = values[1].split("/");
-                        address = InetAddress.getByName(addressString[0]);
-                        int masklen = Integer.valueOf(addressString[1]);
-                        mask = NetUtils.getInetNetworkMask(masklen, address instanceof Inet6Address);
-                    } else {
-                        address = InetAddress.getByName(values[1]);
-                    }
-                    this.setNetworkDestination(address, mask);
-                } catch (UnknownHostException e) {
-                    logger.error("", e);
-                }
-            } else if (values[0].equals(STR_NW_SRC)
-                    || values[0].equals("ip_src")) {
-                try {
-                    InetAddress address = null;
-                    InetAddress mask = null;
-                    if (values[1].contains("/")) {
-                        String addressString[] = values[1].split("/");
-                        address = InetAddress.getByName(addressString[0]);
-                        int masklen = Integer.valueOf(addressString[1]);
-                        mask = NetUtils.getInetNetworkMask(masklen, address instanceof Inet6Address);
-                    } else {
-                        address = InetAddress.getByName(values[1]);
-                    }
-                    this.setNetworkSource(address, mask);
-                } catch (UnknownHostException e) {
-                    logger.error("", e);
-                }
-            } else if (values[0].equals(STR_NW_PROTO)) {
-                this.networkProtocol = U8.t(Short.valueOf(values[1]));
-                if (!(this.networkProtocol == 0)) {
-                    /*
-                     * if user selects proto 0, don't use it
-                     */
-                    nwProtoState = MatchFieldState.MATCH_FIELD_ONLY;
-                    match_len += 5;
-                }
-            } else if (values[0].equals(STR_NW_TOS)) {
-                this.networkTypeOfService = U8.t(Short.valueOf(values[1]));
-                nwTosState = MatchFieldState.MATCH_FIELD_ONLY;
-                match_len += 5;
-            } else if (values[0].equals(STR_TP_DST)) {
-                this.transportDestination = U16.t(Integer.valueOf(values[1]));
-                tpDstState = MatchFieldState.MATCH_FIELD_ONLY;
-                match_len += 6;
-            } else if (values[0].equals(STR_TP_SRC)) {
-                this.transportSource = U16.t(Integer.valueOf(values[1]));
-                tpSrcState = MatchFieldState.MATCH_FIELD_ONLY;
-                match_len += 6;
-            } else {
-                throw new IllegalArgumentException("unknown token " + tokens[i]
-                        + " parsing " + match);
-            }
-        }
-
-        /*
-         * In a V6 extension message action list should be preceded by a padding
-         * of 0 to 7 bytes based upon following formula.
-         */
-
-        pad_size = (short) (((match_len + 7) / 8) * 8 - match_len);
-
-    }
-
-    /**
-     * Write this message's binary format to the specified ByteBuffer
-     *
-     * @param data
-     */
-    @Override
-    public void writeTo(ByteBuffer data) {
-        if (inputPortState == MatchFieldState.MATCH_FIELD_ONLY) {
-            byte[] ipv6ext_ingress_port_msg = getIPv6ExtensionPortMatchMsg(this.inputPort);
-            data.put(ipv6ext_ingress_port_msg);
-        }
-        if (ethTypeState == MatchFieldState.MATCH_FIELD_ONLY) {
-            byte[] ipv6ext_ether_type_msg = getIPv6ExtensionEtherTypeMatchMsg(this.dataLayerType);
-            data.put(ipv6ext_ether_type_msg);
-        }
-        if (dlDestState == MatchFieldState.MATCH_FIELD_ONLY) {
-            byte[] ipv6ext_destmac_msg = getIPv6ExtensionDestMacMatchMsg(this.dataLayerDestination);
-            data.put(ipv6ext_destmac_msg);
-        }
-        if (dlSourceState == MatchFieldState.MATCH_FIELD_ONLY) {
-            byte[] ipv6ext_srcmac_msg = getIPv6ExtensionSrcMacMatchMsg(this.dataLayerSource);
-            data.put(ipv6ext_srcmac_msg);
-        }
-        if (dlVlanTCIState == MatchFieldState.MATCH_FIELD_ONLY) {
-            byte[] ipv6ext_vlan_tci_msg = getIPv6ExtensionVlanTCIMatchMsg(
-                    this.dataLayerVirtualLan,
-                    this.dataLayerVirtualLanPriorityCodePoint);
-            data.put(ipv6ext_vlan_tci_msg);
-        } else if (dlVlanTCIState == MatchFieldState.MATCH_FIELD_WITH_MASK) {
-            byte[] ipv6ext_vlan_tci_msg_with_mask = getIPv6ExtensionVlanTCIMatchWithMaskMsg(
-                    this.dataLayerVirtualLan,
-                    this.dataLayerVirtualLanPriorityCodePoint,
-                    this.dataLayerVirtualLanTCIMask);
-            data.put(ipv6ext_vlan_tci_msg_with_mask);
-        }
-        if (nwSrcState == MatchFieldState.MATCH_FIELD_ONLY) {
-            byte[] ipv6ext_src_ipv6_msg = getIPv6ExtensionSrcIPv6MatchMsg(this.nwSrc
-                    .getAddress());
-            data.put(ipv6ext_src_ipv6_msg);
-        } else if (nwSrcState == MatchFieldState.MATCH_FIELD_WITH_MASK) {
-            byte[] ipv6ext_src_ipv6_with_mask_msg = getIPv6ExtensionSrcIPv6MatchwithMaskMsg(
-                    this.nwSrc.getAddress(), this.srcIPv6SubnetMaskbits);
-            data.put(ipv6ext_src_ipv6_with_mask_msg);
-        }
-        if (nwDstState == MatchFieldState.MATCH_FIELD_ONLY) {
-            byte[] ipv6ext_dst_ipv6_msg = getIPv6ExtensionDstIPv6MatchMsg(this.nwDst
-                    .getAddress());
-            data.put(ipv6ext_dst_ipv6_msg);
-        } else if (nwDstState == MatchFieldState.MATCH_FIELD_WITH_MASK) {
-            byte[] ipv6ext_dst_ipv6_with_mask_msg = getIPv6ExtensionDstIPv6MatchwithMaskMsg(
-                    this.nwDst.getAddress(), this.dstIPv6SubnetMaskbits);
-            data.put(ipv6ext_dst_ipv6_with_mask_msg);
-        }
-        if (nwProtoState == MatchFieldState.MATCH_FIELD_ONLY) {
-            byte[] ipv6ext_protocol_msg = getIPv6ExtensionProtocolMatchMsg(this.networkProtocol);
-            if (ipv6ext_protocol_msg != null) {
-                data.put(ipv6ext_protocol_msg);
-            }
-        }
-        if (nwTosState == MatchFieldState.MATCH_FIELD_ONLY) {
-            byte[] ipv6ext_tos_msg = getIPv6ExtensionTOSMatchMsg(this.networkTypeOfService);
-            data.put(ipv6ext_tos_msg);
-        }
-        if (tpSrcState == MatchFieldState.MATCH_FIELD_ONLY) {
-            byte[] ipv6ext_srcport_msg = null;
-            if (this.networkProtocol == IPProtocols.TCP.getValue()) {
-                ipv6ext_srcport_msg = getIPv6ExtensionTCPSrcPortMatchMsg(this.transportSource);
-            } else if (this.networkProtocol == IPProtocols.UDP.getValue()) {
-                ipv6ext_srcport_msg = getIPv6ExtensionUDPSrcPortMatchMsg(this.transportSource);
-            }
-            if (ipv6ext_srcport_msg != null) {
-                data.put(ipv6ext_srcport_msg);
-            }
-        }
-        if (tpDstState == MatchFieldState.MATCH_FIELD_ONLY) {
-            byte[] ipv6ext_dstport_msg = null;
-            if (this.networkProtocol == IPProtocols.TCP.getValue()) {
-                ipv6ext_dstport_msg = getIPv6ExtensionTCPDstPortMatchMsg(this.transportDestination);
-            } else if (this.networkProtocol == IPProtocols.UDP.getValue()) {
-                ipv6ext_dstport_msg = getIPv6ExtensionUDPDstPortMatchMsg(this.transportDestination);
-            }
-            if (ipv6ext_dstport_msg != null) {
-                data.put(ipv6ext_dstport_msg);
-            }
-        }
-        logger.trace("{}", this);
-    }
-
-    private void readInPort(ByteBuffer data, int nxmLen, boolean hasMask) {
-        if ((nxmLen != 2) || (data.remaining() < 2) || (hasMask)) {
-            /*
-             * mask is not allowed for inport port
-             */
-            return;
-        }
-        super.setInputPort(data.getShort());
-        this.inputPortState = MatchFieldState.MATCH_FIELD_ONLY;
-        this.wildcards ^= (1 << 0); // Sync with 0F 1.0 Match
-        this.match_len += 6;
-    }
-
-    private void readDataLinkDestination(ByteBuffer data, int nxmLen,
-            boolean hasMask) {
-        if (hasMask) {
-            if ((nxmLen != 2 * 6) || (data.remaining() < 2 * 6)) {
-                return;
-            } else {
-                byte[] bytes = new byte[6];
-                data.get(bytes);
-                super.setDataLayerDestination(bytes);
-                this.dataLayerDestinationMask = new byte[6];
-                data.get(this.dataLayerDestinationMask);
-                this.dlDestState = MatchFieldState.MATCH_FIELD_WITH_MASK;
-                this.match_len += 16;
-            }
-        } else {
-            if ((nxmLen != 6) || (data.remaining() < 6)) {
-                return;
-            } else {
-                byte[] bytes = new byte[6];
-                data.get(bytes);
-                super.setDataLayerDestination(bytes);
-                this.dlDestState = MatchFieldState.MATCH_FIELD_ONLY;
-                this.match_len += 10;
-            }
-        }
-        this.wildcards ^= (1 << 3); // Sync with 0F 1.0 Match
-    }
-
-    private void readDataLinkSource(ByteBuffer data, int nxmLen, boolean hasMask) {
-        /*
-         * mask is not allowed in data link source
-         */
-        if ((nxmLen != 6) || (data.remaining() < 6) || (hasMask)) {
-            return;
-        }
-        byte[] bytes = new byte[6];
-        data.get(bytes);
-        super.setDataLayerSource(bytes);
-        this.dlSourceState = MatchFieldState.MATCH_FIELD_ONLY;
-        this.match_len += 10;
-        this.wildcards ^= (1 << 2); // Sync with 0F 1.0 Match
-    }
-
-    private void readEtherType(ByteBuffer data, int nxmLen, boolean hasMask) {
-        /*
-         * mask is not allowed in ethertype
-         */
-        if ((nxmLen != 2) || (data.remaining() < 2) || (hasMask)) {
-            return;
-        }
-        super.setDataLayerType(data.getShort());
-        this.ethTypeState = MatchFieldState.MATCH_FIELD_ONLY;
-        this.wildcards ^= (1 << 4); // Sync with 0F 1.0 Match
-        this.match_len += 6;
-    }
-
-    private short getVlanID(byte firstByte, byte secondByte) {
-        short vlan_id_mask_firstByte = 0x0f;// this is the mask for the first
-                                            // byte
-        short vlan_id_mask_secondByte = 0xff;// this is the mask for the second
-                                             // byte
-        int vlanPart1 = (firstByte & vlan_id_mask_firstByte) << 8;
-        int vlanPart2 = secondByte & vlan_id_mask_secondByte;
-        return (short) (vlanPart1 + vlanPart2);
-    }
-
-    private byte getVlanPCP(byte pcpByte) {
-        short vlan_pcp_mask = 0xe0;// this is the vlan pcp mask
-        int pcp_int = pcpByte & vlan_pcp_mask;
-        return (byte) (pcp_int >> 5);
-    }
-
-    private void readVlanTci(ByteBuffer data, int nxmLen, boolean hasMask) {
-        if (hasMask) {
-            if ((nxmLen != 2 * 2) || (data.remaining() < 2 * 2)) {
-                return;
-            }
-            else {
-                byte firstByte = data.get();
-                byte secondByte = data.get();
-                this.dataLayerVirtualLanTCIMask = data.getShort() & 0xffff; // we
-                                                                            // need
-                                                                            // the
-                                                                            // last
-                                                                            // 16
-                                                                            // bits
-                // check the mask now
-                if ((this.dataLayerVirtualLanTCIMask & 0x0fff) != 0) {
-                    // if its a vlan id mask
-                    // extract the vlan id
-                    super.setDataLayerVirtualLan(getVlanID(firstByte,
-                            secondByte));
-                    this.wildcards ^= (1 << 1); // Sync with 0F 1.0 Match
-                }
-                if ((this.dataLayerVirtualLanTCIMask & 0xe000) != 0) {
-                    // else if its a vlan pcp mask
-                    // extract the vlan pcp
-                    super.setDataLayerVirtualLanPriorityCodePoint(getVlanPCP(firstByte));
-                    this.wildcards ^= (1 << 20);
-                }
-                this.dlVlanTCIState = MatchFieldState.MATCH_FIELD_WITH_MASK;
-                this.match_len += 8;
-            }
-        } else {
-            if ((nxmLen != 2) || (data.remaining() < 2)) {
-                return;
-            }
-            else {
-                // get the vlan pcp
-                byte firstByte = data.get();
-                byte secondByte = data.get();
-                if (firstByte == 0 && secondByte == 0) {
-                    // Match only packets without VLAN tag.
-                    setDataLayerVirtualLan(OFP_VLAN_NONE);
-                } else if (((firstByte << 8) & VLAN_TCI_CFI) == 0) {
-                    // Ignore invalid TCI field.
-                    return;
-                } else {
-                    super.setDataLayerVirtualLanPriorityCodePoint(getVlanPCP(firstByte));
-                    super.setDataLayerVirtualLan(getVlanID(firstByte, secondByte));
-                    this.wildcards ^= (1 << 20);
-                }
-                this.dlVlanTCIState = MatchFieldState.MATCH_FIELD_ONLY;
-                this.match_len += 6;
-                this.wildcards ^= (1 << 1); // Sync with 0F 1.0 Match
-            }
-        }
-    }
-
-    private void readIpTos(ByteBuffer data, int nxmLen, boolean hasMask) {
-        /*
-         * mask is not allowed in IP TOS
-         */
-        if ((nxmLen != 1) || (data.remaining() < 1) || (hasMask)) {
-            return;
-        }
-        super.setNetworkTypeOfService(data.get());
-        this.nwTosState = MatchFieldState.MATCH_FIELD_ONLY;
-        this.match_len += 5;
-        this.wildcards ^= (1 << 21); // Sync with 0F 1.0 Match
-    }
-
-    private void readIpProto(ByteBuffer data, int nxmLen, boolean hasMask) {
-        /*
-         * mask is not allowed in IP protocol
-         */
-        if ((nxmLen != 1) || (data.remaining() < 1) || (hasMask)) {
-            return;
-        }
-        super.setNetworkProtocol(data.get());
-        this.nwProtoState = MatchFieldState.MATCH_FIELD_ONLY;
-        this.match_len += 5;
-        this.wildcards ^= (1 << 5); // Sync with 0F 1.0 Match
-    }
-
-    private void readIpv4Src(ByteBuffer data, int nxmLen, boolean hasMask) {
-        if (hasMask) {
-            if ((nxmLen != 2 * 4) || (data.remaining() < 2 * 4)) {
-                return;
-            } else {
-                byte[] sbytes = new byte[4];
-                data.get(sbytes);
-                // For compatibility, let's set the IPv4 in the parent OFMatch
-                int address = NetUtils.byteArray4ToInt(sbytes);
-                super.setNetworkSource(address);
-                byte[] mbytes = new byte[4];
-                data.get(mbytes);
-                this.nwSrcState = MatchFieldState.MATCH_FIELD_WITH_MASK;
-                this.match_len += 12;
-                int prefixlen = getNetworkMaskPrefixLength(mbytes);
-                this.wildcards ^= (((1 << 6) - 1) << 8); // Sync with 0F 1.0 Match
-                this.wildcards |= ((32 - prefixlen) << 8); // Sync with 0F 1.0 Match
-            }
-        } else {
-            if ((nxmLen != 4) || (data.remaining() < 4)) {
-                return;
-            } else {
-                byte[] sbytes = new byte[4];
-                data.get(sbytes);
-                // For compatibility, let's also set the IPv4 in the parent OFMatch
-                int address = NetUtils.byteArray4ToInt(sbytes);
-                super.setNetworkSource(address);
-                this.nwSrcState = MatchFieldState.MATCH_FIELD_ONLY;
-                this.match_len += 8;
-                this.wildcards ^= (((1 << 6) - 1) << 8); // Sync with 0F 1.0
-                                                         // Match
-            }
-        }
-    }
-
-    private void readIpv4Dst(ByteBuffer data, int nxmLen, boolean hasMask) {
-        if (hasMask) {
-            if ((nxmLen != 2 * 4) || (data.remaining() < 2 * 4)) {
-                return;
-            } else {
-                byte[] dbytes = new byte[4];
-                data.get(dbytes);
-                // For compatibility, let's also set the IPv4 in the parent OFMatch
-                int address = NetUtils.byteArray4ToInt(dbytes);
-                super.setNetworkDestination(address);
-                byte[] mbytes = new byte[4];
-                data.get(mbytes);
-                this.nwDstState = MatchFieldState.MATCH_FIELD_WITH_MASK;
-                this.match_len += 12;
-                int prefixlen = getNetworkMaskPrefixLength(mbytes);
-                this.wildcards ^= (((1 << 6) - 1) << 14); // Sync with 0F 1.0
-                                                          // Match
-                this.wildcards |= ((32 - prefixlen) << 14); // Sync with 0F 1.0
-                                                            // Match
-            }
-        } else {
-            if ((nxmLen != 4) || (data.remaining() < 4)) {
-                return;
-            } else {
-                byte[] dbytes = new byte[4];
-                data.get(dbytes);
-                int address = NetUtils.byteArray4ToInt(dbytes);
-                super.setNetworkDestination(address);
-                this.nwDstState = MatchFieldState.MATCH_FIELD_ONLY;
-                this.wildcards ^= (((1 << 6) - 1) << 14); // Sync with 0F 1.0
-                                                          // Match
-                this.match_len += 8;
-            }
-        }
-    }
-
-    private void readTcpSrc(ByteBuffer data, int nxmLen, boolean hasMask) {
-        /*
-         * mask is not allowed in TCP SRC
-         */
-        if ((nxmLen != 2) || (data.remaining() < 2) || (hasMask)) {
-            return;
-        }
-        super.setTransportSource(data.getShort());
-        this.tpSrcState = MatchFieldState.MATCH_FIELD_ONLY;
-        this.match_len += 6;
-        this.wildcards ^= (1 << 6); // Sync with 0F 1.0 Match
-    }
-
-    private void readTcpDst(ByteBuffer data, int nxmLen, boolean hasMask) {
-        /*
-         * mask is not allowed in TCP DST
-         */
-        if ((nxmLen != 2) || (data.remaining() < 2) || (hasMask)) {
-            return;
-        }
-        super.setTransportDestination(data.getShort());
-        this.tpDstState = MatchFieldState.MATCH_FIELD_ONLY;
-        this.match_len += 6;
-        this.wildcards ^= (1 << 7); // Sync with 0F 1.0 Match
-    }
-
-    private void readUdpSrc(ByteBuffer data, int nxmLen, boolean hasMask) {
-        /*
-         * mask is not allowed in UDP SRC
-         */
-        if ((nxmLen != 2) || (data.remaining() < 2) || (hasMask)) {
-            return;
-        }
-        super.setTransportSource(data.getShort());
-        this.tpSrcState = MatchFieldState.MATCH_FIELD_ONLY;
-        this.match_len += 6;
-        this.wildcards ^= (1 << 6); // Sync with 0F 1.0 Match
-    }
-
-    private void readUdpDst(ByteBuffer data, int nxmLen, boolean hasMask) {
-        /*
-         * mask is not allowed in UDP DST
-         */
-        if ((nxmLen != 2) || (data.remaining() < 2) || (hasMask)) {
-            return;
-        }
-        super.setTransportDestination(data.getShort());
-        this.tpDstState = MatchFieldState.MATCH_FIELD_ONLY;
-        this.match_len += 6;
-        this.wildcards ^= (1 << 7); // Sync with 0F 1.0 Match
-    }
-
-    private void readIpv6Src(ByteBuffer data, int nxmLen, boolean hasMask) {
-        if (hasMask) {
-            if ((nxmLen != 2 * 16) || (data.remaining() < 2 * 16)) {
-                return;
-            } else {
-                byte[] sbytes = new byte[16];
-                data.get(sbytes);
-                try {
-                    this.nwSrc = (Inet6Address) InetAddress.getByAddress(sbytes);
-                } catch (UnknownHostException e) {
-                    return;
-                }
-                byte[] mbytes = new byte[16];
-                data.get(mbytes);
-                this.srcIPv6SubnetMaskbits = (short)NetUtils.getSubnetMaskLength(mbytes);
-                this.nwSrcState = MatchFieldState.MATCH_FIELD_WITH_MASK;
-                this.match_len += 36;
-            }
-        } else {
-            if ((nxmLen != 16) || (data.remaining() < 16)) {
-                return;
-            } else {
-                byte[] sbytes = new byte[16];
-                data.get(sbytes);
-                try {
-                    this.nwSrc = (Inet6Address) InetAddress.getByAddress(sbytes);
-                } catch (UnknownHostException e) {
-                    return;
-                }
-                this.nwSrcState = MatchFieldState.MATCH_FIELD_ONLY;
-                this.match_len += 20;
-            }
-        }
-    }
-
-    private void readIpv6Dst(ByteBuffer data, int nxmLen, boolean hasMask) {
-        if (hasMask) {
-            if ((nxmLen != 2 * 16) || (data.remaining() < 2 * 16)) {
-                return;
-            } else {
-                byte[] dbytes = new byte[16];
-                data.get(dbytes);
-                try {
-                    this.nwDst = (Inet6Address) InetAddress.getByAddress(dbytes);
-                } catch (UnknownHostException e) {
-                    return;
-                }
-                byte[] mbytes = new byte[16];
-                data.get(mbytes);
-                this.dstIPv6SubnetMaskbits = (short)NetUtils.getSubnetMaskLength(mbytes);
-                this.nwDstState = MatchFieldState.MATCH_FIELD_WITH_MASK;
-                this.match_len += 36;
-            }
-        } else {
-            if ((nxmLen != 16) || (data.remaining() < 16)) {
-                return;
-            } else {
-                byte[] dbytes = new byte[16];
-                data.get(dbytes);
-                try {
-                    this.nwDst = (Inet6Address) InetAddress.getByAddress(dbytes);
-                } catch (UnknownHostException e) {
-                    return;
-                }
-                this.nwDstState = MatchFieldState.MATCH_FIELD_ONLY;
-                this.match_len += 20;
-            }
-        }
-    }
-
-    @Override
-    public String toString() {
-        return "V6Match [nwSrc=" + nwSrc + ", nwDst=" + nwDst
-                + ", inputPortMask=" + inputPortMask + ", dataLayerSourceMask="
-                + HexEncode.bytesToHexStringFormat(dataLayerSourceMask)
-                + ", dataLayerDestinationMask="
-                + HexEncode.bytesToHexStringFormat(dataLayerDestinationMask)
-                + ", dataLayerVirtualLanTCIMask=" + dataLayerVirtualLanTCIMask
-                + ", dataLayerTypeMask=" + dataLayerTypeMask
-                + ", networkTypeOfServiceMask=" + networkTypeOfServiceMask
-                + ", networkProtocolMask=" + networkProtocolMask
-                + ", transportSourceMask=" + transportSourceMask
-                + ", transportDestinationMask=" + transportDestinationMask
-                + ", srcIPv6SubnetMaskbits=" + srcIPv6SubnetMaskbits
-                + ", dstIPv6SubnetMaskbits=" + dstIPv6SubnetMaskbits
-                + ", inputPortState=" + inputPortState + ", dlSourceState="
-                + dlSourceState + ", dlDestState=" + dlDestState
-                + ", dlVlanTCIState=" + dlVlanTCIState + ", ethTypeState="
-                + ethTypeState + ", nwTosState=" + nwTosState
-                + ", nwProtoState=" + nwProtoState + ", nwSrcState="
-                + nwSrcState + ", nwDstState=" + nwDstState + ", tpSrcState="
-                + tpSrcState + ", tpDstState=" + tpDstState + ", match_len="
-                + match_len + ", pad_size=" + pad_size + "]";
-    }
-
-    /**
-     * Read the data corresponding to the match field (received from the wire)
-     * Input: data: match field(s). Since match field is of variable length, the
-     * whole data that are passed in are assumed to fem0tbd.be the match fields.
-     *
-     * @param data
-     */
-    @Override
-    public void readFrom(ByteBuffer data) {
-        readFromInternal(data);
-        postprocessWildCardInfo();
-    }
-
-    private void readFromInternal(ByteBuffer data) {
-        this.match_len = 0;
-        while (data.remaining() > 0) {
-            if (data.remaining() < 4) {
-                /*
-                 * at least 4 bytes for each match header
-                 */
-                logger.error("Invalid Vendor Extension Header. Size {}",
-                        data.remaining());
-                return;
-            }
-            /*
-             * read the 4 byte match header
-             */
-            int nxmVendor = data.getShort();
-            int b = data.get();
-            int nxmField = b >> 1;
-            boolean hasMask = ((b & 0x01) == 1) ? true : false;
-            int nxmLen = data.get();
-            if (nxmVendor == Extension_Types.OF_10.getValue()) {
-                if (nxmField == OF_Match_Types.MATCH_OF_IN_PORT.getValue()) {
-                    readInPort(data, nxmLen, hasMask);
-                } else if (nxmField == OF_Match_Types.MATCH_OF_ETH_DST
-                        .getValue()) {
-                    readDataLinkDestination(data, nxmLen, hasMask);
-                } else if (nxmField == OF_Match_Types.MATCH_OF_ETH_SRC
-                        .getValue()) {
-                    readDataLinkSource(data, nxmLen, hasMask);
-                } else if (nxmField == OF_Match_Types.MATCH_OF_ETH_TYPE
-                        .getValue()) {
-                    readEtherType(data, nxmLen, hasMask);
-                } else if (nxmField == OF_Match_Types.MATCH_OF_VLAN_TCI
-                        .getValue()) {
-                    readVlanTci(data, nxmLen, hasMask);
-                } else if (nxmField == OF_Match_Types.MATCH_OF_IP_TOS
-                        .getValue()) {
-                    readIpTos(data, nxmLen, hasMask);
-                } else if (nxmField == OF_Match_Types.MATCH_OF_IP_PROTO
-                        .getValue()) {
-                    readIpProto(data, nxmLen, hasMask);
-                } else if (nxmField == OF_Match_Types.MATCH_OF_IP_SRC
-                        .getValue()) {
-                    readIpv4Src(data, nxmLen, hasMask);
-                } else if (nxmField == OF_Match_Types.MATCH_OF_IP_DST
-                        .getValue()) {
-                    readIpv4Dst(data, nxmLen, hasMask);
-                } else if (nxmField == OF_Match_Types.MATCH_OF_TCP_SRC
-                        .getValue()) {
-                    readTcpSrc(data, nxmLen, hasMask);
-                } else if (nxmField == OF_Match_Types.MATCH_OF_TCP_DST
-                        .getValue()) {
-                    readTcpDst(data, nxmLen, hasMask);
-                } else if (nxmField == OF_Match_Types.MATCH_OF_UDP_SRC
-                        .getValue()) {
-                    readUdpSrc(data, nxmLen, hasMask);
-                } else if (nxmField == OF_Match_Types.MATCH_OF_UDP_DST
-                        .getValue()) {
-                    readUdpDst(data, nxmLen, hasMask);
-                } else {
-                    // unexpected nxmField
-                    return;
-                }
-            } else if (nxmVendor == Extension_Types.IPV6EXT.getValue()) {
-                if (nxmField == IPv6Extension_Match_Types.MATCH_IPV6EXT_IPV6_SRC
-                        .getValue()) {
-                    readIpv6Src(data, nxmLen, hasMask);
-                } else if (nxmField == IPv6Extension_Match_Types.MATCH_IPV6EXT_IPV6_DST
-                        .getValue()) {
-                    readIpv6Dst(data, nxmLen, hasMask);
-                } else {
-                    // unexpected nxmField
-                    return;
-                }
-            } else {
-                // invalid nxmVendor
-                return;
-            }
-        }
-    }
-
-    private void postprocessWildCardInfo() {
-        // Sync with 0F 1.0 Match
-        if (super.getDataLayerType() == 0x800) {
-            if (((this.wildcards >> 8) & 0x3f) == 0x3f) {
-                // ipv4 src processing
-                this.wildcards ^= (((1 << 5) - 1) << 8);
-            }
-            if (((this.wildcards >> 14) & 0x3f) == 0x3f) {
-                // ipv4 dest processing
-                this.wildcards ^= (((1 << 5) - 1) << 14);
-            }
-        }
-    }
-
-    @Override
-    public V6Match clone() {
-
-        V6Match ret = (V6Match) super.clone();
-        try {
-            if (this.nwSrc != null) {
-                ret.nwSrc = (Inet6Address) InetAddress.getByAddress(this.nwSrc.getAddress());
-            }
-            if (this.nwDst != null) {
-                ret.nwDst = (Inet6Address) InetAddress.getByAddress(this.nwDst.getAddress());
-            }
-            return ret;
-        } catch (UnknownHostException e) {
-            throw new RuntimeException(e);
-        }
-    }
-
-    /**
-     * Get nw_dst
-     *
-     * @return
-     */
-    public Inet6Address getNetworkDest() {
-        return this.nwDst;
-    }
-
-    /**
-     * Set nw_src
-     *
-     * @return
-     */
-    public Inet6Address getNetworkSrc() {
-        return this.nwSrc;
-    }
-
-    private int getNetworkMaskPrefixLength(byte[] netMask) {
-        ByteBuffer nm = ByteBuffer.wrap(netMask);
-        int trailingZeros = Integer.numberOfTrailingZeros(nm.getInt());
-        return 32 - trailingZeros;
-    }
-
-    public short getInputPortMask() {
-        return inputPortMask;
-    }
-
-    public void setInputPort(short port, short mask) {
-        super.inputPort = port;
-        this.inputPortState = MatchFieldState.MATCH_FIELD_ONLY;
-        match_len += 6;
-        // Looks like mask is not allowed for input port. Will discard it
-    }
-
-    public byte[] getDataLayerSourceMask() {
-        return dataLayerSourceMask;
-    }
-
-    public void setDataLayerSource(byte[] mac, byte[] mask) {
-        if (mac != null) {
-            System.arraycopy(mac, 0, super.dataLayerSource, 0, mac.length);
-        }
-        if (mask == null) {
-            this.dlSourceState = MatchFieldState.MATCH_FIELD_ONLY;
-            this.match_len += 10;
-        } else {
-            if (this.dataLayerSourceMask == null) {
-                this.dataLayerSourceMask = new byte[mask.length];
-            }
-            System.arraycopy(mask, 0, this.dataLayerSourceMask, 0, mask.length);
-            this.dlSourceState = MatchFieldState.MATCH_FIELD_WITH_MASK;
-            this.match_len += 16;
-        }
-    }
-
-    public byte[] getDataLayerDestinationMask() {
-        return dataLayerDestinationMask;
-    }
-
-    public void setDataLayerDestination(byte[] mac, byte[] mask) {
-        if (mac != null) {
-            System.arraycopy(mac, 0, super.dataLayerDestination, 0, mac.length);
-        }
-        if (mask == null) {
-            this.dlDestState = MatchFieldState.MATCH_FIELD_ONLY;
-            this.match_len += 10;
-        } else {
-            if (this.dataLayerDestinationMask == null) {
-                this.dataLayerDestinationMask = new byte[mask.length];
-            }
-            System.arraycopy(mask, 0, this.dataLayerDestinationMask, 0,
-                    mask.length);
-            this.dlDestState = MatchFieldState.MATCH_FIELD_WITH_MASK;
-            this.match_len += 16;
-        }
-    }
-
-    /**
-     * Set a value to VLAN ID match field.
-     *
-     * @param vlan  A value to match for VLAN ID.
-     * @param mask  A bitmask for VLAN ID.
-     */
-    public void setDataLayerVirtualLan(short vlan, short mask) {
-        if (vlan == OFP_VLAN_NONE
-                && this.dlVlanIDState != MatchFieldState.MATCH_ABSENT) {
-            throw new IllegalStateException
-                ("DL_VLAN_PCP is set.");
-        }
-
-        // mask is ignored as the code sets the appropriate mask
-        super.dataLayerVirtualLan = vlan;
-        this.dlVlanIDState = MatchFieldState.MATCH_FIELD_ONLY;
-        // the variable dlVlanIDState is not really used as a flag
-        // for serializing and deserializing. Rather it is used as a flag
-        // to check if the vlan id is being set so that we can set the
-        // dlVlanTCIState appropriately.
-        if (this.dlVlanPCPState != MatchFieldState.MATCH_ABSENT) {
-            this.dlVlanTCIState = MatchFieldState.MATCH_FIELD_ONLY;
-            match_len -= 2;
-        } else if (this.dataLayerVirtualLan == OFP_VLAN_NONE) {
-            this.dlVlanTCIState = MatchFieldState.MATCH_FIELD_ONLY;
-            match_len += 6;
-        } else {
-            this.dlVlanTCIState = MatchFieldState.MATCH_FIELD_WITH_MASK;
-            this.dataLayerVirtualLanTCIMask = 0x1fff;
-            match_len += 8;
-        }
-    }
-
-    /**
-     * Set a value to VLAN PCP match field.
-     *
-     * @param pcp  A value to match for VLAN PCP.
-     * @param mask  A bitmask for VLAN PCP.
-     */
-    public void setDataLayerVirtualLanPriorityCodePoint(byte pcp, byte mask) {
-        if (this.dlVlanIDState != MatchFieldState.MATCH_ABSENT
-                && this.dataLayerVirtualLan == OFP_VLAN_NONE) {
-            throw new IllegalStateException
-                ("OFP_VLAN_NONE is specified to DL_VLAN.");
-        }
-
-        // mask is ignored as the code sets the appropriate mask
-        super.dataLayerVirtualLanPriorityCodePoint = pcp;
-        this.dlVlanPCPState = MatchFieldState.MATCH_FIELD_ONLY;
-        // the variable dlVlanPCPState is not really used as a flag
-        // for serializing and deserializing. Rather it is used as a flag
-        // to check if the vlan pcp is being set so that we can set the
-        // dlVlanTCIState appropriately.
-        if (this.dlVlanIDState != MatchFieldState.MATCH_ABSENT) {
-            this.dlVlanTCIState = MatchFieldState.MATCH_FIELD_ONLY;
-            match_len -= 2;
-        } else {
-            this.dlVlanTCIState = MatchFieldState.MATCH_FIELD_WITH_MASK;
-            this.dataLayerVirtualLanTCIMask = 0xf000;
-            match_len += 8;
-        }
-    }
-
-    public void setDataLayerType(short ethType, short mask) {
-        // mask not allowed
-        super.dataLayerType = ethType;
-        this.ethTypeState = MatchFieldState.MATCH_FIELD_ONLY;
-        this.match_len += 6;
-    }
-
-    public void setNetworkTypeOfService(byte tos, byte mask) {
-        // mask not allowed
-        super.networkTypeOfService = tos;
-        this.nwTosState = MatchFieldState.MATCH_FIELD_ONLY;
-        match_len += 5;
-    }
-
-    public void setNetworkProtocol(byte ipProto, byte mask) {
-        // mask not allowed
-        super.networkProtocol = ipProto;
-        this.nwProtoState = MatchFieldState.MATCH_FIELD_ONLY;
-        this.match_len += 5;
-    }
-
-    public Inet6Address getNetworkSourceMask() {
-        return (this.nwSrcState == MatchFieldState.MATCH_FIELD_WITH_MASK) ? (Inet6Address) NetUtils.getInetNetworkMask(
-                this.srcIPv6SubnetMaskbits, true) : null;
-    }
-
-    public void setNetworkSource(InetAddress address, InetAddress mask) {
-        if (address instanceof Inet6Address) {
-            this.nwSrc = (Inet6Address) address;
-            if (mask == null) {
-                this.nwSrcState = MatchFieldState.MATCH_FIELD_ONLY;
-                this.match_len += (address instanceof Inet6Address) ? 20 : 8;
-            } else {
-                this.srcIPv6SubnetMaskbits = (short)NetUtils.getSubnetMaskLength(mask);
-                this.nwSrcState = MatchFieldState.MATCH_FIELD_WITH_MASK;
-                this.match_len += (address instanceof Inet6Address) ? 36 : 12;
-            }
-        } else {
-            super.setNetworkSource(NetUtils.byteArray4ToInt(address.getAddress()));
-            this.wildcards ^= (((1 << 6) - 1) << 8);
-            if (mask == null) {
-                this.nwSrcState = MatchFieldState.MATCH_FIELD_ONLY;
-                this.match_len += 8;
-            } else {
-                this.nwSrcState = MatchFieldState.MATCH_FIELD_WITH_MASK;
-                this.match_len += 12;
-                this.wildcards |= ((32 - NetUtils.getSubnetMaskLength(mask)) << 8);
-            }
-        }
-    }
-
-    public Inet6Address getNetworkDestinationMask() {
-        return (this.nwDstState == MatchFieldState.MATCH_FIELD_WITH_MASK) ? (Inet6Address) NetUtils.getInetNetworkMask(
-                this.dstIPv6SubnetMaskbits, true) : null;
-    }
-
-    public void setNetworkDestination(InetAddress address, InetAddress mask) {
-        if (address instanceof Inet6Address) {
-            this.nwDst = (Inet6Address) address;
-            if (mask == null) {
-                this.nwDstState = MatchFieldState.MATCH_FIELD_ONLY;
-                this.match_len += (address instanceof Inet6Address) ? 20 : 8;
-            } else {
-                this.dstIPv6SubnetMaskbits = (short)NetUtils.getSubnetMaskLength(mask);
-                this.nwDstState = MatchFieldState.MATCH_FIELD_WITH_MASK;
-                this.match_len += (address instanceof Inet6Address) ? 36 : 12;
-            }
-        } else {
-            this.setNetworkDestination(NetUtils.byteArray4ToInt(address.getAddress()));
-            this.wildcards ^= (((1 << 6) - 1) << 14);
-            if (mask == null) {
-                this.nwDstState = MatchFieldState.MATCH_FIELD_ONLY;
-                this.match_len += 8;
-            } else {
-                this.nwDstState = MatchFieldState.MATCH_FIELD_WITH_MASK;
-                this.match_len += 12;
-                this.wildcards |= ((32 - NetUtils.getSubnetMaskLength(mask)) << 14);
-            }
-        }
-    }
-
-    public void setTransportSource(short tpSrc, short mask) {
-        // mask not allowed
-        super.transportSource = tpSrc;
-        this.tpSrcState = MatchFieldState.MATCH_FIELD_ONLY;
-        this.match_len += 6;
-    }
-
-    public short getTransportDestinationMask() {
-        return transportDestinationMask;
-    }
-
-    public void setTransportDestination(short tpDst, short mask) {
-        // mask not allowed
-        super.transportDestination = tpDst;
-        this.tpDstState = MatchFieldState.MATCH_FIELD_ONLY;
-        this.match_len += 6;
-    }
-
-    private byte[] getIPv6NetworkMaskinBytes(short num) {
-        byte[] nbytes = new byte[16];
-        int quot = num / 8;
-        int bits = num % 8;
-        int i;
-
-        for (i = 0; i < quot; i++) {
-            nbytes[i] = (byte) 0xff;
-        }
-
-        if (bits > 0) {
-            nbytes[i] = (byte) 0xff;
-            nbytes[i] <<= 8 - bits;
-        }
-        return nbytes;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = super.hashCode();
-        result = prime * result + Arrays.hashCode(dataLayerDestinationMask);
-        result = prime * result + Arrays.hashCode(dataLayerSourceMask);
-        result = prime * result + dataLayerTypeMask;
-        result = prime * result + dataLayerVirtualLanTCIMask;
-        result = prime * result
-                + ((dlDestState == null) ? 0 : dlDestState.hashCode());
-        result = prime * result
-                + ((dlSourceState == null) ? 0 : dlSourceState.hashCode());
-        result = prime * result
-                + ((dlVlanTCIState == null) ? 0 : dlVlanTCIState.hashCode());
-        result = prime * result + dstIPv6SubnetMaskbits;
-        result = prime * result
-                + ((ethTypeState == null) ? 0 : ethTypeState.hashCode());
-        result = prime * result + inputPortMask;
-        result = prime * result
-                + ((inputPortState == null) ? 0 : inputPortState.hashCode());
-        result = prime * result + match_len;
-        result = prime * result + networkProtocolMask;
-        result = prime * result + networkTypeOfServiceMask;
-        result = prime * result + ((nwDst == null) ? 0 : nwDst.hashCode());
-        result = prime * result
-                + ((nwDstState == null) ? 0 : nwDstState.hashCode());
-        result = prime * result
-                + ((nwProtoState == null) ? 0 : nwProtoState.hashCode());
-        result = prime * result + ((nwSrc == null) ? 0 : nwSrc.hashCode());
-        result = prime * result
-                + ((nwSrcState == null) ? 0 : nwSrcState.hashCode());
-        result = prime * result
-                + ((nwTosState == null) ? 0 : nwTosState.hashCode());
-        result = prime * result + pad_size;
-        result = prime * result + srcIPv6SubnetMaskbits;
-        result = prime * result
-                + ((tpDstState == null) ? 0 : tpDstState.hashCode());
-        result = prime * result
-                + ((tpSrcState == null) ? 0 : tpSrcState.hashCode());
-        result = prime * result + transportDestinationMask;
-        result = prime * result + transportSourceMask;
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (!super.equals(obj)) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        V6Match other = (V6Match) obj;
-        if (!Arrays.equals(dataLayerDestinationMask, other.dataLayerDestinationMask)) {
-            return false;
-        }
-        if (!Arrays.equals(dataLayerSourceMask, other.dataLayerSourceMask)) {
-            return false;
-        }
-        if (dataLayerTypeMask != other.dataLayerTypeMask) {
-            return false;
-        }
-        if (dataLayerVirtualLanTCIMask != other.dataLayerVirtualLanTCIMask) {
-            return false;
-        }
-        if (dlVlanTCIState != other.dlVlanTCIState) {
-            return false;
-        }
-        if (dlSourceState != other.dlSourceState) {
-            return false;
-        }
-        if (dstIPv6SubnetMaskbits != other.dstIPv6SubnetMaskbits) {
-            return false;
-        }
-        if (ethTypeState != other.ethTypeState) {
-            return false;
-        }
-        if (inputPortMask != other.inputPortMask) {
-            return false;
-        }
-        if (inputPortState != other.inputPortState) {
-            return false;
-        }
-        if (match_len != other.match_len) {
-            return false;
-        }
-        if (networkProtocolMask != other.networkProtocolMask) {
-            return false;
-        }
-        if (networkTypeOfServiceMask != other.networkTypeOfServiceMask) {
-            return false;
-        }
-        if (nwDst == null) {
-            if (other.nwDst != null) {
-                return false;
-            }
-        } else if (!nwDst.equals(other.nwDst)) {
-            return false;
-        }
-        if (nwDstState != other.nwDstState) {
-            return false;
-        }
-        if (nwProtoState != other.nwProtoState) {
-            return false;
-        }
-        if (nwSrc == null) {
-            if (other.nwSrc != null) {
-                return false;
-            }
-        } else if (!nwSrc.equals(other.nwSrc)) {
-            return false;
-        }
-        if (nwSrcState != other.nwSrcState) {
-            return false;
-        }
-        if (nwTosState != other.nwTosState) {
-            return false;
-        }
-        if (pad_size != other.pad_size) {
-            return false;
-        }
-        if (srcIPv6SubnetMaskbits != other.srcIPv6SubnetMaskbits) {
-            return false;
-        }
-        if (tpDstState != other.tpDstState) {
-            return false;
-        }
-        if (tpSrcState != other.tpSrcState) {
-            return false;
-        }
-        if (transportDestinationMask != other.transportDestinationMask) {
-            return false;
-        }
-        if (transportSourceMask != other.transportSourceMask) {
-            return false;
-        }
-        return true;
-    }
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/vendorextension/v6extension/V6StatsReply.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/vendorextension/v6extension/V6StatsReply.java
deleted file mode 100644 (file)
index 3ae1983..0000000
+++ /dev/null
@@ -1,389 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow.vendorextension.v6extension;
-
-import java.nio.ByteBuffer;
-import java.util.List;
-
-import org.openflow.protocol.action.OFAction;
-import org.openflow.protocol.statistics.OFVendorStatistics;
-import org.openflow.util.U16;
-
-/**
- * This Class processes the OpenFlow Vendor Extension Reply message of a Stats
- * Request. It parses the reply message and initializes fields of  V6StatsReply
- * object. Multiple instances of this class objects are created and used by
- * OpenDaylight's Troubleshooting Application.
- *
- */
-
-public class V6StatsReply extends OFVendorStatistics {
-    private static final long serialVersionUID = 1L;
-
-    public static int MINIMUM_LENGTH = 48; //48 for nx_flow_stats
-
-    protected short length = (short) MINIMUM_LENGTH;
-    protected byte tableId;
-    protected int durationSeconds;
-    protected int durationNanoseconds;
-    protected short priority;
-    protected short idleTimeout;
-    protected short hardTimeout;
-    protected short match_len;
-    protected short idleAge;
-    protected short hardAge;
-    protected long cookie;
-    protected long packetCount;
-    protected long byteCount;
-    protected V6Match match;
-    protected List<OFAction> actions;
-
-    /**
-     * @return vendor id
-     */
-    public int getVendorId() {
-        return vendor;
-    }
-
-    /**
-     * @param vendor the vendor to set
-     */
-    public void setVendorId(int vendor) {
-        this.vendor = vendor;
-    }
-
-    /**
-     * @return the tableId
-     */
-    public byte getTableId() {
-        return tableId;
-    }
-
-    /**
-     * @param tableId the tableId to set
-     */
-    public void setTableId(byte tableId) {
-        this.tableId = tableId;
-    }
-
-    /**
-     * @return the durationSeconds
-     */
-    public int getDurationSeconds() {
-        return durationSeconds;
-    }
-
-    /**
-     * @param durationSeconds the durationSeconds to set
-     */
-    public void setDurationSeconds(int durationSeconds) {
-        this.durationSeconds = durationSeconds;
-    }
-
-    /**
-     * @return the durationNanoseconds
-     */
-    public int getDurationNanoseconds() {
-        return durationNanoseconds;
-    }
-
-    /**
-     * @param durationNanoseconds the durationNanoseconds to set
-     */
-    public void setDurationNanoseconds(int durationNanoseconds) {
-        this.durationNanoseconds = durationNanoseconds;
-    }
-
-    /**
-     * @return the priority
-     */
-    public short getPriority() {
-        return priority;
-    }
-
-    /**
-     * @param priority the priority to set
-     */
-    public void setPriority(short priority) {
-        this.priority = priority;
-    }
-
-    /**
-     * @return the idleTimeout
-     */
-    public short getIdleTimeout() {
-        return idleTimeout;
-    }
-
-    /**
-     * @param idleTimeout the idleTimeout to set
-     */
-    public void setIdleTimeout(short idleTimeout) {
-        this.idleTimeout = idleTimeout;
-    }
-
-    /**
-     * @return the hardTimeout
-     */
-    public short getHardTimeout() {
-        return hardTimeout;
-    }
-
-    /**
-     * @param hardTimeout the hardTimeout to set
-     */
-    public void setHardTimeout(short hardTimeout) {
-        this.hardTimeout = hardTimeout;
-    }
-
-    /**
-     * @param match_len the match_len to set
-     */
-    public void setMatchLen(short match_len) {
-        this.match_len = match_len;
-    }
-
-    /**
-     * @return the match_len
-     */
-    public short getMatchLen() {
-        return match_len;
-    }
-
-    /**
-     * @return the idleAge
-     */
-    public short getIdleAge() {
-        return idleAge;
-    }
-
-    /**
-     * @param idleAge the idleAge to set
-     */
-    public void setIdleAge(short idleAge) {
-        this.idleAge = idleAge;
-    }
-
-    /**
-     * @return the hardAge
-     */
-    public short getHardAge() {
-        return hardAge;
-    }
-
-    /**
-     * @param hardAge the hardAge to set
-     */
-    public void setHardAge(short hardAge) {
-        this.hardAge = hardAge;
-    }
-
-    /**
-     * @return the cookie
-     */
-    public long getCookie() {
-        return cookie;
-    }
-
-    /**
-     * @param cookie the cookie to set
-     */
-    public void setCookie(long cookie) {
-        this.cookie = cookie;
-    }
-
-    /**
-     * @return the packetCount
-     */
-    public long getPacketCount() {
-        return packetCount;
-    }
-
-    /**
-     * @param packetCount the packetCount to set
-     */
-    public void setPacketCount(long packetCount) {
-        this.packetCount = packetCount;
-    }
-
-    /**
-     * @return the byteCount
-     */
-    public long getByteCount() {
-        return byteCount;
-    }
-
-    /**
-     * @param byteCount the byteCount to set
-     */
-    public void setByteCount(long byteCount) {
-        this.byteCount = byteCount;
-    }
-
-    /**
-     * @param length the length to set
-     */
-    public void setLength(short length) {
-        this.length = length;
-    }
-
-    @Override
-    public int getLength() {
-        return U16.f(length);
-    }
-
-    /**
-     * @return the match
-     */
-    public V6Match getMatch() {
-        return match;
-    }
-
-    /**
-     * @return the actions
-     */
-    public List<OFAction> getActions() {
-        return actions;
-    }
-
-    /**
-     * @param actions the actions to set
-     */
-    public void setActions(List<OFAction> actions) {
-        this.actions = actions;
-    }
-
-    @Override
-    public void readFrom(ByteBuffer data) {
-        short i;
-        this.length = data.getShort();
-        if (length < MINIMUM_LENGTH)
-            return; //TBD - Spurious Packet?
-        this.tableId = data.get();
-        data.get(); // pad
-        this.durationSeconds = data.getInt();
-        this.durationNanoseconds = data.getInt();
-        this.priority = data.getShort();
-        this.idleTimeout = data.getShort();
-        this.hardTimeout = data.getShort();
-        this.match_len = data.getShort();
-        this.idleAge = data.getShort();
-        this.hardAge = data.getShort();
-        this.cookie = data.getLong();
-        this.packetCount = data.getLong();
-        this.byteCount = data.getLong();
-        if (this.length == MINIMUM_LENGTH) {
-            return; //TBD - can this happen??
-        }
-        if (this.match == null)
-            this.match = new V6Match();
-        ByteBuffer mbuf = ByteBuffer.allocate(match_len);
-        for (i = 0; i < match_len; i++) {
-            mbuf.put(data.get());
-        }
-        mbuf.rewind();
-        this.match.readFrom(mbuf);
-        if (this.actionFactory == null)
-            throw new RuntimeException("OFActionFactory not set");
-        /*
-         * action list may be preceded by a padding of 0 to 7 bytes based upon this:
-         */
-        short pad_size = (short) (((match_len + 7) / 8) * 8 - match_len);
-        for (i = 0; i < pad_size; i++) {
-            data.get();
-        }
-        int action_len = this.length - MINIMUM_LENGTH - (match_len + pad_size);
-        if (action_len > 0)
-            this.actions = this.actionFactory.parseActions(data, action_len);
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = super.hashCode();
-        result = prime * result + ((actions == null) ? 0 : actions.hashCode());
-        result = prime * result + (int) (byteCount ^ (byteCount >>> 32));
-        result = prime * result + (int) (cookie ^ (cookie >>> 32));
-        result = prime * result + durationNanoseconds;
-        result = prime * result + durationSeconds;
-        result = prime * result + hardAge;
-        result = prime * result + hardTimeout;
-        result = prime * result + idleAge;
-        result = prime * result + idleTimeout;
-        result = prime * result + length;
-        result = prime * result + ((match == null) ? 0 : match.hashCode());
-        result = prime * result + match_len;
-        result = prime * result + (int) (packetCount ^ (packetCount >>> 32));
-        result = prime * result + priority;
-        result = prime * result + tableId;
-        return result;
-    }
-
-    @Override
-    public String toString() {
-        return "V6StatsReply [length=" + length + ", tableId=" + tableId
-                + ", durationSeconds=" + durationSeconds
-                + ", durationNanoseconds=" + durationNanoseconds
-                + ", priority=" + priority + ", idleTimeout=" + idleTimeout
-                + ", hardTimeout=" + hardTimeout + ", match_len=" + match_len
-                + ", idleAge=" + idleAge + ", hardAge=" + hardAge + ", cookie="
-                + cookie + ", packetCount=" + packetCount + ", byteCount="
-                + byteCount + ", match=" + match + ", actions=" + actions + "]";
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj)
-            return true;
-        if (!super.equals(obj))
-            return false;
-        if (getClass() != obj.getClass())
-            return false;
-        V6StatsReply other = (V6StatsReply) obj;
-        if (actions == null) {
-            if (other.actions != null)
-                return false;
-        } else if (!actions.equals(other.actions))
-            return false;
-        if (byteCount != other.byteCount)
-            return false;
-        if (cookie != other.cookie)
-            return false;
-        if (durationNanoseconds != other.durationNanoseconds)
-            return false;
-        if (durationSeconds != other.durationSeconds)
-            return false;
-        if (hardAge != other.hardAge)
-            return false;
-        if (hardTimeout != other.hardTimeout)
-            return false;
-        if (idleAge != other.idleAge)
-            return false;
-        if (idleTimeout != other.idleTimeout)
-            return false;
-        if (length != other.length)
-            return false;
-        if (match == null) {
-            if (other.match != null)
-                return false;
-        } else if (!match.equals(other.match))
-            return false;
-        if (match_len != other.match_len)
-            return false;
-        if (packetCount != other.packetCount)
-            return false;
-        if (priority != other.priority)
-            return false;
-        if (tableId != other.tableId)
-            return false;
-        return true;
-    }
-
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/vendorextension/v6extension/V6StatsRequest.java b/opendaylight/adsal/protocol_plugins/openflow/src/main/java/org/opendaylight/controller/protocol_plugin/openflow/vendorextension/v6extension/V6StatsRequest.java
deleted file mode 100644 (file)
index d9c460b..0000000
+++ /dev/null
@@ -1,178 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow.vendorextension.v6extension;
-
-import java.nio.ByteBuffer;
-
-import org.openflow.protocol.statistics.OFVendorStatistics;
-
-
-/**
- * This Class creates the OpenFlow Vendor Extension IPv6 Flow Stats Request
- * messages and also reads the Reply of a stats request message.
- *
- */
-
-public class V6StatsRequest extends OFVendorStatistics {
-    private static final long serialVersionUID = 1L;
-    protected int msgsubtype;
-    protected short outPort;
-    protected short match_len;
-    protected byte tableId;
-
-    public static final int NICIRA_VENDOR_ID = 0x00002320; //Nicira ID
-    private static final int NXST_FLOW = 0x0; //Nicira Flow Stats Request Id
-
-    public V6StatsRequest() {
-        this.vendor = NICIRA_VENDOR_ID;
-        this.msgsubtype = NXST_FLOW;
-        this.match_len = 0;
-    }
-
-    /**
-     * @param None. Being set with local variable (TBD).
-     */
-    public void setVendorId() {
-        this.vendor = NICIRA_VENDOR_ID;
-    }
-
-    /**
-     * @return vendor id
-     */
-    public int getVendorId() {
-        return vendor;
-    }
-
-    /**
-     * @param None. Being set with local variable (TBD).
-     */
-    public void setMsgtype() {
-        this.msgsubtype = NXST_FLOW;
-    }
-
-    /**
-     * @return vendor_msgtype
-     */
-    public int getMsgtype() {
-        return msgsubtype;
-    }
-
-    /**
-     * @param outPort the outPort to set
-     */
-    public void setOutPort(short outPort) {
-        this.outPort = outPort;
-    }
-
-    /**
-     * @return the outPort
-     */
-    public short getOutPort() {
-        return outPort;
-    }
-
-    /**
-     * @param match_len the match_len to set
-     */
-    public void setMatchLen(short match_len) {
-        this.match_len = match_len;
-    }
-
-    /**
-     * @return the match_len
-     */
-    public short getMatchLen() {
-        return match_len;
-    }
-
-    /**
-     * @param tableId the tableId to set
-     */
-    public void setTableId(byte tableId) {
-        this.tableId = tableId;
-    }
-
-    /**
-     * @return the tableId
-     */
-    public byte getTableId() {
-        return tableId;
-    }
-
-    @Override
-    public int getLength() {
-        return 20;// 4(vendor)+4(msgsubtype)+4(pad)+2(outPort)+2(match_len)+1(tableid)+3(pad)
-    }
-
-    @Override
-    public void readFrom(ByteBuffer data) {
-        this.vendor = data.getInt();
-        this.msgsubtype = data.getInt();
-        data.getInt();//pad 4 bytes
-        this.outPort = data.getShort();
-        this.match_len = data.getShort();
-        this.tableId = data.get();
-        for (int i = 0; i < 3; i++) {
-            data.get();//pad byte
-        }
-
-    }
-
-    @Override
-    public void writeTo(ByteBuffer data) {
-        data.putInt(this.vendor);
-        data.putInt(this.msgsubtype);
-        data.putInt((int) 0x0);//pad0
-        data.putShort(this.outPort);
-        data.putShort(this.match_len);
-        data.put(this.tableId);
-        for (int i = 0; i < 3; i++)  {
-            data.put((byte) 0x0);//pad byte
-        }
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = super.hashCode();
-        result = prime * result + match_len;
-        result = prime * result + msgsubtype;
-        result = prime * result + outPort;
-        result = prime * result + tableId;
-        return result;
-    }
-
-    @Override
-    public String toString() {
-        return "V6StatsRequest [msgsubtype=" + msgsubtype + ", outPort="
-                + outPort + ", match_len=" + match_len + ", tableId=" + tableId
-                + "]";
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj)
-            return true;
-        if (!super.equals(obj))
-            return false;
-        if (getClass() != obj.getClass())
-            return false;
-        V6StatsRequest other = (V6StatsRequest) obj;
-        if (match_len != other.match_len)
-            return false;
-        if (msgsubtype != other.msgsubtype)
-            return false;
-        if (outPort != other.outPort)
-            return false;
-        if (tableId != other.tableId)
-            return false;
-        return true;
-    }
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/test/java/org/opendaylight/controller/protocol_plugin/openflow/internal/FlowProgrammerServiceTest.java b/opendaylight/adsal/protocol_plugins/openflow/src/test/java/org/opendaylight/controller/protocol_plugin/openflow/internal/FlowProgrammerServiceTest.java
deleted file mode 100644 (file)
index 96f0d80..0000000
+++ /dev/null
@@ -1,417 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow.internal;
-
-import java.net.InetAddress;
-import java.net.UnknownHostException;
-import java.util.ArrayList;
-import java.util.Arrays;
-import java.util.List;
-
-import org.junit.Assert;
-import org.junit.Test;
-import org.opendaylight.controller.protocol_plugin.openflow.vendorextension.v6extension.V6Match;
-import org.opendaylight.controller.sal.action.Action;
-import org.opendaylight.controller.sal.action.Flood;
-import org.opendaylight.controller.sal.action.FloodAll;
-import org.opendaylight.controller.sal.action.HwPath;
-import org.opendaylight.controller.sal.action.Loopback;
-import org.opendaylight.controller.sal.action.Output;
-import org.opendaylight.controller.sal.action.PopVlan;
-import org.opendaylight.controller.sal.action.SetDlDst;
-import org.opendaylight.controller.sal.action.SetDlSrc;
-import org.opendaylight.controller.sal.action.SetNwDst;
-import org.opendaylight.controller.sal.action.SetNwSrc;
-import org.opendaylight.controller.sal.action.SetNwTos;
-import org.opendaylight.controller.sal.action.SetTpDst;
-import org.opendaylight.controller.sal.action.SetTpSrc;
-import org.opendaylight.controller.sal.action.SetVlanId;
-import org.opendaylight.controller.sal.action.SwPath;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.flowprogrammer.Flow;
-import org.opendaylight.controller.sal.match.Match;
-import org.opendaylight.controller.sal.match.MatchType;
-import org.opendaylight.controller.sal.utils.EtherTypes;
-import org.opendaylight.controller.sal.utils.IPProtocols;
-import org.opendaylight.controller.sal.utils.NodeConnectorCreator;
-import org.opendaylight.controller.sal.utils.NodeCreator;
-import org.openflow.protocol.OFMatch;
-import org.openflow.protocol.action.OFAction;
-import org.openflow.util.U32;
-
-public class FlowProgrammerServiceTest {
-
-    @Test
-    public void testSALtoOFFlowConverter() throws UnknownHostException {
-        Node node = NodeCreator.createOFNode(1000L);
-        NodeConnector port = NodeConnectorCreator.createNodeConnector(
-                (short) 24, node);
-        NodeConnector oport = NodeConnectorCreator.createNodeConnector(
-                (short) 30, node);
-        byte srcMac[] = { (byte) 0x12, (byte) 0x34, (byte) 0x56, (byte) 0x78,
-                (byte) 0x9a, (byte) 0xbc };
-        byte dstMac[] = { (byte) 0x1a, (byte) 0x2b, (byte) 0x3c, (byte) 0x4d,
-                (byte) 0x5e, (byte) 0x6f };
-        InetAddress srcIP = InetAddress.getByName("172.28.30.50");
-        InetAddress dstIP = InetAddress.getByName("171.71.9.52");
-        InetAddress ipMask = InetAddress.getByName("255.255.255.0");
-        short ethertype = EtherTypes.IPv4.shortValue();
-        short vlan = (short) 27;
-        byte vlanPr = 3;
-        Byte tos = 4;
-        byte proto = IPProtocols.TCP.byteValue();
-        short src = (short) 55000;
-        short dst = 80;
-
-        /*
-         * Create a SAL Flow aFlow
-         */
-        Match match = new Match();
-        match.setField(MatchType.IN_PORT, port);
-        match.setField(MatchType.DL_SRC, srcMac);
-        match.setField(MatchType.DL_DST, dstMac);
-        match.setField(MatchType.DL_TYPE, ethertype);
-        match.setField(MatchType.DL_VLAN, vlan);
-        match.setField(MatchType.DL_VLAN_PR, vlanPr);
-        match.setField(MatchType.NW_SRC, srcIP, ipMask);
-        match.setField(MatchType.NW_DST, dstIP, ipMask);
-        match.setField(MatchType.NW_TOS, tos);
-        match.setField(MatchType.NW_PROTO, proto);
-        match.setField(MatchType.TP_SRC, src);
-        match.setField(MatchType.TP_DST, dst);
-
-        Assert.assertTrue(match.isIPv4());
-
-        List<Action> actions = new ArrayList<Action>();
-        // Setting all the actions supported by of
-        actions.add(new PopVlan());
-        actions.add(new Output(oport));
-        actions.add(new Flood());
-        actions.add(new FloodAll());
-        actions.add(new SwPath());
-        actions.add(new HwPath());
-        actions.add(new Loopback());
-        byte mac[] = { (byte) 1, (byte) 2, (byte) 3, (byte) 4, (byte) 5 };
-        actions.add(new SetDlSrc(mac));
-        actions.add(new SetDlDst(mac));
-        actions.add(new SetNwSrc(dstIP));
-        actions.add(new SetNwDst(srcIP));
-        actions.add(new SetNwTos(3));
-        actions.add(new SetTpSrc(10));
-        actions.add(new SetTpDst(20));
-        actions.add(new SetVlanId(200));
-
-        Flow aFlow = new Flow(match, actions);
-
-        /*
-         * Convert the SAL aFlow to OF Flow
-         */
-        FlowConverter salToOF = new FlowConverter(aFlow);
-        OFMatch ofMatch = salToOF.getOFMatch();
-        List<OFAction> ofActions = salToOF.getOFActions();
-
-        /*
-         * Convert the OF Flow to SAL Flow bFlow
-         */
-        FlowConverter ofToSal = new FlowConverter(ofMatch, ofActions);
-        Flow bFlow = ofToSal.getFlow(node);
-        Match bMatch = bFlow.getMatch();
-        List<Action> bActions = bFlow.getActions();
-
-        /*
-         * Verify the converted SAL flow bFlow is equivalent to the original SAL Flow
-         */
-        Assert.assertTrue(((NodeConnector) match.getField(MatchType.IN_PORT)
-                .getValue()).equals(((NodeConnector) bMatch.getField(
-                MatchType.IN_PORT).getValue())));
-        Assert.assertTrue(Arrays.equals((byte[]) match.getField(
-                MatchType.DL_SRC).getValue(), (byte[]) bMatch.getField(
-                MatchType.DL_SRC).getValue()));
-        Assert.assertTrue(Arrays.equals((byte[]) match.getField(
-                MatchType.DL_DST).getValue(), (byte[]) bMatch.getField(
-                MatchType.DL_DST).getValue()));
-        Assert
-                .assertTrue(((Short) match.getField(MatchType.DL_TYPE)
-                        .getValue()).equals((Short) bMatch.getField(
-                        MatchType.DL_TYPE).getValue()));
-        Assert
-                .assertTrue(((Short) match.getField(MatchType.DL_VLAN)
-                        .getValue()).equals((Short) bMatch.getField(
-                        MatchType.DL_VLAN).getValue()));
-        Assert.assertTrue(((Byte) match.getField(MatchType.DL_VLAN_PR)
-                .getValue()).equals((Byte) bMatch
-                .getField(MatchType.DL_VLAN_PR).getValue()));
-        Assert.assertTrue(((InetAddress) match.getField(MatchType.NW_SRC)
-                .getValue()).equals((InetAddress) bMatch.getField(
-                MatchType.NW_SRC).getValue()));
-        Assert.assertTrue(((InetAddress) match.getField(MatchType.NW_SRC)
-                .getMask()).equals((InetAddress) bMatch.getField(
-                MatchType.NW_SRC).getMask()));
-        Assert.assertTrue(((InetAddress) match.getField(MatchType.NW_DST)
-                .getValue()).equals((InetAddress) bMatch.getField(
-                MatchType.NW_DST).getValue()));
-        Assert.assertTrue(((InetAddress) match.getField(MatchType.NW_DST)
-                .getMask()).equals((InetAddress) bMatch.getField(
-                MatchType.NW_DST).getMask()));
-        Assert
-                .assertTrue(((Byte) match.getField(MatchType.NW_PROTO)
-                        .getValue()).equals((Byte) bMatch.getField(
-                        MatchType.NW_PROTO).getValue()));
-        Assert.assertTrue(((Byte) match.getField(MatchType.NW_TOS).getValue())
-                .equals((Byte) bMatch.getField(MatchType.NW_TOS).getValue()));
-        Assert.assertTrue(((Short) match.getField(MatchType.TP_SRC).getValue())
-                .equals((Short) bMatch.getField(MatchType.TP_SRC).getValue()));
-        Assert.assertTrue(((Short) match.getField(MatchType.TP_DST).getValue())
-                .equals((Short) bMatch.getField(MatchType.TP_DST).getValue()));
-
-        // FlowConverter parses and sets the actions in the same order for sal match and of match
-        for (short i = 0; i < actions.size(); i++) {
-            Assert.assertTrue(actions.get(i).equals(bActions.get(i)));
-        }
-    }
-
-    @Test
-    public void testVlanNoneIdFlowConversion() throws Exception {
-        Node node = NodeCreator.createOFNode(1000L);
-
-        /*
-         * The value 0 is used to indicate that no VLAN ID is set
-         * for SAL Flow.
-         */
-        short vlan = (short) 0;
-
-        /*
-         * Create a SAL Flow aFlow
-         */
-        Match match = new Match();
-        match.setField(MatchType.DL_VLAN, vlan);
-
-        List<Action> actions = new ArrayList<Action>();
-
-        Flow aFlow = new Flow(match, actions);
-
-        /*
-         * Convert the SAL aFlow to OF Flow
-         */
-        FlowConverter salToOF = new FlowConverter(aFlow);
-        OFMatch ofMatch = salToOF.getOFMatch();
-        List<OFAction> ofActions = salToOF.getOFActions();
-
-        /*
-         * The value 0xffff (OFP_VLAN_NONE) is used to indicate
-         * that no VLAN ID is set for OF Flow.
-         */
-        Assert.assertEquals((short) 0xffff, ofMatch.getDataLayerVirtualLan());
-
-        /*
-         * Convert the OF Flow to SAL Flow bFlow
-         */
-        FlowConverter ofToSal = new FlowConverter(ofMatch, ofActions);
-        Flow bFlow = ofToSal.getFlow(node);
-        Match bMatch = bFlow.getMatch();
-
-        /*
-         * Verify the converted SAL flow bFlow is equivalent to the original SAL Flow
-         */
-        Assert
-                .assertTrue(((Short) match.getField(MatchType.DL_VLAN)
-                        .getValue()).equals((Short) bMatch.getField(
-                        MatchType.DL_VLAN).getValue()));
-    }
-
-    @Test
-    public void testV6toSALFlowConversion() throws Exception {
-        Node node = NodeCreator.createOFNode(12L);
-        NodeConnector port = NodeConnectorCreator.createNodeConnector(
-                (short) 34, node);
-        NodeConnector oport = NodeConnectorCreator.createNodeConnector(
-                (short) 30, node);
-        byte srcMac[] = { (byte) 0x12, (byte) 0x34, (byte) 0x56, (byte) 0x78,
-                (byte) 0x9a, (byte) 0xbc };
-        byte dstMac[] = { (byte) 0x1a, (byte) 0x2b, (byte) 0x3c, (byte) 0x4d,
-                (byte) 0x5e, (byte) 0x6f };
-        InetAddress srcIP = InetAddress
-                .getByName("2001:420:281:1004:407a:57f4:4d15:c355");
-        InetAddress dstIP = InetAddress
-                .getByName("2001:420:281:1004:e123:e688:d655:a1b0");
-        InetAddress ipMask = InetAddress
-                .getByName("ffff:ffff:ffff:ffff:0:0:0:0");
-        short ethertype = EtherTypes.IPv6.shortValue();
-        short vlan = (short) 27;
-        byte vlanPr = 3;
-        Byte tos = 4;
-        byte proto = IPProtocols.TCP.byteValue();
-        short src = (short) 55000;
-        short dst = 80;
-
-        /*
-         * Create a SAL Flow aFlow
-         */
-        Match aMatch = new Match();
-
-        aMatch.setField(MatchType.IN_PORT, port);
-        aMatch.setField(MatchType.DL_SRC, srcMac);
-        aMatch.setField(MatchType.DL_DST, dstMac);
-        aMatch.setField(MatchType.DL_TYPE, ethertype);
-        aMatch.setField(MatchType.DL_VLAN, vlan);
-        aMatch.setField(MatchType.DL_VLAN_PR, vlanPr);
-        aMatch.setField(MatchType.NW_SRC, srcIP, ipMask);
-        aMatch.setField(MatchType.NW_DST, dstIP, ipMask);
-        aMatch.setField(MatchType.NW_TOS, tos);
-        aMatch.setField(MatchType.NW_PROTO, proto);
-        aMatch.setField(MatchType.TP_SRC, src);
-        aMatch.setField(MatchType.TP_DST, dst);
-
-        Assert.assertTrue(aMatch.isIPv6());
-
-        List<Action> actions = new ArrayList<Action>();
-        // Setting all the actions supported by of for v6
-        actions.add(new PopVlan());
-        actions.add(new Output(oport));
-        actions.add(new Flood());
-        actions.add(new FloodAll());
-        actions.add(new SwPath());
-        actions.add(new HwPath());
-        actions.add(new Loopback());
-        byte mac[] = { (byte) 1, (byte) 2, (byte) 3, (byte) 4, (byte) 5 };
-        actions.add(new SetDlSrc(mac));
-        actions.add(new SetDlDst(mac));
-        //actions.add(new SetNwSrc(dstIP)); Nicira extensions do not provide IPv6 match addresses change
-        //actions.add(new SetNwDst(srcIP));
-        actions.add(new SetNwTos(3));
-        actions.add(new SetTpSrc(10));
-        actions.add(new SetTpDst(65535));
-        actions.add(new SetVlanId(200));
-
-        Flow aFlow = new Flow(aMatch, actions);
-
-        /*
-         * Convert the SAL aFlow to OF Flow
-         */
-        FlowConverter salToOF = new FlowConverter(aFlow);
-        V6Match v6Match = (V6Match) salToOF.getOFMatch();
-        // need this hardcoding here to make the test pass.
-        // this should not be a problem in actual code.
-        // in the test the sal match is converted to a V6 match.
-        // we lose the wildcard info as the V6 match is used for nicira extensions
-        // and nicira deals with wildcards in a different way.
-        // converting the V6 match back to sal match is not going to preserve the wildcard info.
-        // and we need the wildcard info for reading the vlan pcp now.
-        // when creating a V6Match using the readFrom method
-        // we do convert the nicira extensions format correctly to populate the wildcard info.
-        v6Match.setWildcards(U32.t(Long.valueOf(~OFMatch.OFPFW_DL_VLAN_PCP)));
-        List<OFAction> ofActions = salToOF.getOFActions();
-
-        /*
-         * Convert the OF Flow to SAL Flow bFlow
-         */
-        FlowConverter ofToSal = new FlowConverter(v6Match, ofActions);
-        Flow bFlow = ofToSal.getFlow(node);
-        Match bMatch = bFlow.getMatch();
-        List<Action> bActions = bFlow.getActions();
-
-        /*
-         * Verify the converted SAL flow bFlow is equivalent to the original SAL Flow
-         */
-        Assert.assertTrue(((NodeConnector) aMatch.getField(MatchType.IN_PORT)
-                .getValue()).equals(((NodeConnector) bMatch.getField(
-                MatchType.IN_PORT).getValue())));
-        Assert.assertTrue(Arrays.equals((byte[]) aMatch.getField(
-                MatchType.DL_SRC).getValue(), (byte[]) bMatch.getField(
-                MatchType.DL_SRC).getValue()));
-        Assert.assertTrue(Arrays.equals((byte[]) aMatch.getField(
-                MatchType.DL_DST).getValue(), (byte[]) bMatch.getField(
-                MatchType.DL_DST).getValue()));
-        Assert.assertTrue(((Short) aMatch.getField(MatchType.DL_TYPE)
-                .getValue()).equals((Short) bMatch.getField(MatchType.DL_TYPE)
-                .getValue()));
-        Assert.assertTrue(((Short) aMatch.getField(MatchType.DL_VLAN)
-                .getValue()).equals((Short) bMatch.getField(MatchType.DL_VLAN)
-                .getValue()));
-        Assert.assertTrue(((Byte) aMatch.getField(MatchType.DL_VLAN_PR)
-                .getValue()).equals((Byte) bMatch
-                .getField(MatchType.DL_VLAN_PR).getValue()));
-        Assert.assertTrue(((InetAddress) aMatch.getField(MatchType.NW_SRC)
-                .getValue()).equals((InetAddress) bMatch.getField(
-                MatchType.NW_SRC).getValue()));
-        Assert.assertTrue(((InetAddress) aMatch.getField(MatchType.NW_SRC)
-                .getMask()).equals((InetAddress) bMatch.getField(
-                MatchType.NW_SRC).getMask()));
-        Assert.assertTrue(((InetAddress) aMatch.getField(MatchType.NW_DST)
-                .getValue()).equals((InetAddress) bMatch.getField(
-                MatchType.NW_DST).getValue()));
-        Assert.assertTrue(((InetAddress) aMatch.getField(MatchType.NW_DST)
-                .getMask()).equals((InetAddress) bMatch.getField(
-                MatchType.NW_DST).getMask()));
-        Assert.assertTrue(((Byte) aMatch.getField(MatchType.NW_PROTO)
-                .getValue()).equals((Byte) bMatch.getField(MatchType.NW_PROTO)
-                .getValue()));
-        Assert.assertTrue(((Byte) aMatch.getField(MatchType.NW_TOS).getValue())
-                .equals((Byte) bMatch.getField(MatchType.NW_TOS).getValue()));
-        Assert
-                .assertTrue(((Short) aMatch.getField(MatchType.TP_SRC)
-                        .getValue()).equals((Short) bMatch.getField(
-                        MatchType.TP_SRC).getValue()));
-        Assert
-                .assertTrue(((Short) aMatch.getField(MatchType.TP_DST)
-                        .getValue()).equals((Short) bMatch.getField(
-                        MatchType.TP_DST).getValue()));
-
-        // FlowConverter parses and sets the actions in the same order for sal match and of match
-        for (short i = 0; i < actions.size(); i++) {
-            Assert.assertTrue(actions.get(i).equals(bActions.get(i)));
-        }
-    }
-
-    @Test
-    public void testV6MatchToSALMatchToV6MatchConversion()
-            throws UnknownHostException {
-        NodeConnector port = NodeConnectorCreator.createNodeConnector(
-                (short) 24, NodeCreator.createOFNode(6L));
-        byte srcMac[] = { (byte) 0x12, (byte) 0x34, (byte) 0x56, (byte) 0x78,
-                (byte) 0x9a, (byte) 0xbc };
-        byte dstMac[] = { (byte) 0x1a, (byte) 0x2b, (byte) 0x3c, (byte) 0x4d,
-                (byte) 0x5e, (byte) 0x6f };
-        InetAddress srcIP = InetAddress
-                .getByName("2001:420:281:1004:407a:57f4:4d15:c355");
-        InetAddress dstIP = InetAddress
-                .getByName("2001:420:281:1004:e123:e688:d655:a1b0");
-        InetAddress ipMask = null;//InetAddress.getByName("ffff:ffff:ffff:ffff:0:0:0:0");
-        short ethertype = EtherTypes.IPv6.shortValue();
-        short vlan = (short) 27;
-        byte vlanPr = 3;
-        Byte tos = 4;
-        byte proto = IPProtocols.TCP.byteValue();
-        short src = (short) 55000;
-        short dst = 80;
-
-        /*
-         * Create a SAL Flow aFlow
-         */
-        Match aMatch = new Match();
-
-        aMatch.setField(MatchType.IN_PORT, port);
-        aMatch.setField(MatchType.DL_SRC, srcMac);
-        aMatch.setField(MatchType.DL_DST, dstMac);
-        aMatch.setField(MatchType.DL_TYPE, ethertype);
-        aMatch.setField(MatchType.DL_VLAN, vlan);
-        aMatch.setField(MatchType.DL_VLAN_PR, vlanPr);
-        aMatch.setField(MatchType.NW_SRC, srcIP, ipMask);
-        aMatch.setField(MatchType.NW_DST, dstIP, ipMask);
-        aMatch.setField(MatchType.NW_TOS, tos);
-        aMatch.setField(MatchType.NW_PROTO, proto);
-        aMatch.setField(MatchType.TP_SRC, src);
-        aMatch.setField(MatchType.TP_DST, dst);
-
-        Assert.assertTrue(aMatch.isIPv6());
-
-    }
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/test/java/org/opendaylight/controller/protocol_plugin/openflow/vendorextension/v6extension/V6ExtensionTest.java b/opendaylight/adsal/protocol_plugins/openflow/src/test/java/org/opendaylight/controller/protocol_plugin/openflow/vendorextension/v6extension/V6ExtensionTest.java
deleted file mode 100644 (file)
index abbc438..0000000
+++ /dev/null
@@ -1,236 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.protocol_plugin.openflow.vendorextension.v6extension;
-
-import static org.junit.Assert.fail;
-
-import java.net.InetAddress;
-import java.net.UnknownHostException;
-import java.nio.ByteBuffer;
-import java.util.Arrays;
-
-import org.junit.Assert;
-import org.junit.Test;
-import org.openflow.protocol.OFMatch;
-import org.openflow.util.U32;
-
-public class V6ExtensionTest {
-
-    @Test
-    public void testFromString() throws UnknownHostException {
-        // This tests creating V6Match using fromString and OFMatch by comparing
-        // the results to each other
-        V6Match match = new V6Match();
-        V6Match match2 = new V6Match();
-
-        OFMatch ofm = new OFMatch();
-        V6Match match4 = new V6Match(ofm);
-
-        match.fromString("");
-        Assert.assertTrue(match.equals(match2));
-        match.fromString("any");
-        Assert.assertTrue(match.equals(match2));
-        Assert.assertTrue(match.equals(match4));
-        try {
-            match.fromString("invalidArgument");
-
-            fail("Did not throw IllegalArgumentException");
-        } catch (IllegalArgumentException e) {
-            // passed test for throwing exception.
-        }
-        try {
-            match.fromString("invalidParameter=abcdefg");
-            fail("Did not throw IllegalArgumentException");
-        } catch (IllegalArgumentException e) {
-            // passed test for throwing exception.
-        }
-
-        match.fromString("input_port=1");
-        match.fromString("dl_dst=20:A0:11:10:00:99");
-        match.fromString("dl_src=00:10:08:22:12:75");
-        match.fromString("ip_src=10.1.1.1");
-        match.fromString("ip_dst=1.2.3.4");
-        match.fromString("eth_type=0x800");
-        match.fromString("dl_vlan=10");
-        match.fromString("nw_proto=6");
-        match.fromString("nw_tos=100");
-        match.fromString("tp_dst=8080");
-        match.fromString("tp_src=60");
-        match.fromString("dl_vpcp=1");
-
-        Assert.assertTrue(match.getInputPort() == 1);
-        // Assert.assertTrue(match.getIPv6MatchLen()==6);
-        ofm.setInputPort((short) 1);
-        // V6Match is meant for IPv6, but if using OFMatch, it will be set to
-        // IPv4 values, as OF1.0 doesn't support IPv6.
-        InetAddress addr = InetAddress.getByName("10.1.1.1");
-        int ipsrc = ByteBuffer.wrap(addr.getAddress()).getInt();
-        ofm.setNetworkSource(ipsrc);
-
-        addr = InetAddress.getByName("1.2.3.4");
-        int ipdst = ByteBuffer.wrap(addr.getAddress()).getInt();
-        ofm.setNetworkDestination(ipdst);
-
-        byte[] macSrc = { 0x00, 0x10, 0x08, 0x22, 0x12, 0x75 };
-        ofm.setDataLayerSource(macSrc);
-        byte[] macDst = { 0x20, (byte) 0xA0, 0x11, 0x10, 0x00, (byte) 0x99 };
-        ofm.setDataLayerDestination(macDst);
-        ofm.setDataLayerType((short) 0x800);
-        ofm.setDataLayerVirtualLan((short) 10);
-        ofm.setDataLayerVirtualLanPriorityCodePoint((byte) 1);
-        ofm.setNetworkProtocol((byte) 6);
-        ofm.setNetworkTypeOfService((byte) 100);
-        ofm.setTransportSource((short) 60);
-        ofm.setTransportDestination((short) 8080);
-
-        // this v6match ctor now looks at the wildcard field to
-        // determine if vlan pcp has been set
-        // so set the wildcards appropriately to reflect that vlan pcp
-        // has been set.
-        int wildcards = OFMatch.OFPFW_ALL;
-        wildcards &= ~OFMatch.OFPFW_DL_VLAN_PCP;
-        ofm.setWildcards(U32.t(Long.valueOf(wildcards)));
-        V6Match match3 = new V6Match(ofm);
-
-        Assert.assertTrue(match.getInputPort() == match3.getInputPort());
-        Assert.assertTrue(Arrays.equals(match.getDataLayerSource(),
-                match3.getDataLayerSource()));
-        Assert.assertTrue(Arrays.equals(match.getDataLayerDestination(),
-                match3.getDataLayerDestination()));
-        Assert.assertNull(match.getNetworkSrc());
-        Assert.assertNull(match3.getNetworkSrc());
-        Assert.assertNull(match.getNetworkDest());
-        Assert.assertNull(match3.getNetworkDest());
-        Assert.assertTrue(match.getDataLayerVirtualLan() == match3
-                .getDataLayerVirtualLan());
-        Assert.assertTrue(match.getDataLayerVirtualLanPriorityCodePoint() == match3
-                .getDataLayerVirtualLanPriorityCodePoint());
-        Assert.assertTrue(match.getNetworkProtocol() == match3
-                .getNetworkProtocol());
-        Assert.assertTrue(match.getNetworkTypeOfService() == match3
-                .getNetworkTypeOfService());
-        Assert.assertTrue(match.getTransportSource() == match3
-                .getTransportSource());
-        Assert.assertTrue(match.getTransportDestination() == match3
-                .getTransportDestination());
-        Assert.assertTrue(match.getWildcards() == match3.getWildcards());
-
-    }
-
-    @Test
-    public void testReadWriteBuffer() {
-        V6Match match = new V6Match();
-        match.fromString("input_port=1");
-        match.fromString("dl_dst=20:A0:11:10:00:99");
-        match.fromString("dl_src=00:10:08:22:12:75");
-        // writeTo(ByteBuffer) will only write IPv6
-        match.fromString("ip_src=2001:ddd:3e1:1234:0000:1111:2222:3333/64");
-        match.fromString("ip_dst=2001:123:222:abc:111:aaa:1111:2222/64");
-        match.fromString("dl_vlan=10");
-        match.fromString("dl_vpcp=1");
-        match.fromString("nw_proto=6");
-        match.fromString("nw_tos=100");
-        match.fromString("tp_dst=8080");
-        match.fromString("tp_src=60");
-        match.fromString("dl_type=0x800");
-
-        ByteBuffer data = ByteBuffer.allocateDirect(10000);
-        match.writeTo(data);
-        data.flip();
-        V6Match match2 = new V6Match();
-        match2.readFrom(data);
-        Assert.assertTrue(match.getInputPort() == match2.getInputPort());
-        Assert.assertTrue(Arrays.equals(match.getDataLayerSource(),
-                match2.getDataLayerSource()));
-        Assert.assertTrue(Arrays.equals(match.getDataLayerDestination(),
-                match2.getDataLayerDestination()));
-
-        Assert.assertTrue(match.getNetworkSrc().equals(match2.getNetworkSrc()));
-        Assert.assertTrue(match.getNetworkDest()
-                .equals(match2.getNetworkDest()));
-
-        Assert.assertTrue(match.getDataLayerVirtualLan() == match2
-                .getDataLayerVirtualLan());
-        Assert.assertTrue(match.getDataLayerVirtualLanPriorityCodePoint() == match2
-                .getDataLayerVirtualLanPriorityCodePoint());
-        Assert.assertTrue(match.getNetworkProtocol() == match2
-                .getNetworkProtocol());
-        Assert.assertTrue(match.getNetworkTypeOfService() == match2
-                .getNetworkTypeOfService());
-        Assert.assertTrue(match.getTransportSource() == match2
-                .getTransportSource());
-        Assert.assertTrue(match.getTransportDestination() == match2
-                .getTransportDestination());
-
-    }
-
-    @Test
-    public void testClone() {
-        V6Match match = new V6Match();
-        match.fromString("input_port=1");
-        match.fromString("dl_dst=20:A0:11:10:00:99");
-        match.fromString("dl_src=00:10:08:22:12:75");
-        match.fromString("ip_src=2001:ddd:3e1:1234:0000:1111:2222:3333/64");
-        match.fromString("ip_dst=2001:123:222:abc:111:aaa:1111:2222/64");
-        match.fromString("dl_vlan=10");
-        match.fromString("dl_vpcp=1");
-        match.fromString("nw_proto=6");
-        match.fromString("nw_tos=100");
-        match.fromString("tp_dst=8080");
-        match.fromString("tp_src=60");
-        match.fromString("dl_type=0x800");
-
-        V6Match match2 = match.clone();
-        Assert.assertTrue(match.getInputPort() == match2.getInputPort());
-        Assert.assertTrue(Arrays.equals(match.getDataLayerSource(),
-                match2.getDataLayerSource()));
-        Assert.assertTrue(Arrays.equals(match.getDataLayerDestination(),
-                match2.getDataLayerDestination()));
-        Assert.assertTrue(match.getNetworkSrc().equals(match2.getNetworkSrc()));
-        Assert.assertTrue(match.getNetworkDest()
-                .equals(match2.getNetworkDest()));
-        Assert.assertTrue(match.getDataLayerVirtualLan() == match2
-                .getDataLayerVirtualLan());
-        Assert.assertTrue(match.getDataLayerVirtualLanPriorityCodePoint() == match2
-                .getDataLayerVirtualLanPriorityCodePoint());
-        Assert.assertTrue(match.getNetworkProtocol() == match2
-                .getNetworkProtocol());
-        Assert.assertTrue(match.getNetworkTypeOfService() == match2
-                .getNetworkTypeOfService());
-        Assert.assertTrue(match.getTransportSource() == match2
-                .getTransportSource());
-        Assert.assertTrue(match.getTransportDestination() == match2
-                .getTransportDestination());
-        Assert.assertTrue(match.getWildcards() == match2.getWildcards());
-    }
-
-    @Test
-    public void testPadding() {
-        // testing that matchlen+pad keeps the 8byte alignment
-        V6Match match = new V6Match();
-
-        match.fromString("input_port=1");
-        Assert.assertTrue((match.getPadSize() + match.getIPv6MatchLen()) % 8 == 0);
-        match.fromString("dl_dst=20:A0:11:10:00:99");
-        match.fromString("dl_src=00:10:08:22:12:75");
-        Assert.assertTrue((match.getPadSize() + match.getIPv6MatchLen()) % 8 == 0);
-        match.fromString("ip_src=2001:ddd:3e1:1234:0000:1111:2222:3333");
-        Assert.assertTrue((match.getPadSize() + match.getIPv6MatchLen()) % 8 == 0);
-        match.fromString("ip_dst=2001:123:222:abc:111:aaa:1111:2222");
-        Assert.assertTrue((match.getPadSize() + match.getIPv6MatchLen()) % 8 == 0);
-        match.fromString("dl_vlan=10");
-        match.fromString("dl_vpcp=1");
-        match.fromString("nw_proto=6");
-        Assert.assertTrue((match.getPadSize() + match.getIPv6MatchLen()) % 8 == 0);
-        match.fromString("nw_tos=100");
-        match.fromString("tp_dst=8080");
-        Assert.assertTrue((match.getPadSize() + match.getIPv6MatchLen()) % 8 == 0);
-        match.fromString("tp_src=60");
-        Assert.assertTrue((match.getPadSize() + match.getIPv6MatchLen()) % 8 == 0);
-    }
-}
diff --git a/opendaylight/adsal/protocol_plugins/openflow/src/test/java/org/opendaylight/controller/protocol_plugin/openflow/vendorextension/v6extension/V6MatchTest.java b/opendaylight/adsal/protocol_plugins/openflow/src/test/java/org/opendaylight/controller/protocol_plugin/openflow/vendorextension/v6extension/V6MatchTest.java
deleted file mode 100644 (file)
index fceaaf4..0000000
+++ /dev/null
@@ -1,461 +0,0 @@
-/*
- * Copyright (c) 2014 NEC Corporation
- * All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this
- * distribution, and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugin.openflow.vendorextension.v6extension;
-
-import static org.junit.Assert.assertEquals;
-import static org.junit.Assert.fail;
-import static org.openflow.protocol.OFMatch.OFPFW_ALL;
-import static org.openflow.protocol.OFMatch.OFPFW_DL_VLAN;
-import static org.openflow.protocol.OFMatch.OFPFW_DL_VLAN_PCP;
-import static org.openflow.protocol.OFMatch.OFPFW_IN_PORT;
-
-import java.nio.ByteBuffer;
-import org.junit.Test;
-
-/**
- * JUnit test for {@link V6Match}.
- */
-public class V6MatchTest {
-    /**
-     * Header of a match entry for input port field without a mask.
-     * The vendor-specific value is 0, and the length of value is 2.
-     */
-    private static int  HEADER_INPUT_PORT = (0 << 9) | 2;
-
-    /**
-     * Header of a match entry for VLAN TCI field without a mask.
-     * The vendor-specific value is 4, and the length of value is 2.
-     */
-    private static int  HEADER_VLAN_TCI= (4 << 9) | 2;
-
-    /**
-     * Header of a match entry for VLAN TCI field with a mask.
-     * The vendor-specific value is 4, and the length of value is 4.
-     */
-    private static int  HEADER_VLAN_TCI_W = (4 << 9) | (1 << 8) | 4;
-
-    /**
-     * Length of a match entry for input port field.
-     * Header (4 bytes) + value (2 bytes) = 6 bytes.
-     */
-    private static short  MATCH_LEN_INPUT_PORT = 6;
-
-    /**
-     * Length of a match entry for VLAN TCI field without a mask.
-     * Header (4 bytes) + value (2 bytes) = 6 bytes.
-     */
-    private static short  MATCH_LEN_VLAN_TCI = 6;
-
-    /**
-     * Length of a match entry for VLAN TCI field with a mask.
-     * Header (4 bytes) + value (2 bytes) + bitmask (2 bytes) = 8 bytes.
-     */
-    private static short  MATCH_LEN_VLAN_TCI_WITH_MASK = 8;
-
-    /**
-     * Value of OFP_VLAN_NONE defined by OpenFlow 1.0.
-     */
-    private static final short  OFP_VLAN_NONE = (short)0xffff;
-
-    /**
-     * CFI bit in VLAN TCI field.
-     */
-    private static final int  VLAN_TCI_CFI = 1 << 12;
-
-    /**
-     * Test case for {@link V6Match#fromString(String)} about VLAN TCI field.
-     * This test passes values to "dl_vlan" and "dl_vpcp".
-     */
-    @Test
-    public void testFromStringVlanTci() {
-        // Test for "dl_vlan" using non OFP_VLAN_NONE values.
-        short vlans[] = {1, 10, 1000, 4095};
-        short mask = 0;
-        for (short vlan: vlans) {
-            V6Match match = new V6Match();
-            match.fromString("dl_vlan=" + vlan);
-            assertEquals(MATCH_LEN_VLAN_TCI_WITH_MASK, match.getIPv6MatchLen());
-            assertEquals(vlan, match.getDataLayerVirtualLan());
-            int wildcards = OFPFW_ALL & ~OFPFW_DL_VLAN;
-            assertEquals(wildcards, match.getWildcards());
-        }
-
-        // Test for "dl_vpcp".
-        byte pcps[] = {1, 3, 7};
-        for (byte pcp: pcps) {
-            V6Match match = new V6Match();
-            match.fromString("dl_vpcp=" + pcp);
-            assertEquals(MATCH_LEN_VLAN_TCI_WITH_MASK, match.getIPv6MatchLen());
-            assertEquals(pcp, match.getDataLayerVirtualLanPriorityCodePoint());
-            int wildcards = OFPFW_ALL & ~OFPFW_DL_VLAN_PCP;
-            assertEquals(wildcards, match.getWildcards());
-        }
-
-        // Set "dl_vlan" field firstly, "dl_vpcp" field secondly.
-        for (short vlan: vlans) {
-            for (byte pcp: pcps) {
-                V6Match match = new V6Match();
-                match.fromString("dl_vlan=" + vlan);
-                match.fromString("dl_vpcp=" + pcp);
-                assertEquals(MATCH_LEN_VLAN_TCI, match.getIPv6MatchLen());
-                assertEquals(vlan, match.getDataLayerVirtualLan());
-                assertEquals(pcp,
-                        match.getDataLayerVirtualLanPriorityCodePoint());
-            }
-        }
-
-        // Set "dl_vpcp" field firstly, "dl_vlan" field secondly.
-        for (short vlan: vlans) {
-            for (byte pcp: pcps) {
-                V6Match match = new V6Match();
-                match.fromString("dl_vpcp=" + pcp);
-                match.fromString("dl_vlan=" + vlan);
-                assertEquals(MATCH_LEN_VLAN_TCI, match.getIPv6MatchLen());
-                assertEquals(vlan, match.getDataLayerVirtualLan());
-                assertEquals(pcp,
-                        match.getDataLayerVirtualLanPriorityCodePoint());
-            }
-        }
-
-        // Test for OFP_VLAN_NONE when VLAN PCP is not set.
-        V6Match match = new V6Match();
-        match.fromString("dl_vlan=" + OFP_VLAN_NONE);
-        assertEquals(MATCH_LEN_VLAN_TCI, match.getIPv6MatchLen());
-        assertEquals(OFP_VLAN_NONE, match.getDataLayerVirtualLan());
-
-        // Test for OFP_VLAN_NONE when VLAN PCP is set.
-        match = new V6Match();
-        match.fromString("dl_vpcp=" + 1);
-        try {
-            match.fromString("dl_vlan=" + OFP_VLAN_NONE);
-            fail("Throwing exception was expected.");
-        } catch (IllegalArgumentException e) {
-            // Throwing exception was expected.
-        }
-    }
-
-    /**
-     * Test case for {@link V6Match#writeTo(ByteBuffer)} for VLAN TCI field.
-     */
-    @Test
-    public void testWriteToVlanTci() {
-        byte mask = 0;
-
-        // Set only VLAN ID.
-        short vlans[] = {1, 10, 1000, 4095};
-        for (short vlan: vlans) {
-            V6Match match = new V6Match();
-            match.setDataLayerVirtualLan(vlan, mask);
-            ByteBuffer data = ByteBuffer.allocate(10);
-            match.writeTo(data);
-            assertEquals(MATCH_LEN_VLAN_TCI_WITH_MASK, data.position());
-            data.flip();
-            // Header
-            assertEquals(HEADER_VLAN_TCI_W, data.getInt());
-            // Value
-            short expectedTci = (short) (VLAN_TCI_CFI | vlan);
-            assertEquals(expectedTci, data.getShort());
-            // Mask
-            short expectedMask = 0x1fff;
-            assertEquals(expectedMask, data.getShort());
-        }
-
-        // Set only VLAN PCP.
-        byte pcps[] = {1, 3, 7};
-        for (byte pcp: pcps) {
-            V6Match match = new V6Match();
-            match.setDataLayerVirtualLanPriorityCodePoint(pcp, mask);
-            ByteBuffer data = ByteBuffer.allocate(10);
-            match.writeTo(data);
-            assertEquals(MATCH_LEN_VLAN_TCI_WITH_MASK, data.position());
-            data.flip();
-            // Header
-            assertEquals(HEADER_VLAN_TCI_W, data.getInt());
-            // Value
-            short expectedTci = (short) (pcp << 13 | VLAN_TCI_CFI);
-            assertEquals(expectedTci, data.getShort());
-            // Mask
-            short expectedMask = (short) 0xf000;
-            assertEquals(expectedMask, data.getShort());
-        }
-
-        // Set both VLAN ID and PCP.
-        for (short vlan: vlans) {
-            for (byte pcp: pcps) {
-                V6Match match = new V6Match();
-                match.setDataLayerVirtualLan(vlan, mask);
-                match.setDataLayerVirtualLanPriorityCodePoint(pcp, mask);
-                ByteBuffer data = ByteBuffer.allocate(10);
-                match.writeTo(data);
-                assertEquals(MATCH_LEN_VLAN_TCI, data.position());
-                data.flip();
-                // Header
-                assertEquals(HEADER_VLAN_TCI, data.getInt());
-                // Value
-                short expectedTci = (short) (pcp << 13 | VLAN_TCI_CFI | vlan);
-                assertEquals(expectedTci, data.getShort());
-            }
-        }
-
-        // Set OFP_VLAN_NONE.
-        V6Match match = new V6Match();
-        match.setDataLayerVirtualLan(OFP_VLAN_NONE, mask);
-        ByteBuffer data = ByteBuffer.allocate(10);
-        match.writeTo(data);
-        assertEquals(MATCH_LEN_VLAN_TCI, data.position());
-        data.flip();
-        // Header
-        assertEquals(HEADER_VLAN_TCI, data.getInt());
-        // Value
-        assertEquals(0, data.getShort());
-    }
-
-    /**
-     * Test case for {@link V6Match#writeTo(ByteBuffer)} for input port field.
-     */
-    @Test
-    public void testWriteToInputPort() {
-        // Set input port.
-        short ports[] = {1, 10, 100, 1000};
-        for (short port: ports) {
-            V6Match match = new V6Match();
-            match.setInputPort(port, (short) 0);
-            ByteBuffer data = ByteBuffer.allocate(10);
-            match.writeTo(data);
-            assertEquals(MATCH_LEN_INPUT_PORT, data.position());
-            data.flip();
-            // Header
-            assertEquals(HEADER_INPUT_PORT, data.getInt());
-            // Value
-            assertEquals(port, data.getShort());
-        }
-    }
-
-    /**
-     * Test case for {@link V6Match#readFrom(ByteBuffer)} for VLAN TCI field.
-     */
-    @Test
-    public void testReadFromVlanTci() {
-        // Test for an exact match a TCI value with CFI=1.
-        // It matches packets that have an 802.1Q header with a specified
-        // VID and PCP.
-        short vlans[] = {1, 10, 1000, 4095};
-        byte pcps[] = {1, 3, 7};
-        for (short vlan: vlans) {
-            for (byte pcp: pcps) {
-                ByteBuffer data = ByteBuffer.allocate(MATCH_LEN_VLAN_TCI);
-                data.putInt(HEADER_VLAN_TCI);
-                short tci = (short) (pcp << 13 | VLAN_TCI_CFI | vlan);
-                data.putShort(tci);
-                data.flip();
-
-                V6Match match = new V6Match();
-                match.readFrom(data);
-                assertEquals(MATCH_LEN_VLAN_TCI, match.getIPv6MatchLen());
-                assertEquals(pcp,
-                        match.getDataLayerVirtualLanPriorityCodePoint());
-                assertEquals(vlan, match.getDataLayerVirtualLan());
-                int wildcards = OFPFW_ALL & ~OFPFW_DL_VLAN_PCP & ~OFPFW_DL_VLAN;
-                assertEquals(wildcards, match.getWildcards());
-            }
-        }
-
-        // Test with a specific VID and CFI=1 with mask=0x1fff.
-        // It matches packets that have an 802.1Q header with that VID
-        // and any PCP.
-        for (short vlan: vlans) {
-            ByteBuffer data = ByteBuffer.allocate(MATCH_LEN_VLAN_TCI_WITH_MASK);
-            data.putInt(HEADER_VLAN_TCI_W);
-            short tci = (short) (VLAN_TCI_CFI | vlan);
-            data.putShort(tci);
-            short mask = (short) 0x1fff;
-            data.putShort(mask);
-            data.flip();
-
-            V6Match match = new V6Match();
-            match.readFrom(data);
-            assertEquals(MATCH_LEN_VLAN_TCI_WITH_MASK, match.getIPv6MatchLen());
-            assertEquals(vlan, match.getDataLayerVirtualLan());
-            int wildcards = OFPFW_ALL & ~OFPFW_DL_VLAN;
-            assertEquals(wildcards, match.getWildcards());
-        }
-
-        // Test with a specific PCP and CFI=1 with mask=0xf000.
-        // It matches packets that have an 802.1Q header with that PCP
-        // and any VID.
-        for (byte pcp: pcps) {
-            ByteBuffer data = ByteBuffer.allocate(MATCH_LEN_VLAN_TCI_WITH_MASK);
-            data.putInt(HEADER_VLAN_TCI_W);
-            short tci = (short) (pcp << 13| VLAN_TCI_CFI);
-            data.putShort(tci);
-            short mask = (short) 0xf000;
-            data.putShort(mask);
-            data.flip();
-
-            V6Match match = new V6Match();
-            match.readFrom(data);
-            assertEquals(MATCH_LEN_VLAN_TCI_WITH_MASK, match.getIPv6MatchLen());
-            assertEquals(pcp, match.getDataLayerVirtualLanPriorityCodePoint());
-            int wildcards = OFPFW_ALL & ~OFPFW_DL_VLAN_PCP;
-            assertEquals(wildcards, match.getWildcards());
-        }
-
-        // Test for an exact match with 0.
-        // It matches only packets without an 802.1Q header.
-        ByteBuffer data = ByteBuffer.allocate(MATCH_LEN_VLAN_TCI);
-        data.putInt(HEADER_VLAN_TCI);
-        short tci = 0;
-        data.putShort(tci);
-        data.flip();
-
-        V6Match match = new V6Match();
-        match.readFrom(data);
-        assertEquals(MATCH_LEN_VLAN_TCI, match.getIPv6MatchLen());
-        assertEquals(OFP_VLAN_NONE, match.getDataLayerVirtualLan());
-        int wildcards = OFPFW_ALL & ~OFPFW_DL_VLAN;
-        assertEquals(wildcards, match.getWildcards());
-    }
-
-    /**
-     * Test case for {@link V6Match#readFrom(ByteBuffer)} for input port field.
-     */
-    @Test
-    public void testReadFromInputPort() {
-        // Set input port.
-        short ports[] = {1, 10, 100, 1000};
-        for (short port: ports) {
-            ByteBuffer data = ByteBuffer.allocate(MATCH_LEN_INPUT_PORT);
-            data.putInt(HEADER_INPUT_PORT);
-            data.putShort(port);
-            data.flip();
-
-            V6Match match = new V6Match();
-            match.readFrom(data);
-            assertEquals(MATCH_LEN_INPUT_PORT, match.getIPv6MatchLen());
-            assertEquals(port, match.getInputPort());
-            int wildcards = OFPFW_ALL & ~OFPFW_IN_PORT;
-            assertEquals(wildcards, match.getWildcards());
-        }
-    }
-
-    /**
-     * Test case for {@link V6Match#setDataLayerVirtualLan(short, short)}.
-     */
-    @Test
-    public void testSetDataLayerVirtualLan() {
-        short vlans[] = {1, 10, 1000, 4095};
-        short mask = 0;
-        for (short vlan: vlans) {
-            V6Match match = new V6Match();
-            match.setDataLayerVirtualLan(vlan, mask);
-            assertEquals(MATCH_LEN_VLAN_TCI_WITH_MASK, match.getIPv6MatchLen());
-            assertEquals(vlan, match.getDataLayerVirtualLan());
-        }
-
-        // Test for OFP_VLAN_NONE.
-        V6Match match = new V6Match();
-        match.setDataLayerVirtualLan(OFP_VLAN_NONE, mask);
-        assertEquals(MATCH_LEN_VLAN_TCI, match.getIPv6MatchLen());
-        assertEquals(OFP_VLAN_NONE, match.getDataLayerVirtualLan());
-    }
-
-    /**
-     * Test case for
-     * {@link V6Match#setDataLayerVirtualLanPriorityCodePoint(byte, byte)}.
-     */
-    @Test
-    public void testSetDataLayerVirtualLanPriorityCodePoint() {
-        byte pcps[] = {1, 3, 7};
-        byte mask = 0;
-        for (byte pcp: pcps) {
-            V6Match match = new V6Match();
-            match.setDataLayerVirtualLanPriorityCodePoint(pcp, mask);
-            assertEquals(MATCH_LEN_VLAN_TCI_WITH_MASK, match.getIPv6MatchLen());
-            assertEquals(pcp, match.getDataLayerVirtualLanPriorityCodePoint());
-        }
-    }
-
-    /**
-     * Test case for setter methods for VLAN TCI field.
-     *
-     * This test case calls {@link V6Match#setDataLayerVirtualLan(short, short)}
-     * and {@link V6Match#setDataLayerVirtualLanPriorityCodePoint(byte, byte)}.
-     */
-    @Test
-    public void testSetVlanTCI() {
-        short vlans[] = {1, 10, 1000, 4095};
-        byte pcps[] = {1, 3, 7};
-        byte mask = 0;
-
-        // Call setDataLayerVirtualLan(short, short) firstly,
-        // and setDataLayerVirtualLanPriorityCodePoint(byte, byte) secondly,
-        for (short vlan: vlans) {
-            for (byte pcp: pcps) {
-                V6Match match = new V6Match();
-                match.setDataLayerVirtualLan(vlan, mask);
-                match.setDataLayerVirtualLanPriorityCodePoint(pcp, mask);
-                assertEquals(MATCH_LEN_VLAN_TCI, match.getIPv6MatchLen());
-                assertEquals(vlan, match.getDataLayerVirtualLan());
-                assertEquals(pcp,
-                             match.getDataLayerVirtualLanPriorityCodePoint());
-            }
-        }
-
-        // Call setDataLayerVirtualLanPriorityCodePoint(byte, byte) firstly,
-        // and setDataLayerVirtualLan(short, short) secondly.
-        for (short vlan: vlans) {
-            for (byte pcp: pcps) {
-                V6Match match = new V6Match();
-                match.setDataLayerVirtualLanPriorityCodePoint(pcp, mask);
-                match.setDataLayerVirtualLan(vlan, mask);
-                assertEquals(MATCH_LEN_VLAN_TCI, match.getIPv6MatchLen());
-                assertEquals(vlan, match.getDataLayerVirtualLan());
-                assertEquals(pcp,
-                             match.getDataLayerVirtualLanPriorityCodePoint());
-            }
-        }
-
-        // Test for setting OFP_VLAN_NONE when VLAN PCP is set.
-        for (byte pcp: pcps) {
-            V6Match match = new V6Match();
-            match.setDataLayerVirtualLanPriorityCodePoint(pcp, mask);
-            try {
-                match.setDataLayerVirtualLan(OFP_VLAN_NONE, mask);
-            } catch (IllegalStateException e) {
-                // Throwing exception was expected.
-            }
-        }
-
-        // Test for set VLAN PCP when OFP_VLAN_NONE is set to VLAN match.
-        for (byte pcp: pcps) {
-            V6Match match = new V6Match();
-            match.setDataLayerVirtualLan(OFP_VLAN_NONE, mask);
-            try {
-                match.setDataLayerVirtualLanPriorityCodePoint(pcp, mask);
-            } catch (IllegalStateException e) {
-                // Throwing exception was expected.
-            }
-        }
-    }
-
-    /**
-     * Test case for {@link V6Match#setInputPort(short, short)}.
-     */
-    @Test
-    public void testSetInputPort() {
-        short ports[] = {1, 10, 100, 1000};
-        for (short port: ports) {
-            V6Match match = new V6Match();
-            match.setInputPort(port, (short) 0);
-            assertEquals(MATCH_LEN_INPUT_PORT, match.getIPv6MatchLen());
-            assertEquals(port, match.getInputPort());
-        }
-    }
-}
diff --git a/opendaylight/adsal/protocol_plugins/stub/pom.xml b/opendaylight/adsal/protocol_plugins/stub/pom.xml
deleted file mode 100644 (file)
index 801368a..0000000
+++ /dev/null
@@ -1,60 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>protocol_plugins.stub</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-  </dependencies>
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Import-Package>org.opendaylight.controller.sal.packet,
-              org.opendaylight.controller.sal.action,
-              org.opendaylight.controller.sal.discovery,
-              org.opendaylight.controller.sal.topology,
-              org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.sal.flowprogrammer,
-              org.opendaylight.controller.sal.reader,
-              org.opendaylight.controller.sal.inventory,
-              org.opendaylight.controller.sal.match,
-              org.opendaylight.controller.sal.utils,
-              org.apache.commons.lang3.builder,
-              org.apache.commons.lang3.tuple, org.apache.felix.dm,
-              org.slf4j, org.eclipse.osgi.framework.console,
-              org.osgi.framework</Import-Package>
-            <Export-Package>org.opendaylight.controller.protocol_plugins.stub.internal</Export-Package>
-            <Bundle-Activator>org.opendaylight.controller.protocol_plugins.stub.internal.Activator</Bundle-Activator>
-          </instructions>
-          <manifestLocation>${project.basedir}/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/protocol_plugins/stub/src/main/java/org/opendaylight/controller/protocol_plugins/stub/internal/Activator.java b/opendaylight/adsal/protocol_plugins/stub/src/main/java/org/opendaylight/controller/protocol_plugins/stub/internal/Activator.java
deleted file mode 100644 (file)
index 843e60e..0000000
+++ /dev/null
@@ -1,180 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-
-
-
-package org.opendaylight.controller.protocol_plugins.stub.internal;
-
-import org.apache.felix.dm.Component;
-import org.opendaylight.controller.sal.core.ComponentActivatorAbstractBase;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.flowprogrammer.IPluginInFlowProgrammerService;
-import org.opendaylight.controller.sal.inventory.IPluginInInventoryService;
-import org.opendaylight.controller.sal.inventory.IPluginOutInventoryService;
-import org.opendaylight.controller.sal.reader.IPluginInReadService;
-import org.opendaylight.controller.sal.topology.IPluginInTopologyService;
-import org.opendaylight.controller.sal.topology.IPluginOutTopologyService;
-import org.opendaylight.controller.sal.utils.GlobalConstants;
-import org.opendaylight.controller.sal.utils.INodeConnectorFactory;
-import org.opendaylight.controller.sal.utils.INodeFactory;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import java.util.Dictionary;
-import java.util.Hashtable;
-
-/**
- * stub protocol plugin Activator
- *
- *
- */
-public class Activator extends ComponentActivatorAbstractBase {
-    protected static final Logger logger = LoggerFactory
-            .getLogger(Activator.class);
-
-    /**
-     * Function called when the activator starts just after some initializations
-     * are done by the ComponentActivatorAbstractBase.
-     *
-     */
-    @Override
-    public void init() {
-        Node.NodeIDType.registerIDType("STUB", Integer.class);
-        NodeConnector.NodeConnectorIDType.registerIDType("STUB", Integer.class, "STUB");
-    }
-
-    /**
-     * Function called when the activator stops just before the cleanup done by
-     * ComponentActivatorAbstractBase
-     *
-     */
-    @Override
-    public void destroy() {
-        Node.NodeIDType.unRegisterIDType("STUB");
-        NodeConnector.NodeConnectorIDType.unRegisterIDType("STUB");
-    }
-
-    /**
-     * Function that is used to communicate to dependency manager the list of
-     * known implementations for services inside a container
-     *
-     *
-     * @return An array containing all the CLASS objects that will be
-     *         instantiated in order to get an fully working implementation
-     *         Object
-     */
-    @Override
-    public Object[] getImplementations() {
-        Object[] res = { ReadService.class, InventoryService.class, TopologyServices.class };
-        return res;
-    }
-
-    /**
-     * Function that is called when configuration of the dependencies is
-     * required.
-     *
-     * @param c
-     *            dependency manager Component object, used for configuring the
-     *            dependencies exported and imported
-     * @param imp
-     *            Implementation class that is being configured, needed as long
-     *            as the same routine can configure multiple implementations
-     * @param containerName
-     *            The containerName being configured, this allow also optional
-     *            per-container different behavior if needed, usually should not
-     *            be the case though.
-     */
-    @Override
-    public void configureInstance(Component c, Object imp, String containerName) {
-        if (imp.equals(ReadService.class)) {
-            // export the service to be used by SAL
-            Dictionary<String, Object> props = new Hashtable<String, Object>();
-            // Set the protocolPluginType property which will be used
-            // by SAL
-            props.put(GlobalConstants.PROTOCOLPLUGINTYPE.toString(), "STUB");
-            c.setInterface(IPluginInReadService.class.getName(), props);
-        }
-
-        if (imp.equals(InventoryService.class)) {
-            // export the service to be used by SAL
-            Dictionary<String, Object> props = new Hashtable<String, Object>();
-            // Set the protocolPluginType property which will be used
-            // by SAL
-            props.put(GlobalConstants.PROTOCOLPLUGINTYPE.toString(), "STUB");
-            c.setInterface(IPluginInInventoryService.class.getName(), props);
-        }
-
-        if(imp.equals(TopologyServices.class)){
-            Dictionary<String, Object> props = new Hashtable<String, Object>();
-            props.put(GlobalConstants.PROTOCOLPLUGINTYPE.toString(), "STUB");
-            c.setInterface(IPluginInTopologyService.class.getName(), props);
-            c.add(createServiceDependency().setService(IPluginOutTopologyService.class, "")
-                    .setCallbacks("setPluginOutTopologyService", "unsetPluginOutTopologyService")
-                    .setRequired(true));
-
-        }
-
-    }
-
-    @Override
-    public Object[] getGlobalImplementations() {
-        Object[] res =
-                {
-                        FlowProgrammerService.class,
-                        StubNodeFactory.class,
-                        StubNodeConnectorFactory.class,
-                        InventoryService.class
-                };
-        return res;
-    }
-
-    @Override
-    public void configureGlobalInstance(Component c, Object imp){
-        if (imp.equals(FlowProgrammerService.class)) {
-            // export the service to be used by SAL
-            Dictionary<String, Object> props = new Hashtable<String, Object>();
-            // Set the protocolPluginType property which will be used
-            // by SAL
-            props.put(GlobalConstants.PROTOCOLPLUGINTYPE.toString(), "STUB");
-            c.setInterface(IPluginInFlowProgrammerService.class.getName(), props);
-        }
-        if (imp.equals(StubNodeFactory.class)) {
-            // export the service to be used by SAL
-            Dictionary<String, Object> props = new Hashtable<String, Object>();
-            // Set the protocolPluginType property which will be used
-            // by SAL
-            props.put(GlobalConstants.PROTOCOLPLUGINTYPE.toString(), "STUB");
-            props.put("protocolName", "STUB");
-            c.setInterface(INodeFactory.class.getName(), props);
-        }
-        if (imp.equals(StubNodeConnectorFactory.class)) {
-            // export the service to be used by SAL
-            Dictionary<String, Object> props = new Hashtable<String, Object>();
-            // Set the protocolPluginType property which will be used
-            // by SAL
-            props.put(GlobalConstants.PROTOCOLPLUGINTYPE.toString(), "STUB");
-            props.put("protocolName", "STUB");
-            c.setInterface(INodeConnectorFactory.class.getName(), props);
-        }
-        if (imp.equals(InventoryService.class)) {
-            // export the service to be used by SAL
-            Dictionary<String, Object> props = new Hashtable<String, Object>();
-            // Set the protocolPluginType property which will be used
-            // by SAL
-            props.put(GlobalConstants.PROTOCOLPLUGINTYPE.toString(), "STUB");
-            props.put("scope", "Global");
-            c.setInterface(IPluginInInventoryService.class.getName(), props);
-            c.add(createServiceDependency().setService(IPluginOutInventoryService.class, "(scope=Global)")
-                    .setCallbacks("setPluginOutInventoryServices", "unsetPluginOutInventoryServices")
-                    .setRequired(true));
-        }
-
-    }
-}
diff --git a/opendaylight/adsal/protocol_plugins/stub/src/main/java/org/opendaylight/controller/protocol_plugins/stub/internal/FlowProgrammerService.java b/opendaylight/adsal/protocol_plugins/stub/src/main/java/org/opendaylight/controller/protocol_plugins/stub/internal/FlowProgrammerService.java
deleted file mode 100644 (file)
index 3058297..0000000
+++ /dev/null
@@ -1,144 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugins.stub.internal;
-
-import org.opendaylight.controller.sal.flowprogrammer.Flow;
-import org.opendaylight.controller.sal.flowprogrammer.IPluginInFlowProgrammerService;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.sal.utils.StatusCode;
-
-
-
-/**
- * Represents the openflow plugin component in charge of programming the flows
- * the flow programming and relay them to functional modules above SAL.
- */
-public class FlowProgrammerService implements IPluginInFlowProgrammerService
-  {
-    void init() {
-    }
-
-    /**
-     * Function called by the dependency manager when at least one dependency
-     * become unsatisfied or when the component is shutting down because for
-     * example bundle is being stopped.
-     *
-     */
-    void destroy() {
-    }
-
-    /**
-     * Function called by dependency manager after "init ()" is called and after
-     * the services provided by the class are registered in the service registry
-     *
-     */
-    void start() {
-    }
-
-    /**
-     * Function called by the dependency manager before the services exported by
-     * the component are unregistered, this will be followed by a "destroy ()"
-     * calls
-     *
-     */
-    void stop() {
-    }
-
-
-    /**
-     * Synchronously add a flow to the network node
-     *
-     * @param node
-     * @param flow
-     */
-    public Status addFlow(Node node, Flow flow){
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    /**
-     * Synchronously modify existing flow on the switch
-     *
-     * @param node
-     * @param flow
-     */
-    public Status modifyFlow(Node node, Flow oldFlow, Flow newFlow){
-        return new Status(StatusCode.SUCCESS);
-    }
-    /**
-     * Synchronously remove the flow from the network node
-     *
-     * @param node
-     * @param flow
-     */
-    public Status removeFlow(Node node, Flow flow){
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    /**
-     * Asynchronously add a flow to the network node
-     *
-     * @param node
-     * @param flow
-     * @param rid
-     */
-    public Status addFlowAsync(Node node, Flow flow, long rid){
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    /**
-     * Asynchronously modify existing flow on the switch
-     *
-     * @param node
-     * @param flow
-     * @param rid
-     */
-    public Status modifyFlowAsync(Node node, Flow oldFlow, Flow newFlow, long rid){
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    /**
-     * Asynchronously remove the flow from the network node
-     *
-     * @param node
-     * @param flow
-     * @param rid
-     */
-    public Status removeFlowAsync(Node node, Flow flow, long rid){
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    /**
-     * Remove all flows present on the network node
-     *
-     * @param node
-     */
-    public Status removeAllFlows(Node node){
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    /**
-     * Send Barrier message synchronously. The caller will be blocked until the
-     * Barrier reply arrives.
-     *
-     * @param node
-     */
-    public Status syncSendBarrierMessage(Node node){
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    /**
-     * Send Barrier message asynchronously. The caller is not blocked.
-     *
-     * @param node
-     */
-    public Status asyncSendBarrierMessage(Node node){
-        return new Status(StatusCode.SUCCESS);
-    }
-  }
\ No newline at end of file
diff --git a/opendaylight/adsal/protocol_plugins/stub/src/main/java/org/opendaylight/controller/protocol_plugins/stub/internal/InventoryService.java b/opendaylight/adsal/protocol_plugins/stub/src/main/java/org/opendaylight/controller/protocol_plugins/stub/internal/InventoryService.java
deleted file mode 100644 (file)
index 365813b..0000000
+++ /dev/null
@@ -1,248 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.protocol_plugins.stub.internal;
-
-import java.util.HashMap;
-import java.util.HashSet;
-import java.util.Map;
-import java.util.Set;
-import java.util.concurrent.ConcurrentHashMap;
-import java.util.concurrent.ConcurrentMap;
-import java.util.concurrent.CopyOnWriteArraySet;
-
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-import org.opendaylight.controller.sal.core.Actions;
-import org.opendaylight.controller.sal.core.Bandwidth;
-import org.opendaylight.controller.sal.core.Buffers;
-import org.opendaylight.controller.sal.core.Capabilities;
-import org.opendaylight.controller.sal.core.Capabilities.CapabilitiesType;
-import org.opendaylight.controller.sal.core.ConstructionException;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.core.State;
-import org.opendaylight.controller.sal.core.Tables;
-import org.opendaylight.controller.sal.core.TimeStamp;
-import org.opendaylight.controller.sal.core.UpdateType;
-import org.opendaylight.controller.sal.inventory.IPluginInInventoryService;
-import org.opendaylight.controller.sal.inventory.IPluginOutInventoryService;
-
-/**
- * Stub Implementation for IPluginInReadService used by SAL
- *
- *
- */
-public class InventoryService implements IPluginInInventoryService {
-    private static final Logger logger = LoggerFactory
-            .getLogger(InventoryService.class);
-
-    private ConcurrentMap<Node, Map<String, Property>> nodeProps; // properties
-                                                                  // are
-                                                                  // maintained
-                                                                  // in global
-                                                                  // container
-                                                                  // only
-    private ConcurrentMap<NodeConnector, Map<String, Property>> nodeConnectorProps; // properties
-                                                                                    // are
-                                                                                    // maintained
-                                                                                    // in
-                                                                                    // global
-                                                                                    // container
-                                                                                    // only
-    private final Set<IPluginOutInventoryService> pluginOutInventoryServices =
-            new CopyOnWriteArraySet<IPluginOutInventoryService>();
-
-    public void setPluginOutInventoryServices(IPluginOutInventoryService service) {
-        logger.trace("Got a service set request {}", service);
-        if (this.pluginOutInventoryServices != null) {
-            this.pluginOutInventoryServices.add(service);
-        }
-    }
-
-    public void unsetPluginOutInventoryServices(IPluginOutInventoryService service) {
-        logger.trace("Got a service UNset request");
-        if (this.pluginOutInventoryServices != null) {
-            this.pluginOutInventoryServices.remove(service);
-        }
-    }
-
-    @Override
-    public Set<Node> getConfiguredNotConnectedNodes() {
-        // TODO
-        return null;
-    }
-
-    /**
-     * Function called by the dependency manager when all the required
-     * dependencies are satisfied
-     *
-     */
-    void init() {
-        nodeProps = new ConcurrentHashMap<Node, Map<String, Property>>();
-        nodeConnectorProps = new ConcurrentHashMap<NodeConnector, Map<String, Property>>();
-        Node.NodeIDType.registerIDType("STUB", Integer.class);
-        NodeConnector.NodeConnectorIDType.registerIDType("STUB", Integer.class,
-                "STUB");
-
-        setupNodeProps();
-        setupNodeConnectorProps();
-    }
-
-    private void setupNodeConnectorProps() {
-        Map<String, Property> ncPropMap = new HashMap<String, Property>();
-        Capabilities cap = new Capabilities(
-                CapabilitiesType.FLOW_STATS_CAPABILITY.getValue());
-        ncPropMap.put(Capabilities.CapabilitiesPropName, cap);
-        Bandwidth bw = new Bandwidth(Bandwidth.BW1Gbps);
-        ncPropMap.put(Bandwidth.BandwidthPropName, bw);
-        State st = new State(State.EDGE_UP);
-        ncPropMap.put(State.StatePropName, st);
-
-        // setup property map for all node connectors
-        NodeConnector nc;
-        Node node;
-        try {
-            node = new Node("STUB", new Integer(0xCAFE));
-            nc = new NodeConnector("STUB", 0xCAFE, node);
-        } catch (ConstructionException e) {
-            nc = null;
-            node = null;
-        }
-        nodeConnectorProps.put(nc, ncPropMap);
-
-        try {
-            node = new Node("STUB", 3366);
-            nc = new NodeConnector("STUB", 12, node);
-        } catch (ConstructionException e) {
-            nc = null;
-            node = null;
-        }
-        nodeConnectorProps.put(nc, ncPropMap);
-
-        try {
-            node = new Node("STUB", 4477);
-            nc = new NodeConnector("STUB", 34, node);
-        } catch (ConstructionException e) {
-            nc = null;
-            node = null;
-        }
-        nodeConnectorProps.put(nc, ncPropMap);
-
-    }
-
-    private void setupNodeProps() {
-        Map<String, Property> propMap = new HashMap<String, Property>();
-
-        Tables t = new Tables((byte) 1);
-        propMap.put(Tables.TablesPropName, t);
-        Capabilities c = new Capabilities((int) 3);
-        propMap.put(Capabilities.CapabilitiesPropName, c);
-        Actions a = new Actions((int) 2);
-        propMap.put(Actions.ActionsPropName, a);
-        Buffers b = new Buffers((int) 1);
-        propMap.put(Buffers.BuffersPropName, b);
-        Long connectedSinceTime = 100000L;
-        TimeStamp timeStamp = new TimeStamp(connectedSinceTime,
-                "connectedSince");
-        propMap.put(TimeStamp.TimeStampPropName, timeStamp);
-
-        // setup property map for all nodes
-        Node node;
-        try {
-            node = new Node("STUB", new Integer(0xCAFE));
-        } catch (ConstructionException e) {
-            node = null;
-        }
-
-        nodeProps.put(node, propMap);
-
-        try {
-            node = new Node("STUB", 3366);
-        } catch (ConstructionException e) {
-            node = null;
-        }
-        nodeProps.put(node, propMap);
-
-        try {
-            node = new Node("STUB", 4477);
-        } catch (ConstructionException e) {
-            node = null;
-        }
-        nodeProps.put(node, propMap);
-
-    }
-
-    /**
-     * Function called by the dependency manager when at least one dependency
-     * become unsatisfied or when the component is shutting down because for
-     * example bundle is being stopped.
-     *
-     */
-    void destroy() {
-    }
-
-    /**
-     * Function called by dependency manager after "init ()" is called and after
-     * the services provided by the class are registered in the service registry
-     *
-     */
-    void start() {
-    }
-
-    /**
-     * Method called when the plugin has exposed it's services, this will be
-     * used to publish the updates so connection manager can think the
-     * connection is local
-     */
-    void started() {
-        // update sal and discovery
-        for (IPluginOutInventoryService service : pluginOutInventoryServices) {
-            for (Node node : nodeProps.keySet()) {
-                Set<Property> props = new HashSet<Property>(nodeProps.get(node)
-                        .values());
-                service.updateNode(node, UpdateType.ADDED, props);
-                logger.trace("Adding Node {} with props {}", node, props);
-            }
-            for (NodeConnector nc : nodeConnectorProps.keySet()) {
-                Set<Property> props = new HashSet<Property>(nodeConnectorProps.get(nc)
-                        .values());
-                service.updateNodeConnector(nc, UpdateType.ADDED, props);
-                logger.trace("Adding NodeConnectors {} with props {}", nc, props);
-            }
-        }
-    }
-
-    /**
-     * Function called by the dependency manager before the services exported by
-     * the component are unregistered, this will be followed by a "destroy ()"
-     * calls
-     *
-     */
-    void stop() {
-        pluginOutInventoryServices.clear();
-    }
-
-    /**
-     * Retrieve nodes from openflow
-     */
-    @Override
-    public ConcurrentMap<Node, Map<String, Property>> getNodeProps() {
-        return nodeProps;
-    }
-
-    /**
-     * Retrieve nodeConnectors from openflow
-     */
-    @Override
-    public ConcurrentMap<NodeConnector, Map<String, Property>> getNodeConnectorProps(
-            Boolean refresh) {
-        return nodeConnectorProps;
-    }
-
-}
diff --git a/opendaylight/adsal/protocol_plugins/stub/src/main/java/org/opendaylight/controller/protocol_plugins/stub/internal/ReadService.java b/opendaylight/adsal/protocol_plugins/stub/src/main/java/org/opendaylight/controller/protocol_plugins/stub/internal/ReadService.java
deleted file mode 100644 (file)
index 0ff6083..0000000
+++ /dev/null
@@ -1,270 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.protocol_plugins.stub.internal;
-
-import java.net.InetAddress;
-import java.net.UnknownHostException;
-import java.util.ArrayList;
-import java.util.List;
-
-import org.opendaylight.controller.sal.action.Action;
-import org.opendaylight.controller.sal.action.Controller;
-import org.opendaylight.controller.sal.action.Drop;
-import org.opendaylight.controller.sal.action.Flood;
-import org.opendaylight.controller.sal.action.FloodAll;
-import org.opendaylight.controller.sal.action.HwPath;
-import org.opendaylight.controller.sal.action.Loopback;
-import org.opendaylight.controller.sal.action.Output;
-import org.opendaylight.controller.sal.action.PopVlan;
-import org.opendaylight.controller.sal.action.PushVlan;
-import org.opendaylight.controller.sal.action.SetDlDst;
-import org.opendaylight.controller.sal.action.SetDlSrc;
-import org.opendaylight.controller.sal.action.SetDlType;
-import org.opendaylight.controller.sal.action.SetNwDst;
-import org.opendaylight.controller.sal.action.SetNwSrc;
-import org.opendaylight.controller.sal.action.SetNwTos;
-import org.opendaylight.controller.sal.action.SetTpDst;
-import org.opendaylight.controller.sal.action.SetTpSrc;
-import org.opendaylight.controller.sal.action.SetVlanCfi;
-import org.opendaylight.controller.sal.action.SetVlanId;
-import org.opendaylight.controller.sal.action.SetVlanPcp;
-import org.opendaylight.controller.sal.action.SwPath;
-import org.opendaylight.controller.sal.core.ConstructionException;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.NodeTable;
-import org.opendaylight.controller.sal.flowprogrammer.Flow;
-import org.opendaylight.controller.sal.match.Match;
-import org.opendaylight.controller.sal.match.MatchType;
-import org.opendaylight.controller.sal.reader.FlowOnNode;
-import org.opendaylight.controller.sal.reader.IPluginInReadService;
-import org.opendaylight.controller.sal.reader.NodeConnectorStatistics;
-import org.opendaylight.controller.sal.reader.NodeDescription;
-import org.opendaylight.controller.sal.reader.NodeTableStatistics;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-/**
- * Stub Implementation for IPluginInReadService used by SAL
- *
- *
- */
-public class ReadService implements IPluginInReadService {
-    private static final Logger logger = LoggerFactory
-            .getLogger(ReadService.class);
-
-    /**
-     * Function called by the dependency manager when all the required
-     * dependencies are satisfied
-     *
-     */
-    void init() {
-    }
-
-    /**
-     * Function called by the dependency manager when at least one dependency
-     * become unsatisfied or when the component is shutting down because for
-     * example bundle is being stopped.
-     *
-     */
-    void destroy() {
-    }
-
-    /**
-     * Function called by dependency manager after "init ()" is called and after
-     * the services provided by the class are registered in the service registry
-     *
-     */
-    void start() {
-    }
-
-    /**
-     * Function called by the dependency manager before the services exported by
-     * the component are unregistered, this will be followed by a "destroy ()"
-     * calls
-     *
-     */
-    void stop() {
-    }
-
-    @Override
-    public FlowOnNode readFlow(Node node, Flow flow, boolean cached) {
-        FlowOnNode fn1 = new FlowOnNode(flow);
-        fn1.setByteCount(100);
-        fn1.setDurationNanoseconds(400);
-        fn1.setDurationSeconds(40);
-        fn1.setTableId((byte) 0x1);
-        fn1.setPacketCount(200);
-        return fn1;
-    }
-
-    @Override
-    public List<FlowOnNode> readAllFlow(Node node, boolean cached) {
-
-        ArrayList<FlowOnNode> list = new ArrayList<FlowOnNode>();
-        ArrayList<Action> actionList = new ArrayList<Action>();
-        actionList.add(new Drop()); //IT assumes this is first element
-        actionList.add(new Loopback());
-        actionList.add(new Flood());
-        actionList.add(new FloodAll());
-        actionList.add(new Controller());
-        actionList.add(new SwPath());
-        actionList.add(new HwPath());
-        try {
-            actionList.add(new Output(new NodeConnector("STUB", 0xCAFE, node)));
-        } catch (ConstructionException e) {
-
-        }
-        byte dst[] = { (byte) 1, (byte) 2, (byte) 3, (byte) 4, (byte) 5 };
-        byte src[] = { (byte) 5, (byte) 4, (byte) 3, (byte) 2, (byte) 1 };
-        actionList.add(new SetDlSrc(src));
-        actionList.add(new SetDlDst(dst));
-        actionList.add(new SetDlType(10));
-
-        actionList.add(new SetVlanId(2));
-        actionList.add(new SetVlanPcp(3));
-        actionList.add(new SetVlanCfi(1));
-
-        actionList.add(new PopVlan());
-        actionList.add(new PushVlan(0x8100, 1, 1, 1234));
-
-        try {
-            actionList.add(new SetNwSrc(InetAddress.getByName("2.2.2.2")));
-            actionList.add(new SetNwDst(InetAddress.getByName("1.1.1.1")));
-        } catch (UnknownHostException e) {
-
-        }
-        actionList.add(new SetNwTos(0x10));
-        actionList.add(new SetTpSrc(4201));
-        actionList.add(new SetTpDst(8080));
-
-        short priority = 3500; //IT assumes this value
-        for (Action a : actionList) {
-            Flow flow = new Flow();
-            Match match = new Match();
-            try {
-                match.setField(MatchType.NW_DST,
-                        InetAddress.getByName("1.1.1.1"));
-            } catch (UnknownHostException e) {
-
-            }
-            flow.setMatch(match);
-            List<Action> actions = new ArrayList<Action>();
-            actions.add(a);
-            flow.setActions(actions);
-            flow.setPriority(priority++);
-            flow.setIdleTimeout((short) 1000);
-            flow.setHardTimeout((short) 2000);
-            flow.setId(12345);
-
-            FlowOnNode fn1 = new FlowOnNode(flow);
-            fn1.setByteCount(100);
-            fn1.setDurationNanoseconds(400);
-            fn1.setDurationSeconds(40);
-            fn1.setTableId((byte) 0x1);
-            fn1.setPacketCount(200);
-
-            list.add(fn1);
-        }
-        return list;
-    }
-
-    @Override
-    public NodeDescription readDescription(Node node, boolean cached) {
-        NodeDescription desc = new NodeDescription();
-        desc.setDescription("This is a sample node description");
-        desc.setHardware("stub hardware");
-        desc.setSoftware("stub software");
-        desc.setSerialNumber("123");
-        desc.setManufacturer("opendaylight");
-        return desc;
-    }
-
-    @Override
-    public NodeConnectorStatistics readNodeConnector(NodeConnector connector,
-            boolean cached) {
-        NodeConnectorStatistics stats = new NodeConnectorStatistics();
-        stats.setNodeConnector(connector);
-        stats.setCollisionCount(4);
-        stats.setReceiveByteCount(1000);
-        stats.setReceiveCRCErrorCount(1);
-        stats.setReceiveDropCount(2);
-        stats.setReceiveErrorCount(3);
-        stats.setReceiveFrameErrorCount(5);
-        stats.setReceiveOverRunErrorCount(6);
-        stats.setReceivePacketCount(250);
-        stats.setTransmitByteCount(5000);
-        stats.setTransmitDropCount(50);
-        stats.setTransmitErrorCount(10);
-        stats.setTransmitPacketCount(500);
-
-        return stats;
-    }
-
-    @Override
-    public List<NodeConnectorStatistics> readAllNodeConnector(Node node,
-            boolean cached) {
-        NodeConnectorStatistics stats = new NodeConnectorStatistics();
-        try {
-            NodeConnector nc = new NodeConnector("STUB", 0xCAFE, node);
-            stats.setNodeConnector(nc);
-        } catch (ConstructionException e) {
-            // couldn't create nodeconnector.
-        }
-        stats.setCollisionCount(4);
-        stats.setReceiveByteCount(1000);
-        stats.setReceiveCRCErrorCount(1);
-        stats.setReceiveDropCount(2);
-        stats.setReceiveErrorCount(3);
-        stats.setReceiveFrameErrorCount(5);
-        stats.setReceiveOverRunErrorCount(6);
-        stats.setReceivePacketCount(250);
-        stats.setTransmitByteCount(5000);
-        stats.setTransmitDropCount(50);
-        stats.setTransmitErrorCount(10);
-        stats.setTransmitPacketCount(500);
-
-        List<NodeConnectorStatistics> result = new ArrayList<NodeConnectorStatistics>();
-        result.add(stats);
-        return result;
-    }
-
-    @Override
-    public long getTransmitRate(NodeConnector connector) {
-        return 100;
-    }
-
-    @Override
-    public NodeTableStatistics readNodeTable(NodeTable table, boolean b) {
-        NodeTableStatistics stats = new NodeTableStatistics();
-        stats.setNodeTable(table);
-        stats.setActiveCount(4);
-        stats.setLookupCount(4);
-        stats.setMatchedCount(4);
-
-        return stats;
-    }
-
-    @Override
-    public List<NodeTableStatistics> readAllNodeTable(Node node, boolean cached) {
-        NodeTableStatistics stats = new NodeTableStatistics();
-        try {
-            NodeTable nt = new NodeTable(NodeTable.NodeTableIDType.OPENFLOW, Byte.valueOf("10"), node);
-            stats.setNodeTable(nt);
-        } catch (ConstructionException e) {
-            // couldn't create nodetable.
-        }
-
-        stats.setActiveCount(4);
-        stats.setLookupCount(4);
-        stats.setMatchedCount(4);
-
-        List<NodeTableStatistics> result = new ArrayList<NodeTableStatistics>();
-        result.add(stats);
-        return result;
-    }
-}
diff --git a/opendaylight/adsal/protocol_plugins/stub/src/main/java/org/opendaylight/controller/protocol_plugins/stub/internal/StubNodeConnectorFactory.java b/opendaylight/adsal/protocol_plugins/stub/src/main/java/org/opendaylight/controller/protocol_plugins/stub/internal/StubNodeConnectorFactory.java
deleted file mode 100644 (file)
index 743c4a5..0000000
+++ /dev/null
@@ -1,56 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.protocol_plugins.stub.internal;
-
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.utils.INodeConnectorFactory;
-import org.opendaylight.controller.sal.core.Node;
-
-public class StubNodeConnectorFactory implements INodeConnectorFactory
-    {
-      void init() {
-      }
-
-      /**
-       * Function called by the dependency manager when at least one dependency
-       * become unsatisfied or when the component is shutting down because for
-       * example bundle is being stopped.
-       *
-       */
-      void destroy() {
-      }
-
-      /**
-       * Function called by dependency manager after "init ()" is called and after
-       * the services provided by the class are registered in the service registry
-       *
-       */
-      void start() {
-      }
-
-      /**
-       * Function called by the dependency manager before the services exported by
-       * the component are unregistered, this will be followed by a "destroy ()"
-       * calls
-       *
-       */
-      void stop() {
-      }
-
-      public NodeConnector fromStringNoNode(String typeStr, String IDStr,
-              Node n){
-          if(typeStr.equals("STUB")){
-              try {
-                  return new NodeConnector(typeStr, Integer.parseInt(IDStr), n);
-              } catch (Exception ex) {
-                  return null;
-              }
-          }
-          return null;
-      }
-}
diff --git a/opendaylight/adsal/protocol_plugins/stub/src/main/java/org/opendaylight/controller/protocol_plugins/stub/internal/StubNodeFactory.java b/opendaylight/adsal/protocol_plugins/stub/src/main/java/org/opendaylight/controller/protocol_plugins/stub/internal/StubNodeFactory.java
deleted file mode 100644 (file)
index 439519f..0000000
+++ /dev/null
@@ -1,54 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.protocol_plugins.stub.internal;
-
-import org.opendaylight.controller.sal.core.ConstructionException;
-import org.opendaylight.controller.sal.utils.INodeFactory;
-import org.opendaylight.controller.sal.core.Node;
-
-public class StubNodeFactory implements INodeFactory {
-    void init() {
-    }
-
-    /**
-     * Function called by the dependency manager when at least one dependency
-     * become unsatisfied or when the component is shutting down because for
-     * example bundle is being stopped.
-     *
-     */
-    void destroy() {
-    }
-
-    /**
-     * Function called by dependency manager after "init ()" is called and after
-     * the services provided by the class are registered in the service registry
-     *
-     */
-    void start() {
-    }
-
-    /**
-     * Function called by the dependency manager before the services exported by
-     * the component are unregistered, this will be followed by a "destroy ()"
-     * calls
-     *
-     */
-    void stop() {
-    }
-
-    public Node fromString(String nodeType, String nodeId){
-        if(nodeType.equals("STUB")) {
-            try {
-                return new Node("STUB", Integer.parseInt(nodeId));
-            } catch(ConstructionException e) {
-                return null;
-            }
-        }
-        return null;
-    }
-}
diff --git a/opendaylight/adsal/protocol_plugins/stub/src/main/java/org/opendaylight/controller/protocol_plugins/stub/internal/TopologyServices.java b/opendaylight/adsal/protocol_plugins/stub/src/main/java/org/opendaylight/controller/protocol_plugins/stub/internal/TopologyServices.java
deleted file mode 100644 (file)
index 104df0a..0000000
+++ /dev/null
@@ -1,48 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.protocol_plugins.stub.internal;
-
-import org.opendaylight.controller.sal.core.Edge;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.core.UpdateType;
-import org.opendaylight.controller.sal.topology.IPluginInTopologyService;
-import org.opendaylight.controller.sal.topology.IPluginOutTopologyService;
-import org.opendaylight.controller.sal.topology.TopoEdgeUpdate;
-
-import java.util.ArrayList;
-import java.util.List;
-import java.util.Set;
-
-public class TopologyServices implements IPluginInTopologyService {
-    private IPluginOutTopologyService pluginOutTopologyService;
-
-
-    @Override
-    public void sollicitRefresh() {
-    }
-
-    public void setPluginOutTopologyService(IPluginOutTopologyService pluginOutTopologyService){
-        this.pluginOutTopologyService = pluginOutTopologyService;
-    }
-
-    public void unsetPluginOutTopologyService(IPluginOutTopologyService pluginOutTopologyService){
-        this.pluginOutTopologyService = null;
-    }
-
-
-    public void addEdge(Edge edge, Set<Property> properties, UpdateType updateType){
-
-        List<TopoEdgeUpdate > topoedgeupdateList = new ArrayList<TopoEdgeUpdate>();
-
-        topoedgeupdateList.add(new TopoEdgeUpdate(edge, properties, updateType));
-
-        this.pluginOutTopologyService.edgeUpdate(topoedgeupdateList);
-
-    }
-}
diff --git a/opendaylight/adsal/routing/dijkstra_implementation/pom.xml b/opendaylight/adsal/routing/dijkstra_implementation/pom.xml
deleted file mode 100644 (file)
index 8df6db5..0000000
+++ /dev/null
@@ -1,83 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>routing.dijkstra_implementation</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>org.apache.felix.gogo.runtime</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>clustering.services</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>switchmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>topologymanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller.thirdparty</groupId>
-      <artifactId>net.sf.jung2</artifactId>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Import-Package>org.slf4j,
-              org.opendaylight.controller.sal.routing,
-              org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.sal.topology,
-              org.opendaylight.controller.sal.utils,
-              org.opendaylight.controller.sal.reader,
-              org.opendaylight.controller.clustering.services,
-              org.apache.commons.collections15,
-              org.opendaylight.controller.switchmanager,
-              org.opendaylight.controller.topologymanager,
-              edu.uci.ics.jung.graph,
-              edu.uci.ics.jung.algorithms.shortestpath,
-              edu.uci.ics.jung.graph.util,
-              org.apache.felix.dm,
-              org.osgi.framework,
-              org.apache.felix.service.command,
-              org.junit;resolution:=optional</Import-Package>
-            <Bundle-Activator>org.opendaylight.controller.routing.dijkstra_implementation.internal.Activator</Bundle-Activator>
-          </instructions>
-          <manifestLocation>${project.basedir}/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/routing/dijkstra_implementation/src/main/java/org/opendaylight/controller/routing/dijkstra_implementation/internal/Activator.java b/opendaylight/adsal/routing/dijkstra_implementation/src/main/java/org/opendaylight/controller/routing/dijkstra_implementation/internal/Activator.java
deleted file mode 100644 (file)
index 7d7833b..0000000
+++ /dev/null
@@ -1,93 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.routing.dijkstra_implementation.internal;
-
-import java.util.Dictionary;
-import java.util.Hashtable;
-
-import org.apache.felix.dm.Component;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-import org.opendaylight.controller.sal.core.ComponentActivatorAbstractBase;
-import org.opendaylight.controller.sal.routing.IListenRoutingUpdates;
-import org.opendaylight.controller.sal.routing.IRouting;
-import org.opendaylight.controller.switchmanager.ISwitchManager;
-import org.opendaylight.controller.topologymanager.ITopologyManager;
-import org.opendaylight.controller.topologymanager.ITopologyManagerClusterWideAware;
-import org.opendaylight.controller.clustering.services.IClusterContainerServices;
-
-public class Activator extends ComponentActivatorAbstractBase {
-    protected static final Logger logger = LoggerFactory
-            .getLogger(Activator.class);
-
-    /**
-     * Function that is used to communicate to dependency manager the
-     * list of known implementations for services inside a container
-     *
-     *
-     * @return An array containing all the CLASS objects that will be
-     * instantiated in order to get an fully working implementation
-     * Object
-     */
-    @Override
-    public Object[] getImplementations() {
-        Object[] res = { DijkstraImplementation.class };
-        return res;
-    }
-
-    /**
-     * Function that is called when configuration of the dependencies
-     * is required.
-     *
-     * @param c dependency manager Component object, used for
-     * configuring the dependencies exported and imported
-     * @param imp Implementation class that is being configured,
-     * needed as long as the same routine can configure multiple
-     * implementations
-     * @param containerName The containerName being configured, this allow
-     * also optional per-container different behavior if needed, usually
-     * should not be the case though.
-     */
-    @Override
-    public void configureInstance(final Component c, final Object imp, final String containerName) {
-        if (imp.equals(DijkstraImplementation.class)) {
-            // export the service
-            final Dictionary<String, Object> props = new Hashtable<String, Object>();
-            props.put("topoListenerName", "routing.Dijkstra");
-
-            c.setInterface(new String[] { ITopologyManagerClusterWideAware.class.getName(), IRouting.class.getName() },
-                    props);
-
-            // Now lets add a service dependency to make sure the
-            // provider of service exists
-            c.add(createContainerServiceDependency(containerName).setService(IListenRoutingUpdates.class)
-                    .setCallbacks("setListenRoutingUpdates", "unsetListenRoutingUpdates")
-                    .setRequired(false));
-
-            c.add(createContainerServiceDependency(containerName).setService(ISwitchManager.class)
-                    .setCallbacks("setSwitchManager", "unsetSwitchManager")
-                    .setRequired(true));
-
-            c.add(createContainerServiceDependency(containerName).setService(ITopologyManager.class)
-                    .setCallbacks("setTopologyManager", "unsetTopologyManager")
-                    .setRequired(true));
-
-            c.add(createContainerServiceDependency(containerName).setService(IClusterContainerServices.class)
-                    .setCallbacks("setClusterContainerService", "unsetClusterContainerService")
-                    .setRequired(true));
-        }
-    }
-
-    @Override
-    protected Object[] getGlobalImplementations() {
-        final Object[] res = { DijkstraImplementationCLI.class };
-        return res;
-    }
-}
diff --git a/opendaylight/adsal/routing/dijkstra_implementation/src/main/java/org/opendaylight/controller/routing/dijkstra_implementation/internal/DijkstraImplementation.java b/opendaylight/adsal/routing/dijkstra_implementation/src/main/java/org/opendaylight/controller/routing/dijkstra_implementation/internal/DijkstraImplementation.java
deleted file mode 100644 (file)
index b68cc0c..0000000
+++ /dev/null
@@ -1,503 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * @file   DijkstraImplementation.java
- *
- *
- * @brief  Implementation of a routing engine using
- * dijkstra. Implementation of dijkstra come from Jung2 library
- *
- */
-package org.opendaylight.controller.routing.dijkstra_implementation.internal;
-
-import org.opendaylight.controller.clustering.services.IClusterContainerServices;
-import org.opendaylight.controller.sal.core.Bandwidth;
-import org.opendaylight.controller.sal.core.ConstructionException;
-import org.opendaylight.controller.sal.core.Edge;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.Path;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.core.UpdateType;
-import org.opendaylight.controller.sal.routing.IListenRoutingUpdates;
-import org.opendaylight.controller.sal.routing.IRouting;
-import org.opendaylight.controller.sal.topology.TopoEdgeUpdate;
-import org.opendaylight.controller.switchmanager.ISwitchManager;
-import org.opendaylight.controller.topologymanager.ITopologyManager;
-import org.opendaylight.controller.topologymanager.ITopologyManagerClusterWideAware;
-
-import edu.uci.ics.jung.algorithms.shortestpath.DijkstraShortestPath;
-import edu.uci.ics.jung.graph.Graph;
-import edu.uci.ics.jung.graph.SparseMultigraph;
-import edu.uci.ics.jung.graph.util.EdgeType;
-
-import java.util.HashSet;
-import java.util.Iterator;
-import java.util.List;
-import java.util.ArrayList;
-import java.util.Set;
-import java.util.Map;
-import java.util.concurrent.ConcurrentHashMap;
-import java.util.concurrent.ConcurrentMap;
-
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-import org.apache.commons.collections15.Transformer;
-
-@SuppressWarnings("rawtypes")
-public class DijkstraImplementation implements IRouting, ITopologyManagerClusterWideAware {
-    private static Logger log = LoggerFactory.getLogger(DijkstraImplementation.class);
-    private ConcurrentMap<Short, Graph<Node, Edge>> topologyBWAware;
-    private ConcurrentMap<Short, DijkstraShortestPath<Node, Edge>> sptBWAware;
-    DijkstraShortestPath<Node, Edge> mtp; // Max Throughput Path
-    private Set<IListenRoutingUpdates> routingAware;
-    private ISwitchManager switchManager;
-    private ITopologyManager topologyManager;
-    private static final long DEFAULT_LINK_SPEED = Bandwidth.BW1Gbps;
-    private IClusterContainerServices clusterContainerService;
-
-    public void setListenRoutingUpdates(final IListenRoutingUpdates i) {
-        if (this.routingAware == null) {
-            this.routingAware = new HashSet<IListenRoutingUpdates>();
-        }
-        if (this.routingAware != null) {
-            log.debug("Adding routingAware listener: {}", i);
-            this.routingAware.add(i);
-        }
-    }
-
-    public void unsetListenRoutingUpdates(final IListenRoutingUpdates i) {
-        if (this.routingAware == null) {
-            return;
-        }
-        log.debug("Removing routingAware listener");
-        this.routingAware.remove(i);
-        if (this.routingAware.isEmpty()) {
-            // We don't have any listener lets dereference
-            this.routingAware = null;
-        }
-    }
-
-    @Override
-    public synchronized void initMaxThroughput(
-            final Map<Edge, Number> EdgeWeightMap) {
-        if (mtp != null) {
-            log.error("Max Throughput Dijkstra is already enabled!");
-            return;
-        }
-        Transformer<Edge, ? extends Number> mtTransformer = null;
-        if (EdgeWeightMap == null) {
-            mtTransformer = new Transformer<Edge, Double>() {
-                @Override
-                public Double transform(Edge e) {
-                    if (switchManager == null) {
-                        log.error("switchManager is null");
-                        return (double) -1;
-                    }
-                    NodeConnector srcNC = e.getTailNodeConnector();
-                    NodeConnector dstNC = e.getHeadNodeConnector();
-                    if ((srcNC == null) || (dstNC == null)) {
-                        log.error("srcNC:{} or dstNC:{} is null", srcNC, dstNC);
-                        return (double) -1;
-                    }
-                    Bandwidth bwSrc = (Bandwidth) switchManager.getNodeConnectorProp(srcNC,
-                            Bandwidth.BandwidthPropName);
-                    Bandwidth bwDst = (Bandwidth) switchManager.getNodeConnectorProp(dstNC,
-                            Bandwidth.BandwidthPropName);
-
-                    long srcLinkSpeed = 0, dstLinkSpeed = 0;
-                    if ((bwSrc == null) || ((srcLinkSpeed = bwSrc.getValue()) == 0)) {
-                        log.debug("srcNC: {} - Setting srcLinkSpeed to Default!", srcNC);
-                        srcLinkSpeed = DEFAULT_LINK_SPEED;
-                    }
-
-                    if ((bwDst == null) || ((dstLinkSpeed = bwDst.getValue()) == 0)) {
-                        log.debug("dstNC: {} - Setting dstLinkSpeed to Default!", dstNC);
-                        dstLinkSpeed = DEFAULT_LINK_SPEED;
-                    }
-
-                    // TODO: revisit the logic below with the real use case in
-                    // mind
-                    // For now we assume the throughput to be the speed of the
-                    // link itself
-                    // this kind of logic require information that should be
-                    // polled by statistic manager and are not yet available,
-                    // also this service at the moment is not used, so to be
-                    // revisited later on
-                    long avlSrcThruPut = srcLinkSpeed;
-                    long avlDstThruPut = dstLinkSpeed;
-
-                    // Use lower of the 2 available throughput as the available
-                    // throughput
-                    long avlThruPut = avlSrcThruPut < avlDstThruPut ? avlSrcThruPut : avlDstThruPut;
-
-                    if (avlThruPut <= 0) {
-                        log.debug("Edge {}: Available Throughput {} <= 0!", e, avlThruPut);
-                        return (double) -1;
-                    }
-                    return (double) (Bandwidth.BW1Pbps / avlThruPut);
-                }
-            };
-        } else {
-            mtTransformer = new Transformer<Edge, Number>() {
-                @Override
-                public Number transform(Edge e) {
-                    return EdgeWeightMap.get(e);
-                }
-            };
-        }
-        Short baseBW = Short.valueOf((short) 0);
-        // Initialize mtp also using the default topo
-        Graph<Node, Edge> g = this.topologyBWAware.get(baseBW);
-        if (g == null) {
-            log.error("Default Topology Graph is null");
-            return;
-        }
-        mtp = new DijkstraShortestPath<Node, Edge>(g, mtTransformer);
-    }
-
-    @Override
-    public Path getRoute(final Node src, final Node dst) {
-        if ((src == null) || (dst == null)) {
-            return null;
-        }
-        return getRoute(src, dst, (short) 0);
-    }
-
-    @Override
-    public synchronized Path getMaxThroughputRoute(Node src, Node dst) {
-        if (mtp == null) {
-            log.error("Max Throughput Path Calculation Uninitialized!");
-            return null;
-        }
-
-        List<Edge> path;
-        try {
-            path = mtp.getMaxThroughputPath(src, dst);
-        } catch (IllegalArgumentException ie) {
-            log.debug("A vertex is yet not known between {} {}", src, dst);
-            return null;
-        }
-        Path res;
-        try {
-            res = new Path(path);
-        } catch (ConstructionException e) {
-            log.debug("A vertex is yet not known between {} {}", src, dst);
-            return null;
-        }
-        return res;
-    }
-
-    @Override
-    public synchronized Path getRoute(final Node src, final Node dst, final Short Bw) {
-        DijkstraShortestPath<Node, Edge> spt = this.sptBWAware.get(Bw);
-        if (spt == null) {
-            return null;
-        }
-        List<Edge> path;
-        try {
-            path = spt.getPath(src, dst);
-        } catch (IllegalArgumentException ie) {
-            log.debug("A vertex is yet not known between {} {}", src, dst);
-            return null;
-        }
-        Path res;
-        try {
-            res = new Path(path);
-        } catch (ConstructionException e) {
-            log.debug("A vertex is yet not known between {} {}", src, dst);
-            return null;
-        }
-        return res;
-    }
-
-    @Override
-    public synchronized void clear() {
-        DijkstraShortestPath<Node, Edge> spt;
-        for (Short bw : this.sptBWAware.keySet()) {
-            spt = this.sptBWAware.get(bw);
-            if (spt != null) {
-                spt.reset();
-            }
-        }
-        clearMaxThroughput();
-    }
-
-    @Override
-    public synchronized void clearMaxThroughput() {
-        if (mtp != null) {
-            mtp.reset(); // reset max throughput path
-        }
-    }
-
-    @SuppressWarnings({ "unchecked" })
-    private synchronized boolean updateTopo(Edge edge, Short bw, UpdateType type) {
-        Graph<Node, Edge> topo = this.topologyBWAware.get(bw);
-        DijkstraShortestPath<Node, Edge> spt = this.sptBWAware.get(bw);
-        boolean edgePresentInGraph = false;
-        Short baseBW = Short.valueOf((short) 0);
-
-        if (topo == null) {
-            // Create topology for this BW
-            Graph<Node, Edge> g = new SparseMultigraph();
-            this.topologyBWAware.put(bw, g);
-            topo = this.topologyBWAware.get(bw);
-            this.sptBWAware.put(bw, new DijkstraShortestPath(g));
-            spt = this.sptBWAware.get(bw);
-        }
-
-        if (topo != null) {
-            NodeConnector src = edge.getTailNodeConnector();
-            NodeConnector dst = edge.getHeadNodeConnector();
-            if (spt == null) {
-                spt = new DijkstraShortestPath(topo);
-                this.sptBWAware.put(bw, spt);
-            }
-
-            switch (type) {
-            case ADDED:
-                // Make sure the vertex are there before adding the edge
-                topo.addVertex(src.getNode());
-                topo.addVertex(dst.getNode());
-                // Add the link between
-                edgePresentInGraph = topo.containsEdge(edge);
-                if (edgePresentInGraph == false) {
-                    try {
-                        topo.addEdge(new Edge(src, dst), src.getNode(), dst.getNode(), EdgeType.DIRECTED);
-                    } catch (final ConstructionException e) {
-                        log.error("", e);
-                        return edgePresentInGraph;
-                    }
-                }
-            case CHANGED:
-                // Mainly raised only on properties update, so not really useful
-                // in this case
-                break;
-            case REMOVED:
-                // Remove the edge
-                try {
-                    topo.removeEdge(new Edge(src, dst));
-                } catch (final ConstructionException e) {
-                    log.error("", e);
-                    return edgePresentInGraph;
-                }
-
-                // If the src and dst vertex don't have incoming or
-                // outgoing links we can get ride of them
-                if (topo.containsVertex(src.getNode()) && (topo.inDegree(src.getNode()) == 0)
-                        && (topo.outDegree(src.getNode()) == 0)) {
-                    log.debug("Removing vertex {}", src);
-                    topo.removeVertex(src.getNode());
-                }
-
-                if (topo.containsVertex(dst.getNode()) && (topo.inDegree(dst.getNode()) == 0)
-                        && (topo.outDegree(dst.getNode()) == 0)) {
-                    log.debug("Removing vertex {}", dst);
-                    topo.removeVertex(dst.getNode());
-                }
-                break;
-            }
-            spt.reset();
-            if (bw.equals(baseBW)) {
-                clearMaxThroughput();
-            }
-        } else {
-            log.error("Cannot find topology for BW {} this is unexpected!", bw);
-        }
-        return edgePresentInGraph;
-    }
-
-    private boolean edgeUpdate(Edge e, UpdateType type, Set<Property> props, boolean local) {
-        String srcType = null;
-        String dstType = null;
-
-        log.trace("Got an edgeUpdate: {} props: {} update type: {} local: {}", new Object[] { e, props, type, local });
-
-        if ((e == null) || (type == null)) {
-            log.error("Edge or Update type are null!");
-            return false;
-        } else {
-            srcType = e.getTailNodeConnector().getType();
-            dstType = e.getHeadNodeConnector().getType();
-
-            if (srcType.equals(NodeConnector.NodeConnectorIDType.PRODUCTION)) {
-                log.debug("Skip updates for {}", e);
-                return false;
-            }
-
-            if (dstType.equals(NodeConnector.NodeConnectorIDType.PRODUCTION)) {
-                log.debug("Skip updates for {}", e);
-                return false;
-            }
-        }
-
-        Bandwidth bw = new Bandwidth(0);
-        boolean newEdge = false;
-        if (props != null) {
-            props.remove(bw);
-        }
-
-        Short baseBW = Short.valueOf((short) 0);
-        // Update base topo
-        newEdge = !updateTopo(e, baseBW, type);
-        if (newEdge == true) {
-            if (bw.getValue() != baseBW) {
-                // Update BW topo
-                updateTopo(e, (short) bw.getValue(), type);
-            }
-        }
-        return newEdge;
-    }
-
-    @Override
-    public void edgeUpdate(List<TopoEdgeUpdate> topoedgeupdateList) {
-        log.trace("Start of a Bulk EdgeUpdate with " + topoedgeupdateList.size() + " elements");
-        boolean callListeners = false;
-        for (int i = 0; i < topoedgeupdateList.size(); i++) {
-            Edge e = topoedgeupdateList.get(i).getEdge();
-            Set<Property> p = topoedgeupdateList.get(i)
-                    .getProperty();
-            UpdateType type = topoedgeupdateList.get(i)
-                    .getUpdateType();
-            boolean isLocal = topoedgeupdateList.get(i)
-                    .isLocal();
-            if ((edgeUpdate(e, type, p, isLocal)) && (!callListeners)) {
-                callListeners = true;
-            }
-        }
-
-        // The routing listeners should only be called on the coordinator, to
-        // avoid multiple controller cluster nodes to actually do the
-        // recalculation when only one need to react
-        boolean amICoordinator = true;
-        if (this.clusterContainerService != null) {
-            amICoordinator = this.clusterContainerService.amICoordinator();
-        }
-        if ((callListeners) && (this.routingAware != null) && amICoordinator) {
-            log.trace("Calling the routing listeners");
-            for (IListenRoutingUpdates ra : this.routingAware) {
-                try {
-                    ra.recalculateDone();
-                } catch (Exception ex) {
-                    log.error("Exception on routingAware listener call", ex);
-                }
-            }
-        }
-        log.trace("End of a Bulk EdgeUpdate");
-    }
-
-    /**
-     * Function called by the dependency manager when all the required
-     * dependencies are satisfied
-     *
-     */
-    @SuppressWarnings("unchecked")
-    public void init() {
-        log.debug("Routing init() is called");
-        this.topologyBWAware = new ConcurrentHashMap<Short, Graph<Node, Edge>>();
-        this.sptBWAware = new ConcurrentHashMap<Short, DijkstraShortestPath<Node, Edge>>();
-        // Now create the default topology, which doesn't consider the
-        // BW, also create the corresponding Dijkstra calculation
-        Graph<Node, Edge> g = new SparseMultigraph();
-        Short sZero = Short.valueOf((short) 0);
-        this.topologyBWAware.put(sZero, g);
-        this.sptBWAware.put(sZero, new DijkstraShortestPath(g));
-        // Topologies for other BW will be added on a needed base
-    }
-
-    /**
-     * Function called by the dependency manager when at least one dependency
-     * become unsatisfied or when the component is shutting down because for
-     * example bundle is being stopped.
-     *
-     */
-    void destroy() {
-        log.debug("Routing destroy() is called");
-    }
-
-    /**
-     * Function called by dependency manager after "init ()" is called and after
-     * the services provided by the class are registered in the service registry
-     *
-     */
-    void start() {
-        log.debug("Routing start() is called");
-        // build the routing database from the topology if it exists.
-        Map<Edge, Set<Property>> edges = topologyManager.getEdges();
-        if (edges.isEmpty()) {
-            return;
-        }
-        List<TopoEdgeUpdate> topoedgeupdateList = new ArrayList<TopoEdgeUpdate>();
-        log.debug("Creating routing database from the topology");
-        for (Iterator<Map.Entry<Edge, Set<Property>>> i = edges.entrySet()
-                .iterator(); i.hasNext();) {
-            Map.Entry<Edge, Set<Property>> entry = i.next();
-            Edge e = entry.getKey();
-            Set<Property> props = entry.getValue();
-            TopoEdgeUpdate topoedgeupdate = new TopoEdgeUpdate(e, props,
-                    UpdateType.ADDED);
-            topoedgeupdateList.add(topoedgeupdate);
-        }
-        edgeUpdate(topoedgeupdateList);
-    }
-
-    /**
-     * Function called by the dependency manager before the services exported by
-     * the component are unregistered, this will be followed by a "destroy ()"
-     * calls
-     *
-     */
-    public void stop() {
-        log.debug("Routing stop() is called");
-    }
-
-    public void setSwitchManager(ISwitchManager switchManager) {
-        this.switchManager = switchManager;
-    }
-
-    public void unsetSwitchManager(ISwitchManager switchManager) {
-        if (this.switchManager == switchManager) {
-            this.switchManager = null;
-        }
-    }
-
-    public void setTopologyManager(ITopologyManager tm) {
-        this.topologyManager = tm;
-    }
-
-    public void unsetTopologyManager(ITopologyManager tm) {
-        if (this.topologyManager == tm) {
-            this.topologyManager = null;
-        }
-    }
-
-    void setClusterContainerService(IClusterContainerServices s) {
-        log.debug("Cluster Service set");
-        this.clusterContainerService = s;
-    }
-
-    void unsetClusterContainerService(IClusterContainerServices s) {
-        if (this.clusterContainerService == s) {
-            log.debug("Cluster Service removed!");
-            this.clusterContainerService = null;
-        }
-    }
-
-    @Override
-    public void edgeOverUtilized(Edge edge) {
-        // TODO Auto-generated method stub
-
-    }
-
-    @Override
-    public void edgeUtilBackToNormal(Edge edge) {
-        // TODO Auto-generated method stub
-
-    }
-}
diff --git a/opendaylight/adsal/routing/dijkstra_implementation/src/main/java/org/opendaylight/controller/routing/dijkstra_implementation/internal/DijkstraImplementationCLI.java b/opendaylight/adsal/routing/dijkstra_implementation/src/main/java/org/opendaylight/controller/routing/dijkstra_implementation/internal/DijkstraImplementationCLI.java
deleted file mode 100644 (file)
index a6645cc..0000000
+++ /dev/null
@@ -1,65 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.routing.dijkstra_implementation.internal;
-
-import java.util.Dictionary;
-import java.util.Hashtable;
-
-import org.apache.felix.service.command.Descriptor;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.Path;
-import org.opendaylight.controller.sal.routing.IRouting;
-import org.opendaylight.controller.sal.utils.ServiceHelper;
-import org.osgi.framework.ServiceRegistration;
-
-public class DijkstraImplementationCLI {
-    @SuppressWarnings("rawtypes")
-    private ServiceRegistration sr = null;
-
-    public void init() {
-    }
-
-    public void destroy() {
-    }
-
-    public void start() {
-        final Dictionary<String, Object> props = new Hashtable<String, Object>();
-        props.put("osgi.command.scope", "odpcontroller");
-        props.put("osgi.command.function", new String[] { "getRoute" });
-        this.sr = ServiceHelper.registerGlobalServiceWReg(DijkstraImplementationCLI.class, this, props);
-    }
-
-    public void stop() {
-        if (this.sr != null) {
-            this.sr.unregister();
-            this.sr = null;
-        }
-    }
-
-    @Descriptor("Retrieves a Route between two Nodes in the discovered Topology DB")
-    public void getRoute(
-            @Descriptor("Container on the context of which the routing service need to be looked up") String container,
-            @Descriptor("String representation of the Source Node, this need to be consumable from Node.fromString()") String srcNode,
-            @Descriptor("String representation of the Destination Node") String dstNode) {
-        final IRouting r = (IRouting) ServiceHelper.getInstance(IRouting.class, container, this);
-
-        if (r == null) {
-            System.out.println("Cannot find the routing instance on container:" + container);
-            return;
-        }
-
-        final Node src = Node.fromString(srcNode);
-        final Node dst = Node.fromString(dstNode);
-        final Path p = r.getRoute(src, dst);
-        if (p != null) {
-            System.out.println("Route between srcNode:" + src + " and dstNode:" + dst + " = " + p);
-        } else {
-            System.out.println("There is no route between srcNode:" + src + " and dstNode:" + dst);
-        }
-    }
-}
diff --git a/opendaylight/adsal/routing/dijkstra_implementation/src/test/java/org/opendaylight/controller/routing/dijkstra_implementation/DijkstraTest.java b/opendaylight/adsal/routing/dijkstra_implementation/src/test/java/org/opendaylight/controller/routing/dijkstra_implementation/DijkstraTest.java
deleted file mode 100644 (file)
index e3ae560..0000000
+++ /dev/null
@@ -1,245 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.routing.dijkstra_implementation;
-
-import org.opendaylight.controller.sal.core.Bandwidth;
-import org.opendaylight.controller.sal.core.ConstructionException;
-import org.opendaylight.controller.sal.core.Edge;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.Path;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.core.UpdateType;
-import org.opendaylight.controller.sal.topology.TopoEdgeUpdate;
-import org.opendaylight.controller.sal.utils.NodeConnectorCreator;
-import org.opendaylight.controller.sal.utils.NodeCreator;
-
-import java.util.ArrayList;
-import java.util.HashSet;
-import java.util.LinkedList;
-import java.util.List;
-import java.util.Set;
-
-import org.junit.Assert;
-import org.junit.Test;
-import org.opendaylight.controller.routing.dijkstra_implementation.internal.DijkstraImplementation;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-public class DijkstraTest {
-    protected static final Logger logger = LoggerFactory
-            .getLogger(DijkstraTest.class);
-
-    @Test
-    public void testSinglePathRouteNoBw() {
-        DijkstraImplementation imp = new DijkstraImplementation();
-        imp.init();
-        Node node1 = NodeCreator.createOFNode((long) 1);
-        Node node2 = NodeCreator.createOFNode((long) 2);
-        Node node3 = NodeCreator.createOFNode((long) 3);
-        List<TopoEdgeUpdate> topoedgeupdateList = new ArrayList<TopoEdgeUpdate>();
-        NodeConnector nc11 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 1, node1);
-        NodeConnector nc21 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 1, node2);
-        Edge edge1 = null;
-        try {
-            edge1 = new Edge(nc11, nc21);
-        } catch (ConstructionException e) {
-            logger.error("", e);
-        }
-        Set<Property> props = new HashSet<Property>();
-        props.add(new Bandwidth(0));
-        TopoEdgeUpdate teu1 = new TopoEdgeUpdate(edge1, props, UpdateType.ADDED);
-        topoedgeupdateList.add(teu1);
-
-        NodeConnector nc22 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 2, node2);
-        NodeConnector nc31 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 1, node3);
-        Edge edge2 = null;
-        try {
-            edge2 = new Edge(nc22, nc31);
-        } catch (ConstructionException e) {
-            logger.error("", e);
-        }
-        Set<Property> props2 = new HashSet<Property>();
-        props2.add(new Bandwidth(0));
-        TopoEdgeUpdate teu2 = new TopoEdgeUpdate(edge2, props2,
-                UpdateType.ADDED);
-        topoedgeupdateList.add(teu2);
-        imp.edgeUpdate(topoedgeupdateList);
-        Path res = imp.getRoute(node1, node3);
-
-        List<Edge> expectedPath = (List<Edge>) new LinkedList<Edge>();
-        expectedPath.add(0, edge1);
-        expectedPath.add(1, edge2);
-        Path expectedRes = null;
-        try {
-            expectedRes = new Path(expectedPath);
-        } catch (ConstructionException e) {
-            logger.error("", e);
-        }
-        if (!res.equals(expectedRes)) {
-            System.out.println("Actual Res is " + res);
-            System.out.println("Expected Res is " + expectedRes);
-        }
-        Assert.assertTrue(res.equals(expectedRes));
-    }
-
-    @Test
-    public void testShortestPathRouteNoBw() {
-        DijkstraImplementation imp = new DijkstraImplementation();
-        List<TopoEdgeUpdate> topoedgeupdateList = new ArrayList<TopoEdgeUpdate>();
-        imp.init();
-        Node node1 = NodeCreator.createOFNode((long) 1);
-        Node node2 = NodeCreator.createOFNode((long) 2);
-        Node node3 = NodeCreator.createOFNode((long) 3);
-        NodeConnector nc11 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 1, node1);
-        NodeConnector nc21 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 1, node2);
-        Edge edge1 = null;
-        try {
-            edge1 = new Edge(nc11, nc21);
-        } catch (ConstructionException e) {
-            logger.error("", e);
-        }
-        Set<Property> props = new HashSet<Property>();
-        props.add(new Bandwidth(0));
-        TopoEdgeUpdate teu1 = new TopoEdgeUpdate(edge1, props, UpdateType.ADDED);
-        topoedgeupdateList.add(teu1);
-
-        NodeConnector nc22 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 2, node2);
-        NodeConnector nc31 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 1, node3);
-        Edge edge2 = null;
-        try {
-            edge2 = new Edge(nc22, nc31);
-        } catch (ConstructionException e) {
-            logger.error("", e);
-        }
-        Set<Property> props2 = new HashSet<Property>();
-        props2.add(new Bandwidth(0));
-        TopoEdgeUpdate teu2 = new TopoEdgeUpdate(edge2, props2,
-                UpdateType.ADDED);
-        topoedgeupdateList.add(teu2);
-
-        NodeConnector nc12 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 2, node1);
-        NodeConnector nc32 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 2, node3);
-        Edge edge3 = null;
-        try {
-            edge3 = new Edge(nc12, nc32);
-        } catch (ConstructionException e) {
-            logger.error("", e);
-        }
-        Set<Property> props3 = new HashSet<Property>();
-        props3.add(new Bandwidth(0));
-        TopoEdgeUpdate teu3 = new TopoEdgeUpdate(edge3, props3,
-                UpdateType.ADDED);
-        topoedgeupdateList.add(teu3);
-        imp.edgeUpdate(topoedgeupdateList);
-
-        Path res = imp.getRoute(node1, node3);
-
-        List<Edge> expectedPath = (List<Edge>) new LinkedList<Edge>();
-        expectedPath.add(0, edge3);
-        Path expectedRes = null;
-        try {
-            expectedRes = new Path(expectedPath);
-        } catch (ConstructionException e) {
-            logger.error("", e);
-        }
-        if (!res.equals(expectedRes)) {
-            System.out.println("Actual Res is " + res);
-            System.out.println("Expected Res is " + expectedRes);
-        }
-        Assert.assertTrue(res.equals(expectedRes));
-    }
-
-    @Test
-    public void testShortestPathRouteNoBwAfterLinkDelete() {
-        DijkstraImplementation imp = new DijkstraImplementation();
-        imp.init();
-        List<TopoEdgeUpdate> topoedgeupdateList = new ArrayList<TopoEdgeUpdate>();
-        Node node1 = NodeCreator.createOFNode((long) 1);
-        Node node2 = NodeCreator.createOFNode((long) 2);
-        Node node3 = NodeCreator.createOFNode((long) 3);
-        NodeConnector nc11 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 1, node1);
-        NodeConnector nc21 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 1, node2);
-        Edge edge1 = null;
-        try {
-            edge1 = new Edge(nc11, nc21);
-        } catch (ConstructionException e) {
-            logger.error("", e);
-        }
-        Set<Property> props = new HashSet<Property>();
-        props.add(new Bandwidth(0));
-        TopoEdgeUpdate teu1 = new TopoEdgeUpdate(edge1, props, UpdateType.ADDED);
-        topoedgeupdateList.add(teu1);
-
-        NodeConnector nc22 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 2, node2);
-        NodeConnector nc31 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 1, node3);
-        Edge edge2 = null;
-        try {
-            edge2 = new Edge(nc22, nc31);
-        } catch (ConstructionException e) {
-            logger.error("", e);
-        }
-        Set<Property> props2 = new HashSet<Property>();
-        props2.add(new Bandwidth(0));
-        TopoEdgeUpdate teu2 = new TopoEdgeUpdate(edge2, props2,
-                UpdateType.ADDED);
-        topoedgeupdateList.add(teu2);
-
-        NodeConnector nc12 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 2, node1);
-        NodeConnector nc32 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 2, node3);
-        Edge edge3 = null;
-        try {
-            edge3 = new Edge(nc12, nc32);
-        } catch (ConstructionException e) {
-            logger.error("", e);
-        }
-        Set<Property> props3 = new HashSet<Property>();
-        props3.add(new Bandwidth(0));
-        TopoEdgeUpdate teu3 = new TopoEdgeUpdate(edge3, props3,
-                UpdateType.ADDED);
-        topoedgeupdateList.add(teu3);
-        TopoEdgeUpdate teu4 = new TopoEdgeUpdate(edge3, props3,
-                UpdateType.REMOVED);
-        topoedgeupdateList.add(teu4);
-
-        imp.edgeUpdate(topoedgeupdateList);
-
-        Path res = imp.getRoute(node1, node3);
-        List<Edge> expectedPath = (List<Edge>) new LinkedList<Edge>();
-        expectedPath.add(0, edge1);
-        expectedPath.add(1, edge2);
-        Path expectedRes = null;
-        try {
-            expectedRes = new Path(expectedPath);
-        } catch (ConstructionException e) {
-            logger.error("", e);
-        }
-        if (!res.equals(expectedRes)) {
-            System.out.println("Actual Res is " + res);
-            System.out.println("Expected Res is " + expectedRes);
-        }
-        Assert.assertTrue(res.equals(expectedRes));
-    }
-}
diff --git a/opendaylight/adsal/routing/dijkstra_implementation/src/test/java/org/opendaylight/controller/routing/dijkstra_implementation/MaxThruputTest.java b/opendaylight/adsal/routing/dijkstra_implementation/src/test/java/org/opendaylight/controller/routing/dijkstra_implementation/MaxThruputTest.java
deleted file mode 100644 (file)
index 17952c8..0000000
+++ /dev/null
@@ -1,237 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.routing.dijkstra_implementation;
-
-import org.junit.Test;
-
-import org.opendaylight.controller.sal.core.ConstructionException;
-import org.opendaylight.controller.sal.core.Edge;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.Path;
-import org.opendaylight.controller.sal.topology.TopoEdgeUpdate;
-import org.opendaylight.controller.sal.utils.NodeConnectorCreator;
-import org.opendaylight.controller.sal.utils.NodeCreator;
-
-import java.util.LinkedList;
-import java.util.List;
-import java.util.ArrayList;
-import java.util.HashMap;
-import java.util.Map;
-
-import org.junit.Assert;
-import org.opendaylight.controller.routing.dijkstra_implementation.internal.DijkstraImplementation;
-
-import org.opendaylight.controller.sal.core.UpdateType;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-public class MaxThruputTest {
-    protected static final Logger logger = LoggerFactory
-            .getLogger(MaxThruputTest.class);
-    Map<Edge, Number> LinkCostMap = new HashMap<Edge, Number>();
-
-    @Test
-    public void testMaxThruPut() {
-        DijkstraImplementation imp = new DijkstraImplementation();
-        imp.init();
-        Node node1 = NodeCreator.createOFNode((long) 1);
-        Node node2 = NodeCreator.createOFNode((long) 2);
-        Node node3 = NodeCreator.createOFNode((long) 3);
-        Node node4 = NodeCreator.createOFNode((long) 4);
-        Node node5 = NodeCreator.createOFNode((long) 5);
-        Node node6 = NodeCreator.createOFNode((long) 6);
-        NodeConnector nc11 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 1, node1);
-        NodeConnector nc21 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 1, node2);
-        NodeConnector nc31 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 1, node3);
-        NodeConnector nc41 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 1, node4);
-        NodeConnector nc51 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 1, node5);
-        NodeConnector nc61 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 1, node6);
-        NodeConnector nc12 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 2, node1);
-        NodeConnector nc22 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 2, node2);
-        NodeConnector nc32 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 2, node3);
-        NodeConnector nc42 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 2, node4);
-        NodeConnector nc52 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 2, node5);
-        NodeConnector nc62 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 2, node6);
-
-        Edge edge1 = null;
-        try {
-            edge1 = new Edge(nc11, nc21);
-        } catch (ConstructionException e) {
-            logger.error("", e);
-        }
-        LinkCostMap.put(edge1, 10);
-        Edge edge2 = null;
-        try {
-            edge2 = new Edge(nc21, nc11);
-        } catch (ConstructionException e) {
-            logger.error("", e);
-        }
-        LinkCostMap.put(edge2, 10);
-
-        Edge edge3 = null;
-        try {
-            edge3 = new Edge(nc22, nc31);
-        } catch (ConstructionException e) {
-            logger.error("", e);
-        }
-        LinkCostMap.put(edge3, 30);
-        Edge edge4 = null;
-        try {
-            edge4 = new Edge(nc31, nc22);
-        } catch (ConstructionException e) {
-            logger.error("", e);
-        }
-        LinkCostMap.put(edge4, 30);
-
-        Edge edge5 = null;
-        try {
-            edge5 = new Edge(nc32, nc41);
-        } catch (ConstructionException e) {
-            logger.error("", e);
-        }
-        LinkCostMap.put(edge5, 10);
-        Edge edge6 = null;
-        try {
-            edge6 = new Edge(nc41, nc32);
-        } catch (ConstructionException e) {
-            logger.error("", e);
-        }
-        LinkCostMap.put(edge6, 10);
-
-        Edge edge7 = null;
-        try {
-            edge7 = new Edge(nc12, nc51);
-        } catch (ConstructionException e) {
-            logger.error("", e);
-        }
-        LinkCostMap.put(edge7, 20);
-        Edge edge8 = null;
-        try {
-            edge8 = new Edge(nc51, nc12);
-        } catch (ConstructionException e) {
-            logger.error("", e);
-        }
-        LinkCostMap.put(edge8, 20);
-
-        Edge edge9 = null;
-        try {
-            edge9 = new Edge(nc52, nc61);
-        } catch (ConstructionException e) {
-            logger.error("", e);
-        }
-        LinkCostMap.put(edge9, 20);
-        Edge edge10 = null;
-        try {
-            edge10 = new Edge(nc61, nc52);
-        } catch (ConstructionException e) {
-            logger.error("", e);
-        }
-        LinkCostMap.put(edge10, 20);
-
-        Edge edge11 = null;
-        try {
-            edge11 = new Edge(nc62, nc42);
-        } catch (ConstructionException e) {
-            logger.error("", e);
-        }
-        LinkCostMap.put(edge11, 20);
-        Edge edge12 = null;
-        try {
-            edge12 = new Edge(nc42, nc62);
-        } catch (ConstructionException e) {
-            logger.error("", e);
-        }
-        LinkCostMap.put(edge12, 20);
-
-        List<TopoEdgeUpdate> topoedgeupdateList = new ArrayList<TopoEdgeUpdate>();
-        TopoEdgeUpdate teu1 = new TopoEdgeUpdate(edge1, null, UpdateType.ADDED);
-        topoedgeupdateList.add(teu1);
-        TopoEdgeUpdate teu2 = new TopoEdgeUpdate(edge2, null, UpdateType.ADDED);
-        topoedgeupdateList.add(teu2);
-        TopoEdgeUpdate teu3 = new TopoEdgeUpdate(edge3, null, UpdateType.ADDED);
-        topoedgeupdateList.add(teu3);
-        TopoEdgeUpdate teu4 = new TopoEdgeUpdate(edge4, null, UpdateType.ADDED);
-        topoedgeupdateList.add(teu4);
-        TopoEdgeUpdate teu5 = new TopoEdgeUpdate(edge5, null, UpdateType.ADDED);
-        topoedgeupdateList.add(teu5);
-        TopoEdgeUpdate teu6 = new TopoEdgeUpdate(edge6, null, UpdateType.ADDED);
-        topoedgeupdateList.add(teu6);
-        TopoEdgeUpdate teu7 = new TopoEdgeUpdate(edge7, null, UpdateType.ADDED);
-        topoedgeupdateList.add(teu7);
-        TopoEdgeUpdate teu8 = new TopoEdgeUpdate(edge8, null, UpdateType.ADDED);
-        topoedgeupdateList.add(teu8);
-        TopoEdgeUpdate teu9 = new TopoEdgeUpdate(edge9, null, UpdateType.ADDED);
-        topoedgeupdateList.add(teu9);
-        TopoEdgeUpdate teu10 = new TopoEdgeUpdate(edge10, null,
-                UpdateType.ADDED);
-        topoedgeupdateList.add(teu10);
-        TopoEdgeUpdate teu11 = new TopoEdgeUpdate(edge11, null,
-                UpdateType.ADDED);
-        topoedgeupdateList.add(teu11);
-        TopoEdgeUpdate teu12 = new TopoEdgeUpdate(edge12, null,
-                UpdateType.ADDED);
-        topoedgeupdateList.add(teu12);
-
-        imp.edgeUpdate(topoedgeupdateList);
-
-        imp.initMaxThroughput(LinkCostMap);
-
-        Path res = imp.getMaxThroughputRoute(node1, node3);
-        System.out.println("Max Thruput Path between n1-n3: " + res);
-
-        List<Edge> expectedPath = (List<Edge>) new LinkedList<Edge>();
-        expectedPath.add(0, edge7);
-        expectedPath.add(1, edge9);
-        expectedPath.add(2, edge11);
-        expectedPath.add(3, edge6);
-
-        Path expectedRes = null;
-        try {
-            expectedRes = new Path(expectedPath);
-        } catch (ConstructionException e) {
-            logger.error("", e);
-        }
-        if (!res.equals(expectedRes)) {
-            System.out.println("Actual Res is " + res);
-            System.out.println("Expected Res is " + expectedRes);
-        }
-        Assert.assertTrue(res.equals(expectedRes));
-
-        res = imp.getRoute(node1, node3);
-        System.out.println("Shortest Path between n1-n3: " + res);
-        expectedPath.clear();
-        expectedPath.add(0, edge1);
-        expectedPath.add(1, edge3);
-
-        expectedRes = null;
-        try {
-            expectedRes = new Path(expectedPath);
-        } catch (ConstructionException e) {
-            logger.error("", e);
-        }
-        if (!res.equals(expectedRes)) {
-            System.out.println("Actual Res is " + res);
-            System.out.println("Expected Res is " + expectedRes);
-        }
-        Assert.assertTrue(res.equals(expectedRes));
-    }
-}
diff --git a/opendaylight/adsal/sal/api/pom.xml b/opendaylight/adsal/sal/api/pom.xml
deleted file mode 100644 (file)
index 2a61853..0000000
+++ /dev/null
@@ -1,77 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>sal</artifactId>
-  <version>0.10.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.apache.commons</groupId>
-      <artifactId>commons-lang3</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.apache.felix</groupId>
-      <artifactId>org.apache.felix.dependencymanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.osgi</groupId>
-      <artifactId>org.osgi.core</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.slf4j</groupId>
-      <artifactId>slf4j-api</artifactId>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Import-Package>org.slf4j,
-              org.osgi.framework,
-              org.apache.commons.lang3.builder,
-              org.apache.felix.dm,
-              org.apache.commons.lang3.tuple,
-              javax.xml.bind.annotation,
-              javax.xml.bind.annotation.adapters</Import-Package>
-            <Export-Package>org.opendaylight.controller.sal.authorization,
-              org.opendaylight.controller.sal.action,
-              org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.sal.discovery,
-              org.opendaylight.controller.sal.topology,
-              org.opendaylight.controller.sal.routing,
-              org.opendaylight.controller.sal.packet,
-              org.opendaylight.controller.sal.packet.address,
-              org.opendaylight.controller.sal.utils,
-              org.opendaylight.controller.sal.match,
-              org.opendaylight.controller.sal.inventory,
-              org.opendaylight.controller.sal.flowprogrammer,
-              org.opendaylight.controller.sal.reader</Export-Package>
-          </instructions>
-          <manifestLocation>${project.basedir}/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/Action.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/Action.java
deleted file mode 100644 (file)
index cf303b9..0000000
+++ /dev/null
@@ -1,230 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.action;
-
-import java.util.ArrayList;
-import java.util.Collection;
-import java.util.Collections;
-import java.util.List;
-import java.util.concurrent.ConcurrentMap;
-import java.util.concurrent.ConcurrentHashMap;
-
-import org.opendaylight.controller.sal.core.Property;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-import java.io.Serializable;
-
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-
-/**
- * Represents the generic action to be applied to the matched
- * frame/packet/message
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public abstract class Action implements Serializable {
-    private static final long serialVersionUID = 1L;
-    private static final Logger logger = LoggerFactory.getLogger(Action.class);
-    private static boolean debug = false; // Enable to find where in the code an
-    // invalid assignment is made
-    @XmlElement
-    protected ActionType type;
-    private transient boolean isValid = true;
-    private ConcurrentMap<String, Property> props;
-
-    /* Dummy constructor for JAXB */
-    public Action() {
-    }
-
-    /**
-     * Checks if the passed value is in the valid range for this action
-     *
-     * @param value
-     * @return boolean
-     */
-    protected void checkValue(int value) {
-        if (type.isValidTarget(value) == false) {
-            isValid = false;
-            throwValueException(value);
-        }
-    }
-
-    /**
-     * Checks if the passed value is in the valid range for the passed action
-     * type This method is used for complex Action types which are
-     *
-     * @param value
-     * @return boolean
-     */
-    protected void checkValue(ActionType type, int value) {
-        if (type.isValidTarget(value) == false) {
-            isValid = false;
-            throwValueException(value);
-        }
-    }
-
-    /**
-     * Throw and handle the invalid value exception
-     *
-     * @param value
-     * @return void
-     */
-    private void throwValueException(int value) {
-        String error = "Invalid field value assignement. For type: " + type.getId() + " Expected: " + type.getRange()
-                + ", Got: 0x" + Integer.toHexString(value);
-        try {
-            throw new Exception(error);
-        } catch (Exception e) {
-            logger.error(e.getMessage());
-            if (debug) {
-                logger.error("", e);
-            }
-        }
-    }
-
-    /**
-     * Gets the list of metadata currently registered with this match
-     *
-     * @return List of metadata currently registered
-     */
-    public List <Property> getMetadatas() {
-        if (this.props != null) {
-            // Return all the values in the map
-            Collection res = this.props.values();
-            if (res == null) {
-                return Collections.emptyList();
-            }
-            return new ArrayList<Property>(res);
-        }
-        return Collections.emptyList();
-    }
-
-    /**
-     * Gets the metadata registered with a name if present
-     *
-     * @param name the name of the property to be extracted
-     *
-     * @return List of metadata currently registered
-     */
-    public Property getMetadata(String name) {
-        if (name == null) {
-            return null;
-        }
-        if (this.props != null) {
-            // Return the Property associated to the name
-            return this.props.get(name);
-        }
-        return null;
-    }
-
-    /**
-     * Sets the metadata associated to a name. If the name or prop is NULL,
-     * an exception NullPointerException will be raised.
-     *
-     * @param name the name of the property to be set
-     * @param prop, property to be set
-     */
-    public void setMetadata(String name, Property prop) {
-        if (this.props == null) {
-            props = new ConcurrentHashMap<String, Property>();
-        }
-
-        if (this.props != null) {
-            this.props.put(name, prop);
-        }
-    }
-
-    /**
-     * Remove the metadata associated to a name. If the name is NULL,
-     * nothing will be removed.
-     *
-     * @param name the name of the property to be set
-     * @param prop, property to be set
-     *
-     * @return List of metadata currently registered
-     */
-    public void removeMetadata(String name) {
-        if (this.props == null) {
-            return;
-        }
-
-        if (this.props != null) {
-            this.props.remove(name);
-        }
-        // It's intentional to keep the this.props still allocated
-        // till the parent data structure will be alive, so to avoid
-        // unnecessary allocation/deallocation, even if it's holding
-        // nothing
-    }
-
-    /**
-     * Returns the type of this action
-     *
-     * @return ActionType
-     */
-    public ActionType getType() {
-        return type;
-    }
-
-    /**
-     * Returns the id of this action
-     *
-     * @return String
-     */
-    public String getId() {
-        return type.getId();
-    }
-
-    /**
-     * Returns whether the Action is valid or not
-     *
-     * @return boolean
-     */
-    public boolean isValid() {
-        return isValid;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + ((type == null) ? 0 : type.calculateConsistentHashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        Action other = (Action) obj;
-        if (type != other.type) {
-            return false;
-        }
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        return type.toString();
-    }
-
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/ActionType.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/ActionType.java
deleted file mode 100644 (file)
index 0c059ea..0000000
+++ /dev/null
@@ -1,86 +0,0 @@
-/*
- * Copyright (c) 2013-2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.sal.action;
-
-/**
- * The enumeration of actions supported by the controller
- * Each entry has a unique id and the values range for the action element where applicable
- */
-@Deprecated
-public enum ActionType {
-    DROP("drop", 0, 0),
-    LOOPBACK("loopback", 0, 0),
-    FLOOD("flood", 0, 0), // regular switching flood (obeys to stp port state)
-    FLOOD_ALL("floodAll", 0, 0), // flood to all ports regardless of stp port state
-    CONTROLLER("controller", 0, 0),
-    INTERFACE("interface", 0, 0), // Interface
-    SW_PATH("software path", 0, 0), // OF Local
-    HW_PATH("harware path", 0, 0),
-    OUTPUT("output", 0, 0xffff), // physical port
-    ENQUEUE("enqueue", 0, 0xffff),
-    SET_DL_SRC("setDlSrc", 0, 0),
-    SET_DL_DST("setDlDst", 0, 0),
-    SET_VLAN_ID("setVlan", 1, 0xfff),
-    SET_VLAN_PCP("setVlanPcp", 0, 0x7),
-    SET_VLAN_CFI("setVlanCif", 0, 0x1),
-    POP_VLAN("stripVlan", 0, 0), // Pop
-    PUSH_VLAN("pushVlan", 0, 0xffff), // Push (the max value only takes into account the TCI portion of the 802.1q header)
-    SET_DL_TYPE("setDlType", 0, 0xffff), // Set ethertype/length field
-    SET_NW_SRC("setNwSrc", 0, 0),
-    SET_NW_DST("setNwDst", 0, 0),
-    SET_NW_TOS("setNwTos", 0, 0x3f),
-    SET_TP_SRC("setTpSrc", 0, 0xffff), // Set transport source port
-    SET_TP_DST("setTpDst", 0, 0xffff), // Set transport destination port
-    SET_NEXT_HOP("setNextHop", 0, 0);
-
-    private String id;
-    private int minValue;
-    private int maxValue;
-
-    private ActionType(String id, int minValue, int maxValue) {
-        this.id = id;
-        this.minValue = minValue;
-        this.maxValue = maxValue;
-    }
-
-    public String getId() {
-        return id;
-    }
-
-    public boolean isValidTarget(int value) {
-        return (value >= minValue && value <= maxValue);
-    }
-
-    public String getRange() {
-        return "[0x" + Long.toHexString(minValue) + "-0x" + Long.toHexString(maxValue) + "]";
-    }
-
-    public boolean takesParameter() {
-        switch (this) {
-        case POP_VLAN:
-        case DROP:
-        case SW_PATH:
-        case HW_PATH:
-        case CONTROLLER:
-        case LOOPBACK:
-        case FLOOD:
-        case FLOOD_ALL:
-            return false;
-        default:
-            return true;
-        }
-    }
-
-    public int calculateConsistentHashCode() {
-        if (this.id != null) {
-            return this.id.hashCode();
-        } else {
-            return 0;
-        }
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/Controller.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/Controller.java
deleted file mode 100644 (file)
index 9de09c5..0000000
+++ /dev/null
@@ -1,27 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.action;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlRootElement;
-
-/**
- * Represents the action of punting the packet to the controller
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class Controller extends Action {
-    private static final long serialVersionUID = 1L;
-
-    public Controller() {
-        type = ActionType.CONTROLLER;
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/Drop.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/Drop.java
deleted file mode 100644 (file)
index bfef4c3..0000000
+++ /dev/null
@@ -1,27 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.action;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlRootElement;
-
-/**
- * Represent the action of dropping the matched packet
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class Drop extends Action {
-    private static final long serialVersionUID = 1L;
-
-    public Drop() {
-        type = ActionType.DROP;
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/Enqueue.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/Enqueue.java
deleted file mode 100644 (file)
index d80e2e7..0000000
+++ /dev/null
@@ -1,57 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.action;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.sal.core.NodeConnector;
-
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class Enqueue extends Action {
-    private static final long serialVersionUID = 1L;
-    @XmlElement
-    private NodeConnector port;
-    @XmlElement
-    private int queue;
-
-    /* Dummy constructor for JAXB */
-    @SuppressWarnings("unused")
-    private Enqueue() {
-    }
-
-    public Enqueue(NodeConnector port) {
-        type = ActionType.ENQUEUE;
-        this.port = port;
-        this.queue = 0;
-    }
-
-    public Enqueue(NodeConnector port, int queue) {
-        type = ActionType.ENQUEUE;
-        this.port = port;
-        this.queue = queue;
-    }
-
-    public NodeConnector getPort() {
-        return port;
-    }
-
-    public int getQueue() {
-        return queue;
-    }
-
-    @Override
-    public String toString() {
-        return String.format("%s[%s:%s]", type, port, queue);
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/Flood.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/Flood.java
deleted file mode 100644 (file)
index 02f5fe8..0000000
+++ /dev/null
@@ -1,27 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.action;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlRootElement;
-
-/**
- * Represents the action of flooding the packet out
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class Flood extends Action {
-    private static final long serialVersionUID = 1L;
-
-    public Flood() {
-        type = ActionType.FLOOD;
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/FloodAll.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/FloodAll.java
deleted file mode 100644 (file)
index a11156f..0000000
+++ /dev/null
@@ -1,28 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.action;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlRootElement;
-
-/**
- * Represents the action of flooding the packet out all the physical ports
- * except the input port
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class FloodAll extends Action {
-    private static final long serialVersionUID = 1L;
-
-    public FloodAll() {
-        type = ActionType.FLOOD_ALL;
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/HwPath.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/HwPath.java
deleted file mode 100644 (file)
index 56bcd23..0000000
+++ /dev/null
@@ -1,28 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.action;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlRootElement;
-
-/**
- * Represents the action of sending the packet to the local hardware path for
- * processing
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class HwPath extends Action {
-    private static final long serialVersionUID = 1L;
-
-    public HwPath() {
-        type = ActionType.HW_PATH;
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/Loopback.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/Loopback.java
deleted file mode 100644 (file)
index 7b3198a..0000000
+++ /dev/null
@@ -1,27 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.action;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlRootElement;
-
-/**
- * Represents the action of looping the packet back the port it came in from
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class Loopback extends Action {
-    private static final long serialVersionUID = 1L;
-
-    public Loopback() {
-        type = ActionType.LOOPBACK;
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/Output.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/Output.java
deleted file mode 100644 (file)
index 862f656..0000000
+++ /dev/null
@@ -1,78 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.action;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.sal.core.NodeConnector;
-
-/**
- * Represents the action of sending the packet out of a physical port
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class Output extends Action {
-    private static final long serialVersionUID = 1L;
-    @XmlElement
-    private NodeConnector port;
-
-    /* Dummy constructor for JAXB */
-    @SuppressWarnings("unused")
-    private Output() {
-    }
-
-    public Output(NodeConnector port) {
-        type = ActionType.OUTPUT;
-        this.port = port;
-        // checkValue(port);
-    }
-
-    public NodeConnector getPort() {
-        return port;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (!super.equals(obj)) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        Output other = (Output) obj;
-        if (port == null) {
-            if (other.port != null) {
-                return false;
-            }
-        } else if (!port.equals(other.port)) {
-            return false;
-        }
-        return true;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = super.hashCode();
-        result = prime * result + ((port == null) ? 0 : port.hashCode());
-        return result;
-    }
-
-    @Override
-    public String toString() {
-        return type + "[" + port.toString() + "]";
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/PopVlan.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/PopVlan.java
deleted file mode 100644 (file)
index 071ec71..0000000
+++ /dev/null
@@ -1,27 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.action;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlRootElement;
-
-/**
- * Pop vlan action (strip the outermost 802.1q header)
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class PopVlan extends Action {
-    private static final long serialVersionUID = 1L;
-
-    public PopVlan() {
-        type = ActionType.POP_VLAN;
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/PushVlan.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/PushVlan.java
deleted file mode 100644 (file)
index 7c7c585..0000000
+++ /dev/null
@@ -1,215 +0,0 @@
-/*
- * Copyright (c) 2013-2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.action;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.sal.utils.EtherTypes;
-
-/**
- * Insert a 802.1q (outermost) header action Execute it multiple times to
- * achieve QinQ
- *
- * 802.1q = [TPID(16) + TCI(16)] TCI = [PCP(3) + CFI(1) + VID(12)]
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class PushVlan extends Action {
-    private static final long serialVersionUID = 1L;
-    private int tag; // TPID - 16 bits
-    private int pcp; // PCP - 3 bits
-    private int cfi; // CFI - 1 bit (drop eligible)
-    private int vlanId; // VID - 12 bits
-    private transient int tci; // TCI = [PCP + CFI + VID] - 16 bits
-    private transient int header; // full 802.1q header [TPID + TCI] - 32 bits
-
-    /* Dummy constructor for JAXB */
-    @SuppressWarnings("unused")
-    private PushVlan() {
-    }
-
-    public PushVlan(int tag, int pcp, int cfi, int vlanId) {
-        type = ActionType.PUSH_VLAN;
-        this.tag = tag;
-        this.cfi = cfi;
-        this.pcp = pcp;
-        this.vlanId = vlanId;
-        this.tci = createTci();
-        this.header = createHeader();
-        runChecks();
-    }
-
-    public PushVlan(EtherTypes tag, int pcp, int cfi, int vlanId) {
-        type = ActionType.PUSH_VLAN;
-        this.tag = tag.intValue();
-        this.cfi = cfi;
-        this.pcp = pcp;
-        this.vlanId = vlanId;
-        this.tci = createTci();
-        this.header = createHeader();
-        runChecks();
-    }
-
-    /**
-     * Construct a new action instance which represents OF 1.3 PUSH_VLAN.
-     *
-     * @param tag  An {@link EtherTypes} instance.
-     */
-    public PushVlan(EtherTypes tag) {
-        this(tag.intValue());
-    }
-
-    /**
-     * Construct a new action instance which represents OF 1.3 PUSH_VLAN.
-     *
-     * @param tag  An ethernet type of a new VLAN tag.
-     */
-    public PushVlan(int tag) {
-        type = ActionType.PUSH_VLAN;
-        this.tag = tag;
-
-        if (tag != EtherTypes.VLANTAGGED.intValue() &&
-            tag != EtherTypes.QINQ.intValue()) {
-            // pass a value which will tell fail and tell something about the
-            // original wrong value
-            checkValue(ActionType.SET_DL_TYPE, 0xBAD << 16 | tag);
-        }
-    }
-
-    private int createTci() {
-        return (pcp & 0x7) << 13 | (cfi & 0x1) << 12 | (vlanId & 0xfff);
-    }
-
-    private int createHeader() {
-        return (tag & 0xffff) << 16 | (pcp & 0x7) << 13 | (cfi & 0x1) << 12 | (vlanId & 0xfff);
-    }
-
-    private void runChecks() {
-        checkValue(ActionType.SET_DL_TYPE, tag);
-        checkValue(ActionType.SET_VLAN_PCP, pcp);
-        checkValue(ActionType.SET_VLAN_CFI, cfi);
-        checkValue(ActionType.SET_VLAN_ID, vlanId);
-        checkValue(tci);
-
-        // Run action specific check which cannot be run by parent
-        if (tag != EtherTypes.VLANTAGGED.intValue() && tag != EtherTypes.QINQ.intValue()
-                && tag != EtherTypes.OLDQINQ.intValue() && tag != EtherTypes.CISCOQINQ.intValue()) {
-            // pass a value which will tell fail and tell something about the
-            // original wrong value
-            checkValue(ActionType.SET_DL_TYPE, 0xBAD << 16 | tag);
-        }
-    }
-
-    /**
-     * Returns the VID portion of the 802.1q header this action will insert VID
-     * - (12 bits)
-     *
-     * @return byte[]
-     */
-    public int getVlanId() {
-        return vlanId;
-    }
-
-    /**
-     * Returns the CFI portion of the 802.1q header this action will insert CFI
-     * - (1 bit)
-     *
-     * @return
-     */
-    public int getCfi() {
-        return cfi;
-    }
-
-    /**
-     * Returns the vlan PCP portion of the 802.1q header this action will insert
-     * PCP - (3 bits)
-     *
-     * @return byte[]
-     */
-    public int getPcp() {
-        return pcp;
-    }
-
-    /**
-     * Returns the TPID portion of the 802.1q header this action will insert
-     * TPID - (16 bits)
-     */
-    public int getTag() {
-        return tag;
-    }
-
-    /**
-     * Returns the TCI portion of the 802.1q header this action will insert TCI
-     * = [PCP + CFI + VID] - (16 bits)
-     *
-     * @return
-     */
-    public int getTci() {
-        return tci;
-    }
-
-    /**
-     * Returns the full 802.1q header this action will insert header = [TPID +
-     * TIC] (32 bits)
-     *
-     * @return int
-     */
-    @XmlElement(name = "VlanHeader")
-    public int getHeader() {
-        return header;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (!super.equals(obj)) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        PushVlan other = (PushVlan) obj;
-        if (cfi != other.cfi) {
-            return false;
-        }
-        if (pcp != other.pcp) {
-            return false;
-        }
-        if (tag != other.tag) {
-            return false;
-        }
-        if (vlanId != other.vlanId) {
-            return false;
-        }
-        return true;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = super.hashCode();
-        result = prime * result + cfi;
-        result = prime * result + pcp;
-        result = prime * result + tag;
-        result = prime * result + vlanId;
-        return result;
-    }
-
-    @Override
-    public String toString() {
-        return type + "[tag = " + tag + ", pcp = " + pcp + ", cfi = " + cfi + ", vlanId = " + vlanId + "]";
-    }
-
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/SetDlDst.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/SetDlDst.java
deleted file mode 100644 (file)
index 23d0a22..0000000
+++ /dev/null
@@ -1,84 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.action;
-
-import java.util.Arrays;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.sal.utils.HexEncode;
-
-/**
- * Set destination datalayer address action
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class SetDlDst extends Action {
-    private static final long serialVersionUID = 1L;
-    private byte[] address;
-
-    /* Dummy constructor for JAXB */
-    @SuppressWarnings("unused")
-    private SetDlDst() {
-    }
-
-    public SetDlDst(byte[] dlAddress) {
-        type = ActionType.SET_DL_DST;
-        this.address = dlAddress.clone();
-    }
-
-    /**
-     * Returns the datalayer address that this action will set
-     *
-     * @return byte[]
-     */
-    public byte[] getDlAddress() {
-        return address.clone();
-    }
-
-    @XmlElement(name = "address")
-    public String getDlAddressString() {
-        return HexEncode.bytesToHexString(address);
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (!super.equals(obj)) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        SetDlDst other = (SetDlDst) obj;
-        if (!Arrays.equals(address, other.address)) {
-            return false;
-        }
-        return true;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = super.hashCode();
-        result = prime * result + Arrays.hashCode(address);
-        return result;
-    }
-
-    @Override
-    public String toString() {
-        return type + "[address = " + HexEncode.bytesToHexString(address) + "]";
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/SetDlSrc.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/SetDlSrc.java
deleted file mode 100644 (file)
index 735cda3..0000000
+++ /dev/null
@@ -1,89 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.action;
-
-import java.util.Arrays;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.sal.utils.HexEncode;
-
-/**
- * Set source datalayer address action
- *
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class SetDlSrc extends Action {
-    private static final long serialVersionUID = 1L;
-    private byte[] address;
-
-    /* Dummy constructor for JAXB */
-    @SuppressWarnings("unused")
-    private SetDlSrc() {
-    }
-
-    public SetDlSrc(byte[] dlAddress) {
-        type = ActionType.SET_DL_SRC;
-        if (dlAddress != null) {
-            this.address = dlAddress.clone();
-        } else {
-            this.address = null;
-        }
-    }
-
-    /**
-     * Returns the datalayer address that this action will set
-     *
-     * @return byte[]
-     */
-    public byte[] getDlAddress() {
-        return address.clone();
-    }
-
-    @XmlElement(name = "address")
-    public String getDlAddressString() {
-        return HexEncode.bytesToHexString(address);
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (!super.equals(obj)) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        SetDlSrc other = (SetDlSrc) obj;
-        if (!Arrays.equals(address, other.address)) {
-            return false;
-        }
-        return true;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = super.hashCode();
-        result = prime * result + Arrays.hashCode(address);
-        return result;
-    }
-
-    @Override
-    public String toString() {
-        return type + "[address = " + HexEncode.bytesToHexString(address) + "]";
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/SetDlType.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/SetDlType.java
deleted file mode 100644 (file)
index 0c8762c..0000000
+++ /dev/null
@@ -1,86 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.action;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.sal.utils.EtherTypes;
-
-/**
- * Set ethertype/length field action
- */
-
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class SetDlType extends Action {
-    private static final long serialVersionUID = 1L;
-    @XmlElement
-    private int dlType;
-
-    /* Dummy constructor for JAXB */
-    @SuppressWarnings("unused")
-    private SetDlType() {
-    }
-
-    public SetDlType(int dlType) {
-        type = ActionType.SET_DL_TYPE;
-        this.dlType = dlType;
-        checkValue(dlType);
-    }
-
-    public SetDlType(EtherTypes dlType) {
-        type = ActionType.SET_DL_TYPE;
-        this.dlType = dlType.intValue();
-        checkValue(this.dlType);
-    }
-
-    /**
-     * Returns the ethertype/lenght value that this action will set
-     *
-     * @return byte[]
-     */
-    public int getDlType() {
-        return dlType;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (!super.equals(obj)) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        SetDlType other = (SetDlType) obj;
-        if (dlType != other.dlType) {
-            return false;
-        }
-        return true;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = super.hashCode();
-        result = prime * result + dlType;
-        return result;
-    }
-
-    @Override
-    public String toString() {
-        return type + "[dlType = 0x" + Integer.toHexString(dlType) + "]";
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/SetNextHop.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/SetNextHop.java
deleted file mode 100644 (file)
index 7aa872d..0000000
+++ /dev/null
@@ -1,73 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.sal.action;
-
-import java.net.InetAddress;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class SetNextHop extends Action {
-    private static final long serialVersionUID = 1L;
-    @XmlElement
-    private InetAddress address;
-
-    /* Dummy constructor for JAXB */
-    @SuppressWarnings("unused")
-    private SetNextHop() {
-    }
-
-    public SetNextHop(InetAddress address) {
-        type = ActionType.SET_NEXT_HOP;
-        this.address = address;
-    }
-
-    public InetAddress getAddress() {
-        return address;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = super.hashCode();
-        result = prime * result + ((address == null) ? 0 : address.hashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (!super.equals(obj)) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        SetNextHop other = (SetNextHop) obj;
-        if (address == null) {
-            if (other.address != null) {
-                return false;
-            }
-        } else if (!address.equals(other.address)) {
-            return false;
-        }
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        return type + "[" + address.toString() + "]";
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/SetNwDst.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/SetNwDst.java
deleted file mode 100644 (file)
index bff7b35..0000000
+++ /dev/null
@@ -1,87 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.action;
-
-import java.net.InetAddress;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-/**
- * Set network destination address action
- */
-
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class SetNwDst extends Action {
-    private static final long serialVersionUID = 1L;
-    InetAddress address;
-
-    /* Dummy constructor for JAXB */
-    @SuppressWarnings("unused")
-    private SetNwDst() {
-    }
-
-    public SetNwDst(InetAddress address) {
-        type = ActionType.SET_NW_DST;
-        this.address = address;
-    }
-
-    /**
-     * Returns the network address this action will set
-     *
-     * @return InetAddress
-     */
-    public InetAddress getAddress() {
-        return address;
-    }
-
-    @XmlElement(name = "address")
-    public String getAddressAsString() {
-        return address.getHostAddress();
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (!super.equals(obj)) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        SetNwDst other = (SetNwDst) obj;
-        if (address == null) {
-            if (other.address != null) {
-                return false;
-            }
-        } else if (!address.equals(other.address)) {
-            return false;
-        }
-        return true;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = super.hashCode();
-        result = prime * result + ((address == null) ? 0 : address.hashCode());
-        return result;
-    }
-
-    @Override
-    public String toString() {
-        return type + "[address = " + address + "]";
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/SetNwSrc.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/SetNwSrc.java
deleted file mode 100644 (file)
index b3d62bc..0000000
+++ /dev/null
@@ -1,87 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.action;
-
-import java.net.InetAddress;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-/**
- * Set network source address action
- */
-
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class SetNwSrc extends Action {
-    private static final long serialVersionUID = 1L;
-    InetAddress address;
-
-    /* Dummy constructor for JAXB */
-    @SuppressWarnings("unused")
-    private SetNwSrc() {
-    }
-
-    public SetNwSrc(InetAddress address) {
-        type = ActionType.SET_NW_SRC;
-        this.address = address;
-    }
-
-    /**
-     * Returns the network address this action will set
-     *
-     * @return InetAddress
-     */
-    public InetAddress getAddress() {
-        return address;
-    }
-
-    @XmlElement(name = "address")
-    public String getAddressAsString() {
-        return address.getHostAddress();
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (!super.equals(obj)) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        SetNwSrc other = (SetNwSrc) obj;
-        if (address == null) {
-            if (other.address != null) {
-                return false;
-            }
-        } else if (!address.equals(other.address)) {
-            return false;
-        }
-        return true;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = super.hashCode();
-        result = prime * result + ((address == null) ? 0 : address.hashCode());
-        return result;
-    }
-
-    @Override
-    public String toString() {
-        return type + "[address = " + address + "]";
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/SetNwTos.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/SetNwTos.java
deleted file mode 100644 (file)
index fcb11f0..0000000
+++ /dev/null
@@ -1,77 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.action;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-/**
- * Set network TOS action
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class SetNwTos extends Action {
-    private static final long serialVersionUID = 1L;
-    @XmlElement
-    private int tos;
-
-    /* Dummy constructor for JAXB */
-    @SuppressWarnings("unused")
-    private SetNwTos() {
-    }
-
-    public SetNwTos(int tos) {
-        type = ActionType.SET_NW_TOS;
-        this.tos = tos;
-        checkValue(tos);
-    }
-
-    /**
-     * Returns the network TOS value which the action will set
-     *
-     * @return int
-     */
-    public int getNwTos() {
-        return tos;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (!super.equals(obj)) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        SetNwTos other = (SetNwTos) obj;
-        if (tos != other.tos) {
-            return false;
-        }
-        return true;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = super.hashCode();
-        result = prime * result + tos;
-        return result;
-    }
-
-    @Override
-    public String toString() {
-        return type + "[tos = 0x" + Integer.toHexString(tos) + "]";
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/SetTpDst.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/SetTpDst.java
deleted file mode 100644 (file)
index e352d15..0000000
+++ /dev/null
@@ -1,77 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.action;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-/**
- * Set destination transport port action
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class SetTpDst extends Action {
-    private static final long serialVersionUID = 1L;
-    @XmlElement
-    private int port;
-
-    /* Dummy constructor for JAXB */
-    @SuppressWarnings("unused")
-    private SetTpDst() {
-    }
-
-    public SetTpDst(int port) {
-        type = ActionType.SET_TP_DST;
-        this.port = port;
-        checkValue(port);
-    }
-
-    /**
-     * Returns the transport port the action will set
-     *
-     * @return
-     */
-    public int getPort() {
-        return port;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (!super.equals(obj)) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        SetTpDst other = (SetTpDst) obj;
-        if (port != other.port) {
-            return false;
-        }
-        return true;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = super.hashCode();
-        result = prime * result + port;
-        return result;
-    }
-
-    @Override
-    public String toString() {
-        return type + "[port = " + port + "]";
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/SetTpSrc.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/SetTpSrc.java
deleted file mode 100644 (file)
index fa80c85..0000000
+++ /dev/null
@@ -1,78 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.action;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-/**
- * Set source transport port action
- *
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class SetTpSrc extends Action {
-    private static final long serialVersionUID = 1L;
-    @XmlElement
-    private int port;
-
-    /* Dummy constructor for JAXB */
-    @SuppressWarnings("unused")
-    private SetTpSrc() {
-    }
-
-    public SetTpSrc(int port) {
-        type = ActionType.SET_TP_SRC;
-        this.port = port;
-        checkValue(port);
-    }
-
-    /**
-     * Returns the transport port the action will set
-     *
-     * @return
-     */
-    public int getPort() {
-        return port;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (!super.equals(obj)) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        SetTpSrc other = (SetTpSrc) obj;
-        if (port != other.port) {
-            return false;
-        }
-        return true;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = super.hashCode();
-        result = prime * result + port;
-        return result;
-    }
-
-    @Override
-    public String toString() {
-        return type + "[port = " + port + "]";
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/SetVlanCfi.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/SetVlanCfi.java
deleted file mode 100644 (file)
index e71bb68..0000000
+++ /dev/null
@@ -1,78 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.action;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-/**
- * Set vlan CFI action
- *
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class SetVlanCfi extends Action {
-    private static final long serialVersionUID = 1L;
-    @XmlElement
-    private int cfi;
-
-    /* Dummy constructor for JAXB */
-    @SuppressWarnings("unused")
-    private SetVlanCfi() {
-    }
-
-    public SetVlanCfi(int cfi) {
-        type = ActionType.SET_VLAN_CFI;
-        this.cfi = cfi;
-        checkValue(cfi);
-    }
-
-    /**
-     * Returns the 802.1q CFI value that this action will set
-     *
-     * @return
-     */
-    public int getCfi() {
-        return cfi;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (!super.equals(obj)) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        SetVlanCfi other = (SetVlanCfi) obj;
-        if (cfi != other.cfi) {
-            return false;
-        }
-        return true;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = super.hashCode();
-        result = prime * result + cfi;
-        return result;
-    }
-
-    @Override
-    public String toString() {
-        return type + "[cfi = " + Integer.toHexString(cfi) + "]";
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/SetVlanId.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/SetVlanId.java
deleted file mode 100644 (file)
index e06159b..0000000
+++ /dev/null
@@ -1,78 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.action;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-/**
- * Set vlan id action
- */
-
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class SetVlanId extends Action {
-    private static final long serialVersionUID = 1L;
-    @XmlElement
-    private int vlanId;
-
-    @SuppressWarnings("unused")
-    private SetVlanId() {
-
-    }
-
-    public SetVlanId(int vlanId) {
-        type = ActionType.SET_VLAN_ID;
-        this.vlanId = vlanId;
-        checkValue(vlanId);
-    }
-
-    /**
-     * Returns the vlan id this action will set
-     *
-     * @return int
-     */
-    public int getVlanId() {
-        return vlanId;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (!super.equals(obj)) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        SetVlanId other = (SetVlanId) obj;
-        if (vlanId != other.vlanId) {
-            return false;
-        }
-        return true;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = super.hashCode();
-        result = prime * result + vlanId;
-        return result;
-    }
-
-    @Override
-    public String toString() {
-        return type + "[vlanId = " + vlanId + "]";
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/SetVlanPcp.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/SetVlanPcp.java
deleted file mode 100644 (file)
index 31afbf3..0000000
+++ /dev/null
@@ -1,77 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.action;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-/**
- * Set vlan PCP action
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class SetVlanPcp extends Action {
-    private static final long serialVersionUID = 1L;
-    @XmlElement
-    private int pcp;
-
-    @SuppressWarnings("unused")
-    private SetVlanPcp() {
-
-    }
-
-    public SetVlanPcp(int pcp) {
-        type = ActionType.SET_VLAN_PCP;
-        this.pcp = pcp;
-        checkValue(pcp);
-    }
-
-    /**
-     * Returns the value of the vlan PCP this action will set
-     *
-     * @return int
-     */
-    public int getPcp() {
-        return pcp;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (!super.equals(obj)) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        SetVlanPcp other = (SetVlanPcp) obj;
-        if (pcp != other.pcp) {
-            return false;
-        }
-        return true;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = super.hashCode();
-        result = prime * result + pcp;
-        return result;
-    }
-
-    @Override
-    public String toString() {
-        return type + "[pcp = " + Integer.toHexString(pcp) + "]";
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/SupportedFlowActions.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/SupportedFlowActions.java
deleted file mode 100644 (file)
index 4fd6531..0000000
+++ /dev/null
@@ -1,100 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.action;
-
-import java.util.ArrayList;
-import java.util.Collections;
-import java.util.List;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-
-import org.opendaylight.controller.sal.core.Property;
-
-/**
- * @file SupportedFlowActions.java
- *
- * @brief Class representing the supported flow actions
- *
- *        Describes the supported flow actions
- */
-
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class SupportedFlowActions extends Property {
-    private static final long serialVersionUID = 1L;
-    public static final String SupportedFlowActionsPropName = "supportedFlowActions";
-    private List<Class<? extends Action>> actions;
-
-    private SupportedFlowActions() {
-        super(SupportedFlowActionsPropName);
-        this.actions = new ArrayList<Class<? extends Action>>();
-    }
-
-    public SupportedFlowActions(List<Class<? extends Action>> actions) {
-        super(SupportedFlowActionsPropName);
-        this.actions = new ArrayList<Class<? extends Action>>(actions);
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = super.hashCode();
-        result = prime * result + ((actions == null) ? 0 : actions.hashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (!super.equals(obj)) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        SupportedFlowActions other = (SupportedFlowActions) obj;
-        if (actions == null) {
-            if (other.actions != null) {
-                return false;
-            }
-        } else if (!actions.equals(other.actions)) {
-            return false;
-        }
-        return true;
-    }
-
-    public List<Class<? extends Action>> getActions() {
-        return new ArrayList<Class<? extends Action>>(this.actions);
-    }
-
-    @XmlElement(name = "value")
-    @Override
-    public String getStringValue() {
-        List<String> nameList = new ArrayList<String>();
-        for (Class<? extends Action> clazz : actions) {
-            nameList.add(clazz.getSimpleName());
-        }
-        Collections.sort(nameList);
-        return nameList.toString();
-    }
-
-    @Override
-    public Property clone() {
-        return new SupportedFlowActions(this.actions);
-    }
-
-    @Override
-    public String toString() {
-        return this.getStringValue();
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/SwPath.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/action/SwPath.java
deleted file mode 100644 (file)
index e700d25..0000000
+++ /dev/null
@@ -1,28 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.action;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlRootElement;
-
-/**
- * Represents the action of sending the packet to the local software path for
- * processing
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class SwPath extends Action {
-    private static final long serialVersionUID = 1L;
-
-    public SwPath() {
-        type = ActionType.SW_PATH;
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/authorization/AppRole.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/authorization/AppRole.java
deleted file mode 100644 (file)
index c36f981..0000000
+++ /dev/null
@@ -1,45 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.authorization;
-
-import java.io.Serializable;
-
-/**
- * Represents a user role level in the application space
- * It contains the role name and the role level in the
- * application context as specified by {@link AppRoleLevel}
- */
-@Deprecated
-public class AppRole implements Serializable {
-    private static final long serialVersionUID = 1L;
-    String name;
-    AppRoleLevel level;
-
-    public AppRole(String name, AppRoleLevel level) {
-        this.name = name;
-        this.level = level;
-    }
-
-    /**
-     * Returns the application role name
-     * @return the string containing the role name
-     */
-    public String getName() {
-        return name;
-    }
-
-    /**
-     * Returns the application role level
-     * @return the application user level
-     */
-    public AppRoleLevel getLevel() {
-        return level;
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/authorization/AppRoleLevel.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/authorization/AppRoleLevel.java
deleted file mode 100644 (file)
index 98ac26e..0000000
+++ /dev/null
@@ -1,56 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.authorization;
-
-import java.io.Serializable;
-
-/**
- * Represents the application user role levels
- * This level has meaning only inside the application context
- * In the controller space such a role will be seen as <code>APPUSER<code>
- * as specified in {@link UserLevel}
- */
-@Deprecated
-public enum AppRoleLevel implements Serializable {
-    APPADMIN(0, "App-Admin", "Application Administrator"), APPUSER(1,
-            "App-User", "Application User"), APPOPERATOR(2, "App-Operator",
-            "Application Operator"), NOUSER(255, "Unknown User", "Unknown User");
-
-    private int userLevel;
-    private String level;
-    private String prettyLevel;
-
-    private AppRoleLevel(int userlevel, String level, String prettyLevel) {
-        this.userLevel = userlevel;
-        this.level = level;
-        this.prettyLevel = prettyLevel;
-    }
-
-    public int toNumber() {
-        return this.userLevel;
-    }
-
-    public String toString() {
-        return this.level;
-    }
-
-    public String toStringPretty() {
-        return this.prettyLevel;
-    }
-
-    public static AppRoleLevel fromString(String levelString) {
-        for (AppRoleLevel rolelevel : AppRoleLevel.values()) {
-                if (rolelevel.toString().equals(levelString)) {
-                        return rolelevel;
-                }
-        }
-        return null;
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/authorization/AuthResultEnum.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/authorization/AuthResultEnum.java
deleted file mode 100644 (file)
index 05801be..0000000
+++ /dev/null
@@ -1,53 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * Defines the enumerated values for possible results of an Authentication
- * request made from a AAA client to a AAA server.
- */
-
-package org.opendaylight.controller.sal.authorization;
-
-import java.io.Serializable;
-
-@Deprecated
-public enum AuthResultEnum implements Serializable {
-    AUTH_NONE("AUTH_NOT_ATTEMPTED"), AUTH_ACCEPT("AUTHENTICATION_ACCEPTED"), // request accepted
-    AUTH_REJECT("AUTHENTICATION_REJECTED"), // request rejected
-    AUTH_TIMEOUT("AUTHENTICATION_TIMEDOUT"), // request timeout
-    AUTH_USERNAME_EMPTY("AUTHENTICATION_USERNAME_EMPTY"), // user name is empty
-    AUTH_PASSWORD_EMPTY("AUTHENTICATION_PASSWORD_EMPTY"), // password is empty
-    AUTH_SECRET_EMPTY("AUTHENTICATION_SECRET_EMPTY"), // secret is empty
-    AUTH_COMM_ERROR("AUTHENTICATION_COMM_ERROR"), // communication channel problem
-    AUTH_INVALID_ADDR("AUTHENTICATION_INVALID_ADDR"), // invalid network address
-    AUTH_INVALID_PACKET("AUTHENTICATION_INVALID_PACKET"), // invalid packets or malformed attributes
-
-    /*
-     * Local AAA values
-     */
-    AUTH_ACCEPT_LOC("AUTHENTICATION_ACCEPTED"), // request accepted on local database
-    AUTH_REJECT_LOC("AUTHENTICATION_REJECTED"), // request rejected on local database
-    AUTH_INVALID_LOC_USER("INALID_LOCAL_USER"),
-
-    /*
-     * Authorization
-     */
-    AUTHOR_PASS("AUTHORIZATION_PASSED"), AUTHOR_FAIL("AUTHORIZATION_FAILED"), AUTHOR_ERROR(
-            "AUTHORIZATION_SERVER_ERROR");
-
-    private AuthResultEnum(String name) {
-        this.name = name;
-    }
-
-    private String name;
-
-    public String toString() {
-        return name;
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/authorization/IResourceAuthorization.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/authorization/IResourceAuthorization.java
deleted file mode 100644 (file)
index 0468ebd..0000000
+++ /dev/null
@@ -1,229 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.authorization;
-
-import java.util.List;
-import java.util.Set;
-
-import org.opendaylight.controller.sal.utils.Status;
-
-/**
- * Interface for applications which maintain an authorization
- * database for their resources. Respective application web bundle
- * and User Manager make use of this interface to retrieve
- * authorization information at user or and role level.
- */
-@Deprecated
-public interface IResourceAuthorization {
-
-    /**
-     * Create a Role name for the application
-     *
-     * @param role  the role name
-     * @param userLevel the user level in the application context
-     * @return the status of the request
-     */
-    public Status createRole(String role, AppRoleLevel userLevel);
-
-    /**
-     * Remove a Role
-     *
-     * @param role the role name
-     * @return the status of the request
-     */
-    public Status removeRole(String role);
-
-    /**
-     * Return the list of roles configured for the application
-     *
-     * @return the list of roles
-     */
-    public List<String> getRoles();
-
-    /**
-     * Returns the application role level for the specified role. If the role is
-     * not known to this application NOUSER will be returned as specified in
-     * {@link AppRoleLevel}
-     *
-     * @param roleName
-     *            the role name to query
-     * @return the application level of the given role in the application
-     *         context as specified by {@link AppRoleLevel}. If the role is not
-     *         part of this application's roles, NOUSER is returned.
-     */
-    public AppRoleLevel getApplicationRoleLevel(String roleName);
-
-    /**
-     * Returns whether the specified role is part of this application's roles
-     *
-     * @param roleName the role name to test
-     * @return  true if the role belongs to this application, false otherwise
-     */
-    public boolean isApplicationRole(String roleName);
-
-    /**
-     * Create a resource group for application.
-     *
-     * NOTE: Resource addition is "best effort", if an object is not of correct type,
-     * it is discarded.
-     *
-     * @param groupName
-     *            the name for the resource group
-     * @param resources
-     *            the list of resources for the group
-     * @return the status of the request
-     */
-    public Status createResourceGroup(String groupName, List<Object> resources);
-
-    /**
-     * Removes a resource group
-     *
-     * @param groupName the name of the group
-     * @return the status of the request
-     */
-    public Status removeResourceGroup(String groupName);
-
-    /**
-     * Returns the list of resource groups configured for the application
-     *
-     * @return the list of resource group names
-     */
-    public List<String> getResourceGroups();
-
-    /**
-     * Assign a resource group to a role
-     *
-     * @param groupName the name of the resource group
-     * @param privilege the access privilege role will have on the resource group
-     * @param role the role name
-     * @return the status of the request
-     */
-    @Deprecated
-    public Status assignResourceGroupToRole(String groupName,
-            Privilege privilege, String role);
-
-    /**
-     * Assign a resource group to a role. The access privilege on the resources
-     * is inferred by the AppRoleLevel associated to role.
-     *
-     * @param groupName the name of the resource group
-     * @param role the role name
-     * @return the status of the request
-     */
-    public Status assignResourceGroupToRole(String groupName, String role);
-
-    /**
-     * Unassign the passed resource group from the specified role
-     *
-     * @param groupName the name of the resource group
-     * @param role the role name
-     * @return the status of the request
-     */
-    public Status unassignResourceGroupFromRole(String groupName, String role);
-
-    /**
-     * Returns the list of resource groups the given Role is authorized to use
-     * The returning object expresses the resource group name and the access
-     * its privilege for the given user role
-     *
-     * @param role  the role name
-     * @return list of resources
-     */
-    public List<ResourceGroup> getAuthorizedGroups(String role);
-
-    /**
-     * Returns the list of resources contained in the given resource group
-     *
-     * @param groupName the resource group name
-     * @return
-     */
-    public List<Object> getResources(String groupName);
-
-    /**
-     * Returns the list of authorized resources for the given role
-     * For each resource only the highest privilege occurrence is returned
-     * @param role  the role name
-     * @return the list of Resource
-     */
-    public List<Resource> getAuthorizedResources(String role);
-
-    /*
-     * Per user name API
-     */
-    /**
-     * Returns the controller user role level the passed user name is associated with
-     *
-     * @param userName the user name
-     * @return the user role level as specified in {@link UserLevel}
-     */
-    public UserLevel getUserLevel(String userName);
-
-    /**
-     * Returns the application context user role level the passed user name is associated with
-     *
-     * @param userName the user name
-     * @return the user role level as specified in {@link AppRoleLevel}
-     */
-    public AppRoleLevel getUserApplicationLevel(String userName);
-
-    /**
-     * Returns the list of resources (resource + privilege) associated
-     * with the passed user name for this application context
-     * For each resource only the highest privilege occurrence is returned
-     *
-     * @param userName the user name
-     * @return the list of resources associated with this user name in this application context
-     */
-    public Set<Resource> getAllResourcesforUser(String userName);
-
-    /**
-     * Returns the highest privilege that the user has on the specified
-     * resource in this application context
-     *
-     * @param userName the user name
-     * @param resource the given resource
-     * @return the privilege the user has on the passed resource
-     */
-    public Privilege getResourcePrivilege(String userName, Object resource);
-
-    /**
-     * Add a resource to a group
-     *
-     * @param groupName
-     *            the resource group
-     * @param resource
-     *            the resource object
-     * @return the status of the request
-     */
-    public Status addResourceToGroup(String groupName, Object resource);
-
-    /**
-     * Remove a resource from a group
-     *
-     * @param groupName
-     *            the resource group
-     * @param resource
-     *            the resource object
-     * @return the status of the request
-     */
-    public Status removeResourceFromGroup(String groupName, Object resource);
-
-    /**
-     * Return whether the specified user has access to this application. In
-     * other words if the user is associated any roles belonging to this
-     * application.
-     *
-     * @param userName
-     *            the user name
-     * @return true if the user has access to this application's resources,
-     *         false otherwise
-     */
-    boolean isApplicationUser(String userName);
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/authorization/Privilege.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/authorization/Privilege.java
deleted file mode 100644 (file)
index e3d3217..0000000
+++ /dev/null
@@ -1,35 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.authorization;
-
-import java.io.Serializable;
-
-/**
- * It represents the group/resource access privilege
- */
-@Deprecated
-public enum Privilege implements Serializable {
-    NONE(""), // no privilege
-    READ("r"), // read only
-    USE("u"), // use
-    WRITE("w"); // modify
-
-    private String p;
-
-    private Privilege(String p) {
-        this.p = p;
-    }
-
-    @Override
-    public String toString() {
-        return p;
-    }
-
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/authorization/Resource.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/authorization/Resource.java
deleted file mode 100644 (file)
index 9fa8b2e..0000000
+++ /dev/null
@@ -1,71 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.authorization;
-
-import java.io.Serializable;
-
-/**
- * It represents the elementary resource along with
- * the access privilege associated to it
- */
-@Deprecated
-public class Resource implements Serializable {
-    private static final long serialVersionUID = 1L;
-    Object resource; // the generic resource
-    Privilege privilege; // read/use/write privilege
-
-    public Resource(Object resource, Privilege privilege) {
-        this.resource = resource;
-        this.privilege = privilege;
-    }
-
-    public Object getResource() {
-        return resource;
-    }
-
-    public Privilege getPrivilege() {
-        return privilege;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result
-                + ((privilege == null) ? 0 : privilege.hashCode());
-        result = prime * result
-                + ((resource == null) ? 0 : resource.hashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj)
-            return true;
-        if (obj == null)
-            return false;
-        if (getClass() != obj.getClass())
-            return false;
-        Resource other = (Resource) obj;
-        if (privilege != other.privilege)
-            return false;
-        if (resource == null) {
-            if (other.resource != null)
-                return false;
-        } else if (!resource.equals(other.resource))
-            return false;
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        return "[" + resource + ", " + privilege.toString() + "]";
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/authorization/ResourceGroup.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/authorization/ResourceGroup.java
deleted file mode 100644 (file)
index f5b4448..0000000
+++ /dev/null
@@ -1,81 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.authorization;
-
-import java.io.Serializable;
-
-/**
- * Represents a group of resources along with the privilege associated to it
- *
- *
- *
- */
-@Deprecated
-public class ResourceGroup implements Serializable {
-    private static final long serialVersionUID = 1L;
-    private String groupName; // the resource group name
-    private Privilege privilege; // the privilege for this profile on the resource group
-
-    public ResourceGroup(String groupName, Privilege privilege) {
-        this.groupName = groupName;
-        this.privilege = privilege;
-    }
-
-    /**
-     * Returns the name for this resource group
-     * @return
-     */
-    public String getGroupName() {
-        return groupName;
-    }
-
-    /**
-     * Returns the privilege for this group on its resources
-     * @return
-     */
-    public Privilege getPrivilege() {
-        return privilege;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result
-                + ((groupName == null) ? 0 : groupName.hashCode());
-        result = prime * result
-                + ((privilege == null) ? 0 : privilege.hashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj)
-            return true;
-        if (obj == null)
-            return false;
-        if (getClass() != obj.getClass())
-            return false;
-        ResourceGroup other = (ResourceGroup) obj;
-        if (groupName == null) {
-            if (other.groupName != null)
-                return false;
-        } else if (!groupName.equals(other.groupName))
-            return false;
-        if (privilege != other.privilege)
-            return false;
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        return "[" + groupName + ", " + privilege.toString() + "]";
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/authorization/UserLevel.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/authorization/UserLevel.java
deleted file mode 100644 (file)
index f4db119..0000000
+++ /dev/null
@@ -1,47 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.authorization;
-
-import java.io.Serializable;
-
-/**
- * Describes the user role level in the controller space
- */
-@Deprecated
-public enum UserLevel implements Serializable {
-    SYSTEMADMIN(0, "System-Admin", "System Administrator"),     // can do everything
-    NETWORKADMIN(1, "Network-Admin", "Network Administrator"),  // can do everything but setting a system admin user profile
-    NETWORKOPERATOR(2, "Network-Operator", "Network Operator"), // can only see what is configured anywhere
-    CONTAINERUSER(4, "Container-User", "Container User"),       // container context user
-    APPUSER(5, "App-User", "Application User"),                                 // application context user
-    NOUSER(255, "Not Authorized", "Not Authorized");
-
-    private int userLevel;
-    private String level;
-    private String prettyLevel;
-
-    private UserLevel(int userlevel, String level, String prettyLevel) {
-        this.userLevel = userlevel;
-        this.level = level;
-        this.prettyLevel = prettyLevel;
-    }
-
-    public int toNumber() {
-        return this.userLevel;
-    }
-
-    public String toString() {
-        return this.level;
-    }
-
-    public String toStringPretty() {
-        return this.prettyLevel;
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/Actions.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/Actions.java
deleted file mode 100644 (file)
index b3fa45b..0000000
+++ /dev/null
@@ -1,121 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.core;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-/**
- * @file   Actions.java
- *
- * @brief  Class representing actions
- *
- * Describes supported actions
- * @Deprecated This class is OF 1.0 specific. Use SupportedFlowActions instead.
- */
-@Deprecated
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-public class Actions extends Property {
-        private static final long serialVersionUID = 1L;
-    @XmlElement(name="value")
-    private int actionsValue;
-
-    public enum ActionType {
-        OUTPUT_PORT_ACTION(1<<0),
-        VLAN_VID_ACTION(1<<1),
-        VLAN_PCP_ACTION(1<<2),
-        VLAN_STRIP_ACTION(1<<3),
-        DLSRC_ACTION(1<<4),
-        DLDST_ACTION(1<<5),
-        NWSRC_ACTION(1<<6),
-        NWDST_ACTION(1<<7),
-        NWTOS_ACTION(1<<8),
-        TPTSRC_ACTION(1<<9),
-        TPTDST_ACTION(1<<10),
-        ENQUEUE_ACTION(1<<11),
-        VENDOR_ACTION(0xffff);
-        private final int at;
-        ActionType(int val) {
-                this.at = val;
-        }
-        public int getValue() {
-                return at;
-        }
-    }
-
-    public static final String ActionsPropName = "actions";
-    /**
-     * Construct a actions property
-     *
-     * @param actions the actions value
-     * @return Constructed object
-     */
-    public Actions(int actions) {
-        super(ActionsPropName);
-        this.actionsValue = actions;
-    }
-
-    /*
-     * Private constructor used for JAXB mapping
-     */
-    private Actions() {
-        super(ActionsPropName);
-        this.actionsValue = 0;
-    }
-
-    @Override
-    public Actions clone() {
-        return new Actions(this.actionsValue);
-    }
-
-    public int getValue() {
-        return this.actionsValue;
-    }
-
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = super.hashCode();
-        result = prime * result + actionsValue;
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (!super.equals(obj)) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        Actions other = (Actions) obj;
-        if (actionsValue != other.actionsValue) {
-            return false;
-        }
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        return "Actions[" + actionsValue + "]";
-    }
-
-    @Override
-    public String getStringValue() {
-        return Integer.toHexString(actionsValue);
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/AdvertisedBandwidth.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/AdvertisedBandwidth.java
deleted file mode 100644 (file)
index be42a59..0000000
+++ /dev/null
@@ -1,58 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.core;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlRootElement;
-
-/**
- * @file   AdvertisedBandWidth.java
- *
- * @brief  Class representing advertised bandwidth
- *
- * Describes Advertised Bandwidth which could be of a link or whatever could have
- * bandwidth as description. It's intended in multiple of bits per
- * seconds.
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@SuppressWarnings("serial")
-@Deprecated
-public class AdvertisedBandwidth extends Bandwidth {
-        public static final String AdvertisedBandwidthPropName = "advertisedBandwidth";
-
-        public AdvertisedBandwidth(long value) {
-                super(AdvertisedBandwidthPropName);
-                this.bandwidthValue = value;
-        }
-
-        /*
-     * Private constructor used for JAXB mapping
-     */
-    private AdvertisedBandwidth() {
-        super(AdvertisedBandwidthPropName);
-                this.bandwidthValue = 0;
-    }
-
-        public AdvertisedBandwidth clone() {
-                return new AdvertisedBandwidth(this.bandwidthValue);
-    }
-
-    @Override
-    public String toString() {
-        StringBuffer sb = new StringBuffer();
-        sb.append("AdvertisedBandWidth[");
-        sb.append(super.toString());
-        sb.append("]");
-        return sb.toString();
-    }
-
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/Bandwidth.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/Bandwidth.java
deleted file mode 100644 (file)
index 4fd962a..0000000
+++ /dev/null
@@ -1,132 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.core;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-/**
- * @file   BandWidth.java
- *
- * @brief  Class representing bandwidth
- *
- * Describe Bandwidth which could be of a link or whatever could have
- * bandwidth as description. It's intended in multiple of bits per
- * seconds.
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class Bandwidth extends Property {
-    private static final long serialVersionUID = 1L;
-
-    @XmlElement(name="value")
-    protected long bandwidthValue;
-
-    public static final long BWUNK = 0;
-    public static final long BW1Kbps = (long) Math.pow(10, 3);
-    public static final long BW1Mbps = (long) Math.pow(10, 6);
-    public static final long BW10Mbps = (long) Math.pow(10, 7);
-    public static final long BW100Mbps = (long) Math.pow(10, 8);
-    public static final long BW1Gbps = (long) Math.pow(10, 9);
-    public static final long BW10Gbps = (long) Math.pow(10, 10);
-    public static final long BW40Gbps = 4 * (long) Math.pow(10, 10);
-    public static final long BW100Gbps = (long) Math.pow(10, 11);
-    public static final long BW400Gbps = 4 * (long) Math.pow(10, 11);
-    public static final long BW1Tbps = (long) Math.pow(10, 12);
-    public static final long BW1Pbps = (long) Math.pow(10, 15);
-
-    public static final String BandwidthPropName = "bandwidth";
-
-    /*
-     * Private constructor used for JAXB mapping
-     */
-    private Bandwidth() {
-        super(BandwidthPropName);
-        this.bandwidthValue = BWUNK;
-    }
-
-    public Bandwidth(long bandwidth) {
-        super(BandwidthPropName);
-        this.bandwidthValue = bandwidth;
-    }
-
-    public Bandwidth(int bandwidth) {
-        super(BandwidthPropName);
-        this.bandwidthValue = (long) bandwidth;
-    }
-
-    public Bandwidth(short bandwidth) {
-        super(BandwidthPropName);
-        this.bandwidthValue = (long) bandwidth;
-    }
-
-    public Bandwidth(String name) {
-        super(name);
-    }
-
-    @Override
-    public Bandwidth clone() {
-        return new Bandwidth(this.bandwidthValue);
-    }
-
-    public long getValue() {
-        return this.bandwidthValue;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = super.hashCode();
-        result = prime * result
-                + (int) (bandwidthValue ^ (bandwidthValue >>> 32));
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj)
-            return true;
-        if (!super.equals(obj))
-            return false;
-        if (getClass() != obj.getClass())
-            return false;
-        Bandwidth other = (Bandwidth) obj;
-        if (bandwidthValue != other.bandwidthValue)
-            return false;
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        return "BandWidth[" + getStringValue() + "]";
-    }
-
-    @Override
-    public String getStringValue() {
-        if (this.bandwidthValue == 0) {
-            return("UnKnown");
-        } else if (this.bandwidthValue < BW1Kbps) {
-            return(this.bandwidthValue + "bps");
-        } else if (this.bandwidthValue < BW1Mbps) {
-            return(Long.toString(this.bandwidthValue / BW1Kbps) + "Kbps");
-        } else if (this.bandwidthValue < BW1Gbps) {
-            return(Long.toString(this.bandwidthValue / BW1Mbps) + "Mbps");
-        } else if (this.bandwidthValue < BW1Tbps) {
-            return(Long.toString(this.bandwidthValue / BW1Gbps) + "Gbps");
-        } else if (this.bandwidthValue < BW1Pbps) {
-            return(Long.toString(this.bandwidthValue / BW1Tbps) + "Tbps");
-        } else {
-            return(this.bandwidthValue + "bps");
-        }
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/Buffers.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/Buffers.java
deleted file mode 100644 (file)
index 010d903..0000000
+++ /dev/null
@@ -1,93 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.core;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-/**
- * @file   Buffers.java
- *
- * @brief  Class representing buffers
- *
- * Describes supported buffers (#packets)
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class Buffers extends Property {
-        private static final long serialVersionUID = 1L;
-    @XmlElement(name="value")
-    private int buffersValue;
-
-    public static final String BuffersPropName = "buffers";
-
-    /**
-     * Construct a Buffers property
-     *
-     * @param buffers the Buffers
-     * @return Constructed object
-     */
-    public Buffers(int buffers) {
-        super(BuffersPropName);
-        this.buffersValue = buffers;
-    }
-
-    /*
-     * Private constructor used for JAXB mapping
-     */
-    private Buffers() {
-        super(BuffersPropName);
-        this.buffersValue = 0;
-    }
-
-    @Override
-    public Buffers clone() {
-        return new Buffers(this.buffersValue);
-    }
-
-    public int getValue() {
-        return this.buffersValue;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = super.hashCode();
-        result = prime * result + buffersValue;
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj)
-            return true;
-        if (!super.equals(obj))
-            return false;
-        if (getClass() != obj.getClass())
-            return false;
-        Buffers other = (Buffers) obj;
-        if (buffersValue != other.buffersValue)
-            return false;
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        return "Buffers[" + buffersValue + "]";
-    }
-
-    @Override
-    public String getStringValue() {
-        return Integer.toHexString(buffersValue);
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/Capabilities.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/Capabilities.java
deleted file mode 100644 (file)
index d6a9458..0000000
+++ /dev/null
@@ -1,110 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.core;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-/**
- * @file   Capabilities.java
- *
- * @brief  Class representing capabilities
- *
- * Describes supported capabilities
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class Capabilities extends Property {
-        private static final long serialVersionUID = 1L;
-    @XmlElement(name="value")
-    private int capabilitiesValue;
-
-    public enum CapabilitiesType {
-        FLOW_STATS_CAPABILITY(1<<0),
-        TABLE_STATS_CAPABILITY(1<<1),
-        PORT_STATS_CAPABILITY(1<<2),
-        STP_CAPABILITY(1<<3),
-        RSVD_CAPABILITY(1<<4),
-        IP_REASSEM_CAPABILITY(1<<5),
-        QUEUE_STATS_CAPABILITY(1<<6),
-        ARP_MATCH_IP_CAPABILITY(1<<7);
-        private final int ct;
-        CapabilitiesType(int val) {
-                this.ct = val;
-        }
-        public int getValue() {
-                return ct;
-        }
-    }
-
-    public static final String CapabilitiesPropName = "capabilities";
-    /**
-     * Construct a Capabilities property
-     *
-     * @param capabilities the Capabilities value
-     * @return Constructed object
-     */
-    public Capabilities(int capabilities) {
-        super(CapabilitiesPropName);
-        this.capabilitiesValue = capabilities;
-    }
-
-    /*
-     * Private constructor used for JAXB mapping
-     */
-    private Capabilities() {
-        super(CapabilitiesPropName);
-        this.capabilitiesValue = 0;
-    }
-
-    @Override
-    public Capabilities clone() {
-        return new Capabilities(this.capabilitiesValue);
-    }
-
-    public int getValue() {
-        return this.capabilitiesValue;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = super.hashCode();
-        result = prime * result + capabilitiesValue;
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj)
-            return true;
-        if (!super.equals(obj))
-            return false;
-        if (getClass() != obj.getClass())
-            return false;
-        Capabilities other = (Capabilities) obj;
-        if (capabilitiesValue != other.capabilitiesValue)
-            return false;
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        return "Capabilities[" + capabilitiesValue + "]";
-    }
-
-    @Override
-    public String getStringValue() {
-        return Integer.toHexString(capabilitiesValue);
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/ComponentActivatorAbstractBase.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/ComponentActivatorAbstractBase.java
deleted file mode 100644 (file)
index eb4ed5f..0000000
+++ /dev/null
@@ -1,470 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.core;
-
-/**
- * @file   ComponentActivatorAbstractBase.java
- *
- * @brief  Abstract class which need to be subclassed in order to
- * track and register dependencies per-container
- *
- * Abstract class which need to be subclassed in order to
- * track and register dependencies per-container
- *
- */
-
-import java.util.Dictionary;
-import java.util.Hashtable;
-import java.util.concurrent.ConcurrentHashMap;
-import java.util.concurrent.ConcurrentMap;
-
-import org.apache.commons.lang3.tuple.ImmutablePair;
-import org.apache.felix.dm.Component;
-import org.apache.felix.dm.ComponentStateListener;
-import org.apache.felix.dm.DependencyManager;
-import org.apache.felix.dm.ServiceDependency;
-import org.osgi.framework.BundleActivator;
-import org.osgi.framework.BundleContext;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * Abstract class which need to be subclassed in order to track and
- * register dependencies per-container
- *
- */
-@Deprecated
-abstract public class ComponentActivatorAbstractBase implements
-        BundleActivator, IContainerAware {
-    Logger logger = LoggerFactory
-            .getLogger(ComponentActivatorAbstractBase.class);
-    private DependencyManager dm;
-    private ConcurrentMap<ImmutablePair<String, Object>, Component> dbInstances = new ConcurrentHashMap<ImmutablePair<String, Object>, Component>();
-    private ConcurrentMap<Object, Component> dbGlobalInstances = new ConcurrentHashMap<Object, Component>();
-
-    /**
-     * Method that should be overriden by the derived class for customization
-     * during activation of the Component bundle in a container.
-     */
-    protected void init() {
-
-    }
-
-    /**
-     * Method that should be overriden by the derived class for customization
-     * during DE-activation of the Component bundle in a container.
-     */
-    public void destroy() {
-
-    }
-
-    /**
-     * Method which tells how many implementations are supported by
-     * the bundle. This way we can tune the number of components
-     * created.
-     *
-     *
-     * @return The list of implementations the bundle will support,
-     * this will be used to decide how many components need to be
-     * created per-container
-     */
-    protected Object[] getImplementations() {
-        return null;
-    }
-
-    /**
-     * Method which tells how many Global implementations are
-     * supported by the bundle. This way we can tune the number of
-     * components created. This components will be created ONLY at the
-     * time of bundle startup and will be destroyed only at time of
-     * bundle destruction, this is the major difference with the
-     * implementation retrieved via getImplementations where all of
-     * them are assumed to be in a container!
-     *
-     *
-     * @return The list of implementations the bundle will support,
-     * in Global version
-     */
-    protected Object[] getGlobalImplementations() {
-        return null;
-    }
-
-    /**
-     * Configure the dependency for a given instance inside a container
-     *
-     * @param c Component assigned for this instance, this will be
-     * what will be used for configuration
-     * @param imp implementation to be configured
-     * @param containerName container on which the configuration happens
-     */
-    protected void configureInstance(Component c, Object imp,
-            String containerName) {
-        // do nothing by default
-    }
-
-    /**
-     * Configure the dependency for a given instance Global
-     *
-     * @param c Component assigned for this instance, this will be
-     * what will be used for configuration
-     * @param imp implementation to be configured
-     * @param containerName container on which the configuration happens
-     */
-    protected void configureGlobalInstance(Component c, Object imp) {
-        // Do nothing by default
-    }
-
-    // Private class used to listen to state transition so we can
-    // implement the necessary logic to call "started" and "stopping"
-    // methods on the component. Right now the framework natively
-    // support only the call of:
-    // - "init": Called after dependency are satisfied
-    // - "start": Called after init but before services are registered
-    // - "stop": Called after services are unregistered but before the
-    // component is going to be destroyed
-    // - "destroy": Called to destroy the component.
-    // There is still a need for two notifications:
-    // - "started" method to be called after "start" and after the
-    // services has been registered in the OSGi service registry
-    // - "stopping" method to be called before "stop" method and
-    // before the services of the component are removed from OSGi
-    // service registry
-    class ListenerComponentStates implements ComponentStateListener {
-        @Override
-        public void starting(Component component) {
-            // do nothing
-        }
-
-        @Override
-        public void started(Component component) {
-            if (component == null) {
-                return;
-            }
-            component.invokeCallbackMethod(new Object[] { component
-                    .getService() }, "started", new Class[][] {
-                    { Component.class }, {} }, new Object[][] { { component },
-                    {} });
-        }
-
-        @Override
-        public void stopped(Component component) {
-            // do nothing
-        }
-
-        @Override
-        public void stopping(Component component) {
-            if (component == null) {
-                return;
-            }
-            component.invokeCallbackMethod(new Object[] { component
-                    .getService() }, "stopping", new Class[][] {
-                    { Component.class }, {} }, new Object[][] { { component },
-                    {} });
-        }
-    }
-
-    /**
-     * Method of IContainerAware called when a new container is available
-     *
-     * @param containerName Container being created
-     */
-    @Override
-    public void containerCreate(String containerName) {
-        try {
-            Object[] imps = getImplementations();
-            logger.trace("Creating instance {}", containerName);
-            if (imps != null) {
-                for (int i = 0; i < imps.length; i++) {
-                    ImmutablePair<String, Object> key = new ImmutablePair<String, Object>(
-                            containerName, imps[i]);
-                    Component c = this.dbInstances.get(key);
-                    if (c == null) {
-                        c = this.dm.createComponent();
-                        c.addStateListener(new ListenerComponentStates());
-                        // Now let the derived class to configure the
-                        // dependencies it wants
-                        configureInstance(c, imps[i], containerName);
-                        // Set the implementation so the component can manage
-                        // its lifecycle
-                        if (c.getService() == null) {
-                            logger.trace("Setting implementation to: {}",
-                                          imps[i]);
-                            c.setImplementation(imps[i]);
-                        }
-
-                        //Set the service properties to include the containerName
-                        //in the service, that is fundamental for supporting
-                        //multiple services just distinguished via a container
-                        @SuppressWarnings("unchecked")
-                        Dictionary<String, String> serviceProps = c
-                                .getServiceProperties();
-                        if (serviceProps != null) {
-                            logger.trace("Adding new property for container");
-                            serviceProps.put("containerName", containerName);
-                        } else {
-                            logger
-                                    .trace("Create a new properties for the service");
-                            serviceProps = new Hashtable<String, String>();
-                            serviceProps.put("containerName", containerName);
-                        }
-                        c.setServiceProperties(serviceProps);
-
-                        // Now add the component to the dependency Manager
-                        // which will immediately start tracking the dependencies
-                        this.dm.add(c);
-
-                        //Now lets keep track in our shadow database of the
-                        //association
-                        this.dbInstances.put(key, c);
-                    } else {
-                        logger
-                                .error("I have been asked again to create an instance "
-                                        + "on: "
-                                        + containerName
-                                        + "for object: "
-                                        + imps[i]
-                                        + "when i already have it!!");
-                    }
-                }
-            }
-        } catch (Exception ex) {
-            logger
-                    .error("During containerDestroy invocation caught exception: "
-                            + ex
-                            + "\nStacktrace:"
-                            + stackToString(ex.getStackTrace()));
-        }
-    }
-
-    @Override
-    public void containerDestroy(String containerName) {
-        try {
-            Object[] imps = getImplementations();
-            logger.trace("Destroying instance {}", containerName);
-            if (imps != null) {
-                for (int i = 0; i < imps.length; i++) {
-                    ImmutablePair<String, Object> key = new ImmutablePair<String, Object>(
-                            containerName, imps[i]);
-                    Component c = this.dbInstances.get(key);
-                    if (c != null) {
-                        if (c.getService() != null) {
-                            c.invokeCallbackMethod(new Object[] { c.getService() }, "containerStop",
-                                                   new Class[][] {{ Component.class}, {} },
-                                                   new Object[][] { {c}, {} });
-                        }
-                        // Now remove the component from dependency manager,
-                        // which will implicitely stop it first
-                        this.dm.remove(c);
-                    } else {
-                        logger
-                                .error("I have been asked again to remove an instance "
-                                        + "on: "
-                                        + containerName
-                                        + "for object: "
-                                        + imps[i]
-                                        + "when i already have cleared it!!");
-                    }
-
-                    //Now lets remove the association from our shadow
-                    //database so the component can be recycled, this is done
-                    //unconditionally in case of spurious conditions
-                    this.dbInstances.remove(key);
-                }
-            }
-        } catch (Exception ex) {
-            logger
-                    .error("During containerDestroy invocation caught exception: "
-                            + ex
-                            + "\nStacktrace:"
-                            + stackToString(ex.getStackTrace()));
-        }
-    }
-
-    private String stackToString(StackTraceElement[] stack) {
-        if (stack == null) {
-            return "<EmptyStack>";
-        }
-        StringBuffer buffer = new StringBuffer();
-
-        for (int i = 0; i < stack.length; i++) {
-            buffer.append("\n\t").append(stack[i].toString());
-        }
-        return buffer.toString();
-    }
-
-    /**
-     * Method called by the OSGi framework when the OSGi bundle
-     * starts. The functionality we want to perform here are:
-     *
-     * 1) Register with the OSGi framework, that we are a provider of
-     * IContainerAware service and so in case of startup of a container we
-     * want to be called
-     *
-     * 2) Create data structures that allow to keep track of all the
-     * instances created per-container given the derived class of
-     * ComponentActivatorAbstractBase will act as a Factory manager
-     *
-     * @param context OSGi bundle context to interact with OSGi framework
-     */
-    @Override
-    public void start(BundleContext context) {
-        try {
-            this.dm = new DependencyManager(context);
-
-            logger.trace("Activating");
-
-            // Now create Global components
-            Object[] imps = getGlobalImplementations();
-            if (imps != null) {
-                for (int i = 0; i < imps.length; i++) {
-                    Object key = imps[i];
-                    Component c = this.dbGlobalInstances.get(key);
-                    if (c == null) {
-                        try {
-                            c = this.dm.createComponent();
-                            c.addStateListener(new ListenerComponentStates());
-                            // Now let the derived class to configure the
-                            // dependencies it wants
-                            configureGlobalInstance(c, imps[i]);
-                            // Set the implementation so the component
-                            // can manage its lifesycle
-                            if (c.getService() == null) {
-                                logger.trace("Setting implementation to: {}",
-                                        imps[i]);
-                                c.setImplementation(imps[i]);
-                            }
-
-                            // Now add the component to the dependency
-                            // Manager which will immediately start
-                            // tracking the dependencies
-                            this.dm.add(c);
-                        } catch (Exception nex) {
-                            logger.error("During creation of a Global "
-                                    + "instance caught exception: " + nex
-                                    + "\nStacktrace:"
-                                    + stackToString(nex.getStackTrace()));
-                        }
-
-                        //Now lets keep track in our shadow database of the
-                        //association
-                        if (c != null)
-                            this.dbGlobalInstances.put(key, c);
-                    } else {
-                        logger.error("I have been asked again to create an "
-                                + "instance " + " Global for object: "
-                                + imps[i] + "when i already have it!!");
-                    }
-                }
-            }
-
-            // Register with OSGi the provider for the service IContainerAware
-            context.registerService(
-                    IContainerAware.class.getName(), this, null);
-
-            // Now call the derived class init function
-            this.init();
-
-            logger.trace("Activation DONE!");
-        } catch (Exception ex) {
-            logger.error("During Activator start caught exception: " + ex
-                    + "\nStacktrace:" + stackToString(ex.getStackTrace()));
-        }
-    }
-
-    /**
-     * Method called by the OSGi framework when the OSGi bundle
-     * stops. The functionality we want to perform here are:
-     *
-     * 1) Force all the instances to stop and do cleanup and
-     * unreference them so garbage collection can clean them up
-     *
-     * NOTE: UN-Register with the OSGi framework,is not needed because
-     * the framework will automatically do it
-     *
-     * @param context OSGi bundle context to interact with OSGi framework
-     */
-    @Override
-    public void stop(BundleContext context) {
-        try {
-            logger.trace("DE-Activating");
-
-            // Now call the derived class destroy function
-            this.destroy();
-
-            // Now remove all the components tracked for container components
-            for (ImmutablePair<String, Object> key : this.dbInstances.keySet()) {
-                try {
-                    Component c = this.dbInstances.get(key);
-                    if (c != null) {
-                        logger.trace("Remove component on container: {} Object: {}",
-                                key.getLeft(), key.getRight());
-                        this.dm.remove(c);
-                    }
-                } catch (Exception nex) {
-                    logger.error("During removal of a container component "
-                            + "instance caught exception: " + nex
-                            + "\nStacktrace:"
-                            + stackToString(nex.getStackTrace()));
-                }
-                this.dbInstances.remove(key);
-            }
-
-            // Now remove all the components tracked for Global Components
-            for (Object key : this.dbGlobalInstances.keySet()) {
-                try {
-                    Component c = this.dbGlobalInstances.get(key);
-                    if (c != null) {
-                        logger.trace("Remove component for Object: {}" , key);
-                        this.dm.remove(c);
-                    }
-                } catch (Exception nex) {
-                    logger.error("During removal of a Global "
-                            + "instance caught exception: " + nex
-                            + "\nStacktrace:"
-                            + stackToString(nex.getStackTrace()));
-                }
-
-                this.dbGlobalInstances.remove(key);
-            }
-
-            // Detach Dependency Manager
-            this.dm = null;
-
-            logger.trace("Deactivation DONE!");
-        } catch (Exception ex) {
-            logger.error("During Activator stop caught exception: " + ex
-                    + "\nStacktrace:" + stackToString(ex.getStackTrace()));
-        }
-    }
-
-    /**
-     * Return a ServiceDependency customized ad hoc for slicing, this
-     * essentially the same org.apache.felix.dm.ServiceDependency just
-     * with some filters pre-set
-     *
-     * @param containerName containerName for which we want to create the dependency
-     *
-     * @return a ServiceDependency
-     */
-    protected ServiceDependency createContainerServiceDependency(
-            String containerName) {
-        return (new ContainerServiceDependency(this.dm, containerName));
-    }
-
-    /**
-     * Return a ServiceDependency as provided by Dependency Manager as it's
-     *
-     *
-     * @return a ServiceDependency
-     */
-    protected ServiceDependency createServiceDependency() {
-        return this.dm.createServiceDependency();
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/Config.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/Config.java
deleted file mode 100644 (file)
index 3f5b173..0000000
+++ /dev/null
@@ -1,95 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.core;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-/**
- * The class represents Admin Config status
- *
- *
- */
-@XmlRootElement
-@SuppressWarnings("serial")
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class Config extends Property {
-    @XmlElement(name="value")
-    private short configValue;
-
-    public static final short ADMIN_DOWN = 0;
-    public static final short ADMIN_UP = 1;
-    public static final short ADMIN_UNDEF = 0x7fff;
-    public static final String ConfigPropName = "config";
-
-    /*
-     * Private constructor used for JAXB mapping
-     */
-    private Config() {
-        super(ConfigPropName);
-        this.configValue = ADMIN_UNDEF;
-    }
-
-    public Config(short config) {
-        super(ConfigPropName);
-        this.configValue = config;
-    }
-
-    @Override
-    public Config clone() {
-        return new Config(this.configValue);
-    }
-
-    public short getValue() {
-        return this.configValue;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = super.hashCode();
-        result = prime * result + configValue;
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj)
-            return true;
-        if (!super.equals(obj))
-            return false;
-        if (getClass() != obj.getClass())
-            return false;
-        Config other = (Config) obj;
-        if (configValue != other.configValue)
-            return false;
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        return "Config["+ configValue +"]";
-    }
-
-    @Override
-    public String getStringValue() {
-        if (configValue == 0) {
-            return "ADMIN_DOWN";
-        } else if (configValue == 1) {
-            return "ADMIN_UP";
-        } else if (configValue == 0x7fff) {
-            return "ADMIN_UNDEF";
-        } else {
-            return String.valueOf(configValue);
-        }
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/ConstructionException.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/ConstructionException.java
deleted file mode 100644 (file)
index 2dadff7..0000000
+++ /dev/null
@@ -1,29 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * @file   ConstructionException.java
- *
- *
- * @brief  Describe an exception that is raised when a construction
- * for a Node/NodeConnector/Edge or any of the SAL basic object fails
- * because input passed are not valid or compatible
- *
- *
- */
-package org.opendaylight.controller.sal.core;
-
-@Deprecated
-public class ConstructionException extends Exception {
-    private static final long serialVersionUID = 1L;
-
-    public ConstructionException(String message) {
-        super(message);
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/ContainerFlow.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/ContainerFlow.java
deleted file mode 100644 (file)
index aeb9fe7..0000000
+++ /dev/null
@@ -1,148 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.core;
-
-import java.io.Serializable;
-
-import org.opendaylight.controller.sal.action.Action;
-import org.opendaylight.controller.sal.action.SetDlType;
-import org.opendaylight.controller.sal.action.SetNwDst;
-import org.opendaylight.controller.sal.action.SetNwSrc;
-import org.opendaylight.controller.sal.action.SetTpDst;
-import org.opendaylight.controller.sal.action.SetTpSrc;
-import org.opendaylight.controller.sal.action.SetVlanId;
-import org.opendaylight.controller.sal.flowprogrammer.Flow;
-import org.opendaylight.controller.sal.match.Match;
-import org.opendaylight.controller.sal.match.MatchType;
-
-/**
- * Express a container flow
- *
- *
- *
- */
-@Deprecated
-public class ContainerFlow implements Serializable {
-    private static final long serialVersionUID = 1L;
-    private Match match;
-
-    public ContainerFlow(Match match) {
-        this.match = match;
-    }
-
-    /**
-     * Returns a copy of the Match defined by this Container Flow
-     *
-     * @return Match
-     */
-    public Match getMatch() {
-        return match.clone();
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + ((match == null) ? 0 : match.hashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        ContainerFlow other = (ContainerFlow) obj;
-        if (match == null) {
-            if (other.match != null) {
-                return false;
-            }
-        } else if (!match.equals(other.match)) {
-            return false;
-        }
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        return "Container Flow [" + match.toString() + "]";
-    }
-
-    /**
-     * Returns whether the specified flow is allowed
-     *
-     * @return true if the flow is allowed, false otherwise
-     */
-    public boolean allowsFlow(Flow flow) {
-        Match target = flow.getMatch();
-
-        // Check if flow's match is allowed
-        if (!this.allowsMatch(target)) {
-            return false;
-        }
-
-        // Now check if the flow's actions are not allowed
-        // Create a Match which summarizes the list of actions
-        if (flow.getActions() == null) {
-            return true;
-        }
-        Match actionMatch = new Match();
-        for (Action action : flow.getActions()) {
-            switch (action.getType()) {
-            case SET_VLAN_ID:
-                actionMatch.setField(MatchType.DL_VLAN,
-                        ((Integer) ((SetVlanId) action).getVlanId())
-                                .shortValue());
-                break;
-            case SET_DL_TYPE:
-                actionMatch.setField(MatchType.DL_TYPE,
-                        ((Integer) ((SetDlType) action).getDlType())
-                                .shortValue());
-                break;
-            case SET_NW_SRC:
-                actionMatch.setField(MatchType.NW_SRC, ((SetNwSrc) action)
-                        .getAddress());
-                break;
-            case SET_NW_DST:
-                actionMatch.setField(MatchType.NW_DST, ((SetNwDst) action)
-                        .getAddress());
-                break;
-            case SET_TP_SRC:
-                actionMatch.setField(MatchType.TP_SRC,
-                        ((Integer) ((SetTpSrc) action).getPort()).shortValue());
-                break;
-            case SET_TP_DST:
-                actionMatch.setField(MatchType.TP_DST,
-                        ((Integer) ((SetTpDst) action).getPort()).shortValue());
-                break;
-            default:
-                // This action cannot conflict
-            }
-        }
-
-        return this.allowsMatch(actionMatch);
-    }
-
-    /**
-     * Returns whether the specified match is allowed
-     *
-     * @param match the match to test
-     * @return true if the match is allowed, false otherwise
-     */
-    public boolean allowsMatch(Match target) {
-        return !target.conflictWithFilter(this.match);
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/ContainerServiceDependency.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/ContainerServiceDependency.java
deleted file mode 100644 (file)
index 2db8334..0000000
+++ /dev/null
@@ -1,253 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.core;
-
-/**
- * @file   ContainerServiceDependency.java
- *
- * @brief  Class representing a ServiceDependency on a container
- *
- * Class representing a ServiceDependency on a container
- */
-
-import java.util.Dictionary;
-import org.osgi.framework.ServiceReference;
-import org.apache.felix.dm.ServiceDependency;
-import org.apache.felix.dm.DependencyManager;
-import org.apache.felix.dm.Dependency;
-import org.apache.felix.dm.DependencyActivation;
-import org.apache.felix.dm.DependencyService;
-
-/**
- * Class representing a ServiceDependency on a container
- *
- */
-@Deprecated
-public class ContainerServiceDependency implements ServiceDependency,
-        DependencyActivation {
-    private ServiceDependency m_dep;
-    private String containerName;
-
-    public ContainerServiceDependency(DependencyManager manager,
-            String containerName) {
-        this.m_dep = manager.createServiceDependency();
-        this.containerName = containerName;
-    }
-
-    private ContainerServiceDependency(ServiceDependency explicitDependency,
-            String containerName) {
-        this.m_dep = explicitDependency;
-        this.containerName = containerName;
-    }
-
-    @SuppressWarnings("rawtypes") // can't change org.apache.felix.dm.ServiceDependency
-    @Override
-    public ServiceDependency setService(Class serviceName) {
-        this.m_dep.setService(serviceName, "(containerName="
-                + this.containerName + ")");
-        return this;
-    }
-
-    @SuppressWarnings("rawtypes") // can't change org.apache.felix.dm.ServiceDependency
-    @Override
-    public ServiceDependency setService(Class serviceName, String serviceFilter) {
-        this.m_dep.setService(serviceName, "(&(containerName="
-                + this.containerName + ")" + serviceFilter + ")");
-        return this;
-    }
-
-    @Override
-    public ServiceDependency setService(String serviceFilter) {
-        this.m_dep.setService("(&(containerName=" + this.containerName + ")"
-                + serviceFilter + ")");
-        return this;
-    }
-
-    @SuppressWarnings("rawtypes") // can't change org.apache.felix.dm.ServiceDependency
-    @Override
-    public ServiceDependency setService(Class serviceName,
-            ServiceReference serviceReference) {
-        this.m_dep.setService(serviceName, serviceReference);
-        return this;
-    }
-
-    @Override
-    public ServiceDependency setDefaultImplementation(Object implementation) {
-        this.m_dep.setDefaultImplementation(implementation);
-        return this;
-    }
-
-    @Override
-    public ServiceDependency setRequired(boolean required) {
-        this.m_dep.setRequired(required);
-        return this;
-    }
-
-    @Override
-    public ServiceDependency setAutoConfig(boolean autoConfig) {
-        this.m_dep.setAutoConfig(autoConfig);
-        return this;
-    }
-
-    @Override
-    public ServiceDependency setAutoConfig(String instanceName) {
-        this.m_dep.setAutoConfig(instanceName);
-        return this;
-    }
-
-    @Override
-    public ServiceDependency setCallbacks(String added, String removed) {
-        this.m_dep.setCallbacks(added, removed);
-        return this;
-    }
-
-    @Override
-    public ServiceDependency setCallbacks(String added, String changed,
-            String removed) {
-        this.m_dep.setCallbacks(added, changed, removed);
-        return this;
-    }
-
-    @Override
-    public ServiceDependency setCallbacks(String added, String changed,
-            String removed, String swapped) {
-        this.m_dep.setCallbacks(added, changed, removed, swapped);
-        return this;
-    }
-
-    @Override
-    public ServiceDependency setCallbacks(Object instance, String added,
-            String removed) {
-        this.m_dep.setCallbacks(instance, added, removed);
-        return this;
-    }
-
-    @Override
-    public ServiceDependency setCallbacks(Object instance, String added,
-            String changed, String removed) {
-        this.m_dep.setCallbacks(instance, added, changed, removed);
-        return this;
-    }
-
-    @Override
-    public ServiceDependency setCallbacks(Object instance, String added,
-            String changed, String removed, String swapped) {
-        this.m_dep.setCallbacks(instance, added, changed, removed, swapped);
-        return this;
-    }
-
-    @Override
-    public ServiceDependency setPropagate(boolean propagate) {
-        this.m_dep.setPropagate(propagate);
-        return this;
-    }
-
-    @Override
-    public ServiceDependency setPropagate(Object instance, String method) {
-        this.m_dep.setPropagate(instance, method);
-        return this;
-    }
-
-    @Override
-    public ServiceDependency setInstanceBound(boolean isInstanceBound) {
-        this.m_dep.setInstanceBound(isInstanceBound);
-        return this;
-    }
-
-    @Override
-    public Dependency createCopy() {
-        return new ContainerServiceDependency((ServiceDependency) this.m_dep
-                .createCopy(), this.containerName);
-    }
-
-    @SuppressWarnings("rawtypes") // can't change org.apache.felix.dm.ServiceDependency
-    @Override
-    public Dictionary getProperties() {
-        return this.m_dep.getProperties();
-    }
-
-    @Override
-    public boolean isPropagated() {
-        return this.m_dep.isPropagated();
-    }
-
-    @Override
-    public boolean isRequired() {
-        return this.m_dep.isRequired();
-    }
-
-    @Override
-    public boolean isAvailable() {
-        return this.m_dep.isAvailable();
-    }
-
-    @Override
-    public boolean isInstanceBound() {
-        return this.m_dep.isInstanceBound();
-    }
-
-    @Override
-    public boolean isAutoConfig() {
-        return this.m_dep.isAutoConfig();
-    }
-
-    @SuppressWarnings("rawtypes") // can't change org.apache.felix.dm.ServiceDependency
-    @Override
-    public Class getAutoConfigType() {
-        return this.m_dep.getAutoConfigType();
-    }
-
-    @Override
-    public Object getAutoConfigInstance() {
-        return this.m_dep.getAutoConfigInstance();
-    }
-
-    @Override
-    public String getAutoConfigName() {
-        return this.m_dep.getAutoConfigName();
-    }
-
-    @Override
-    public void invokeAdded(DependencyService service) {
-        this.m_dep.invokeAdded(service);
-    }
-
-    @Override
-    public void invokeRemoved(DependencyService service) {
-        this.m_dep.invokeRemoved(service);
-    }
-
-    @Override
-    public String getName() {
-        return this.m_dep.getName();
-    }
-
-    @Override
-    public String getType() {
-        return this.m_dep.getType();
-    }
-
-    @Override
-    public int getState() {
-        return this.m_dep.getState();
-    }
-
-    @Override
-    public void start(DependencyService service) {
-        DependencyActivation a = (DependencyActivation) this.m_dep;
-        a.start(service);
-    }
-
-    @Override
-    public void stop(DependencyService service) {
-        DependencyActivation a = (DependencyActivation) this.m_dep;
-        a.stop(service);
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/Description.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/Description.java
deleted file mode 100644 (file)
index 82ac8eb..0000000
+++ /dev/null
@@ -1,84 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.sal.core;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-/**
- * The class represents the Name property of an element.
- */
-@XmlRootElement
-@SuppressWarnings("serial")
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class Description extends Property {
-    @XmlElement(name="value")
-    private String descriptionValue;
-    public static final String propertyName = "description";
-
-    /*
-     * Private constructor used for JAXB mapping
-     */
-    private Description() {
-        super(propertyName);
-        this.descriptionValue = null;
-    }
-
-    public Description(String description) {
-        super(propertyName);
-        this.descriptionValue = description;
-    }
-
-    @Override
-    public Description clone() {
-        return new Description(this.descriptionValue);
-    }
-
-    public String getValue() {
-        return this.descriptionValue;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = super.hashCode();
-        result = prime * result
-                + ((descriptionValue == null) ? 0 : descriptionValue.hashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj)
-            return true;
-        if (!super.equals(obj))
-            return false;
-        if (getClass() != obj.getClass())
-            return false;
-        Description other = (Description) obj;
-        if (descriptionValue == null) {
-            if (other.descriptionValue != null)
-                return false;
-        } else if (!descriptionValue.equals(other.descriptionValue))
-            return false;
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        return "Description[" + descriptionValue + "]";
-    }
-
-    @Override
-    public String getStringValue() {
-        return descriptionValue;
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/Edge.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/Edge.java
deleted file mode 100644 (file)
index 18c38d9..0000000
+++ /dev/null
@@ -1,182 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * @file   Edge.java
- *
- * @brief  Describe an edge in network made of multiple SDN technologies
- *
- * Class that describe an Edge connecting two NodeConnector, the edge
- * is directed because there is the head and the tail concept which
- * implies a direction.
- */
-package org.opendaylight.controller.sal.core;
-
-import java.io.Serializable;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-/**
- *
- * Class that describe an Edge connecting two NodeConnector, the edge
- * is directed because there is the tail and the head concept which
- * implies a direction.
- *
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class Edge implements Serializable {
-    private static final long serialVersionUID = 1L;
-    @XmlElement
-    private NodeConnector tailNodeConnector;
-    @XmlElement
-    private NodeConnector headNodeConnector;
-
-    /**
-     * Private constructor used for JAXB mapping
-     */
-    @SuppressWarnings("unused")
-    private Edge() {
-        this.tailNodeConnector = null;
-        this.headNodeConnector = null;
-    }
-
-    /**
-     * Construct the Edge
-     *
-     * @param tailNodeConnector Tail Node output connector
-     * @param headNodeConnector Head Node input connector
-     *
-     */
-    public Edge(NodeConnector tailNodeConnector, NodeConnector headNodeConnector)
-            throws ConstructionException {
-        if (tailNodeConnector == null || headNodeConnector == null) {
-            throw new ConstructionException(
-                    "Null tail or head NodeConnector supplied");
-        } else {
-            this.tailNodeConnector = tailNodeConnector;
-            this.headNodeConnector = headNodeConnector;
-        }
-    }
-
-    /**
-     * Copy Construct the Edge
-     *
-     * @param src Edge to copy from
-     *
-     */
-    public Edge(Edge src) throws ConstructionException {
-        if (src != null) {
-            this.tailNodeConnector = new NodeConnector(src
-                    .getTailNodeConnector());
-            this.headNodeConnector = new NodeConnector(src
-                    .getHeadNodeConnector());
-        } else {
-            throw new ConstructionException("src supplied was null");
-        }
-    }
-
-    /**
-     * Create the reversed edge
-     * @return The reversed edge.
-     */
-    public Edge reverse() {
-        Edge re;
-        try {
-            re = new Edge(this.headNodeConnector, this.tailNodeConnector);
-        } catch (ConstructionException e) {
-            re = null;
-        }
-        return re;
-    }
-    /**
-     * getter of edge
-     *
-     *
-     * @return tail NodeConnector of the edge
-     */
-    public NodeConnector getTailNodeConnector() {
-        return tailNodeConnector;
-    }
-
-    /**
-     * setter for edge
-     *
-     * @param tailNodeConnector NodeConnector to set the tail
-     */
-    public void setTailNodeConnector(NodeConnector tailNodeConnector) {
-        this.tailNodeConnector = tailNodeConnector;
-    }
-
-    /**
-     * getter of edge
-     *
-     *
-     * @return head NodeConnector of the edge
-     */
-    public NodeConnector getHeadNodeConnector() {
-        return headNodeConnector;
-    }
-
-    /**
-     * setter for edge
-     *
-     * @param headNodeConnector NodeConnector to set the head
-     */
-    public void setHeadNodeConnector(NodeConnector headNodeConnector) {
-        this.headNodeConnector = headNodeConnector;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime
-                * result
-                + ((headNodeConnector == null) ? 0 : headNodeConnector
-                        .hashCode());
-        result = prime
-                * result
-                + ((tailNodeConnector == null) ? 0 : tailNodeConnector
-                        .hashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj)
-            return true;
-        if (obj == null)
-            return false;
-        if (getClass() != obj.getClass())
-            return false;
-        Edge other = (Edge) obj;
-        if (headNodeConnector == null) {
-            if (other.headNodeConnector != null)
-                return false;
-        } else if (!headNodeConnector.equals(other.headNodeConnector))
-            return false;
-        if (tailNodeConnector == null) {
-            if (other.tailNodeConnector != null)
-                return false;
-        } else if (!tailNodeConnector.equals(other.tailNodeConnector))
-            return false;
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        return "(" + this.tailNodeConnector + "->" + this.headNodeConnector
-                + ")";
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/ForwardingMode.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/ForwardingMode.java
deleted file mode 100644 (file)
index 312a598..0000000
+++ /dev/null
@@ -1,90 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.sal.core;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-/**
- * The class represents the forwarding mode property of a node.
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@SuppressWarnings("serial")
-@Deprecated
-public class ForwardingMode extends Property {
-    @XmlElement(name="value")
-    private final int modeValue;
-    public static final int REACTIVE_FORWARDING = 0;
-    public static final int PROACTIVE_FORWARDING = 1;
-    public static final String name = "forwarding";
-
-    /*
-     * Private constructor used for JAXB mapping
-     */
-    private ForwardingMode() {
-        super(name);
-        this.modeValue = REACTIVE_FORWARDING;
-    }
-
-    public ForwardingMode(int mode) {
-        super(name);
-        this.modeValue = mode;
-    }
-
-    public int getValue() {
-        return this.modeValue;
-    }
-
-    public boolean isProactive() {
-        return (modeValue == ForwardingMode.PROACTIVE_FORWARDING);
-    }
-
-    public boolean isValid() {
-        return ((modeValue >= 0) && (modeValue <= 1));
-    }
-
-    @Override
-    public ForwardingMode clone() {
-        return new ForwardingMode(this.modeValue);
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = super.hashCode();
-        result = prime * result + modeValue;
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj)
-            return true;
-        if (!super.equals(obj))
-            return false;
-        if (getClass() != obj.getClass())
-            return false;
-        ForwardingMode other = (ForwardingMode) obj;
-        if (modeValue != other.modeValue)
-            return false;
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        return "Mode[" + modeValue + "]";
-    }
-
-    @Override
-    public String getStringValue() {
-        return (modeValue == ForwardingMode.PROACTIVE_FORWARDING) ? "Proactive" : "Reactive";
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/Host.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/Host.java
deleted file mode 100644 (file)
index 3e863ad..0000000
+++ /dev/null
@@ -1,131 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.core;
-
-import java.io.Serializable;
-import java.net.InetAddress;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.sal.packet.address.DataLinkAddress;
-
-@XmlRootElement(name="host")
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class Host implements Serializable {
-    private static final long serialVersionUID = 1L;
-    @XmlElement
-    private DataLinkAddress dataLayerAddress;
-    private InetAddress networkAddress;
-
-    public Host() {
-
-    }
-
-    /**
-     * Create an Host representation from the combination Data Link
-     * layer/Network layer address, both are needed to construct the
-     * object. Fake value can also be provided in case are not
-     * existent.
-     *
-     * @param dataLayerAddress Data Link Address for the host
-     * @param networkAddress Network Address for the host
-     *
-     * @return the constructed object
-     */
-    public Host(DataLinkAddress dataLayerAddress, InetAddress networkAddress)
-            throws ConstructionException {
-        if (dataLayerAddress == null) {
-            throw new ConstructionException("Passed null datalink address");
-        }
-        if (networkAddress == null) {
-            throw new ConstructionException("Passed null network address");
-        }
-        this.dataLayerAddress = dataLayerAddress;
-        this.networkAddress = networkAddress;
-    }
-
-    /**
-     * Copy constructor
-     *
-     * @param h Host to copy values from
-     *
-     * @return constructed copy
-     */
-    public Host(Host h) throws ConstructionException {
-        if (h == null) {
-            throw new ConstructionException("Passed null host");
-        }
-        this.dataLayerAddress = h.getDataLayerAddress();
-        this.networkAddress = h.getNetworkAddress();
-    }
-
-    /**
-     * @return the dataLayerAddress
-     */
-    public DataLinkAddress getDataLayerAddress() {
-        return this.dataLayerAddress;
-    }
-
-    /**
-     * @return the networkAddress
-     */
-    public InetAddress getNetworkAddress() {
-        return networkAddress;
-    }
-
-    @XmlElement(name = "networkAddress")
-    public String getNetworkAddressAsString() {
-        return networkAddress.getHostAddress();
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime
-                * result
-                + ((dataLayerAddress == null) ? 0 : dataLayerAddress.hashCode());
-        result = prime * result
-                + ((networkAddress == null) ? 0 : networkAddress.hashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj)
-            return true;
-        if (obj == null)
-            return false;
-        if (getClass() != obj.getClass())
-            return false;
-        Host other = (Host) obj;
-        if (dataLayerAddress == null) {
-            if (other.dataLayerAddress != null)
-                return false;
-        } else if (!dataLayerAddress.equals(other.dataLayerAddress))
-            return false;
-        if (networkAddress == null) {
-            if (other.networkAddress != null)
-                return false;
-        } else if (!networkAddress.equals(other.networkAddress))
-            return false;
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        return "Host [dataLayerAddress=" + dataLayerAddress
-                + ", networkAddress=" + networkAddress + "]";
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/IContainer.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/IContainer.java
deleted file mode 100644 (file)
index 98475d8..0000000
+++ /dev/null
@@ -1,82 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * @file   IContainer.java
- *
- * @brief  Interface used to retrieve the status of a given Container
- *
- *
- */
-
-package org.opendaylight.controller.sal.core;
-
-import java.util.List;
-import java.util.Set;
-
-/**
- *
- * Interface used to retrieve the status of a given Container
- */
-@Deprecated
-public interface IContainer {
-    /**
-     * Returns the Name of the container described
-     *
-     * @return the container Name
-     */
-    public String getName();
-
-    /**
-     * The list of container flows associated with a container
-     *
-     * @return The list of FlowSpecs associated with the container
-     */
-    public List<ContainerFlow> getContainerFlows();
-
-    /**
-     * Return the tag on which a Node is expected to receive traffic
-     * for a given container.
-     *
-     * @param n The node for which we want to get the Tag
-     *
-     * @return the tag on which we expect to receive traffic on a
-     * given Node for a given container
-     */
-    public short getTag(Node n);
-
-    /**
-     * Return an array of all the NodeConnectors that are part of the
-     * container
-     *
-     * @return The array of nodeConnectors part of the container
-     */
-    public Set<NodeConnector> getNodeConnectors();
-
-    /**
-     * Return an array of all the Nodes that are part of a container
-     *
-     * @return The array of Nodes that are part of the container
-     */
-    public Set<Node> getNodes();
-
-    /**
-     * Return the well known administrator role for this container
-     *
-     * @return The administrator role for this container
-     */
-    public String getContainerAdminRole();
-
-    /**
-     * Return the well known operator role for this container
-     *
-     * @return The operator role for this container
-     */
-    public String getContainerOperatorRole();
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/IContainerAware.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/IContainerAware.java
deleted file mode 100644 (file)
index 164db91..0000000
+++ /dev/null
@@ -1,32 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.core;
-
-/**
- * The interface describes methods to be called when the Container is being
- * created/destroyed
- */
-
-@Deprecated
-public interface IContainerAware {
-    /**
-     * Method invoked to signal that a container is being created
-     *
-     * @param containerName Container being created
-     */
-    public void containerCreate(String containerName);
-
-    /**
-     * Method invoked to signal that a container is being destroyed
-     *
-     * @param containerName Container being destroyed
-     */
-    public void containerDestroy(String containerName);
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/IContainerListener.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/IContainerListener.java
deleted file mode 100644 (file)
index ce94ee6..0000000
+++ /dev/null
@@ -1,96 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * @file   IContainerListener.java
- *
- * @brief  Set of methods needed to listen to changes in the Container
- * configuration
- *
- * Set of methods needed to listen to changes in the Container
- * configuration
- *
- *
- */
-package org.opendaylight.controller.sal.core;
-
-/**
- * The interface describes methods used to retrieve the status of a given
- * Container
- */
-@Deprecated
-public interface IContainerListener {
-    /**
-     * Called to notify a change in the tag assigned to a switch
-     *
-     * @param containerName container for which the update has been raised
-     * @param n Node of the tag under notification
-     * @param oldTag previous version of the tag, this differ from the
-     * newTag only if the UpdateType is a modify
-     * @param newTag new value for the tag, different from oldTag only
-     * in case of modify operation
-     * @param t type of update
-     */
-    public void tagUpdated(String containerName, Node n, short oldTag,
-            short newTag, UpdateType t);
-
-    /**
-     * Notification raised when the container flow layout changes
-     *
-     * @param containerName
-     *            container for which the update has been raised
-     * @param previousFlow
-     *            previous value of the container flow
-     *            {@link org.opendaylight.controller.sal.core.ContainerFlow}
-     *            under update, differs from the currentFlow only and only if
-     *            it's an update operation
-     * @param currentFlow
-     *            current version of the container flow
-     *            {@link org.opendaylight.controller.sal.core.ContainerFlow}
-     *            differs from the previousFlow only in case of update
-     * @param t
-     *            type of update
-     *            {@link org.opendaylight.controller.sal.core.UpdateType}
-     */
-    public void containerFlowUpdated(String containerName,
-            ContainerFlow previousFlow, ContainerFlow currentFlow, UpdateType t);
-
-    /**
-     * Notification raised when a NodeConnector is added or removed in the
-     * container.
-     *
-     * @param containerName
-     *            container for which the update has been raised
-     * @param p
-     *            NodeConnector
-     *            {@link org.opendaylight.controller.sal.core.NodeConnector}
-     *            being updated
-     * @param t
-     *            type of modification
-     *            {@link org.opendaylight.controller.sal.core.UpdateType}, but
-     *            among the types the modify operation is not expected to be
-     *            raised because the nodeConnectors are anyway immutable so this
-     *            is only used to add/delete
-     */
-    public void nodeConnectorUpdated(String containerName, NodeConnector p,
-            UpdateType t);
-
-    /**
-     * Notification raised when the container mode has changed This notification
-     * is needed for some bundle in the default container to cleanup some HW
-     * state when switching from non-slicing to slicing case and vice-versa
-     *
-     * @param t
-     *            type of modification
-     *            {@link org.opendaylight.controller.sal.core.UpdateType}. ADDED
-     *            when first container is created, REMOVED when last container
-     *            is removed
-     */
-    public void containerModeUpdated(UpdateType t);
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/IContainerLocalListener.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/IContainerLocalListener.java
deleted file mode 100644 (file)
index 531f111..0000000
+++ /dev/null
@@ -1,25 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * @file IContainerLocalListener.java
- *
- * @brief Set of methods needed to listen to changes in the Container
- *        configuration for listeners on the local cluster node only
- */
-package org.opendaylight.controller.sal.core;
-
-
-/**
- * The interface describes methods used to publish the changes to a given
- * Container configuration to listeners on the local cluster node only.
- */
-@Deprecated
-public interface IContainerLocalListener extends IContainerListener {
-
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/Latency.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/Latency.java
deleted file mode 100644 (file)
index 677431a..0000000
+++ /dev/null
@@ -1,136 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.core;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-/**
- * @file   Latency.java
- *
- * @brief  Class representing Latency
- *
- * Describe a latency in picoseconds or multiple of its.
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class Latency extends Property {
-    private static final long serialVersionUID = 1L;
-
-    @XmlElement(name="value")
-    private long latencyValue;
-
-    public static final long LATENCYUNK = 0;
-    public static final long LATENCY1ns = (long) Math.pow(10, 3);
-    public static final long LATENCY10ns = (long) Math.pow(10, 4);
-    public static final long LATENCY100ns = (long) Math.pow(10, 5);
-    public static final long LATENCY1us = (long) Math.pow(10, 6);
-    public static final long LATENCY10us = (long) Math.pow(10, 7);
-    public static final long LATENCY100us = (long) Math.pow(10, 8);
-    public static final long LATENCY1ms = (long) Math.pow(10, 9);
-    public static final long LATENCY1s = (long) Math.pow(10, 12);
-
-    public static final String LatencyPropName = "latency";
-
-    /*
-     * Private constructor used for JAXB mapping
-     */
-    private Latency() {
-        super(LatencyPropName);
-        this.latencyValue = LATENCYUNK;
-    }
-
-    public Latency(long latency) {
-        super(LatencyPropName);
-        this.latencyValue = latency;
-    }
-
-    public Latency(int latency) {
-        super(LatencyPropName);
-        this.latencyValue = (long) latency;
-    }
-
-    public Latency(short latency) {
-        super(LatencyPropName);
-        this.latencyValue = (long) latency;
-    }
-
-    @Override
-    public Latency clone() {
-        return new Latency(this.latencyValue);
-    }
-
-    public long getValue() {
-        return this.latencyValue;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = super.hashCode();
-        result = prime * result + (int) (latencyValue ^ (latencyValue >>> 32));
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj)
-            return true;
-        if (!super.equals(obj))
-            return false;
-        if (getClass() != obj.getClass())
-            return false;
-        Latency other = (Latency) obj;
-        if (latencyValue != other.latencyValue)
-            return false;
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        StringBuffer sb = new StringBuffer();
-
-        sb.append("Latency[");
-        if (this.latencyValue == 0) {
-            sb.append("UnKnown");
-        } else if (this.latencyValue < LATENCY1ns) {
-            sb.append(this.latencyValue).append("psec");
-        } else if (this.latencyValue < LATENCY1us) {
-            sb.append(Long.toString(this.latencyValue / LATENCY1ns)).append("nsec");
-        } else if (this.latencyValue < LATENCY1ms) {
-            sb.append(Long.toString(this.latencyValue / LATENCY1us)).append("usec");
-        } else if (this.latencyValue < LATENCY1s) {
-            sb.append(Long.toString(this.latencyValue / LATENCY1ms)).append("msec");
-        }
-
-        sb.append("]");
-        return sb.toString();
-    }
-
-    @Override
-    public String getStringValue() {
-        if (this.latencyValue == 0) {
-            return("UnKnown");
-        } else if (this.latencyValue < LATENCY1ns) {
-            return(this.latencyValue + "psec");
-        } else if (this.latencyValue < LATENCY1us) {
-            return(Long.toString(this.latencyValue / LATENCY1ns) + "nsec");
-        } else if (this.latencyValue < LATENCY1ms) {
-            return(Long.toString(this.latencyValue / LATENCY1us) + "usec");
-        } else if (this.latencyValue < LATENCY1s) {
-            return(Long.toString(this.latencyValue / LATENCY1ms) + "msec");
-        } else {
-            return Long.toString(this.latencyValue) + "sec";
-        }
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/MacAddress.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/MacAddress.java
deleted file mode 100644 (file)
index 737058a..0000000
+++ /dev/null
@@ -1,118 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.core;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.sal.utils.HexEncode;
-
-/**
- * The class contains MAC address property.
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class MacAddress extends Property implements Cloneable {
-    private static final long serialVersionUID = 1L;
-    @XmlElement(name="value")
-    private final String address;
-    public static final String name = "macAddress";
-
-    /*
-     * Private constructor used for JAXB mapping
-     */
-    private MacAddress() {
-        super(name);
-        this.address = null;
-    }
-
-    /**
-     * Constructor to create DatalinkAddress property which contains the MAC
-     * address. The property will be attached to a
-     * {@link org.opendaylight.controller.sal.core.Node}.
-     *
-     *
-     * @param nodeMacAddress
-     *            Data Link Address for the node in byte array format
-     *
-     * @return the constructed object
-     */
-    public MacAddress(byte[] nodeMacAddress) {
-        super(name);
-        this.address = HexEncode.bytesToHexStringFormat(nodeMacAddress);
-    }
-
-    /**
-     * Constructor to create DatalinkAddress property which contains the MAC
-     * address. The property will be attached to a
-     * {@link org.opendaylight.controller.sal.core.Node}.
-     *
-     *
-     * @param nodeMacAddress
-     *            Data Link Address for the node in String format
-     *
-     * @return the constructed object
-     */
-    public MacAddress(String nodeMacAddress) {
-        super(name);
-        this.address = nodeMacAddress;
-    }
-
-    /**
-     * @return the node MAC address in byte array format
-     */
-    public byte[] getMacAddress() {
-        return HexEncode.bytesFromHexString(this.address);
-    }
-
-    @Override
-    public MacAddress clone() {
-        return new MacAddress(this.address);
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = super.hashCode();
-        result = prime * result
-                + ((address == null) ? 0 : address.hashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (!super.equals(obj)) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        MacAddress other = (MacAddress) obj;
-        if (!address.equals(other.address)) {
-            return false;
-        }
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        return "MacAddress[" + address + "]";
-    }
-
-    @Override
-    public String getStringValue() {
-        return address;
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/Name.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/Name.java
deleted file mode 100644 (file)
index a1d80f2..0000000
+++ /dev/null
@@ -1,86 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.core;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-/**
- * The class represents the Name property of an element.
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@SuppressWarnings("serial")
-@Deprecated
-public class Name extends Property {
-    @XmlElement(name="value")
-    private String nameValue;
-    public static final String NamePropName = "name";
-
-    /*
-     * Private constructor used for JAXB mapping
-     */
-    private Name() {
-        super(NamePropName);
-        this.nameValue = null;
-    }
-
-    public Name(String name) {
-        super(NamePropName);
-        this.nameValue = name;
-    }
-
-    @Override
-    public Name clone() {
-        return new Name(this.nameValue);
-    }
-
-    public String getValue() {
-        return this.nameValue;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = super.hashCode();
-        result = prime * result
-                + ((nameValue == null) ? 0 : nameValue.hashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj)
-            return true;
-        if (!super.equals(obj))
-            return false;
-        if (getClass() != obj.getClass())
-            return false;
-        Name other = (Name) obj;
-        if (nameValue == null) {
-            if (other.nameValue != null)
-                return false;
-        } else if (!nameValue.equals(other.nameValue))
-            return false;
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        return "Name[" + nameValue + "]";
-    }
-
-    @Override
-    public String getStringValue() {
-        return nameValue;
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/Node.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/Node.java
deleted file mode 100644 (file)
index be1ed07..0000000
+++ /dev/null
@@ -1,459 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * @file   Node.java
- *
- * @brief  Describe a generic network element in multiple SDNs technologies
- *
- * Describe a generic network element in multiple SDNs technologies. A
- * Node is identified by the pair (NodeType, NodeID), the nodetype are
- * needed in order to further specify the nodeID
- */
-package org.opendaylight.controller.sal.core;
-
-import java.io.Serializable;
-import java.math.BigInteger;
-import java.util.Set;
-import java.util.UUID;
-import java.util.concurrent.ConcurrentHashMap;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.sal.utils.HexEncode;
-import org.opendaylight.controller.sal.utils.INodeFactory;
-import org.opendaylight.controller.sal.utils.ServiceHelper;
-
-/**
- * Describe a generic network element in multiple SDNs technologies. A
- * Node is identified by the pair (NodeType, NodeID), the nodetype are
- * needed in order to further specify the nodeID
- *
- */
-@XmlAccessorType(XmlAccessType.NONE)
-@XmlRootElement
-@Deprecated
-public class Node implements Serializable {
-    private static final long serialVersionUID = 1L;
-
-    /**
-     * Enum-like static class created with the purpose of identifing
-     * multiple type of nodes in the SDN network. The type is
-     * necessary to figure out to later on correctly use the
-     * nodeID. Using a static class instead of an Enum so we can add
-     * dynamically new types without changing anything in the
-     * surround.
-     */
-    public static final class NodeIDType {
-        private static final ConcurrentHashMap<String, Class<? extends Object>> compatibleType =
-            new ConcurrentHashMap<String, Class<? extends Object>>();
-        /**
-         * Identifier for an OpenFlow node
-         */
-        public static String OPENFLOW = "OF";
-        /**
-         * Identifier for a PCEP node
-         */
-        public static String PCEP = "PE";
-        /**
-         * Identifier for a ONEPK node
-         */
-        public static String ONEPK = "PK";
-        /**
-         * Identifier for a node in a non-SDN network
-         */
-        public static String PRODUCTION = "PR";
-
-        // Pre-populated types, just here for convenience and ease of
-        // unit-testing, but certainly those could live also outside.
-        static {
-            compatibleType.put(OPENFLOW, Long.class);
-            compatibleType.put(PCEP, UUID.class);
-            compatibleType.put(ONEPK, String.class);
-            compatibleType.put(PRODUCTION, String.class);
-        }
-
-        /**
-         * Return the type of the class expected for the
-         * NodeID, it's used for validity check in the constructor
-         *
-         * @param nodeType the type of the node we want to check
-         * compatibility for
-         *
-         * @return The Class which is supposed to instantiate the ID
-         * for the NodeID
-         */
-        public static Class<?> getClassType(String nodeType) {
-            return compatibleType.get(nodeType);
-        }
-
-        /**
-         * Returns all the registered nodeIDTypes currently available
-         *
-         * @return The current registered NodeIDTypes
-         */
-        public static Set<String> values() {
-            return compatibleType.keySet();
-        }
-
-        /**
-         * Register a new ID for which Node can be created
-         *
-         * @param type, the new type being registered
-         * @param compatibleID, the type of class to be accepted as ID
-         *
-         * @return true if registered, false otherwise
-         */
-        public static boolean registerIDType(String type,
-                                             Class<? extends Object> compatibleID) {
-            if (compatibleType.get(type) != null) {
-                return false;
-            }  else {
-                compatibleType.put(type, compatibleID);
-                return true;
-            }
-        }
-
-        /**
-         * UNRegister a new ID for which Node can be created
-         *
-         * @param type, the type being UN-registered
-         *
-         */
-        public static void unRegisterIDType(String type) {
-            compatibleType.remove(type);
-        }
-    }
-
-    // This is the identity of the Node a (Type,ID) pair!, the full
-    // essence of this class.
-    private Object nodeID;
-    private String nodeType;
-
-    // Shadow value for unmarshalling
-    private String nodeIDString;
-
-    /**
-     * Private constructor used for JAXB mapping
-     */
-    private Node() {
-        this.nodeID = null;
-        this.nodeType = null;
-        this.nodeIDString = null;
-    }
-
-    /**
-     * Constructor for the Node objects, it validate the input so if
-     * the ID passed is not of the type expected accordingly to the
-     * type an exception is raised.
-     *
-     * @param nodeType Type of the node we are building
-     * @param id ID used by the SDN technology to identify the node
-     *
-     */
-    public Node(String nodeType, Object id) throws ConstructionException {
-        if (NodeIDType.getClassType(nodeType) != null &&
-            NodeIDType.getClassType(nodeType).isInstance(id)) {
-            this.nodeType = nodeType;
-            this.nodeID = id;
-        } else {
-            throw new ConstructionException("Type of incoming object:"
-                                            + id.getClass() + " not compatible with expected type:"
-                                            + NodeIDType.getClassType(nodeType));
-        }
-    }
-
-    /**
-     * Copy Constructor for the Node objects.
-     *
-     * @param src type of nodes to copy from
-     *
-     */
-    public Node(Node src) throws ConstructionException {
-        if (src != null) {
-            this.nodeType = src.getType();
-            // Here we can reference the object because that is
-            // supposed to be an immutable identifier as well like a
-            // UUID/Integer and so on, hence no need to create a copy
-            // of it
-            this.nodeID = src.getID();
-        } else {
-            throw
-                new ConstructionException("Null incoming object to copy from");
-        }
-    }
-
-    /**
-     * getter for node type
-     *
-     *
-     * @return The node Type for this Node object
-     */
-    @XmlElement(name = "type")
-    public String getType() {
-        return this.nodeType;
-    }
-
-    /**
-     * fill the current object from the string parameters passed, will
-     * be only used by JAXB
-     *
-     * @param typeStr string representing the type of the Node
-     * @param IDStr String representation of the ID
-     */
-    private void fillmeFromString(String typeStr, String IDStr) {
-        if (typeStr == null) {
-            return;
-        }
-
-        if (IDStr == null) {
-            return;
-        }
-
-        this.nodeType = typeStr;
-        if (typeStr.equals(NodeIDType.OPENFLOW)) {
-            this.nodeID = Long.valueOf(HexEncode.stringToLong(IDStr));
-        } else if (typeStr.equals(NodeIDType.ONEPK)) {
-            this.nodeID = IDStr;
-        } else if (typeStr.equals(NodeIDType.PCEP)) {
-            this.nodeID = UUID.fromString(IDStr);
-        } else if (typeStr.equals(NodeIDType.PRODUCTION)) {
-            this.nodeID = IDStr;
-        } else {
-            //Use plugin's method to get appropriate conversion from IDStr to nodeID
-            INodeFactory f = (INodeFactory) ServiceHelper
-                    .getGlobalInstance(INodeFactory.class, new Node(), "(protocolName="+typeStr+")");
-            if(f!=null){
-                Node n = f.fromString(typeStr, IDStr);
-                this.nodeID = n.nodeID;
-            }
-        }
-    }
-
-    /**
-     * Private setter for nodeType to be called by JAXB not by anyone
-     * else, Node is immutable
-     *
-     * @param type of node to be set
-     */
-    @SuppressWarnings("unused")
-    private void setType(String type) {
-        this.nodeType = type;
-        if (this.nodeIDString != null) {
-            this.fillmeFromString(type, this.nodeIDString);
-        }
-    }
-
-    /**
-     * getter for node ID
-     *
-     *
-     * @return The node ID for this Node object
-     */
-    public Object getID() {
-        return this.nodeID;
-    }
-
-    /**
-     * Getter for the node ID in string format
-     *
-     * @return The nodeID in string format
-     */
-    @XmlElement(name = "id")
-    public String getNodeIDString() {
-        if (this.nodeType.equals(NodeIDType.OPENFLOW)) {
-            return HexEncode.longToHexString((Long) this.nodeID);
-        } else {
-            return this.nodeID.toString();
-        }
-    }
-
-    /**
-     * private setter to be used by JAXB
-     *
-     * @param nodeIDString String representation for NodeID
-     */
-    @SuppressWarnings("unused")
-    private void setNodeIDString(String nodeIDString) {
-        this.nodeIDString = nodeIDString;
-        if (this.nodeType != null) {
-            this.fillmeFromString(this.nodeType, nodeIDString);
-        }
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + ((nodeID == null) ? 0 : nodeID.hashCode());
-        result = prime * result
-                + ((nodeType == null) ? 0 : nodeType.hashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj)
-            return true;
-        if (obj == null)
-            return false;
-        if (getClass() != obj.getClass())
-            return false;
-        Node other = (Node) obj;
-        if (nodeID == null) {
-            if (other.nodeID != null)
-                return false;
-        } else if (!nodeID.equals(other.nodeID))
-            return false;
-        if (nodeType == null) {
-            if (other.nodeType != null)
-                return false;
-        } else if (!nodeType.equals(other.nodeType))
-            return false;
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        if (this.nodeType.equals(NodeIDType.OPENFLOW)) {
-            return this.nodeType + "|"
-                + HexEncode.longToHexString((Long) this.nodeID);
-        } else {
-            return this.nodeType + "|" + this.nodeID.toString();
-        }
-    }
-
-    /**
-     * Static method to get back a Node from a string
-     *
-     * @param str string formatted in toString mode that can be
-     * converted back to a Node format.
-     *
-     * @return a Node if succed or null if no
-     */
-    public static Node fromString(String str) {
-        if (str == null) {
-            return null;
-        }
-
-        String parts[] = str.split("\\|");
-        if (parts.length != 2) {
-            // Try to guess from a String formatted as a long because
-            // for long time openflow has been prime citizen so lets
-            // keep this legacy for now
-            String numStr = str.toUpperCase();
-
-            Long ofNodeID = null;
-            if (numStr.startsWith("0X")) {
-                // Try as an hex number
-                try {
-                    BigInteger b = new BigInteger(
-                        numStr.replaceFirst("0X", ""), 16);
-                    ofNodeID = Long.valueOf(b.longValue());
-                } catch (Exception ex) {
-                    ofNodeID = null;
-                }
-            } else {
-                // Try as a decimal number
-                try {
-                    BigInteger b = new BigInteger(numStr);
-                    ofNodeID = Long.valueOf(b.longValue());
-                } catch (Exception ex) {
-                    ofNodeID = null;
-                }
-            }
-
-            // Startegy #3 parse as HexLong
-            if (ofNodeID == null) {
-                try {
-                    ofNodeID = Long.valueOf(HexEncode.stringToLong(numStr));
-                } catch (Exception ex) {
-                    ofNodeID = null;
-                }
-            }
-
-            // We ran out of ideas ... return null
-            if (ofNodeID == null) {
-                return null;
-            }
-
-            // Lets return the cooked up NodeID
-            try {
-                return new Node(NodeIDType.OPENFLOW, ofNodeID);
-            } catch (ConstructionException ex) {
-                return null;
-            }
-        }
-
-        String typeStr = parts[0];
-        String IDStr = parts[1];
-
-        return fromString(typeStr, IDStr);
-    }
-
-    /**
-     * Static method to get back a Node from a pair of strings, the
-     * first one being the Type representation, the second one being
-     * the ID string representation, expected to be heavily used in
-     * northbound API.
-     *
-     * @param type, the type of the node we are parsing
-     * @param id, the string representation of the node id
-     *
-     * @return a Node if succed or null if no
-     */
-    public static Node fromString(String typeStr, String IDStr) {
-        if (typeStr == null) {
-            return null;
-        }
-
-        if (IDStr == null) {
-            return null;
-        }
-
-        if (typeStr.equals(NodeIDType.OPENFLOW)) {
-            try {
-                Long ID = Long.valueOf(HexEncode.stringToLong(IDStr));
-                return new Node(typeStr, ID);
-            } catch (Exception ex) {
-                return null;
-            }
-        } else if (typeStr.equals(NodeIDType.ONEPK)) {
-            try {
-                return new Node(typeStr, IDStr);
-            } catch (Exception ex) {
-                return null;
-            }
-        } else if (typeStr.equals(NodeIDType.PCEP)) {
-            try {
-                UUID ID = UUID.fromString(IDStr);
-                return new Node(typeStr, ID);
-            } catch (Exception ex) {
-                return null;
-            }
-        } else if (typeStr.equals(NodeIDType.PRODUCTION)) {
-            try {
-                return new Node(typeStr, IDStr);
-            } catch (Exception ex) {
-                return null;
-            }
-        } else {
-            //Use INodeFactory to create a Node of registered Node type.
-            //The protocol plugin being used depends on typeStr.
-            INodeFactory f = (INodeFactory) ServiceHelper
-                    .getGlobalInstance(INodeFactory.class, new Node(), "(protocolName="+typeStr+")");
-            if(f==null)
-                return null;
-            return f.fromString(typeStr, IDStr);
-        }
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/NodeConnector.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/NodeConnector.java
deleted file mode 100644 (file)
index 7b1058a..0000000
+++ /dev/null
@@ -1,652 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * @file   NodeConnector.java
- *
- * @brief  Describe a generic network element attachment points,
- * attached to one Node, the NodeConnector is formed by the pair
- * (NodeConnectorType, NodeConnectorID) because each SDN technlogy can
- * identify an attachment point on the Node in different way.
- *
- */
-package org.opendaylight.controller.sal.core;
-
-import java.io.Serializable;
-import java.util.Collection;
-import java.util.HashSet;
-import java.util.Set;
-import java.util.concurrent.ConcurrentHashMap;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.apache.commons.lang3.tuple.ImmutablePair;
-import org.opendaylight.controller.sal.utils.INodeConnectorFactory;
-import org.opendaylight.controller.sal.utils.ServiceHelper;
-
-/**
- * Describe a generic network element attachment points,
- * attached to one Node, the NodeConnector is formed by the pair
- * (NodeConnectorType, NodeConnectorID) because each SDN technology can
- * identify an attachment point on the Node in different way.
- *
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class NodeConnector implements Serializable {
-    private static final long serialVersionUID = 1L;
-    public static final Short SPECIALNODECONNECTORID = (short) 0;
-
-    /**
-     * Enumerate the different types of NodeConnectors supported by the class
-     *
-     */
-    public static class NodeConnectorIDType {
-        private static final
-        ConcurrentHashMap<String, ImmutablePair<Class<? extends Object>, String>> compatibleType =
-            new ConcurrentHashMap<String, ImmutablePair<Class<? extends Object>, String>>();
-        /**
-         * Represents the OFPP_CONTROLLER reserved port to forward a
-         * packet to the controller, this is to send data packets
-         * to the controller from the data plane triggering
-         * a packet_in event.
-         */
-        public static String CONTROLLER = "CTRL";
-        /**
-         * Represents the OFPP_ALL reserved OF port
-         * to forward to ALL the ports in the system ,
-         * should be used for flooding like mechanism to
-         * be used cautiously to avoid excessive flooding.
-         */
-        public static String ALL = "ALL";
-        /**
-         * Represents the OFPP_LOCAL reserved OF port
-         * to access the local networking stack of the node
-         * of which the packet is destined. Typically used for
-         * inband OF communications channel.
-         */
-        public static String SWSTACK = "SW";
-        /**
-         * Describes OFPP_Normal reserved port destination that invokes
-         * the traditional native L2/L3 HW normal forwarding functionality
-         * if supported on the forwarding element.
-         */
-        public static String HWPATH = "HW";
-        public static String OPENFLOW = "OF";
-        public static String PCEP = "PE";
-        public static String ONEPK = "PK";
-        public static String OPENFLOW2PCEP = "O2E";
-        public static String PCEP2OPENFLOW = "E2O";
-        public static String OPENFLOW2ONEPK = "O2K";
-        public static String ONEPK2OPENFLOW = "K2O";
-        public static String PCEP2ONEPK = "E2K";
-        public static String ONEPK2PCEP = "K2E";
-        public static String PRODUCTION = "PR";
-
-        // Initialize the map with some well known, even though all of
-        // them could be siting outside of here, but it's convenient
-        // for Unit Testing coverage
-        static {
-            compatibleType.put(CONTROLLER,
-                               new ImmutablePair<Class<? extends Object>, String>(Short.class, null));
-            compatibleType.put(ALL,
-                               new ImmutablePair<Class<? extends Object>, String>(Short.class, null));
-            compatibleType.put(SWSTACK,
-                               new ImmutablePair<Class<? extends Object>, String>(Short.class, null));
-            compatibleType.put(HWPATH,
-                               new ImmutablePair<Class<? extends Object>, String>(Short.class, null));
-            compatibleType.put(OPENFLOW,
-                               new ImmutablePair<Class<? extends Object>, String>(Short.class,
-                                                 Node.NodeIDType.OPENFLOW));
-            compatibleType.put(PCEP,
-                               new ImmutablePair<Class<? extends Object>, String>(Integer.class,
-                                                 Node.NodeIDType.PCEP));
-            compatibleType.put(ONEPK,
-                               new ImmutablePair<Class<? extends Object>, String>(String.class,
-                                                 Node.NodeIDType.ONEPK));
-            compatibleType.put(OPENFLOW2PCEP,
-                               new ImmutablePair<Class<? extends Object>, String>(Short.class,
-                                                 Node.NodeIDType.OPENFLOW));
-            compatibleType.put(OPENFLOW2ONEPK,
-                               new ImmutablePair<Class<? extends Object>, String>(Short.class,
-                                                 Node.NodeIDType.OPENFLOW));
-            compatibleType.put(PCEP2OPENFLOW,
-                               new ImmutablePair<Class<? extends Object>, String>(Integer.class,
-                                                 Node.NodeIDType.PCEP));
-            compatibleType.put(PCEP2ONEPK,
-                               new ImmutablePair<Class<? extends Object>, String>(Integer.class,
-                                                 Node.NodeIDType.PCEP));
-            compatibleType.put(ONEPK2OPENFLOW,
-                               new ImmutablePair<Class<? extends Object>, String>(String.class,
-                                                 Node.NodeIDType.ONEPK));
-            compatibleType.put(ONEPK2PCEP,
-                               new ImmutablePair<Class<? extends Object>, String>(String.class,
-                                                 Node.NodeIDType.ONEPK));
-            compatibleType.put(PRODUCTION,
-                               new ImmutablePair<Class<? extends Object>, String>(String.class,
-                                                 Node.NodeIDType.PRODUCTION));
-        }
-
-        /**
-         * Return the type of the class expected for the
-         * NodeConnectorID, it's used for validity check in the constructor
-         *
-         * @param type, the type of the NodeConnector for which we
-         * want to retrieve the compatible class to be used as ID.
-         *
-         * @return The Class which is supposed to instantiate the ID
-         * for the NodeConnectorID
-         */
-        public static Class<?> getClassType(String type) {
-            if (compatibleType.get(type) == null) {
-                return null;
-            }
-            return compatibleType.get(type).getLeft();
-        }
-
-        /**
-         * Return the NodeIDType compatible with this NodeConnector,
-         * in fact you cannot attach for example a PCEP NodeConnector
-         * to an OpenFlow Node.
-         *
-         * @param type, the type of the NodeConnector for which we
-         * want to retrieve the compatible class to be used as ID.
-         *
-         * @return The ID of the compatible Node
-         */
-        public static String getCompatibleNode(String type) {
-            if (compatibleType.get(type) == null) {
-                return null;
-            }
-            return compatibleType.get(type).getRight();
-        }
-
-        /**
-         * Register a new ID for which Node can be created
-         *
-         * @param type, the new type being registered
-         * @param compatibleID, the type of class to be accepted as ID
-         * @param compatibleNode, the type of Node with which this
-         * NodeConnector is compatible
-         *
-         * @return true if registered, false otherwise
-         */
-        public static boolean registerIDType(String type,
-                                             Class<? extends Object> compatibleID,
-                                             String compatibleNode) {
-            if (compatibleType.get(type) != null) {
-                return false;
-            }  else {
-                compatibleType.put(type, new ImmutablePair<Class<? extends Object>, String>(compatibleID,
-                                                           compatibleNode));
-                return true;
-            }
-        }
-
-        /**
-         * UNRegister a new ID for which Node can be created
-         *
-         * @param type, the type being UN-registered
-         *
-         */
-        public static void unRegisterIDType(String type) {
-            compatibleType.remove(type);
-        }
-    }
-
-    // Elements that constitute the NodeConnector
-    private Object nodeConnectorID;
-    private String nodeConnectorType;
-    @XmlElement(name = "node")
-    private Node nodeConnectorNode;
-
-    // Helper field for JAXB
-    private String nodeConnectorIDString;
-
-    /**
-     * Private constructor used for JAXB mapping
-     */
-    private NodeConnector() {
-        this.nodeConnectorIDString = null;
-        this.nodeConnectorID = null;
-        this.nodeConnectorType = null;
-        this.nodeConnectorNode = null;
-    }
-
-    /**
-     * Create a NodeConnector from the component element. The
-     * constructor make sure the NodeConnector type is congruent with
-     * the Node used and also the NodeConnector ID is of type expected
-     *
-     * @param nodeConnectorType Type of the NodeConnector
-     * @param id ID portion of the NodeConnector
-     * @param node Node to which the NodeConnector is attached too
-     *
-     */
-    public NodeConnector(String nodeConnectorType, Object id,
-            Node node) throws ConstructionException {
-        // In case of compatible type being null then assume that this
-        // port can be attached on any node.
-        String compatibleNode =
-            NodeConnectorIDType.getCompatibleNode(nodeConnectorType);
-        if (NodeConnectorIDType.getClassType(nodeConnectorType) != null &&
-            NodeConnectorIDType.getClassType(nodeConnectorType).isInstance(id) &&
-            (compatibleNode == null ||
-             node.getType().equals(compatibleNode))) {
-            this.nodeConnectorType = nodeConnectorType;
-            this.nodeConnectorID = id;
-            this.nodeConnectorNode = node;
-        } else {
-            throw new ConstructionException("Type of incoming object:"
-                    + id.getClass() + " not compatible with expected type:"
-                    + NodeConnectorIDType.getClassType(nodeConnectorType)
-                    + " or Node type incompatible:" + node.getType());
-        }
-    }
-
-    /**
-     * Copy constructor for NodeConnector
-     *
-     * @param src NodeConnector to copy from
-     *
-     */
-    public NodeConnector(NodeConnector src) throws ConstructionException {
-        if (src != null) {
-            this.nodeConnectorType = src.getType();
-            // Here we can reference the object because that is
-            // supposed to be an immutable identifier as well like a
-            // UUID/Integer and so on, hence no need to create a copy
-            // of it
-            this.nodeConnectorID = src.getID();
-            this.nodeConnectorNode = new Node(src.getNode());
-        } else {
-            throw
-                new ConstructionException("Null incoming object to copy from");
-        }
-    }
-
-    /**
-     * getter method for NodeConnector
-     *
-     *
-     * @return the NodeConnectorType of this object
-     */
-    @XmlElement(name = "type")
-    public String getType() {
-        return this.nodeConnectorType;
-    }
-
-    /**
-     * fill the current object from the string parameters passed, will
-     * be only used by JAXB
-     *
-     * @param typeStr string representing the type of the Node
-     * @param IDStr String representation of the ID
-     */
-    private void fillmeFromString(String typeStr, String IDStr) {
-        if (typeStr == null) {
-            return;
-        }
-
-        if (IDStr == null) {
-            return;
-        }
-
-        this.nodeConnectorType = typeStr;
-        if (typeStr.equals(NodeConnectorIDType.OPENFLOW) ||
-            typeStr.equals(NodeConnectorIDType.OPENFLOW2ONEPK) ||
-            typeStr.equals(NodeConnectorIDType.OPENFLOW2PCEP)) {
-            try {
-                Short ID = Short.parseShort(IDStr);
-                this.nodeConnectorID = ID;
-            } catch (Exception ex) {
-                return;
-            }
-        } else if (typeStr.equals(NodeConnectorIDType.ONEPK) ||
-                   typeStr.equals(NodeConnectorIDType.ONEPK2OPENFLOW) ||
-                   typeStr.equals(NodeConnectorIDType.ONEPK2PCEP) ||
-                   typeStr.equals(NodeConnectorIDType.PRODUCTION)) {
-            try {
-                this.nodeConnectorID = IDStr;
-            } catch (Exception ex) {
-                return;
-            }
-        } else if (typeStr.equals(NodeConnectorIDType.PCEP) ||
-                   typeStr.equals(NodeConnectorIDType.PCEP2ONEPK) ||
-                   typeStr.equals(NodeConnectorIDType.PCEP2OPENFLOW)) {
-            try {
-                Integer ID = Integer.parseInt(IDStr);
-                this.nodeConnectorID = ID;
-            } catch (Exception ex) {
-                return;
-            }
-        } else {
-            // Lookup via OSGi service registry
-        }
-    }
-
-    /**
-     * Private setter for nodeConnectorType to be called by JAXB not by anyone
-     * else, NodeConnector is immutable
-     *
-     * @param type of node to be set
-     */
-    @SuppressWarnings("unused")
-    private void setType(String type) {
-        this.nodeConnectorType = type;
-        if (this.nodeConnectorIDString != null) {
-            this.fillmeFromString(type, this.nodeConnectorIDString);
-        }
-    }
-
-    /**
-     * getter method for NodeConnector
-     *
-     *
-     * @return the NodeConnector ID of this object
-     */
-    public Object getID() {
-        return this.nodeConnectorID;
-    }
-
-    /**
-     * getter method for NodeConnector ID in string format.
-     *
-     *
-     * @return the NodeConnector ID of this object in String format
-     */
-    @XmlElement(name = "id")
-    public String getNodeConnectorIDString() {
-        return this.nodeConnectorID.toString();
-    }
-
-    /**
-     * private setter to be used by JAXB
-     *
-     * @param nodeConnectorIDString String representation for NodeConnectorID
-     */
-    @SuppressWarnings("unused")
-    private void setNodeConnectorIDString(String IDStr) {
-        this.nodeConnectorIDString = IDStr;
-        if (this.nodeConnectorType != null) {
-            this.fillmeFromString(this.nodeConnectorType, IDStr);
-        }
-    }
-
-    /**
-     * getter method for NodeConnector
-     *
-     *
-     * @return the Node of this object
-     */
-    public Node getNode() {
-        return this.nodeConnectorNode;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result
-                + ((nodeConnectorID == null) ? 0 : nodeConnectorID.hashCode());
-        result = prime
-                * result
-                + ((nodeConnectorNode == null) ? 0 : nodeConnectorNode
-                        .hashCode());
-        result = prime
-                * result
-                + ((nodeConnectorType == null) ? 0 : nodeConnectorType
-                        .hashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        NodeConnector other = (NodeConnector) obj;
-        if (nodeConnectorID == null) {
-            if (other.nodeConnectorID != null) {
-                return false;
-            }
-        } else if (!nodeConnectorID.equals(other.nodeConnectorID)) {
-            return false;
-        }
-        if (nodeConnectorNode == null) {
-            if (other.nodeConnectorNode != null) {
-                return false;
-            }
-        } else if (!nodeConnectorNode.equals(other.nodeConnectorNode)) {
-            return false;
-        }
-        if (nodeConnectorType == null) {
-            if (other.nodeConnectorType != null) {
-                return false;
-            }
-        } else if (!nodeConnectorType.equals(other.nodeConnectorType)) {
-            return false;
-        }
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        return this.getNodeConnectorIdAsString() + "@" + this.nodeConnectorNode;
-    }
-
-    /**
-     * A String representation of the NodeConnector without
-     * the Node context
-     *
-     * @return A String representation of the NodeConnector without
-     * the Node context
-     */
-    public String getNodeConnectorIdAsString() {
-        if (this.nodeConnectorType
-            .equals(NodeConnectorIDType.CONTROLLER) ||
-            this.nodeConnectorType
-            .equals(NodeConnectorIDType.ALL) ||
-            this.nodeConnectorType
-            .equals(NodeConnectorIDType.SWSTACK) ||
-            this.nodeConnectorType
-            .equals(NodeConnectorIDType.HWPATH)) {
-            return this.nodeConnectorType;
-        } else {
-            return this.nodeConnectorType + "|"
-                    + this.nodeConnectorID.toString();
-        }
-    }
-
-    /**
-     * return a NodeConnector from a string
-     *
-     * @param str String to be parsed in a NodeConnector
-     *
-     * @return the NodeConnector if parse is successful, null otherwise
-     */
-    public static NodeConnector fromString(String str) {
-        if (str == null) {
-            return null;
-        }
-        String parts[] = str.split("\\@");
-        if (parts.length != 2) {
-            return null;
-        }
-        // Now get the Node from the Node portion
-        Node n = Node.fromString(parts[1]);
-        if (n == null) {
-            return null;
-        }
-        return fromStringNoNode(parts[0], n);
-    }
-
-    /**
-     * return a set of NodeConnector from a collection of string
-     *
-     * @param stringCollection Collection of String object to be parsed as a NodeConnector
-     *
-     * @return the Set of unique NodeConnector objects if parse is successful, empty Set otherwise
-     */
-    public static Set<NodeConnector> fromString(Collection<String> stringCollection) {
-        Set<NodeConnector> set = new HashSet<NodeConnector>();
-        if (stringCollection != null) {
-
-            for (String str : stringCollection) {
-                NodeConnector nodeConnector = NodeConnector.fromString(str);
-                if (nodeConnector != null) {
-                    set.add(nodeConnector);
-                }
-            }
-        }
-        return set;
-    }
-
-    /**
-     * return a NodeConnector from a string not containing explicitly
-     * the Node portion which has to be supplied as parameter
-     *
-     * @param str String to be parsed in a NodeConnector
-     * @param n Node to which the NodeConnector is attached
-     *
-     * @return the NodeConnector if parse is successful, null otherwise
-     */
-    public static NodeConnector fromStringNoNode(String str, Node n) {
-        if (str == null) {
-            return null;
-        }
-        String nodeConnectorParts[] = str.split("\\|");
-        if (nodeConnectorParts.length != 2) {
-            // Try to guess from a String formatted as a short because
-            // for long time openflow has been prime citizen so lets
-            // keep this legacy for now
-            String numStr = str.toUpperCase();
-
-            Short ofPortID = null;
-            // Try as an decimal/hex number
-            try {
-                ofPortID = Short.decode(numStr);
-            } catch (Exception ex) {
-                ofPortID = null;
-            }
-
-            // Lets try the special ports we know about
-            if (ofPortID == null) {
-                try {
-                    if (str.equalsIgnoreCase(NodeConnectorIDType.CONTROLLER
-                            .toString())) {
-                        return new NodeConnector(
-                                NodeConnectorIDType.CONTROLLER,
-                                SPECIALNODECONNECTORID, n);
-                    }
-                    if (str.equalsIgnoreCase(NodeConnectorIDType.HWPATH
-                            .toString())) {
-                        return new NodeConnector(NodeConnectorIDType.HWPATH,
-                                SPECIALNODECONNECTORID, n);
-                    }
-                    if (str.equalsIgnoreCase(NodeConnectorIDType.SWSTACK
-                            .toString())) {
-                        return new NodeConnector(NodeConnectorIDType.SWSTACK,
-                                SPECIALNODECONNECTORID, n);
-                    }
-                    if (str
-                            .equalsIgnoreCase(NodeConnectorIDType.ALL
-                                    .toString())) {
-                        return new NodeConnector(NodeConnectorIDType.ALL,
-                                SPECIALNODECONNECTORID, n);
-                    }
-                } catch (ConstructionException ex) {
-                    return null;
-                }
-                return null;
-            }
-
-            // Lets return the cooked up NodeID
-            try {
-                return new NodeConnector(NodeConnectorIDType.OPENFLOW,
-                        ofPortID, n);
-            } catch (ConstructionException ex) {
-                return null;
-            }
-        }
-
-        String typeStr = nodeConnectorParts[0];
-        String IDStr = nodeConnectorParts[1];
-        return fromStringNoNode(typeStr, IDStr, n);
-    }
-
-    /**
-     * return a NodeConnector from a pair (type, ID) in string format
-     * not containing explicitly the Node portion which has to be
-     * supplied as parameter
-     *
-     * @param typeStr type String to be parsed in a NodeConnector
-     * @param IDStr ID String portion to be parsed in a NodeConnector
-     * @param n Node to which the NodeConnector is attached
-     *
-     * @return the NodeConnector if parse is successful, null otherwise
-     */
-    public static NodeConnector fromStringNoNode(String typeStr, String IDStr,
-                                                 Node n) {
-        if (typeStr == null) {
-            return null;
-        }
-        if (IDStr == null) {
-            return null;
-        }
-
-        if (typeStr.equals(NodeConnectorIDType.OPENFLOW) ||
-            typeStr.equals(NodeConnectorIDType.OPENFLOW2ONEPK) ||
-            typeStr.equals(NodeConnectorIDType.OPENFLOW2PCEP)) {
-            try {
-                Short ID = Short.parseShort(IDStr);
-                return new NodeConnector(typeStr, ID, n);
-            } catch (Exception ex) {
-                return null;
-            }
-        } else if (typeStr.equals(NodeConnectorIDType.ONEPK) ||
-                   typeStr.equals(NodeConnectorIDType.ONEPK2OPENFLOW) ||
-                   typeStr.equals(NodeConnectorIDType.ONEPK2PCEP) ||
-                   typeStr.equals(NodeConnectorIDType.PRODUCTION)) {
-            try {
-                return new NodeConnector(typeStr, IDStr, n);
-            } catch (Exception ex) {
-                return null;
-            }
-        } else if (typeStr.equals(NodeConnectorIDType.PCEP) ||
-                   typeStr.equals(NodeConnectorIDType.PCEP2ONEPK) ||
-                   typeStr.equals(NodeConnectorIDType.PCEP2OPENFLOW)) {
-            try {
-                Integer ID = Integer.parseInt(IDStr);
-                return new NodeConnector(typeStr, ID, n);
-            } catch (Exception ex) {
-                return null;
-            }
-        } else {
-            //Use INodeConnectorFactory to create a NodeConnector of registered type.
-            //The protocol plugin being used depends on typeStr.
-            INodeConnectorFactory f = (INodeConnectorFactory) ServiceHelper
-                    .getGlobalInstance(INodeConnectorFactory.class, new NodeConnector(), "(protocolName="+typeStr+")");
-            if(f==null) {
-                return null;
-            }
-            return f.fromStringNoNode(typeStr, IDStr, n);
-        }
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/NodeTable.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/NodeTable.java
deleted file mode 100644 (file)
index 7df20e4..0000000
+++ /dev/null
@@ -1,300 +0,0 @@
-/*
- * Copyright (c) 2013 Big Switch Networks, Inc.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.sal.core;
-
-import java.io.Serializable;
-import java.util.Set;
-import java.util.UUID;
-import java.util.concurrent.ConcurrentHashMap;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class NodeTable implements Serializable {
-
-    private static final long serialVersionUID = 1L;
-    public static final Short SPECIALNODETABLEID = (short) 0;
-
-    /**
-     * Enum-like static class created with the purpose of identifing
-     * multiple type of nodes in the SDN network. The type is
-     * necessary to figure out to later on correctly use the
-     * nodeTableID. Using a static class instead of an Enum so we can add
-     * dynamically new types without changing anything in the
-     * surround.
-     */
-    public static final class NodeTableIDType {
-        private static final ConcurrentHashMap<String, Class<? extends Object>> compatibleType =
-                new ConcurrentHashMap<String, Class<? extends Object>>();
-        /**
-         * These are in compliance with the compatibility types in 'Node'
-         */
-        public static String OPENFLOW = "OF";
-        public static String PCEP = "PE";
-        public static String ONEPK = "PK";
-        public static String PRODUCTION = "PR";
-
-        // Pre-populated types, just here for convenience and ease of
-        // unit-testing, but certainly those could live also outside.
-        // Currently we allow these 4. It can be changed later.
-        static {
-            compatibleType.put(OPENFLOW, Byte.class);
-            compatibleType.put(PCEP, UUID.class);
-            compatibleType.put(ONEPK, String.class);
-            compatibleType.put(PRODUCTION, String.class);
-        }
-
-        /**
-         * Return the type of the class expected for the
-         * NodeTableID, it's used for validity check in the constructor
-         *
-         * @param type, the type of the NodeTable for which we
-         * want to retrieve the compatible class to be used as ID.
-         *
-         * @return The Class which is supposed to instantiate the ID
-         * for the NodeTableID
-         */
-        public static Class<?> getClassType(String type) {
-            return compatibleType.get(type);
-        }
-
-        /**
-         * Returns all the registered nodeTableIDTypes currently available
-         *
-         * @return The current registered NodeTableIDTypes
-         */
-        public static Set<String> values() {
-            return compatibleType.keySet();
-        }
-
-        /**
-         * Register a new ID for which NodeTable can be created
-         *
-         * @param type, the new type being registered
-         * @param compatibleID, the type of class to be accepted as ID
-         *
-         * @return true if registered, false otherwise
-         */
-        public static boolean registerIDType(String type,
-                Class<? extends Object> compatibleID) {
-            if (compatibleType.get(type) != null) {
-                return false;
-            }  else {
-                compatibleType.put(type, compatibleID);
-                return true;
-            }
-        }
-
-        /**
-         * UNRegister a new ID for which Node can be created
-         *
-         * @param type, the type being UN-registered
-         *
-         */
-        public static void unRegisterIDType(String type) {
-            compatibleType.remove(type);
-        }
-    }
-
-    // Elements that constitute the NodeTable
-    private Object nodeTableID;
-    private String nodeTableType;
-    @XmlElement(name = "node")
-    private Node nodeTableNode;
-
-    // Helper field for JAXB
-    private String nodeTableIDString;
-
-    /**
-     * Private constructor used for JAXB mapping
-     */
-    @SuppressWarnings("unused")
-    private NodeTable() {
-        this.nodeTableIDString = null;
-        this.nodeTableID = null;
-        this.nodeTableType = null;
-        this.nodeTableNode = null;
-    }
-
-    public NodeTable(String nodeTableType, Object id, Node node) throws ConstructionException {
-        if (NodeTableIDType.getClassType(nodeTableType) != null &&
-                NodeTableIDType.getClassType(nodeTableType).isInstance(id) &&
-                node.getType().equals(nodeTableType)) {
-            this.nodeTableType = nodeTableType;
-            this.nodeTableID = id;
-            this.nodeTableNode = node;
-        } else {
-            throw new ConstructionException("Type of incoming object:"
-                    + id.getClass() + " not compatible with expected type:"
-                    + NodeTableIDType.getClassType(nodeTableType)
-                    + " or Node type incompatible:" + node.getType());
-        }
-    }
-
-    /**
-     * Copy constructor for NodeTable
-     *
-     * @param src NodeTable to copy from
-     *
-     */
-    public NodeTable(NodeTable src) throws ConstructionException {
-        if (src != null) {
-            this.nodeTableType = src.getType();
-            // Here we can reference the object because that is
-            // supposed to be an immutable identifier as well like a
-            // UUID/Integer and so on, hence no need to create a copy
-            // of it
-            this.nodeTableID = src.getID();
-            this.nodeTableNode = new Node(src.getNode());
-        } else {
-            throw
-            new ConstructionException("Null incoming object to copy from");
-        }
-    }
-
-    /**
-     * @return the nodeTableID
-     */
-    public Object getID() {
-        return this.nodeTableID;
-    }
-
-    /**
-     * @return the nodeTableType
-     */
-    public String getType() {
-        return this.nodeTableType;
-    }
-
-    /**
-     * Private setter for nodeConnectorType to be called by JAXB not by anyone
-     * else, NodeConnector is immutable
-     *
-     * @param type the nodeTableType to set
-     */
-    @SuppressWarnings("unused")
-    private void setType(String type) {
-        this.nodeTableType = type;
-        if (this.nodeTableIDString != null) {
-            this.fillmeFromString(type, this.nodeTableIDString);
-        }
-    }
-
-    /**
-     * @return the nodeTableNode
-     */
-    public Node getNode() {
-        return this.nodeTableNode;
-    }
-
-    /**
-     * @param nodeTableNode the nodeTableNode to set
-     */
-    public void setNodeTableNode(Node nodeTableNode) {
-        this.nodeTableNode = nodeTableNode;
-    }
-
-    /**
-     * @return the nodeTableIDString
-     */
-    @XmlElement(name = "id")
-    public String getNodeTableIDString() {
-        return this.nodeTableIDString != null? this.nodeTableIDString : nodeTableID.toString();
-    }
-
-    /**
-     * @param nodeTableIDString the nodeTableIDString to set
-     */
-    @SuppressWarnings("unused")
-    private void setNodeTableIDString(String IDStr) {
-        this.nodeTableIDString = IDStr;
-        if (this.nodeTableType != null) {
-            this.fillmeFromString(this.nodeTableType, IDStr);
-        }
-    }
-
-    /**
-     * fill the current object from the string parameters passed, will
-     * be only used by JAXB
-     *
-     * @param typeStr string representing the type of the Node
-     * @param IDStr String representation of the ID
-     */
-    private void fillmeFromString(String typeStr, String IDStr) {
-        if (typeStr == null) {
-            return;
-        }
-
-        if (IDStr == null) {
-            return;
-        }
-
-        this.nodeTableType = typeStr;
-        this.nodeTableID = (byte) Byte.parseByte(IDStr);
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result
-                + ((nodeTableID == null) ? 0 : nodeTableID.hashCode());
-        result = prime
-                * result
-                + ((nodeTableNode == null) ? 0 : nodeTableNode
-                        .hashCode());
-        result = prime
-                * result
-                + ((nodeTableType == null) ? 0 : nodeTableType
-                        .hashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj)
-            return true;
-        if (obj == null)
-            return false;
-        if (getClass() != obj.getClass())
-            return false;
-        NodeTable other = (NodeTable) obj;
-        if (nodeTableID == null) {
-            if (other.nodeTableID != null)
-                return false;
-        } else if (!nodeTableID.equals(other.nodeTableID))
-            return false;
-        if (nodeTableNode == null) {
-            if (other.nodeTableNode != null)
-                return false;
-        } else if (!nodeTableNode.equals(other.nodeTableNode))
-            return false;
-        if (nodeTableType == null) {
-            if (other.nodeTableType != null)
-                return false;
-        } else if (!nodeTableType.equals(other.nodeTableType))
-            return false;
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        return this.getNodeTableIdAsString() + "@" + this.nodeTableNode;
-    }
-
-    public String getNodeTableIdAsString() {
-        return this.nodeTableType + "|"
-                + this.nodeTableID.toString();
-    }
-
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/Path.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/Path.java
deleted file mode 100644 (file)
index 6049cee..0000000
+++ /dev/null
@@ -1,208 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * @file   Path.java
- *
- * @brief  Describe a path as a sequence of Edge such that from
- * each of its Head Node there is an link to the next Tail Node in the sequence
- *
- */
-package org.opendaylight.controller.sal.core;
-
-import java.io.Serializable;
-import java.util.ArrayList;
-import java.util.Arrays;
-import java.util.Collections;
-import java.util.LinkedList;
-import java.util.List;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-/**
- * Describe a path as a sequence of Edge such that from
- * each of its Head Node there is an link to the next Tail Node in the
- * sequence
- *
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class Path implements Serializable {
-    private static final long serialVersionUID = 1L;
-    @XmlElement
-    private List<Edge> edges;
-
-    /**
-     * Private constructor used for JAXB mapping
-     */
-    @SuppressWarnings("unused")
-    private Path() {
-        this.edges = null;
-    }
-
-    /**
-     * Construct an object representing a path, the constructor will
-     * check if the passed list of edges is such that for every
-     * consecutive edges the head node of the first edge coincide with
-     * the tail node of the subsequent in order for connectivity to be there.
-     *
-     * @param edges Edges of the path
-     *
-     */
-    public Path(List<Edge> edges) throws ConstructionException {
-        // Lets check if the list of edges is such that the head node
-        // of an edge is also the tail node of the subsequent one
-        boolean sequential = true;
-        if (edges.size() >= 2) {
-            for (int i = 0; i < edges.size() - 1; i++) {
-                Edge current = edges.get(i);
-                Edge next = edges.get(i + 1);
-                if (!current.getHeadNodeConnector().getNode().equals(next.getTailNodeConnector().getNode())) {
-                    sequential = false;
-                    break;
-                }
-            }
-        } else if (edges.size() == 0) {
-            throw new ConstructionException("Path is empty");
-        }
-
-        if (!sequential) {
-            throw new ConstructionException("Path is not sequential");
-        }
-
-        this.edges = edges;
-    }
-
-    /**
-     * Create the reversed path
-     * @return The reversed path
-     */
-    public Path reverse() {
-        int j = edges.size(); // size always > 0
-        Edge[]  aEdges = new Edge[j];
-        for (Edge e : edges) {
-            j--;
-            aEdges[j] = e.reverse();
-        }
-        Path rp;
-        try {
-         rp = new Path(Arrays.asList(aEdges));
-        } catch (ConstructionException ce) {
-            rp = null;
-        }
-        return rp;
-    }
-
-    /**
-     * Return the list of nodes of this path, the first node is the start node
-     * @return the list of nodes
-     */
-    public List<Node> getNodes() {
-        List<Node> nl = new ArrayList<Node>();
-        nl.add(this.getStartNode());
-        for (Edge e : edges) {
-            nl.add(e.getHeadNodeConnector().getNode());
-        }
-        return nl;
-    }
-
-    /**
-     * Copy Construct for a path
-     *
-     * @param src Path to copy from
-     *
-     */
-    public Path(Path src) throws ConstructionException {
-        if (src != null) {
-            this.edges = new LinkedList<Edge>(src.getEdges());
-        } else {
-            throw new ConstructionException("src supplied was null");
-        }
-    }
-
-    /**
-     * get the First Node of the path
-     *
-     *
-     * @return The start Node of the Path
-     */
-    public Node getStartNode() {
-        return this.edges.get(0).getTailNodeConnector().getNode();
-    }
-
-    /**
-     * get the Last Node of the path
-     *
-     *
-     * @return The last Node of the Path
-     */
-    public Node getEndNode() {
-        return this.edges.get(this.edges.size() - 1).getHeadNodeConnector()
-                .getNode();
-    }
-
-    /**
-     * getter method for the Path
-     *
-     *
-     * @return Return the list of edges that constitute the Path
-     */
-    public List<Edge> getEdges() {
-        return (edges == null) ? Collections.<Edge>emptyList() : new ArrayList<Edge>(edges);
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + ((edges == null) ? 0 : edges.hashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        Path other = (Path) obj;
-        if (edges == null) {
-            if (other.edges != null) {
-                return false;
-            }
-        } else if (!edges.equals(other.edges)) {
-            return false;
-        }
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        StringBuilder sb = new StringBuilder();
-        sb.append("[");
-        for (int i = 0; i < this.edges.size(); i++) {
-            if (i != 0) {
-                // add the comma to the previous element
-                sb.append(",");
-            }
-            sb.append(this.edges.get(i).toString());
-        }
-        sb.append("]");
-        return sb.toString();
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/PeerBandwidth.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/PeerBandwidth.java
deleted file mode 100644 (file)
index 3e448e4..0000000
+++ /dev/null
@@ -1,58 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.core;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlRootElement;
-
-/**
- * @file   PeerBandWidth.java
- *
- * @brief  Class representing peer bandwidth
- *
- * Describes peer Bandwidth of peer element. It's intended in multiple of
- *  bits per seconds.
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class PeerBandwidth extends Bandwidth {
-        private static final long serialVersionUID = 1L;
-
-        public static final String PeerBandwidthPropName = "peerBandwidth";
-
-        public PeerBandwidth(long value) {
-                super(PeerBandwidthPropName);
-                this.bandwidthValue = value;
-        }
-
-        /*
-     * Private constructor used for JAXB mapping
-     */
-    private PeerBandwidth() {
-        super(PeerBandwidthPropName);
-                this.bandwidthValue = 0;
-    }
-
-        public PeerBandwidth clone() {
-                return new PeerBandwidth(this.bandwidthValue);
-    }
-
-
-    @Override
-    public String toString() {
-        StringBuffer sb = new StringBuffer();
-        sb.append("PeerBandWidth[");
-        sb.append(super.toString());
-        sb.append("]");
-        return sb.toString();
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/Property.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/Property.java
deleted file mode 100644 (file)
index fe35ea5..0000000
+++ /dev/null
@@ -1,98 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.core;
-
-import java.io.Serializable;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlRootElement;
-
-/**
- * @file   Property.java
- *
- * @brief  Abstract base class for a Property that can be attached to
- * any sal core element
- *
- * Abstract base class for a Property that can be attached to any sal
- * core element
- */
-
-/**
- * Abstract base class for a Property that can be attached to any sal core
- * element
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-abstract public class Property implements Serializable, Cloneable {
-    private static final long serialVersionUID = 1L;
-    private final String name;
-
-    /**
-     * Private constructor used for JAXB mapping
-     */
-    @SuppressWarnings("unused")
-    private Property() {
-        this.name = null;
-    }
-
-    protected Property(String name) {
-        this.name = name;
-    }
-
-    public String getName() {
-        return this.name;
-    }
-
-    public abstract String getStringValue();
-
-    /**
-     * Used to copy the Property in a polymorphic way
-     *
-     * @return A clone of this Property
-     */
-    @Override
-    public abstract Property clone();
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + ((name == null) ? 0 : name.hashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        Property other = (Property) obj;
-        if (name == null) {
-            if (other.name != null) {
-                return false;
-            }
-        } else if (!name.equals(other.name)) {
-            return false;
-        }
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        return "Property [name=" + name + "]";
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/State.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/State.java
deleted file mode 100644 (file)
index 4bda500..0000000
+++ /dev/null
@@ -1,96 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.core;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-/**
- * The class represents the State property of an Edge
- *
- *
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@SuppressWarnings("serial")
-@Deprecated
-public class State extends Property {
-    @XmlElement(name="value")
-    private short stateValue;
-
-    public static final short EDGE_DOWN = 0;
-    public static final short EDGE_UP = 1;
-    public static final short EDGE_UNK = 0x7fff;
-    public static final String StatePropName = "state";
-
-    /*
-     * Private constructor used for JAXB mapping
-     */
-    private State() {
-        super(StatePropName);
-        this.stateValue = EDGE_UNK;
-    }
-
-    public State(short state) {
-        super(StatePropName);
-        this.stateValue = state;
-    }
-
-    @Override
-    public State clone() {
-        return new State(this.stateValue);
-    }
-
-    public short getValue() {
-        return this.stateValue;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = super.hashCode();
-        result = prime * result + stateValue;
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj)
-            return true;
-        if (!super.equals(obj))
-            return false;
-        if (getClass() != obj.getClass())
-            return false;
-        State other = (State) obj;
-        if (stateValue != other.stateValue)
-            return false;
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        return "State[" + stateValue + "]";
-    }
-
-    @Override
-    public String getStringValue() {
-        if (stateValue == 0) {
-            return ("EDGE_DOWN");
-        } else if (stateValue == 1) {
-            return ("EDGE_UP");
-        } else if (stateValue == 0x7fff) {
-            return ("EDGE_UNK");
-        } else {
-            return String.valueOf(stateValue);
-        }
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/SupportedBandwidth.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/SupportedBandwidth.java
deleted file mode 100644 (file)
index 842104f..0000000
+++ /dev/null
@@ -1,59 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.core;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlRootElement;
-
-/**
- * @file   SupportedBandWidth.java
- *
- * @brief  Class representing supported bandwidth
- *
- * Describes Supported Bandwidth which could be of a link or whatever could have
- * bandwidth as description. It's intended in multiple of bits per
- * seconds.
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class SupportedBandwidth extends Bandwidth {
-        private static final long serialVersionUID = 1L;
-        public static final String SupportedBandwidthPropName = "supportedBandwidth";
-
-        public SupportedBandwidth(long value) {
-                super(SupportedBandwidthPropName);
-                this.bandwidthValue = value;
-        }
-
-        /*
-     * Private constructor used for JAXB mapping
-     */
-    private SupportedBandwidth() {
-        super(SupportedBandwidthPropName);
-                this.bandwidthValue = 0;
-    }
-
-        public SupportedBandwidth clone() {
-                return new SupportedBandwidth(this.bandwidthValue);
-    }
-
-    @Override
-    public String toString() {
-        StringBuffer sb = new StringBuffer();
-        sb.append("SupportedBandWidth[");
-        sb.append(super.toString());
-        sb.append("]");
-        return sb.toString();
-    }
-
-
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/Tables.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/Tables.java
deleted file mode 100644 (file)
index 99a3661..0000000
+++ /dev/null
@@ -1,92 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.core;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-/**
- * @file   Tables.java
- *
- * @brief  Class representing tables
- *
- * Describes supported # of datapath tables
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class Tables extends Property {
-        private static final long serialVersionUID = 1L;
-    @XmlElement(name="value")
-    private byte tablesValue;
-
-    public static final String TablesPropName = "tables";
-    /**
-     * Construct a Tables property
-     *
-     * @param tables the Tables
-     * @return Constructed object
-     */
-    public Tables(byte tables) {
-        super(TablesPropName);
-        this.tablesValue = tables;
-    }
-
-    /*
-     * Private constructor used for JAXB mapping
-     */
-    private Tables() {
-        super(TablesPropName);
-        this.tablesValue = 0;
-    }
-
-    @Override
-    public Tables clone() {
-        return new Tables(this.tablesValue);
-    }
-
-    public byte getValue() {
-        return this.tablesValue;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = super.hashCode();
-        result = prime * result + tablesValue;
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj)
-            return true;
-        if (!super.equals(obj))
-            return false;
-        if (getClass() != obj.getClass())
-            return false;
-        Tables other = (Tables) obj;
-        if (tablesValue != other.tablesValue)
-            return false;
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        return "Tables[" + tablesValue + "]";
-    }
-
-    @Override
-    public String getStringValue() {
-        return String.format("%02x", tablesValue);
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/Tier.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/Tier.java
deleted file mode 100644 (file)
index 2e76e50..0000000
+++ /dev/null
@@ -1,84 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.core;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-/**
- * The class represents the Tier property of a node
- *
- *
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@SuppressWarnings("serial")
-@Deprecated
-public class Tier extends Property {
-    @XmlElement(name="value")
-    private int tierValue;
-    public static final String TierPropName = "tier";
-
-    public Tier(int tier) {
-        super(TierPropName);
-        this.tierValue = tier;
-    }
-
-    /*
-     * Private constructor used for JAXB mapping
-     */
-    private Tier() {
-        super(TierPropName);
-        this.tierValue = 0;
-    }
-
-    @Override
-    public Tier clone() {
-        return new Tier(this.tierValue);
-    }
-
-    public int getValue() {
-        return this.tierValue;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = super.hashCode();
-        result = prime * result + tierValue;
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj)
-            return true;
-        if (!super.equals(obj))
-            return false;
-        if (getClass() != obj.getClass())
-            return false;
-        Tier other = (Tier) obj;
-        if (tierValue != other.tierValue)
-            return false;
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        return "Tier[" + tierValue + "]";
-    }
-
-    @Override
-    public String getStringValue() {
-        return String.valueOf(tierValue);
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/TimeStamp.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/TimeStamp.java
deleted file mode 100644 (file)
index 288f765..0000000
+++ /dev/null
@@ -1,117 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.core;
-
-import java.util.Date;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-/**
- * @file   TimeStamp.java
- *
- * @brief  Class representing a TimeStamp
- *
- * A property describing a timestamp based following the rules of
- * java.util.Date, also given the time stamp represent the time when
- * something happened, then a name is attached to this property so
- * to qualify what are we talking about
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class TimeStamp extends Property {
-    private static final long serialVersionUID = 1L;
-    @XmlElement(name = "value")
-    private long timestamp;
-    @XmlElement(name = "name")
-    private String timestampName;
-
-    public static final String TimeStampPropName = "timeStamp";
-
-    /**
-     * Construct a TimeStamp proporty
-     *
-     * @param timestamp the time stampt we want to describe in "epoch"
-     * format following the rules of java.util.Date
-     * @param timestampName A qualifier for the timestamp, for example
-     * "JoinTime" or any even qualifier could come up
-     *
-     * @return Constructed object
-     */
-    public TimeStamp(long timestamp, String timestampName) {
-        super(TimeStampPropName);
-        this.timestamp = timestamp;
-        this.timestampName = timestampName;
-    }
-
-    /*
-     * Private constructor used for JAXB mapping
-     */
-    private TimeStamp() {
-        super(TimeStampPropName);
-        this.timestamp = 0;
-        this.timestampName = null;
-    }
-
-    @Override
-    public TimeStamp clone() {
-        return new TimeStamp(this.timestamp, this.timestampName);
-    }
-
-    public long getValue() {
-        return this.timestamp;
-    }
-
-    public String getTimeStampName() {
-        return this.timestampName;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = super.hashCode();
-        result = prime * result + (int) (timestamp ^ (timestamp >>> 32));
-        result = prime * result
-                + ((timestampName == null) ? 0 : timestampName.hashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj)
-            return true;
-        if (!super.equals(obj))
-            return false;
-        if (getClass() != obj.getClass())
-            return false;
-        TimeStamp other = (TimeStamp) obj;
-        if (timestamp != other.timestamp)
-            return false;
-        if (timestampName == null) {
-            if (other.timestampName != null)
-                return false;
-        } else if (!timestampName.equals(other.timestampName))
-            return false;
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        return "TimeStamp[" + timestampName + ": " + timestamp +"]";
-    }
-
-    @Override
-    public String getStringValue() {
-        return timestampName + ": " + new Date(timestamp);
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/UpdateType.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/core/UpdateType.java
deleted file mode 100644 (file)
index 99a21a8..0000000
+++ /dev/null
@@ -1,40 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.core;
-
-
-/**
- * @file   UpdateType.java
- *
- * @brief  Describes update types
- *
- */
-@Deprecated
-public enum UpdateType {
-    ADDED("added"), REMOVED("removed"), CHANGED("changed");
-
-    private String name;
-
-    UpdateType(String name) {
-        this.name = name;
-    }
-
-    public String getName() {
-        return this.name;
-    }
-
-    public int calculateConsistentHashCode() {
-        if (this.name != null) {
-            return this.name.hashCode();
-        } else {
-            return 0;
-        }
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/discovery/IDiscoveryService.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/discovery/IDiscoveryService.java
deleted file mode 100644 (file)
index 26e9ab5..0000000
+++ /dev/null
@@ -1,34 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.discovery;
-
-import java.util.Set;
-
-import org.opendaylight.controller.sal.core.Edge;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.core.UpdateType;
-
-/**
- * The interface provides the methods to notify the listener when an edge is
- * added/deleted/changed.
- */
-@Deprecated
-public interface IDiscoveryService {
-    /**
-     * The methods is called when an edge is added/deleted/changed
-     *
-     * @param edge                      {@link org.opendaylight.controller.sal.core.Edge} being updated
-     * @param type              {@link org.opendaylight.controller.sal.core.UpdateType}
-     * @param props             set of {@link org.opendaylight.controller.sal.core.Property} like
-     *                                          {@link org.opendaylight.controller.sal.core.Bandwidth} and/or
-     *                                          {@link org.opendaylight.controller.sal.core.Latency} etc.
-     */
-    public void notifyEdge(Edge edge, UpdateType type, Set<Property> props);
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/flowprogrammer/Flow.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/flowprogrammer/Flow.java
deleted file mode 100644 (file)
index 8505793..0000000
+++ /dev/null
@@ -1,309 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.flowprogrammer;
-
-import org.opendaylight.controller.sal.action.Action;
-import org.opendaylight.controller.sal.action.ActionType;
-import org.opendaylight.controller.sal.action.SetDlType;
-import org.opendaylight.controller.sal.action.SetNwDst;
-import org.opendaylight.controller.sal.action.SetNwSrc;
-import org.opendaylight.controller.sal.match.Match;
-import org.opendaylight.controller.sal.utils.EtherTypes;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-import java.io.Serializable;
-import java.net.Inet6Address;
-import java.util.ArrayList;
-import java.util.Iterator;
-import java.util.List;
-
-/**
- * Represent a flow: match + actions + flow specific properties
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class Flow implements Cloneable, Serializable {
-    protected static final Logger logger = LoggerFactory.getLogger(Flow.class);
-    private static final long serialVersionUID = 1L;
-    @XmlElement
-    private Match match;
-    @XmlElement
-    private List<Action> actions;
-    @XmlElement
-    private short priority;
-    @XmlElement
-    private short idleTimeout;
-    @XmlElement
-    private short hardTimeout;
-    @XmlElement
-    private long id; // unique identifier for this flow
-
-    public Flow() {
-        match = null;
-        actions = null;
-    }
-
-    public Flow(Match match, List<Action> actions) {
-        if (match.isIPv4() && actionsAreIPv6()) {
-            try {
-                throw new Exception("Conflicting Match and Action list");
-            } catch (Exception e) {
-                logger.error("", e);
-            }
-        } else {
-            this.match = match;
-            this.actions = actions;
-        }
-    }
-
-    /**
-     * Return a copy of the Match configured on this flow
-     *
-     * @return
-     */
-    public Match getMatch() {
-        return match.clone();
-    }
-
-    /**
-     * Set the Match for this flow This operation will overwrite an existing
-     * Match if present
-     *
-     * @param match
-     */
-    public void setMatch(Match match) {
-        this.match = match;
-    }
-
-    /**
-     * Returns a copy of the actions list of this flow
-     *
-     * @return
-     */
-    public List<Action> getActions() {
-        return (actions == null) ? null : new ArrayList<Action>(actions);
-    }
-
-    /**
-     * Set the actions list for this flow If a list is already present, it will
-     * be replaced with the passed one. During addition, only the valid actions
-     * will be added It is a no op if the passed actions is null An empty
-     * actions is a vlaid input
-     *
-     * @param actions
-     */
-    public void setActions(List<Action> actions) {
-        if (actions == null) {
-            return;
-        }
-
-        this.actions = new ArrayList<Action>(actions.size());
-        for (Action action : actions) {
-            if (action.isValid()) {
-                this.actions.add(action);
-            }
-        }
-    }
-
-    /**
-     * Returns whether the Flow is for IPv4 or IPv6 Information is derived from
-     * match and actions list
-     *
-     * @return
-     */
-    public boolean isIPv6() {
-        return (match.isIPv6()) ? true : actionsAreIPv6();
-    }
-
-    /**
-     * Returns true if it finds at least one action which is for IPv6 in the
-     * list of actions for this Flow
-     *
-     * @return
-     */
-    private boolean actionsAreIPv6() {
-        if (this.actions != null) {
-            for (Action action : actions) {
-                switch (action.getType()) {
-                case SET_NW_SRC:
-                    if (((SetNwSrc) action).getAddress() instanceof Inet6Address) {
-                        return true;
-                    }
-                    break;
-                case SET_NW_DST:
-                    if (((SetNwDst) action).getAddress() instanceof Inet6Address) {
-                        return true;
-                    }
-                    break;
-                case SET_DL_TYPE:
-                    if (((SetDlType) action).getDlType() == EtherTypes.IPv6.intValue()) {
-                        return true;
-                    }
-                    break;
-                default:
-                }
-            }
-        }
-        return false;
-    }
-
-    @Override
-    public Flow clone() {
-        Flow cloned = null;
-        try {
-            cloned = (Flow) super.clone();
-            cloned.match = this.getMatch();
-            cloned.actions = this.getActions();
-        } catch (CloneNotSupportedException e) {
-            logger.error("", e);
-        }
-        return cloned;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + ((actions == null) ? 0 : actions.hashCode());
-        result = prime * result + hardTimeout;
-        result = prime * result + (int) (id ^ (id >>> 32));
-        result = prime * result + idleTimeout;
-        result = prime * result + ((match == null) ? 0 : match.hashCode());
-        result = prime * result + priority;
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        Flow other = (Flow) obj;
-        if (actions == null) {
-            if (other.actions != null) {
-                return false;
-            }
-        } else if (!actions.equals(other.actions)) {
-            return false;
-        }
-        if (hardTimeout != other.hardTimeout) {
-            return false;
-        }
-        if (id != other.id) {
-            return false;
-        }
-        if (idleTimeout != other.idleTimeout) {
-            return false;
-        }
-        if (match == null) {
-            if (other.match != null) {
-                return false;
-            }
-        } else if (!match.equals(other.match)) {
-            return false;
-        }
-        if (priority != other.priority) {
-            return false;
-        }
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        return "Flow[match = " + match + ", actions = " + actions + ", priority = " + priority + ", id = " + id
-                + ", idleTimeout = " + idleTimeout + ", hardTimeout = " + hardTimeout + "]";
-    }
-
-    public short getPriority() {
-        return priority;
-    }
-
-    public void setPriority(short priority) {
-        this.priority = priority;
-    }
-
-    public short getIdleTimeout() {
-        return idleTimeout;
-    }
-
-    public void setIdleTimeout(short idleTimeout) {
-        this.idleTimeout = idleTimeout;
-    }
-
-    public short getHardTimeout() {
-        return hardTimeout;
-    }
-
-    public void setHardTimeout(short hardTimeout) {
-        this.hardTimeout = hardTimeout;
-    }
-
-    public long getId() {
-        return id;
-    }
-
-    public void setId(long id) {
-        this.id = id;
-    }
-
-    /**
-     * Adds the specified action to the list of action of this flow
-     *
-     * @param action
-     * @return false if the passed action is null or not valid or if it fails to
-     *         add it
-     */
-    public boolean addAction(Action action) {
-        if (action == null || !action.isValid()) {
-            return false;
-        }
-        return actions.add(action);
-    }
-
-    public boolean removeAction(Action action) {
-        if (action == null) {
-            return false;
-        }
-        return actions.remove(action);
-    }
-
-    /**
-     * remove ALL actions of type actionType from the list of actions of this
-     * flow
-     *
-     * @param actionType
-     * @return false if an action of that type is present and it fails to remove
-     *         it
-     */
-    public boolean removeAction(ActionType actionType) {
-        Iterator<Action> actionIter = this.getActions().iterator();
-        while (actionIter.hasNext()) {
-            Action action = actionIter.next();
-            if (action.getType() == actionType) {
-                if (!this.removeAction(action)) {
-                    return false;
-                }
-            }
-        }
-        return true;
-    }
-
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/flowprogrammer/IFlowProgrammerListener.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/flowprogrammer/IFlowProgrammerListener.java
deleted file mode 100644 (file)
index c8aed91..0000000
+++ /dev/null
@@ -1,19 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.flowprogrammer;
-
-/**
- * This interface defines the methods the SAL service which relay to the
- * functional modules the asynchronous messages related to flow programming
- * coming from the network nodes.
- */
-@Deprecated
-public interface IFlowProgrammerListener extends IPluginOutFlowProgrammerService {
-
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/flowprogrammer/IFlowProgrammerService.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/flowprogrammer/IFlowProgrammerService.java
deleted file mode 100644 (file)
index de4c25e..0000000
+++ /dev/null
@@ -1,129 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.flowprogrammer;
-
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.utils.Status;
-
-/**
- * Interface that defines the methods available to the functional modules above
- * SAL for installing/modifying/removing flows on a network node
- */
-@Deprecated
-public interface IFlowProgrammerService {
-    /**
-     * Synchronously add a flow to the network node
-     *
-     * @param node
-     *            The target network node
-     * @param flow
-     *            The flow to install
-     * @return The status of this request
-     */
-    Status addFlow(Node node, Flow flow);
-
-    /**
-     * Synchronously modify existing flow on the switch
-     *
-     * @param node
-     *            The target network node
-     * @param oldFlow
-     *            The existing flow to modify
-     * @param newFlow
-     *            The new flow to install
-     * @return The status of this request
-     */
-    Status modifyFlow(Node node, Flow oldFlow, Flow newFlow);
-
-    /**
-     * Synchronously remove the flow from the network node
-     *
-     * @param node
-     *            The target network node
-     * @param flow
-     *            The flow to remove
-     * @return The status of this request
-     */
-    Status removeFlow(Node node, Flow flow);
-
-    /**
-     * Asynchronously add a flow to the network node
-     *
-     * @param node
-     *            The target network node
-     * @param flow
-     *            The flow to install
-     * @return The status of this request containing the unique request id
-     */
-    Status addFlowAsync(Node node, Flow flow);
-
-    /**
-     * Asynchronously modify existing flow on the switch
-     *
-     * @param node
-     *            The target network node
-     * @param oldFlow
-     *            The existing flow to modify
-     * @param newFlow
-     *            The new flow to install
-     * @return The status of this request containing the unique request id
-     */
-    Status modifyFlowAsync(Node node, Flow oldFlow, Flow newFlow);
-
-    /**
-     * Asynchronously remove the flow from the network node
-     *
-     * @param node
-     *            The target network node
-     * @param flow
-     *            The flow to remove
-     * @return The status of this request containing the unique request id
-     */
-    Status removeFlowAsync(Node node, Flow flow);
-
-    /**
-     * Remove all flows present on the network node
-     *
-     * @param node
-     *            The target network node
-     * @return The status of this request containing the unique request id
-     */
-    Status removeAllFlows(Node node);
-
-    /**
-     * Send Barrier message synchronously. The caller will be blocked until the
-     * solicitation response arrives.
-     *
-     * Solicit the network node to report whether all the requests sent so far
-     * are completed. When this call is done, caller knows that all past flow
-     * operations requested to the node in asynchronous fashion were satisfied
-     * by the network node and that in case of any failure, a message was sent
-     * to the controller.
-     *
-     * @param node
-     *            The network node to solicit
-     * @return The status of this request containing the unique request id
-     */
-    Status syncSendBarrierMessage(Node node);
-
-    /**
-     * Send Barrier message asynchronously. The caller is not blocked.
-     *
-     * Solicit the network node to report whether all the requests sent so far
-     * are completed. When this call is done, caller knows that all past flow
-     * operations requested to the node in asynchronous fashion were satisfied
-     * by the network node and that in case of any failure, a message was sent
-     * to the controller.
-     *
-     * @param node
-     *            The network node to solicit
-     * @return The status of this request containing the unique request id
-     */
-    Status asyncSendBarrierMessage(Node node);
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/flowprogrammer/IPluginInFlowProgrammerService.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/flowprogrammer/IPluginInFlowProgrammerService.java
deleted file mode 100644 (file)
index 63481ee..0000000
+++ /dev/null
@@ -1,158 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.flowprogrammer;
-
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.utils.Status;
-
-/**
- * This interface defines the flow programmer methods to be implemented by
- * protocol plugins
- */
-@Deprecated
-public interface IPluginInFlowProgrammerService {
-    /**
-     * Synchronously add a flow to the network node
-     *
-     * @param node
-     *            the network node
-     *            {@link org.opendaylight.controller.sal.core.Node} on which the
-     *            flow got added
-     * @param flow
-     *            the flow
-     *            {@link org.opendaylight.controller.sal.flowprogrammer.Flow}
-     *            that got added
-     * @return Status the operation status
-     *         {@link org.opendaylight.controller.sal.utils.Status}
-     */
-    Status addFlow(Node node, Flow flow);
-
-    /**
-     * Synchronously modify existing flow on the switch
-     *
-     * @param node
-     *            the network node
-     *            {@link org.opendaylight.controller.sal.core.Node} on which the
-     *            flow got modified
-     * @param flow
-     *            the flow
-     *            {@link org.opendaylight.controller.sal.flowprogrammer.Flow}
-     *            that got modified
-     * @return Status the operation status
-     *         {@link org.opendaylight.controller.sal.utils.Status}
-     */
-    Status modifyFlow(Node node, Flow oldFlow, Flow newFlow);
-
-    /**
-     * Synchronously remove the flow from the network node
-     *
-     * @param node
-     *            the network node
-     *            {@link org.opendaylight.controller.sal.core.Node} on which the
-     *            flow got removed
-     * @param flow
-     *            the flow
-     *            {@link org.opendaylight.controller.sal.flowprogrammer.Flow}
-     *            that got removed
-     * @return Status the operation status
-     *         {@link org.opendaylight.controller.sal.utils.Status}
-     */
-    Status removeFlow(Node node, Flow flow);
-
-    /**
-     * Asynchronously add a flow to the network node
-     *
-     * @param node
-     *            the network node
-     *            {@link org.opendaylight.controller.sal.core.Node} on which the
-     *            flow got added
-     * @param flow
-     *            the flow
-     *            {@link org.opendaylight.controller.sal.flowprogrammer.Flow}
-     *            that got added
-     * @param rid
-     *            the request id
-     * @return Status the operation status
-     *         {@link org.opendaylight.controller.sal.utils.Status}
-     */
-    Status addFlowAsync(Node node, Flow flow, long rid);
-
-    /**
-     * Asynchronously modify existing flow on the switch
-     *
-     * @param node
-     *            the network node
-     *            {@link org.opendaylight.controller.sal.core.Node} on which the
-     *            flow got modified
-     * @param oldFlow
-     *            the original flow
-     *            {@link org.opendaylight.controller.sal.flowprogrammer.Flow}
-     * @param newFlow
-     *            the new flow
-     *            {@link org.opendaylight.controller.sal.flowprogrammer.Flow}
-     * @param rid
-     *            the request id
-     * @return Status the operation status
-     *         {@link org.opendaylight.controller.sal.utils.Status}
-     */
-    Status modifyFlowAsync(Node node, Flow oldFlow, Flow newFlow, long rid);
-
-    /**
-     * Asynchronously remove the flow from the network node
-     *
-     * @param node
-     *            the network node
-     *            {@link org.opendaylight.controller.sal.core.Node} on which the
-     *            flow got removed
-     * @param flow
-     *            the flow
-     *            {@link org.opendaylight.controller.sal.flowprogrammer.Flow}
-     *            that got removed
-     * @param rid
-     *            the request id
-     * @return Status the operation status
-     *         {@link org.opendaylight.controller.sal.utils.Status}
-     */
-    Status removeFlowAsync(Node node, Flow flow, long rid);
-
-    /**
-     * Remove all flows present on the network node
-     *
-     * @param node
-     *            the network node
-     *            {@link org.opendaylight.controller.sal.core.Node} on which the
-     *            flow got removed
-     * @return Status the operation status
-     *         {@link org.opendaylight.controller.sal.utils.Status}
-     */
-    Status removeAllFlows(Node node);
-
-    /**
-     * Send Barrier message synchronously. The caller will be blocked until the
-     * Barrier reply arrives.
-     *
-     * @param node
-     *            the network node
-     *            {@link org.opendaylight.controller.sal.core.Node}
-     * @return Status the operation status
-     *         {@link org.opendaylight.controller.sal.utils.Status}
-     */
-    Status syncSendBarrierMessage(Node node);
-
-    /**
-     * Send Barrier message asynchronously. The caller is not blocked.
-     *
-     * @param node
-     *            the network node
-     *            {@link org.opendaylight.controller.sal.core.Node}
-     * @return Status the operation status
-     *         {@link org.opendaylight.controller.sal.utils.Status}
-     */
-    Status asyncSendBarrierMessage(Node node);
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/flowprogrammer/IPluginOutFlowProgrammerService.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/flowprogrammer/IPluginOutFlowProgrammerService.java
deleted file mode 100644 (file)
index 83f45d4..0000000
+++ /dev/null
@@ -1,46 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.flowprogrammer;
-
-import org.opendaylight.controller.sal.core.Node;
-
-/**
- * This interface defines the methods the protocol plugin must implement to
- * inform the SAL layer about the asynchronous messages related to flow
- * programming coming from the network nodes.
- */
-@Deprecated
-public interface IPluginOutFlowProgrammerService {
-    /**
-     * Inform SAL that the flow on the specified node has been removed Consumer
-     * has to expect this notification only for flows which were installed with
-     * an idle or hard timeout specified.
-     *
-     * @param node
-     *            the network node on which the flow got removed
-     * @param flow
-     *            the flow that got removed. Note: It may contain only the Match
-     *            and flow parameters fields. Actions may not be present.
-     */
-    public void flowRemoved(Node node, Flow flow);
-
-    /**
-     * Inform SAL that an error message has been received from a switch
-     * regarding a flow message previously sent to the switch. A Request ID
-     * associated with the offending message is also returned.
-     *
-     * @param node
-     *            the network node on which the error reported
-     * @param rid
-     *            the offending message request id
-     * @param err
-     *            the error message
-     */
-    public void flowErrorReported(Node node, long rid, Object err);
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/inventory/IInventoryService.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/inventory/IInventoryService.java
deleted file mode 100644 (file)
index 32eb232..0000000
+++ /dev/null
@@ -1,46 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.inventory;
-
-import java.util.Map;
-import java.util.Set;
-import java.util.concurrent.ConcurrentMap;
-
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.Property;
-
-/**
- * The Interface describes methods invoked from application toward SAL to
- * solicit existing inventory data.
- */
-@Deprecated
-public interface IInventoryService {
-    /**
-     * The method retrieves all the existing nodes and properties attached
-     *
-     * @return map of {@link org.opendaylight.controller.sal.core.Node} and {@link org.opendaylight.controller.sal.core.Property}
-     */
-    public ConcurrentMap<Node, Map<String, Property>> getNodeProps();
-
-    /**
-     * The method retrieves all the configured nodes that are not connected to
-     * the controller
-     *
-     * @return Set of {@link org.opendaylight.controller.sal.core.Node}
-     */
-    public Set<Node> getConfiguredNotConnectedNodes();
-    /**
-     * The method retrieve all the existing nodeConnectors and their properties
-     *
-     * @return map of {@link org.opendaylight.controller.sal.core.NodeConnector} and {@link org.opendaylight.controller.sal.core.Property}
-     */
-    public ConcurrentMap<NodeConnector, Map<String, Property>> getNodeConnectorProps();
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/inventory/IListenInventoryUpdates.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/inventory/IListenInventoryUpdates.java
deleted file mode 100644 (file)
index 768d90c..0000000
+++ /dev/null
@@ -1,47 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.inventory;
-
-import java.util.Set;
-
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.core.UpdateType;
-
-/**
- * The interface provides the methods to notify the upper applications in
- * regards to any inventory changes.
- */
-@Deprecated
-public interface IListenInventoryUpdates {
-    /**
-     * This method is called when some properties of a node are added/deleted/changed.
-     *
-     * @param node                      {@link org.opendaylight.controller.sal.core.Node} being updated
-     * @param type              {@link org.opendaylight.controller.sal.core.UpdateType}
-     * @param props             set of {@link org.opendaylight.controller.sal.core.Property} such as
-     *                                          {@link org.opendaylight.controller.sal.core.Description} and/or
-     *                                          {@link org.opendaylight.controller.sal.core.Tier} etc.
-     */
-    public void updateNode(Node node, UpdateType type, Set<Property> props);
-
-    /**
-     * This method is called when some properties of a node connector are added/deleted/changed.
-     *
-     * @param nodeConnector {@link org.opendaylight.controller.sal.core.NodeConnector} being updated
-     * @param type              {@link org.opendaylight.controller.sal.core.UpdateType}
-     * @param props             set of {@link org.opendaylight.controller.sal.core.Property} such as
-     *                                          {@link org.opendaylight.controller.sal.core.Description} and/or
-     *                                          {@link org.opendaylight.controller.sal.core.State} etc.
-     */
-    public void updateNodeConnector(NodeConnector nodeConnector,
-            UpdateType type, Set<Property> props);
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/inventory/IPluginInInventoryService.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/inventory/IPluginInInventoryService.java
deleted file mode 100644 (file)
index 203c411..0000000
+++ /dev/null
@@ -1,49 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.inventory;
-
-import java.util.Map;
-import java.util.Set;
-import java.util.concurrent.ConcurrentMap;
-
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.Property;
-
-/**
- * The Interface describes methods invoked from SAL toward the protocol plugin
- * to solicit existing inventory data.
- */
-@Deprecated
-public interface IPluginInInventoryService {
-    /**
-     * The method retrieves all the existing nodes and properties attached
-     *
-     * @return map of {@link org.opendaylight.controller.sal.core.Node} and {@link org.opendaylight.controller.sal.core.Property}
-     */
-    public ConcurrentMap<Node, Map<String, Property>> getNodeProps();
-
-    /**
-     * The method retrieve all the existing nodeConnectors and their properties
-     *
-     * @param refresh true if it needs to solicit Openflow core; otherwise, retrieve from local cache.
-     * @return map of {@link org.opendaylight.controller.sal.core.NodeConnector} and {@link org.opendaylight.controller.sal.core.Property}
-     */
-    public ConcurrentMap<NodeConnector, Map<String, Property>> getNodeConnectorProps(
-            Boolean refresh);
-
-    /**
-     * The method retrieves all the configured nodes that are not connected to
-     * the controller
-     *
-     * @return Set of {@link org.opendaylight.controller.sal.core.Node}
-     */
-    public Set<Node> getConfiguredNotConnectedNodes();
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/inventory/IPluginOutInventoryService.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/inventory/IPluginOutInventoryService.java
deleted file mode 100644 (file)
index 56a0388..0000000
+++ /dev/null
@@ -1,47 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.inventory;
-
-import java.util.Set;
-
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.core.UpdateType;
-
-/**
- * The Interface describes Inventory update methods to be implemented by
- * protocol plugin.
- */
-@Deprecated
-public interface IPluginOutInventoryService {
-    /**
-     * This method is called when some properties of a node are added/deleted/changed.
-     *
-     * @param node                      {@link org.opendaylight.controller.sal.core.Node} being updated
-     * @param type              {@link org.opendaylight.controller.sal.core.UpdateType}
-     * @param props             set of {@link org.opendaylight.controller.sal.core.Property} such as
-     *                                          {@link org.opendaylight.controller.sal.core.Description} and/or
-     *                                          {@link org.opendaylight.controller.sal.core.Tier} etc.
-     */
-    public void updateNode(Node node, UpdateType type, Set<Property> props);
-
-    /**
-     * This method is called when some properties of a node connector are added/deleted/changed.
-     *
-     * @param nodeConnector {@link org.opendaylight.controller.sal.core.NodeConnector} being updated
-     * @param type              {@link org.opendaylight.controller.sal.core.UpdateType}
-     * @param props             set of {@link org.opendaylight.controller.sal.core.Property} such as
-     *                                          {@link org.opendaylight.controller.sal.core.Description} and/or
-     *                                          {@link org.opendaylight.controller.sal.core.State} etc.
-     */
-    public void updateNodeConnector(NodeConnector nodeConnector,
-            UpdateType type, Set<Property> props);
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/Match.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/Match.java
deleted file mode 100644 (file)
index 47f70b7..0000000
+++ /dev/null
@@ -1,580 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.match;
-
-import java.io.Serializable;
-import java.net.Inet4Address;
-import java.net.Inet6Address;
-import java.net.InetAddress;
-import java.util.ArrayList;
-import java.util.Arrays;
-import java.util.Collection;
-import java.util.Collections;
-import java.util.HashMap;
-import java.util.List;
-import java.util.Map;
-import java.util.Map.Entry;
-import java.util.TreeMap;
-import java.util.concurrent.ConcurrentMap;
-import java.util.concurrent.ConcurrentHashMap;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.utils.EtherTypes;
-import org.opendaylight.controller.sal.utils.IPProtocols;
-import org.opendaylight.controller.sal.utils.NetUtils;
-
-/**
- * Represents the generic match criteria for a network frame/packet/message
- * It contains a collection of individual field match
- *
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class Match implements Cloneable, Serializable {
-        private static final long serialVersionUID = 1L;
-        private static final Map<MatchType, MatchType> reversableMatches;
-    static {
-        Map<MatchType, MatchType> map = new HashMap<MatchType, MatchType>();
-        map.put(MatchType.DL_SRC, MatchType.DL_DST);
-        map.put(MatchType.DL_DST, MatchType.DL_SRC);
-        map.put(MatchType.NW_SRC, MatchType.NW_DST);
-        map.put(MatchType.NW_DST, MatchType.NW_SRC);
-        map.put(MatchType.TP_SRC, MatchType.TP_DST);
-        map.put(MatchType.TP_DST, MatchType.TP_SRC);
-        reversableMatches = Collections.unmodifiableMap(map);
-    }
-    private Map<MatchType, MatchField> fields;
-    private int matches; // concise way to tell which fields the match
-                         // is set for (may remove if not needed)
-    private ConcurrentMap<String, Property> props;
-
-    public Match() {
-        fields = new HashMap<MatchType, MatchField>();
-        matches = 0;
-    }
-
-    public Match(Match match) {
-        fields = new HashMap<MatchType, MatchField>(match.fields);
-        matches = match.matches;
-    }
-
-    /**
-     * Gets the list of metadata currently registered with this match
-     *
-     * @return List of metadata currently registered
-     */
-    public List <Property> getMetadatas() {
-        if (this.props != null) {
-            // Return all the values in the map
-            Collection res = this.props.values();
-            if (res == null) {
-                return Collections.emptyList();
-            }
-            return new ArrayList<Property>(res);
-        }
-        return Collections.emptyList();
-    }
-
-    /**
-     * Gets the metadata registered with a name if present
-     *
-     * @param name the name of the property to be extracted
-     *
-     * @return List of metadata currently registered
-     */
-    public Property getMetadata(String name) {
-        if (name == null) {
-            return null;
-        }
-        if (this.props != null) {
-            // Return the Property associated to the name
-            return this.props.get(name);
-        }
-        return null;
-    }
-
-    /**
-     * Sets the metadata associated to a name. If the name or prop is NULL,
-     * an exception NullPointerException will be raised.
-     *
-     * @param name the name of the property to be set
-     * @param prop, property to be set
-     */
-    public void setMetadata(String name, Property prop) {
-        if (this.props == null) {
-            props = new ConcurrentHashMap<String, Property>();
-        }
-
-        if (this.props != null) {
-            this.props.put(name, prop);
-        }
-    }
-
-    /**
-     * Remove the metadata associated to a name. If the name is NULL,
-     * nothing will be removed.
-     *
-     * @param name the name of the property to be set
-     * @param prop, property to be set
-     *
-     * @return List of metadata currently registered
-     */
-    public void removeMetadata(String name) {
-        if (this.props == null) {
-            return;
-        }
-
-        if (this.props != null) {
-            this.props.remove(name);
-        }
-        // It's intentional to keep the this.props still allocated
-        // till the parent data structure will be alive, so to avoid
-        // unnecessary allocation/deallocation, even if it's holding
-        // nothing
-    }
-
-    /**
-     * Generic setter for frame/packet/message's header fields against which to match
-     * Note: For MAC addresses, please pass the cloned value to this function
-     *
-     * @param type      packet's header field type
-     * @param value     field's value to assign to the match
-     * @param mask      field's bitmask to apply to the match (has to be of the same class type of value)
-     */
-    public void setField(MatchType type, Object value, Object mask) {
-        MatchField field = new MatchField(type, value, mask);
-        if (field.isValid()) {
-            fields.put(type, field);
-            matches |= type.getIndex();
-        }
-    }
-
-    /**
-     * Generic setter for frame/packet/message's header fields against which to match
-     * Note: For MAC addresses, please pass the cloned value to this function
-     *
-     * @param type      packet's header field type
-     * @param value     field's value to assign to the match
-     */
-    public void setField(MatchType type, Object value) {
-        MatchField field = new MatchField(type, value);
-        if (field.isValid()) {
-            fields.put(type, field);
-            matches |= type.getIndex();
-        }
-    }
-
-    /**
-     * Generic setter for frame/packet/message's header field against which to match
-     *
-     * @param field the fields parameters as MAtchField object
-     */
-    public void setField(MatchField field) {
-        if (field.isValid()) {
-            fields.put(field.getType(), field);
-            matches |= field.getType().getIndex();
-        }
-    }
-
-    /**
-     * Generic method to clear a field from the match
-     */
-    public void clearField(MatchType type) {
-        fields.remove(type);
-        matches &= ~type.getIndex();
-    }
-
-    /**
-     * Generic getter for fields against which the match is programmed
-     *
-     * @param type  frame/packet/message's header field type
-     * @return
-     */
-    public MatchField getField(MatchType type) {
-        return fields.get(type);
-    }
-
-    /**
-     * Returns the fields the match is set for in a bitmask fashion
-     * Each bit represents a field the match is configured for
-     *
-     * @return the 32 bit long mask (Refer to {@code}org.opendaylight.controller.sal.match.MatchElement)
-     */
-    public int getMatches() {
-        return matches;
-    }
-
-    /**
-     * Returns the list of MatchType fields the match is set for
-     *
-     * @return List of individual MatchType fields.
-     */
-    public List<MatchType> getMatchesList() {
-        return new ArrayList<MatchType>(fields.keySet());
-    }
-
-    /**
-     * Returns the list of MatchFields the match is set for
-     *
-     * @return List of individual MatchField values.
-     */
-    @XmlElement(name="matchField")
-    public List<MatchField> getMatchFields() {
-        return new ArrayList<MatchField>(fields.values());
-    }
-
-    /**
-     * Returns whether this match is for an IPv6 flow
-     */
-    public boolean isIPv6() {
-        return (isPresent(MatchType.DL_TYPE)
-                && ((Short) getField(MatchType.DL_TYPE).getValue())
-                        .equals(EtherTypes.IPv6.shortValue())
-                || isPresent(MatchType.NW_PROTO)
-                && ((Byte) getField(MatchType.NW_PROTO).getValue())
-                        .equals(IPProtocols.IPV6ICMP.byteValue())
-                || isPresent(MatchType.NW_SRC)
-                && getField(MatchType.NW_SRC).getValue() instanceof Inet6Address || isPresent(MatchType.NW_DST)
-                && getField(MatchType.NW_DST).getValue() instanceof Inet6Address);
-    }
-
-    /**
-     * Returns whether this match is for an IPv4 flow
-     */
-    public boolean isIPv4() {
-        return !isIPv6();
-    }
-
-    /**
-     * Returns whether for the specified field type the match is to be considered "any"
-     * Equivalent to say this match does not care about the value of the specified field
-     *
-     * @param type
-     * @return
-     */
-    public boolean isAny(MatchType type) {
-        //return ((fields.get(type) == null) || (fields.get(type).getBitMask() == 0L));
-        return !fields.containsKey(type);
-    }
-
-    /**
-     * Returns whether a match for the specified field type is configured
-     *
-     * @param type
-     * @return
-     */
-    public boolean isPresent(MatchType type) {
-        return (fields.get(type) != null);
-    }
-
-    @Override
-    public Match clone() {
-        Match cloned = null;
-        try {
-            cloned = (Match) super.clone();
-            cloned.matches = matches;
-            cloned.fields = new HashMap<MatchType, MatchField>();
-            for (Entry<MatchType, MatchField> entry : this.fields.entrySet()) {
-                cloned.fields.put(entry.getKey(), entry.getValue().clone());
-            }
-        } catch (CloneNotSupportedException e) {
-            throw new RuntimeException(e);
-        }
-        return cloned;
-    }
-
-    /**
-     * Returns a reversed version of this match
-     * For example, in the reversed version the network source and destination
-     * addresses will be exchanged. Non symmetric match field will not be
-     * copied over into the reversed match version, like input port.
-     *
-     * @return
-     */
-    public Match reverse() {
-        // Copy over all fields
-        Match reverse = this.clone();
-
-        // Flip symmetric fields
-        for (Map.Entry<MatchType, MatchType> entry : Match.reversableMatches.entrySet()) {
-            MatchType from = entry.getKey();
-            MatchType to = entry.getValue();
-            if (this.isPresent(from)) {
-                reverse.setField(to, this.getField(from).getValue(), this.getField(from).getMask());
-                if (!this.isPresent(to)) {
-                    reverse.clearField(from);
-                }
-            }
-        }
-
-        // Reset asymmetric fields
-        reverse.clearField(MatchType.IN_PORT);
-
-        return reverse;
-    }
-
-    /**
-     * Check whether the current match conflicts with the passed filter match
-     * This match conflicts with the filter if for at least a MatchType defined
-     * in the filter match, the respective MatchFields differ or are not
-     * compatible
-     *
-     * In other words the function returns true if the set of packets described
-     * by one match and the set of packets described by the other match are
-     * disjoint. Equivalently, if the intersection of the two sets of packets
-     * described by the two matches is an empty.
-     *
-     * For example, Let's suppose the filter has the following MatchFields:
-     * DL_TYPE = 0x800
-     * NW_DST = 172.20.30.110/24
-     *
-     * while this match has the following MatchFields:
-     * DL_TYPE = 0x800
-     * NW_DST = 172.20.30.45/24
-     * TP_DST = 80
-     *
-     * Then the function would return false as the two Match are not
-     * conflicting.
-     *
-     * Note: the mask value is taken into account only for MatchType.NW_SRC and
-     * MatchType.NW_DST
-     *
-     * @param match
-     *            the Match describing the filter
-     * @return true if the set of packets described by one match and the set of
-     *         packets described by the other match are disjoint, false
-     *         otherwise
-     */
-    public boolean conflictWithFilter(Match filter) {
-        return !this.intersetcs(filter);
-    }
-
-    /**
-     * Merge the current Match fields with the fields of the filter Match. A
-     * check is first run to see if this Match is compatible with the filter
-     * Match. If it is not, the merge is not attempted.
-     *
-     * The result is the match object representing the intersection of the set
-     * of packets described by this match with the set of packets described by
-     * the filter match. If the intersection of the two sets is empty, the
-     * return match will be null.
-     *
-     * @param filter
-     *            the match with which attempting the merge
-     * @return a new Match object describing the set of packets represented by
-     *         the intersection of this and the filter matches. null if the
-     *         intersection is empty.
-     */
-    public Match mergeWithFilter(Match filter) {
-        return this.getIntersection(filter);
-    }
-
-    /**
-     * Return the match representing the intersection of the set of packets
-     * described by this match with the set of packets described by the other
-     * match. Such as m.getIntersection(m) == m, m.getIntersection(u) == m and
-     * m.getIntersection(o) == o where u is an empty match (universal set, all
-     * packets) and o is the null match (empty set).
-     *
-     * @param other
-     *            the match with which computing the intersection
-     * @return a new Match object representing the intersection of the set of
-     *         packets described by this match with the set of packets described
-     *         by the other match. null when the intersection is the empty set.
-     */
-    public Match getIntersection(Match other) {
-        // If no intersection, return the empty set
-        if (!this.intersetcs(other)) {
-            return null;
-        }
-        // Check if any of the two is the universal match
-        if (this.getMatches() == 0) {
-            return other.clone();
-        }
-        if (other.getMatches() == 0) {
-            return this.clone();
-        }
-        // Derive the intersection
-        Match intersection = new Match();
-        for (MatchType type : MatchType.values()) {
-            if (this.isAny(type) && other.isAny(type)) {
-                continue;
-            }
-            if (this.isAny(type)) {
-                intersection.setField(other.getField(type).clone());
-                continue;
-            } else if (other.isAny(type)) {
-                intersection.setField(this.getField(type).clone());
-                continue;
-            }
-            // Either they are equal or it is about IP address
-            switch (type) {
-            // When it is about IP address, take the wider prefix address
-            // between the twos
-            case NW_SRC:
-            case NW_DST:
-                MatchField thisField = this.getField(type);
-                MatchField otherField = other.getField(type);
-                InetAddress thisAddress = (InetAddress) thisField.getValue();
-                InetAddress otherAddress = (InetAddress) otherField.getValue();
-                InetAddress thisMask = (InetAddress) thisField.getMask();
-                InetAddress otherMask = (InetAddress) otherField.getMask();
-
-                int thisMaskLen = (thisMask == null) ? ((thisAddress instanceof Inet4Address) ? 32 : 128) : NetUtils
-                        .getSubnetMaskLength(thisMask);
-                int otherMaskLen = (otherMask == null) ? ((otherAddress instanceof Inet4Address) ? 32 : 128) : NetUtils
-                        .getSubnetMaskLength(otherMask);
-                if (thisMaskLen < otherMaskLen) {
-                    intersection.setField(new MatchField(type, NetUtils.getSubnetPrefix(otherAddress, otherMaskLen),
-                            otherMask));
-                } else {
-                    intersection.setField(new MatchField(type, NetUtils.getSubnetPrefix(thisAddress, thisMaskLen),
-                            thisMask));
-                }
-                break;
-            default:
-                // this and other match field are equal for this type, pick this
-                // match field
-                intersection.setField(this.getField(type).clone());
-            }
-        }
-        return intersection;
-    }
-
-    /**
-     * Checks whether the intersection of the set of packets described by this
-     * match with the set of packets described by the other match is non empty
-     *
-     * For example, if this match is: DL_SRC = 00:cc:bb:aa:11:22
-     *
-     * and the other match is: DL_TYPE = 0x800 NW_SRC = 1.2.3.4
-     *
-     * then their respective matching packets set intersection is non empty:
-     * DL_SRC = 00:cc:bb:aa:11:22 DL_TYPE = 0x800 NW_SRC = 1.2.3.4
-     *
-     * @param other
-     *            the other match with which testing the intersection
-     * @return true if the intersection of the respective matching packets sets
-     *         is non empty
-     */
-    public boolean intersetcs(Match other) {
-        // No intersection with the empty set
-        if (other == null) {
-            return false;
-        }
-        // Always intersection with the universal set
-        if (this.getMatches() == 0 || other.getMatches() == 0) {
-            return true;
-        }
-        // Iterate through the MatchType defined in the filter
-        for (MatchType type : MatchType.values()) {
-            if (this.isAny(type) || other.isAny(type)) {
-                continue;
-            }
-
-            MatchField thisField = this.getField(type);
-            MatchField otherField = other.getField(type);
-
-            switch (type) {
-            case DL_SRC:
-            case DL_DST:
-                if (!Arrays.equals((byte[]) thisField.getValue(), (byte[]) otherField.getValue())) {
-                    return false;
-                }
-                break;
-            case NW_SRC:
-            case NW_DST:
-                InetAddress thisAddress = (InetAddress) thisField.getValue();
-                InetAddress otherAddress = (InetAddress) otherField.getValue();
-                // Validity check
-                if (thisAddress instanceof Inet4Address && otherAddress instanceof Inet6Address
-                        || thisAddress instanceof Inet6Address && otherAddress instanceof Inet4Address) {
-                    return false;
-                }
-                InetAddress thisMask = (InetAddress) thisField.getMask();
-                InetAddress otherMask = (InetAddress) otherField.getMask();
-                if (NetUtils.inetAddressConflict(thisAddress, otherAddress, thisMask, otherMask)
-                        && NetUtils.inetAddressConflict(otherAddress, thisAddress, otherMask, thisMask)) {
-                    return false;
-                }
-                break;
-            default:
-                if (!thisField.getValue().equals(otherField.getValue())) {
-                    return false;
-                }
-            }
-        }
-        return true;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        if (this.fields == null) {
-            result = prime * result;
-        } else {
-            // use a tree map as the order of hashMap is not guaranteed.
-            // 2 Match objects with fields in different order are still equal.
-            // Hence the hashCode should be the same too.
-            TreeMap<MatchType, MatchField> tm = new TreeMap<MatchType, MatchField>(this.fields);
-            for (MatchType field : tm.keySet()) {
-                MatchField f = tm.get(field);
-                int fieldHashCode = (field==null ? 0 : field.calculateConsistentHashCode()) ^
-                             (f==null ? 0 : f.hashCode());
-                result = prime * result + fieldHashCode;
-            }
-        }
-        result = prime * result + matches;
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        Match other = (Match) obj;
-        if (fields == null) {
-            if (other.fields != null) {
-                return false;
-            }
-        } else if (!fields.equals(other.fields)) {
-            return false;
-        }
-        if (matches != other.matches) {
-            return false;
-        }
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        StringBuilder builder = new StringBuilder();
-        builder.append("Match [fields=");
-        builder.append(fields);
-        builder.append(", matches=");
-        builder.append(matches);
-        builder.append("]");
-        return builder.toString();
-    }
-
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/MatchField.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/MatchField.java
deleted file mode 100644 (file)
index 05e8462..0000000
+++ /dev/null
@@ -1,217 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.match;
-
-import java.io.Serializable;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * Represents the generic matching field
- *
- */
-
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class MatchField implements Cloneable, Serializable {
-    private static final long serialVersionUID = 1L;
-    private static final Logger logger = LoggerFactory.getLogger(MatchField.class);
-    private MatchType type; // the field we want to match
-    private Object value; // the value of the field we want to match
-    private Object mask; // the value of the mask we want to match on the
-    // specified field
-    private boolean isValid;
-
-    // To satisfy JAXB
-    @SuppressWarnings("unused")
-    private MatchField() {
-    }
-
-    /**
-     * Mask based match constructor
-     *
-     * @param type
-     * @param value
-     * @param mask
-     *            has to be of the same class type of value. A null mask means
-     *            full match
-     */
-    public MatchField(MatchType type, Object value, Object mask) {
-        this.type = type;
-        this.value = value;
-        this.mask = mask;
-        // Keep this logic, value checked only if type check is fine
-        this.isValid = checkValueType() && checkValues();
-    }
-
-    /**
-     * Full match constructor
-     *
-     * @param type
-     * @param value
-     */
-    public MatchField(MatchType type, Object value) {
-        this.type = type;
-        this.value = value;
-        this.mask = null;
-        // Keep this logic, value checked only if type check is fine
-        this.isValid = checkValueType() && checkValues();
-    }
-
-    /**
-     * Returns the value set for this match field
-     *
-     * @return
-     */
-    public Object getValue() {
-        return value;
-    }
-
-    @XmlElement(name = "value")
-    private String getValueString() {
-        return type.stringify(value);
-    }
-
-    /**
-     * Returns the type field this match field object is for
-     *
-     * @return
-     */
-    public MatchType getType() {
-        return type;
-    }
-
-    @XmlElement(name = "type")
-    private String getTypeString() {
-        return type.toString();
-    }
-
-    /**
-     * Returns the mask value set for this field match A null mask means this is
-     * a full match
-     *
-     * @return
-     */
-    public Object getMask() {
-        return mask;
-    }
-
-    @XmlElement(name = "mask")
-    private String getMaskString() {
-        return type.stringify(mask);
-    }
-
-    /**
-     * Returns the bitmask set for this field match
-     *
-     * @return
-     */
-    public long getBitMask() {
-        return type.getBitMask(mask);
-    }
-
-    /**
-     * Returns whether the field match configuration is valid or not
-     *
-     * @return
-     */
-    public boolean isValid() {
-        return isValid;
-    }
-
-    private boolean checkValueType() {
-        if (type.isCongruentType(value, mask) == false) {
-            String valueClass = (value == null) ? "null" : value.getClass().getSimpleName();
-            String maskClass = (mask == null) ? "null" : mask.getClass().getSimpleName();
-            String error = "Invalid match field's value or mask types.For field: " + type.id() + " Expected:"
-                    + type.dataType().getSimpleName() + " or equivalent," + " Got:(" + valueClass + "," + maskClass
-                    + ")";
-            throwException(error);
-            return false;
-        }
-        return true;
-    }
-
-    private boolean checkValues() {
-        if (type.isValid(value, mask) == false) {
-            String maskString = (mask == null) ? "null" : ("0x" + Integer
-                    .toHexString(Integer.parseInt(mask.toString())));
-            String error = "Invalid match field's value or mask assignement.For field: " + type.id() + " Expected: "
-                    + type.getRange() + ", Got:(0x" + Integer.toHexString(Integer.parseInt(value.toString())) + ","
-                    + maskString + ")";
-
-            throwException(error);
-            return false;
-        }
-        return true;
-    }
-
-    private static void throwException(String error) {
-        try {
-            throw new Exception(error);
-        } catch (Exception e) {
-            logger.error(e.getMessage());
-        }
-    }
-
-    @Override
-    public MatchField clone() {
-        MatchField cloned = null;
-        try {
-            cloned = (MatchField) super.clone();
-            if (value instanceof byte[]) {
-                cloned.value = ((byte[]) this.value).clone();
-                if (this.mask != null) {
-                    cloned.mask = ((byte[]) this.mask).clone();
-                }
-            }
-            cloned.type = this.type;
-            cloned.isValid = this.isValid;
-        } catch (CloneNotSupportedException e) {
-            logger.error("", e);
-        }
-        return cloned;
-    }
-
-    @Override
-    public String toString() {
-        return (mask == null) ? String.format("%s(%s)", getTypeString(), getValueString()) :
-            String.format("%s(%s,%s)", getTypeString(), getValueString(), getMaskString());
-    }
-
-    @Override
-    public int hashCode() {
-        return type.hashCode(value, mask);
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        MatchField other = (MatchField) obj;
-        if (type != other.type) {
-            return false;
-        }
-        return type.equals(this.value, other.value, this.mask, other.mask);
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/MatchType.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/MatchType.java
deleted file mode 100644 (file)
index 05baa21..0000000
+++ /dev/null
@@ -1,328 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.match;
-
-import java.net.Inet4Address;
-import java.net.InetAddress;
-import java.util.Arrays;
-
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.utils.HexEncode;
-import org.opendaylight.controller.sal.utils.NetUtils;
-
-/**
- * Represents the binding between the id, the value and mask type and the range
- * values of the elements type that can be matched on the network
- * frame/packet/message
- */
-@Deprecated
-public enum MatchType {
-    IN_PORT("inPort", 1 << 0, NodeConnector.class, 1, 0),
-    DL_SRC("dlSrc", 1 << 1, Byte[].class, 0, 0xffffffffffffL),
-    DL_DST("dlDst", 1 << 2, Byte[].class, 0, 0xffffffffffffL),
-    DL_VLAN("dlVlan", 1 << 3, Short.class, 0, 0xfff), // 2 bytes
-    DL_VLAN_PR("dlVlanPriority", 1 << 4, Byte.class, 0, 0x7), // 3 bits
-    DL_OUTER_VLAN("dlOuterVlan", 1 << 5, Short.class, 1, 0xfff),
-    DL_OUTER_VLAN_PR("dlOuterVlanPriority", 1 << 6, Short.class, 0, 0x7),
-    DL_TYPE("dlType", 1 << 7, Short.class, 0, 0xffff), // 2 bytes
-    NW_TOS("nwTOS", 1 << 8, Byte.class, 0, 0x3f), // 6 bits (DSCP field)
-    NW_PROTO("nwProto", 1 << 9, Byte.class, 0, 0xff), // 1 byte
-    NW_SRC("nwSrc", 1 << 10, InetAddress.class, 0, 0),
-    NW_DST("nwDst", 1 << 11, InetAddress.class, 0, 0),
-    TP_SRC("tpSrc", 1 << 12, Short.class, 0, 0xffff), // 2 bytes
-    TP_DST("tpDst", 1 << 13, Short.class, 0, 0xffff); // 2 bytes
-
-    // Used to indicate that no VLAN ID is set.
-    public static final short DL_VLAN_NONE = (short) 0;
-
-    private String id;
-    private int index;
-    private Class<?> dataType;
-    private long minValue;
-    private long maxValue;
-
-    private MatchType(String id, int index, Class<?> dataType, long minValue, long maxValue) {
-        this.id = id;
-        this.index = index;
-        this.dataType = dataType;
-        this.minValue = minValue;
-        this.maxValue = maxValue;
-    }
-
-    public String id() {
-        return id;
-    }
-
-    public int getIndex() {
-        return index;
-    }
-
-    public Class<?> dataType() {
-        return dataType;
-    }
-
-    public String getRange() {
-        return "[0x" + Long.toHexString(minValue) + "-0x" + Long.toHexString(maxValue) + "]";
-    }
-
-    /**
-     * Perform the assignment type validation
-     *
-     * @param value
-     * @param mask
-     * @return
-     */
-    public boolean isCongruentType(Object value, Object mask) {
-        // Mask type has to match value type
-        if (mask != null && (mask.getClass() != value.getClass())) {
-            return false;
-        }
-
-        Class<?> e = this.dataType();
-        Class<?> g = value.getClass();
-
-        // This is all what we need, if value type is same of match required
-        // type
-        if (g.equals(e)) {
-            return true;
-        }
-
-        // This is for the numeric class vs primitive congruence
-        // For what concerns here, for instance, Integer is congruent to int
-        if (e == Short.class) {
-            return g.equals(short.class);
-        }
-
-        if (e == Integer.class) {
-            return g.equals(int.class);
-        }
-
-        if (e == Byte.class) {
-            return g.equals(byte.class);
-        }
-
-        if (e == Byte[].class) {
-            return g.equals(byte[].class);
-        }
-
-        if (e == InetAddress.class) {
-            return g.getSuperclass().equals(InetAddress.class);
-        }
-        return false;
-    }
-
-    /**
-     * Perform the value and mask range validation
-     *
-     * @param value
-     * @param mask
-     * @return
-     */
-    public boolean isValid(Object value, Object mask) {
-        // Skip if main error
-        if (mask != null && (mask.getClass() != value.getClass())) {
-            return false;
-        }
-        // For the complex below types let's skip the value range check for now
-        if (this.dataType == InetAddress.class) {
-            return true;
-        }
-        if (this.dataType() == Byte[].class) {
-            return true;
-        }
-        if (this.dataType() == NodeConnector.class) {
-            return true;
-        }
-
-        int val = 0;
-        int msk = 0;
-        if (value.getClass() == Integer.class || value.getClass() == int.class) {
-            val = ((Integer) value).intValue();
-            msk = (mask != null) ? ((Integer) mask).intValue() : 0;
-
-        } else if (value.getClass() == Short.class || value.getClass() == short.class) {
-            val = ((Short) value).intValue() & 0xffff;
-            msk = (mask != null) ? ((Short) mask).intValue() & 0xffff : 0;
-
-        } else if (value.getClass() == Byte.class || value.getClass() == byte.class) {
-            val = ((Byte) value).intValue() & 0xff;
-            msk = (mask != null) ? ((Byte) mask).intValue() & 0xff : 0;
-        }
-        return ((val >= minValue && val <= maxValue) && (mask == null || (msk >= minValue && msk <= maxValue)));
-
-    }
-
-    /**
-     * Return the mask value in 64 bits bitmask form
-     *
-     * @param mask
-     * @return
-     */
-    public long getBitMask(Object mask) {
-        if (this.dataType == InetAddress.class) {
-            // TODO handle Inet v4 and v6 v6 will have a second upper mask
-            return 0;
-        }
-        if (this.dataType() == Byte[].class) {
-            if (mask == null) {
-                return 0xffffffffffffL;
-            }
-            byte mac[] = (byte[]) mask;
-            long bitmask = 0;
-            for (short i = 0; i < 6; i++) {
-                bitmask |= ((mac[i] & 0xffL) << ((5 - i) * 8));
-            }
-            return bitmask;
-        }
-        if (this.dataType == Integer.class || this.dataType == int.class) {
-            return (mask == null) ? this.maxValue : ((Integer) mask).longValue();
-
-        }
-        if (this.dataType == Short.class || this.dataType == short.class) {
-            return (mask == null) ? this.maxValue : ((Short) mask).longValue();
-        }
-        if (this.dataType == Byte.class || this.dataType == byte.class) {
-            return (mask == null) ? this.maxValue : ((Byte) mask).longValue();
-
-        }
-        return 0L;
-    }
-
-    public String stringify(Object value) {
-        if (value == null) {
-            return null;
-        }
-
-        switch (this) {
-        case DL_DST:
-        case DL_SRC:
-            return HexEncode.bytesToHexStringFormat((byte[]) value);
-        case DL_TYPE:
-        case DL_VLAN:
-            return ((Integer) NetUtils.getUnsignedShort((Short) value)).toString();
-        case NW_SRC:
-        case NW_DST:
-            return ((InetAddress) value).getHostAddress();
-        case NW_TOS:
-            return ((Integer) NetUtils.getUnsignedByte((Byte) value)).toString();
-        case TP_SRC:
-        case TP_DST:
-            return ((Integer) NetUtils.getUnsignedShort((Short) value)).toString();
-        default:
-            break;
-        }
-        return value.toString();
-    }
-
-    public int valueHashCode(Object o) {
-        if (o == null) {
-            return 0;
-        }
-        switch (this) {
-        case DL_SRC:
-        case DL_DST:
-            return NetUtils.byteArray4ToInt((byte[])o);
-        default:
-            return o.hashCode();
-        }
-    }
-
-    public int hashCode(Object v, Object m) {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + this.calculateConsistentHashCode();
-
-        switch (this) {
-        case DL_SRC:
-        case DL_DST:
-            result = prime * result + ((v == null)? 0 : NetUtils.byteArray4ToInt((byte[])v));
-            result = prime * result + ((m == null)? 0 : NetUtils.byteArray4ToInt((byte[])m));
-            break;
-        case NW_SRC:
-        case NW_DST:
-            // Hash code has to take into account only prefix address
-            InetAddress ip = (InetAddress) v;
-            int maskLen = (m == null) ? ((ip instanceof Inet4Address) ? 32 : 128) : NetUtils
-                    .getSubnetMaskLength((InetAddress) m);
-            InetAddress prefix = NetUtils.getSubnetPrefix(ip, maskLen);
-            result = prime * result + ((v == null)? 0 : prefix.hashCode());
-            break;
-        default:
-            result = prime * result + ((v == null)? 0 : v.hashCode());
-            result = prime * result + ((m == null)? 0 : m.hashCode());
-        }
-        return result;
-    }
-    public boolean equalValues(Object a, Object b) {
-        if (a == b) {
-            return true;
-        }
-        if (a == null || b == null) {
-            return false;
-        }
-        switch (this) {
-        case DL_DST:
-        case DL_SRC:
-            return Arrays.equals((byte[]) a, (byte[]) b);
-        default:
-            return a.equals(b);
-        }
-    }
-
-    public boolean equalMasks(Object a, Object b) {
-        if (a == b) {
-            return true;
-        }
-        switch (this) {
-        case NW_SRC:
-        case NW_DST:
-            /*
-             * For network address mask, network node may return full mask for
-             * flows the controller generated with a null mask object
-             */
-            if (a == null || b == null) {
-                InetAddress mask = (a == null) ? (InetAddress) b : (InetAddress) a;
-                int maxLength = (mask instanceof Inet4Address) ? 32 : 128;
-                return (NetUtils.getSubnetMaskLength(mask) == maxLength);
-            }
-        default:
-            if (a == null) {
-                return false;
-            }
-            return a.equals(b);
-        }
-    }
-
-    public boolean equals(Object value1, Object value2, Object mask1, Object mask2) {
-        switch (this) {
-        case NW_SRC:
-        case NW_DST:
-            // Equality to be checked against prefix addresses
-            InetAddress thisIP = (InetAddress) value1;
-            int thisMaskLen = (mask1 == null) ? ((thisIP instanceof Inet4Address) ? 32 : 128) : NetUtils
-                    .getSubnetMaskLength((InetAddress) mask1);
-            InetAddress otherIP = (InetAddress) value2;
-            int otherMaskLen = (mask2 == null) ? ((otherIP instanceof Inet4Address) ? 32 : 128) : NetUtils
-                    .getSubnetMaskLength((InetAddress) mask2);
-
-            return NetUtils.getSubnetPrefix(thisIP, thisMaskLen)
-                    .equals(NetUtils.getSubnetPrefix(otherIP, otherMaskLen));
-        default:
-            return (this.equalValues(value1, value2) && this.equalMasks(mask1, mask2));
-        }
-    }
-
-    public int calculateConsistentHashCode() {
-        if (this.id != null) {
-            return this.id.hashCode();
-        } else {
-            return 0;
-        }
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/extensible/DlDst.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/extensible/DlDst.java
deleted file mode 100644 (file)
index b5c154d..0000000
+++ /dev/null
@@ -1,107 +0,0 @@
-package org.opendaylight.controller.sal.match.extensible;
-
-import java.util.Arrays;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.sal.utils.HexEncode;
-import org.opendaylight.controller.sal.utils.NetUtils;
-
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class DlDst extends MatchField<byte[]> {
-    private static final long serialVersionUID = 1L;
-    public static final String TYPE = "DL_DST";
-    private byte[] address;
-
-    /**
-     * Creates a Match field for the destination data layer address
-     *
-     * @param address
-     *            the data layer address. The constructor makes a copy of it
-     */
-    public DlDst(byte[] address) {
-        super(TYPE);
-        if (address != null) {
-            this.address = Arrays.copyOf(address, address.length);
-        }
-    }
-
-    // To satisfy JAXB
-    public DlDst() {
-        super(TYPE);
-    }
-
-    @Override
-    public byte[] getValue() {
-        return Arrays.copyOf(address, address.length);
-    }
-
-    @Override
-    @XmlElement(name = "value")
-    protected String getValueString() {
-        return HexEncode.bytesToHexStringFormat(address);
-    }
-
-    @Override
-    public byte[] getMask() {
-        return null;
-    }
-
-    @Override
-    protected String getMaskString() {
-        return null;
-    }
-
-    @Override
-    public boolean isValid() {
-        return address != null && address.length == NetUtils.MACAddrLengthInBytes;
-    }
-
-    @Override
-    public boolean hasReverse() {
-        return true;
-    }
-
-    @Override
-    public DlSrc getReverse() {
-        return new DlSrc(address);
-    }
-
-    @Override
-    public DlDst clone() {
-        return new DlDst(address);
-    }
-
-    @Override
-    public boolean isV6() {
-        return true;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + Arrays.hashCode(address);
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (!(obj instanceof DlDst)) {
-            return false;
-        }
-        DlDst other = (DlDst) obj;
-        return Arrays.equals(address, other.address);
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/extensible/DlSrc.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/extensible/DlSrc.java
deleted file mode 100644 (file)
index 0248073..0000000
+++ /dev/null
@@ -1,107 +0,0 @@
-package org.opendaylight.controller.sal.match.extensible;
-
-import java.util.Arrays;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.sal.utils.HexEncode;
-import org.opendaylight.controller.sal.utils.NetUtils;
-
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class DlSrc extends MatchField<byte[]> {
-    private static final long serialVersionUID = 1L;
-    public static final String TYPE = "DL_SRC";
-    private byte[] address;
-
-    /**
-     * Creates a Match field for the source datalayer address
-     *
-     * @param address
-     *            the datalayer address. The constructor makes a copy of it
-     */
-    public DlSrc(byte[] address) {
-        super(TYPE);
-        if (address != null) {
-            this.address = Arrays.copyOf(address, address.length);
-        }
-    }
-
-    // To satisfy JAXB
-    private DlSrc() {
-        super(TYPE);
-    }
-
-    @Override
-    public byte[] getValue() {
-        return Arrays.copyOf(address, address.length);
-    }
-
-    @Override
-    @XmlElement(name = "value")
-    protected String getValueString() {
-        return HexEncode.bytesToHexStringFormat(address);
-    }
-
-    @Override
-    public byte[] getMask() {
-        return null;
-    }
-
-    @Override
-    protected String getMaskString() {
-        return null;
-    }
-
-    @Override
-    public boolean isValid() {
-        return address != null && address.length == NetUtils.MACAddrLengthInBytes;
-    }
-
-    @Override
-    public boolean hasReverse() {
-        return true;
-    }
-
-    @Override
-    public DlDst getReverse() {
-        return new DlDst(address);
-    }
-
-    @Override
-    public DlSrc clone() {
-        return new DlSrc(address);
-    }
-
-    @Override
-    public boolean isV6() {
-        return true;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + Arrays.hashCode(address);
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (!(obj instanceof DlSrc)) {
-            return false;
-        }
-        DlSrc other = (DlSrc) obj;
-        return Arrays.equals(address, other.address);
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/extensible/DlType.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/extensible/DlType.java
deleted file mode 100644 (file)
index e2433aa..0000000
+++ /dev/null
@@ -1,106 +0,0 @@
-package org.opendaylight.controller.sal.match.extensible;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.sal.utils.EtherTypes;
-import org.opendaylight.controller.sal.utils.NetUtils;
-
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class DlType extends MatchField<Short> {
-    private static final long serialVersionUID = 1L;
-    public static final String TYPE = "DL_TYPE";
-    private short ethertype;
-
-    /**
-     * Creates a Match field for the data layer type
-     *
-     * @param address
-     *            the data layer type
-     */
-    public DlType(short ethertype) {
-        super(TYPE);
-        this.ethertype = ethertype;
-    }
-
-    // To satisfy JAXB
-    private DlType() {
-        super(TYPE);
-    }
-
-    @Override
-    public Short getValue() {
-        return ethertype;
-    }
-
-    @Override
-    @XmlElement(name = "value")
-    protected String getValueString() {
-        return String.format("0X%s", Integer.toHexString(NetUtils.getUnsignedShort(ethertype)));
-    }
-
-    @Override
-    public Short getMask() {
-        return null;
-    }
-
-    @Override
-    protected String getMaskString() {
-        return null;
-    }
-
-    @Override
-    public boolean isValid() {
-        return true;
-    }
-
-    @Override
-    public boolean hasReverse() {
-        return false;
-    }
-
-    @Override
-    public DlType getReverse() {
-        return this.clone();
-    }
-
-    @Override
-    public DlType clone() {
-        return new DlType(ethertype);
-    }
-
-    @Override
-    public boolean isV6() {
-        return this.ethertype == EtherTypes.IPv6.shortValue();
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + ethertype;
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (!(obj instanceof DlType)) {
-            return false;
-        }
-        DlType other = (DlType) obj;
-        if (ethertype != other.ethertype) {
-            return false;
-        }
-        return true;
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/extensible/DlVlan.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/extensible/DlVlan.java
deleted file mode 100644 (file)
index bde3257..0000000
+++ /dev/null
@@ -1,105 +0,0 @@
-package org.opendaylight.controller.sal.match.extensible;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class DlVlan extends MatchField<Short> {
-    private static final long serialVersionUID = 1L;
-    public static final String TYPE = "DL_VLAN";
-    private static final short MAX = 4095;
-    private short vlan;
-
-    /**
-     * Creates a Match field for the data layer type
-     *
-     * @param address
-     *            the data layer type
-     */
-    public DlVlan(short vlan) {
-        super(TYPE);
-        this.vlan = vlan;
-    }
-
-    // To satisfy JAXB
-    private DlVlan() {
-        super(TYPE);
-    }
-
-    @Override
-    public Short getValue() {
-        return vlan;
-    }
-
-    @Override
-    @XmlElement(name = "value")
-    protected String getValueString() {
-        return String.valueOf(vlan);
-    }
-
-    @Override
-    public Short getMask() {
-        return null;
-    }
-
-    @Override
-    protected String getMaskString() {
-        return null;
-    }
-
-    @Override
-    public boolean isValid() {
-        return vlan >= 0 && vlan <= MAX;
-    }
-
-    @Override
-    public DlVlan getReverse() {
-        return this.clone();
-    }
-
-    @Override
-    public boolean hasReverse() {
-        return false;
-    }
-
-    @Override
-    public DlVlan clone() {
-        return new DlVlan(vlan);
-    }
-
-    @Override
-    public boolean isV6() {
-        return true;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + vlan;
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (!(obj instanceof DlVlan)) {
-            return false;
-        }
-        DlVlan other = (DlVlan) obj;
-        if (vlan != other.vlan) {
-            return false;
-        }
-        return true;
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/extensible/DlVlanPriority.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/extensible/DlVlanPriority.java
deleted file mode 100644 (file)
index d899d64..0000000
+++ /dev/null
@@ -1,106 +0,0 @@
-package org.opendaylight.controller.sal.match.extensible;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.sal.utils.NetUtils;
-
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class DlVlanPriority extends MatchField<Byte> {
-    private static final long serialVersionUID = 1L;
-    public static final String TYPE = "DL_VLAN_PR";
-    private static final byte MAX = 7;
-    private byte vlanPriority;
-
-    /**
-     * Creates a Match field for the data layer type
-     *
-     * @param address
-     *            the data layer type
-     */
-    public DlVlanPriority(byte vlanPriority) {
-        super(TYPE);
-        this.vlanPriority = vlanPriority;
-    }
-
-    // To satisfy JAXB
-    private DlVlanPriority() {
-        super(TYPE);
-    }
-
-    @Override
-    public Byte getValue() {
-        return vlanPriority;
-    }
-
-    @Override
-    @XmlElement(name = "mask")
-    protected String getValueString() {
-        return String.format("0X%s", Integer.toHexString(NetUtils.getUnsignedByte(vlanPriority)));
-    }
-
-    @Override
-    public Byte getMask() {
-        return null;
-    }
-
-    @Override
-    protected String getMaskString() {
-        return null;
-    }
-
-    @Override
-    public boolean isValid() {
-        return vlanPriority >= 0 && vlanPriority <= MAX;
-    }
-
-    @Override
-    public boolean hasReverse() {
-        return false;
-    }
-
-    @Override
-    public DlVlanPriority getReverse() {
-        return this.clone();
-    }
-
-    @Override
-    public DlVlanPriority clone() {
-        return new DlVlanPriority(vlanPriority);
-    }
-
-    @Override
-    public boolean isV6() {
-        return true;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + vlanPriority;
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (!(obj instanceof DlVlanPriority)) {
-            return false;
-        }
-        DlVlanPriority other = (DlVlanPriority) obj;
-        if (vlanPriority != other.vlanPriority) {
-            return false;
-        }
-        return true;
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/extensible/InPort.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/extensible/InPort.java
deleted file mode 100644 (file)
index a0b899e..0000000
+++ /dev/null
@@ -1,109 +0,0 @@
-package org.opendaylight.controller.sal.match.extensible;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.sal.core.NodeConnector;
-
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class InPort extends MatchField<NodeConnector> {
-    private static final long serialVersionUID = 1L;
-    public static final String TYPE = "IN_PORT";
-    private NodeConnector port;
-
-    /**
-     * Creates a Match field for the input port
-     *
-     * @param port
-     *            the input port
-     */
-    public InPort(NodeConnector port) {
-        super(TYPE);
-        this.port = port;
-    }
-
-    // To satisfy JAXB
-    private InPort() {
-        super(TYPE);
-    }
-
-    @Override
-    public NodeConnector getValue() {
-        return port;
-    }
-
-    @Override
-    @XmlElement(name = "value")
-    protected String getValueString() {
-        return port.toString();
-    }
-
-    @Override
-    public NodeConnector getMask() {
-        return null;
-    }
-
-    @Override
-    protected String getMaskString() {
-        return null;
-    }
-
-    @Override
-    public boolean isValid() {
-        return true;
-    }
-
-    @Override
-    public boolean hasReverse() {
-        return false;
-    }
-
-    @Override
-    public InPort getReverse() {
-        return this.clone();
-    }
-
-    @Override
-    public InPort clone() {
-        return new InPort(port);
-    }
-
-    @Override
-    public boolean isV6() {
-        return true;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + ((port == null) ? 0 : port.hashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (!(obj instanceof InPort)) {
-            return false;
-        }
-        InPort other = (InPort) obj;
-        if (port == null) {
-            if (other.port != null) {
-                return false;
-            }
-        } else if (!port.equals(other.port)) {
-            return false;
-        }
-        return true;
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/extensible/Match.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/extensible/Match.java
deleted file mode 100644 (file)
index 7f4ddd0..0000000
+++ /dev/null
@@ -1,423 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.match.extensible;
-
-import java.io.Serializable;
-import java.net.Inet4Address;
-import java.net.Inet6Address;
-import java.net.InetAddress;
-import java.util.ArrayList;
-import java.util.Arrays;
-import java.util.HashMap;
-import java.util.HashSet;
-import java.util.List;
-import java.util.Map;
-import java.util.Map.Entry;
-import java.util.Set;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-
-import org.opendaylight.controller.sal.utils.NetUtils;
-
-/**
- * Represents the generic match criteria for a network frame/packet/message
- * It contains a collection of individual field match
- *
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class Match implements Cloneable, Serializable {
-        private static final long serialVersionUID = 1L;
-    private Map<String, MatchField<?>> fields;
-
-    public Match() {
-        fields = new HashMap<String, MatchField<?>>();
-    }
-
-    public Match(Match match) {
-        fields = new HashMap<String, MatchField<?>>(match.fields);
-    }
-
-    /**
-     * Generic setter for frame/packet/message's header field against which to match
-     *
-     * @param field the fields parameters as MAtchField object
-     */
-    public void setField(MatchField<?> field) {
-        if (field.isValid()) {
-            fields.put(field.getType(), field);
-        }
-    }
-
-    /**
-     * Generic method to clear a field from the match
-     */
-    public void clearField(String type) {
-        fields.remove(type);
-    }
-
-    /**
-     * Generic getter for fields against which the match is programmed
-     *
-     * @param type  frame/packet/message's header field type
-     * @return
-     */
-    public MatchField<?> getField(String type) {
-        return fields.get(type);
-    }
-
-    /**
-     * Returns the list of MatchType fields the match is set for
-     *
-     * @return List of individual MatchType fields.
-     */
-    public List<String> getMatchesList() {
-        return new ArrayList<String>(fields.keySet());
-    }
-
-    /**
-     * Returns the list of MatchFields the match is set for
-     *
-     * @return List of individual MatchField values.
-     */
-    @XmlElement(name="matchField")
-    public List<MatchField<?>> getMatchFields() {
-        return new ArrayList<MatchField<?>>(fields.values());
-    }
-
-    /**
-     * Returns whether this match is for an IPv6 flow
-     */
-    public boolean isIPv6() {
-        if (isPresent(DlType.TYPE)) {
-            for (MatchField<?> field : fields.values()) {
-                if (!field.isV6()) {
-                    return false;
-                }
-            }
-        }
-        return true;
-    }
-
-    /**
-     * Returns whether this match is for an IPv4 flow
-     */
-    public boolean isIPv4() {
-        return !isIPv6();
-    }
-
-    /**
-     * Returns whether for the specified field type the match is to be considered "any"
-     * Equivalent to say this match does not care about the value of the specified field
-     *
-     * @param type
-     * @return
-     */
-    public boolean isAny(String type) {
-        return !fields.containsKey(type);
-    }
-
-    /**
-     * Returns whether a match for the specified field type is configured
-     *
-     * @param type
-     * @return
-     */
-    public boolean isPresent(String type) {
-        return (fields.get(type) != null);
-    }
-
-    public boolean isEmpty() {
-        return fields.isEmpty();
-    }
-
-    @Override
-    public Match clone() {
-        Match cloned = null;
-        try {
-            cloned = (Match) super.clone();
-            cloned.fields = new HashMap<String, MatchField<?>>();
-            for (Entry<String, MatchField<?>> entry : this.fields.entrySet()) {
-                cloned.fields.put(entry.getKey(), entry.getValue().clone());
-            }
-        } catch (CloneNotSupportedException e) {
-            throw new RuntimeException(e);
-        }
-        return cloned;
-    }
-
-    /**
-     * Returns a reversed version of this match
-     * For example, in the reversed version the network source and destination
-     * addresses will be exchanged. Non symmetric match field will not be
-     * copied over into the reversed match version, like input port.
-     *
-     * @return
-     */
-    public Match reverse() {
-        Match reverse = new Match();
-        for (MatchField<?> field : fields.values()) {
-            reverse.setField(field.hasReverse()? field.getReverse() : field.clone());
-        }
-
-        // Reset asymmetric fields
-        reverse.clearField(InPort.TYPE);
-
-        return reverse;
-    }
-
-    /**
-     * Check whether the current match conflicts with the passed filter match
-     * This match conflicts with the filter if for at least a MatchType defined
-     * in the filter match, the respective MatchFields differ or are not
-     * compatible
-     *
-     * In other words the function returns true if the set of packets described
-     * by one match and the set of packets described by the other match are
-     * disjoint. Equivalently, if the intersection of the two sets of packets
-     * described by the two org.opendaylight.controller.sal.matches is an empty.
-     *
-     * For example, Let's suppose the filter has the following MatchFields:
-     * DL_TYPE = 0x800
-     * NW_DST = 172.20.30.110/24
-     *
-     * while this match has the following MatchFields:
-     * DL_TYPE = 0x800
-     * NW_DST = 172.20.30.45/24
-     * TP_DST = 80
-     *
-     * Then the function would return false as the two Match are not
-     * conflicting.
-     *
-     * Note: the mask value is taken into account only for MatchType.NW_SRC and
-     * MatchType.NW_DST
-     *
-     * @param match
-     *            the Match describing the filter
-     * @return true if the set of packets described by one match and the set of
-     *         packets described by the other match are disjoint, false
-     *         otherwise
-     */
-    public boolean conflictWithFilter(Match filter) {
-        return !this.intersetcs(filter);
-    }
-
-    /**
-     * Merge the current Match fields with the fields of the filter Match. A
-     * check is first run to see if this Match is compatible with the filter
-     * Match. If it is not, the merge is not attempted.
-     *
-     * The result is the match object representing the intersection of the set
-     * of packets described by this match with the set of packets described by
-     * the filter match. If the intersection of the two sets is empty, the
-     * return match will be null.
-     *
-     * @param filter
-     *            the match with which attempting the merge
-     * @return a new Match object describing the set of packets represented by
-     *         the intersection of this and the filter org.opendaylight.controller.sal.matches. null if the
-     *         intersection is empty.
-     */
-    public Match mergeWithFilter(Match filter) {
-        return this.getIntersection(filter);
-    }
-
-    /**
-     * Return the match representing the intersection of the set of packets
-     * described by this match with the set of packets described by the other
-     * match. Such as m.getIntersection(m) == m, m.getIntersection(u) == m and
-     * m.getIntersection(o) == o where u is an empty match (universal set, all
-     * packets) and o is the null match (empty set).
-     *
-     * @param other
-     *            the match with which computing the intersection
-     * @return a new Match object representing the intersection of the set of
-     *         packets described by this match with the set of packets described
-     *         by the other match. null when the intersection is the empty set.
-     */
-    public Match getIntersection(Match other) {
-        // If no intersection, return the empty set
-        if (!this.intersetcs(other)) {
-            return null;
-        }
-        // Check if any of the two is the universal match
-        if (this.isEmpty()) {
-            return other.clone();
-        }
-        if (other.isEmpty()) {
-            return this.clone();
-        }
-        // Get all the match types for both filters
-        Set<String> allTypes = new HashSet<String>(this.fields.keySet());
-        allTypes.addAll(new HashSet<String>(other.fields.keySet()));
-        // Derive the intersection
-        Match intersection = new Match();
-        for (String type : allTypes) {
-            if (this.isAny(type) && other.isAny(type)) {
-                continue;
-            }
-            if (this.isAny(type)) {
-                intersection.setField(other.getField(type).clone());
-                continue;
-            } else if (other.isAny(type)) {
-                intersection.setField(this.getField(type).clone());
-                continue;
-            }
-            // Either they are equal or it is about IP address
-            switch (type) {
-            // When it is about IP address, take the wider prefix address
-            // between the twos
-            case NwSrc.TYPE:
-            case NwDst.TYPE:
-                MatchField<?> thisField = this.getField(type);
-                MatchField<?> otherField = other.getField(type);
-                InetAddress thisAddress = (InetAddress) thisField.getValue();
-                InetAddress otherAddress = (InetAddress) otherField.getValue();
-                InetAddress thisMask = (InetAddress) thisField.getMask();
-                InetAddress otherMask = (InetAddress) otherField.getMask();
-
-                int thisMaskLen = (thisMask == null) ? ((thisAddress instanceof Inet4Address) ? 32 : 128) : NetUtils
-                        .getSubnetMaskLength(thisMask);
-                int otherMaskLen = (otherMask == null) ? ((otherAddress instanceof Inet4Address) ? 32 : 128) : NetUtils
-                        .getSubnetMaskLength(otherMask);
-
-                InetAddress subnetPrefix = null;
-                InetAddress subnetMask = null;
-                if (thisMaskLen < otherMaskLen) {
-                    subnetPrefix = NetUtils.getSubnetPrefix(otherAddress, otherMaskLen);
-                    subnetMask = otherMask;
-                } else {
-                    subnetPrefix = NetUtils.getSubnetPrefix(thisAddress, thisMaskLen);
-                    subnetMask = thisMask;
-                }
-                MatchField<?> field = (type.equals(NwSrc.TYPE)) ? new NwSrc(subnetPrefix, subnetMask) : new NwDst(
-                        subnetPrefix, subnetMask);
-                intersection.setField(field);
-                break;
-            default:
-                // this and other match field are equal for this type, pick this
-                // match field
-                intersection.setField(this.getField(type).clone());
-            }
-        }
-        return intersection;
-    }
-
-    /**
-     * Checks whether the intersection of the set of packets described by this
-     * match with the set of packets described by the other match is non empty
-     *
-     * For example, if this match is: DL_SRC = 00:cc:bb:aa:11:22
-     *
-     * and the other match is: DL_TYPE = 0x800 NW_SRC = 1.2.3.4
-     *
-     * then their respective matching packets set intersection is non empty:
-     * DL_SRC = 00:cc:bb:aa:11:22 DL_TYPE = 0x800 NW_SRC = 1.2.3.4
-     *
-     * @param other
-     *            the other match with which testing the intersection
-     * @return true if the intersection of the respective matching packets sets
-     *         is non empty
-     */
-    public boolean intersetcs(Match other) {
-        // No intersection with the empty set
-        if (other == null) {
-            return false;
-        }
-        // Always intersection with the universal set
-        if (this.isEmpty() || other.isEmpty()) {
-            return true;
-        }
-
-        // Get all the match types for both filters
-        Set<String> allTypes = new HashSet<String>(this.fields.keySet());
-        allTypes.addAll(new HashSet<String>(other.fields.keySet()));
-
-        // Iterate through all the match types defined in the two filters
-        for (String type : allTypes) {
-            if (this.isAny(type) || other.isAny(type)) {
-                continue;
-            }
-
-            MatchField<?> thisField = this.getField(type);
-            MatchField<?> otherField = other.getField(type);
-
-            switch (type) {
-            case DlSrc.TYPE:
-            case DlDst.TYPE:
-                if (!Arrays.equals((byte[]) thisField.getValue(), (byte[]) otherField.getValue())) {
-                    return false;
-                }
-                break;
-            case NwSrc.TYPE:
-            case NwDst.TYPE:
-                InetAddress thisAddress = (InetAddress) thisField.getValue();
-                InetAddress otherAddress = (InetAddress) otherField.getValue();
-                // Validity check
-                if (thisAddress instanceof Inet4Address && otherAddress instanceof Inet6Address
-                        || thisAddress instanceof Inet6Address && otherAddress instanceof Inet4Address) {
-                    return false;
-                }
-                InetAddress thisMask = (InetAddress) thisField.getMask();
-                InetAddress otherMask = (InetAddress) otherField.getMask();
-                if (NetUtils.inetAddressConflict(thisAddress, otherAddress, thisMask, otherMask)
-                        && NetUtils.inetAddressConflict(otherAddress, thisAddress, otherMask, thisMask)) {
-                    return false;
-                }
-                break;
-            default:
-                if (!thisField.getValue().equals(otherField.getValue())) {
-                    return false;
-                }
-            }
-        }
-        return true;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + ((fields == null) ? 0 : fields.hashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (!(obj instanceof Match)) {
-            return false;
-        }
-        Match other = (Match) obj;
-        if (fields == null) {
-            if (other.fields != null) {
-                return false;
-            }
-        } else if (!fields.equals(other.fields)) {
-            return false;
-        }
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        return "Match[" + fields.values() + "]";
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/extensible/MatchField.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/extensible/MatchField.java
deleted file mode 100644 (file)
index 8b9a71b..0000000
+++ /dev/null
@@ -1,129 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.match.extensible;
-
-import java.io.Serializable;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-/**
- * Represents the generic matching field object
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public abstract class MatchField<T> implements Cloneable, Serializable {
-    private static final long serialVersionUID = 1L;
-    private String type;
-
-    // To satisfy JAXB
-    @SuppressWarnings("unused")
-    private MatchField() {
-    }
-
-    public MatchField(String type) {
-        this.type = type;
-    }
-
-    @XmlElement(name = "type")
-    public String getType() {
-        return type;
-    }
-
-    /**
-     * Returns the value set for this match field
-     *
-     * @return
-     */
-    public abstract T getValue();
-
-    @XmlElement(name = "value")
-    protected abstract String getValueString();
-
-    /**
-     * Returns the mask value set for this field match A null mask means this is
-     * a full match
-     *
-     * @return
-     */
-    public abstract T getMask();
-
-    @XmlElement(name = "mask")
-    protected abstract String getMaskString();
-
-    /**
-     * Returns whether the field match configuration is valid or not
-     *
-     * @return true if valid, false otherwise
-     */
-    public abstract boolean isValid();
-
-    public abstract boolean hasReverse();
-
-    /**
-     * Returns the reverse match field. For example for a MatchField matching on
-     * source ip 1.1.1.1 it will return a MatchField matching on destination IP
-     * 1.1.1.1. For not reversable MatchField, a copy of this MatchField will be
-     * returned
-     *
-     * @return the correspondent reverse MatchField object or a copy of this
-     *         object if the field is not reversable
-     */
-    public abstract MatchField<T> getReverse();
-
-    /**
-     * Returns whether the match field is congruent with IPv6 frames
-     *
-     * @return true if congruent with IPv6 frames
-     */
-    public abstract boolean isV6();
-
-    @Override
-    public abstract MatchField<T> clone();
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + ((type == null) ? 0 : type.hashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (!(obj instanceof MatchField)) {
-            return false;
-        }
-        MatchField<?> other = (MatchField<?>) obj;
-        if (type == null) {
-            if (other.type != null) {
-                return false;
-            }
-        } else if (!type.equals(other.type)) {
-            return false;
-        }
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        return (getMask() == null) ? String.format("%s(%s)", getType(), getValueString()) :
-            String.format("%s(%s,%s)", getType(), getValueString(), getMaskString());
-    }
-
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/extensible/NwDst.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/extensible/NwDst.java
deleted file mode 100644 (file)
index 4026bc2..0000000
+++ /dev/null
@@ -1,132 +0,0 @@
-package org.opendaylight.controller.sal.match.extensible;
-
-import java.net.Inet4Address;
-import java.net.Inet6Address;
-import java.net.InetAddress;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.sal.utils.NetUtils;
-
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class NwDst extends MatchField<InetAddress> {
-    private static final long serialVersionUID = 1L;
-    public static final String TYPE = "NW_DST";
-    private InetAddress address;
-    private InetAddress mask;
-
-    /**
-     * Creates a Match field for the network destination address
-     *
-     * @param address
-     *            the network address
-     * @param mask
-     *            the network mask
-     */
-    public NwDst(InetAddress address, InetAddress mask) {
-        super(TYPE);
-        this.address = address;
-        this.mask = mask;
-    }
-
-    // To satisfy JAXB
-    private NwDst() {
-        super(TYPE);
-    }
-
-    public NwDst(InetAddress address) {
-        super(TYPE);
-        this.address = address;
-        this.mask = null;
-    }
-
-    @Override
-    public InetAddress getValue() {
-        return address;
-    }
-
-    @Override
-    @XmlElement(name = "value")
-    protected String getValueString() {
-        return address.getHostAddress();
-    }
-
-    @Override
-    public InetAddress getMask() {
-        return mask;
-    }
-
-    @Override
-    @XmlElement(name = "mask")
-    protected String getMaskString() {
-        return (mask == null) ? "null" : mask.getHostAddress();
-    }
-
-    @Override
-    public boolean isValid() {
-        if (address != null) {
-            if (mask != null) {
-                return address instanceof Inet4Address && mask instanceof Inet4Address
-                        || address instanceof Inet6Address && mask instanceof Inet6Address;
-            }
-            return true;
-        }
-        return false;
-    }
-
-    @Override
-    public boolean hasReverse() {
-        return true;
-    }
-
-    @Override
-    public NwSrc getReverse() {
-        return new NwSrc(address, mask);
-    }
-
-    @Override
-    public NwDst clone() {
-        return new NwDst(address, mask);
-    }
-
-    @Override
-    public boolean isV6() {
-        return address instanceof Inet6Address;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + ((address == null) ? 0 : address.hashCode());
-        result = prime * result + ((mask == null) ? 0 : mask.hashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (!(obj instanceof NwDst)) {
-            return false;
-        }
-        NwDst other = (NwDst) obj;
-        // Equality to be checked against prefix addresses
-        int thisMaskLen = (this.mask == null) ? ((this.address instanceof Inet4Address) ? 32 : 128) : NetUtils
-                .getSubnetMaskLength(this.mask);
-        int otherMaskLen = (other.mask == null) ? ((other.address instanceof Inet4Address) ? 32 : 128) : NetUtils
-                .getSubnetMaskLength(other.mask);
-
-        return NetUtils.getSubnetPrefix(address, thisMaskLen).equals(
-                NetUtils.getSubnetPrefix(other.address, otherMaskLen));
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/extensible/NwProtocol.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/extensible/NwProtocol.java
deleted file mode 100644 (file)
index ecaeff1..0000000
+++ /dev/null
@@ -1,117 +0,0 @@
-package org.opendaylight.controller.sal.match.extensible;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.sal.utils.NetUtils;
-
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class NwProtocol extends MatchField<Byte> {
-    private static final long serialVersionUID = 1L;
-    public static final String TYPE = "NW_PROTO";
-    private static final short MAX = 255;
-    private byte protocol;
-
-    /**
-     * Creates a Match field for the network protocol
-     *
-     * @param protocol
-     *            the protocol number
-     */
-    public NwProtocol(byte protocol) {
-        super(TYPE);
-        this.protocol = protocol;
-    }
-
-    public NwProtocol(int protocol) {
-        super(TYPE);
-        this.protocol = (byte) protocol;
-    }
-
-    public NwProtocol(short protocol) {
-        super(TYPE);
-        this.protocol = (byte) protocol;
-    }
-
-    // To satisfy JAXB
-    private NwProtocol() {
-        super(TYPE);
-    }
-
-    @Override
-    public Byte getValue() {
-        return protocol;
-    }
-
-    @Override
-    @XmlElement(name = "value")
-    protected String getValueString() {
-        return String.format("0X%s", Integer.toHexString(NetUtils.getUnsignedByte(protocol)));
-    }
-
-    @Override
-    public Byte getMask() {
-        return null;
-    }
-
-    @Override
-    protected String getMaskString() {
-        return null;
-    }
-
-    @Override
-    public boolean isValid() {
-        int intProtocol = NetUtils.getUnsignedByte(protocol);
-        return intProtocol >= 0 && intProtocol <= MAX;
-    }
-
-    @Override
-    public boolean hasReverse() {
-        return false;
-    }
-
-    @Override
-    public NwProtocol getReverse() {
-        return this.clone();
-    }
-
-    @Override
-    public NwProtocol clone() {
-        return new NwProtocol(protocol);
-    }
-
-    @Override
-    public boolean isV6() {
-        return true;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + protocol;
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (!(obj instanceof NwProtocol)) {
-            return false;
-        }
-        NwProtocol other = (NwProtocol) obj;
-        if (protocol != other.protocol) {
-            return false;
-        }
-        return true;
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/extensible/NwSrc.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/extensible/NwSrc.java
deleted file mode 100644 (file)
index e74b513..0000000
+++ /dev/null
@@ -1,132 +0,0 @@
-package org.opendaylight.controller.sal.match.extensible;
-
-import java.net.Inet4Address;
-import java.net.Inet6Address;
-import java.net.InetAddress;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.sal.utils.NetUtils;
-
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class NwSrc extends MatchField<InetAddress> {
-    private static final long serialVersionUID = 1L;
-    public static final String TYPE = "NW_SRC";
-    private InetAddress address;
-    private InetAddress mask;
-
-    /**
-     * Creates a Match field for the network source address
-     *
-     * @param address
-     *            the network address
-     * @param mask
-     *            the network mask
-     */
-    public NwSrc(InetAddress address, InetAddress mask) {
-        super(TYPE);
-        this.address = address;
-        this.mask = mask;
-    }
-
-    // To satisfy JAXB
-    private NwSrc() {
-        super(TYPE);
-    }
-
-    public NwSrc(InetAddress address) {
-        super(TYPE);
-        this.address = address;
-        this.mask = null;
-    }
-
-    @Override
-    public InetAddress getValue() {
-        return address;
-    }
-
-    @Override
-    @XmlElement(name = "value")
-    protected String getValueString() {
-        return address.toString();
-    }
-
-    @Override
-    public InetAddress getMask() {
-        return mask;
-    }
-
-    @Override
-    @XmlElement(name = "mask")
-    protected String getMaskString() {
-        return mask == null ? "null" : mask.toString();
-    }
-
-    @Override
-    public boolean isValid() {
-        if (address != null) {
-            if (mask != null) {
-                return address instanceof Inet4Address && mask instanceof Inet4Address
-                        || address instanceof Inet6Address && mask instanceof Inet6Address;
-            }
-            return true;
-        }
-        return false;
-    }
-
-    @Override
-    public boolean hasReverse() {
-        return true;
-    }
-
-    @Override
-    public NwDst getReverse() {
-        return new NwDst(address, mask);
-    }
-
-    @Override
-    public NwSrc clone() {
-        return new NwSrc(address, mask);
-    }
-
-    @Override
-    public boolean isV6() {
-        return address instanceof Inet6Address;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + ((address == null) ? 0 : address.hashCode());
-        result = prime * result + ((mask == null) ? 0 : mask.hashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (!(obj instanceof NwSrc)) {
-            return false;
-        }
-        NwSrc other = (NwSrc) obj;
-        // Equality to be checked against prefix addresses
-        int thisMaskLen = (this.mask == null) ? ((this.address instanceof Inet4Address) ? 32 : 128) : NetUtils
-                .getSubnetMaskLength(this.mask);
-        int otherMaskLen = (other.mask == null) ? ((other.address instanceof Inet4Address) ? 32 : 128) : NetUtils
-                .getSubnetMaskLength(other.mask);
-
-        return NetUtils.getSubnetPrefix(address, thisMaskLen).equals(
-                NetUtils.getSubnetPrefix(other.address, otherMaskLen));
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/extensible/NwTos.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/extensible/NwTos.java
deleted file mode 100644 (file)
index 95137ae..0000000
+++ /dev/null
@@ -1,116 +0,0 @@
-package org.opendaylight.controller.sal.match.extensible;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.sal.utils.NetUtils;
-
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class NwTos extends MatchField<Byte> {
-    private static final long serialVersionUID = 1L;
-    public static final String TYPE = "NW_TOS";
-    private static final short MAX = 63;
-    private byte tos;
-
-    /**
-     * Creates a Match field for the network TOS
-     *
-     * @param address
-     *            the network TOS
-     */
-    public NwTos(byte tos) {
-        super(TYPE);
-        this.tos = tos;
-    }
-
-    public NwTos(int tos) {
-        super(TYPE);
-        this.tos = (byte) tos;
-    }
-
-    public NwTos(short tos) {
-        super(TYPE);
-        this.tos = (byte) tos;
-    }
-
-    // To satisfy JAXB
-    private NwTos() {
-        super(TYPE);
-    }
-
-    @Override
-    public Byte getValue() {
-        return tos;
-    }
-
-    @Override
-    @XmlElement(name = "value")
-    protected String getValueString() {
-        return String.format("0X%s", Integer.toHexString(NetUtils.getUnsignedByte(tos)));
-    }
-
-    @Override
-    public Byte getMask() {
-        return null;
-    }
-
-    @Override
-    protected String getMaskString() {
-        return null;
-    }
-
-    @Override
-    public boolean isValid() {
-        return tos >= 0 && tos <= MAX;
-    }
-
-    @Override
-    public boolean hasReverse() {
-        return false;
-    }
-
-    @Override
-    public NwTos getReverse() {
-        return this.clone();
-    }
-
-    @Override
-    public NwTos clone() {
-        return new NwTos(tos);
-    }
-
-    @Override
-    public boolean isV6() {
-        return true;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + tos;
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (!(obj instanceof NwTos)) {
-            return false;
-        }
-        NwTos other = (NwTos) obj;
-        if (tos != other.tos) {
-            return false;
-        }
-        return true;
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/extensible/TpDst.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/extensible/TpDst.java
deleted file mode 100644 (file)
index 3e698d8..0000000
+++ /dev/null
@@ -1,105 +0,0 @@
-package org.opendaylight.controller.sal.match.extensible;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.sal.utils.NetUtils;
-
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class TpDst extends MatchField<Short> {
-    private static final long serialVersionUID = 1L;
-    public static final String TYPE = "TP_DST";
-    private short port;
-
-    /**
-     * Creates a Match field for the transport destination port
-     *
-     * @param port
-     *            the transport port
-     */
-    public TpDst(short port) {
-        super(TYPE);
-        this.port = port;
-    }
-
-    // To satisfy JAXB
-    private TpDst() {
-        super(TYPE);
-    }
-
-    @Override
-    public Short getValue() {
-        return port;
-    }
-
-    @Override
-    @XmlElement(name = "value")
-    protected String getValueString() {
-        return String.valueOf(NetUtils.getUnsignedShort(port));
-    }
-
-    @Override
-    public Short getMask() {
-        return null;
-    }
-
-    @Override
-    protected String getMaskString() {
-        return null;
-    }
-
-    @Override
-    public boolean isValid() {
-        return true;
-    }
-
-    @Override
-    public TpSrc getReverse() {
-        return new TpSrc(port);
-    }
-
-    @Override
-    public boolean hasReverse() {
-        return true;
-    }
-
-    @Override
-    public TpDst clone() {
-        return new TpDst(port);
-    }
-
-    @Override
-    public boolean isV6() {
-        return true;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = super.hashCode();
-        result = prime * result + port;
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (!super.equals(obj)) {
-            return false;
-        }
-        if (!(obj instanceof TpDst)) {
-            return false;
-        }
-        TpDst other = (TpDst) obj;
-        if (port != other.port) {
-            return false;
-        }
-        return true;
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/extensible/TpSrc.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/match/extensible/TpSrc.java
deleted file mode 100644 (file)
index d3e8427..0000000
+++ /dev/null
@@ -1,105 +0,0 @@
-package org.opendaylight.controller.sal.match.extensible;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.sal.utils.NetUtils;
-
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class TpSrc extends MatchField<Short> {
-    private static final long serialVersionUID = 1L;
-    public static final String TYPE = "TP_SRC";
-    private short port;
-
-    /**
-     * Creates a Match field for the Transport source port
-     *
-     * @param port
-     *            the transport port
-     */
-    public TpSrc(short port) {
-        super(TYPE);
-        this.port = port;
-    }
-
-    // To satisfy JAXB
-    private TpSrc() {
-        super(TYPE);
-    }
-
-    @Override
-    public Short getValue() {
-        return port;
-    }
-
-    @Override
-    @XmlElement(name = "value")
-    protected String getValueString() {
-        return String.valueOf(NetUtils.getUnsignedShort(port));
-    }
-
-    @Override
-    public Short getMask() {
-        return null;
-    }
-
-    @Override
-    protected String getMaskString() {
-        return null;
-    }
-
-    @Override
-    public boolean isValid() {
-        return true;
-    }
-
-    @Override
-    public boolean hasReverse() {
-        return true;
-    }
-
-    @Override
-    public TpDst getReverse() {
-        return new TpDst(port);
-    }
-
-    @Override
-    public TpSrc clone() {
-        return new TpSrc(port);
-    }
-
-    @Override
-    public boolean isV6() {
-        return true;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = super.hashCode();
-        result = prime * result + port;
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (!super.equals(obj)) {
-            return false;
-        }
-        if (!(obj instanceof TpSrc)) {
-            return false;
-        }
-        TpSrc other = (TpSrc) obj;
-        if (port != other.port) {
-            return false;
-        }
-        return true;
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/ARP.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/ARP.java
deleted file mode 100644 (file)
index 3c9e9b6..0000000
+++ /dev/null
@@ -1,280 +0,0 @@
-
-/*
- * Copyright (c) 2013-2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.packet;
-
-import java.util.HashMap;
-import java.util.LinkedHashMap;
-import java.util.Map;
-
-import org.apache.commons.lang3.tuple.ImmutablePair;
-import org.apache.commons.lang3.tuple.Pair;
-
-/**
- * Class that represents the ARP packet objects
- *
- *
- */
-@Deprecated
-public class ARP extends Packet {
-    private static final String HWTYPE = "HardwareType";
-    private static final String PTYPE = "ProtocolType";
-    private static final String HWADDRLENGTH = "HardwareAddressLength";
-    private static final String PADDRLENGTH = "ProtocolAddressLength";
-    private static final String OPCODE = "OpCode";
-    private static final String SENDERHWADDR = "SenderHardwareAddress";
-    private static final String SENDERPADDR = "SenderProtocolAddress";
-    private static final String TARGETHWADDR = "TargetHardwareAddress";
-    private static final String TARGETPADDR = "TargetProtocolAddress";
-
-    public static short HW_TYPE_ETHERNET = (short) 0x1;
-    public static short REQUEST = (short) 0x1;
-    public static short REPLY = (short) 0x2;
-
-    public static short PROTO_TYPE_IP = 0x800;
-
-    private static Map<String, Pair<Integer, Integer>> fieldCoordinates = new LinkedHashMap<String, Pair<Integer, Integer>>() {
-        private static final long serialVersionUID = 1L;
-        {
-            put(HWTYPE, new ImmutablePair<Integer, Integer>(0, 16));
-            put(PTYPE, new ImmutablePair<Integer, Integer>(16, 16));
-            put(HWADDRLENGTH, new ImmutablePair<Integer, Integer>(32, 8));
-            put(PADDRLENGTH, new ImmutablePair<Integer, Integer>(40, 8));
-            put(OPCODE, new ImmutablePair<Integer, Integer>(48, 16));
-            put(SENDERHWADDR, new ImmutablePair<Integer, Integer>(64, 48));
-            put(SENDERPADDR, new ImmutablePair<Integer, Integer>(112, 32));
-            put(TARGETHWADDR, new ImmutablePair<Integer, Integer>(144, 48));
-            put(TARGETPADDR, new ImmutablePair<Integer, Integer>(192, 32));
-
-        }
-    };
-    private Map<String, byte[]> fieldValues;
-
-    /**
-     * Default constructor that creates and sets the HashMap
-     */
-    public ARP() {
-        super();
-        fieldValues = new HashMap<String, byte[]>();
-        hdrFieldCoordMap = fieldCoordinates;
-        hdrFieldsMap = fieldValues;
-    }
-
-    /**
-     * Constructor that sets the access level for the packet and
-     * creates and sets the HashMap
-     */
-    public ARP(boolean writeAccess) {
-        super(writeAccess);
-        fieldValues = new HashMap<String, byte[]>();
-        hdrFieldCoordMap = fieldCoordinates;
-        hdrFieldsMap = fieldValues;
-    }
-
-    /**
-     * Gets the hardware type from the stored ARP header
-     * @return short - the hardwareType
-     */
-    public short getHardwareType() {
-        return (BitBufferHelper.getShort(fieldValues.get(HWTYPE)));
-
-    }
-
-    /**
-     * Gets the protocol type from the stored ARP header
-     * @return short - the protocolType
-     */
-    public short getProtocolType() {
-        return (BitBufferHelper.getShort(fieldValues.get(PTYPE)));
-    }
-
-    /**
-     * Gets the hardware address length from the stored ARP header
-     * @return byte - the protocolAddressLength
-     */
-    public byte getHardwareAddressLength() {
-        return (BitBufferHelper.getByte(fieldValues.get(HWADDRLENGTH)));
-    }
-
-    /**
-     * Get the protocol address length from Protocol header
-     * @return byte - the protocolAddressLength
-     */
-    public byte getProtocolAddressLength() {
-        return (BitBufferHelper.getByte(fieldValues.get(PADDRLENGTH)));
-    }
-
-    /**
-     * Gets the opCode from stored ARP header
-     * @param short - the opCode to set
-     */
-    public short getOpCode() {
-        return (BitBufferHelper.getShort(fieldValues.get(OPCODE)));
-    }
-
-    /**
-     * Gets the sender hardware address from the stored ARP header
-     * @return byte[] - the senderHardwareAddress
-     */
-    public byte[] getSenderHardwareAddress() {
-        return (fieldValues.get(SENDERHWADDR));
-    }
-
-    /**
-     * Gets the IP address from the stored ARP header
-     * @return byte[] - the senderProtocolAddress
-     */
-    public byte[] getSenderProtocolAddress() {
-        return (fieldValues.get(SENDERPADDR));
-    }
-
-    /**
-     * Gets the hardware address from the stored ARP header
-     * @return byte[] - the targetHardwareAddress
-     */
-    public byte[] getTargetHardwareAddress() {
-        return (fieldValues.get(TARGETHWADDR));
-    }
-
-    /**
-     * Sets the hardware Type for the current ARP object instance
-     * @param short - hardwareType the hardwareType to set
-     * @return ARP
-     */
-    public ARP setHardwareType(short hardwareType) {
-        byte[] hwType = BitBufferHelper.toByteArray(hardwareType);
-        fieldValues.put(HWTYPE, hwType);
-        return this;
-    }
-
-    /**
-     * Sets the protocol Type for the current ARP object instance
-     * @param short - the protocolType to set
-     * @return ARP
-     */
-    public ARP setProtocolType(short protocolType) {
-        byte[] protType = BitBufferHelper.toByteArray(protocolType);
-        fieldValues.put(PTYPE, protType);
-        return this;
-    }
-
-    /**
-     * Sets the hardware address length for the current ARP object instance
-     * @param byte - the hardwareAddressLength to set
-     * @return ARP
-     */
-    public ARP setHardwareAddressLength(byte hardwareAddressLength) {
-        byte[] hwAddressLength = BitBufferHelper
-                .toByteArray(hardwareAddressLength);
-        fieldValues.put(HWADDRLENGTH, hwAddressLength);
-        return this;
-    }
-
-    /**
-     * Sets the Protocol address for the current ARP object instance
-     * @param byte - the protocolAddressLength to set
-     * @return ARP
-     */
-    public ARP setProtocolAddressLength(byte protocolAddressLength) {
-        byte[] protocolAddrLength = BitBufferHelper
-                .toByteArray(protocolAddressLength);
-        fieldValues.put(PADDRLENGTH, protocolAddrLength);
-        return this;
-    }
-
-    /**
-     * Sets the opCode for the current ARP object instance
-     * @param short - the opCode to set
-     * @return ARP
-     */
-    public ARP setOpCode(short opCode) {
-        byte[] operationCode = BitBufferHelper.toByteArray(opCode);
-        fieldValues.put(OPCODE, operationCode);
-        return this;
-    }
-
-    /**
-     * Sets the sender hardware address for the current ARP object instance
-     * @param byte[] - the senderHardwareAddress to set
-     * @return ARP
-     */
-    public ARP setSenderHardwareAddress(byte[] senderHardwareAddress) {
-        fieldValues.put(SENDERHWADDR, senderHardwareAddress);
-        return this;
-    }
-
-    /**
-     * Sets the target hardware address for the current ARP object instance
-     * @param byte[] - the targetHardwareAddress to set
-     * @return ARP
-     */
-    public ARP setTargetHardwareAddress(byte[] targetHardwareAddress) {
-        fieldValues.put(TARGETHWADDR, targetHardwareAddress);
-        return this;
-    }
-
-    /**
-     * Sets the target protocol address for the current ARP object instance
-     * @param byte[] - the targetProtocolAddress to set
-     * @return ARP
-     */
-    public ARP setTargetProtocolAddress(byte[] targetProtocolAddress) {
-        fieldValues.put(TARGETPADDR, targetProtocolAddress);
-        return this;
-    }
-
-    /**
-     * Sets the sender protocol address for the current ARP object instance
-     * @param byte[] - senderIP
-     * @return ARP
-     */
-    public ARP setSenderProtocolAddress(byte[] senderIP) {
-        fieldValues.put(SENDERPADDR, senderIP);
-        return this;
-    }
-
-    /**
-     * Gets the target protocol address
-     * @return - byte[] targetProtocolAddress
-     */
-    public byte[] getTargetProtocolAddress() {
-        return fieldValues.get(TARGETPADDR);
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = super.hashCode();
-        result = prime * result
-                + ((fieldValues == null) ? 0 : fieldValues.hashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (!super.equals(obj)) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        ARP other = (ARP) obj;
-        if (fieldValues == null) {
-            if (other.fieldValues != null) {
-                return false;
-            }
-        } else if (!fieldValues.equals(other.fieldValues)) {
-            return false;
-        }
-        return true;
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/BitBufferHelper.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/BitBufferHelper.java
deleted file mode 100644 (file)
index 176e446..0000000
+++ /dev/null
@@ -1,720 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- *
- */
-package org.opendaylight.controller.sal.packet;
-
-import java.util.Arrays;
-
-import org.opendaylight.controller.sal.utils.NetUtils;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * BitBufferHelper class that provides utility methods to
- * - fetch specific bits from a serialized stream of bits
- * - convert bits to primitive data type - like short, int, long
- * - store bits in specified location in stream of bits
- * - convert primitive data types to stream of bits
- */
-@Deprecated
-public abstract class BitBufferHelper {
-    protected static final Logger logger = LoggerFactory
-    .getLogger(BitBufferHelper.class);
-
-    public static final long ByteMask = 0xFF;
-
-    // Getters
-    // data: array where data are stored
-    // startOffset: bit from where to start reading
-    // numBits: number of bits to read
-    // All this function return an exception if overflow or underflow
-
-    /**
-     * Returns the first byte from the byte array
-     * @param byte[] data
-     * @return byte value
-     */
-    public static byte getByte(byte[] data) {
-        if ((data.length * NetUtils.NumBitsInAByte) > Byte.SIZE) {
-            try {
-                throw new BufferException(
-                        "Container is too small for the number of requested bits");
-            } catch (BufferException e) {
-                logger.error("", e);
-            }
-        }
-        return (data[0]);
-    }
-
-    /**
-     * Returns the short value for the byte array passed.
-     * Size of byte array is restricted to Short.SIZE
-     * @param byte[] data
-     * @return short value
-     */
-    public static short getShort(byte[] data) {
-        if (data.length > Short.SIZE) {
-            try {
-                throw new BufferException(
-                        "Container is too small for the number of requested bits");
-            } catch (BufferException e) {
-                logger.error("", e);
-            }
-        }
-        return (short) toNumber(data);
-    }
-
-    /**
-     * Returns the int value for the byte array passed.
-     * Size of byte array is restricted to Integer.SIZE
-     * @param byte[] data
-     * @return int - the integer value of byte array
-     */
-    public static int getInt(byte[] data) {
-        if (data.length > Integer.SIZE) {
-            try {
-                throw new BufferException(
-                        "Container is too small for the number of requested bits");
-            } catch (BufferException e) {
-                logger.error("", e);
-            }
-        }
-        return (int) toNumber(data);
-    }
-
-    /**
-     * Returns the long value for the byte array passed.
-     * Size of byte array is restricted to Long.SIZE
-     * @param byte[] data
-     * @return long - the integer value of byte array
-     */
-    public static long getLong(byte[] data) {
-        if (data.length > Long.SIZE) {
-            try {
-                throw new BufferException(
-                        "Container is too small for the number of requested bits");
-            } catch (Exception e) {
-                logger.error("", e);
-            }
-        }
-        return (long) toNumber(data);
-    }
-
-    /**
-     * Returns the short value for the last numBits of the byte array passed.
-     * Size of numBits is restricted to Short.SIZE
-     * @param byte[] data
-     * @param int - numBits
-     * @return short - the short value of byte array
-     */
-    public static short getShort(byte[] data, int numBits) {
-        if (numBits > Short.SIZE) {
-            try {
-                throw new BufferException(
-                        "Container is too small for the number of requested bits");
-            } catch (BufferException e) {
-                logger.error("", e);
-            }
-        }
-        int startOffset = data.length * NetUtils.NumBitsInAByte - numBits;
-        byte[] bits = null;
-        try {
-            bits = BitBufferHelper.getBits(data, startOffset, numBits);
-        } catch (BufferException e) {
-            logger.error("", e);
-        }
-        return (short) toNumber(bits, numBits);
-    }
-
-    /**
-     * Returns the int value for the last numBits of the byte array passed.
-     * Size of numBits is restricted to Integer.SIZE
-     * @param byte[] data
-     * @param int - numBits
-     * @return int - the integer value of byte array
-     */
-    public static int getInt(byte[] data, int numBits) {
-        if (numBits > Integer.SIZE) {
-            try {
-                throw new BufferException(
-                        "Container is too small for the number of requested bits");
-            } catch (BufferException e) {
-                logger.error("", e);
-            }
-        }
-        int startOffset = data.length * NetUtils.NumBitsInAByte - numBits;
-        byte[] bits = null;
-        try {
-            bits = BitBufferHelper.getBits(data, startOffset, numBits);
-        } catch (BufferException e) {
-            logger.error("", e);
-        }
-        return (int) toNumber(bits, numBits);
-    }
-
-    /**
-     * Returns the long value for the last numBits of the byte array passed.
-     * Size of numBits is restricted to Long.SIZE
-     * @param byte[] data
-     * @param int - numBits
-     * @return long - the integer value of byte array
-     */
-    public static long getLong(byte[] data, int numBits) {
-        if (numBits > Long.SIZE) {
-            try {
-                throw new BufferException(
-                        "Container is too small for the number of requested bits");
-            } catch (BufferException e) {
-                logger.error("", e);
-            }
-        }
-        if (numBits > data.length * NetUtils.NumBitsInAByte) {
-            try {
-                throw new BufferException(
-                        "Trying to read more bits than contained in the data buffer");
-            } catch (BufferException e) {
-                logger.error("", e);
-            }
-        }
-        int startOffset = data.length * NetUtils.NumBitsInAByte - numBits;
-        byte[] bits = null;
-        try {
-            bits = BitBufferHelper.getBits(data, startOffset, numBits);
-        } catch (BufferException e) {
-            logger.error("", e);
-        }
-        return (long) toNumber(bits, numBits);
-    }
-
-    /**
-     * Reads the specified number of bits from the passed byte array
-     * starting to read from the specified offset
-     * The bits read are stored in a byte array which size is dictated
-     * by the number of bits to be stored.
-     * The bits are stored in the byte array LSB aligned.
-     *
-     * Ex.
-     * Read 7 bits at offset 10
-     * 0         9 10     16 17
-     * 0101000010 | 0000101 | 1111001010010101011
-     * will be returned as {0,0,0,0,0,1,0,1}
-     *
-     * @param byte[] data
-     * @param int startOffset - offset to start fetching bits from data from
-     * @param int numBits - number of bits to be fetched from data
-     * @return byte [] - LSB aligned bits
-     *
-     * @throws BufferException
-     *             when the startOffset and numBits parameters are not congruent
-     *             with the data buffer size
-     */
-    public static byte[] getBits(byte[] data, int startOffset, int numBits)
-            throws BufferException {
-
-        int startByteOffset = 0;
-        int valfromcurr, valfromnext;
-        int extranumBits = numBits % NetUtils.NumBitsInAByte;
-        int extraOffsetBits = startOffset % NetUtils.NumBitsInAByte;
-        int numBytes = (numBits % NetUtils.NumBitsInAByte != 0) ? 1 + numBits
-                / NetUtils.NumBitsInAByte : numBits / NetUtils.NumBitsInAByte;
-        byte[] shiftedBytes = new byte[numBytes];
-        startByteOffset = startOffset / NetUtils.NumBitsInAByte;
-        byte[] bytes = new byte[numBytes];
-        if (numBits == 0) {
-            return bytes;
-        }
-
-        checkExceptions(data, startOffset, numBits);
-
-        if (extraOffsetBits == 0) {
-            if (extranumBits == 0) {
-                System.arraycopy(data, startByteOffset, bytes, 0, numBytes);
-                return bytes;
-            } else {
-                System.arraycopy(data, startByteOffset, bytes, 0, numBytes - 1);
-                bytes[numBytes - 1] = (byte) ((int) data[startByteOffset
-                        + numBytes - 1] & getMSBMask(extranumBits));
-            }
-        } else {
-            int i;
-            for (i = 0; i < numBits / NetUtils.NumBitsInAByte; i++) {
-                // Reading numBytes starting from offset
-                valfromcurr = (data[startByteOffset + i])
-                        & getLSBMask(NetUtils.NumBitsInAByte - extraOffsetBits);
-                valfromnext = (data[startByteOffset + i + 1])
-                        & getMSBMask(extraOffsetBits);
-                bytes[i] = (byte) (valfromcurr << (extraOffsetBits) | (valfromnext >> (NetUtils.NumBitsInAByte - extraOffsetBits)));
-            }
-            // Now adding the rest of the bits if any
-            if (extranumBits != 0) {
-                if (extranumBits < (NetUtils.NumBitsInAByte - extraOffsetBits)) {
-                    valfromnext = (byte) (data[startByteOffset + i] & ((getMSBMask(extranumBits)) >> extraOffsetBits));
-                    bytes[i] = (byte) (valfromnext << extraOffsetBits);
-                } else if (extranumBits == (NetUtils.NumBitsInAByte - extraOffsetBits)) {
-                    valfromcurr = (data[startByteOffset + i])
-                            & getLSBMask(NetUtils.NumBitsInAByte
-                                    - extraOffsetBits);
-                    bytes[i] = (byte) (valfromcurr << extraOffsetBits);
-                } else {
-                    valfromcurr = (data[startByteOffset + i])
-                            & getLSBMask(NetUtils.NumBitsInAByte
-                                    - extraOffsetBits);
-                    valfromnext = (data[startByteOffset + i + 1])
-                            & (getMSBMask(extranumBits
-                                    - (NetUtils.NumBitsInAByte - extraOffsetBits)));
-                    bytes[i] = (byte) (valfromcurr << (extraOffsetBits) | (valfromnext >> (NetUtils.NumBitsInAByte - extraOffsetBits)));
-                }
-
-            }
-        }
-        // Aligns the bits to LSB
-        shiftedBytes = shiftBitsToLSB(bytes, numBits);
-        return shiftedBytes;
-    }
-
-    // Setters
-    // data: array where data will be stored
-    // input: the data that need to be stored in the data array
-    // startOffset: bit from where to start writing
-    // numBits: number of bits to read
-
-    /**
-     * Bits are expected to be stored in the input byte array from LSB
-     * @param byte[] - data to set the input byte
-     * @param byte - input byte to be inserted
-     * @param startOffset - offset of data[] to start inserting byte from
-     * @param numBits - number of bits of input to be inserted into data[]
-     *
-     * @throws BufferException
-     *             when the input, startOffset and numBits are not congruent
-     *             with the data buffer size
-     */
-    public static void setByte(byte[] data, byte input, int startOffset,
-            int numBits) throws BufferException {
-        byte[] inputByteArray = new byte[1];
-        Arrays.fill(inputByteArray, 0, 1, input);
-        setBytes(data, inputByteArray, startOffset, numBits);
-    }
-
-    /**
-     * Bits are expected to be stored in the input byte array from LSB
-     * @param byte[] - data to set the input byte
-     * @param byte[] - input bytes to be inserted
-     * @param startOffset - offset of data[] to start inserting byte from
-     * @param numBits - number of bits of input to be inserted into data[]
-     * @return void
-     * @throws BufferException
-     *             when the startOffset and numBits parameters are not congruent
-     *             with data and input buffers' size
-     */
-    public static void setBytes(byte[] data, byte[] input, int startOffset,
-            int numBits) throws BufferException {
-        checkExceptions(data, startOffset, numBits);
-        insertBits(data, input, startOffset, numBits);
-    }
-
-    /**
-     * Returns numBits 1's in the MSB position
-     *
-     * @param numBits
-     * @return
-     */
-    public static int getMSBMask(int numBits) {
-        int mask = 0;
-        for (int i = 0; i < numBits; i++) {
-            mask = mask | (1 << (7 - i));
-        }
-        return mask;
-    }
-
-    /**
-     * Returns numBits 1's in the LSB position
-     *
-     * @param numBits
-     * @return
-     */
-    public static int getLSBMask(int numBits) {
-        int mask = 0;
-        for (int i = 0; i < numBits; i++) {
-            mask = mask | (1 << i);
-        }
-        return mask;
-    }
-
-    /**
-     * Returns the numerical value of the byte array passed
-     *
-     * @param byte[] - array
-     * @return long - numerical value of byte array passed
-     */
-    static public long toNumber(byte[] array) {
-        long ret = 0;
-        long length = array.length;
-        int value = 0;
-        for (int i = 0; i < length; i++) {
-            value = array[i];
-            if (value < 0)
-                value += 256;
-            ret = ret
-                    | (long) ((long) value << ((length - i - 1) * NetUtils.NumBitsInAByte));
-        }
-        return ret;
-    }
-
-    /**
-     * Returns the numerical value of the last numBits (LSB bits) of the byte
-     * array passed
-     *
-     * @param byte[] - array
-     * @param int - numBits
-     * @return long - numerical value of byte array passed
-     */
-    static public long toNumber(byte[] array, int numBits) {
-        int length = numBits / NetUtils.NumBitsInAByte;
-        int bitsRest = numBits % NetUtils.NumBitsInAByte;
-        int startOffset = array.length - length;
-        long ret = 0;
-        int value = 0;
-
-        value = array[startOffset - 1] & getLSBMask(bitsRest);
-        value = (array[startOffset - 1] < 0) ? (array[startOffset - 1] + 256)
-                : array[startOffset - 1];
-        ret = ret
-                | (value << ((array.length - startOffset) * NetUtils.NumBitsInAByte));
-
-        for (int i = startOffset; i < array.length; i++) {
-            value = array[i];
-            if (value < 0)
-                value += 256;
-            ret = ret
-                    | (long) ((long) value << ((array.length - i - 1) * NetUtils.NumBitsInAByte));
-        }
-
-        return ret;
-    }
-
-    /**
-     * Accepts a number as input and returns its value in byte form in LSB
-     * aligned form example: input = 5000 [1001110001000] bytes = 19, -120
-     * [00010011] [10001000]
-     *
-     * @param Number
-     * @return byte[]
-     *
-     */
-
-    public static byte[] toByteArray(Number input) {
-        Class<? extends Number> dataType = input.getClass();
-        short size = 0;
-        long longValue = input.longValue();
-
-        if (dataType == Byte.class || dataType == byte.class) {
-            size = Byte.SIZE;
-        } else if (dataType == Short.class || dataType == short.class) {
-            size = Short.SIZE;
-        } else if (dataType == Integer.class || dataType == int.class) {
-            size = Integer.SIZE;
-        } else if (dataType == Long.class || dataType == long.class) {
-            size = Long.SIZE;
-        } else {
-            throw new IllegalArgumentException(
-                    "Parameter must one of the following: Short/Int/Long\n");
-        }
-
-        int length = size / NetUtils.NumBitsInAByte;
-        byte bytes[] = new byte[length];
-
-        // Getting the bytes from input value
-        for (int i = 0; i < length; i++) {
-            bytes[i] = (byte) ((longValue >> (NetUtils.NumBitsInAByte * (length
-                    - i - 1))) & ByteMask);
-        }
-        return bytes;
-    }
-
-    /**
-     * Accepts a number as input and returns its value in byte form in MSB
-     * aligned form example: input = 5000 [1001110001000] bytes = -114, 64
-     * [10011100] [01000000]
-     *
-     * @param Number
-     *            input
-     * @param int numBits - the number of bits to be returned
-     * @return byte[]
-     *
-     */
-    public static byte[] toByteArray(Number input, int numBits) {
-        Class<? extends Number> dataType = input.getClass();
-        short size = 0;
-        long longValue = input.longValue();
-
-        if (dataType == Short.class) {
-            size = Short.SIZE;
-        } else if (dataType == Integer.class) {
-            size = Integer.SIZE;
-        } else if (dataType == Long.class) {
-            size = Long.SIZE;
-        } else {
-            throw new IllegalArgumentException(
-                    "Parameter must one of the following: Short/Int/Long\n");
-        }
-
-        int length = size / NetUtils.NumBitsInAByte;
-        byte bytes[] = new byte[length];
-        byte[] inputbytes = new byte[length];
-        byte shiftedBytes[];
-
-        // Getting the bytes from input value
-        for (int i = 0; i < length; i++) {
-            bytes[i] = (byte) ((longValue >> (NetUtils.NumBitsInAByte * (length
-                    - i - 1))) & ByteMask);
-        }
-
-        if ((bytes[0] == 0 && dataType == Long.class)
-                || (bytes[0] == 0 && dataType == Integer.class)) {
-            int index = 0;
-            for (index = 0; index < length; ++index) {
-                if (bytes[index] != 0) {
-                    bytes[0] = bytes[index];
-                    break;
-                }
-            }
-            System.arraycopy(bytes, index, inputbytes, 0, length - index);
-            Arrays.fill(bytes, length - index + 1, length - 1, (byte) 0);
-        } else {
-            System.arraycopy(bytes, 0, inputbytes, 0, length);
-        }
-
-        shiftedBytes = shiftBitsToMSB(inputbytes, numBits);
-
-        return shiftedBytes;
-    }
-
-    /**
-     * Takes an LSB aligned byte array and returned the LSB numBits in a MSB
-     * aligned byte array
-     *
-     * @param inputbytes
-     * @param numBits
-     * @return
-     */
-    /**
-     * It aligns the last numBits bits to the head of the byte array following
-     * them with numBits % 8 zero bits.
-     *
-     * Example: For inputbytes = [00000111][01110001] and numBits = 12 it
-     * returns: shiftedBytes = [01110111][00010000]
-     *
-     * @param byte[] inputBytes
-     * @param int numBits - number of bits to be left aligned
-     * @return byte[]
-     */
-    public static byte[] shiftBitsToMSB(byte[] inputBytes, int numBits) {
-        int numBitstoShiftBy = 0, leadZeroesMSB = 8, numEndRestBits = 0;
-        int size = inputBytes.length;
-        byte[] shiftedBytes = new byte[size];
-        int i;
-
-        for (i = 0; i < Byte.SIZE; i++) {
-            if (((byte) (inputBytes[0] & getMSBMask(i + 1))) != 0) {
-                leadZeroesMSB = i;
-                break;
-            }
-        }
-
-        if (numBits % NetUtils.NumBitsInAByte == 0) {
-            numBitstoShiftBy = 0;
-        } else {
-            numBitstoShiftBy = ((NetUtils.NumBitsInAByte - (numBits % NetUtils.NumBitsInAByte)) < leadZeroesMSB) ? (NetUtils.NumBitsInAByte - (numBits % NetUtils.NumBitsInAByte))
-                    : leadZeroesMSB;
-        }
-        if (numBitstoShiftBy == 0) {
-            return inputBytes;
-        }
-
-        if (numBits < NetUtils.NumBitsInAByte) {
-            // inputbytes.length = 1 OR read less than a byte
-            shiftedBytes[0] = (byte) ((inputBytes[0] & getLSBMask(numBits)) << numBitstoShiftBy);
-        } else {
-            // # of bits to read from last byte
-            numEndRestBits = NetUtils.NumBitsInAByte
-                    - (inputBytes.length * NetUtils.NumBitsInAByte - numBits - numBitstoShiftBy);
-
-            for (i = 0; i < (size - 1); i++) {
-                if ((i + 1) == (size - 1)) {
-                    if (numEndRestBits > numBitstoShiftBy) {
-                        shiftedBytes[i] = (byte) ((inputBytes[i] << numBitstoShiftBy) | ((inputBytes[i + 1] & getMSBMask(numBitstoShiftBy)) >> (numEndRestBits - numBitstoShiftBy)));
-                        shiftedBytes[i + 1] = (byte) ((inputBytes[i + 1] & getLSBMask(numEndRestBits
-                                - numBitstoShiftBy)) << numBitstoShiftBy);
-                    } else
-                        shiftedBytes[i] = (byte) ((inputBytes[i] << numBitstoShiftBy) | ((inputBytes[i + 1] & getMSBMask(numEndRestBits)) >> (NetUtils.NumBitsInAByte - numEndRestBits)));
-                }
-                shiftedBytes[i] = (byte) ((inputBytes[i] << numBitstoShiftBy) | (inputBytes[i + 1] & getMSBMask(numBitstoShiftBy)) >> (NetUtils.NumBitsInAByte - numBitstoShiftBy));
-            }
-
-        }
-        return shiftedBytes;
-    }
-
-    /**
-     * It aligns the first numBits bits to the right end of the byte array
-     * preceding them with numBits % 8 zero bits.
-     *
-     * Example: For inputbytes = [01110111][00010000] and numBits = 12 it
-     * returns: shiftedBytes = [00000111][01110001]
-     *
-     * @param byte[] inputBytes
-     * @param int numBits - number of bits to be right aligned
-     * @return byte[]
-     */
-    public static byte[] shiftBitsToLSB(byte[] inputBytes, int numBits) {
-        int numBytes = inputBytes.length;
-        int numBitstoShift = numBits % NetUtils.NumBitsInAByte;
-        byte[] shiftedBytes = new byte[numBytes];
-        int inputLsb = 0, inputMsb = 0;
-
-        if (numBitstoShift == 0) {
-            return inputBytes;
-        }
-
-        for (int i = 1; i < numBytes; i++) {
-            inputLsb = inputBytes[i - 1]
-                    & getLSBMask(NetUtils.NumBitsInAByte - numBitstoShift);
-            inputLsb = (inputLsb < 0) ? (inputLsb + 256) : inputLsb;
-            inputMsb = inputBytes[i] & getMSBMask(numBitstoShift);
-            inputMsb = (inputBytes[i] < 0) ? (inputBytes[i] + 256)
-                    : inputBytes[i];
-            shiftedBytes[i] = (byte) ((inputLsb << numBitstoShift) | (inputMsb >> (NetUtils.NumBitsInAByte - numBitstoShift)));
-        }
-        inputMsb = inputBytes[0] & (getMSBMask(numBitstoShift));
-        inputMsb = (inputMsb < 0) ? (inputMsb + 256) : inputMsb;
-        shiftedBytes[0] = (byte) (inputMsb >> (NetUtils.NumBitsInAByte - numBitstoShift));
-        return shiftedBytes;
-    }
-
-    /**
-     * Insert in the data buffer at position dictated by the offset the number
-     * of bits specified from the input data byte array. The input byte array
-     * has the bits stored starting from the LSB
-     *
-     * @param byte[] data
-     * @param byte[] inputdata
-     * @param int startOffset
-     * @param int numBits
-     */
-    public static void insertBits(byte[] data, byte[] inputdataLSB,
-            int startOffset, int numBits) {
-        byte[] inputdata = shiftBitsToMSB(inputdataLSB, numBits); // Align to
-                                                                  // MSB the
-                                                                  // passed byte
-                                                                  // array
-        int numBytes = numBits / NetUtils.NumBitsInAByte;
-        int startByteOffset = startOffset / NetUtils.NumBitsInAByte;
-        int extraOffsetBits = startOffset % NetUtils.NumBitsInAByte;
-        int extranumBits = numBits % NetUtils.NumBitsInAByte;
-        int RestBits = numBits % NetUtils.NumBitsInAByte;
-        int InputMSBbits = 0, InputLSBbits = 0;
-        int i;
-
-        if (numBits == 0) {
-            return;
-        }
-
-        if (extraOffsetBits == 0) {
-            if (extranumBits == 0) {
-                numBytes = numBits / NetUtils.NumBitsInAByte;
-                System.arraycopy(inputdata, 0, data, startByteOffset, numBytes);
-            } else {
-                System.arraycopy(inputdata, 0, data, startByteOffset, numBytes);
-                data[startByteOffset + numBytes] = (byte) (data[startByteOffset
-                        + numBytes] | (inputdata[numBytes] & getMSBMask(extranumBits)));
-            }
-        } else {
-            for (i = 0; i < numBytes; i++) {
-                if (i != 0)
-                    InputLSBbits = (inputdata[i - 1] & getLSBMask(extraOffsetBits));
-                InputMSBbits = (byte) (inputdata[i] & (getMSBMask(NetUtils.NumBitsInAByte
-                        - extraOffsetBits)));
-                InputMSBbits = (InputMSBbits >= 0) ? InputMSBbits
-                        : InputMSBbits + 256;
-                data[startByteOffset + i] = (byte) (data[startByteOffset + i]
-                        | (InputLSBbits << (NetUtils.NumBitsInAByte - extraOffsetBits)) | (InputMSBbits >> extraOffsetBits));
-                InputMSBbits = InputLSBbits = 0;
-            }
-            if (RestBits < (NetUtils.NumBitsInAByte - extraOffsetBits)) {
-                if (numBytes != 0)
-                    InputLSBbits = (inputdata[i - 1] & getLSBMask(extraOffsetBits));
-                InputMSBbits = (byte) (inputdata[i] & (getMSBMask(RestBits)));
-                InputMSBbits = (InputMSBbits >= 0) ? InputMSBbits
-                        : InputMSBbits + 256;
-                data[startByteOffset + i] = (byte) ((data[startByteOffset + i])
-                        | (InputLSBbits << (NetUtils.NumBitsInAByte - extraOffsetBits)) | (InputMSBbits >> extraOffsetBits));
-            } else if (RestBits == (NetUtils.NumBitsInAByte - extraOffsetBits)) {
-                if (numBytes != 0)
-                    InputLSBbits = (inputdata[i - 1] & getLSBMask(extraOffsetBits));
-                InputMSBbits = (byte) (inputdata[i] & (getMSBMask(NetUtils.NumBitsInAByte
-                        - extraOffsetBits)));
-                InputMSBbits = (InputMSBbits >= 0) ? InputMSBbits
-                        : InputMSBbits + 256;
-                data[startByteOffset + i] = (byte) (data[startByteOffset + i]
-                        | (InputLSBbits << (NetUtils.NumBitsInAByte - extraOffsetBits)) | (InputMSBbits >> extraOffsetBits));
-            } else {
-                if (numBytes != 0)
-                    InputLSBbits = (inputdata[i - 1] & getLSBMask(extraOffsetBits));
-                InputMSBbits = (byte) (inputdata[i] & (getMSBMask(NetUtils.NumBitsInAByte
-                        - extraOffsetBits)));
-                InputMSBbits = (InputMSBbits >= 0) ? InputMSBbits
-                        : InputMSBbits + 256;
-                data[startByteOffset + i] = (byte) (data[startByteOffset + i]
-                        | (InputLSBbits << (NetUtils.NumBitsInAByte - extraOffsetBits)) | (InputMSBbits >> extraOffsetBits));
-
-                InputLSBbits = (inputdata[i] & (getLSBMask(RestBits
-                        - (NetUtils.NumBitsInAByte - extraOffsetBits)) << (NetUtils.NumBitsInAByte - RestBits)));
-                data[startByteOffset + i + 1] = (byte) (data[startByteOffset
-                        + i + 1] | (InputLSBbits << (NetUtils.NumBitsInAByte - extraOffsetBits)));
-            }
-        }
-    }
-
-    /**
-     * Checks for overflow and underflow exceptions
-     * @param data
-     * @param startOffset
-     * @param numBits
-     * @throws PacketException when the startOffset and numBits parameters
-     *                    are not congruent with the data buffer's size
-     */
-    public static void checkExceptions(byte[] data, int startOffset, int numBits)
-            throws BufferException {
-        int endOffsetByte;
-        int startByteOffset;
-        endOffsetByte = startOffset
-                / NetUtils.NumBitsInAByte
-                + numBits
-                / NetUtils.NumBitsInAByte
-                + ((numBits % NetUtils.NumBitsInAByte != 0) ? 1 : ((startOffset
-                        % NetUtils.NumBitsInAByte != 0) ? 1 : 0));
-        startByteOffset = startOffset / NetUtils.NumBitsInAByte;
-
-        if (data == null) {
-            throw new BufferException("data[] is null\n");
-        }
-
-        if ((startOffset < 0) || (startByteOffset >= data.length)
-                || (endOffsetByte > data.length) || (numBits < 0)
-                || (numBits > NetUtils.NumBitsInAByte * data.length)) {
-            throw new BufferException(
-                    "Illegal arguement/out of bound exception - data.length = "
-                            + data.length + " startOffset = " + startOffset
-                            + " numBits " + numBits);
-        }
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/BufferException.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/BufferException.java
deleted file mode 100644 (file)
index 63fd4ec..0000000
+++ /dev/null
@@ -1,20 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.sal.packet;
-
-/**
- * Describes an exception that is raised during BitBufferHelper operations.
- */
-@Deprecated
-public class BufferException extends Exception {
-    private static final long serialVersionUID = 1L;
-
-    public BufferException(String message) {
-        super(message);
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/Ethernet.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/Ethernet.java
deleted file mode 100644 (file)
index a7ffbe7..0000000
+++ /dev/null
@@ -1,151 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.packet;
-
-import java.util.HashMap;
-import java.util.LinkedHashMap;
-import java.util.Map;
-
-import org.apache.commons.lang3.tuple.ImmutablePair;
-import org.apache.commons.lang3.tuple.Pair;
-import org.opendaylight.controller.sal.match.Match;
-import org.opendaylight.controller.sal.match.MatchType;
-import org.opendaylight.controller.sal.utils.EtherTypes;
-import org.opendaylight.controller.sal.utils.NetUtils;
-
-/**
- * Class that represents the Ethernet frame objects
- */
-@Deprecated
-public class Ethernet extends Packet {
-    private static final String DMAC = "DestinationMACAddress";
-    private static final String SMAC = "SourceMACAddress";
-    private static final String ETHT = "EtherType";
-
-    // TODO: This has to be outside and it should be possible for osgi
-    // to add new coming packet classes
-    public static final Map<Short, Class<? extends Packet>> etherTypeClassMap;
-    static {
-        etherTypeClassMap = new HashMap<Short, Class<? extends Packet>>();
-        etherTypeClassMap.put(EtherTypes.ARP.shortValue(), ARP.class);
-        etherTypeClassMap.put(EtherTypes.IPv4.shortValue(), IPv4.class);
-        etherTypeClassMap.put(EtherTypes.LLDP.shortValue(), LLDP.class);
-        etherTypeClassMap.put(EtherTypes.VLANTAGGED.shortValue(), IEEE8021Q.class);
-        etherTypeClassMap.put(EtherTypes.OLDQINQ.shortValue(), IEEE8021Q.class);
-        etherTypeClassMap.put(EtherTypes.QINQ.shortValue(), IEEE8021Q.class);
-        etherTypeClassMap.put(EtherTypes.CISCOQINQ.shortValue(), IEEE8021Q.class);
-    }
-    private static Map<String, Pair<Integer, Integer>> fieldCoordinates = new LinkedHashMap<String, Pair<Integer, Integer>>() {
-        private static final long serialVersionUID = 1L;
-        {
-            put(DMAC, new ImmutablePair<Integer, Integer>(0, 48));
-            put(SMAC, new ImmutablePair<Integer, Integer>(48, 48));
-            put(ETHT, new ImmutablePair<Integer, Integer>(96, 16));
-        }
-    };
-    private final Map<String, byte[]> fieldValues;
-
-    /**
-     * Default constructor that creates and sets the HashMap
-     */
-    public Ethernet() {
-        super();
-        fieldValues = new HashMap<String, byte[]>();
-        hdrFieldCoordMap = fieldCoordinates;
-        hdrFieldsMap = fieldValues;
-    }
-
-    /**
-     * Constructor that sets the access level for the packet and
-     * creates and sets the HashMap
-     */
-    public Ethernet(boolean writeAccess) {
-        super(writeAccess);
-        fieldValues = new HashMap<String, byte[]>();
-        hdrFieldCoordMap = fieldCoordinates;
-        hdrFieldsMap = fieldValues;
-    }
-
-    @Override
-    public void setHeaderField(String headerField, byte[] readValue) {
-        if (headerField.equals(ETHT)) {
-            payloadClass = etherTypeClassMap.get(BitBufferHelper
-                    .getShort(readValue));
-        }
-        hdrFieldsMap.put(headerField, readValue);
-    }
-
-    /**
-     * Gets the destination MAC address stored
-     * @return byte[] - the destinationMACAddress
-     */
-    public byte[] getDestinationMACAddress() {
-        return fieldValues.get(DMAC);
-    }
-
-    /**
-     * Gets the source MAC address stored
-     * @return byte[] - the sourceMACAddress
-     */
-    public byte[] getSourceMACAddress() {
-        return fieldValues.get(SMAC);
-    }
-
-    /**
-     * Gets the etherType stored
-     * @return short - the etherType
-     */
-    public short getEtherType() {
-        return BitBufferHelper.getShort(fieldValues.get(ETHT));
-    }
-
-    public boolean isBroadcast(){
-        return NetUtils.isBroadcastMACAddr(getDestinationMACAddress());
-    }
-
-    public boolean isMulticast(){
-        return NetUtils.isMulticastMACAddr(getDestinationMACAddress());
-    }
-
-    /**
-     * Sets the destination MAC address for the current Ethernet object instance
-     * @param byte[] - the destinationMACAddress to set
-     */
-    public Ethernet setDestinationMACAddress(byte[] destinationMACAddress) {
-        fieldValues.put(DMAC, destinationMACAddress);
-        return this;
-    }
-
-    /**
-     * Sets the source MAC address for the current Ethernet object instance
-     * @param byte[] - the sourceMACAddress to set
-     */
-    public Ethernet setSourceMACAddress(byte[] sourceMACAddress) {
-        fieldValues.put(SMAC, sourceMACAddress);
-        return this;
-    }
-
-    /**
-     * Sets the etherType for the current Ethernet object instance
-     * @param short - the etherType to set
-     */
-    public Ethernet setEtherType(short etherType) {
-        byte[] ethType = BitBufferHelper.toByteArray(etherType);
-        fieldValues.put(ETHT, ethType);
-        return this;
-    }
-
-    @Override
-    public void populateMatch(Match match) {
-        match.setField(MatchType.DL_SRC, this.getSourceMACAddress());
-        match.setField(MatchType.DL_DST, this.getDestinationMACAddress());
-        match.setField(MatchType.DL_TYPE, this.getEtherType());
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/ICMP.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/ICMP.java
deleted file mode 100644 (file)
index 79d6f60..0000000
+++ /dev/null
@@ -1,244 +0,0 @@
-
-/*
- * Copyright (c) 2013-2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.packet;
-
-import java.util.HashMap;
-import java.util.LinkedHashMap;
-import java.util.Map;
-
-import org.apache.commons.lang3.tuple.ImmutablePair;
-import org.apache.commons.lang3.tuple.Pair;
-import org.opendaylight.controller.sal.utils.NetUtils;
-
-/**
- * Class that represents the ICMP packet objects
- */
-@Deprecated
-public class ICMP extends Packet {
-    private static final String TYPE = "Type";
-    private static final String CODE = "Code";
-    private static final String CHECKSUM = "Checksum";
-    private static final String IDENTIFIER = "Identifier";
-    private static final String SEQNUMBER = "SequenceNumber";
-
-    private static Map<String, Pair<Integer, Integer>> fieldCoordinates = new LinkedHashMap<String, Pair<Integer, Integer>>() {
-        private static final long serialVersionUID = 1L;
-        {
-            put(TYPE, new ImmutablePair<Integer, Integer>(0, 8));
-            put(CODE, new ImmutablePair<Integer, Integer>(8, 8));
-            put(CHECKSUM, new ImmutablePair<Integer, Integer>(16, 16));
-            put(IDENTIFIER, new ImmutablePair<Integer, Integer>(32, 16));
-            put(SEQNUMBER, new ImmutablePair<Integer, Integer>(48, 16));
-        }
-    };
-
-    /**
-     * Default constructor that creates and sets the hash map values
-     */
-    public ICMP() {
-        super();
-        fieldValues = new HashMap<String, byte[]>();
-        hdrFieldCoordMap = fieldCoordinates;
-        hdrFieldsMap = fieldValues;
-    }
-
-    /**
-     * Constructor that sets the access level for the packet
-     */
-    public ICMP(boolean writeAccess) {
-        super(writeAccess);
-        fieldValues = new HashMap<String, byte[]>();
-        hdrFieldCoordMap = fieldCoordinates;
-        hdrFieldsMap = fieldValues;
-    }
-
-    private final Map<String, byte[]> fieldValues;
-
-    @Override
-    public void setHeaderField(String headerField, byte[] readValue) {
-        hdrFieldsMap.put(headerField, readValue);
-    }
-
-    /**
-     * Sets the type for the current ICMP message
-     *
-     * @param type
-     *            The ICMP message type
-     * @return This ICMP object
-     */
-    public ICMP setType(byte type) {
-        byte[] icmpType = BitBufferHelper.toByteArray(type);
-        fieldValues.put(TYPE, icmpType);
-        return this;
-    }
-
-    /**
-     * Returns the type field of the current ICMP packet
-     *
-     * @return The type code of the current ICMP packet
-     */
-    public byte getType() {
-        return BitBufferHelper.getByte(fieldValues.get(TYPE));
-    }
-
-    /**
-     * Sets the ICMP code (type subtype) for the current ICMP object instance
-     *
-     * @param code
-     *            The ICMP message type subtype
-     * @return This ICMP object
-     */
-    public ICMP setCode(byte code) {
-        byte[] icmpCode = BitBufferHelper.toByteArray(code);
-        fieldValues.put(CODE, icmpCode);
-        return this;
-    }
-
-    /**
-     * Gets the ICMP code (type subtype) for the current ICMP object instance
-     *
-     * @return The ICMP message type subtype
-     */
-    public byte getCode() {
-        return BitBufferHelper.getByte(fieldValues.get(CODE));
-    }
-
-    /**
-     * Sets the ICMP checksum  for the current ICMP object instance
-     * @param short - checksum
-     * @return ICMP
-     */
-    public ICMP setChecksum(short checksum) {
-        byte[] icmpChecksum = BitBufferHelper.toByteArray(checksum);
-        fieldValues.put(CHECKSUM, icmpChecksum);
-        return this;
-    }
-
-    /**
-     * Sets the ICMP identifier for the current ICMP object instance
-     * @param short - identifier
-     * @return ICMP
-     */
-    public ICMP setIdentifier(short identifier) {
-        byte[] icmpIdentifier = BitBufferHelper.toByteArray(identifier);
-        fieldValues.put(IDENTIFIER, icmpIdentifier);
-        return this;
-    }
-
-    /**
-     * Gets the ICMP identifier of the current ICMP object instance
-     *
-     * @return short - identifier
-     */
-
-    public short getIdentifier() {
-        return BitBufferHelper.getShort(fieldValues.get(IDENTIFIER));
-    }
-
-    /**
-     * Sets the ICMP sequence number for the current ICMP object instance
-     * @param short - seqNumber
-     * @return ICMP
-     */
-    public ICMP setSequenceNumber(short seqNumber) {
-        byte[] icmpSeqNumber = BitBufferHelper.toByteArray(seqNumber);
-        fieldValues.put(SEQNUMBER, icmpSeqNumber);
-        return this;
-    }
-
-    /**
-     * Gets the ICMP sequence number of the current ICMP object instance
-     *
-     * @return short - seqNumber
-     */
-
-    public short getSequenceNumber() {
-        return BitBufferHelper.getShort(fieldValues.get(SEQNUMBER));
-    }
-
-    /**
-     * Gets the header size in bits
-     * @return The ICMP header size in bits
-     */
-    @Override
-    public int getHeaderSize() {
-        return 64;
-    }
-
-    /**
-     * Computes the ICMP checksum on the serialized ICMP message
-     *
-     * @param serialized
-     *            The data stream
-     * @param start
-     *            The byte index on the data stream from which the ICMP packet
-     *            starts
-     * @return The checksum
-     */
-    short computeChecksum(byte[] data, int start) {
-        int sum = 0, carry = 0, finalSum = 0;
-        int wordData;
-        int end = start + this.getHeaderSize() / NetUtils.NumBitsInAByte;
-        if (rawPayload != null) {
-            end += rawPayload.length;
-        }
-        int checksumStartByte = start + getfieldOffset(CHECKSUM) / NetUtils.NumBitsInAByte;
-        int even = end & ~1;
-
-        for (int i = start; i < even; i = i + 2) {
-            // Skip, if the current bytes are checkSum bytes
-            if (i == checksumStartByte) {
-                continue;
-            }
-            wordData = ((data[i] << 8) & 0xFF00) + (data[i + 1] & 0xFF);
-            sum = sum + wordData;
-        }
-        if (even < end) {
-            // Add the last octet with zero padding.
-            wordData = (data[even] << 8) & 0xFF00;
-            sum = sum + wordData;
-        }
-
-        carry = sum >>> 16;
-        finalSum = (sum & 0xFFFF) + carry;
-        return (short) ~((short) finalSum & 0xFFFF);
-    }
-
-    @Override
-    protected void postSerializeCustomOperation(byte[] serializedBytes)
-            throws PacketException {
-        byte[] checkSum = BitBufferHelper
-                .toByteArray(computeChecksum(serializedBytes, 0));
-        try {
-            BitBufferHelper.setBytes(serializedBytes, checkSum,
-                    getfieldOffset(CHECKSUM), getfieldnumBits(CHECKSUM));
-        } catch (BufferException e) {
-            throw new PacketException(e.getMessage());
-        }
-    }
-
-    @Override
-    protected void postDeserializeCustomOperation(byte[] data, int endBitOffset) {
-        short computedChecksum = computeChecksum(data, endBitOffset / NetUtils.NumBitsInAByte);
-        short actualChecksum = BitBufferHelper.getShort(fieldValues.get(CHECKSUM));
-
-        if (computedChecksum != actualChecksum) {
-            corrupted = true;
-        }
-    }
-
-    /**
-     * Gets the checksum value stored
-     * @return the checksum
-     */
-    public short getChecksum() {
-        return (BitBufferHelper.getShort(fieldValues.get(CHECKSUM)));
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/IDataPacketService.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/IDataPacketService.java
deleted file mode 100644 (file)
index 41937b2..0000000
+++ /dev/null
@@ -1,50 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * @file   IDataPacketService.java
- *
- * @brief  SAL exported Data Packet services
- *
- * Data Packet Services SAL provides to the components
- */
-package org.opendaylight.controller.sal.packet;
-
-/**
- * Data Packet Services SAL provides to the components
- */
-@Deprecated
-public interface IDataPacketService {
-    /**
-     * Transmit a data Packet. Transmission will ONLY happen if the
-     * RawPacket has the OutgoingNodeConnector set else of course
-     * transmission cannot happen.
-     *
-     * @param outPkt Packet to be transmitted out
-     */
-    void transmitDataPacket(RawPacket outPkt);
-
-    /**
-     * Decode a Data Packet received as a raw stream
-     *
-     * @param pkt Raw Packet to be decoded
-     *
-     * @return The formatted Data Packet
-     */
-    Packet decodeDataPacket(RawPacket pkt);
-
-    /**
-     * Encode a Formatted Data Packet in a raw bytestream
-     *
-     * @param pkt Formatted Data Packet to be encoded
-     *
-     * @return a RawPacket representation, good for transmission purpose
-     */
-    RawPacket encodeDataPacket(Packet pkt);
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/IEEE8021Q.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/IEEE8021Q.java
deleted file mode 100644 (file)
index 196d87f..0000000
+++ /dev/null
@@ -1,171 +0,0 @@
-/*
- * Copyright (c) 2013-2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.packet;
-
-import java.util.HashMap;
-import java.util.LinkedHashMap;
-import java.util.Map;
-
-import org.apache.commons.lang3.tuple.ImmutablePair;
-import org.apache.commons.lang3.tuple.Pair;
-import org.opendaylight.controller.sal.match.Match;
-import org.opendaylight.controller.sal.match.MatchType;
-
-/**
- * Class that represents the IEEE 802.1Q objects
- */
-@Deprecated
-public class IEEE8021Q extends Packet {
-    private static final String PCP = "PriorityCodePoint";
-    private static final String CFI = "CanonicalFormatIndicator";
-    private static final String VID = "VlanIdentifier";
-    private static final String ETHT = "EtherType";
-
-    private static Map<String, Pair<Integer, Integer>> fieldCoordinates = new LinkedHashMap<String, Pair<Integer, Integer>>() {
-        private static final long serialVersionUID = 1L;
-        {
-            put(PCP, new ImmutablePair<Integer, Integer>(0, 3));
-            put(CFI, new ImmutablePair<Integer, Integer>(3, 1));
-            put(VID, new ImmutablePair<Integer, Integer>(4, 12));
-            put(ETHT, new ImmutablePair<Integer, Integer>(16, 16));
-        }
-    };
-    private final Map<String, byte[]> fieldValues;
-
-    /**
-     * Default constructor that creates and sets the HashMap
-     */
-    public IEEE8021Q() {
-        super();
-        fieldValues = new HashMap<String, byte[]>();
-        hdrFieldCoordMap = fieldCoordinates;
-        hdrFieldsMap = fieldValues;
-    }
-
-    /**
-     * Constructor that sets the access level for the packet and creates and
-     * sets the HashMap
-     */
-    public IEEE8021Q(boolean writeAccess) {
-        super(writeAccess);
-        fieldValues = new HashMap<String, byte[]>();
-        hdrFieldCoordMap = fieldCoordinates;
-        hdrFieldsMap = fieldValues;
-    }
-
-    @Override
-    /**
-     * Store the value read from data stream in hdrFieldMap
-     */
-    public void setHeaderField(String headerField, byte[] readValue) {
-        if (headerField.equals(ETHT)) {
-            payloadClass = Ethernet.etherTypeClassMap.get(BitBufferHelper.getShort(readValue));
-        }
-        hdrFieldsMap.put(headerField, readValue);
-    }
-
-    /**
-     * Gets the priority code point(PCP) stored
-     *
-     * @return byte - the PCP
-     */
-    public byte getPcp() {
-        return BitBufferHelper.getByte(fieldValues.get(PCP));
-    }
-
-    /**
-     * Gets the canonical format indicator(CFI) stored
-     *
-     * @return byte - the CFI
-     */
-    public byte getCfi() {
-        return BitBufferHelper.getByte(fieldValues.get(CFI));
-    }
-
-    /**
-     * Gets the VLAN identifier(VID) stored
-     *
-     * @return short - the VID
-     */
-    public short getVid() {
-        return BitBufferHelper.getShort(fieldValues.get(VID));
-    }
-
-    /**
-     * Gets the etherType stored
-     *
-     * @return short - the etherType
-     */
-    public short getEtherType() {
-        return BitBufferHelper.getShort(fieldValues.get(ETHT));
-    }
-
-    /**
-     * Sets the priority code point(PCP) for the current IEEE 802.1Q object
-     * instance
-     *
-     * @param byte - the PCP to set
-     */
-    public IEEE8021Q setPcp(byte pcp) {
-        byte[] priorityCodePoint = BitBufferHelper.toByteArray(pcp);
-        fieldValues.put(PCP, priorityCodePoint);
-        return this;
-    }
-
-    /**
-     * Sets the canonical format indicator(CFI) for the current IEEE 802.1Q
-     * object instance
-     *
-     * @param byte - the CFI to set
-     */
-    public IEEE8021Q setCfi(byte cfi) {
-        byte[] canonicalFormatIndicator = BitBufferHelper.toByteArray(cfi);
-        fieldValues.put(CFI, canonicalFormatIndicator);
-        return this;
-    }
-
-    /**
-     * Sets the VLAN identifier(VID) for the current IEEE 802.1Q instance
-     *
-     * @param short - the VID to set
-     */
-    public IEEE8021Q setVid(short vid) {
-        byte[] vlanIdentifier = BitBufferHelper.toByteArray(vid);
-        fieldValues.put(VID, vlanIdentifier);
-        return this;
-    }
-
-    /**
-     * Sets the etherType for the current IEEE 802.1Q object instance
-     *
-     * @param short - the etherType to set
-     */
-    public IEEE8021Q setEtherType(short etherType) {
-        byte[] ethType = BitBufferHelper.toByteArray(etherType);
-        fieldValues.put(ETHT, ethType);
-        return this;
-    }
-
-    @Override
-    public void populateMatch(Match match) {
-        match.setField(MatchType.DL_VLAN, this.getVid());
-        match.setField(MatchType.DL_VLAN_PR, this.getPcp());
-        match.setField(MatchType.DL_TYPE, this.getEtherType());
-    }
-
-    /**
-     * Gets the header size in bits
-     * @return The .1Q header size in bits
-     */
-    @Override
-    public int getHeaderSize() {
-        return 32;
-    }
-
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/IListenDataPacket.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/IListenDataPacket.java
deleted file mode 100644 (file)
index a64de5b..0000000
+++ /dev/null
@@ -1,71 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * @file   IListenDataPacket.java
- *
- * @brief  Interface a component will need to implement and export as
- * implemented interface in order to get data packet
- *
- * Interface a component will need to implement and export as
- * implemented interface in order to get data packet
- */
-
-package org.opendaylight.controller.sal.packet;
-
-/**
- * Interface that all the components that want to receive a dataPacket
- * need to implement. The interface by itself doesn't specify any
- * filtering or sequencing mechanism, but the model supported by Data
- * Packet Service is such that the packets can be processed in two
- * ways:
- * - Serial: When a Data Packet Listener gets a packet after another,
- * this case is necessary when the subsequent handler needs some extra
- * information that can only be provided by another Data Packet
- * Service Handler. If the dependent service is missing, then the one
- * with dependencies will not be invoked. In a serial
- * processing, a plugin has the the power to prevent the packet to be
- * seen but other in the chain, if the return result is CONSUMED, else
- * the packet will go through all the elements in the chain.
- * - Parallel: When a Data Packet Listener doesn't express any
- * dependency then it will get a copy of the packet as anybody
- * else. Practical example, let say we have 2 handlers, both didn't
- * express any dependency then both will get a copy of any incoming
- * packet and they cannot step over each other feet.
- * The Processing model is choosen by the properties with which the
- * service is registered in the OSGi service registry.
- * The properties that will be looked at are:
- * salListenerName: Unique identifier of the SAL Data Packet
- * Listener
- * salListenerDependency: A String containing the
- * salListenerName that consitute a dependency for this Listener, for
- * now ONLY a SINGLE dependency is supported
- * salListenerFilter: A Match class to be used to match a DataPacket,
- * processing either parallel or serial will ONLY continue if the
- * incoming DataPacket match the filter. If no filter is provided, the
- * handler is called for EVERY packet i.e. match All is implied!
- */
-@Deprecated
-public interface IListenDataPacket {
-    /**
-     * Handler for receiving the packet. The application can signal
-     * back to SAL if the packet has been consumed or no. In case of
-     * packet consumed SAL will prevent to keep passing to subsequent
-     * listener in the serial chain, but for handlers without
-     * dependency things will keep going .
-     * The packet will received will have the IncomingNodeConnector
-     * set to understand where the packet is coming from
-     *
-     * @param inPkt Packet received
-     *
-     * @return An indication if the packet should still be processed
-     * or we should stop it.
-     */
-    PacketResult receiveDataPacket(RawPacket inPkt);
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/IPluginInDataPacketService.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/IPluginInDataPacketService.java
deleted file mode 100644 (file)
index 863ed68..0000000
+++ /dev/null
@@ -1,36 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * @file   IPluginInDataPacketService.java
- *
- * @brief  Data Packet Services exported by SouthBound plugins for SAL usage
- *
- * Data Packet Services exported by SouthBound plugins for SAL usage
- */
-package org.opendaylight.controller.sal.packet;
-
-/**
- * Data Packet Services exported by SouthBound plugins for SAL usage.
- * The service will be used by SAL such that for every Protocol Plugin
- * there is only one expected, for this reason the service need to be
- * registered in the OSGi service registry along with the property:
- * - "protocoloPluginType"
- * the value of the property will org.opendaylight.controller.sal.core.Node.NodeIDType
- */
-@Deprecated
-public interface IPluginInDataPacketService {
-    /**
-     * Transmit a data Packet. Packet will go out ONLY if the packet
-     * has property OutgoingNodeConnector set.
-     *
-     * @param outPkt Packet to be transmitted out
-     */
-    void transmitDataPacket(RawPacket outPkt);
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/IPluginOutDataPacketService.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/IPluginOutDataPacketService.java
deleted file mode 100644 (file)
index d8852fe..0000000
+++ /dev/null
@@ -1,43 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * @file   IPluginOutDataPacketService.java
- *
- * @brief  Interface SAL will need to register in order to get some
- * packets from the southbound protocol plugins
- *
- * Interface SAL will need to register in order to get some
- * packets from the southbound protocol plugins
- */
-
-package org.opendaylight.controller.sal.packet;
-
-/**
- * Interface used by SAL to intercept any Data Packet coming from the
- * southbound protocol plugins
- */
-@Deprecated
-public interface IPluginOutDataPacketService {
-    /**
-     * Handler for receiving the packet. The SAL layer can signal back
-     * to the southbound plugin if the packet has been consumed or can
-     * go for further processing. Usually after SAL processing
-     * probably there is no other processing to be done, but just in
-     * case there is chain the return code can be used.
-     * The protocol plugin is supposed to deliver a packet with the
-     * IncomingNodeConnector set
-     *
-     * @param inPkt Packet received
-     *
-     * @return An indication if the packet should still be processed
-     * or we should stop it.
-     */
-    PacketResult receiveDataPacket(RawPacket inPkt);
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/IPv4.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/IPv4.java
deleted file mode 100644 (file)
index 148f351..0000000
+++ /dev/null
@@ -1,600 +0,0 @@
-
-/*
- * Copyright (c) 2013-2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- *
- */
-package org.opendaylight.controller.sal.packet;
-
-import java.net.InetAddress;
-import java.util.HashMap;
-import java.util.LinkedHashMap;
-import java.util.Map;
-import java.util.Random;
-
-import org.apache.commons.lang3.tuple.ImmutablePair;
-import org.apache.commons.lang3.tuple.Pair;
-import org.opendaylight.controller.sal.match.Match;
-import org.opendaylight.controller.sal.match.MatchType;
-import org.opendaylight.controller.sal.utils.IPProtocols;
-import org.opendaylight.controller.sal.utils.NetUtils;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * Class that represents the IPv4  packet objects
- */
-@Deprecated
-public class IPv4 extends Packet {
-    protected static final Logger logger = LoggerFactory
-            .getLogger(IPv4.class);
-    private static final String VERSION = "Version";
-    private static final String HEADERLENGTH = "HeaderLength";
-    private static final String DIFFSERV = "DiffServ";
-    private static final String ECN = "ECN";
-    private static final String TOTLENGTH = "TotalLength";
-    private static final String IDENTIFICATION = "Identification";
-    private static final String FLAGS = "Flags";
-    private static final String FRAGOFFSET = "FragmentOffset";
-    private static final String TTL = "TTL";
-    private static final String PROTOCOL = "Protocol";
-    private static final String CHECKSUM = "Checksum";
-    private static final String SIP = "SourceIPAddress";
-    private static final String DIP = "DestinationIPAddress";
-    private static final String OPTIONS = "Options";
-
-    private static final int UNIT_SIZE_SHIFT = 2;
-    private static final int UNIT_SIZE = (1 << UNIT_SIZE_SHIFT);
-    private static final int MIN_HEADER_SIZE = 20;
-
-    public static final Map<Byte, Class<? extends Packet>> protocolClassMap;
-    static {
-        protocolClassMap = new HashMap<Byte, Class<? extends Packet>>();
-        protocolClassMap.put(IPProtocols.ICMP.byteValue(), ICMP.class);
-        protocolClassMap.put(IPProtocols.UDP.byteValue(), UDP.class);
-        protocolClassMap.put(IPProtocols.TCP.byteValue(), TCP.class);
-    }
-    private static Map<String, Pair<Integer, Integer>> fieldCoordinates = new LinkedHashMap<String, Pair<Integer, Integer>>() {
-        private static final long serialVersionUID = 1L;
-        {
-            put(VERSION, new ImmutablePair<Integer, Integer>(0, 4));
-            put(HEADERLENGTH, new ImmutablePair<Integer, Integer>(4, 4));
-            put(DIFFSERV, new ImmutablePair<Integer, Integer>(8, 6));
-            put(ECN, new ImmutablePair<Integer, Integer>(14, 2));
-            put(TOTLENGTH, new ImmutablePair<Integer, Integer>(16, 16));
-            put(IDENTIFICATION, new ImmutablePair<Integer, Integer>(32, 16));
-            put(FLAGS, new ImmutablePair<Integer, Integer>(48, 3));
-            put(FRAGOFFSET, new ImmutablePair<Integer, Integer>(51, 13));
-            put(TTL, new ImmutablePair<Integer, Integer>(64, 8));
-            put(PROTOCOL, new ImmutablePair<Integer, Integer>(72, 8));
-            put(CHECKSUM, new ImmutablePair<Integer, Integer>(80, 16));
-            put(SIP, new ImmutablePair<Integer, Integer>(96, 32));
-            put(DIP, new ImmutablePair<Integer, Integer>(128, 32));
-            put(OPTIONS, new ImmutablePair<Integer, Integer>(160, 0));
-        }
-    };
-
-    private final Map<String, byte[]> fieldValues;
-
-
-    /**
-     * Default constructor that sets the version to 4, headerLength to 5,
-     * and flags to 2.  The default value for the identification is set to a
-     * random number and the remaining fields are set to 0.
-     */
-    public IPv4() {
-        super();
-        fieldValues = new HashMap<String, byte[]>();
-        hdrFieldCoordMap = fieldCoordinates;
-        hdrFieldsMap = fieldValues;
-        corrupted = false;
-
-        setVersion((byte) 4);
-        setHeaderLength((byte) 5);
-        setDiffServ((byte) 0);
-        setECN((byte) 0);
-        setIdentification(generateId());
-        setFlags((byte) 2);
-        setFragmentOffset((short) 0);
-    }
-
-    /**
-     * The write access to the packet is set in this constructor.
-     * Constructor that sets the version to 4, headerLength to 5,
-     * and flags to 2.  The default value for the identification is set to a
-     * random number and the remaining fields are set to 0.
-     * @param boolean
-     */
-    public IPv4(boolean writeAccess) {
-        super(writeAccess);
-        fieldValues = new HashMap<String, byte[]>();
-        hdrFieldCoordMap = fieldCoordinates;
-        hdrFieldsMap = fieldValues;
-        corrupted = false;
-
-        setVersion((byte) 4);
-        setHeaderLength((byte) 5);
-        setDiffServ((byte) 0);
-        setECN((byte) 0);
-        setIdentification(generateId());
-        setFlags((byte) 2);
-        setFragmentOffset((short) 0);
-    }
-
-    /**
-     * Gets the IP version stored
-     * @return the version
-     */
-    public byte getVersion() {
-        return (BitBufferHelper.getByte(fieldValues.get(VERSION)));
-    }
-
-    /**
-     * Gets the IP header length stored
-     * @return the headerLength in bytes
-     */
-    public int getHeaderLen() {
-        return (4 * BitBufferHelper.getByte(fieldValues.get(HEADERLENGTH)));
-    }
-
-    /**
-     * Gets the header size in bits
-     * @return The number of bits constituting the header
-     */
-    @Override
-    public int getHeaderSize() {
-        int headerLen = this.getHeaderLen();
-        if (headerLen == 0) {
-            headerLen = MIN_HEADER_SIZE;
-        }
-
-        return headerLen * NetUtils.NumBitsInAByte;
-    }
-
-    /**
-     * Gets the differential services value stored
-     * @return the diffServ
-     */
-    public byte getDiffServ() {
-        return BitBufferHelper.getByte(fieldValues.get(DIFFSERV));
-    }
-
-    /**
-     * Gets the ecn bits stored
-     * @return the ecn bits
-     */
-    public byte getECN() {
-        return BitBufferHelper.getByte(fieldValues.get(ECN));
-    }
-
-    /**
-     * Gets the total length of the IP header in bytes
-     * @return the totalLength
-     */
-    public short getTotalLength() {
-        return (BitBufferHelper.getShort(fieldValues.get(TOTLENGTH)));
-    }
-
-    /**
-     * Gets the identification value stored
-     * @return the identification
-     */
-    public short getIdentification() {
-        return (BitBufferHelper.getShort(fieldValues.get(IDENTIFICATION)));
-    }
-
-    /**
-     * Gets the flag values stored
-     * @return the flags
-     */
-    public byte getFlags() {
-        return (BitBufferHelper.getByte(fieldValues.get(FLAGS)));
-    }
-
-    /**
-     * Gets the TTL value stored
-     * @return the ttl
-     */
-    public byte getTtl() {
-        return (BitBufferHelper.getByte(fieldValues.get(TTL)));
-    }
-
-    /**
-     * Gets the protocol value stored
-     * @return the protocol
-     */
-    public byte getProtocol() {
-        return (BitBufferHelper.getByte(fieldValues.get(PROTOCOL)));
-    }
-
-    /**
-     * Gets the checksum value stored
-     * @return the checksum
-     */
-    public short getChecksum() {
-        return (BitBufferHelper.getShort(fieldValues.get(CHECKSUM)));
-    }
-
-    /**
-     * Gets the fragment offset stored
-     * @return the fragmentOffset
-     */
-    public short getFragmentOffset() {
-        return (BitBufferHelper.getShort(fieldValues.get(FRAGOFFSET)));
-    }
-
-    /**
-     * Gets the source IP address stored
-     * @return the sourceAddress
-     */
-    public int getSourceAddress() {
-        return (BitBufferHelper.getInt(fieldValues.get(SIP)));
-    }
-
-    /**
-     * Gets the destination IP address stored
-     * @return the destinationAddress
-     */
-    public int getDestinationAddress() {
-        return (BitBufferHelper.getInt(fieldValues.get(DIP)));
-    }
-
-    /**
-     * gets the Options stored
-     * @return the options
-     */
-    public byte[] getOptions() {
-        return (fieldValues.get(OPTIONS));
-    }
-
-    @Override
-    /**
-     * Stores the value of fields read from data stream
-     * Variable header value like payload protocol, is stored here
-     */
-    public void setHeaderField(String headerField, byte[] readValue) {
-        if (headerField.equals(PROTOCOL)) {
-            // Don't set payloadClass if framgment offset is not zero.
-            byte[] fragoff = hdrFieldsMap.get(FRAGOFFSET);
-            if (fragoff == null || BitBufferHelper.getShort(fragoff) == 0) {
-                payloadClass = protocolClassMap.get(readValue[0]);
-            }
-        } else if (headerField.equals(FRAGOFFSET)) {
-            if (readValue != null && BitBufferHelper.getShort(readValue) != 0) {
-                // Clear payloadClass because protocol header is not present
-                // in this packet.
-                payloadClass = null;
-            }
-        } else if (headerField.equals(OPTIONS) &&
-                   (readValue == null || readValue.length == 0)) {
-            hdrFieldsMap.remove(headerField);
-            return;
-        }
-        hdrFieldsMap.put(headerField, readValue);
-    }
-
-    /**
-     * Stores the IP version from the header
-     * @param version the version to set
-     * @return @IPv4
-     */
-    public IPv4 setVersion(byte ipVersion) {
-        byte[] version = BitBufferHelper.toByteArray(ipVersion);
-        fieldValues.put(VERSION, version);
-        return this;
-    }
-
-    /**
-     * Stores the length of IP header in words (4 bytes)
-     * @param headerLength the headerLength to set
-     * @return IPv4
-     */
-    public IPv4 setHeaderLength(byte ipheaderLength) {
-        byte[] headerLength = BitBufferHelper.toByteArray(ipheaderLength);
-        fieldValues.put(HEADERLENGTH, headerLength);
-        return this;
-    }
-
-    /**
-     * Stores the differential services value from the IP header
-     * @param diffServ the diffServ to set
-     * @return IPv4
-     */
-    public IPv4 setDiffServ(byte ipdiffServ) {
-        byte[] diffServ = BitBufferHelper.toByteArray(ipdiffServ);
-        fieldValues.put(DIFFSERV, diffServ);
-        return this;
-    }
-
-    /**
-     * Stores the ECN bits from the header
-     * @param ECN bits to set
-     * @return IPv4
-     */
-    public IPv4 setECN(byte ecn) {
-        byte[] ecnbytes = BitBufferHelper.toByteArray(ecn);
-        fieldValues.put(ECN, ecnbytes);
-        return this;
-    }
-
-    /**
-     * Stores the total length of IP header in bytes
-     * @param totalLength the totalLength to set
-     * @return IPv4
-     */
-    public IPv4 setTotalLength(short iptotalLength) {
-        byte[] totalLength = BitBufferHelper.toByteArray(iptotalLength);
-        fieldValues.put(TOTLENGTH, totalLength);
-        return this;
-    }
-
-    /**
-     * Stores the identification number from the header
-     * @param identification the identification to set
-     * @return IPv4
-     */
-    public IPv4 setIdentification(short ipIdentification) {
-        byte[] identification = BitBufferHelper.toByteArray(ipIdentification);
-        fieldValues.put(IDENTIFICATION, identification);
-        return this;
-    }
-
-    /**
-     * Stores the IP flags value
-     * @param flags the flags to set
-     * @return IPv4
-     */
-    public IPv4 setFlags(byte ipFlags) {
-        byte[] flags = { ipFlags };
-        fieldValues.put(FLAGS, flags);
-        return this;
-    }
-
-    /**
-     * Stores the IP fragmentation offset value
-     * @param fragmentOffset the fragmentOffset to set
-     * @return IPv4
-     */
-    public IPv4 setFragmentOffset(short ipFragmentOffset) {
-        byte[] fragmentOffset = BitBufferHelper.toByteArray(ipFragmentOffset);
-        fieldValues.put(FRAGOFFSET, fragmentOffset);
-        return this;
-    }
-
-    /**
-     * Stores the TTL value
-     * @param ttl the ttl to set
-     * @return IPv4
-     */
-    public IPv4 setTtl(byte ipTtl) {
-        byte[] ttl = BitBufferHelper.toByteArray(ipTtl);
-        fieldValues.put(TTL, ttl);
-        return this;
-    }
-
-    /**
-     * Stores the protocol value of the IP payload
-     * @param protocol the protocol to set
-     * @return IPv4
-     */
-    public IPv4 setProtocol(byte ipProtocol) {
-        byte[] protocol = BitBufferHelper.toByteArray(ipProtocol);
-        fieldValues.put(PROTOCOL, protocol);
-        return this;
-    }
-
-    /**
-     * @param checksum the checksum to set
-     */
-    /*public IPv4 setChecksum() {
-        short ipChecksum = computeChecksum();
-        byte[] checksum = BitBufferHelper.toByteArray(ipChecksum);
-        fieldValues.put(CHECKSUM, checksum);
-        return this;
-    }*/
-
-    /**
-     * Stores the IP source address from the header
-     * @param sourceAddress the sourceAddress to set
-     * @return IPv4
-     */
-    public IPv4 setSourceAddress(InetAddress ipSourceAddress) {
-        byte[] sourceAddress = ipSourceAddress.getAddress();
-        fieldValues.put(SIP, sourceAddress);
-        return this;
-    }
-
-    /**
-     * Stores the IP destination address from the header
-     * @param the destination Address to set
-     * @return IPv4
-     */
-    public IPv4 setDestinationAddress(InetAddress ipDestinationAddress) {
-        byte[] sourceAddress = ipDestinationAddress.getAddress();
-        fieldValues.put(DIP, sourceAddress);
-        return this;
-    }
-
-    /**
-     * Stores the IP destination address from the header
-     * @param destinationAddress the destinationAddress to set
-     * @return IPv4
-     */
-    public IPv4 setDestinationAddress(int ipDestinationAddress) {
-        byte[] destinationAddress = BitBufferHelper
-                .toByteArray(ipDestinationAddress);
-        fieldValues.put(DIP, destinationAddress);
-        return this;
-    }
-
-    /**
-     * Generate a random number to set the Identification field
-     * in IPv4 Header
-     * @return short
-     */
-    private short generateId() {
-        Random randomgen = new Random();
-        return (short) (randomgen.nextInt(Short.MAX_VALUE + 1));
-    }
-
-    /**
-     * Store the options from IP header
-     * @param options - byte[]
-     * @return IPv4
-     */
-    public IPv4 setOptions(byte[] options) {
-        byte newIHL = (byte)(MIN_HEADER_SIZE >>> UNIT_SIZE_SHIFT);
-        if (options == null || options.length == 0) {
-            fieldValues.remove(OPTIONS);
-        } else {
-            int len = options.length;
-            int rlen = (len + (UNIT_SIZE - 1)) & ~(UNIT_SIZE - 1);
-            if (rlen > len) {
-                // Padding is required.
-                byte[] newopt = new byte[rlen];
-                System.arraycopy(options, 0, newopt, 0, len);
-                options = newopt;
-                len = rlen;
-            }
-            fieldValues.put(OPTIONS, options);
-            newIHL += (len >>> UNIT_SIZE_SHIFT);
-        }
-
-        setHeaderLength(newIHL);
-
-        return this;
-    }
-
-    /**
-     * Computes the IPv4 header checksum on the passed stream of bytes
-     * representing the packet
-     *
-     * @param data
-     *            The byte stream
-     * @param offset
-     *            The byte offset from where the IPv4 packet starts
-     * @return The computed checksum
-     */
-    short computeChecksum(byte[] data, int start) {
-        int end = start + getHeaderLen();
-        short checkSum = (short) 0;
-        int sum = 0, carry = 0, finalSum = 0;
-        int wordData;
-        int checksumStart = start
-                + (getfieldOffset(CHECKSUM) / NetUtils.NumBitsInAByte);
-
-        for (int i = start; i <= (end - 1); i = i + 2) {
-            // Skip, if the current bytes are checkSum bytes
-            if (i == checksumStart) {
-                continue;
-            }
-            wordData = ((data[i] << 8) & 0xFF00) + (data[i + 1] & 0xFF);
-            sum = sum + wordData;
-        }
-        carry = (sum >> 16) & 0xFF;
-        finalSum = (sum & 0xFFFF) + carry;
-        checkSum = (short) ~((short) finalSum & 0xFFFF);
-
-        return checkSum;
-    }
-
-    @Override
-    /**
-     * Gets the number of bits for the fieldname specified
-     * If the fieldname has variable length like "Options", then this value is computed using the header length
-     * @param fieldname - String
-     * @return number of bits for fieldname - int
-     */
-    public int getfieldnumBits(String fieldName) {
-        if (fieldName.equals(OPTIONS)) {
-            return (getHeaderLen() - MIN_HEADER_SIZE) * NetUtils.NumBitsInAByte;
-        }
-        return hdrFieldCoordMap.get(fieldName).getRight();
-    }
-
-    @Override
-    /**
-     * Method to perform post serialization - like computation of checksum of serialized header
-     * @param data
-     * @return void
-     * @Exception throws PacketException
-     */
-    protected void postSerializeCustomOperation(byte[] data)
-            throws PacketException {
-
-        // Recompute the total length field here
-        byte[] totalLength = BitBufferHelper.toByteArray((short) data.length);
-        try {
-            BitBufferHelper.setBytes(data, totalLength, getfieldOffset(TOTLENGTH),
-                    getfieldnumBits(TOTLENGTH));
-        } catch (BufferException e) {
-            throw new PacketException(e.getMessage());
-        }
-
-        // Now compute the Header Checksum
-        byte[] checkSum = BitBufferHelper.toByteArray(computeChecksum(data, 0));
-
-        try {
-            BitBufferHelper.setBytes(data, checkSum, getfieldOffset(CHECKSUM),
-                    getfieldnumBits(CHECKSUM));
-        } catch (BufferException e) {
-            throw new PacketException(e.getMessage());
-        }
-    }
-
-    @Override
-    /**
-     * Stores the payload of IP, serializes it and stores the length of serialized payload
-     * bytes in Total Length
-     * @param payload - Packet
-     */
-    /**
-     * Set the total length field in the IPv4 Object
-     * Note: this field will get overwritten during serialization phase.
-     */
-    public void setPayload(Packet payload) {
-        this.payload = payload;
-        /*
-         * Deriving the Total Length here
-         */
-        int payloadLength = 0;
-        if (payload != null) {
-            try {
-                payloadLength = payload.serialize().length;
-            } catch (PacketException e) {
-                logger.error("", e);
-            }
-        }
-
-        this.setTotalLength((short) (this.getHeaderLen() + payloadLength));
-    }
-
-
-    /**
-     * Method to perform post deserialization - like compare computed checksum with
-     * the one obtained from IP header
-     */
-    @Override
-    protected void postDeserializeCustomOperation(byte[] data, int startBitOffset) {
-        int start = startBitOffset / NetUtils.NumBitsInAByte;
-        short computedChecksum = computeChecksum(data, start);
-        short actualChecksum = BitBufferHelper.getShort(fieldValues.get(CHECKSUM));
-        if (computedChecksum != actualChecksum) {
-            corrupted = true;
-        }
-    }
-
-    @Override
-    public void populateMatch(Match match) {
-        match.setField(MatchType.NW_SRC, NetUtils.getInetAddress(this.getSourceAddress()));
-        match.setField(MatchType.NW_DST, NetUtils.getInetAddress(this.getDestinationAddress()));
-        match.setField(MatchType.NW_PROTO, this.getProtocol());
-        match.setField(MatchType.NW_TOS, this.getDiffServ());
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/LLDP.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/LLDP.java
deleted file mode 100644 (file)
index 1f20e85..0000000
+++ /dev/null
@@ -1,262 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.packet;
-
-import java.util.ArrayList;
-import java.util.LinkedHashMap;
-import java.util.List;
-import java.util.Map;
-
-import org.opendaylight.controller.sal.utils.HexEncode;
-import org.opendaylight.controller.sal.utils.NetUtils;
-
-/**
- * Class that represents the LLDP frame objects
- */
-@Deprecated
-public class LLDP extends Packet {
-    private static final String CHASSISID = "ChassisId";
-    private static final String SYSTEMNAMEID = "SystemNameID";
-    private static final String PORTID = "PortId";
-    private static final String TTL = "TTL";
-    private static final int LLDPDefaultTlvs = 4;
-    private static LLDPTLV emptyTLV = new LLDPTLV().setLength((short) 0)
-            .setType((byte) 0);
-    public static final byte[] LLDPMulticastMac = { 1, (byte) 0x80,
-            (byte) 0xc2, 0, 0, (byte) 0xe };
-    private Map<Byte, LLDPTLV> tlvList;
-
-    /**
-     * Default constructor that creates the tlvList LinkedHashMap
-     */
-    public LLDP() {
-        super();
-        tlvList = new LinkedHashMap<Byte, LLDPTLV>(LLDPDefaultTlvs);
-    }
-
-    /**
-     * Constructor that creates the tlvList LinkedHashMap and sets the write
-     * access for the same
-     */
-    public LLDP(boolean writeAccess) {
-        super(writeAccess);
-        tlvList = new LinkedHashMap<Byte, LLDPTLV>(LLDPDefaultTlvs); // Mandatory
-                                                                     // TLVs
-    }
-
-    /**
-     * @param String
-     *            - description of the type of TLV
-     * @return byte - type of TLV
-     */
-    private byte getType(String typeDesc) {
-        if (typeDesc.equals(CHASSISID)) {
-            return LLDPTLV.TLVType.ChassisID.getValue();
-        } else if (typeDesc.equals(PORTID)) {
-            return LLDPTLV.TLVType.PortID.getValue();
-        } else if (typeDesc.equals(TTL)) {
-            return LLDPTLV.TLVType.TTL.getValue();
-        } else {
-            return LLDPTLV.TLVType.Unknown.getValue();
-        }
-    }
-
-    /**
-     * @param String
-     *            - description of the type of TLV
-     * @return LLDPTLV - full TLV
-     */
-    public LLDPTLV getTLV(String type) {
-        return tlvList.get(getType(type));
-    }
-
-    /**
-     * @param String
-     *            - description of the type of TLV
-     * @param LLDPTLV
-     *            - tlv to set
-     * @return void
-     */
-    public void setTLV(String type, LLDPTLV tlv) {
-        tlvList.put(getType(type), tlv);
-    }
-
-    /**
-     * @return the chassisId TLV
-     */
-    public LLDPTLV getChassisId() {
-        return getTLV(CHASSISID);
-    }
-
-    /**
-     * @param LLDPTLV
-     *            - the chassisId to set
-     */
-    public LLDP setChassisId(LLDPTLV chassisId) {
-        tlvList.put(getType(CHASSISID), chassisId);
-        return this;
-    }
-
-    /**
-     * @return the SystemName TLV
-     */
-    public LLDPTLV getSystemNameId() {
-        return getTLV(SYSTEMNAMEID);
-    }
-
-    /**
-     * @param LLDPTLV
-     *            - the chassisId to set
-     */
-    public LLDP setSystemNameId(LLDPTLV systemNameId) {
-        tlvList.put(getType(SYSTEMNAMEID), systemNameId);
-        return this;
-    }
-
-    /**
-     * @return LLDPTLV - the portId TLV
-     */
-    public LLDPTLV getPortId() {
-        return tlvList.get(getType(PORTID));
-    }
-
-    /**
-     * @param LLDPTLV
-     *            - the portId to set
-     * @return LLDP
-     */
-    public LLDP setPortId(LLDPTLV portId) {
-        tlvList.put(getType(PORTID), portId);
-        return this;
-    }
-
-    /**
-     * @return LLDPTLV - the ttl TLV
-     */
-    public LLDPTLV getTtl() {
-        return tlvList.get(getType(TTL));
-    }
-
-    /**
-     * @param LLDPTLV
-     *            - the ttl to set
-     * @return LLDP
-     */
-    public LLDP setTtl(LLDPTLV ttl) {
-        tlvList.put(getType(TTL), ttl);
-        return this;
-    }
-
-    /**
-     * @return the optionalTLVList
-     */
-    public List<LLDPTLV> getOptionalTLVList() {
-        List<LLDPTLV> list = new ArrayList<LLDPTLV>();
-        for (Map.Entry<Byte, LLDPTLV> entry : tlvList.entrySet()) {
-            byte type = entry.getKey();
-            if ((type == LLDPTLV.TLVType.ChassisID.getValue())
-                    || (type == LLDPTLV.TLVType.PortID.getValue())
-                    || (type == LLDPTLV.TLVType.TTL.getValue())) {
-                continue;
-            } else {
-                list.add(entry.getValue());
-            }
-        }
-        return list;
-    }
-
-    /**
-     * @param optionalTLVList
-     *            the optionalTLVList to set
-     * @return LLDP
-     */
-    public LLDP setOptionalTLVList(List<LLDPTLV> optionalTLVList) {
-        for (LLDPTLV tlv : optionalTLVList) {
-            tlvList.put(tlv.getType(), tlv);
-        }
-        return this;
-    }
-
-    @Override
-    public Packet deserialize(byte[] data, int bitOffset, int size)
-            throws PacketException {
-        int lldpOffset = bitOffset; // LLDP start
-        int lldpSize = size; // LLDP size
-
-        if (logger.isTraceEnabled()) {
-          logger.trace("LLDP: {} (offset {} bitsize {})", new Object[] {
-                  HexEncode.bytesToHexString(data), lldpOffset, lldpSize });
-        }
-        /*
-         * Deserialize the TLVs until we reach the end of the packet
-         */
-        while (lldpSize > 0) {
-            LLDPTLV tlv = new LLDPTLV();
-            tlv.deserialize(data, lldpOffset, lldpSize);
-            if (tlv.getType() == 0 && tlv.getLength() == 0) {
-               break;
-            }
-            int tlvSize = tlv.getTLVSize(); // Size of current TLV in bits
-            lldpOffset += tlvSize;
-            lldpSize -= tlvSize;
-            this.tlvList.put(tlv.getType(), tlv);
-        }
-        return this;
-    }
-
-    @Override
-    public byte[] serialize() throws PacketException {
-        int startOffset = 0;
-        byte[] serializedBytes = new byte[getLLDPPacketLength()];
-
-        for (Map.Entry<Byte, LLDPTLV> entry : tlvList.entrySet()) {
-            LLDPTLV tlv = entry.getValue();
-            int numBits = tlv.getTLVSize();
-            try {
-                BitBufferHelper.setBytes(serializedBytes, tlv.serialize(),
-                        startOffset, numBits);
-            } catch (BufferException e) {
-                throw new PacketException(e.getMessage());
-            }
-            startOffset += numBits;
-        }
-        // Now add the empty LLDPTLV at the end
-        try {
-            BitBufferHelper.setBytes(serializedBytes,
-                    LLDP.emptyTLV.serialize(), startOffset,
-                    LLDP.emptyTLV.getTLVSize());
-        } catch (BufferException e) {
-            throw new PacketException(e.getMessage());
-        }
-
-        if (logger.isTraceEnabled()) {
-          logger.trace("LLDP: serialized: {}",
-                  HexEncode.bytesToHexString(serializedBytes));
-        }
-        return serializedBytes;
-    }
-
-    /**
-     * Returns the size of LLDP packet in bytes
-     *
-     * @return int - LLDP Packet size in bytes
-     */
-    private int getLLDPPacketLength() {
-        int len = 0;
-        LLDPTLV tlv;
-
-        for (Map.Entry<Byte, LLDPTLV> entry : this.tlvList.entrySet()) {
-            tlv = entry.getValue();
-            len += tlv.getTLVSize();
-        }
-        len += LLDP.emptyTLV.getTLVSize();
-
-        return len / NetUtils.NumBitsInAByte;
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/LLDPTLV.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/LLDPTLV.java
deleted file mode 100644 (file)
index f03704c..0000000
+++ /dev/null
@@ -1,339 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.packet;
-
-import java.io.UnsupportedEncodingException;
-import java.nio.charset.Charset;
-import java.util.Arrays;
-import java.util.HashMap;
-import java.util.LinkedHashMap;
-import java.util.Map;
-
-import org.apache.commons.lang3.tuple.MutablePair;
-import org.apache.commons.lang3.tuple.Pair;
-import org.opendaylight.controller.sal.utils.HexEncode;
-import org.opendaylight.controller.sal.utils.NetUtils;
-
-/**
- * Class that represents the LLDPTLV objects
- */
-@Deprecated
-public class LLDPTLV extends Packet {
-    private static final String TYPE = "Type";
-    private static final String LENGTH = "Length";
-    private static final String VALUE = "Value";
-    private static final int LLDPTLVFields = 3;
-    public static final byte[] OFOUI = new byte[] { (byte) 0x00, (byte) 0x26,
-        (byte) 0xe1 }; // OpenFlow OUI
-    public static final byte[] customTlvSubType = new byte[] { 0 };
-    public static final int customTlvOffset = OFOUI.length
-            + customTlvSubType.length;
-    public static final byte chassisIDSubType[] = new byte[] { 4 }; // MAC address for the system
-    public static final byte portIDSubType[] = new byte[] { 7 }; // locally assigned
-
-    public enum TLVType {
-        Unknown((byte) 0), ChassisID((byte) 1), PortID((byte) 2), TTL((byte) 3), PortDesc(
-                (byte) 4), SystemName((byte) 5), SystemDesc((byte) 6), Custom(
-                        (byte) 127);
-
-        private byte value;
-
-        private TLVType(byte value) {
-            this.value = value;
-        }
-
-        public byte getValue() {
-            return value;
-        }
-    }
-
-    private static Map<String, Pair<Integer, Integer>> fieldCoordinates = new LinkedHashMap<String, Pair<Integer, Integer>>() {
-        private static final long serialVersionUID = 1L;
-
-        {
-            put(TYPE, new MutablePair<Integer, Integer>(0, 7));
-            put(LENGTH, new MutablePair<Integer, Integer>(7, 9));
-            put(VALUE, new MutablePair<Integer, Integer>(16, 0));
-        }
-    };
-
-    protected Map<String, byte[]> fieldValues;
-
-    /**
-     * Default constructor that creates and sets the hash map values and sets
-     * the payload to null
-     */
-    public LLDPTLV() {
-        payload = null;
-        fieldValues = new HashMap<String, byte[]>(LLDPTLVFields);
-        hdrFieldCoordMap = fieldCoordinates;
-        hdrFieldsMap = fieldValues;
-    }
-
-    /**
-     * Constructor that writes the passed LLDPTLV values to the hdrFieldsMap
-     */
-    public LLDPTLV(LLDPTLV other) {
-        for (Map.Entry<String, byte[]> entry : other.hdrFieldsMap.entrySet()) {
-            this.hdrFieldsMap.put(entry.getKey(), entry.getValue());
-        }
-    }
-
-    /**
-     * @return int - the length of TLV
-     */
-    public int getLength() {
-        return (int) BitBufferHelper.toNumber(fieldValues.get(LENGTH),
-                fieldCoordinates.get(LENGTH).getRight().intValue());
-    }
-
-    /**
-     * @return byte - the type of TLV
-     */
-    public byte getType() {
-        return BitBufferHelper.getByte(fieldValues.get(TYPE));
-    }
-
-    /**
-     * @return byte[] - the value field of TLV
-     */
-    public byte[] getValue() {
-        return fieldValues.get(VALUE);
-    }
-
-    /**
-     * @param byte - the type to set
-     * @return LLDPTLV
-     */
-    public LLDPTLV setType(byte type) {
-        byte[] lldpTLVtype = { type };
-        fieldValues.put(TYPE, lldpTLVtype);
-        return this;
-    }
-
-    /**
-     * @param short - the length to set
-     * @return LLDPTLV
-     */
-    public LLDPTLV setLength(short length) {
-        fieldValues.put(LENGTH, BitBufferHelper.toByteArray(length));
-        return this;
-    }
-
-    /**
-     * @param byte[] - the value to set
-     * @return LLDPTLV
-     */
-    public LLDPTLV setValue(byte[] value) {
-        fieldValues.put(VALUE, value);
-        return this;
-    }
-
-    @Override
-    public void setHeaderField(String headerField, byte[] readValue) {
-        hdrFieldsMap.put(headerField, readValue);
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = super.hashCode();
-        result = prime * result
-                + ((fieldValues == null) ? 0 : fieldValues.hashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (!super.equals(obj)) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        LLDPTLV other = (LLDPTLV) obj;
-        if (fieldValues == null) {
-            if (other.fieldValues != null) {
-                return false;
-            }
-        } else if (!fieldValues.equals(other.fieldValues)) {
-            return false;
-        }
-        return true;
-    }
-
-    @Override
-    public int getfieldnumBits(String fieldName) {
-        if (fieldName.equals(VALUE)) {
-            return (NetUtils.NumBitsInAByte * BitBufferHelper.getShort(
-                    fieldValues.get(LENGTH), fieldCoordinates.get(LENGTH)
-                    .getRight().intValue()));
-        }
-        return fieldCoordinates.get(fieldName).getRight();
-    }
-
-    /**
-     * Returns the size in bits of the whole TLV
-     *
-     * @return int - size in bits of full TLV
-     */
-    public int getTLVSize() {
-        return (LLDPTLV.fieldCoordinates.get(TYPE).getRight() + // static
-                LLDPTLV.fieldCoordinates.get(LENGTH).getRight() + // static
-                getfieldnumBits(VALUE)); // variable
-    }
-
-    /**
-     * Creates the SystemName TLV value
-     *
-     * @param nodeId
-     *            node identifier string
-     * @return the SystemName TLV value in byte array
-     */
-    static public byte[] createSystemNameTLVValue(String nodeId) {
-        byte[] nid = nodeId.getBytes();
-        return nid;
-    }
-
-    /**
-     * Creates the ChassisID TLV value including the subtype and ChassisID
-     * string
-     *
-     * @param nodeId
-     *            node identifier string
-     * @return the ChassisID TLV value in byte array
-     */
-    static public byte[] createChassisIDTLVValue(String nodeId) {
-        byte[] nid = HexEncode.bytesFromHexString(nodeId);
-        byte[] cid = new byte[6];
-        int srcPos = 0, dstPos = 0;
-
-        if (nid.length > cid.length) {
-            srcPos = nid.length - cid.length;
-        } else {
-            dstPos = cid.length - nid.length;
-        }
-        System.arraycopy(nid, srcPos, cid, dstPos, cid.length);
-
-        byte[] cidValue = new byte[cid.length + chassisIDSubType.length];
-
-        System.arraycopy(chassisIDSubType, 0, cidValue, 0,
-                chassisIDSubType.length);
-        System.arraycopy(cid, 0, cidValue, chassisIDSubType.length, cid.length);
-
-        return cidValue;
-    }
-
-    /**
-     * Creates the PortID TLV value including the subtype and PortID string
-     *
-     * @param portId
-     *            port identifier string
-     * @return the PortID TLV value in byte array
-     */
-    static public byte[] createPortIDTLVValue(String portId) {
-        byte[] pid = portId.getBytes(Charset.defaultCharset());
-        byte[] pidValue = new byte[pid.length + portIDSubType.length];
-
-        System.arraycopy(portIDSubType, 0, pidValue, 0, portIDSubType.length);
-        System.arraycopy(pid, 0, pidValue, portIDSubType.length, pid.length);
-
-        return pidValue;
-    }
-
-    /**
-     * Creates the custom TLV value including OUI, subtype and custom string
-     *
-     * @param portId
-     *            port identifier string
-     * @return the custom TLV value in byte array
-     */
-    static public byte[] createCustomTLVValue(String customString) {
-        byte[] customArray = customString.getBytes(Charset.defaultCharset());
-        byte[] customValue = new byte[customTlvOffset + customArray.length];
-
-        System.arraycopy(OFOUI, 0, customValue, 0, OFOUI.length);
-        System.arraycopy(customTlvSubType, 0, customValue, OFOUI.length,
-                customTlvSubType.length);
-        System.arraycopy(customArray, 0, customValue, customTlvOffset,
-                customArray.length);
-
-        return customValue;
-    }
-
-    /**
-     * Retrieves the string from TLV value and returns it in HexString format
-     *
-     * @param tlvValue
-     *            the TLV value
-     * @param tlvLen
-     *            the TLV length
-     * @return the HexString
-     */
-    static public String getHexStringValue(byte[] tlvValue, int tlvLen) {
-        byte[] cidBytes = new byte[tlvLen - chassisIDSubType.length];
-        System.arraycopy(tlvValue, chassisIDSubType.length, cidBytes, 0,
-                cidBytes.length);
-        return HexEncode.bytesToHexStringFormat(cidBytes);
-    }
-
-    /**
-     * Retrieves the string from TLV value
-     *
-     * @param tlvValue
-     *            the TLV value
-     * @param tlvLen
-     *            the TLV length
-     * @return the string
-     */
-    static public String getStringValue(byte[] tlvValue, int tlvLen) {
-        byte[] pidSubType = new byte[portIDSubType.length];
-        byte[] pidBytes = new byte[tlvLen - portIDSubType.length];
-        System.arraycopy(tlvValue, 0, pidSubType, 0,
-                pidSubType.length);
-        System.arraycopy(tlvValue, portIDSubType.length, pidBytes, 0,
-                pidBytes.length);
-        if (pidSubType[0] == (byte) 0x3) {
-            return HexEncode.bytesToHexStringFormat(pidBytes);
-        } else {
-            return (new String(pidBytes, Charset.defaultCharset()));
-        }
-    }
-
-    /**
-     * Retrieves the custom string from the Custom TLV value which includes OUI,
-     * subtype and custom string
-     *
-     * @param customTlvValue
-     *            the custom TLV value
-     * @param customTlvLen
-     *            the custom TLV length
-     * @return the custom string
-     */
-    static public String getCustomString(byte[] customTlvValue, int customTlvLen) {
-        String customString = "";
-        byte[] vendor = new byte[3];
-        System.arraycopy(customTlvValue, 0, vendor, 0, vendor.length);
-        if (Arrays.equals(vendor, LLDPTLV.OFOUI)) {
-            int customArrayLength = customTlvLen - customTlvOffset;
-            byte[] customArray = new byte[customArrayLength];
-            System.arraycopy(customTlvValue, customTlvOffset, customArray, 0,
-                    customArrayLength);
-            try {
-                customString = new String(customArray, "UTF-8");
-            } catch (UnsupportedEncodingException e) {
-            }
-        }
-
-        return customString;
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/LinkEncap.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/LinkEncap.java
deleted file mode 100644 (file)
index 3c75694..0000000
+++ /dev/null
@@ -1,25 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * @file   LinkEncap.java
- *
- * @brief  Enum some datalink packet format understood
- *
- * Enum some datalink packet format understood
- */
-package org.opendaylight.controller.sal.packet;
-
-/**
- * Describe a packet data link format
- */
-@Deprecated
-public enum LinkEncap {
-    ETHERNET
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/Packet.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/Packet.java
deleted file mode 100644 (file)
index 45e3142..0000000
+++ /dev/null
@@ -1,395 +0,0 @@
-/*
- * Copyright (c) 2013-2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.packet;
-
-import java.util.Arrays;
-import java.util.Map;
-import java.util.Map.Entry;
-
-import org.apache.commons.lang3.tuple.Pair;
-import org.opendaylight.controller.sal.match.Match;
-import org.opendaylight.controller.sal.utils.HexEncode;
-import org.opendaylight.controller.sal.utils.NetUtils;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * Abstract class which represents the generic network packet object It provides
- * the basic methods which are common for all the packets, like serialize and
- * deserialize
- */
-@Deprecated
-public abstract class Packet {
-    protected static final Logger logger = LoggerFactory
-            .getLogger(Packet.class);
-    // Access level granted to this packet
-    protected boolean writeAccess;
-    // When deserialized from wire, packet could result corrupted
-    protected boolean corrupted;
-    // The packet that encapsulate this packet
-    protected Packet parent;
-    // The packet encapsulated by this packet
-    protected Packet payload;
-    // The unparsed raw payload carried by this packet
-    protected byte[] rawPayload;
-    // Bit coordinates of packet header fields
-    protected Map<String, Pair<Integer, Integer>> hdrFieldCoordMap;
-    // Header fields values: Map<FieldName,Value>
-    protected Map<String, byte[]> hdrFieldsMap;
-    // The class of the encapsulated packet object
-    protected Class<? extends Packet> payloadClass;
-
-    public Packet() {
-        writeAccess = false;
-        corrupted = false;
-    }
-
-    public Packet(boolean writeAccess) {
-        this.writeAccess = writeAccess;
-        corrupted = false;
-    }
-
-    public Packet getParent() {
-        return parent;
-    }
-
-    public Packet getPayload() {
-        return payload;
-    }
-
-    public void setParent(Packet parent) {
-        this.parent = parent;
-    }
-
-    public void setPayload(Packet payload) {
-        this.payload = payload;
-    }
-
-    public void setHeaderField(String headerField, byte[] readValue) {
-        hdrFieldsMap.put(headerField, readValue);
-    }
-
-    /**
-     * This method deserializes the data bits obtained from the wire into the
-     * respective header and payload which are of type Packet
-     *
-     * @param byte[] data - data from wire to deserialize
-     * @param int bitOffset bit position where packet header starts in data
-     *        array
-     * @param int size of packet in bits
-     * @return Packet
-     * @throws PacketException
-     */
-    public Packet deserialize(byte[] data, int bitOffset, int size)
-            throws PacketException {
-
-        // Deserialize the header fields one by one
-        int startOffset = 0, numBits = 0;
-        for (Entry<String, Pair<Integer, Integer>> pairs : hdrFieldCoordMap
-                .entrySet()) {
-            String hdrField = pairs.getKey();
-            startOffset = bitOffset + this.getfieldOffset(hdrField);
-            numBits = this.getfieldnumBits(hdrField);
-
-            byte[] hdrFieldBytes = null;
-            try {
-                hdrFieldBytes = BitBufferHelper.getBits(data, startOffset,
-                        numBits);
-            } catch (BufferException e) {
-                throw new PacketException(e.getMessage());
-            }
-
-            /*
-             * Store the raw read value, checks the payload type and set the
-             * payloadClass accordingly
-             */
-            this.setHeaderField(hdrField, hdrFieldBytes);
-
-            if (logger.isTraceEnabled()) {
-                logger.trace("{}: {}: {} (offset {} bitsize {})",
-                        new Object[] { this.getClass().getSimpleName(), hdrField,
-                        HexEncode.bytesToHexString(hdrFieldBytes),
-                        startOffset, numBits });
-            }
-        }
-
-        // Deserialize the payload now
-        int payloadStart = startOffset + numBits;
-        int payloadSize = data.length * NetUtils.NumBitsInAByte - payloadStart;
-
-        if (payloadClass != null) {
-            try {
-                payload = payloadClass.newInstance();
-            } catch (Exception e) {
-                throw new RuntimeException(
-                        "Error parsing payload for Ethernet packet", e);
-            }
-            payload.deserialize(data, payloadStart, payloadSize);
-            payload.setParent(this);
-        } else {
-            /*
-             *  The payload class was not set, it means no class for parsing
-             *  this payload is present. Let's store the raw payload if any.
-             */
-            int start = payloadStart / NetUtils.NumBitsInAByte;
-            int stop = start + payloadSize / NetUtils.NumBitsInAByte;
-            rawPayload = Arrays.copyOfRange(data, start, stop);
-        }
-
-
-        // Take care of computation that can be done only after deserialization
-        postDeserializeCustomOperation(data, payloadStart - getHeaderSize());
-
-        return this;
-    }
-
-    /**
-     * This method serializes the header and payload from the respective
-     * packet class, into a single stream of bytes to be sent on the wire
-     *
-     * @return The byte array representing the serialized Packet
-     * @throws PacketException
-     */
-    public byte[] serialize() throws PacketException {
-
-        // Acquire or compute the serialized payload
-        byte[] payloadBytes = null;
-        if (payload != null) {
-            payloadBytes = payload.serialize();
-        } else if (rawPayload != null) {
-            payloadBytes = rawPayload;
-        }
-        int payloadSize = (payloadBytes == null) ? 0 : payloadBytes.length;
-
-        // Allocate the buffer to contain the full (header + payload) packet
-        int headerSize = this.getHeaderSize() / NetUtils.NumBitsInAByte;
-        byte packetBytes[] = new byte[headerSize + payloadSize];
-        if (payloadBytes != null) {
-            System.arraycopy(payloadBytes, 0, packetBytes, headerSize, payloadSize);
-        }
-
-        // Serialize this packet header, field by field
-        for (Map.Entry<String, Pair<Integer, Integer>> pairs : hdrFieldCoordMap
-                .entrySet()) {
-            String field = pairs.getKey();
-            byte[] fieldBytes = hdrFieldsMap.get(field);
-            // Let's skip optional fields when not set
-            if (fieldBytes != null) {
-                try {
-                    BitBufferHelper.setBytes(packetBytes, fieldBytes,
-                            getfieldOffset(field), getfieldnumBits(field));
-                } catch (BufferException e) {
-                    throw new PacketException(e.getMessage());
-                }
-            }
-        }
-
-        // Perform post serialize operations (like checksum computation)
-        postSerializeCustomOperation(packetBytes);
-
-        if (logger.isTraceEnabled()) {
-            logger.trace("{}: {}", this.getClass().getSimpleName(),
-                    HexEncode.bytesToHexString(packetBytes));
-        }
-
-        return packetBytes;
-    }
-
-    /**
-     * This method gets called at the end of the serialization process It is
-     * intended for the child packets to insert some custom data into the output
-     * byte stream which cannot be done or cannot be done efficiently during the
-     * normal Packet.serialize() path. An example is the checksum computation
-     * for IPv4
-     *
-     * @param byte[] - serialized bytes
-     * @throws PacketException
-     */
-    protected void postSerializeCustomOperation(byte[] myBytes)
-            throws PacketException {
-        // no op
-    }
-
-    /**
-     * This method re-computes the checksum of the bits received on the wire and
-     * validates it with the checksum in the bits received Since the computation
-     * of checksum varies based on the protocol, this method is overridden.
-     * Currently only IPv4 and ICMP do checksum computation and validation. TCP
-     * and UDP need to implement these if required.
-     *
-     * @param byte[] data The byte stream representing the Ethernet frame
-     * @param int startBitOffset The bit offset from where the byte array corresponding to this Packet starts in the frame
-     * @throws PacketException
-     */
-    protected void postDeserializeCustomOperation(byte[] data, int startBitOffset)
-            throws PacketException {
-        // no op
-    }
-
-    /**
-     * Gets the header length in bits
-     *
-     * @return int the header length in bits
-     */
-    public int getHeaderSize() {
-        int size = 0;
-        /*
-         * We need to iterate over the fields that were read in the frame
-         * (hdrFieldsMap) not all the possible ones described in
-         * hdrFieldCoordMap. For ex, 802.1Q may or may not be there
-         */
-        for (Map.Entry<String, byte[]> fieldEntry : hdrFieldsMap.entrySet()) {
-            if (fieldEntry.getValue() != null) {
-                String field = fieldEntry.getKey();
-                size += getfieldnumBits(field);
-            }
-        }
-        return size;
-    }
-
-    /**
-     * This method fetches the start bit offset for header field specified by
-     * 'fieldname'. The offset is present in the hdrFieldCoordMap of the
-     * respective packet class
-     *
-     * @param String
-     *            fieldName
-     * @return Integer - startOffset of the requested field
-     */
-    public int getfieldOffset(String fieldName) {
-        return hdrFieldCoordMap.get(fieldName).getLeft();
-    }
-
-    /**
-     * This method fetches the number of bits for header field specified by
-     * 'fieldname'. The numBits are present in the hdrFieldCoordMap of the
-     * respective packet class
-     *
-     * @param String
-     *            fieldName
-     * @return Integer - number of bits of the requested field
-     */
-    public int getfieldnumBits(String fieldName) {
-        return hdrFieldCoordMap.get(fieldName).getRight();
-    }
-
-    @Override
-    public String toString() {
-        StringBuilder ret = new StringBuilder();
-        ret.append(this.getClass().getSimpleName());
-        ret.append(": [");
-        for (String field : hdrFieldCoordMap.keySet()) {
-            byte[] value = hdrFieldsMap.get(field);
-            ret.append(field);
-            ret.append(": ");
-            ret.append(HexEncode.bytesToHexString(value));
-            ret.append(", ");
-        }
-        ret.replace(ret.length()-2, ret.length()-1, "]");
-        return ret.toString();
-    }
-
-    /**
-     * Returns the raw payload carried by this packet in case payload was not
-     * parsed. Caller can call this function in case the getPaylod() returns null.
-     *
-     * @return The raw payload if not parsable as an array of bytes, null otherwise
-     */
-    public byte[] getRawPayload() {
-        return rawPayload;
-    }
-
-    /**
-     * Set a raw payload in the packet class
-     *
-     * @param payload The raw payload as byte array
-     */
-    public void setRawPayload(byte[] payload) {
-        this.rawPayload = Arrays.copyOf(payload, payload.length);
-    }
-
-    /**
-     * Return whether the deserialized packet is to be considered corrupted.
-     * This is the case when the checksum computed after reconstructing the
-     * packet received from wire is not equal to the checksum read from the
-     * stream. For the Packet class which do not have a checksum field, this
-     * function will always return false.
-     *
-     *
-     * @return true if the deserialized packet's recomputed checksum is not
-     *         equal to the packet carried checksum
-     */
-    public boolean isCorrupted() {
-        return corrupted;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = super.hashCode();
-        result = prime * result
-                + ((this.hdrFieldsMap == null) ? 0 : hdrFieldsMap.hashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        Packet other = (Packet) obj;
-        if (hdrFieldsMap == other.hdrFieldsMap) {
-            return true;
-        }
-        if (hdrFieldsMap == null || other.hdrFieldsMap == null) {
-            return false;
-        }
-        if (hdrFieldsMap != null && other.hdrFieldsMap != null) {
-            for (String field : hdrFieldsMap.keySet()) {
-                if (!Arrays.equals(hdrFieldsMap.get(field), other.hdrFieldsMap.get(field))) {
-                    return false;
-                }
-            }
-        } else {
-            return false;
-        }
-        return true;
-    }
-
-    /**
-     * Adds to the passed Match this packet's header fields
-     *
-     * @param match
-     *            The Match object to populate
-     */
-    public void populateMatch(Match match) {
-        // To be overridden by derived packet classes which have well known
-        // header fields so that Packet.getMatch would return desired result
-    }
-
-    /**
-     * Returns the Match object containing this packet and its payload
-     * encapsulated packets' header fields
-     *
-     * @return The Match containing the header fields of this packet and of its
-     *         payload encapsulated packets
-     */
-    public Match getMatch() {
-        Match match = new Match();
-        Packet packet = this;
-        while (packet != null) {
-            packet.populateMatch(match);
-            packet = packet.getPayload();
-        }
-        return match;
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/PacketException.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/PacketException.java
deleted file mode 100644 (file)
index 14e1bbb..0000000
+++ /dev/null
@@ -1,23 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.sal.packet;
-
-/**
- * Describes an exception that is raised when the process of serializing or
- * deserializing a network packet/stream fails. This generally happens when the
- * packet/stream is malformed.
- *
- */
-@Deprecated
-public class PacketException extends Exception {
-    private static final long serialVersionUID = 1L;
-
-    public PacketException(String message) {
-        super(message);
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/PacketResult.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/PacketResult.java
deleted file mode 100644 (file)
index 3583bd1..0000000
+++ /dev/null
@@ -1,41 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * @file   PacketResult.java
- *
- * @brief  Possible results for Data packet processing handler
- */
-package org.opendaylight.controller.sal.packet;
-
-/**
- * Possible results for Data packet processing handler
- *
- */
-@Deprecated
-public enum PacketResult {
-    /**
-     * Packet has been processed and noone in the chain after us is
-     * supposed to see it
-     *
-     */
-    CONSUME,
-    /**
-     * Packet has been processed and still further processing is
-     * possible
-     *
-     */
-    KEEP_PROCESSING,
-    /**
-     * Packet has been ignored so further handler is present in
-     * the sequence need to still look at it.
-     *
-     */
-    IGNORED
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/RawPacket.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/RawPacket.java
deleted file mode 100644 (file)
index 2241774..0000000
+++ /dev/null
@@ -1,215 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * @file   RawPacket.java
- *
- * @brief  Describe a raw Data Packet, this is how a packet is
- * received from the network and how it will be transmitted. It
- * essentially wraps the raw bytestream
- *
- */
-package org.opendaylight.controller.sal.packet;
-
-import java.util.Map;
-import java.util.HashMap;
-
-import org.opendaylight.controller.sal.core.ConstructionException;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.TimeStamp;
-
-/**
- *
- * Describe a raw Data Packet, this is how a packet is received from the network
- * and how it will be transmitted. It essentially wraps the raw bytestream
- *
- */
-@Deprecated
-public class RawPacket {
-    private byte[] packetData;
-    private final LinkEncap encap;
-    private final TimeStamp incomingTime;
-    private final TimeStamp copyTime;
-    private Map<Object, Object> props;
-    private NodeConnector incomingNodeConnector;
-    private NodeConnector outgoingNodeConnector;
-
-    /**
-     * If the packet is being sent this parameter tells where the packet is sent
-     * toward
-     *
-     *
-     * @return the NodeConnector toward where the packet is being sent
-     */
-    public NodeConnector getOutgoingNodeConnector() {
-        return outgoingNodeConnector;
-    }
-
-    /**
-     * Setter method for OutGoing NodeConnector
-     *
-     * @param outgoingNodeConnector
-     *            NodeConnector toward where the packet is travelling
-     */
-    public void setOutgoingNodeConnector(NodeConnector outgoingNodeConnector) {
-        this.outgoingNodeConnector = outgoingNodeConnector;
-    }
-
-    /**
-     * Return the incoming NodeConnector if the packet was received
-     *
-     * @return NodeConnector where the packet was received from
-     */
-    public NodeConnector getIncomingNodeConnector() {
-        return incomingNodeConnector;
-    }
-
-    /**
-     * Setter for Incoming NodeConnector
-     *
-     * @param incomingNodeConnector
-     *            NodeConnector to be used and incoming one
-     */
-    public void setIncomingNodeConnector(NodeConnector incomingNodeConnector) {
-        this.incomingNodeConnector = incomingNodeConnector;
-    }
-
-    /**
-     * Retrieve a given property attached to the packet, if exits of course
-     *
-     * @param key
-     *            Key to retrieve the wanted property attached to the packet
-     *
-     * @return The property attached to the packet
-     */
-    public Object getProps(Object key) {
-        if (this.props != null) {
-            return this.props.get(key);
-        }
-        return null;
-    }
-
-    /**
-     * Generic data associated to the data packet
-     *
-     * @param key
-     *            key for the association
-     * @param value
-     *            value associated to the key
-     */
-    public void setProps(Object key, Object value) {
-        if (this.props == null) {
-            this.props = new HashMap<Object, Object>();
-        }
-
-        this.props.put(key, value);
-    }
-
-    /**
-     * Constructor for RawPacket
-     *
-     * @param data
-     *            content of the packet as bytestream
-     * @param e
-     *            datalink encapsulation for the packet
-     *
-     */
-    public RawPacket(byte[] data, LinkEncap e) throws ConstructionException {
-        if (data == null) {
-            throw new ConstructionException("Empty data");
-        }
-        if (e == null) {
-            throw new ConstructionException("Encap not known");
-        }
-        this.packetData = new byte[data.length];
-        System.arraycopy(data, 0, this.packetData, 0, data.length);
-        this.encap = e;
-        this.incomingTime = new TimeStamp(System.currentTimeMillis(),
-                "IncomingTime");
-        this.copyTime = null;
-    }
-
-    /**
-     * Copy Constructor for RawPacket, it performs a copy of the packet so each
-     * packet can be modified independently without worrying that source packet
-     * content is touched
-     *
-     * @param src
-     *            packet to copy data from
-     *
-     */
-    public RawPacket(RawPacket src) throws ConstructionException {
-        if (src == null) {
-            throw new ConstructionException("null source packet");
-        }
-        if (src.getPacketData() != null) {
-            this.packetData = new byte[src.getPacketData().length];
-            System.arraycopy(src.getPacketData(), 0, this.packetData, 0,
-                    src.getPacketData().length);
-        } else {
-            throw new ConstructionException("Empty packetData");
-        }
-        this.encap = src.getEncap();
-        this.incomingTime = src.getIncomingTime();
-        this.incomingNodeConnector = src.getIncomingNodeConnector();
-        this.outgoingNodeConnector = src.getOutgoingNodeConnector();
-        this.props = (src.props == null ? null : new HashMap<Object, Object>(
-                src.props));
-        this.copyTime = new TimeStamp(System.currentTimeMillis(), "CopyTime");
-    }
-
-    /**
-     * Constructor for RawPacket with Ethernet encapsulation
-     *
-     * @param data
-     *            content of the packet as bytestream
-     *
-     */
-    public RawPacket(byte[] data) throws ConstructionException {
-        this(data, LinkEncap.ETHERNET);
-    }
-
-    /**
-     * Read the time stamp when the packet has entered the system
-     *
-     * @return The time stamp when the packet has entered the system
-     */
-    public TimeStamp getIncomingTime() {
-        return this.incomingTime;
-    }
-
-    /**
-     * Read the packet encapsulation
-     *
-     * @return The encapsulation for the raw packet, necessary to start parsing
-     *         the packet
-     */
-    public LinkEncap getEncap() {
-        return this.encap;
-    }
-
-    /**
-     * Get bytestream of the packet body
-     *
-     * @return The raw bytestream composing the packet
-     */
-    public byte[] getPacketData() {
-        return this.packetData;
-    }
-
-    /**
-     * Returns the time at which the current instance of RawPacket was created
-     * as a copy of the original one.
-     *
-     * @return The time stamp at which this RawPacket instance was created. null
-     *         if this is the original instance.
-     */
-    public TimeStamp getCopyTime() {
-        return this.copyTime;
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/TCP.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/TCP.java
deleted file mode 100644 (file)
index 91cd93e..0000000
+++ /dev/null
@@ -1,249 +0,0 @@
-
-/*
- * Copyright (c) 2013-2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.packet;
-
-import java.util.HashMap;
-import java.util.LinkedHashMap;
-import java.util.Map;
-
-import org.apache.commons.lang3.tuple.ImmutablePair;
-import org.apache.commons.lang3.tuple.Pair;
-import org.opendaylight.controller.sal.match.Match;
-import org.opendaylight.controller.sal.match.MatchType;
-
-/**
- * Class that represents the TCP segment objects
- */
-@Deprecated
-public class TCP extends Packet {
-
-    public static final String SRCPORT = "SourcePort";
-    public static final String DESTPORT = "DestinationPort";
-    public static final String SEQNUMBER = "SequenceNumber";
-    public static final String ACKNUMBER = "AcknowledgementNumber";
-    public static final String DATAOFFSET = "DataOffset";
-    public static final String RESERVED = "Reserved";
-    public static final String HEADERLENFLAGS = "HeaderLenFlags";
-    public static final String WINDOWSIZE = "WindowSize";
-    public static final String CHECKSUM = "Checksum";
-    public static final String URGENTPOINTER = "UrgentPointer";
-
-    private static Map<String, Pair<Integer, Integer>> fieldCoordinates = new LinkedHashMap<String, Pair<Integer, Integer>>() {
-        private static final long serialVersionUID = 1L;
-        {
-            put(SRCPORT, new ImmutablePair<Integer, Integer>(0, 16));
-            put(DESTPORT, new ImmutablePair<Integer, Integer>(16, 16));
-            put(SEQNUMBER, new ImmutablePair<Integer, Integer>(32, 32));
-            put(ACKNUMBER, new ImmutablePair<Integer, Integer>(64, 32));
-            put(DATAOFFSET, new ImmutablePair<Integer, Integer>(96, 4));
-            put(RESERVED, new ImmutablePair<Integer, Integer>(100, 3));
-            put(HEADERLENFLAGS, new ImmutablePair<Integer, Integer>(103, 9));
-            put(WINDOWSIZE, new ImmutablePair<Integer, Integer>(112, 16));
-            put(CHECKSUM, new ImmutablePair<Integer, Integer>(128, 16));
-            put(URGENTPOINTER, new ImmutablePair<Integer, Integer>(144, 16));
-        }
-    };
-
-    private final Map<String, byte[]> fieldValues;
-
-    /**
-     * Default constructor that sets all the header fields to zero
-     */
-    public TCP() {
-        super();
-        fieldValues = new HashMap<String, byte[]>();
-        hdrFieldCoordMap = fieldCoordinates;
-        hdrFieldsMap = fieldValues;
-        /* Setting all remaining header field values to
-         * default value of 0.  These maybe changed as needed
-         */
-        setSourcePort((short) 0);
-        setDestinationPort((short) 0);
-        setSequenceNumber(0);
-        setAckNumber(0);
-        setDataOffset((byte) 0);
-        setReserved((byte) 0);
-        setWindowSize((short) 0);
-        setUrgentPointer((short) 0);
-        setChecksum((short) 0);
-    }
-
-    /**
-     * Constructor that sets the access level for the packet and
-     * sets all the header fields to zero.
-     */
-    public TCP(boolean writeAccess) {
-        super(writeAccess);
-        fieldValues = new HashMap<String, byte[]>();
-        hdrFieldCoordMap = fieldCoordinates;
-        hdrFieldsMap = fieldValues;
-        /* Setting all remaining header field values to
-         * default value of 0.  These maybe changed as needed
-         */
-        setSourcePort((short) 0);
-        setDestinationPort((short) 0);
-        setSequenceNumber(0);
-        setAckNumber(0);
-        setDataOffset((byte) 0);
-        setReserved((byte) 0);
-        setWindowSize((short) 0);
-        setUrgentPointer((short) 0);
-        setChecksum((short) 0);
-    }
-
-    @Override
-    /**
-     * Stores the value read from data stream
-     */
-    public void setHeaderField(String headerField, byte[] readValue) {
-        hdrFieldsMap.put(headerField, readValue);
-    }
-
-    /**
-     * Sets the TCP source port for the current TCP object instance
-     * @param short tcpSourcePort
-     * @return TCP
-     */
-    public TCP setSourcePort(short tcpSourcePort) {
-        byte[] sourcePort = BitBufferHelper.toByteArray(tcpSourcePort);
-        fieldValues.put(SRCPORT, sourcePort);
-        return this;
-    }
-
-    /**
-     * Sets the TCP destination port for the current TCP object instance
-     * @param short tcpDestinationPort
-     * @return TCP
-     */
-    public TCP setDestinationPort(short tcpDestinationPort) {
-        byte[] destinationPort = BitBufferHelper
-                .toByteArray(tcpDestinationPort);
-        fieldValues.put(DESTPORT, destinationPort);
-        return this;
-    }
-
-    /**
-     * Sets the TCP sequence number for the current TCP object instance
-     * @param int tcpSequenceNumber
-     * @return TCP
-     */
-    public TCP setSequenceNumber(int tcpSequenceNumber) {
-        byte[] sequenceNumber = BitBufferHelper.toByteArray(tcpSequenceNumber);
-        fieldValues.put(SEQNUMBER, sequenceNumber);
-        return this;
-    }
-
-    /**
-     * Sets the TCP data offset for the current TCP object instance
-     * @param byte tcpDataOffset
-     * @return TCP
-     */
-    public TCP setDataOffset(byte tcpDataOffset) {
-        byte[] offset = BitBufferHelper.toByteArray(tcpDataOffset);
-        fieldValues.put("DataOffset", offset);
-        return this;
-    }
-
-    /**
-     * Sets the TCP reserved bits for the current TCP object instance
-     * @param byte tcpReserved
-     * @return TCP
-     */
-    public TCP setReserved(byte tcpReserved) {
-        byte[] reserved = BitBufferHelper.toByteArray(tcpReserved);
-        fieldValues.put("Reserved", reserved);
-        return this;
-    }
-
-    /**
-     * Sets the TCP Ack number for the current TCP object instance
-     * @param int tcpAckNumber
-     * @return TCP
-     */
-    public TCP setAckNumber(int tcpAckNumber) {
-        byte[] ackNumber = BitBufferHelper.toByteArray(tcpAckNumber);
-        fieldValues.put(ACKNUMBER, ackNumber);
-        return this;
-    }
-
-    /**
-     * Sets the TCP flags for the current TCP object instance
-     * @param short tcpFlags
-     * @return TCP
-     */
-    public TCP setHeaderLenFlags(short tcpFlags) {
-        byte[] headerLenFlags = BitBufferHelper.toByteArray(tcpFlags);
-        fieldValues.put(HEADERLENFLAGS, headerLenFlags);
-        return this;
-    }
-
-    /**
-     * Sets the TCP window size for the current TCP object instance
-     * @param short tcpWsize
-     * @return TCP
-     */
-    public TCP setWindowSize(short tcpWsize) {
-        byte[] wsize = BitBufferHelper.toByteArray(tcpWsize);
-        fieldValues.put(WINDOWSIZE, wsize);
-        return this;
-    }
-
-    /**
-     * Sets the TCP checksum for the current TCP object instance
-     * @param short tcpChecksum
-     * @return TCP
-     */
-    public TCP setChecksum(short tcpChecksum) {
-        byte[] checksum = BitBufferHelper.toByteArray(tcpChecksum);
-        fieldValues.put(CHECKSUM, checksum);
-        return this;
-    }
-
-    /**
-     * Sets the TCP Urgent Pointer for the current TCP object instance
-     * @param short tcpUrgentPointer
-     * @return TCP
-     */
-    public TCP setUrgentPointer(short tcpUrgentPointer) {
-        byte[] urgentPointer = BitBufferHelper.toByteArray(tcpUrgentPointer);
-        fieldValues.put(URGENTPOINTER, urgentPointer);
-        return this;
-    }
-
-    /**
-     * Gets the stored source port value of TCP header
-     * @return the sourcePort
-     */
-    public short getSourcePort() {
-        return (BitBufferHelper.getShort(fieldValues.get(SRCPORT)));
-    }
-
-    /**
-     * Gets the stored destination port value of TCP header
-     * @return the destinationPort
-     */
-    public short getDestinationPort() {
-        return (BitBufferHelper.getShort(fieldValues.get(DESTPORT)));
-    }
-
-    /**
-     * Get the stored checksum value of the TCP header
-     * @return short - the checksum
-     */
-    public short getChecksum() {
-        return (BitBufferHelper.getShort(fieldValues.get(CHECKSUM)));
-    }
-
-    @Override
-    public void populateMatch(Match match) {
-        match.setField(MatchType.TP_SRC, this.getSourcePort());
-        match.setField(MatchType.TP_DST, this.getDestinationPort());
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/UDP.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/UDP.java
deleted file mode 100644 (file)
index 4c7e0ff..0000000
+++ /dev/null
@@ -1,167 +0,0 @@
-
-/*
- * Copyright (c) 2013-2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.packet;
-
-import java.util.HashMap;
-import java.util.LinkedHashMap;
-import java.util.Map;
-
-import org.apache.commons.lang3.tuple.ImmutablePair;
-import org.apache.commons.lang3.tuple.Pair;
-import org.opendaylight.controller.sal.match.Match;
-import org.opendaylight.controller.sal.match.MatchType;
-
-/**
- * Class that represents the UDP datagram objects
- */
-@Deprecated
-public class UDP extends Packet {
-
-    private static final String SRCPORT = "SourcePort";
-    private static final String DESTPORT = "DestinationPort";
-    private static final String LENGTH = "Length";
-    private static final String CHECKSUM = "Checksum";
-
-    private static Map<String, Pair<Integer, Integer>> fieldCoordinates = new LinkedHashMap<String, Pair<Integer, Integer>>() {
-        private static final long serialVersionUID = 1L;
-        {
-            put(SRCPORT, new ImmutablePair<Integer, Integer>(0, 16));
-            put(DESTPORT, new ImmutablePair<Integer, Integer>(16, 16));
-            put(LENGTH, new ImmutablePair<Integer, Integer>(32, 16));
-            put(CHECKSUM, new ImmutablePair<Integer, Integer>(48, 16));
-        }
-    };
-
-    public UDP() {
-        super();
-        fieldValues = new HashMap<String, byte[]>();
-        hdrFieldCoordMap = fieldCoordinates;
-        hdrFieldsMap = fieldValues;
-        /* Setting all remaining header field values to
-         * default value of 0.  These maybe changed as needed
-         */
-        setSourcePort((short) 0);
-        setDestinationPort((short) 0);
-        setChecksum((short) 0);
-    }
-
-    public UDP(boolean writeAccess) {
-        super(writeAccess);
-        fieldValues = new HashMap<String, byte[]>();
-        hdrFieldCoordMap = fieldCoordinates;
-        hdrFieldsMap = fieldValues;
-        /* Setting all remaining header field values to
-         * default value of 0.  These maybe changed as needed
-         */
-        setSourcePort((short) 0);
-        setDestinationPort((short) 0);
-        setChecksum((short) 0);
-    }
-
-    private final Map<String, byte[]> fieldValues;
-
-    /* public static Map<Short, Class<? extends Packet>> decodeMap;
-
-      static {
-          decodeMap = new HashMap<Short, Class<? extends Packet>>();
-          UDP.decodeMap.put((short)67, DHCP.class);
-          UDP.decodeMap.put((short)68, DHCP.class);
-      }*/
-    /**
-     * Get the stored source port
-     * @return short - the sourcePort
-     */
-    public short getSourcePort() {
-        return (BitBufferHelper.getShort(fieldValues.get(SRCPORT)));
-    }
-
-    /**
-     * Get the stored destination port
-     * @return short - the destinationPort
-     */
-    public short getDestinationPort() {
-        return (BitBufferHelper.getShort(fieldValues.get(DESTPORT)));
-    }
-
-    /**
-     * Gets the stored length of UDP header
-     * @return short - the length
-     */
-    public short getLength() {
-        return (BitBufferHelper.getShort(fieldValues.get(LENGTH)));
-    }
-
-    /**
-     * Get the stored checksum value of the UDP header
-     * @return short - the checksum
-     */
-    public short getChecksum() {
-        return (BitBufferHelper.getShort(fieldValues.get(CHECKSUM)));
-    }
-
-    @Override
-    /**
-     * Store the value read from data stream in hdrFieldMap
-     */
-    public void setHeaderField(String headerField, byte[] readValue) {
-        hdrFieldsMap.put(headerField, readValue);
-    }
-
-    /**
-     * Sets the sourcePort value for the current UDP object instance
-     * @param short - the sourcePort to set
-     * @return UDP
-     */
-    public UDP setSourcePort(short udpSourcePort) {
-        byte[] sourcePort = BitBufferHelper.toByteArray(udpSourcePort);
-        fieldValues.put(SRCPORT, sourcePort);
-        return this;
-    }
-
-    /**
-     * Sets the destinationPort value for the current UDP object instance
-     * @param short - the destinationPort to set
-     * @return UDP
-     */
-    public UDP setDestinationPort(short udpDestinationPort) {
-        byte[] destinationPort = BitBufferHelper
-                .toByteArray(udpDestinationPort);
-        fieldValues.put(DESTPORT, destinationPort);
-        return this;
-    }
-
-    /**
-     * Set the UDP header length value for the current UDP object instance
-     * @param short - the length to set
-     * @return UDP
-     */
-    public UDP setLength(short udpLength) {
-        byte[] length = BitBufferHelper.toByteArray(udpLength);
-        fieldValues.put(LENGTH, length);
-        return this;
-    }
-
-    /**
-     * Set the checksum for the current UDP object instance
-     * @param short - the checksum to set
-     * @return UDP
-     */
-    public UDP setChecksum(short udpChecksum) {
-        byte[] checksum = BitBufferHelper.toByteArray(udpChecksum);
-        fieldValues.put(CHECKSUM, checksum);
-        return this;
-    }
-
-    @Override
-    public void populateMatch(Match match) {
-        match.setField(MatchType.TP_SRC, this.getSourcePort());
-        match.setField(MatchType.TP_DST, this.getDestinationPort());
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/address/DataLinkAddress.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/address/DataLinkAddress.java
deleted file mode 100644 (file)
index 3e75993..0000000
+++ /dev/null
@@ -1,97 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.packet.address;
-
-import java.io.Serializable;
-
-import javax.xml.bind.annotation.XmlRootElement;
-
-/**
- * @file   DataLinkAddress.java
- *
- * @brief  Abstract base class for a Datalink Address
- *
- */
-
-/**
- * Abstract base class for a Datalink Address
- *
- */
-@XmlRootElement
-@Deprecated
-abstract public class DataLinkAddress implements Serializable {
-    private static final long serialVersionUID = 1L;
-    private String name;
-
-    public DataLinkAddress() {
-
-    }
-
-    /**
-     * Constructor of super class
-     *
-     * @param name Create a new DataLink, not for general use but
-     * available only for sub classes
-     *
-     * @return constructed object
-     */
-    protected DataLinkAddress(String name) {
-        this.name = name;
-    }
-
-    /**
-     * Used to copy the DataLinkAddress in a polymorphic way
-     *
-     *
-     * @return A clone of this DataLinkAddress
-     */
-    @Override
-    abstract public DataLinkAddress clone();
-
-    /**
-     * Allow to distinguish among different data link addresses
-     *
-     *
-     * @return Name of the DataLinkAdress we are working on
-     */
-    public String getName() {
-        return this.name;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + ((name == null) ? 0 : name.hashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj)
-            return true;
-        if (obj == null)
-            return false;
-        if (getClass() != obj.getClass())
-            return false;
-        DataLinkAddress other = (DataLinkAddress) obj;
-        if (name == null) {
-            if (other.name != null)
-                return false;
-        } else if (!name.equals(other.name))
-            return false;
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        return "DataLinkAddress [name=" + name + "]";
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/address/EthernetAddress.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/packet/address/EthernetAddress.java
deleted file mode 100644 (file)
index 731a731..0000000
+++ /dev/null
@@ -1,128 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.packet.address;
-
-import java.util.Arrays;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-import javax.xml.bind.annotation.XmlTransient;
-
-import org.opendaylight.controller.sal.core.ConstructionException;
-import org.opendaylight.controller.sal.utils.HexEncode;
-
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class EthernetAddress extends DataLinkAddress {
-    private static final long serialVersionUID = 1L;
-    @XmlTransient
-    private byte[] macAddress;
-
-    public static final EthernetAddress BROADCASTMAC = createWellKnownAddress(new byte[] {
-            (byte) 0xff, (byte) 0xff, (byte) 0xff, (byte) 0xff, (byte) 0xff,
-            (byte) 0xff });
-
-    public static final EthernetAddress INVALIDHOST = BROADCASTMAC;
-
-    public static final String addressName = "Ethernet MAC Address";
-    public static final int SIZE = 6;
-
-    private static final EthernetAddress createWellKnownAddress(byte[] mac) {
-        try {
-            return new EthernetAddress(mac);
-        } catch (ConstructionException ce) {
-            return null;
-        }
-    }
-
-    /* Private constructor to satisfy JAXB */
-    @SuppressWarnings("unused")
-    private EthernetAddress() {
-    }
-
-    /**
-     * Public constructor for an Ethernet MAC address starting from
-     * the byte constituing the address, the constructor validate the
-     * size of the arrive to make sure it met the expected size
-     *
-     * @param macAddress A byte array in big endian format
-     * representing the Ethernet MAC Address
-     *
-     * @return The constructed object if valid
-     */
-    public EthernetAddress(byte[] macAddress) throws ConstructionException {
-        super(addressName);
-
-        if (macAddress == null) {
-            throw new ConstructionException("Null input parameter passed");
-        }
-
-        if (macAddress.length != SIZE) {
-            throw new ConstructionException(
-                    "Wrong size of passed byte array, expected:" + SIZE
-                            + " got:" + macAddress.length);
-        }
-        this.macAddress = new byte[SIZE];
-        System.arraycopy(macAddress, 0, this.macAddress, 0, SIZE);
-    }
-
-    public EthernetAddress clone() {
-        try {
-            return new EthernetAddress(this.macAddress.clone());
-        } catch (ConstructionException ce) {
-            return null;
-        }
-    }
-
-    /**
-     * Return the Ethernet Mac address in byte array format
-     *
-     * @return The Ethernet Mac address in byte array format
-     */
-    public byte[] getValue() {
-        return this.macAddress;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = super.hashCode();
-        result = prime * result + Arrays.hashCode(macAddress);
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj)
-            return true;
-        if (!super.equals(obj))
-            return false;
-        if (getClass() != obj.getClass())
-            return false;
-        EthernetAddress other = (EthernetAddress) obj;
-        if (!Arrays.equals(macAddress, other.macAddress))
-            return false;
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        return "EthernetAddress [macAddress=" + HexEncode.bytesToHexStringFormat(macAddress)
-                + "]";
-    }
-
-    @XmlElement(name = "macAddress")
-    public String getMacAddress() {
-        return HexEncode.bytesToHexStringFormat(macAddress);
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/reader/FlowOnNode.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/reader/FlowOnNode.java
deleted file mode 100644 (file)
index bcd404e..0000000
+++ /dev/null
@@ -1,175 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.reader;
-
-import java.io.Serializable;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.sal.flowprogrammer.Flow;
-
-/**
- * Represents the flow that is installed on the network node
- * along with the table location, hit counters and timers
- */
-
-@XmlRootElement (name="FlowStat")
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class FlowOnNode implements Serializable{
-    private static final long serialVersionUID = 1L;
-
-    @XmlElement
-    private Flow flow; // Flow descriptor
-    @XmlElement
-    private byte tableId;
-    @XmlElement
-    private int durationSeconds;
-    @XmlElement
-    private int durationNanoseconds;
-    @XmlElement
-    private long packetCount;
-    @XmlElement
-    private long byteCount;
-
-    /* Dummy constructor for JAXB */
-    @SuppressWarnings("unused")
-    private FlowOnNode () {
-    }
-
-    public FlowOnNode(Flow flow) {
-        this.flow = flow;
-    }
-
-    /**
-     * Returns the description of the flow which statistics are about
-     * @return
-     */
-    public Flow getFlow() {
-        return flow;
-    }
-
-    /**
-     * Set the packet count's value
-     * @param count
-     */
-    public void setPacketCount(long count) {
-        packetCount = count;
-    }
-
-    /**
-     * Set the byte count's value
-     * @param count
-     */
-    public void setByteCount(long count) {
-        byteCount = count;
-    }
-
-    /**
-     * Returns the packet count for the flow
-     * @return
-     */
-    public long getPacketCount() {
-        return packetCount;
-    }
-
-    /**
-     * Return the byte count for the flow
-     * @return
-     */
-    public long getByteCount() {
-        return byteCount;
-    }
-
-    public byte getTableId() {
-        return tableId;
-    }
-
-    public void setTableId(byte tableId) {
-        this.tableId = tableId;
-    }
-
-    public int getDurationSeconds() {
-        return durationSeconds;
-    }
-
-    public void setDurationSeconds(int durationSeconds) {
-        this.durationSeconds = durationSeconds;
-    }
-
-    public int getDurationNanoseconds() {
-        return durationNanoseconds;
-    }
-
-    public void setDurationNanoseconds(int durationNanoseconds) {
-        this.durationNanoseconds = durationNanoseconds;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + (int) (byteCount ^ (byteCount >>> 32));
-        result = prime * result + durationNanoseconds;
-        result = prime * result + durationSeconds;
-        result = prime * result + ((flow == null) ? 0 : flow.hashCode());
-        result = prime * result + (int) (packetCount ^ (packetCount >>> 32));
-        result = prime * result + tableId;
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (!(obj instanceof FlowOnNode)) {
-            return false;
-        }
-        FlowOnNode other = (FlowOnNode) obj;
-        if (byteCount != other.byteCount) {
-            return false;
-        }
-        if (durationNanoseconds != other.durationNanoseconds) {
-            return false;
-        }
-        if (durationSeconds != other.durationSeconds) {
-            return false;
-        }
-        if (flow == null) {
-            if (other.flow != null) {
-                return false;
-            }
-        } else if (!flow.equals(other.flow)) {
-            return false;
-        }
-        if (packetCount != other.packetCount) {
-            return false;
-        }
-        if (tableId != other.tableId) {
-            return false;
-        }
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        return "FlowOnNode[flow =" + flow + ", tableId = " + tableId
-                + ", sec = " + durationSeconds + ", nsec = "
-                + durationNanoseconds + ", pkt = " + packetCount + ", byte = "
-                + byteCount + "]";
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/reader/IPluginInReadService.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/reader/IPluginInReadService.java
deleted file mode 100644 (file)
index edaee5f..0000000
+++ /dev/null
@@ -1,138 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.reader;
-
-import java.util.List;
-
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.NodeTable;
-import org.opendaylight.controller.sal.flowprogrammer.Flow;
-
-/**
- * The interface defines hardware view read methods to be implemented by protocol plugins
- */
-@Deprecated
-public interface IPluginInReadService {
-
-    /**
-     * Returns the hardware image for the specified flow on the specified
-     * network node
-     *
-     * @param node
-     *            the network node
-     * @param flow
-     *            the target flow
-     * @param cached
-     *            specify if entry has to be queried from the cached hardware
-     *            information maintained locally or directly from the network
-     *            node.
-     * @return The FlowOnNode object containing the information present in
-     *         hardware for the passed flow on the specified network node
-     */
-    public FlowOnNode readFlow(Node node, Flow flow, boolean cached);
-
-    /**
-     * Returns the hardware view of all the flow installed on the specified
-     * network node
-     *
-     * @param node
-     *            the network node
-     * @param cached
-     *            specify if entries have to be queried from the cached hardware
-     *            information maintained locally or directly from the network
-     *            node.
-     * @return The list of FlowOnNode objects containing the information present
-     *         in hardware on the specified network node for all its flows
-     */
-    public List<FlowOnNode> readAllFlow(Node node, boolean cached);
-
-    /**
-     * Returns the description of the network node as provided by the node
-     * itself
-     *
-     * @param node
-     *            the network node
-     * @param cached
-     *            specify if entry has to be queried from the cached hardware
-     *            information maintained locally or directly from the network
-     *            node.
-     * @return The NodeDescription object containing the description information
-     *         for the specified network node
-     */
-    public NodeDescription readDescription(Node node, boolean cached);
-
-    /**
-     * Returns the hardware view of the specified network node connector
-     *
-     * @param connector
-     *            the target nodeConnector
-     * @param cached
-     *            specify if entry has to be queried from the cached hardware
-     *            information maintained locally or directly from the
-     *            corresponding network node.
-     * @return The NodeConnectorStatistics object containing the statistics
-     *         present in hardware for the corresponding network node port
-     */
-    public NodeConnectorStatistics readNodeConnector(NodeConnector connector,
-            boolean cached);
-
-    /**
-     * Returns the hardware info for all the node connectors on the specified
-     * network node
-     *
-     * @param node
-     *            the target node
-     * @param cached
-     *            specify if entries have to be queried from the cached hardware
-     *            information maintained locally or directly from the
-     *            corresponding network node.
-     * @return The list of NodeConnectorStatistics objects containing the
-     *         statistics present in hardware for all the network node ports
-     */
-    public List<NodeConnectorStatistics> readAllNodeConnector(Node node,
-            boolean cached);
-
-    /**
-     * Returns the table statistics for the node
-     * @param table
-     *            the target network node table
-     * @param cached
-     *            specify if entry has to be queried from the cached hardware
-     *            information maintained locally or directly from
-     *            the corresponding network node.
-     * @return The NodeTableStatistics object containing the statistics present
-     *         in hardware for the corresponding network node table
-     */
-    public NodeTableStatistics readNodeTable(NodeTable table, boolean cached);
-
-    /**
-     * Returns all the table statistics for the node
-     *
-     * @param node
-     *            the target node
-     * @param cached
-     *            specify if entries have to be queried from the cached hardware
-     *            information maintained locally or directly from the
-     *            corresponding network node.
-     * @return The list of NodeTableStatistics objects containing the statistics
-     *         present in hardware for all the network node tables
-     */
-    public List<NodeTableStatistics> readAllNodeTable(Node node, boolean cached);
-
-    /**
-     * Returns the averaged transmit rate for the specified node connector
-     * @param connector
-     *            the target nodeConnector
-     * @return tx rate [bps]
-     */
-    public long getTransmitRate(NodeConnector connector);
-
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/reader/IPluginOutReadService.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/reader/IPluginOutReadService.java
deleted file mode 100644 (file)
index e5baa40..0000000
+++ /dev/null
@@ -1,75 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.reader;
-
-import java.util.List;
-
-import org.opendaylight.controller.sal.core.Node;
-
-/**
- * The interface defines hardware statistics updates service to be offered by
- * protocol plugins
- */
-@Deprecated
-public interface IPluginOutReadService {
-
-    /**
-     * Notifies the hardware view of all the flow installed on the specified
-     * network node
-     *
-     * @param node
-     *            the network node
-     *            {@link org.opendaylight.controller.sal.core.Node}
-     * @param flowStatsList
-     *            the hardware view of all the flow
-     *            {@link org.opendaylight.controller.sal.reader.FlowOnNode}
-     *            installed on the specified network node
-     */
-    public void nodeFlowStatisticsUpdated(Node node, List<FlowOnNode> flowStatsList);
-
-    /**
-     * Notifies the hardware view of the specified network node
-     *
-     * @param node
-     *            the network node
-     *            {@link org.opendaylight.controller.sal.core.Node}
-     * @param ncStatsList
-     *            the statistics
-     *            {@link org.opendaylight.controller.sal.reader.NodeConnectorStatistics}
-     *            for all node connectors in a given node
-     */
-    public void nodeConnectorStatisticsUpdated(Node node, List<NodeConnectorStatistics> ncStatsList);
-
-    /**
-     * Notifies all the table statistics for a node
-     *
-     * @param node
-     *            the network node
-     *            {@link org.opendaylight.controller.sal.core.Node}
-     * @param tableStatsList
-     *            the statistics
-     *            {@link org.opendaylight.controller.sal.reader.NodeTableStatistics}
-     *            for all the tables in a given node
-     */
-    public void nodeTableStatisticsUpdated(Node node, List<NodeTableStatistics> tableStatsList);
-
-    /**
-     * Notifies the hardware view of node description changes
-     *
-     * @param node
-     *            the network node
-     *            {@link org.opendaylight.controller.sal.core.Node}
-     * @param nodeDescription
-     *            the node description
-     *            {@link org.opendaylight.controller.sal.reader.NodeDescription}
-     */
-    public void descriptionStatisticsUpdated(Node node, NodeDescription nodeDescription );
-
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/reader/IReadService.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/reader/IReadService.java
deleted file mode 100644 (file)
index d25a6f6..0000000
+++ /dev/null
@@ -1,203 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.reader;
-
-import java.util.List;
-
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.NodeTable;
-import org.opendaylight.controller.sal.flowprogrammer.Flow;
-
-/**
- * This interface defines methods for retrieving the network node's
- * flow/port/queue hardware view
- */
-@Deprecated
-public interface IReadService {
-    /**
-     * Get the hardware view for the specified flow on the specified network
-     * node
-     *
-     * @param node
-     *            the network node
-     *            {@link org.opendaylight.controller.sal.core.Node}
-     * @param flow
-     *            the given flow
-     *            {@link org.opendaylight.controller.sal.flowprogrammer.Flow}
-     * @return the flow
-     *         {@link org.opendaylight.controller.sal.reader.FlowOnNode}
-     *         installed on the node
-     */
-    FlowOnNode readFlow(Node node, Flow flow);
-
-    /**
-     * Get the hardware view for the specified flow on the specified network node
-     * This call results in a direct polling of the information from the node
-     * Caller will be blocked until node replies or request times out
-     *
-     * @param node
-     *            the network node
-     *            {@link org.opendaylight.controller.sal.core.Node}
-     * @param flow
-     *            the given flow
-     *            {@link org.opendaylight.controller.sal.flowprogrammer.Flow}
-     * @return the flow
-     *         {@link org.opendaylight.controller.sal.reader.FlowOnNode}
-     *         installed on the node
-     */
-    FlowOnNode nonCachedReadFlow(Node node, Flow flow);
-
-    /**
-     * Get the hardware view for all the flows installed on the network node
-     *
-     * @param node
-     *            the network node
-     *            {@link org.opendaylight.controller.sal.core.Node}
-     * @return all the flows
-     *         {@link org.opendaylight.controller.sal.reader.FlowOnNode}
-     *         installed on the node
-     */
-    List<FlowOnNode> readAllFlows(Node node);
-
-    /**
-     * Get the hardware view for all the flows installed on the network node
-     * This call results in a direct polling of the information from the node
-     * Caller will be blocked until node replies or request times out
-     *
-     * @param node
-     *            the network node
-     *            {@link org.opendaylight.controller.sal.core.Node}
-     * @return the hardware view of all the flows
-     *         {@link org.opendaylight.controller.sal.reader.FlowOnNode}
-     *         installed on the node
-     */
-    List<FlowOnNode> nonCachedReadAllFlows(Node node);
-
-    /**
-     * Get the description information for the network node
-     *
-     * @param node
-     *            the network node
-     *            {@link org.opendaylight.controller.sal.core.Node}
-     * @return the node description
-     *         {@link org.opendaylight.controller.sal.reader.NodeDescription}
-     */
-    NodeDescription readDescription(Node node);
-
-    /**
-     * Get the description information for the network node
-     * This call results in a direct polling of the information from the node
-     * Caller will be blocked until node replies or request times out
-     *
-     * @param node
-     *            the network node
-     *            {@link org.opendaylight.controller.sal.core.Node}
-     * @return the node description
-     *         {@link org.opendaylight.controller.sal.reader.NodeDescription}
-     */
-    NodeDescription nonCachedReadDescription(Node node);
-
-    /**
-     * Get the hardware view for the specified node connector
-     *
-     * @param connector
-     *            the given node connector
-     *            {@link org.opendaylight.controller.sal.core.NodeConnector}
-     * @return the node connector statistics
-     *         {@link org.opendaylight.controller.sal.reader.NodeConnectorStatistics}
-     */
-    NodeConnectorStatistics readNodeConnector(NodeConnector connector);
-
-    /**
-     * Get the hardware view for all the node connectors
-     * present on the specified network node
-     *
-     * @param node
-     *            the network node
-     *            {@link org.opendaylight.controller.sal.core.Node}
-     * @return the statistics for all the node connectors
-     *         {@link org.opendaylight.controller.sal.reader.NodeConnectorStatistics}
-     */
-    List<NodeConnectorStatistics> readNodeConnectors(Node node);
-
-    /**
-     * Read the Table statistics for the given node table
-     *
-     * @param table
-     *            the table
-     *            {@link org.opendaylight.controller.sal.core.NodeTable}
-     * @return the table statistics
-     *         {@link org.opendaylight.controller.sal.reader.NodeTableStatistics}
-     */
-    NodeTableStatistics readNodeTable(NodeTable table);
-
-    /**
-     * Read the Table statistics for the given node This is not used. Querying
-     * all tables on a node is not currently a feature.
-     *
-     * @param node
-     *            the network node
-     *            {@link org.opendaylight.controller.sal.core.Node}
-     * @return the table statistics
-     *         {@link org.opendaylight.controller.sal.reader.NodeTableStatistics}
-     *         for all tables in a given node
-     */
-    List<NodeTableStatistics> readNodeTable(Node node);
-
-    /**
-     * Get the table statistics for the given node table
-     * This call results in a direct polling of the information from the node
-     * Caller will be blocked until the node replies or request times out
-     *
-     * @param table
-     *            the table
-     *            {@link org.opendaylight.controller.sal.core.NodeTable}
-     * @return the table statistics
-     *         {@link org.opendaylight.controller.sal.reader.NodeTableStatistics}
-     */
-    NodeTableStatistics nonCachedReadNodeTable(NodeTable table);
-
-    /**
-     * Get the node connectors statistics information for the network node
-     * This call results in a direct polling of the information from the node
-     * Caller will be blocked until node replies or request times out
-     *
-     * @param node
-     *            the network node
-     *            {@link org.opendaylight.controller.sal.core.Node}
-     * @return the statistics
-     *         {@link org.opendaylight.controller.sal.reader.NodeConnectorStatistics}
-     *         for all node connectors in a given node
-     */
-    List<NodeConnectorStatistics> nonCachedReadNodeConnectors(Node node);
-
-    /**
-     * Get the node connectors statistics information for the network node
-     *
-     * @param connector
-     *            the given node connector
-     *            {@link org.opendaylight.controller.sal.core.NodeConnector}
-     * @return the node connector statistics
-     *         {@link org.opendaylight.controller.sal.reader.NodeConnectorStatistics}
-     */
-    NodeConnectorStatistics nonCachedReadNodeConnector(NodeConnector connector);
-
-    /**
-     * Get the transmit rate for the specified node connector
-     *
-     * @param connector
-     *            the given node connector
-     *            {@link org.opendaylight.controller.sal.core.NodeConnector}
-     * @return tx rate [bps]
-     */
-    long getTransmitRate(NodeConnector connector);
-
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/reader/IReadServiceListener.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/reader/IReadServiceListener.java
deleted file mode 100644 (file)
index 01eaf1e..0000000
+++ /dev/null
@@ -1,17 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.sal.reader;
-
-/**
- * The interface describes SAL service to be consumed by functional modules that
- * are interested in reader updates
- */
-@Deprecated
-public interface IReadServiceListener extends IPluginOutReadService {
-
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/reader/NodeConnectorStatistics.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/reader/NodeConnectorStatistics.java
deleted file mode 100644 (file)
index 1ef2fd5..0000000
+++ /dev/null
@@ -1,388 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.reader;
-
-import java.io.Serializable;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.sal.core.NodeConnector;
-
-/**
- * Represents the statistics for a node connector
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class NodeConnectorStatistics implements Serializable {
-    private static final long serialVersionUID = 1L;
-
-    @XmlElement
-    private NodeConnector nodeConnector;
-    @XmlElement
-    private long receivePackets;
-    @XmlElement
-    private long transmitPackets;
-    @XmlElement
-    private long receiveBytes;
-    @XmlElement
-    private long transmitBytes;
-    @XmlElement
-    private long receiveDrops;
-    @XmlElement
-    private long transmitDrops;
-    @XmlElement
-    private long receiveErrors;
-    @XmlElement
-    private long transmitErrors;
-    @XmlElement
-    private long receiveFrameError;
-    @XmlElement
-    private long receiveOverRunError;
-    @XmlElement
-    private long receiveCrcError;
-    @XmlElement
-    private long collisionCount;
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + (int) (collisionCount ^ (collisionCount >>> 32));
-        result = prime * result + ((nodeConnector == null) ? 0 : nodeConnector.hashCode());
-        result = prime * result + (int) (receiveBytes ^ (receiveBytes >>> 32));
-        result = prime * result + (int) (receiveCrcError ^ (receiveCrcError >>> 32));
-        result = prime * result + (int) (receiveDrops ^ (receiveDrops >>> 32));
-        result = prime * result + (int) (receiveErrors ^ (receiveErrors >>> 32));
-        result = prime * result + (int) (receiveFrameError ^ (receiveFrameError >>> 32));
-        result = prime * result + (int) (receiveOverRunError ^ (receiveOverRunError >>> 32));
-        result = prime * result + (int) (receivePackets ^ (receivePackets >>> 32));
-        result = prime * result + (int) (transmitBytes ^ (transmitBytes >>> 32));
-        result = prime * result + (int) (transmitDrops ^ (transmitDrops >>> 32));
-        result = prime * result + (int) (transmitErrors ^ (transmitErrors >>> 32));
-        result = prime * result + (int) (transmitPackets ^ (transmitPackets >>> 32));
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (!(obj instanceof NodeConnectorStatistics)) {
-            return false;
-        }
-        NodeConnectorStatistics other = (NodeConnectorStatistics) obj;
-        if (collisionCount != other.collisionCount) {
-            return false;
-        }
-        if (nodeConnector == null) {
-            if (other.nodeConnector != null) {
-                return false;
-            }
-        } else if (!nodeConnector.equals(other.nodeConnector)) {
-            return false;
-        }
-        if (receiveBytes != other.receiveBytes) {
-            return false;
-        }
-        if (receiveCrcError != other.receiveCrcError) {
-            return false;
-        }
-        if (receiveDrops != other.receiveDrops) {
-            return false;
-        }
-        if (receiveErrors != other.receiveErrors) {
-            return false;
-        }
-        if (receiveFrameError != other.receiveFrameError) {
-            return false;
-        }
-        if (receiveOverRunError != other.receiveOverRunError) {
-            return false;
-        }
-        if (receivePackets != other.receivePackets) {
-            return false;
-        }
-        if (transmitBytes != other.transmitBytes) {
-            return false;
-        }
-        if (transmitDrops != other.transmitDrops) {
-            return false;
-        }
-        if (transmitErrors != other.transmitErrors) {
-            return false;
-        }
-        if (transmitPackets != other.transmitPackets) {
-            return false;
-        }
-        return true;
-    }
-
-    // To Satisfy JAXB
-    public NodeConnectorStatistics() {
-
-    }
-
-    /**
-     * Set the node connector
-     *
-     * @param port
-     */
-    public void setNodeConnector(NodeConnector port) {
-        this.nodeConnector = port;
-    }
-
-    /**
-     * Returns the node connector
-     *
-     * @return
-     */
-    public NodeConnector getNodeConnector() {
-        return nodeConnector;
-    }
-
-    /**
-     * Set the rx packet count's value
-     *
-     * @param count
-     */
-    public void setReceivePacketCount(long count) {
-        receivePackets = count;
-    }
-
-    /**
-     * Returns the rx packet count for the port
-     *
-     * @return
-     */
-    public long getReceivePacketCount() {
-        return receivePackets;
-    }
-
-    /**
-     * Set the tx packet count's value
-     *
-     * @param count
-     */
-    public void setTransmitPacketCount(long count) {
-        transmitPackets = count;
-    }
-
-    /**
-     * Returns the tx packet count for the port
-     *
-     * @return
-     */
-    public long getTransmitPacketCount() {
-        return transmitPackets;
-    }
-
-    /**
-     * Set the rx byte count's value
-     *
-     * @param count
-     */
-    public void setReceiveByteCount(long count) {
-        receiveBytes = count;
-    }
-
-    /**
-     * Return the rx byte count for the port
-     *
-     * @return
-     */
-    public long getReceiveByteCount() {
-        return receiveBytes;
-    }
-
-    /**
-     * Set the tx byte count's value
-     *
-     * @param count
-     */
-    public void setTransmitByteCount(long count) {
-        transmitBytes = count;
-    }
-
-    /**
-     * Return the tx byte count for the port
-     *
-     * @return
-     */
-    public long getTransmitByteCount() {
-        return transmitBytes;
-    }
-
-    /**
-     * Set the rx drop count's value
-     *
-     * @param count
-     */
-    public void setReceiveDropCount(long count) {
-        receiveDrops = count;
-    }
-
-    /**
-     * Returns the rx drop count for the port
-     *
-     * @return
-     */
-    public long getReceiveDropCount() {
-        return receiveDrops;
-    }
-
-    /**
-     * Set the tx drop count's value
-     *
-     * @param count
-     */
-    public void setTransmitDropCount(long count) {
-        transmitDrops = count;
-    }
-
-    /**
-     * Returns the tx drop count for the port
-     *
-     * @return
-     */
-    public long getTransmitDropCount() {
-        return transmitDrops;
-    }
-
-    /**
-     * Set the rx error count's value
-     *
-     * @param count
-     */
-    public void setReceiveErrorCount(long count) {
-        receiveErrors = count;
-    }
-
-    /**
-     * Return the rx error count for the port
-     *
-     * @return
-     */
-    public long getReceiveErrorCount() {
-        return receiveErrors;
-    }
-
-    /**
-     * Set the tx error count's value
-     *
-     * @param count
-     */
-    public void setTransmitErrorCount(long count) {
-        transmitErrors = count;
-    }
-
-    /**
-     * Return the tx error count for the port
-     *
-     * @return
-     */
-    public long getTransmitErrorCount() {
-        return transmitErrors;
-    }
-
-    /**
-     * Set the rx frame error value
-     *
-     * @param count
-     */
-    public void setReceiveFrameErrorCount(long count) {
-        receiveFrameError = count;
-    }
-
-    /**
-     * Returns the rx frame error for the port
-     *
-     * @return
-     */
-    public long getReceiveFrameErrorCount() {
-        return receiveFrameError;
-    }
-
-    /**
-     * Set the rx overrun error value
-     *
-     * @param count
-     */
-    public void setReceiveOverRunErrorCount(long count) {
-        receiveOverRunError = count;
-    }
-
-    /**
-     * Return the rx overrun error for the port
-     *
-     * @return
-     */
-    public long getReceiveOverRunErrorCount() {
-        return receiveOverRunError;
-    }
-
-    /**
-     * Set the rx CRC Error value
-     *
-     * @param count
-     */
-    public void setReceiveCRCErrorCount(long count) {
-        receiveCrcError = count;
-    }
-
-    /**
-     * Return the rx CRC error for the port
-     *
-     * @return
-     */
-    public long getReceiveCRCErrorCount() {
-        return receiveCrcError;
-    }
-
-    /**
-     * Set the collisionCount count's value
-     *
-     * @param count
-     */
-    public void setCollisionCount(long count) {
-        collisionCount = count;
-    }
-
-    /**
-     * Return the collisionCount count for the port
-     *
-     * @return
-     */
-    public long getCollisionCount() {
-        return collisionCount;
-    }
-
-    @Override
-    public String toString() {
-        return "NodeConnectorStats[portNumber = " + nodeConnector
-            + ", receivePackets = " + receivePackets
-            + ", transmitPackets = " + transmitPackets
-            + ", receiveBytes = " + receiveBytes + ", transmitBytes = "
-            + transmitBytes + ", receiveDrops = " + receiveDrops
-            + ", transmitDrops = " + transmitDrops + ", receiveErrors = "
-            + receiveErrors + ", transmitErrors = " + transmitErrors
-            + ", receiveFrameError = " + receiveFrameError
-            + ", receiveOverRunError = " + receiveOverRunError
-            + ", receiveCrcError = " + receiveCrcError
-            + ", collisionCount = " + collisionCount + "]";
-    }
-
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/reader/NodeDescription.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/reader/NodeDescription.java
deleted file mode 100644 (file)
index afcd02e..0000000
+++ /dev/null
@@ -1,151 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.reader;
-
-import java.io.Serializable;
-
-
-/**
- * Represents the network node description information
- */
-@Deprecated
-public class NodeDescription implements Serializable, Cloneable{
-    private static final long serialVersionUID = 1L;
-
-    private String manufacturer;
-    private String hardware;
-    private String software;
-    private String serialNumber;
-    private String description;
-
-    public NodeDescription() {
-
-    }
-
-    public String getManufacturer() {
-        return manufacturer;
-    }
-
-    public void setManufacturer(String manufacturer) {
-        this.manufacturer = manufacturer;
-    }
-
-    public String getHardware() {
-        return hardware;
-    }
-
-    public void setHardware(String hardware) {
-        this.hardware = hardware;
-    }
-
-    public String getSoftware() {
-        return software;
-    }
-
-    public void setSoftware(String software) {
-        this.software = software;
-    }
-
-    public String getSerialNumber() {
-        return serialNumber;
-    }
-
-    public void setSerialNumber(String serialNumber) {
-        this.serialNumber = serialNumber;
-    }
-
-    public String getDescription() {
-        return description;
-    }
-
-    public void setDescription(String description) {
-        this.description = description;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + ((description == null) ? 0 : description.hashCode());
-        result = prime * result + ((hardware == null) ? 0 : hardware.hashCode());
-        result = prime * result + ((manufacturer == null) ? 0 : manufacturer.hashCode());
-        result = prime * result + ((serialNumber == null) ? 0 : serialNumber.hashCode());
-        result = prime * result + ((software == null) ? 0 : software.hashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (!(obj instanceof NodeDescription)) {
-            return false;
-        }
-        NodeDescription other = (NodeDescription) obj;
-        if (description == null) {
-            if (other.description != null) {
-                return false;
-            }
-        } else if (!description.equals(other.description)) {
-            return false;
-        }
-        if (hardware == null) {
-            if (other.hardware != null) {
-                return false;
-            }
-        } else if (!hardware.equals(other.hardware)) {
-            return false;
-        }
-        if (manufacturer == null) {
-            if (other.manufacturer != null) {
-                return false;
-            }
-        } else if (!manufacturer.equals(other.manufacturer)) {
-            return false;
-        }
-        if (serialNumber == null) {
-            if (other.serialNumber != null) {
-                return false;
-            }
-        } else if (!serialNumber.equals(other.serialNumber)) {
-            return false;
-        }
-        if (software == null) {
-            if (other.software != null) {
-                return false;
-            }
-        } else if (!software.equals(other.software)) {
-            return false;
-        }
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        return "HwDescription[manufacturer=" + manufacturer + ", hardware="
-                        + hardware + ", software=" + software + ", serialNumber="
-                        + serialNumber + ", description=" + description + "]";
-    }
-    @Override
-    public NodeDescription clone() {
-        NodeDescription nd = new NodeDescription();
-        nd.setDescription(description);
-        nd.setHardware(hardware);
-        nd.setManufacturer(manufacturer);
-        nd.setSerialNumber(serialNumber);
-        nd.setSoftware(software);
-
-        return nd;
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/reader/NodeTableStatistics.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/reader/NodeTableStatistics.java
deleted file mode 100644 (file)
index e85bfd4..0000000
+++ /dev/null
@@ -1,196 +0,0 @@
-/*
- * Copyright (c) 2013 Big Switch Networks, Inc.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.sal.reader;
-
-import java.io.Serializable;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.sal.core.NodeTable;
-
-/**
- * @author Aditya Prakash Vaja <aditya.vaja@bigswitch.com>
- * Represents the Table statistics for the node
- *
- */
-
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-@Deprecated
-public class NodeTableStatistics implements Serializable {
-    private static final long serialVersionUID = 1L;
-
-    @XmlElement
-    private NodeTable nodeTable;
-    @XmlElement
-    private String name;
-    @XmlElement
-    private int activeCount;
-    @XmlElement
-    private long lookupCount;
-    @XmlElement
-    private long matchedCount;
-    @XmlElement
-    private int maximumEntries;
-
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + activeCount;
-        result = prime * result + (int) (lookupCount ^ (lookupCount >>> 32));
-        result = prime * result + (int) (matchedCount ^ (matchedCount >>> 32));
-        result = prime * result + maximumEntries;
-        result = prime * result + ((name == null) ? 0 : name.hashCode());
-        result = prime * result + ((nodeTable == null) ? 0 : nodeTable.hashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (!(obj instanceof NodeTableStatistics)) {
-            return false;
-        }
-        NodeTableStatistics other = (NodeTableStatistics) obj;
-        if (activeCount != other.activeCount) {
-            return false;
-        }
-        if (lookupCount != other.lookupCount) {
-            return false;
-        }
-        if (matchedCount != other.matchedCount) {
-            return false;
-        }
-        if (maximumEntries != other.maximumEntries) {
-            return false;
-        }
-        if (name == null) {
-            if (other.name != null) {
-                return false;
-            }
-        } else if (!name.equals(other.name)) {
-            return false;
-        }
-        if (nodeTable == null) {
-            if (other.nodeTable != null) {
-                return false;
-            }
-        } else if (!nodeTable.equals(other.nodeTable)) {
-            return false;
-        }
-        return true;
-    }
-
-    //To Satisfy JAXB
-    public NodeTableStatistics() {
-
-    }
-
-    /**
-     * @return the node table
-     */
-    public NodeTable getNodeTable() {
-        return nodeTable;
-    }
-
-    /**
-     * @param table of the node
-     */
-    public void setNodeTable(NodeTable table) {
-        this.nodeTable = table;
-    }
-
-    /**
-     * @return name of the table
-     */
-    public String getName() {
-        return name;
-    }
-
-    /**
-     * @param name - set the table name to name
-     */
-    public void setName(String name) {
-        this.name = name;
-    }
-
-    /**
-     * @return the activeCount
-     */
-    public int getActiveCount() {
-        return activeCount;
-    }
-
-    /**
-     * @param activeCount the activeCount to set
-     */
-    public void setActiveCount(int activeCount) {
-        this.activeCount = activeCount;
-    }
-
-    /**
-     * @return the lookupCount
-     */
-    public long getLookupCount() {
-        return lookupCount;
-    }
-
-    /**
-     * @param lookupCount the lookupCount to set
-     */
-    public void setLookupCount(long lookupCount) {
-        this.lookupCount = lookupCount;
-    }
-
-    /**
-     * @return the matchedCount
-     */
-    public long getMatchedCount() {
-        return matchedCount;
-    }
-
-    /**
-     * @param matchedCount the matchedCount to set
-     */
-    public void setMatchedCount(long matchedCount) {
-        this.matchedCount = matchedCount;
-    }
-
-    /**
-     * @return the maximumEntries
-     */
-    public int getMaximumEntries() {
-        return maximumEntries;
-    }
-
-    /**
-     * @param maximumEntries the maximumEntries to set
-     */
-    public void setMaximumEntries(int maximumEntries) {
-        this.maximumEntries = maximumEntries;
-    }
-
-    @Override
-    public String toString() {
-        return "NodeTableStats[tableId = " + nodeTable
-                + ", activeCount = " + activeCount
-                + ", lookupCount = " + lookupCount
-                + ", matchedCount = " + matchedCount
-                + ", maximumEntries = " + maximumEntries + "]";
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/routing/IListenRoutingUpdates.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/routing/IListenRoutingUpdates.java
deleted file mode 100644 (file)
index dd2262b..0000000
+++ /dev/null
@@ -1,26 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.routing;
-
-/**
- * Interface that will be implemented by the modules that wants to
- * know events published by the routing engine
- *
- */
-@Deprecated
-public interface IListenRoutingUpdates {
-    /**
-     * Method invoked when the recalculation of the all shortest path
-     * tree is done
-     *
-     */
-    public void recalculateDone();
-
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/routing/IRouting.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/routing/IRouting.java
deleted file mode 100644 (file)
index b50f616..0000000
+++ /dev/null
@@ -1,87 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.routing;
-
-import java.util.Map;
-
-import org.opendaylight.controller.sal.core.Edge;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.Path;
-
-/**
- * This interface provides APIs to manage and query the routing information
- *
- */
-@Deprecated
-public interface IRouting {
-
-    /**
-     * Returns a Path leading from the source to the destination
-     *
-     * @param src
-     *            source {@link org.opendaylight.controller.sal.core.Node}
-     *
-     * @param dst
-     *            destination
-     *            {@link org.opendaylight.controller.sal.core.Node}
-     * @return: the {@link org.opendaylight.controller.sal.core.Path}
-     */
-    public Path getRoute(Node src, Node dst);
-
-    /**
-     * Returns a Max ThroughPut Path leading from the source to the destination
-     *
-     * @param src
-     *            source {@link org.opendaylight.controller.sal.core.Node}
-     *
-     * @param dst
-     *            destination
-     *            {@link org.opendaylight.controller.sal.core.Node}
-     * @return: the max throughput {@link org.opendaylight.controller.sal.core.Path}
-     */
-    public Path getMaxThroughputRoute(Node src, Node dst);
-
-    /**
-     * Returns a Path leading from the source to the destination that meets the
-     * specified bandwidth
-     *
-     * @param src
-     *            source {@link org.opendaylight.controller.sal.core.Node}
-     *
-     * @param dst
-     *            destination {@link org.opendaylight.controller.sal.core.Node}
-     * @param Bw
-     *            the bandwidth
-     * @return: the {@link org.opendaylight.controller.sal.core.Path}
-     */
-    public Path getRoute(Node src, Node dst, Short Bw);
-
-    /**
-     * Remove all routes and reset all state. USE CAREFULLY!
-     */
-    public void clear();
-
-    /**
-     * Remove all Max Throughput Routes and reset all state. USE CAREFULLY!
-     */
-    public void clearMaxThroughput();
-
-    /**
-     * Initialization For Max Throughput
-     *
-     * @param EdgeWeightMap
-     *            Map containing
-     *            {@link org.opendaylight.controller.sal.core.Edge} and
-     *            Corresponding Weight. Optional Param - if null, implementation
-     *            specific weight calculation will be used.
-     */
-    public void initMaxThroughput(Map<Edge, Number> EdgeWeightMap);
-
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/topology/IListenTopoUpdates.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/topology/IListenTopoUpdates.java
deleted file mode 100644 (file)
index 3895993..0000000
+++ /dev/null
@@ -1,50 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.topology;
-
-import java.util.List;
-
-import org.opendaylight.controller.sal.core.Edge;
-
-/**
- * This interface defines the methods for topology notifications provided by SAL
- * toward the application. For example an application that wants to keep up to
- * date with the updates coming from SAL it will register in the OSGi service
- * registry. This interface (on a per-container base) and SAL will call it
- * providing the update.
- */
-@Deprecated
-public interface IListenTopoUpdates {
-    /**
-     * Called to update on Edge in the topology graph
-     *
-     * @param topoedgeupdateList
-     *            List of topoedgeupdates Each topoedgeupdate includes edge, its
-     *            Properties ( BandWidth and/or Latency etc) and update type.
-     */
-    public void edgeUpdate(List<TopoEdgeUpdate> topoedgeupdateList);
-
-    /**
-     * Called when an Edge utilization is above the safety threshold configured
-     * on the controller
-     *
-     * @param edge
-     *            The edge which bandwidth usage is above the safety level
-     */
-    public void edgeOverUtilized(Edge edge);
-
-    /**
-     * Called when the Edge utilization is back to normal, below the safety
-     * threshold level configured on the controller
-     *
-     * @param edge
-     *            The edge which bandwidth usage is back to normal
-     */
-    public void edgeUtilBackToNormal(Edge edge);
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/topology/IPluginInTopologyService.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/topology/IPluginInTopologyService.java
deleted file mode 100644 (file)
index 35e0872..0000000
+++ /dev/null
@@ -1,37 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.topology;
-
-/**
- * @file   IPluginInTopologyService.java
- *
- * @brief  Methods that are invoked from SAL toward the protocol
- * plugin.
- *
- * For example if SAL startup late in respect to a protocol plugin, or
- * restarts, we need away to sollicit the push of older updates from
- * Protocol Plugins this interface serve the purpose. This a practical
- * example of the type of service provided by this interface
- */
-
-/**
- * Methods that are invoked from SAL toward the protocol
- * plugin to sollicit Topoloy updates
- *
- */
-@Deprecated
-public interface IPluginInTopologyService {
-    /**
-     * Tell to protocol plugin that is time to send the updates of the
-     * current topology because someone joined late the game
-     *
-     */
-    public void sollicitRefresh();
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/topology/IPluginOutTopologyService.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/topology/IPluginOutTopologyService.java
deleted file mode 100644 (file)
index 42d1a5e..0000000
+++ /dev/null
@@ -1,49 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.topology;
-
-import java.util.List;
-import org.opendaylight.controller.sal.core.Edge;
-
-/**
- * This interface defines the methods that are invoked from Protocol Plugin
- * toward SAL. Every time a protocol plugin update the topology, it will call
- * this service provided by SAL so the update can migrate upward toward the
- * applications.
- */
-@Deprecated
-public interface IPluginOutTopologyService {
-
-    /**
-     * Called to update on Edge in the topology graph
-     *
-     * @param topoedgeupdateList
-     *            List of topoedgeupdates Each topoedgeupdate includes edge, its
-     *            Properties ( BandWidth and/or Latency etc) and update type.
-     */
-    public void edgeUpdate(List<TopoEdgeUpdate> topoedgeupdateList);
-
-    /**
-     * Called when an Edge utilization is above the safety threshold configured
-     * on the controller
-     *
-     * @param edge
-      *            The edge which bandwidth usage is above the safety level
-    */
-    public void edgeOverUtilized(Edge edge);
-
-    /**
-     * Called when the Edge utilization is back to normal, below the safety
-     * threshold level configured on the controller
-     *
-     * @param edge
-     *            The edge which bandwidth usage is back to normal
-     */
-    public void edgeUtilBackToNormal(Edge edge);
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/topology/ITopologyService.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/topology/ITopologyService.java
deleted file mode 100644 (file)
index ffad237..0000000
+++ /dev/null
@@ -1,33 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.topology;
-
-/**
- * @file   ITopologyService.java
- *
- * @brief  Topology methods provided by SAL toward the applications
- *
- * For example An application that startup late in the game or restart
- * for example, wants to know the current status of SAL, so can use
- * this interface to get a bunlk sync of the topology status.
- */
-
-/**
- * Topology methods provided by SAL toward the applications
- */
-@Deprecated
-public interface ITopologyService {
-    /**
-     * Tell to SAL that is time to send the updates of the
-     * current topology because someone joined late the game
-     *
-     */
-    public void sollicitRefresh();
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/topology/TopoEdgeUpdate.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/topology/TopoEdgeUpdate.java
deleted file mode 100644 (file)
index 90596bd..0000000
+++ /dev/null
@@ -1,105 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.topology;
-
-import java.util.Set;
-
-import org.opendaylight.controller.sal.core.Edge;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.core.UpdateType;
-
-/**
- * The class represents an Edge, the Edge's Property Set and its UpdateType.
- * If update is on new properties added to an existing edge, appropriate type is CHANGED.
- */
-@Deprecated
-public class TopoEdgeUpdate {
-    private Edge edge;
-    private Set<Property> props;
-    private UpdateType type;
-    private boolean isLocal;
-
-    /**
-     * Constructor for a topology element update. A TopologyElementUpdate is an
-     * object that summarize what has happened on an Edge and if the update is
-     * generated locally to this controller or no
-     *
-     * @param e
-     *            Edge being updated
-     * @param p
-     *            Set of Properties attached to the edge
-     * @param t
-     *            Type of update
-     */
-    public TopoEdgeUpdate(Edge e, Set<Property> p, UpdateType t) {
-        edge = e;
-        props = p;
-        type = t;
-        setLocal(true);
-    }
-
-    public Edge getEdge() {
-        return edge;
-    }
-
-    public Set<Property> getProperty() {
-        return props;
-    }
-
-    public UpdateType getUpdateType() {
-        return type;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = (prime * result) + ((edge == null) ? 0 : edge.hashCode());
-        result = (prime * result) + ((type == null) ? 0 : type.hashCode());
-        return result;
-    }
-
-    @Override
-    public String toString() {
-        return "TopoEdgeUpdate [edge=" + edge + ", props=" + props + ", type=" + type + ", isLocal=" + isLocal + "]";
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        TopoEdgeUpdate other = (TopoEdgeUpdate) obj;
-        if (edge == null) {
-            if (other.edge != null) {
-                return false;
-            }
-        } else if (!edge.equals(other.edge)) {
-            return false;
-        }
-        if (type != other.type) {
-            return false;
-        }
-        return true;
-    }
-
-    public boolean isLocal() {
-        return isLocal;
-    }
-
-    public void setLocal(boolean isLocal) {
-        this.isLocal = isLocal;
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/ConfigurationObject.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/ConfigurationObject.java
deleted file mode 100644 (file)
index 8f48228..0000000
+++ /dev/null
@@ -1,19 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.utils;
-
-/**
- * This interface defines the methods for configuration object
- *
- */
-@Deprecated
-public interface ConfigurationObject {
-
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/Direction.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/Direction.java
deleted file mode 100644 (file)
index 0959971..0000000
+++ /dev/null
@@ -1,32 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.utils;
-
-import java.io.Serializable;
-
-/**
- * Direction enum
- *
- *
- *
- */
-@Deprecated
-public enum Direction implements Serializable {
-    FORWARD("forward"), REVERSE("reverse");
-    private Direction(String name) {
-        this.name = name;
-    }
-
-    private String name;
-
-    public String toString() {
-        return name;
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/EtherTypes.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/EtherTypes.java
deleted file mode 100644 (file)
index 7f1955d..0000000
+++ /dev/null
@@ -1,118 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.utils;
-
-import java.util.ArrayList;
-import java.util.List;
-
-/**
- * The enum contains the most common 802.3 ethernet types and 802.2 + SNAP protocol ids
- *
- *
- *
- */
-@Deprecated
-public enum EtherTypes {
-    PVSTP("PVSTP", 0x010B), // 802.2 + SNAP (Spanning Tree)
-    CDP("CDP", 0x2000), // 802.2 + SNAP
-    VTP("VTP", 0x2003), // 802.2 + SNAP
-    IPv4("IPv4", 0x800), ARP("ARP", 0x806), RARP("Reverse ARP", 0x8035), VLANTAGGED(
-            "VLAN Tagged", 0x8100), // 802.1Q
-    IPv6("IPv6", 0x86DD), MPLSUCAST("MPLS Unicast", 0x8847), MPLSMCAST(
-            "MPLS Multicast", 0x8848), QINQ("QINQ", 0x88A8), // Standard 802.1ad QinQ
-    LLDP("LLDP", 0x88CC), OLDQINQ("Old QINQ", 0x9100), // Old non-standard QinQ
-    CISCOQINQ("Cisco QINQ", 0x9200); // Cisco non-standard QinQ
-
-    private static final String regexNumberString = "^[0-9]+$";
-    private String description;
-    private int number;
-
-    private EtherTypes(String description, int number) {
-        this.description = description;
-        this.number = number;
-    }
-
-    public String toString() {
-        return description;
-    }
-
-    public int intValue() {
-        return number;
-    }
-
-    public short shortValue() {
-        return ((Integer) number).shortValue();
-    }
-
-    public static String getEtherTypeName(int number) {
-        return getEtherTypeInternal(number);
-    }
-
-    public static String getEtherTypeName(short number) {
-        return getEtherTypeInternal((int) number & 0xffff);
-    }
-
-    public static String getEtherTypeName(byte number) {
-        return getEtherTypeInternal((int) number & 0xff);
-    }
-
-    private static String getEtherTypeInternal(int number) {
-        for (EtherTypes type : EtherTypes.values()) {
-            if (type.number == number) {
-                return type.toString();
-            }
-        }
-        return "0x" + Integer.toHexString(number);
-    }
-
-    public static short getEtherTypeNumberShort(String name) {
-        if (name.matches(regexNumberString)) {
-            return Short.valueOf(name);
-        }
-        for (EtherTypes type : EtherTypes.values()) {
-            if (type.description.equalsIgnoreCase(name)) {
-                return type.shortValue();
-            }
-        }
-        return 0;
-    }
-
-    public static int getEtherTypeNumberInt(String name) {
-        if (name.matches(regexNumberString)) {
-            return Integer.valueOf(name);
-        }
-        for (EtherTypes type : EtherTypes.values()) {
-            if (type.description.equalsIgnoreCase(name)) {
-                return type.intValue();
-            }
-        }
-        return 0;
-    }
-
-    public static List<String> getEtherTypesNameList() {
-        List<String> ethertypesList = new ArrayList<String>();
-        for (EtherTypes type : EtherTypes.values()) {
-            ethertypesList.add(type.toString());
-        }
-        return ethertypesList;
-    }
-
-    public static EtherTypes loadFromString(String string) {
-        int intType = Integer.parseInt(string);
-
-        for (EtherTypes type : EtherTypes.values()) {
-            if (type.number == intType) {
-                return type;
-            }
-        }
-        return null;
-    }
-
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/FilterIterator.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/FilterIterator.java
deleted file mode 100644 (file)
index d0de0be..0000000
+++ /dev/null
@@ -1,101 +0,0 @@
-/*
- * Copyright (c) 2012 Big Switch Networks, Inc.
- *
- * Licensed under the Eclipse Public License, Version 1.0 (the
- * "License"); you may not use this file except in compliance with the
- * License. You may obtain a copy of the License at
- *
- *      http://www.eclipse.org/legal/epl-v10.html
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
- * implied. See the License for the specific language governing
- * permissions and limitations under the License.
- *
- * This file incorporates work covered by the following copyright and
- * permission notice:
- *
- *    Originally created by David Erickson, Stanford University
- *
- *    Licensed under the Apache License, Version 2.0 (the "License");
- *    you may not use this file except in compliance with the
- *    License. You may obtain a copy of the License at
- *
- *         http://www.apache.org/licenses/LICENSE-2.0
- *
- *    Unless required by applicable law or agreed to in writing,
- *    software distributed under the License is distributed on an "AS
- *    IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
- *    express or implied. See the License for the specific language
- *    governing permissions and limitations under the License.
- */
-
-package org.opendaylight.controller.sal.utils;
-
-import java.util.Iterator;
-import java.util.NoSuchElementException;
-
-/**
- * An iterator that will filter values from an iterator and return only those
- * values that match the predicate.
- */
-@Deprecated
-public abstract class FilterIterator<T> implements Iterator<T> {
-    protected Iterator<T> subIterator;
-    protected T next;
-
-    /**
-     * Construct a filter iterator from the given sub iterator
-     *
-     * @param subIterator
-     *            the sub iterator over which we'll filter
-     */
-    public FilterIterator(Iterator<T> subIterator) {
-        super();
-        this.subIterator = subIterator;
-    }
-
-    /**
-     * Check whether the given value should be returned by the filter
-     *
-     * @param value
-     *            the value to check
-     * @return true if the value should be included
-     */
-    protected abstract boolean matches(T value);
-
-    // ***********
-    // Iterator<T>
-    // ***********
-
-    @Override
-    public boolean hasNext() {
-        if (next != null)
-            return true;
-
-        while (subIterator.hasNext()) {
-            next = subIterator.next();
-            if (matches(next))
-                return true;
-        }
-        next = null;
-        return false;
-    }
-
-    @Override
-    public T next() {
-        if (hasNext()) {
-            T cur = next;
-            next = null;
-            return cur;
-        }
-        throw new NoSuchElementException();
-    }
-
-    @Override
-    public void remove() {
-        throw new UnsupportedOperationException();
-    }
-
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/GUIField.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/GUIField.java
deleted file mode 100644 (file)
index 6d69a27..0000000
+++ /dev/null
@@ -1,49 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.utils;
-
-/**
- * GUI field constants
- *
- *
- *
- */
-@Deprecated
-public enum GUIField {
-    USER("User"), PASSWORD("Password"), ROLE("Role"), SERVERIP("Server address"), SERVERSECRET(
-            "Server secret"), SERVERPROTOCOL("Server protocol"), NAME("Name"), CONTAINER(
-            "Container"), SUBNET("Subnet"), GATEWAYIP("Gateway IP Address/Mask"), NODE(
-            "Node"), NODEID("Node ID"), NODEMAC("Node MAC Address"), NODENAME(
-            "Node Name"), SRCNODE("Source Node"), DSTNODE("Destination Node"), SRCPORT(
-            "Source Port"), DSTPORT("Destination Port"), PORTS("Ports"), NODEPORTS(
-            "Node/Ports"), SPANPORTS("Span Ports"), TIER("Tier"), MODE("Mode"), INPUTPORT(
-            "Input Port"), ETHERTYPE("Ether Type"), DLSRCADDRESS("Source MAC"), DLDSTADDRESS(
-            "Dest MAC"), VLANID("Vlan Id"), VLANPRIO("Vlan Priority"), NWSRCADDRESS(
-            "Source IP"), NWDSTADDRESS("Dest IP"), NWPROTOCOL("Protocol"), NWPROTOCOLSHORT(
-            "Proto"), NWTOSBITS("TOS"), TPSRCPORT("Transport Source Port"), TPDSTPORT(
-            "Transport Dest Port"), TPSRCPORTSHORT("Source L4 Port"), TPDSTPORTSHORT(
-            "Dest L4 Port"), METRIC("Metric"), STATUS("Status"), TAG("Tag"), TAGS(
-            "Tags"), STATICVLAN("Static Vlan"), PRIORITY("Priority"), PORTGROUP(
-            "Port Group"), COOKIE("Cookie"), ACTIONS("Actions"), ACTIVE(
-            "Active"), IDLETIMEOUT("Idle Time Out"), HARDTIMEOUT(
-            "Hard Time Out"), INHARDWARE("Install on Switch"), STATICROUTE(
-            "Static Route"), NEXTHOPTYPE("NextHop Type"), NEXTHOP(
-            "NextHop address");
-
-    private GUIField(String name) {
-        this.name = name;
-    }
-
-    private String name;
-
-    public String toString() {
-        return name;
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/GlobalConstants.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/GlobalConstants.java
deleted file mode 100644 (file)
index 342a99b..0000000
+++ /dev/null
@@ -1,35 +0,0 @@
-/*
- * Copyright (c) 2013-2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.utils;
-
-/**
- * Global Constants
- *
- */
-@Deprecated
-public enum GlobalConstants {
-    DEFAULT("default"),
-    CONTAINERMANAGER("containermanager"),
-    CONTAINERNAME("name"),
-    STATICVLAN("staticvlan"),
-    CLUSTERINGSERVICES("clusteringservices"),
-    STARTUPHOME("configuration/startup/"),
-    PROTOCOLPLUGINTYPE("protocolPluginType"),
-    PROTOCOLPLUGINPRIORITY("protocolPluginPriority");
-
-    private GlobalConstants(String name) {
-        this.name = name;
-    }
-
-    private String name;
-
-    public String toString() {
-        return name;
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/HexEncode.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/HexEncode.java
deleted file mode 100644 (file)
index 4e6b59e..0000000
+++ /dev/null
@@ -1,115 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.utils;
-
-import java.math.BigInteger;
-
-/**
- * The class provides methods to convert hex encode strings
- *
- *
- */
-@Deprecated
-public class HexEncode {
-    /**
-     * This method converts byte array into String format without ":" inserted.
-     *
-     * @param bytes
-     *            The byte array to convert to string
-     * @return The hexadecimal representation of the byte array. If bytes is
-     *         null, "null" string is returned
-     */
-    public static String bytesToHexString(byte[] bytes) {
-
-        if (bytes == null) {
-            return "null";
-        }
-
-        String ret = "";
-        StringBuffer buf = new StringBuffer();
-        for (int i = 0; i < bytes.length; i++) {
-            if (i > 0) {
-                ret += ":";
-            }
-            short u8byte = (short) (bytes[i] & 0xff);
-            String tmp = Integer.toHexString(u8byte);
-            if (tmp.length() == 1) {
-                buf.append("0");
-            }
-            buf.append(tmp);
-        }
-        ret = buf.toString();
-        return ret;
-    }
-
-    public static String longToHexString(long val) {
-        char arr[] = Long.toHexString(val).toCharArray();
-        StringBuffer buf = new StringBuffer();
-        // prepend the right number of leading zeros
-        int i = 0;
-        for (; i < (16 - arr.length); i++) {
-            buf.append("0");
-            if ((i & 0x01) == 1) {
-                buf.append(":");
-            }
-        }
-        for (int j = 0; j < arr.length; j++) {
-            buf.append(arr[j]);
-            if ((((i + j) & 0x01) == 1) && (j < (arr.length - 1))) {
-                buf.append(":");
-            }
-        }
-        return buf.toString();
-    }
-
-
-    public static byte[] bytesFromHexString(String values) {
-        String target = "";
-        if (values != null) {
-            target = values;
-        }
-        String[] octets = target.split(":");
-
-        byte[] ret = new byte[octets.length];
-        for (int i = 0; i < octets.length; i++) {
-            ret[i] = Integer.valueOf(octets[i], 16).byteValue();
-        }
-        return ret;
-    }
-
-    public static long stringToLong(String values) {
-        long value = new BigInteger(values.replaceAll(":", ""), 16).longValue();
-        return value;
-    }
-
-    /**
-     * This method converts byte array into HexString format with ":" inserted.
-     */
-    public static String bytesToHexStringFormat(byte[] bytes) {
-        if (bytes == null) {
-            return "null";
-        }
-        String ret = "";
-        StringBuffer buf = new StringBuffer();
-        for (int i = 0; i < bytes.length; i++) {
-            if (i > 0) {
-                buf.append(":");
-            }
-            short u8byte = (short) (bytes[i] & 0xff);
-            String tmp = Integer.toHexString(u8byte);
-            if (tmp.length() == 1) {
-                buf.append("0");
-            }
-            buf.append(tmp);
-        }
-        ret = buf.toString();
-        return ret;
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/IListener.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/IListener.java
deleted file mode 100644 (file)
index ae72643..0000000
+++ /dev/null
@@ -1,78 +0,0 @@
-/*
- * Copyright (c) 2011 Big Switch Networks, Inc.
- *
- * Licensed under the Eclipse Public License, Version 1.0 (the
- * "License"); you may not use this file except in compliance with the
- * License. You may obtain a copy of the License at
- *
- *      http://www.eclipse.org/legal/epl-v10.html
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
- * implied. See the License for the specific language governing
- * permissions and limitations under the License.
- *
- * This file incorporates work covered by the following copyright and
- * permission notice:
- *
- *    Originally created by David Erickson, Stanford University
- *
- *    Licensed under the Apache License, Version 2.0 (the "License");
- *    you may not use this file except in compliance with the
- *    License. You may obtain a copy of the License at
- *
- *         http://www.apache.org/licenses/LICENSE-2.0
- *
- *    Unless required by applicable law or agreed to in writing,
- *    software distributed under the License is distributed on an "AS
- *    IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
- *    express or implied. See the License for the specific language
- *    governing permissions and limitations under the License.
- */
-
-package org.opendaylight.controller.sal.utils;
-
-/**
- * This interface defines the methods for callback ordering
- *
- */
-@Deprecated
-public interface IListener<T> {
-    public enum Command {
-        CONTINUE, STOP
-    }
-
-    /**
-     * The name assigned to this listener
-     *
-     * @return the name string
-     */
-    public String getName();
-
-    /**
-     * Check if the module called name is a callback ordering prerequisite for
-     * this module. In other words, if this function returns true for the given
-     * name, then this listener will be called after that message listener.
-     *
-     * @param type
-     *            the object type to which this applies
-     * @param name
-     *            the name of the module
-     * @return whether name is a prerequisite.
-     */
-    public boolean isCallbackOrderingPrereq(T type, String name);
-
-    /**
-     * Check if the module called name is a callback ordering post-requisite for
-     * this module. In other words, if this function returns true for the given
-     * name, then this listener will be called before that message listener.
-     *
-     * @param type
-     *            the object type to which this applies
-     * @param name
-     *            the name of the module
-     * @return whether name is a post-requisite.
-     */
-    public boolean isCallbackOrderingPostreq(T type, String name);
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/INodeConnectorFactory.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/INodeConnectorFactory.java
deleted file mode 100644 (file)
index 5c8076b..0000000
+++ /dev/null
@@ -1,36 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.utils;
-
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-
-/**
- * This interface defines the methods to be called when looking up custom node types
- *
- */
-@Deprecated
-public interface INodeConnectorFactory {
-    /**
-     * Method to get custom NodeConnector types from protocol plugins
-     *
-     * @param typeStr
-     *            {@Link
-     *            org.opendaylight.controller.sal.core.NodeConnector} type
-     *            string
-     * @param IDStr
-     *            {@Link
-     *            org.opendaylight.controller.sal.core.NodeConnector} ID string
-     * @return the custom {@Link
-     *         org.opendaylight.controller.sal.core.NodeConnector}
-     */
-    public NodeConnector fromStringNoNode(String typeStr, String IDStr,
-            Node n);
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/INodeFactory.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/INodeFactory.java
deleted file mode 100644 (file)
index 09339f8..0000000
+++ /dev/null
@@ -1,33 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.utils;
-
-import org.opendaylight.controller.sal.core.Node;
-
-/**
- * This interface defines the methods to be called when looking up custom node types
- *
- */
-@Deprecated
-public interface INodeFactory {
-    /**
-     * Method to get custom node types from protocol plugins
-     *
-     * @param nodeType
-     *            {@Link org.opendaylight.controller.sal.core.Node} type
-     *            string
-     * @param nodeId
-     *            {@Link org.opendaylight.controller.sal.core.Node} ID
-     *            string
-     * @return the custom {@Link
-     *         org.opendaylight.controller.sal.core.Node}
-     */
-    public Node fromString(String nodeType, String nodeId);
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/IObjectReader.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/IObjectReader.java
deleted file mode 100644 (file)
index 4cd1c9f..0000000
+++ /dev/null
@@ -1,30 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.utils;
-
-import java.io.FileNotFoundException;
-import java.io.IOException;
-import java.io.ObjectInputStream;
-
-/**
- * This interface is needed to allow object reconstruction when reading serialized objects from
- * inside a package other than the one where ObjectReader is defined (otherwise you hit the
- * java.lang.ClassNotFoundException). This interface will allow to deserialize a class from inside
- * the package where the class is defined. All the exception handling can still happen in
- * ObjectReader and the implementer of IObjectReader only need to throws such exceptions
- *
- *
- *
- */
-@Deprecated
-public interface IObjectReader {
-    public Object readObject(ObjectInputStream ois)
-            throws FileNotFoundException, IOException, ClassNotFoundException;
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/IPProtocols.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/IPProtocols.java
deleted file mode 100644 (file)
index dbe74ef..0000000
+++ /dev/null
@@ -1,304 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.utils;
-
-import java.util.ArrayList;
-import java.util.List;
-
-/**
- * Enum represents the most common IP protocols numbers It provides the binding
- * between IP protocol names and numbers and provides APIs to read and parse
- * them in either of the two forms
- *
- * NOTE: Openflow 1.0 supports the IP Proto match only for ICMP, TCP and UDP
- *
- * references:
- * http://www.iana.org/assignments/protocol-numbers/protocol-numbers.xhtml
- */
-@Deprecated
-public enum IPProtocols {
-     ANY("any", -1),
-     HOPOPT("HOPOPT",0),
-     ICMP("ICMP", 1),
-     IGMP("IGMP",2),
-     GGP("GGP",3),
-     IPV4("IPv4",4),
-     ST("ST",5),
-     TCP("TCP", 6),
-     CBT("CBT",7),
-     EGP("EGP",8),
-     IGP("IGP",9),
-     BBNRCCMON("BBN-RCC-MON",10),
-     NVPII("NVP-II",11),
-     PUP("PUP",12),
-     ARGUS("ARGUS",13),
-     EMCON("EMCON",14),
-     XNET("XNET",15),
-     CHAOS("CHAOS",16),
-     UDP("UDP", 17),
-     MUX("MUX",18),
-     DCNMEAS("DCN-MEAS",19),
-     HMP("HMP",20),
-     PRM("PRM",21),
-     XNSIDP("XNS-IDP",22),
-     TRUNK1("TRUNK-1",23),
-     TRUNK2("TRUNK-2",24),
-     LEAF1("LEAF-1",25),
-     LEAF2("LEAF-2",26),
-     RDP("RDP",27),
-     IRTP("IRTP",28),
-     ISOTP4("ISO-TP4",29),
-     NETBLT("NETBLT",30),
-     MFENSP("MFE-NSP",31),
-     MERITINP("MERIT-INP",32),
-     DCCP("DCCP",33),
-     THREEPC("3PC",34),
-     IDPR("IDPR",35),
-     XTP("XTP",36),
-     DDP("DDP",37),
-     IDPRCMTP("IDPR-CMTP",38),
-     TPPLUSPLUS("TP++",39),
-     IL("IL",40),
-     IPV6("IPv6",41),
-     SDRP("SDRP",42),
-     IPV6Route("IPv6-Route",43),
-     IPV6Frag("IPv6-Frag",44),
-     IDRP("IDRP",45),
-     RSVP("RSVP",46),
-     GRE("GRE",47),
-     DSR("DSR",48),
-     BNA("BNA",49),
-     ESP("ESP",50),
-     AH("AH",51),
-     INLSP("I-NLSP",52),
-     SWIPE("SWIPE",53),
-     NARP("NARP",54),
-     MOBILE("MOBILE",55),
-     TLSP("TLSP",56),
-     SKIP("SKIP",57),
-     IPV6ICMP("IPv6-ICMP", 58),
-     IPV6NoNxt("IPv6-NoNxt",59),
-     IPV6Opts("IPv6-Opts",60),
-     ANYHOST("ANY-HOST",61),
-     CFTP("CFTP",62),
-     ANYNETWORK("ANY-NETWORK",63),
-     SATEXPAK("SAT-EXPAK",64),
-     KRYPTOLAN("KRYPTOLAN",65),
-     RVD("RVD",66),
-     IPPC("IPPC",67),
-     ANYDISTFS("ANY-DIST-FS",68),
-     SATMON("SAT-MON",69),
-     VISA("VISA",70),
-     IPCV("IPCV",71),
-     CPNX("CPNX",72),
-     CPHB("CPHB",73),
-     WSN("WSN",74),
-     PVP("PVP",75),
-     BRSATMON("BR-SAT-MON",76),
-     SUNND("SUN-ND",77),
-     WBMON("WB-MON",78),
-     WBEXPAK("WB-EXPAK",79),
-     ISOIP("ISO-IP",80),
-     VMTP("VMTP",81),
-     SECUREVMTP("SECURE-VMTP",82),
-     VINES("VINES",83),
-     TTP("TTP",84),
-     IPTM("IPTM",84),
-     NSFNETIGP("NSFNET-IGP",85),
-     DGP("DGP",86),
-     TCF("TCF",87),
-     EIGRP("EIGRP",88),
-     OSPFIGP("OSPFIGP",89),
-     SPRITERPC("Sprite-RPC",90),
-     LARP("LARP",91),
-     MTP("MTP",92),
-     AX25("AX.25",93),
-     IPIP("IPIP",94),
-     MICP("MICP",95),
-     SCCSP("SCC-SP",96),
-     ETHERIP("ETHERIP",97),
-     ENCAP("ENCAP",98),
-     ANYENC("ANY-ENC",99),
-     GMTP("GMTP",100),
-     IFMP("IFMP",101),
-     PNNI("PNNI",102),
-     PIM("PIM",103),
-     ARIS("ARIS",104),
-     SCPS("SCPS",105),
-     QNX("QNX",106),
-     AN("A/N",107),
-     IPComp("IPComp",108),
-     SNP("SNP",109),
-     COMPAQPEER("Compaq-Peer",110),
-     IPXINIP("IPX-in-IP",111),
-     VRRP("VRRP",112),
-     PGM("PGM",113),
-     ANY0HOP("ANY-0-HOP",114),
-     L2TP("L2TP",115),
-     DDX("DDX",116),
-     IATP("IATP",117),
-     STP("STP",118),
-     SRP("SRP",119),
-     UTI("UTI",120),
-     SMP("SMP",121),
-     SM("SM",122),
-     PTP("PTP",123),
-     ISIS("ISIS",124),
-     FIRE("FIRE",125),
-     CRTP("CRTP",126),
-     CRUDP("CRUDP",127),
-     SSCOPMCE("SSCOPMCE",128),
-     IPLT("IPLT",129),
-     SPS("SPS",130),
-     PIPE("PIPE",131),
-     SCTP("SCTP",132),
-     FC("FC",133),
-     RSVPE2EIGNORE("RSVP-E2E-IGNORE",134),
-     MOBILITYHEADER("Mobility Header",135),
-     UDPLITE("UDPLite",136),
-     MPLSINIP("MPLS-in-IP",137),
-     MANET("MANET",138),
-     HIP("HIP",139),
-     SHIM6("Shim6",140),
-     WESP("WESP",141),
-     ROHC("ROHC",142),
-     /*143-252 Unassigned by IANA*/
-
-     //Experimebtal protocol numbers (http://tools.ietf.org/html/rfc3692)
-     EXP1("Experimental1", 253),
-     EXP2("Experimental2", 254),
-
-     RESERVED("RESERVED",255);
-
-    private String protocolName;
-    private int protocolNumber;
-
-    private IPProtocols(String name, int number) {
-        protocolName = name;
-        protocolNumber = number;
-    }
-
-    public int intValue() {
-        return protocolNumber;
-    }
-
-    public short shortValue() {
-        return ((Integer) protocolNumber).shortValue();
-    }
-
-    public byte byteValue() {
-        return ((Integer) protocolNumber).byteValue();
-    }
-
-    @Override
-    public String toString() {
-        return protocolName;
-    }
-
-    public static String getProtocolName(int number) {
-        return getProtocolNameInternal(number);
-    }
-
-    public static String getProtocolName(short number) {
-        return getProtocolNameInternal(number & 0xffff);
-    }
-
-    public static String getProtocolName(byte number) {
-        return getProtocolNameInternal(number & 0xff);
-    }
-
-    private static String getProtocolNameInternal(int number) {
-        for (IPProtocols proto : IPProtocols.values()) {
-            if (proto.protocolNumber == number) {
-                return proto.toString();
-            }
-        }
-        //TODO: this is for backwards compatibility
-        return "0x" + Integer.toHexString(number);
-    }
-
-    public static short getProtocolNumberShort(String name) {
-        IPProtocols p = fromString(name);
-        if (p != null) {
-            return p.shortValue();
-        }
-        //This method should be called after validation only
-        throw new IllegalArgumentException("Illegal IP protocol value: " + name);
-    }
-
-    public static int getProtocolNumberInt(String name) {
-        IPProtocols p = fromString(name);
-        if (p != null) {
-            return p.intValue();
-        }
-        //This method should be called after validation only
-        throw new IllegalArgumentException("Illegal IP protocol value: " + name);
-    }
-
-    public static byte getProtocolNumberByte(String name) {
-        IPProtocols p = fromString(name);
-        if (p != null) {
-            return p.byteValue();
-        }
-        //This method should be called after validation only
-        throw new IllegalArgumentException("Illegal IP protocol value: " + name);
-    }
-
-    public static List<String> getProtocolNameList() {
-        List<String> protoList = new ArrayList<String>();
-        for (IPProtocols proto : IPProtocols.values()) {
-            protoList.add(proto.toString());
-        }
-        return protoList;
-    }
-
-    /**
-     * Method to parse an IPProtocol from a numeric string
-     * (see: {@link Java.Lang.Integer.decode(java.lang.String)} for parsable strings),
-     * or this enum's name string.
-     *
-     * @param s
-     *            The IP protocol string to be parsed
-     * @return The IP protocol Enum, or null if invalid protocol string is passed
-     */
-    public static IPProtocols fromString(String s) {
-        // null/empty/any/* evaluates to ANY
-        if (s == null || s.isEmpty() || s.equalsIgnoreCase("any") || s.equals("*")) {
-            return IPProtocols.ANY;
-        }
-
-        // Try parsing numeric and find the related ENUM
-        try {
-            int protoNum = Integer.decode(s);
-            for (IPProtocols protoEnum : IPProtocols.values()) {
-                if (protoEnum.protocolNumber == protoNum) {
-                    return protoEnum;
-                }
-            }
-            // At this point it's an invalid number (i.e. out of range or not a valid proto num)
-            return null;
-        } catch (NumberFormatException nfe) {
-            // numeric failed try by NAME
-            try {
-                return valueOf(s);
-            } catch(IllegalArgumentException e) {
-                // Neither numeric nor enum NAME, attempt human readable name
-                for (IPProtocols protoEnum : IPProtocols.values()) {
-                    if (protoEnum.toString().equalsIgnoreCase(s)) {
-                        return protoEnum;
-                    }
-                }
-                //couldn't parse, signifies an invalid proto field!
-                return null;
-            }
-
-        }
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/IterableIterator.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/IterableIterator.java
deleted file mode 100644 (file)
index 8a72028..0000000
+++ /dev/null
@@ -1,84 +0,0 @@
-/*
- * Copyright (c) 2012 Big Switch Networks, Inc.
- *
- * Licensed under the Eclipse Public License, Version 1.0 (the
- * "License"); you may not use this file except in compliance with the
- * License. You may obtain a copy of the License at
- *
- *      http://www.eclipse.org/legal/epl-v10.html
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
- * implied. See the License for the specific language governing
- * permissions and limitations under the License.
- *
- * This file incorporates work covered by the following copyright and
- * permission notice:
- *
- *    Originally created by David Erickson, Stanford University
- *
- *    Licensed under the Apache License, Version 2.0 (the "License");
- *    you may not use this file except in compliance with the
- *    License. You may obtain a copy of the License at
- *
- *         http://www.apache.org/licenses/LICENSE-2.0
- *
- *    Unless required by applicable law or agreed to in writing,
- *    software distributed under the License is distributed on an "AS
- *    IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
- *    express or implied. See the License for the specific language
- *    governing permissions and limitations under the License.
- */
-
-package org.opendaylight.controller.sal.utils;
-
-import java.util.Iterator;
-import java.util.NoSuchElementException;
-
-/**
- * Iterator over all values in an iterator of iterators
- *
- * @param <T>
- *            the type of elements returned by this iterator
- */
-@Deprecated
-public class IterableIterator<T> implements Iterator<T> {
-    Iterator<? extends Iterable<T>> subIterator;
-    Iterator<T> current = null;
-
-    public IterableIterator(Iterator<? extends Iterable<T>> subIterator) {
-        super();
-        this.subIterator = subIterator;
-    }
-
-    @Override
-    public boolean hasNext() {
-        if (current == null) {
-            if (subIterator.hasNext()) {
-                current = subIterator.next().iterator();
-            } else {
-                return false;
-            }
-        }
-        while (!current.hasNext() && subIterator.hasNext()) {
-            current = subIterator.next().iterator();
-        }
-
-        return current.hasNext();
-    }
-
-    @Override
-    public T next() {
-        if (hasNext())
-            return current.next();
-        throw new NoSuchElementException();
-    }
-
-    @Override
-    public void remove() {
-        if (hasNext())
-            current.remove();
-        throw new NoSuchElementException();
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/ListenerDispatcher.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/ListenerDispatcher.java
deleted file mode 100644 (file)
index 2a4ea3d..0000000
+++ /dev/null
@@ -1,147 +0,0 @@
-/*
- * Copyright (c) 2011 Big Switch Networks, Inc.
- *
- * Licensed under the Eclipse Public License, Version 1.0 (the
- * "License"); you may not use this file except in compliance with the
- * License. You may obtain a copy of the License at
- *
- *      http://www.eclipse.org/legal/epl-v10.html
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
- * implied. See the License for the specific language governing
- * permissions and limitations under the License.
- *
- * This file incorporates work covered by the following copyright and
- * permission notice:
- *
- *    Originally created by David Erickson, Stanford University
- *
- *    Licensed under the Apache License, Version 2.0 (the "License");
- *    you may not use this file except in compliance with the
- *    License. You may obtain a copy of the License at
- *
- *         http://www.apache.org/licenses/LICENSE-2.0
- *
- *    Unless required by applicable law or agreed to in writing,
- *    software distributed under the License is distributed on an "AS
- *    IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
- *    express or implied. See the License for the specific language
- *    governing permissions and limitations under the License.
- */
-
-package org.opendaylight.controller.sal.utils;
-
-import java.util.ArrayList;
-import java.util.HashSet;
-import java.util.List;
-
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * Maintain lists of listeners ordered by dependency.
- *
- * @author readams
- *
- */
-@Deprecated
-public class ListenerDispatcher<U, T extends IListener<U>> {
-    protected static Logger logger = LoggerFactory
-            .getLogger(ListenerDispatcher.class);
-    volatile List<T> listeners = new ArrayList<T>();
-
-    private void visit(List<T> newlisteners, U type, HashSet<T> visited,
-            List<T> ordering, T listener) {
-        if (!visited.contains(listener)) {
-            visited.add(listener);
-
-            for (T i : newlisteners) {
-                if (ispre(type, i, listener)) {
-                    visit(newlisteners, type, visited, ordering, i);
-                }
-            }
-            ordering.add(listener);
-        }
-    }
-
-    private boolean ispre(U type, T l1, T l2) {
-        return (l2.isCallbackOrderingPrereq(type, l1.getName()) || l1
-                .isCallbackOrderingPostreq(type, l2.getName()));
-    }
-
-    /**
-     * Add a listener to the list of listeners
-     *
-     * @param listener
-     */
-    public void addListener(U type, T listener) {
-        List<T> newlisteners = new ArrayList<T>();
-        if (listeners != null)
-            newlisteners.addAll(listeners);
-
-        newlisteners.add(listener);
-        // Find nodes without outgoing edges
-        List<T> terminals = new ArrayList<T>();
-        for (T i : newlisteners) {
-            boolean isterm = true;
-            for (T j : newlisteners) {
-                if (ispre(type, i, j)) {
-                    isterm = false;
-                    break;
-                }
-            }
-            if (isterm) {
-                terminals.add(i);
-            }
-        }
-
-        if (terminals.size() == 0) {
-            logger.error("No listener dependency solution: "
-                    + "No listeners without incoming dependencies");
-            listeners = newlisteners;
-            return;
-        }
-
-        // visit depth-first traversing in the opposite order from
-        // the dependencies. Note we will not generally detect cycles
-        HashSet<T> visited = new HashSet<T>();
-        List<T> ordering = new ArrayList<T>();
-        for (T term : terminals) {
-            visit(newlisteners, type, visited, ordering, term);
-        }
-        listeners = ordering;
-    }
-
-    /**
-     * Remove the given listener
-     *
-     * @param listener
-     *            the listener to remove
-     */
-    public void removeListener(T listener) {
-        if (listeners != null) {
-            List<T> newlisteners = new ArrayList<T>();
-            newlisteners.addAll(listeners);
-            newlisteners.remove(listener);
-            listeners = newlisteners;
-        }
-    }
-
-    /**
-     * Clear all listeners
-     */
-    public void clearListeners() {
-        listeners = new ArrayList<T>();
-    }
-
-    /**
-     * Get the ordered list of listeners ordered by dependencies
-     *
-     * @return
-     */
-    public List<T> getOrderedListeners() {
-        return listeners;
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/MultiIterator.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/MultiIterator.java
deleted file mode 100644 (file)
index fbb4088..0000000
+++ /dev/null
@@ -1,84 +0,0 @@
-/*
- * Copyright (c) 2012 Big Switch Networks, Inc.
- *
- * Licensed under the Eclipse Public License, Version 1.0 (the
- * "License"); you may not use this file except in compliance with the
- * License. You may obtain a copy of the License at
- *
- *      http://www.eclipse.org/legal/epl-v10.html
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
- * implied. See the License for the specific language governing
- * permissions and limitations under the License.
- *
- * This file incorporates work covered by the following copyright and
- * permission notice:
- *
- *    Originally created by David Erickson, Stanford University
- *
- *    Licensed under the Apache License, Version 2.0 (the "License");
- *    you may not use this file except in compliance with the
- *    License. You may obtain a copy of the License at
- *
- *         http://www.apache.org/licenses/LICENSE-2.0
- *
- *    Unless required by applicable law or agreed to in writing,
- *    software distributed under the License is distributed on an "AS
- *    IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
- *    express or implied. See the License for the specific language
- *    governing permissions and limitations under the License.
- */
-
-package org.opendaylight.controller.sal.utils;
-
-import java.util.Iterator;
-import java.util.NoSuchElementException;
-
-/**
- * Iterator over all values in an iterator of iterators
- *
- * @param <T>
- *            the type of elements returned by this iterator
- */
-@Deprecated
-public class MultiIterator<T> implements Iterator<T> {
-    Iterator<Iterator<T>> subIterator;
-    Iterator<T> current = null;
-
-    public MultiIterator(Iterator<Iterator<T>> subIterator) {
-        super();
-        this.subIterator = subIterator;
-    }
-
-    @Override
-    public boolean hasNext() {
-        if (current == null) {
-            if (subIterator.hasNext()) {
-                current = subIterator.next();
-            } else {
-                return false;
-            }
-        }
-        while (!current.hasNext() && subIterator.hasNext()) {
-            current = subIterator.next();
-        }
-
-        return current.hasNext();
-    }
-
-    @Override
-    public T next() {
-        if (hasNext())
-            return current.next();
-        throw new NoSuchElementException();
-    }
-
-    @Override
-    public void remove() {
-        if (hasNext())
-            current.remove();
-        throw new NoSuchElementException();
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/NetUtils.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/NetUtils.java
deleted file mode 100644 (file)
index 79b1778..0000000
+++ /dev/null
@@ -1,522 +0,0 @@
-/*
- * Copyright (c) 2013-2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.utils;
-
-import java.net.Inet4Address;
-import java.net.Inet6Address;
-import java.net.InetAddress;
-import java.net.UnknownHostException;
-import java.util.Arrays;
-import java.util.regex.Matcher;
-import java.util.regex.Pattern;
-
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * Utility class containing the common utility functions needed for operating on
- * networking data structures
- */
-@Deprecated
-public abstract class NetUtils {
-    protected static final Logger logger = LoggerFactory.getLogger(NetUtils.class);
-    /**
-     * Constant holding the number of bits in a byte
-     */
-    public static final int NumBitsInAByte = 8;
-
-    /**
-     * Constant holding the number of bytes in MAC Address
-     */
-    public static final int MACAddrLengthInBytes = 6;
-
-    /**
-     * Constant holding the number of words in MAC Address
-     */
-    public static final int MACAddrLengthInWords = 3;
-
-    /**
-     * Constant holding the broadcast MAC address
-     */
-    private static final byte[] BroadcastMACAddr = {-1, -1, -1, -1, -1, -1};
-
-    /**
-     * Converts a 4 bytes array into an integer number
-     *
-     * @param ba
-     *            the 4 bytes long byte array
-     * @return the integer number
-     */
-    public static int byteArray4ToInt(byte[] ba) {
-        if (ba == null || ba.length != 4) {
-            return 0;
-        }
-        return (0xff & ba[0]) << 24 | (0xff & ba[1]) << 16 | (0xff & ba[2]) << 8 | (0xff & ba[3]);
-    }
-
-    /**
-     * Converts a 6 bytes array into a long number MAC addresses.
-     *
-     * @param ba
-     *            The 6 bytes long byte array.
-     * @return The long number.
-     *         Zero is returned if {@code ba} is {@code null} or
-     *         the length of it is not six.
-     */
-    public static long byteArray6ToLong(byte[] ba) {
-        if (ba == null || ba.length != MACAddrLengthInBytes) {
-            return 0L;
-        }
-        long num = 0L;
-        int i = 0;
-        do {
-            num <<= NumBitsInAByte;
-            num |= 0xff & ba[i];
-            i++;
-        } while (i < MACAddrLengthInBytes);
-        return num;
-    }
-
-    /**
-     * Converts a long number to a 6 bytes array for MAC addresses.
-     *
-     * @param addr
-     *            The long number.
-     * @return The byte array.
-     */
-    public static byte[] longToByteArray6(long addr){
-        byte[] mac = new byte[MACAddrLengthInBytes];
-        int i = MACAddrLengthInBytes - 1;
-        do {
-            mac[i] = (byte) addr;
-            addr >>>= NumBitsInAByte;
-            i--;
-        } while (i >= 0);
-        return mac;
-    }
-
-    /**
-     * Converts an integer number into a 4 bytes array
-     *
-     * @param i
-     *            the integer number
-     * @return the byte array
-     */
-    public static byte[] intToByteArray4(int i) {
-        return new byte[] { (byte) ((i >> 24) & 0xff), (byte) ((i >> 16) & 0xff), (byte) ((i >> 8) & 0xff),
-                (byte) (i & 0xff) };
-    }
-
-    /**
-     * Converts an IP address passed as integer value into the respective
-     * InetAddress object
-     *
-     * @param address
-     *            the IP address in integer form
-     * @return the IP address in InetAddress form
-     */
-    public static InetAddress getInetAddress(int address) {
-        InetAddress ip = null;
-        try {
-            ip = InetAddress.getByAddress(NetUtils.intToByteArray4(address));
-        } catch (UnknownHostException e) {
-            logger.error("", e);
-        }
-        return ip;
-    }
-
-    /**
-     * Return the InetAddress Network Mask given the length of the prefix bit
-     * mask. The prefix bit mask indicates the contiguous leading bits that are
-     * NOT masked out. Example: A prefix bit mask length of 8 will give an
-     * InetAddress Network Mask of 255.0.0.0
-     *
-     * @param prefixMaskLength
-     *            integer representing the length of the prefix network mask
-     * @param isV6
-     *            boolean representing the IP version of the returned address
-     * @return
-     */
-    public static InetAddress getInetNetworkMask(int prefixMaskLength, boolean isV6) {
-        if (prefixMaskLength < 0 || (!isV6 && prefixMaskLength > 32) || (isV6 && prefixMaskLength > 128)) {
-            return null;
-        }
-        byte v4Address[] = { 0, 0, 0, 0 };
-        byte v6Address[] = { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 };
-        byte address[] = (isV6) ? v6Address : v4Address;
-        int numBytes = prefixMaskLength / 8;
-        int numBits = prefixMaskLength % 8;
-        int i = 0;
-        for (; i < numBytes; i++) {
-            address[i] = (byte) 0xff;
-        }
-        if (numBits > 0) {
-            int rem = 0;
-            for (int j = 0; j < numBits; j++) {
-                rem |= 1 << (7 - j);
-            }
-            address[i] = (byte) rem;
-        }
-
-        try {
-            return InetAddress.getByAddress(address);
-        } catch (UnknownHostException e) {
-            logger.error("", e);
-        }
-        return null;
-    }
-
-    /**
-     * Returns the prefix size in bits of the specified subnet mask. Example:
-     * For the subnet mask ff.ff.ff.e0 it returns 25 while for ff.00.00.00 it
-     * returns 8. If the passed subnetMask array is null, 0 is returned.
-     *
-     * @param subnetMask
-     *            the subnet mask as byte array
-     * @return the prefix length as number of bits
-     */
-    public static int getSubnetMaskLength(byte[] subnetMask) {
-        int maskLength = 0;
-        if (subnetMask != null && (subnetMask.length == 4 || subnetMask.length == 16)) {
-            int index = 0;
-            while (index < subnetMask.length && subnetMask[index] == (byte) 0xFF) {
-                maskLength += NetUtils.NumBitsInAByte;
-                index++;
-            }
-            if (index != subnetMask.length) {
-                int bits = NetUtils.NumBitsInAByte - 1;
-                while (bits >= 0 && (subnetMask[index] & 1 << bits)  != 0) {
-                    bits--;
-                    maskLength++;
-                }
-            }
-        }
-        return maskLength;
-    }
-
-    /**
-     * Returns the prefix size in bits of the specified subnet mask. Example:
-     * For the subnet mask 255.255.255.128 it returns 25 while for 255.0.0.0 it
-     * returns 8. If the passed subnetMask object is null, 0 is returned
-     *
-     * @param subnetMask
-     *            the subnet mask as InetAddress
-     * @return the prefix length as number of bits
-     */
-    public static int getSubnetMaskLength(InetAddress subnetMask) {
-        return subnetMask == null ? 0 : NetUtils.getSubnetMaskLength(subnetMask.getAddress());
-    }
-
-    /**
-     * Given an IP address and a prefix network mask length, it returns the
-     * equivalent subnet prefix IP address Example: for ip = "172.28.30.254" and
-     * maskLen = 25 it will return "172.28.30.128"
-     *
-     * @param ip
-     *            the IP address in InetAddress form
-     * @param maskLen
-     *            the length of the prefix network mask
-     * @return the subnet prefix IP address in InetAddress form
-     */
-    public static InetAddress getSubnetPrefix(InetAddress ip, int maskLen) {
-        int bytes = maskLen / 8;
-        int bits = maskLen % 8;
-        byte modifiedByte;
-        byte[] sn = ip.getAddress();
-        if (bits > 0) {
-            modifiedByte = (byte) (sn[bytes] >> (8 - bits));
-            sn[bytes] = (byte) (modifiedByte << (8 - bits));
-            bytes++;
-        }
-        for (; bytes < sn.length; bytes++) {
-            sn[bytes] = (byte) (0);
-        }
-        try {
-            return InetAddress.getByAddress(sn);
-        } catch (UnknownHostException e) {
-            return null;
-        }
-    }
-
-    /**
-     * Checks if the test address and mask conflicts with the filter address and
-     * mask
-     *
-     * For example:
-     * testAddress: 172.28.2.23
-     * testMask: 255.255.255.0
-     * filterAddress: 172.28.1.10
-     * testMask: 255.255.255.0
-     * do conflict
-     *
-     * testAddress: 172.28.2.23
-     * testMask: 255.255.255.0
-     * filterAddress: 172.28.1.10
-     * testMask: 255.255.0.0
-     * do not conflict
-     *
-     * Null parameters are permitted
-     *
-     * @param testAddress
-     * @param filterAddress
-     * @param testMask
-     * @param filterMask
-     * @return
-     */
-    public static boolean inetAddressConflict(InetAddress testAddress, InetAddress filterAddress, InetAddress testMask,
-            InetAddress filterMask) {
-        // Sanity check
-        if ((testAddress == null) || (filterAddress == null)) {
-            return false;
-        }
-
-        // Presence check
-        if (isAny(testAddress) || isAny(filterAddress)) {
-            return false;
-        }
-
-        int testMaskLen = (testMask == null) ? ((testAddress instanceof Inet4Address) ? 32 : 128) : NetUtils
-                .getSubnetMaskLength(testMask);
-        int filterMaskLen = (filterMask == null) ? ((testAddress instanceof Inet4Address) ? 32 : 128) : NetUtils
-                .getSubnetMaskLength(filterMask);
-
-        // Mask length check. Test mask has to be more specific than filter one
-        if (testMaskLen < filterMaskLen) {
-            return true;
-        }
-
-        // Subnet Prefix on filter mask length must be the same
-        InetAddress prefix1 = getSubnetPrefix(testAddress, filterMaskLen);
-        InetAddress prefix2 = getSubnetPrefix(filterAddress, filterMaskLen);
-        return (!prefix1.equals(prefix2));
-    }
-
-    /**
-     * Returns true if the passed MAC address is all zero
-     *
-     * @param mac
-     *            the byte array representing the MAC address
-     * @return true if all MAC bytes are zero
-     */
-    public static boolean isZeroMAC(byte[] mac) {
-        for (short i = 0; i < 6; i++) {
-            if (mac[i] != 0) {
-                return false;
-            }
-        }
-        return true;
-    }
-
-    /**
-     * Returns true if the MAC address is the broadcast MAC address and false
-     * otherwise.
-     *
-     * @param MACAddress
-     * @return
-     */
-    public static boolean isBroadcastMACAddr(byte[] MACAddress) {
-        if (MACAddress.length == MACAddrLengthInBytes) {
-            for (int i = 0; i < 6; i++) {
-                if (MACAddress[i] != BroadcastMACAddr[i]) {
-                    return false;
-                }
-            }
-            return true;
-        }
-
-        return false;
-    }
-    /**
-     * Returns true if the MAC address is a unicast MAC address and false
-     * otherwise.
-     *
-     * @param MACAddress
-     * @return
-     */
-    public static boolean isUnicastMACAddr(byte[] MACAddress) {
-        if (MACAddress.length == MACAddrLengthInBytes) {
-            return (MACAddress[0] & 1) == 0;
-        }
-        return false;
-    }
-
-    /**
-     * Returns true if the MAC address is a multicast MAC address and false
-     * otherwise. Note that this explicitly returns false for the broadcast MAC
-     * address.
-     *
-     * @param MACAddress
-     * @return
-     */
-    public static boolean isMulticastMACAddr(byte[] MACAddress) {
-        if (MACAddress.length == MACAddrLengthInBytes && !isBroadcastMACAddr(MACAddress)) {
-            return (MACAddress[0] & 1) != 0;
-        }
-        return false;
-    }
-
-    /**
-     * Returns true if the passed InetAddress contains all zero
-     *
-     * @param ip
-     *            the IP address to test
-     * @return true if the address is all zero
-     */
-    public static boolean isAny(InetAddress ip) {
-        for (byte b : ip.getAddress()) {
-            if (b != 0) {
-                return false;
-            }
-        }
-        return true;
-    }
-
-    public static boolean fieldsConflict(int field1, int field2) {
-        if ((field1 == 0) || (field2 == 0) || (field1 == field2)) {
-            return false;
-        }
-        return true;
-    }
-
-    public static InetAddress parseInetAddress(String addressString) {
-        InetAddress address = null;
-        try {
-            address = InetAddress.getByName(addressString);
-        } catch (UnknownHostException e) {
-            logger.error("", e);
-        }
-        return address;
-    }
-
-    /**
-     * Checks if the passed IP v4 address in string form is valid The address
-     * may specify a mask at the end as "/MM"
-     *
-     * @param cidr
-     *            the v4 address as A.B.C.D/MM
-     * @return
-     */
-    public static boolean isIPv4AddressValid(String cidr) {
-        if (cidr == null) {
-            return false;
-        }
-
-        String values[] = cidr.split("/");
-        Pattern ipv4Pattern = Pattern
-                .compile("(([01]?\\d\\d?|2[0-4]\\d|25[0-5])\\.){3}([01]?\\d\\d?|2[0-4]\\d|25[0-5])");
-        Matcher mm = ipv4Pattern.matcher(values[0]);
-        if (!mm.matches()) {
-            return false;
-        }
-        if (values.length >= 2) {
-            int prefix = Integer.valueOf(values[1]);
-            if ((prefix < 0) || (prefix > 32)) {
-                return false;
-            }
-        }
-        return true;
-    }
-
-    /**
-     * Checks if the passed IP v6 address in string form is valid The address
-     * may specify a mask at the end as "/MMM"
-     *
-     * @param cidr
-     *            the v6 address as A::1/MMM
-     * @return
-     */
-    public static boolean isIPv6AddressValid(String cidr) {
-        if (cidr == null) {
-            return false;
-        }
-
-        String values[] = cidr.split("/");
-        try {
-            // when given an IP address, InetAddress.getByName validates the ip
-            // address
-            InetAddress addr = InetAddress.getByName(values[0]);
-            if (!(addr instanceof Inet6Address)) {
-                return false;
-            }
-        } catch (UnknownHostException ex) {
-            return false;
-        }
-
-        if (values.length >= 2) {
-            int prefix = Integer.valueOf(values[1]);
-            if ((prefix < 0) || (prefix > 128)) {
-                return false;
-            }
-        }
-        return true;
-    }
-
-    /**
-     * Checks if the passed IP address in string form is a valid v4 or v6
-     * address. The address may specify a mask at the end as "/MMM"
-     *
-     * @param cidr
-     *            the v4 or v6 address as IP/MMM
-     * @return
-     */
-    public static boolean isIPAddressValid(String cidr) {
-        return NetUtils.isIPv4AddressValid(cidr) || NetUtils.isIPv6AddressValid(cidr);
-    }
-
-    /*
-     * Following utilities are useful when you need to compare or bit shift java
-     * primitive type variable which are inherently signed
-     */
-    /**
-     * Returns the unsigned value of the passed byte variable
-     *
-     * @param b
-     *            the byte value
-     * @return the int variable containing the unsigned byte value
-     */
-    public static int getUnsignedByte(byte b) {
-        return b & 0xFF;
-    }
-
-    /**
-     * Return the unsigned value of the passed short variable
-     *
-     * @param s
-     *            the short value
-     * @return the int variable containing the unsigned short value
-     */
-    public static int getUnsignedShort(short s) {
-        return s & 0xFFFF;
-    }
-
-    /**
-     * Returns the highest v4 or v6 InetAddress
-     *
-     * @param v6
-     *            true for IPv6, false for Ipv4
-     * @return The highest IPv4 or IPv6 address
-     */
-    public static InetAddress gethighestIP(boolean v6) {
-        try {
-            return (v6) ? InetAddress.getByName("ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff") : InetAddress
-                    .getByName("255.255.255.255");
-        } catch (UnknownHostException e) {
-            return null;
-        }
-    }
-
-    /**
-     * Returns Broadcast MAC Address
-     *
-     * @return the byte array containing  broadcast mac address
-     */
-    public static byte[] getBroadcastMACAddr() {
-        return Arrays.copyOf(BroadcastMACAddr, BroadcastMACAddr.length);
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/NodeConnectorCreator.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/NodeConnectorCreator.java
deleted file mode 100644 (file)
index df57e0e..0000000
+++ /dev/null
@@ -1,113 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.utils;
-
-import java.util.HashSet;
-import java.util.Set;
-
-import org.opendaylight.controller.sal.core.ConstructionException;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.Node.NodeIDType;
-import org.opendaylight.controller.sal.core.NodeConnector.NodeConnectorIDType;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * The class provides helper functions to create a node connector
- *
- *
- */
-@Deprecated
-public abstract class NodeConnectorCreator {
-    protected static final Logger logger = LoggerFactory
-    .getLogger(NodeConnectorCreator.class);
-    /**
-     * Generic NodeConnector creator
-     * The nodeConnector type is inferred from the node type
-     *
-     * @param portId
-     * @param node
-     * @return
-     */
-    public static NodeConnector createNodeConnector(Object portId, Node node) {
-        if (node.getType().equals(NodeIDType.OPENFLOW)) {
-            try {
-                return new NodeConnector(NodeConnectorIDType.OPENFLOW,
-                        portId, node);
-            } catch (ConstructionException e1) {
-                logger.error("",e1);
-                return null;
-            }
-        }
-        return null;
-    }
-
-    /**
-     * Generic NodeConnector creator
-     * The nodeConnector type is inferred from the node type
-     *
-     * @param portId The string representing the port id
-     * @param node The network node as {@link org.opendaylight.controller.sal.core.Node Node} object
-     * @return The corresponding {@link org.opendaylight.controller.sal.core.NodeConnector NodeConnector} object
-     */
-    public static NodeConnector createNodeConnector(String portId, Node node) {
-        return NodeConnector.fromString(String.format("%s|%s@%s", node.getType(), portId, node.toString()));
-    }
-
-    /**
-     * NodeConnector creator where NodeConnector type can be specified
-     * Needed to create special internal node connectors (like software stack)
-     *
-     * @param nodeConnectorType
-     * @param portId
-     * @param node
-     * @return
-     */
-    public static NodeConnector createNodeConnector(
-            String nodeConnectorType, Object portId, Node node) {
-        try {
-            if (nodeConnectorType.equals(Node.NodeIDType.OPENFLOW) && (portId.getClass() == String.class)) {
-                return new NodeConnector(nodeConnectorType, Short.parseShort((String) portId), node);
-            } else {
-                return new NodeConnector(nodeConnectorType, portId, node);
-            }
-        } catch (ConstructionException e1) {
-            logger.error("",e1);
-            return null;
-        }
-    }
-
-    public static NodeConnector createOFNodeConnector(Short portId, Node node) {
-        try {
-            return new NodeConnector(NodeConnectorIDType.OPENFLOW, portId, node);
-        } catch (ConstructionException e1) {
-            logger.error("",e1);
-            return null;
-        }
-    }
-
-    public static Set<NodeConnector> createOFNodeConnectorSet(
-            Set<Short> portIds, Node n) {
-        try {
-            Set<NodeConnector> nodeConnectors = new HashSet<NodeConnector>();
-            for (Short ofPortID : portIds) {
-                NodeConnector p = new NodeConnector(
-                        NodeConnector.NodeConnectorIDType.OPENFLOW, Short
-                                .valueOf(ofPortID), n);
-                nodeConnectors.add(p);
-            }
-            return nodeConnectors;
-        } catch (ConstructionException e1) {
-            logger.error("",e1);
-            return null;
-        }
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/NodeCreator.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/NodeCreator.java
deleted file mode 100644 (file)
index 3e4339a..0000000
+++ /dev/null
@@ -1,36 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.utils;
-
-import org.opendaylight.controller.sal.core.ConstructionException;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.Node.NodeIDType;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * Utility class for creating a Node object
- *
- *
- *
- */
-@Deprecated
-public abstract class NodeCreator {
-    protected static final Logger logger = LoggerFactory.getLogger(NodeCreator.class);
-
-    public static Node createOFNode(Long switchId) {
-        try {
-            return new Node(NodeIDType.OPENFLOW, switchId);
-        } catch (ConstructionException e1) {
-            logger.error("",e1);
-            return null;
-        }
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/NodeTableCreator.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/NodeTableCreator.java
deleted file mode 100644 (file)
index d6793d7..0000000
+++ /dev/null
@@ -1,47 +0,0 @@
-/*
- * Copyright (c) 2013 Big Switch Networks, Inc.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.sal.utils;
-
-import org.opendaylight.controller.sal.core.ConstructionException;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeTable;
-import org.opendaylight.controller.sal.core.NodeTable.NodeTableIDType;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-@Deprecated
-public class NodeTableCreator {
-    protected static final Logger logger = LoggerFactory
-            .getLogger(NodeTableCreator.class);
-
-    /**
-     * Generic NodeTable creator
-     * The nodeTable type is OPENFLOW only for the time being
-     *
-     * @param portId
-     * @param node
-     * @return
-     */
-    public static NodeTable createNodeTable(byte tableId, Node node) {
-        try {
-            return new NodeTable(NodeTableIDType.OPENFLOW, tableId, node);
-        } catch (ConstructionException e1) {
-            logger.error("",e1);
-            return null;
-        }
-    }
-
-    public static NodeTable createOFNodeTable(byte tableId, Node node) {
-        try {
-            return new NodeTable(NodeTableIDType.OPENFLOW, tableId, node);
-        } catch (ConstructionException e1) {
-            logger.error("",e1);
-            return null;
-        }
-    }
-
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/ObjectReader.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/ObjectReader.java
deleted file mode 100644 (file)
index 042e71e..0000000
+++ /dev/null
@@ -1,69 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.utils;
-
-import java.io.FileInputStream;
-import java.io.FileNotFoundException;
-import java.io.IOException;
-import java.io.ObjectInputStream;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * Read object to read from file stream
- *
- *
- *
- */
-@Deprecated
-public class ObjectReader {
-    private static Logger logger = LoggerFactory.getLogger(ObjectReader.class);
-    private FileInputStream fis;
-    public ObjectInputStream ois;
-
-    public ObjectReader() {
-        fis = null;
-        ois = null;
-    }
-
-    public Object read(IObjectReader reader, String file) {
-        Object obj = null;
-        try {
-            fis = new FileInputStream(file);
-            ois = new ObjectInputStream(fis);
-            obj = reader.readObject(ois);
-        } catch (FileNotFoundException fnfex) {
-            //logger.info("Cannot find {} for reading", file);
-        } catch (IOException ioex) {
-            logger.error("Failed to read from {}", file);
-        } catch (ClassNotFoundException cnfex) {
-            logger.error("Failed to interpret content of {}", file);
-        } catch (Exception e) {
-
-        } finally {
-            if (ois != null) {
-                try {
-                    ois.close();
-                } catch (IOException ioex) {
-                    logger.error("Failed to close object input stream: {}",
-                            file);
-                }
-            }
-            if (fis != null) {
-                try {
-                    fis.close();
-                } catch (IOException ioex) {
-                    logger.error("Failed to close input file stream: {}", file);
-                }
-            }
-        }
-        return obj;
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/ObjectWriter.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/ObjectWriter.java
deleted file mode 100644 (file)
index 22a83ca..0000000
+++ /dev/null
@@ -1,67 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.utils;
-
-import java.io.FileNotFoundException;
-import java.io.FileOutputStream;
-import java.io.IOException;
-import java.io.ObjectOutputStream;
-
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * Write object to write to file stream
- *
- */
-@Deprecated
-public class ObjectWriter {
-    private static Logger logger = LoggerFactory.getLogger(ObjectWriter.class);
-    private FileOutputStream fos;
-    private ObjectOutputStream oos;
-
-    public ObjectWriter() {
-        fos = null;
-        oos = null;
-    }
-
-    public Status write(Object obj, String file) {
-        try {
-            fos = new FileOutputStream(file);
-            oos = new ObjectOutputStream(fos);
-            oos.writeObject(obj);
-        } catch (FileNotFoundException fex) {
-            logger.error("Cannot create {} for writing", file);
-            return new Status(StatusCode.INTERNALERROR, "IO Error");
-        } catch (IOException ioex) {
-            logger.error("Failed to write to {}", file);
-            return new Status(StatusCode.INTERNALERROR, "IO Error");
-        } finally {
-            if (oos != null) {
-                try {
-                    oos.close();
-                } catch (IOException ioex) {
-                    logger.error("Failed to close object output stream: {}",
-                            file);
-                }
-            }
-            if (fos != null) {
-                try {
-                    fos.close();
-                } catch (IOException ioex) {
-                    logger
-                            .error("Failed to close output file stream: {}",
-                                    file);
-                }
-            }
-        }
-        return new Status(StatusCode.SUCCESS);
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/ReadFromFile.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/ReadFromFile.java
deleted file mode 100644 (file)
index 8ec3f8a..0000000
+++ /dev/null
@@ -1,58 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.utils;
-
-import java.io.BufferedReader;
-import java.io.DataInputStream;
-import java.io.File;
-import java.io.FileInputStream;
-import java.io.FileNotFoundException;
-import java.io.IOException;
-import java.io.InputStreamReader;
-import java.util.ArrayList;
-
-/**
- * Convenience object for reading from file
- *
- *
- *
- */
-@Deprecated
-public class ReadFromFile {
-    private FileInputStream fileStream;
-    private File filePointer;
-
-    public ReadFromFile(String fileName) throws FileNotFoundException {
-        fileStream = new FileInputStream(fileName);
-        filePointer = new File(fileName); //needed to allow file deletion
-    }
-
-    public ArrayList<String> readFile() throws IOException {
-        DataInputStream dataInput = new DataInputStream(this.fileStream);
-        BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(dataInput));
-
-        ArrayList<String> lineList = new ArrayList<String>();
-        String line;
-        while ((line = bufferedReader.readLine()) != null) {
-            lineList.add(line);
-        }
-        bufferedReader.close();
-        dataInput.close();
-        fileStream.close();
-        return lineList;
-    }
-
-    public boolean delete() {
-        if (filePointer == null) {
-            return true;
-        }
-        return filePointer.delete();
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/ServiceHelper.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/ServiceHelper.java
deleted file mode 100644 (file)
index 95aa683..0000000
+++ /dev/null
@@ -1,262 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * @file   ServiceHelper.java
- *
- * @brief  The class helps to register and retrieve OSGi service registry
- */
-package org.opendaylight.controller.sal.utils;
-
-import java.util.Hashtable;
-import org.osgi.framework.ServiceRegistration;
-import java.util.Dictionary;
-import org.osgi.framework.BundleContext;
-import org.osgi.framework.FrameworkUtil;
-import org.osgi.framework.ServiceReference;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * The class helps to register and retrieve OSGi service registry
- *
- *
- */
-@Deprecated
-public class ServiceHelper {
-    private static final Logger logger = LoggerFactory
-            .getLogger(ServiceHelper.class);
-
-    /**
-     * Register a Service in the OSGi service registry
-     *
-     * @param clazz The target class
-     * @param containerName The container name
-     * @param instance of the object exporting the service, be careful
-     * the object must implement/extend clazz else the registration
-     * will fail unless a ServiceFactory is passed as parameter
-     * @param properties The properties to be attached to the service
-     * registration
-     * @return true if registration happened, false otherwise
-     */
-    public static boolean registerService(Class<?> clazz, String containerName,
-            Object instance, Dictionary<String, Object> properties) {
-        if (properties == null) {
-            properties = (Dictionary<String, Object>) new Hashtable<String, Object>();
-        }
-        properties.put("containerName", containerName);
-        return registerGlobalService(clazz, instance, properties);
-    }
-
-    /**
-     * Register a Global Service in the OSGi service registry
-     *
-     * @param clazz The target class
-     * @param instance of the object exporting the service, be careful
-     * the object must implement/extend clazz else the registration
-     * will fail unless a ServiceFactory is passed as parameter
-     * @param properties The properties to be attached to the service
-     * registration
-     * @return true if registration happened, false otherwise
-     */
-    public static boolean registerGlobalService(Class<?> clazz,
-                                                Object instance,
-                                                Dictionary<String, Object> properties) {
-        ServiceRegistration<?> registration = registerGlobalServiceWReg(clazz, instance, properties);
-        if (registration == null) {
-            logger.error("Failed to register {} for instance {}", clazz, instance);
-            return false;
-        }
-        return true;
-    }
-
-    /**
-     * Register a Service in the OSGi service registry and return the ServiceRegistration
-     *
-     * @param clazz The target class
-     * @param containerName The container name
-     * @param instance of the object exporting the service, be careful
-     * the object must implement/extend clazz else the registration
-     * will fail unless a ServiceFactory is passed as parameter
-     * @param properties The properties to be attached to the service
-     * registration
-     * @return the ServiceRegistration if registration happened, null otherwise
-     */
-    public static ServiceRegistration<?> registerServiceWReg(Class<?> clazz, String containerName,
-                                                          Object instance, Dictionary<String, Object> properties) {
-        if (properties == null) {
-            properties = (Dictionary<String, Object>) new Hashtable<String, Object>();
-        }
-        properties.put("containerName", containerName);
-        return registerGlobalServiceWReg(clazz, instance, properties);
-    }
-
-    /**
-     * Register a Global Service in the OSGi service registry
-     *
-     * @param clazz The target class
-     * @param instance of the object exporting the service, be careful
-     * the object must implement/extend clazz else the registration
-     * will fail unless a ServiceFactory is passed as parameter
-     * @param properties The properties to be attached to the service
-     * registration
-     * @return the ServiceRegistration if registration happened, null otherwise
-     */
-    public static ServiceRegistration<?> registerGlobalServiceWReg(Class<?> clazz,
-                                                                Object instance,
-                                                                Dictionary<String, Object> properties) {
-        try {
-            BundleContext bCtx = FrameworkUtil.getBundle(instance.getClass()).getBundleContext();
-            if (bCtx == null) {
-                logger.error("Could not retrieve the BundleContext");
-                return null;
-            }
-
-            ServiceRegistration<?> registration = bCtx.registerService(clazz.getName(), instance, properties);
-            return registration;
-        } catch (Exception e) {
-            logger.error("Exception {} while registering the service {}",
-                         e.getMessage(), instance.toString());
-        }
-        return null;
-    }
-
-    /**
-     * Retrieve instance of a class via OSGI registry, if there
-     * are many only the first is returned.
-     *
-     * @param clazz The target class
-     * @param containerName The container name
-     * @param bundle The caller
-     */
-    public static Object getInstance(Class<?> clazz, String containerName,
-            Object bundle) {
-        // Back-end convention: Container id in lower case. Let's enforce it here
-        return getInstance(clazz, containerName.toLowerCase(), bundle, null);
-    }
-
-    /**
-     * Retrieve global instance of a class via OSGI registry, if
-     * there are many only the first is returned.
-     *
-     * @param clazz The target class
-     * @param bundle The caller
-     */
-    public static Object getGlobalInstance(Class<?> clazz, Object bundle) {
-        return getGlobalInstance(clazz, bundle, null);
-    }
-
-    /**
-     * Retrieve instance of a class via OSGI registry, if there
-     * are many only the first is returned. On this version an LDAP
-     * type of filter is applied
-     *
-     * @param clazz The target class
-     * @param containerName The container name
-     * @param bundle The caller
-     * @param serviceFilter LDAP filter to be applied in the search
-     */
-    public static Object getInstance(Class<?> clazz, String containerName,
-            Object bundle, String serviceFilter) {
-        Object[] instances = getInstances(clazz, containerName, bundle,
-                serviceFilter);
-        if (instances != null) {
-            return instances[0];
-        }
-        return null;
-    }
-
-    /**
-     * Retrieve global instance of a class via OSGI registry, if
-     * there are many only the first is returned. On this version an LDAP
-     * type of filter is applied
-     *
-     * @param clazz The target class
-     * @param bundle The caller
-     * @param serviceFilter LDAP filter to be applied in the search
-     */
-    public static Object getGlobalInstance(Class<?> clazz, Object bundle,
-            String serviceFilter) {
-        Object[] instances = getGlobalInstances(clazz, bundle, serviceFilter);
-        if (instances != null) {
-            return instances[0];
-        }
-        return null;
-    }
-
-    /**
-     * Retrieve all the Instances of a Service, optionally
-     * filtered via serviceFilter if non-null else all the results are
-     * returned if null
-     *
-     * @param clazz The target class
-     * @param containerName The container name
-     * @param bundle The caller
-     * @param serviceFilter LDAP filter to be applied in the search
-     */
-    public static Object[] getInstances(Class<?> clazz, String containerName,
-            Object bundle, String serviceFilter) {
-        Object instances[] = null;
-        try {
-            BundleContext bCtx = FrameworkUtil.getBundle(bundle.getClass())
-                    .getBundleContext();
-
-            ServiceReference<?>[] services = null;
-            if (serviceFilter != null) {
-                services = bCtx.getServiceReferences(clazz.getName(),
-                        "(&(containerName=" + containerName + ")"
-                                + serviceFilter + ")");
-            } else {
-                services = bCtx.getServiceReferences(clazz.getName(),
-                        "(containerName=" + containerName + ")");
-            }
-
-            if (services != null) {
-                instances = new Object[services.length];
-                for (int i = 0; i < services.length; i++) {
-                    instances[i] = bCtx.getService(services[i]);
-                }
-            }
-        } catch (Exception e) {
-            logger.error("Instance reference is NULL");
-        }
-        return instances;
-    }
-
-    /**
-     * Retrieve all the Instances of a Service, optionally
-     * filtered via serviceFilter if non-null else all the results are
-     * returned if null
-     *
-     * @param clazz The target class
-     * @param bundle The caller
-     * @param serviceFilter LDAP filter to be applied in the search
-     */
-    public static Object[] getGlobalInstances(Class<?> clazz, Object bundle,
-            String serviceFilter) {
-        Object instances[] = null;
-        try {
-            BundleContext bCtx = FrameworkUtil.getBundle(bundle.getClass())
-                    .getBundleContext();
-
-            ServiceReference<?>[] services = bCtx.getServiceReferences(clazz
-                    .getName(), serviceFilter);
-
-            if (services != null) {
-                instances = new Object[services.length];
-                for (int i = 0; i < services.length; i++) {
-                    instances[i] = bCtx.getService(services[i]);
-                }
-            }
-        } catch (Exception e) {
-            logger.error("Instance reference is NULL");
-        }
-        return instances;
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/SingletonTask.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/SingletonTask.java
deleted file mode 100644 (file)
index 664beff..0000000
+++ /dev/null
@@ -1,177 +0,0 @@
-/*
- * Copyright (c) 2011,2013 Big Switch Networks, Inc.
- *
- * Licensed under the Eclipse Public License, Version 1.0 (the
- * "License"); you may not use this file except in compliance with the
- * License. You may obtain a copy of the License at
- *
- *      http://www.eclipse.org/legal/epl-v10.html
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
- * implied. See the License for the specific language governing
- * permissions and limitations under the License.
- *
- * This file incorporates work covered by the following copyright and
- * permission notice:
- *
- *    Originally created by David Erickson, Stanford University
- *
- *    Licensed under the Apache License, Version 2.0 (the "License");
- *    you may not use this file except in compliance with the
- *    License. You may obtain a copy of the License at
- *
- *         http://www.apache.org/licenses/LICENSE-2.0
- *
- *    Unless required by applicable law or agreed to in writing,
- *    software distributed under the License is distributed on an "AS
- *    IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
- *    express or implied. See the License for the specific language
- *    governing permissions and limitations under the License.
- */
-
-package org.opendaylight.controller.sal.utils;
-
-import java.util.concurrent.ScheduledExecutorService;
-import java.util.concurrent.TimeUnit;
-
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * This allows you to represent a task that should be queued for future
- * execution but where you only want the task to complete once in response to
- * some sequence of events. For example, if you get a change notification and
- * want to reload state, you only want to reload the state once, at the end, and
- * don't want to queue an update for every notification that might come in.
- *
- * The semantics are as follows: * If the task hasn't begun yet, do not queue a
- * new task * If the task has begun, set a bit to restart it after the current
- * task finishes
- */
-@Deprecated
-public class SingletonTask {
-    protected static Logger logger = LoggerFactory
-            .getLogger(SingletonTask.class);
-
-    protected static class SingletonTaskContext {
-        protected boolean taskShouldRun = false;
-        protected boolean taskRunning = false;
-
-        protected SingletonTaskWorker waitingTask = null;
-    }
-
-    protected static class SingletonTaskWorker implements Runnable {
-        SingletonTask parent;
-        boolean canceled = false;
-        long nextschedule = 0;
-
-        public SingletonTaskWorker(SingletonTask parent) {
-            super();
-            this.parent = parent;
-        }
-
-        @Override
-        public void run() {
-            synchronized (parent.context) {
-                if (canceled || !parent.context.taskShouldRun)
-                    return;
-
-                parent.context.taskRunning = true;
-                parent.context.taskShouldRun = false;
-            }
-
-            try {
-                parent.task.run();
-            } catch (Exception e) {
-                logger.error("Exception while executing task", e);
-            }
-
-            synchronized (parent.context) {
-                parent.context.taskRunning = false;
-
-                if (parent.context.taskShouldRun) {
-                    long now = System.nanoTime();
-                    if ((nextschedule <= 0 || (nextschedule - now) <= 0)) {
-                        parent.ses.execute(this);
-                    } else {
-                        parent.ses.schedule(this, nextschedule - now,
-                                TimeUnit.NANOSECONDS);
-                    }
-                }
-            }
-        }
-    }
-
-    protected SingletonTaskContext context = new SingletonTaskContext();
-    protected Runnable task;
-    protected ScheduledExecutorService ses;
-
-    /**
-     * Construct a new SingletonTask for the given runnable. The context is used
-     * to manage the state of the task execution and can be shared by more than
-     * one instance of the runnable.
-     *
-     * @param context
-     * @param Task
-     */
-    public SingletonTask(ScheduledExecutorService ses, Runnable task) {
-        super();
-        this.task = task;
-        this.ses = ses;
-    }
-
-    /**
-     * Schedule the task to run if there's not already a task scheduled If there
-     * is such a task waiting that has not already started, it cancel that task
-     * and reschedule it to run at the given time. If the task is already
-     * started, it will cause the task to be rescheduled once it completes to
-     * run after delay from the time of reschedule.
-     *
-     * @param delay
-     *            the delay in scheduling
-     * @param unit
-     *            the timeunit of the delay
-     */
-    public void reschedule(long delay, TimeUnit unit) {
-        boolean needQueue = true;
-        SingletonTaskWorker stw = null;
-
-        synchronized (context) {
-            if (context.taskRunning || context.taskShouldRun) {
-                if (context.taskRunning) {
-                    // schedule to restart at the right time
-                    if (delay > 0) {
-                        long now = System.nanoTime();
-                        long then = now
-                                + TimeUnit.NANOSECONDS.convert(delay, unit);
-                        context.waitingTask.nextschedule = then;
-                    } else {
-                        context.waitingTask.nextschedule = 0;
-                    }
-                    needQueue = false;
-                } else {
-                    // cancel and requeue
-                    context.waitingTask.canceled = true;
-                    context.waitingTask = null;
-                }
-            }
-
-            context.taskShouldRun = true;
-
-            if (needQueue) {
-                stw = context.waitingTask = new SingletonTaskWorker(this);
-            }
-        }
-
-        if (needQueue) {
-            if (delay <= 0) {
-                ses.execute(stw);
-            }
-            else {
-                ses.schedule(stw, delay, unit);
-            }
-        }
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/Status.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/Status.java
deleted file mode 100644 (file)
index 44d1c57..0000000
+++ /dev/null
@@ -1,149 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.utils;
-
-import java.io.Serializable;
-
-/**
- * Represents the return object of the osgi service interfaces function calls.
- * It contains a code {@code StatusCode} representing the result of the call and
- * a string which describes a failure reason (if any) in human readable form.
- */
-@Deprecated
-public class Status implements Serializable {
-    private static final long serialVersionUID = 0L;
-    private StatusCode code;
-    private String description;
-    private long requestId;
-
-    /**
-     * Generates an instance of the Status class. This is used as return code
-     * for internal API2 function calls. This constructor allows to specify,
-     * beside the Status Code, a custom human readable description to add more
-     * information about the status.
-     *
-     * @param errorCode
-     *            The status code. If passed as null, code will be stored as
-     *            {@code StatusCode.UNDEFINED}
-     * @param description
-     *            The human readable description of the status. If passed as
-     *            null, description will be inferred by the code
-     */
-    public Status(StatusCode errorCode, String description) {
-        this.code = (errorCode != null) ? errorCode : StatusCode.UNDEFINED;
-        this.description = (description != null) ? description : this.code
-                .toString();
-        this.requestId = 0;
-    }
-
-    /**
-     * Generates an instance of the Status class based on the passed StatusCode
-     * only. The description field of the Status object will be inferred by the
-     * status code.
-     *
-     * @param errorCode
-     *            The status code. If passed as null, code will be stored as
-     *            {@code StatusCode.UNDEFINED}
-     */
-    public Status(StatusCode errorCode) {
-        this.code = (errorCode != null) ? errorCode : StatusCode.UNDEFINED;
-        this.description = (description != null) ? description : this.code
-                .toString();
-        this.requestId = 0;
-    }
-
-    /**
-     * Generates an instance of the Status class to be used in case of
-     * asynchronous call. It is supposed to be created by the underlying
-     * infrastructure only when it was successful in allocating the asynchronous
-     * request id, hence caller should expect StatusCode to be successful.
-     *
-     * @param errorCode
-     *            The status code. If passed as null, code will be stored as
-     *            {@code StatusCode.UNDEFINED}
-     * @param requestId
-     *            The request id set by underlying infrastructure for this
-     *            request
-     */
-    public Status(StatusCode errorCode, long requestId) {
-        this.code = (errorCode != null) ? errorCode : StatusCode.UNDEFINED;
-        this.description = (description != null) ? description : this.code
-                .toString();
-        this.requestId = requestId;
-    }
-
-    /**
-     * Returns the status code
-     *
-     * @return the {@code StatusCode} representing the status code
-     */
-    public StatusCode getCode() {
-        return code;
-    }
-
-    /**
-     * Returns a human readable description of the failure if any
-     *
-     * @return a string representing the reason of failure
-     */
-    public String getDescription() {
-        return description;
-    }
-
-    /**
-     * Tells whether the status is successful
-     *
-     * @return true if the Status code is {@code StatusCode.SUCCESS}
-     */
-    public boolean isSuccess() {
-        return code == StatusCode.SUCCESS || code == StatusCode.CREATED;
-    }
-
-    /**
-     * Return the request id assigned by underlying infrastructure in case of
-     * asynchronous request. In case of synchronous requests, the returned id
-     * is expected to be 0
-     *
-     * @return The request id assigned for this asynchronous request
-     */
-    public long getRequestId() {
-        return requestId;
-    }
-
-    @Override
-    public String toString() {
-        return code + ": " + description + " (" + requestId + ")";
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + ((code == null) ? 0 : code.calculateConsistentHashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        Status other = (Status) obj;
-        if (code != other.code) {
-            return false;
-        }
-        return true;
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/StatusCode.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/StatusCode.java
deleted file mode 100644 (file)
index 81f0b76..0000000
+++ /dev/null
@@ -1,58 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.utils;
-
-/**
- * The enum which describes the generic error conditions.
- * Each enum value is associated with a minimal description string.
- *
- */
-@Deprecated
-public enum StatusCode {
-        SUCCESS("Success"),
-        CREATED("Created"),
-
-        BADREQUEST("Bad Request"),
-        UNAUTHORIZED("UnAuthorized"),
-        FORBIDDEN("Forbidden"),
-        NOTFOUND("Not Found"),
-        NOTALLOWED("Method Not Allowed"),
-        NOTACCEPTABLE("Request Not Acceptable"),
-        TIMEOUT("Request Timeout"),
-        CONFLICT("Resource Conflict"),
-        GONE("Resource Gone"),
-        UNSUPPORTED("Unsupported"),
-
-        INTERNALERROR("Internal Error"),
-        NOTIMPLEMENTED("Not Implemented"),
-        NOSERVICE("Service Not Available"),
-
-        UNDEFINED("Undefined Error");
-
-        private String description;
-        private StatusCode(String description) {
-                this.description = description;
-        }
-
-        /**
-         * Prints the description associated to the code value
-         */
-        @Override
-        public String toString() {
-                return description;
-        }
-
-    public int calculateConsistentHashCode() {
-        if (this.description != null) {
-            return this.description.hashCode();
-        } else {
-            return 0;
-        }
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/TierHelper.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/TierHelper.java
deleted file mode 100644 (file)
index c1ce6f4..0000000
+++ /dev/null
@@ -1,51 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.utils;
-
-import java.util.ArrayList;
-import java.util.List;
-@Deprecated
-public final class TierHelper {
-    private static TierHelper tierHelper;
-    public static final int unknownTierNumber = 0;
-    private List<String> tierNames;
-
-    static {
-        tierHelper = new TierHelper();
-    }
-
-    private TierHelper() {
-        tierNames = new ArrayList<String>();
-        tierNames.add("Unknown");
-        tierNames.add("Access");
-        tierNames.add("Distribution");
-        tierNames.add("Core");
-    }
-
-    public static void setTierName(int tier, String name) {
-        if (tier > tierHelper.tierNames.size() - 1) {
-            for (int i = tierHelper.tierNames.size() - 1; i < tier; i++) {
-                tierHelper.tierNames.add("Unknown");
-            }
-        }
-        tierHelper.tierNames.set(tier, name);
-    }
-
-    public static String getTierName(int tier) {
-        if ((tier < 0) || (tier > tierHelper.tierNames.size() - 1)) {
-            return "Unknown";
-        }
-        return tierHelper.tierNames.get(tier);
-    }
-
-    public static List<String> getTiers() {
-        return tierHelper.tierNames;
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/WriteToFile.java b/opendaylight/adsal/sal/api/src/main/java/org/opendaylight/controller/sal/utils/WriteToFile.java
deleted file mode 100644 (file)
index 6b109ba..0000000
+++ /dev/null
@@ -1,59 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.utils;
-
-import java.io.BufferedWriter;
-import java.io.FileWriter;
-import java.io.IOException;
-import java.util.ArrayList;
-
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * Convenience object to write a file
- *
- *
- *
- */
-@Deprecated
-public class WriteToFile {
-    protected static final Logger logger = LoggerFactory
-    .getLogger(WriteToFile.class);
-    private FileWriter fstream;
-    private BufferedWriter bufferOut;
-
-    public WriteToFile(String fileName) throws IOException {
-        fstream = new FileWriter(fileName);
-        bufferOut = new BufferedWriter(fstream);
-    }
-
-    public void save(ArrayList<String> entryList) throws IOException {
-        for (String entry : entryList) {
-            bufferOut.write(entry);
-            bufferOut.append('\n');
-        }
-        try {
-            this.bufferOut.flush();
-        } catch (IOException e) {
-            logger.error("",e);
-        }
-    }
-
-    public boolean close() {
-        try {
-            bufferOut.close();
-            fstream.close();
-        } catch (IOException e) {
-            return false;
-        }
-        return true;
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/action/ActionTest.java b/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/action/ActionTest.java
deleted file mode 100644 (file)
index edcb3e2..0000000
+++ /dev/null
@@ -1,360 +0,0 @@
-/*
- * Copyright (c) 2013-2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.sal.action;
-
-import org.opendaylight.controller.sal.core.ConstructionException;
-import java.net.InetAddress;
-import java.net.UnknownHostException;
-import java.util.ArrayList;
-import java.util.List;
-
-import org.junit.Test;
-import org.junit.Assert;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.core.Tables;
-import org.opendaylight.controller.sal.core.Tier;
-import org.opendaylight.controller.sal.utils.EtherTypes;
-import org.opendaylight.controller.sal.utils.NodeConnectorCreator;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-public class ActionTest {
-    protected static final Logger logger = LoggerFactory
-    .getLogger(ActionTest.class);
-    @Test
-    public void tesActionCreationValidation() {
-        Action action = new PopVlan();
-        Assert.assertTrue(action.isValid());
-
-        byte mac[] = { (byte) 0xaa, (byte) 0xbb, (byte) 0xcc, (byte) 0x11,
-                (byte) 0x22, (byte) 0x33 };
-
-        action = new SetDlSrc(mac);
-        Assert.assertTrue(action.isValid());
-
-        action = new SetDlSrc(mac);
-        Assert.assertTrue(action.isValid());
-    }
-
-    @Test
-    public void testSetVlanActionCreation() {
-        Action action = null;
-
-        action = new SetVlanId(2);
-        Assert.assertTrue(action.isValid());
-
-        action = new SetVlanId(4095);
-        Assert.assertTrue(action.isValid());
-
-        action = new SetVlanId(0);
-        Assert.assertFalse(action.isValid());
-
-        action = new SetVlanId(1);
-        Assert.assertTrue(action.isValid());
-
-        action = new SetVlanId(4096);
-        Assert.assertFalse(action.isValid());
-    }
-
-    @Test
-    public void testPushVlanActionCreation() {
-        Action action = null;
-
-        action = new PushVlan(EtherTypes.QINQ, 0x4, 0x1, 2000);
-        Assert.assertTrue(action.isValid());
-
-        action = new PushVlan(EtherTypes.QINQ.intValue(), 0x4, 0x1, 2000);
-        Assert.assertTrue(action.isValid());
-
-        action = new PushVlan(EtherTypes.OLDQINQ, 0x4, 2, 2000);
-        Assert.assertFalse(action.isValid());
-
-        action = new PushVlan(EtherTypes.VLANTAGGED, 0x4, 0, 2000);
-        Assert.assertTrue(action.isValid());
-
-        action = new PushVlan(EtherTypes.QINQ.intValue(), 0x4, 0x1, 5000);
-        Assert.assertFalse(action.isValid());
-
-        action = new PushVlan(EtherTypes.LLDP, 0x4, 0x1, 2000);
-        Assert.assertFalse(action.isValid());
-
-        action = new PushVlan(EtherTypes.PVSTP, 0x4, 2, 2000);
-        Assert.assertFalse(action.isValid());
-
-        action = new PushVlan(EtherTypes.QINQ, 0x4, -1, 2000);
-        Assert.assertFalse(action.isValid());
-
-        // OF 1.3 PUSH_VLAN test.
-        for (EtherTypes tag: EtherTypes.values()) {
-            int t = tag.intValue();
-            boolean valid =
-                (tag == EtherTypes.VLANTAGGED || tag == EtherTypes.QINQ);
-            PushVlan pv = new PushVlan(tag);
-            Assert.assertEquals(valid, pv.isValid());
-            if (valid) {
-                Assert.assertEquals(t, pv.getTag());
-            }
-
-            pv = new PushVlan(t);
-            Assert.assertEquals(valid, pv.isValid());
-            if (valid) {
-                Assert.assertEquals(t, pv.getTag());
-            }
-        }
-    }
-
-    @Test
-    public void testSetVlanPcpActionCreation() {
-        Action action = null;
-
-        action = new SetVlanPcp(0x4);
-        Assert.assertTrue(action.isValid());
-
-        action = new SetVlanPcp(0x8);
-        Assert.assertFalse(action.isValid());
-
-        action = new SetVlanPcp(-1);
-        Assert.assertFalse(action.isValid());
-    }
-
-    @Test
-    public void testSetVlanCfiActionCreation() {
-        Action action = null;
-
-        action = new SetVlanCfi(0x0);
-        Assert.assertTrue(action.isValid());
-
-        action = new SetVlanCfi(0x1);
-        Assert.assertTrue(action.isValid());
-
-        action = new SetVlanCfi(0x2);
-        Assert.assertFalse(action.isValid());
-
-        action = new SetVlanCfi(-1);
-        Assert.assertFalse(action.isValid());
-    }
-
-    @Test
-    public void testNetworkSetActionCreation() {
-        Action action = null;
-
-        InetAddress ip = null;
-        try {
-            ip = InetAddress.getByName("171.71.9.52");
-        } catch (UnknownHostException e) {
-            logger.error("",e);
-        }
-
-        action = new SetNwSrc(ip);
-        Assert.assertTrue(action.isValid());
-
-        action = new SetNwDst(ip);
-        Assert.assertTrue(action.isValid());
-
-        try {
-            ip = InetAddress.getByName("2001:420:281:1003:f2de:f1ff:fe71:728d");
-        } catch (UnknownHostException e) {
-            logger.error("", e);
-        }
-        action = new SetNwSrc(ip);
-        Assert.assertTrue(action.isValid());
-
-        action = new SetNwDst(ip);
-        Assert.assertTrue(action.isValid());
-
-        action = new SetNwTos(0xf);
-        Assert.assertTrue(action.isValid());
-
-        action = new SetNwTos(0x3f);
-        Assert.assertTrue(action.isValid());
-
-        action = new SetNwTos(0x40);
-        Assert.assertFalse(action.isValid());
-
-        action = new SetNwTos(0xff1);
-        Assert.assertFalse(action.isValid());
-
-        action = new SetNwTos(-1);
-        Assert.assertFalse(action.isValid());
-    }
-
-    @Test
-    public void testTransportSetActionCreation() {
-        Action action = null;
-
-        action = new SetTpSrc(50000);
-        Assert.assertTrue(action.isValid());
-
-        action = new SetTpDst(65535);
-        Assert.assertTrue(action.isValid());
-
-        action = new SetTpSrc(0);
-        Assert.assertTrue(action.isValid());
-
-        action = new SetTpDst(0);
-        Assert.assertTrue(action.isValid());
-
-        action = new SetTpSrc(-1);
-        Assert.assertFalse(action.isValid());
-
-        action = new SetTpDst(-1);
-        Assert.assertFalse(action.isValid());
-
-        action = new SetTpSrc(65536);
-        Assert.assertFalse(action.isValid());
-
-        action = new SetTpDst(65536);
-        Assert.assertFalse(action.isValid());
-    }
-
-    @Test
-    public void testNextHopActionCreation() {
-        SetNextHop action = null;
-
-        InetAddress ip = null;
-        try {
-            ip = InetAddress.getByName("171.71.9.52");
-        } catch (UnknownHostException e) {
-            logger.error("", e);
-        }
-
-        action = new SetNextHop(ip);
-        Assert.assertTrue(action.getAddress().equals(ip));
-
-        try {
-            ip = InetAddress.getByName("2001:420:281:1003:f2de:f1ff:fe71:728d");
-        } catch (UnknownHostException e) {
-            logger.error("", e);
-        }
-        action = new SetNextHop(ip);
-        Assert.assertTrue(action.getAddress().equals(ip));
-    }
-
-    @Test
-    public void testActionList() {
-        List<Action> actions = new ArrayList<Action>();
-        short portId = (short) 9;
-        Node node = null;
-        try {
-            node = new Node(Node.NodeIDType.OPENFLOW, new Long(0x55667788L));
-        } catch (ConstructionException e) {
-            // If we reach this point the exception was raised
-            // which is not expected
-            Assert.assertTrue(false);
-        }
-        NodeConnector nc = NodeConnectorCreator.createNodeConnector(portId,
-                node);
-        byte mac[] = { (byte) 0xaa, (byte) 0xbb, (byte) 0xcc, (byte) 0x11,
-                (byte) 0x22, (byte) 0x33 };
-        InetAddress ip = null;
-        try {
-            ip = InetAddress.getByName("1.1.1.1");
-        } catch (UnknownHostException e) {
-            logger.error("",e);
-        }
-
-        actions.add(new SetDlSrc(mac));
-        actions.add(new SetNwSrc(ip));
-        actions.add(new Output(nc));
-        Assert.assertTrue(actions.size() == 3);
-        Assert.assertTrue(actions.get(0).isValid());
-
-        Action probe = new Output(nc);
-        Assert.assertTrue(actions.contains(probe));
-        Assert.assertFalse(actions.contains(new Output(NodeConnectorCreator
-                .createNodeConnector((short) 5, node))));
-        Assert.assertFalse(actions.contains(new Controller()));
-    }
-
-    @Test
-    public void testMetadata() {
-        Property tier1 = new Tier(1);
-        Property tier2 = new Tier(2);
-        Property table1 = new Tables((byte)0x7f);
-        Action a1 = new PopVlan();
-        List<Property> resprops = null;
-        resprops = a1.getMetadatas();
-        // This should be an empty list
-        Assert.assertTrue(resprops.isEmpty());
-        a1.setMetadata("tier1", tier1);
-        a1.setMetadata("tier2", tier2);
-        a1.setMetadata("table1", table1);
-        resprops = a1.getMetadatas();
-        // Check for the number of elements in it
-        Assert.assertTrue(resprops.size() == 3);
-        // Check if the elements are in it
-        Assert.assertTrue(resprops.contains(tier1));
-        Assert.assertTrue(resprops.contains(tier2));
-        Assert.assertTrue(resprops.contains(table1));
-        // Check for single elements retrieve
-        Assert.assertTrue(a1.getMetadata("tier1").equals(tier1));
-        Assert.assertTrue(a1.getMetadata("tier2").equals(tier2));
-        Assert.assertTrue(a1.getMetadata("table1").equals(table1));
-        // Now remove an element and make sure the remaining are
-        // correct
-        a1.removeMetadata("tier1");
-
-        resprops = a1.getMetadatas();
-        // Check for the number of elements in it
-        Assert.assertTrue(resprops.size() == 2);
-        // Check if the elements are in it
-        Assert.assertFalse(resprops.contains(tier1));
-        Assert.assertTrue(resprops.contains(tier2));
-        Assert.assertTrue(resprops.contains(table1));
-        // Check for single elements retrieve
-        Assert.assertTrue(a1.getMetadata("table1").equals(table1));
-        Assert.assertTrue(a1.getMetadata("tier2").equals(tier2));
-        Assert.assertNull(a1.getMetadata("tier1"));
-
-        // Check for an element never existed
-        Assert.assertNull(a1.getMetadata("table100"));
-
-        // Remove them all
-        a1.removeMetadata("tier2");
-        a1.removeMetadata("table1");
-
-        // Remove also a non-existent one
-        a1.removeMetadata("table100");
-
-        resprops = a1.getMetadatas();
-        // Check there are no elements left
-        Assert.assertTrue(resprops.size() == 0);
-
-        // Now check for exception on setting null values
-        try {
-            a1.setMetadata("foo", null);
-            // The line below should never be reached
-            Assert.assertTrue(false);
-        } catch (NullPointerException nue) {
-            // NPE should be raised for null value
-            Assert.assertTrue(true);
-        }
-
-        // Now check on using null key
-        try {
-            a1.setMetadata(null, table1);
-            // The line below should never be reached
-            Assert.assertTrue(false);
-        } catch (NullPointerException nue) {
-            // NPE should be raised for null value
-            Assert.assertTrue(true);
-        }
-
-        // Now check on using null key and null value
-        try {
-            a1.setMetadata(null, null);
-            // The line below should never be reached
-            Assert.assertTrue(false);
-        } catch (NullPointerException nue) {
-            // NPE should be raised for null value
-            Assert.assertTrue(true);
-        }
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/authorization/AuthorizationTest.java b/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/authorization/AuthorizationTest.java
deleted file mode 100644 (file)
index 869d7ff..0000000
+++ /dev/null
@@ -1,77 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.authorization;
-
-import java.util.ArrayList;
-import java.util.HashMap;
-import java.util.Map;
-import java.util.Map.Entry;
-
-import org.junit.Assert;
-import org.junit.Test;
-
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.utils.NodeCreator;
-
-        public class AuthorizationTest {
-
-        @Test
-        public void testResources () {
-        Privilege p = Privilege.WRITE;
-        ResourceGroup resourceGroup = new ResourceGroup("NodeGroup", p);
-        Map<ResourceGroup, ArrayList<Resource>> resourceMap = new HashMap<ResourceGroup, ArrayList<Resource>>();
-        ArrayList<Resource> resourceList = new ArrayList<Resource>();
-
-                for (int i = 0; i < 5; i++) {
-                        Node node = NodeCreator.createOFNode((long)i);
-                        Resource resource = new Resource (node, p);
-                        resourceList.add(resource);
-                }
-
-                resourceMap.put(resourceGroup, resourceList);
-
-                ArrayList<Resource> retrievedResourceList = resourceMap.get(resourceGroup);
-                for (Entry<ResourceGroup, ArrayList<Resource>> entry : resourceMap.entrySet()) {
-                        ResourceGroup rGroup = entry.getKey();
-                        Assert.assertTrue(rGroup.getGroupName().equals(resourceGroup.getGroupName()));
-                        for (int i = 0; i < 5; i++) {
-                                Resource resource = retrievedResourceList.get(i);
-                                Assert.assertTrue(resource.getPrivilege().equals(Privilege.WRITE));
-                                Assert.assertTrue(((Long)((Node)resource.getResource()).getID()).equals((long)i));
-                        }
-                }
-        }
-
-        @Test
-        public void testAppRoleLevel() {
-                AppRoleLevel appRoleLevel = AppRoleLevel.APPOPERATOR;
-                Assert.assertTrue(appRoleLevel.toString().equals("App-Operator"));
-                Assert.assertTrue(appRoleLevel.toNumber() == 2);
-                Assert.assertTrue(appRoleLevel.toStringPretty().equals("Application Operator"));
-        }
-
-        @Test
-        public void testUserLevel() {
-                UserLevel userLevel = UserLevel.SYSTEMADMIN;
-                Assert.assertTrue(userLevel.toString().equals("System-Admin"));
-                Assert.assertTrue(userLevel.toNumber() == 0);
-                Assert.assertTrue(userLevel.toStringPretty().equals("System Administrator"));
-        }
-
-        @Test
-        public void testAppRoleLevelFromString() {
-                Assert.assertTrue(AppRoleLevel.fromString("App-Admin") == AppRoleLevel.APPADMIN);
-                Assert.assertTrue(AppRoleLevel.fromString("App-User") == AppRoleLevel.APPUSER);
-                Assert.assertTrue(AppRoleLevel.fromString("App-Operator") == AppRoleLevel.APPOPERATOR);
-                Assert.assertTrue(AppRoleLevel.fromString(" ") == null);
-                Assert.assertTrue(AppRoleLevel.fromString("") == null);
-                Assert.assertTrue(AppRoleLevel.fromString("App-Admini") == null);
-        }
-}
diff --git a/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/core/EdgeTest.java b/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/core/EdgeTest.java
deleted file mode 100644 (file)
index 7c36d09..0000000
+++ /dev/null
@@ -1,186 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * @file   EdgeTest.java
- *
- * @brief  Unit Tests for Edge element
- *
- * Unit Tests for Edge element
- */
-package org.opendaylight.controller.sal.core;
-
-import org.junit.Assert;
-import org.junit.Test;
-
-public class EdgeTest {
-    @Test
-    public void testEdgeEquals() {
-        try {
-            Node n0 = new Node(Node.NodeIDType.OPENFLOW, new Long(40L));
-            NodeConnector c0 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.OPENFLOW, new Short(
-                            (short) 0x4), n0);
-
-            Node n1 = new Node(Node.NodeIDType.OPENFLOW, new Long(110L));
-            NodeConnector c1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.OPENFLOW, new Short(
-                            (short) 0x1), n1);
-
-            Node n2 = new Node(Node.NodeIDType.OPENFLOW, new Long(40L));
-            NodeConnector c2 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.OPENFLOW, new Short(
-                            (short) 0x4), n2);
-
-            Node n3 = new Node(Node.NodeIDType.OPENFLOW, new Long(110L));
-            NodeConnector c3 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.OPENFLOW, new Short(
-                            (short) 0x1), n3);
-
-            Edge e0 = new Edge(c0, c1);
-            Edge e1 = new Edge(c2, c3);
-            // e0 must be equal to e1 to pass the test
-            Assert.assertTrue(e0.equals(e1));
-        } catch (ConstructionException e) {
-            // Exception is NOT expected if raised test will fail
-            Assert.assertTrue(false);
-        }
-    }
-
-    @Test
-    public void testEdgeDifferents() {
-        Node n0, n1, n2, n3;
-        NodeConnector c0, c1, c2, c3;
-        Edge e0, e1;
-        try {
-            // Difference in the tail node
-            n0 = new Node(Node.NodeIDType.OPENFLOW, new Long(40L));
-            c0 = new NodeConnector(NodeConnector.NodeConnectorIDType.OPENFLOW,
-                    new Short((short) 0x4), n0);
-
-            n1 = new Node(Node.NodeIDType.OPENFLOW, new Long(110L));
-            c1 = new NodeConnector(NodeConnector.NodeConnectorIDType.OPENFLOW,
-                    new Short((short) 0x1), n1);
-
-            e0 = new Edge(c0, c1);
-
-            n2 = new Node(Node.NodeIDType.OPENFLOW, new Long(40L));
-            c2 = new NodeConnector(NodeConnector.NodeConnectorIDType.OPENFLOW,
-                    new Short((short) 0x4), n2);
-
-            n3 = new Node(Node.NodeIDType.OPENFLOW, new Long(111L));
-            c3 = new NodeConnector(NodeConnector.NodeConnectorIDType.OPENFLOW,
-                    new Short((short) 0x1), n3);
-
-            e0 = new Edge(c0, c1);
-            e1 = new Edge(c2, c3);
-            // e0 must be different from e1 to pass the test
-            Assert.assertTrue(!e0.equals(e1));
-
-            // Difference in the head node
-            n0 = new Node(Node.NodeIDType.OPENFLOW, new Long(40L));
-            c0 = new NodeConnector(NodeConnector.NodeConnectorIDType.OPENFLOW,
-                    new Short((short) 0x4), n0);
-
-            n1 = new Node(Node.NodeIDType.OPENFLOW, new Long(110L));
-            c1 = new NodeConnector(NodeConnector.NodeConnectorIDType.OPENFLOW,
-                    new Short((short) 0x1), n1);
-
-            e0 = new Edge(c0, c1);
-
-            n2 = new Node(Node.NodeIDType.OPENFLOW, new Long(41L));
-            c2 = new NodeConnector(NodeConnector.NodeConnectorIDType.OPENFLOW,
-                    new Short((short) 0x4), n2);
-
-            n3 = new Node(Node.NodeIDType.OPENFLOW, new Long(110L));
-            c3 = new NodeConnector(NodeConnector.NodeConnectorIDType.OPENFLOW,
-                    new Short((short) 0x1), n3);
-
-            e0 = new Edge(c0, c1);
-            e1 = new Edge(c2, c3);
-            // e0 must be different from e1 to pass the test
-            Assert.assertTrue(!e0.equals(e1));
-
-            // Difference in the head nodeconnetor
-            n0 = new Node(Node.NodeIDType.OPENFLOW, new Long(40L));
-            c0 = new NodeConnector(NodeConnector.NodeConnectorIDType.OPENFLOW,
-                    new Short((short) 0x4), n0);
-
-            n1 = new Node(Node.NodeIDType.OPENFLOW, new Long(110L));
-            c1 = new NodeConnector(NodeConnector.NodeConnectorIDType.OPENFLOW,
-                    new Short((short) 0x1), n1);
-
-            e0 = new Edge(c0, c1);
-
-            n2 = new Node(Node.NodeIDType.OPENFLOW, new Long(40L));
-            c2 = new NodeConnector(NodeConnector.NodeConnectorIDType.OPENFLOW,
-                    new Short((short) 0x5), n2);
-
-            n3 = new Node(Node.NodeIDType.OPENFLOW, new Long(110L));
-            c3 = new NodeConnector(NodeConnector.NodeConnectorIDType.OPENFLOW,
-                    new Short((short) 0x1), n3);
-
-            e0 = new Edge(c0, c1);
-            e1 = new Edge(c2, c3);
-            // e0 must be different from e1 to pass the test
-            Assert.assertTrue(!e0.equals(e1));
-
-            // Difference in the tail nodeconnetor
-            n0 = new Node(Node.NodeIDType.OPENFLOW, new Long(40L));
-            c0 = new NodeConnector(NodeConnector.NodeConnectorIDType.OPENFLOW,
-                    new Short((short) 0x4), n0);
-
-            n1 = new Node(Node.NodeIDType.OPENFLOW, new Long(110L));
-            c1 = new NodeConnector(NodeConnector.NodeConnectorIDType.OPENFLOW,
-                    new Short((short) 0x1), n1);
-
-            e0 = new Edge(c0, c1);
-
-            n2 = new Node(Node.NodeIDType.OPENFLOW, new Long(40L));
-            c2 = new NodeConnector(NodeConnector.NodeConnectorIDType.OPENFLOW,
-                    new Short((short) 0x4), n2);
-
-            n3 = new Node(Node.NodeIDType.OPENFLOW, new Long(110L));
-            c3 = new NodeConnector(NodeConnector.NodeConnectorIDType.OPENFLOW,
-                    new Short((short) 0x2), n3);
-
-            e0 = new Edge(c0, c1);
-            e1 = new Edge(c2, c3);
-            // e0 must be different from e1 to pass the test
-            Assert.assertTrue(!e0.equals(e1));
-
-            // Difference in the both nodeconnetor/node
-            n0 = new Node(Node.NodeIDType.OPENFLOW, new Long(40L));
-            c0 = new NodeConnector(NodeConnector.NodeConnectorIDType.OPENFLOW,
-                    new Short((short) 0x4), n0);
-
-            n1 = new Node(Node.NodeIDType.OPENFLOW, new Long(110L));
-            c1 = new NodeConnector(NodeConnector.NodeConnectorIDType.OPENFLOW,
-                    new Short((short) 0x1), n1);
-
-            e0 = new Edge(c0, c1);
-
-            n2 = new Node(Node.NodeIDType.OPENFLOW, new Long(40L));
-            c2 = new NodeConnector(NodeConnector.NodeConnectorIDType.OPENFLOW,
-                    new Short((short) 0x4), n2);
-
-            n3 = new Node(Node.NodeIDType.OPENFLOW, new Long(111L));
-            c3 = new NodeConnector(NodeConnector.NodeConnectorIDType.OPENFLOW,
-                    new Short((short) 0x2), n3);
-
-            e0 = new Edge(c0, c1);
-            e1 = new Edge(c2, c3);
-            // e0 must be different from e1 to pass the test
-            Assert.assertTrue(!e0.equals(e1));
-        } catch (ConstructionException e) {
-            // Exception is NOT expected if raised test will fail
-            Assert.assertTrue(false);
-        }
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/core/NodeConnectorTest.java b/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/core/NodeConnectorTest.java
deleted file mode 100644 (file)
index f85b7b4..0000000
+++ /dev/null
@@ -1,1281 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * @file   NodeConnectorTest.java
- *
- * @brief  Unit Tests for NodeConnector element
- *
- * Unit Tests for NodeConnector element
- */
-package org.opendaylight.controller.sal.core;
-
-import java.util.UUID;
-
-import org.junit.Assert;
-import org.junit.Test;
-
-public class NodeConnectorTest {
-    @Test
-    public void testNodeConnectorOpenFlowOfWrongType() {
-        try {
-            Node n1 = new Node(Node.NodeIDType.OPENFLOW, new Long(110L));
-            @SuppressWarnings("unused")
-            NodeConnector of1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.OPENFLOW, new String(
-                            "0xDEADBEEFCAFE0001L"), n1);
-
-            // If we reach this point the exception was not raised
-            // which should have been the case
-            Assert.assertTrue(false);
-        } catch (ConstructionException e) {
-            // If we reach this point the exception has been raised
-            // and so test passed
-            System.out.println("Got exception as expected!:" + e);
-            Assert.assertTrue(true);
-        }
-    }
-
-    @Test
-    public void testNodeConnectorONEPKOfWrongType() {
-        try {
-            Node n1 = new Node(Node.NodeIDType.ONEPK, new String("Router1"));
-            @SuppressWarnings("unused")
-            NodeConnector onepk1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.ONEPK, new Long(
-                            0xDEADBEEFCAFE0001L), n1);
-
-            // If we reach this point the exception was not raised
-            // which should have been the case
-            Assert.assertTrue(false);
-        } catch (ConstructionException e) {
-            // If we reach this point the exception has been raised
-            // and so test passed
-            System.out.println("Got exception as expected!:" + e);
-            Assert.assertTrue(true);
-        }
-    }
-
-    @Test
-    public void testNodeConnectorPCEPOfWrongType() {
-        try {
-            Node n1 = new Node(Node.NodeIDType.PCEP, new UUID(0L, 0L));
-            @SuppressWarnings("unused")
-            NodeConnector pcep1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.PCEP, new Long(
-                            0xDEADBEEFCAFE0001L), n1);
-
-            // If we reach this point the exception was not raised
-            // which should have been the case
-            Assert.assertTrue(false);
-        } catch (ConstructionException e) {
-            // If we reach this point the exception has been raised
-            // and so test passed
-            System.out.println("Got exception as expected!:" + e);
-            Assert.assertTrue(true);
-        }
-    }
-
-    @Test
-    public void testNodeConnectorOpenFlowOfCorrectType() {
-        try {
-            Node n1 = new Node(Node.NodeIDType.OPENFLOW, new Long(110L));
-            NodeConnector of1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.OPENFLOW, new Short(
-                            (short) 0xCAFE), n1);
-
-            // If we reach this point the exception has not been
-            // raised so we passed the test
-            System.out.println("Got node:" + of1);
-            Assert.assertTrue(true);
-        } catch (ConstructionException e) {
-            // If we reach this point the exception was raised
-            // which is not expected
-            Assert.assertTrue(false);
-        }
-    }
-
-    @Test
-    public void testNodeConnectorONEPKOfCorrectType() {
-        try {
-            Node n1 = new Node(Node.NodeIDType.ONEPK, new String("Router1"));
-            NodeConnector onepk1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.ONEPK, new String(
-                            "Gi1/0/1"), n1);
-
-            // If we reach this point the exception has not been
-            // raised so we passed the test
-            System.out.println("Got node:" + onepk1);
-            Assert.assertTrue(true);
-        } catch (ConstructionException e) {
-            // If we reach this point the exception was raised
-            // which is not expected
-            Assert.assertTrue(false);
-        }
-    }
-
-    @Test
-    public void testNodeConnectorPCEPOfCorrectType() {
-        try {
-            Node n1 = new Node(Node.NodeIDType.PCEP, new UUID(0L, 0L));
-            NodeConnector pcep1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.PCEP, new Integer(
-                            0xDEADBEEF), n1);
-
-            // If we reach this point the exception has not been
-            // raised so we passed the test
-            System.out.println("Got node:" + pcep1);
-            Assert.assertTrue(true);
-        } catch (ConstructionException e) {
-            // If we reach this point the exception was raised
-            // which is not expected
-            Assert.assertTrue(false);
-        }
-    }
-
-    @Test
-    public void testTwoOpenFlowNodeConnectorEquals() {
-        try {
-            Node n1 = new Node(Node.NodeIDType.OPENFLOW, new Long(110L));
-            NodeConnector of1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.OPENFLOW, new Short(
-                            (short) 0xCAFE), n1);
-            NodeConnector of2 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.OPENFLOW, new Short(
-                            (short) 0xCAFE), n1);
-
-            Assert.assertTrue(of1.equals(of2));
-        } catch (ConstructionException e) {
-            // If we reach this point the exception was raised
-            // which is not expected
-            Assert.assertTrue(false);
-        }
-    }
-
-    @Test
-    public void testTwoONEPKNodeConnectorEquals() {
-        try {
-            Node n1 = new Node(Node.NodeIDType.ONEPK, new String("Router1"));
-            NodeConnector onepk1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.ONEPK, new String(
-                            "Gi1/0/1"), n1);
-            NodeConnector onepk2 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.ONEPK, new String(
-                            "Gi1/0/1"), n1);
-
-            Assert.assertTrue(onepk1.equals(onepk2));
-        } catch (ConstructionException e) {
-            // If we reach this point the exception was raised
-            // which is not expected
-            Assert.assertTrue(false);
-        }
-    }
-
-    @Test
-    public void testTwoPCEPNodeConnectorEquals() {
-        try {
-            Node n1 = new Node(Node.NodeIDType.PCEP, new UUID(0L, 0L));
-            NodeConnector pcep1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.PCEP, new Integer(
-                            0xDEADBEEF), n1);
-            NodeConnector pcep2 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.PCEP, new Integer(
-                            0xDEADBEEF), n1);
-
-            Assert.assertTrue(pcep1.equals(pcep2));
-        } catch (ConstructionException e) {
-            // If we reach this point the exception was raised
-            // which is not expected
-            Assert.assertTrue(false);
-        }
-    }
-
-    @Test
-    public void testTwoOpenFlowNodeConnectorDifferents() {
-        try {
-            Node n1 = new Node(Node.NodeIDType.OPENFLOW, new Long(110L));
-            NodeConnector of1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.OPENFLOW, new Short(
-                            (short) 0xCAFE), n1);
-            NodeConnector of2 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.OPENFLOW, new Short(
-                            (short) 0xBEEF), n1);
-
-            Assert.assertTrue(!of1.equals(of2));
-        } catch (ConstructionException e) {
-            // If we reach this point the exception was raised
-            // which is not expected
-            Assert.assertTrue(false);
-        }
-    }
-
-    @Test
-    public void testTwoONEPKNodeConnectorDifferents() {
-        try {
-            Node n1 = new Node(Node.NodeIDType.ONEPK, new String("Router1"));
-            NodeConnector onepk1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.ONEPK, new String(
-                            "Gi1/0/1"), n1);
-            NodeConnector onepk2 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.ONEPK, new String(
-                            "Gi1/0/2"), n1);
-
-            Assert.assertTrue(!onepk1.equals(onepk2));
-        } catch (ConstructionException e) {
-            // If we reach this point the exception was raised
-            // which is not expected
-            Assert.assertTrue(false);
-        }
-    }
-
-    @Test
-    public void testTwoPCEPNodeConnectorDifferents() {
-        try {
-            Node n1 = new Node(Node.NodeIDType.PCEP, new UUID(0L, 0L));
-            NodeConnector pcep1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.PCEP, new Integer(
-                            0xDEADBEEF), n1);
-            NodeConnector pcep2 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.PCEP, new Integer(
-                            0xCAFECAFE), n1);
-
-            Assert.assertTrue(!pcep1.equals(pcep2));
-        } catch (ConstructionException e) {
-            // If we reach this point the exception was raised
-            // which is not expected
-            Assert.assertTrue(false);
-        }
-    }
-
-    @Test
-    public void testTwoOpenFlowNodeConnectorDifferentsNodes() {
-        try {
-            Node n1 = new Node(Node.NodeIDType.OPENFLOW, new Long(110L));
-            Node n2 = new Node(Node.NodeIDType.OPENFLOW, new Long(111L));
-            NodeConnector of1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.OPENFLOW, new Short(
-                            (short) 0xCAFE), n1);
-            NodeConnector of2 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.OPENFLOW, new Short(
-                            (short) 0xCAFE), n2);
-
-            Assert.assertTrue(!of1.equals(of2));
-        } catch (ConstructionException e) {
-            // If we reach this point the exception was raised
-            // which is not expected
-            Assert.assertTrue(false);
-        }
-    }
-
-    @Test
-    public void testTwoONEPKNodeConnectorDifferentsNodes() {
-        try {
-            Node n1 = new Node(Node.NodeIDType.ONEPK, new String("Router1"));
-            Node n2 = new Node(Node.NodeIDType.ONEPK, new String("Router2"));
-            NodeConnector onepk1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.ONEPK, new String(
-                            "Gi1/0/1"), n1);
-            NodeConnector onepk2 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.ONEPK, new String(
-                            "Gi1/0/1"), n2);
-
-            Assert.assertTrue(!onepk1.equals(onepk2));
-        } catch (ConstructionException e) {
-            // If we reach this point the exception was raised
-            // which is not expected
-            Assert.assertTrue(false);
-        }
-    }
-
-    @Test
-    public void testTwoPCEPNodeConnectorDifferentsNodes() {
-        try {
-            Node n1 = new Node(Node.NodeIDType.PCEP, new UUID(0L, 0L));
-            Node n2 = new Node(Node.NodeIDType.PCEP, new UUID(0L, 1L));
-            NodeConnector pcep1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.PCEP, new Integer(
-                            0xDEADBEEF), n1);
-            NodeConnector pcep2 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.PCEP, new Integer(
-                            0xDEADBEEF), n2);
-
-            Assert.assertTrue(!pcep1.equals(pcep2));
-        } catch (ConstructionException e) {
-            // If we reach this point the exception was raised
-            // which is not expected
-            Assert.assertTrue(false);
-        }
-    }
-
-    @SuppressWarnings("unused")
-    @Test
-    public void testIncompatibleNodes() {
-        try {
-            Node n1 = new Node(Node.NodeIDType.PCEP, new UUID(0L, 0L));
-            NodeConnector nc1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.OPENFLOW, new Short(
-                            (short) 0), n1);
-            // Exception is expected if not raised test will fail
-            Assert.assertTrue(false);
-        } catch (ConstructionException e) {
-        }
-
-        try {
-            Node n1 = new Node(Node.NodeIDType.PCEP, new UUID(0L, 0L));
-            NodeConnector nc1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.OPENFLOW2PCEP, new Short(
-                            (short) 0), n1);
-            // Exception is expected if not raised test will fail
-            Assert.assertTrue(false);
-        } catch (ConstructionException e) {
-        }
-
-        try {
-            Node n1 = new Node(Node.NodeIDType.PCEP, new UUID(0L, 0L));
-            NodeConnector nc1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.OPENFLOW2ONEPK,
-                    new Short((short) 0), n1);
-            // Exception is expected if not raised test will fail
-            Assert.assertTrue(false);
-        } catch (ConstructionException e) {
-        }
-
-        try {
-            Node n1 = new Node(Node.NodeIDType.PCEP, new UUID(0L, 0L));
-            NodeConnector nc1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.ONEPK2PCEP, new String(
-                            "towardPCEP1"), n1);
-            // Exception is expected if not raised test will fail
-            Assert.assertTrue(false);
-        } catch (ConstructionException e) {
-        }
-
-        try {
-            Node n1 = new Node(Node.NodeIDType.PCEP, new UUID(0L, 0L));
-            NodeConnector nc1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.ONEPK2OPENFLOW,
-                    new String("towardPCEP1"), n1);
-            // Exception is expected if not raised test will fail
-            Assert.assertTrue(false);
-        } catch (ConstructionException e) {
-        }
-
-        try {
-            Node n1 = new Node(Node.NodeIDType.PCEP, new UUID(0L, 0L));
-            NodeConnector nc1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.ONEPK, new String(
-                            "Gi1/0/1"), n1);
-            // Exception is expected if not raised test will fail
-            Assert.assertTrue(false);
-        } catch (ConstructionException e) {
-        }
-
-        try {
-            Node n1 = new Node(Node.NodeIDType.PCEP, new UUID(0L, 0L));
-            NodeConnector nc1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.PCEP, new Integer(0), n1);
-        } catch (ConstructionException e) {
-            // Exception is NOT expected if raised test will fail
-            Assert.assertTrue(false);
-        }
-        try {
-            Node n1 = new Node(Node.NodeIDType.PCEP, new UUID(0L, 0L));
-            NodeConnector nc1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.PCEP2ONEPK,
-                    new Integer(0), n1);
-        } catch (ConstructionException e) {
-            // Exception is NOT expected if raised test will fail
-            Assert.assertTrue(false);
-        }
-
-        try {
-            Node n1 = new Node(Node.NodeIDType.PCEP, new UUID(0L, 0L));
-            NodeConnector nc1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.PCEP2OPENFLOW,
-                    new Integer(0), n1);
-        } catch (ConstructionException e) {
-            // Exception is NOT expected if raised test will fail
-            Assert.assertTrue(false);
-        }
-
-        try {
-            Node n1 = new Node(Node.NodeIDType.ONEPK, new String("Router1"));
-            NodeConnector nc1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.OPENFLOW, new Short(
-                            (short) 0), n1);
-            // Exception is expected if not raised test will fail
-            Assert.assertTrue(false);
-        } catch (ConstructionException e) {
-        }
-
-        try {
-            Node n1 = new Node(Node.NodeIDType.ONEPK, new String("Router1"));
-            NodeConnector nc1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.OPENFLOW2PCEP, new Short(
-                            (short) 0), n1);
-            // Exception is expected if not raised test will fail
-            Assert.assertTrue(false);
-        } catch (ConstructionException e) {
-        }
-
-        try {
-            Node n1 = new Node(Node.NodeIDType.ONEPK, new String("Router1"));
-            NodeConnector nc1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.OPENFLOW2ONEPK,
-                    new Short((short) 0), n1);
-            // Exception is expected if not raised test will fail
-            Assert.assertTrue(false);
-        } catch (ConstructionException e) {
-        }
-
-        try {
-            Node n1 = new Node(Node.NodeIDType.ONEPK, new String("Router1"));
-            NodeConnector nc1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.ONEPK2PCEP, new String(
-                            "towardPCEP1"), n1);
-        } catch (ConstructionException e) {
-            // Exception is NOT expected if raised test will fail
-            Assert.assertTrue(false);
-        }
-
-        try {
-            Node n1 = new Node(Node.NodeIDType.ONEPK, new String("Router1"));
-            NodeConnector nc1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.ONEPK2OPENFLOW,
-                    new String("towardPCEP1"), n1);
-        } catch (ConstructionException e) {
-            // Exception is NOT expected if raised test will fail
-            Assert.assertTrue(false);
-        }
-
-        try {
-            Node n1 = new Node(Node.NodeIDType.ONEPK, new String("Router1"));
-            NodeConnector nc1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.ONEPK, new String(
-                            "Gi1/0/1"), n1);
-        } catch (ConstructionException e) {
-            // Exception is NOT expected if raised test will fail
-            Assert.assertTrue(false);
-        }
-
-        try {
-            Node n1 = new Node(Node.NodeIDType.ONEPK, new String("Router1"));
-            NodeConnector nc1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.PCEP, new Integer(0), n1);
-            // Exception is expected if not raised test will fail
-            Assert.assertTrue(false);
-        } catch (ConstructionException e) {
-        }
-
-        try {
-            Node n1 = new Node(Node.NodeIDType.ONEPK, new String("Router1"));
-            NodeConnector nc1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.PCEP2ONEPK,
-                    new Integer(0), n1);
-            // Exception is expected if not raised test will fail
-            Assert.assertTrue(false);
-        } catch (ConstructionException e) {
-        }
-
-        try {
-            Node n1 = new Node(Node.NodeIDType.ONEPK, new String("Router1"));
-            NodeConnector nc1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.PCEP2OPENFLOW,
-                    new Integer(0), n1);
-            // Exception is expected if not raised test will fail
-            Assert.assertTrue(false);
-        } catch (ConstructionException e) {
-        }
-
-        try {
-            Node n1 = new Node(Node.NodeIDType.OPENFLOW, new Long(110L));
-            NodeConnector nc1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.OPENFLOW, new Short(
-                            (short) 0), n1);
-        } catch (ConstructionException e) {
-            // Exception is NOT expected if raised test will fail
-            Assert.assertTrue(false);
-        }
-
-        try {
-            Node n1 = new Node(Node.NodeIDType.OPENFLOW, new Long(110L));
-            NodeConnector nc1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.OPENFLOW2PCEP, new Short(
-                            (short) 0), n1);
-        } catch (ConstructionException e) {
-            // Exception is NOT expected if raised test will fail
-            Assert.assertTrue(false);
-        }
-
-        try {
-            Node n1 = new Node(Node.NodeIDType.OPENFLOW, new Long(110L));
-            NodeConnector nc1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.OPENFLOW2ONEPK,
-                    new Short((short) 0), n1);
-        } catch (ConstructionException e) {
-            // Exception is NOT expected if raised test will fail
-            Assert.assertTrue(false);
-        }
-
-        try {
-            Node n1 = new Node(Node.NodeIDType.OPENFLOW, new Long(110L));
-            NodeConnector nc1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.ONEPK2PCEP, new String(
-                            "towardPCEP1"), n1);
-            // Exception is expected if not raised test will fail
-            Assert.assertTrue(false);
-        } catch (ConstructionException e) {
-        }
-
-        try {
-            Node n1 = new Node(Node.NodeIDType.OPENFLOW, new Long(110L));
-            NodeConnector nc1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.ONEPK2OPENFLOW,
-                    new String("towardPCEP1"), n1);
-            // Exception is expected if not raised test will fail
-            Assert.assertTrue(false);
-        } catch (ConstructionException e) {
-        }
-
-        try {
-            Node n1 = new Node(Node.NodeIDType.OPENFLOW, new Long(110L));
-            NodeConnector nc1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.ONEPK, new String(
-                            "Gi1/0/1"), n1);
-            // Exception is expected if not raised test will fail
-            Assert.assertTrue(false);
-        } catch (ConstructionException e) {
-        }
-
-        try {
-            Node n1 = new Node(Node.NodeIDType.OPENFLOW, new Long(110L));
-            NodeConnector nc1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.PCEP, new Integer(0), n1);
-            // Exception is expected if not raised test will fail
-            Assert.assertTrue(false);
-        } catch (ConstructionException e) {
-        }
-
-        try {
-            Node n1 = new Node(Node.NodeIDType.OPENFLOW, new Long(110L));
-            NodeConnector nc1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.PCEP2ONEPK,
-                    new Integer(0), n1);
-            // Exception is expected if not raised test will fail
-            Assert.assertTrue(false);
-        } catch (ConstructionException e) {
-        }
-
-        try {
-            Node n1 = new Node(Node.NodeIDType.OPENFLOW, new Long(110L));
-            NodeConnector nc1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.PCEP2OPENFLOW,
-                    new Integer(0), n1);
-            // Exception is expected if not raised test will fail
-            Assert.assertTrue(false);
-        } catch (ConstructionException e) {
-        }
-    }
-
-    @Test
-    public void testConversionToStringAndBack() {
-        try {
-            Node n1 = new Node(Node.NodeIDType.PCEP, new UUID(
-                    0xDEADBEEFCAFE0001L, 0xDEADBEEFCAFE0002L));
-            NodeConnector nc1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.PCEP2ONEPK, new Integer(
-                            0xDEADBEEF), n1);
-            String nc1Str = nc1.toString();
-            System.out.println("NodeConnector String = " + nc1Str);
-            NodeConnector nc1FromStr = NodeConnector.fromString(nc1Str);
-
-            // Make sure we got a nodeconnector
-            Assert.assertTrue(nc1FromStr != null);
-
-            // Now the converted nodeconnector need to be the same of the
-            // original one
-            Assert.assertTrue(nc1.equals(nc1FromStr));
-        } catch (ConstructionException e) {
-            // Fail if exception raised
-            Assert.assertTrue(false);
-        }
-
-        try {
-            Node n1 = new Node(Node.NodeIDType.PCEP, new UUID(
-                    0xDEADBEEFCAFE0001L, 0xDEADBEEFCAFE0002L));
-            NodeConnector nc1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.PCEP2OPENFLOW,
-                    new Integer(0x10), n1);
-            String nc1Str = nc1.toString();
-            System.out.println("NodeConnector String = " + nc1Str);
-            NodeConnector nc1FromStr = NodeConnector.fromString(nc1Str);
-
-            // Make sure we got a nodeconnector
-            Assert.assertTrue(nc1FromStr != null);
-
-            // Now the converted nodeconnector need to be the same of the
-            // original one
-            Assert.assertTrue(nc1.equals(nc1FromStr));
-        } catch (ConstructionException e) {
-            // Fail if exception raised
-            Assert.assertTrue(false);
-        }
-
-        try {
-            Node n1 = new Node(Node.NodeIDType.PCEP, new UUID(
-                    0xDEADBEEFCAFE0001L, 0xDEADBEEFCAFE0002L));
-            NodeConnector nc1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.PCEP, new Integer(0x10),
-                    n1);
-            String nc1Str = nc1.toString();
-            System.out.println("NodeConnector String = " + nc1Str);
-            NodeConnector nc1FromStr = NodeConnector.fromString(nc1Str);
-
-            // Make sure we got a nodeconnector
-            Assert.assertTrue(nc1FromStr != null);
-
-            // Now the converted nodeconnector need to be the same of the
-            // original one
-            Assert.assertTrue(nc1.equals(nc1FromStr));
-        } catch (ConstructionException e) {
-            // Fail if exception raised
-            Assert.assertTrue(false);
-        }
-
-        try {
-            Node n1 = new Node(Node.NodeIDType.ONEPK, new String("Router1"));
-            NodeConnector nc1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.ONEPK2PCEP, new String(
-                            "towardPCEP1"), n1);
-
-            String nc1Str = nc1.toString();
-            System.out.println("NodeConnector String = " + nc1Str);
-            NodeConnector nc1FromStr = NodeConnector.fromString(nc1Str);
-
-            // Make sure we got a nodeconnector
-            Assert.assertTrue(nc1FromStr != null);
-
-            // Now the converted nodeconnector need to be the same of the
-            // original one
-            Assert.assertTrue(nc1.equals(nc1FromStr));
-        } catch (ConstructionException e) {
-            // Fail if exception raised
-            Assert.assertTrue(false);
-        }
-
-        try {
-            Node n1 = new Node(Node.NodeIDType.ONEPK, new String("Router1"));
-            NodeConnector nc1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.ONEPK2OPENFLOW,
-                    new String("towardOPENFLOW1"), n1);
-
-            String nc1Str = nc1.toString();
-            System.out.println("NodeConnector String = " + nc1Str);
-            NodeConnector nc1FromStr = NodeConnector.fromString(nc1Str);
-
-            // Make sure we got a nodeconnector
-            Assert.assertTrue(nc1FromStr != null);
-
-            // Now the converted nodeconnector need to be the same of the
-            // original one
-            Assert.assertTrue(nc1.equals(nc1FromStr));
-        } catch (ConstructionException e) {
-            // Fail if exception raised
-            Assert.assertTrue(false);
-        }
-
-        try {
-            Node n1 = new Node(Node.NodeIDType.ONEPK, new String("Router1"));
-            NodeConnector nc1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.ONEPK, new String(
-                            "Gi1/0/1"), n1);
-
-            String nc1Str = nc1.toString();
-            System.out.println("NodeConnector String = " + nc1Str);
-            NodeConnector nc1FromStr = NodeConnector.fromString(nc1Str);
-
-            // Make sure we got a nodeconnector
-            Assert.assertTrue(nc1FromStr != null);
-
-            // Now the converted nodeconnector need to be the same of the
-            // original one
-            Assert.assertTrue(nc1.equals(nc1FromStr));
-        } catch (ConstructionException e) {
-            // Fail if exception raised
-            Assert.assertTrue(false);
-        }
-
-        try {
-            Node n1 = new Node(Node.NodeIDType.OPENFLOW, new Long(
-                    0xDEADBEEFCAFE0001L));
-            NodeConnector nc1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.OPENFLOW, new Short(
-                            (short) 0xCAFE), n1);
-
-            String nc1Str = nc1.toString();
-            System.out.println("NodeConnector String = " + nc1Str);
-            NodeConnector nc1FromStr = NodeConnector.fromString(nc1Str);
-
-            // Make sure we got a nodeconnector
-            Assert.assertTrue(nc1FromStr != null);
-
-            // Now the converted nodeconnector need to be the same of the
-            // original one
-            Assert.assertTrue(nc1.equals(nc1FromStr));
-        } catch (ConstructionException e) {
-            // Fail if exception raised
-            Assert.assertTrue(false);
-        }
-
-        try {
-            Node n1 = new Node(Node.NodeIDType.OPENFLOW, new Long(0x100L));
-            NodeConnector nc1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.OPENFLOW2PCEP, new Short(
-                            (short) 0x10), n1);
-
-            String nc1Str = nc1.toString();
-            System.out.println("NodeConnector String = " + nc1Str);
-            NodeConnector nc1FromStr = NodeConnector.fromString(nc1Str);
-
-            // Make sure we got a nodeconnector
-            Assert.assertTrue(nc1FromStr != null);
-
-            // Now the converted nodeconnector need to be the same of the
-            // original one
-            Assert.assertTrue(nc1.equals(nc1FromStr));
-        } catch (ConstructionException e) {
-            // Fail if exception raised
-            Assert.assertTrue(false);
-        }
-
-        try {
-            Node n1 = new Node(Node.NodeIDType.OPENFLOW, new Long(0x100L));
-            NodeConnector nc1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.OPENFLOW2ONEPK,
-                    new Short((short) 0x11), n1);
-
-            String nc1Str = nc1.toString();
-            System.out.println("NodeConnector String = " + nc1Str);
-            NodeConnector nc1FromStr = NodeConnector.fromString(nc1Str);
-
-            // Make sure we got a nodeconnector
-            Assert.assertTrue(nc1FromStr != null);
-
-            // Now the converted nodeconnector need to be the same of the
-            // original one
-            Assert.assertTrue(nc1.equals(nc1FromStr));
-        } catch (ConstructionException e) {
-            // Fail if exception raised
-            Assert.assertTrue(false);
-        }
-    }
-
-    @Test
-    public void testNodeConnectorSpecialType() {
-        try {
-            Node n = new Node(Node.NodeIDType.OPENFLOW, new Long(110L));
-            NodeConnector specialNc = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.CONTROLLER,
-                    NodeConnector.SPECIALNODECONNECTORID, n);
-            System.out.println("Special NC = " + specialNc);
-            // We expect to reach this point succesfully
-            Assert.assertTrue(true);
-        } catch (ConstructionException e) {
-            // If this expection is raised the test is failing
-            System.out.println("Got exception as expected!:" + e);
-            Assert.assertTrue(false);
-        }
-
-        try {
-            Node n = new Node(Node.NodeIDType.OPENFLOW, new Long(110L));
-            NodeConnector specialNc = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.ALL,
-                    NodeConnector.SPECIALNODECONNECTORID, n);
-            System.out.println("Special NC = " + specialNc);
-            // We expect to reach this point succesfully
-            Assert.assertTrue(true);
-        } catch (ConstructionException e) {
-            // If this expection is raised the test is failing
-            System.out.println("Got exception as expected!:" + e);
-            Assert.assertTrue(false);
-        }
-
-        try {
-            Node n = new Node(Node.NodeIDType.OPENFLOW, new Long(110L));
-            NodeConnector specialNc = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.SWSTACK,
-                    NodeConnector.SPECIALNODECONNECTORID, n);
-            System.out.println("Special NC = " + specialNc);
-            // We expect to reach this point succesfully
-            Assert.assertTrue(true);
-        } catch (ConstructionException e) {
-            // If this expection is raised the test is failing
-            System.out.println("Got exception as expected!:" + e);
-            Assert.assertTrue(false);
-        }
-
-        try {
-            Node n = new Node(Node.NodeIDType.OPENFLOW, new Long(110L));
-            NodeConnector specialNc = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.HWPATH,
-                    NodeConnector.SPECIALNODECONNECTORID, n);
-            System.out.println("Special NC = " + specialNc);
-            // We expect to reach this point succesfully
-            Assert.assertTrue(true);
-        } catch (ConstructionException e) {
-            // If this expection is raised the test is failing
-            System.out.println("Got exception as expected!:" + e);
-            Assert.assertTrue(false);
-        }
-
-        try {
-            Node n = new Node(Node.NodeIDType.ONEPK, new String("Router1"));
-            NodeConnector specialNc = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.CONTROLLER,
-                    NodeConnector.SPECIALNODECONNECTORID, n);
-            System.out.println("Special NC = " + specialNc);
-            // We expect to reach this point succesfully
-            Assert.assertTrue(true);
-        } catch (ConstructionException e) {
-            // If this expection is raised the test is failing
-            System.out.println("Got exception as expected!:" + e);
-            Assert.assertTrue(false);
-        }
-
-        try {
-            Node n = new Node(Node.NodeIDType.ONEPK, new String("Router1"));
-            NodeConnector specialNc = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.ALL,
-                    NodeConnector.SPECIALNODECONNECTORID, n);
-            System.out.println("Special NC = " + specialNc);
-            // We expect to reach this point succesfully
-            Assert.assertTrue(true);
-        } catch (ConstructionException e) {
-            // If this expection is raised the test is failing
-            System.out.println("Got exception as expected!:" + e);
-            Assert.assertTrue(false);
-        }
-
-        try {
-            Node n = new Node(Node.NodeIDType.ONEPK, new String("Router1"));
-            NodeConnector specialNc = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.SWSTACK,
-                    NodeConnector.SPECIALNODECONNECTORID, n);
-            System.out.println("Special NC = " + specialNc);
-            // We expect to reach this point succesfully
-            Assert.assertTrue(true);
-        } catch (ConstructionException e) {
-            // If this expection is raised the test is failing
-            System.out.println("Got exception as expected!:" + e);
-            Assert.assertTrue(false);
-        }
-
-        try {
-            Node n = new Node(Node.NodeIDType.ONEPK, new String("Router1"));
-            NodeConnector specialNc = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.HWPATH,
-                    NodeConnector.SPECIALNODECONNECTORID, n);
-            System.out.println("Special NC = " + specialNc);
-            // We expect to reach this point succesfully
-            Assert.assertTrue(true);
-        } catch (ConstructionException e) {
-            // If this expection is raised the test is failing
-            System.out.println("Got exception as expected!:" + e);
-            Assert.assertTrue(false);
-        }
-
-        try {
-            Node n = new Node(Node.NodeIDType.PCEP, new UUID(0L, 0L));
-            NodeConnector specialNc = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.CONTROLLER,
-                    NodeConnector.SPECIALNODECONNECTORID, n);
-            System.out.println("Special NC = " + specialNc);
-            // We expect to reach this point succesfully
-            Assert.assertTrue(true);
-        } catch (ConstructionException e) {
-            // If this expection is raised the test is failing
-            System.out.println("Got exception as expected!:" + e);
-            Assert.assertTrue(false);
-        }
-
-        try {
-            Node n = new Node(Node.NodeIDType.PCEP, new UUID(0L, 0L));
-            NodeConnector specialNc = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.ALL,
-                    NodeConnector.SPECIALNODECONNECTORID, n);
-            System.out.println("Special NC = " + specialNc);
-            // We expect to reach this point succesfully
-            Assert.assertTrue(true);
-        } catch (ConstructionException e) {
-            // If this expection is raised the test is failing
-            System.out.println("Got exception as expected!:" + e);
-            Assert.assertTrue(false);
-        }
-
-        try {
-            Node n = new Node(Node.NodeIDType.PCEP, new UUID(0L, 0L));
-            NodeConnector specialNc = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.SWSTACK,
-                    NodeConnector.SPECIALNODECONNECTORID, n);
-            System.out.println("Special NC = " + specialNc);
-            // We expect to reach this point succesfully
-            Assert.assertTrue(true);
-        } catch (ConstructionException e) {
-            // If this expection is raised the test is failing
-            System.out.println("Got exception as expected!:" + e);
-            Assert.assertTrue(false);
-        }
-
-        try {
-            Node n = new Node(Node.NodeIDType.PCEP, new UUID(0L, 0L));
-            NodeConnector specialNc = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.HWPATH,
-                    NodeConnector.SPECIALNODECONNECTORID, n);
-            System.out.println("Special NC = " + specialNc);
-            // We expect to reach this point succesfully
-            Assert.assertTrue(true);
-        } catch (ConstructionException e) {
-            // If this expection is raised the test is failing
-            System.out.println("Got exception as expected!:" + e);
-            Assert.assertTrue(false);
-        }
-    }
-
-    @Test
-    public void testToStringConversionForOpenFlow() {
-        try {
-            Node n = new Node(Node.NodeIDType.OPENFLOW, new Long(110L));
-            NodeConnector nc = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.OPENFLOW, new Short(
-                            (short) 0x2AB), n);
-
-            NodeConnector ofFromStr = null;
-
-            ofFromStr = NodeConnector.fromStringNoNode("0x2ab", n);
-
-            // Make sure we got a nodeconnector
-            Assert.assertTrue(ofFromStr != null);
-
-            // Now the converted nodeconnector need to be the same of the
-            // original one
-            Assert.assertTrue(nc.equals(ofFromStr));
-
-            ofFromStr = NodeConnector.fromStringNoNode("0x2AB", n);
-
-            // Make sure we got a nodeconnector
-            Assert.assertTrue(ofFromStr != null);
-
-            // Now the converted nodeconnector need to be the same of the
-            // original one
-            Assert.assertTrue(nc.equals(ofFromStr));
-
-            ofFromStr = NodeConnector.fromStringNoNode("683", n);
-
-            // Make sure we got a nodeconnector
-            Assert.assertTrue(ofFromStr != null);
-
-            // Now the converted nodeconnector need to be the same of the
-            // original one
-            Assert.assertTrue(nc.equals(ofFromStr));
-        } catch (Exception e) {
-            // If this expection is raised the test is failing
-            System.out.println("Got exception as expected!:" + e);
-            Assert.assertTrue(false);
-        }
-
-        try {
-            Node n = new Node(Node.NodeIDType.OPENFLOW, new Long(110L));
-            NodeConnector nc = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.OPENFLOW, new Short(
-                            (short) 0xcafe), n);
-
-            NodeConnector ofFromStr = null;
-
-            ofFromStr = NodeConnector.fromStringNoNode("-13570", n);
-
-            // Make sure we got a nodeconnector
-            Assert.assertTrue(ofFromStr != null);
-
-            // Now the converted nodeconnector need to be the same of the
-            // original one
-            Assert.assertTrue(nc.equals(ofFromStr));
-        } catch (Exception e) {
-            // If this expection is raised the test is failing
-            System.out.println("Got exception as expected!:" + e);
-            Assert.assertTrue(false);
-        }
-    }
-
-    @Test
-    public void testConversionToStringAndBackSpecialPorts() {
-        try {
-            Node n = new Node(Node.NodeIDType.OPENFLOW, new Long(110L));
-            NodeConnector specialNc = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.CONTROLLER,
-                    NodeConnector.SPECIALNODECONNECTORID, n);
-
-            String specialNcStr = specialNc.toString();
-            System.out.println("NodeConnector String obtained= " + specialNc);
-            NodeConnector specialNcFromStr = NodeConnector
-                    .fromString(specialNcStr);
-
-            // Make sure we got a nodeconnector
-            Assert.assertTrue(specialNcFromStr != null);
-
-            // Now the converted nodeconnector need to be the same of the
-            // original one
-            Assert.assertTrue(specialNc.equals(specialNcFromStr));
-        } catch (ConstructionException e) {
-            // Fail if exception raised
-            Assert.assertTrue(false);
-        }
-
-        try {
-            Node n = new Node(Node.NodeIDType.OPENFLOW, new Long(110L));
-            NodeConnector specialNc = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.ALL,
-                    NodeConnector.SPECIALNODECONNECTORID, n);
-
-            String specialNcStr = specialNc.toString();
-            System.out.println("NodeConnector String obtained= " + specialNc);
-            NodeConnector specialNcFromStr = NodeConnector
-                    .fromString(specialNcStr);
-
-            // Make sure we got a nodeconnector
-            Assert.assertTrue(specialNcFromStr != null);
-
-            // Now the converted nodeconnector need to be the same of the
-            // original one
-            Assert.assertTrue(specialNc.equals(specialNcFromStr));
-        } catch (ConstructionException e) {
-            // Fail if exception raised
-            Assert.assertTrue(false);
-        }
-
-        try {
-            Node n = new Node(Node.NodeIDType.OPENFLOW, new Long(110L));
-            NodeConnector specialNc = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.HWPATH,
-                    NodeConnector.SPECIALNODECONNECTORID, n);
-
-            String specialNcStr = specialNc.toString();
-            System.out.println("NodeConnector String obtained= " + specialNc);
-            NodeConnector specialNcFromStr = NodeConnector
-                    .fromString(specialNcStr);
-
-            // Make sure we got a nodeconnector
-            Assert.assertTrue(specialNcFromStr != null);
-
-            // Now the converted nodeconnector need to be the same of the
-            // original one
-            Assert.assertTrue(specialNc.equals(specialNcFromStr));
-        } catch (ConstructionException e) {
-            // Fail if exception raised
-            Assert.assertTrue(false);
-        }
-
-        try {
-            Node n = new Node(Node.NodeIDType.OPENFLOW, new Long(110L));
-            NodeConnector specialNc = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.SWSTACK,
-                    NodeConnector.SPECIALNODECONNECTORID, n);
-
-            String specialNcStr = specialNc.toString();
-            System.out.println("NodeConnector String obtained= " + specialNc);
-            NodeConnector specialNcFromStr = NodeConnector
-                    .fromString(specialNcStr);
-
-            // Make sure we got a nodeconnector
-            Assert.assertTrue(specialNcFromStr != null);
-
-            // Now the converted nodeconnector need to be the same of the
-            // original one
-            Assert.assertTrue(specialNc.equals(specialNcFromStr));
-        } catch (ConstructionException e) {
-            // Fail if exception raised
-            Assert.assertTrue(false);
-        }
-
-        try {
-            Node n = new Node(Node.NodeIDType.PCEP, new UUID(0L, 0L));
-            NodeConnector specialNc = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.CONTROLLER,
-                    NodeConnector.SPECIALNODECONNECTORID, n);
-
-            String specialNcStr = specialNc.toString();
-            System.out.println("NodeConnector String obtained= " + specialNc);
-            NodeConnector specialNcFromStr = NodeConnector
-                    .fromString(specialNcStr);
-
-            // Make sure we got a nodeconnector
-            Assert.assertTrue(specialNcFromStr != null);
-
-            // Now the converted nodeconnector need to be the same of the
-            // original one
-            Assert.assertTrue(specialNc.equals(specialNcFromStr));
-        } catch (ConstructionException e) {
-            // Fail if exception raised
-            Assert.assertTrue(false);
-        }
-
-        try {
-            Node n = new Node(Node.NodeIDType.PCEP, new UUID(0L, 0L));
-            NodeConnector specialNc = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.ALL,
-                    NodeConnector.SPECIALNODECONNECTORID, n);
-
-            String specialNcStr = specialNc.toString();
-            System.out.println("NodeConnector String obtained= " + specialNc);
-            NodeConnector specialNcFromStr = NodeConnector
-                    .fromString(specialNcStr);
-
-            // Make sure we got a nodeconnector
-            Assert.assertTrue(specialNcFromStr != null);
-
-            // Now the converted nodeconnector need to be the same of the
-            // original one
-            Assert.assertTrue(specialNc.equals(specialNcFromStr));
-        } catch (ConstructionException e) {
-            // Fail if exception raised
-            Assert.assertTrue(false);
-        }
-
-        try {
-            Node n = new Node(Node.NodeIDType.PCEP, new UUID(0L, 0L));
-            NodeConnector specialNc = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.HWPATH,
-                    NodeConnector.SPECIALNODECONNECTORID, n);
-
-            String specialNcStr = specialNc.toString();
-            System.out.println("NodeConnector String obtained= " + specialNc);
-            NodeConnector specialNcFromStr = NodeConnector
-                    .fromString(specialNcStr);
-
-            // Make sure we got a nodeconnector
-            Assert.assertTrue(specialNcFromStr != null);
-
-            // Now the converted nodeconnector need to be the same of the
-            // original one
-            Assert.assertTrue(specialNc.equals(specialNcFromStr));
-        } catch (ConstructionException e) {
-            // Fail if exception raised
-            Assert.assertTrue(false);
-        }
-
-        try {
-            Node n = new Node(Node.NodeIDType.PCEP, new UUID(0L, 0L));
-            NodeConnector specialNc = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.SWSTACK,
-                    NodeConnector.SPECIALNODECONNECTORID, n);
-
-            String specialNcStr = specialNc.toString();
-            System.out.println("NodeConnector String obtained= " + specialNc);
-            NodeConnector specialNcFromStr = NodeConnector
-                    .fromString(specialNcStr);
-
-            // Make sure we got a nodeconnector
-            Assert.assertTrue(specialNcFromStr != null);
-
-            // Now the converted nodeconnector need to be the same of the
-            // original one
-            Assert.assertTrue(specialNc.equals(specialNcFromStr));
-        } catch (ConstructionException e) {
-            // Fail if exception raised
-            Assert.assertTrue(false);
-        }
-
-        try {
-            Node n = new Node(Node.NodeIDType.ONEPK, new String("Router1"));
-            NodeConnector specialNc = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.CONTROLLER,
-                    NodeConnector.SPECIALNODECONNECTORID, n);
-
-            String specialNcStr = specialNc.toString();
-            System.out.println("NodeConnector String obtained= " + specialNc);
-            NodeConnector specialNcFromStr = NodeConnector
-                    .fromString(specialNcStr);
-
-            // Make sure we got a nodeconnector
-            Assert.assertTrue(specialNcFromStr != null);
-
-            // Now the converted nodeconnector need to be the same of the
-            // original one
-            Assert.assertTrue(specialNc.equals(specialNcFromStr));
-        } catch (ConstructionException e) {
-            // Fail if exception raised
-            Assert.assertTrue(false);
-        }
-
-        try {
-            Node n = new Node(Node.NodeIDType.ONEPK, new String("Router1"));
-            NodeConnector specialNc = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.ALL,
-                    NodeConnector.SPECIALNODECONNECTORID, n);
-
-            String specialNcStr = specialNc.toString();
-            System.out.println("NodeConnector String obtained= " + specialNc);
-            NodeConnector specialNcFromStr = NodeConnector
-                    .fromString(specialNcStr);
-
-            // Make sure we got a nodeconnector
-            Assert.assertTrue(specialNcFromStr != null);
-
-            // Now the converted nodeconnector need to be the same of the
-            // original one
-            Assert.assertTrue(specialNc.equals(specialNcFromStr));
-        } catch (ConstructionException e) {
-            // Fail if exception raised
-            Assert.assertTrue(false);
-        }
-
-        try {
-            Node n = new Node(Node.NodeIDType.ONEPK, new String("Router1"));
-            NodeConnector specialNc = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.HWPATH,
-                    NodeConnector.SPECIALNODECONNECTORID, n);
-
-            String specialNcStr = specialNc.toString();
-            System.out.println("NodeConnector String obtained= " + specialNc);
-            NodeConnector specialNcFromStr = NodeConnector
-                    .fromString(specialNcStr);
-
-            // Make sure we got a nodeconnector
-            Assert.assertTrue(specialNcFromStr != null);
-
-            // Now the converted nodeconnector need to be the same of the
-            // original one
-            Assert.assertTrue(specialNc.equals(specialNcFromStr));
-        } catch (ConstructionException e) {
-            // Fail if exception raised
-            Assert.assertTrue(false);
-        }
-
-        try {
-            Node n = new Node(Node.NodeIDType.ONEPK, new String("Router1"));
-            NodeConnector specialNc = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.SWSTACK,
-                    NodeConnector.SPECIALNODECONNECTORID, n);
-
-            String specialNcStr = specialNc.toString();
-            System.out.println("NodeConnector String obtained= " + specialNc);
-            NodeConnector specialNcFromStr = NodeConnector
-                    .fromString(specialNcStr);
-
-            // Make sure we got a nodeconnector
-            Assert.assertTrue(specialNcFromStr != null);
-
-            // Now the converted nodeconnector need to be the same of the
-            // original one
-            Assert.assertTrue(specialNc.equals(specialNcFromStr));
-        } catch (ConstructionException e) {
-            // Fail if exception raised
-            Assert.assertTrue(false);
-        }
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/core/NodeTableTest.java b/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/core/NodeTableTest.java
deleted file mode 100644 (file)
index d018823..0000000
+++ /dev/null
@@ -1,80 +0,0 @@
-/*
- * Copyright (c) 2013 Big Switch Networks, Inc.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.sal.core;
-
-import org.junit.Assert;
-import org.junit.Test;
-import org.opendaylight.controller.sal.utils.NodeCreator;
-
-public class NodeTableTest {
-    @Test
-    public void testNodeTableOpenFlowOfWrongType() {
-        try {
-            Node node = NodeCreator.createOFNode((long) 20);
-            @SuppressWarnings("unused")
-            NodeTable of1 = new NodeTable(NodeTable.NodeTableIDType.OPENFLOW, "name", node);
-
-            // If we reach this point the exception was not raised
-            // which should have been the case
-            Assert.assertTrue(false);
-        } catch (ConstructionException e) {
-            // If we reach this point the exception has been raised
-            // and so test passed
-            System.out.println("Got exception as expected!:" + e);
-            Assert.assertTrue(true);
-        }
-    }
-
-    @Test
-    public void testNodeTableOpenFlowOfCorrectType() {
-        try {
-            Node node = NodeCreator.createOFNode((long) 20);
-            NodeTable of1 = new NodeTable(NodeTable.NodeTableIDType.OPENFLOW, Byte.valueOf("10"), node);
-
-            // If we reach this point the exception has not been
-            // raised so we passed the test
-            System.out.println("Got node table:" + of1);
-            Assert.assertTrue(true);
-        } catch (ConstructionException e) {
-            // If we reach this point the exception was raised
-            // which is not expected
-            Assert.assertTrue(false);
-        }
-    }
-
-    @Test
-    public void testTwoOpenFlowNodeTableEquals() {
-        try {
-            Node node1 = NodeCreator.createOFNode((long) 20);
-            NodeTable of1 = new NodeTable(NodeTable.NodeTableIDType.OPENFLOW, Byte.valueOf("10"), node1);
-            NodeTable of2 = new NodeTable(NodeTable.NodeTableIDType.OPENFLOW, Byte.valueOf("10"), node1);
-
-            Assert.assertTrue(of1.equals(of2));
-        } catch (ConstructionException e) {
-            // If we reach this point the exception was raised
-            // which is not expected
-            Assert.assertTrue(false);
-        }
-    }
-
-    @Test
-    public void testTwoOpenFlowNodeTableDifferents() {
-        try {
-            Node node1 = NodeCreator.createOFNode((long) 20);
-            NodeTable of1 = new NodeTable(NodeTable.NodeTableIDType.OPENFLOW, Byte.valueOf("10"), node1);
-            Node node2 = NodeCreator.createOFNode((long) 40);
-            NodeTable of2 = new NodeTable(NodeTable.NodeTableIDType.OPENFLOW, Byte.valueOf("20"), node2);
-
-            Assert.assertTrue(!of1.equals(of2));
-        } catch (ConstructionException e) {
-            // If we reach this point the exception was raised
-            // which is not expected
-            Assert.assertTrue(false);
-        }
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/core/NodeTest.java b/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/core/NodeTest.java
deleted file mode 100644 (file)
index 0b394bf..0000000
+++ /dev/null
@@ -1,429 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * @file   NodeTest.java
- *
- * @brief  Unit Tests for Node element
- *
- * Unit Tests for Node element
- */
-package org.opendaylight.controller.sal.core;
-
-import java.util.UUID;
-import org.junit.Assert;
-import org.junit.Test;
-
-public class NodeTest {
-    @Test
-    public void testNodeOpenFlowOfWrongType() {
-        try {
-            @SuppressWarnings("unused")
-            Node of1 = new Node(Node.NodeIDType.OPENFLOW, new String(
-                    "0xDEADBEEFCAFE0001L"));
-
-            // If we reach this point the exception was not raised
-            // which should have been the case
-            Assert.assertTrue(false);
-        } catch (ConstructionException e) {
-            // If we reach this point the exception has been raised
-            // and so test passed
-            System.out.println("Got exception as expected!:" + e);
-            Assert.assertTrue(true);
-        }
-    }
-
-    @Test
-    public void testNodeONEPKOfWrongType() {
-        try {
-            @SuppressWarnings("unused")
-            Node onepk1 = new Node(Node.NodeIDType.ONEPK, new Long(
-                    0xDEADBEEFCAFE0001L));
-
-            // If we reach this point the exception was not raised
-            // which should have been the case
-            Assert.assertTrue(false);
-        } catch (ConstructionException e) {
-            // If we reach this point the exception has been raised
-            // and so test passed
-            System.out.println("Got exception as expected!:" + e);
-            Assert.assertTrue(true);
-        }
-    }
-
-    @Test
-    public void testNodePCEPOfWrongType() {
-        try {
-            @SuppressWarnings("unused")
-            Node pcep1 = new Node(Node.NodeIDType.PCEP, new Long(
-                    0xDEADBEEFCAFE0001L));
-
-            // If we reach this point the exception was not raised
-            // which should have been the case
-            Assert.assertTrue(false);
-        } catch (ConstructionException e) {
-            // If we reach this point the exception has been raised
-            // and so test passed
-            System.out.println("Got exception as expected!:" + e);
-            Assert.assertTrue(true);
-        }
-    }
-
-    @Test
-    public void testNodeOpenFlowOfCorrectType() {
-        try {
-            Node of1 = new Node(Node.NodeIDType.OPENFLOW, new Long(
-                    0xDEADBEEFCAFE0001L));
-
-            // If we reach this point the exception has not been
-            // raised so we passed the test
-            System.out.println("Got node:" + of1);
-            Assert.assertTrue(true);
-        } catch (ConstructionException e) {
-            // If we reach this point the exception was raised
-            // which is not expected
-            Assert.assertTrue(false);
-        }
-    }
-
-    @Test
-    public void testNodeONEPKOfCorrectType() {
-        try {
-            Node onepk1 = new Node(Node.NodeIDType.ONEPK, new String(
-                    "0xDEADBEEFCAFE0001L"));
-
-            // If we reach this point the exception has not been
-            // raised so we passed the test
-            System.out.println("Got node:" + onepk1);
-            Assert.assertTrue(true);
-        } catch (ConstructionException e) {
-            // If we reach this point the exception was raised
-            // which is not expected
-            Assert.assertTrue(false);
-        }
-    }
-
-    @Test
-    public void testNodePCEPOfCorrectType() {
-        try {
-            Node pcep1 = new Node(Node.NodeIDType.PCEP, new UUID(0L, 0L));
-
-            // If we reach this point the exception has not been
-            // raised so we passed the test
-            System.out.println("Got node:" + pcep1);
-            Assert.assertTrue(true);
-        } catch (ConstructionException e) {
-            // If we reach this point the exception was raised
-            // which is not expected
-            Assert.assertTrue(false);
-        }
-    }
-
-    @Test
-    public void testTwoOpenFlowNodeEquals() {
-        try {
-            Node of1 = new Node(Node.NodeIDType.OPENFLOW, new Long(
-                    0xDEADBEEFCAFE0001L));
-            Node of2 = new Node(Node.NodeIDType.OPENFLOW, new Long(
-                    0xDEADBEEFCAFE0001L));
-
-            Assert.assertTrue(of1.equals(of2));
-        } catch (ConstructionException e) {
-            // If we reach this point the exception was raised
-            // which is not expected
-            Assert.assertTrue(false);
-        }
-    }
-
-    @Test
-    public void testTwoONEPKNodeEquals() {
-        try {
-            Node onepk1 = new Node(Node.NodeIDType.ONEPK, new String(
-                    "0xDEADBEEFCAFE0001L"));
-            Node onepk2 = new Node(Node.NodeIDType.ONEPK, new String(
-                    "0xDEADBEEFCAFE0001L"));
-
-            Assert.assertTrue(onepk1.equals(onepk2));
-        } catch (ConstructionException e) {
-            // If we reach this point the exception was raised
-            // which is not expected
-            Assert.assertTrue(false);
-        }
-    }
-
-    @Test
-    public void testTwoPCEPNodeEquals() {
-        try {
-            Node pcep1 = new Node(Node.NodeIDType.PCEP, new UUID(
-                    0xDEADBEEFCAFE0001L, 0L));
-            Node pcep2 = new Node(Node.NodeIDType.PCEP, new UUID(
-                    0xDEADBEEFCAFE0001L, 0L));
-
-            Assert.assertTrue(pcep1.equals(pcep2));
-        } catch (ConstructionException e) {
-            // If we reach this point the exception was raised
-            // which is not expected
-            Assert.assertTrue(false);
-        }
-    }
-
-    @Test
-    public void testTwoOpenFlowNodeDifferents() {
-        try {
-            Node of1 = new Node(Node.NodeIDType.OPENFLOW, new Long(
-                    0xDEADBEEFCAFE0001L));
-            Node of2 = new Node(Node.NodeIDType.OPENFLOW, new Long(
-                    0xDEADBEEFCAFE0002L));
-
-            Assert.assertTrue(!of1.equals(of2));
-        } catch (ConstructionException e) {
-            // If we reach this point the exception was raised
-            // which is not expected
-            Assert.assertTrue(false);
-        }
-    }
-
-    @Test
-    public void testTwoONEPKNodeDifferents() {
-        try {
-            Node onepk1 = new Node(Node.NodeIDType.ONEPK, new String(
-                    "0xDEADBEEFCAFE0001L"));
-            Node onepk2 = new Node(Node.NodeIDType.ONEPK, new String(
-                    "0xDEADBEEFCAFE0002L"));
-
-            Assert.assertTrue(!onepk1.equals(onepk2));
-        } catch (ConstructionException e) {
-            // If we reach this point the exception was raised
-            // which is not expected
-            Assert.assertTrue(false);
-        }
-    }
-
-    @Test
-    public void testTwoPCEPNodeDifferents() {
-        try {
-            Node pcep1 = new Node(Node.NodeIDType.PCEP, new UUID(
-                    0xDEADBEEFCAFE0001L, 0L));
-            Node pcep2 = new Node(Node.NodeIDType.PCEP, new UUID(
-                    0xDEADBEEFCAFE0001L, 1L));
-
-            Assert.assertTrue(!pcep1.equals(pcep2));
-        } catch (ConstructionException e) {
-            // If we reach this point the exception was raised
-            // which is not expected
-            Assert.assertTrue(false);
-        }
-    }
-
-    @Test
-    public void testToStringConversionAndBack() {
-        // Test PCEP
-        try {
-            Node pcep = new Node(Node.NodeIDType.PCEP, new UUID(
-                    0xDEADBEEFCAFE0001L, 0L));
-
-            String pcepToStr = pcep.toString();
-            System.out.println("Got String from PCEP=(" + pcepToStr + ")");
-
-            Node pcepFromStr = Node.fromString(pcepToStr);
-
-            // Make sure we got a node
-            Assert.assertTrue(pcepFromStr != null);
-
-            // Now the converted node need to be the same of the
-            // original one
-            Assert.assertTrue(pcep.equals(pcepFromStr));
-        } catch (ConstructionException e) {
-            // If we reach this point the exception was raised
-            // which is not expected
-            Assert.assertTrue(false);
-        }
-
-        // Test ONEPK
-        try {
-            Node onepk = new Node(Node.NodeIDType.ONEPK, new String(
-                    "0xDEADBEEFCAFE0001L"));
-
-            String onepkToStr = onepk.toString();
-            System.out.println("Got String from ONEPK=(" + onepkToStr + ")");
-
-            Node onepkFromStr = Node.fromString(onepkToStr);
-
-            // Make sure we got a node
-            Assert.assertTrue(onepkFromStr != null);
-
-            // Now the converted node need to be the same of the
-            // original one
-            Assert.assertTrue(onepk.equals(onepkFromStr));
-        } catch (ConstructionException e) {
-            // If we reach this point the exception was raised
-            // which is not expected
-            Assert.assertTrue(false);
-        }
-
-        // Test OPENFLOW short string
-        try {
-            Node of = new Node(Node.NodeIDType.OPENFLOW, new Long(0x10L));
-
-            String ofToStr = of.toString();
-            System.out.println("Got String from OPENFLOW=(" + ofToStr + ")");
-
-            Node ofFromStr = Node.fromString(ofToStr);
-
-            // Make sure we got a node
-            Assert.assertTrue(ofFromStr != null);
-
-            // Now the converted node need to be the same of the
-            // original one
-            Assert.assertTrue(of.equals(ofFromStr));
-        } catch (ConstructionException e) {
-            // If we reach this point the exception was raised
-            // which is not expected
-            Assert.assertTrue(false);
-        }
-
-        // Test OPENFLOW longer string
-        try {
-            Node of = new Node(Node.NodeIDType.OPENFLOW, new Long(
-                    0xDEADBEEFCAFE0001L));
-
-            String ofToStr = of.toString();
-            System.out.println("Got String from OPENFLOW=(" + ofToStr + ")");
-
-            Node ofFromStr = Node.fromString(ofToStr);
-
-            // Make sure we got a node
-            Assert.assertTrue(ofFromStr != null);
-
-            // Now the converted node need to be the same of the
-            // original one
-            Assert.assertTrue(of.equals(ofFromStr));
-        } catch (ConstructionException e) {
-            // If we reach this point the exception was raised
-            // which is not expected
-            Assert.assertTrue(false);
-        }
-    }
-
-    @Test
-    public void testToStringConversionForOpenFlow() {
-        // Test OPENFLOW longer string
-        try {
-            Node of = new Node(Node.NodeIDType.OPENFLOW, new Long(
-                    0xDEADBEEFCAFE0001L));
-            Node ofFromStr = null;
-
-            // Decimal value for deadbeefcafe0001
-            ofFromStr = Node.fromString("-2401053089206501375");
-
-            // Make sure we got a node
-            Assert.assertTrue(ofFromStr != null);
-
-            // Now the converted node need to be the same of the
-            // original one
-            Assert.assertTrue(of.equals(ofFromStr));
-
-            ofFromStr = Node.fromString("deadbeefcafe0001");
-
-            // Make sure we got a node
-            Assert.assertTrue(ofFromStr != null);
-
-            // Now the converted node need to be the same of the
-            // original one
-            Assert.assertTrue(of.equals(ofFromStr));
-
-            ofFromStr = Node.fromString("DEADBEEFCAFE0001");
-
-            // Make sure we got a node
-            Assert.assertTrue(ofFromStr != null);
-
-            // Now the converted node need to be the same of the
-            // original one
-            Assert.assertTrue(of.equals(ofFromStr));
-
-            // Now the converted node need to be the same of the
-            // original one
-            Assert.assertTrue(of.equals(ofFromStr));
-
-            ofFromStr = Node.fromString("0xdeadbeefcafe0001");
-
-            // Make sure we got a node
-            Assert.assertTrue(ofFromStr != null);
-
-            // Now the converted node need to be the same of the
-            // original one
-            Assert.assertTrue(of.equals(ofFromStr));
-
-            ofFromStr = Node.fromString("0xDEADBEEFCAFE0001");
-
-            // Make sure we got a node
-            Assert.assertTrue(ofFromStr != null);
-
-            // Now the converted node need to be the same of the
-            // original one
-            Assert.assertTrue(of.equals(ofFromStr));
-
-            ofFromStr = Node.fromString("DE:AD:BE:EF:CA:FE:00:01");
-
-            // Make sure we got a node
-            Assert.assertTrue(ofFromStr != null);
-
-            // Now the converted node need to be the same of the
-            // original one
-            Assert.assertTrue(of.equals(ofFromStr));
-
-            ofFromStr = Node.fromString("de:ad:be:ef:ca:fe:00:01");
-
-            // Make sure we got a node
-            Assert.assertTrue(ofFromStr != null);
-
-            // Now the converted node need to be the same of the
-            // original one
-            Assert.assertTrue(of.equals(ofFromStr));
-        } catch (ConstructionException e) {
-            // If we reach this point the exception was raised
-            // which is not expected
-            Assert.assertTrue(false);
-        }
-    }
-
-    @Test
-    public void testExtensibleNode() {
-        // Add a new ID type
-        Assert.assertTrue(Node.NodeIDType.registerIDType("FOO", Integer.class));
-
-        // Trying to re-register the node must fail
-        Assert.assertFalse(Node.NodeIDType.registerIDType("FOO",
-                                                          Integer.class));
-        try {
-            Node n = new Node("FOO", new Integer(0xCAFE));
-
-            System.out.println("Got Extended node:" + n);
-        } catch (ConstructionException e) {
-            // Got an unexpected exception
-            Assert.assertTrue(false);
-        }
-
-        // Now unregister the type and make sure the node doesn't get
-        // created
-        Node.NodeIDType.unRegisterIDType("FOO");
-        try {
-            @SuppressWarnings("unused")
-            Node n = new Node("FOO", new Integer(0xCAFE));
-
-            // If we reach here, something didn't go fine, an
-            // exception should have been raised
-            Assert.assertTrue(false);
-        } catch (ConstructionException e) {
-            // Got an expected exception, do nothing!
-        }
-
-        Assert.assertTrue(true);
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/core/PathTest.java b/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/core/PathTest.java
deleted file mode 100644 (file)
index 0ea8855..0000000
+++ /dev/null
@@ -1,341 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * @file   PathTest.java
- *
- * @brief  Unit Tests for Path element
- *
- * Unit Tests for Path element
- */
-package org.opendaylight.controller.sal.core;
-
-import java.util.LinkedList;
-import java.util.List;
-import java.util.Arrays;
-import org.junit.Assert;
-import org.junit.Test;
-
-public class PathTest {
-    @Test
-    public void testPathValid() {
-        List<Edge> edges = null;
-        try {
-            Node n0 = new Node(Node.NodeIDType.OPENFLOW, new Long(40L));
-            NodeConnector c0 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.OPENFLOW, new Short(
-                            (short) 0x4), n0);
-
-            Node n1 = new Node(Node.NodeIDType.OPENFLOW, new Long(110L));
-            NodeConnector c1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.OPENFLOW, new Short(
-                            (short) 0x1), n1);
-            NodeConnector c2 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.OPENFLOW2ONEPK,
-                    new Short((short) 0xCAFE), n1);
-
-            Node n2 = new Node(Node.NodeIDType.ONEPK, new String("Router1"));
-            NodeConnector c3 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.ONEPK2OPENFLOW,
-                    new String("towardOF1"), n2);
-            NodeConnector c4 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.ONEPK, new String(
-                            "Gi1/0/1"), n2);
-
-            Node n3 = new Node(Node.NodeIDType.ONEPK, new String("Router2"));
-            NodeConnector c5 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.ONEPK, new String(
-                            "Gi1/0/1"), n3);
-
-            Edge e0 = new Edge(c0, c1);
-            Edge e1 = new Edge(c1, c2);
-            Edge e2 = new Edge(c2, c3);
-            Edge e3 = new Edge(c3, c4);
-            Edge e4 = new Edge(c4, c5);
-            // actually need a LinkedList because we're going to .remove()
-            edges = new LinkedList<Edge>(Arrays.asList(e0, e1, e2, e3, e4));
-        } catch (ConstructionException e) {
-            // Exception is NOT expected if raised test will fail
-            Assert.assertTrue(false);
-        }
-
-        try {
-            @SuppressWarnings("unused")
-            Path res = new Path(edges);
-        } catch (ConstructionException e) {
-            // Exception is NOT expected if raised test will fail
-            Assert.assertTrue(false);
-        }
-
-        // Now lets disconnect on edge so to create a disconnected
-        // path, the constructor should catch that and should not
-        // create the path
-        edges.remove(2);
-
-        try {
-            @SuppressWarnings("unused")
-            Path res = new Path(edges);
-            // Exception is expected if not raised test will fail
-            Assert.assertTrue(false);
-        } catch (ConstructionException e) {
-        }
-    }
-
-    @Test
-    public void testPathComparison() {
-        List<Edge> edges1 = null;
-        Path path1 = null;
-        List<Edge> edges2 = null;
-        Path path2 = null;
-        List<Edge> edges3 = null;
-        Path path3 = null;
-
-        try {
-            Node n0 = new Node(Node.NodeIDType.OPENFLOW, new Long(40L));
-            NodeConnector c0 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.OPENFLOW, new Short(
-                            (short) 0x4), n0);
-
-            Node n1 = new Node(Node.NodeIDType.OPENFLOW, new Long(110L));
-            NodeConnector c1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.OPENFLOW, new Short(
-                            (short) 0x1), n1);
-            NodeConnector c2 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.OPENFLOW2ONEPK,
-                    new Short((short) 0xCAFE), n1);
-
-            Node n2 = new Node(Node.NodeIDType.ONEPK, new String("Router1"));
-            NodeConnector c3 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.ONEPK2OPENFLOW,
-                    new String("towardOF1"), n2);
-            NodeConnector c4 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.ONEPK, new String(
-                            "Gi1/0/1"), n2);
-
-            Node n3 = new Node(Node.NodeIDType.ONEPK, new String("Router2"));
-            NodeConnector c5 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.ONEPK, new String(
-                            "Gi1/0/1"), n3);
-
-            Edge e0 = new Edge(c0, c1);
-            Edge e1 = new Edge(c1, c2);
-            Edge e2 = new Edge(c2, c3);
-            Edge e3 = new Edge(c3, c4);
-            Edge e4 = new Edge(c4, c5);
-            edges1 = Arrays.asList(e0, e1, e2, e3, e4);
-        } catch (ConstructionException e) {
-            // Exception is NOT expected if raised test will fail
-            Assert.assertTrue(false);
-        }
-
-        try {
-            Node n0 = new Node(Node.NodeIDType.OPENFLOW, new Long(40L));
-            NodeConnector c0 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.OPENFLOW, new Short(
-                            (short) 0x4), n0);
-
-            Node n1 = new Node(Node.NodeIDType.OPENFLOW, new Long(110L));
-            NodeConnector c1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.OPENFLOW, new Short(
-                            (short) 0x1), n1);
-            NodeConnector c2 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.OPENFLOW2ONEPK,
-                    new Short((short) 0xCAFE), n1);
-
-            Node n2 = new Node(Node.NodeIDType.ONEPK, new String("Router1"));
-            NodeConnector c3 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.ONEPK2OPENFLOW,
-                    new String("towardOF1"), n2);
-            NodeConnector c4 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.ONEPK, new String(
-                            "Gi1/0/1"), n2);
-
-            Node n3 = new Node(Node.NodeIDType.ONEPK, new String("Router2"));
-            NodeConnector c5 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.ONEPK, new String(
-                            "Gi1/0/1"), n3);
-
-            Edge e0 = new Edge(c0, c1);
-            Edge e1 = new Edge(c1, c2);
-            Edge e2 = new Edge(c2, c3);
-            Edge e3 = new Edge(c3, c4);
-            Edge e4 = new Edge(c4, c5);
-            edges2 = Arrays.asList(e0, e1, e2, e3, e4);
-        } catch (ConstructionException e) {
-            // Exception is NOT expected if raised test will fail
-            Assert.assertTrue(false);
-        }
-
-        try {
-            Node n0 = new Node(Node.NodeIDType.OPENFLOW, new Long(40L));
-            NodeConnector c0 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.OPENFLOW, new Short(
-                            (short) 0x5), n0);
-
-            Node n1 = new Node(Node.NodeIDType.OPENFLOW, new Long(110L));
-            NodeConnector c1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.OPENFLOW, new Short(
-                            (short) 0x1), n1);
-            NodeConnector c2 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.OPENFLOW2ONEPK,
-                    new Short((short) 0xCAFE), n1);
-
-            Node n2 = new Node(Node.NodeIDType.ONEPK, new String("Router1"));
-            NodeConnector c3 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.ONEPK2OPENFLOW,
-                    new String("towardOF1"), n2);
-            NodeConnector c4 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.ONEPK, new String(
-                            "Gi1/0/1"), n2);
-
-            Node n3 = new Node(Node.NodeIDType.ONEPK, new String("Router2"));
-            NodeConnector c5 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.ONEPK, new String(
-                            "Gi1/0/1"), n3);
-
-            Edge e0 = new Edge(c0, c1);
-            Edge e1 = new Edge(c1, c2);
-            Edge e2 = new Edge(c2, c3);
-            Edge e3 = new Edge(c3, c4);
-            Edge e4 = new Edge(c4, c5);
-            edges3 = Arrays.asList(e0, e1, e2, e3, e4);
-        } catch (ConstructionException e) {
-            // Exception is NOT expected if raised test will fail
-            Assert.assertTrue(false);
-        }
-
-        try {
-            path1 = new Path(edges1);
-            path2 = new Path(edges2);
-            path3 = new Path(edges3);
-
-            System.out.println("Path1: " + path1);
-            System.out.println("Path2: " + path2);
-            System.out.println("Path3: " + path3);
-
-            // Make sure the path are equals
-            Assert.assertTrue(path1.equals(path2));
-
-            // Make sure the path are marked as different
-            Assert.assertTrue(!path1.equals(path3));
-        } catch (ConstructionException e) {
-            // Exception is NOT expected if raised test will fail
-            Assert.assertTrue(false);
-        }
-    }
-
-    @Test
-    public void testPathEmpty() {
-        try {
-            @SuppressWarnings("unused")
-            Path path = new Path(new LinkedList<Edge>());
-            // Exception is expected if not raised test will fail
-            Assert.assertTrue(false);
-        } catch (ConstructionException e) {
-        }
-    }
-
-    @Test
-    public void testPathOneElement() {
-        try {
-            Node n0 = new Node(Node.NodeIDType.OPENFLOW, new Long(40L));
-            NodeConnector c0 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.OPENFLOW, new Short(
-                            (short) 0x5), n0);
-
-            Node n1 = new Node(Node.NodeIDType.OPENFLOW, new Long(110L));
-            NodeConnector c1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.OPENFLOW, new Short(
-                            (short) 0x1), n1);
-
-            Edge e0 = new Edge(c0, c1);
-
-            @SuppressWarnings("unused")
-            Path path = new Path(Arrays.asList(e0));
-        } catch (ConstructionException e) {
-            // Exception is NOT expected if raised test will fail
-            Assert.assertTrue(false);
-        }
-    }
-
-    @Test
-    public void testPathGetNodes() {
-        // Test on >2 edges paths
-        try {
-            Node n0 = new Node(Node.NodeIDType.OPENFLOW, new Long(40L));
-            NodeConnector c0 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.OPENFLOW, new Short(
-                            (short) 0x4), n0);
-
-            Node n1 = new Node(Node.NodeIDType.OPENFLOW, new Long(110L));
-            NodeConnector c1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.OPENFLOW, new Short(
-                            (short) 0x1), n1);
-            NodeConnector c2 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.OPENFLOW2ONEPK,
-                    new Short((short) 0xCAFE), n1);
-
-            Node n2 = new Node(Node.NodeIDType.ONEPK, new String("Router1"));
-            NodeConnector c3 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.ONEPK2OPENFLOW,
-                    new String("towardOF1"), n2);
-            NodeConnector c4 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.ONEPK, new String(
-                            "Gi1/0/1"), n2);
-
-            Node n3 = new Node(Node.NodeIDType.ONEPK, new String("Router2"));
-            NodeConnector c5 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.ONEPK, new String(
-                            "Gi1/0/1"), n3);
-
-            Edge e0 = new Edge(c0, c1);
-            Edge e1 = new Edge(c1, c2);
-            Edge e2 = new Edge(c2, c3);
-            Edge e3 = new Edge(c3, c4);
-            Edge e4 = new Edge(c4, c5);
-            List<Edge> edges = Arrays.asList(e0, e1, e2, e3, e4);
-            Path path = new Path(edges);
-
-            // Test start node
-            Assert.assertTrue(path.getStartNode().equals(n0));
-
-            // Test end node
-            Assert.assertTrue(path.getEndNode().equals(n3));
-        } catch (ConstructionException e) {
-            // Exception is NOT expected if raised test will fail
-            Assert.assertTrue(false);
-        }
-
-        // Test on 1 edge path
-        try {
-            Node n0 = new Node(Node.NodeIDType.OPENFLOW, new Long(40L));
-            NodeConnector c0 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.OPENFLOW, new Short(
-                            (short) 0x4), n0);
-
-            Node n1 = new Node(Node.NodeIDType.OPENFLOW, new Long(110L));
-            NodeConnector c1 = new NodeConnector(
-                    NodeConnector.NodeConnectorIDType.OPENFLOW, new Short(
-                            (short) 0x1), n1);
-
-            Edge e0 = new Edge(c0, c1);
-            List<Edge> edges = Arrays.asList(e0);
-            Path path = new Path(edges);
-
-            // Test start node
-            Assert.assertTrue(path.getStartNode().equals(n0));
-
-            // Test end node
-            Assert.assertTrue(path.getEndNode().equals(n1));
-        } catch (ConstructionException e) {
-            // Exception is NOT expected if raised test will fail
-            Assert.assertTrue(false);
-        }
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/core/PropertyTest.java b/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/core/PropertyTest.java
deleted file mode 100644 (file)
index 0828268..0000000
+++ /dev/null
@@ -1,92 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * @file   PropertyTest.java
- *
- * @brief  Test for properties
- *
- */
-
-package org.opendaylight.controller.sal.core;
-
-import org.junit.Assert;
-import org.junit.Test;
-
-public class PropertyTest {
-    @Test
-    public void testBandWidthStr() {
-        Property b;
-
-        b = new Bandwidth(Bandwidth.BWUNK);
-        System.out.println("b = " + b);
-        Assert.assertTrue(b.toString().equals("BandWidth[UnKnown]"));
-
-        b = new Bandwidth(100L);
-        System.out.println("b = " + b);
-        Assert.assertTrue(b.toString().equals("BandWidth[100bps]"));
-
-        b = new Bandwidth(Bandwidth.BW10Mbps);
-        System.out.println("b = " + b);
-        Assert.assertTrue(b.toString().equals("BandWidth[10Mbps]"));
-
-        b = new Bandwidth(Bandwidth.BW100Mbps);
-        System.out.println("b = " + b);
-        Assert.assertTrue(b.toString().equals("BandWidth[100Mbps]"));
-
-        b = new Bandwidth(Bandwidth.BW100Mbps);
-        System.out.println("b = " + b);
-        Assert.assertTrue(b.toString().equals("BandWidth[100Mbps]"));
-
-        b = new Bandwidth(Bandwidth.BW1Gbps);
-        System.out.println("b = " + b);
-        Assert.assertTrue(b.toString().equals("BandWidth[1Gbps]"));
-
-        b = new Bandwidth(Bandwidth.BW10Gbps);
-        System.out.println("b = " + b);
-        Assert.assertTrue(b.toString().equals("BandWidth[10Gbps]"));
-
-        b = new Bandwidth(Bandwidth.BW40Gbps);
-        System.out.println("b = " + b);
-        Assert.assertTrue(b.toString().equals("BandWidth[40Gbps]"));
-
-        b = new Bandwidth(Bandwidth.BW100Gbps);
-        System.out.println("b = " + b);
-        Assert.assertTrue(b.toString().equals("BandWidth[100Gbps]"));
-
-        b = new Bandwidth(Bandwidth.BW100Gbps + 15L);
-        System.out.println("b = " + b);
-        Assert.assertTrue(b.toString().equals("BandWidth[100Gbps]"));
-
-        b = new Bandwidth(Bandwidth.BW1Tbps);
-        System.out.println("b = " + b);
-        Assert.assertTrue(b.toString().equals("BandWidth[1Tbps]"));
-    }
-
-    @Test
-    public void testLatencyStr() {
-        Property l;
-
-        l = new Latency(Latency.LATENCYUNK);
-        System.out.println("l = " + l);
-        Assert.assertTrue(l.toString().equals("Latency[UnKnown]"));
-
-        l = new Latency(Latency.LATENCY1ns);
-        System.out.println("l = " + l);
-        Assert.assertTrue(l.toString().equals("Latency[1nsec]"));
-
-        l = new Latency(Latency.LATENCY1us);
-        System.out.println("l = " + l);
-        Assert.assertTrue(l.toString().equals("Latency[1usec]"));
-
-        l = new Latency(Latency.LATENCY1ms);
-        System.out.println("l = " + l);
-        Assert.assertTrue(l.toString().equals("Latency[1msec]"));
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/flowprogrammer/FlowTest.java b/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/flowprogrammer/FlowTest.java
deleted file mode 100644 (file)
index e644b0d..0000000
+++ /dev/null
@@ -1,220 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.flowprogrammer;
-
-import java.net.InetAddress;
-import java.net.UnknownHostException;
-import java.util.ArrayList;
-import java.util.List;
-
-import org.junit.Assert;
-import org.junit.Test;
-import org.opendaylight.controller.sal.action.Action;
-import org.opendaylight.controller.sal.action.Controller;
-import org.opendaylight.controller.sal.action.Flood;
-import org.opendaylight.controller.sal.action.Loopback;
-import org.opendaylight.controller.sal.action.Output;
-import org.opendaylight.controller.sal.action.PopVlan;
-import org.opendaylight.controller.sal.action.PushVlan;
-import org.opendaylight.controller.sal.action.SetDlDst;
-import org.opendaylight.controller.sal.action.SetNwDst;
-import org.opendaylight.controller.sal.action.SetVlanId;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.match.Match;
-import org.opendaylight.controller.sal.match.MatchType;
-import org.opendaylight.controller.sal.utils.EtherTypes;
-import org.opendaylight.controller.sal.utils.IPProtocols;
-import org.opendaylight.controller.sal.utils.NodeConnectorCreator;
-import org.opendaylight.controller.sal.utils.NodeCreator;
-
-public class FlowTest {
-
-    @Test
-    public void testFlowEquality() throws Exception {
-        Node node = NodeCreator.createOFNode(1055L);
-        Flow flow1 = getSampleFlowV6(node);
-        Flow flow2 = getSampleFlowV6(node);
-        Flow flow3 = getSampleFlow(node);
-
-        // Check Match equality
-        Assert.assertTrue(flow1.getMatch().equals(flow2.getMatch()));
-
-        // Check Actions equality
-        for (int i = 0; i < flow1.getActions().size(); i++) {
-            Action a = flow1.getActions().get(i);
-            Action b = flow2.getActions().get(i);
-            Assert.assertTrue(a != b);
-            Assert.assertTrue(a.equals(b));
-        }
-
-        Assert.assertTrue(flow1.equals(flow2));
-        Assert.assertFalse(flow2.equals(flow3));
-
-        // Check Flow equality where Flow has null action list (pure match)
-        List<Action> emptyList = new ArrayList<Action>(1);
-        Flow x = flow1.clone();
-        x.setActions(emptyList);
-        Assert.assertFalse(flow1.equals(x));
-        flow1.setActions(emptyList);
-        Assert.assertTrue(flow1.equals(x));
-    }
-
-    @Test
-    public void testFlowCloning() throws UnknownHostException {
-        Node node = NodeCreator.createOFNode(55L);
-        Flow flow1 = getSampleFlowV6(node);
-        Flow flow2 = flow1.clone();
-
-        Assert.assertTrue(flow1.equals(flow2));
-        Assert.assertTrue(flow1.getMatch().equals(flow2.getMatch()));
-        Assert.assertTrue(flow1.getActions() != flow2.getActions());
-        Assert.assertTrue(flow1.getActions().equals(flow2.getActions()));
-    }
-
-    @Test
-    public void testFlowActions() throws UnknownHostException {
-        Node node = NodeCreator.createOFNode(55L);
-        Flow flow = getSampleFlowV6(node);
-
-        List<Action> actions = flow.getActions();
-        actions.add(new Loopback());
-
-        Assert.assertTrue(flow.getActions() != actions);
-        Assert.assertTrue(!flow.getActions().equals(actions));
-
-        flow.addAction(new Loopback());
-        Assert.assertTrue(flow.getActions().equals(actions));
-
-        actions.remove(new Loopback());
-        flow.removeAction(new Loopback());
-        Assert.assertTrue(flow.getActions().equals(actions));
-
-        // Add a malformed action
-        Assert.assertFalse(flow.addAction(new PushVlan(EtherTypes.CISCOQINQ, 3,
-                3, 8000)));
-    }
-
-    private Flow getSampleFlow(Node node) throws UnknownHostException {
-        NodeConnector port = NodeConnectorCreator.createOFNodeConnector(
-                (short) 24, node);
-        NodeConnector oport = NodeConnectorCreator.createOFNodeConnector(
-                (short) 30, node);
-        byte srcMac[] = { (byte) 0x12, (byte) 0x34, (byte) 0x56, (byte) 0x78,
-                (byte) 0x9a, (byte) 0xbc };
-        byte dstMac[] = { (byte) 0x1a, (byte) 0x2b, (byte) 0x3c, (byte) 0x4d,
-                (byte) 0x5e, (byte) 0x6f };
-        InetAddress srcIP = InetAddress.getByName("172.28.30.50");
-        InetAddress dstIP = InetAddress.getByName("171.71.9.52");
-        InetAddress newIP = InetAddress.getByName("200.200.100.1");
-        InetAddress ipMask = InetAddress.getByName("255.255.255.0");
-        InetAddress ipMask2 = InetAddress.getByName("255.240.0.0");
-        short ethertype = EtherTypes.IPv4.shortValue();
-        short vlan = (short) 27;
-        byte vlanPr = 3;
-        Byte tos = 4;
-        byte proto = IPProtocols.TCP.byteValue();
-        short src = (short) 55000;
-        short dst = 80;
-
-        /*
-         * Create a SAL Flow aFlow
-         */
-        Match match = new Match();
-        match.setField(MatchType.IN_PORT, port);
-        match.setField(MatchType.DL_SRC, srcMac);
-        match.setField(MatchType.DL_DST, dstMac);
-        match.setField(MatchType.DL_TYPE, ethertype);
-        match.setField(MatchType.DL_VLAN, vlan);
-        match.setField(MatchType.DL_VLAN_PR, vlanPr);
-        match.setField(MatchType.NW_SRC, srcIP, ipMask);
-        match.setField(MatchType.NW_DST, dstIP, ipMask2);
-        match.setField(MatchType.NW_TOS, tos);
-        match.setField(MatchType.NW_PROTO, proto);
-        match.setField(MatchType.TP_SRC, src);
-        match.setField(MatchType.TP_DST, dst);
-
-        List<Action> actions = new ArrayList<Action>();
-        actions.add(new SetNwDst(newIP));
-        actions.add(new Output(oport));
-        actions.add(new PopVlan());
-        actions.add(new Flood());
-        actions.add(new Controller());
-
-        Flow flow = new Flow(match, actions);
-        flow.setPriority((short) 100);
-        flow.setHardTimeout((short) 360);
-
-        return flow;
-    }
-
-    private Flow getSampleFlowV6(Node node) throws UnknownHostException {
-        NodeConnector port = NodeConnectorCreator.createOFNodeConnector(
-                (short) 24, node);
-        NodeConnector oport = NodeConnectorCreator.createOFNodeConnector(
-                (short) 30, node);
-        byte srcMac[] = { (byte) 0x12, (byte) 0x34, (byte) 0x56, (byte) 0x78,
-                (byte) 0x9a, (byte) 0xbc };
-        byte dstMac[] = { (byte) 0x1a, (byte) 0x2b, (byte) 0x3c, (byte) 0x4d,
-                (byte) 0x5e, (byte) 0x6f };
-        byte newMac[] = { (byte) 0x11, (byte) 0xaa, (byte) 0xbb, (byte) 0x34,
-                (byte) 0x9a, (byte) 0xee };
-        InetAddress srcIP = InetAddress
-                .getByName("2001:420:281:1004:407a:57f4:4d15:c355");
-        InetAddress dstIP = InetAddress
-                .getByName("2001:420:281:1004:e123:e688:d655:a1b0");
-        InetAddress ipMask = InetAddress
-                .getByName("ffff:ffff:ffff:ffff:0:0:0:0");
-        InetAddress ipMask2 = InetAddress
-                .getByName("ffff:ffff:ffff:ffff:ffff:ffff:ffff:0");
-        InetAddress newIP = InetAddress.getByName("2056:650::a1b0");
-        short ethertype = EtherTypes.IPv6.shortValue();
-        short vlan = (short) 27;
-        byte vlanPr = (byte) 3;
-        Byte tos = 4;
-        byte proto = IPProtocols.UDP.byteValue();
-        short src = (short) 5500;
-        short dst = 80;
-
-        /*
-         * Create a SAL Flow aFlow
-         */
-        Match match = new Match();
-        match.setField(MatchType.IN_PORT, port);
-        match.setField(MatchType.DL_SRC, srcMac);
-        match.setField(MatchType.DL_DST, dstMac);
-        match.setField(MatchType.DL_TYPE, ethertype);
-        match.setField(MatchType.DL_VLAN, vlan);
-        match.setField(MatchType.DL_VLAN_PR, vlanPr);
-        match.setField(MatchType.NW_SRC, srcIP, ipMask);
-        match.setField(MatchType.NW_DST, dstIP, ipMask2);
-        match.setField(MatchType.NW_TOS, tos);
-        match.setField(MatchType.NW_PROTO, proto);
-        match.setField(MatchType.TP_SRC, src);
-        match.setField(MatchType.TP_DST, dst);
-
-        List<Action> actions = new ArrayList<Action>();
-        actions.add(new Controller());
-        actions.add(new SetVlanId(5));
-        actions.add(new SetDlDst(newMac));
-        actions.add(new SetNwDst(newIP));
-        actions.add(new Output(oport));
-        actions.add(new PopVlan());
-        actions.add(new Flood());
-
-        actions.add(new Controller());
-
-        Flow flow = new Flow(match, actions);
-        flow.setPriority((short) 300);
-        flow.setHardTimeout((short) 240);
-
-        return flow;
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/match/MatchExtensibleTest.java b/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/match/MatchExtensibleTest.java
deleted file mode 100644 (file)
index 0f49f42..0000000
+++ /dev/null
@@ -1,589 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.match;
-
-import java.net.InetAddress;
-import java.net.UnknownHostException;
-import java.util.Arrays;
-import java.util.HashSet;
-import java.util.Set;
-
-
-import org.junit.Assert;
-import org.junit.Test;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.match.extensible.DlDst;
-import org.opendaylight.controller.sal.match.extensible.DlSrc;
-import org.opendaylight.controller.sal.match.extensible.DlType;
-import org.opendaylight.controller.sal.match.extensible.DlVlan;
-import org.opendaylight.controller.sal.match.extensible.DlVlanPriority;
-import org.opendaylight.controller.sal.match.extensible.InPort;
-import org.opendaylight.controller.sal.match.extensible.Match;
-import org.opendaylight.controller.sal.match.extensible.MatchField;
-import org.opendaylight.controller.sal.match.extensible.NwDst;
-import org.opendaylight.controller.sal.match.extensible.NwProtocol;
-import org.opendaylight.controller.sal.match.extensible.NwSrc;
-import org.opendaylight.controller.sal.match.extensible.NwTos;
-import org.opendaylight.controller.sal.match.extensible.TpDst;
-import org.opendaylight.controller.sal.match.extensible.TpSrc;
-import org.opendaylight.controller.sal.utils.EtherTypes;
-import org.opendaylight.controller.sal.utils.IPProtocols;
-import org.opendaylight.controller.sal.utils.NodeConnectorCreator;
-import org.opendaylight.controller.sal.utils.NodeCreator;
-
-public class MatchExtensibleTest {
-    @Test
-    public void testMatchCreation() {
-        Node node = NodeCreator.createOFNode(7L);
-        NodeConnector port = NodeConnectorCreator.createOFNodeConnector((short) 6, node);
-        MatchField<?> field = new InPort(port);
-
-        Assert.assertTrue(field != null);
-        Assert.assertEquals(field.getType(), InPort.TYPE);
-        Assert.assertEquals(field.getValue(), port);
-        Assert.assertTrue(field.isValid());
-
-
-        byte mac[] = { (byte) 0xaa, (byte) 0xbb, (byte) 0xcc, (byte) 0xdd, (byte) 11, (byte) 22 };
-        field = null;
-        field = new DlSrc(mac);
-        Assert.assertNotNull(field.getValue());
-
-        field = null;
-        field = new NwTos((byte) 0x22);
-        Assert.assertNotNull(field.getValue());
-    }
-
-    @Test
-    public void testMatchSetGet() {
-        Match x = new Match();
-        short val = 2346;
-        NodeConnector inPort = NodeConnectorCreator.createOFNodeConnector(val, NodeCreator.createOFNode(1L));
-        x.setField(new InPort(inPort));
-        Assert.assertEquals(x.getField(InPort.TYPE).getValue(), inPort);
-        Assert.assertTrue((Short) ((NodeConnector) x.getField(InPort.TYPE).getValue()).getID() == val);
-    }
-
-    @Test
-    public void testMatchSetGetMAC() {
-        Match x = new Match();
-        byte mac[] = { (byte) 0xaa, (byte) 0xbb, (byte) 0xcc, (byte) 0xdd, (byte) 11, (byte) 22 };
-        byte mac2[] = { (byte) 0xaa, (byte) 0xbb, 0, 0, 0, (byte) 0xbb };
-
-        x.setField(new DlSrc(mac));
-        x.setField(new DlDst(mac2));
-        Assert.assertArrayEquals(mac, (byte[]) x.getField(DlSrc.TYPE).getValue());
-        Assert.assertFalse(Arrays.equals((byte[]) x.getField(DlSrc.TYPE).getValue(), (byte[]) x.getField(DlDst.TYPE)
-                .getValue()));
-
-        x.setField(new DlDst(mac.clone()));
-        Assert.assertArrayEquals((byte[]) x.getField(DlSrc.TYPE).getValue(), (byte[]) x.getField(DlDst.TYPE).getValue());
-    }
-
-    @Test
-    public void testMatchSetGetNWAddr() throws UnknownHostException {
-        Match x = new Match();
-        String ip = "172.20.231.23";
-        InetAddress address = InetAddress.getByName(ip);
-        InetAddress mask = InetAddress.getByName("255.255.0.0");
-
-        x.setField(new NwSrc(address, mask));
-        Assert.assertEquals(address, x.getField(NwSrc.TYPE).getValue());
-        Assert.assertEquals(x.getField(NwSrc.TYPE).getMask(), mask);
-    }
-
-    @Test
-    public void testMatchSetGetEtherType() throws UnknownHostException {
-        Match x = new Match();
-
-        x.setField(new DlType(EtherTypes.QINQ.shortValue()));
-        Assert.assertEquals(x.getField(DlType.TYPE).getValue(), EtherTypes.QINQ.shortValue());
-
-        x.setField(new DlType(EtherTypes.LLDP.shortValue()));
-        Assert.assertEquals(x.getField(DlType.TYPE).getValue(), EtherTypes.LLDP.shortValue());
-        Assert.assertFalse(x.getField(DlType.TYPE).equals(EtherTypes.LLDP.intValue()));
-    }
-
-    @Test
-    public void testSetGetNwTos() {
-        Match x = new Match();
-        x.setField(new NwTos((byte) 0xb));
-
-        Byte t = new Byte((byte) 0xb);
-
-        Object o = x.getField(NwTos.TYPE).getValue();
-        Assert.assertEquals(o, t);
-        Assert.assertEquals(o, Byte.valueOf((byte)0xb));
-    }
-
-    @Test
-    public void testSetGetNwProto() {
-        Match x = new Match();
-        Byte proto = (byte) 199;
-        x.setField(new NwProtocol(proto));
-
-        Byte o = (Byte) x.getField(NwProtocol.TYPE).getValue();
-        Assert.assertEquals(o, proto);
-    }
-
-    @Test
-    public void testSetTpSrc() {
-        // Minimum value validation.
-        Match match = new Match();
-        short tp_src = 0;
-        match.setField(new TpSrc(tp_src));
-
-        Object o = match.getField(TpSrc.TYPE).getValue();
-        Assert.assertEquals(o, tp_src);
-
-        // Maximum value validation.
-        match = new Match();
-        tp_src = (short) 0xffff;
-        match.setField(new TpSrc(tp_src));
-
-        o = match.getField(TpSrc.TYPE).getValue();
-        Assert.assertEquals(o, tp_src);
-    }
-
-    @Test
-    public void testSetTpDst() {
-        // Minimum value validation.
-        Match match = new Match();
-        short tp_dst = 0;
-        match.setField(new TpDst(tp_dst));
-
-        Object o = match.getField(TpDst.TYPE).getValue();
-        Assert.assertTrue(o.equals(tp_dst));
-
-        // Maximum value validation.
-        match = new Match();
-        tp_dst = (short) 0xffff;
-        match.setField(new TpDst(tp_dst));
-
-        o = match.getField(TpDst.TYPE).getValue();
-        Assert.assertEquals(o, tp_dst);
-    }
-
-    @Test
-    public void testEquality() throws Exception {
-        Node node = NodeCreator.createOFNode(7L);
-        NodeConnector port = NodeConnectorCreator.createOFNodeConnector((short) 24, node);
-        NodeConnector port2 = NodeConnectorCreator.createOFNodeConnector((short) 24, node);
-        byte srcMac[] = { (byte) 0x12, (byte) 0x34, (byte) 0x56, (byte) 0x78, (byte) 0x9a, (byte) 0xbc };
-        byte dstMac[] = { (byte) 0x1a, (byte) 0x2b, (byte) 0x3c, (byte) 0x4d, (byte) 0x5e, (byte) 0x6f };
-        byte srcMac2[] = { (byte) 0x12, (byte) 0x34, (byte) 0x56, (byte) 0x78, (byte) 0x9a, (byte) 0xbc };
-        byte dstMac2[] = { (byte) 0x1a, (byte) 0x2b, (byte) 0x3c, (byte) 0x4d, (byte) 0x5e, (byte) 0x6f };
-        InetAddress srcIP = InetAddress.getByName("2001:420:281:1004:407a:57f4:4d15:c355");
-        InetAddress dstIP = InetAddress.getByName("2001:420:281:1004:e123:e688:d655:a1b0");
-        InetAddress ipMask = InetAddress.getByName("ffff:ffff:ffff:ffff:0:0:0:0");
-        InetAddress ipMaskd = InetAddress.getByName("ffff:ffff:ffff:ffff:ffff:ffff:ffff:0");
-        InetAddress ipMask2 = InetAddress.getByName("ffff:ffff:ffff:ffff:0:0:0:0");
-        InetAddress ipMaskd2 = InetAddress.getByName("ffff:ffff:ffff:ffff:ffff:ffff:ffff:0");
-        short ethertype = EtherTypes.IPv6.shortValue();
-        short ethertype2 = EtherTypes.IPv6.shortValue();
-        short vlan = (short) 27, vlan2 = (short) 27;
-        byte vlanPr = (byte) 3, vlanPr2 = (byte) 3;
-        Byte tos = 4, tos2 = 4;
-        byte proto = IPProtocols.UDP.byteValue(), proto2 = IPProtocols.UDP.byteValue();
-        short src = (short) 5500, src2 = (short) 5500;
-        short dst = 80, dst2 = 80;
-
-        /*
-         * Create a SAL Flow aFlow
-         */
-        Match match1 = new Match();
-        Match match2 = new Match();
-        match1.setField(new InPort(port));
-        match1.setField(new DlSrc(srcMac));
-        match1.setField(new DlDst(dstMac));
-        match1.setField(new DlType(ethertype));
-        match1.setField(new DlVlan(vlan));
-        match1.setField(new DlVlanPriority(vlanPr));
-        match1.setField(new NwSrc(srcIP, ipMask));
-        match1.setField(new NwDst(dstIP, ipMaskd));
-        match1.setField(new NwTos(tos));
-        match1.setField(new NwProtocol(proto));
-        match1.setField(new TpSrc(src));
-        match1.setField(new TpDst(dst));
-
-        match2.setField(new InPort(port2));
-        match2.setField(new DlSrc(srcMac2));
-        match2.setField(new DlDst(dstMac2));
-        match2.setField(new DlType(ethertype2));
-        match2.setField(new DlVlan(vlan2));
-        match2.setField(new DlVlanPriority(vlanPr2));
-        match2.setField(new NwSrc(srcIP, ipMask2));
-        match2.setField(new NwDst(dstIP, ipMaskd2));
-        match2.setField(new NwTos(tos2));
-        match2.setField(new NwProtocol(proto2));
-        match2.setField(new TpSrc(src2));
-        match2.setField(new TpDst(dst2));
-
-        Assert.assertTrue(match1.equals(match2));
-
-        Set<String> allFields = new HashSet<String>(match1.getMatchesList());
-        allFields.addAll(match2.getMatchesList());
-        // Make sure all values are equals
-        for (String type : allFields) {
-            if (match1.isPresent(type)) {
-                Assert.assertEquals(match1.getField(type), match2.getField(type));
-            }
-        }
-
-        // Make none of the fields couples are pointing to the same reference
-        MatchField<?> a = null, b = null;
-        for (String type : allFields) {
-            a = match1.getField(type);
-            b = match2.getField(type);
-            if (a != null && b != null) {
-                Assert.assertFalse(a == b);
-            }
-        }
-    }
-
-    @Test
-    public void testEqualityNetMask() throws Exception {
-
-        InetAddress srcIP = InetAddress.getByName("1.1.1.1");
-        InetAddress ipMask = InetAddress.getByName("255.255.255.255");
-        InetAddress srcIP2 = InetAddress.getByName("1.1.1.1");
-        InetAddress ipMask2 = null;
-        short ethertype = EtherTypes.IPv4.shortValue();
-        short ethertype2 = EtherTypes.IPv4.shortValue();
-
-        /*
-         * Create a SAL Flow aFlow
-         */
-        Match match1 = new Match();
-        Match match2 = new Match();
-
-        match1.setField(new DlType(ethertype));
-        match1.setField(new NwSrc(srcIP, ipMask));
-
-        match2.setField(new DlType(ethertype2));
-        match2.setField(new NwSrc(srcIP2, ipMask2));
-
-        Assert.assertTrue(match1.equals(match2));
-
-        ipMask2 = InetAddress.getByName("255.255.255.255");
-        match2.setField(new NwSrc(srcIP2, ipMask2));
-
-        srcIP = InetAddress.getByName("2001:420:281:1004:407a:57f4:4d15:c355");
-        srcIP2 = InetAddress.getByName("2001:420:281:1004:407a:57f4:4d15:c355");
-        ipMask = null;
-        ipMask2 = InetAddress.getByName("ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff");
-        ethertype = EtherTypes.IPv6.shortValue();
-        ethertype2 = EtherTypes.IPv6.shortValue();
-
-        match1.setField(new DlType(ethertype));
-        match1.setField(new NwSrc(srcIP, ipMask));
-
-        match2.setField(new DlType(ethertype2));
-        match2.setField(new NwSrc(srcIP2, ipMask2));
-
-        Assert.assertEquals(match1, match2);
-    }
-
-    @Test
-    public void testHashCodeWithReverseMatch() throws Exception {
-        InetAddress srcIP1 = InetAddress.getByName("1.1.1.1");
-        InetAddress ipMask1 = InetAddress.getByName("255.255.255.255");
-        InetAddress srcIP2 = InetAddress.getByName("2.2.2.2");
-        InetAddress ipMask2 = InetAddress.getByName("255.255.255.255");
-        MatchField<?> field1 = new NwSrc(srcIP1, ipMask1);
-        MatchField<?> field2 = new NwDst(srcIP2, ipMask2);
-        Match match1 = new Match();
-        match1.setField(field1);
-        match1.setField(field2);
-        Match match2 = match1.reverse();
-        Assert.assertFalse(match1.hashCode() == match2.hashCode());
-    }
-
-    @Test
-    public void testHashCode() throws Exception {
-        byte srcMac1[] = { (byte) 0x12, (byte) 0x34, (byte) 0x56, (byte) 0x78, (byte) 0x9a, (byte) 0xbc };
-        byte srcMac2[] = { (byte) 0x12, (byte) 0x34, (byte) 0x56, (byte) 0x78, (byte) 0x9a, (byte) 0xbc };
-        byte dstMac1[] = { (byte) 0x1a, (byte) 0x2b, (byte) 0x3c, (byte) 0x4d, (byte) 0x5e, (byte) 0x6f };
-        byte dstMac2[] = { (byte) 0x1a, (byte) 0x2b, (byte) 0x3c, (byte) 0x4d, (byte) 0x5e, (byte) 0x6f };
-        short ethertype = EtherTypes.IPv4.shortValue();
-        short ethertype2 = EtherTypes.IPv4.shortValue();
-        InetAddress srcIP1 = InetAddress.getByName("1.1.1.1");
-        InetAddress ipMask1 = InetAddress.getByName("255.255.255.255");
-        InetAddress srcIP2 = InetAddress.getByName("1.1.1.1");
-        InetAddress ipMask2 = InetAddress.getByName("255.255.255.255");
-
-        Match match1 = new Match();
-        Match match2 = new Match();
-
-        MatchField<?> field1 = new DlSrc(srcMac1);
-        MatchField<?> field2 = new DlSrc(srcMac2);
-        Assert.assertTrue(field1.hashCode() == field2.hashCode());
-
-        match1.setField(field1);
-        match2.setField(field2);
-        Assert.assertTrue(match1.hashCode() == match2.hashCode());
-
-        MatchField<?> field3 = new DlDst(dstMac1);
-        MatchField<?> field4 = new DlDst(dstMac2);
-        Assert.assertTrue(field3.hashCode() == field4.hashCode());
-
-        match1.setField(field3);
-        match2.setField(field4);
-        Assert.assertTrue(match1.hashCode() == match2.hashCode());
-
-        MatchField<?> field5 = new DlType(ethertype);
-        MatchField<?> field6 = new DlType(ethertype2);
-        Assert.assertTrue(field5.hashCode() == field6.hashCode());
-
-        match1.setField(field5);
-        match2.setField(field6);
-        Assert.assertTrue(match1.hashCode() == match2 .hashCode());
-
-        MatchField<?> field7 = new NwSrc(srcIP1, ipMask1);
-        MatchField<?> field8 = new NwSrc(srcIP2, ipMask2);
-        Assert.assertTrue(field7.hashCode() == field8.hashCode());
-
-        match1.setField(field7);
-        match2.setField(field8);
-        Assert.assertTrue(match1.hashCode() == match2.hashCode());
-
-    }
-
-    @Test
-    public void testCloning() throws Exception {
-        Node node = NodeCreator.createOFNode(7L);
-        NodeConnector port = NodeConnectorCreator.createOFNodeConnector((short) 24, node);
-        byte srcMac[] = { (byte) 0x12, (byte) 0x34, (byte) 0x56, (byte) 0x78, (byte) 0x9a, (byte) 0xbc };
-        byte dstMac[] = { (byte) 0x1a, (byte) 0x2b, (byte) 0x3c, (byte) 0x4d, (byte) 0x5e, (byte) 0x6f };
-        InetAddress srcIP = InetAddress.getByName("2001:420:281:1004:407a:57f4:4d15:c355");
-        InetAddress dstIP = InetAddress.getByName("2001:420:281:1004:e123:e688:d655:a1b0");
-        InetAddress ipMasks = InetAddress.getByName("ffff:ffff:ffff:ffff:0:0:0:0");
-        InetAddress ipMaskd = InetAddress.getByName("ffff:ffff:ffff:ffff:ffff:ffff:ffff:0");
-        short ethertype = EtherTypes.IPv6.shortValue();
-        short vlan = (short) 27;
-        byte vlanPr = (byte) 3;
-        Byte tos = 4;
-        byte proto = IPProtocols.UDP.byteValue();
-        short src = (short) 5500;
-        short dst = 80;
-
-        /*
-         * Create a SAL Flow aFlow
-         */
-        Match match = new Match();
-        match.setField(new InPort(port));
-        match.setField(new DlSrc(srcMac));
-        match.setField(new DlDst(dstMac));
-        match.setField(new DlType(ethertype));
-        match.setField(new DlVlan(vlan));
-        match.setField(new DlVlanPriority(vlanPr));
-        match.setField(new NwSrc(srcIP, ipMasks));
-        match.setField(new NwDst(dstIP, ipMaskd));
-        match.setField(new NwTos(tos));
-        match.setField(new NwProtocol(proto));
-        match.setField(new TpSrc(src));
-        match.setField(new TpDst(dst));
-
-        Match cloned = match.clone();
-
-        // Make sure all values are equals
-        for (String type : match.getMatchesList()) {
-            if (match.isPresent(type)) {
-                if (!match.getField(type).equals(cloned.getField(type))) {
-                    Assert.assertEquals(match.getField(type), cloned.getField(type));
-                }
-            }
-        }
-
-        // Make sure none of the fields couples are pointing to the same
-        // reference
-        MatchField<?> a = null, b = null;
-        for (String type : match.getMatchesList()) {
-            a = match.getField(type);
-            b = cloned.getField(type);
-            if (a != null && b != null) {
-                Assert.assertFalse(a == b);
-            }
-        }
-
-        Assert.assertTrue(match.equals(cloned));
-
-        Assert.assertEquals(match.getField(DlSrc.TYPE), cloned.getField(DlSrc.TYPE));
-        Assert.assertEquals(match.getField(NwDst.TYPE), cloned.getField(NwDst.TYPE));
-        Assert.assertEquals(match.getField(NwDst.TYPE).getMask(), cloned.getField(NwDst.TYPE).getMask());
-        Assert.assertEquals(match.hashCode(), cloned.hashCode());
-    }
-
-    @Test
-    public void testFlip() throws Exception {
-        Node node = NodeCreator.createOFNode(7L);
-        NodeConnector port = NodeConnectorCreator.createOFNodeConnector((short) 24, node);
-        byte srcMac[] = { (byte) 0x12, (byte) 0x34, (byte) 0x56, (byte) 0x78, (byte) 0x9a, (byte) 0xbc };
-        byte dstMac[] = { (byte) 0x1a, (byte) 0x2b, (byte) 0x3c, (byte) 0x4d, (byte) 0x5e, (byte) 0x6f };
-        InetAddress srcIP = InetAddress.getByName("2001:420:281:1004:407a:57f4:4d15:c355");
-        InetAddress dstIP = InetAddress.getByName("2001:420:281:1004:e123:e688:d655:a1b0");
-        InetAddress ipMasks = InetAddress.getByName("ffff:ffff:ffff:ffff:0:0:0:0");
-        InetAddress ipMaskd = InetAddress.getByName("ffff:ffff:ffff:ffff:ffff:ffff:ffff:0");
-        short ethertype = EtherTypes.IPv6.shortValue();
-        short vlan = (short) 27;
-        byte vlanPr = (byte) 3;
-        Byte tos = 4;
-        byte proto = IPProtocols.UDP.byteValue();
-        short src = (short) 5500;
-        short dst = 80;
-
-        /*
-         * Create a SAL Flow aFlow
-         */
-        Match match = new Match();
-        match.setField(new InPort(port));
-        match.setField(new DlSrc(srcMac));
-        match.setField(new DlDst(dstMac));
-        match.setField(new DlType(ethertype));
-        match.setField(new DlVlan(vlan));
-        match.setField(new DlVlanPriority(vlanPr));
-        match.setField(new NwSrc(srcIP, ipMasks));
-        match.setField(new NwDst(dstIP, ipMaskd));
-        match.setField(new NwTos(tos));
-        match.setField(new NwProtocol(proto));
-        match.setField(new TpSrc(src));
-        match.setField(new TpDst(dst));
-
-        Match flipped = match.reverse();
-
-        Assert.assertEquals(match.getField(DlType.TYPE), flipped.getField(DlType.TYPE));
-        Assert.assertEquals(match.getField(DlVlan.TYPE), flipped.getField(DlVlan.TYPE));
-
-        Assert.assertArrayEquals((byte[]) match.getField(DlDst.TYPE).getValue(), (byte[]) flipped.getField(DlSrc.TYPE)
-                .getValue());
-
-        Assert.assertEquals(match.getField(NwDst.TYPE).getValue(), flipped.getField(NwSrc.TYPE).getValue());
-
-        Assert.assertEquals(match.getField(TpDst.TYPE).getValue(), flipped.getField(TpSrc.TYPE).getValue());
-
-        Match flipflip = flipped.reverse().reverse();
-        Assert.assertEquals(flipflip, flipped);
-
-    }
-
-    @Test
-    public void testVlanNone() throws Exception {
-        // The value 0 is used to indicate that no VLAN ID is set
-        short vlan = (short) 0;
-        MatchField<?> field = new DlVlan(vlan);
-
-        Assert.assertTrue(field != null);
-        Assert.assertEquals(field.getValue(), new Short(vlan));
-        Assert.assertTrue(field.isValid());
-    }
-
-    @Test
-    public void testIntersection() throws UnknownHostException {
-        Short ethType = Short.valueOf((short)0x800);
-        InetAddress ip1 = InetAddress.getByName("1.1.1.1");
-        InetAddress ip2 = InetAddress.getByName("1.1.1.0");
-        InetAddress ipm2 = InetAddress.getByName("255.255.255.0");
-        InetAddress ip3 = InetAddress.getByName("1.3.0.0");
-        InetAddress ipm3 = InetAddress.getByName("255.255.0.0");
-        InetAddress ip4 = InetAddress.getByName("1.3.4.4");
-        InetAddress ipm4 = InetAddress.getByName("255.255.255.0");
-
-        Match m1 = new Match();
-        m1.setField(new DlType(ethType));
-        m1.setField(new NwSrc(ip1));
-
-        Match m2 = new Match();
-        m2.setField(new DlType(ethType));
-        m2.setField(new NwSrc(ip2, ipm2));
-
-        Match m3 = new Match();
-        m3.setField(new DlType(ethType));
-        m3.setField(new NwSrc(ip3, ipm3));
-        m3.setField(new NwProtocol(IPProtocols.TCP.byteValue()));
-
-        Match m3r = m3.reverse();
-        Assert.assertTrue(m3.intersetcs(m3r));
-
-        Assert.assertTrue(m1.intersetcs(m2));
-        Assert.assertTrue(m2.intersetcs(m1));
-        Assert.assertFalse(m1.intersetcs(m3));
-        Assert.assertTrue(m1.intersetcs(m3r));
-        Assert.assertFalse(m3.intersetcs(m1));
-        Assert.assertTrue(m3.intersetcs(m1.reverse()));
-        Assert.assertFalse(m2.intersetcs(m3));
-        Assert.assertFalse(m3.intersetcs(m2));
-        Assert.assertTrue(m2.intersetcs(m3r));
-
-
-        Match i = m1.getIntersection(m2);
-        Assert.assertTrue(((Short)i.getField(DlType.TYPE).getValue()).equals(ethType));
-        // Verify intersection of IP addresses is correct
-        Assert.assertTrue(((InetAddress)i.getField(NwSrc.TYPE).getValue()).equals(ip1));
-        Assert.assertNull(i.getField(NwSrc.TYPE).getMask());
-
-        // Empty set
-        i = m2.getIntersection(m3);
-        Assert.assertNull(i);
-
-        Match m4 = new Match();
-        m4.setField(new DlType(ethType));
-        m4.setField(new NwProtocol(IPProtocols.TCP.byteValue()));
-        m3.setField(new NwSrc(ip4, ipm4));
-        Assert.assertTrue(m4.intersetcs(m3));
-
-        // Verify intersection of IP and IP mask addresses is correct
-        Match ii = m3.getIntersection(m4);
-        Assert.assertTrue(((InetAddress)ii.getField(NwSrc.TYPE).getValue()).equals(ip4));
-        Assert.assertTrue(((InetAddress)ii.getField(NwSrc.TYPE).getMask()).equals(ipm4));
-
-        Match m5 = new Match();
-        m5.setField(new DlType(ethType));
-        m3.setField(new NwSrc(ip3, ipm3));
-        m5.setField(new NwProtocol(IPProtocols.UDP.byteValue()));
-        Assert.assertFalse(m5.intersetcs(m3));
-        Assert.assertFalse(m5.intersetcs(m4));
-        Assert.assertTrue(m5.intersetcs(m5));
-        Assert.assertFalse(m3.intersetcs(m5));
-        Assert.assertFalse(m4.intersetcs(m5));
-
-
-        Match i2 = m4.getIntersection(m3);
-        Assert.assertFalse(i2.isEmpty());
-        Assert.assertFalse(i2.getMatchesList().isEmpty());
-        Assert.assertTrue(((InetAddress)i2.getField(NwSrc.TYPE).getValue()).equals(ip3));
-        Assert.assertTrue(((InetAddress)i2.getField(NwSrc.TYPE).getMask()).equals(ipm3));
-        Assert.assertTrue(((Byte)i2.getField(NwProtocol.TYPE).getValue()).equals(IPProtocols.TCP.byteValue()));
-
-        byte src[] = {(byte)0, (byte)0xab,(byte)0xbc,(byte)0xcd,(byte)0xde,(byte)0xef};
-        byte dst[] = {(byte)0x10, (byte)0x11,(byte)0x12,(byte)0x13,(byte)0x14,(byte)0x15};
-        Short srcPort = (short)1024;
-        Short dstPort = (short)80;
-
-        // Check identity
-        Match m6 = new Match();
-        m6.setField(new DlSrc(src));
-        m6.setField(new DlDst(dst));
-        m6.setField(new NwSrc(ip2, ipm2));
-        m6.setField(new NwDst(ip3, ipm3));
-        m6.setField(new NwProtocol(IPProtocols.UDP.byteValue()));
-        m6.setField(new TpSrc(srcPort));
-        m6.setField(new TpDst(dstPort));
-        Assert.assertTrue(m6.intersetcs(m6));
-        Assert.assertTrue(m6.getIntersection(m6).equals(m6));
-
-        // Empty match, represents the universal set (all packets)
-        Match u = new Match();
-        Assert.assertEquals(m6.getIntersection(u), m6);
-        Assert.assertEquals(u.getIntersection(m6), m6);
-
-        // No intersection with null match, empty set
-        Assert.assertNull(m6.getIntersection(null));
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/match/MatchTest.java b/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/match/MatchTest.java
deleted file mode 100644 (file)
index b89b27f..0000000
+++ /dev/null
@@ -1,730 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.match;
-
-import java.net.InetAddress;
-import java.net.UnknownHostException;
-import java.util.Arrays;
-import java.util.List;
-
-import org.junit.Assert;
-import org.junit.Test;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.core.Tables;
-import org.opendaylight.controller.sal.core.Tier;
-import org.opendaylight.controller.sal.utils.EtherTypes;
-import org.opendaylight.controller.sal.utils.IPProtocols;
-import org.opendaylight.controller.sal.utils.NodeConnectorCreator;
-import org.opendaylight.controller.sal.utils.NodeCreator;
-
-public class MatchTest {
-    @Test
-    public void testMatchCreation() {
-        Node node = NodeCreator.createOFNode(7L);
-        NodeConnector port = NodeConnectorCreator.createOFNodeConnector((short) 6, node);
-        MatchField field = new MatchField(MatchType.IN_PORT, port);
-
-        Assert.assertTrue(field != null);
-        Assert.assertTrue(field.getType() == MatchType.IN_PORT);
-        Assert.assertTrue((NodeConnector) field.getValue() == port);
-        Assert.assertTrue(field.isValid());
-
-        field = null;
-        field = new MatchField(MatchType.TP_SRC, Long.valueOf(23));
-        Assert.assertFalse(field.isValid());
-
-        field = null;
-        field = new MatchField(MatchType.TP_SRC, (long) 45);
-        Assert.assertFalse(field.isValid());
-
-        field = null;
-        field = new MatchField(MatchType.TP_SRC, 120000);
-        Assert.assertFalse(field.isValid());
-
-        byte mac[] = { (byte) 0xaa, (byte) 0xbb, (byte) 0xcc, (byte) 0xdd, (byte) 11, (byte) 22 };
-        byte mask[] = { (byte) 0xff, (byte) 0xff, (byte) 0xff, (byte) 0xff, (byte) 0xff, (byte) 0xff };
-        field = null;
-        field = new MatchField(MatchType.DL_SRC, mac, mask);
-        Assert.assertFalse(field.getValue() == null);
-
-        field = null;
-        field = new MatchField(MatchType.NW_TOS, (byte) 0x22, (byte) 0x3);
-        Assert.assertFalse(field.getValue() == null);
-    }
-
-    @Test
-    public void testMatchSetGet() {
-        Match x = new Match();
-        short val = 2346;
-        NodeConnector inPort = NodeConnectorCreator.createOFNodeConnector(val, NodeCreator.createOFNode(1L));
-        x.setField(MatchType.IN_PORT, inPort);
-        Assert.assertTrue(((NodeConnector) x.getField(MatchType.IN_PORT).getValue()).equals(inPort));
-        Assert.assertTrue((Short) ((NodeConnector) x.getField(MatchType.IN_PORT).getValue()).getID() == val);
-    }
-
-    @Test
-    public void testMatchSetGetMAC() {
-        Match x = new Match();
-        byte mac[] = { (byte) 0xaa, (byte) 0xbb, (byte) 0xcc, (byte) 0xdd, (byte) 11, (byte) 22 };
-        byte mac2[] = { (byte) 0xaa, (byte) 0xbb, 0, 0, 0, (byte) 0xbb };
-        byte mask1[] = { (byte) 0x11, (byte) 0x22, (byte) 0x33, (byte) 0x44, (byte) 0x55, (byte) 0x66 };
-        byte mask2[] = { (byte) 0xff, (byte) 0xff, (byte) 0, (byte) 0, (byte) 0, (byte) 0xff };
-
-        x.setField(MatchType.DL_SRC, mac.clone(), mask1);
-        x.setField(MatchType.DL_DST, mac2.clone(), mask2);
-        Assert.assertTrue(Arrays.equals(mac, (byte[]) x.getField(MatchType.DL_SRC).getValue()));
-        Assert.assertFalse(Arrays.equals((byte[]) x.getField(MatchType.DL_SRC).getValue(),
-                (byte[]) x.getField(MatchType.DL_DST).getValue()));
-        Assert.assertFalse(x.getField(MatchType.DL_SRC).getBitMask() == x.getField(MatchType.DL_DST).getBitMask());
-
-        x.setField(new MatchField(MatchType.DL_DST, mac.clone(), mask1));
-        Assert.assertTrue(Arrays.equals((byte[]) x.getField(MatchType.DL_SRC).getValue(),
-                (byte[]) x.getField(MatchType.DL_DST).getValue()));
-    }
-
-    @Test
-    public void testMatchSetGetNWAddr() throws UnknownHostException {
-        Match x = new Match();
-        String ip = "172.20.231.23";
-        InetAddress address = InetAddress.getByName(ip);
-        InetAddress mask = InetAddress.getByName("255.255.0.0");
-
-        x.setField(MatchType.NW_SRC, address, mask);
-        Assert.assertTrue(ip.equals(((InetAddress) x.getField(MatchType.NW_SRC).getValue()).getHostAddress()));
-        Assert.assertTrue(x.getField(MatchType.NW_SRC).getMask().equals(mask));
-    }
-
-    @Test
-    public void testMatchSetGetEtherType() throws UnknownHostException {
-        Match x = new Match();
-
-        x.setField(MatchType.DL_TYPE, EtherTypes.QINQ.shortValue(), (short) 0xffff);
-        Assert.assertTrue(((Short) x.getField(MatchType.DL_TYPE).getValue()).equals(EtherTypes.QINQ.shortValue()));
-        Assert.assertFalse(x.getField(MatchType.DL_TYPE).getValue() == EtherTypes.QINQ);
-        Assert.assertFalse(x.getField(MatchType.DL_TYPE).getValue().equals(EtherTypes.QINQ));
-
-        x.setField(MatchType.DL_TYPE, EtherTypes.LLDP.shortValue(), (short) 0xffff);
-        Assert.assertTrue(((Short) x.getField(MatchType.DL_TYPE).getValue()).equals(EtherTypes.LLDP.shortValue()));
-        Assert.assertFalse(x.getField(MatchType.DL_TYPE).equals(EtherTypes.LLDP.intValue()));
-    }
-
-    @Test
-    public void testSetGetNwTos() {
-        Match x = new Match();
-        x.setField(MatchType.NW_TOS, (byte) 0xb, (byte) 0xf);
-
-        Byte t = new Byte((byte) 0xb);
-
-        Object o = x.getField(MatchType.NW_TOS).getValue();
-        Assert.assertTrue(o.equals(t));
-        Assert.assertTrue(o.equals((byte) 0xb));
-    }
-
-    @Test
-    public void testSetGetNwProto() {
-        Match x = new Match();
-        byte proto = (byte) 199;
-        x.setField(MatchType.NW_PROTO, proto, (byte) 0xff);
-
-        Object o = x.getField(MatchType.NW_PROTO).getValue();
-        Assert.assertTrue(o.equals(proto));
-    }
-
-    @Test
-    public void testSetTpSrc() {
-        // Minimum value validation.
-        Match match = new Match();
-        short tp_src = 0;
-        match.setField(MatchType.TP_SRC, tp_src);
-
-        Object o = match.getField(MatchType.TP_SRC).getValue();
-        Assert.assertTrue(o.equals(tp_src));
-
-        // Maximum value validation.
-        match = new Match();
-        tp_src = (short) 0xffff;
-        match.setField(MatchType.TP_SRC, tp_src);
-
-        o = match.getField(MatchType.TP_SRC).getValue();
-        Assert.assertTrue(o.equals(tp_src));
-    }
-
-    @Test
-    public void testSetTpDst() {
-        // Minimum value validation.
-        Match match = new Match();
-        short tp_dst = 0;
-        match.setField(MatchType.TP_DST, tp_dst);
-
-        Object o = match.getField(MatchType.TP_DST).getValue();
-        Assert.assertTrue(o.equals(tp_dst));
-
-        // Maximum value validation.
-        match = new Match();
-        tp_dst = (short) 0xffff;
-        match.setField(MatchType.TP_DST, tp_dst);
-
-        o = match.getField(MatchType.TP_DST).getValue();
-        Assert.assertTrue(o.equals(tp_dst));
-    }
-
-    @Test
-    public void testMatchMask() {
-        Match x = new Match();
-        NodeConnector inPort = NodeConnectorCreator.createOFNodeConnector((short) 6, NodeCreator.createOFNode(3L));
-        x.setField(MatchType.IN_PORT, inPort);
-        x.setField(MatchType.DL_VLAN, (short) 28, (short) 0xfff);
-        Assert.assertFalse(x.getMatches() == 0);
-        Assert.assertTrue(x.getMatches() == (MatchType.IN_PORT.getIndex() | MatchType.DL_VLAN.getIndex()));
-    }
-
-    @Test
-    public void testMatchBitMask() {
-        byte mac[] = { (byte) 0x00, (byte) 0x00, (byte) 0x00, (byte) 0x00, (byte) 22, (byte) 12 };
-        byte mask[] = { (byte) 0xff, (byte) 0xff, (byte) 0xff, (byte) 0xff, (byte) 0xff, (byte) 0 };
-        NodeConnector inPort = NodeConnectorCreator.createOFNodeConnector((short) 4095, NodeCreator.createOFNode(7L));
-
-        MatchField x = new MatchField(MatchType.IN_PORT, inPort);
-        Assert.assertTrue((x.getMask()) == null);
-
-        x = new MatchField(MatchType.DL_VLAN, (short) 255, (short) 0xff);
-        Assert.assertTrue(x.getBitMask() == 0xff);
-
-        x = new MatchField(MatchType.DL_SRC, mac, mask);
-        Assert.assertTrue(x.getMask().equals(mask));
-        Assert.assertTrue(x.getBitMask() == 0xffffffffff00L);
-    }
-
-    @Test
-    public void testNullMask() {
-        byte mac[] = { (byte) 0x00, (byte) 0x00, (byte) 0x00, (byte) 0x00, (byte) 22, (byte) 12 };
-        NodeConnector inPort = NodeConnectorCreator.createOFNodeConnector((short) 2000, NodeCreator.createOFNode(7L));
-
-        MatchField x = new MatchField(MatchType.IN_PORT, inPort);
-        Assert.assertTrue(x.getBitMask() == 0);
-
-        x = new MatchField(MatchType.NW_PROTO, (byte) 17);
-        Assert.assertTrue(x.getBitMask() == 0xff);
-
-        x = new MatchField(MatchType.DL_VLAN, (short) 255);
-        Assert.assertTrue(x.getBitMask() == 0xfff);
-
-        x = new MatchField(MatchType.DL_SRC, mac);
-        Assert.assertTrue(x.getBitMask() == 0xffffffffffffL);
-    }
-
-    @Test
-    public void testEquality() throws Exception {
-        Node node = NodeCreator.createOFNode(7L);
-        NodeConnector port = NodeConnectorCreator.createOFNodeConnector((short) 24, node);
-        NodeConnector port2 = NodeConnectorCreator.createOFNodeConnector((short) 24, node);
-        byte srcMac[] = { (byte) 0x12, (byte) 0x34, (byte) 0x56, (byte) 0x78, (byte) 0x9a, (byte) 0xbc };
-        byte dstMac[] = { (byte) 0x1a, (byte) 0x2b, (byte) 0x3c, (byte) 0x4d, (byte) 0x5e, (byte) 0x6f };
-        byte srcMac2[] = { (byte) 0x12, (byte) 0x34, (byte) 0x56, (byte) 0x78, (byte) 0x9a, (byte) 0xbc };
-        byte dstMac2[] = { (byte) 0x1a, (byte) 0x2b, (byte) 0x3c, (byte) 0x4d, (byte) 0x5e, (byte) 0x6f };
-        InetAddress srcIP = InetAddress.getByName("2001:420:281:1004:407a:57f4:4d15:c355");
-        InetAddress dstIP = InetAddress.getByName("2001:420:281:1004:e123:e688:d655:a1b0");
-        InetAddress ipMask = InetAddress.getByName("ffff:ffff:ffff:ffff:0:0:0:0");
-        InetAddress ipMaskd = InetAddress.getByName("ffff:ffff:ffff:ffff:ffff:ffff:ffff:0");
-        InetAddress srcIP2 = InetAddress.getByName("2001:420:281:1004:407a:57f4:4d15:c355");
-        InetAddress dstIP2 = InetAddress.getByName("2001:420:281:1004:e123:e688:d655:a1b0");
-        InetAddress ipMask2 = InetAddress.getByName("ffff:ffff:ffff:ffff:0:0:0:0");
-        InetAddress ipMaskd2 = InetAddress.getByName("ffff:ffff:ffff:ffff:ffff:ffff:ffff:0");
-        short ethertype = EtherTypes.IPv6.shortValue();
-        short ethertype2 = EtherTypes.IPv6.shortValue();
-        short vlan = (short) 27, vlan2 = (short) 27;
-        byte vlanPr = (byte) 3, vlanPr2 = (byte) 3;
-        Byte tos = 4, tos2 = 4;
-        byte proto = IPProtocols.UDP.byteValue(), proto2 = IPProtocols.UDP.byteValue();
-        short src = (short) 5500, src2 = (short) 5500;
-        short dst = 80, dst2 = 80;
-
-        /*
-         * Create a SAL Flow aFlow
-         */
-        Match match1 = new Match();
-        Match match2 = new Match();
-        match1.setField(MatchType.IN_PORT, port);
-        match1.setField(MatchType.DL_SRC, srcMac);
-        match1.setField(MatchType.DL_DST, dstMac);
-        match1.setField(MatchType.DL_TYPE, ethertype);
-        match1.setField(MatchType.DL_VLAN, vlan);
-        match1.setField(MatchType.DL_VLAN_PR, vlanPr);
-        match1.setField(MatchType.NW_SRC, srcIP, ipMask);
-        match1.setField(MatchType.NW_DST, dstIP, ipMaskd);
-        match1.setField(MatchType.NW_TOS, tos);
-        match1.setField(MatchType.NW_PROTO, proto);
-        match1.setField(MatchType.TP_SRC, src);
-        match1.setField(MatchType.TP_DST, dst);
-
-        match2.setField(MatchType.IN_PORT, port2);
-        match2.setField(MatchType.DL_SRC, srcMac2);
-        match2.setField(MatchType.DL_DST, dstMac2);
-        match2.setField(MatchType.DL_TYPE, ethertype2);
-        match2.setField(MatchType.DL_VLAN, vlan2);
-        match2.setField(MatchType.DL_VLAN_PR, vlanPr2);
-        match2.setField(MatchType.NW_SRC, srcIP2, ipMask2);
-        match2.setField(MatchType.NW_DST, dstIP2, ipMaskd2);
-        match2.setField(MatchType.NW_TOS, tos2);
-        match2.setField(MatchType.NW_PROTO, proto2);
-        match2.setField(MatchType.TP_SRC, src2);
-        match2.setField(MatchType.TP_DST, dst2);
-
-        Assert.assertTrue(match1.equals(match2));
-
-        // Make sure all values are equals
-        for (MatchType type : MatchType.values()) {
-            if (match1.isPresent(type)) {
-                Assert.assertTrue(match1.getField(type).equals(match2.getField(type)));
-            }
-        }
-
-        // Make none of the fields couples are pointing to the same reference
-        MatchField a = null, b = null;
-        for (MatchType type : MatchType.values()) {
-            a = match1.getField(type);
-            b = match2.getField(type);
-            if (a != null && b != null) {
-                Assert.assertFalse(a == b);
-            }
-        }
-    }
-
-    @Test
-    public void testEqualityNetMask() throws Exception {
-
-        InetAddress srcIP = InetAddress.getByName("1.1.1.1");
-        InetAddress ipMask = InetAddress.getByName("255.255.255.255");
-        InetAddress srcIP2 = InetAddress.getByName("1.1.1.1");
-        InetAddress ipMask2 = null;
-        short ethertype = EtherTypes.IPv4.shortValue();
-        short ethertype2 = EtherTypes.IPv4.shortValue();
-
-        /*
-         * Create a SAL Flow aFlow
-         */
-        Match match1 = new Match();
-        Match match2 = new Match();
-
-        match1.setField(MatchType.DL_TYPE, ethertype);
-        match1.setField(MatchType.NW_SRC, srcIP, ipMask);
-
-        match2.setField(MatchType.DL_TYPE, ethertype2);
-        match2.setField(MatchType.NW_SRC, srcIP2, ipMask2);
-
-        Assert.assertTrue(match1.equals(match2));
-
-        ipMask2 = InetAddress.getByName("255.255.255.255");
-        match2.setField(MatchType.NW_SRC, srcIP2, ipMask2);
-
-        srcIP = InetAddress.getByName("2001:420:281:1004:407a:57f4:4d15:c355");
-        srcIP2 = InetAddress.getByName("2001:420:281:1004:407a:57f4:4d15:c355");
-        ipMask = null;
-        ipMask2 = InetAddress.getByName("ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff");
-        ethertype = EtherTypes.IPv6.shortValue();
-        ethertype2 = EtherTypes.IPv6.shortValue();
-
-        match1.setField(MatchType.DL_TYPE, ethertype);
-        match1.setField(MatchType.NW_SRC, srcIP, ipMask);
-
-        match2.setField(MatchType.DL_TYPE, ethertype2);
-        match2.setField(MatchType.NW_SRC, srcIP2, ipMask2);
-
-        Assert.assertTrue(match1.equals(match2));
-    }
-
-    @Test
-    public void testHashCodeWithReverseMatch() throws Exception {
-        InetAddress srcIP1 = InetAddress.getByName("1.1.1.1");
-        InetAddress ipMask1 = InetAddress.getByName("255.255.255.255");
-        InetAddress srcIP2 = InetAddress.getByName("2.2.2.2");
-        InetAddress ipMask2 = InetAddress.getByName("255.255.255.255");
-        MatchField field1 = new MatchField(MatchType.NW_SRC, srcIP1, ipMask1);
-        MatchField field2 = new MatchField(MatchType.NW_DST, srcIP2, ipMask2);
-        Match match1 = new Match();
-        match1.setField(field1);
-        match1.setField(field2);
-        Match match2 = match1.reverse();
-        Assert.assertFalse(match1.hashCode() == match2.hashCode());
-    }
-
-    @Test
-    public void testHashCode() throws Exception {
-        byte srcMac1[] = { (byte) 0x12, (byte) 0x34, (byte) 0x56, (byte) 0x78, (byte) 0x9a, (byte) 0xbc };
-        byte srcMac2[] = { (byte) 0x12, (byte) 0x34, (byte) 0x56, (byte) 0x78, (byte) 0x9a, (byte) 0xbc };
-        byte dstMac1[] = { (byte) 0x1a, (byte) 0x2b, (byte) 0x3c, (byte) 0x4d, (byte) 0x5e, (byte) 0x6f };
-        byte dstMac2[] = { (byte) 0x1a, (byte) 0x2b, (byte) 0x3c, (byte) 0x4d, (byte) 0x5e, (byte) 0x6f };
-        short ethertype = EtherTypes.IPv4.shortValue();
-        short ethertype2 = EtherTypes.IPv4.shortValue();
-        InetAddress srcIP1 = InetAddress.getByName("1.1.1.1");
-        InetAddress ipMask1 = InetAddress.getByName("255.255.255.255");
-        InetAddress srcIP2 = InetAddress.getByName("1.1.1.1");
-        InetAddress ipMask2 = InetAddress.getByName("255.255.255.255");
-
-        Match match1 = new Match();
-        Match match2 = new Match();
-
-        MatchField field1 = new MatchField(MatchType.DL_SRC, srcMac1);
-        MatchField field2 = new MatchField(MatchType.DL_SRC, srcMac2);
-        Assert.assertTrue(field1.hashCode() == field2.hashCode());
-
-        match1.setField(field1);
-        match2.setField(field2);
-        Assert.assertTrue(match1.hashCode() == match2.hashCode());
-
-        MatchField field3 = new MatchField(MatchType.DL_DST, dstMac1);
-        MatchField field4 = new MatchField(MatchType.DL_DST, dstMac2);
-        Assert.assertTrue(field3.hashCode() == field4.hashCode());
-
-        match1.setField(field3);
-        match2.setField(field4);
-        Assert.assertTrue(match1.hashCode() == match2.hashCode());
-
-        MatchField field5 = new MatchField(MatchType.DL_TYPE, ethertype);
-        MatchField field6 = new MatchField(MatchType.DL_TYPE, ethertype2);
-        Assert.assertTrue(field5.hashCode() == field6.hashCode());
-
-        match1.setField(field5);
-        match2.setField(field6);
-        Assert.assertTrue(match1.hashCode() == match2 .hashCode());
-
-        MatchField field7 = new MatchField(MatchType.NW_SRC, srcIP1, ipMask1);
-        MatchField field8 = new MatchField(MatchType.NW_SRC, srcIP2, ipMask2);
-        Assert.assertTrue(field7.hashCode() == field8.hashCode());
-
-        match1.setField(field7);
-        match2.setField(field8);
-        Assert.assertTrue(match1.hashCode() == match2.hashCode());
-
-    }
-
-    @Test
-    public void testCloning() throws Exception {
-        Node node = NodeCreator.createOFNode(7L);
-        NodeConnector port = NodeConnectorCreator.createOFNodeConnector((short) 24, node);
-        byte srcMac[] = { (byte) 0x12, (byte) 0x34, (byte) 0x56, (byte) 0x78, (byte) 0x9a, (byte) 0xbc };
-        byte dstMac[] = { (byte) 0x1a, (byte) 0x2b, (byte) 0x3c, (byte) 0x4d, (byte) 0x5e, (byte) 0x6f };
-        InetAddress srcIP = InetAddress.getByName("2001:420:281:1004:407a:57f4:4d15:c355");
-        InetAddress dstIP = InetAddress.getByName("2001:420:281:1004:e123:e688:d655:a1b0");
-        InetAddress ipMasks = InetAddress.getByName("ffff:ffff:ffff:ffff:0:0:0:0");
-        InetAddress ipMaskd = InetAddress.getByName("ffff:ffff:ffff:ffff:ffff:ffff:ffff:0");
-        short ethertype = EtherTypes.IPv6.shortValue();
-        short vlan = (short) 27;
-        byte vlanPr = (byte) 3;
-        Byte tos = 4;
-        byte proto = IPProtocols.UDP.byteValue();
-        short src = (short) 5500;
-        short dst = 80;
-
-        /*
-         * Create a SAL Flow aFlow
-         */
-        Match match = new Match();
-        match.setField(MatchType.IN_PORT, port);
-        match.setField(MatchType.DL_SRC, srcMac);
-        match.setField(MatchType.DL_DST, dstMac);
-        match.setField(MatchType.DL_TYPE, ethertype);
-        match.setField(MatchType.DL_VLAN, vlan);
-        match.setField(MatchType.DL_VLAN_PR, vlanPr);
-        match.setField(MatchType.NW_SRC, srcIP, ipMasks);
-        match.setField(MatchType.NW_DST, dstIP, ipMaskd);
-        match.setField(MatchType.NW_TOS, tos);
-        match.setField(MatchType.NW_PROTO, proto);
-        match.setField(MatchType.TP_SRC, src);
-        match.setField(MatchType.TP_DST, dst);
-
-        Match cloned = match.clone();
-
-        // Make sure all values are equals
-        for (MatchType type : MatchType.values()) {
-            if (match.isPresent(type)) {
-                if (!match.getField(type).equals(cloned.getField(type))) {
-                    Assert.assertTrue(match.getField(type).equals(cloned.getField(type)));
-                }
-            }
-        }
-
-        // Make sure none of the fields couples are pointing to the same
-        // reference
-        MatchField a = null, b = null;
-        for (MatchType type : MatchType.values()) {
-            a = match.getField(type);
-            b = cloned.getField(type);
-            if (a != null && b != null) {
-                Assert.assertFalse(a == b);
-            }
-        }
-
-        Assert.assertTrue(match.equals(cloned));
-
-        Assert.assertFalse(match.getField(MatchType.DL_SRC) == cloned.getField(MatchType.DL_SRC));
-        Assert.assertFalse(match.getField(MatchType.NW_DST) == cloned.getField(MatchType.NW_DST));
-        Assert.assertTrue(match.getField(MatchType.NW_DST).getMask()
-                .equals(cloned.getField(MatchType.NW_DST).getMask()));
-        Assert.assertTrue(match.hashCode() == cloned.hashCode());
-    }
-
-    @Test
-    public void testFlip() throws Exception {
-        Node node = NodeCreator.createOFNode(7L);
-        NodeConnector port = NodeConnectorCreator.createOFNodeConnector((short) 24, node);
-        byte srcMac[] = { (byte) 0x12, (byte) 0x34, (byte) 0x56, (byte) 0x78, (byte) 0x9a, (byte) 0xbc };
-        byte dstMac[] = { (byte) 0x1a, (byte) 0x2b, (byte) 0x3c, (byte) 0x4d, (byte) 0x5e, (byte) 0x6f };
-        InetAddress srcIP = InetAddress.getByName("2001:420:281:1004:407a:57f4:4d15:c355");
-        InetAddress dstIP = InetAddress.getByName("2001:420:281:1004:e123:e688:d655:a1b0");
-        InetAddress ipMasks = InetAddress.getByName("ffff:ffff:ffff:ffff:0:0:0:0");
-        InetAddress ipMaskd = InetAddress.getByName("ffff:ffff:ffff:ffff:ffff:ffff:ffff:0");
-        short ethertype = EtherTypes.IPv6.shortValue();
-        short vlan = (short) 27;
-        byte vlanPr = (byte) 3;
-        Byte tos = 4;
-        byte proto = IPProtocols.UDP.byteValue();
-        short src = (short) 5500;
-        short dst = 80;
-
-        /*
-         * Create a SAL Flow aFlow
-         */
-        Match match = new Match();
-        match.setField(MatchType.IN_PORT, port);
-        match.setField(MatchType.DL_SRC, srcMac);
-        match.setField(MatchType.DL_DST, dstMac);
-        match.setField(MatchType.DL_TYPE, ethertype);
-        match.setField(MatchType.DL_VLAN, vlan);
-        match.setField(MatchType.DL_VLAN_PR, vlanPr);
-        match.setField(MatchType.NW_SRC, srcIP, ipMasks);
-        match.setField(MatchType.NW_DST, dstIP, ipMaskd);
-        match.setField(MatchType.NW_TOS, tos);
-        match.setField(MatchType.NW_PROTO, proto);
-        match.setField(MatchType.TP_SRC, src);
-        match.setField(MatchType.TP_DST, dst);
-
-        Match flipped = match.reverse();
-
-        Assert.assertTrue(match.getField(MatchType.DL_TYPE).equals(flipped.getField(MatchType.DL_TYPE)));
-        Assert.assertTrue(match.getField(MatchType.DL_VLAN).equals(flipped.getField(MatchType.DL_VLAN)));
-
-        Assert.assertTrue(match.getField(MatchType.DL_DST).getValue()
-                .equals(flipped.getField(MatchType.DL_SRC).getValue()));
-        Assert.assertTrue(match.getField(MatchType.DL_DST).getMask() == flipped.getField(MatchType.DL_SRC).getMask());
-
-        Assert.assertTrue(match.getField(MatchType.NW_DST).getValue()
-                .equals(flipped.getField(MatchType.NW_SRC).getValue()));
-        Assert.assertTrue(match.getField(MatchType.NW_DST).getMask() == flipped.getField(MatchType.NW_SRC).getMask());
-
-        Assert.assertTrue(match.getField(MatchType.TP_DST).getValue()
-                .equals(flipped.getField(MatchType.TP_SRC).getValue()));
-        Assert.assertTrue(match.getField(MatchType.TP_DST).getMask() == flipped.getField(MatchType.TP_SRC).getMask());
-
-        Match flipflip = flipped.reverse().reverse();
-        Assert.assertTrue(flipflip.equals(flipped));
-
-    }
-
-    @Test
-    public void testVlanNone() throws Exception {
-        // The value 0 is used to indicate that no VLAN ID is set
-        short vlan = (short) 0;
-        MatchField field = new MatchField(MatchType.DL_VLAN, vlan);
-
-        Assert.assertTrue(field != null);
-        Assert.assertTrue(field.getValue().equals(new Short(vlan)));
-        Assert.assertTrue(field.isValid());
-    }
-
-    @Test
-    public void testIntersection() throws UnknownHostException {
-        Short ethType = Short.valueOf((short)0x800);
-        InetAddress ip1 = InetAddress.getByName("1.1.1.1");
-        InetAddress ip2 = InetAddress.getByName("1.1.1.0");
-        InetAddress ipm2 = InetAddress.getByName("255.255.255.0");
-        InetAddress ip3 = InetAddress.getByName("1.3.0.0");
-        InetAddress ipm3 = InetAddress.getByName("255.255.0.0");
-        InetAddress ip4 = InetAddress.getByName("1.3.4.4");
-        InetAddress ipm4 = InetAddress.getByName("255.255.255.0");
-
-        Match m1 = new Match();
-        m1.setField(MatchType.DL_TYPE, ethType);
-        m1.setField(MatchType.NW_SRC, ip1);
-
-        Match m2 = new Match();
-        m2.setField(MatchType.DL_TYPE, ethType);
-        m2.setField(MatchType.NW_SRC, ip2, ipm2);
-
-        Match m3 = new Match();
-        m3.setField(MatchType.DL_TYPE, ethType);
-        m3.setField(MatchType.NW_SRC, ip3, ipm3);
-        m3.setField(MatchType.NW_PROTO, IPProtocols.TCP.byteValue());
-
-        Match m3r = m3.reverse();
-        Assert.assertTrue(m3.intersetcs(m3r));
-
-        Assert.assertTrue(m1.intersetcs(m2));
-        Assert.assertTrue(m2.intersetcs(m1));
-        Assert.assertFalse(m1.intersetcs(m3));
-        Assert.assertTrue(m1.intersetcs(m3r));
-        Assert.assertFalse(m3.intersetcs(m1));
-        Assert.assertTrue(m3.intersetcs(m1.reverse()));
-        Assert.assertFalse(m2.intersetcs(m3));
-        Assert.assertFalse(m3.intersetcs(m2));
-        Assert.assertTrue(m2.intersetcs(m3r));
-
-
-        Match i = m1.getIntersection(m2);
-        Assert.assertTrue(((Short)i.getField(MatchType.DL_TYPE).getValue()).equals(ethType));
-        // Verify intersection of IP addresses is correct
-        Assert.assertTrue(((InetAddress)i.getField(MatchType.NW_SRC).getValue()).equals(ip1));
-        Assert.assertNull(i.getField(MatchType.NW_SRC).getMask());
-
-        // Empty set
-        i = m2.getIntersection(m3);
-        Assert.assertNull(i);
-
-        Match m4 = new Match();
-        m4.setField(MatchType.DL_TYPE, ethType);
-        m4.setField(MatchType.NW_PROTO, IPProtocols.TCP.byteValue());
-        m3.setField(MatchType.NW_SRC, ip4, ipm4);
-        Assert.assertTrue(m4.intersetcs(m3));
-
-        // Verify intersection of IP and IP mask addresses is correct
-        Match ii = m3.getIntersection(m4);
-        Assert.assertTrue(((InetAddress)ii.getField(MatchType.NW_SRC).getValue()).equals(ip4));
-        Assert.assertTrue(((InetAddress)ii.getField(MatchType.NW_SRC).getMask()).equals(ipm4));
-
-        Match m5 = new Match();
-        m5.setField(MatchType.DL_TYPE, ethType);
-        m3.setField(MatchType.NW_SRC, ip3, ipm3);
-        m5.setField(MatchType.NW_PROTO, IPProtocols.UDP.byteValue());
-        Assert.assertFalse(m5.intersetcs(m3));
-        Assert.assertFalse(m5.intersetcs(m4));
-        Assert.assertTrue(m5.intersetcs(m5));
-        Assert.assertFalse(m3.intersetcs(m5));
-        Assert.assertFalse(m4.intersetcs(m5));
-
-
-        Match i2 = m4.getIntersection(m3);
-        Assert.assertFalse(i2.getMatches() == 0);
-        Assert.assertFalse(i2.getMatchesList().isEmpty());
-        Assert.assertTrue(((InetAddress)i2.getField(MatchType.NW_SRC).getValue()).equals(ip3));
-        Assert.assertTrue(((InetAddress)i2.getField(MatchType.NW_SRC).getMask()).equals(ipm3));
-        Assert.assertTrue(((Byte)i2.getField(MatchType.NW_PROTO).getValue()).equals(IPProtocols.TCP.byteValue()));
-
-        byte src[] = {(byte)0, (byte)0xab,(byte)0xbc,(byte)0xcd,(byte)0xde,(byte)0xef};
-        byte dst[] = {(byte)0x10, (byte)0x11,(byte)0x12,(byte)0x13,(byte)0x14,(byte)0x15};
-        Short srcPort = (short)1024;
-        Short dstPort = (short)80;
-
-        // Check identity
-        Match m6 = new Match();
-        m6.setField(MatchType.DL_SRC, src);
-        m6.setField(MatchType.DL_DST, dst);
-        m6.setField(MatchType.NW_SRC, ip2, ipm2);
-        m6.setField(MatchType.NW_DST, ip3, ipm3);
-        m6.setField(MatchType.NW_PROTO, IPProtocols.UDP.byteValue());
-        m6.setField(MatchType.TP_SRC, srcPort);
-        m6.setField(MatchType.TP_DST, dstPort);
-        Assert.assertTrue(m6.intersetcs(m6));
-        Assert.assertTrue(m6.getIntersection(m6).equals(m6));
-
-        // Empty match, represents the universal set (all packets)
-        Match u = new Match();
-        Assert.assertTrue(m6.getIntersection(u).equals(m6));
-        Assert.assertTrue(u.getIntersection(m6).equals(m6));
-
-        // No intersection with null match, empty set
-        Assert.assertNull(m6.getIntersection(null));
-    }
-
-    @Test
-    public void testMetadata() {
-        Property tier1 = new Tier(1);
-        Property tier2 = new Tier(2);
-        Property table1 = new Tables((byte)0x7f);
-        Match m1 = new Match();
-        List<Property> resprops = null;
-        resprops = m1.getMetadatas();
-        // This should be null
-        Assert.assertTrue(resprops.isEmpty());
-        m1.setMetadata("tier1", tier1);
-        m1.setMetadata("tier2", tier2);
-        m1.setMetadata("table1", table1);
-        resprops = m1.getMetadatas();
-        // Check for the number of elements in it
-        Assert.assertTrue(resprops.size() == 3);
-        // Check if the elements are in it
-        Assert.assertTrue(resprops.contains(tier1));
-        Assert.assertTrue(resprops.contains(tier2));
-        Assert.assertTrue(resprops.contains(table1));
-        // Check for single elements retrieve
-        Assert.assertTrue(m1.getMetadata("tier1").equals(tier1));
-        Assert.assertTrue(m1.getMetadata("tier2").equals(tier2));
-        Assert.assertTrue(m1.getMetadata("table1").equals(table1));
-        // Now remove an element and make sure the remaining are
-        // correct
-        m1.removeMetadata("tier1");
-
-        resprops = m1.getMetadatas();
-        // Check for the number of elements in it
-        Assert.assertTrue(resprops.size() == 2);
-        // Check if the elements are in it
-        Assert.assertFalse(resprops.contains(tier1));
-        Assert.assertTrue(resprops.contains(tier2));
-        Assert.assertTrue(resprops.contains(table1));
-        // Check for single elements retrieve
-        Assert.assertTrue(m1.getMetadata("table1").equals(table1));
-        Assert.assertTrue(m1.getMetadata("tier2").equals(tier2));
-        Assert.assertNull(m1.getMetadata("tier1"));
-
-        // Check for an element never existed
-        Assert.assertNull(m1.getMetadata("table100"));
-
-        // Remove them all
-        m1.removeMetadata("tier2");
-        m1.removeMetadata("table1");
-
-        // Remove also a non-existent one
-        m1.removeMetadata("table100");
-
-        resprops = m1.getMetadatas();
-        // Check there are no elements left
-        Assert.assertTrue(resprops.size() == 0);
-
-        // Now check for exception on setting null values
-        try {
-            m1.setMetadata("foo", null);
-            // The line below should never be reached
-            Assert.assertTrue(false);
-        } catch (NullPointerException nue) {
-            // NPE should be raised for null value
-            Assert.assertTrue(true);
-        }
-
-        // Now check on using null key
-        try {
-            m1.setMetadata(null, table1);
-            // The line below should never be reached
-            Assert.assertTrue(false);
-        } catch (NullPointerException nue) {
-            // NPE should be raised for null value
-            Assert.assertTrue(true);
-        }
-
-        // Now check on using null key and null value
-        try {
-            m1.setMetadata(null, null);
-            // The line below should never be reached
-            Assert.assertTrue(false);
-        } catch (NullPointerException nue) {
-            // NPE should be raised for null value
-            Assert.assertTrue(true);
-        }
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/packet/ARPTest.java b/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/packet/ARPTest.java
deleted file mode 100644 (file)
index 792772a..0000000
+++ /dev/null
@@ -1,226 +0,0 @@
-
-/*
- * Copyright (c) 2013-2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.packet;
-
-import org.junit.Test;
-
-import org.junit.Assert;
-
-public class ARPTest {
-
-    @Test
-    public void testGetHardwareType() {
-        ARP arp = new ARP();
-        byte[] hardwaretype = { 8, 6 };
-        arp.hdrFieldsMap.put("HardwareType", hardwaretype);
-        short hwtype = arp.getHardwareType();
-        Assert.assertTrue(hwtype == 2054);
-    }
-
-    @Test
-    public void testGetProtocolType() {
-        ARP arp = new ARP();
-        byte[] protocoltype = { 8, 0 };
-        arp.hdrFieldsMap.put("ProtocolType", protocoltype);
-        short ptype = arp.getProtocolType();
-        Assert.assertTrue(ptype == 2048);
-    }
-
-    @Test
-    public void testGetHardwareAddressLength() {
-        ARP arp = new ARP();
-        byte[] hardwareaddresslength = { 48 };
-        arp.hdrFieldsMap.put("HardwareAddressLength", hardwareaddresslength);
-        byte hwaddrlength = arp.getHardwareAddressLength();
-        Assert.assertTrue(hwaddrlength == 48);
-    }
-
-    @Test
-    public void testGetProtocolAddressLength() {
-        ARP arp = new ARP();
-        byte[] protocoladdresslength = { 32 };
-        arp.hdrFieldsMap.put("ProtocolAddressLength", protocoladdresslength);
-        byte paddrlength = arp.getProtocolAddressLength();
-        Assert.assertTrue(paddrlength == 32);
-    }
-
-    @Test
-    public void testGetOpCode() {
-        ARP arp = new ARP();
-        byte[] opcode = { 0, 2 };
-        arp.hdrFieldsMap.put("OpCode", opcode);
-        short opCode = arp.getOpCode();
-        Assert.assertTrue(opCode == 2);
-    }
-
-    @Test
-    public void testGetSenderHardwareAddress() {
-        ARP arp = new ARP();
-        byte[] hardwareaddress = { 48, 50, 120, 15, 66, 80 };
-        arp.hdrFieldsMap.put("SenderHardwareAddress", hardwareaddress);
-        byte[] hwAddress = arp.getSenderHardwareAddress();
-        Assert.assertTrue(hwAddress[0] == 48);
-        Assert.assertTrue(hwAddress[1] == 50);
-        Assert.assertTrue(hwAddress[2] == 120);
-        Assert.assertTrue(hwAddress[3] == 15);
-        Assert.assertTrue(hwAddress[4] == 66);
-        Assert.assertTrue(hwAddress[5] == 80);
-    }
-
-    @Test
-    public void testGetSenderProtocolAddress() {
-        ARP arp = new ARP();
-        byte[] protocoladdress = { 50, 100, 10, 20, 40, 80 };
-        arp.hdrFieldsMap.put("SenderProtocolAddress", protocoladdress);
-        byte[] pAddress = arp.getSenderProtocolAddress();
-        Assert.assertTrue(pAddress[0] == 50);
-        Assert.assertTrue(pAddress[1] == 100);
-        Assert.assertTrue(pAddress[2] == 10);
-        Assert.assertTrue(pAddress[3] == 20);
-        Assert.assertTrue(pAddress[4] == 40);
-        Assert.assertTrue(pAddress[5] == 80);
-    }
-
-    @Test
-    public void testGetTargetHardwareAddress() {
-        ARP arp = new ARP();
-        byte[] hardwareaddress = { 48, 50, 120, 15, 66, 80 };
-        arp.hdrFieldsMap.put("TargetHardwareAddress", hardwareaddress);
-        byte[] hwAddress = arp.getTargetHardwareAddress();
-        Assert.assertTrue(hwAddress[0] == 48);
-        Assert.assertTrue(hwAddress[1] == 50);
-        Assert.assertTrue(hwAddress[2] == 120);
-        Assert.assertTrue(hwAddress[3] == 15);
-        Assert.assertTrue(hwAddress[4] == 66);
-        Assert.assertTrue(hwAddress[5] == 80);
-    }
-
-    @Test
-    public void testGetTargetProtocolAddress() {
-        ARP arp = new ARP();
-        byte[] protocoladdress = { 50, 100, 10, 20, 40, 80 };
-        arp.hdrFieldsMap.put("TargetProtocolAddress", protocoladdress);
-        byte[] pAddress = arp.getTargetProtocolAddress();
-        Assert.assertTrue(pAddress[0] == 50);
-        Assert.assertTrue(pAddress[1] == 100);
-        Assert.assertTrue(pAddress[2] == 10);
-        Assert.assertTrue(pAddress[3] == 20);
-        Assert.assertTrue(pAddress[4] == 40);
-        Assert.assertTrue(pAddress[5] == 80);
-    }
-
-    @Test
-    public void testSetHardwareType() {
-        ARP arp = new ARP();
-        short hwtype = 2054;
-        arp.setHardwareType(hwtype);
-        byte[] hardwaretype = arp.hdrFieldsMap.get("HardwareType");
-        Assert.assertTrue(hardwaretype[0] == 8);
-        Assert.assertTrue(hardwaretype[1] == 6);
-    }
-
-    @Test
-    public void testSetProtocolType() {
-        ARP arp = new ARP();
-        short ptype = 2048;
-        arp.setProtocolType(ptype);
-        byte[] protocoltype = arp.hdrFieldsMap.get("ProtocolType");
-        Assert.assertTrue(protocoltype[0] == 8);
-        Assert.assertTrue(protocoltype[1] == 0);
-    }
-
-    @Test
-    public void testSetHardwareAddressLength() {
-        ARP arp = new ARP();
-        byte hwaddrlength = 48;
-        arp.setHardwareAddressLength(hwaddrlength);
-        byte[] hardwareaddresslength = arp.hdrFieldsMap
-                .get("HardwareAddressLength");
-        Assert.assertTrue(hardwareaddresslength[0] == 48);
-    }
-
-    @Test
-    public void testSetProtocolAddressLength() {
-        ARP arp = new ARP();
-        byte PAddrlength = 32;
-        arp.setProtocolAddressLength(PAddrlength);
-        byte[] protocoladdresslength = arp.hdrFieldsMap
-                .get("ProtocolAddressLength");
-        Assert.assertTrue(protocoladdresslength[0] == 32);
-    }
-
-    @Test
-    public void testSetOpCode() {
-        ARP arp = new ARP();
-        short opCode = (short) 2;
-        arp.setOpCode(opCode);
-        byte[] opcode = arp.hdrFieldsMap.get("OpCode");
-        //System.out.println(opCode);
-        Assert.assertTrue(opcode[0] == 0);
-        Assert.assertTrue(opcode[1] == 2);
-    }
-
-    @Test
-    public void testSetSenderHardwareAddress() {
-        ARP arp = new ARP();
-        byte[] hardwareaddress = { 48, 50, 120, 15, 66, 80 };
-        arp.setSenderHardwareAddress(hardwareaddress);
-        byte[] hwAddress = arp.hdrFieldsMap.get("SenderHardwareAddress");
-        Assert.assertTrue(hwAddress[0] == 48);
-        Assert.assertTrue(hwAddress[1] == 50);
-        Assert.assertTrue(hwAddress[2] == 120);
-        Assert.assertTrue(hwAddress[3] == 15);
-        Assert.assertTrue(hwAddress[4] == 66);
-        Assert.assertTrue(hwAddress[5] == 80);
-    }
-
-    @Test
-    public void testSetSenderProtocolAddress() {
-        ARP arp = new ARP();
-        byte[] protocoladdress = { 50, 100, 10, 20, 40, 80 };
-        arp.setSenderProtocolAddress(protocoladdress);
-        byte[] pAddress = arp.hdrFieldsMap.get("SenderProtocolAddress");
-        Assert.assertTrue(pAddress[0] == 50);
-        Assert.assertTrue(pAddress[1] == 100);
-        Assert.assertTrue(pAddress[2] == 10);
-        Assert.assertTrue(pAddress[3] == 20);
-        Assert.assertTrue(pAddress[4] == 40);
-        Assert.assertTrue(pAddress[5] == 80);
-    }
-
-    @Test
-    public void testSetTargetHardwareAddress() {
-        ARP arp = new ARP();
-        byte[] hardwareaddress = { 48, 50, 120, 15, 66, 80 };
-        arp.setTargetHardwareAddress(hardwareaddress);
-        byte[] hwAddress = arp.hdrFieldsMap.get("TargetHardwareAddress");
-        Assert.assertTrue(hwAddress[0] == 48);
-        Assert.assertTrue(hwAddress[1] == 50);
-        Assert.assertTrue(hwAddress[2] == 120);
-        Assert.assertTrue(hwAddress[3] == 15);
-        Assert.assertTrue(hwAddress[4] == 66);
-        Assert.assertTrue(hwAddress[5] == 80);
-    }
-
-    @Test
-    public void testSetTargetProtocolAddress() {
-        ARP arp = new ARP();
-        byte[] protocoladdress = { 50, 100, 10, 20, 40, 80 };
-        arp.setTargetProtocolAddress(protocoladdress);
-        byte[] pAddress = arp.hdrFieldsMap.get("TargetProtocolAddress");
-        Assert.assertTrue(pAddress[0] == 50);
-        Assert.assertTrue(pAddress[1] == 100);
-        Assert.assertTrue(pAddress[2] == 10);
-        Assert.assertTrue(pAddress[3] == 20);
-        Assert.assertTrue(pAddress[4] == 40);
-        Assert.assertTrue(pAddress[5] == 80);
-    }
-
-}
diff --git a/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/packet/BitBufferHelperTest.java b/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/packet/BitBufferHelperTest.java
deleted file mode 100644 (file)
index 98e8c45..0000000
+++ /dev/null
@@ -1,692 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.packet;
-
-import org.junit.Assert;
-
-import org.junit.Test;
-
-public class BitBufferHelperTest {
-
-    @Test
-    public void testGetByte() {
-        byte[] data = { 100 };
-        Assert.assertTrue(BitBufferHelper.getByte(data) == 100);
-    }
-
-    @Test
-    public void testGetBits() throws Exception {
-        byte[] data = { 10, 12, 14, 20, 55, 69, 82, 97, 109, 117, 127, -50 };
-        byte[] bits;
-
-        bits = BitBufferHelper.getBits(data, 88, 8); //BYTE extraOffsetBits = extranumBits = 0
-        Assert.assertTrue(bits[0] == -50);
-
-        bits = BitBufferHelper.getBits(data, 8, 16); //Short
-        Assert.assertTrue(bits[0] == 12);
-        Assert.assertTrue(bits[1] == 14);
-
-        bits = BitBufferHelper.getBits(data, 32, 32); //Int
-        Assert.assertTrue(bits[0] == 55);
-        Assert.assertTrue(bits[1] == 69);
-        Assert.assertTrue(bits[2] == 82);
-        Assert.assertTrue(bits[3] == 97);
-
-        bits = BitBufferHelper.getBits(data, 16, 48); //Long
-        Assert.assertTrue(bits[0] == 14);
-        Assert.assertTrue(bits[1] == 20);
-        Assert.assertTrue(bits[2] == 55);
-        Assert.assertTrue(bits[3] == 69);
-        Assert.assertTrue(bits[4] == 82);
-        Assert.assertTrue(bits[5] == 97);
-
-        bits = BitBufferHelper.getBits(data, 40, 7); //BYTE extraOffsetBits = extranumBits != 0
-        Assert.assertTrue(bits[0] == 34);
-
-        bits = BitBufferHelper.getBits(data, 8, 13); //Short
-        Assert.assertTrue(bits[0] == 1);
-        Assert.assertTrue(bits[1] == -127);
-
-        bits = BitBufferHelper.getBits(data, 32, 28); //Int
-        Assert.assertTrue(bits[0] == 3);
-        Assert.assertTrue(bits[1] == 116);
-        Assert.assertTrue(bits[2] == 85);
-        Assert.assertTrue(bits[3] == 38);
-
-        bits = BitBufferHelper.getBits(data, 16, 41); //Long
-        Assert.assertTrue(bits[0] == 0);
-        Assert.assertTrue(bits[1] == 28);
-        Assert.assertTrue(bits[2] == 40);
-        Assert.assertTrue(bits[3] == 110);
-        Assert.assertTrue(bits[4] == -118);
-        Assert.assertTrue(bits[5] == -92);
-
-        bits = BitBufferHelper.getBits(data, 3, 7); //BYTE extraOffsetBits != 0; extranumBits == 0
-        Assert.assertTrue(bits[0] == 40);
-
-        bits = BitBufferHelper.getBits(data, 13, 16); //Short
-        Assert.assertTrue(bits[0] == -127);
-        Assert.assertTrue(bits[1] == -62);
-
-        bits = BitBufferHelper.getBits(data, 5, 32); //Int
-        Assert.assertTrue(bits[0] == 65);
-        Assert.assertTrue(bits[1] == -127);
-        Assert.assertTrue(bits[2] == -62);
-        Assert.assertTrue(bits[3] == -122);
-
-        bits = BitBufferHelper.getBits(data, 23, 48); //Long
-        Assert.assertTrue(bits[0] == 10);
-        Assert.assertTrue(bits[1] == 27);
-        Assert.assertTrue(bits[2] == -94);
-        Assert.assertTrue(bits[3] == -87);
-        Assert.assertTrue(bits[4] == 48);
-        Assert.assertTrue(bits[5] == -74);
-
-        bits = BitBufferHelper.getBits(data, 66, 9); //BYTE extraOffsetBits != 0; extranumBits != 0
-        Assert.assertTrue(bits[0] == 1);
-        Assert.assertTrue(bits[1] == 107);
-
-        bits = BitBufferHelper.getBits(data, 13, 15); //Short
-        Assert.assertTrue(bits[0] == 64);
-        Assert.assertTrue(bits[1] == -31);
-
-        bits = BitBufferHelper.getBits(data, 5, 29); //Int
-        Assert.assertTrue(bits[0] == 8);
-        Assert.assertTrue(bits[1] == 48);
-        Assert.assertTrue(bits[2] == 56);
-        Assert.assertTrue(bits[3] == 80);
-
-        bits = BitBufferHelper.getBits(data, 31, 43); //Long
-        Assert.assertTrue(bits[0] == 0);
-        Assert.assertTrue(bits[1] == -35);
-        Assert.assertTrue(bits[2] == 21);
-        Assert.assertTrue(bits[3] == 73);
-        Assert.assertTrue(bits[4] == -123);
-        Assert.assertTrue(bits[5] == -75);
-
-        bits = BitBufferHelper.getBits(data, 4, 12); //Short
-        Assert.assertTrue(bits[0] == 10);
-        Assert.assertTrue(bits[1] == 12);
-
-        byte[] data1 = { 0, 8 };
-        bits = BitBufferHelper.getBits(data1, 7, 9); //Short
-        Assert.assertTrue(bits[0] == 0);
-        Assert.assertTrue(bits[1] == 8);
-
-        byte[] data2 = { 2, 8 };
-        bits = BitBufferHelper.getBits(data2, 0, 7); //Short
-        Assert.assertTrue(bits[0] == 1);
-
-        bits = BitBufferHelper.getBits(data2, 7, 9); //Short
-        Assert.assertTrue(bits[0] == 0);
-        Assert.assertTrue(bits[1] == 8);
-    }
-
-    // [01101100][01100000]
-    //     [01100011]
-    @Test
-    public void testGetBytes() throws Exception {
-        byte data[] = { 108, 96, 125, -112, 5, 6, 108, 8, 9, 10, 11, 12, 13,
-                14, 15, 16, 17, 18, 19, 20, 21, 22 };
-        byte[] x;
-
-        Assert.assertTrue(BitBufferHelper.getBits(data, 0, 8)[0] == 108);
-        Assert.assertTrue(BitBufferHelper.getBits(data, 8, 8)[0] == 96);
-
-        x = BitBufferHelper.getBits(data, 0, 10);
-        Assert.assertTrue(x[0] == 1);
-        Assert.assertTrue(x[1] == -79);
-
-        x = BitBufferHelper.getBits(data, 3, 8);
-        Assert.assertTrue(x[0] == 99);
-        //Assert.assertTrue(x[1] == 97);
-
-    }
-
-    @Test
-    public void testMSBMask() {
-        int numBits = 1; //MSB
-        int mask = BitBufferHelper.getMSBMask(numBits);
-        Assert.assertTrue(mask == 128);
-
-        numBits = 8;
-        mask = BitBufferHelper.getMSBMask(numBits);
-        Assert.assertTrue(mask == 255);
-
-        numBits = 2;
-        mask = BitBufferHelper.getMSBMask(numBits);
-        Assert.assertTrue(mask == 192);
-    }
-
-    @Test
-    public void testLSBMask() {
-        int numBits = 1; //LSB
-        int mask = BitBufferHelper.getLSBMask(numBits);
-        Assert.assertTrue(mask == 1);
-
-        numBits = 3;
-        mask = BitBufferHelper.getLSBMask(numBits);
-        Assert.assertTrue(mask == 7);
-
-        numBits = 8;
-        mask = BitBufferHelper.getLSBMask(numBits);
-        Assert.assertTrue(mask == 255);
-    }
-
-    @Test
-    public void testToByteArray() {
-        short sh = Short.MAX_VALUE;
-        byte[] data_sh = new byte[Byte.SIZE / 8];
-        data_sh = BitBufferHelper.toByteArray(sh);
-        Assert.assertTrue(data_sh[0] == 127);
-        Assert.assertTrue(data_sh[1] == -1);
-
-        short sh2 = Short.MIN_VALUE;
-        byte[] data_sh2 = new byte[Byte.SIZE / 8];
-        data_sh2 = BitBufferHelper.toByteArray(sh2);
-        Assert.assertTrue(data_sh2[0] == -128);
-        Assert.assertTrue(data_sh2[1] == 0);
-
-        short sh3 = 16384;
-        byte[] data_sh3 = new byte[Byte.SIZE / 8];
-        data_sh3 = BitBufferHelper.toByteArray(sh3);
-        Assert.assertTrue(data_sh3[0] == 64);
-        Assert.assertTrue(data_sh3[1] == 0);
-
-        short sh4 = 146; //TCP headerlenflags - startoffset = 103
-        byte[] data_sh4 = new byte[Byte.SIZE / 8];
-        data_sh4 = BitBufferHelper.toByteArray(sh4);
-        Assert.assertTrue(data_sh4[0] == 0);
-        Assert.assertTrue(data_sh4[1] == -110);
-
-        short sh4_2 = 5000; //IPv4 Offset - startOffset = 51 (to 63)
-        byte[] data_sh4_2 = new byte[Byte.SIZE / 8];
-        data_sh4_2 = BitBufferHelper.toByteArray(sh4_2);
-        Assert.assertTrue(data_sh4_2[0] == 19);
-        Assert.assertTrue(data_sh4_2[1] == -120);
-
-        short sh4_3 = 5312; //numEndRestBits < numBitstoShiftBy
-        byte[] data_sh4_3 = new byte[Byte.SIZE / 8];
-        data_sh4_3 = BitBufferHelper.toByteArray(sh4_3);
-        Assert.assertTrue(data_sh4_3[0] == 20);
-        Assert.assertTrue(data_sh4_3[1] == -64);
-
-        int Int = Integer.MAX_VALUE;
-        byte[] data_Int = new byte[Integer.SIZE / 8];
-        data_Int = BitBufferHelper.toByteArray(Int);
-        Assert.assertTrue(data_Int[0] == 127);
-        Assert.assertTrue(data_Int[1] == -1);
-        Assert.assertTrue(data_Int[2] == -1);
-        Assert.assertTrue(data_Int[3] == -1);
-
-        int Int2 = Integer.MIN_VALUE;
-        byte[] data_Int2 = new byte[Integer.SIZE / 8];
-        data_Int2 = BitBufferHelper.toByteArray(Int2);
-        Assert.assertTrue(data_Int2[0] == -128);
-        Assert.assertTrue(data_Int2[1] == 0);
-        Assert.assertTrue(data_Int2[2] == 0);
-        Assert.assertTrue(data_Int2[3] == 0);
-
-        int Int3 = 1077952576;
-        byte[] data_Int3 = new byte[Integer.SIZE / 8];
-        data_Int3 = BitBufferHelper.toByteArray(Int3);
-        Assert.assertTrue(data_Int3[0] == 64);
-        Assert.assertTrue(data_Int3[1] == 64);
-        Assert.assertTrue(data_Int3[2] == 64);
-        Assert.assertTrue(data_Int3[3] == 64);
-
-        long Lng = Long.MAX_VALUE;
-        byte[] data_lng = new byte[Long.SIZE / 8];
-        data_lng = BitBufferHelper.toByteArray(Lng);
-        Assert.assertTrue(data_lng[0] == 127);
-        Assert.assertTrue(data_lng[1] == -1);
-        Assert.assertTrue(data_lng[2] == -1);
-        Assert.assertTrue(data_lng[3] == -1);
-        Assert.assertTrue(data_lng[4] == -1);
-        Assert.assertTrue(data_lng[5] == -1);
-        Assert.assertTrue(data_lng[6] == -1);
-        Assert.assertTrue(data_lng[7] == -1);
-
-        long Lng2 = Long.MIN_VALUE;
-        byte[] data_lng2 = new byte[Long.SIZE / 8];
-        data_lng2 = BitBufferHelper.toByteArray(Lng2);
-        Assert.assertTrue(data_lng2[0] == -128);
-        Assert.assertTrue(data_lng2[1] == 0);
-        Assert.assertTrue(data_lng2[2] == 0);
-        Assert.assertTrue(data_lng2[3] == 0);
-        Assert.assertTrue(data_lng2[4] == 0);
-        Assert.assertTrue(data_lng2[5] == 0);
-        Assert.assertTrue(data_lng2[6] == 0);
-        Assert.assertTrue(data_lng2[7] == 0);
-
-        byte B = Byte.MAX_VALUE;
-        byte[] data_B = new byte[Byte.SIZE / 8];
-        data_B = BitBufferHelper.toByteArray(B);
-        Assert.assertTrue(data_B[0] == 127);
-
-        byte B1 = Byte.MIN_VALUE;
-        byte[] data_B1 = new byte[Byte.SIZE / 8];
-        data_B1 = BitBufferHelper.toByteArray(B1);
-        Assert.assertTrue(data_B1[0] == -128);
-
-        byte B2 = 64;
-        byte[] data_B2 = new byte[Byte.SIZE / 8];
-        data_B2 = BitBufferHelper.toByteArray(B2);
-        Assert.assertTrue(data_B2[0] == 64);
-
-        byte B3 = 32;
-        byte[] data_B3 = new byte[Byte.SIZE / 8];
-        data_B3 = BitBufferHelper.toByteArray(B3);
-        Assert.assertTrue(data_B3[0] == 32);
-
-    }
-
-    @Test
-    public void testToByteArrayVariable() {
-        int len = 9;
-        byte[] data_sh;
-        data_sh = BitBufferHelper.toByteArray(511, len);
-        Assert.assertTrue(data_sh[0] == (byte) 255);
-        Assert.assertTrue(data_sh[1] == (byte) 128);
-
-        data_sh = BitBufferHelper.toByteArray((int) 511, len);
-        Assert.assertTrue(data_sh[0] == (byte) 255);
-        Assert.assertTrue(data_sh[1] == (byte) 128);
-
-        data_sh = BitBufferHelper.toByteArray((long) 511, len);
-        Assert.assertTrue(data_sh[0] == (byte) 255);
-        Assert.assertTrue(data_sh[1] == (byte) 128);
-    }
-
-    @Test
-    public void testToInt() {
-        byte data[] = { 1 };
-        Assert.assertTrue(BitBufferHelper.toNumber(data) == 1);
-
-        byte data2[] = { 1, 1 };
-        Assert.assertTrue(BitBufferHelper.toNumber(data2) == 257);
-
-        byte data3[] = { 1, 1, 1 };
-        Assert.assertTrue(BitBufferHelper.toNumber(data3) == 65793);
-    }
-
-    @Test
-    public void testToLongGetter() {
-        byte data[] = { 1, 1 };
-        Assert.assertTrue(BitBufferHelper.getLong(data) == 257L);
-    }
-
-    @Test
-    public void testSetByte() throws Exception {
-        byte input;
-        byte[] data = new byte[20];
-
-        input = 125;
-        BitBufferHelper.setByte(data, input, 0, Byte.SIZE);
-        Assert.assertTrue(data[0] == 125);
-
-        input = 109;
-        BitBufferHelper.setByte(data, input, 152, Byte.SIZE);
-        Assert.assertTrue(data[19] == 109);
-    }
-
-    @Test
-    public void testSetBytes() throws Exception {
-        byte[] input = { 0, 1 };
-        byte[] data = { 6, 0 };
-
-        BitBufferHelper.setBytes(data, input, 7, 9);
-        Assert.assertTrue(data[0] == 6);
-        Assert.assertTrue(data[1] == 1);
-    }
-
-    //@Test
-    //INPUT: {75, 110, 107, 80, 10, 12, 35, 100, 125, 65} =
-    // [01001011] [01101110] [01101011] [10100000] [00001010] [00001100] [00100011] [01100100] [11111101] [01000001]*/
-    public void testInsertBits() throws Exception {
-        //CASE 1: startOffset%8 == 0 && numBits%8 == 0
-        byte inputdata[] = { 75, 110, 107, 80, 10, 12, 35, 100, 125, 65 };
-        int startOffset = 0;
-        int numBits = 8;
-
-        byte data1[] = new byte[2];
-        startOffset = 0;
-        numBits = 16;
-        BitBufferHelper.insertBits(data1, inputdata, startOffset, numBits);
-        Assert.assertTrue(data1[0] == 75);
-        Assert.assertTrue(data1[1] == 110);
-
-        byte data2[] = new byte[4];
-        startOffset = 0;
-        numBits = 32;
-        BitBufferHelper.insertBits(data2, inputdata, startOffset, numBits);
-        Assert.assertTrue(data2[0] == 75);
-        Assert.assertTrue(data2[1] == 110);
-        Assert.assertTrue(data2[2] == 107);
-        Assert.assertTrue(data2[3] == 80);
-
-        // INPUT: {75, 110, 107, 80, 10, 12, 35, 100, 125, 65} =
-        // [01001011] [01101110] [01101011] [10100000] [00001010] [00001100] [00100011] [01100100] [11111101] [01000001]        // OUTPUT: [01001011] [01101000] = {75, 104}
-        byte data10[] = new byte[2];
-        startOffset = 0;
-        numBits = 13;
-        BitBufferHelper.insertBits(data10, inputdata, startOffset, numBits);
-        Assert.assertTrue(data10[0] == 75);
-        Assert.assertTrue(data10[1] == 104);
-
-        // INPUT: {75, 110, 107, 80, 10, 12, 35, 100, 125, 65} =
-        // [01001011] [01101110] [01101011] [10100000] [00001010] [00001100] [00100011] [01100100] [11111101] [01000001]        // OUTPUT: [01001000] = {72}
-        byte data11[] = new byte[4];
-        startOffset = 8;
-        numBits = 6;
-        BitBufferHelper.insertBits(data11, inputdata, startOffset, numBits);
-        Assert.assertTrue(data11[1] == 72);
-
-        // INPUT: {75, 110, 107, 80, 10, 12, 35, 100, 125, 65} =
-        // [01001011] [01101110] [01101011] [10100000] [00001010] [00001100] [00100011] [01100100] [11111101] [01000001]        //OUTPUT: [01001011] [01101110] [01101000] = {75, 110, 105}
-        byte data12[] = new byte[4];
-        startOffset = 0;
-        numBits = 23;
-        BitBufferHelper.insertBits(data12, inputdata, startOffset, numBits);
-        Assert.assertTrue(data12[0] == 75);
-        Assert.assertTrue(data12[1] == 110);
-        Assert.assertTrue(data12[2] == 106);
-
-        // INPUT: {75, 110, 107, 80, 10, 12, 35, 100, 125, 65} =
-        // [01001011] [01101110] [01101011] [10100000] [00001010] [00001100] [00100011] [01100100] [11111101] [01000001]        //OUTPUT: [01001011] [01101110] [01100000] = {75, 110, 96}
-        byte data13[] = new byte[4];
-        startOffset = 8;
-        numBits = 20;
-        BitBufferHelper.insertBits(data13, inputdata, startOffset, numBits);
-        Assert.assertTrue(data13[1] == 75);
-        Assert.assertTrue(data13[2] == 110);
-        Assert.assertTrue(data13[3] == 96);
-
-        // INPUT: {75, 110, 107, 80, 10, 12, 35, 100, 125, 65} =
-        // [01001011] [01101110] [01101011] [10100000] [00001010] [00001100] [00100011] [01100100] [11111101] [01000001]        //OUTPUT: [01001011] [01101110] [01101011] [10100000]= {75, 110, 107, 80}
-        byte data14[] = new byte[4];
-        startOffset = 0;
-        numBits = 30;
-        BitBufferHelper.insertBits(data14, inputdata, startOffset, numBits);
-        Assert.assertTrue(data14[0] == 75);
-        Assert.assertTrue(data14[1] == 110);
-        Assert.assertTrue(data14[2] == 107);
-        Assert.assertTrue(data14[3] == 80);
-
-        //CASE 3: startOffset%8 != 0, numBits%8 = 0
-        // INPUT: {75, 110, 107, 80, 10, 12, 35, 100, 125, 65} =
-        // [01001011] [01101110] [01101011] [10100000] [00001010] [00001100] [00100011] [01100100] [11111101] [01000001]        //OUTPUT: [00001001] [11000000] = {72, 96}
-        byte data16[] = new byte[5];
-        startOffset = 3;
-        numBits = 8;
-        BitBufferHelper.insertBits(data16, inputdata, startOffset, numBits);
-        Assert.assertTrue(data16[0] == 9);
-        Assert.assertTrue(data16[1] == 96);
-        Assert.assertTrue(data16[2] == 0);
-
-        // INPUT: {75, 110, 107, 80, 10, 12, 35, 100, 125, 65} =
-        // [01001011] [01101110] [01101011] [01010000] [00001010] [00001100] [00100011] [01100100] [11111101] [01000001]        //OUTPUT: [00000000] [00000100] [10110110] [11100000]= {0, 4, -54, -96}
-        // OUTPUT: [00000100] [1011 0110] [1110 0000] = {4, -54, -96}
-
-        startOffset = 3;
-        numBits = 16;
-        byte data17[] = new byte[5];
-        BitBufferHelper.insertBits(data17, inputdata, startOffset, numBits);
-        Assert.assertTrue(data17[0] == 9);
-        Assert.assertTrue(data17[1] == 109);
-        Assert.assertTrue(data17[2] == -64);
-        Assert.assertTrue(data17[3] == 0);
-
-        // INPUT: {79, 110, 111}
-        // = [01001111] [01101110] [01101111]
-        //OUTPUT: [0000 1001] [1110 1101] [110 00000] = {9, -19, -64}
-        byte data18[] = new byte[5];
-        byte inputdata3[] = { 79, 110, 111 };
-        startOffset = 3;
-        numBits = 16;
-        BitBufferHelper.insertBits(data18, inputdata3, startOffset, numBits);
-        Assert.assertTrue(data18[0] == 9);
-        Assert.assertTrue(data18[1] == -19);
-        Assert.assertTrue(data18[2] == -64);
-
-        // INPUT: {75, 110, 107, 80, 10, 12, 35, 100, 125, 65} =
-        // [01001011] [01101110] [01101011] [01010000] [00001010] [00001100] [00100011] [01100100] [11111101] [01000001]        //OUTPUT: [00000000] [00000100] [10110110] [11100000]= {0, 4, -54, -96}
-        // OUTPUT: [0000 1001] [0110 1101] [1100 1101] [0110 1010] [0000 0001] = {9, 109, -51, 106, 0}
-
-        startOffset = 3;
-        numBits = 32;
-        byte data19[] = new byte[5];
-        BitBufferHelper.insertBits(data19, inputdata, startOffset, numBits);
-        Assert.assertTrue(data19[0] == 9);
-        Assert.assertTrue(data19[1] == 109);
-        Assert.assertTrue(data19[2] == -51);
-        Assert.assertTrue(data19[3] == 106);
-        Assert.assertTrue(data19[4] == 0);
-
-        // INPUT: {75, 110, 107, 80, 10, 12, 35, 100, 125, 65} =
-        // [01001011] [01101110] [01101011] [01010000] [00001010] [00001100] [00100011] [01100100] [11111101] [01000001]        //OUTPUT: [00000000] [00000100] [10110110] [11100000]= {0, 4, -54, -96}
-        // OUTPUT: data[4, 5, 6] = [0 010 0101] [1 011 0111] [0 000 0000] = {37, -73, 0}
-        startOffset = 33;
-        numBits = 16;
-        byte data20[] = new byte[7];
-        BitBufferHelper.insertBits(data20, inputdata, startOffset, numBits);
-        Assert.assertTrue(data20[4] == 37);
-        Assert.assertTrue(data20[5] == -73);
-        Assert.assertTrue(data20[6] == 0);
-
-        //CASE 4: extranumBits != 0 AND extraOffsetBits != 0
-        // INPUT: {75, 110, 107, 80, 10, 12, 35, 100, 125, 65} =
-        // [01001011] [01101110] [01101011] [01010000] [00001010] [00001100] [00100011] [01100100] [11111101] [01000001]        //OUTPUT: [00000000] [00000100] [10110110] [11100000]= {0, 4, -54, -96}
-        // OUTPUT: [0000 1001] [0100 0000]  = {9, 96}
-        startOffset = 3;
-        numBits = 7;
-        byte data21[] = new byte[7];
-        BitBufferHelper.insertBits(data21, inputdata, startOffset, numBits);
-        Assert.assertTrue(data21[0] == 9);
-        Assert.assertTrue(data21[1] == 64);
-        Assert.assertTrue(data21[2] == 0);
-
-        // INPUT: {75, 110, 107, 80, 10, 12, 35, 100, 125, 65} =
-        // [01001011] [01101110] [01101011] [01010000] [00001010] [00001100] [00100011] [01100100] [11111101] [01000001]        //OUTPUT: [00000000] [00000100] [10110110] [11100000]= {0, 4, -54, -96}
-        // OUTPUT: data = [00000 010] [01011 011] [01110 000] = {37, -73, 0}
-        startOffset = 5;
-        numBits = 17;
-        byte data22[] = new byte[7];
-        BitBufferHelper.insertBits(data22, inputdata, startOffset, numBits);
-        Assert.assertTrue(data22[0] == 2);
-        Assert.assertTrue(data22[1] == 91);
-        Assert.assertTrue(data22[2] == 112);
-
-        // INPUT: {75, 110, 107, 80, 10, 12, 35, 100, 125, 65} =
-        // [01001011] [01101110] [01101011] [01010000] [00001010] [00001100] [00100011] [01100100] [11111101] [01000001]        //OUTPUT: [00000000] [00000100] [10110110] [11100000]= {0, 4, -54, -96}
-        // OUTPUT: [0000 1001] [0110 1101] [110 01101] [01 00000] = {9, 109, -51, 64}
-        startOffset = 3;
-        numBits = 23;
-        byte data23[] = new byte[7];
-        BitBufferHelper.insertBits(data23, inputdata, startOffset, numBits);
-        Assert.assertTrue(data23[0] == 9);
-        Assert.assertTrue(data23[1] == 109);
-        Assert.assertTrue(data23[2] == -51);
-        Assert.assertTrue(data23[3] == 64);
-
-        // INPUT: {75, 110, 107, 80, 10, 12, 35, 100, 125, 65} =
-        // [01001011] [01101110] [01101011] [01010000] [00001010] [00001100] [00100011] [01100100] [11111101] [01000001]        //OUTPUT: [00000000] [00000100] [10110110] [11100000]= {0, 4, -54, -96}
-        // OUTPUT: [0000 1001] [0110 1101]  = {9, 109}
-        startOffset = 3;
-        numBits = 13;
-        byte data24[] = new byte[7];
-        BitBufferHelper.insertBits(data24, inputdata, startOffset, numBits);
-        Assert.assertTrue(data24[0] == 9);
-        Assert.assertTrue(data24[1] == 109);
-        Assert.assertTrue(data24[2] == 0);
-
-        // INPUT: {75, 110, 107, 80, 10, 12, 35, 100, 125, 65} =
-        // [01001011] [01101110] [01101011] [01010000] [00001010] [00001100] [00100011] [01100100] [11111101] [01000001]        //OUTPUT: [00000000] [00000100] [10110110] [11100000]= {0, 4, -54, -96}
-        // OUTPUT: [0000 0100] [1011 0110] [1110 0110]  = {4, -74, -26}
-        startOffset = 4;
-        numBits = 20;
-        byte data25[] = new byte[7];
-        BitBufferHelper.insertBits(data25, inputdata, startOffset, numBits);
-        Assert.assertTrue(data25[0] == 4);
-        Assert.assertTrue(data25[1] == -74);
-        Assert.assertTrue(data25[2] == -26);
-        Assert.assertTrue(data25[3] == -0);
-
-        // INPUT: {75, 110, 107, 80, 10, 12, 35, 100, 125, 65} =
-        // [01001011] [01101110] [01101011] [01010000] [00001010] [00001100] [00100011] [01100100] [11111101] [01000001]        //OUTPUT: [00000000] [00000100] [10110110] [11100000]= {0, 4, -54, -96}
-        // OUTPUT: [0000 0010] [0101 1011]   = {0, 2, 91, 0}
-        startOffset = 13;
-        numBits = 11;
-        byte data26[] = new byte[7];
-        BitBufferHelper.insertBits(data26, inputdata, startOffset, numBits);
-        Assert.assertTrue(data26[0] == 0);
-        Assert.assertTrue(data26[1] == 2);
-        Assert.assertTrue(data26[2] == 91);
-        Assert.assertTrue(data26[3] == 0);
-
-        // INPUT: {75, 110, 107, 80, 10, 12, 35, 100, 125, 65} =
-        // [01001011] [01101110] [01101011] [01010000] [00001010] [00001100] [00100011] [01100100] [11111101] [01000001]        //OUTPUT: [00000000] [00000100] [10110110] [11100000]= {0, 4, -54, -96}
-        // OUTPUT: [000 01001] [011 01101] [110 0 0000]   = {9, 109, -64, 0}
-        startOffset = 3;
-        numBits = 17;
-        byte data27[] = new byte[7];
-        BitBufferHelper.insertBits(data27, inputdata, startOffset, numBits);
-        Assert.assertTrue(data27[0] == 9);
-        Assert.assertTrue(data27[1] == 109);
-        Assert.assertTrue(data27[2] == -64);
-        Assert.assertTrue(data27[3] == 0);
-
-        // INPUT: {75, 110, 107, 80, 10, 12, 35, 100, 125, 65} =
-        // [01001011] [01101110] [01101011] [01010000] [00001010] [00001100] [00100011] [01100100] [11111101] [01000001]        //OUTPUT: [00000000] [00000100] [10110110] [11100000]= {0, 4, -54, -96}
-        // OUTPUT: [00 000000] [00 000000] [00 010010] [11 011011] [10 011010] [11 010100] [0000 0000] = {0, 0, 18, -37,-102,-44,0}
-        startOffset = 18;
-        numBits = 34;
-        byte data28[] = new byte[7];
-        BitBufferHelper.insertBits(data28, inputdata, startOffset, numBits);
-        Assert.assertTrue(data28[0] == 0);
-        Assert.assertTrue(data28[1] == 0);
-        Assert.assertTrue(data28[2] == 18);
-        Assert.assertTrue(data28[3] == -37);
-        Assert.assertTrue(data28[4] == -102);
-        Assert.assertTrue(data28[5] == -44);
-        Assert.assertTrue(data28[6] == 0);
-
-    }
-
-    @Test
-    public void testGetShort() throws Exception {
-        byte data[] = new byte[2];
-        data[0] = 7;
-        data[1] = 8;
-        int length = 9; // num bits
-        Assert.assertTrue(BitBufferHelper.getShort(data, length) == 264);
-
-        data[0] = 6;
-        data[1] = 8;
-        short result = BitBufferHelper.getShort(data, length);
-        Assert.assertTrue(result == 8);
-
-        data[0] = 8;
-        data[1] = 47;
-        result = BitBufferHelper.getShort(data, length);
-        Assert.assertTrue(result == 47);
-
-        //[0000 0001] [0001 0100] [0110 0100]
-        byte[] data1 = new byte[2];
-        data1[0] = 1;
-        data1[1] = 20; //data1[2] = 100;
-        length = 15;
-        result = BitBufferHelper.getShort(data1, length);
-        Assert.assertTrue(result == 276);
-
-        byte[] data2 = new byte[2];
-        data2[0] = 64;
-        data2[1] = 99; //data2[2] = 100;
-        length = 13;
-        result = BitBufferHelper.getShort(data2, length);
-        Assert.assertTrue(result == 99);
-
-        byte[] data3 = { 100, 50 };
-        result = BitBufferHelper.getShort(data3);
-        Assert.assertTrue(result == 25650);
-    }
-
-    @Test
-    public void testToIntVarLength() throws Exception {
-        byte data[] = { (byte) 255, (byte) 128 };
-        int length = 9; // num bits
-        Assert.assertTrue(BitBufferHelper.getInt(data, length) == 384);
-
-        byte data2[] = { 0, 8 };
-        Assert.assertTrue(BitBufferHelper.getInt(data2, 9) == 8);
-
-        byte data3[] = { 1, 1, 1 };
-        Assert.assertTrue(BitBufferHelper.getInt(data3) == 65793);
-
-        byte data4[] = { 1, 1, 1 };
-        Assert.assertTrue(BitBufferHelper.getInt(data4) == 65793);
-
-        byte data5[] = { 1, 1 };
-        Assert.assertTrue(BitBufferHelper.getInt(data5) == 257);
-
-    }
-
-    @Test
-    public void testShiftBitstoLSB() {
-        byte[] data = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };
-
-        byte[] data2 = { 8, 9, 10 };
-        byte[] shiftedBytes2 = BitBufferHelper.shiftBitsToLSB(data2, 11);
-
-        Assert.assertTrue(shiftedBytes2[0] == 0);
-        Assert.assertTrue(shiftedBytes2[1] == 64);
-        Assert.assertTrue(shiftedBytes2[2] == 72);
-
-        byte[] shiftedBytes = BitBufferHelper.shiftBitsToLSB(data, 49);
-
-        Assert.assertTrue(shiftedBytes[0] == 0);
-        Assert.assertTrue(shiftedBytes[1] == 2);
-        Assert.assertTrue(shiftedBytes[2] == 4);
-        Assert.assertTrue(shiftedBytes[3] == 6);
-        Assert.assertTrue(shiftedBytes[4] == 8);
-        Assert.assertTrue(shiftedBytes[5] == 10);
-        Assert.assertTrue(shiftedBytes[6] == 12);
-        Assert.assertTrue(shiftedBytes[7] == 14);
-        Assert.assertTrue(shiftedBytes[8] == 16);
-        Assert.assertTrue(shiftedBytes[9] == 18);
-
-        byte[] data1 = { 1, 2, 3 };
-        byte[] shiftedBytes1 = BitBufferHelper.shiftBitsToLSB(data1, 18);
-        Assert.assertTrue(shiftedBytes1[0] == 0);
-        Assert.assertTrue(shiftedBytes1[1] == 4);
-        Assert.assertTrue(shiftedBytes1[2] == 8);
-
-    }
-
-    @Test
-    public void testShiftBitstoLSBMSB() {
-        byte[] data = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 0 };
-
-        byte[] clone = BitBufferHelper.shiftBitsToMSB(BitBufferHelper
-                .shiftBitsToLSB(data, 72), 72);
-
-        Assert.assertTrue(clone[0] == 1);
-        Assert.assertTrue(clone[1] == 2);
-        Assert.assertTrue(clone[2] == 3);
-        Assert.assertTrue(clone[3] == 4);
-        Assert.assertTrue(clone[4] == 5);
-        Assert.assertTrue(clone[5] == 6);
-        Assert.assertTrue(clone[6] == 7);
-        Assert.assertTrue(clone[7] == 8);
-        Assert.assertTrue(clone[8] == 9);
-        Assert.assertTrue(clone[9] == 0);
-    }
-
-}
diff --git a/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/packet/EthernetTest.java b/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/packet/EthernetTest.java
deleted file mode 100644 (file)
index 5176bd6..0000000
+++ /dev/null
@@ -1,121 +0,0 @@
-
-/*
- * Copyright (c) 2013-2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.packet;
-
-import java.util.Arrays;
-
-import org.junit.Assert;
-
-import org.junit.Test;
-import org.opendaylight.controller.sal.match.Match;
-import org.opendaylight.controller.sal.match.MatchType;
-import org.opendaylight.controller.sal.utils.EtherTypes;
-
-public class EthernetTest {
-
-    @Test
-    public void testGetDestinationMACAddress() {
-        Ethernet eth = new Ethernet();
-        byte mac[] = { 10, 12, 14, 20, 55, 69 };
-        eth.hdrFieldsMap.put("DestinationMACAddress", mac);
-        byte[] dMAC = eth.getDestinationMACAddress();
-        Assert.assertTrue(dMAC[0] == 10);
-        Assert.assertTrue(dMAC[1] == 12);
-        Assert.assertTrue(dMAC[2] == 14);
-        Assert.assertTrue(dMAC[3] == 20);
-        Assert.assertTrue(dMAC[4] == 55);
-        Assert.assertTrue(dMAC[5] == 69);
-
-    }
-
-    @Test
-    public void testSourceMACAddress() {
-        Ethernet eth = new Ethernet();
-        byte mac[] = { 120, 30, 25, 80, 66, 99 };
-        eth.hdrFieldsMap.put("SourceMACAddress", mac);
-        byte[] sMAC = eth.getSourceMACAddress();
-        Assert.assertTrue(sMAC[0] == 120);
-        Assert.assertTrue(sMAC[1] == 30);
-        Assert.assertTrue(sMAC[2] == 25);
-        Assert.assertTrue(sMAC[3] == 80);
-        Assert.assertTrue(sMAC[4] == 66);
-        Assert.assertTrue(sMAC[5] == 99);
-
-    }
-
-    @Test
-    public void testGetEthertype() throws Exception {
-        Ethernet eth = new Ethernet();
-        byte ethType[] = { 8, 6 };
-        eth.hdrFieldsMap.put("EtherType", ethType);
-        short etherType = eth.getEtherType();
-        Assert.assertTrue(etherType == 2054);
-    }
-
-    @Test
-    public void testSetDestinationMACAddress() {
-        Ethernet eth = new Ethernet();
-        byte mac[] = { 10, 12, 14, 20, 55, 69 };
-        eth.setDestinationMACAddress(mac);
-        byte[] dMAC = eth.hdrFieldsMap.get("DestinationMACAddress");
-        Assert.assertTrue(dMAC[0] == 10);
-        Assert.assertTrue(dMAC[1] == 12);
-        Assert.assertTrue(dMAC[2] == 14);
-        Assert.assertTrue(dMAC[3] == 20);
-        Assert.assertTrue(dMAC[4] == 55);
-        Assert.assertTrue(dMAC[5] == 69);
-
-    }
-
-    @Test
-    public void testSetSourceMACAddress() {
-        Ethernet eth = new Ethernet();
-        byte mac[] = { 120, 30, 25, 80, 66, 99 };
-        eth.setSourceMACAddress(mac);
-        byte[] sMAC = eth.hdrFieldsMap.get("SourceMACAddress");
-        Assert.assertTrue(sMAC[0] == 120);
-        Assert.assertTrue(sMAC[1] == 30);
-        Assert.assertTrue(sMAC[2] == 25);
-        Assert.assertTrue(sMAC[3] == 80);
-        Assert.assertTrue(sMAC[4] == 66);
-        Assert.assertTrue(sMAC[5] == 99);
-
-    }
-
-    @Test
-    public void testSetEthertype() throws Exception {
-        Ethernet eth = new Ethernet();
-        short ethType = 2054;
-        eth.setEtherType(ethType);
-        byte[] etherType = eth.hdrFieldsMap.get("EtherType");
-        Assert.assertTrue(etherType[0] == 8);
-        Assert.assertTrue(etherType[1] == 6);
-
-    }
-
-    @Test
-    public void testGetMatch() throws Exception {
-        Ethernet eth = new Ethernet();
-        byte smac[] = { (byte) 0xf0, (byte) 0xde, (byte) 0xf1, (byte) 0x71, (byte) 0x72, (byte) 0x8d };
-        byte dmac[] = { (byte) 0xde, (byte) 0x28, (byte) 0xdb, (byte) 0xb3, (byte) 0x7c, (byte) 0xf8 };
-        short ethType = EtherTypes.IPv4.shortValue();
-        eth.setDestinationMACAddress(dmac);
-        eth.setSourceMACAddress(smac);
-        eth.setEtherType(ethType);
-
-        Match match = eth.getMatch();
-
-        Assert.assertTrue(Arrays.equals(smac, (byte[]) match.getField(MatchType.DL_SRC).getValue()));
-        Assert.assertTrue(Arrays.equals(dmac, (byte[]) match.getField(MatchType.DL_DST).getValue()));
-        Assert.assertEquals(ethType, (short) match.getField(MatchType.DL_TYPE).getValue());
-
-    }
-
-}
diff --git a/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/packet/ICMPTest.java b/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/packet/ICMPTest.java
deleted file mode 100644 (file)
index f591fb1..0000000
+++ /dev/null
@@ -1,133 +0,0 @@
-
-/*
- * Copyright (c) 2013-2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.packet;
-
-import java.util.Arrays;
-
-import org.junit.Assert;
-
-import org.junit.Test;
-
-public class ICMPTest {
-
-    @Test
-    public void testSetTypeCode() {
-        ICMP icmp = new ICMP();
-        byte icmpType = 2;
-        icmp.setType(icmpType);
-        byte[] typeCode = icmp.hdrFieldsMap.get("Type");
-        Assert.assertTrue(typeCode[0] == 2);
-
-    }
-
-    @Test
-    public void testSetChecksum() {
-        ICMP icmp = new ICMP();
-        short icmpChecksum = 200;
-        icmp.setChecksum(icmpChecksum);
-        byte[] checksum = icmp.hdrFieldsMap.get("Checksum");
-        Assert.assertTrue(checksum[0] == 0);
-        Assert.assertTrue(checksum[1] == -56);
-
-    }
-
-    @Test
-    public void testSetIdentifier() {
-        ICMP icmp = new ICMP();
-        short icmpIdentifier = 1201;
-        icmp.setIdentifier(icmpIdentifier);
-        byte[] identifier = icmp.hdrFieldsMap.get("Identifier");
-        Assert.assertTrue(identifier[0] == 4);
-        Assert.assertTrue(identifier[1] == -79);
-
-    }
-
-    @Test
-    public void testSetSequenceNumber() {
-        ICMP icmp = new ICMP();
-        short icmpSequenceNumber = 5000;
-        icmp.setSequenceNumber(icmpSequenceNumber);
-        byte[] sequenceNumber = icmp.hdrFieldsMap.get("SequenceNumber");
-        Assert.assertTrue(sequenceNumber[0] == 19);
-        Assert.assertTrue(sequenceNumber[1] == -120);
-
-    }
-
-    @Test
-    public void testSerialization() throws PacketException {
-        byte icmpRawPayload[] = { (byte) 0x38, (byte) 0x26, (byte) 0x9e,
-                (byte) 0x51, (byte) 0x00, (byte) 0x00, (byte) 0x00,
-                (byte) 0x00, (byte) 0x2e, (byte) 0x6a, (byte) 0x08,
-                (byte) 0x00, (byte) 0x00, (byte) 0x00, (byte) 0x00,
-                (byte) 0x00, (byte) 0x10, (byte) 0x11, (byte) 0x12,
-                (byte) 0x13, (byte) 0x14, (byte) 0x15, (byte) 0x16,
-                (byte) 0x17, (byte) 0x18, (byte) 0x19, (byte) 0x1a,
-                (byte) 0x1b, (byte) 0x1c, (byte) 0x1d, (byte) 0x1e,
-                (byte) 0x1f, (byte) 0x20, (byte) 0x21, (byte) 0x22,
-                (byte) 0x23, (byte) 0x24, (byte) 0x25, (byte) 0x26,
-                (byte) 0x27, (byte) 0x28, (byte) 0x29, (byte) 0x2a,
-                (byte) 0x2b, (byte) 0x2c, (byte) 0x2d, (byte) 0x2e,
-                (byte) 0x2f, (byte) 0x30, (byte) 0x31, (byte) 0x32,
-                (byte) 0x33, (byte) 0x34, (byte) 0x35, (byte) 0x36, (byte) 0x37 };
-        serializeTest(icmpRawPayload, (short)0xe553);
-
-        serializeTest(null, (short)0xb108);
-        serializeTest(new byte[0], (short)0xb108);
-
-        byte[] odd = {
-            (byte)0xba, (byte)0xd4, (byte)0xc7, (byte)0x53,
-            (byte)0xf8, (byte)0x59, (byte)0x68, (byte)0x77,
-            (byte)0xfd, (byte)0x27, (byte)0xe0, (byte)0x5b,
-            (byte)0xd0, (byte)0x2e, (byte)0x28, (byte)0x41,
-            (byte)0xa3, (byte)0x48, (byte)0x5d, (byte)0x2e,
-            (byte)0x7d, (byte)0x5b, (byte)0xd3, (byte)0x60,
-            (byte)0xb3, (byte)0x88, (byte)0x8d, (byte)0x0f,
-            (byte)0x1d, (byte)0x87, (byte)0x51, (byte)0x0f,
-            (byte)0x6a, (byte)0xff, (byte)0xf7, (byte)0xd4,
-            (byte)0x40, (byte)0x35, (byte)0x4e, (byte)0x01,
-            (byte)0x36,
-        };
-        serializeTest(odd, (short)0xd0ad);
-
-        // Large payload that causes 16-bit checksum overflow more than
-        // 255 times.
-        byte[] largeEven = new byte[1024];
-        Arrays.fill(largeEven, (byte)0xff);
-        serializeTest(largeEven, (short)0xb108);
-
-        byte[] largeOdd = new byte[1021];
-        Arrays.fill(largeOdd, (byte)0xff);
-        serializeTest(largeOdd, (short)0xb207);
-    }
-
-    private void serializeTest(byte[] payload, short checksum)
-        throws PacketException {
-        ICMP icmp = new ICMP();
-        icmp.setType((byte)8).setCode((byte)0).
-            setIdentifier((short)0x46f5).setSequenceNumber((short)2);
-        int payloadSize = 0;
-        if (payload != null) {
-            icmp.setRawPayload(payload);
-            payloadSize = payload.length;
-        }
-
-        // Serialize
-        byte[] data = icmp.serialize();
-        Assert.assertEquals(payloadSize + 8, data.length);
-
-        // Deserialize
-        ICMP icmpDes = new ICMP();
-        icmpDes.deserialize(data, 0, data.length);
-
-        Assert.assertFalse(icmpDes.isCorrupted());
-        Assert.assertEquals(checksum, icmpDes.getChecksum());
-        Assert.assertEquals(icmp, icmpDes);
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/packet/IEEE8021QTest.java b/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/packet/IEEE8021QTest.java
deleted file mode 100644 (file)
index 99da52a..0000000
+++ /dev/null
@@ -1,236 +0,0 @@
-/*
- * Copyright (c) 2013-2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.packet;
-
-import org.junit.Assert;
-
-import org.junit.Test;
-import org.opendaylight.controller.sal.match.Match;
-import org.opendaylight.controller.sal.match.MatchType;
-import org.opendaylight.controller.sal.utils.EtherTypes;
-import org.opendaylight.controller.sal.utils.NetUtils;
-
-public class IEEE8021QTest {
-
-    @Test
-    public void testGetPcp() throws Exception {
-        IEEE8021Q vlan = new IEEE8021Q();
-        byte pcp[] = { 5 };
-        vlan.hdrFieldsMap.put("PriorityCodePoint", pcp);
-        byte spcp = vlan.getPcp();
-        Assert.assertTrue(spcp == 5);
-    }
-
-    @Test
-    public void testGetCfi() throws Exception {
-        IEEE8021Q vlan = new IEEE8021Q();
-        byte cfi[] = { 0 };
-        vlan.hdrFieldsMap.put("CanonicalFormatIndicator", cfi);
-        byte scfi = vlan.getCfi();
-        Assert.assertTrue(scfi == 0);
-    }
-
-    @Test
-    public void testGetVid() throws Exception {
-        IEEE8021Q vlan = new IEEE8021Q();
-        byte vid[] = { (byte) 0xF, (byte) 0xFE }; // 4094
-        vlan.hdrFieldsMap.put("VlanIdentifier", vid);
-        short svid = vlan.getVid();
-        Assert.assertTrue(svid == 4094);
-    }
-
-    @Test
-    public void testGetEthertype() throws Exception {
-        IEEE8021Q vlan = new IEEE8021Q();
-        byte ethType[] = { 8, 6 };
-        vlan.hdrFieldsMap.put("EtherType", ethType);
-        short etherType = vlan.getEtherType();
-        Assert.assertTrue(etherType == 2054);
-    }
-
-    @Test
-    public void testSetPcp() throws Exception {
-        IEEE8021Q vlan = new IEEE8021Q();
-        byte pcp = 5;
-        vlan.setPcp(pcp);
-        byte[] bpcp = vlan.hdrFieldsMap.get("PriorityCodePoint");
-        Assert.assertTrue(bpcp[0] == 5);
-    }
-
-    @Test
-    public void testSetCfi() throws Exception {
-        IEEE8021Q vlan = new IEEE8021Q();
-        byte cfi = 0;
-        vlan.setCfi(cfi);
-        byte[] bcfi = vlan.hdrFieldsMap.get("CanonicalFormatIndicator");
-        Assert.assertTrue(bcfi[0] == 0);
-    }
-
-    @Test
-    public void testSetVid() throws Exception {
-        IEEE8021Q vlan = new IEEE8021Q();
-        short vid = 4094; // 0xFFE
-        vlan.setVid(vid);
-        byte[] bvid = vlan.hdrFieldsMap.get("VlanIdentifier");
-        Assert.assertTrue(bvid[0] == (byte) 0xF);
-        Assert.assertTrue(bvid[1] == (byte) 0xFE);
-    }
-
-    @Test
-    public void testSetEthertype() throws Exception {
-        Ethernet eth = new Ethernet();
-        short ethType = 2054; // 0x806
-        eth.setEtherType(ethType);
-        byte[] etherType = eth.hdrFieldsMap.get("EtherType");
-        Assert.assertTrue(etherType[0] == 8);
-        Assert.assertTrue(etherType[1] == 6);
-    }
-
-    @Test
-    public void testDeserialize() throws Exception {
-        short startOffset, numBits;
-        Ethernet eth = new Ethernet();
-        byte[] data = {
-                (byte) 0xA, (byte) 0xC, (byte) 0xE, (byte) 0x14, (byte) 0x37, (byte) 0x45, // Destination MAC
-                (byte) 0xA6, (byte) 0xEC, (byte) 0x9C, (byte) 0xAE, (byte) 0xB2, (byte) 0x9F, // Source MAC
-                (byte) 0x81, (byte) 0x00, // EtherType
-                (byte) 0xAF, (byte) 0xFE, // PCP, CFI, VLAN ID
-                8, 6, // EtherType
-                0, 1, // Hardware Type
-                8, 0, // Protocol Type
-                6, // Hardware Address Length
-                4, // Protocol Address Length
-                0, 1, // opCode
-                (byte) 0xA6, (byte) 0xEC, (byte) 0x9C, (byte) 0xAE, (byte) 0xB2, (byte) 0x9F, // Sender Hardware Address
-                (byte) 0x9, (byte) 0x9, (byte) 0x9, (byte) 0x1, // Sender Protocol Address
-                (byte) 0x0, (byte) 0x0, (byte) 0x0, (byte) 0x0, (byte) 0x0, (byte) 0x0, // Target Hardware Address
-                (byte) 0x9, (byte) 0x9, (byte) 0x9, (byte) 0xFE }; // Target Protocol Address
-
-        startOffset = 0;
-        numBits = (short) (data.length * 8);
-        eth.deserialize(data, startOffset, numBits);
-
-        short etherType = eth.getEtherType();
-        Assert.assertTrue(NetUtils.getUnsignedShort(etherType) == 0x8100);
-
-        IEEE8021Q vlanPacket = (IEEE8021Q) eth.getPayload();
-        Assert.assertTrue(vlanPacket.getCfi() == 0);
-        Assert.assertTrue(vlanPacket.getPcp() == 5);
-        Assert.assertTrue(vlanPacket.getVid() == 4094);
-        Assert.assertTrue(vlanPacket.getEtherType() == 2054); // 0x806
-
-        Packet arpPkt = (vlanPacket).getPayload();
-        Assert.assertTrue(arpPkt instanceof ARP);
-    }
-
-    @Test
-    public void testSerialize() throws Exception {
-        Ethernet eth = new Ethernet();
-
-        byte[] dMac = { (byte) 0xA, (byte) 0xC, (byte) 0xE, (byte) 0x14, (byte) 0x37, (byte) 0x45 };
-        byte[] sMac = { (byte) 0xA6, (byte) 0xEC, (byte) 0x9C, (byte) 0xAE, (byte) 0xB2, (byte) 0x9F };
-        eth.setDestinationMACAddress(dMac);
-        eth.setSourceMACAddress(sMac);
-        eth.setEtherType((short) 33024);
-
-        IEEE8021Q vlan = new IEEE8021Q();
-        vlan.setCfi((byte) 0x0);
-        vlan.setPcp((byte) 0x5);
-        vlan.setVid((short) 4094);
-        vlan.setEtherType((short) 2054);
-
-        vlan.setParent(eth);
-        eth.setPayload(vlan);
-
-        ARP arp = new ARP();
-        arp.setHardwareType((short) 1);
-        arp.setProtocolType((short) 2048);
-        arp.setHardwareAddressLength((byte) 0x6);
-        arp.setProtocolAddressLength((byte) 0x4);
-        arp.setOpCode((byte) 0x1);
-
-        byte[] senderHardwareAddress = { (byte) 0xA6, (byte) 0xEC, (byte) 0x9C, (byte) 0xAE, (byte) 0xB2, (byte) 0x9F };
-        byte[] senderProtocolAddress = { (byte) 0x9, (byte) 0x9, (byte) 0x9, (byte) 0x1 };
-        byte[] targetProtocolAddress = { (byte) 0x9, (byte) 0x9, (byte) 0x9, (byte) 0xFE };
-        byte[] targetHardwareAddress = { (byte) 0x0, (byte) 0x0, (byte) 0x0, (byte) 0x0, (byte) 0x0, (byte) 0x0 };
-        arp.setSenderHardwareAddress(senderHardwareAddress);
-        arp.setSenderProtocolAddress(senderProtocolAddress);
-        arp.setTargetHardwareAddress(targetHardwareAddress);
-        arp.setTargetProtocolAddress(targetProtocolAddress);
-
-        arp.setParent(vlan);
-        vlan.setPayload(arp);
-
-        byte[] data = eth.serialize();
-
-        Assert.assertTrue(data[0] == (byte) 0x0A); // Destination MAC
-        Assert.assertTrue(data[1] == (byte) 0x0C);
-        Assert.assertTrue(data[2] == (byte) 0x0E);
-        Assert.assertTrue(data[3] == (byte) 0x14);
-        Assert.assertTrue(data[4] == (byte) 0x37);
-        Assert.assertTrue(data[5] == (byte) 0x45);
-        Assert.assertTrue(data[6] == (byte) 0xA6); // Source MAC
-        Assert.assertTrue(data[7] == (byte) 0xEC);
-        Assert.assertTrue(data[8] == (byte) 0x9C);
-        Assert.assertTrue(data[9] == (byte) 0xAE);
-        Assert.assertTrue(data[10] == (byte) 0xB2);
-        Assert.assertTrue(data[11] == (byte) 0x9F);
-        Assert.assertTrue(data[12] == (byte) 0x81); // EtherType
-        Assert.assertTrue(data[13] == (byte) 0x00);
-        Assert.assertTrue(data[14] == (byte) 0xAF); // PCP, CFI, VLAN ID
-        Assert.assertTrue(data[15] == (byte) 0xFE);
-        Assert.assertTrue(data[16] == (byte) 0x08); // EtherType
-        Assert.assertTrue(data[17] == (byte) 0x06);
-        Assert.assertTrue(data[18] == (byte) 0x00); // Hardware Type
-        Assert.assertTrue(data[19] == (byte) 0x01);
-        Assert.assertTrue(data[20] == (byte) 0x08); // Protocol Type
-        Assert.assertTrue(data[21] == (byte) 0x0);
-        Assert.assertTrue(data[22] == (byte) 0x6); // Hardware Address Length
-        Assert.assertTrue(data[23] == (byte) 0x4); // Protocol Address Length
-        Assert.assertTrue(data[24] == (byte) 0x0); // opCode
-        Assert.assertTrue(data[25] == (byte) 0x1); // opCode
-        Assert.assertTrue(data[26] == (byte) 0xA6); // Source MAC
-        Assert.assertTrue(data[27] == (byte) 0xEC);
-        Assert.assertTrue(data[28] == (byte) 0x9C);
-        Assert.assertTrue(data[29] == (byte) 0xAE);
-        Assert.assertTrue(data[30] == (byte) 0xB2);
-        Assert.assertTrue(data[31] == (byte) 0x9F);
-        Assert.assertTrue(data[32] == (byte) 0x09); // Sender Protocol Address
-        Assert.assertTrue(data[33] == (byte) 0x09);
-        Assert.assertTrue(data[34] == (byte) 0x09);
-        Assert.assertTrue(data[35] == (byte) 0x01); // Target Hardware Address
-        Assert.assertTrue(data[36] == (byte) 0x00);
-        Assert.assertTrue(data[37] == (byte) 0x00);
-        Assert.assertTrue(data[38] == (byte) 0x00);
-        Assert.assertTrue(data[39] == (byte) 0x00);
-        Assert.assertTrue(data[40] == (byte) 0x00);
-        Assert.assertTrue(data[41] == (byte) 0x00);
-        Assert.assertTrue(data[42] == (byte) 0x09); // Target Protocol Address
-        Assert.assertTrue(data[43] == (byte) 0x09);
-        Assert.assertTrue(data[44] == (byte) 0x09);
-        Assert.assertTrue(data[45] == (byte) 0xFE);
-    }
-
-    @Test
-    public void testGetMatchFullPacket() throws Exception {
-        IEEE8021Q dot1q = new IEEE8021Q();
-        byte priority = 4;
-        short vlanId = 59;
-        short ethType = EtherTypes.IPv4.shortValue();
-        dot1q.setPcp(priority);
-        dot1q.setVid(vlanId);
-        dot1q.setEtherType(ethType);
-
-        Match match = dot1q.getMatch();
-
-        Assert.assertEquals(priority, (byte) match.getField(MatchType.DL_VLAN_PR).getValue());
-        Assert.assertEquals(vlanId, (short) match.getField(MatchType.DL_VLAN).getValue());
-        Assert.assertEquals(ethType, (short) match.getField(MatchType.DL_TYPE).getValue());
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/packet/IPv4Test.java b/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/packet/IPv4Test.java
deleted file mode 100644 (file)
index b983428..0000000
+++ /dev/null
@@ -1,680 +0,0 @@
-/*
- * Copyright (c) 2013-2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.packet;
-
-import java.net.InetAddress;
-import java.net.UnknownHostException;
-import java.util.Arrays;
-
-import org.junit.Assert;
-import org.junit.Test;
-
-import org.opendaylight.controller.sal.match.Match;
-import org.opendaylight.controller.sal.match.MatchType;
-import org.opendaylight.controller.sal.utils.EtherTypes;
-import org.opendaylight.controller.sal.utils.IPProtocols;
-import org.opendaylight.controller.sal.utils.NetUtils;
-
-public class IPv4Test {
-
-    @Test
-    public void testGetVersion() {
-        IPv4 ip = new IPv4();
-        byte[] ipVersion = { (byte) 4 };
-        ip.hdrFieldsMap.put("Version", ipVersion);
-        byte version = ip.getVersion();
-        Assert.assertTrue(version == (byte) 4);
-    }
-
-    @Test
-    public void testGetHeaderLength() {
-        IPv4 ip = new IPv4();
-        byte[] ipHeaderLength = { 5 };
-        ip.hdrFieldsMap.put("HeaderLength", ipHeaderLength);
-        byte headerLength = (byte) ip.getHeaderLen();
-        Assert.assertTrue(headerLength == 20);
-    }
-
-    @Test
-    public void testGetDiffServ() {
-        IPv4 ip = new IPv4();
-        byte[] ipDiffServ = { 20 };
-        ip.hdrFieldsMap.put("DiffServ", ipDiffServ);
-        byte diffServ = ip.getDiffServ();
-        Assert.assertTrue(diffServ == 20);
-    }
-
-    @Test
-    public void testGetTotalLength() {
-        IPv4 ip = new IPv4();
-        byte[] iptotLength = { 3, -24 };
-        ip.hdrFieldsMap.put("TotalLength", iptotLength);
-        short totalLength = ip.getTotalLength();
-        Assert.assertTrue(totalLength == 1000);
-    }
-
-    @Test
-    public void testGetIdentification() {
-        IPv4 ip = new IPv4();
-        byte[] ipIdentification = { 7, -48 };
-        ip.hdrFieldsMap.put("Identification", ipIdentification);
-        short identification = ip.getIdentification();
-        Assert.assertTrue(identification == 2000);
-    }
-
-    @Test
-    public void testGetFlags() {
-        IPv4 ip = new IPv4();
-        byte[] ipFlags = { 7 };
-        ip.hdrFieldsMap.put("Flags", ipFlags);
-        byte flags = ip.getFlags();
-        Assert.assertTrue(flags == 7);
-    }
-
-    @Test
-    public void testGetTtl() {
-        IPv4 ip = new IPv4();
-        byte[] ipTtl = { 100 };
-        ip.hdrFieldsMap.put("TTL", ipTtl);
-        byte ttl = ip.getTtl();
-        Assert.assertTrue(ttl == 100);
-    }
-
-    @Test
-    public void testGetProtocol() {
-        IPv4 ip = new IPv4();
-        byte[] ipProtocol = { 1 };
-        ip.hdrFieldsMap.put("Protocol", ipProtocol);
-        byte protocol = ip.getProtocol();
-        Assert.assertTrue(protocol == 1);
-
-        Class<? extends Packet> clazz = IPv4.protocolClassMap.get(protocol);
-        Assert.assertTrue(clazz == ICMP.class);
-    }
-
-    @Test
-    public void testGetFragmentOffset() {
-        IPv4 ip = new IPv4();
-        byte[] ipFragmentOffset = { 6, -35 };
-        ip.hdrFieldsMap.put("FragmentOffset", ipFragmentOffset);
-        short fragmentOffset = ip.getFragmentOffset();
-        Assert.assertTrue(fragmentOffset == 1757);
-    }
-
-    @Test
-    public void testGetSourceAddress() {
-        IPv4 ip = new IPv4();
-        byte[] ipSourceAddress = { 10, 110, 31, 55 };
-        ip.hdrFieldsMap.put("SourceIPAddress", ipSourceAddress);
-        int sourceAddress = ip.getSourceAddress();
-        Assert.assertTrue(sourceAddress == 174989111);
-    }
-
-    @Test
-    public void testGetDestinationAddress() {
-        IPv4 ip = new IPv4();
-        byte[] ipDestinationAddress = { 20, 55, 62, 110 };
-        ip.hdrFieldsMap.put("DestinationIPAddress", ipDestinationAddress);
-        int destinationAddress = ip.getDestinationAddress();
-        Assert.assertTrue(destinationAddress == 339164782);
-    }
-
-    @Test
-    public void testSetVersion() {
-        IPv4 ip = new IPv4();
-        byte ipVersion = (byte) 4;
-        ip.setVersion(ipVersion);
-        byte[] version = ip.hdrFieldsMap.get("Version");
-        Assert.assertTrue(version[0] == (byte) 4);
-    }
-
-    @Test
-    public void testSetHeaderLength() {
-        IPv4 ip = new IPv4();
-        byte ipHeaderLength = 5;
-        ip.setHeaderLength(ipHeaderLength);
-        byte[] headerLength = ip.hdrFieldsMap.get("HeaderLength");
-        Assert.assertTrue(headerLength[0] == 5);
-    }
-
-    @Test
-    public void testSetDiffServ() {
-        IPv4 ip = new IPv4();
-        byte ipDiffServ = 20;
-        ip.setDiffServ(ipDiffServ);
-        byte[] diffServ = ip.hdrFieldsMap.get("DiffServ");
-        Assert.assertTrue(diffServ[0] == 20);
-    }
-
-    @Test
-    public void testSetTotalLength() {
-        IPv4 ip = new IPv4();
-        short iptotLength = 1000;
-        ip.setTotalLength(iptotLength);
-        byte[] totalLength = ip.hdrFieldsMap.get("TotalLength");
-        Assert.assertTrue(totalLength[0] == 3);
-        Assert.assertTrue(totalLength[1] == -24);
-
-        ip.setTotalLength((short)84);
-        totalLength = ip.hdrFieldsMap.get("TotalLength");
-        Assert.assertTrue(totalLength[0] == 0);
-        Assert.assertTrue(totalLength[1] == 84);
-    }
-
-    @Test
-    public void testSetIdentification() {
-        IPv4 ip = new IPv4();
-        short ipIdentification = 2000;
-        ip.setIdentification(ipIdentification);
-        byte[] identification = ip.hdrFieldsMap.get("Identification");
-        Assert.assertTrue(identification[0] == 7);
-        Assert.assertTrue(identification[1] == -48);
-    }
-
-    @Test
-    public void testSetFlags() {
-        IPv4 ip = new IPv4();
-        byte ipFlags = 7;
-        ip.setFlags(ipFlags);
-        byte[] flags = ip.hdrFieldsMap.get("Flags");
-        Assert.assertTrue(flags[0] == 7);
-    }
-
-    @Test
-    public void testSetTtl() {
-        IPv4 ip = new IPv4();
-        byte ipTtl = 100;
-        ip.setTtl(ipTtl);
-        byte[] ttl = ip.hdrFieldsMap.get("TTL");
-        Assert.assertTrue(ttl[0] == 100);
-    }
-
-    @Test
-    public void testSetProtocol() {
-        IPv4 ip = new IPv4();
-        byte ipProtocol = 11;
-        ip.setProtocol(ipProtocol);
-        byte[] protocol = ip.hdrFieldsMap.get("Protocol");
-        Assert.assertTrue(protocol[0] == 11);
-    }
-
-    @Test
-    public void testSetFragmentOffset() {
-        IPv4 ip = new IPv4();
-        short ipFragmentOffset = 1757;
-        ip.setFragmentOffset(ipFragmentOffset);
-        byte[] fragmentOffset = ip.hdrFieldsMap.get("FragmentOffset");
-        Assert.assertTrue(fragmentOffset[0] == 6);
-        Assert.assertTrue(fragmentOffset[1] == -35);
-    }
-
-    @Test
-    public void testSetDestinationAddress() {
-        IPv4 ip = new IPv4();
-        int ipDestinationAddress = 339164782;
-        ip.setDestinationAddress(ipDestinationAddress);
-        byte[] destinationAddress = ip.hdrFieldsMap.get("DestinationIPAddress");
-        Assert.assertTrue(destinationAddress[0] == 20);
-        Assert.assertTrue(destinationAddress[1] == 55);
-        Assert.assertTrue(destinationAddress[2] == 62);
-        Assert.assertTrue(destinationAddress[3] == 110);
-    }
-
-    @Test
-    public void testOptions() throws Exception {
-        IPv4 ip = new IPv4();
-        Assert.assertEquals(20, ip.getHeaderLen());
-        Assert.assertEquals(160, ip.getHeaderSize());
-        Assert.assertEquals(0, ip.getfieldnumBits("Options"));
-
-        byte[][] options = {
-            new byte[] {
-                (byte)0x01,
-            },
-            new byte[] {
-                (byte)0x01, (byte)0x02,
-            },
-            new byte[] {
-                (byte)0x01, (byte)0x02, (byte)0x03,
-            },
-            new byte[] {
-                (byte)0x01, (byte)0x02, (byte)0x03, (byte)0x04,
-            },
-            null,
-            new byte[] {
-                (byte)0x01, (byte)0x02, (byte)0x03, (byte)0x04,
-                (byte)0x05,
-            },
-            new byte[] {
-                (byte)0x01, (byte)0x02, (byte)0x03, (byte)0x04,
-                (byte)0x05, (byte)0x06,
-            },
-            new byte[] {
-                (byte)0x01, (byte)0x02, (byte)0x03, (byte)0x04,
-                (byte)0x05, (byte)0x06, (byte)0x07,
-            },
-            new byte[] {
-                (byte)0x01, (byte)0x02, (byte)0x03, (byte)0x04,
-                (byte)0x05, (byte)0x06, (byte)0x07, (byte)0x08,
-            },
-            new byte[0],
-        };
-
-        byte[][] expected = {
-            new byte[] {
-                (byte)0x01, (byte)0x00, (byte)0x00, (byte)0x00,
-            },
-            new byte[] {
-                (byte)0x01, (byte)0x02, (byte)0x00, (byte)0x00,
-            },
-            new byte[] {
-                (byte)0x01, (byte)0x02, (byte)0x03, (byte)0x00,
-            },
-            new byte[] {
-                (byte)0x01, (byte)0x02, (byte)0x03, (byte)0x04,
-            },
-            null,
-            new byte[] {
-                (byte)0x01, (byte)0x02, (byte)0x03, (byte)0x04,
-                (byte)0x05, (byte)0x00, (byte)0x00, (byte)0x00,
-            },
-            new byte[] {
-                (byte)0x01, (byte)0x02, (byte)0x03, (byte)0x04,
-                (byte)0x05, (byte)0x06, (byte)0x00, (byte)0x00,
-            },
-            new byte[] {
-                (byte)0x01, (byte)0x02, (byte)0x03, (byte)0x04,
-                (byte)0x05, (byte)0x06, (byte)0x07, (byte)0x00,
-            },
-            new byte[] {
-                (byte)0x01, (byte)0x02, (byte)0x03, (byte)0x04,
-                (byte)0x05, (byte)0x06, (byte)0x07, (byte)0x08,
-            },
-            null,
-        };
-
-        byte[] echo = {
-            (byte)0x11, (byte)0x22, (byte)0x33, (byte)0x44,
-            (byte)0x55, (byte)0x66, (byte)0x77, (byte)0x88,
-            (byte)0x99, (byte)0xaa,
-        };
-        ICMP icmp = new ICMP();
-        icmp.setType((byte)8);
-        icmp.setCode((byte)0);
-        icmp.setIdentifier((short)0xabcd);
-        icmp.setSequenceNumber((short)7777);
-        icmp.setRawPayload(echo);
-
-        ip.setSourceAddress(InetAddress.getByName("192.168.10.20"));
-        ip.setDestinationAddress(InetAddress.getByName("192.168.30.40"));
-        ip.setProtocol(IPProtocols.ICMP.byteValue());
-
-        for (int i = 0; i < options.length; i++) {
-            byte[] opts = options[i];
-            byte[] exp = expected[i];
-
-            // Set IPv4 options.
-            int hlen = 20;
-            int optlen;
-            if (exp != null) {
-                optlen = exp.length;
-                hlen += optlen;
-            } else {
-                optlen = 0;
-            }
-            ip.setOptions(opts);
-            Assert.assertTrue(Arrays.equals(exp, ip.getOptions()));
-            Assert.assertEquals(hlen, ip.getHeaderLen());
-            Assert.assertEquals(hlen * 8, ip.getHeaderSize());
-            Assert.assertEquals(optlen * 8, ip.getfieldnumBits("Options"));
-
-            // Serialize/Deserialize test.
-            ip.setPayload(icmp);
-
-            byte[] raw = ip.serialize();
-            IPv4 newip = new IPv4();
-            newip.deserialize(raw, 0, raw.length * 8);
-            Assert.assertEquals(ip, newip);
-            Assert.assertEquals(icmp, newip.getPayload());
-            Assert.assertTrue(Arrays.equals(exp, newip.getOptions()));
-        }
-    }
-
-    @Test
-    public void testChecksum() {
-        byte header[] = { (byte) 0x45, 00, 00, (byte) 0x3c, (byte) 0x1c,
-                (byte) 0x46, (byte) 0x40, 00, (byte) 0x40, 06, (byte) 0xb1,
-                (byte) 0xe6, (byte) 0xac, (byte) 0x10, (byte) 0x0a,
-                (byte) 0x63, (byte) 0xac, (byte) 0x10, (byte) 0x0a, (byte) 0x0c };
-        byte header2[] = { (byte) 0x45, 00, 00, (byte) 0x73, 00, 00,
-                (byte) 0x40, 00, (byte) 0x40, (byte) 0x11, (byte) 0xb8,
-                (byte) 0x61, (byte) 0xc0, (byte) 0xa8, 00, 01, (byte) 0xc0,
-                (byte) 0xa8, 00, (byte) 0xc7 };
-        byte header3[] = { (byte) 0x45, 00, 00, (byte) 0x47, (byte) 0x73,
-                (byte) 0x88, (byte) 0x40, 00, (byte) 0x40, 06, (byte) 0xA2,
-                (byte) 0xC4, (byte) 0x83, (byte) 0x9F, (byte) 0x0E,
-                (byte) 0x85, (byte) 0x83, (byte) 0x9F, (byte) 0x0E, (byte) 0xA1 };
-        byte header4[] = { (byte) 0x45, 00, 00, (byte) 0x54, 00, 00,
-                (byte) 0x40, 00, (byte) 0x40, 01, (byte) 0xf0, (byte) 0x8e,
-                (byte) 0xc0, (byte) 0xa8, (byte) 0x64, (byte) 0x65,
-                (byte) 0xc0, (byte) 0xa8, (byte) 0x64, (byte) 0x64 };
-        byte header5[] = { (byte) 0x45, 00, 00, (byte) 0x54, 00, 00,
-                (byte) 0x40, 00, (byte) 0x40, 01, (byte) 0xef, (byte) 0x8d,
-                (byte) 0xc0, (byte) 0xa8, (byte) 0x64, (byte) 0x65,
-                (byte) 0xc0, (byte) 0xa8, (byte) 0x65, (byte) 0x65 };
-        byte header6[] = { (byte) 0x45, 00, 00, (byte) 0x54, 00, 00,
-                (byte) 0x40, 00, (byte) 0x40, 01, (byte) 0x0b, (byte) 0x92,
-                (byte) 0xc0, (byte) 0xa8, (byte) 0x64, (byte) 0x65, (byte) 0x9,
-                (byte) 0x9, (byte) 0x1, (byte) 0x1 };
-        byte header7[] = { (byte) 0x45, 00, 00, (byte) 0x54, 00, 00,
-                (byte) 0x40, 00, (byte) 0x40, 01, (byte) 0, (byte) 0,
-                (byte) 0xc0, (byte) 0xa8, (byte) 0x64, (byte) 0x65, (byte) 0x9,
-                (byte) 0x9, (byte) 0x2, (byte) 0x2 };
-
-        IPv4 ip = new IPv4();
-
-        Assert.assertTrue(NetUtils.getUnsignedShort(ip.computeChecksum(header,
-                0)) == 0xB1E6);
-        Assert.assertTrue(NetUtils.getUnsignedShort(ip.computeChecksum(header2,
-                0)) == 0xb861);
-        Assert.assertTrue(NetUtils.getUnsignedShort(ip.computeChecksum(header3,
-                0)) == 0xa2c4);
-        Assert.assertTrue(NetUtils.getUnsignedShort(ip.computeChecksum(header4,
-                0)) == 0xf08e);
-        Assert.assertTrue(NetUtils.getUnsignedShort(ip.computeChecksum(header5,
-                0)) == 0xef8d);
-        Assert.assertTrue(NetUtils.getUnsignedShort(ip.computeChecksum(header6,
-                0)) == 0x0b92);
-        Assert.assertTrue(NetUtils.getUnsignedShort(ip.computeChecksum(header7,
-                0)) == 0x0a91);
-    }
-
-    @Test
-    public void testFullIP() throws UnknownHostException, PacketException {
-        byte[] icmpRawPayload = new byte[] { (byte) 0x38, (byte) 0x26,
-                (byte) 0x9e, (byte) 0x51, (byte) 0x00, (byte) 0x00,
-                (byte) 0x00, (byte) 0x00, (byte) 0x2e, (byte) 0x6a,
-                (byte) 0x08, (byte) 0x00, (byte) 0x00, (byte) 0x00,
-                (byte) 0x00, (byte) 0x00, (byte) 0x10, (byte) 0x11,
-                (byte) 0x12, (byte) 0x13, (byte) 0x14, (byte) 0x15,
-                (byte) 0x16, (byte) 0x17, (byte) 0x18, (byte) 0x19,
-                (byte) 0x1a, (byte) 0x1b, (byte) 0x1c, (byte) 0x1d,
-                (byte) 0x1e, (byte) 0x1f, (byte) 0x20, (byte) 0x21,
-                (byte) 0x22, (byte) 0x23, (byte) 0x24, (byte) 0x25,
-                (byte) 0x26, (byte) 0x27, (byte) 0x28, (byte) 0x29,
-                (byte) 0x2a, (byte) 0x2b, (byte) 0x2c, (byte) 0x2d,
-                (byte) 0x2e, (byte) 0x2f, (byte) 0x30, (byte) 0x31,
-                (byte) 0x32, (byte) 0x33, (byte) 0x34, (byte) 0x35,
-                (byte) 0x36, (byte) 0x37 };
-        ICMP icmp = new ICMP();
-        icmp.setType((byte) 8);
-        icmp.setCode((byte) 0);
-        icmp.setIdentifier((short) 0x46f5);
-        icmp.setSequenceNumber((short) 2);
-        icmp.setRawPayload(icmpRawPayload);
-
-        IPv4 ip = new IPv4();
-        ip.setVersion((byte) 4);
-        ip.setIdentification((short) 5);
-        ip.setDiffServ((byte) 0);
-        ip.setECN((byte) 0);
-        ip.setTotalLength((short) 84);
-        ip.setFlags((byte) 2);
-        ip.setFragmentOffset((short) 0);
-        ip.setTtl((byte) 64);
-        ip.setProtocol(IPProtocols.ICMP.byteValue());
-        ip.setDestinationAddress(InetAddress.getByName("192.168.100.100"));
-        ip.setSourceAddress(InetAddress.getByName("192.168.100.101"));
-        ip.setPayload(icmp);
-
-        Ethernet eth = new Ethernet();
-        eth.setDestinationMACAddress(new byte[] { (byte) 0x98, (byte) 0xfc,
-                (byte) 0x11, (byte) 0x93, (byte) 0x5c, (byte) 0xb8 });
-        eth.setSourceMACAddress(new byte[] { (byte) 0x00, (byte) 0x24,
-                (byte) 0xd7, (byte) 0xa9, (byte) 0xa3, (byte) 0x50 });
-        eth.setEtherType(EtherTypes.IPv4.shortValue());
-        eth.setPayload(ip);
-
-        byte[] stream = eth.serialize();
-
-        Ethernet decEth = new Ethernet();
-        decEth.deserialize(stream, 0, stream.length * NetUtils.NumBitsInAByte);
-
-        IPv4 decIp = (IPv4) decEth.getPayload();
-        Assert.assertFalse(decIp.isCorrupted());
-        Assert.assertTrue(ip.equals(decIp));
-
-        ICMP decIcmp = (ICMP) decIp.getPayload();
-        Assert.assertFalse(decIcmp.isCorrupted());
-        Assert.assertTrue(Arrays.equals(icmpRawPayload, decIcmp.getRawPayload()));
-    }
-
-    @Test
-    public void testGetMatch() throws Exception {
-        IPv4 ip = new IPv4();
-        InetAddress sourceAddress = InetAddress.getByName("172.168.190.15");
-        InetAddress destintationAddress = InetAddress.getByName("23.128.0.11");
-        byte protocol = IPProtocols.TCP.byteValue();
-        byte tos = 7;
-        ip.setVersion((byte) 4);
-        ip.setIdentification((short) 5);
-        ip.setDiffServ(tos);
-        ip.setECN((byte) 0);
-        ip.setTotalLength((short) 84);
-        ip.setFlags((byte) 2);
-        ip.setFragmentOffset((short) 0);
-        ip.setTtl((byte) 64);
-        ip.setProtocol(protocol);
-        ip.setDestinationAddress(destintationAddress);
-        ip.setSourceAddress(sourceAddress);
-
-        Match match = ip.getMatch();
-
-        Assert.assertEquals(sourceAddress, match.getField(MatchType.NW_SRC).getValue());
-        Assert.assertEquals(destintationAddress, match.getField(MatchType.NW_DST).getValue());
-        Assert.assertEquals(protocol, (byte) match.getField(MatchType.NW_PROTO).getValue());
-        Assert.assertEquals(tos, (byte) match.getField(MatchType.NW_TOS).getValue());
-    }
-
-    @Test
-    public void testFragment() throws Exception {
-        byte[] payload1 = new byte[0];
-        byte[] payload2 = {
-            (byte)0x61, (byte)0xd1, (byte)0x3d, (byte)0x51,
-            (byte)0x1b, (byte)0x75, (byte)0xa7, (byte)0x83,
-        };
-        byte[] payload3 = {
-            (byte)0xe7, (byte)0x0f, (byte)0x2d, (byte)0x7e,
-            (byte)0x15, (byte)0xba, (byte)0xe7, (byte)0x6d,
-            (byte)0xb5, (byte)0xc5, (byte)0xb5, (byte)0x37,
-            (byte)0x59, (byte)0xbc, (byte)0x91, (byte)0x43,
-            (byte)0xb5, (byte)0xb7, (byte)0xe4, (byte)0x28,
-            (byte)0xec, (byte)0x62, (byte)0x6b, (byte)0x6a,
-            (byte)0xd1, (byte)0xcb, (byte)0x79, (byte)0x1e,
-            (byte)0xfc, (byte)0x82, (byte)0xf5, (byte)0xb4,
-        };
-
-        // Ensure that the payload is not deserialized if the fragment offset
-        // is not zero.
-        byte proto = IPProtocols.TCP.byteValue();
-        fragmentTest(payload1, proto, (short)0xf250);
-        fragmentTest(payload2, proto, (short)0xf248);
-        fragmentTest(payload3, proto, (short)0xf230);
-
-        proto = IPProtocols.UDP.byteValue();
-        fragmentTest(payload1, proto, (short)0xf245);
-        fragmentTest(payload2, proto, (short)0xf23d);
-        fragmentTest(payload3, proto, (short)0xf225);
-
-        proto = IPProtocols.ICMP.byteValue();
-        fragmentTest(payload1, proto, (short)0xf255);
-        fragmentTest(payload2, proto, (short)0xf24d);
-        fragmentTest(payload3, proto, (short)0xf235);
-
-        // Ensure that the protocol header in the first fragment is
-        // deserialized.
-        proto = IPProtocols.TCP.byteValue();
-        TCP tcp = new TCP();
-        tcp.setSourcePort((short)1234).setDestinationPort((short)32000).
-            setSequenceNumber((int)0xd541f5f8).setAckNumber((int)0x58da787d).
-            setDataOffset((byte)5).setReserved((byte)0).
-            setHeaderLenFlags((short)0x18).setWindowSize((short)0x40e8).
-            setUrgentPointer((short)0x15f7).setChecksum((short)0x0d4e);
-        firstFragmentTest(tcp, payload1, proto, (short)0xdfe6);
-        tcp.setChecksum((short)0xab2a);
-        firstFragmentTest(tcp, payload2, proto, (short)0xdfde);
-        tcp.setChecksum((short)0x1c75);
-        firstFragmentTest(tcp, payload3, proto, (short)0xdfc6);
-
-        proto = IPProtocols.UDP.byteValue();
-        UDP udp = new UDP();
-        udp.setSourcePort((short)53).setDestinationPort((short)45383).
-            setLength((short)(payload1.length + 8)).setChecksum((short)0);
-        firstFragmentTest(udp, payload1, proto, (short)0xdfe7);
-        udp.setLength((short)(payload2.length + 8));
-        firstFragmentTest(udp, payload2, proto, (short)0xdfdf);
-        udp.setLength((short)(payload3.length + 8));
-        firstFragmentTest(udp, payload3, proto, (short)0xdfc7);
-
-        proto = IPProtocols.ICMP.byteValue();
-        ICMP icmp = new ICMP();
-        icmp.setType((byte)8).setCode((byte)0).setIdentifier((short)0x3d1e).
-            setSequenceNumber((short)1);
-        firstFragmentTest(icmp, payload1, proto, (short)0xdff7);
-        firstFragmentTest(icmp, payload2, proto, (short)0xdfef);
-        firstFragmentTest(icmp, payload3, proto, (short)0xdfd7);
-    }
-
-    private void fragmentTest(byte[] payload, byte proto, short checksum)
-        throws Exception {
-        // Construct a fragmented raw IPv4 packet.
-        int ipv4Len = 20;
-        byte[] rawIp = new byte[ipv4Len + payload.length];
-
-        byte ipVersion = 4;
-        byte dscp = 35;
-        byte ecn = 2;
-        byte tos = (byte)((dscp << 2) | ecn);
-        short totalLen = (short)rawIp.length;
-        short id = 22143;
-        short offset = 0xb9;
-        byte ttl = 64;
-        byte[] srcIp = {(byte)0x0a, (byte)0x00, (byte)0x00, (byte)0x01};
-        byte[] dstIp = {(byte)0xc0, (byte)0xa9, (byte)0x66, (byte)0x23};
-
-        rawIp[0] = (byte)((ipVersion << 4) | (ipv4Len >> 2));
-        rawIp[1] = tos;
-        rawIp[2] = (byte)(totalLen >>> Byte.SIZE);
-        rawIp[3] = (byte)totalLen;
-        rawIp[4] = (byte)(id >>> Byte.SIZE);
-        rawIp[5] = (byte)id;
-        rawIp[6] = (byte)(offset >>> Byte.SIZE);
-        rawIp[7] = (byte)offset;
-        rawIp[8] = ttl;
-        rawIp[9] = proto;
-        rawIp[10] = (byte)(checksum >>> Byte.SIZE);
-        rawIp[11] = (byte)checksum;
-        System.arraycopy(srcIp, 0, rawIp, 12, srcIp.length);
-        System.arraycopy(dstIp, 0, rawIp, 16, srcIp.length);
-        System.arraycopy(payload, 0, rawIp, ipv4Len, payload.length);
-
-        // Deserialize.
-        IPv4 ipv4 = new IPv4();
-        ipv4.deserialize(rawIp, 0, rawIp.length * Byte.SIZE);
-
-        Assert.assertEquals(ipVersion, ipv4.getVersion());
-        Assert.assertEquals(ipv4Len, ipv4.getHeaderLen());
-        Assert.assertEquals(dscp, ipv4.getDiffServ());
-        Assert.assertEquals(ecn, ipv4.getECN());
-        Assert.assertEquals(totalLen, ipv4.getTotalLength());
-        Assert.assertEquals(id, ipv4.getIdentification());
-        Assert.assertEquals((byte)0, ipv4.getFlags());
-        Assert.assertEquals(offset, ipv4.getFragmentOffset());
-        Assert.assertEquals(ttl, ipv4.getTtl());
-        Assert.assertEquals(proto, ipv4.getProtocol());
-        Assert.assertEquals(checksum, ipv4.getChecksum());
-        Assert.assertEquals(NetUtils.byteArray4ToInt(srcIp),
-                            ipv4.getSourceAddress());
-        Assert.assertEquals(NetUtils.byteArray4ToInt(dstIp),
-                            ipv4.getDestinationAddress());
-        Assert.assertFalse(ipv4.isCorrupted());
-
-        // payloadClass should not be set if fragment offset is not zero.
-        Assert.assertEquals(null, ipv4.getPayload());
-        Assert.assertArrayEquals(payload, ipv4.getRawPayload());
-    }
-
-    private void firstFragmentTest(Packet payload, byte[] rawPayload,
-                                   byte proto, short checksum)
-        throws Exception {
-        // Construct a raw IPv4 packet with MF flag.
-        int ipv4Len = 20;
-        payload.setRawPayload(rawPayload);
-        byte[] payloadBytes = payload.serialize();
-        byte[] rawIp = new byte[ipv4Len + payloadBytes.length];
-
-        byte ipVersion = 4;
-        byte dscp = 13;
-        byte ecn = 1;
-        byte tos = (byte)((dscp << 2) | ecn);
-        short totalLen = (short)rawIp.length;
-        short id = 19834;
-        byte flags = 0x1;
-        short offset = 0;
-        short off = (short)(((short)flags << 13) | offset);
-        byte ttl = 64;
-        byte[] srcIp = {(byte)0xac, (byte)0x23, (byte)0x5b, (byte)0xfd};
-        byte[] dstIp = {(byte)0xc0, (byte)0xa8, (byte)0x64, (byte)0x71};
-
-        rawIp[0] = (byte)((ipVersion << 4) | (ipv4Len >> 2));
-        rawIp[1] = tos;
-        rawIp[2] = (byte)(totalLen >>> Byte.SIZE);
-        rawIp[3] = (byte)totalLen;
-        rawIp[4] = (byte)(id >>> Byte.SIZE);
-        rawIp[5] = (byte)id;
-        rawIp[6] = (byte)(off >>> Byte.SIZE);
-        rawIp[7] = (byte)off;
-        rawIp[8] = ttl;
-        rawIp[9] = proto;
-        rawIp[10] = (byte)(checksum >>> Byte.SIZE);
-        rawIp[11] = (byte)checksum;
-        System.arraycopy(srcIp, 0, rawIp, 12, srcIp.length);
-        System.arraycopy(dstIp, 0, rawIp, 16, srcIp.length);
-        System.arraycopy(payloadBytes, 0, rawIp, ipv4Len, payloadBytes.length);
-
-        // Deserialize.
-        IPv4 ipv4 = new IPv4();
-        ipv4.deserialize(rawIp, 0, rawIp.length * Byte.SIZE);
-
-        Assert.assertEquals(ipVersion, ipv4.getVersion());
-        Assert.assertEquals(ipv4Len, ipv4.getHeaderLen());
-        Assert.assertEquals(dscp, ipv4.getDiffServ());
-        Assert.assertEquals(ecn, ipv4.getECN());
-        Assert.assertEquals(totalLen, ipv4.getTotalLength());
-        Assert.assertEquals(id, ipv4.getIdentification());
-        Assert.assertEquals(flags, ipv4.getFlags());
-        Assert.assertEquals(offset, ipv4.getFragmentOffset());
-        Assert.assertEquals(ttl, ipv4.getTtl());
-        Assert.assertEquals(proto, ipv4.getProtocol());
-        Assert.assertEquals(checksum, ipv4.getChecksum());
-        Assert.assertEquals(NetUtils.byteArray4ToInt(srcIp),
-                            ipv4.getSourceAddress());
-        Assert.assertEquals(NetUtils.byteArray4ToInt(dstIp),
-                            ipv4.getDestinationAddress());
-        Assert.assertFalse(ipv4.isCorrupted());
-
-        // Protocol header in the first fragment should be deserialized.
-        Assert.assertEquals(null, ipv4.getRawPayload());
-
-        Packet desPayload = ipv4.getPayload();
-        Assert.assertEquals(payload, desPayload);
-        Assert.assertFalse(desPayload.isCorrupted());
-        Assert.assertArrayEquals(rawPayload, desPayload.getRawPayload());
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/packet/PacketTest.java b/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/packet/PacketTest.java
deleted file mode 100644 (file)
index 00b0fee..0000000
+++ /dev/null
@@ -1,227 +0,0 @@
-
-/*
- * Copyright (c) 2013-2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.packet;
-
-import java.net.InetAddress;
-import java.util.Arrays;
-import java.util.Map;
-
-import org.junit.Assert;
-
-import org.junit.Test;
-import org.opendaylight.controller.sal.match.Match;
-import org.opendaylight.controller.sal.match.MatchType;
-import org.opendaylight.controller.sal.utils.EtherTypes;
-import org.opendaylight.controller.sal.utils.IPProtocols;
-
-public class PacketTest {
-
-    @Test
-    public void testDeserialize() throws NoSuchFieldException, Exception {
-        short startOffset, numBits;
-
-        Ethernet eth = new Ethernet();
-        byte[] data = { 10, 12, 14, 20, 55, 69, //DMAC
-                -90, -20, -100, -82, -78, -97, //SMAC
-                8, 6, //ethype
-                0, 1, // hw type
-                8, 0, // proto (ip)
-                6, // hw addr len
-                4, // proto addr len
-                0, 1, // op codes
-                -90, -20, -100, -82, -78, -97, //src hw addr
-                9, 9, 9, 1, // src proto
-                0, 0, 0, 0, 0, 0, // target hw addr
-                9, 9, 9, -2 }; // target proto
-
-        startOffset = 0;
-        numBits = 42 * 8;
-        eth.deserialize(data, startOffset, numBits);
-
-        byte[] dMAC = eth.getDestinationMACAddress();
-        byte[] sMAC = eth.getSourceMACAddress();
-        short etherType = eth.getEtherType();
-
-        Assert.assertTrue(dMAC[0] == 10);
-        Assert.assertTrue(dMAC[1] == 12);
-        Assert.assertTrue(dMAC[2] == 14);
-        Assert.assertTrue(dMAC[3] == 20);
-        Assert.assertTrue(dMAC[4] == 55);
-        Assert.assertTrue(dMAC[5] == 69);
-
-        Assert.assertTrue(sMAC[0] == -90);
-        Assert.assertTrue(sMAC[1] == -20);
-        Assert.assertTrue(sMAC[2] == -100);
-        Assert.assertTrue(sMAC[3] == -82);
-        Assert.assertTrue(sMAC[4] == -78);
-        Assert.assertTrue(sMAC[5] == -97);
-
-        Assert.assertTrue(etherType == 0x806);
-
-        ARP arpPacket = (ARP) eth.getPayload();
-
-        Assert.assertTrue(arpPacket.getHardwareType() == (byte)0x1);
-        Assert.assertTrue(arpPacket.getProtocolType() == 2048);
-        Assert.assertTrue(arpPacket.getHardwareAddressLength() == (byte)0x6);
-        Assert.assertTrue(arpPacket.getProtocolAddressLength() == (byte)0x4);
-        Assert.assertTrue(arpPacket.getOpCode() == 1);
-
-        byte[] senderHwAddress = arpPacket.getSenderHardwareAddress();
-        byte[] senderProtocolAddress = arpPacket.getSenderProtocolAddress();
-
-        byte[] targetHwAddress = arpPacket.getTargetHardwareAddress();
-        byte[] targetProtocolAddress = arpPacket.getTargetProtocolAddress();
-
-
-        Assert.assertTrue(senderHwAddress[0] == (byte)0xA6);
-        Assert.assertTrue(senderHwAddress[1] == (byte)0xEC);
-        Assert.assertTrue(senderHwAddress[2] == (byte)0x9C);
-        Assert.assertTrue(senderHwAddress[3] == (byte)0xAE);
-        Assert.assertTrue(senderHwAddress[4] == (byte)0xB2);
-        Assert.assertTrue(senderHwAddress[5] == (byte)0x9F);
-
-        Assert.assertTrue(senderProtocolAddress[0] == (byte)0x9);
-        Assert.assertTrue(senderProtocolAddress[1] == (byte)0x9);
-        Assert.assertTrue(senderProtocolAddress[2] == (byte)0x9);
-        Assert.assertTrue(senderProtocolAddress[3] == (byte)0x1);
-
-        Assert.assertTrue(targetHwAddress[0] == (byte)0x0);
-        Assert.assertTrue(targetHwAddress[1] == (byte)0x0);
-        Assert.assertTrue(targetHwAddress[2] == (byte)0x0);
-        Assert.assertTrue(targetHwAddress[3] == (byte)0x0);
-        Assert.assertTrue(targetHwAddress[4] == (byte)0x0);
-        Assert.assertTrue(targetHwAddress[5] == (byte)0x0);
-
-        Assert.assertTrue(senderProtocolAddress[0] == (byte)0x9);
-        Assert.assertTrue(senderProtocolAddress[1] == (byte)0x9);
-        Assert.assertTrue(senderProtocolAddress[2] == (byte)0x9);
-        Assert.assertTrue(senderProtocolAddress[3] == (byte)0x1);
-
-        Assert.assertTrue(targetProtocolAddress[0] == (byte)0x9);
-        Assert.assertTrue(targetProtocolAddress[1] == (byte)0x9);
-        Assert.assertTrue(targetProtocolAddress[2] == (byte)0x9);
-        Assert.assertTrue(targetProtocolAddress[3] == (byte)0xFE);
-    }
-
-    @Test
-    public void testSerialize() throws NoSuchFieldException, Exception {
-        Ethernet eth = new Ethernet();
-        Map<String, byte[]> fCValues = eth.hdrFieldsMap;
-
-        byte[] dMAC = { 10, 12, 14, 20, 55, 69 };
-        byte[] sMAC = { 82, 97, 109, 117, 127, -50 };
-        short etherType = 2054;
-
-        byte[] dMACdata, sMACdata, etherTypedata;
-        byte[] data = new byte[20];
-
-        eth.setDestinationMACAddress(dMAC);
-        eth.setSourceMACAddress(sMAC);
-        eth.setEtherType(etherType);
-
-        dMACdata = fCValues.get("DestinationMACAddress");
-        sMACdata = fCValues.get("SourceMACAddress");
-        etherTypedata = fCValues.get("EtherType");
-
-        Assert.assertTrue(dMACdata[0] == 10);
-        Assert.assertTrue(dMACdata[1] == 12);
-        Assert.assertTrue(dMACdata[2] == 14);
-        Assert.assertTrue(dMACdata[3] == 20);
-        Assert.assertTrue(dMACdata[4] == 55);
-        Assert.assertTrue(dMACdata[5] == 69);
-
-        Assert.assertTrue(sMACdata[0] == 82);
-        Assert.assertTrue(sMACdata[1] == 97);
-        Assert.assertTrue(sMACdata[2] == 109);
-        Assert.assertTrue(sMACdata[3] == 117);
-        Assert.assertTrue(sMACdata[4] == 127);
-        Assert.assertTrue(sMACdata[5] == -50);
-
-        Assert.assertTrue(etherTypedata[0] == 8);
-        Assert.assertTrue(etherTypedata[1] == 6);
-        data = eth.serialize();
-
-        Assert.assertTrue(data[0] == 10);
-        Assert.assertTrue(data[1] == 12);
-        Assert.assertTrue(data[2] == 14);
-        Assert.assertTrue(data[3] == 20);
-        Assert.assertTrue(data[4] == 55);
-        Assert.assertTrue(data[5] == 69);
-
-        Assert.assertTrue(data[6] == 82);
-        Assert.assertTrue(data[7] == 97);
-        Assert.assertTrue(data[8] == 109);
-        Assert.assertTrue(data[9] == 117);
-        Assert.assertTrue(data[10] == 127);
-        Assert.assertTrue(data[11] == -50);
-
-        Assert.assertTrue(data[12] == 8);
-        Assert.assertTrue(data[13] == 6);
-
-    }
-
-    @Test
-    public void testGetMatch() throws Exception {
-        TCP tcp = new TCP();
-        short sport = (short) 11093;
-        short dport = (short) 23;
-        tcp.setSourcePort(sport);
-        tcp.setDestinationPort(dport);
-
-        IPv4 ip = new IPv4();
-        InetAddress sourceAddress = InetAddress.getByName("192.168.100.100");
-        InetAddress destintationAddress = InetAddress.getByName("192.168.100.101");
-        byte protocol = IPProtocols.TCP.byteValue();
-        byte tos = 5;
-        ip.setVersion((byte) 4);
-        ip.setIdentification((short) 5);
-        ip.setDiffServ(tos);
-        ip.setECN((byte) 0);
-        ip.setTotalLength((short) 84);
-        ip.setFlags((byte) 2);
-        ip.setFragmentOffset((short) 0);
-        ip.setTtl((byte) 64);
-        ip.setProtocol(protocol);
-        ip.setDestinationAddress(destintationAddress);
-        ip.setSourceAddress(sourceAddress);
-        ip.setPayload(tcp);
-
-        IEEE8021Q dot1q = new IEEE8021Q();
-        byte priority = 4;
-        short vlanId = 59;
-        short ethType = EtherTypes.IPv4.shortValue();
-        dot1q.setPcp(priority);
-        dot1q.setVid(vlanId);
-        dot1q.setEtherType(ethType);
-        dot1q.setPayload(ip);
-
-        Ethernet eth = new Ethernet();
-        byte smac[] = { (byte) 0xf0, (byte) 0xde, (byte) 0xf1, (byte) 0x71, (byte) 0x72, (byte) 0x8d };
-        byte dmac[] = { (byte) 0xde, (byte) 0x28, (byte) 0xdb, (byte) 0xb3, (byte) 0x7c, (byte) 0xf8 };
-        eth.setDestinationMACAddress(dmac);
-        eth.setSourceMACAddress(smac);
-        eth.setEtherType(EtherTypes.VLANTAGGED.shortValue());
-        eth.setPayload(dot1q);
-
-        Match match = eth.getMatch();
-
-        Assert.assertTrue(Arrays.equals(smac, (byte[]) match.getField(MatchType.DL_SRC).getValue()));
-        Assert.assertTrue(Arrays.equals(dmac, (byte[]) match.getField(MatchType.DL_DST).getValue()));
-        Assert.assertEquals(priority, (byte) match.getField(MatchType.DL_VLAN_PR).getValue());
-        Assert.assertEquals(vlanId, (short) match.getField(MatchType.DL_VLAN).getValue());
-        Assert.assertEquals(ethType, (short) match.getField(MatchType.DL_TYPE).getValue());
-        Assert.assertEquals(sourceAddress, match.getField(MatchType.NW_SRC).getValue());
-        Assert.assertEquals(destintationAddress, match.getField(MatchType.NW_DST).getValue());
-        Assert.assertEquals(protocol, (byte) match.getField(MatchType.NW_PROTO).getValue());
-        Assert.assertEquals(tos, (byte) match.getField(MatchType.NW_TOS).getValue());
-        Assert.assertEquals(sport, (short) match.getField(MatchType.TP_SRC).getValue());
-        Assert.assertEquals(dport, (short) match.getField(MatchType.TP_DST).getValue());
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/packet/TCPTest.java b/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/packet/TCPTest.java
deleted file mode 100644 (file)
index c5f6951..0000000
+++ /dev/null
@@ -1,132 +0,0 @@
-
-/*
- * Copyright (c) 2013-2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.packet;
-
-import org.junit.Assert;
-
-import org.junit.Test;
-import org.opendaylight.controller.sal.match.Match;
-import org.opendaylight.controller.sal.match.MatchType;
-
-public class TCPTest {
-
-    @Test
-    public void testSetSourcePort() {
-        TCP tcp = new TCP();
-        short tcpSourcePort = 118;
-        tcp.setSourcePort(tcpSourcePort);
-        byte[] sourcePort = tcp.hdrFieldsMap.get(TCP.SRCPORT);
-        Assert.assertTrue(sourcePort[0] == 0);
-        Assert.assertTrue(sourcePort[1] == 118);
-
-    }
-
-    @Test
-    public void testSetDestinationPort() {
-        TCP tcp = new TCP();
-        short tcpDestinationPort = 443;
-        tcp.setDestinationPort(tcpDestinationPort);
-        byte[] destinationPort = tcp.hdrFieldsMap.get(TCP.DESTPORT);
-        Assert.assertTrue(destinationPort[0] == 1);
-        Assert.assertTrue(destinationPort[1] == -69);
-
-    }
-
-    @Test
-    public void testSetSequenceNumber() {
-        TCP tcp = new TCP();
-        short tcpSequenceNumber = 700;
-        tcp.setSequenceNumber(tcpSequenceNumber);
-        byte[] sequenceNumber = tcp.hdrFieldsMap.get(TCP.SEQNUMBER);
-        Assert.assertTrue(sequenceNumber[0] == 0);
-        Assert.assertTrue(sequenceNumber[1] == 0);
-        Assert.assertTrue(sequenceNumber[2] == 2);
-        Assert.assertTrue(sequenceNumber[3] == -68);
-    }
-
-    @Test
-    public void testSetAckNumber() {
-        TCP tcp = new TCP();
-        short tcpAckNumber = 697;
-        tcp.setAckNumber(tcpAckNumber);
-        byte[] ackNumber = tcp.hdrFieldsMap.get(TCP.ACKNUMBER);
-        Assert.assertTrue(ackNumber[0] == 0);
-        Assert.assertTrue(ackNumber[1] == 0);
-        Assert.assertTrue(ackNumber[2] == 2);
-        Assert.assertTrue(ackNumber[3] == -71);
-    }
-
-    @Test
-    public void testSetHeaderLenFlags() {
-        TCP tcp = new TCP();
-        short tcpFlags = 26;
-        tcp.setHeaderLenFlags(tcpFlags);
-        byte[] headerLenFlags = tcp.hdrFieldsMap.get(TCP.HEADERLENFLAGS);
-        Assert.assertTrue(headerLenFlags[0] == 0);
-        Assert.assertTrue(headerLenFlags[1] == 26);
-
-    }
-
-    @Test
-    public void testSetWindowSize() {
-        TCP tcp = new TCP();
-        short tcpWindowSize = 100;
-        tcp.setWindowSize(tcpWindowSize);
-        byte[] windowSize = tcp.hdrFieldsMap.get(TCP.WINDOWSIZE);
-        Assert.assertTrue(windowSize[0] == 0);
-        Assert.assertTrue(windowSize[1] == 100);
-
-    }
-
-    @Test
-    public void testSetChecksum() {
-        TCP tcp = new TCP();
-        short tcpChecksum = 134;
-        tcp.setChecksum(tcpChecksum);
-        byte[] checksum = tcp.hdrFieldsMap.get(TCP.CHECKSUM);
-        Assert.assertTrue(checksum[0] == 0);
-        Assert.assertTrue(checksum[1] == -122);
-
-    }
-
-    @Test
-    public void testSetUrgentPointer() {
-        TCP tcp = new TCP();
-        short tcpUrgentPointer = 25098;
-        tcp.setUrgentPointer(tcpUrgentPointer);
-        byte[] urgentPointer = tcp.hdrFieldsMap.get(TCP.URGENTPOINTER);
-        Assert.assertTrue(urgentPointer[0] == 98);
-        Assert.assertTrue(urgentPointer[1] == 10);
-
-    }
-
-    @Test
-    public void testGetChecksum() {
-        TCP tcp = new TCP();
-        byte[] udpChecksum = { 0, -56 };
-        tcp.hdrFieldsMap.put("Checksum", udpChecksum);
-        short checksum = tcp.getChecksum();
-        Assert.assertTrue(checksum == 200);
-    }
-
-    @Test
-    public void testGetMatch() throws Exception {
-        TCP tcp = new TCP();
-        short sport = (short) 52012;
-        short dport = (short) 40345;
-        tcp.setSourcePort(sport);
-        tcp.setDestinationPort(dport);
-
-        Match match = tcp.getMatch();
-
-        Assert.assertEquals(sport, (short) match.getField(MatchType.TP_SRC).getValue());
-        Assert.assertEquals(dport, (short) match.getField(MatchType.TP_DST).getValue());
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/packet/UDPTest.java b/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/packet/UDPTest.java
deleted file mode 100644 (file)
index ddb6acb..0000000
+++ /dev/null
@@ -1,115 +0,0 @@
-
-/*
- * Copyright (c) 2013-2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.packet;
-
-import org.junit.Assert;
-
-import org.junit.Test;
-import org.opendaylight.controller.sal.match.Match;
-import org.opendaylight.controller.sal.match.MatchType;
-
-public class UDPTest {
-
-    @Test
-    public void testGetSourcePort() {
-        UDP udp = new UDP();
-        byte[] udpSourcePort = { 0, 118 };
-        udp.hdrFieldsMap.put("SourcePort", udpSourcePort);
-        short sourcePort = udp.getSourcePort();
-        Assert.assertTrue(sourcePort == 118);
-    }
-
-    @Test
-    public void testGetDestinationPort() {
-        UDP udp = new UDP();
-        byte[] udpDestinationPort = { 1, -69 };
-        udp.hdrFieldsMap.put("DestinationPort", udpDestinationPort);
-        short destinationPort = udp.getDestinationPort();
-        Assert.assertTrue(destinationPort == 443);
-    }
-
-    @Test
-    public void testGetLength() {
-        UDP udp = new UDP();
-        byte[] udpLength = { 0, 20 };
-        udp.hdrFieldsMap.put("Length", udpLength);
-        short length = udp.getLength();
-        Assert.assertTrue(length == 20);
-    }
-
-    @Test
-    public void testGetChecksum() {
-        UDP udp = new UDP();
-        byte[] udpChecksum = { 0, -56 };
-        udp.hdrFieldsMap.put("Checksum", udpChecksum);
-        short checksum = udp.getChecksum();
-        Assert.assertTrue(checksum == 200);
-    }
-
-    @Test
-    public void testSetSourcePort() {
-        UDP udp = new UDP();
-        short tcpSourcePort = 118;
-        udp.setSourcePort(tcpSourcePort);
-        byte[] sourcePort = udp.hdrFieldsMap.get("SourcePort");
-        Assert.assertTrue(sourcePort[0] == 0);
-        Assert.assertTrue(sourcePort[1] == 118);
-
-    }
-
-    @Test
-    public void testSetDestinationPort() {
-        UDP udp = new UDP();
-        short tcpDestinationPort = 443;
-        udp.setDestinationPort(tcpDestinationPort);
-        byte[] destinationPort = udp.hdrFieldsMap.get("DestinationPort");
-        Assert.assertTrue(destinationPort[0] == 1);
-        Assert.assertTrue(destinationPort[1] == -69);
-
-    }
-
-    @Test
-    public void testSetLength() {
-        UDP udp = new UDP();
-        short udpLength = 20;
-        udp.setLength(udpLength);
-        byte[] length = udp.hdrFieldsMap.get("Length");
-        Assert.assertTrue(length[0] == 0);
-        Assert.assertTrue(length[1] == 20);
-
-    }
-
-    @Test
-    public void testSetChecksum() {
-        UDP udp = new UDP();
-        short udpChecksum = 200;
-        udp.setChecksum(udpChecksum);
-        byte[] checksum = udp.hdrFieldsMap.get("Checksum");
-        Assert.assertTrue(checksum[0] == 0);
-        Assert.assertTrue(checksum[1] == -56);
-
-    }
-
-    @Test
-    public void testGetMatch() throws Exception {
-        UDP udp = new UDP();
-        short sport = (short) 33000;
-        short dport = (short) 843;
-        udp.setSourcePort(sport);
-        udp.setDestinationPort(dport);
-
-        Match match = udp.getMatch();
-
-        Assert.assertEquals(sport, (short) match.getField(MatchType.TP_SRC).getValue());
-        Assert.assertEquals(dport, (short) match.getField(MatchType.TP_DST).getValue());
-
-    }
-
-}
diff --git a/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/packet/address/EthernetAddressTest.java b/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/packet/address/EthernetAddressTest.java
deleted file mode 100644 (file)
index e20e22a..0000000
+++ /dev/null
@@ -1,113 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * @file   EthernetAddressTest.java
- *
- * @brief  Unit Tests for EthernetAddress class
- *
- * Unit Tests for EthernetAddress class
- */
-package org.opendaylight.controller.sal.packet.address;
-
-import org.junit.Assert;
-import org.junit.Test;
-import org.opendaylight.controller.sal.core.ConstructionException;
-
-public class EthernetAddressTest {
-    @Test
-    public void testNonValidConstructor() {
-        @SuppressWarnings("unused")
-        EthernetAddress ea1;
-        // Null input array
-        try {
-            ea1 = new EthernetAddress((byte[]) null);
-
-            // Exception is expected if NOT raised test will fail
-            Assert.assertTrue(false);
-        } catch (ConstructionException e) {
-        }
-
-        // Array too short
-        try {
-            ea1 = new EthernetAddress(new byte[] { (byte) 0x0, (byte) 0x0 });
-
-            // Exception is expected if NOT raised test will fail
-            Assert.assertTrue(false);
-        } catch (ConstructionException e) {
-        }
-
-        // Array too long
-        try {
-            ea1 = new EthernetAddress(new byte[] { (byte) 0x0, (byte) 0x0,
-                    (byte) 0x0, (byte) 0x0, (byte) 0x0, (byte) 0x0, (byte) 0x0,
-                    (byte) 0x0 });
-
-            // Exception is expected if NOT raised test will fail
-            Assert.assertTrue(false);
-        } catch (ConstructionException e) {
-        }
-    }
-
-    @Test
-    public void testEquality() {
-        EthernetAddress ea1;
-        EthernetAddress ea2;
-        try {
-            ea1 = new EthernetAddress(new byte[] { (byte) 0x0, (byte) 0x0,
-                    (byte) 0x0, (byte) 0x0, (byte) 0x0, (byte) 0x1 });
-
-            ea2 = new EthernetAddress(new byte[] { (byte) 0x0, (byte) 0x0,
-                    (byte) 0x0, (byte) 0x0, (byte) 0x0, (byte) 0x1 });
-            Assert.assertTrue(ea1.equals(ea2));
-        } catch (ConstructionException e) {
-            // Exception is NOT expected if raised test will fail
-            Assert.assertTrue(false);
-        }
-
-        try {
-            ea1 = new EthernetAddress(new byte[] { (byte) 0x0, (byte) 0x0,
-                    (byte) 0x0, (byte) 0x0, (byte) 0x0, (byte) 0x1 });
-
-            ea2 = ea1.clone();
-            Assert.assertTrue(ea1.equals(ea2));
-        } catch (ConstructionException e) {
-            // Exception is NOT expected if raised test will fail
-            Assert.assertTrue(false);
-        }
-
-        // Check for well knowns
-        try {
-            ea1 = EthernetAddress.BROADCASTMAC;
-            ea2 = new EthernetAddress(new byte[] { (byte) 0xff, (byte) 0xff,
-                    (byte) 0xff, (byte) 0xff, (byte) 0xff, (byte) 0xff });
-            Assert.assertTrue(ea1.equals(ea2));
-        } catch (ConstructionException e) {
-            // Exception is NOT expected if raised test will fail
-            Assert.assertTrue(false);
-        }
-    }
-
-    @Test
-    public void testUnEquality() {
-        EthernetAddress ea1;
-        EthernetAddress ea2;
-        try {
-            ea1 = new EthernetAddress(new byte[] { (byte) 0x0, (byte) 0x0,
-                    (byte) 0x0, (byte) 0x0, (byte) 0x0, (byte) 0x2 });
-
-            ea2 = new EthernetAddress(new byte[] { (byte) 0x0, (byte) 0x0,
-                    (byte) 0x0, (byte) 0x0, (byte) 0x0, (byte) 0x1 });
-            Assert.assertTrue(!ea1.equals(ea2));
-        } catch (ConstructionException e) {
-            // Exception is NOT expected if raised test will fail
-            Assert.assertTrue(false);
-        }
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/reader/FlowOnNodeTest.java b/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/reader/FlowOnNodeTest.java
deleted file mode 100644 (file)
index b27b275..0000000
+++ /dev/null
@@ -1,58 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.reader;
-
-import java.util.ArrayList;
-import org.junit.Assert;
-import org.junit.Test;
-import org.opendaylight.controller.sal.action.Action;
-import org.opendaylight.controller.sal.action.Output;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.flowprogrammer.Flow;
-import org.opendaylight.controller.sal.match.Match;
-import org.opendaylight.controller.sal.match.MatchType;
-import org.opendaylight.controller.sal.utils.EtherTypes;
-import org.opendaylight.controller.sal.utils.NodeConnectorCreator;
-import org.opendaylight.controller.sal.utils.NodeCreator;
-
-public class FlowOnNodeTest {
-
-                @Test
-                public void testFlowOnNodeMethods () {
-                Match match = new Match();
-                NodeConnector inNC = NodeConnectorCreator.createNodeConnector((short)10, NodeCreator.createOFNode((long)10));
-                NodeConnector outNC = NodeConnectorCreator.createNodeConnector((short)20, NodeCreator.createOFNode((long)20));
-
-                match.setField(MatchType.DL_TYPE, EtherTypes.IPv4.shortValue());
-                match.setField(MatchType.IN_PORT, inNC);
-
-                Output output = new Output(outNC);
-                ArrayList<Action> action = new ArrayList<Action>();
-                action.add(output);
-
-                Flow flow = new Flow (match, action);
-
-                FlowOnNode flowOnNode = new FlowOnNode (flow);
-
-                Assert.assertTrue(flowOnNode.getFlow().equals(flow));
-
-                flowOnNode.setPacketCount((long)100);
-                flowOnNode.setByteCount((long)800);
-                flowOnNode.setTableId((byte)0x55);
-                flowOnNode.setDurationNanoseconds(40);
-                flowOnNode.setDurationSeconds(45);
-
-                Assert.assertTrue(flowOnNode.getPacketCount() == 100);
-                Assert.assertTrue(flowOnNode.getByteCount() == 800);
-                Assert.assertTrue(flowOnNode.getDurationNanoseconds() == 40);
-                Assert.assertTrue(flowOnNode.getDurationSeconds() == 45);
-                Assert.assertTrue(flowOnNode.getTableId() == (byte)0x55);
-        }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/reader/NodeConnectorStatisticsTest.java b/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/reader/NodeConnectorStatisticsTest.java
deleted file mode 100644 (file)
index cd160e8..0000000
+++ /dev/null
@@ -1,50 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.reader;
-
-import org.junit.Test;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.utils.NodeConnectorCreator;
-import org.opendaylight.controller.sal.utils.NodeCreator;
-import org.junit.Assert;
-
-public class NodeConnectorStatisticsTest {
-
-        @Test
-        public void testNodeConnectorStatisticsMethods() {
-                NodeConnector nc = NodeConnectorCreator.createNodeConnector((short)20, NodeCreator.createOFNode((long)20));
-                NodeConnectorStatistics ncStats = new NodeConnectorStatistics();
-                ncStats.setNodeConnector(nc);
-                ncStats.setReceiveByteCount(800);
-                ncStats.setReceiveCRCErrorCount(10);
-                ncStats.setReceiveDropCount(5);
-                ncStats.setReceiveErrorCount(20);
-                ncStats.setReceiveFrameErrorCount(25);
-                ncStats.setReceiveOverRunErrorCount(30);
-                ncStats.setReceivePacketCount(100);
-                ncStats.setTransmitByteCount(400);
-                ncStats.setTransmitDropCount(15);
-                ncStats.setTransmitErrorCount(18);
-                ncStats.setTransmitPacketCount(50);
-                ncStats.setCollisionCount(2);
-
-                Assert.assertTrue(ncStats.getCollisionCount() == 2);
-                Assert.assertTrue(ncStats.getTransmitPacketCount() == 50);
-                Assert.assertTrue(ncStats.getTransmitErrorCount() == 18);
-                Assert.assertTrue(ncStats.getTransmitDropCount() == 15);
-                Assert.assertTrue(ncStats.getReceivePacketCount() == 100);
-                Assert.assertTrue(ncStats.getReceiveOverRunErrorCount() == 30);
-                Assert.assertTrue(ncStats.getReceiveFrameErrorCount() == 25);
-                Assert.assertTrue(ncStats.getReceiveDropCount() == 5);
-                Assert.assertTrue(ncStats.getReceiveCRCErrorCount() == 10);
-                Assert.assertTrue(ncStats.getReceiveByteCount() == 800);
-                Assert.assertTrue(ncStats.getNodeConnector().equals(nc));
-        }
-}
diff --git a/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/reader/NodeDescriptionTest.java b/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/reader/NodeDescriptionTest.java
deleted file mode 100644 (file)
index c41c154..0000000
+++ /dev/null
@@ -1,39 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.reader;
-
-import org.junit.Assert;
-import org.junit.Test;
-
-public class NodeDescriptionTest {
-
-        @Test
-        public void testNodeDescriptionMethods() {
-                NodeDescription ncDesc = new NodeDescription();
-                ncDesc.setHardware("Hardware1");
-                ncDesc.setManufacturer("Manufacturer1");
-                ncDesc.setDescription("SDNProtocol1");
-                ncDesc.setSerialNumber("serialNumber1");
-                ncDesc.setSoftware("Software1");
-
-                Assert.assertTrue(ncDesc.getHardware().equals("Hardware1"));
-                Assert.assertTrue(ncDesc.getManufacturer().equals("Manufacturer1"));
-                Assert.assertTrue(ncDesc.getDescription().equals("SDNProtocol1"));
-                Assert.assertTrue(ncDesc.getSerialNumber().equals("serialNumber1"));
-                Assert.assertTrue(ncDesc.getSoftware().equals("Software1"));
-
-                Assert.assertFalse(ncDesc.getHardware().equals("Hardware2"));
-                Assert.assertFalse(ncDesc.getManufacturer().equals("Manufacturer2"));
-                Assert.assertFalse(ncDesc.getDescription().equals("SDNProtocol2"));
-                Assert.assertFalse(ncDesc.getSerialNumber().equals("serialNumber2"));
-                Assert.assertFalse(ncDesc.getSoftware().equals("Software2"));
-
-        }
-}
diff --git a/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/reader/NodeTableStatisticsTest.java b/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/reader/NodeTableStatisticsTest.java
deleted file mode 100644 (file)
index a29d426..0000000
+++ /dev/null
@@ -1,37 +0,0 @@
-/*
- * Copyright (c) 2013 Big Switch Networks, Inc.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.sal.reader;
-
-import org.junit.Assert;
-import org.junit.Test;
-import org.opendaylight.controller.sal.core.NodeTable;
-import org.opendaylight.controller.sal.utils.NodeCreator;
-import org.opendaylight.controller.sal.utils.NodeTableCreator;
-
-public class NodeTableStatisticsTest {
-
-    @Test
-    public void testNodeTableStatisticsMethods() {
-        NodeTable nt = NodeTableCreator.createNodeTable(Byte.valueOf("2") , NodeCreator.createOFNode((long)20));
-        NodeTableStatistics ntStats = new NodeTableStatistics();
-
-        ntStats.setNodeTable(nt);
-        ntStats.setActiveCount(100);
-        ntStats.setLookupCount(200);
-        ntStats.setMatchedCount(500);
-        ntStats.setMaximumEntries(1000);
-        ntStats.setName("Test");
-
-        Assert.assertTrue(ntStats.getNodeTable().equals(nt));
-        Assert.assertTrue(ntStats.getActiveCount() == 100);
-        Assert.assertTrue(ntStats.getLookupCount() == 200);
-        Assert.assertTrue(ntStats.getMatchedCount() == 500);
-        Assert.assertTrue(ntStats.getMaximumEntries() == 1000);
-        Assert.assertTrue(ntStats.getName().equals("Test"));
-    }
-}
diff --git a/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/utils/EtherTypesTest.java b/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/utils/EtherTypesTest.java
deleted file mode 100644 (file)
index 5beb871..0000000
+++ /dev/null
@@ -1,71 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.utils;
-
-import java.util.ArrayList;
-import org.junit.Assert;
-import org.junit.Test;
-
-public class EtherTypesTest {
-
-        @Test
-        public void testEthertypesCreation() {
-
-                EtherTypes arp = EtherTypes.ARP;
-
-                Assert.assertTrue(arp.toString().equals("ARP"));
-                Assert.assertTrue(arp.intValue() == 2054);
-                Assert.assertTrue(arp.shortValue() == (short)2054);
-        }
-
-        @Test
-        public void testGetEtherTypesString() {
-
-                Assert.assertTrue(EtherTypes.getEtherTypeName(34984).equals("QINQ"));
-                Assert.assertTrue(EtherTypes.getEtherTypeName((short)2048).equals("IPv4"));
-                Assert.assertTrue(EtherTypes.getEtherTypeName(0x010B).equals("PVSTP"));
-
-                Assert.assertFalse(EtherTypes.getEtherTypeName(0x800).equals("ARP"));
-        }
-
-        @Test
-        public void testGetEtherTypesNumber() {
-                Assert.assertTrue(EtherTypes.getEtherTypeNumberInt("VLAN Tagged") == 33024);
-                Assert.assertTrue(EtherTypes.getEtherTypeNumberShort("ARP") == 2054);
-
-                Assert.assertFalse(EtherTypes.getEtherTypeNumberInt("CDP") == 1000);
-        }
-
-        @Test
-        public void testGetEtherTypesList() {
-                ArrayList<String> etherTypeNames = (ArrayList<String>) EtherTypes.getEtherTypesNameList();
-                Assert.assertTrue(etherTypeNames.get(0).equals("PVSTP"));
-                Assert.assertTrue(etherTypeNames.get(1).equals("CDP"));
-                Assert.assertTrue(etherTypeNames.get(2).equals("VTP"));
-                Assert.assertTrue(etherTypeNames.get(3).equals("IPv4"));
-                Assert.assertTrue(etherTypeNames.get(4).equals("ARP"));
-                Assert.assertTrue(etherTypeNames.get(5).equals("Reverse ARP"));
-                Assert.assertTrue(etherTypeNames.get(6).equals("VLAN Tagged"));
-                Assert.assertTrue(etherTypeNames.get(7).equals("IPv6"));
-                Assert.assertTrue(etherTypeNames.get(8).equals("MPLS Unicast"));
-                Assert.assertTrue(etherTypeNames.get(9).equals("MPLS Multicast"));
-                Assert.assertTrue(etherTypeNames.get(10).equals("QINQ"));
-                Assert.assertTrue(etherTypeNames.get(11).equals("LLDP"));
-                Assert.assertTrue(etherTypeNames.get(12).equals("Old QINQ"));
-                Assert.assertTrue(etherTypeNames.get(13).equals("Cisco QINQ"));
-        }
-
-        @Test
-        public void testGetEtherTypesloadFromString() {
-                Assert.assertTrue(EtherTypes.loadFromString("37376").equals(EtherTypes.CISCOQINQ));
-                Assert.assertTrue(EtherTypes.loadFromString("100") == null);
-        }
-
-}
diff --git a/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/utils/HexEncodeTest.java b/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/utils/HexEncodeTest.java
deleted file mode 100644 (file)
index 3cfa747..0000000
+++ /dev/null
@@ -1,67 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.utils;
-
-import org.junit.Assert;
-import org.junit.Test;
-
-public class HexEncodeTest {
-
-        @Test
-        public void testbytesToHexString() {
-                byte[] bytes1 = {(byte)0x01, (byte)0x02, (byte)0x03};
-                String str1 = HexEncode.bytesToHexString(bytes1);
-                Assert.assertTrue(str1.equals("010203"));
-
-                byte[] bytes2 = {(byte)0x11, (byte)0x22, (byte)0x33};
-                String str2 = HexEncode.bytesToHexString(bytes2);
-                Assert.assertFalse(str2.equals("010203"));
-
-        }
-
-        @Test
-        public void testLongToHexString() {
-                long value1 = 12345678L;
-                String str1 = HexEncode.longToHexString(value1);
-                Assert.assertTrue(str1.equals("00:00:00:00:00:bc:61:4e"));
-
-                long value2 = 98765432L;
-                String str2 = HexEncode.longToHexString(value2);
-                Assert.assertFalse(str2.equals("00:44:33:22:11:bc:61:4e"));
-
-        }
-
-        @Test
-        public void testBytesFromHexString() {
-                String byteStr1 = "00:11:22:33:44:55";
-                byte byteArray1[] = new byte[(byteStr1.length() + 1)/3];
-                byteArray1 = HexEncode.bytesFromHexString(byteStr1);
-
-                Assert.assertTrue(byteArray1[0] == (byte)0x0);
-                Assert.assertTrue(byteArray1[1] == (byte)0x11);
-                Assert.assertTrue(byteArray1[2] == (byte)0x22);
-                Assert.assertTrue(byteArray1[3] == (byte)0x33);
-                Assert.assertTrue(byteArray1[4] == (byte)0x44);
-                Assert.assertTrue(byteArray1[5] == (byte)0x55);
-
-                String byteStr2 = "00:11:22:33:44:55";
-                byte byteArray2[] = new byte[(byteStr2.length() + 1)/3];
-                byteArray2 = HexEncode.bytesFromHexString(byteStr2);
-
-                Assert.assertFalse(byteArray2[0] == (byte)0x55);
-                Assert.assertFalse(byteArray2[1] == (byte)0x44);
-                Assert.assertFalse(byteArray2[2] == (byte)0x33);
-                Assert.assertFalse(byteArray2[3] == (byte)0x22);
-                Assert.assertFalse(byteArray2[4] == (byte)0x11);
-                Assert.assertFalse(byteArray2[5] == (byte)0x0);
-
-        }
-
-}
diff --git a/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/utils/IPProtocolsTest.java b/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/utils/IPProtocolsTest.java
deleted file mode 100644 (file)
index 0851c60..0000000
+++ /dev/null
@@ -1,111 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.sal.utils;
-
-import static org.junit.Assert.assertEquals;
-import static org.junit.Assert.assertTrue;
-
-import org.junit.Test;
-
-/**
- * @author ykhodork
- *
- */
-public class IPProtocolsTest {
-
-    static short shortVal = 1;
-    static int   intVal = 1;
-    static byte  byteVal = 1;
-
-    /**
-     * Test method for {@link org.opendaylight.controller.sal.utils.IPProtocols#getProtocolName(int)}.
-     */
-    @Test
-    public void testGetProtocolNameInt() {
-        assertEquals("ICMP", IPProtocols.getProtocolName(1));
-        assertEquals("0x4d2", IPProtocols.getProtocolName(1234));
-    }
-
-    /**
-     * Test method for {@link org.opendaylight.controller.sal.utils.IPProtocols#getProtocolName(short)}.
-     */
-    @Test
-    public void testGetProtocolNameShort() {
-        assertEquals("ICMP", IPProtocols.getProtocolName(shortVal));
-    }
-
-    /**
-     * Test method for {@link org.opendaylight.controller.sal.utils.IPProtocols#getProtocolName(byte)}.
-     */
-    @Test
-    public void testGetProtocolNameByte() {
-        assertEquals("ICMP", IPProtocols.getProtocolName(byteVal));
-    }
-
-    /**
-     * Test method for {@link org.opendaylight.controller.sal.utils.IPProtocols#getProtocolNumberShort(java.lang.String)}.
-     */
-    @Test
-    public void testGetProtocolNumberShort() {
-        assertEquals(shortVal, IPProtocols.getProtocolNumberShort("ICMP"));
-    }
-
-    /**
-     * Test method for {@link org.opendaylight.controller.sal.utils.IPProtocols#getProtocolNumberInt(java.lang.String)}.
-     */
-    @Test
-    public void testGetProtocolNumberInt() {
-        assertEquals(intVal, IPProtocols.getProtocolNumberInt("ICMP"));
-    }
-
-    /**
-     * Test method for {@link org.opendaylight.controller.sal.utils.IPProtocols#getProtocolNumberByte(java.lang.String)}.
-     */
-    @Test
-    public void testGetProtocolNumberByte() {
-        assertEquals(byteVal, IPProtocols.getProtocolNumberByte("ICMP"));
-    }
-
-    /**
-     * Test method for {@link org.opendaylight.controller.sal.utils.IPProtocols#fromString(java.lang.String)}.
-     */
-    @Test
-    public void testFromString() {
-        assertTrue(null == IPProtocols.fromString("Not a protocol"));
-        assertTrue(null == IPProtocols.fromString("0xFFF"));
-        assertTrue(null == IPProtocols.fromString("-2"));
-
-        assertTrue(IPProtocols.ANY == IPProtocols.fromString("any"));
-        assertTrue(IPProtocols.ANY == IPProtocols.fromString("ANY"));
-        assertTrue(IPProtocols.ANY == IPProtocols.fromString("*"));
-        assertTrue(IPProtocols.ANY == IPProtocols.fromString(null));
-
-        assertTrue(IPProtocols.TCP == IPProtocols.fromString("TCP"));
-        assertTrue(IPProtocols.TCP == IPProtocols.fromString("tcp"));
-        assertTrue(IPProtocols.UDP == IPProtocols.fromString("0x11"));
-        assertTrue(IPProtocols.UDP == IPProtocols.fromString("0X11"));
-
-    }
-
-}
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/utils/NetUtilsTest.java b/opendaylight/adsal/sal/api/src/test/java/org/opendaylight/controller/sal/utils/NetUtilsTest.java
deleted file mode 100644 (file)
index e5e0a09..0000000
+++ /dev/null
@@ -1,502 +0,0 @@
-/*
- * Copyright (c) 2013-2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.utils;
-
-import java.net.InetAddress;
-import java.net.UnknownHostException;
-import java.util.Arrays;
-
-import org.junit.Assert;
-import org.junit.Test;
-
-public class NetUtilsTest {
-
-    @Test
-    public void testByteArrayMethods() {
-        int ip = 8888;
-        Assert.assertTrue(NetUtils
-                .byteArray4ToInt(NetUtils.intToByteArray4(ip)) == ip);
-
-        ip = 0xffffffff;
-        Assert.assertTrue(NetUtils
-                .byteArray4ToInt(NetUtils.intToByteArray4(ip)) == ip);
-
-        ip = 0;
-        Assert.assertTrue(NetUtils
-                .byteArray4ToInt(NetUtils.intToByteArray4(ip)) == ip);
-
-        ip = 0x1fffffff;
-        Assert.assertTrue(NetUtils
-                .byteArray4ToInt(NetUtils.intToByteArray4(ip)) == ip);
-
-        ip = 0xfffffff;
-        Assert.assertTrue(NetUtils
-                .byteArray4ToInt(NetUtils.intToByteArray4(ip)) == ip);
-
-        ip = 0xf000ffff;
-        Assert.assertTrue(NetUtils
-                .byteArray4ToInt(NetUtils.intToByteArray4(ip)) == ip);
-
-        byte ba[] = { (byte) 0xf, (byte) 0xf, (byte) 0xf, (byte) 0xff };
-        Assert.assertTrue(Arrays.equals(ba, NetUtils.intToByteArray4(NetUtils
-                .byteArray4ToInt(ba))));
-
-        byte ba1[] = { (byte) 255, (byte) 255, (byte) 255, (byte) 255 };
-        Assert.assertTrue(Arrays.equals(ba1, NetUtils.intToByteArray4(NetUtils
-                .byteArray4ToInt(ba1))));
-
-        byte ba2[] = { (byte) 255, (byte) 0, (byte) 0, (byte) 0 };
-        Assert.assertTrue(Arrays.equals(ba2, NetUtils.intToByteArray4(NetUtils
-                .byteArray4ToInt(ba2))));
-
-        byte ba3[] = { (byte) 0, (byte) 0, (byte) 0, (byte) 0 };
-        Assert.assertTrue(Arrays.equals(ba3, NetUtils.intToByteArray4(NetUtils
-                .byteArray4ToInt(ba3))));
-
-        byte ba4[] = { (byte) 255, (byte) 128, (byte) 0, (byte) 0 };
-        Assert.assertTrue(Arrays.equals(ba4, NetUtils.intToByteArray4(NetUtils
-                .byteArray4ToInt(ba4))));
-    }
-
-    @Test
-    public void testByteArrayMethodsForLong() {
-        // Test of longToByteArray6 method.
-        byte ba[] = {
-            (byte) 0x11, (byte) 0x22, (byte) 0x33, (byte) 0x44,
-            (byte) 0x55, (byte) 0x66
-        };
-        long mac = 0x112233445566L;
-        Assert.assertTrue(Arrays.equals(ba, NetUtils.longToByteArray6(mac)));
-
-        byte ba1[] = {
-            (byte) 0xff, (byte) 0xff, (byte) 0xff, (byte) 0xff,
-            (byte) 0xff, (byte) 0xff
-        };
-        long mac1 = 0xffffffffffffL;
-        Assert.assertTrue(Arrays.equals(ba1, NetUtils.longToByteArray6(mac1)));
-
-        byte ba2[] = {
-            (byte) 0x00, (byte) 0x00, (byte) 0x00, (byte) 0x00,
-            (byte) 0x00, (byte) 0x00
-        };
-        long mac2 = 0x000000000000L;
-        Assert.assertTrue(Arrays.equals(ba2, NetUtils.longToByteArray6(mac2)));
-
-        byte ba3[] = {
-            (byte) 0xff, (byte) 0xff, (byte) 0xff, (byte) 0x00,
-            (byte) 0x00, (byte) 0x00
-        };
-        long mac3 = 0xffffff000000L;
-        Assert.assertTrue(Arrays.equals(ba3, NetUtils.longToByteArray6(mac3)));
-
-        byte ba4[] = {
-            (byte) 0x00, (byte) 0x00, (byte) 0x00, (byte) 0xff,
-            (byte) 0xff, (byte) 0xff
-        };
-        long mac4 = 0x000000ffffffL;
-        Assert.assertTrue(Arrays.equals(ba4, NetUtils.longToByteArray6(mac4)));
-
-        // Convert a long number to a byte array,
-        // and revert it to the long number again.
-        Assert.assertTrue(NetUtils
-                .byteArray6ToLong(NetUtils.longToByteArray6(mac)) == mac);
-
-        Assert.assertTrue(NetUtils
-                .byteArray6ToLong(NetUtils.longToByteArray6(mac1)) == mac1);
-
-        Assert.assertTrue(NetUtils
-                .byteArray6ToLong(NetUtils.longToByteArray6(mac2)) == mac2);
-
-        Assert.assertTrue(NetUtils
-                .byteArray6ToLong(NetUtils.longToByteArray6(mac3)) == mac3);
-
-        Assert.assertTrue(NetUtils
-                .byteArray6ToLong(NetUtils.longToByteArray6(mac4)) == mac4);
-
-        // Convert a byte array to a long nubmer,
-        // and revert it to the byte array again.
-        Assert.assertTrue(Arrays.equals(ba,
-                    NetUtils.longToByteArray6(NetUtils.byteArray6ToLong(ba))));
-
-        Assert.assertTrue(Arrays.equals(ba1,
-                    NetUtils.longToByteArray6(NetUtils.byteArray6ToLong(ba1))));
-
-        Assert.assertTrue(Arrays.equals(ba2,
-                    NetUtils.longToByteArray6(NetUtils.byteArray6ToLong(ba2))));
-
-        Assert.assertTrue(Arrays.equals(ba3,
-                    NetUtils.longToByteArray6(NetUtils.byteArray6ToLong(ba3))));
-
-        Assert.assertTrue(Arrays.equals(ba4,
-                    NetUtils.longToByteArray6(NetUtils.byteArray6ToLong(ba4))));
-
-        // Test of paramter validation of byteArray6ToLong method.
-        byte array5[] = {
-            (byte) 0x11, (byte) 0x22, (byte) 0x33, (byte) 0x44
-        };
-        Assert.assertEquals(0, NetUtils.byteArray6ToLong(array5));
-
-        byte array7[] = {
-            (byte) 0x11, (byte) 0x22, (byte) 0x33, (byte) 0x44,
-            (byte) 0x55, (byte) 0x66, (byte) 0x77
-        };
-        Assert.assertEquals(0, NetUtils.byteArray6ToLong(array7));
-
-        byte arrayNull[] = null;
-        Assert.assertEquals(0, NetUtils.byteArray6ToLong(arrayNull));
-    }
-
-    @Test
-    public void testInetMethods() throws UnknownHostException {
-        int ip = 0xfffffff0;
-        InetAddress inet = InetAddress.getByName("255.255.255.240");
-        Assert.assertTrue(inet.equals(NetUtils.getInetAddress(ip)));
-
-        ip = 0;
-        inet = InetAddress.getByName("0.0.0.0");
-        Assert.assertTrue(inet.equals(NetUtils.getInetAddress(ip)));
-
-        ip = 0x9ffff09;
-        inet = InetAddress.getByName("9.255.255.9");
-        Assert.assertTrue(inet.equals(NetUtils.getInetAddress(ip)));
-    }
-
-    @Test
-    public void testMasksV4() throws UnknownHostException {
-
-        InetAddress mask = InetAddress.getByName("128.0.0.0");
-        Assert.assertTrue(mask.equals(NetUtils.getInetNetworkMask(1, false)));
-
-        mask = InetAddress.getByName("192.0.0.0");
-        Assert.assertTrue(mask.equals(NetUtils.getInetNetworkMask(2, false)));
-
-        mask = InetAddress.getByName("224.0.0.0");
-        Assert.assertTrue(mask.equals(NetUtils.getInetNetworkMask(3, false)));
-
-        mask = InetAddress.getByName("240.0.0.0");
-        Assert.assertTrue(mask.equals(NetUtils.getInetNetworkMask(4, false)));
-
-        mask = InetAddress.getByName("248.0.0.0");
-        Assert.assertTrue(mask.equals(NetUtils.getInetNetworkMask(5, false)));
-
-        mask = InetAddress.getByName("252.0.0.0");
-        Assert.assertTrue(mask.equals(NetUtils.getInetNetworkMask(6, false)));
-
-        mask = InetAddress.getByName("254.0.0.0");
-        Assert.assertTrue(mask.equals(NetUtils.getInetNetworkMask(7, false)));
-
-        mask = InetAddress.getByName("255.0.0.0");
-        Assert.assertTrue(mask.equals(NetUtils.getInetNetworkMask(8, false)));
-
-        mask = InetAddress.getByName("255.128.0.0");
-        Assert.assertTrue(mask.equals(NetUtils.getInetNetworkMask(9, false)));
-
-        mask = InetAddress.getByName("255.192.0.0");
-        Assert.assertTrue(mask.equals(NetUtils.getInetNetworkMask(10, false)));
-
-        mask = InetAddress.getByName("255.224.0.0");
-        Assert.assertTrue(mask.equals(NetUtils.getInetNetworkMask(11, false)));
-
-        mask = InetAddress.getByName("255.240.0.0");
-        Assert.assertTrue(mask.equals(NetUtils.getInetNetworkMask(12, false)));
-
-        mask = InetAddress.getByName("255.248.0.0");
-        Assert.assertTrue(mask.equals(NetUtils.getInetNetworkMask(13, false)));
-
-        mask = InetAddress.getByName("255.252.0.0");
-        Assert.assertTrue(mask.equals(NetUtils.getInetNetworkMask(14, false)));
-
-        mask = InetAddress.getByName("255.254.0.0");
-        Assert.assertTrue(mask.equals(NetUtils.getInetNetworkMask(15, false)));
-
-        mask = InetAddress.getByName("255.255.0.0");
-        Assert.assertTrue(mask.equals(NetUtils.getInetNetworkMask(16, false)));
-
-        mask = InetAddress.getByName("255.255.128.0");
-        Assert.assertTrue(mask.equals(NetUtils.getInetNetworkMask(17, false)));
-
-        mask = InetAddress.getByName("255.255.192.0");
-        Assert.assertTrue(mask.equals(NetUtils.getInetNetworkMask(18, false)));
-
-        mask = InetAddress.getByName("255.255.224.0");
-        Assert.assertTrue(mask.equals(NetUtils.getInetNetworkMask(19, false)));
-
-        mask = InetAddress.getByName("255.255.240.0");
-        Assert.assertTrue(mask.equals(NetUtils.getInetNetworkMask(20, false)));
-
-        mask = InetAddress.getByName("255.255.248.0");
-        Assert.assertTrue(mask.equals(NetUtils.getInetNetworkMask(21, false)));
-
-        mask = InetAddress.getByName("255.255.252.0");
-        Assert.assertTrue(mask.equals(NetUtils.getInetNetworkMask(22, false)));
-
-        mask = InetAddress.getByName("255.255.254.0");
-        Assert.assertTrue(mask.equals(NetUtils.getInetNetworkMask(23, false)));
-
-        mask = InetAddress.getByName("255.255.255.0");
-        Assert.assertTrue(mask.equals(NetUtils.getInetNetworkMask(24, false)));
-
-        mask = InetAddress.getByName("255.255.255.128");
-        Assert.assertTrue(mask.equals(NetUtils.getInetNetworkMask(25, false)));
-
-        mask = InetAddress.getByName("255.255.255.192");
-        Assert.assertTrue(mask.equals(NetUtils.getInetNetworkMask(26, false)));
-
-        mask = InetAddress.getByName("255.255.255.224");
-        Assert.assertTrue(mask.equals(NetUtils.getInetNetworkMask(27, false)));
-
-        mask = InetAddress.getByName("255.255.255.240");
-        Assert.assertTrue(mask.equals(NetUtils.getInetNetworkMask(28, false)));
-
-        mask = InetAddress.getByName("255.255.255.248");
-        Assert.assertTrue(mask.equals(NetUtils.getInetNetworkMask(29, false)));
-
-        mask = InetAddress.getByName("255.255.255.252");
-        Assert.assertTrue(mask.equals(NetUtils.getInetNetworkMask(30, false)));
-
-        mask = InetAddress.getByName("255.255.255.254");
-        Assert.assertTrue(mask.equals(NetUtils.getInetNetworkMask(31, false)));
-
-        mask = InetAddress.getByName("255.255.255.255");
-        Assert.assertTrue(mask.equals(NetUtils.getInetNetworkMask(32, false)));
-    }
-
-    @Test
-    public void testMasksV6() throws UnknownHostException {
-
-        InetAddress mask = InetAddress.getByName("ff00::0");
-        Assert.assertTrue(mask.equals(NetUtils.getInetNetworkMask(8, true)));
-
-        mask = InetAddress.getByName("8000::0");
-        Assert.assertTrue(mask.equals(NetUtils.getInetNetworkMask(1, true)));
-
-        mask = InetAddress.getByName("f800::0");
-        Assert.assertTrue(mask.equals(NetUtils.getInetNetworkMask(5, true)));
-
-        mask = InetAddress.getByName("ffff:ffff:ffff:ffff:ffff:ffff:ffff:fffe");
-        Assert.assertTrue(mask.equals(NetUtils.getInetNetworkMask(127, true)));
-    }
-
-    @Test
-    public void testGetSubnetLen() {
-
-        byte address[] = { (byte) 128, (byte) 0, (byte) 0, 0 };
-        Assert.assertTrue(NetUtils.getSubnetMaskLength(address) == 1);
-
-        byte address1[] = { (byte) 255, 0, 0, 0 };
-        Assert.assertTrue(NetUtils.getSubnetMaskLength(address1) == 8);
-
-        byte address2[] = { (byte) 255, (byte) 255, (byte) 248, 0 };
-        Assert.assertTrue(NetUtils.getSubnetMaskLength(address2) == 21);
-
-        byte address4[] = { (byte) 255, (byte) 255, (byte) 255, (byte) 254 };
-        Assert.assertTrue(NetUtils.getSubnetMaskLength(address4) == 31);
-
-        byte address5[] = { (byte) 255, (byte) 255, (byte) 255, (byte) 255, (byte) 255, (byte) 255, (byte) 255,
-                (byte) 255, (byte) 255, (byte) 255, (byte) 255, (byte) 255, (byte) 255, (byte) 255, (byte) 255,
-                (byte) 255 };
-        Assert.assertTrue(NetUtils.getSubnetMaskLength(address5) == 128);
-
-        byte address6[] = { (byte) 255, (byte) 255, (byte) 255, (byte) 255, (byte) 255, (byte) 255, (byte) 255,
-                (byte) 255, (byte) 255, (byte) 255, (byte) 255, (byte) 255, (byte) 255, (byte) 255, (byte) 255,
-                (byte) 254 };
-        Assert.assertTrue(NetUtils.getSubnetMaskLength(address6) == 127);
-
-        byte address7[] = { (byte) 255, (byte) 255, (byte) 255, (byte) 255, (byte) 255, (byte) 255, (byte) 255,
-                (byte) 255, (byte) 0, (byte) 0, (byte) 0, (byte) 0, (byte) 0, (byte) 0, (byte) 0, (byte) 0 };
-        Assert.assertTrue(NetUtils.getSubnetMaskLength(address7) == 64);
-
-        byte address8[] = { (byte) 255, (byte) 255, (byte) 255, (byte) 255, (byte) 255, (byte) 255, (byte) 255,
-                (byte) 254, (byte) 0, (byte) 0, (byte) 0, (byte) 0, (byte) 0, (byte) 0, (byte) 0, (byte) 0 };
-        Assert.assertTrue(NetUtils.getSubnetMaskLength(address8) == 63);
-
-        byte address9[] = { (byte) 255, (byte) 255, (byte) 255, (byte) 255, (byte) 255, (byte) 255, (byte) 128,
-                (byte) 0, (byte) 0, (byte) 0, (byte) 0, (byte) 0, (byte) 0, (byte) 0, (byte) 0, (byte) 0 };
-        Assert.assertTrue(NetUtils.getSubnetMaskLength(address9) == 49);
-
-        byte address10[] = { (byte) 128, (byte) 0, (byte) 0, (byte) 0, (byte) 0, (byte) 0, (byte) 0, (byte) 0,
-                (byte) 0, (byte) 0, (byte) 0, (byte) 0, (byte) 0, (byte) 0, (byte) 0, (byte) 0 };
-        Assert.assertTrue(NetUtils.getSubnetMaskLength(address10) == 1);
-
-        byte address11[] = { (byte) 0, (byte) 0, (byte) 0, (byte) 0, (byte) 0, (byte) 0, (byte) 0, (byte) 0, (byte) 0,
-                (byte) 0, (byte) 0, (byte) 0, (byte) 0, (byte) 0, (byte) 0, (byte) 0 };
-        Assert.assertTrue(NetUtils.getSubnetMaskLength(address11) == 0);
-    }
-
-    @Test
-    public void testGetSubnetPrefix() throws UnknownHostException {
-        InetAddress ip = InetAddress.getByName("192.128.64.252");
-        int maskLen = 25;
-        Assert.assertTrue(NetUtils.getSubnetPrefix(ip, maskLen).equals(
-                InetAddress.getByName("192.128.64.128")));
-    }
-
-    @Test
-    public void testIsIPv6Valid() throws UnknownHostException {
-        Assert.assertTrue(NetUtils
-                .isIPv6AddressValid("fe80:0000:0000:0000:0204:61ff:fe9d:f156")); //normal ipv6
-        Assert.assertTrue(NetUtils
-                .isIPv6AddressValid("fe80:0:0:0:204:61ff:fe9d:f156")); //no leading zeroes
-        Assert.assertTrue(NetUtils
-                .isIPv6AddressValid("fe80::204:61ff:fe9d:f156")); //zeroes to ::
-        Assert
-                .assertTrue(NetUtils
-                        .isIPv6AddressValid("fe80:0000:0000:0000:0204:61ff:254.157.241.86")); // ipv4 ending
-        Assert.assertTrue(NetUtils
-                .isIPv6AddressValid("fe80:0:0:0:0204:61ff:254.157.241.86")); // no leading zeroes, ipv4 end
-        Assert.assertTrue(NetUtils
-                .isIPv6AddressValid("fe80::204:61ff:254.157.241.86")); // zeroes ::, no leading zeroes
-
-        Assert.assertTrue(NetUtils.isIPv6AddressValid("2001::")); //link-local prefix
-        Assert.assertTrue(NetUtils.isIPv6AddressValid("::1")); //localhost
-        Assert.assertTrue(NetUtils.isIPv6AddressValid("fe80::")); //global-unicast
-        Assert.assertFalse(NetUtils.isIPv6AddressValid("abcd")); //not valid
-        Assert.assertFalse(NetUtils.isIPv6AddressValid("1")); //not valid
-        Assert.assertFalse(NetUtils
-                .isIPv6AddressValid("fe80:0:0:0:204:61ff:fe9d")); //not valid, too short
-        Assert.assertFalse(NetUtils
-                .isIPv6AddressValid("fe80:::0:0:0:204:61ff:fe9d")); //not valid
-        Assert.assertFalse(NetUtils.isIPv6AddressValid("192.168.1.1")); //not valid,ipv4
-        Assert
-                .assertFalse(NetUtils
-                        .isIPv6AddressValid("2001:0000:1234:0000:10001:C1C0:ABCD:0876")); //not valid, extra number
-        Assert
-                .assertFalse(NetUtils
-                        .isIPv6AddressValid("20010:0000:1234:0000:10001:C1C0:ABCD:0876")); //not valid, extra number
-
-        Assert
-                .assertTrue(NetUtils
-                        .isIPv6AddressValid("2001:0DB8:0000:CD30:0000:0000:0000:0000/60")); //full with mask
-        Assert.assertTrue(NetUtils.isIPv6AddressValid("2001:0DB8:0:CD30::/64")); //shortened with mask
-        Assert.assertTrue(NetUtils.isIPv6AddressValid("2001:0DB8:0:CD30::/0")); //0 subnet with mask
-        Assert.assertTrue(NetUtils.isIPv6AddressValid("::1/128")); //localhost 128 mask
-
-        Assert.assertFalse(NetUtils.isIPv6AddressValid("124.15.6.89/60")); //invalid, ip with mask
-        Assert
-                .assertFalse(NetUtils
-                        .isIPv6AddressValid("2001:0DB8:0000:CD30:0000:0000:0000:0000/130")); //invalid, mask >128
-        Assert
-                .assertFalse(NetUtils
-                        .isIPv6AddressValid("2001:0DB8:0:CD30::/-5")); //invalid, mask < 0
-        Assert.assertFalse(NetUtils
-                .isIPv6AddressValid("fe80:::0:0:0:204:61ff:fe9d/64")); //not valid ip, valid netmask
-        Assert.assertFalse(NetUtils
-                .isIPv6AddressValid("fe80:::0:0:0:204:61ff:fe9d/-1")); //not valid both
-
-    }
-
-    @Test
-    public void testInetAddressConflict() throws UnknownHostException {
-
-        // test a ipv4 testAddress in the same subnet as the filter
-        // the method should return false as there is no conflict
-        Assert.assertFalse(NetUtils.inetAddressConflict(
-                InetAddress.getByName("9.9.1.1"),
-                InetAddress.getByName("9.9.1.0"), null,
-                InetAddress.getByName("255.255.255.0")));
-
-        // test a ipv4 testAddress not in the same subnet as the filter
-        // the method should return true as there is a conflict
-        Assert.assertTrue(NetUtils.inetAddressConflict(
-                InetAddress.getByName("9.9.2.1"),
-                InetAddress.getByName("9.9.1.0"), null,
-                InetAddress.getByName("255.255.255.0")));
-
-        // test a ipv4 testAddress more generic than the filter
-        // the method should return true as there is a conflict
-        Assert.assertTrue(NetUtils.inetAddressConflict(
-                InetAddress.getByName("9.9.1.1"),
-                InetAddress.getByName("9.9.1.0"),
-                InetAddress.getByName("255.255.0.0"),
-                InetAddress.getByName("255.255.255.0")));
-
-        // test a ipv4 testAddress less generic than the filter and in the same
-        // subnet as the filter
-        // the method should return false as there is no conflict
-        Assert.assertFalse(NetUtils.inetAddressConflict(
-                InetAddress.getByName("9.9.1.0"),
-                InetAddress.getByName("9.9.0.0"),
-                InetAddress.getByName("255.255.255.0"),
-                InetAddress.getByName("255.255.0.0")));
-
-        // test a ipv4 testAddress less generic than the filter and not in the
-        // same subnet as the filter
-        // the method should return true as there is a conflict
-        Assert.assertTrue(NetUtils.inetAddressConflict(
-                InetAddress.getByName("9.8.1.0"),
-                InetAddress.getByName("9.9.0.0"),
-                InetAddress.getByName("255.255.255.0"),
-                InetAddress.getByName("255.255.0.0")));
-
-    }
-
-    @Test
-    public void testIPAddressValidity() {
-        Assert.assertFalse(NetUtils.isIPAddressValid(null));
-        Assert.assertFalse(NetUtils.isIPAddressValid("abc"));
-        Assert.assertFalse(NetUtils.isIPAddressValid("1.1.1"));
-        Assert.assertFalse(NetUtils.isIPAddressValid("1.1.1.1/49"));
-
-        Assert.assertTrue(NetUtils.isIPAddressValid("1.1.1.1"));
-        Assert.assertTrue(NetUtils.isIPAddressValid("1.1.1.1/32"));
-        Assert.assertTrue(NetUtils
-                .isIPAddressValid("2001:420:281:1004:407a:57f4:4d15:c355"));
-    }
-
-    @Test
-    public void testGetUnsignedByte() {
-        Assert.assertEquals(0,   NetUtils.getUnsignedByte((byte) 0x00));
-        Assert.assertEquals(1,   NetUtils.getUnsignedByte((byte) 0x01));
-        Assert.assertEquals(127, NetUtils.getUnsignedByte((byte) 0x7f));
-
-        Assert.assertEquals(128, NetUtils.getUnsignedByte((byte) 0x80));
-        Assert.assertEquals(255, NetUtils.getUnsignedByte((byte) 0xff));
-    }
-
-    @Test
-    public void testGetUnsignedShort() {
-        Assert.assertEquals(0,     NetUtils.getUnsignedShort((short) 0x0000));
-        Assert.assertEquals(1,     NetUtils.getUnsignedShort((short) 0x0001));
-        Assert.assertEquals(32767, NetUtils.getUnsignedShort((short) 0x7fff));
-
-        Assert.assertEquals(32768, NetUtils.getUnsignedShort((short) 0x8000));
-        Assert.assertEquals(65535, NetUtils.getUnsignedShort((short) 0xffff));
-    }
-
-    @Test
-    public void testMulticastMACAddr() {
-        byte[] empty = new byte[0];
-        Assert.assertFalse(NetUtils.isUnicastMACAddr(empty));
-        Assert.assertFalse(NetUtils.isMulticastMACAddr(empty));
-
-        byte[] bcast = {
-            (byte)0xff, (byte)0xff, (byte)0xff,
-            (byte)0xff, (byte)0xff, (byte)0xff,
-        };
-        Assert.assertFalse(NetUtils.isUnicastMACAddr(bcast));
-        Assert.assertFalse(NetUtils.isMulticastMACAddr(bcast));
-
-        byte[] firstOctet = {
-            (byte)0x00, (byte)0x20, (byte)0x80, (byte)0xfe,
-        };
-        for (int len = 1; len <= 10; len++) {
-            byte[] ba = new byte[len];
-            boolean valid = (len == 6);
-            for (byte first: firstOctet) {
-                ba[0] = first;
-                Assert.assertFalse(NetUtils.isMulticastMACAddr(ba));
-                Assert.assertEquals(valid, NetUtils.isUnicastMACAddr(ba));
-
-                ba[0] |= (byte)0x01;
-                Assert.assertEquals(valid, NetUtils.isMulticastMACAddr(ba));
-                Assert.assertFalse(NetUtils.isUnicastMACAddr(ba));
-            }
-        }
-    }
-}
diff --git a/opendaylight/adsal/sal/connection/api/pom.xml b/opendaylight/adsal/sal/connection/api/pom.xml
deleted file mode 100644 (file)
index f9f5258..0000000
+++ /dev/null
@@ -1,54 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>sal.connection</artifactId>
-  <version>0.3.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Import-Package>org.slf4j,
-              org.osgi.framework,
-              org.apache.felix.dm,
-              org.apache.commons.lang3.tuple,
-              javax.xml.bind.annotation,
-              javax.xml.bind.annotation.adapters,
-              org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.sal.utils</Import-Package>
-            <Export-Package>org.opendaylight.controller.sal.connection</Export-Package>
-          </instructions>
-          <manifestLocation>${project.basedir}/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/sal/connection/api/src/main/java/org/opendaylight/controller/sal/connection/ConnectionConstants.java b/opendaylight/adsal/sal/connection/api/src/main/java/org/opendaylight/controller/sal/connection/ConnectionConstants.java
deleted file mode 100644 (file)
index aaa883b..0000000
+++ /dev/null
@@ -1,33 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.connection;
-
-/**
- * ConnectionConstants
- * Expand this enum as and when needed to support other connection parameters that
- * might be needed for certain protocol plugins.
- */
-public enum ConnectionConstants {
-    ADDRESS("address"),
-    PORT("port"),
-    PROTOCOL("protocol"),
-    USERNAME("username"),
-    PASSWORD("password");
-
-    private ConnectionConstants(String name) {
-        this.name = name;
-    }
-
-    private String name;
-
-    public String toString() {
-        return name;
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/sal/connection/api/src/main/java/org/opendaylight/controller/sal/connection/ConnectionLocality.java b/opendaylight/adsal/sal/connection/api/src/main/java/org/opendaylight/controller/sal/connection/ConnectionLocality.java
deleted file mode 100644 (file)
index 39dd80d..0000000
+++ /dev/null
@@ -1,35 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.sal.connection;
-
-public enum ConnectionLocality {
-    /**
-     * This controller is the (or one of the) master for a given node
-     */
-    LOCAL("This controller is the (or one of the) master for a given node"),
-
-    /**
-     * This controller is not the master for a given node
-     */
-    NOT_LOCAL("This controller is not the master for a given node"),
-
-    /**
-     * The given node is not connected to any of the controllers in the cluster
-     */
-    NOT_CONNECTED("The given node is not connected to any of the controllers in the cluster");
-
-    private ConnectionLocality(String description) {
-        this.description = description;
-    }
-
-    private String description;
-
-    public String toString() {
-        return description;
-    }
-}
diff --git a/opendaylight/adsal/sal/connection/api/src/main/java/org/opendaylight/controller/sal/connection/IConnectionListener.java b/opendaylight/adsal/sal/connection/api/src/main/java/org/opendaylight/controller/sal/connection/IConnectionListener.java
deleted file mode 100644 (file)
index 7ab3bb2..0000000
+++ /dev/null
@@ -1,15 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.connection;
-/**
- * This interface defines the methods the SAL service which relay the Connection
- * Notification events to the functional modules
- */
-public interface IConnectionListener extends IPluginOutConnectionService {
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/sal/connection/api/src/main/java/org/opendaylight/controller/sal/connection/IConnectionService.java b/opendaylight/adsal/sal/connection/api/src/main/java/org/opendaylight/controller/sal/connection/IConnectionService.java
deleted file mode 100644 (file)
index ff63cf7..0000000
+++ /dev/null
@@ -1,68 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.connection;
-
-import java.util.Map;
-
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.utils.Status;
-
-/**
- * Interface that defines the methods available to the functional modules that operate
- * above SAL for disconnecting or connecting to a particular node.
- */
-public interface IConnectionService {
-    /**
-     * Connect to a node with a specified node type.
-     *
-     * @param type Type of the node representing NodeIDType.
-     * @param connectionIdentifier Convenient identifier for the applications to make use of
-     * @param params Connection Params in Map format. This is entirely handled by the south-bound
-     * plugins and is an opaque value for SAL. Typical values keyed inside this params are
-     * Management IP-Address, Username, Password, Security Keys, etc...
-     *
-     * @return Node {@link org.opendaylight.controller.sal.core.Node}
-     */
-    public Node connect (String type, String connectionIdentifier, Map<ConnectionConstants, String> params);
-
-    /**
-     * Discover the node type and Connect to the first plugin that is able to connect with the specified parameters.
-     *
-     * @param type Type of the node representing NodeIDType.
-     * @param connectionIdentifier Convenient identifier for the applications to make use of
-     * @param params Connection Params in Map format. This is entirely handled by the south-bound
-     * plugins and is an opaque value for SAL. Typical values keyed inside this params are
-     * Management IP-Address, Username, Password, Security Keys, etc...
-     *
-     * @return Node {@link org.opendaylight.controller.sal.core.Node}
-     */
-    public Node connect (String connectionIdentifier, Map<ConnectionConstants, String> params);
-
-    /**
-     * Disconnect a Node that is connected to this Controller.
-     *
-     * @param node
-     *            the node {@link org.opendaylight.controller.sal.core.Node}
-     * @return Status {@link org.opendaylight.controller.sal.utils.Status}
-     */
-    public Status disconnect(Node node);
-
-    /**
-     * View Change notification
-     *
-     * @param node
-     *            the node {@link org.opendaylight.controller.sal.core.Node}
-     */
-    public void notifyNodeDisconnectFromMaster(Node node);
-
-    /**
-     * View Change notification
-     */
-    public void notifyClusterViewChanged();
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/sal/connection/api/src/main/java/org/opendaylight/controller/sal/connection/IPluginInConnectionService.java b/opendaylight/adsal/sal/connection/api/src/main/java/org/opendaylight/controller/sal/connection/IPluginInConnectionService.java
deleted file mode 100644 (file)
index f4e16fa..0000000
+++ /dev/null
@@ -1,53 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.connection;
-
-import java.util.Map;
-
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.utils.Status;
-
-/**
- * The interface describes methods to be implemented by protocol plugins
- */
-public interface IPluginInConnectionService {
-    /**
-     * Disconnect a Node that is connected to this Controller.
-     *
-     * @param node
-     *            the given node {@link org.opendaylight.controller.sal.core.Node}
-     */
-    public Status disconnect(Node node);
-
-    /**
-     * Connect to a node
-     *
-     * @param connectionIdentifier Convenient identifier for the applications to make use of
-     * @param params Connection Params in Map format. This is entirely handled by the south-bound
-     * plugins and is an opaque value for SAL. Typical values keyed inside this params are
-     * Management IP-Address, Username, Password, Security Keys, etc...
-     *
-     * @return Node
-     */
-    public Node connect (String connectionIdentifier, Map<ConnectionConstants, String> params);
-
-    /**
-     * View Change notification
-     */
-    public void notifyClusterViewChanged();
-
-    /**
-     * Node Disconnected from the node's master controller.
-     *
-     * @param node
-     *            the given node {@link org.opendaylight.controller.sal.core.Node}
-     */
-    public void notifyNodeDisconnectFromMaster(Node node);
-
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/sal/connection/api/src/main/java/org/opendaylight/controller/sal/connection/IPluginOutConnectionService.java b/opendaylight/adsal/sal/connection/api/src/main/java/org/opendaylight/controller/sal/connection/IPluginOutConnectionService.java
deleted file mode 100644 (file)
index 16e2154..0000000
+++ /dev/null
@@ -1,27 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.connection;
-
-import org.opendaylight.controller.sal.core.Node;
-
-/**
- * The interface describes methods to be implemented by SAL connection service
- */
-public interface IPluginOutConnectionService {
-    /**
-     * Method to test if a node is local to a controller.
-     *
-     * @param node
-     *            the given node {@link org.opendaylight.controller.sal.core.Node}
-     * @return true if node is local to this controller. false otherwise.
-     */
-    public boolean isLocal(Node node);
-
-    public ConnectionLocality getLocalityStatus(Node node);
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/sal/connection/implementation/pom.xml b/opendaylight/adsal/sal/connection/implementation/pom.xml
deleted file mode 100644 (file)
index b09a517..0000000
+++ /dev/null
@@ -1,61 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>sal.connection.implementation</artifactId>
-  <version>0.3.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal.connection</artifactId>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Import-Package>org.slf4j,
-              org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.sal.packet,
-              org.opendaylight.controller.sal.inventory,
-              org.opendaylight.controller.sal.flowprogrammer,
-              org.opendaylight.controller.sal.reader,
-              org.opendaylight.controller.sal.topology,
-              org.opendaylight.controller.sal.action,
-              org.opendaylight.controller.sal.match,
-              org.opendaylight.controller.sal.utils,
-              org.opendaylight.controller.sal.connection,
-              org.apache.felix.dm,
-              org.eclipse.osgi.framework.console,
-              org.osgi.framework</Import-Package>
-            <Export-Package></Export-Package>
-            <Bundle-Activator>org.opendaylight.controller.sal.connection.implementation.internal.Activator</Bundle-Activator>
-          </instructions>
-          <manifestLocation>${project.basedir}/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/sal/connection/implementation/src/main/java/org/opendaylight/controller/sal/connection/implementation/internal/Activator.java b/opendaylight/adsal/sal/connection/implementation/src/main/java/org/opendaylight/controller/sal/connection/implementation/internal/Activator.java
deleted file mode 100644 (file)
index c4e38a1..0000000
+++ /dev/null
@@ -1,65 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.connection.implementation.internal;
-
-import org.apache.felix.dm.Component;
-import org.opendaylight.controller.sal.connection.IConnectionListener;
-import org.opendaylight.controller.sal.connection.IConnectionService;
-import org.opendaylight.controller.sal.connection.IPluginInConnectionService;
-import org.opendaylight.controller.sal.connection.IPluginOutConnectionService;
-import org.opendaylight.controller.sal.core.ComponentActivatorAbstractBase;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-public class Activator extends ComponentActivatorAbstractBase {
-    protected static final Logger logger = LoggerFactory
-            .getLogger(Activator.class);
-
-    /**
-     * Function that is used to communicate to dependency manager the list of
-     * known Global implementations
-     *
-     *
-     * @return An array containing all the CLASS objects that will be
-     *         instantiated in order to get an fully working implementation
-     *         Object
-     */
-    public Object[] getGlobalImplementations() {
-        Object[] res = { ConnectionService.class};
-        return res;
-    }
-
-    /**
-     * Function that is called when configuration of the dependencies is required.
-     *
-     * @param c
-     *            dependency manager Component object, used for configuring the
-     *            dependencies exported and imported
-     * @param imp
-     *            Implementation class that is being configured, needed as long
-     *            as the same routine can configure multiple implementations
-     */
-    public void configureGlobalInstance(Component c, Object imp) {
-        if (imp.equals(ConnectionService.class)) {
-            c.setInterface(
-                    new String[] { IConnectionService.class.getName(),
-                                   IPluginOutConnectionService.class.getName() },
-                                   null);
-
-            c.add(createServiceDependency()
-                    .setService(IPluginInConnectionService.class)
-                    .setCallbacks("setPluginService", "unsetPluginService")
-                    .setRequired(false));
-            c.add(createServiceDependency()
-                    .setService(IConnectionListener.class)
-                    .setCallbacks("setListener", "unsetListener")
-                    .setRequired(false));
-        }
-    }
-}
diff --git a/opendaylight/adsal/sal/connection/implementation/src/main/java/org/opendaylight/controller/sal/connection/implementation/internal/ConnectionService.java b/opendaylight/adsal/sal/connection/implementation/src/main/java/org/opendaylight/controller/sal/connection/implementation/internal/ConnectionService.java
deleted file mode 100644 (file)
index c73607a..0000000
+++ /dev/null
@@ -1,165 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.connection.implementation.internal;
-
-import java.util.Map;
-import java.util.concurrent.ConcurrentHashMap;
-import java.util.concurrent.ConcurrentMap;
-import org.opendaylight.controller.sal.connection.ConnectionConstants;
-import org.opendaylight.controller.sal.connection.ConnectionLocality;
-import org.opendaylight.controller.sal.connection.IConnectionListener;
-import org.opendaylight.controller.sal.connection.IConnectionService;
-import org.opendaylight.controller.sal.connection.IPluginInConnectionService;
-import org.opendaylight.controller.sal.connection.IPluginOutConnectionService;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.utils.GlobalConstants;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.sal.utils.StatusCode;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-public class ConnectionService implements IPluginOutConnectionService, IConnectionService {
-    protected static final Logger logger = LoggerFactory
-            .getLogger(ConnectionService.class);
-    private IConnectionListener connectionListener;
-    private ConcurrentMap<String, IPluginInConnectionService> pluginService =
-            new ConcurrentHashMap<String, IPluginInConnectionService>();
-
-    void setPluginService (Map<?, ?> props, IPluginInConnectionService s) {
-        String type = null;
-        Object value = props.get(GlobalConstants.PROTOCOLPLUGINTYPE.toString());
-        if (value instanceof String) {
-            type = (String) value;
-        }
-        if (type == null) {
-            logger.error("Received a PluginInConnectionService without any "
-                    + "protocolPluginType provided");
-        } else {
-            this.pluginService.put(type, s);
-        }
-    }
-
-    void unsetPluginService(Map<?, ?> props, IPluginInConnectionService s) {
-        String type = null;
-
-        Object value = props.get(GlobalConstants.PROTOCOLPLUGINTYPE.toString());
-        if (value instanceof String) {
-            type = (String) value;
-        }
-        if (type == null) {
-            logger.error("Received a PluginInConnectionService without any "
-                    + "protocolPluginType provided");
-        } else if (this.pluginService.get(type).equals(s)) {
-            this.pluginService.remove(type);
-        }
-    }
-
-    void setListener(IConnectionListener s) {
-        this.connectionListener = s;
-    }
-
-    void unsetListener(IConnectionListener s) {
-        if (this.connectionListener == s) {
-            this.connectionListener = null;
-        }
-    }
-
-    /**
-     * Function called by the dependency manager when all the required
-     * dependencies are satisfied
-     *
-     */
-    void init() {
-    }
-
-    /**
-     * Function called by the dependency manager when at least one dependency
-     * become unsatisfied or when the component is shutting down because for
-     * example bundle is being stopped.
-     *
-     */
-    void destroy() {
-        connectionListener = null;
-        if (this.pluginService != null) {
-            this.pluginService.clear();
-        }
-    }
-
-    /**
-     * Method to test if a node is local to a controller.
-     *
-     * @return true if node is local to this controller. false otherwise.
-     */
-    public boolean isLocal(Node node) {
-        if (this.connectionListener == null) return false;
-        return connectionListener.isLocal(node);
-    }
-
-    @Override
-    public ConnectionLocality getLocalityStatus(Node node) {
-        if (this.connectionListener == null) {
-            return ConnectionLocality.NOT_CONNECTED;
-        }
-        return connectionListener.getLocalityStatus(node);
-    }
-
-    @Override
-    public Node connect (String type, String connectionIdentifier, Map<ConnectionConstants, String> params) {
-        IPluginInConnectionService s = pluginService.get(type);
-        if (s != null) {
-            return s.connect(connectionIdentifier, params);
-        }
-        return null;
-    }
-
-    @Override
-    public Node connect (String connectionIdentifier, Map<ConnectionConstants, String> params) {
-        synchronized (this.pluginService) {
-            for (String pluginType : this.pluginService.keySet()) {
-                IPluginInConnectionService s = pluginService.get(pluginType);
-                Node node = s.connect(connectionIdentifier, params);
-                if (node != null) {
-                    return node;
-                }
-            }
-        }
-        return null;
-    }
-
-    @Override
-    public Status disconnect(Node node) {
-        IPluginInConnectionService s = pluginService.get(node.getType());
-        if (s != null) {
-            return s.disconnect(node);
-        }
-        return new Status(StatusCode.NOTFOUND);
-    }
-
-    /**
-     * View Change notification
-     */
-    @Override
-    public void notifyClusterViewChanged() {
-        for (String pluginType : this.pluginService.keySet()) {
-            IPluginInConnectionService s = pluginService.get(pluginType);
-            s.notifyClusterViewChanged();
-        }
-    }
-
-    /**
-     * Node Disconnected from the node's master controller.
-     */
-    @Override
-    public void notifyNodeDisconnectFromMaster(Node node) {
-        IPluginInConnectionService s = pluginService.get(node.getType());
-        if (s != null) {
-             s.notifyNodeDisconnectFromMaster(node);
-        }
-    }
-}
diff --git a/opendaylight/adsal/sal/implementation/pom.xml b/opendaylight/adsal/sal/implementation/pom.xml
deleted file mode 100644 (file)
index 61c6acf..0000000
+++ /dev/null
@@ -1,66 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>sal.implementation</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>org.eclipse.osgi</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-      <scope>test</scope>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Import-Package>org.slf4j,
-              org.apache.commons.lang3.builder,
-              org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.sal.packet,
-              org.opendaylight.controller.sal.inventory,
-              org.opendaylight.controller.sal.flowprogrammer,
-              org.opendaylight.controller.sal.reader,
-              org.opendaylight.controller.sal.topology,
-              org.opendaylight.controller.sal.action,
-              org.opendaylight.controller.sal.match,
-              org.opendaylight.controller.sal.utils,
-              org.apache.felix.dm,
-              org.eclipse.osgi.framework.console,
-              org.osgi.framework</Import-Package>
-            <Export-Package></Export-Package>
-            <Bundle-Activator>org.opendaylight.controller.sal.implementation.internal.Activator</Bundle-Activator>
-          </instructions>
-          <manifestLocation>${project.basedir}/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/sal/implementation/src/main/java/org/opendaylight/controller/sal/implementation/internal/Activator.java b/opendaylight/adsal/sal/implementation/src/main/java/org/opendaylight/controller/sal/implementation/internal/Activator.java
deleted file mode 100644 (file)
index 98cb3b8..0000000
+++ /dev/null
@@ -1,220 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.implementation.internal;
-
-import java.util.Dictionary;
-import java.util.Hashtable;
-
-import org.apache.felix.dm.Component;
-import org.opendaylight.controller.sal.core.ComponentActivatorAbstractBase;
-import org.opendaylight.controller.sal.flowprogrammer.IFlowProgrammerListener;
-import org.opendaylight.controller.sal.flowprogrammer.IFlowProgrammerService;
-import org.opendaylight.controller.sal.flowprogrammer.IPluginInFlowProgrammerService;
-import org.opendaylight.controller.sal.flowprogrammer.IPluginOutFlowProgrammerService;
-import org.opendaylight.controller.sal.inventory.IInventoryService;
-import org.opendaylight.controller.sal.inventory.IListenInventoryUpdates;
-import org.opendaylight.controller.sal.inventory.IPluginInInventoryService;
-import org.opendaylight.controller.sal.inventory.IPluginOutInventoryService;
-import org.opendaylight.controller.sal.packet.IDataPacketService;
-import org.opendaylight.controller.sal.packet.IListenDataPacket;
-import org.opendaylight.controller.sal.packet.IPluginInDataPacketService;
-import org.opendaylight.controller.sal.packet.IPluginOutDataPacketService;
-import org.opendaylight.controller.sal.reader.IPluginInReadService;
-import org.opendaylight.controller.sal.reader.IPluginOutReadService;
-import org.opendaylight.controller.sal.reader.IReadService;
-import org.opendaylight.controller.sal.reader.IReadServiceListener;
-import org.opendaylight.controller.sal.topology.IListenTopoUpdates;
-import org.opendaylight.controller.sal.topology.IPluginInTopologyService;
-import org.opendaylight.controller.sal.topology.IPluginOutTopologyService;
-import org.opendaylight.controller.sal.topology.ITopologyService;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-public class Activator extends ComponentActivatorAbstractBase {
-    protected static final Logger logger = LoggerFactory
-            .getLogger(Activator.class);
-
-
-    /**
-     * Function that is used to communicate to dependency manager the list of
-     * known Global implementations
-     *
-     *
-     * @return An array containing all the CLASS objects that will be
-     *         instantiated in order to get an fully working implementation
-     *         Object
-     */
-    public Object[] getGlobalImplementations() {
-        Object[] res = { Inventory.class };
-        return res;
-    }
-
-    /**
-     * Function that is called when configuration of the dependencies is required.
-     *
-     * @param c
-     *            dependency manager Component object, used for configuring the
-     *            dependencies exported and imported
-     * @param imp
-     *            Implementation class that is being configured, needed as long
-     *            as the same routine can configure multiple implementations
-     */
-    public void configureGlobalInstance(Component c, Object imp) {
-        if (imp.equals(Inventory.class)) {
-            Dictionary<String, Object> props = new Hashtable<String, Object>();
-            props.put("scope", "Global");
-            // export the service
-            c.setInterface(
-                    new String[] { IPluginOutInventoryService.class.getName(),
-                            IInventoryService.class.getName() }, props);
-
-            // Now lets add a service dependency to make sure the
-            // provider of service exists
-            c.add(createServiceDependency()
-                    .setService(IListenInventoryUpdates.class, "(scope=Global)")
-                    .setCallbacks("setUpdateService", "unsetUpdateService")
-                    .setRequired(false));
-            c.add(createServiceDependency()
-                    .setService(IPluginInInventoryService.class, "(scope=Global)")
-                    .setCallbacks("setPluginService", "unsetPluginService")
-                    .setRequired(false));
-        }
-    }
-
-    /**
-     * Function that is used to communicate to dependency manager the list of
-     * known implementations for services inside a container
-     *
-     *
-     * @return An array containing all the CLASS objects that will be
-     *         instantiated in order to get an fully working implementation
-     *         Object
-     */
-    @Override
-    public Object[] getImplementations() {
-        Object[] res = { Topology.class, Inventory.class,
-                FlowProgrammerService.class, ReadService.class,
-                DataPacketService.class };
-        return res;
-    }
-
-    /**
-     * Function that is called when configuration of the dependencies is
-     * required.
-     *
-     * @param c
-     *            dependency manager Component object, used for configuring the
-     *            dependencies exported and imported
-     * @param imp
-     *            Implementation class that is being configured, needed as long
-     *            as the same routine can configure multiple implementations
-     * @param containerName
-     *            The containerName being configured, this allow also optional
-     *            per-container different behavior if needed, usually should not
-     *            be the case though.
-     */
-    @Override
-    public void configureInstance(Component c, Object imp, String containerName) {
-        if (imp.equals(Topology.class)) {
-            // export the service for Apps and Plugins
-            c.setInterface(
-                    new String[] { IPluginOutTopologyService.class.getName(),
-                            ITopologyService.class.getName() }, null);
-
-            // There can be multiple Topology listeners or there could
-            // be none, hence the dependency is optional
-            c.add(createContainerServiceDependency(containerName)
-                    .setService(IListenTopoUpdates.class)
-                    .setCallbacks("setUpdateService", "unsetUpdateService")
-                    .setRequired(false));
-
-            // There can be multiple southbound plugins or there could
-            // be none, the dependency is optional
-            c.add(createContainerServiceDependency(containerName)
-                    .setService(IPluginInTopologyService.class)
-                    .setCallbacks("setPluginService", "unsetPluginService")
-                    .setRequired(false));
-        }
-
-        if (imp.equals(Inventory.class)) {
-            // export the service
-            c.setInterface(
-                    new String[] { IPluginOutInventoryService.class.getName(),
-                            IInventoryService.class.getName() }, null);
-
-            // Now lets add a service dependency to make sure the
-            // provider of service exists
-            c.add(createContainerServiceDependency(containerName)
-                    .setService(IListenInventoryUpdates.class)
-                    .setCallbacks("setUpdateService", "unsetUpdateService")
-                    .setRequired(false));
-            c.add(createContainerServiceDependency(containerName)
-                    .setService(IPluginInInventoryService.class)
-                    .setCallbacks("setPluginService", "unsetPluginService")
-                    .setRequired(false));
-        }
-
-        if (imp.equals(FlowProgrammerService.class)) {
-            c.setInterface(
-                    new String[] { IFlowProgrammerService.class.getName(),
-                            IPluginOutFlowProgrammerService.class.getName() },
-                    null);
-
-            c.add(createServiceDependency()
-                    .setService(IPluginInFlowProgrammerService.class)
-                    .setCallbacks("setService", "unsetService")
-                    .setRequired(false));
-            c.add(createContainerServiceDependency(containerName)
-                    .setService(IFlowProgrammerListener.class)
-                    .setCallbacks("setListener", "unsetListener")
-                    .setRequired(false));
-        }
-
-        if (imp.equals(ReadService.class)) {
-            // export services
-            c.setInterface(new String[] {
-                    IReadService.class.getName(),IPluginOutReadService.class.getName()}, null);
-
-            // It is also the consumer of IPluginInReadService
-            c.add(createContainerServiceDependency(containerName)
-                    .setService(IPluginInReadService.class)
-                    .setCallbacks("setService", "unsetService")
-                    .setRequired(false));
-
-            //consumes plugins' reader updates
-            c.add(createContainerServiceDependency(containerName)
-                    .setService(IReadServiceListener.class)
-                    .setCallbacks("setReaderListener", "unsetReaderListener")
-                    .setRequired(false));
-
-        }
-
-        /************************/
-        /* DATA PACKET SERVICES */
-        /************************/
-        if (imp.equals(DataPacketService.class)) {
-            c.setInterface(
-                    new String[] { IPluginOutDataPacketService.class.getName(),
-                            IDataPacketService.class.getName() }, null);
-
-            // Optionally use PluginInDataService if any southbound
-            // protocol plugin exists
-            c.add(createContainerServiceDependency(containerName)
-                    .setService(IPluginInDataPacketService.class)
-                    .setCallbacks("setPluginInDataService",
-                            "unsetPluginInDataService").setRequired(false));
-
-            // Optionally listed to IListenDataPacket services
-            c.add(createContainerServiceDependency(containerName)
-                    .setService(IListenDataPacket.class)
-                    .setCallbacks("setListenDataPacket",
-                            "unsetListenDataPacket").setRequired(false));
-        }
-    }
-}
diff --git a/opendaylight/adsal/sal/implementation/src/main/java/org/opendaylight/controller/sal/implementation/internal/DataPacketService.java b/opendaylight/adsal/sal/implementation/src/main/java/org/opendaylight/controller/sal/implementation/internal/DataPacketService.java
deleted file mode 100644 (file)
index 6f23cc7..0000000
+++ /dev/null
@@ -1,473 +0,0 @@
-/*
- * Copyright (c) 2013-2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-/**
- * @file   DataPacketService.java
- *
- * @brief  Implementation of Data Packet services in SAL
- *
- * Implementation of Data Packet services in SAL
- */
-
-package org.opendaylight.controller.sal.implementation.internal;
-
-import java.util.Collections;
-import java.util.HashMap;
-import java.util.HashSet;
-import java.util.List;
-import java.util.Map;
-import java.util.Set;
-import java.util.concurrent.ConcurrentHashMap;
-import java.util.concurrent.CopyOnWriteArrayList;
-import java.util.concurrent.LinkedBlockingQueue;
-import java.util.concurrent.atomic.AtomicInteger;
-
-import org.opendaylight.controller.sal.core.ConstructionException;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.match.Match;
-import org.opendaylight.controller.sal.packet.Ethernet;
-import org.opendaylight.controller.sal.packet.IDataPacketService;
-import org.opendaylight.controller.sal.packet.IListenDataPacket;
-import org.opendaylight.controller.sal.packet.IPluginInDataPacketService;
-import org.opendaylight.controller.sal.packet.IPluginOutDataPacketService;
-import org.opendaylight.controller.sal.packet.LinkEncap;
-import org.opendaylight.controller.sal.packet.Packet;
-import org.opendaylight.controller.sal.packet.PacketResult;
-import org.opendaylight.controller.sal.packet.RawPacket;
-import org.opendaylight.controller.sal.utils.NetUtils;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-public class DataPacketService implements IPluginOutDataPacketService,
-        IDataPacketService {
-    private int TXMAXQUEUESIZE = 1000;
-    protected static final Logger logger = LoggerFactory
-            .getLogger(DataPacketService.class);
-    /**
-     * Database that associates one NodeIDType to the
-     * IPluginDataPacketService, in fact we expect that there will be
-     * one instance of IPluginDataPacketService for each southbound
-     * plugin.
-     * Using the ConcurrentHashMap because the threads that will be
-     * adding a new service, removing a service, going through all of
-     * them maybe different.
-     */
-    private ConcurrentHashMap<String, ProtocolService<IPluginInDataPacketService>>
-        pluginInDataService =
-        new ConcurrentHashMap<String, ProtocolService<IPluginInDataPacketService>>();
-    private Map<String, AtomicInteger> statistics = new HashMap<String, AtomicInteger>();
-
-    /**
-     * Queue for packets that need to be transmitted to Data Path
-     */
-    private LinkedBlockingQueue<RawPacket> txQueue = new LinkedBlockingQueue<RawPacket>(
-            TXMAXQUEUESIZE);
-    /**
-     * Transmission thread
-     */
-    private Thread txThread = new Thread(new TxLoop(),
-            "DataPacketService TX thread");
-
-    /**
-     * Representation of a Data Packet Listener including of its
-     * properties
-     */
-    private class DataPacketListener {
-        // Key fields
-        private String listenerName;
-        // Attribute fields
-        private IListenDataPacket listener;
-        private String dependency;
-        private Match match;
-
-        DataPacketListener(String name, IListenDataPacket s, String dependency,
-                Match match) {
-            this.listenerName = name;
-            this.listener = s;
-            this.dependency = dependency;
-            this.match = match;
-        }
-
-        @Override
-        public boolean equals(Object obj) {
-            if (this == obj)
-                return true;
-            if (obj == null)
-                return false;
-            if (getClass() != obj.getClass())
-                return false;
-            DataPacketListener other = (DataPacketListener) obj;
-            if (!getOuterType().equals(other.getOuterType()))
-                return false;
-            if (listenerName == null) {
-                if (other.listenerName != null)
-                    return false;
-            } else if (!listenerName.equals(other.listenerName))
-                return false;
-            return true;
-        }
-
-        @Override
-        public int hashCode() {
-            final int prime = 31;
-            int result = 1;
-            result = prime * result + getOuterType().hashCode();
-            result = prime * result
-                    + ((listenerName == null) ? 0 : listenerName.hashCode());
-            return result;
-        }
-
-        private DataPacketService getOuterType() {
-            return DataPacketService.this;
-        }
-    }
-
-    /**
-     * This very expensive version of List is being used because it
-     * work well in concurrent situation, as we expect new service
-     * addition, service removal and walk of the service will happen
-     * from different places
-     */
-    private List<List<DataPacketListener>> listenDataPacket = new CopyOnWriteArrayList<List<DataPacketListener>>();
-    // Quick index to make sure there are no duplicate elements
-    private Set<DataPacketListener> indexDataPacket = Collections
-            .synchronizedSet(new HashSet<DataPacketListener>());
-
-    /**
-     * Loop for processing Received packets
-     */
-    private void dispatchPacket(RawPacket pkt) {
-
-        // for now we treat all listeners as serial listeners
-        for (List<DataPacketListener> serialListeners : listenDataPacket) {
-            for (DataPacketListener l : serialListeners) {
-
-                // TODO: possibly deal with read-only and read-write packet
-                // copies
-                IListenDataPacket s = (l == null ? null : l.listener);
-                if (s != null) {
-                    try {
-                        // TODO Make sure to filter based on the match too,
-                        // later on
-                        PacketResult res = s.receiveDataPacket(pkt);
-                        increaseStat("RXPacketSuccess");
-                        if (res.equals(PacketResult.CONSUME)) {
-                            increaseStat("RXPacketSerialExit");
-                            break;
-                        }
-                    } catch (Exception e) {
-                        increaseStat("RXPacketFailedForException");
-                    }
-                }
-            }
-        }
-    }
-
-    /**
-     * Loop for processing packets to be transmitted
-     *
-     */
-    private class TxLoop implements Runnable {
-        public void run() {
-            RawPacket pkt;
-            try {
-                for (pkt = txQueue.take(); pkt != null; pkt = txQueue.take()) {
-                    // Retrieve outgoing node connector so to send out
-                    // the packet to corresponding node
-                    NodeConnector p = pkt.getOutgoingNodeConnector();
-                    if (p != null) {
-                        String t = p.getNode()
-                                .getType();
-                        // Now locate the TX dispatcher
-                        ProtocolService<IPluginInDataPacketService> service =
-                            pluginInDataService.get(t);
-                        if (service != null) {
-                            try {
-                                service.getService().transmitDataPacket(pkt);
-                                increaseStat("TXPacketSuccess");
-                            } catch (Exception e) {
-                                increaseStat("TXPacketFailedForException");
-                            }
-                        } else {
-                            increaseStat("TXpluginNotFound");
-                        }
-                    }
-                }
-            } catch (InterruptedException e) {
-                // Not a big deal
-            }
-        }
-    }
-
-    void setPluginInDataService(Map<?, ?> props, IPluginInDataPacketService s) {
-        ProtocolService.set(this.pluginInDataService, props, s, logger);
-    }
-
-    void unsetPluginInDataService(Map<?, ?> props, IPluginInDataPacketService s) {
-        ProtocolService.unset(this.pluginInDataService, props, s, logger);
-    }
-
-    void setListenDataPacket(Map<?, ?> props, IListenDataPacket s) {
-        if (this.listenDataPacket == null || this.indexDataPacket == null) {
-            logger.error("data structure to store data is NULL");
-            return;
-        }
-        logger.trace("Received setListenDataPacket request");
-        for (Map.Entry<?, ?> e : props.entrySet()) {
-            logger.trace("Prop key:({}) value:({})",e.getKey(), e.getValue());
-        }
-
-        String listenerName = null;
-        String listenerDependency = null;
-        Match filter = null;
-        Object value;
-        // Read the listenerName
-        value = props.get("salListenerName");
-        if (value instanceof String) {
-            listenerName = (String) value;
-        }
-
-        if (listenerName == null) {
-            logger.error("Trying to set a listener without a Name");
-            return;
-        }
-
-        //Read the dependency
-        value = props.get("salListenerDependency");
-        if (value instanceof String) {
-            listenerDependency = (String) value;
-        }
-
-        //Read match filter if any
-        value = props.get("salListenerFilter");
-        if (value instanceof Match) {
-            filter = (Match) value;
-        }
-
-        DataPacketListener l = new DataPacketListener(listenerName, s,
-                listenerDependency, filter);
-
-        DataPacketListener lDependency = new DataPacketListener(
-                listenerDependency, null, null, null);
-
-        // Now let see if there is any dependency
-        if (listenerDependency == null) {
-            logger.debug("listener without any dependency");
-            if (this.indexDataPacket.contains(l)) {
-                logger.error("trying to add an existing element");
-            } else {
-                logger.debug("adding listener: {}", listenerName);
-                CopyOnWriteArrayList<DataPacketListener> serialListeners = new CopyOnWriteArrayList<DataPacketListener>();
-                serialListeners.add(l);
-                this.listenDataPacket.add(serialListeners);
-                this.indexDataPacket.add(l);
-            }
-        } else {
-            logger.debug("listener with dependency");
-            // Now search for the dependency and put things in order
-            if (this.indexDataPacket.contains(l)) {
-                logger.error("trying to add an existing element");
-            } else {
-                logger.debug("adding listener: {}", listenerName);
-                // Lets find the set with the dependency in it, if we
-                // find it lets just add our dependency at the end of
-                // the list.
-                for (List<DataPacketListener> serialListeners : this.listenDataPacket) {
-                    boolean done = false;
-                    if (serialListeners.contains(lDependency)) {
-                        serialListeners.add(l);
-                        done = true;
-                    }
-                    // If we did fine the element, lets break early
-                    if (done) {
-                        break;
-                    }
-                }
-
-                this.indexDataPacket.add(l);
-            }
-        }
-    }
-
-    void unsetListenDataPacket(Map<?, ?> props, IListenDataPacket s) {
-        if (this.listenDataPacket == null || this.indexDataPacket == null) {
-            logger.error("data structure to store data is NULL");
-            return;
-        }
-        logger.trace("Received UNsetListenDataPacket request");
-        for (Map.Entry<?, ?> e : props.entrySet()) {
-            logger.trace("Prop key:({}) value:({})",e.getKey(), e.getValue());
-        }
-
-        String listenerName = null;
-        Object value;
-        // Read the listenerName
-        value = props.get("salListenerName");
-        if (value instanceof String) {
-            listenerName = (String) value;
-        }
-
-        if (listenerName == null) {
-            logger.error("Trying to set a listener without a Name");
-            return;
-        }
-
-        DataPacketListener l = new DataPacketListener(listenerName, s, null,
-                null);
-        if (!this.indexDataPacket.contains(l)) {
-            logger.error("trying to remove a non-existing element");
-        } else {
-            logger.debug("removing listener: {}", listenerName);
-            for (List<DataPacketListener> serialListeners : this.listenDataPacket) {
-                int i = 0;
-                boolean done = false;
-                for (i = 0; i < serialListeners.size(); i++) {
-                    if (serialListeners.get(i).equals(l)) {
-                        serialListeners.remove(i);
-                        done = true;
-                        break;
-                    }
-                }
-                // Now remove a serialListener that maybe empty
-                if (serialListeners.isEmpty()) {
-                    this.listenDataPacket.remove(serialListeners);
-                }
-                // If we did fine the element, lets break early
-                if (done) {
-                    break;
-                }
-            }
-
-            this.indexDataPacket.remove(l);
-        }
-    }
-
-    /**
-     * Function called by the dependency manager when all the required
-     * dependencies are satisfied
-     *
-     */
-    void init() {
-        this.txThread.start();
-    }
-
-    /**
-     * Function called by the dependency manager when at least one
-     * dependency become unsatisfied or when the component is shutting
-     * down because for example bundle is being stopped.
-     *
-     */
-    void destroy() {
-        // Make sure to cleanup the data structure we use to track
-        // services
-        this.listenDataPacket.clear();
-        this.indexDataPacket.clear();
-        this.pluginInDataService.clear();
-        this.statistics.clear();
-        this.txQueue.clear();
-        this.txThread.interrupt();
-        // Wait for them to be done
-        try {
-            this.txThread.join();
-        } catch (InterruptedException ex) {
-            // Not a big deal
-        }
-    }
-
-    private void increaseStat(String name) {
-        if (this.statistics == null) {
-            return;
-        }
-
-        AtomicInteger currValue = null;
-        synchronized (this.statistics) {
-            currValue = this.statistics.get(name);
-
-            if (currValue == null) {
-                this.statistics.put(name, new AtomicInteger(0));
-                return;
-            }
-        }
-        currValue.incrementAndGet();
-    }
-
-    @Override
-    public PacketResult receiveDataPacket(RawPacket inPkt) {
-        if (inPkt.getIncomingNodeConnector() == null) {
-            increaseStat("nullIncomingNodeConnector");
-            return PacketResult.IGNORED;
-        }
-
-        // send the packet off to be processed by listeners
-        this.dispatchPacket(inPkt);
-
-        // Walk the chain of listener going first throw all the
-        // parallel ones and for each parallel in serial
-        return PacketResult.IGNORED;
-    }
-
-    @Override
-    public void transmitDataPacket(RawPacket outPkt) {
-        if (outPkt.getOutgoingNodeConnector() == null) {
-            increaseStat("nullOutgoingNodeConnector");
-            return;
-        }
-
-        if (!this.txQueue.offer(outPkt)) {
-            increaseStat("fullTXQueue");
-            return;
-        }
-    }
-
-    @Override
-    public Packet decodeDataPacket(RawPacket pkt) {
-        // Sanity checks
-        if (pkt == null) {
-            return null;
-        }
-        byte[] data = pkt.getPacketData();
-        if (data.length <= 0) {
-            return null;
-        }
-        if (pkt.getEncap().equals(LinkEncap.ETHERNET)) {
-            Ethernet res = new Ethernet();
-            try {
-                res.deserialize(data, 0, data.length * NetUtils.NumBitsInAByte);
-            } catch (Exception e) {
-                logger.warn("Failed to decode packet: {}", e.getMessage());
-            }
-            return res;
-        }
-        return null;
-    }
-
-    @Override
-    public RawPacket encodeDataPacket(Packet pkt) {
-        // Sanity checks
-        if (pkt == null) {
-            return null;
-        }
-        byte[] data;
-        try {
-            data = pkt.serialize();
-        } catch (Exception e) {
-            logger.error("",e);
-            return null;
-        }
-        if (data.length <= 0) {
-            return null;
-        }
-        try {
-            RawPacket res = new RawPacket(data);
-            return res;
-        } catch (ConstructionException cex) {
-        }
-        // If something goes wrong then we have to return null
-        return null;
-    }
-}
diff --git a/opendaylight/adsal/sal/implementation/src/main/java/org/opendaylight/controller/sal/implementation/internal/FlowProgrammerService.java b/opendaylight/adsal/sal/implementation/src/main/java/org/opendaylight/controller/sal/implementation/internal/FlowProgrammerService.java
deleted file mode 100644 (file)
index 60a7882..0000000
+++ /dev/null
@@ -1,490 +0,0 @@
-/*
- * Copyright (c) 2013-2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.implementation.internal;
-
-import java.util.Map;
-import java.util.concurrent.ConcurrentHashMap;
-import java.util.concurrent.atomic.AtomicLong;
-import java.net.InetAddress;
-import java.net.UnknownHostException;
-import java.util.ArrayList;
-import java.util.HashSet;
-import java.util.List;
-import java.util.Set;
-
-import org.eclipse.osgi.framework.console.CommandInterpreter;
-import org.eclipse.osgi.framework.console.CommandProvider;
-import org.opendaylight.controller.sal.action.Action;
-import org.opendaylight.controller.sal.action.Controller;
-import org.opendaylight.controller.sal.action.Flood;
-import org.opendaylight.controller.sal.action.Output;
-import org.opendaylight.controller.sal.action.PopVlan;
-import org.opendaylight.controller.sal.action.SetNwDst;
-import org.opendaylight.controller.sal.core.ConstructionException;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.Node.NodeIDType;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.flowprogrammer.Flow;
-import org.opendaylight.controller.sal.flowprogrammer.IFlowProgrammerListener;
-import org.opendaylight.controller.sal.flowprogrammer.IFlowProgrammerService;
-import org.opendaylight.controller.sal.flowprogrammer.IPluginInFlowProgrammerService;
-import org.opendaylight.controller.sal.flowprogrammer.IPluginOutFlowProgrammerService;
-import org.opendaylight.controller.sal.match.Match;
-import org.opendaylight.controller.sal.match.MatchType;
-import org.opendaylight.controller.sal.utils.EtherTypes;
-import org.opendaylight.controller.sal.utils.IPProtocols;
-import org.opendaylight.controller.sal.utils.NodeConnectorCreator;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.sal.utils.StatusCode;
-import org.osgi.framework.BundleContext;
-import org.osgi.framework.FrameworkUtil;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * The SAL Flow Programmer Service. It dispatches the flow programming requests
- * to the proper SDN protocol plugin and it notifies about asynchronous messages
- * received from the network node related to flow programming.
- */
-public class FlowProgrammerService implements IFlowProgrammerService,
-        IPluginOutFlowProgrammerService, CommandProvider {
-
-    protected static final Logger logger = LoggerFactory
-            .getLogger(FlowProgrammerService.class);
-    private ConcurrentHashMap<String, ProtocolService<IPluginInFlowProgrammerService>> pluginFlowProgrammer;
-    private Set<IFlowProgrammerListener> listener;
-    private AtomicLong seq;
-
-    public FlowProgrammerService() {
-        pluginFlowProgrammer = new ConcurrentHashMap<String, ProtocolService<IPluginInFlowProgrammerService>>();
-        listener = new HashSet<IFlowProgrammerListener>();
-        seq = new AtomicLong();
-        /*
-         * This Request ID generator starts with 1. Each aysnc message is
-         * associated with an unique Request ID (!= 0).
-         */
-        seq.lazySet(1);
-    }
-
-    /**
-     * Function called by the dependency manager when all the required
-     * dependencies are satisfied
-     *
-     */
-    void init() {
-        logger.debug("INIT called!");
-    }
-
-    /**
-     * Function called by the dependency manager when at least one dependency
-     * become unsatisfied or when the component is shutting down because for
-     * example bundle is being stopped.
-     *
-     */
-    void destroy() {
-        // Clear previous registration to avoid they are left hanging
-        this.pluginFlowProgrammer.clear();
-        logger.debug("DESTROY called!");
-    }
-
-    /**
-     * Function called by dependency manager after "init ()" is called and after
-     * the services provided by the class are registered in the service registry
-     *
-     */
-    void start() {
-        logger.debug("START called!");
-        // OSGI console
-        registerWithOSGIConsole();
-    }
-
-    /**
-     * Function called by the dependency manager before the services exported by
-     * the component are unregistered, this will be followed by a "destroy ()"
-     * calls
-     *
-     */
-    void stop() {
-        logger.debug("STOP called!");
-    }
-
-    // Set the reference to the plugin flow programmer
-    public void setService(Map<String, Object> props, IPluginInFlowProgrammerService s) {
-        ProtocolService.set(this.pluginFlowProgrammer, props, s, logger);
-    }
-
-    public void unsetService(Map<String, Object> props, IPluginInFlowProgrammerService s) {
-        ProtocolService.unset(this.pluginFlowProgrammer, props, s, logger);
-    }
-
-    public void setListener(IFlowProgrammerListener s) {
-        this.listener.add(s);
-    }
-
-    public void unsetListener(IFlowProgrammerListener s) {
-        this.listener.remove(s);
-    }
-
-    @Override
-    public Status addFlow(Node node, Flow flow) {
-        if (pluginFlowProgrammer != null) {
-            ProtocolService<IPluginInFlowProgrammerService> service =
-                this.pluginFlowProgrammer.get(node.getType());
-            if (service != null) {
-                return service.getService().addFlow(node, flow);
-            }
-        }
-        return new Status(StatusCode.NOSERVICE, "Plugin unuvailable");
-    }
-
-    @Override
-    public Status removeFlow(Node node, Flow flow) {
-        if (pluginFlowProgrammer != null) {
-            ProtocolService<IPluginInFlowProgrammerService> service =
-                this.pluginFlowProgrammer.get(node.getType());
-            if (service != null) {
-                return service.getService().removeFlow(node, flow);
-            }
-        }
-        return new Status(StatusCode.NOSERVICE, "Plugin unuvailable");
-    }
-
-    @Override
-    public Status removeAllFlows(Node node) {
-        if (pluginFlowProgrammer != null) {
-            ProtocolService<IPluginInFlowProgrammerService> service =
-                this.pluginFlowProgrammer.get(node.getType());
-            if (service != null) {
-                return service.getService().removeAllFlows(node);
-            }
-        }
-        return new Status(StatusCode.NOSERVICE, "Plugin unuvailable");
-    }
-
-    @Override
-    public Status modifyFlow(Node node, Flow oldFlow, Flow newFlow) {
-        if (pluginFlowProgrammer != null) {
-            ProtocolService<IPluginInFlowProgrammerService> service =
-                this.pluginFlowProgrammer.get(node.getType());
-            if (service != null) {
-                return service.getService().modifyFlow(node, oldFlow, newFlow);
-            }
-        }
-        return new Status(StatusCode.NOSERVICE, "Plugin unuvailable");
-    }
-
-    @Override
-    public Status addFlowAsync(Node node, Flow flow) {
-        if (pluginFlowProgrammer != null) {
-            ProtocolService<IPluginInFlowProgrammerService> service =
-                this.pluginFlowProgrammer.get(node.getType());
-            if (service != null) {
-                return service.getService().addFlowAsync(node, flow, getNextRid());
-            }
-        }
-        return new Status(StatusCode.NOSERVICE, "Plugin unuvailable");
-    }
-
-    @Override
-    public Status removeFlowAsync(Node node, Flow flow) {
-        if (pluginFlowProgrammer != null) {
-            ProtocolService<IPluginInFlowProgrammerService> service =
-                this.pluginFlowProgrammer.get(node.getType());
-            if (service != null) {
-                return service.getService().removeFlowAsync(node, flow, getNextRid());
-            }
-        }
-        return new Status(StatusCode.NOSERVICE, "Plugin unuvailable");
-    }
-
-    @Override
-    public Status modifyFlowAsync(Node node, Flow oldFlow, Flow newFlow) {
-        if (pluginFlowProgrammer != null) {
-            ProtocolService<IPluginInFlowProgrammerService> service =
-                this.pluginFlowProgrammer.get(node.getType());
-            if (service != null) {
-                return service.getService().modifyFlowAsync(node, oldFlow, newFlow, getNextRid());
-            }
-        }
-        return new Status(StatusCode.NOSERVICE, "Plugin unuvailable");
-    }
-
-    @Override
-    public void flowRemoved(Node node, Flow flow) {
-        for (IFlowProgrammerListener l : listener) {
-            l.flowRemoved(node, flow);
-        }
-    }
-
-    @Override
-    public void flowErrorReported(Node node, long rid, Object err) {
-        logger.error("Got error {} for message rid {} from node {}",
-                new Object[] { err, rid, node });
-
-        for (IFlowProgrammerListener l : listener) {
-            l.flowErrorReported(node, rid, err);
-        }
-    }
-
-    // ---------------- OSGI TEST CODE ------------------------------//
-
-    private void registerWithOSGIConsole() {
-        BundleContext bundleContext = FrameworkUtil.getBundle(this.getClass())
-                .getBundleContext();
-        bundleContext.registerService(CommandProvider.class.getName(), this,
-                null);
-    }
-
-    @Override
-    public String getHelp() {
-        StringBuffer help = new StringBuffer();
-        help.append("---SAL Flow Programmer testing commands---\n");
-        help.append("\t addflow <sid> - Add a sample flow to the openflow switch <sid>\n");
-        help.append("\t removeflow <sid> - Remove the sample flow from the openflow switch <sid>\n");
-        return help.toString();
-    }
-
-    public void _addflow(CommandInterpreter ci) throws UnknownHostException {
-        Node node = null;
-        String nodeId = ci.nextArgument();
-        if (nodeId == null) {
-            ci.print("Node id not specified");
-            return;
-        }
-        try {
-            node = new Node(NodeIDType.OPENFLOW, Long.valueOf(nodeId));
-        } catch (NumberFormatException e) {
-            logger.error("",e);
-        } catch (ConstructionException e) {
-            logger.error("",e);
-        }
-        ci.println(this.addFlow(node, getSampleFlow(node)));
-    }
-
-    public void _modifyflow(CommandInterpreter ci) throws UnknownHostException {
-        Node node = null;
-        String nodeId = ci.nextArgument();
-        if (nodeId == null) {
-            ci.print("Node id not specified");
-            return;
-        }
-        try {
-            node = new Node(NodeIDType.OPENFLOW, Long.valueOf(nodeId));
-        } catch (NumberFormatException e) {
-            logger.error("",e);
-        } catch (ConstructionException e) {
-            logger.error("",e);
-        }
-        Flow flowA = getSampleFlow(node);
-        Flow flowB = getSampleFlow(node);
-        Match matchB = flowB.getMatch();
-        matchB.setField(MatchType.NW_DST,
-                InetAddress.getByName("190.190.190.190"));
-        flowB.setMatch(matchB);
-        ci.println(this.modifyFlow(node, flowA, flowB));
-    }
-
-    public void _removeflow(CommandInterpreter ci) throws UnknownHostException {
-        Node node = null;
-        String nodeId = ci.nextArgument();
-        if (nodeId == null) {
-            ci.print("Node id not specified");
-            return;
-        }
-        try {
-            node = new Node(NodeIDType.OPENFLOW, Long.valueOf(nodeId));
-        } catch (NumberFormatException e) {
-            logger.error("",e);
-        } catch (ConstructionException e) {
-            logger.error("",e);
-        }
-        ci.println(this.removeFlow(node, getSampleFlow(node)));
-    }
-
-    public void _addflowv6(CommandInterpreter ci) throws UnknownHostException {
-        Node node = null;
-        String nodeId = ci.nextArgument();
-        if (nodeId == null) {
-            ci.print("Node id not specified");
-            return;
-        }
-        try {
-            node = new Node(NodeIDType.OPENFLOW, Long.valueOf(nodeId));
-        } catch (NumberFormatException e) {
-            logger.error("",e);
-        } catch (ConstructionException e) {
-            logger.error("",e);
-        }
-        ci.println(this.addFlow(node, getSampleFlowV6(node)));
-    }
-
-    public void _removeflowv6(CommandInterpreter ci)
-            throws UnknownHostException {
-        Node node = null;
-        String nodeId = ci.nextArgument();
-        if (nodeId == null) {
-            ci.print("Node id not specified");
-            return;
-        }
-        try {
-            node = new Node(NodeIDType.OPENFLOW, Long.valueOf(nodeId));
-        } catch (NumberFormatException e) {
-            logger.error("",e);
-        } catch (ConstructionException e) {
-            logger.error("",e);
-        }
-        ci.println(this.removeFlow(node, getSampleFlowV6(node)));
-    }
-
-    private Flow getSampleFlow(Node node) throws UnknownHostException {
-        NodeConnector port = NodeConnectorCreator.createOFNodeConnector(
-                (short) 24, node);
-        NodeConnector oport = NodeConnectorCreator.createOFNodeConnector(
-                (short) 30, node);
-        byte srcMac[] = { (byte) 0x12, (byte) 0x34, (byte) 0x56, (byte) 0x78,
-                (byte) 0x9a, (byte) 0xbc };
-        byte dstMac[] = { (byte) 0x1a, (byte) 0x2b, (byte) 0x3c, (byte) 0x4d,
-                (byte) 0x5e, (byte) 0x6f };
-        InetAddress srcIP = InetAddress.getByName("172.28.30.50");
-        InetAddress dstIP = InetAddress.getByName("171.71.9.52");
-        InetAddress newIP = InetAddress.getByName("200.200.100.1");
-        InetAddress ipMask = InetAddress.getByName("255.255.255.0");
-        InetAddress ipMask2 = InetAddress.getByName("255.240.0.0");
-        short ethertype = EtherTypes.IPv4.shortValue();
-        short vlan = (short) 27;
-        byte vlanPr = 3;
-        Byte tos = 4;
-        byte proto = IPProtocols.TCP.byteValue();
-        short src = (short) 55000;
-        short dst = 80;
-
-        /*
-         * Create a SAL Flow aFlow
-         */
-        Match match = new Match();
-        match.setField(MatchType.IN_PORT, port);
-        match.setField(MatchType.DL_SRC, srcMac);
-        match.setField(MatchType.DL_DST, dstMac);
-        match.setField(MatchType.DL_TYPE, ethertype);
-        match.setField(MatchType.DL_VLAN, vlan);
-        match.setField(MatchType.DL_VLAN_PR, vlanPr);
-        match.setField(MatchType.NW_SRC, srcIP, ipMask);
-        match.setField(MatchType.NW_DST, dstIP, ipMask2);
-        match.setField(MatchType.NW_TOS, tos);
-        match.setField(MatchType.NW_PROTO, proto);
-        match.setField(MatchType.TP_SRC, src);
-        match.setField(MatchType.TP_DST, dst);
-
-        List<Action> actions = new ArrayList<Action>();
-        actions.add(new SetNwDst(newIP));
-        actions.add(new Output(oport));
-        actions.add(new PopVlan());
-        actions.add(new Flood());
-        actions.add(new Controller());
-
-        Flow flow = new Flow(match, actions);
-        flow.setPriority((short) 100);
-        flow.setHardTimeout((short) 360);
-        flow.setId(1234L);
-
-        return flow;
-    }
-
-    private Flow getSampleFlowV6(Node node) throws UnknownHostException {
-        NodeConnector port = NodeConnectorCreator.createOFNodeConnector(
-                (short) 24, node);
-        NodeConnector oport = NodeConnectorCreator.createOFNodeConnector(
-                (short) 30, node);
-        byte srcMac[] = { (byte) 0x12, (byte) 0x34, (byte) 0x56, (byte) 0x78,
-                (byte) 0x9a, (byte) 0xbc };
-        byte dstMac[] = { (byte) 0x1a, (byte) 0x2b, (byte) 0x3c, (byte) 0x4d,
-                (byte) 0x5e, (byte) 0x6f };
-        InetAddress srcIP = InetAddress
-                .getByName("2001:420:281:1004:407a:57f4:4d15:c355");
-        InetAddress dstIP = InetAddress
-                .getByName("2001:420:281:1004:e123:e688:d655:a1b0");
-        InetAddress ipMask = null; // InetAddress.getByName("ffff:ffff:ffff:ffff:0:0:0:0");
-                                   // V6Match implementation assumes no mask is
-                                   // specified
-        InetAddress ipMask2 = null; // InetAddress.getByName("ffff:ffff:ffff:ffff:ffff:ffff:ffff:0");
-        short ethertype = EtherTypes.IPv6.shortValue();
-        short vlan = (short) 27;
-        byte vlanPr = (byte) 3;
-        Byte tos = 4;
-        byte proto = IPProtocols.UDP.byteValue();
-        short src = (short) 5500;
-        // short dst = 80;
-
-        /*
-         * Create a SAL Flow aFlow
-         */
-        Match match = new Match();
-        match.setField(MatchType.IN_PORT, port);
-        match.setField(MatchType.DL_SRC, srcMac);
-        match.setField(MatchType.DL_DST, dstMac);
-        match.setField(MatchType.DL_TYPE, ethertype);
-        match.setField(MatchType.DL_VLAN, vlan);
-        match.setField(MatchType.DL_VLAN_PR, vlanPr); // V6Match does not handle
-                                                      // this properly...
-        match.setField(MatchType.NW_SRC, srcIP, ipMask);
-        match.setField(MatchType.NW_DST, dstIP, ipMask2);
-        match.setField(MatchType.NW_TOS, tos);
-        match.setField(MatchType.NW_PROTO, proto);
-        match.setField(MatchType.TP_SRC, src); // V6Match does not handle this
-                                               // properly...
-        // match.setField(MatchType.TP_DST, dst); V6Match does not handle this
-        // properly...
-
-        List<Action> actions = new ArrayList<Action>();
-        actions.add(new Output(oport));
-        actions.add(new PopVlan());
-        actions.add(new Flood());
-
-        Flow flow = new Flow(match, actions);
-        flow.setPriority((short) 300);
-        flow.setHardTimeout((short) 240);
-        flow.setId(65536L);
-
-        return flow;
-    }
-
-    /**
-     * This Request ID generator starts with 1. Each aysnc message is
-     * associated with an unique Request ID (!= 0).
-     *
-     * @return Request ID
-     */
-    private long getNextRid() {
-        return seq.getAndIncrement();
-    }
-
-    @Override
-    public Status syncSendBarrierMessage(Node node) {
-        if (this.pluginFlowProgrammer != null) {
-            ProtocolService<IPluginInFlowProgrammerService> service =
-                this.pluginFlowProgrammer.get(node.getType());
-            if (service != null) {
-                return service.getService().syncSendBarrierMessage(node);
-            }
-        }
-        return new Status(StatusCode.NOSERVICE, "Plugin unuvailable");
-    }
-
-    @Override
-    public Status asyncSendBarrierMessage(Node node) {
-        if (this.pluginFlowProgrammer != null) {
-            ProtocolService<IPluginInFlowProgrammerService> service =
-                this.pluginFlowProgrammer.get(node.getType());
-            if (service != null) {
-                return service.getService().asyncSendBarrierMessage(node);
-            }
-        }
-        return new Status(StatusCode.NOSERVICE, "Plugin unuvailable");
-    }
-}
diff --git a/opendaylight/adsal/sal/implementation/src/main/java/org/opendaylight/controller/sal/implementation/internal/Inventory.java b/opendaylight/adsal/sal/implementation/src/main/java/org/opendaylight/controller/sal/implementation/internal/Inventory.java
deleted file mode 100644 (file)
index fbb9fbc..0000000
+++ /dev/null
@@ -1,175 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.implementation.internal;
-
-import java.util.HashSet;
-import java.util.List;
-import java.util.Map;
-import java.util.Set;
-import java.util.concurrent.ConcurrentHashMap;
-import java.util.concurrent.ConcurrentMap;
-import java.util.concurrent.CopyOnWriteArrayList;
-
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.core.UpdateType;
-import org.opendaylight.controller.sal.inventory.IInventoryService;
-import org.opendaylight.controller.sal.inventory.IListenInventoryUpdates;
-import org.opendaylight.controller.sal.inventory.IPluginInInventoryService;
-import org.opendaylight.controller.sal.inventory.IPluginOutInventoryService;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * The class describes SAL service to bridge inventory protocol plugin and upper
- * applications. One instance per container of the network.
- */
-public class Inventory implements IPluginOutInventoryService, IInventoryService {
-    protected static final Logger logger = LoggerFactory
-            .getLogger(Inventory.class);
-    private List<IListenInventoryUpdates> updateService = new CopyOnWriteArrayList<IListenInventoryUpdates>();
-    private List<IPluginInInventoryService> pluginService = new CopyOnWriteArrayList<IPluginInInventoryService>();
-
-    /**
-     * Function called by the dependency manager when all the required
-     * dependencies are satisfied
-     *
-     */
-    void init() {
-        logger.trace("INIT called!");
-    }
-
-    /**
-     * Function called by the dependency manager when at least one
-     * dependency become unsatisfied or when the component is shutting
-     * down because for example bundle is being stopped.
-     *
-     */
-    void destroy() {
-        logger.trace("DESTROY called!");
-    }
-
-    /**
-     * Function called by dependency manager after "init ()" is called
-     * and after the services provided by the class are registered in
-     * the service registry
-     *
-     */
-    void start() {
-        logger.trace("START called!");
-
-        if (pluginService == null) {
-            logger.debug("plugin service not avaiable");
-            return;
-        }
-    }
-
-    /**
-     * Function called by the dependency manager before the services
-     * exported by the component are unregistered, this will be
-     * followed by a "destroy ()" calls
-     *
-     */
-    void stop() {
-        logger.trace("STOP called!");
-    }
-
-    public void setPluginService(IPluginInInventoryService service) {
-        logger.trace("Got plugin service set request {}", service);
-        this.pluginService.add(service);
-    }
-
-    public void unsetPluginService(IPluginInInventoryService service) {
-        logger.trace("Got plugin service UNset request");
-        this.pluginService.remove(service);
-    }
-
-    public void setUpdateService(IListenInventoryUpdates service) {
-        logger.trace("Got update service set request {}", service);
-        this.updateService.add(service);
-    }
-
-    public void unsetUpdateService(IListenInventoryUpdates service) {
-        logger.trace("Got a service UNset request");
-        this.updateService.remove(service);
-    }
-
-    @Override
-    public void updateNode(Node node, UpdateType type, Set<Property> props) {
-        if (type == null) {
-            logger.trace("Input type is null");
-            return;
-        }
-
-        logger.trace("{} {}", node, type);
-
-        for (IListenInventoryUpdates s : this.updateService) {
-            s.updateNode(node, type, props);
-        }
-    }
-
-    @Override
-    public void updateNodeConnector(NodeConnector nodeConnector,
-            UpdateType type, Set<Property> props) {
-        if (type == null) {
-            logger.trace("Input type is null");
-            return;
-        }
-
-        logger.trace("{} {}", nodeConnector, type);
-
-        for (IListenInventoryUpdates s : this.updateService) {
-            s.updateNodeConnector(nodeConnector, type, props);
-        }
-    }
-
-    @Override
-    public ConcurrentMap<Node, Map<String, Property>> getNodeProps() {
-        ConcurrentMap<Node, Map<String, Property>> nodeProps =
-            new ConcurrentHashMap<Node, Map<String, Property>>(), rv;
-
-        for (IPluginInInventoryService s : this.pluginService) {
-            rv = s.getNodeProps();
-            if (rv != null) {
-                nodeProps.putAll(rv);
-            }
-        }
-
-        return nodeProps;
-    }
-
-    @Override
-    public Set<Node> getConfiguredNotConnectedNodes() {
-        Set<Node> configuredNotConnected = new HashSet<Node>(), rv;
-        for (IPluginInInventoryService s : this.pluginService) {
-            rv = s.getConfiguredNotConnectedNodes();
-            if (rv != null) {
-                configuredNotConnected.addAll(rv);
-            }
-        }
-        return configuredNotConnected;
-    }
-
-    @Override
-    public ConcurrentMap<NodeConnector, Map<String, Property>> getNodeConnectorProps() {
-        ConcurrentMap<NodeConnector, Map<String, Property>> ncProps =
-            new ConcurrentHashMap<NodeConnector, Map<String, Property>>(), rv;
-
-        for (IPluginInInventoryService s : this.pluginService) {
-            rv = s.getNodeConnectorProps(true);
-            if (rv != null) {
-                ncProps.putAll(rv);
-            }
-        }
-
-        return ncProps;
-    }
-}
diff --git a/opendaylight/adsal/sal/implementation/src/main/java/org/opendaylight/controller/sal/implementation/internal/ProtocolService.java b/opendaylight/adsal/sal/implementation/src/main/java/org/opendaylight/controller/sal/implementation/internal/ProtocolService.java
deleted file mode 100644 (file)
index c0b6127..0000000
+++ /dev/null
@@ -1,223 +0,0 @@
-/*
- * Copyright (c) 2014 NEC Corporation and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.implementation.internal;
-
-import java.util.Map;
-import java.util.concurrent.ConcurrentMap;
-
-import org.slf4j.Logger;
-
-import org.opendaylight.controller.sal.utils.GlobalConstants;
-
-/**
- * An instance of this class keeps a protocol plugin service handler.
- *
- * @param <T>  Type of protocol plugin service.
- */
-public final class ProtocolService<T> {
-    /**
-     * Default priority value.
-     */
-    private static final int  DEFAULT_PRIORITY = 0;
-
-    /**
-     * A protocol plugin service handler.
-     */
-    private final T  service;
-
-    /**
-     * A priority value assigned to this protocol plugin.
-     */
-    private final int  priority;
-
-    /**
-     * Set protocol plugin service.
-     *
-     * @param map     A map that keeps protocol plugin services.
-     * @param props   Service properties.
-     * @param s       Protocol plugin service.
-     * @param logger  A logger instance.
-     * @param <S>     Type of protocol plugin service.
-     */
-    public static <S> void set(ConcurrentMap<String, ProtocolService<S>> map,
-                               Map<?, ?> props, S s, Logger logger) {
-        if (map == null) {
-            logger.error("Protocol plugin service store is null.");
-            return;
-        }
-        if (s == null) {
-            logger.error("Protocol plugin service is null.");
-            return;
-        }
-        if (props == null) {
-            logger.error("Service property is null.");
-            return;
-        }
-
-        if (logger.isTraceEnabled()) {
-            logger.trace("Received set service request: {}", s);
-            for (Map.Entry<?, ?> entry: props.entrySet()) {
-                logger.trace("Prop key:({}) value:({})", entry.getKey(),
-                             entry.getValue());
-            }
-        }
-
-        Object value = props.get(GlobalConstants.PROTOCOLPLUGINTYPE.toString());
-        if (!(value instanceof String)) {
-            logger.error("Unexpected protocol type: {}", value);
-            return;
-        }
-
-        String type = (String)value;
-        ProtocolService<S> service = new ProtocolService<S>(props, s);
-        ProtocolService<S> old = map.putIfAbsent(type, service);
-        while (old != null) {
-            // Compare priority value.
-            if (old.getPriority() >= service.getPriority()) {
-                logger.trace("Protocol plugin service for {} is already set: " +
-                             "current={}, requested={}", type, old, service);
-                return;
-            }
-
-            if (map.replace(type, old, service)) {
-                break;
-            }
-            old = map.putIfAbsent(type, service);
-        }
-
-        logger.debug("Stored protocol plugin service for {}: {}",
-                     type, service);
-    }
-
-    /**
-     * Unset protocol plugin service.
-     *
-     * @param map     A map that keeps protocol plugin services.
-     * @param props   Service properties.
-     * @param s       Protocol plugin service.
-     * @param logger  A logger instance.
-     * @param <S>     Type of protocol plugin service.
-     */
-    public static <S> void unset(ConcurrentMap<String, ProtocolService<S>> map,
-                                 Map<?, ?> props, S s, Logger logger) {
-        if (map == null) {
-            logger.error("Protocol plugin service store is null.");
-            return;
-        }
-        if (s == null) {
-            logger.error("Protocol plugin service is null.");
-            return;
-        }
-        if (props == null) {
-            logger.error("Service property is null.");
-            return;
-        }
-
-        if (logger.isTraceEnabled()) {
-            logger.trace("Received unset service request: {}", s);
-            for (Map.Entry<?, ?> entry: props.entrySet()) {
-                logger.trace("Prop key:({}) value:({})",
-                             entry.getKey(), entry.getValue());
-            }
-        }
-
-        Object value = props.get(GlobalConstants.PROTOCOLPLUGINTYPE.toString());
-        if (!(value instanceof String)) {
-            logger.error("Unexpected protocol type {}: service={}", value, s);
-            return;
-        }
-
-        String type = (String)value;
-        ProtocolService<S> plugin = new ProtocolService<S>(props, s);
-        if (map.remove(type, plugin)) {
-            logger.debug("Removed protocol plugin service for {}: {}",
-                         type, plugin);
-        } else {
-            logger.trace("Ignore unset service request for {}: {}",
-                         type, plugin);
-        }
-    }
-
-    /**
-     * Constructor.
-     *
-     * @param props  Protocol plugin service properties.
-     * @param s      A protocol plugin service handler.
-     */
-    public ProtocolService(Map<?, ?> props, T s) {
-        service = s;
-
-        String key = GlobalConstants.PROTOCOLPLUGINPRIORITY.toString();
-        Object value = props.get(key);
-        if (value instanceof Integer) {
-            priority = ((Integer)value).intValue();
-        } else {
-            priority = DEFAULT_PRIORITY;
-        }
-    }
-
-    /**
-     * Return a protocol plugin service handler.
-     *
-     * @return  A protocol plugin service handler.
-     */
-    public T getService() {
-        return service;
-    }
-
-    /**
-     * Return a priority value assigned to this protocol plugin.
-     *
-     * @return  A priority value.
-     */
-    public int getPriority() {
-        return priority;
-    }
-
-    /**
-     * Determine whether the given object is identical to this object.
-     *
-     * @param o  An object to be compared.
-     * @return   {@code true} if identical. Otherwise {@code false}.
-     */
-    @Override
-    public boolean equals(Object o) {
-        if (o == this) {
-            return true;
-        }
-        if (o == null || o.getClass() != getClass()) {
-            return false;
-        }
-
-        ProtocolService<?> plugin = (ProtocolService<?>)o;
-        return (service.equals(plugin.service) && priority == plugin.priority);
-    }
-
-    /**
-     * Return the hash code of this object.
-     *
-     * @return  The hash code.
-     */
-    @Override
-    public int hashCode() {
-        return service.hashCode() + (priority * 31);
-    }
-
-    /**
-     * Return a string representation of this instance.
-     *
-     * @return  A string representation of this instance.
-     */
-    @Override
-    public String toString() {
-        StringBuilder builder = new StringBuilder("[service=");
-        return builder.append(service).append(", priority=").append(priority).
-            append(']').toString();
-    }
-}
diff --git a/opendaylight/adsal/sal/implementation/src/main/java/org/opendaylight/controller/sal/implementation/internal/ReadService.java b/opendaylight/adsal/sal/implementation/src/main/java/org/opendaylight/controller/sal/implementation/internal/ReadService.java
deleted file mode 100644 (file)
index 356c0e5..0000000
+++ /dev/null
@@ -1,576 +0,0 @@
-/*
- * Copyright (c) 2013-2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.implementation.internal;
-
-import java.net.InetAddress;
-import java.net.UnknownHostException;
-import java.util.ArrayList;
-import java.util.Collections;
-import java.util.List;
-import java.util.Map;
-import java.util.Set;
-import java.util.concurrent.ConcurrentHashMap;
-import java.util.concurrent.CopyOnWriteArraySet;
-
-import org.eclipse.osgi.framework.console.CommandInterpreter;
-import org.eclipse.osgi.framework.console.CommandProvider;
-import org.opendaylight.controller.sal.action.Action;
-import org.opendaylight.controller.sal.action.Controller;
-import org.opendaylight.controller.sal.action.Flood;
-import org.opendaylight.controller.sal.action.Output;
-import org.opendaylight.controller.sal.action.PopVlan;
-import org.opendaylight.controller.sal.core.ConstructionException;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.Node.NodeIDType;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.NodeTable;
-import org.opendaylight.controller.sal.flowprogrammer.Flow;
-import org.opendaylight.controller.sal.match.Match;
-import org.opendaylight.controller.sal.match.MatchType;
-import org.opendaylight.controller.sal.reader.FlowOnNode;
-import org.opendaylight.controller.sal.reader.IPluginInReadService;
-import org.opendaylight.controller.sal.reader.IPluginOutReadService;
-import org.opendaylight.controller.sal.reader.IReadService;
-import org.opendaylight.controller.sal.reader.IReadServiceListener;
-import org.opendaylight.controller.sal.reader.NodeConnectorStatistics;
-import org.opendaylight.controller.sal.reader.NodeDescription;
-import org.opendaylight.controller.sal.reader.NodeTableStatistics;
-import org.opendaylight.controller.sal.utils.EtherTypes;
-import org.opendaylight.controller.sal.utils.IPProtocols;
-import org.opendaylight.controller.sal.utils.NodeConnectorCreator;
-import org.opendaylight.controller.sal.utils.NodeCreator;
-import org.opendaylight.controller.sal.utils.NodeTableCreator;
-import org.osgi.framework.BundleContext;
-import org.osgi.framework.FrameworkUtil;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * The SAL Read Service. Dispatches read requests to the proper SDN protocol
- * plugin, and notifies any listeners on updates from any plugin readers
- */
-public class ReadService implements IReadService, CommandProvider, IPluginOutReadService {
-
-    protected static final Logger logger = LoggerFactory.getLogger(ReadService.class);
-    private ConcurrentHashMap<String, ProtocolService<IPluginInReadService>> pluginReader =
-        new ConcurrentHashMap<String, ProtocolService<IPluginInReadService>>();
-    private Set<IReadServiceListener> readerListeners =
-        new CopyOnWriteArraySet<IReadServiceListener>();
-
-    /**
-     * Function called by the dependency manager when all the required
-     * dependencies are satisfied
-     *
-     */
-    void init() {
-    }
-
-    /**
-     * Function called by the dependency manager when at least one
-     * dependency become unsatisfied or when the component is shutting
-     * down because for example bundle is being stopped.
-     *
-     */
-    void destroy() {
-        // In case of plugin disactivating make sure we clear the
-        // dependencies
-        this.pluginReader.clear();
-        this.readerListeners.clear();
-    }
-
-    /**
-     * Function called by dependency manager after "init ()" is called
-     * and after the services provided by the class are registered in
-     * the service registry
-     *
-     */
-    void start() {
-        registerWithOSGIConsole();
-    }
-
-    /**
-     * Function called by the dependency manager before the services
-     * exported by the component are unregistered, this will be
-     * followed by a "destroy ()" calls
-     *
-     */
-    void stop() {
-    }
-
-    // Set the reference to the plugin flow Reader service
-    public void setService(Map<?, ?> props, IPluginInReadService s) {
-        ProtocolService.set(this.pluginReader, props, s, logger);
-    }
-
-    public void unsetService(Map<?, ?> props, IPluginInReadService s) {
-        ProtocolService.unset(this.pluginReader, props, s, logger);
-    }
-
-    public void setReaderListener(IReadServiceListener service) {
-        logger.trace("Got a listener set request {}", service);
-        this.readerListeners.add(service);
-    }
-
-    public void unsetReaderListener(IReadServiceListener service) {
-        logger.trace("Got a listener Unset request");
-        this.readerListeners.remove(service);
-    }
-
-    @Override
-    public FlowOnNode readFlow(Node node, Flow flow) {
-        if (pluginReader != null) {
-            ProtocolService<IPluginInReadService> service =
-                this.pluginReader.get(node.getType());
-            if (service != null) {
-                return service.getService().readFlow(node, flow, true);
-            }
-        }
-        logger.warn("Plugin {} unavailable", node.getType());
-        return null;
-    }
-
-    @Override
-    public FlowOnNode nonCachedReadFlow(Node node, Flow flow) {
-        if (pluginReader != null) {
-            ProtocolService<IPluginInReadService> service =
-                this.pluginReader.get(node.getType());
-            if (service != null) {
-                return service.getService().readFlow(node, flow, false);
-            }
-        }
-        logger.warn("Plugin {} unavailable", node.getType());
-        return null;
-    }
-
-    @Override
-    public List<FlowOnNode> readAllFlows(Node node) {
-        if (pluginReader != null) {
-            ProtocolService<IPluginInReadService> service =
-                this.pluginReader.get(node.getType());
-            if (service != null) {
-                return service.getService().readAllFlow(node, true);
-            }
-        }
-        logger.warn("Plugin {} unavailable", node.getType());
-        return Collections.emptyList();
-    }
-
-    @Override
-    public List<FlowOnNode> nonCachedReadAllFlows(Node node) {
-        if (pluginReader != null) {
-            ProtocolService<IPluginInReadService> service =
-                this.pluginReader.get(node.getType());
-            if (service != null) {
-                return service.getService().readAllFlow(node, false);
-            }
-        }
-        logger.warn("Plugin {} unavailable", node.getType());
-        return Collections.emptyList();
-    }
-
-    @Override
-    public NodeDescription readDescription(Node node) {
-        if (pluginReader != null) {
-            ProtocolService<IPluginInReadService> service =
-                this.pluginReader.get(node.getType());
-            if (service != null) {
-                return service.getService().readDescription(node, true);
-            }
-        }
-        logger.warn("Plugin {} unavailable", node.getType());
-        return null;
-    }
-
-    @Override
-    public NodeDescription nonCachedReadDescription(Node node) {
-        if (pluginReader != null) {
-            ProtocolService<IPluginInReadService> service =
-                this.pluginReader.get(node.getType());
-            if (service != null) {
-                return service.getService().readDescription(node, false);
-            }
-        }
-        logger.warn("Plugin {} unavailable", node.getType());
-        return null;
-    }
-
-    @Override
-    public NodeConnectorStatistics readNodeConnector(NodeConnector connector) {
-        Node node = connector.getNode();
-        if (pluginReader != null && node != null) {
-            ProtocolService<IPluginInReadService> service =
-                this.pluginReader.get(node.getType());
-            if (service != null) {
-                return service.getService().readNodeConnector(connector, true);
-            }
-        }
-        logger.warn("Plugin {} unavailable", node.getType());
-        return null;
-    }
-
-    @Override
-    public NodeConnectorStatistics nonCachedReadNodeConnector(
-            NodeConnector connector) {
-        Node node = connector.getNode();
-        if (pluginReader != null && node != null) {
-            ProtocolService<IPluginInReadService> service =
-                this.pluginReader.get(node.getType());
-            if (service != null) {
-                return service.getService().readNodeConnector(connector, false);
-            }
-        }
-        logger.warn("Plugin {} unavailable", node.getType());
-        return null;
-    }
-
-    @Override
-    public List<NodeConnectorStatistics> readNodeConnectors(Node node) {
-        if (pluginReader != null) {
-            ProtocolService<IPluginInReadService> service =
-                this.pluginReader.get(node.getType());
-            if (service != null) {
-                return service.getService().readAllNodeConnector(node, true);
-            }
-        }
-        logger.warn("Plugin {} unavailable", node.getType());
-        return Collections.emptyList();
-    }
-
-    @Override
-    public List<NodeTableStatistics> readNodeTable(Node node) {
-        if (pluginReader != null) {
-            ProtocolService<IPluginInReadService> service =
-                this.pluginReader.get(node.getType());
-            if (service != null) {
-                return service.getService().readAllNodeTable(node, true);
-            }
-        }
-        logger.warn("Plugin {} unavailable", node.getType());
-        return Collections.emptyList();
-    }
-
-
-    @Override
-    public NodeTableStatistics nonCachedReadNodeTable(NodeTable table) {
-        Node node = table.getNode();
-        if (pluginReader != null && node != null) {
-            ProtocolService<IPluginInReadService> service =
-                this.pluginReader.get(node.getType());
-            if (service != null) {
-                return service.getService().readNodeTable(table, false);
-            }
-        }
-        logger.warn("Plugin {} unavailable", node.getType());
-        return null;
-    }
-
-    @Override
-    public NodeTableStatistics readNodeTable(NodeTable table) {
-        Node node = table.getNode();
-        if (pluginReader != null && node != null) {
-            ProtocolService<IPluginInReadService> service =
-                this.pluginReader.get(node.getType());
-            if (service != null) {
-                return service.getService().readNodeTable(table, true);
-            }
-        }
-        logger.warn("Plugin {} unavailable", node.getType());
-        return null;
-    }
-
-    @Override
-    public List<NodeConnectorStatistics> nonCachedReadNodeConnectors(Node node) {
-        if (pluginReader != null) {
-            ProtocolService<IPluginInReadService> service =
-                this.pluginReader.get(node.getType());
-            if (service != null) {
-                return service.getService().readAllNodeConnector(node, false);
-            }
-        }
-        logger.warn("Plugin {} unavailable", node.getType());
-        return Collections.emptyList();
-    }
-
-    @Override
-    public long getTransmitRate(NodeConnector connector) {
-        Node node = connector.getNode();
-        if (pluginReader != null && node != null) {
-            ProtocolService<IPluginInReadService> service =
-                this.pluginReader.get(node.getType());
-            if (service != null) {
-                return service.getService().getTransmitRate(connector);
-            }
-        }
-        logger.warn("Plugin {} unavailable", node.getType());
-        return 0;
-    }
-
-    @Override
-    public void nodeFlowStatisticsUpdated(Node node, List<FlowOnNode> flowStatsList) {
-        for (IReadServiceListener l : readerListeners){
-            l.nodeFlowStatisticsUpdated(node, flowStatsList);
-        }
-    }
-
-    @Override
-    public void nodeConnectorStatisticsUpdated(Node node, List<NodeConnectorStatistics> ncStatsList) {
-        for (IReadServiceListener l : readerListeners){
-            l.nodeConnectorStatisticsUpdated(node, ncStatsList);
-        }
-    }
-
-    @Override
-    public void nodeTableStatisticsUpdated(Node node, List<NodeTableStatistics> tableStatsList) {
-        for (IReadServiceListener l : readerListeners){
-            l.nodeTableStatisticsUpdated(node, tableStatsList);
-        }
-    }
-
-    @Override
-    public void descriptionStatisticsUpdated(Node node, NodeDescription nodeDescription) {
-        for (IReadServiceListener l : readerListeners){
-            l.descriptionStatisticsUpdated(node, nodeDescription);
-        }
-    }
-
-    // ---------------- OSGI TEST CODE ------------------------------//
-
-    private void registerWithOSGIConsole() {
-        BundleContext bundleContext = FrameworkUtil.getBundle(this.getClass())
-                .getBundleContext();
-        bundleContext.registerService(CommandProvider.class.getName(), this,
-                null);
-    }
-
-    @Override
-    public String getHelp() {
-        StringBuffer help = new StringBuffer();
-        help.append("---SAL Reader testing commands---\n");
-        help.append("\t readflows <sid> <cached> - Read all the (cached) flows from the openflow switch <sid>\n");
-        help.append("\t readflow  <sid> <cached> - Read the (cached) sample flow from the openflow switch <sid>\n");
-        help.append("\t readdescr <sid> <cached> - Read the (cached) description from openflow switch <sid>\n");
-        help.append("\t\t cached = (true|false). If false or not specified, the plugin cached info\n");
-        help.append("\t\t is returned. If true, the info is directly retrieved from the switch\n");
-        help.append("\t readport <sid> <port>    - Read port statistics for the specified port\n");
-        help.append("\t readports <sid>          - Read port statistics for all ports of specified switch\n");
-        help.append("\t readtable <sid> <tableid>- Read specified table statistics\n");
-
-        return help.toString();
-    }
-
-    public void _readflows(CommandInterpreter ci) {
-        String nodeId = ci.nextArgument();
-        String cacheReq = ci.nextArgument();
-        boolean cached;
-        if (nodeId == null) {
-            ci.print("Node id not specified");
-            return;
-        }
-        cached = (cacheReq == null) ? true : cacheReq.equals("true");
-        Node node = null;
-        try {
-            node = new Node(NodeIDType.OPENFLOW, Long.valueOf(nodeId));
-        } catch (NumberFormatException e) {
-            logger.error("",e);
-        } catch (ConstructionException e) {
-            logger.error("",e);
-        }
-        List<FlowOnNode> list = (cached) ? this.readAllFlows(node) : this
-                .nonCachedReadAllFlows(node);
-        if (list != null) {
-            ci.println(list.toString());
-        } else {
-            ci.println("null");
-        }
-    }
-
-    // Requests the hw view for the specific sample flow
-    public void _readflow(CommandInterpreter ci) throws UnknownHostException {
-        String nodeId = ci.nextArgument();
-        String cacheReq = ci.nextArgument();
-        boolean cached;
-        if (nodeId == null) {
-            ci.print("Node id not specified");
-            return;
-        }
-        cached = (cacheReq == null) ? true : cacheReq.equals("true");
-        Node node = null;
-        try {
-            node = new Node(NodeIDType.OPENFLOW, Long.valueOf(nodeId));
-        } catch (NumberFormatException e) {
-            logger.error("",e);
-        } catch (ConstructionException e) {
-            logger.error("",e);
-        }
-        Flow flow = getSampleFlow(node);
-        FlowOnNode flowOnNode = (cached) ? this.readFlow(node, flow) : this
-                .nonCachedReadFlow(node, flow);
-        if (flowOnNode != null) {
-            ci.println(flowOnNode.toString());
-        } else {
-            ci.println("null");
-        }
-    }
-
-    public void _readports(CommandInterpreter ci) {
-        String nodeId = ci.nextArgument();
-        String cacheReq = ci.nextArgument();
-        boolean cached;
-        if (nodeId == null) {
-            ci.print("Node id not specified");
-            return;
-        }
-        cached = (cacheReq == null) ? true : cacheReq.equals("true");
-        Node node = null;
-        try {
-            node = new Node(NodeIDType.OPENFLOW, Long.valueOf(nodeId));
-        } catch (NumberFormatException e) {
-            logger.error("",e);
-        } catch (ConstructionException e) {
-            logger.error("",e);
-        }
-        List<NodeConnectorStatistics> list = (cached) ? this
-                .readNodeConnectors(node) : this
-                .nonCachedReadNodeConnectors(node);
-                if (list != null) {
-                    ci.println(list.toString());
-                } else {
-                    ci.println("null");
-                }
-    }
-
-    public void _readport(CommandInterpreter ci) {
-        String nodeId = ci.nextArgument();
-        String portId = ci.nextArgument();
-        String cacheReq = ci.nextArgument();
-        boolean cached;
-        if (nodeId == null) {
-            ci.print("Node id not specified");
-            return;
-        }
-        if (portId == null) {
-            ci.print("Port id not specified");
-            return;
-        }
-        cached = (cacheReq == null) ? true : cacheReq.equals("true");
-        NodeConnector nodeConnector = null;
-        Node node = NodeCreator.createOFNode(Long.parseLong(nodeId));
-        nodeConnector = NodeConnectorCreator.createNodeConnector(Short
-                .valueOf(portId), node);
-        NodeConnectorStatistics stats = (cached) ? this
-                .readNodeConnector(nodeConnector) : this
-                .nonCachedReadNodeConnector(nodeConnector);
-                if (stats != null) {
-                    ci.println(stats.toString());
-                } else {
-                    ci.println("null");
-                }
-    }
-
-    public void _readtable(CommandInterpreter ci) {
-        String nodeId = ci.nextArgument();
-        String tableId = ci.nextArgument();
-        String cacheReq = ci.nextArgument();
-        boolean cached;
-        if (nodeId == null) {
-            ci.print("Node id not specified");
-            return;
-        }
-        if (tableId == null) {
-            ci.print("Table id not specified");
-            return;
-        }
-        cached = (cacheReq == null) ? true : cacheReq.equals("true");
-        NodeTable nodeTable = null;
-        Node node = NodeCreator.createOFNode(Long.parseLong(nodeId));
-        nodeTable = NodeTableCreator.createNodeTable(Byte
-                .valueOf(tableId), node);
-        NodeTableStatistics stats = (cached) ? this
-                .readNodeTable(nodeTable) : this
-                .nonCachedReadNodeTable(nodeTable);
-                if (stats != null) {
-                    ci.println(stats.toString());
-                } else {
-                    ci.println("null");
-                }
-    }
-
-    public void _readdescr(CommandInterpreter ci) {
-        String nodeId = ci.nextArgument();
-        String cacheReq = ci.nextArgument();
-        boolean cached;
-        if (nodeId == null) {
-            ci.print("Node id not specified");
-            return;
-        }
-        cached = (cacheReq == null) ? true : cacheReq.equals("true");
-
-        Node node = null;
-        try {
-            node = new Node(NodeIDType.OPENFLOW, Long.valueOf(nodeId));
-        } catch (NumberFormatException e) {
-            logger.error("",e);
-        } catch (ConstructionException e) {
-            logger.error("",e);
-        }
-        NodeDescription desc = (cached) ? this.readDescription(node) : this
-                .nonCachedReadDescription(node);
-        if (desc != null) {
-            ci.println(desc.toString());
-        } else {
-            ci.println("null");
-        }
-    }
-
-    private Flow getSampleFlow(Node node) throws UnknownHostException {
-        NodeConnector port = NodeConnectorCreator.createOFNodeConnector(
-                (short) 24, node);
-        NodeConnector oport = NodeConnectorCreator.createOFNodeConnector(
-                (short) 30, node);
-        byte srcMac[] = { (byte) 0x12, (byte) 0x34, (byte) 0x56, (byte) 0x78,
-                (byte) 0x9a, (byte) 0xbc };
-        byte dstMac[] = { (byte) 0x1a, (byte) 0x2b, (byte) 0x3c, (byte) 0x4d,
-                (byte) 0x5e, (byte) 0x6f };
-        InetAddress srcIP = InetAddress.getByName("172.28.30.50");
-        InetAddress dstIP = InetAddress.getByName("171.71.9.52");
-        InetAddress ipMask = InetAddress.getByName("255.255.255.0");
-        InetAddress ipMask2 = InetAddress.getByName("255.0.0.0");
-        short ethertype = EtherTypes.IPv4.shortValue();
-        short vlan = (short) 27;
-        byte vlanPr = 3;
-        Byte tos = 4;
-        byte proto = IPProtocols.TCP.byteValue();
-        short src = (short) 55000;
-        short dst = 80;
-
-        /*
-         * Create a SAL Flow aFlow
-         */
-        Match match = new Match();
-        match.setField(MatchType.IN_PORT, port);
-        match.setField(MatchType.DL_SRC, srcMac);
-        match.setField(MatchType.DL_DST, dstMac);
-        match.setField(MatchType.DL_TYPE, ethertype);
-        match.setField(MatchType.DL_VLAN, vlan);
-        match.setField(MatchType.DL_VLAN_PR, vlanPr);
-        match.setField(MatchType.NW_SRC, srcIP, ipMask);
-        match.setField(MatchType.NW_DST, dstIP, ipMask2);
-        match.setField(MatchType.NW_TOS, tos);
-        match.setField(MatchType.NW_PROTO, proto);
-        match.setField(MatchType.TP_SRC, src);
-        match.setField(MatchType.TP_DST, dst);
-
-        List<Action> actions = new ArrayList<Action>();
-        actions.add(new Output(oport));
-        actions.add(new PopVlan());
-        actions.add(new Flood());
-        actions.add(new Controller());
-        return new Flow(match, actions);
-    }
-}
diff --git a/opendaylight/adsal/sal/implementation/src/main/java/org/opendaylight/controller/sal/implementation/internal/Topology.java b/opendaylight/adsal/sal/implementation/src/main/java/org/opendaylight/controller/sal/implementation/internal/Topology.java
deleted file mode 100644 (file)
index d488096..0000000
+++ /dev/null
@@ -1,117 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.implementation.internal;
-
-import java.util.Collections;
-import java.util.HashSet;
-import java.util.List;
-import java.util.Set;
-
-import org.opendaylight.controller.sal.core.Edge;
-import org.opendaylight.controller.sal.topology.IListenTopoUpdates;
-import org.opendaylight.controller.sal.topology.IPluginInTopologyService;
-import org.opendaylight.controller.sal.topology.IPluginOutTopologyService;
-import org.opendaylight.controller.sal.topology.ITopologyService;
-import org.opendaylight.controller.sal.topology.TopoEdgeUpdate;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-public class Topology implements IPluginOutTopologyService, ITopologyService {
-    protected static final Logger logger = LoggerFactory
-            .getLogger(Topology.class);
-    private Set<IListenTopoUpdates> updateService = Collections
-            .synchronizedSet(new HashSet<IListenTopoUpdates>());
-    private Set<IPluginInTopologyService> pluginService = Collections
-            .synchronizedSet(new HashSet<IPluginInTopologyService>());
-
-    void setPluginService(IPluginInTopologyService s) {
-        if (this.pluginService != null) {
-            this.pluginService.add(s);
-        }
-    }
-
-    void unsetPluginService(IPluginInTopologyService s) {
-        if (this.pluginService != null) {
-            this.pluginService.remove(s);
-        }
-    }
-
-    void setUpdateService(IListenTopoUpdates s) {
-        if (this.updateService != null) {
-            this.updateService.add(s);
-        }
-    }
-
-    void unsetUpdateService(IListenTopoUpdates s) {
-        if (this.updateService != null) {
-            this.updateService.remove(s);
-        }
-    }
-
-    /**
-     * Function called by the dependency manager when all the required
-     * dependencies are satisfied
-     *
-     */
-    void init() {
-    }
-
-    /**
-     * Function called by the dependency manager when at least one dependency
-     * become unsatisfied or when the component is shutting down because for
-     * example bundle is being stopped.
-     *
-     */
-    void destroy() {
-        // Make sure to clear all the data structure we use to track
-        // services
-        if (this.updateService != null) {
-            this.updateService.clear();
-        }
-        if (this.pluginService != null) {
-            this.pluginService.clear();
-        }
-    }
-
-    @Override
-    public void sollicitRefresh() {
-        synchronized (this.pluginService) {
-            for (IPluginInTopologyService s : this.pluginService) {
-                s.sollicitRefresh();
-            }
-        }
-    }
-
-    @Override
-    public void edgeUpdate(List<TopoEdgeUpdate> topoedgeupdateList) {
-        synchronized (this.updateService) {
-            for (IListenTopoUpdates s : this.updateService) {
-                s.edgeUpdate(topoedgeupdateList);
-            }
-        }
-    }
-
-    @Override
-    public void edgeOverUtilized(Edge edge) {
-        synchronized (this.updateService) {
-            for (IListenTopoUpdates s : this.updateService) {
-                s.edgeOverUtilized(edge);
-            }
-        }
-    }
-
-    @Override
-    public void edgeUtilBackToNormal(Edge edge) {
-        synchronized (this.updateService) {
-            for (IListenTopoUpdates s : this.updateService) {
-                s.edgeUtilBackToNormal(edge);
-            }
-        }
-    }
-}
diff --git a/opendaylight/adsal/sal/implementation/src/test/java/org/opendaylight/controller/sal/implementation/DataPacketServiceTest.java b/opendaylight/adsal/sal/implementation/src/test/java/org/opendaylight/controller/sal/implementation/DataPacketServiceTest.java
deleted file mode 100644 (file)
index 3a07288..0000000
+++ /dev/null
@@ -1,180 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.implementation;
-
-import org.junit.Assert;
-import org.junit.Test;
-import org.opendaylight.controller.sal.core.ConstructionException;
-import org.opendaylight.controller.sal.implementation.internal.DataPacketService;
-import org.opendaylight.controller.sal.packet.ARP;
-import org.opendaylight.controller.sal.packet.Ethernet;
-import org.opendaylight.controller.sal.packet.Packet;
-import org.opendaylight.controller.sal.packet.RawPacket;
-
-public class DataPacketServiceTest {
-
-        @Test
-        public void DataPacketServiceDecodeTest() throws ConstructionException, InstantiationException, IllegalAccessException {
-
-                DataPacketService dService = new DataPacketService();
-                RawPacket rawPkt = null;
-
-                Assert.assertTrue(dService.decodeDataPacket(rawPkt) == null);
-
-        byte[] data = { 10, 12, 14, 20, 55, 69, //DMAC
-                -90, -20, -100, -82, -78, -97, //SMAC
-                8, 6, //ethype
-                0, 1, // hw type
-                8, 0, // proto (ip)
-                6, // hw addr len
-                4, // proto addr len
-                0, 1, // op codes
-                -90, -20, -100, -82, -78, -97, //src hw addr
-                9, 9, 9, 1, // src proto
-                0, 0, 0, 0, 0, 0, // target hw addr
-                9, 9, 9, -2 }; // target proto
-
-        rawPkt = new RawPacket(data);
-
-        Packet decodedPkt = dService.decodeDataPacket(rawPkt);
-        Class<? extends Packet> payloadClass = ARP.class;
-        Assert.assertTrue(payloadClass == decodedPkt.getPayload().getClass());
-
-        ARP arpPacket = (ARP) decodedPkt.getPayload();
-
-        Assert.assertTrue(arpPacket.getHardwareType() == (byte)0x1);
-        Assert.assertTrue(arpPacket.getProtocolType() == 2048);
-        Assert.assertTrue(arpPacket.getHardwareAddressLength() == (byte)0x6);
-        Assert.assertTrue(arpPacket.getProtocolAddressLength() == (byte)0x4);
-        Assert.assertTrue(arpPacket.getOpCode() == 1);
-
-        byte[] senderHwAddress = arpPacket.getSenderHardwareAddress();
-        byte[] senderProtocolAddress = arpPacket.getSenderProtocolAddress();
-
-        byte[] targetHwAddress = arpPacket.getTargetHardwareAddress();
-        byte[] targetProtocolAddress = arpPacket.getTargetProtocolAddress();
-
-
-        Assert.assertTrue(senderHwAddress[0] == (byte)0xA6);
-        Assert.assertTrue(senderHwAddress[1] == (byte)0xEC);
-        Assert.assertTrue(senderHwAddress[2] == (byte)0x9C);
-        Assert.assertTrue(senderHwAddress[3] == (byte)0xAE);
-        Assert.assertTrue(senderHwAddress[4] == (byte)0xB2);
-        Assert.assertTrue(senderHwAddress[5] == (byte)0x9F);
-
-        Assert.assertTrue(senderProtocolAddress[0] == (byte)0x9);
-        Assert.assertTrue(senderProtocolAddress[1] == (byte)0x9);
-        Assert.assertTrue(senderProtocolAddress[2] == (byte)0x9);
-        Assert.assertTrue(senderProtocolAddress[3] == (byte)0x1);
-
-        Assert.assertTrue(targetHwAddress[0] == (byte)0x0);
-        Assert.assertTrue(targetHwAddress[1] == (byte)0x0);
-        Assert.assertTrue(targetHwAddress[2] == (byte)0x0);
-        Assert.assertTrue(targetHwAddress[3] == (byte)0x0);
-        Assert.assertTrue(targetHwAddress[4] == (byte)0x0);
-        Assert.assertTrue(targetHwAddress[5] == (byte)0x0);
-
-        Assert.assertTrue(senderProtocolAddress[0] == (byte)0x9);
-        Assert.assertTrue(senderProtocolAddress[1] == (byte)0x9);
-        Assert.assertTrue(senderProtocolAddress[2] == (byte)0x9);
-        Assert.assertTrue(senderProtocolAddress[3] == (byte)0x1);
-
-        Assert.assertTrue(targetProtocolAddress[0] == (byte)0x9);
-        Assert.assertTrue(targetProtocolAddress[1] == (byte)0x9);
-        Assert.assertTrue(targetProtocolAddress[2] == (byte)0x9);
-        Assert.assertTrue(targetProtocolAddress[3] == (byte)0xFE);
-        }
-
-        @Test
-        public void DataPacketServiceEncodeTest() throws ConstructionException, InstantiationException, IllegalAccessException {
-
-                DataPacketService dService = new DataPacketService();
-                Ethernet eth = new Ethernet();
-        ARP arp = new ARP();
-
-                byte[] data = null;
-                RawPacket rawPkt;
-
-
-        byte[] dMAC = { 10, 12, 14, 20, 55, 69 };
-        byte[] sMAC = { 82, 97, 109, 117, 127, -50 };
-        short etherType = 2054;
-
-        eth.setDestinationMACAddress(dMAC);
-        eth.setSourceMACAddress(sMAC);
-        eth.setEtherType(etherType);
-
-        arp.setHardwareType((short)1);
-        arp.setProtocolType((short)2048);
-        arp.setHardwareAddressLength((byte)0x6);
-        arp.setProtocolAddressLength((byte)0x4);
-        arp.setOpCode((byte)0x1);
-
-        byte[] senderHardwareAddress = {(byte)0xA6, (byte)0xEC, (byte)0x9C, (byte)0xAE,
-                                                                        (byte)0xB2, (byte)0x9F};
-        byte[] senderProtocolAddress = {(byte)0x09, (byte)0x09, (byte)0x09, (byte)0x01};
-        byte[] targetProtocolAddress = {(byte)0x09, (byte)0x09, (byte)0x09, (byte)0xFE};
-        byte[] targetHardwareAddress = {(byte)0x0, (byte)0x0, (byte)0x0, (byte)0x0, (byte)0x0, (byte)0x0};
-        arp.setSenderHardwareAddress(senderHardwareAddress);
-        arp.setSenderProtocolAddress(senderProtocolAddress);
-        arp.setTargetHardwareAddress(targetHardwareAddress);
-        arp.setTargetProtocolAddress(targetProtocolAddress);
-
-        arp.setParent(eth);
-        eth.setPayload(arp);
-
-        rawPkt = dService.encodeDataPacket(eth);
-        data = rawPkt.getPacketData();
-
-        Assert.assertTrue(data[0] == (byte)0x0A);//Destination MAC
-        Assert.assertTrue(data[1] == (byte)0x0C);
-        Assert.assertTrue(data[2] == (byte)0x0E);
-        Assert.assertTrue(data[3] == (byte)0x14);
-        Assert.assertTrue(data[4] == (byte)0x37);
-        Assert.assertTrue(data[5] == (byte)0x45);
-        Assert.assertTrue(data[6] == (byte)0x52);//Source MAC
-        Assert.assertTrue(data[7] == (byte)0x61);
-        Assert.assertTrue(data[8] == (byte)0x6D);
-        Assert.assertTrue(data[9] == (byte)0x75);
-        Assert.assertTrue(data[10] == (byte)0x7F);
-        Assert.assertTrue(data[11] == (byte)0xCE);
-        Assert.assertTrue(data[12] == (byte)0x08);//EtherType
-        Assert.assertTrue(data[13] == (byte)0x06);
-        Assert.assertTrue(data[14] == (byte)0x00);//Hardware Type
-        Assert.assertTrue(data[15] == (byte)0x01);
-        Assert.assertTrue(data[16] == (byte)0x08);//Protocol Type
-        Assert.assertTrue(data[17] == (byte)0x0);
-        Assert.assertTrue(data[18] == (byte)0x6);//Hardware Address Length
-        Assert.assertTrue(data[19] == (byte)0x4);//Protocol Address Length
-        Assert.assertTrue(data[20] == (byte)0x0);//Opcode
-        Assert.assertTrue(data[21] == (byte)0x1);//Opcode
-        Assert.assertTrue(data[22] == (byte)0xA6);//Sender Hardware Address
-        Assert.assertTrue(data[23] == (byte)0xEC);
-        Assert.assertTrue(data[24] == (byte)0x9C);
-        Assert.assertTrue(data[25] == (byte)0xAE);
-        Assert.assertTrue(data[26] == (byte)0xB2);
-        Assert.assertTrue(data[27] == (byte)0x9F);
-        Assert.assertTrue(data[28] == (byte)0x09);//Sender Protocol Address
-        Assert.assertTrue(data[29] == (byte)0x09);
-        Assert.assertTrue(data[30] == (byte)0x09);
-        Assert.assertTrue(data[31] == (byte)0x01);//Target Hardware Address
-        Assert.assertTrue(data[32] == (byte)0x00);
-        Assert.assertTrue(data[33] == (byte)0x00);
-        Assert.assertTrue(data[34] == (byte)0x00);
-        Assert.assertTrue(data[35] == (byte)0x00);
-        Assert.assertTrue(data[36] == (byte)0x00);
-        Assert.assertTrue(data[37] == (byte)0x00);
-        Assert.assertTrue(data[38] == (byte)0x09);//Target Protocol Address
-        Assert.assertTrue(data[39] == (byte)0x09);
-        Assert.assertTrue(data[40] == (byte)0x09);
-        Assert.assertTrue(data[41] == (byte)0xFE);
-        }
-
-}
diff --git a/opendaylight/adsal/sal/implementation/src/test/java/org/opendaylight/controller/sal/implementation/ProtocolServiceTest.java b/opendaylight/adsal/sal/implementation/src/test/java/org/opendaylight/controller/sal/implementation/ProtocolServiceTest.java
deleted file mode 100644 (file)
index 079350b..0000000
+++ /dev/null
@@ -1,199 +0,0 @@
-/*
- * Copyright (c) 2014 NEC Corporation and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.sal.implementation;
-
-import java.util.HashMap;
-import java.util.HashSet;
-import java.util.Map;
-import java.util.concurrent.ConcurrentHashMap;
-import java.util.concurrent.ConcurrentMap;
-
-import org.junit.Test;
-import static org.junit.Assert.assertEquals;
-import static org.junit.Assert.assertFalse;
-import static org.junit.Assert.assertNotNull;
-import static org.junit.Assert.assertTrue;
-
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import org.opendaylight.controller.sal.implementation.internal.ProtocolService;
-import org.opendaylight.controller.sal.utils.GlobalConstants;
-
-/**
- * Unit test for {@link ProtocolService}.
- */
-public class ProtocolServiceTest {
-    private static final Logger LOG =
-        LoggerFactory.getLogger(ProtocolServiceTest.class);
-
-    @Test
-    public void testInstance() {
-        HashSet<ProtocolService<ITestService>> set = new HashSet<>();
-        TestService sv1 = new TestService();
-        HashMap<String, Object> prop1 = new HashMap<>();
-
-        ProtocolService<ITestService> ps1 =
-            new ProtocolService<ITestService>(prop1, sv1);
-        assertEquals(sv1, ps1.getService());
-        // Default priority is 0.
-        assertEquals(0, ps1.getPriority());
-        assertTrue(set.add(ps1));
-        assertFalse(set.add(ps1));
-
-        // Specify the same service and priority.
-        String priKey = GlobalConstants.PROTOCOLPLUGINPRIORITY.toString();
-        prop1.put(priKey, Integer.valueOf(0));
-        ProtocolService<ITestService> ps2 =
-            new ProtocolService<ITestService>(prop1, sv1);
-        assertEquals(sv1, ps2.getService());
-        assertEquals(0, ps2.getPriority());
-        assertEquals(ps1, ps2);
-        assertFalse(set.add(ps1));
-
-        // Specify different priority.
-        prop1.put(priKey, Integer.valueOf(Integer.MAX_VALUE));
-        ps2 = new ProtocolService<ITestService>(prop1, sv1);
-        assertEquals(sv1, ps2.getService());
-        assertEquals(Integer.MAX_VALUE, ps2.getPriority());
-        assertFalse(ps1.equals(ps2));
-        assertTrue(set.add(ps2));
-        assertFalse(set.add(ps2));
-
-        // Specify another service.
-        TestService sv2 = new TestService();
-        prop1.put(priKey, Integer.valueOf(0));
-        ps2 = new ProtocolService<ITestService>(prop1, sv2);
-        assertEquals(sv2, ps2.getService());
-        assertEquals(0, ps2.getPriority());
-        assertFalse(ps1.equals(ps2));
-        assertTrue(set.add(ps2));
-        assertFalse(set.add(ps2));
-    }
-
-    @Test
-    public void testSetUnsetError() {
-        ConcurrentMap<String, ProtocolService<ITestService>> services =
-            new ConcurrentHashMap<>();
-        TestService sv = new TestService();
-        Map<String, Object> props = new HashMap<>();
-
-        // null service.
-        ProtocolService.set(services, props, null, LOG);
-        assertTrue(services.isEmpty());
-
-        ProtocolService.unset(services, props, null, LOG);
-        assertTrue(services.isEmpty());
-
-        // null service property.
-        ProtocolService.set(services, null, sv, LOG);
-        assertTrue(services.isEmpty());
-
-        ProtocolService.unset(services, null, sv, LOG);
-        assertTrue(services.isEmpty());
-
-        // Type is not specified.
-        ProtocolService.set(services, props, sv, LOG);
-        assertTrue(services.isEmpty());
-
-        ProtocolService.unset(services, props, sv, LOG);
-        assertTrue(services.isEmpty());
-
-        // null service map.
-        final String typeKey = GlobalConstants.PROTOCOLPLUGINTYPE.toString();
-        assertEquals(null, props.put(typeKey, "OF"));
-        ProtocolService.set(null, props, sv, LOG);
-        assertTrue(services.isEmpty());
-
-        ProtocolService.unset(null, props, sv, LOG);
-        assertTrue(services.isEmpty());
-    }
-
-    @Test
-    public void testSetUnset() {
-        ConcurrentMap<String, ProtocolService<ITestService>> serviceMap =
-            new ConcurrentHashMap<>();
-        ConcurrentMap<String, ProtocolService<ITestService>> expected =
-            new ConcurrentHashMap<>();
-
-        final String typeKey = GlobalConstants.PROTOCOLPLUGINTYPE.toString();
-        final String priKey = GlobalConstants.PROTOCOLPLUGINPRIORITY.toString();
-        final String[] protocols = {"OF", "PE", "PK"};
-        final int basePri = 0;
-        final int loop = 5;
-
-        // Should override the service if higher priority is specified.
-        for (String proto: protocols) {
-            for (int pri = basePri - loop + 1; pri <= basePri; pri++) {
-                TestService sv = new TestService();
-                Map<String, Object> props = new HashMap<>();
-                assertEquals(null, props.put(typeKey, proto));
-                assertEquals(null, props.put(priKey, Integer.valueOf(pri)));
-                ProtocolService.set(serviceMap, props, sv, LOG);
-
-                ProtocolService<ITestService> service = serviceMap.get(proto);
-                assertNotNull(service);
-                assertEquals(sv, service.getService());
-                assertEquals(pri, service.getPriority());
-
-                ProtocolService<ITestService> service1 =
-                    new ProtocolService<ITestService>(props, sv);
-                expected.put(proto, service1);
-                assertEquals(expected, serviceMap);
-
-                // Unset service request should be ignored if different
-                // parameters are specified.
-                TestService another = new TestService();
-                ProtocolService.unset(serviceMap, props, another, LOG);
-                assertEquals(expected, serviceMap);
-
-                props.put(priKey, Integer.valueOf(Integer.MAX_VALUE));
-                ProtocolService.unset(serviceMap, props, sv, LOG);
-                assertEquals(expected, serviceMap);
-            }
-        }
-
-        // Should reject the set service request if lower priority is specified.
-        for (String proto: protocols) {
-            for (int pri = basePri - loop; pri < basePri; pri++) {
-                TestService sv = new TestService();
-                Map<String, Object> props = new HashMap<>();
-                assertEquals(null, props.put(typeKey, proto));
-                assertEquals(null, props.put(priKey, Integer.valueOf(pri)));
-                ProtocolService.set(serviceMap, props, sv, LOG);
-                assertEquals(expected, serviceMap);
-            }
-        }
-
-        // Unset protocol services.
-        for (String proto: protocols) {
-            ProtocolService<ITestService> service = expected.remove(proto);
-            assertNotNull(service);
-
-            ITestService sv = service.getService();
-            Map<String, Object> props = new HashMap<>();
-            assertEquals(null, props.put(typeKey, proto));
-            assertEquals(null, props.put(priKey, Integer.valueOf(basePri)));
-            ProtocolService.unset(serviceMap, props, sv, LOG);
-            assertEquals(expected, serviceMap);
-
-            // Should be ignored if the specified service does not exist.
-            ProtocolService.unset(serviceMap, props, sv, LOG);
-            assertEquals(expected, serviceMap);
-        }
-
-        assertTrue(serviceMap.isEmpty());
-    }
-}
-
-interface ITestService {
-}
-
-class TestService implements ITestService {
-}
diff --git a/opendaylight/adsal/sal/networkconfiguration/api/pom.xml b/opendaylight/adsal/sal/networkconfiguration/api/pom.xml
deleted file mode 100644 (file)
index 36706f0..0000000
+++ /dev/null
@@ -1,47 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>sal.networkconfiguration</artifactId>
-  <version>0.2.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Import-Package>org.slf4j,
-              org.osgi.framework,
-              org.apache.felix.dm,
-              org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.sal.utils</Import-Package>
-            <Export-Package>org.opendaylight.controller.sal.networkconfig.bridgedomain</Export-Package>
-          </instructions>
-          <manifestLocation>${project.basedir}/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/sal/networkconfiguration/api/src/main/java/org/opendaylight/controller/sal/networkconfig/bridgedomain/BridgeDomainConfigServiceException.java b/opendaylight/adsal/sal/networkconfiguration/api/src/main/java/org/opendaylight/controller/sal/networkconfig/bridgedomain/BridgeDomainConfigServiceException.java
deleted file mode 100644 (file)
index 19f467e..0000000
+++ /dev/null
@@ -1,24 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.sal.networkconfig.bridgedomain;
-
-/**
- * Exception thrown by IPluginInBridgeDomainConfigService implementations.
- */
-public class BridgeDomainConfigServiceException extends Exception {
-    private static final long serialVersionUID = 1L;
-
-    public BridgeDomainConfigServiceException(String message) {
-        super(message);
-    }
-
-    public BridgeDomainConfigServiceException(String message, Throwable cause) {
-        super(message, cause);
-    }
-}
-
diff --git a/opendaylight/adsal/sal/networkconfiguration/api/src/main/java/org/opendaylight/controller/sal/networkconfig/bridgedomain/ConfigConstants.java b/opendaylight/adsal/sal/networkconfiguration/api/src/main/java/org/opendaylight/controller/sal/networkconfig/bridgedomain/ConfigConstants.java
deleted file mode 100644 (file)
index def1b33..0000000
+++ /dev/null
@@ -1,40 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.sal.networkconfig.bridgedomain;
-
-/**
- * Enum constant that is used as a key for the configuration parameters for BridgeDomains and Ports.
- * The main intention of having a constant type is to avoid fragmentation and find common grounds for
- * applications to rely on.
- *
- * This is set to expand based on various capabilities south-bound protocol might expose.
- * Not all of them be supported by all the plugins. But this gives a consolidated view of
- * all the supported feature configs and avoid config fragmentation.
- */
-public enum ConfigConstants {
-    TYPE("type"),
-    VLAN("Vlan"),
-    VLAN_MODE("vlan_mode"),
-    TUNNEL_TYPE("Tunnel Type"),
-    SOURCE_IP("Source IP"),
-    DEST_IP("Destination IP"),
-    MACADDRESS("MAC Address"),
-    INTERFACE_IDENTIFIER("Interface Identifier"),
-    MGMT("Management"),
-    CUSTOM("Custom Configurations");
-
-    private ConfigConstants(String name) {
-        this.name = name;
-    }
-
-    private String name;
-
-    public String toString() {
-        return name;
-    }
-}
diff --git a/opendaylight/adsal/sal/networkconfiguration/api/src/main/java/org/opendaylight/controller/sal/networkconfig/bridgedomain/IBridgeDomainConfigService.java b/opendaylight/adsal/sal/networkconfiguration/api/src/main/java/org/opendaylight/controller/sal/networkconfig/bridgedomain/IBridgeDomainConfigService.java
deleted file mode 100644 (file)
index 590dff1..0000000
+++ /dev/null
@@ -1,14 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.sal.networkconfig.bridgedomain;
-
-/**
- * This interface is just a wrapper of IPluginInBridgeDomainConfigService
- */
-public interface IBridgeDomainConfigService extends IPluginInBridgeDomainConfigService {
-}
diff --git a/opendaylight/adsal/sal/networkconfiguration/api/src/main/java/org/opendaylight/controller/sal/networkconfig/bridgedomain/IPluginInBridgeDomainConfigService.java b/opendaylight/adsal/sal/networkconfiguration/api/src/main/java/org/opendaylight/controller/sal/networkconfig/bridgedomain/IPluginInBridgeDomainConfigService.java
deleted file mode 100644 (file)
index c841361..0000000
+++ /dev/null
@@ -1,164 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.sal.networkconfig.bridgedomain;
-
-import java.util.List;
-import java.util.Map;
-
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.utils.Status;
-
-/**
- * This interface defines bridge domain configuration service methods to be
- * implemented by protocol plugins
- */
-public interface IPluginInBridgeDomainConfigService {
-    /**
-     * Create a Bridge Domain
-     *
-     * @param node Node serving this configuration service
-     * @param bridgeIdentifier String representation of a Bridge Domain
-     * @param params Map representation of config name (ConfigConstants) and Parameter value (represented as Object).
-     * @return Status.StatusCode.SUCCESS if bridge domain is created successfully. Failure Status otherwise.
-     * @note This method will return false if one or more of the supplied params is not supported by the
-     * protocol plugin that serves the Node.
-     */
-    public Status createBridgeDomain(Node node, String bridgeIdentifier, Map<ConfigConstants, Object> params) throws BridgeDomainConfigServiceException;
-
-    /**
-     * Delete a Bridge Domain
-     *
-     * @param node Node serving this configuration service
-     * @param bridgeIdentifier String representation of a Bridge Domain
-     * @return Status.StatusCode.SUCCESS if bridge domain is deleted successfully. Failure Status otherwise.
-     */
-    public Status deleteBridgeDomain(Node node, String bridgeIdentifier);
-
-    /**
-     * Returns the configured Bridge Domains
-     *
-     * @param node Node serving this configuration service
-     * @return List of Bridge Domain Identifiers
-     */
-    public List<String> getBridgeDomains(Node node);
-
-    /**
-     * add Bridge Domain Configuration
-     *
-     * @param node Node serving this configuration service
-     * @param bridgeIdentifier String representation of a Bridge Domain
-     * @param params Map representation of config Name (ConfigConstants) and config value(represented as Object).
-     * @return Status.StatusCode.SUCCESS if bridge domain configuration is added successfully. Failure Status otherwise.
-     * @note This method will return false if one or more of the supplied params is not supported by the
-     * protocol plugin that serves the Node.
-     */
-    public Status addBridgeDomainConfig(Node node, String bridgeIdentifier, Map<ConfigConstants, Object> params);
-
-    /**
-     * Delete Bridge Domain Configuration
-     *
-     * @param node Node serving this configuration service
-     * @param bridgeIdentifier String representation of a Bridge Domain
-     * @param params Map representation of config name (ConfigConstants) and Parameter value (represented as Object).
-     * @return Status.StatusCode.SUCCESS if bridge domain configuration is deleted successfully. Failure Status otherwise.
-     * @note This method will return false if one or more of the supplied params is not supported by the
-     * protocol plugin that serves the Node.
-     */
-    public Status removeBridgeDomainConfig(Node node, String bridgeIdentifier, Map<ConfigConstants, Object> params);
-
-    /**
-     * Returns Bridge Domain Configurations
-     *
-     * @param node Node serving this configuration service
-     * @param bridgeIdentifier String representation of a Bridge Domain
-     * @return Map representation of config Name (ConfigConstants) and config value(represented as Object).
-     */
-
-    public Map<ConfigConstants, Object> getBridgeDomainConfigs(Node node, String bridgeIdentifier);
-
-    /**
-     * Returns a Node dedicated to a Bridge Domain (if available) that is created using createBridgeDomain.
-     * @param configNode Node serving this configuration service.
-     * @param bridgeIdentifier Name of the bridge domain that would map to a dedicated Node
-     * @return Node dedicated to a bridge domain that is created using createBridgeDomain.
-     *         returns null if there is no such dedicated node is available or represented.
-     */
-    public Node getBridgeDomainNode(Node configNode, String bridgeIdentifier);
-
-    /**
-     * Add a port to a bridge domain
-     *
-     * @param node Node serving this configuration service
-     * @param bridgeIdentifier String representation of a Bridge Domain
-     * @param portIdentifier String representation of a Port.
-     * @param params Map representation of config name (ConfigConstants) and Parameter value (represented as Object).
-     * @return Status.StatusCode.SUCCESS if a port is added successfully. Failure Status otherwise.
-     * @note This method will return false if one or more of the supplied params is not supported by the
-     * protocol plugin that serves the Node.
-     */
-    public Status addPort(Node node, String bridgeIdentifier, String portIdentifier,
-                           Map<ConfigConstants, Object> params);
-
-    /**
-     * Delete a Port from a bridge domain
-     *
-     * @param node Node serving this configuration service
-     * @param bridgeIdentifier String representation of a Bridge Domain
-     * @param portIdentifier String representation of a Port.
-     * @return Status.StatusCode.SUCCESS if a port is added successfully. Failure Status otherwise.
-     */
-    public Status deletePort(Node node, String bridgeIdentifier, String portIdentifier);
-
-    /**
-     * add Port Configuration
-     *
-     * @param node Node serving this configuration service
-     * @param bridgeIdentifier String representation of a Bridge Domain
-     * @param portIdentifier String representation of a Port.
-     * @param params Map representation of config name (ConfigConstants) and Parameter value (represented as Object).
-     * @return Status.StatusCode.SUCCESS if a port configuration is added successfully. Failure Status otherwise.
-     * @note This method will return false if one or more of the supplied params is not supported by the
-     * protocol plugin that serves the Node.
-     */
-    public Status addPortConfig(Node node, String bridgeIdentifier, String portIdentifier,
-                                 Map<ConfigConstants, Object> params);
-
-    /**
-     * Delete Port Configuration
-     *
-     * @param node Node serving this configuration service
-     * @param portIdentifier String representation of a Port.
-     * @param config Map representation of ConfigName and Configuration Value in Strings.
-     * @return Status.StatusCode.SUCCESS if a port configuration is removed successfully. Failure Status otherwise.
-     * @note This method will return false if one or more of the supplied params is not supported by the
-     * protocol plugin that serves the Node.
-     */
-    public Status removePortConfig(Node node, String bridgeIdentifier, String portIdentifier, Map<ConfigConstants, Object> params);
-
-    /**
-     * Returns Port Configurations
-     *
-     * @param node Node serving this configuration service
-     * @param bridgeIdentifier String representation of a Bridge Domain
-     * @param portIdentifier String representation of a Port.
-     * @return Map representation of Configuration Name (ConfigConstants) and Configuration value (represented as Object).
-     */
-    public Map<ConfigConstants, Object> getPortConfigs(Node node, String bridgeIdentifier, String portIdentifier);
-
-
-    /**
-     * Returns a NodeConnector mapped to a Port (if available) that is created using addPort.
-     * @param configNode Node serving this configuration service.
-     * @param bridgeIdentifier Name of the bridge domain that would map to a dedicated Node
-     * @param portIdentifier String representation of a Port.
-     * @return NodeConnector that is mapped to a port created using addPort.
-     *         returns null if there is no such nodeConnector is available or mapped.
-     */
-    public NodeConnector getNodeConnector(Node configNode, String bridgeIdentifier, String portIdentifier);
-}
diff --git a/opendaylight/adsal/sal/networkconfiguration/implementation/pom.xml b/opendaylight/adsal/sal/networkconfiguration/implementation/pom.xml
deleted file mode 100644 (file)
index da2bc97..0000000
+++ /dev/null
@@ -1,53 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>sal.networkconfiguration.implementation</artifactId>
-  <version>0.2.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal.networkconfiguration</artifactId>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Import-Package>org.slf4j,
-              org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.sal.utils,
-              org.opendaylight.controller.sal.networkconfig.bridgedomain,
-              org.apache.felix.dm,
-              org.osgi.framework</Import-Package>
-            <Export-Package></Export-Package>
-            <Bundle-Activator>org.opendaylight.controller.sal.networkconfig.internal.Activator</Bundle-Activator>
-          </instructions>
-          <manifestLocation>${project.basedir}/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/sal/networkconfiguration/implementation/src/main/java/org/opendaylight/controller/sal/networkconfig/bridgedomain/internal/BridgeDomainConfigService.java b/opendaylight/adsal/sal/networkconfiguration/implementation/src/main/java/org/opendaylight/controller/sal/networkconfig/bridgedomain/internal/BridgeDomainConfigService.java
deleted file mode 100644 (file)
index 14c5e0d..0000000
+++ /dev/null
@@ -1,227 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.sal.networkconfig.bridgedomain.internal;
-
-import java.util.List;
-import java.util.Map;
-import java.util.concurrent.ConcurrentHashMap;
-import java.util.concurrent.ConcurrentMap;
-
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.networkconfig.bridgedomain.BridgeDomainConfigServiceException;
-import org.opendaylight.controller.sal.networkconfig.bridgedomain.ConfigConstants;
-import org.opendaylight.controller.sal.networkconfig.bridgedomain.IBridgeDomainConfigService;
-import org.opendaylight.controller.sal.networkconfig.bridgedomain.IPluginInBridgeDomainConfigService;
-import org.opendaylight.controller.sal.utils.GlobalConstants;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.sal.utils.StatusCode;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-public class BridgeDomainConfigService implements IBridgeDomainConfigService {
-    protected static final Logger logger = LoggerFactory
-            .getLogger(BridgeDomainConfigService.class);
-    private final ConcurrentMap<String, IPluginInBridgeDomainConfigService> pluginService =
-            new ConcurrentHashMap<String, IPluginInBridgeDomainConfigService>();
-
-    void setPluginInService (Map props, IPluginInBridgeDomainConfigService s) {
-        String type = null;
-        Object value = props.get(GlobalConstants.PROTOCOLPLUGINTYPE.toString());
-        if (value instanceof String) {
-            type = (String) value;
-        }
-        if (type == null) {
-            logger.error("Received a PluginInConnectionService without any "
-                    + "protocolPluginType provided");
-        } else {
-            this.pluginService.put(type, s);
-        }
-    }
-
-    void unsetPluginInService(Map props, IPluginInBridgeDomainConfigService s) {
-        String type = null;
-
-        Object value = props.get(GlobalConstants.PROTOCOLPLUGINTYPE.toString());
-        if (value instanceof String) {
-            type = (String) value;
-        }
-        if (type == null) {
-            logger.error("Received a PluginInConnectionService without any "
-                    + "protocolPluginType provided");
-        } else if (this.pluginService.get(type).equals(s)) {
-            this.pluginService.remove(type);
-        }
-    }
-
-    /**
-     * Function called by the dependency manager when all the required
-     * dependencies are satisfied
-     *
-     */
-    void init() {
-    }
-
-    /**
-     * Function called by the dependency manager when at least one dependency
-     * become unsatisfied or when the component is shutting down because for
-     * example bundle is being stopped.
-     *
-     */
-    void destroy() {
-        if (this.pluginService != null) {
-            this.pluginService.clear();
-        }
-    }
-
-    @Override
-    public Status createBridgeDomain(Node node, String bridgeIdentifier, Map<ConfigConstants, Object> params)
-            throws BridgeDomainConfigServiceException {
-        if (pluginService != null) {
-            IPluginInBridgeDomainConfigService plugin = this.pluginService.get(node.getType());
-            if (plugin != null) {
-                return plugin.createBridgeDomain(node, bridgeIdentifier, params);
-            }
-        }
-        return new Status(StatusCode.NOSERVICE, "Requested Plugin Service Not available");
-    }
-
-    @Override
-    public Status deleteBridgeDomain(Node node, String bridgeIdentifier) {
-        if (pluginService != null) {
-            IPluginInBridgeDomainConfigService plugin = this.pluginService.get(node.getType());
-            if (plugin != null) {
-                return plugin.deleteBridgeDomain(node, bridgeIdentifier);
-            }
-        }
-        return new Status(StatusCode.NOSERVICE, "Requested Plugin Service Not available");
-    }
-
-    @Override
-    public List<String> getBridgeDomains(Node node) {
-        if (pluginService != null) {
-            IPluginInBridgeDomainConfigService plugin = this.pluginService.get(node.getType());
-            if (plugin != null) {
-                return plugin.getBridgeDomains(node);
-            }
-        }
-        return null;
-    }
-
-    @Override
-    public Status addBridgeDomainConfig(Node node, String bridgeIdentifier, Map<ConfigConstants, Object> params) {
-        if (pluginService != null) {
-            IPluginInBridgeDomainConfigService plugin = this.pluginService.get(node.getType());
-            if (plugin != null) {
-                return plugin.addBridgeDomainConfig(node, bridgeIdentifier, params);
-            }
-        }
-        return new Status(StatusCode.NOSERVICE, "Requested Plugin Service Not available");
-    }
-
-    @Override
-    public Status removeBridgeDomainConfig(Node node, String bridgeIdentifier, Map<ConfigConstants, Object> params) {
-        if (pluginService != null) {
-            IPluginInBridgeDomainConfigService plugin = this.pluginService.get(node.getType());
-            if (plugin != null) {
-                return plugin.removeBridgeDomainConfig(node, bridgeIdentifier, params);
-            }
-        }
-        return new Status(StatusCode.NOSERVICE, "Requested Plugin Service Not available");
-    }
-
-    @Override
-    public Map<ConfigConstants, Object> getBridgeDomainConfigs(Node node, String bridgeIdentifier) {
-        if (pluginService != null) {
-            IPluginInBridgeDomainConfigService plugin = this.pluginService.get(node.getType());
-            if (plugin != null) {
-                return plugin.getBridgeDomainConfigs(node, bridgeIdentifier);
-            }
-        }
-        return null;
-    }
-
-    @Override
-    public Node getBridgeDomainNode(Node configNode, String bridgeIdentifier) {
-        if (pluginService != null) {
-            IPluginInBridgeDomainConfigService plugin = this.pluginService.get(configNode.getType());
-            if (plugin != null) {
-                return plugin.getBridgeDomainNode(configNode, bridgeIdentifier);
-            }
-        }
-        return null;
-    }
-
-    @Override
-    public Status addPort(Node node, String bridgeIdentifier, String portIdentifier, Map<ConfigConstants, Object> params) {
-        if (pluginService != null) {
-            IPluginInBridgeDomainConfigService plugin = this.pluginService.get(node.getType());
-            if (plugin != null) {
-                return plugin.addPort(node, bridgeIdentifier, portIdentifier, params);
-            }
-        }
-        return new Status(StatusCode.NOSERVICE, "Requested Plugin Service Not available");
-    }
-
-    @Override
-    public Status deletePort(Node node, String bridgeIdentifier, String portIdentifier) {
-        if (pluginService != null) {
-            IPluginInBridgeDomainConfigService plugin = this.pluginService.get(node.getType());
-            if (plugin != null) {
-                return plugin.deletePort(node, bridgeIdentifier, portIdentifier);
-            }
-        }
-        return new Status(StatusCode.NOSERVICE, "Requested Plugin Service Not available");
-    }
-
-    @Override
-    public Status addPortConfig(Node node, String bridgeIdentifier, String portIdentifier,
-            Map<ConfigConstants, Object> params) {
-        if (pluginService != null) {
-            IPluginInBridgeDomainConfigService plugin = this.pluginService.get(node.getType());
-            if (plugin != null) {
-                return plugin.addPortConfig(node, bridgeIdentifier, portIdentifier, params);
-            }
-        }
-        return new Status(StatusCode.NOSERVICE, "Requested Plugin Service Not available");
-    }
-
-    @Override
-    public Status removePortConfig(Node node, String bridgeIdentifier, String portIdentifier,
-            Map<ConfigConstants, Object> params) {
-        if (pluginService != null) {
-            IPluginInBridgeDomainConfigService plugin = this.pluginService.get(node.getType());
-            if (plugin != null) {
-                return plugin.removePortConfig(node, bridgeIdentifier, portIdentifier, params);
-            }
-        }
-        return new Status(StatusCode.NOSERVICE, "Requested Plugin Service Not available");
-    }
-
-    @Override
-    public Map<ConfigConstants, Object> getPortConfigs(Node node, String bridgeIdentifier, String portIdentifier) {
-        if (pluginService != null) {
-            IPluginInBridgeDomainConfigService plugin = this.pluginService.get(node.getType());
-            if (plugin != null) {
-                return plugin.getPortConfigs(node, bridgeIdentifier, portIdentifier);
-            }
-        }
-        return null;
-    }
-
-    @Override
-    public NodeConnector getNodeConnector(Node configNode, String bridgeIdentifier, String portIdentifier) {
-        if (pluginService != null) {
-            IPluginInBridgeDomainConfigService plugin = this.pluginService.get(configNode.getType());
-            if (plugin != null) {
-                return plugin.getNodeConnector(configNode, bridgeIdentifier, portIdentifier);
-            }
-        }
-        return null;
-    }
-}
diff --git a/opendaylight/adsal/sal/networkconfiguration/implementation/src/main/java/org/opendaylight/controller/sal/networkconfig/internal/Activator.java b/opendaylight/adsal/sal/networkconfiguration/implementation/src/main/java/org/opendaylight/controller/sal/networkconfig/internal/Activator.java
deleted file mode 100644 (file)
index 1fc7349..0000000
+++ /dev/null
@@ -1,59 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.sal.networkconfig.internal;
-
-import org.apache.felix.dm.Component;
-import org.opendaylight.controller.sal.core.ComponentActivatorAbstractBase;
-import org.opendaylight.controller.sal.networkconfig.bridgedomain.IBridgeDomainConfigService;
-import org.opendaylight.controller.sal.networkconfig.bridgedomain.IPluginInBridgeDomainConfigService;
-import org.opendaylight.controller.sal.networkconfig.bridgedomain.internal.BridgeDomainConfigService;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-public class Activator extends ComponentActivatorAbstractBase {
-    protected static final Logger logger = LoggerFactory
-            .getLogger(Activator.class);
-
-
-    /**
-     * Function that is used to communicate to dependency manager the list of
-     * known Global implementations
-     *
-     *
-     * @return An array containing all the CLASS objects that will be
-     *         instantiated in order to get an fully working implementation
-     *         Object
-     */
-    public Object[] getGlobalImplementations() {
-        Object[] res = { BridgeDomainConfigService.class};
-        return res;
-    }
-
-    /**
-     * Function that is called when configuration of the dependencies is required.
-     *
-     * @param c
-     *            dependency manager Component object, used for configuring the
-     *            dependencies exported and imported
-     * @param imp
-     *            Implementation class that is being configured, needed as long
-     *            as the same routine can configure multiple implementations
-     */
-    public void configureGlobalInstance(Component c, Object imp) {
-        if (imp.equals(BridgeDomainConfigService.class)) {
-            c.setInterface(
-                    new String[] { IBridgeDomainConfigService.class.getName()},
-                                   null);
-
-            c.add(createServiceDependency()
-                    .setService(IPluginInBridgeDomainConfigService.class)
-                    .setCallbacks("setPluginInService", "unsetPluginInService")
-                    .setRequired(false));
-        }
-    }
-}
diff --git a/opendaylight/adsal/samples/clustersession/pom.xml b/opendaylight/adsal/samples/clustersession/pom.xml
deleted file mode 100644 (file)
index 977a324..0000000
+++ /dev/null
@@ -1,109 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-  <groupId>org.opendaylight.controller</groupId>
-  <artifactId>clustersession</artifactId>
-  <version>1.2.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>javax.servlet</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>orbit</groupId>
-      <artifactId>org.apache.catalina</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>orbit</groupId>
-      <artifactId>org.apache.catalina.ha</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>orbit</groupId>
-      <artifactId>org.apache.coyote</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>orbit</groupId>
-      <artifactId>org.apache.juli.extras</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>orbit</groupId>
-      <artifactId>org.apache.tomcat.api</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>orbit</groupId>
-      <artifactId>org.apache.tomcat.util</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>clustering.services</artifactId>
-      <version>0.7.0-SNAPSHOT</version>
-    </dependency>
-    <dependency>
-      <groupId>org.slf4j</groupId>
-      <artifactId>jcl-over-slf4j</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.osgi</groupId>
-      <artifactId>org.osgi.core</artifactId>
-      <scope>provided</scope>
-    </dependency>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-      <scope>test</scope>
-    </dependency>
-    <dependency>
-      <groupId>org.mockito</groupId>
-      <artifactId>mockito-all</artifactId>
-      <version>1.9.5</version>
-      <scope>test</scope>
-    </dependency>
-    <dependency>
-      <groupId>org.powermock</groupId>
-      <artifactId>powermock-api-mockito</artifactId>
-      <version>1.5.4</version>
-      <scope>test</scope>
-    </dependency>
-    <dependency>
-      <groupId>org.powermock</groupId>
-      <artifactId>powermock-module-junit4</artifactId>
-      <version>1.5.4</version>
-      <scope>test</scope>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <version>2.4.0</version>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Fragment-Host>org.eclipse.gemini.web.tomcat</Fragment-Host>
-            <Export-Package>org.opendaylight.controller.clustersession</Export-Package>
-            <Import-Package>org.apache.catalina,
-              org.apache.catalina.session,
-              org.apache.catalina.util,
-              org.apache.catalina.ha.session,
-              javax.servlet,
-              javax.servlet.http,
-              org.slf4j,
-              org.osgi.framework,
-              org.eclipse.osgi.framework.console,
-              org.opendaylight.controller.clustering.services</Import-Package>
-          </instructions>
-          <manifestLocation>${project.basedir}/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-</project>
diff --git a/opendaylight/adsal/samples/clustersession/src/main/java/org/opendaylight/controller/clustersession/ClusterSession.java b/opendaylight/adsal/samples/clustersession/src/main/java/org/opendaylight/controller/clustersession/ClusterSession.java
deleted file mode 100644 (file)
index dc93700..0000000
+++ /dev/null
@@ -1,162 +0,0 @@
-package org.opendaylight.controller.clustersession;
-
-import java.beans.PropertyChangeSupport;
-import java.io.Serializable;
-import java.security.Principal;
-import java.util.ArrayList;
-import java.util.concurrent.ConcurrentHashMap;
-
-import org.apache.catalina.Manager;
-import org.apache.catalina.SessionListener;
-import org.apache.catalina.session.StandardSession;
-import org.opendaylight.controller.clustersession.service.ClusterSessionService;
-
-public class ClusterSession extends StandardSession implements Serializable {
-
-  private static final long serialVersionUID = 1L;
-
-  private transient ClusterSessionService sessionService;
-
-  public ClusterSession(Manager manager, ClusterSessionService sessionService) {
-    super(manager);
-    this.sessionService = sessionService;
-  }
-
-  public void setSessionService(ClusterSessionService sessionService){
-    this.sessionService = sessionService;
-  }
-
-  @Override
-  public void setAuthType(String authType) {
-    super.setAuthType(authType);
-    sessionService.updateSession(this);
-  }
-
-  @Override
-  public void setCreationTime(long time) {
-    super.setCreationTime(time);
-    sessionService.updateSession(this);
-  }
-
-  @Override
-  public void setMaxInactiveInterval(int interval) {
-    super.setMaxInactiveInterval(interval);
-    sessionService.updateSession(this);
-  }
-
-  @Override
-  public void setNew(boolean isNew) {
-    super.setNew(isNew);
-    sessionService.updateSession(this);
-  }
-
-  @Override
-  public void setPrincipal(Principal principal) {
-    super.setPrincipal(principal);
-    sessionService.updateSession(this);
-  }
-
-  @Override
-  public void setValid(boolean isValid) {
-    super.setValid(isValid);
-    sessionService.updateSession(this);
-  }
-
-  @Override
-  public void access() {
-    super.access();
-    sessionService.updateSession(this);
-  }
-
-  @Override
-  public void endAccess() {
-    super.endAccess();
-    sessionService.updateSession(this);
-  }
-
-  @Override
-  public void removeAttribute(String name, boolean notify) {
-    super.removeAttribute(name, notify);
-    sessionService.updateSession(this);
-  }
-
-  @Override
-  public void setAttribute(String name, Object value, boolean notify) {
-    super.setAttribute(name, value, notify);
-    sessionService.updateSession(this);
-  }
-
-  @Override
-  public void recycle() {
-    super.recycle();
-    sessionService.updateSession(this);
-  }
-
-  @Override
-  public void removeNote(String name) {
-    super.removeNote(name);
-    sessionService.updateSession(this);
-  }
-
-  @Override
-  public void addSessionListener(SessionListener listener) {
-    super.addSessionListener(listener);
-    sessionService.updateSession(this);
-  }
-
-  @Override
-  public void removeSessionListener(SessionListener listener) {
-    super.removeSessionListener(listener);
-    sessionService.updateSession(this);
-  }
-
-  @Override
-  public void setNote(String name, Object value) {
-    super.setNote(name, value);
-    sessionService.updateSession(this);
-  }
-
-  /*
-   * Certain fields inside Standard session are not serialized, We need to process them here
-   */
-   public void afterDeserialization(){
-    if (listeners == null){
-      listeners = new ArrayList<SessionListener>();
-    }
-    if (notes == null){
-      notes = new ConcurrentHashMap<String, Object>();
-    }
-    if(support == null){
-      support = new PropertyChangeSupport(this);
-    }
-   }
-
-   @Override
-   public String toString() {
-     StringBuilder sb = new StringBuilder();
-     sb.append("ClusterSession[");
-     sb.append(id);
-     sb.append(", isNew : ");
-     sb.append(isNew);
-     sb.append(", isValid : ");
-     sb.append(isValid);
-     sb.append("]");
-     return sb.toString();
-   }
-
-   /*
-    * These methods are added for deserialization purpose
-    */
-
-   public void setAuthTypeInternal(String authType){
-     this.authType = authType;
-   }
-
-   public void setPrincipalInternal(Principal principal){
-     this.principal = principal;
-   }
-
-   public void setNoteInternal(String name, Object value) {
-     notes.put(name, value);
-   }
-}
diff --git a/opendaylight/adsal/samples/clustersession/src/main/java/org/opendaylight/controller/clustersession/ClusterSessionData.java b/opendaylight/adsal/samples/clustersession/src/main/java/org/opendaylight/controller/clustersession/ClusterSessionData.java
deleted file mode 100644 (file)
index b5796d2..0000000
+++ /dev/null
@@ -1,79 +0,0 @@
-package org.opendaylight.controller.clustersession;
-
-import java.io.Serializable;
-import java.util.Arrays;
-
-public class ClusterSessionData implements Serializable{
-
-  private static final long serialVersionUID = 1L;
-
-  private ClusterSession session;
-
-  private byte[] principalData;
-
-  private byte[] savedRequestData;
-
-  private byte[] savedPrincipalData;
-
-  private String authType;
-
-  private String userName;
-
-  private String password;
-
-  public ClusterSession getSession() {
-    return session;
-  }
-
-  public void setSession(final ClusterSession session) {
-    this.session = session;
-  }
-
-  public byte[] getPrincipalData() {
-    return principalData;
-  }
-
-  public void setPrincipalData(final byte[] principalData) {
-    this.principalData = Arrays.copyOf(principalData, principalData.length);
-  }
-
-  public String getAuthType() {
-    return authType;
-  }
-
-  public void setAuthType(String authType) {
-    this.authType = authType;
-  }
-
-  public byte[] getSavedRequestData() {
-    return savedRequestData;
-  }
-
-  public void setSavedRequestData(byte[] savedRequestData) {
-    this.savedRequestData = Arrays.copyOf(savedRequestData, savedRequestData.length);
-  }
-
-  public byte[] getSavedPrincipalData() {
-    return savedPrincipalData;
-  }
-
-  public void setSavedPrincipalData(byte[] savedPrincipalData) {
-    this.savedPrincipalData = Arrays.copyOf(savedPrincipalData, savedPrincipalData.length);
-  }
-
-  public String getUserName() {
-    return userName;
-  }
-
-  public void setUserName(String userName) {
-    this.userName = userName;
-  }
-
-  public String getPassword() {
-    return password;
-  }
-
-  public void setPassword(String password) {
-    this.password = password;
-  }
-}
diff --git a/opendaylight/adsal/samples/clustersession/src/main/java/org/opendaylight/controller/clustersession/ClusterSessionManager.java b/opendaylight/adsal/samples/clustersession/src/main/java/org/opendaylight/controller/clustersession/ClusterSessionManager.java
deleted file mode 100644 (file)
index e285bb4..0000000
+++ /dev/null
@@ -1,222 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- */
-package org.opendaylight.controller.clustersession;
-
-import java.io.IOException;
-import java.util.HashMap;
-
-import org.apache.catalina.LifecycleException;
-import org.apache.catalina.LifecycleState;
-import org.apache.catalina.Session;
-import org.apache.catalina.session.ManagerBase;
-import org.apache.catalina.util.SessionIdGenerator;
-import org.opendaylight.controller.clustersession.impl.ClusterSessionServiceImpl;
-import org.opendaylight.controller.clustersession.service.ClusterSessionService;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-/**
- * ClusterSession Manager is a custom session manager, that is used to persist session data
- * across cluster of a storage such as infinispan or memcache
- * @author harman singh
- *
- */
-public class ClusterSessionManager extends ManagerBase{
-  /**
-   * Has this component been _started yet?
-   */
-  protected boolean started = false;
-
-  protected ClusterSessionService sessionService;
-
-  private static final Logger LOGGER = LoggerFactory.getLogger(ClusterSessionManager.class);
-  /**
-   * The descriptive information about this implementation.
-   */
-  protected static final String INFO = "ClusterSessionManager/1.0";
-
-  /**
-   * The descriptive name of this Manager implementation (for logging).
-   */
-  protected static final String NAME = "ClusterSessionManager";
-
-  public ClusterSessionManager(){
-    sessionService = new ClusterSessionServiceImpl(this);
-  }
-
-  /**
-   * Return descriptive information about this Manager implementation and
-   * the corresponding version number, in the format
-   * <code>&lt;description&gt;/&lt;version&gt;</code>.
-   */
-  @Override
-  public String getInfo(){
-    return INFO;
-  }
-
-  /**
-   * Return the descriptive short name of this Manager implementation.
-   */
-  @Override
-  public String getName(){
-    return NAME;
-  }
-
-  /**
-   * {@inheritDoc}
-   */
-  @Override
-  public void load() throws ClassNotFoundException, IOException {
-    // We are not persisting any session in database, infinispan does not persist data.
-    // loading of persisted session is not required.
-  }
-
-  /**
-   * {@inheritDoc}
-   */
-  @Override
-  public void unload() throws IOException {
-    // We are not persisting any session in database, infinispan does not persist data.
-    // unloading of session to persistence layer is not required.
-  }
-
-  /**
-   * Start this component and implement the requirements
-   * of {@link org.apache.catalina.util.LifecycleBase#startInternal()}.
-   *
-   * @exception LifecycleException if this component detects a fatal error
-   *  that prevents this component from being used
-   */
-  @Override
-  protected synchronized void startInternal() throws LifecycleException {
-    sessionIdGenerator = new SessionIdGenerator();
-    sessionIdGenerator.setJvmRoute(getJvmRoute());
-    sessionIdGenerator.setSecureRandomAlgorithm(getSecureRandomAlgorithm());
-    sessionIdGenerator.setSecureRandomClass(getSecureRandomClass());
-    sessionIdGenerator.setSecureRandomProvider(getSecureRandomProvider());
-    sessionIdGenerator.setSessionIdLength(getSessionIdLength());
-    sessionService.startInternal(sessionIdGenerator);
-    setState(LifecycleState.STARTING);
-  }
-
-  /**
-   * Stop this component and implement the requirements
-   * of {@link org.apache.catalina.util.LifecycleBase#stopInternal()}.
-   *
-   * @exception LifecycleException if this component detects a fatal error
-   *  that prevents this component from being used
-   */
-  @Override
-  protected synchronized void stopInternal() throws LifecycleException {
-    setState(LifecycleState.STOPPING);
-
-    // Expire all active sessions
-    Session sessions[] = findSessions();
-    for (int i = 0; i < sessions.length; i++) {
-      Session session = sessions[i];
-      try {
-        if (session.isValid()) {
-          session.expire();
-        }
-      } catch (Exception e) {
-        LOGGER.warn(e.toString());
-      } finally {
-        // Measure against memory leaking if references to the session
-        // object are kept in a shared field somewhere
-        session.recycle();
-      }
-    }
-    // Require a new random number generator if we are restarted
-    super.stopInternal();
-    sessionService.stopInternal();
-  }
-
-  /**
-   * {@inheritDoc}
-   */
-  @Override
-  public void expireSession(final String sessionId){
-    LOGGER.debug("SESSION EXPIRE : ", sessionId);
-    sessionService.expireSession(sessionId);
-  }
-
-  /**
-   * {@inheritDoc}
-   */
-  @Override
-  public void remove(final Session session){
-    LOGGER.debug("SESSION REMOVE : ", session.getId());
-    sessionService.removeSession(session.getId());
-  }
-
-  /**
-   * {@inheritDoc}
-   */
-  @Override
-  public void remove(Session session, boolean update) {
-    sessionService.removeSession(session.getId());
-  }
-
-  /**
-   * {@inheritDoc}
-   */
-  @Override
-  public Session findSession(final String id) throws IOException{
-    return sessionService.findSession(id);
-  }
-
-  /**
-   * {@inheritDoc}
-   */
-  @Override
-  public Session createSession(final String sessionId){
-    LOGGER.debug("SESSION CREATE : ", sessionId);
-    if(sessionId != null){
-      Session session = sessionService.findSession(sessionId);
-      if(session != null){
-        return session;
-      }
-    }
-    return sessionService.createSession(sessionId);
-  }
-
-  /**
-   * {@inheritDoc}
-   */
-  @Override
-  public Session createEmptySession(){
-    return sessionService.createEmptySession();
-  }
-  /**
-   * {@inheritDoc}
-   */
-  @Override
-  public void add(Session session){
-    LOGGER.debug("SESSION ADD : ", session.getId());
-    sessionService.addSession((ClusterSession)session);
-  }
-  /**
-   * {@inheritDoc}
-   */
-  @Override
-  public HashMap<String, String> getSession(String sessionId){
-    return sessionService.getSession(sessionId);
-  }
-  /**
-   * {@inheritDoc}
-   */
-  @Override
-  public Session[] findSessions() {
-    return sessionService.findSessions();
-  }
-
-  public ClusterSessionService getSessionService() {
-    return sessionService;
-  }
-
-  public void setSessionService(ClusterSessionService sessionService) {
-    this.sessionService = sessionService;
-  }
-
-}
diff --git a/opendaylight/adsal/samples/clustersession/src/main/java/org/opendaylight/controller/clustersession/ClusterSessionUtil.java b/opendaylight/adsal/samples/clustersession/src/main/java/org/opendaylight/controller/clustersession/ClusterSessionUtil.java
deleted file mode 100644 (file)
index 01fad1a..0000000
+++ /dev/null
@@ -1,269 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- */
-package org.opendaylight.controller.clustersession;
-
-import java.io.ByteArrayInputStream;
-import java.io.ByteArrayOutputStream;
-import java.io.IOException;
-import java.io.InputStream;
-import java.io.ObjectInputStream;
-import java.io.ObjectOutputStream;
-import java.io.OutputStream;
-import java.security.Principal;
-import java.util.ArrayList;
-import java.util.Collections;
-import java.util.HashMap;
-import java.util.Iterator;
-import java.util.List;
-import java.util.Locale;
-import java.util.Map;
-import java.util.Map.Entry;
-
-import org.apache.catalina.authenticator.Constants;
-import org.apache.catalina.authenticator.SavedRequest;
-import org.apache.catalina.ha.session.SerializablePrincipal;
-import org.apache.catalina.realm.GenericPrincipal;
-import org.opendaylight.controller.clustersession.service.ClusterSessionService;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * ClusterSessionUtil will be used to convert ClusterSession object into ClusterSessionData object,
- * which is serializable and can be passed for storage. This class also perform deserialization to
- * create ClusterSession object
- * @author harman singh
- *
- */
-
-public class ClusterSessionUtil {
-
-  private static final Logger LOGGER = LoggerFactory.getLogger(ClusterSessionUtil.class);
-
-  private ClusterSessionUtil() {
-
-  }
-
-  /**
-   * Serialize the ClusterSession object to provide ClusterSessionData object,
-   * that will be used for storage like in inifinispan or memcache etc.
-   * @param session an instance of ClusterSession
-   * @return an instance of ClusterSessionData
-   */
-  public static ClusterSessionData getSerializableSession(ClusterSession session) {
-    if(session == null){
-      return null;
-    }
-    ClusterSessionData sessionData = new ClusterSessionData();
-    sessionData.setSession(session);
-    sessionData.setAuthType(session.getAuthType());
-    sessionData.setPrincipalData(serializePrincipal(session.getPrincipal()));
-    sessionData.setSavedRequestData(serializeSavedRequest(session.getNote(Constants.FORM_REQUEST_NOTE)));
-    Principal notePrincipal = (Principal) session.getNote(Constants.FORM_PRINCIPAL_NOTE);
-    byte[] principalBytes = serializePrincipal(notePrincipal);
-    sessionData.setSavedPrincipalData(principalBytes);
-    if(session.getPrincipal() == null && notePrincipal != null){
-      sessionData.setPrincipalData(principalBytes);
-    }
-    sessionData.setUserName((String) session.getNote(Constants.FORM_USERNAME));
-    sessionData.setPassword((String) session.getNote(Constants.FORM_PASSWORD));
-    return sessionData;
-  }
-
-  /**
-   * Deserialize the ClusterSessionData object that usually comes from storage
-   * to provide ClusterSession object,
-   * that will be used by Session Manager
-   * @param sessionData an instance of ClusterSessionData
-   * @param sessionService an instance of ClusterSessionService
-   * @param manager an instance of ClusterSessionManager
-   * @return an instance of ClusterSession
-   */
-
-  public static ClusterSession getDeserializedSession(ClusterSessionData sessionData, ClusterSessionService sessionService,
-      ClusterSessionManager manager) {
-    if(sessionData == null){
-      return null;
-    }
-    ClusterSession session = sessionData.getSession();
-    session.afterDeserialization();
-    session.setManager(manager);
-    session.setSessionService(sessionService);
-    if(sessionData.getAuthType() != null) {
-      session.setAuthTypeInternal(sessionData.getAuthType());
-    }
-    if(sessionData.getPrincipalData() != null && sessionData.getPrincipalData().length > 0){
-      session.setPrincipalInternal(deserializePrincipal(sessionData.getPrincipalData()));
-    }
-    if(sessionData.getSavedPrincipalData() != null && sessionData.getSavedPrincipalData().length > 0){
-      session.setNoteInternal(Constants.FORM_PRINCIPAL_NOTE, deserializePrincipal(sessionData.getSavedPrincipalData()));
-    }
-    if(sessionData.getSavedRequestData() != null && sessionData.getSavedRequestData().length > 0){
-      session.setNoteInternal(Constants.FORM_REQUEST_NOTE, deserializeSavedRequest(sessionData.getSavedRequestData()));
-    }
-    if(sessionData.getUserName() != null){
-      session.setNoteInternal(Constants.FORM_USERNAME, sessionData.getUserName());
-    }
-    if(sessionData.getPassword() != null){
-      session.setNoteInternal(Constants.FORM_PASSWORD, sessionData.getPassword());
-    }
-    return session;
-  }
-
-  private static byte[] serializePrincipal(final Principal principal){
-    if(principal == null) {
-      return new byte[0];
-    }
-    ByteArrayOutputStream bos = null;
-    ObjectOutputStream oos = null;
-    try {
-      bos = new ByteArrayOutputStream();
-      oos = new ObjectOutputStream(bos);
-      SerializablePrincipal.writePrincipal((GenericPrincipal) principal, oos );
-      oos.flush();
-      return bos.toByteArray();
-    } catch (IOException e) {
-      throw new IllegalArgumentException( "Non-serializable object", e);
-    } finally {
-      closeSilently(bos);
-      closeSilently(oos);
-    }
-  }
-
-  private static byte[] serializeSavedRequest(final Object obj) {
-    if(obj == null) {
-      return new byte[0];
-    }
-    final SavedRequest savedRequest = (SavedRequest) obj;
-    ByteArrayOutputStream bos = null;
-    ObjectOutputStream oos = null;
-    try {
-      bos = new ByteArrayOutputStream();
-      oos = new ObjectOutputStream(bos);
-      oos.writeObject(savedRequest.getContentType());
-      oos.writeObject(getHeaders(savedRequest));
-      oos.writeObject(newArrayList(savedRequest.getLocales()));
-      oos.writeObject(savedRequest.getMethod());
-      oos.writeObject(savedRequest.getQueryString());
-      oos.writeObject(savedRequest.getRequestURI());
-      oos.writeObject(savedRequest.getDecodedRequestURI());
-      oos.flush();
-      return bos.toByteArray();
-    } catch (IOException e) {
-      throw new IllegalArgumentException( "Non-serializable object", e);
-    } finally {
-      closeSilently(bos);
-      closeSilently(oos);
-    }
-  }
-
-  private static Principal deserializePrincipal(final byte[] data) {
-    ByteArrayInputStream bis = null;
-    ObjectInputStream ois = null;
-    try {
-      bis = new ByteArrayInputStream(data);
-      ois = new ObjectInputStream(bis);
-      return SerializablePrincipal.readPrincipal(ois);
-    } catch (IOException e) {
-      throw new IllegalArgumentException( "Could not deserialize principal", e);
-    } catch (ClassNotFoundException e) {
-      throw new IllegalArgumentException( "Could not deserialize principal", e);
-    } finally {
-      closeSilently(bis);
-      closeSilently(ois);
-    }
-  }
-
-  @SuppressWarnings("unchecked")
-  private static SavedRequest deserializeSavedRequest(final byte[] data) {
-    ByteArrayInputStream bis = null;
-    ObjectInputStream ois = null;
-    try {
-      bis = new ByteArrayInputStream(data);
-      ois = new ObjectInputStream(bis);
-      final SavedRequest savedRequest = new SavedRequest();
-      savedRequest.setContentType((String) ois.readObject());
-      setHeaders(savedRequest, (Map<String, List<String>>) ois.readObject());
-      setLocales(savedRequest, (List<Locale>) ois.readObject());
-      savedRequest.setMethod((String) ois.readObject());
-      savedRequest.setQueryString((String) ois.readObject());
-      savedRequest.setRequestURI((String) ois.readObject());
-      savedRequest.setDecodedRequestURI((String) ois.readObject());
-      return savedRequest;
-    } catch (final IOException e) {
-      throw new IllegalArgumentException( "Could not deserialize SavedRequest", e );
-    } catch (final ClassNotFoundException e) {
-      throw new IllegalArgumentException( "Could not deserialize SavedRequest", e );
-    } finally {
-      closeSilently(bis);
-      closeSilently(ois);
-    }
-  }
-
-  private static void setLocales(final SavedRequest savedRequest, final List<Locale> locales) {
-    if(locales != null && !locales.isEmpty()) {
-      for (final Locale locale : locales) {
-        savedRequest.addLocale(locale);
-      }
-    }
-  }
-
-  private static <T> List<T> newArrayList(final Iterator<T> iter) {
-    if(!iter.hasNext()) {
-      return Collections.emptyList();
-    }
-    final List<T> result = new ArrayList<T>();
-    while (iter.hasNext()) {
-      result.add(iter.next());
-    }
-    return result;
-  }
-
-  private static Map<String, List<String>> getHeaders(final SavedRequest obj) {
-    final Map<String, List<String>> result = new HashMap<String, List<String>>();
-    final Iterator<String> namesIter = obj.getHeaderNames();
-    while (namesIter.hasNext()) {
-      final String name = namesIter.next();
-      final List<String> values = new ArrayList<String>();
-      result.put(name, values);
-      final Iterator<String> valuesIter = obj.getHeaderValues(name);
-      while (valuesIter.hasNext()) {
-        final String value = valuesIter.next();
-        values.add(value);
-      }
-    }
-    return result;
-  }
-
-  private static void setHeaders(final SavedRequest obj, final Map<String, List<String>> headers) {
-    if(headers != null) {
-      for (final Entry<String, List<String>> entry : headers.entrySet()) {
-        final List<String> values = entry.getValue();
-        for (final String value : values) {
-          obj.addHeader(entry.getKey(), value);
-        }
-      }
-    }
-  }
-
-  private static void closeSilently(final OutputStream os) {
-    if (os != null) {
-      try {
-        os.close();
-      } catch (final IOException f) {
-        LOGGER.debug("Exception occurred while closing output stream",  f.toString());
-      }
-    }
-  }
-
-  private static void closeSilently(final InputStream is) {
-    if (is != null) {
-      try {
-        is.close();
-      } catch (final IOException f) {
-        LOGGER.debug("Exception occurred while closing input stream", f.toString());
-      }
-    }
-  }
-}
diff --git a/opendaylight/adsal/samples/clustersession/src/main/java/org/opendaylight/controller/clustersession/impl/ClusterSessionServiceImpl.java b/opendaylight/adsal/samples/clustersession/src/main/java/org/opendaylight/controller/clustersession/impl/ClusterSessionServiceImpl.java
deleted file mode 100644 (file)
index e1c7dfd..0000000
+++ /dev/null
@@ -1,328 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- */
-package org.opendaylight.controller.clustersession.impl;
-
-import java.util.ArrayList;
-import java.util.Collection;
-import java.util.EnumSet;
-import java.util.Enumeration;
-import java.util.HashMap;
-import java.util.concurrent.ConcurrentMap;
-
-import org.apache.catalina.Session;
-import org.apache.catalina.util.SessionIdGenerator;
-import org.opendaylight.controller.clustering.services.CacheConfigException;
-import org.opendaylight.controller.clustering.services.CacheExistException;
-import org.opendaylight.controller.clustering.services.IClusterGlobalServices;
-import org.opendaylight.controller.clustering.services.IClusterServices;
-import org.opendaylight.controller.clustersession.ClusterSession;
-import org.opendaylight.controller.clustersession.ClusterSessionData;
-import org.opendaylight.controller.clustersession.ClusterSessionManager;
-import org.opendaylight.controller.clustersession.ClusterSessionUtil;
-import org.opendaylight.controller.clustersession.service.ClusterSessionService;
-import org.osgi.framework.BundleContext;
-import org.osgi.framework.FrameworkUtil;
-import org.osgi.framework.ServiceReference;
-import org.osgi.util.tracker.ServiceTracker;
-import org.osgi.util.tracker.ServiceTrackerCustomizer;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * Implementation to persist and retrieve session data from infinispan cache
- * @author harman singh
- *
- */
-public class ClusterSessionServiceImpl implements ClusterSessionService,
-  ServiceTrackerCustomizer<IClusterGlobalServices, IClusterGlobalServices>{
-
-  private IClusterGlobalServices clusterGlobalServices = null;
-  private static final Logger LOGGER = LoggerFactory.getLogger(ClusterSessionServiceImpl.class);
-  private ConcurrentMap<String, ClusterSessionData> sessions = null;
-  private static final String SESSION_CACHE = "customSessionManager.sessionData";
-  private ClusterSessionManager manager = null;
-  private SessionIdGenerator sessionIdGenerator = null;
-  private BundleContext context = null;
-  private ServiceTracker<IClusterGlobalServices, IClusterGlobalServices> clusterTracker;
-  public ClusterSessionServiceImpl(ClusterSessionManager manager) {
-    this.manager = manager;
-  }
-  /**
-   * This method initialize the cluster service of opendaylight and
-   * create a cache map in infinispan
-   */
-
-  @Override
-  public void startInternal(SessionIdGenerator sessionIdGenerator){
-    this.sessionIdGenerator = sessionIdGenerator;
-    context = FrameworkUtil.getBundle(ClusterSessionManager.class).getBundleContext();
-    getClusterService();
-    createCache();
-  }
-
-  /**
-   * Removes the cluster service tracker while shut down
-   */
-  @Override
-  public void stopInternal(){
-    if(clusterTracker != null){
-      clusterTracker.close();
-    }
-  }
-  /**
-   * {@inheritDoc}
-   */
-  @Override
-  public Session findSession(final String id){
-    if(id == null) {
-      return null;
-    }
-    if(sessions == null) {
-      LOGGER.debug("Session cache not present, try to create.");
-      createCache();
-      return null;
-    }
-    ClusterSessionData sessionData = sessions.get(id);
-    if(sessionData != null) {
-      LOGGER.debug("SESSION FOUND : ", id);
-    } else {
-      LOGGER.debug("SESSION NOTFOUND : ", id);
-    }
-    return ClusterSessionUtil.getDeserializedSession(sessionData, this, this.manager);
-  }
-
-  /**
-   * {@inheritDoc}
-   */
-  @Override
-  public Session[] findSessions() {
-    if(sessions == null) {
-      LOGGER.debug("Session cache not present, try to create.");
-      createCache();
-      return new Session[0];
-    }
-    Collection<ClusterSessionData> sessionDataList = sessions.values();
-    ArrayList<ClusterSession> sessionList = new ArrayList<ClusterSession>();
-    for(ClusterSessionData sessionData : sessionDataList){
-      sessionList.add(ClusterSessionUtil.getDeserializedSession(sessionData, this, this.manager));
-    }
-    return sessionList.toArray(new Session[0]);
-  }
-
-  /**
-   * {@inheritDoc}
-   */
-  @Override
-  public void removeSession(final String id){
-    if(sessions == null) {
-      LOGGER.debug("Session cache not present, try to create.");
-      createCache();
-      return;
-    }
-    sessions.remove(id);
-  }
-
-  /**
-   * {@inheritDoc}
-   */
-  @Override
-  public void expireSession(final String id){
-    if(sessions == null) {
-      LOGGER.debug("Session cache not present, try to create.");
-      createCache();
-      return;
-    }
-    ClusterSessionData sessionData = sessions.get(id);
-    if(sessionData != null) {
-      sessionData.getSession().expire();
-      removeSession(id);
-    }
-  }
-
-  /**
-   * {@inheritDoc}
-   */
-  @Override
-  public Session createSession(final String sessionId){
-    if(sessions == null) {
-      LOGGER.debug("Session cache not present, try to create.");
-      createCache();
-      return null;
-    }
-    Session session = createEmptySession();
-    session.setNew(true);
-    session.setValid(true);
-    session.setCreationTime(System.currentTimeMillis());
-    String id = sessionId;
-    if (id == null) {
-      id = generateSessionId();
-    }
-    session.setId(id);
-    return session;
-  }
-
-  /**
-   * {@inheritDoc}
-   */
-  @Override
-  public void addSession(final ClusterSession session){
-    if(sessions == null) {
-      LOGGER.debug("Session cache not present, try to create.");
-      createCache();
-      return;
-    }
-    ClusterSessionData sessionData = ClusterSessionUtil.getSerializableSession(session);
-    sessions.put(session.getId(), sessionData);
-  }
-
-  /**
-   * {@inheritDoc}
-   */
-  @Override
-  public Session createEmptySession(){
-    return getNewSession();
-  }
-
-  /**
-   * Returns information about the session with the given session id.
-   *
-   * <p>The session information is organized as a HashMap, mapping
-   * session attribute names to the String representation of their values.
-   *
-   * @param sessionId Session id
-   *
-   * @return HashMap mapping session attribute names to the String
-   * representation of their values, or null if no session with the
-   * specified id exists, or if the session does not have any attributes
-   */
-  public HashMap<String, String> getSession(String sessionId) {
-    if(sessions == null) {
-      LOGGER.debug("Session cache not present, try to create.");
-      createCache();
-      return null;
-    }
-    ClusterSessionData sessionData = sessions.get(sessionId);
-    if (sessionData == null) {
-      return null;
-    }
-    ClusterSession s = ClusterSessionUtil.getDeserializedSession(sessionData, this, this.manager);
-    Enumeration<String> ee = s.getAttributeNames();
-    if (ee == null || !ee.hasMoreElements()) {
-      return null;
-    }
-    HashMap<String, String> map = new HashMap<String, String>();
-    while (ee.hasMoreElements()) {
-      String attrName = ee.nextElement();
-      map.put(attrName, s.getAttribute(attrName).toString());
-    }
-    return map;
-  }
-
-  /**
-   * {@inheritDoc}
-   */
-  @Override
-  public void updateSession(ClusterSession session) {
-    if(sessions == null) {
-      LOGGER.debug("Session cache not present, try to create.");
-      createCache();
-      return;
-    }
-    if(session.getId() != null && sessions.get(session.getId()) != null){
-      ClusterSessionData sessionData = ClusterSessionUtil.getSerializableSession(session);
-      sessions.put(session.getId(), sessionData);
-    }
-  }
-
-  @Override
-  public IClusterGlobalServices addingService(ServiceReference<IClusterGlobalServices> reference) {
-      if (clusterGlobalServices == null) {
-        this.clusterGlobalServices = context.getService(reference);
-        createCache();
-        return clusterGlobalServices;
-      }
-      return null;
-  }
-
-  @Override
-  public void modifiedService(ServiceReference<IClusterGlobalServices> reference, IClusterGlobalServices service) {
-    // This method is added from ServiceTracker interface, We don't have to modify service.
-  }
-
-  @Override
-  public void removedService(ServiceReference<IClusterGlobalServices> reference, IClusterGlobalServices service) {
-      if (clusterGlobalServices == service) {
-          clusterGlobalServices = null;
-      }
-  }
-
-  /*
-   * Return an instance of Standard Session object with current session manager
-   */
-  private ClusterSession getNewSession() {
-    return new ClusterSession(this.manager, this);
-  }
-
-  /*
-   * Generate and return a new session identifier.
-   */
-  private String generateSessionId() {
-    String result = null;
-    do {
-      result = sessionIdGenerator.generateSessionId();
-    } while (sessions.containsKey(result));
-    return result;
-  }
-
-  private void createCache() {
-    allocateCache();
-    retrieveCache();
-  }
-
-  /*
-   * This is a fragment bundle, so We can't use Activator to set Service.
-   * This is the alternative to get registered clustered service
-   */
-  private void getClusterService(){
-    if (context != null) {
-      clusterTracker = new ServiceTracker<>(context, IClusterGlobalServices.class, this);
-      clusterTracker.open();
-    }
-  }
-
-  /*
-   * Allocate space in infinispan to persist session data
-   */
-  private void allocateCache() {
-    if (clusterGlobalServices == null) {
-      LOGGER.trace("un-initialized clusterGlobalService, can't create cache");
-      return;
-    }
-    try {
-      clusterGlobalServices.createCache(SESSION_CACHE,
-          EnumSet.of(IClusterServices.cacheMode.SYNC , IClusterServices.cacheMode.TRANSACTIONAL));
-
-    } catch (CacheConfigException cce) {
-      LOGGER.error("Cache configuration invalid - check cache mode", cce.toString());
-    } catch (CacheExistException ce) {
-      LOGGER.debug("Skipping cache creation as already present", ce.toString());
-    }
-  }
-
-  /*
-   * Fetch cached session data map object from infinispan
-   */
-  @SuppressWarnings("unchecked")
-  private void retrieveCache(){
-    if (clusterGlobalServices == null) {
-      LOGGER.trace("un-initialized clusterGlobalService, can't retrieve cache");
-      return;
-    }
-    sessions = (ConcurrentMap<String, ClusterSessionData>)clusterGlobalServices.getCache(SESSION_CACHE);
-    if(sessions == null){
-      LOGGER.warn("Failed to get session cache");
-    }
-  }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/samples/clustersession/src/main/java/org/opendaylight/controller/clustersession/service/ClusterSessionService.java b/opendaylight/adsal/samples/clustersession/src/main/java/org/opendaylight/controller/clustersession/service/ClusterSessionService.java
deleted file mode 100644 (file)
index 9991b33..0000000
+++ /dev/null
@@ -1,84 +0,0 @@
-package org.opendaylight.controller.clustersession.service;
-
-import java.util.HashMap;
-
-import org.apache.catalina.Session;
-import org.apache.catalina.util.SessionIdGenerator;
-import org.opendaylight.controller.clustersession.ClusterSession;
-
-/**
- * A service to handle session persistence and retrieval in any data store
- *
- * @author harman singh
- *
- */
-public interface ClusterSessionService {
-
-  /**
-   * This method performs all startup operations
-   */
-  void startInternal(SessionIdGenerator sessionIdGenerator);
-
-  /**
-   * Method to perform all clean up operations
-   */
-  void stopInternal();
-
-  /**
-   * Find Session object based on provided session id from persistance
-   * @param id
-   * @return an instance of Session
-   */
-  Session findSession(final String id);
-
-  /**
-   * Get an array of session objects available in storage
-   */
-  Session[] findSessions();
-
-  /**
-   * Remove a session object from persistence
-   * @param id of session object need to be removed
-   */
-  void removeSession(final String id);
-
-  /**
-   * Expire and remove a session object from persistence
-   * @param id of session object need to be expired
-   */
-  void expireSession(final String id);
-
-  /**
-   * Create a session object based on session id, if session is not present
-   * use random session id
-   * @param sessionId
-   * @return an instance of Session
-   */
-  Session createSession(final String sessionId);
-
-  /**
-   * Add a session object in persistence
-   * @param session an instance of ClusterSession
-   */
-  void addSession(final ClusterSession session);
-
-  /**
-   * Create an empty Session object
-   * @return session object
-   */
-  Session createEmptySession();
-
-  /**
-   * Fetch attributes of Session object fetched by supplied session id
-   * @param sessionId
-   * @return
-   */
-  HashMap<String, String> getSession(String sessionId);
-
-  /**
-   * update the session object in persistence
-   * @param session
-   */
-  void updateSession(final ClusterSession session);
-
-}
diff --git a/opendaylight/adsal/samples/clustersession/src/test/java/org/opendaylight/controller/clustersession/ClusterSessionManagerTest.java b/opendaylight/adsal/samples/clustersession/src/test/java/org/opendaylight/controller/clustersession/ClusterSessionManagerTest.java
deleted file mode 100644 (file)
index 9aae2bb..0000000
+++ /dev/null
@@ -1,157 +0,0 @@
-package org.opendaylight.controller.clustersession;
-
-import static org.junit.Assert.assertEquals;
-import static org.junit.Assert.assertNotNull;
-import static org.junit.Assert.assertNull;
-import static org.mockito.Mockito.mock;
-import static org.mockito.Mockito.when;
-
-import java.io.IOException;
-import java.util.HashMap;
-import java.util.concurrent.ConcurrentHashMap;
-import java.util.concurrent.ConcurrentMap;
-
-import org.apache.catalina.Context;
-import org.apache.catalina.LifecycleException;
-import org.apache.catalina.Session;
-import org.junit.AfterClass;
-import org.junit.BeforeClass;
-import org.junit.Test;
-import org.junit.runner.RunWith;
-import org.opendaylight.controller.clustering.services.IClusterGlobalServices;
-import org.opendaylight.controller.clustersession.impl.ClusterSessionServiceImpl;
-import org.osgi.framework.Bundle;
-import org.osgi.framework.BundleContext;
-import org.osgi.framework.FrameworkUtil;
-import org.osgi.framework.ServiceReference;
-import org.powermock.api.mockito.PowerMockito;
-import org.powermock.core.classloader.annotations.PrepareForTest;
-import org.powermock.modules.junit4.PowerMockRunner;
-
-@RunWith(PowerMockRunner.class)
-@PrepareForTest({FrameworkUtil.class})
-public class ClusterSessionManagerTest {
-  static ClusterSessionManager manager = null;
-  static ClusterSessionServiceImpl sessionService = null;
-  private static final String SESSION_CACHE = "customSessionManager.sessionData";
-  static ConcurrentMap<String, ClusterSessionData> sessions = new ConcurrentHashMap<String, ClusterSessionData>();
-  private String sessionId = "1234567";
-  final String AUTH_TYPE = "FORM";
-  final String ATTRIBUTE_NAME = "AuthType";
-  final int SESSION_ID_LENGTH = 7;
-  @SuppressWarnings("unchecked")
-  @BeforeClass
-  public static void init(){
-    Bundle bundle = mock(Bundle.class);
-    BundleContext context = mock(BundleContext.class);
-    IClusterGlobalServices clusterGlobalService = mock(IClusterGlobalServices.class);
-    ServiceReference<IClusterGlobalServices> serviceReference = mock(ServiceReference.class);
-    PowerMockito.mockStatic(FrameworkUtil.class);
-    when(FrameworkUtil.getBundle(ClusterSessionManager.class)).thenReturn(bundle);
-    when(bundle.getBundleContext()).thenReturn(context);
-    when(context.getService(serviceReference)).thenReturn(clusterGlobalService);
-    when((ConcurrentMap<String, ClusterSessionData>)clusterGlobalService.getCache(SESSION_CACHE)).thenReturn(sessions);
-    Context containerContext = mock(Context.class);
-    manager = new ClusterSessionManager();
-    manager.setContainer(containerContext);
-    try {
-      manager.startInternal();
-    } catch (LifecycleException e) {
-    }
-    sessionService = (ClusterSessionServiceImpl) manager.getSessionService();
-    sessionService.addingService(serviceReference);
-  }
-
-  @Test
-  public void checkSessionManagerCreated(){
-    assertEquals("session manager info does not match", "ClusterSessionManager/1.0", manager.getInfo());
-    assertEquals("session manager name does not match", "ClusterSessionManager", manager.getName());
-  }
-
-  @Test
-  public void testCreateEmptySession(){
-    Session session = manager.createEmptySession();
-    assertEquals("session manager does not match", manager, session.getManager());
-  }
-
-  @Test
-  public void testCreateRandomSessionId(){
-    Session session = manager.createSession(null);
-    assertEquals("Session should be valid", true, session.isValid());
-    manager.remove(session);
-  }
-
-  @Test
-  public void testCreateSession(){
-    Session session = manager.createSession(sessionId);
-    assertEquals("Session should be valid", true, session.isValid());
-    assertEquals("Session id does not match", sessionId, session.getId());
-    manager.remove(session);
-  }
-
-  @Test
-  public void testReCreateSession(){
-    Session session = manager.createSession(sessionId);
-    assertEquals("Session should be valid", true, session.isValid());
-    assertEquals("Session id does not match", sessionId, session.getId());
-    manager.createSession(sessionId);
-    manager.remove(session);
-  }
-
-  @Test
-  public void testSessionCRUD() throws IOException{
-    Session foundSession = manager.findSession(sessionId);
-    assertNull("Session should not exist here", foundSession);
-    Session session = manager.createSession(sessionId);
-    manager.add(session);
-    foundSession = manager.findSession(sessionId);
-    assertEquals("Session was not found, id does not match", sessionId, foundSession.getId());
-    manager.remove(session);
-    foundSession = manager.findSession(sessionId);
-    assertEquals("Session was not removed", null, foundSession);
-  }
-
-  @Test
-  public void testExpireSession() throws IOException{
-    Session session = manager.createSession(sessionId);
-    session.setAuthType(AUTH_TYPE);
-    manager.add(session);
-    Session foundSession = manager.findSession(sessionId);
-    assertEquals("Session was not found", sessionId, foundSession.getId());
-    manager.expireSession(sessionId);
-    foundSession = manager.findSession(sessionId);
-    assertEquals("Session was not expired", null, foundSession);
-  }
-
-  @Test
-  public void testFindSessions(){
-    Session session = manager.createSession(sessionId);
-    session.setAuthType(AUTH_TYPE);
-    manager.add(session);
-    Session[] sessions = manager.findSessions();
-    assertEquals("Session array size does not match", 1, sessions.length);
-    assertEquals("Session array size does not match", sessionId, sessions[0].getId());
-    manager.remove(session);
-  }
-
-  @Test
-  public void testGetSession(){
-    ClusterSession session = (ClusterSession) manager.createSession(sessionId);
-    session.setAttribute(ATTRIBUTE_NAME, AUTH_TYPE);
-    manager.add(session);
-    HashMap<String, String> sessionAttributes = manager.getSession(sessionId);
-    assertNotNull("Session attribute should not be null", sessionAttributes);
-    assertEquals("Session attribute size does not match", 1, sessionAttributes.size());
-    assertEquals("Session attribute size does not match", AUTH_TYPE, sessionAttributes.get(ATTRIBUTE_NAME));
-    manager.remove(session);
-  }
-
-  @AfterClass
-  public static void cleanup(){
-    try {
-      manager.stopInternal();
-    } catch (LifecycleException e) {
-    }
-  }
-
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/samples/clustersession/src/test/java/org/opendaylight/controller/clustersession/ClusterSessionServiceImplTest.java b/opendaylight/adsal/samples/clustersession/src/test/java/org/opendaylight/controller/clustersession/ClusterSessionServiceImplTest.java
deleted file mode 100644 (file)
index 1835db5..0000000
+++ /dev/null
@@ -1,162 +0,0 @@
-package org.opendaylight.controller.clustersession;
-
-import static org.junit.Assert.assertEquals;
-import static org.junit.Assert.assertNotNull;
-import static org.junit.Assert.assertNull;
-import static org.mockito.Mockito.mock;
-import static org.mockito.Mockito.when;
-
-import java.util.HashMap;
-import java.util.Map;
-import java.util.concurrent.ConcurrentHashMap;
-import java.util.concurrent.ConcurrentMap;
-
-import org.apache.catalina.Context;
-import org.apache.catalina.Session;
-import org.apache.catalina.util.SessionIdGenerator;
-import org.junit.AfterClass;
-import org.junit.BeforeClass;
-import org.junit.Test;
-import org.junit.runner.RunWith;
-import org.opendaylight.controller.clustering.services.IClusterGlobalServices;
-import org.opendaylight.controller.clustersession.impl.ClusterSessionServiceImpl;
-import org.osgi.framework.Bundle;
-import org.osgi.framework.BundleContext;
-import org.osgi.framework.FrameworkUtil;
-import org.osgi.framework.ServiceReference;
-import org.powermock.api.mockito.PowerMockito;
-import org.powermock.core.classloader.annotations.PrepareForTest;
-import org.powermock.modules.junit4.PowerMockRunner;
-
-@RunWith(PowerMockRunner.class)
-@PrepareForTest({FrameworkUtil.class})
-public class ClusterSessionServiceImplTest {
-  static ClusterSessionManager manager = null;
-  static ClusterSessionServiceImpl sessionService = null;
-  private static final String SESSION_CACHE = "customSessionManager.sessionData";
-  static ConcurrentMap<String, ClusterSessionData> sessions = new ConcurrentHashMap<String, ClusterSessionData>();
-  private String sessionId = "1234567";
-  final String AUTH_TYPE = "FORM";
-  final String ATTRIBUTE_NAME = "AuthType";
-
-  @SuppressWarnings("unchecked")
-  @BeforeClass
-  public static void init(){
-    Bundle bundle = mock(Bundle.class);
-    BundleContext context = mock(BundleContext.class);
-    IClusterGlobalServices clusterGlobalService = mock(IClusterGlobalServices.class);
-    ServiceReference<IClusterGlobalServices> serviceReference = mock(ServiceReference.class);
-    PowerMockito.mockStatic(FrameworkUtil.class);
-    when(FrameworkUtil.getBundle(ClusterSessionManager.class)).thenReturn(bundle);
-    when(bundle.getBundleContext()).thenReturn(context);
-    when(context.getService(serviceReference)).thenReturn(clusterGlobalService);
-    when((ConcurrentMap<String, ClusterSessionData>)clusterGlobalService.getCache(SESSION_CACHE)).thenReturn(sessions);
-    Context containerContext = mock(Context.class);
-    manager = new ClusterSessionManager();
-    sessionService = (ClusterSessionServiceImpl) manager.getSessionService();
-    manager.setContainer(containerContext);
-    sessionService.startInternal(new SessionIdGenerator());
-    sessionService.addingService(serviceReference);
-  }
-
-  @Test
-  public void testCreateEmptySession(){
-    Session session = sessionService.createEmptySession();
-    assertEquals("session manager does not match", manager, session.getManager());
-  }
-
-  @Test
-  public void testCreateSessionwithRandomId(){
-    Session session = sessionService.createSession(null);
-    assertEquals("Session should be valid", true, session.isValid());
-    sessionService.removeSession(session.getId());
-  }
-
-  @Test
-  public void testCreateSession(){
-    Session session = sessionService.createSession(sessionId);
-    assertEquals("Session should be valid", true, session.isValid());
-    assertEquals("Session id does not match", sessionId, session.getId());
-    sessionService.removeSession(sessionId);
-  }
-
-  @Test
-  public void testNullfindSession() {
-    Session session = sessionService.findSession(null);
-    assertNull("Session should be null", session);
-  }
-
-  @Test
-  public void testSessionCRUD(){
-    Session foundSession = sessionService.findSession(sessionId);
-    assertNull("Session should not exist here", foundSession);
-    Session session = sessionService.createSession(sessionId);
-    foundSession = sessionService.findSession(sessionId);
-    assertEquals("Session was not added", sessionId, foundSession.getId());
-    session.setAuthType(AUTH_TYPE);
-    sessionService.updateSession((ClusterSession)session);
-    foundSession = sessionService.findSession(sessionId);
-    assertEquals("Session was not found, id does not match", sessionId, foundSession.getId());
-    assertEquals("Session was not found, auth type does match", AUTH_TYPE, foundSession.getAuthType());
-    sessionService.removeSession(sessionId);
-    foundSession = sessionService.findSession(sessionId);
-    assertEquals("Session was not removed", null, foundSession);
-  }
-
-  @Test
-  public void testExpireSession(){
-    Session session = sessionService.createSession(sessionId);
-    session.setAuthType(AUTH_TYPE);
-    sessionService.addSession((ClusterSession)session);
-    Session foundSession = sessionService.findSession(sessionId);
-    assertEquals("Session was not found", sessionId, foundSession.getId());
-    sessionService.expireSession(sessionId);
-    foundSession = sessionService.findSession(sessionId);
-    assertEquals("Session was not expired", null, foundSession);
-  }
-
-  @Test
-  public void testFindSessions(){
-    Session session = sessionService.createSession(sessionId);
-    session.setAuthType(AUTH_TYPE);
-    sessionService.addSession((ClusterSession)session);
-    Session[] sessions = sessionService.findSessions();
-    assertEquals("Session array size does not match", 1, sessions.length);
-    assertEquals("Session array size does not match", sessionId, sessions[0].getId());
-    sessionService.removeSession(sessionId);
-  }
-
-  @Test
-  public void testGetSession(){
-    ClusterSession session = (ClusterSession) sessionService.createSession(sessionId);
-    session.setAttribute(ATTRIBUTE_NAME, AUTH_TYPE);
-    HashMap<String, String> sessionAttributes = sessionService.getSession(sessionId);
-    assertNotNull("Session attribute should not be null", sessionAttributes);
-    assertEquals("Session attribute size does not match", 1, sessionAttributes.size());
-    assertEquals("Session attribute size does not match", AUTH_TYPE, sessionAttributes.get(ATTRIBUTE_NAME));
-    sessionService.removeSession(sessionId);
-  }
-
-  @Test
-  public void testNullSessionCache(){
-    ClusterSessionManager clustermanager = new ClusterSessionManager();
-    ClusterSessionServiceImpl service = new ClusterSessionServiceImpl(clustermanager);
-    Session session = service.findSession(sessionId);
-    assertNull("Session should be null, as cache is null", session);
-    Session[] sessions = service.findSessions();
-    assertEquals("Session array should be empty", 0, sessions.length);
-    service.removeSession(sessionId);
-    service.expireSession(sessionId);
-    session = service.createSession(sessionId);
-    assertNull("Session should be null, as cache is null", session);
-    service.addSession(null);
-    Map<String,String> attributes = service.getSession(sessionId);
-    assertNull("Attributes should be null, as cache is null", attributes);
-    service.updateSession(null);
-  }
-
-  @AfterClass
-  public static void cleanup(){
-      sessionService.stopInternal();
-  }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/samples/clustersession/src/test/java/org/opendaylight/controller/clustersession/ClusterSessionUtilTest.java b/opendaylight/adsal/samples/clustersession/src/test/java/org/opendaylight/controller/clustersession/ClusterSessionUtilTest.java
deleted file mode 100644 (file)
index 563b2be..0000000
+++ /dev/null
@@ -1,156 +0,0 @@
-package org.opendaylight.controller.clustersession;
-
-import static org.junit.Assert.assertEquals;
-import static org.junit.Assert.fail;
-
-import java.io.BufferedInputStream;
-import java.io.BufferedOutputStream;
-import java.io.File;
-import java.io.FileInputStream;
-import java.io.FileOutputStream;
-import java.io.IOException;
-import java.io.InputStream;
-import java.io.ObjectInput;
-import java.io.ObjectInputStream;
-import java.io.ObjectOutput;
-import java.io.ObjectOutputStream;
-import java.io.OutputStream;
-import java.util.ArrayList;
-import java.util.List;
-import java.util.Locale;
-
-import org.apache.catalina.authenticator.Constants;
-import org.apache.catalina.authenticator.SavedRequest;
-import org.apache.catalina.realm.GenericPrincipal;
-import org.junit.Test;
-import org.opendaylight.controller.clustersession.impl.ClusterSessionServiceImpl;
-import org.opendaylight.controller.clustersession.service.ClusterSessionService;
-
-
-public class ClusterSessionUtilTest {
-
-  final String AUTH_TYPE = "FORM";
-  final String ADMIN = "admin";
-  final String REQUEST_URI = "/test";
-  final String BLANK = "";
-  final String HEADER_NAME = "ContentType";
-  final String HEADER_VALUE = "JSON";
-  final long creationTime = 54545454L;
-  final int interval = 0;
-  ClusterSessionManager manager = new ClusterSessionManager();
-  ClusterSessionService sessionService = new ClusterSessionServiceImpl(manager);
-
-  @Test
-  public void testNullSerializableClusterSession() {
-    ClusterSessionData sessionData = ClusterSessionUtil.getSerializableSession(null);
-    assertEquals("Session data should be null for null session", null, sessionData);
-  }
-
-  @Test
-  public void testSerializableClusterSession() {
-    ClusterSession customSession = createClusterSesion();
-    ClusterSessionData sessionData = ClusterSessionUtil.getSerializableSession(customSession);
-    assertEquals("Session authentication type not valid", AUTH_TYPE, sessionData.getAuthType());
-    assertEquals("Session username does not match", ADMIN, sessionData.getUserName());
-    assertEquals("Session password does not match", ADMIN, sessionData.getPassword());
-    assertEquals("Session prinicpal does not match", ADMIN, sessionData.getSession().getPrincipal().getName());
-  }
-
-  @Test
-  public void testNullDeserialzableclusterSession() {
-    ClusterSession session =  ClusterSessionUtil.getDeserializedSession(null, sessionService, manager);
-    assertEquals("Session should be null for null session data", null, session);
-  }
-
-  @Test
-  public void testDeserializableClusterSesion() {
-    ClusterSession customSession = createClusterSesion();
-    ClusterSessionData sessionData = ClusterSessionUtil.getSerializableSession(customSession);
-    customSession = sessionData.getSession();
-    customSession.setAuthType(AUTH_TYPE);
-    customSession.setNote(Constants.FORM_PRINCIPAL_NOTE, BLANK);
-    customSession.setNote(Constants.FORM_REQUEST_NOTE, BLANK);
-    ClusterSession session = ClusterSessionUtil.getDeserializedSession(sessionData, sessionService, manager);
-    assertEquals("Session authentication type not valid", AUTH_TYPE, session.getAuthType());
-    assertEquals("prinicpal name is not valid", ADMIN, session.getPrincipal().getName());
-    SavedRequest savedRequest = (SavedRequest)session.getNote(Constants.FORM_REQUEST_NOTE);
-    assertEquals("saved request uri does not match", REQUEST_URI, savedRequest.getRequestURI());
-    assertEquals("saved request header does not match", HEADER_VALUE, savedRequest.getHeaderValues(HEADER_NAME).next());
-    assertEquals("saved request header does not match", Locale.ENGLISH, savedRequest.getLocales().next());
-    String username = (String)session.getNote(Constants.FORM_USERNAME);
-    assertEquals("username does not match", ADMIN, username);
-    String password = (String)session.getNote(Constants.FORM_PASSWORD);
-    assertEquals("password does not match", ADMIN, password);
-    assertEquals("session manager does not match", manager, session.getManager());
-    assertEquals("session creation time does not match", creationTime, session.getCreationTime());
-    assertEquals("session man inactive interval does not match", interval, session.getMaxInactiveInterval());
-    assertEquals("is session new does not match", true, session.isNew());
-    assertEquals("is session valid does not match", true, session.isValid());
-  }
-
-  @Test
-  public void testSerializationtoFile(){
-    ClusterSession customSession = createClusterSesion();
-    ClusterSessionData sessionData = ClusterSessionUtil.getSerializableSession(customSession);
-    try(
-        OutputStream file = new FileOutputStream("sessionData.ser");
-        OutputStream buffer = new BufferedOutputStream(file);
-        ObjectOutput output = new ObjectOutputStream(buffer);
-        ){
-      output.writeObject(sessionData);
-    }
-    catch(IOException ex){
-      fail("IO exception while serializing object to a file.");
-    }
-    try(
-        InputStream file = new FileInputStream("sessionData.ser");
-        InputStream buffer = new BufferedInputStream(file);
-        ObjectInput input = new ObjectInputStream (buffer);
-        ){
-      //deserialize the session
-      ClusterSessionData recovedSession = (ClusterSessionData)input.readObject();
-      //display its data
-      ClusterSession session = ClusterSessionUtil.getDeserializedSession(recovedSession, sessionService, manager);
-      assertEquals("Session authentication type not valid", AUTH_TYPE, session.getAuthType());
-      assertEquals("prinicpal name is not valid", ADMIN, session.getPrincipal().getName());
-      SavedRequest savedRequest = (SavedRequest)session.getNote(Constants.FORM_REQUEST_NOTE);
-      assertEquals("saved request uri is not valid", REQUEST_URI, savedRequest.getRequestURI());
-      assertEquals("saved request header does not match", HEADER_VALUE, savedRequest.getHeaderValues(HEADER_NAME).next());
-      assertEquals("saved request header does not match", Locale.ENGLISH, savedRequest.getLocales().next());
-      String username = (String)session.getNote(Constants.FORM_USERNAME);
-      assertEquals("username does not match", ADMIN, username);
-      String password = (String)session.getNote(Constants.FORM_PASSWORD);
-      assertEquals("password does not match", ADMIN, password);
-    }
-    catch(ClassNotFoundException ex){
-      fail("Exception in object deserialization from file");
-    }
-    catch(IOException ex){
-      fail("Exception in object deserialization from file");
-    }
-    File serializedFile = new File("sessionData.ser");
-    serializedFile.delete();
-  }
-
-  private ClusterSession createClusterSesion(){
-    ClusterSession clusterSession = new ClusterSession(manager, sessionService);
-    clusterSession.setAuthType(AUTH_TYPE);
-    clusterSession.setCreationTime(creationTime);
-    clusterSession.setMaxInactiveInterval(interval);
-    clusterSession.setNew(true);
-    clusterSession.setValid(true);
-    List<String> roles = new ArrayList<String>();
-    roles.add(ADMIN);
-    GenericPrincipal principal = new GenericPrincipal(ADMIN, ADMIN, roles);
-    clusterSession.setPrincipal(principal);
-    clusterSession.setNote(Constants.FORM_PRINCIPAL_NOTE, principal);
-    SavedRequest savedRequest = new SavedRequest();
-    savedRequest.setRequestURI(REQUEST_URI);
-    savedRequest.addHeader(HEADER_NAME, HEADER_VALUE);
-    savedRequest.addLocale(Locale.ENGLISH);
-    clusterSession.setNote(Constants.FORM_REQUEST_NOTE, savedRequest);
-    clusterSession.setNote(Constants.FORM_USERNAME, ADMIN);
-    clusterSession.setNote(Constants.FORM_PASSWORD, ADMIN);
-    return clusterSession;
-  }
-}
diff --git a/opendaylight/adsal/samples/loadbalancer/pom.xml b/opendaylight/adsal/samples/loadbalancer/pom.xml
deleted file mode 100644 (file)
index d8d72a2..0000000
+++ /dev/null
@@ -1,93 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>samples.loadbalancer</artifactId>
-  <version>0.7.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>forwardingrulesmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>hosttracker</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>switchmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>topologymanager</artifactId>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Export-Package>org.opendaylight.controller.samples.loadbalancer,
-              org.opendaylight.controller.samples.loadbalancer.entities,
-              org.opendaylight.controller.samples.loadbalancer.internal,
-              org.opendaylight.controller.samples.loadbalancer.policies</Export-Package>
-            <Import-Package>org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.sal.utils,
-              org.opendaylight.controller.sal.action,
-              org.opendaylight.controller.sal.match,
-              org.opendaylight.controller.sal.packet,
-              org.opendaylight.controller.sal.routing,
-              org.opendaylight.controller.sal.flowprogrammer,
-              org.opendaylight.controller.sal.packet.address,
-              org.opendaylight.controller.hosttracker,
-              org.opendaylight.controller.hosttracker.hostAware,
-              org.opendaylight.controller.samples.loadbalancer,
-              org.opendaylight.controller.samples.loadbalancer.entities,
-              org.opendaylight.controller.samples.loadbalancer.internal,
-              org.opendaylight.controller.samples.loadbalancer.policies,
-              org.opendaylight.controller.topologymanager,
-              org.opendaylight.controller.forwardingrulesmanager,
-              org.opendaylight.controller.switchmanager,
-              org.opendaylight.controller.clustering.services,
-              javax.xml.bind.annotation,
-              javax.xml.bind,
-              org.apache.felix.dm,
-              org.apache.commons.lang3.builder,
-              org.osgi.service.component,
-              org.slf4j,
-              org.eclipse.osgi.framework.console,
-              org.osgi.framework</Import-Package>
-            <Bundle-Activator>org.opendaylight.controller.samples.loadbalancer.internal.Activator</Bundle-Activator>
-            <Service-Component></Service-Component>
-          </instructions>
-          <manifestLocation>${project.basedir}/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/samples/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/ConfigManager.java b/opendaylight/adsal/samples/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/ConfigManager.java
deleted file mode 100644 (file)
index e7b261c..0000000
+++ /dev/null
@@ -1,294 +0,0 @@
-/*
- * Copyright IBM Corporation, 2013.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.samples.loadbalancer;
-
-import java.util.HashMap;
-import java.util.HashSet;
-import java.util.Set;
-
-import org.opendaylight.controller.samples.loadbalancer.entities.Pool;
-import org.opendaylight.controller.samples.loadbalancer.entities.PoolMember;
-import org.opendaylight.controller.samples.loadbalancer.entities.VIP;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * This class represents a configuration manager for the Load Balancer service.
- * This class is responsible for managing(store/update/delete) the load balancer
- * configuration that it receives through REST APIs or from any other applications
- * present in the controller.
- *
- */
-public class ConfigManager implements IConfigManager{
-
-    /*
-     * Logger instance
-     */
-    private static final Logger cmLogger = LoggerFactory.getLogger(ConfigManager.class);
-
-    /*
-     * All the available VIPs
-     */
-    private HashMap<String,VIP> vips = new HashMap<String,VIP>();
-
-    /*
-     * All the available Pools
-     */
-    private HashMap<String,Pool> pools = new HashMap<String,Pool>();
-
-    public ConfigManager(){
-    }
-
-    @Override
-    public boolean vipExists(String name) {
-        return this.vips.containsKey(name);
-    }
-
-    @Override
-    public boolean vipExists(VIP vip){
-        if(vip.getName()==null){
-            if(!vips.containsValue(vip)){
-                return false;
-            }
-        }else{
-            if(!vips.containsKey(vip.getName())){
-                if(!vips.containsValue(vip)){
-                    return false;
-                }
-            }
-        }
-        return true;
-    }
-
-    @Override
-    public boolean vipExists(String name,String ip,String protocol,short protocolPort,String poolName){
-
-        VIP vip = new VIP(name,ip,protocol,protocolPort,poolName);
-
-        //Check VIP with the same name
-
-        if(!vips.containsKey(name)){
-            //Check VIP with the same ip, protocol and protocolPort
-            if(!vips.containsValue(vip)){
-
-                //if you reach here, means this VIP don't exist
-                return false;
-            }
-        }
-
-        //Yeah, i have it.
-        return true;
-    }
-
-    @Override
-    public Set<VIP> getAllVIPs(){
-        return new HashSet<VIP>(this.vips.values());
-    }
-
-    public VIP getVIPWithPoolName(VIP vip){
-        cmLogger.trace("Search a VIP with name:{}",vip);
-        for(VIP vipTemp: this.vips.values()){
-            if(vipTemp.equals(vip)){
-
-                cmLogger.trace("Found VIP with pool detail : {}",vipTemp);
-                return vipTemp;
-            }
-        }
-
-        cmLogger.trace("VIP with pool detail not found ");
-        return null;
-    }
-
-    @Override
-    public VIP createVIP(String name,String ip,String protocol,short protocolPort,String poolName){
-
-        cmLogger.trace("Create VIP with the following details :[ name : "+name
-                                                                    +" ip : "+ip
-                                                                    +" protocol : "+protocol
-                                                                    +" protocol_port : "+protocolPort
-                                                                    +" pool name : "+poolName);
-
-        VIP vip = new VIP(name,ip,protocol,protocolPort,poolName);
-
-        if(poolName !=null && !poolName.isEmpty()){
-            if(pools.containsKey(poolName)){
-                pools.get(poolName).addVIP(vip);
-            }
-        }
-
-        vip.setStatus(LBConst.STATUS_ACTIVE);
-        this.vips.put(name, vip);
-
-        cmLogger.trace("New VIP created : "+vip.toString());
-        return vip;
-    }
-
-    @Override
-    public String getVIPAttachedPool(String name) {
-        return this.vips.get(name).getPoolName();
-    }
-
-    @Override
-    public VIP updateVIP(String name, String poolName){
-
-        cmLogger.trace("Updating VIP : "+name+" pool name  to "+poolName);
-
-        if(vips.containsKey(name)){
-            VIP vip = vips.get(name);
-            if(vip.getPoolName() == null){
-                vip.setPoolName(poolName);
-                cmLogger.error("VIP is now attached to the pool : {}",vip.toString());
-                return vip;
-            }
-            cmLogger.error("VIP is already attached to one pool : {}",vip.toString());
-        }
-        cmLogger.error("VIP with name: "+name+" does not exist");
-        return null;
-    }
-
-    @Override
-    public VIP deleteVIP(String name){
-
-        cmLogger.trace("Deleting VIP : "+name);
-
-        VIP vip = vips.get(name);
-
-        String poolName = vip.getPoolName();
-
-        if(poolName != null){
-            if(pools.containsKey(poolName)){
-                Pool pool = pools.get(poolName);
-                pool.removeVIP(vip.getName());
-            }
-        }
-
-        cmLogger.trace("VIP removed : "+vip.toString());
-
-        vips.remove(vip.getName());
-
-        return vip;
-    }
-
-    @Override
-    public boolean memberExists(String name, String poolName) {
-        if (this.pools.containsKey(poolName)) {
-            if (this.pools.get(poolName).getMember(name) != null) {
-                return true;
-            }
-        }
-        return false;
-    }
-
-    @Override
-    public boolean memberExists(String name, String memberIP,String poolName) {
-        if (!this.pools.containsKey(poolName)) {
-            return false;
-        }
-
-        return this.pools.get(poolName).poolMemberExists(new PoolMember(name, memberIP, poolName));
-    }
-
-    @Override
-    public PoolMember addPoolMember(String name, String memberIP, String poolName){
-
-        PoolMember pm = new PoolMember(name,memberIP,poolName);
-
-        cmLogger.trace("Adding pool member : "+pm.toString());
-
-        pools.get(poolName).addMember(pm);
-
-        return pm;
-    }
-
-    @Override
-    public PoolMember removePoolMember(String name, String poolName){
-
-        cmLogger.trace("Removing pool member : {} from pool {}",name, poolName);
-
-        Pool pool = pools.get(poolName);
-
-        PoolMember pm = pool.getMember(name);
-
-        pool.removeMember(name);
-
-        cmLogger.trace("Pool member {} removed from {} ",name,poolName);
-
-        return pm;
-    }
-
-    @Override
-    public Set<Pool> getAllPools(){
-        return new HashSet<Pool>(this.pools.values());
-    }
-
-    @Override
-    public boolean poolExists(String name) {
-        return this.pools.containsKey(name);
-    }
-
-    @Override
-    public boolean poolExists(String name, String lbMethod){
-
-        return pools.containsValue(new Pool(name,lbMethod));
-    }
-
-    @Override
-    public Pool createPool(String name, String lbMethod){
-
-        Pool newPool = new Pool(name,lbMethod);
-
-        cmLogger.trace("New pool created : " + newPool.toString());
-
-        pools.put(name, newPool);
-
-        return newPool;
-    }
-
-    @Override
-    public Pool deletePool(String poolName){
-
-        Pool pool = pools.get(poolName);
-
-        for(VIP vip:pool.getAllVip()){
-
-            vip.setPoolName(null);
-
-        }
-
-        cmLogger.trace("Pool removed : "+pool.toString());
-
-        pools.remove(poolName);
-
-        return pool;
-    }
-
-    @Override
-    public Pool getPool( String poolName){
-        if(pools.containsKey(poolName)){
-            return pools.get(poolName);
-        }
-        return null;
-    }
-
-    @Override
-    public Set<PoolMember> getAllPoolMembers(String poolName) {
-
-        if(pools.containsKey(poolName)){
-            return new HashSet<PoolMember>(pools.get(poolName).getAllMembers());
-        }
-        return null;
-    }
-
-    /* (non-Javadoc)
-     * @see java.lang.Object#toString()
-     */
-    @Override
-    public String toString() {
-        return "ConfigManager [vips=" + vips + ", pools=" + pools + "]";
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/samples/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/IConfigManager.java b/opendaylight/adsal/samples/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/IConfigManager.java
deleted file mode 100644 (file)
index 5e55b2a..0000000
+++ /dev/null
@@ -1,182 +0,0 @@
-/*
- * Copyright IBM Corporation, 2013.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.samples.loadbalancer;
-
-import java.util.Set;
-
-import org.opendaylight.controller.samples.loadbalancer.entities.Pool;
-import org.opendaylight.controller.samples.loadbalancer.entities.PoolMember;
-import org.opendaylight.controller.samples.loadbalancer.entities.VIP;
-
-/**
- * Interface implemented by the configuration manager.
- *
- */
-public interface IConfigManager {
-
-    /**
-     * Return all existing VIPs
-     * @return Set of VIP's
-     * if there is no VIP, it will return empty set.
-     */
-    public Set<VIP> getAllVIPs();
-
-    /**
-     * Check if VIP with the 'name' exists
-     * @param name  Name of the VIP
-     * @return  true    if exists
-     *                  false   else
-     */
-    public boolean vipExists(String name);
-
-    /**
-     * Check if VIP exists with the details 'VIP'
-     * @param vip Search for this VIP
-     * @return  true    if exists
-     *                  false   else
-     */
-    public boolean vipExists(VIP vip);
-
-    /**
-     * Check if VIP with the provided details exists
-     * @param name  Name of the VIP
-     * @param ip    IP of the VIP
-     * @param protocol  IP Protocol of the VIP (TCP/UDP)
-     * @param protocolPort  Transport port of the VIP (e.g 5550)
-     * @param poolName  Name of the pool attached with the VIP
-     * @return  true    if exists
-     *                  false   else
-     */
-    public boolean vipExists(String name,String ip,String protocol,short protocolPort,String poolName);
-
-    /**
-     * Add VIP to the configuration
-     * @param name  Name of the VIP
-     * @param ip    IP of the VIP
-     * @param protocol  IP Protocol of the VIP (TCP/UDP)
-     * @param protocolPort  Transport port of the VIP
-     * @param poolName  Name of the pool that VIP will use for load balancing its traffic
-     * @return  Newly created VIP
-     */
-    public VIP createVIP(String name,String ip,String protocol,short protocolPort,String poolName);
-
-    /**
-     * Return pool attached to VIP
-     * @param name Name of the VIP
-     * @return  Name of the pool attached to VIP
-     *                  else null
-     */
-    public String getVIPAttachedPool(String name);
-    /**
-     * Update pool name of the VIP.
-     * @param name  Name of the VIP
-     * @param poolName  Attach this pool to VIP
-     * @return  Updated VIP     If successful
-     *                  null            If this VIP is already attached to any existing pool.
-     */
-    public VIP updateVIP(String name, String poolName);
-
-    /**
-     * Delete the VIP
-     * @param name  Delete VIP with this name
-     * @return  Details of the deleted VIP
-     */
-    public VIP deleteVIP(String name);
-
-    /**
-     * Check if pool member with the 'name' present in the pool with name 'poolName'
-     * @param name  Name of the pool member
-     * @param poolName  Name of the pool, you want to search for pool member
-     * @return  true    If exist
-     *                  false   else
-     */
-    public boolean memberExists(String name, String poolName);
-
-    /**
-     * Check if pool member with name 'name' and IP 'memberIP' exist in the pool 'poolName'
-     * @param name  Name of the pool member
-     * @param memberIP  IP of the pool member
-     * @param poolName  Name of the pool member you want to search
-     * @return  true    If Exist
-     *                  false   else
-     */
-    public boolean memberExists(String name, String memberIP,String poolName);
-
-    /**
-     * Return all  pool members of the pool 'poolName'
-     * @param poolName  Name of the pool
-     * @return  Set of all the pool members     if pool with the name present in the configuration
-     *                  null                            else
-     *
-     */
-    public Set<PoolMember> getAllPoolMembers(String poolName);
-
-    /**
-     * Add new pool member to the configuration
-     * @param name  Name of the pool
-     * @param memberIP  IP of the pool
-     * @param poolName  Attach pool member to this pool
-     * @return  Newly created pool member
-     */
-    public PoolMember addPoolMember(String name, String memberIP, String poolName);
-
-    /**
-     * Remove pool member from the pool
-     * @param name  Name of the pool member
-     * @param poolName  Name of the pool
-     * @return  Details of the removed pool member
-     */
-    public PoolMember removePoolMember(String name, String poolName);
-
-    /**
-     * Return all the existing pools
-     * @return  Set of Pools
-     */
-    public Set<Pool> getAllPools();
-
-    /**
-     * Return pool with input name
-     * @param poolName  Name of the pool
-     * @return  Details of the pool     if pool exist
-     *                  null                    else
-     */
-    public Pool getPool(String poolName);
-
-    /**
-     * Check if pool exists with the input name
-     * @param name  Name of the pool
-     * @return  true    If exists
-     *                  false   else
-     */
-    public boolean poolExists(String name);
-
-    /**
-     * Check if pool exists with the input name and loadbalancing method.
-     * @param name  Name of the pool
-     * @param lbMethod  Load balancing method name
-     * @return  true    If exists
-     *                  false   else
-     */
-    public boolean poolExists(String name, String lbMethod);
-
-    /**
-     * Create new pool with the provided details
-     * @param name  Name of the pool
-     * @param lbMethod  Load balancing method this pool will use
-     * @return  Details of the newly created pool
-     */
-    public Pool createPool(String name, String lbMethod);
-
-    /**
-     * Delete pool with the provided name
-     * @param poolName  Name of the pool
-     * @return  Details of the deleted pool
-     */
-    public Pool deletePool(String poolName);
-
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/samples/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/LBConst.java b/opendaylight/adsal/samples/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/LBConst.java
deleted file mode 100644 (file)
index bd6fb47..0000000
+++ /dev/null
@@ -1,32 +0,0 @@
-/*
- * Copyright IBM Corporation, 2013.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.samples.loadbalancer;
-
-/**
- * Class defines all the constants used by load balancer service
- *
- */
-public class LBConst {
-
-    public static final int FORWARD_DIRECTION_LB_FLOW = 0;
-
-    public static final int REVERSE_DIRECTION_LB_FLOW = 1;
-
-    public static final String ROUND_ROBIN_LB_METHOD = "roundrobin";
-
-    public static final String RANDOM_LB_METHOD = "random";
-
-    public static final String STATUS_ACTIVE="active";
-
-    public static final String STATUS_INACTIVE="inactive";
-
-    public static final String STATUS_PENDING="pending";
-
-    public static final String STATUS_ERROR="error";
-
-}
diff --git a/opendaylight/adsal/samples/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/LBUtil.java b/opendaylight/adsal/samples/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/LBUtil.java
deleted file mode 100644 (file)
index 729a49b..0000000
+++ /dev/null
@@ -1,102 +0,0 @@
-/*
- * Copyright IBM Corporation, 2013.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.samples.loadbalancer;
-
-import org.opendaylight.controller.sal.packet.IPv4;
-import org.opendaylight.controller.sal.packet.Packet;
-import org.opendaylight.controller.sal.packet.TCP;
-import org.opendaylight.controller.sal.packet.UDP;
-import org.opendaylight.controller.sal.utils.IPProtocols;
-import org.opendaylight.controller.sal.utils.NetUtils;
-import org.opendaylight.controller.samples.loadbalancer.entities.Client;
-import org.opendaylight.controller.samples.loadbalancer.entities.VIP;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * Class defines utilty methods that will be used by different components
- * of the load balancer service
- *
- */
-public class LBUtil {
-
-    private static final Logger lbuLogger = LoggerFactory.getLogger(LBUtil.class);
-
-    public LBUtil(){}
-
-    /**
-     * Extract the details of the source machine that sent this packet 'inPkt'
-     * @param inPkt Packet that is received by the controller
-     * @return  Details of the source machine in Client object.
-     */
-    public Client getClientFromPacket(IPv4 inPkt){
-        lbuLogger.trace("Find client information from packet : {}",inPkt.toString());
-
-        String ip = NetUtils.getInetAddress(inPkt.getSourceAddress()).getHostAddress();
-
-        String protocol = IPProtocols.getProtocolName(inPkt.getProtocol());
-
-        lbuLogger.trace("client ip {} and protocl {}",ip,protocol);
-
-        Packet tpFrame= inPkt.getPayload();
-
-        lbuLogger.trace("Get protocol layer {}",tpFrame.toString());
-
-        short port = 0;
-
-        if(protocol.equals(IPProtocols.TCP.toString())){
-            TCP tcpFrame = (TCP)tpFrame;
-            port = tcpFrame.getSourcePort();
-        }else{
-            UDP udpFrame = (UDP)tpFrame;
-            port = udpFrame.getSourcePort();
-        }
-
-        lbuLogger.trace("Found port {}",port);
-
-        Client source = new Client(ip, protocol,port);
-
-        lbuLogger.trace("Client information : {}",source.toString());
-
-        return source;
-    }
-
-    /**
-     * Extract the details of the destination machine where this packet 'inPkt' need
-     * to be delivered
-     * @param inPkt Packet that is received by controller for forwarding
-     * @return  Details of the destination machine packet in VIP
-     */
-    public VIP getVIPFromPacket(IPv4 inPkt){
-
-        lbuLogger.trace("Find VIP information from packet : {}",inPkt.toString());
-
-        String ip = NetUtils.getInetAddress(inPkt.getDestinationAddress()).getHostAddress();
-
-        String protocol = IPProtocols.getProtocolName(inPkt.getProtocol());
-
-        Packet tpFrame= inPkt.getPayload();
-
-        short port = 0;
-
-        if(protocol.equals(IPProtocols.TCP.toString())){
-            TCP tcpFrame = (TCP)tpFrame;
-            port = tcpFrame.getDestinationPort();
-        }else{
-
-            UDP udpFrame = (UDP)tpFrame;
-            port = udpFrame.getDestinationPort();
-        }
-
-        VIP dest = new VIP(null,ip, protocol,port,null);
-
-        lbuLogger.trace("VIP information : {}",dest.toString());
-
-        return dest;
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/samples/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/entities/Client.java b/opendaylight/adsal/samples/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/entities/Client.java
deleted file mode 100644 (file)
index a16582d..0000000
+++ /dev/null
@@ -1,142 +0,0 @@
-/*
- * Copyright IBM Corporation, 2013.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.samples.loadbalancer.entities;
-
-/**
- * This class represents the source host that sends any traffic to any existing virtual IP (VIP).
- * This source host is referred to as a 'Client'. Clients will be differentiated from each other
- * based on the following three properties:
- * 1. IP address of the client.
- * 2. Protocol of the traffic it is using for sending traffic
- * 3. Source port from which it is sending traffic.
- * e.g TCP traffic from two different ports from the same host to a given VIP will be considered
- * as two different clients by this service. Similarly, traffic using two different protocols
- * (TCP, UDP) from the same host will be considered as two different clients.
- *
- */
-public class Client {
-
-    /*
-     * IP address of the client (source address)
-     */
-    private String ip;
-
-    /*
-     * Network protocol of the traffic sent by client
-     */
-    private String protocol;
-
-    /*
-     * Port used to send network traffic (source port)
-     */
-    private short port;
-
-    public Client(String ip, String protocol, short port){
-        this.ip = ip;
-        this.protocol = protocol;
-        this.port = port;
-    }
-
-    /**
-     * @return the client IP
-     */
-    public String getIp() {
-        return ip;
-    }
-
-    /**
-     * @param ip the IP to set
-     */
-    public void setIp(String ip) {
-        this.ip = ip;
-    }
-
-    /**
-     * @return the client network protocol
-     */
-    public String getProtocol() {
-        return protocol;
-    }
-
-    /**
-     * @param protocol the protocol to set
-     */
-    public void setProtocol(String protocol) {
-        this.protocol = protocol;
-    }
-
-    /**
-     * @return the client port
-     */
-    public short getPort() {
-        return port;
-    }
-
-    /**
-     * @param port the port to set
-     */
-    public void setPort(short port) {
-        this.port = port;
-    }
-
-    /* (non-Javadoc)
-     * @see java.lang.Object#hashCode()
-     */
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + ((ip == null) ? 0 : ip.hashCode());
-        result = prime * result + port;
-        result = prime * result+ ((protocol == null) ? 0 : protocol.hashCode());
-        return result;
-    }
-
-    /* (non-Javadoc)
-     * @see java.lang.Object#equals(java.lang.Object)
-     */
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (!(obj instanceof Client)) {
-            return false;
-        }
-        Client other = (Client) obj;
-        if (ip == null) {
-            if (other.ip != null) {
-                return false;
-            }
-        }else if (!ip.equals(other.ip)) {
-            return false;
-        }
-        if (port != other.port) {
-            return false;
-        }
-        if (protocol == null) {
-            if (other.protocol != null) {
-                return false;
-            }
-        }else if (!protocol.equals(other.protocol)) {
-            return false;
-        }
-        return true;
-    }
-
-    /* (non-Javadoc)
-     * @see java.lang.Object#toString()
-     */
-    @Override
-    public String toString() {
-        return "Client [ip=" + ip + ", protocol=" + protocol + ", port=" + port+ "]";
-    }
-}
diff --git a/opendaylight/adsal/samples/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/entities/Pool.java b/opendaylight/adsal/samples/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/entities/Pool.java
deleted file mode 100644 (file)
index 86e6a36..0000000
+++ /dev/null
@@ -1,276 +0,0 @@
-/*
- * Copyright IBM Corporation, 2013.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.samples.loadbalancer.entities;
-
-import java.util.ArrayList;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-/**
- * This class represents the pool of hosts among which incoming traffic
- * will be load balanced. Each pool will load balance the traffic among its pool members
- * based on the loadbalancing policy set for the pool.
- * Currently, the pool supports two load balancing policies:
- * 1. Round Robin Policy{@link org.opendaylight.controller.samples.loadbalancer.policies.RoundRobinLBPolicy}
- * 2. Random Policy {@link org.opendaylight.controller.samples.loadbalancer.policies.RandomLBPolicy}
- *
- * NOTE: After creation of the pool, user can't update (change) its load balancing policy.
- * NOTE: Each Pool should have a unique name.
- */
-
-@XmlRootElement(name="pool")
-@XmlAccessorType(XmlAccessType.NONE)
-public class Pool {
-
-    /*
-     * Unique name of the pool
-     */
-    @XmlElement
-    private String name;
-
-    /*
-     * Associated load balancing policy
-     */
-    @XmlElement(name="lbmethod")
-    private String lbMethod;
-
-    /*
-     * Status of the pool (active/inactive)
-     */
-    @XmlElement
-    private String status;
-
-    /*
-     * List of all the VIPs using this pool for load balancing their traffic - more than
-     * one VIP can be mapped to each pool.
-     */
-    @XmlElement
-    private ArrayList<VIP> vips = new ArrayList<VIP>();
-
-    /*
-     * List of all the pool members used for load balancing the traffic
-     */
-    @XmlElement
-    private ArrayList<PoolMember> members = new ArrayList<PoolMember>();
-
-    /*
-     * Private constructor used for JAXB mapping
-     */
-    @SuppressWarnings("unused")
-    private Pool() {}
-
-    /**
-     * Getter/ Setter methods
-     */
-
-    public Pool(String name,
-                    String lbMethod) {
-        this.name = name;
-        this.lbMethod = lbMethod;
-    }
-
-    /**
-     * @return the name
-     */
-    public String getName() {
-        return name;
-    }
-
-    /**
-     * @param name the name to set
-     */
-    public void setName(String name) {
-        this.name = name;
-    }
-
-    /**
-     * @return the lbMethod
-     */
-    public String getLbMethod() {
-        return lbMethod;
-    }
-
-    /**
-     * @param lbMethod the lbMethod to set
-     */
-    public void setLbMethod(String lbMethod) {
-        this.lbMethod = lbMethod;
-    }
-
-    /**
-     * @return the status
-     */
-    public String getStatus() {
-        return status;
-    }
-
-    /**
-     * @param status the status to set
-     */
-    public void setStatus(String status) {
-        this.status = status;
-    }
-
-    /**
-     * @return the vip
-     */
-    public ArrayList<VIP> getAllVip() {
-        return vips;
-    }
-
-    /**
-     * @param vip the vip to set
-     */
-    public void setVips(ArrayList<VIP> vips) {
-        this.vips = vips;
-    }
-
-    /**
-     * @return the members
-     */
-    public ArrayList<PoolMember> getAllMembers() {
-        return members;
-    }
-
-    /**
-     * @param members the members to set
-     */
-    public void setMembers(ArrayList<PoolMember> members) {
-        this.members = members;
-    }
-
-    /**
-     * Add new VIP to the VIP list
-     * @param vip       new VIP to add
-     */
-    public void addVIP(VIP vip){
-        this.vips.add(vip);
-    }
-
-    /**
-     * Remove VIP with given name from the VIP list of the pool
-     * @param name      Name of the VIP
-     * @return  true     If VIP was using this pool and removed
-     *          false   IF VIP is not using this pool
-     */
-    public boolean removeVIP(String name){
-        for(VIP vip: this.vips){
-            if(vip.getName().equals(name)){
-                this.vips.remove(vip);
-                return true;
-            }
-        }
-        return false;
-    }
-
-    /**
-     * Check if the given pool member is part of this pool
-     * @param pm        Search for this pool member
-     * @return  true     If pool member is attached to this pool
-     *          false   else
-     */
-    public boolean poolMemberExists(PoolMember pm){
-        return this.members.contains(pm);
-    }
-
-    /**
-     * Returns the pool member with the given name
-     * @param name      Search for this pool member
-     * @return  PoolMember       If pool member is attached to this pool
-     *          null            else
-     */
-    public PoolMember getMember(String name){
-
-        for(PoolMember pm: this.members){
-            if(pm.getName().equals(name)){
-                return pm;
-            }
-        }
-        return null;
-    }
-
-    /**
-     * Add new pool member to the pool
-     * @param pm        Add this new pool
-     */
-    public void addMember(PoolMember pm){
-        this.members.add(pm);
-    }
-
-    /**
-     * Remove pool member from the pool list
-     * @param name Remove this pool member
-     * @return  true    If pool member was attached to this pool and successfully removed
-     *          false   If pool member is not attached to this pool
-     */
-    public boolean removeMember(String name){
-        for(PoolMember pm: this.members){
-            if(pm.getName().equals(name)){
-                this.members.remove(pm);
-                return true;
-            }
-        }
-        return false;
-    }
-
-    /* (non-Javadoc)
-     * @see java.lang.Object#hashCode()
-     */
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result+ ((lbMethod == null) ? 0 : lbMethod.hashCode());
-        result = prime * result + ((name == null) ? 0 : name.hashCode());
-        return result;
-    }
-
-    /* (non-Javadoc)
-     * @see java.lang.Object#equals(java.lang.Object)
-     */
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (!(obj instanceof Pool)) {
-            return false;
-        }
-        Pool other = (Pool) obj;
-        if (lbMethod == null) {
-            if (other.lbMethod != null) {
-                return false;
-            }
-        }else if (!lbMethod.equals(other.lbMethod)) {
-            return false;
-        }
-        if (name == null) {
-            if (other.name != null) {
-                return false;
-            }
-        }else if (!name.equals(other.name)) {
-            return false;
-        }
-        return true;
-    }
-
-    /* (non-Javadoc)
-     * @see java.lang.Object#toString()
-     */
-    @Override
-    public String toString() {
-        return "Pool [name=" + name + ", lbMethod=" + lbMethod + ", status="
-                            + status + ", vips=" + vips + ", members=" + members + "]";
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/samples/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/entities/PoolMember.java b/opendaylight/adsal/samples/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/entities/PoolMember.java
deleted file mode 100644 (file)
index 31949b4..0000000
+++ /dev/null
@@ -1,178 +0,0 @@
-/*
- * Copyright IBM Corporation, 2013.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.samples.loadbalancer.entities;
-
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-/**
- * This class represents the host where load balancing service will
- * redirect VIP traffic for load balancing. All these hosts have to
- * register with a pool to be a part of traffic load balancing.
- * This entity is referred to as a 'PoolMember'.
- * Load balancer service differentiates each pool member based on its
- * two properties { ip address, attached pool }.
- * A host (IP) can be attached to two different pools through creation of two
- * different pool member objects.
- *
- * NOTE: Each pool member should have a unique name.
- *
- */
-@XmlRootElement(name="poolmember")
-@XmlAccessorType(XmlAccessType.NONE)
-public class PoolMember {
-
-    /*
-     * Unique name of the pool member
-     */
-    @XmlElement
-    private String name;
-
-    /*
-     * IP address of the pool member
-     */
-    @XmlElement
-    private String ip;
-
-    /*
-     * Name of the pool this member is attached to.
-     */
-    @XmlElement(name="poolname")
-    private String poolName;
-
-    /*
-     * Status (active/inactive)
-     */
-    @XmlElement
-    private String status;
-
-    /**
-     * Private constructor used for JAXB mapping
-     */
-    @SuppressWarnings("unused")
-    private PoolMember() {}
-
-    public PoolMember(String name, String memberIP, String poolName){
-        this.name = name;
-        this.ip = memberIP;
-        this.poolName = poolName;
-    }
-
-    /**
-     * @return the name
-     */
-    public String getName() {
-        return name;
-    }
-
-    /**
-     * @param name the name to set
-     */
-    public void setName(String name) {
-        this.name = name;
-    }
-
-    /**
-     * @return the ip
-     */
-    public String getIp() {
-        return ip;
-    }
-
-    /**
-     * @param ip the ip to set
-     */
-    public void setIp(String ip) {
-        this.ip = ip;
-    }
-
-    /**
-     * @return the poolName
-     */
-    public String getPoolName() {
-        return poolName;
-    }
-
-    /**
-     * @param poolName the poolName to set
-     */
-    public void setPoolName(String poolName) {
-        this.poolName = poolName;
-    }
-
-    /**
-     * @return the status
-     */
-    public String getStatus() {
-        return status;
-    }
-
-    /**
-     * @param status the status to set
-     */
-    public void setStatus(String status) {
-        this.status = status;
-    }
-
-    /* (non-Javadoc)
-     * @see java.lang.Object#hashCode()
-     */
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + ((ip == null) ? 0 : ip.hashCode());
-        result = prime * result
-                + ((poolName == null) ? 0 : poolName.hashCode());
-        return result;
-    }
-
-    /* (non-Javadoc)
-     * @see java.lang.Object#equals(java.lang.Object)
-     */
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (!(obj instanceof PoolMember)) {
-            return false;
-        }
-        PoolMember other = (PoolMember) obj;
-        if (ip == null) {
-            if (other.ip != null) {
-                return false;
-            }
-        }else if (!ip.equals(other.ip)) {
-            return false;
-        }
-        if (poolName == null) {
-            if (other.poolName != null) {
-                return false;
-            }
-        }else if (!poolName.equals(other.poolName)) {
-            return false;
-        }
-        return true;
-    }
-
-    /* (non-Javadoc)
-     * @see java.lang.Object#toString()
-     */
-    @Override
-    public String toString() {
-        return "PoolMember [name=" + name + ", ip=" + ip + ", poolName="
-                                    + poolName + ", status=" + status + "]";
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/samples/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/entities/VIP.java b/opendaylight/adsal/samples/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/entities/VIP.java
deleted file mode 100644 (file)
index 22a7109..0000000
+++ /dev/null
@@ -1,200 +0,0 @@
-/*
- * Copyright IBM Corporation, 2013.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.samples.loadbalancer.entities;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-/**
- * This class represents the Virtual IP  (VIP) address exposed by the load balancer application.
- * Load balancer service differentiates one VIP from the other, using the following three properties:
- * 1. IP address of the VIP exposed by the application
- * 2. Protocol of the network traffic (TCP/UDP)
- * 3. Port to which incoming traffic is destined
- *
- * User is allowed to create mutliple VIPs with the same IP, but all such VIPs (with the same IP)
- * should differ at least in the protocol or port or both.
- *
- * NOTE: Each VIP should have a unique name.
- */
-@XmlRootElement(name="vip")
-@XmlAccessorType(XmlAccessType.NONE)
-
-public class VIP {
-
-    /*
-     * Unique name of the VIP
-     */
-    @XmlElement
-    private String name;
-
-    /*
-     * Virtual IP address of the VIP
-     */
-    @XmlElement
-    private String ip;
-
-    /*
-     *  Network traffic protocol
-     */
-    @XmlElement
-    private String protocol;
-
-    /*
-     * Port where network traffic is destined (destination port)
-     */
-    @XmlElement
-    private short port;
-
-    /*
-     * Name of the pool attached to the VIP for load balancing its traffic
-     */
-    @XmlElement(name="poolname")
-    private String poolName;
-
-    /*
-     * Status (Active/inactive)
-     */
-    @XmlElement
-    private String status;
-
-    /**
-     * Private constructor used for JAXB mapping
-     */
-    @SuppressWarnings("unused")
-    private VIP() {}
-
-    public VIP(String name,
-                String ip,
-                String protocol,
-                short port,
-                String poolName){
-        this.name = name;
-        this.ip=ip;
-        this.protocol=protocol;
-        this.port = port;
-        this.poolName = poolName;
-    }
-
-    public String getName() {
-        return name;
-    }
-
-    public void setName(String name) {
-        this.name = name;
-    }
-
-    public String getIp() {
-        return ip;
-    }
-
-    public void setIp(String ip) {
-        this.ip = ip;
-    }
-
-    public String getProtocol() {
-        return protocol;
-    }
-
-    public void setProtocol(String protocol) {
-        this.protocol = protocol;
-    }
-
-    public short getPort() {
-        return port;
-    }
-
-    public void setPort(short port) {
-        this.port = port;
-    }
-
-    public String getPoolName() {
-        return poolName;
-    }
-
-    public void setPoolName(String poolName) {
-        this.poolName = poolName;
-    }
-
-    /**
-     * @return the status
-     */
-    public String getStatus() {
-        return status;
-    }
-
-    /**
-     * @param status the status to set
-     */
-    public void setStatus(String status) {
-        this.status = status;
-    }
-
-    /* (non-Javadoc)
-     * @see java.lang.Object#hashCode()
-     */
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + ((ip == null) ? 0 : ip.hashCode());
-        result = prime * result + port;
-        result = prime * result
-                + ((protocol == null) ? 0 : protocol.hashCode());
-        return result;
-    }
-
-    /* (non-Javadoc)
-     * @see java.lang.Object#equals(java.lang.Object)
-     */
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (!(obj instanceof VIP)) {
-            return false;
-        }
-
-        VIP other = (VIP) obj;
-        if (ip == null) {
-            if (other.ip != null) {
-                return false;
-            }
-        }else if (!ip.equals(other.ip)) {
-            return false;
-        }
-        if (port != other.port) {
-            return false;
-        }
-        if (protocol == null) {
-            if (other.protocol != null) {
-                return false;
-            }
-        }else if (!protocol.equalsIgnoreCase(other.protocol)) {
-            return false;
-        }
-        return true;
-    }
-
-    /* (non-Javadoc)
-     * @see java.lang.Object#toString()
-     */
-    @Override
-    public String toString() {
-        return "VIP [name=" + name + ", ip=" + ip + ", protocol=" + protocol
-                            + ", port=" + port + ", poolName=" + poolName + ", status="
-                            + status + "]";
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/samples/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/internal/Activator.java b/opendaylight/adsal/samples/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/internal/Activator.java
deleted file mode 100644 (file)
index 8979fec..0000000
+++ /dev/null
@@ -1,122 +0,0 @@
-/*
- * Copyright IBM Corporation, 2013.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.samples.loadbalancer.internal;
-
-import java.util.Dictionary;
-import java.util.Hashtable;
-
-import org.apache.felix.dm.Component;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import org.opendaylight.controller.forwardingrulesmanager.IForwardingRulesManager;
-import org.opendaylight.controller.hosttracker.IfIptoHost;
-import org.opendaylight.controller.sal.core.ComponentActivatorAbstractBase;
-import org.opendaylight.controller.sal.packet.IDataPacketService;
-import org.opendaylight.controller.sal.packet.IListenDataPacket;
-import org.opendaylight.controller.sal.routing.IRouting;
-import org.opendaylight.controller.samples.loadbalancer.IConfigManager;
-
-/**
- * Main application activator class for registering the dependencies and
- * initialising the load balancer application.
- *
- */
-
-public class Activator extends ComponentActivatorAbstractBase {
-
-    /*
-     * Logger instance
-     */
-    protected static final Logger logger = LoggerFactory.getLogger(Activator.class);
-
-
-    /**
-     * Function that is used to communicate to dependency manager the
-     * list of known implementations for services inside a container
-     *
-     *
-     * @return An array containing all the CLASS objects that will be
-     * instantiated in order to get an fully working implementation
-     * Object
-     */
-    public Object[] getImplementations() {
-        Object[] res = { LoadBalancerService.class };
-        return res;
-    }
-
-    /**
-     * Function that is called when configuration of the dependencies
-     * is required.
-     *
-     * @param c dependency manager Component object, used for
-     * configuring the dependencies exported and imported
-     * @param imp Implementation class that is being configured,
-     * needed as long as the same routine can configure multiple
-     * implementations
-     * @param containerName The containerName being configured, this allow
-     * also optional per-container different behavior if needed, usually
-     * should not be the case though.
-     */
-    public void configureInstance(Component c, Object imp, String containerName) {
-        if (imp.equals(LoadBalancerService.class)) {
-            // export the service
-            Dictionary<String, String> props = new Hashtable<String, String>();
-            props.put("salListenerName", "loadbalancer");
-
-            c.setInterface(new String[] { IListenDataPacket.class.getName(),
-                        IConfigManager.class.getName()}, props);
-
-            c.add(createContainerServiceDependency(containerName).setService(
-                    IDataPacketService.class).setCallbacks(
-                    "setDataPacketService", "unsetDataPacketService")
-                    .setRequired(true));
-
-            c.add(createContainerServiceDependency(containerName).setService(
-                    IRouting.class).setCallbacks("setRouting", "unsetRouting")
-                    .setRequired(false));
-
-            c.add(createContainerServiceDependency(containerName).setService(
-                    IfIptoHost.class).setCallbacks("setHostTracker",
-                    "unsetHostTracker").setRequired(true));
-
-            c.add(createContainerServiceDependency(containerName).setService(
-                    IForwardingRulesManager.class).setCallbacks(
-                    "setForwardingRulesManager", "unsetForwardingRulesManager")
-                    .setRequired(true));
-        }
-    }
-
-    /**
-     * Method which tells how many Global implementations are
-     * supported by the bundle. This way we can tune the number of
-     * components created. This components will be created ONLY at the
-     * time of bundle startup and will be destroyed only at time of
-     * bundle destruction, this is the major difference with the
-     * implementation retrieved via getImplementations where all of
-     * them are assumed to be in a container !
-     *
-     *
-     * @return The list of implementations the bundle will support,
-     * in Global version
-     */
-    protected Object[] getGlobalImplementations() {
-        return null;
-    }
-
-    /**
-     * Configure the dependency for a given instance Global
-     *
-     * @param c Component assigned for this instance, this will be
-     * what will be used for configuration
-     * @param imp implementation to be configured
-     * @param containerName container on which the configuration happens
-     */
-    protected void configureGlobalInstance(Component c, Object imp) {
-    }
-}
diff --git a/opendaylight/adsal/samples/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/internal/LoadBalancerService.java b/opendaylight/adsal/samples/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/internal/LoadBalancerService.java
deleted file mode 100644 (file)
index b4836e9..0000000
+++ /dev/null
@@ -1,555 +0,0 @@
-/*
- * Copyright IBM Corporation, 2013.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.samples.loadbalancer.internal;
-
-import java.net.InetAddress;
-import java.net.UnknownHostException;
-import java.util.ArrayList;
-import java.util.Dictionary;
-import java.util.List;
-import java.util.Set;
-
-import org.apache.felix.dm.Component;
-import org.opendaylight.controller.forwardingrulesmanager.FlowEntry;
-import org.opendaylight.controller.forwardingrulesmanager.IForwardingRulesManager;
-import org.opendaylight.controller.hosttracker.HostIdFactory;
-import org.opendaylight.controller.hosttracker.IHostId;
-import org.opendaylight.controller.hosttracker.IfIptoHost;
-import org.opendaylight.controller.hosttracker.hostAware.HostNodeConnector;
-import org.opendaylight.controller.sal.action.Action;
-import org.opendaylight.controller.sal.action.Output;
-import org.opendaylight.controller.sal.action.SetDlDst;
-import org.opendaylight.controller.sal.action.SetDlSrc;
-import org.opendaylight.controller.sal.action.SetNwDst;
-import org.opendaylight.controller.sal.action.SetNwSrc;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.Path;
-import org.opendaylight.controller.sal.flowprogrammer.Flow;
-import org.opendaylight.controller.sal.match.Match;
-import org.opendaylight.controller.sal.match.MatchType;
-import org.opendaylight.controller.sal.packet.Ethernet;
-import org.opendaylight.controller.sal.packet.IDataPacketService;
-import org.opendaylight.controller.sal.packet.IListenDataPacket;
-import org.opendaylight.controller.sal.packet.IPv4;
-import org.opendaylight.controller.sal.packet.Packet;
-import org.opendaylight.controller.sal.packet.PacketResult;
-import org.opendaylight.controller.sal.packet.RawPacket;
-import org.opendaylight.controller.sal.routing.IRouting;
-import org.opendaylight.controller.sal.utils.EtherTypes;
-import org.opendaylight.controller.sal.utils.GlobalConstants;
-import org.opendaylight.controller.sal.utils.IPProtocols;
-import org.opendaylight.controller.samples.loadbalancer.ConfigManager;
-import org.opendaylight.controller.samples.loadbalancer.IConfigManager;
-import org.opendaylight.controller.samples.loadbalancer.LBConst;
-import org.opendaylight.controller.samples.loadbalancer.LBUtil;
-import org.opendaylight.controller.samples.loadbalancer.entities.Client;
-import org.opendaylight.controller.samples.loadbalancer.entities.Pool;
-import org.opendaylight.controller.samples.loadbalancer.entities.PoolMember;
-import org.opendaylight.controller.samples.loadbalancer.entities.VIP;
-import org.opendaylight.controller.samples.loadbalancer.policies.RandomLBPolicy;
-import org.opendaylight.controller.samples.loadbalancer.policies.RoundRobinLBPolicy;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * This class is the main class that represents the load balancer service. This
- * is a sample load balancer application that balances traffic to backend
- * servers based on the source address and source port on each incoming packet.
- * The service reactively installs OpenFlow rules to direct all packets with a
- * specific source address and source port to one of the appropriate backend
- * servers. The servers may be chosen using a round robin policy or a random
- * policy. This service can be configured via a REST APIs which are similar to
- * the OpenStack Quantum LBaaS (Load-balancer-as-a-Service) v1.0 API proposal
- * (http://wiki.openstack.org/Quantum/LBaaS)
- *
- * To use this service, a virtual IP (or VIP) should be exposed to the clients
- * of this service and used as the destination address. A VIP is a entity that
- * comprises of a virtual IP, port and protocol (TCP or UDP). Assumptions: 1.
- * One or more VIPs may be mapped to the same server pool. All VIPs that share
- * the same pool must also share the same load balancing policy (random or round
- * robin).
- *
- * 2. Only one server pool can be be assigned to a VIP.
- *
- * 3. All flow rules are installed with an idle timeout of 5 seconds.
- *
- * 4. Packets to a VIP must leave the OpenFlow cluster from the same switch from
- * where it entered it.
- *
- * 5. When you delete a VIP or a server pool or a server from a pool, the
- * service does not delete the flow rules it has already installed. The flow
- * rules should automatically time out after the idle timeout of 5 seconds.
- *
- */
-public class LoadBalancerService implements IListenDataPacket, IConfigManager {
-
-    /*
-     * Logger instance
-     */
-    private static Logger lbsLogger = LoggerFactory.getLogger(LoadBalancerService.class);
-
-    /*
-     * Single instance of the configuration manager. Application passes this
-     * reference to all the new policies implemented for load balancing.
-     */
-    private static ConfigManager configManager = new ConfigManager();
-
-    /*
-     * Round robing policy instance. Need to implement factory patterns to get
-     * policy instance.
-     */
-    private static RoundRobinLBPolicy rrLBMethod = new RoundRobinLBPolicy(configManager);
-
-    /*
-     * Random policy instance.
-     */
-    private static RandomLBPolicy ranLBMethod = new RandomLBPolicy(configManager);
-
-    /*
-     * Reference to the data packet service
-     */
-    private IDataPacketService dataPacketService = null;
-
-    /*
-     * Reference to the host tracker service
-     */
-    private IfIptoHost hostTracker;
-
-    /*
-     * Reference to the forwarding manager
-     */
-    private IForwardingRulesManager ruleManager;
-
-    /*
-     * Reference to the routing service
-     */
-    private IRouting routing;
-
-    /*
-     * Load balancer application installs all flows with priority 2.
-     */
-    private static short LB_IPSWITCH_PRIORITY = 2;
-
-    /*
-     * Name of the container where this application will register.
-     */
-    private String containerName = null;
-
-    /*
-     * Set/unset methods for the service instance that load balancer service
-     * requires
-     */
-    public String getContainerName() {
-        if (containerName == null) {
-            return GlobalConstants.DEFAULT.toString();
-        }
-        return containerName;
-    }
-
-    void setDataPacketService(IDataPacketService s) {
-        this.dataPacketService = s;
-    }
-
-    void unsetDataPacketService(IDataPacketService s) {
-        if (this.dataPacketService == s) {
-            this.dataPacketService = null;
-        }
-    }
-
-    public void setRouting(IRouting routing) {
-        this.routing = routing;
-    }
-
-    public void unsetRouting(IRouting routing) {
-        if (this.routing == routing) {
-            this.routing = null;
-        }
-    }
-
-    public void setHostTracker(IfIptoHost hostTracker) {
-        lbsLogger.debug("Setting HostTracker");
-        this.hostTracker = hostTracker;
-    }
-
-    public void unsetHostTracker(IfIptoHost hostTracker) {
-        if (this.hostTracker == hostTracker) {
-            this.hostTracker = null;
-        }
-    }
-
-    public void setForwardingRulesManager(IForwardingRulesManager forwardingRulesManager) {
-        lbsLogger.debug("Setting ForwardingRulesManager");
-        this.ruleManager = forwardingRulesManager;
-    }
-
-    public void unsetForwardingRulesManager(IForwardingRulesManager forwardingRulesManager) {
-        if (this.ruleManager == forwardingRulesManager) {
-            this.ruleManager = null;
-        }
-    }
-
-    /**
-     * This method receives first packet of flows for which there is no matching
-     * flow rule installed on the switch. IP addresses used for VIPs are not
-     * supposed to be used by any real/virtual host in the network. Hence, any
-     * forwarding/routing service will not install any flows rules matching
-     * these VIPs. This ensures that all the flows destined for VIPs will not
-     * find a match in the switch and will be forwarded to the load balancing
-     * service. Service will decide where to route this traffic based on the
-     * load balancing policy of the VIP's attached pool and will install
-     * appropriate flow rules in a reactive manner.
-     */
-    @Override
-    public PacketResult receiveDataPacket(RawPacket inPkt) {
-
-        if (inPkt == null) {
-            return PacketResult.IGNORED;
-        }
-
-        Packet formattedPak = this.dataPacketService.decodeDataPacket(inPkt);
-
-        if (formattedPak instanceof Ethernet) {
-            byte[] vipMacAddr = ((Ethernet) formattedPak).getDestinationMACAddress();
-            Object ipPkt = formattedPak.getPayload();
-
-            if (ipPkt instanceof IPv4) {
-
-                lbsLogger.debug("Packet recieved from switch : {}", inPkt.getIncomingNodeConnector().getNode()
-                        .toString());
-                IPv4 ipv4Pkt = (IPv4) ipPkt;
-                if (IPProtocols.getProtocolName(ipv4Pkt.getProtocol()).equals(IPProtocols.TCP.toString())
-                        || IPProtocols.getProtocolName(ipv4Pkt.getProtocol()).equals(IPProtocols.UDP.toString())) {
-
-                    lbsLogger.debug("Packet protocol : {}", IPProtocols.getProtocolName(ipv4Pkt.getProtocol()));
-                    Client client = new LBUtil().getClientFromPacket(ipv4Pkt);
-                    VIP vip = new LBUtil().getVIPFromPacket(ipv4Pkt);
-
-                    if (configManager.vipExists(vip)) {
-                        VIP vipWithPoolName = configManager.getVIPWithPoolName(vip);
-                        String poolMemberIp = null;
-                        if (vipWithPoolName.getPoolName() == null) {
-                            lbsLogger.error("No pool attached. Please attach pool with the VIP -- {}", vip);
-                            return PacketResult.IGNORED;
-                        }
-                        if (configManager.getPool(vipWithPoolName.getPoolName()).getLbMethod()
-                                .equalsIgnoreCase(LBConst.ROUND_ROBIN_LB_METHOD)) {
-
-                            poolMemberIp = rrLBMethod.getPoolMemberForClient(client, vipWithPoolName);
-                        }
-
-                        if (configManager.getPool(vipWithPoolName.getPoolName()).getLbMethod()
-                                .equalsIgnoreCase(LBConst.RANDOM_LB_METHOD)) {
-                            poolMemberIp = ranLBMethod.getPoolMemberForClient(client, vipWithPoolName);
-                        }
-
-                        try {
-
-                            Node clientNode = inPkt.getIncomingNodeConnector().getNode();
-                            // HostTracker hosts db key scheme implementation
-                            IHostId id = HostIdFactory.create(InetAddress.getByName(poolMemberIp), null);
-                            HostNodeConnector hnConnector = this.hostTracker.hostFind(id);
-
-                            Node destNode = hnConnector.getnodeconnectorNode();
-
-                            lbsLogger.debug("Client is connected to switch : {}", clientNode.toString());
-                            lbsLogger
-                                    .debug("Destination pool machine is connected to switch : {}", destNode.toString());
-
-                            // Get path between both the nodes
-                            NodeConnector forwardPort = null;
-
-                            if (clientNode.getNodeIDString().equals(destNode.getNodeIDString())) {
-
-                                forwardPort = hnConnector.getnodeConnector();
-
-                                lbsLogger
-                                        .trace("Both source (client) and destination pool machine is connected to same switch nodes. Respective ports are - {},{}",
-                                                forwardPort, inPkt.getIncomingNodeConnector());
-
-                            } else {
-
-                                Path route = this.routing.getRoute(clientNode, destNode);
-
-                                lbsLogger.trace("Path between source (client) and destination switch nodes : {}",
-                                        route.toString());
-
-                                forwardPort = route.getEdges().get(0).getTailNodeConnector();
-
-                            }
-
-                            if (installLoadBalancerFlow(client, vip, clientNode, poolMemberIp,
-                                    hnConnector.getDataLayerAddressBytes(), forwardPort,
-                                    LBConst.FORWARD_DIRECTION_LB_FLOW)) {
-                                lbsLogger.trace("Traffic from client : {} will be routed " + "to pool machine : {}",
-                                        client, poolMemberIp);
-                            } else {
-                                lbsLogger.error("Not able to route traffic from client : {}", client);
-                            }
-
-                            if (installLoadBalancerFlow(client, vip, clientNode, poolMemberIp, vipMacAddr,
-                                    inPkt.getIncomingNodeConnector(), LBConst.REVERSE_DIRECTION_LB_FLOW)) {
-                                lbsLogger.trace("Flow rule installed to change the source ip/mac from "
-                                        + "pool machine ip {} to VIP {} for traffic coming pool machine", poolMemberIp,
-                                        vip);
-                            } else {
-                                lbsLogger.error("Not able to route traffic from client : {}", client);
-                            }
-                        } catch (UnknownHostException e) {
-                            lbsLogger.error("Pool member not found  in the network : {}", e.getMessage());
-                            lbsLogger.error("", e);
-                        }
-                    }
-                }
-            }
-        }
-        return PacketResult.IGNORED;
-    }
-
-    /*
-     * This method installs the flow rule for routing the traffic between two
-     * hosts.
-     *
-     * @param source Traffic is sent by this source
-     *
-     * @param dest Traffic is destined to this destination (VIP)
-     *
-     * @param sourceSwitch Switch from where controller received the packet
-     *
-     * @param destMachineIp IP address of the pool member where traffic needs to
-     * be routed
-     *
-     * @param destMachineMac MAC address of the pool member where traffic needs
-     * to be routed
-     *
-     * @param outport Use this port to send out traffic
-     *
-     * @param flowDirection FORWARD_DIRECTION_LB_FLOW or
-     * REVERSE_DIRECTION_LB_FLOW
-     *
-     * @return true If flow installation was successful false else
-     *
-     * @throws UnknownHostException
-     */
-    private boolean installLoadBalancerFlow(Client source, VIP dest, Node sourceSwitch, String destMachineIp,
-            byte[] destMachineMac, NodeConnector outport, int flowDirection) throws UnknownHostException {
-
-        Match match = new Match();
-        List<Action> actions = new ArrayList<Action>();
-
-        if (flowDirection == LBConst.FORWARD_DIRECTION_LB_FLOW) {
-            match.setField(MatchType.DL_TYPE, EtherTypes.IPv4.shortValue());
-            match.setField(MatchType.NW_SRC, InetAddress.getByName(source.getIp()));
-            match.setField(MatchType.NW_DST, InetAddress.getByName(dest.getIp()));
-            match.setField(MatchType.NW_PROTO, IPProtocols.getProtocolNumberByte(dest.getProtocol()));
-            match.setField(MatchType.TP_SRC, source.getPort());
-            match.setField(MatchType.TP_DST, dest.getPort());
-
-            actions.add(new SetNwDst(InetAddress.getByName(destMachineIp)));
-            actions.add(new SetDlDst(destMachineMac));
-        }
-
-        if (flowDirection == LBConst.REVERSE_DIRECTION_LB_FLOW) {
-            match.setField(MatchType.DL_TYPE, EtherTypes.IPv4.shortValue());
-            match.setField(MatchType.NW_SRC, InetAddress.getByName(destMachineIp));
-            match.setField(MatchType.NW_DST, InetAddress.getByName(source.getIp()));
-            match.setField(MatchType.NW_PROTO, IPProtocols.getProtocolNumberByte(source.getProtocol()));
-            match.setField(MatchType.TP_SRC, dest.getPort());
-            match.setField(MatchType.TP_DST, source.getPort());
-
-            actions.add(new SetNwSrc(InetAddress.getByName(dest.getIp())));
-            actions.add(new SetDlSrc(destMachineMac));
-        }
-
-        actions.add(new Output(outport));
-
-        // Make sure the priority for IP switch entries is
-        // set to a level just above default drop entries
-
-        Flow flow = new Flow(match, actions);
-        flow.setIdleTimeout((short) 5);
-        flow.setHardTimeout((short) 0);
-        flow.setPriority(LB_IPSWITCH_PRIORITY);
-
-        String policyName = source.getIp() + ":" + source.getProtocol() + ":" + source.getPort();
-        String flowName = null;
-
-        if (flowDirection == LBConst.FORWARD_DIRECTION_LB_FLOW) {
-            flowName = "[" + policyName + ":" + source.getIp() + ":" + dest.getIp() + "]";
-        }
-
-        if (flowDirection == LBConst.REVERSE_DIRECTION_LB_FLOW) {
-
-            flowName = "[" + policyName + ":" + dest.getIp() + ":" + source.getIp() + "]";
-        }
-
-        FlowEntry fEntry = new FlowEntry(policyName, flowName, flow, sourceSwitch);
-
-        lbsLogger.trace("Install flow entry {} on node {}", fEntry.toString(), sourceSwitch.toString());
-
-        if (!this.ruleManager.checkFlowEntryConflict(fEntry)) {
-            if (this.ruleManager.installFlowEntry(fEntry).isSuccess()) {
-                return true;
-            } else {
-                lbsLogger.error("Error in installing flow entry to node : {}", sourceSwitch);
-            }
-        } else {
-            lbsLogger.error("Conflicting flow entry exists : {}", fEntry.toString());
-        }
-        return false;
-    }
-
-    /**
-     * Function called by the dependency manager when all the required
-     * dependencies are satisfied
-     *
-     */
-    void init(Component c) {
-        Dictionary<?, ?> props = c.getServiceProperties();
-        if (props != null) {
-            this.containerName = (String) props.get("containerName");
-
-            lbsLogger.trace("Running container name:" + this.containerName);
-        } else {
-
-            // In the Global instance case the containerName is empty
-            this.containerName = "";
-        }
-        lbsLogger.trace(configManager.toString());
-
-    }
-
-    /**
-     * Function called by the dependency manager when at least one dependency
-     * become unsatisfied or when the component is shutting down because for
-     * example bundle is being stopped.
-     *
-     */
-    void destroy() {
-    }
-
-    /**
-     * Function called by dependency manager after "init ()" is called and after
-     * the services provided by the class are registered in the service registry
-     *
-     */
-    void start() {
-    }
-
-    /**
-     * Function called by the dependency manager before the services exported by
-     * the component are unregistered, this will be followed by a "destroy ()"
-     * calls
-     *
-     */
-    void stop() {
-    }
-
-    /*
-     * All the methods below are just proxy methods to direct the REST API
-     * requests to configuration manager. We need this redirection as currently,
-     * opendaylight supports only one implementation of the service.
-     */
-    @Override
-    public Set<VIP> getAllVIPs() {
-        return configManager.getAllVIPs();
-    }
-
-    @Override
-    public boolean vipExists(String name, String ip, String protocol, short protocolPort, String poolName) {
-        return configManager.vipExists(name, ip, protocol, protocolPort, poolName);
-    }
-
-    @Override
-    public boolean vipExists(VIP vip) {
-        return configManager.vipExists(vip);
-    }
-
-    @Override
-    public VIP createVIP(String name, String ip, String protocol, short protocolPort, String poolName) {
-        return configManager.createVIP(name, ip, protocol, protocolPort, poolName);
-    }
-
-    @Override
-    public VIP updateVIP(String name, String poolName) {
-        return configManager.updateVIP(name, poolName);
-    }
-
-    @Override
-    public VIP deleteVIP(String name) {
-        return configManager.deleteVIP(name);
-    }
-
-    @Override
-    public boolean memberExists(String name, String memberIP, String poolName) {
-        return configManager.memberExists(name, memberIP, poolName);
-    }
-
-    @Override
-    public Set<PoolMember> getAllPoolMembers(String poolName) {
-
-        return configManager.getAllPoolMembers(poolName);
-    }
-
-    @Override
-    public PoolMember addPoolMember(String name, String memberIP, String poolName) {
-        return configManager.addPoolMember(name, memberIP, poolName);
-    }
-
-    @Override
-    public PoolMember removePoolMember(String name, String poolName) {
-
-        return configManager.removePoolMember(name, poolName);
-    }
-
-    @Override
-    public Set<Pool> getAllPools() {
-
-        return configManager.getAllPools();
-    }
-
-    @Override
-    public Pool getPool(String poolName) {
-        return configManager.getPool(poolName);
-    }
-
-    @Override
-    public boolean poolExists(String name, String lbMethod) {
-        return configManager.poolExists(name, lbMethod);
-    }
-
-    @Override
-    public Pool createPool(String name, String lbMethod) {
-        return configManager.createPool(name, lbMethod);
-    }
-
-    @Override
-    public Pool deletePool(String poolName) {
-        return configManager.deletePool(poolName);
-    }
-
-    @Override
-    public boolean vipExists(String name) {
-        return configManager.vipExists(name);
-    }
-
-    @Override
-    public boolean memberExists(String name, String poolName) {
-        return configManager.memberExists(name, poolName);
-    }
-
-    @Override
-    public boolean poolExists(String name) {
-        return configManager.poolExists(name);
-    }
-
-    @Override
-    public String getVIPAttachedPool(String name) {
-        return configManager.getVIPAttachedPool(name);
-    }
-}
diff --git a/opendaylight/adsal/samples/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/policies/ILoadBalancingPolicy.java b/opendaylight/adsal/samples/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/policies/ILoadBalancingPolicy.java
deleted file mode 100644 (file)
index f9562d6..0000000
+++ /dev/null
@@ -1,29 +0,0 @@
-/*
- * Copyright IBM Corporation, 2013.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.samples.loadbalancer.policies;
-
-import org.opendaylight.controller.samples.loadbalancer.entities.Client;
-import org.opendaylight.controller.samples.loadbalancer.entities.VIP;
-
-/**
- * All new load balancer policies must implement this interface.
- */
-public interface ILoadBalancingPolicy {
-
-    /**
-     * Returns IP address of the next pool member from the pool
-     * to which the load balancer service can direct incoming packets.
-     * @param source    source on the packet
-     * @param dest      virtual IP (VIP) that is used as destination on the packet
-     * @return  IP address of the next pool member which will serve
-     *          all incoming traffic destined for the given VIP and with the given source
-     *          information
-     */
-    public String getPoolMemberForClient(Client source, VIP dest);
-
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/samples/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/policies/RandomLBPolicy.java b/opendaylight/adsal/samples/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/policies/RandomLBPolicy.java
deleted file mode 100644 (file)
index c169d79..0000000
+++ /dev/null
@@ -1,108 +0,0 @@
-/*
- * Copyright IBM Corporation, 2013.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.samples.loadbalancer.policies;
-
-import java.util.ArrayList;
-import java.util.HashMap;
-import java.util.Random;
-
-import org.opendaylight.controller.samples.loadbalancer.ConfigManager;
-import org.opendaylight.controller.samples.loadbalancer.entities.Client;
-import org.opendaylight.controller.samples.loadbalancer.entities.Pool;
-import org.opendaylight.controller.samples.loadbalancer.entities.PoolMember;
-import org.opendaylight.controller.samples.loadbalancer.entities.VIP;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * This class implements the random load balancing policy.
- *
- */
-public class RandomLBPolicy implements ILoadBalancingPolicy {
-
-    /*
-     * Instance logger
-     */
-    private static final Logger rLogger = LoggerFactory.getLogger(RandomLBPolicy.class);
-
-    /*
-     * Reference to the configuration manager. This reference is passed from load balancer
-     * class.
-     */
-    private ConfigManager cmgr;
-
-    /*
-     * Mapping between the client and the pool member that serves all traffic for that client.
-     */
-    private HashMap<Client, PoolMember> clientMemberMap;
-
-    /*
-     * Random generator
-     */
-    Random randomGenerator = null;
-
-    @SuppressWarnings("unused")
-    private RandomLBPolicy(){}
-
-    public RandomLBPolicy(ConfigManager cmgr){
-        this.cmgr = cmgr;
-        this.clientMemberMap = new HashMap<Client, PoolMember>();
-        randomGenerator = new Random();
-    }
-    @Override
-    public String getPoolMemberForClient(Client source, VIP dest){
-
-        rLogger.trace("Received traffic from client : {} for VIP : {} ",source, dest);
-
-        syncWithLoadBalancerData();
-
-        PoolMember pm= null;
-
-        if(this.clientMemberMap.containsKey(source)){
-            pm= this.clientMemberMap.get(source);
-            rLogger.trace("Client {} had sent traffic before,new traffic will be routed to the same pool member {}",source,pm);
-        }else{
-            Pool pool = null;
-            pool = this.cmgr.getPool(dest.getPoolName());
-            int memberNum = this.randomGenerator.nextInt(pool.getAllMembers().size()-1);
-            pm = pool.getAllMembers().get(memberNum);
-            this.clientMemberMap.put(source, pm );
-            rLogger.trace("Network traffic from client {} will be directed to pool member {}",pm);
-        }
-        return pm.getIp();
-    }
-
-    /*
-     * This method does the clean up. Whenever a new client packet arrives with a given VIP,
-     * this method checks the current configuration to see if any pool members have been deleted and
-     * cleans up the metadata stored by this loadbalancing algorithm.
-     */
-    private void syncWithLoadBalancerData(){
-        rLogger.debug("[Client - PoolMember] table before cleanup : {}",this.clientMemberMap.toString());
-
-        ArrayList<Client> removeClient = new ArrayList<Client>();
-
-        if(this.clientMemberMap.size() != 0){
-            for(Client client : this.clientMemberMap.keySet()){
-
-                if(!this.cmgr.memberExists(this.clientMemberMap.get(client).getName(),
-                                                this.clientMemberMap.get(client).getPoolName())){
-                    removeClient.add(client);
-                }
-            }
-        }
-
-        for(Client client : removeClient){
-            this.clientMemberMap.remove(client);
-
-            rLogger.debug("Removed client : {} ",client);
-        }
-        rLogger.debug("[Client - PoolMember] table after cleanup : {}",this.clientMemberMap.toString());
-    }
-
-}
diff --git a/opendaylight/adsal/samples/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/policies/RoundRobinLBPolicy.java b/opendaylight/adsal/samples/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/policies/RoundRobinLBPolicy.java
deleted file mode 100644 (file)
index 492c7a9..0000000
+++ /dev/null
@@ -1,153 +0,0 @@
-/*
- * Copyright IBM Corporation, 2013.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.samples.loadbalancer.policies;
-
-import java.util.ArrayList;
-import java.util.HashMap;
-
-import org.opendaylight.controller.samples.loadbalancer.ConfigManager;
-import org.opendaylight.controller.samples.loadbalancer.entities.Client;
-import org.opendaylight.controller.samples.loadbalancer.entities.Pool;
-import org.opendaylight.controller.samples.loadbalancer.entities.PoolMember;
-import org.opendaylight.controller.samples.loadbalancer.entities.VIP;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * This class implements the round robin load balancing policy.
- *
- */
-public class RoundRobinLBPolicy implements ILoadBalancingPolicy{
-
-    /*
-     * Logger instance
-     */
-    private static final Logger rrLogger = LoggerFactory.getLogger(RoundRobinLBPolicy.class);
-
-    /*
-     * Reference to the configuration manager. This reference is passed from load balancer
-     * class.
-     */
-    private ConfigManager cmgr;
-
-    /*
-     * Mapping between the client and the pool member that serves all traffic for that client.
-     */
-    private HashMap<Client, PoolMember> clientMemberMap;
-
-    /*
-     * Maintains the next pool member counter for the VIPs.
-     * More than one VIP can be attached to one pool, so each VIP
-     * will have its own counter for the next pool member from
-     * the same pool.
-     */
-    private HashMap<VIP,Integer> nextItemFromPool;
-
-    @SuppressWarnings("unused")
-    private RoundRobinLBPolicy(){}
-
-    public RoundRobinLBPolicy(ConfigManager cmgr){
-        this.cmgr = cmgr;
-        this.clientMemberMap = new HashMap<Client, PoolMember>();
-        this.nextItemFromPool = new HashMap<VIP, Integer>();
-    }
-
-    @Override
-    public String getPoolMemberForClient(Client source, VIP dest){
-
-        rrLogger.trace("Received traffic from client : {} for VIP : {} ",source, dest);
-
-        syncWithLoadBalancerData();
-
-        PoolMember pm= null;
-
-        if(this.clientMemberMap.containsKey(source)){
-
-            pm= this.clientMemberMap.get(source);
-            rrLogger.trace("Client {} had sent traffic before,new traffic will be routed to the same pool member {}",source,pm);
-        }else{
-
-            Pool pool = null;
-            if(nextItemFromPool.containsKey(dest)){
-
-                int memberNum = nextItemFromPool.get(dest).intValue();
-                rrLogger.debug("Packet is from new client for VIP {}",dest);
-                pool = this.cmgr.getPool(dest.getPoolName());
-                pm = pool.getAllMembers().get(memberNum);
-                this.clientMemberMap.put(source, pm );
-                rrLogger.trace("New client's packet will be directed to pool member {}",pm);
-                memberNum++;
-
-                if(memberNum > pool.getAllMembers().size()-1){
-                    memberNum = 0;
-                }
-                rrLogger.debug("Next pool member for new client of VIP is set to {}",pool.getAllMembers().get(memberNum));
-
-                this.nextItemFromPool.put(dest, memberNum);
-            }else{
-                rrLogger.debug("Network traffic for VIP : {} has appeared first time from client {}",dest,source);
-                pool = this.cmgr.getPool(dest.getPoolName());
-                pm = pool.getAllMembers().get(0);
-                this.clientMemberMap.put(source, pm);
-
-                rrLogger.trace("Network traffic from client {} will be directed to pool member {}",pm);
-                this.nextItemFromPool.put(dest, 1);
-                rrLogger.debug("Next pool member for new client of VIP is set to {}",pool.getAllMembers().get(1));
-            }
-        }
-        return pm.getIp();
-    }
-
-    /*
-     * This method does the clean up. Whenever a new client packet arrives with a given VIP,
-     * this method checks the current configuration to see if any pool members have been deleted and
-     * cleans up the metadata stored by this loadbalancing algorithm.
-     */
-    private void syncWithLoadBalancerData(){
-        rrLogger.debug("[Client - PoolMember] table before cleanup : {}",this.clientMemberMap.toString());
-        ArrayList<Client> removeClient = new ArrayList<Client>();
-
-        if(this.clientMemberMap.size() != 0){
-            for(Client client : this.clientMemberMap.keySet()){
-                if(!this.cmgr.memberExists(this.clientMemberMap.get(client).getName(),
-                                            this.clientMemberMap.get(client).getPoolName())){
-
-                    removeClient.add(client);
-                }
-            }
-        }
-
-        for(Client client : removeClient){
-            this.clientMemberMap.remove(client);
-
-            rrLogger.debug("Removed client : {} ",client);
-        }
-        rrLogger.debug("[Client - PoolMember] table after cleanup : {}",this.clientMemberMap.toString());
-
-        rrLogger.debug("[VIP- NextMember] table before cleanup : {}",this.nextItemFromPool.toString());
-
-        ArrayList<VIP> resetVIPPoolMemberCount= new ArrayList<VIP>();
-
-        if(this.nextItemFromPool.size() != 0){
-
-            for(VIP vip:this.nextItemFromPool.keySet()){
-                if(this.nextItemFromPool.get(vip).intValue() > this.cmgr.getPool(vip.getPoolName()).getAllMembers().size()-1){
-
-                    resetVIPPoolMemberCount.add(vip);
-                }
-            }
-        }
-
-        for(VIP vip:resetVIPPoolMemberCount){
-            rrLogger.debug("VIP next pool member counter reset to 0");
-            this.nextItemFromPool.put(vip, 0);
-        }
-
-        rrLogger.debug("[VIP- NextMember] table after cleanup : {}",this.nextItemFromPool.toString());
-    }
-}
diff --git a/opendaylight/adsal/samples/loadbalancer/src/test/java/org/opendaylight/controller/samples/loadbalancer/internal/LoadBalancerTest.java b/opendaylight/adsal/samples/loadbalancer/src/test/java/org/opendaylight/controller/samples/loadbalancer/internal/LoadBalancerTest.java
deleted file mode 100644 (file)
index cfffb7e..0000000
+++ /dev/null
@@ -1,66 +0,0 @@
-/*\r
- * Copyright IBM Corporation, 2013.  All rights reserved.\r
- *\r
- * This program and the accompanying materials are made available under the\r
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,\r
- * and is available at http://www.eclipse.org/legal/epl-v10.html\r
- */\r
-package org.opendaylight.controller.samples.loadbalancer.internal;\r
-\r
-\r
-import org.junit.Assert;\r
-import org.junit.Test;\r
-import org.opendaylight.controller.samples.loadbalancer.ConfigManager;\r
-import org.opendaylight.controller.samples.loadbalancer.entities.Client;\r
-import org.opendaylight.controller.samples.loadbalancer.entities.Pool;\r
-import org.opendaylight.controller.samples.loadbalancer.entities.PoolMember;\r
-import org.opendaylight.controller.samples.loadbalancer.entities.VIP;\r
-import org.opendaylight.controller.samples.loadbalancer.policies.RoundRobinLBPolicy;\r
-\r
-/**\r
- *\r
- * Class to unit test the load balancing policies.\r
- *\r
- */\r
-public class LoadBalancerTest {\r
-    @Test\r
-    public void testRoundRobinPolicy() {\r
-        ConfigManager cm = null;\r
-        cm = new ConfigManager();\r
-\r
-        Pool pool = cm.createPool("TestPool","roundrobin");\r
-        VIP vip = cm.createVIP("TestVIP","10.0.0.9","TCP",(short)5550,"TestPool");\r
-        PoolMember host1 = new PoolMember("host1","10.0.0.1","TestPool");\r
-        PoolMember host2 = new PoolMember("host2","10.0.0.2","TestPool");\r
-        PoolMember host3 = new PoolMember("host3","10.0.0.3","TestPool");\r
-        PoolMember host4 = new PoolMember("host4","10.0.0.4","TestPool");\r
-        PoolMember host5 = new PoolMember("host5","10.0.0.5","TestPool");\r
-        PoolMember host6 = new PoolMember("host6","10.0.0.6","TestPool");\r
-        PoolMember host7 = new PoolMember("host7","10.0.0.7","TestPool");\r
-\r
-        pool.addMember(host1);\r
-        pool.addMember(host2);\r
-        pool.addMember(host3);\r
-        pool.addMember(host4);\r
-        pool.addMember(host5);\r
-        pool.addMember(host6);\r
-        pool.addMember(host7);\r
-        pool.addVIP(vip);\r
-\r
-        Assert.assertTrue(cm.getAllPoolMembers("TestPool").size() == pool.getAllMembers().size());\r
-\r
-        RoundRobinLBPolicy rrp = new RoundRobinLBPolicy(cm);\r
-\r
-        Client c1 = new Client("10.0.0.1","TCP",(short)5000);\r
-        Assert.assertTrue(rrp.getPoolMemberForClient(c1, vip).equals(host1.getIp()));\r
-\r
-        c1 = new Client("10.0.0.1","TCP",(short)5001);\r
-        Assert.assertTrue(rrp.getPoolMemberForClient(c1, vip).equals(host2.getIp()));\r
-\r
-        c1 = new Client("10.0.0.1","TCP",(short)5002);\r
-        Assert.assertTrue(rrp.getPoolMemberForClient(c1, vip).equals(host3.getIp()));\r
-\r
-        c1 = new Client("10.0.0.1","TCP",(short)5003);\r
-        Assert.assertTrue(rrp.getPoolMemberForClient(c1, vip).equals(host4.getIp()));\r
-    }\r
-}
diff --git a/opendaylight/adsal/samples/northbound/loadbalancer/enunciate.xml b/opendaylight/adsal/samples/northbound/loadbalancer/enunciate.xml
deleted file mode 100644 (file)
index 13ec7ca..0000000
+++ /dev/null
@@ -1,12 +0,0 @@
-<?xml version="1.0"?>
-<enunciate label="full" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
-    xsi:noNamespaceSchemaLocation="http://enunciate.codehaus.org/schemas/enunciate-1.26.xsd">
-
-  <services>
-    <rest defaultRestSubcontext="/one/nb/v2/lb"/>
-  </services>
-
-  <modules>
-    <docs docsDir="rest" title="Load Balancer REST API" includeExampleXml="true" includeExampleJson="true"/>
-  </modules>
-</enunciate>
diff --git a/opendaylight/adsal/samples/northbound/loadbalancer/pom.xml b/opendaylight/adsal/samples/northbound/loadbalancer/pom.xml
deleted file mode 100644 (file)
index 5c4322f..0000000
+++ /dev/null
@@ -1,85 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>adsal-enunciate-parent</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../adsal-enunciate-parent</relativePath>
-  </parent>
-
-  <artifactId>samples.loadbalancer.northbound</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>org.codehaus.enunciate</groupId>
-      <artifactId>enunciate-core-annotations</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>commons.northbound</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>containermanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>hosttracker</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>samples.loadbalancer</artifactId>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Import-Package>org.opendaylight.controller.samples.loadbalancer,
-              org.opendaylight.controller.samples.loadbalancer.entities,
-              org.opendaylight.controller.samples.loadbalancer.internal,
-              org.opendaylight.controller.samples.loadbalancer.policies,
-              org.opendaylight.controller.hosttracker,
-              org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.sal.utils,
-              org.opendaylight.controller.containermanager,
-              org.opendaylight.controller.switchmanager,
-              org.apache.commons.logging,
-              com.sun.jersey.spi.container.servlet,
-              org.opendaylight.controller.northbound.commons,
-              org.opendaylight.controller.northbound.commons.exception,
-              javax.ws.rs,
-              javax.ws.rs.core,
-              javax.xml.bind.annotation,
-              javax.xml.bind,
-              org.slf4j,
-              org.apache.catalina.filters,
-              com.fasterxml.jackson.jaxrs.base,
-              com.fasterxml.jackson.jaxrs.json,
-              !org.codehaus.enunciate.jaxrs</Import-Package>
-            <Web-ContextPath>/one/nb/v2/lb</Web-ContextPath>
-            <Jaxrs-Resources>,${classes;ANNOTATION;javax.ws.rs.Path}</Jaxrs-Resources>
-          </instructions>
-          <manifestLocation>${project.basedir}/src/main/resources/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/samples/northbound/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/northbound/LoadBalancerNorthbound.java b/opendaylight/adsal/samples/northbound/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/northbound/LoadBalancerNorthbound.java
deleted file mode 100644 (file)
index 2734c09..0000000
+++ /dev/null
@@ -1,470 +0,0 @@
-/*
- * Copyright IBM Corporation, 2013.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.samples.loadbalancer.northbound;
-
-import java.util.List;
-
-import javax.ws.rs.Consumes;
-import javax.ws.rs.DELETE;
-import javax.ws.rs.GET;
-import javax.ws.rs.POST;
-import javax.ws.rs.PUT;
-import javax.ws.rs.Path;
-import javax.ws.rs.PathParam;
-import javax.ws.rs.Produces;
-import javax.ws.rs.core.MediaType;
-import javax.ws.rs.core.Response;
-
-import org.codehaus.enunciate.jaxrs.ResponseCode;
-import org.codehaus.enunciate.jaxrs.StatusCodes;
-import org.codehaus.enunciate.jaxrs.TypeHint;
-import org.opendaylight.controller.containermanager.IContainerManager;
-import org.opendaylight.controller.samples.loadbalancer.entities.Pool;
-import org.opendaylight.controller.samples.loadbalancer.entities.PoolMember;
-import org.opendaylight.controller.samples.loadbalancer.entities.VIP;
-import org.opendaylight.controller.northbound.commons.RestMessages;
-import org.opendaylight.controller.northbound.commons.exception.InternalServerErrorException;
-import org.opendaylight.controller.northbound.commons.exception.MethodNotAllowedException;
-import org.opendaylight.controller.northbound.commons.exception.ResourceConflictException;
-import org.opendaylight.controller.northbound.commons.exception.ResourceNotFoundException;
-import org.opendaylight.controller.northbound.commons.exception.ServiceUnavailableException;
-import org.opendaylight.controller.northbound.commons.exception.UnsupportedMediaTypeException;
-import org.opendaylight.controller.sal.utils.ServiceHelper;
-import org.opendaylight.controller.samples.loadbalancer.IConfigManager;
-
-/**
- * This class exposes North bound REST APIs for the Load Balancer Service.
- * Following APIs are exposed by the Load Balancer Service:
- *
- * Data retrieval REST APIs::
- *      1. Get details of all existing pools
- *              Type : GET
- *              URI : /one/nb/v2/lb/{container-name}/
- *      NOTE: Current implementation of the opendaylight usage 'default' as a container-name
- *      e.g : http://localhost:8080/one/nb/v2/lb/default will give you list of all the pools
- *
- *      2. Get details of all the existing VIPs
- *              Type : GET
- *              URI:  /one/nb/v2/lb/{container-name}/vips
- *
- * Pool related REST APIs::
- *      1. Create Pool :
- *              Type : POST
- *              URI : /one/nb/v2/lb/{container-name}/create/pool
- *              Request body :
- *                      {
- *                              "name":"",
- *                              "lbmethod":""
- *                      }
- *              Currently, two load balancing policies are allowed {"roundrobin" and "random" }
- *
- *      2. Delete Pool :
- *              Type : DELETE
- *              URI : /one/nb/v2/lb/{container-name}/delete/pool/{pool-name}
- *
- * VIP related REST APIs::
- *      1. Create VIP:
- *              Type : POST
- *              URI : /one/nb/v2/lb/{container-name}/create/vip
- *              Request body :
- *                      {
- *                              "name":"",
- *                              "ip":"ip in (xxx.xxx.xxx.xxx) format",
- *                              "protocol":"TCP/UDP",
- *                              "port":"any valid port number",
- *                              "poolname":"" (optional)
- *                       }
- *              The pool name is optional and can be set up at a later stage (using the REST API given below).
- *
- *      2. Update VIP: Update pool name of the VIP
- *              Type : PUT
- *              URI : /one/nb/v2/lb/{container-name}/update/vip
- *              Request body :
- *                      {
- *                              "name":"",
- *                              "poolname":""
- *                       }
- *              Currently, we only allow update of the VIP pool name (if a VIP does not have an attached pool)
- *              and not of the VIP name itself.
- *              The specified pool name must already exist. If the specified VIP is already attached to a pool, the update
- *              will fail.
- *
- *      3. Delete VIP :
- *              Type : DELETE
- *              URI : /one/nb/v2/lb/{container-name}/delete/vip/{vip-name}
- *
- * Pool member related REST APIs::
- *      1. Create pool member:
- *              Type : POST
- *              URI : /one/nb/v2/lb/default/create/poolmember
- *              Request body :
- *                      {
- *                              "name":"",
- *                              "ip":"ip in (xxx.xxx.xxx.xxx) format",
- *                              "poolname":"existing pool name"
- *                       }
- *
- *      2. Delete pool member:
- *              Type : DELETE
- *              URI : /one/nb/v2/lb/{container-name}/delete/poolmember/{pool-member-name}/{pool-name}
- *
- *  NOTE: Property "name" of each individual entity must be unique.
- *  All the above REST APIs throw appropriate response codes in case of error/success.
- *  Please consult the respective methods to get details of various response codes.
- */
-
-@Path("/")
-public class LoadBalancerNorthbound {
-
-    /*
-     * Method returns the Load balancer service instance running within
-     * 'default' container.
-     */
-    private IConfigManager getConfigManagerService(String containerName) {
-        IContainerManager containerManager = (IContainerManager) ServiceHelper
-                .getGlobalInstance(IContainerManager.class, this);
-        if (containerManager == null) {
-            throw new ServiceUnavailableException("Container "
-                    + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        boolean found = false;
-        List<String> containerNames = containerManager.getContainerNames();
-        for (String cName : containerNames) {
-            if (cName.trim().equalsIgnoreCase(containerName.trim())) {
-                found = true;
-            }
-        }
-
-        if (found == false) {
-            throw new ResourceNotFoundException(containerName + " "
-                    + RestMessages.NOCONTAINER.toString());
-        }
-
-        IConfigManager configManager = (IConfigManager) ServiceHelper.getInstance(
-                        IConfigManager.class, containerName, this);
-
-        if (configManager == null) {
-            throw new ServiceUnavailableException("Load Balancer"
-                    + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        return configManager;
-    }
-
-    @Path("/{containerName}")
-    @GET
-    @Produces( { MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @TypeHint(Pools.class)
-    @StatusCodes( {
-        @ResponseCode(code = 200, condition = "Operation successful"),
-        @ResponseCode(code = 404, condition = "The containerName is not found"),
-        @ResponseCode(code = 503, condition = "Load balancer service is unavailable") })
-    public Pools getAllPools(
-            @PathParam("containerName") String containerName) {
-
-        IConfigManager configManager = getConfigManagerService(containerName);
-        if (configManager == null) {
-            throw new ServiceUnavailableException("Load Balancer "
-                                                    + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        return new Pools(configManager.getAllPools());
-    }
-
-    @Path("/{containerName}/vips")
-    @GET
-    @Produces( { MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @TypeHint(VIPs.class)
-    @StatusCodes( {
-        @ResponseCode(code = 200, condition = "Operation successful"),
-        @ResponseCode(code = 404, condition = "The containerName is not found"),
-        @ResponseCode(code = 503, condition = "Load balancer service is unavailable") })
-    public VIPs getAllVIPs(
-            @PathParam("containerName") String containerName) {
-
-        IConfigManager configManager = getConfigManagerService(containerName);
-        if (configManager == null) {
-            throw new ServiceUnavailableException("Load Balancer "
-                    + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        return new VIPs(configManager.getAllVIPs());
-    }
-
-    @Path("/{containerName}/create/vip")
-    @POST
-    @Consumes( { MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @StatusCodes( {
-        @ResponseCode(code = 201, condition = "VIP created successfully"),
-        @ResponseCode(code = 404, condition = "The Container Name not found"),
-        @ResponseCode(code = 503, condition = "Load balancer service is unavailable"),
-        @ResponseCode(code = 409, condition = "VIP already exist"),
-        @ResponseCode(code = 415, condition = "Invalid input data")})
-    public Response addVIP(@PathParam("containerName") String containerName,
-            @TypeHint(VIP.class) VIP inVIP){
-
-        VIP vipInput = inVIP;
-        String name = vipInput.getName();
-        String ip = vipInput.getIp();
-        String protocol = vipInput.getProtocol();
-        short protocolPort = vipInput.getPort();
-        String poolName = vipInput.getPoolName();
-        if(name.isEmpty() ||
-                ip.isEmpty()||
-                protocol.isEmpty()||
-                protocolPort < 0 ){
-            throw new UnsupportedMediaTypeException(RestMessages.INVALIDDATA.toString());
-        }
-
-        IConfigManager configManager = getConfigManagerService(containerName);
-
-        if (configManager == null) {
-            throw new ServiceUnavailableException("Load Balancer "
-                    + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        if(!configManager.vipExists(name, ip, protocol, protocolPort, poolName)){
-
-            VIP vip = configManager.createVIP(name, ip, protocol, protocolPort, poolName);
-            if ( vip != null){
-                return Response.status(Response.Status.CREATED).build();
-            }
-        }else{
-            throw new ResourceConflictException(NBConst.RES_VIP_ALREADY_EXIST);
-        }
-        throw new InternalServerErrorException(NBConst.RES_VIP_CREATION_FAILED);
-    }
-
-    @Path("/{containerName}/update/vip")
-    @PUT
-    @Consumes( { MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @StatusCodes( {
-        @ResponseCode(code = 201, condition = "VIP updated successfully"),
-        @ResponseCode(code = 404, condition = "The containerName not found"),
-        @ResponseCode(code = 503, condition = "VIP not found"),
-        @ResponseCode(code = 404, condition = "Pool not found"),
-        @ResponseCode(code = 405, condition = "Pool already attached to the VIP"),
-        @ResponseCode(code = 415, condition = "Invalid input name")})
-    public Response updateVIP(@PathParam("containerName") String containerName,
-            @TypeHint(VIP.class) VIP inVIP) {
-
-        VIP vipInput = inVIP;
-        String name = vipInput.getName();
-        String poolName = vipInput.getPoolName();
-        if(name.isEmpty() ||
-                poolName.isEmpty()){
-            throw new UnsupportedMediaTypeException(RestMessages.INVALIDDATA.toString());
-        }
-
-        IConfigManager configManager = getConfigManagerService(containerName);
-        if (configManager == null) {
-            throw new ServiceUnavailableException("Load Balancer "
-                                                + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        if(!configManager.poolExists(poolName))
-            throw new ResourceNotFoundException(NBConst.RES_POOL_NOT_FOUND);
-
-        if(configManager.getVIPAttachedPool(name)!=null)
-            throw new MethodNotAllowedException(NBConst.RES_VIP_POOL_EXIST);
-
-        if(configManager.updateVIP(name, poolName)!= null)
-            return Response.status(Response.Status.ACCEPTED).build();
-
-        throw new InternalServerErrorException(NBConst.RES_VIP_UPDATE_FAILED);
-    }
-
-    @Path("/{containerName}/delete/vip/{vipName}")
-    @DELETE
-    @Consumes( { MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @StatusCodes( {
-        @ResponseCode(code = 200, condition = "VIP deleted successfully"),
-        @ResponseCode(code = 404, condition = "The containerName not found"),
-        @ResponseCode(code = 503, condition = "Load balancer service is unavailable"),
-        @ResponseCode(code = 404, condition = "VIP not found"),
-        @ResponseCode(code = 500, condition = "Failed to delete VIP")})
-    public Response deleteVIP(
-            @PathParam(value = "containerName") String containerName,
-            @PathParam(value = "vipName") String vipName) {
-
-        if(vipName.isEmpty())
-            throw new UnsupportedMediaTypeException(RestMessages.INVALIDDATA.toString());
-
-        IConfigManager configManager = getConfigManagerService(containerName);
-        if (configManager == null) {
-            throw new ServiceUnavailableException("Load Balancer"
-                                            + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        if(!configManager.vipExists(vipName))
-            throw new ResourceNotFoundException(NBConst.RES_VIP_NOT_FOUND);
-
-        for(VIP vip : configManager.getAllVIPs()){
-            if(vip.getName().equals(vipName)){
-                configManager.deleteVIP(vipName);
-                return Response.ok().build();
-            }
-        }
-        throw new InternalServerErrorException(NBConst.RES_VIP_DELETION_FAILED);
-    }
-
-    @Path("/{containerName}/create/pool")
-    @POST
-    @Consumes( { MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @StatusCodes( {
-        @ResponseCode(code = 201, condition = "Pool created successfully"),
-        @ResponseCode(code = 404, condition = "The containerName not found"),
-        @ResponseCode(code = 503, condition = "Load balancer service is unavailable"),
-        @ResponseCode(code = 409, condition = "Pool already exist"),
-        @ResponseCode(code = 415, condition = "Invalid input data")})
-    public Response addPool(@PathParam("containerName") String containerName,
-            @TypeHint(Pool.class) Pool inPool) {
-
-        Pool poolInput = inPool;
-        String name = poolInput.getName();
-        String lbMethod =poolInput.getLbMethod();
-        if(name.isEmpty() ||
-                lbMethod.isEmpty()){
-            throw new UnsupportedMediaTypeException(RestMessages.INVALIDDATA.toString());
-        }
-
-        IConfigManager configManager = getConfigManagerService(containerName);
-        if (configManager == null) {
-            throw new ServiceUnavailableException("Load Balancer "
-                                            + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        if(!configManager.poolExists(name)){
-
-            Pool pool = configManager.createPool(name, lbMethod);
-            if ( pool != null){
-                return Response.status(Response.Status.CREATED).build();
-            }
-        }else{
-            throw new ResourceConflictException(NBConst.RES_POOL_ALREADY_EXIST);
-        }
-        throw new InternalServerErrorException(NBConst.RES_POOL_CREATION_FAILED);
-    }
-
-    @Path("/{containerName}/delete/pool/{poolName}")
-    @DELETE
-    @Consumes( { MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @StatusCodes( {
-        @ResponseCode(code = 200, condition = "Pool deleted successfully"),
-        @ResponseCode(code = 404, condition = "The containerName not found"),
-        @ResponseCode(code = 503, condition = "Load balancer service is unavailable"),
-        @ResponseCode(code = 404, condition = "Pool not found"),
-        @ResponseCode(code = 500, condition = "Failed to delete Pool")})
-    public Response deletePool(
-            @PathParam(value = "containerName") String containerName,
-            @PathParam(value = "poolName") String poolName) {
-
-        if(poolName.isEmpty())
-            throw new UnsupportedMediaTypeException(RestMessages.INVALIDDATA.toString());
-
-        IConfigManager configManager = getConfigManagerService(containerName);
-        if (configManager == null) {
-            throw new ServiceUnavailableException("Load Balancer"
-                                        + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        if(!configManager.poolExists(poolName))
-            throw new ResourceNotFoundException(NBConst.RES_POOL_NOT_FOUND);
-
-        for(Pool pool:configManager.getAllPools()){
-            if(pool.getName().equals(poolName)){
-                configManager.deletePool(poolName);
-                return Response.ok().build();
-            }
-        }
-        throw new InternalServerErrorException(NBConst.RES_POOL_DELETION_FAILED);
-    }
-
-    @Path("/{containerName}/create/poolmember")
-    @POST
-    @Consumes( { MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @StatusCodes( {
-        @ResponseCode(code = 201, condition = "Pool member created successfully"),
-        @ResponseCode(code = 404, condition = "The containerName not found"),
-        @ResponseCode(code = 503, condition = "Load balancer service is unavailable"),
-        @ResponseCode(code = 404, condition = "Pool not found"),
-        @ResponseCode(code = 409, condition = "Pool member already exist"),
-        @ResponseCode(code = 415, condition = "Invalid input data")})
-    public Response addPoolMember(@PathParam("containerName") String containerName,
-            @TypeHint(PoolMember.class) PoolMember inPoolMember){
-
-        PoolMember pmInput = inPoolMember;
-        String name = pmInput.getName();
-        String memberIP = pmInput.getIp();
-        String poolName = pmInput.getPoolName();
-
-        if(name.isEmpty() ||
-                memberIP.isEmpty()||
-                poolName.isEmpty()){
-            throw new UnsupportedMediaTypeException(RestMessages.INVALIDDATA.toString());
-        }
-
-        IConfigManager configManager = getConfigManagerService(containerName);
-        if (configManager == null) {
-            throw new ServiceUnavailableException("Load Balancer "
-                                        + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        if(!configManager.poolExists(poolName))
-            throw new ResourceNotFoundException(NBConst.RES_POOL_NOT_FOUND);
-
-        if(!configManager.memberExists(name, memberIP, poolName)){
-
-            PoolMember poolMember = configManager.addPoolMember(name, memberIP, poolName);
-            if ( poolMember != null){
-                return Response.status(Response.Status.CREATED).build();
-            }
-        }else{
-            throw new ResourceConflictException(NBConst.RES_POOLMEMBER_ALREADY_EXIST);
-        }
-        throw new InternalServerErrorException(NBConst.RES_POOLMEMBER_CREATION_FAILED);
-    }
-
-    @Path("/{containerName}/delete/poolmember/{poolMemberName}/{poolName}")
-    @DELETE
-    @Consumes( { MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
-    @StatusCodes( {
-        @ResponseCode(code = 200, condition = "Pool member deleted successfully"),
-        @ResponseCode(code = 404, condition = "The containerName not found"),
-        @ResponseCode(code = 503, condition = "Load balancer service is unavailable"),
-        @ResponseCode(code = 404, condition = "Pool member not found"),
-        @ResponseCode(code = 404, condition = "Pool not found")})
-    public Response deletePoolMember(
-            @PathParam(value = "containerName") String containerName,
-            @PathParam(value = "poolMemberName") String poolMemberName,
-            @PathParam(value = "poolName") String poolName) {
-
-        if(poolMemberName.isEmpty()||
-                poolName.isEmpty())
-            throw new UnsupportedMediaTypeException(RestMessages.INVALIDDATA.toString());
-
-        IConfigManager configManager = getConfigManagerService(containerName);
-
-        if (configManager == null) {
-            throw new ServiceUnavailableException("Load Balancer"
-                                        + RestMessages.SERVICEUNAVAILABLE.toString());
-        }
-
-        if(!configManager.poolExists(poolName))
-            throw new ResourceNotFoundException(NBConst.RES_POOL_NOT_FOUND);
-
-        if(configManager.memberExists(poolMemberName, poolName)){
-
-            configManager.removePoolMember(poolMemberName, poolName);
-
-            return Response.ok().build();
-        }
-        throw new ResourceNotFoundException(NBConst.RES_POOLMEMBER_NOT_FOUND);
-    }
-}
diff --git a/opendaylight/adsal/samples/northbound/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/northbound/NBConst.java b/opendaylight/adsal/samples/northbound/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/northbound/NBConst.java
deleted file mode 100644 (file)
index a5d2091..0000000
+++ /dev/null
@@ -1,43 +0,0 @@
-/*
- * Copyright IBM Corporation, 2013.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.samples.loadbalancer.northbound;
-
-/**
- * This class defines all the constants used by the load balancer north bound service
- *
- */
-public class NBConst {
-
-    public static final String RES_VIP_ALREADY_EXIST= " VIP already exists";
-
-    public static final String RES_VIP_NOT_FOUND= " VIP not found";
-
-    public static final String RES_VIP_CREATION_FAILED = " Creation of VIP failed";
-
-    public static final String RES_VIP_DELETION_FAILED = " Deletion of VIP failed";
-
-    public static final String RES_VIP_UPDATE_FAILED = " Update of VIP failed";
-
-    public static final String RES_POOL_ALREADY_EXIST= " Pool already exists";
-
-    public static final String RES_POOL_NOT_FOUND= " Pool not found";
-
-    public static final String RES_POOL_CREATION_FAILED = " Creation of pool failed";
-
-    public static final String RES_POOL_DELETION_FAILED = " Deletion of pool failed";
-
-    public static final String RES_POOLMEMBER_ALREADY_EXIST= " Pool member already exists";
-
-    public static final String RES_POOLMEMBER_NOT_FOUND= " Pool member not found";
-
-    public static final String RES_POOLMEMBER_CREATION_FAILED = " Creation of pool member failed";
-
-    public static final String RES_POOLMEMBER_DELETION_FAILED = " Deletion of pool member failed";
-
-    public static final String RES_VIP_POOL_EXIST = "Pool already attached to a VIP";
-}
diff --git a/opendaylight/adsal/samples/northbound/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/northbound/Pools.java b/opendaylight/adsal/samples/northbound/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/northbound/Pools.java
deleted file mode 100644 (file)
index 74be568..0000000
+++ /dev/null
@@ -1,51 +0,0 @@
-/*
- * Copyright IBM Corporation, 2013.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.samples.loadbalancer.northbound;
-
-import java.util.Set;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.samples.loadbalancer.entities.Pool;
-
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-/**
- * JAX-RS resource for handling details of all the available pools
- * in response to respective REST API requests.
- */
-
-public class Pools {
-
-    @XmlElement (name="pool")
-    Set<Pool> loadBalancerPools;
-
-    public Pools() {
-    }
-
-    public Pools (Set<Pool> loadBalancerPools) {
-        this.loadBalancerPools = loadBalancerPools;
-    }
-
-    /**
-     * @return the loadBalancerPools
-     */
-    public Set<Pool> getLoadBalancerPools() {
-        return loadBalancerPools;
-    }
-
-    /**
-     * @param loadBalancerPools the loadBalancerPools to set
-     */
-    public void setLoadBalancerPools(Set<Pool> loadBalancerPools) {
-        this.loadBalancerPools = loadBalancerPools;
-    }
-}
diff --git a/opendaylight/adsal/samples/northbound/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/northbound/VIPs.java b/opendaylight/adsal/samples/northbound/loadbalancer/src/main/java/org/opendaylight/controller/samples/loadbalancer/northbound/VIPs.java
deleted file mode 100644 (file)
index 66a2033..0000000
+++ /dev/null
@@ -1,53 +0,0 @@
-/*
- * Copyright IBM Corporation, 2013.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.samples.loadbalancer.northbound;
-
-import java.util.Set;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.samples.loadbalancer.entities.VIP;
-
-/**
- * JAX-RS resource for handling details of all the available VIPs
- * in response to respective REST API requests.
- */
-
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-
-public class VIPs {
-
-    @XmlElement (name="vip")
-    Set<VIP> loadBalancerVIPs;
-
-    public VIPs() {}
-
-
-    public VIPs (Set<VIP> loadBalancerVIPs) {
-        this.loadBalancerVIPs = loadBalancerVIPs;
-    }
-
-    /**
-     * @return the loadBalancerVIPs
-     */
-    public Set<VIP> getLoadBalancerVIPs() {
-        return loadBalancerVIPs;
-    }
-
-    /**
-     * @param loadBalancerVIPs the loadBalancerVIPs to set
-     */
-
-    public void setLoadBalancerVIPs(Set<VIP> loadBalancerVIPs) {
-        this.loadBalancerVIPs = loadBalancerVIPs;
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/samples/northbound/loadbalancer/src/main/resources/META-INF/spring.factories b/opendaylight/adsal/samples/northbound/loadbalancer/src/main/resources/META-INF/spring.factories
deleted file mode 100644 (file)
index 93db02e..0000000
+++ /dev/null
@@ -1 +0,0 @@
-org.springframework.beans.BeanInfoFactory=org.springframework.beans.ExtendedBeanInfoFactory
diff --git a/opendaylight/adsal/samples/northbound/loadbalancer/src/main/resources/META-INF/spring.handlers b/opendaylight/adsal/samples/northbound/loadbalancer/src/main/resources/META-INF/spring.handlers
deleted file mode 100644 (file)
index 957af91..0000000
+++ /dev/null
@@ -1,10 +0,0 @@
-http\://www.springframework.org/schema/context=org.springframework.context.config.ContextNamespaceHandler
-http\://www.springframework.org/schema/jee=org.springframework.ejb.config.JeeNamespaceHandler
-http\://www.springframework.org/schema/lang=org.springframework.scripting.config.LangNamespaceHandler
-http\://www.springframework.org/schema/task=org.springframework.scheduling.config.TaskNamespaceHandler
-http\://www.springframework.org/schema/cache=org.springframework.cache.config.CacheNamespaceHandler
-http\://www.springframework.org/schema/c=org.springframework.beans.factory.xml.SimpleConstructorNamespaceHandler
-http\://www.springframework.org/schema/p=org.springframework.beans.factory.xml.SimplePropertyNamespaceHandler
-http\://www.springframework.org/schema/util=org.springframework.beans.factory.xml.UtilNamespaceHandler
-http\://www.springframework.org/schema/mvc=org.springframework.web.servlet.config.MvcNamespaceHandler
-http\://www.springframework.org/schema/security=org.springframework.security.config.SecurityNamespaceHandler
diff --git a/opendaylight/adsal/samples/northbound/loadbalancer/src/main/resources/META-INF/spring.schemas b/opendaylight/adsal/samples/northbound/loadbalancer/src/main/resources/META-INF/spring.schemas
deleted file mode 100644 (file)
index d865edc..0000000
+++ /dev/null
@@ -1,49 +0,0 @@
-http\://www.springframework.org/schema/beans/spring-beans-2.0.xsd=org/springframework/beans/factory/xml/spring-beans-2.0.xsd
-http\://www.springframework.org/schema/beans/spring-beans-2.5.xsd=org/springframework/beans/factory/xml/spring-beans-2.5.xsd
-http\://www.springframework.org/schema/beans/spring-beans-3.0.xsd=org/springframework/beans/factory/xml/spring-beans-3.0.xsd
-http\://www.springframework.org/schema/beans/spring-beans-3.1.xsd=org/springframework/beans/factory/xml/spring-beans-3.1.xsd
-http\://www.springframework.org/schema/beans/spring-beans-3.2.xsd=org/springframework/beans/factory/xml/spring-beans-3.2.xsd
-http\://www.springframework.org/schema/beans/spring-beans.xsd=org/springframework/beans/factory/xml/spring-beans-3.2.xsd
-http\://www.springframework.org/schema/tool/spring-tool-2.0.xsd=org/springframework/beans/factory/xml/spring-tool-2.0.xsd
-http\://www.springframework.org/schema/tool/spring-tool-2.5.xsd=org/springframework/beans/factory/xml/spring-tool-2.5.xsd
-http\://www.springframework.org/schema/tool/spring-tool-3.0.xsd=org/springframework/beans/factory/xml/spring-tool-3.0.xsd
-http\://www.springframework.org/schema/tool/spring-tool-3.1.xsd=org/springframework/beans/factory/xml/spring-tool-3.1.xsd
-http\://www.springframework.org/schema/tool/spring-tool-3.2.xsd=org/springframework/beans/factory/xml/spring-tool-3.2.xsd
-http\://www.springframework.org/schema/tool/spring-tool.xsd=org/springframework/beans/factory/xml/spring-tool-3.2.xsd
-http\://www.springframework.org/schema/util/spring-util-2.0.xsd=org/springframework/beans/factory/xml/spring-util-2.0.xsd
-http\://www.springframework.org/schema/util/spring-util-2.5.xsd=org/springframework/beans/factory/xml/spring-util-2.5.xsd
-http\://www.springframework.org/schema/util/spring-util-3.0.xsd=org/springframework/beans/factory/xml/spring-util-3.0.xsd
-http\://www.springframework.org/schema/util/spring-util-3.1.xsd=org/springframework/beans/factory/xml/spring-util-3.1.xsd
-http\://www.springframework.org/schema/util/spring-util-3.2.xsd=org/springframework/beans/factory/xml/spring-util-3.2.xsd
-http\://www.springframework.org/schema/util/spring-util.xsd=org/springframework/beans/factory/xml/spring-util-3.2.xsd
-http\://www.springframework.org/schema/context/spring-context-2.5.xsd=org/springframework/context/config/spring-context-2.5.xsd
-http\://www.springframework.org/schema/context/spring-context-3.0.xsd=org/springframework/context/config/spring-context-3.0.xsd
-http\://www.springframework.org/schema/context/spring-context-3.1.xsd=org/springframework/context/config/spring-context-3.1.xsd
-http\://www.springframework.org/schema/context/spring-context-3.2.xsd=org/springframework/context/config/spring-context-3.2.xsd
-http\://www.springframework.org/schema/context/spring-context.xsd=org/springframework/context/config/spring-context-3.2.xsd
-http\://www.springframework.org/schema/jee/spring-jee-2.0.xsd=org/springframework/ejb/config/spring-jee-2.0.xsd
-http\://www.springframework.org/schema/jee/spring-jee-2.5.xsd=org/springframework/ejb/config/spring-jee-2.5.xsd
-http\://www.springframework.org/schema/jee/spring-jee-3.0.xsd=org/springframework/ejb/config/spring-jee-3.0.xsd
-http\://www.springframework.org/schema/jee/spring-jee-3.1.xsd=org/springframework/ejb/config/spring-jee-3.1.xsd
-http\://www.springframework.org/schema/jee/spring-jee-3.2.xsd=org/springframework/ejb/config/spring-jee-3.2.xsd
-http\://www.springframework.org/schema/jee/spring-jee.xsd=org/springframework/ejb/config/spring-jee-3.2.xsd
-http\://www.springframework.org/schema/lang/spring-lang-2.0.xsd=org/springframework/scripting/config/spring-lang-2.0.xsd
-http\://www.springframework.org/schema/lang/spring-lang-2.5.xsd=org/springframework/scripting/config/spring-lang-2.5.xsd
-http\://www.springframework.org/schema/lang/spring-lang-3.0.xsd=org/springframework/scripting/config/spring-lang-3.0.xsd
-http\://www.springframework.org/schema/lang/spring-lang-3.1.xsd=org/springframework/scripting/config/spring-lang-3.1.xsd
-http\://www.springframework.org/schema/lang/spring-lang-3.2.xsd=org/springframework/scripting/config/spring-lang-3.2.xsd
-http\://www.springframework.org/schema/lang/spring-lang.xsd=org/springframework/scripting/config/spring-lang-3.2.xsd
-http\://www.springframework.org/schema/task/spring-task-3.0.xsd=org/springframework/scheduling/config/spring-task-3.0.xsd
-http\://www.springframework.org/schema/task/spring-task-3.1.xsd=org/springframework/scheduling/config/spring-task-3.1.xsd
-http\://www.springframework.org/schema/task/spring-task-3.2.xsd=org/springframework/scheduling/config/spring-task-3.2.xsd
-http\://www.springframework.org/schema/task/spring-task.xsd=org/springframework/scheduling/config/spring-task-3.2.xsd
-http\://www.springframework.org/schema/cache/spring-cache-3.1.xsd=org/springframework/cache/config/spring-cache-3.1.xsd
-http\://www.springframework.org/schema/cache/spring-cache-3.2.xsd=org/springframework/cache/config/spring-cache-3.2.xsd
-http\://www.springframework.org/schema/cache/spring-cache.xsd=org/springframework/cache/config/spring-cache-3.2.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd=org/springframework/web/servlet/config/spring-mvc-3.0.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc-3.1.xsd=org/springframework/web/servlet/config/spring-mvc-3.1.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc-3.2.xsd=org/springframework/web/servlet/config/spring-mvc-3.2.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc.xsd=org/springframework/web/servlet/config/spring-mvc-3.2.xsd
-http\://www.springframework.org/schema/security/spring-security-3.1.xsd=org/springframework/security/config/spring-security-3.1.xsd
-http\://www.springframework.org/schema/security/spring-security-3.2.xsd=org/springframework/security/config/spring-security-3.2.xsd
-
diff --git a/opendaylight/adsal/samples/northbound/loadbalancer/src/main/resources/META-INF/spring.tooling b/opendaylight/adsal/samples/northbound/loadbalancer/src/main/resources/META-INF/spring.tooling
deleted file mode 100644 (file)
index 057d834..0000000
+++ /dev/null
@@ -1,39 +0,0 @@
-# Tooling related information for the beans namespace
-http\://www.springframework.org/schema/beans@name=beans Namespace
-http\://www.springframework.org/schema/beans@prefix=beans
-http\://www.springframework.org/schema/beans@icon=org/springframework/beans/factory/xml/spring-beans.gif
-
-# Tooling related information for the util namespace
-http\://www.springframework.org/schema/util@name=util Namespace
-http\://www.springframework.org/schema/util@prefix=util
-http\://www.springframework.org/schema/util@icon=org/springframework/beans/factory/xml/spring-util.gif
-
-# Tooling related information for the context namespace
-http\://www.springframework.org/schema/context@name=context Namespace
-http\://www.springframework.org/schema/context@prefix=context
-http\://www.springframework.org/schema/context@icon=org/springframework/context/config/spring-context.gif
-
-# Tooling related information for the jee namespace
-http\://www.springframework.org/schema/jee@name=jee Namespace
-http\://www.springframework.org/schema/jee@prefix=jee
-http\://www.springframework.org/schema/jee@icon=org/springframework/ejb/config/spring-jee.gif
-
-# Tooling related information for the scheduling namespace
-http\://www.springframework.org/schema/task@name=task Namespace
-http\://www.springframework.org/schema/task@prefix=task
-http\://www.springframework.org/schema/task@icon=org/springframework/scheduling/config/spring-task.gif
-
-# Tooling related information for the lang namespace
-http\://www.springframework.org/schema/lang@name=lang Namespace
-http\://www.springframework.org/schema/lang@prefix=lang
-http\://www.springframework.org/schema/lang@icon=org/springframework/scripting/config/spring-lang.gif
-
-# Tooling related information for the cache namespace
-http\://www.springframework.org/schema/cache@name=cache Namespace
-http\://www.springframework.org/schema/cache@prefix=cache
-http\://www.springframework.org/schema/cache@icon=org/springframework/cache/config/spring-cache.gif
-
-# Tooling related information for the mvc namespace
-http\://www.springframework.org/schema/mvc@name=mvc Namespace
-http\://www.springframework.org/schema/mvc@prefix=mvc
-http\://www.springframework.org/schema/mvc@icon=org/springframework/web/servlet/config/spring-mvc.gif
diff --git a/opendaylight/adsal/samples/northbound/loadbalancer/src/main/resources/WEB-INF/web.xml b/opendaylight/adsal/samples/northbound/loadbalancer/src/main/resources/WEB-INF/web.xml
deleted file mode 100644 (file)
index 20529e9..0000000
+++ /dev/null
@@ -1,89 +0,0 @@
-<?xml version="1.0" encoding="ISO-8859-1"?>
-<web-app xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
-        xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
-        version="3.0">
-  <servlet>
-    <servlet-name>JAXRSLoadBalancer</servlet-name>
-    <servlet-class>com.sun.jersey.spi.container.servlet.ServletContainer</servlet-class>
-    <init-param>
-      <param-name>javax.ws.rs.Application</param-name>
-      <param-value>org.opendaylight.controller.northbound.commons.NorthboundApplication</param-value>
-    </init-param>
-    <load-on-startup>1</load-on-startup>
-  </servlet>
-
-  <servlet-mapping>
-    <servlet-name>JAXRSLoadBalancer</servlet-name>
-    <url-pattern>/*</url-pattern>
-  </servlet-mapping>
-
-        <filter>
-          <filter-name>CorsFilter</filter-name>
-          <filter-class>org.apache.catalina.filters.CorsFilter</filter-class>
-          <init-param>
-            <param-name>cors.allowed.origins</param-name>
-            <param-value>*</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.allowed.methods</param-name>
-            <param-value>GET,POST,HEAD,OPTIONS,PUT,DELETE</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.allowed.headers</param-name>
-            <param-value>Content-Type,X-Requested-With,accept,authorization, origin,Origin,Access-Control-Request-Method,Access-Control-Request-Headers</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.exposed.headers</param-name>
-            <param-value>Access-Control-Allow-Origin,Access-Control-Allow-Credentials</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.support.credentials</param-name>
-            <param-value>true</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.preflight.maxage</param-name>
-            <param-value>10</param-value>
-          </init-param>
-        </filter>
-        <filter-mapping>
-          <filter-name>CorsFilter</filter-name>
-          <url-pattern>/*</url-pattern>
-        </filter-mapping>
-
-        <security-constraint>
-          <web-resource-collection>
-            <web-resource-name>NB api</web-resource-name>
-            <url-pattern>/*</url-pattern>
-            <http-method>POST</http-method>
-            <http-method>GET</http-method>
-            <http-method>PUT</http-method>
-            <http-method>PATCH</http-method>
-            <http-method>DELETE</http-method>
-            <http-method>HEAD</http-method>
-          </web-resource-collection>
-          <auth-constraint>
-            <role-name>System-Admin</role-name>
-            <role-name>Network-Admin</role-name>
-            <role-name>Network-Operator</role-name>
-            <role-name>Container-User</role-name>
-          </auth-constraint>
-        </security-constraint>
-
-        <security-role>
-                <role-name>System-Admin</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Network-Admin</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Network-Operator</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Container-User</role-name>
-        </security-role>
-
-        <login-config>
-                <auth-method>BASIC</auth-method>
-                <realm-name>opendaylight</realm-name>
-        </login-config>
-</web-app>
diff --git a/opendaylight/adsal/samples/simpleforwarding/pom.xml b/opendaylight/adsal/samples/simpleforwarding/pom.xml
deleted file mode 100644 (file)
index a90fd69..0000000
+++ /dev/null
@@ -1,81 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>samples.simpleforwarding</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>forwardingrulesmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>hosttracker</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>switchmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>topologymanager</artifactId>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Import-Package>org.opendaylight.controller.sal.utils,
-              org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.forwardingrulesmanager,
-              org.opendaylight.controller.hosttracker,
-              org.opendaylight.controller.hosttracker.hostAware,
-              org.opendaylight.controller.switchmanager,
-              org.opendaylight.controller.clustering.services,
-              org.opendaylight.controller.sal.action,
-              org.opendaylight.controller.sal.flowprogrammer,
-              org.opendaylight.controller.sal.inventory,
-              org.opendaylight.controller.sal.match,
-              org.opendaylight.controller.sal.packet,
-              org.opendaylight.controller.sal.routing,
-              org.opendaylight.controller.topologymanager,
-              org.apache.commons.lang3.builder,
-              org.junit;resolution:=optional,
-              org.slf4j,
-              org.apache.felix.dm</Import-Package>
-            <Export-Package>org.opendaylight.controller.samples.simpleforwarding</Export-Package>
-            <Bundle-Activator>org.opendaylight.controller.samples.simpleforwarding.internal.Activator</Bundle-Activator>
-          </instructions>
-          <manifestLocation>${project.basedir}/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/samples/simpleforwarding/src/main/java/org/opendaylight/controller/samples/simpleforwarding/HostNodePair.java b/opendaylight/adsal/samples/simpleforwarding/src/main/java/org/opendaylight/controller/samples/simpleforwarding/HostNodePair.java
deleted file mode 100644 (file)
index 2d0d468..0000000
+++ /dev/null
@@ -1,85 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.samples.simpleforwarding;
-
-import java.io.Serializable;
-
-import org.opendaylight.controller.hosttracker.hostAware.HostNodeConnector;
-import org.opendaylight.controller.sal.core.Node;
-
-/**
- * Class that represent a pair of {Host, Node}, the intent of it
- * is to be used as a key in the database kept by IPSwitching module
- * where for every Host, Switch we will have a Forwarding Rule that
- * will route the traffic toward the /32 destination
- *
- */
-public class HostNodePair implements Serializable {
-    private static final long serialVersionUID = 1L;
-    private HostNodeConnector host;
-    private Node node;
-
-    public HostNodePair(HostNodeConnector h, Node s) {
-        setNode(s);
-        setHost(h);
-    }
-
-    public Node getNode() {
-        return node;
-    }
-
-    public void setNode(Node nodeId) {
-        this.node = nodeId;
-    }
-
-    public HostNodeConnector getHost() {
-        return host;
-    }
-
-    public void setHost(HostNodeConnector host) {
-        this.host = host;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + ((host == null) ? 0 : host.hashCode());
-        result = prime * result + ((node == null) ? 0 : node.hashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj)
-            return true;
-        if (obj == null)
-            return false;
-        if (getClass() != obj.getClass())
-            return false;
-        HostNodePair other = (HostNodePair) obj;
-        if (host == null) {
-            if (other.host != null)
-                return false;
-        } else if (!host.equals(other.host))
-            return false;
-        if (node == null) {
-            if (other.node != null)
-                return false;
-        } else if (!node.equals(other.node))
-            return false;
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        return "HostNodePair [host=" + host + ", node=" + node + "]";
-    }
-}
diff --git a/opendaylight/adsal/samples/simpleforwarding/src/main/java/org/opendaylight/controller/samples/simpleforwarding/IBroadcastHandler.java b/opendaylight/adsal/samples/simpleforwarding/src/main/java/org/opendaylight/controller/samples/simpleforwarding/IBroadcastHandler.java
deleted file mode 100644 (file)
index 3ae5d82..0000000
+++ /dev/null
@@ -1,65 +0,0 @@
-/*
- * Copyright (c) 2013 IBM and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.samples.simpleforwarding;
-
-import org.opendaylight.controller.sal.packet.RawPacket;
-
-
-/**
- * Provides support for flooding/broadcasting of packets.
- */
-public interface IBroadcastHandler {
-
-    /**
-     * The mode to select which ports to broadcast a given packet. See the
-     * individual modes for the expected behavior.
-     */
-    static enum BroadcastMode {
-        /**
-         * Turn off broadcast handling and ignore all received data packets.
-         */
-        DISABLED,
-
-        /**
-         * sends broadcast packets out ports where there are known hosts as
-         * discovered by {@link ITopologyManager#getNodeConnectorWithHost}.
-         */
-        BROADCAST_TO_HOSTS,
-
-        /**
-         * sends broadcast packets out all non-internal links as discovered by
-         * {@link ITopologyManager#isInternal}. Also ignores ports which have
-         * {@link NodeConnector#getType} of "SW" indicating OFPP_LOCAL.
-         */
-        BROADCAST_TO_NONINTERNAL,
-
-        /**
-         * sends broadcast packets out the ports specified by an external
-         * implementation of {@link IBroadcastPortSelector}.
-         */
-        EXTERNAL_QUERY
-    };
-
-    /**
-     * Set the {@link BroadcastMode} for this {@link IBroadcastHandler}.
-     * @param m
-     */
-    void setMode(BroadcastMode m);
-
-    /**
-     * Safely flood/broadcast a {@link RawPacket} received on a given
-     * {@link NodeConnector}.
-     *
-     * @param pkt
-     *            The packet to flood/broadcast
-     * @return <tt>true</tt> if the broadcast is successful, <tt>false</tt>
-     *         otherwise
-     */
-    boolean broadcastPacket(RawPacket pkt);
-}
diff --git a/opendaylight/adsal/samples/simpleforwarding/src/main/java/org/opendaylight/controller/samples/simpleforwarding/IBroadcastPortSelector.java b/opendaylight/adsal/samples/simpleforwarding/src/main/java/org/opendaylight/controller/samples/simpleforwarding/IBroadcastPortSelector.java
deleted file mode 100644 (file)
index 438c921..0000000
+++ /dev/null
@@ -1,17 +0,0 @@
-/*
- * Copyright (c) 2013 IBM and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.samples.simpleforwarding;
-
-import java.util.Set;
-
-import org.opendaylight.controller.sal.core.NodeConnector;
-
-public interface IBroadcastPortSelector {
-    Set<NodeConnector> getBroadcastPorts();
-}
diff --git a/opendaylight/adsal/samples/simpleforwarding/src/main/java/org/opendaylight/controller/samples/simpleforwarding/internal/Activator.java b/opendaylight/adsal/samples/simpleforwarding/src/main/java/org/opendaylight/controller/samples/simpleforwarding/internal/Activator.java
deleted file mode 100644 (file)
index 6ee04b4..0000000
+++ /dev/null
@@ -1,133 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.samples.simpleforwarding.internal;
-
-import java.util.Dictionary;
-import java.util.Hashtable;
-
-import org.apache.felix.dm.Component;
-import org.opendaylight.controller.clustering.services.IClusterContainerServices;
-import org.opendaylight.controller.forwardingrulesmanager.IForwardingRulesManager;
-import org.opendaylight.controller.hosttracker.IfIptoHost;
-import org.opendaylight.controller.hosttracker.IfNewHostNotify;
-import org.opendaylight.controller.sal.core.ComponentActivatorAbstractBase;
-import org.opendaylight.controller.sal.packet.IDataPacketService;
-import org.opendaylight.controller.sal.packet.IListenDataPacket;
-import org.opendaylight.controller.sal.routing.IListenRoutingUpdates;
-import org.opendaylight.controller.sal.routing.IRouting;
-import org.opendaylight.controller.samples.simpleforwarding.IBroadcastHandler;
-import org.opendaylight.controller.samples.simpleforwarding.IBroadcastPortSelector;
-import org.opendaylight.controller.switchmanager.IInventoryListener;
-import org.opendaylight.controller.switchmanager.ISwitchManager;
-import org.opendaylight.controller.topologymanager.ITopologyManager;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-public class Activator extends ComponentActivatorAbstractBase {
-    protected static final Logger logger = LoggerFactory
-            .getLogger(Activator.class);
-
-
-    /**
-     * Function that is used to communicate to dependency manager the
-     * list of known implementations for services inside a container
-     *
-     *
-     * @return An array containing all the CLASS objects that will be
-     * instantiated in order to get an fully working implementation
-     * Object
-     */
-    @Override
-    public Object[] getImplementations() {
-        Object[] res = { SimpleForwardingImpl.class,
-                         SimpleBroadcastHandlerImpl.class };
-        return res;
-    }
-
-    /**
-     * Function that is called when configuration of the dependencies
-     * is required.
-     *
-     * @param c dependency manager Component object, used for
-     * configuring the dependencies exported and imported
-     * @param imp Implementation class that is being configured,
-     * needed as long as the same routine can configure multiple
-     * implementations
-     * @param containerName The containerName being configured, this allow
-     * also optional per-container different behavior if needed, usually
-     * should not be the case though.
-     */
-    @Override
-    public void configureInstance(Component c, Object imp, String containerName) {
-        if (imp.equals(SimpleForwardingImpl.class)) {
-            Dictionary<String, Object> props = new Hashtable<String, Object>();
-            props.put("salListenerName", "simpleforwarding");
-
-            // export the service
-            c.setInterface(new String[] { IInventoryListener.class.getName(),
-                    IfNewHostNotify.class.getName(),
-                    IListenRoutingUpdates.class.getName(),
-                    IListenDataPacket.class.getName() }, props);
-
-            c.add(createContainerServiceDependency(containerName).setService(
-                    IClusterContainerServices.class).setCallbacks(
-                    "setClusterContainerService",
-                    "unsetClusterContainerService").setRequired(true));
-
-            c.add(createContainerServiceDependency(containerName).setService(
-                    ISwitchManager.class).setCallbacks("setSwitchManager",
-                    "unsetSwitchManager").setRequired(false));
-
-            c.add(createContainerServiceDependency(containerName).setService(
-                    IfIptoHost.class).setCallbacks("setHostTracker",
-                    "unsetHostTracker").setRequired(false));
-
-            c.add(createContainerServiceDependency(containerName).setService(
-                    IForwardingRulesManager.class).setCallbacks(
-                    "setForwardingRulesManager", "unsetForwardingRulesManager")
-                    .setRequired(true));
-
-            c.add(createContainerServiceDependency(containerName).setService(
-                    ITopologyManager.class).setCallbacks("setTopologyManager",
-                    "unsetTopologyManager").setRequired(false));
-
-            c.add(createContainerServiceDependency(containerName).setService(
-                    IRouting.class).setCallbacks("setRouting", "unsetRouting")
-                    .setRequired(false));
-            c.add(createContainerServiceDependency(containerName).setService(
-                    IDataPacketService.class).setCallbacks("setDataPacketService",
-                   "unsetDataPacketService").setRequired(false));
-
-        } else if (imp.equals(SimpleBroadcastHandlerImpl.class)) {
-            Dictionary<String, String> props = new Hashtable<String, String>();
-            props.put("salListenerName", "simplebroadcasthandler");
-
-            // export the service
-            c.setInterface(new String[] { IBroadcastHandler.class.getName(),
-                    IListenDataPacket.class.getName() }, props);
-
-            c.add(createContainerServiceDependency(containerName).setService(
-                    IDataPacketService.class).setCallbacks("setDataPacketService",
-                   "unsetDataPacketService").setRequired(false));
-
-            c.add(createContainerServiceDependency(containerName).setService(
-                   ITopologyManager.class).setCallbacks("setTopologyManager",
-                   "unsetTopologyManager").setRequired(true));
-
-            c.add(createContainerServiceDependency(containerName).setService(
-                   IBroadcastPortSelector.class).setCallbacks("setBroadcastPortSelector",
-                   "unsetBroadcastPortSelector").setRequired(false));
-
-            c.add(createContainerServiceDependency(containerName).setService(
-                   ISwitchManager.class).setCallbacks("setSwitchManager",
-                   "unsetSwitchManager").setRequired(false));
-        }
-    }
-}
diff --git a/opendaylight/adsal/samples/simpleforwarding/src/main/java/org/opendaylight/controller/samples/simpleforwarding/internal/SimpleBroadcastHandlerImpl.java b/opendaylight/adsal/samples/simpleforwarding/src/main/java/org/opendaylight/controller/samples/simpleforwarding/internal/SimpleBroadcastHandlerImpl.java
deleted file mode 100644 (file)
index 96e36f4..0000000
+++ /dev/null
@@ -1,228 +0,0 @@
-/*
- * Copyright (c) 2013 IBM and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.samples.simpleforwarding.internal;
-
-import java.util.HashSet;
-import java.util.Set;
-import java.util.concurrent.locks.ReentrantReadWriteLock;
-
-import org.opendaylight.controller.sal.core.ConstructionException;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.packet.Ethernet;
-import org.opendaylight.controller.sal.packet.IDataPacketService;
-import org.opendaylight.controller.sal.packet.IListenDataPacket;
-import org.opendaylight.controller.sal.packet.Packet;
-import org.opendaylight.controller.sal.packet.PacketResult;
-import org.opendaylight.controller.sal.packet.RawPacket;
-import org.opendaylight.controller.sal.utils.EtherTypes;
-import org.opendaylight.controller.samples.simpleforwarding.IBroadcastHandler;
-import org.opendaylight.controller.samples.simpleforwarding.IBroadcastPortSelector;
-import org.opendaylight.controller.switchmanager.ISwitchManager;
-import org.opendaylight.controller.topologymanager.ITopologyManager;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * The simple broadcast handler simply sends broadcast packets out all ports
- * that are not known to belong to an internal, i.e., switch-switch, link. Note
- * that this is *not* safe in the general case when an OpenDaylight-controlled
- * network has L2 peering with normal a normal L2 network. It is entirely
- * possible for a packet to be flooded to a legacy/non-controlled switch and
- * then be reflected back into the OpenDaylight-controlled region resulting in a
- * loop.
- */
-public class SimpleBroadcastHandlerImpl implements IBroadcastHandler, IListenDataPacket {
-
-    private static Logger log = LoggerFactory.getLogger(SimpleBroadcastHandlerImpl.class);
-    protected IDataPacketService dataPacketService = null;
-    protected ITopologyManager topoManager = null;
-    protected ISwitchManager swMgr = null;
-    protected IBroadcastPortSelector bcastPorts = null;
-
-    protected ReentrantReadWriteLock lock = new ReentrantReadWriteLock();
-
-    BroadcastMode mode = BroadcastMode.DISABLED;
-
-    @Override
-    public PacketResult receiveDataPacket(RawPacket inPkt) {
-        /*
-         * note that this assumes that the protocol plugin will do appropriate
-         * filtering to ensure that this only receives packets for its
-         * container.
-         */
-
-        if (mode == BroadcastMode.DISABLED) {
-            return PacketResult.IGNORED;
-        }
-
-        Packet decodedPkt = this.dataPacketService.decodeDataPacket(inPkt);
-        if (decodedPkt instanceof Ethernet) {
-            Ethernet eth = (Ethernet) decodedPkt;
-
-            // TODO: should we offer an option to not handle ARP since the
-            // ARPHandler already does that
-
-            // ignore LLDP
-            if (eth.getEtherType() != EtherTypes.LLDP.shortValue()) {
-
-                if (eth.isBroadcast()) {
-                    broadcastPacket(inPkt);
-                } else if (eth.isMulticast()) {
-                    // TODO: for now just treat multicast as broadcast
-                    broadcastPacket(inPkt);
-                }
-            }
-        }
-
-        return PacketResult.KEEP_PROCESSING;
-    }
-
-    @Override
-    public boolean broadcastPacket(RawPacket pkt) {
-        Set<NodeConnector> toPacketOut = new HashSet<NodeConnector>();
-
-        // make sure that topoManager/datPacketService aren't pulled out from
-        // under us
-        lock.readLock().lock();
-        if (topoManager == null || dataPacketService == null
-            || swMgr == null) {
-            lock.readLock().unlock();
-            return false;
-        }
-
-        // find all non-internal NodeConnectors
-        switch (mode) {
-            case DISABLED:
-                // intentionally blank; don't send the packet anywhere
-                break;
-
-            case BROADCAST_TO_HOSTS:
-                toPacketOut.addAll(topoManager.getNodeConnectorWithHost());
-                break;
-
-            case BROADCAST_TO_NONINTERNAL:
-                for (Node n : swMgr.getNodes()) {
-                    // getUpNodeConnectors will filter out NodeConnectors of type "SW"
-                    for (NodeConnector nc : swMgr.getUpNodeConnectors(n)) {
-                        if (!topoManager.isInternal(nc)) {
-                            toPacketOut.add(nc);
-                        }
-                    }
-                }
-                break;
-
-            case EXTERNAL_QUERY:
-                if (bcastPorts != null) {
-                    toPacketOut.addAll(bcastPorts.getBroadcastPorts());
-                } else {
-                    log.error("Mode set to "
-                              + BroadcastMode.EXTERNAL_QUERY
-                              + ", but no external source of broadcast ports was provided.");
-                    lock.readLock().unlock();
-                    return false;
-                }
-                break;
-
-            default:
-                log.error("Mode " + mode + " is not supported.");
-                break;
-        }
-
-        // remove the NodeConnector it came in on
-        toPacketOut.remove(pkt.getIncomingNodeConnector());
-
-        // send it out all the node connectors
-        for (NodeConnector nc : toPacketOut) {
-            try {
-                RawPacket toSend = new RawPacket(pkt);
-                toSend.setOutgoingNodeConnector(nc);
-                dataPacketService.transmitDataPacket(toSend);
-            } catch (ConstructionException e) {
-                log.error("Could create packet: {}", e);
-            }
-        }
-
-        lock.readLock().unlock();
-
-        return true;
-    }
-
-    public void setDataPacketService(IDataPacketService s) {
-        // make sure dataPacketService doesn't change while we're in the middle
-        // of stuff
-        lock.writeLock().lock();
-        this.dataPacketService = s;
-        lock.writeLock().unlock();
-    }
-
-    public void unsetDataPacketService(IDataPacketService s) {
-        // make sure dataPacketService doesn't change while we're in the middle
-        // of stuff
-        lock.writeLock().lock();
-        if (this.dataPacketService == s) {
-            this.dataPacketService = null;
-        }
-        lock.writeLock().unlock();
-    }
-
-    public void setTopologyManager(ITopologyManager t) {
-        // make sure topoManager doesn't change while we're in the middle of
-        // stuff
-        lock.writeLock().lock();
-        this.topoManager = t;
-        lock.writeLock().unlock();
-    }
-
-    public void unsetTopologyManager(ITopologyManager t) {
-        // make sure topoManager doesn't change while we're in the middle of
-        // stuff
-        lock.writeLock().lock();
-        if (this.topoManager == t) {
-            this.topoManager = null;
-        }
-        lock.writeLock().unlock();
-    }
-
-    public void setSwitchManager(ISwitchManager i) {
-        lock.writeLock().lock();
-        this.swMgr = i;
-        lock.writeLock().unlock();
-    }
-
-    public void unsetSwitchManager(ISwitchManager i) {
-        lock.writeLock().lock();
-        if (this.swMgr == i) {
-            this.swMgr = null;
-        }
-        lock.writeLock().unlock();
-    }
-
-    public void setBroadcastPortSelector(IBroadcastPortSelector bps) {
-        lock.writeLock().lock();
-        bcastPorts = bps;
-        lock.writeLock().unlock();
-    }
-
-    public void unsetBroadcastPortSelector(IBroadcastPortSelector bps) {
-        lock.writeLock().lock();
-        if (bcastPorts == bps) {
-            this.bcastPorts = null;
-        }
-        lock.writeLock().unlock();
-    }
-
-    @Override
-    public void setMode(BroadcastMode m) {
-        lock.writeLock().lock();
-        mode = m;
-        lock.writeLock().unlock();
-    }
-
-}
diff --git a/opendaylight/adsal/samples/simpleforwarding/src/main/java/org/opendaylight/controller/samples/simpleforwarding/internal/SimpleForwardingImpl.java b/opendaylight/adsal/samples/simpleforwarding/src/main/java/org/opendaylight/controller/samples/simpleforwarding/internal/SimpleForwardingImpl.java
deleted file mode 100644 (file)
index a48d331..0000000
+++ /dev/null
@@ -1,1145 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.samples.simpleforwarding.internal;
-
-import java.net.InetAddress;
-import java.util.ArrayList;
-import java.util.EnumSet;
-import java.util.HashMap;
-import java.util.HashSet;
-import java.util.Iterator;
-import java.util.LinkedList;
-import java.util.List;
-import java.util.Map;
-import java.util.Set;
-import java.util.concurrent.ConcurrentHashMap;
-import java.util.concurrent.ConcurrentMap;
-import java.util.Timer;
-import java.util.TimerTask;
-
-import org.opendaylight.controller.clustering.services.CacheConfigException;
-import org.opendaylight.controller.clustering.services.CacheExistException;
-import org.opendaylight.controller.clustering.services.IClusterContainerServices;
-import org.opendaylight.controller.clustering.services.IClusterServices;
-import org.opendaylight.controller.forwardingrulesmanager.FlowEntry;
-import org.opendaylight.controller.forwardingrulesmanager.IForwardingRulesManager;
-import org.opendaylight.controller.hosttracker.IfIptoHost;
-import org.opendaylight.controller.hosttracker.IfNewHostNotify;
-import org.opendaylight.controller.hosttracker.hostAware.HostNodeConnector;
-import org.opendaylight.controller.sal.action.Action;
-import org.opendaylight.controller.sal.action.Output;
-import org.opendaylight.controller.sal.action.PopVlan;
-import org.opendaylight.controller.sal.action.SetDlDst;
-import org.opendaylight.controller.sal.action.SetVlanId;
-import org.opendaylight.controller.sal.core.Edge;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.NodeConnector.NodeConnectorIDType;
-import org.opendaylight.controller.sal.core.Path;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.core.State;
-import org.opendaylight.controller.sal.core.UpdateType;
-import org.opendaylight.controller.sal.flowprogrammer.Flow;
-import org.opendaylight.controller.sal.match.Match;
-import org.opendaylight.controller.sal.match.MatchType;
-import org.opendaylight.controller.sal.packet.Ethernet;
-import org.opendaylight.controller.sal.packet.IDataPacketService;
-import org.opendaylight.controller.sal.packet.IListenDataPacket;
-import org.opendaylight.controller.sal.packet.IPv4;
-import org.opendaylight.controller.sal.packet.Packet;
-import org.opendaylight.controller.sal.packet.PacketResult;
-import org.opendaylight.controller.sal.packet.RawPacket;
-import org.opendaylight.controller.sal.routing.IListenRoutingUpdates;
-import org.opendaylight.controller.sal.routing.IRouting;
-import org.opendaylight.controller.sal.utils.EtherTypes;
-import org.opendaylight.controller.sal.utils.NetUtils;
-import org.opendaylight.controller.sal.utils.NodeConnectorCreator;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.samples.simpleforwarding.HostNodePair;
-import org.opendaylight.controller.switchmanager.IInventoryListener;
-import org.opendaylight.controller.switchmanager.ISwitchManager;
-import org.opendaylight.controller.topologymanager.ITopologyManager;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * This class implements basic L3 forwarding within the managed devices.
- * Forwarding is only done within configured subnets.</br>
- * <br/>
- * The basic flow is that the module listens for new hosts from the
- * {@link org.opendaylight.controller.hosttracker.IfIptoHost HostTracker}
- * service and on discovering a new host it first calls
- * <tt>preparePerHostRules()</tt> to create a set of new rules that must be
- * installed in the network. This is done by repeatedly calling
- * <tt>updatePerHostRuleInSW()</tt> for each switch in the network. Then it
- * installs those rules using <tt>installPerHostRules()</tt>.
- */
-public class SimpleForwardingImpl implements IfNewHostNotify,
-        IListenRoutingUpdates, IInventoryListener, IListenDataPacket {
-    private static Logger log = LoggerFactory.getLogger(SimpleForwardingImpl.class);
-    private static short DEFAULT_IPSWITCH_PRIORITY = 1;
-    static final String FORWARDING_RULES_CACHE_NAME = "forwarding.ipswitch.rules";
-    private IfIptoHost hostTracker;
-    private IForwardingRulesManager frm;
-    private ITopologyManager topologyManager;
-    private IRouting routing;
-
-    /**
-     * The set of all forwarding rules: (host) -> (switch -> flowmod). Note that
-     * the host includes an attachment point and that while the switch appears
-     * to be a switch's port, in actuality it is a special port which just
-     * represents the switch.
-     */
-    private ConcurrentMap<HostNodePair, HashMap<NodeConnector, FlowEntry>> rulesDB;
-    private Map<Node, List<FlowEntry>> tobePrunedPos = new HashMap<Node, List<FlowEntry>>();
-    private IClusterContainerServices clusterContainerService = null;
-    private ISwitchManager switchManager;
-    private IDataPacketService dataPacketService;
-
-    /**
-     * Ip packets that are punted may not have their destination known by hostTracker at the time it
-     * is presented to SimpleForwardingImpl. Instead of dropping the packet, we will keep it around
-     * for a 'little' while, to accommodate any transients. See bug 590 for more details.
-     */
-    private class PendingPacketData {
-        private final static byte MAX_AGE = 2;
-
-        public final IPv4 pkt;
-        public final NodeConnector incomingNodeConnector;
-        private byte age;
-
-        public PendingPacketData(IPv4 pkt, NodeConnector incomingNodeConnector) {
-            this.pkt = pkt;
-            this.incomingNodeConnector = incomingNodeConnector;
-            this.age = 0;
-        }
-        boolean bumpAgeAndCheckIfTooOld() { return ++age > MAX_AGE; }
-    }
-    private static final int MAX_PENDING_PACKET_DESTINATIONS = 64;
-    private ConcurrentMap<InetAddress, PendingPacketData> pendingPacketDestinations;
-    private Timer pendingPacketsAgerTimer;
-
-    private class PendingPacketsAgerTimerHandler extends TimerTask {
-        @Override
-        public void run() {
-            if (pendingPacketDestinations == null) {
-                return;
-            }
-            try {
-                Iterator<ConcurrentMap.Entry<InetAddress, PendingPacketData>> iterator =
-                        pendingPacketDestinations.entrySet().iterator();
-                while (iterator.hasNext()) {
-                    ConcurrentHashMap.Entry<InetAddress, PendingPacketData> entry = iterator.next();
-                    InetAddress dIP = entry.getKey();
-                    PendingPacketData pendingPacketData = entry.getValue();
-
-                    if (pendingPacketData.bumpAgeAndCheckIfTooOld()) {
-                        iterator.remove(); // safe to remove while iterating...
-                        log.debug("Pending packet for {} has been aged out", dIP);
-                    } else {
-                        /** Replace the entry for a key only if currently mapped to some value.
-                         * This will protect the concurrent map against a race where this thread
-                         * would be re-adding an entry that just got taken out.
-                         */
-                        pendingPacketDestinations.replace(dIP, pendingPacketData);
-                    }
-                }
-            } catch (IllegalStateException e) {
-                log.warn("IllegalStateException Received by PendingPacketsAgerTimerHandler from: {}",
-                        e.getMessage());
-            }
-        }
-    }
-
-    /**
-     * Add punted packet to pendingPackets
-     */
-    private void addToPendingPackets(InetAddress dIP, IPv4 pkt, NodeConnector incomingNodeConnector) {
-        if (pendingPacketDestinations.size() >= MAX_PENDING_PACKET_DESTINATIONS) {
-            log.info("Will not pend packet for {}: Too many destinations", dIP);
-            return;
-        }
-
-        /** TODO: The current implementation allows for up to 1 pending packet per InetAddress.
-         * This limitation is done for sake of simplicity. A potential enhancement could be to use a
-         * ConcurrentMultiMap instead of ConcurrentMap.
-         */
-        if (pendingPacketDestinations.containsKey(dIP)) {
-            log.trace("Will not pend packet for {}: Already have a packet pending", dIP);
-            return;
-        }
-
-        PendingPacketData pendingPacketData = new PendingPacketData(pkt, incomingNodeConnector);
-        pendingPacketDestinations.put(dIP, pendingPacketData);
-        log.debug("Pending packet for {}", dIP);
-    }
-
-    /**
-     * Send punted packet to given destination. This is invoked when there is a certain level of
-     * hope that the destination is known by hostTracker.
-     */
-    private void sendPendingPacket(InetAddress dIP) {
-        PendingPacketData pendingPacketData = pendingPacketDestinations.get(dIP);
-        if (pendingPacketData != null) {
-            handlePuntedIPPacket(pendingPacketData.pkt, pendingPacketData.incomingNodeConnector, false);
-            log.trace("Packet for {} is no longer pending", dIP);
-            pendingPacketDestinations.remove(dIP);
-        }
-    }
-
-    /**
-     * Return codes from the programming of the perHost rules in HW
-     */
-    public enum RulesProgrammingReturnCode {
-        SUCCESS, FAILED_FEW_SWITCHES, FAILED_ALL_SWITCHES, FAILED_WRONG_PARAMS
-    }
-    public void setDataPacketService(IDataPacketService s) {
-        log.debug("Setting dataPacketService");
-        this.dataPacketService = s;
-    }
-
-    public void unsetDataPacketService(IDataPacketService s) {
-        if (this.dataPacketService == s) {
-            this.dataPacketService = null;
-        }
-    }
-
-    public void setRouting(IRouting routing) {
-        log.debug("Setting routing");
-        this.routing = routing;
-    }
-
-    public void unsetRouting(IRouting routing) {
-        if (this.routing == routing) {
-            this.routing = null;
-        }
-    }
-
-    public void setTopologyManager(ITopologyManager topologyManager) {
-        log.debug("Setting topologyManager");
-        this.topologyManager = topologyManager;
-    }
-
-    public void unsetTopologyManager(ITopologyManager topologyManager) {
-        if (this.topologyManager == topologyManager) {
-            this.topologyManager = null;
-        }
-    }
-
-    public void setHostTracker(IfIptoHost hostTracker) {
-        log.debug("Setting HostTracker");
-        this.hostTracker = hostTracker;
-    }
-
-    public void setForwardingRulesManager(
-            IForwardingRulesManager forwardingRulesManager) {
-        log.debug("Setting ForwardingRulesManager");
-        this.frm = forwardingRulesManager;
-    }
-
-    public void unsetHostTracker(IfIptoHost hostTracker) {
-        if (this.hostTracker == hostTracker) {
-            this.hostTracker = null;
-        }
-    }
-
-    public void unsetForwardingRulesManager(
-            IForwardingRulesManager forwardingRulesManager) {
-        if (this.frm == forwardingRulesManager) {
-            this.frm = null;
-        }
-    }
-
-    /**
-     * Function called when the bundle gets activated
-     *
-     */
-    public void startUp() {
-        allocateCaches();
-        retrieveCaches();
-        nonClusterObjectCreate();
-    }
-
-    public void nonClusterObjectCreate() {
-        pendingPacketDestinations = new ConcurrentHashMap<InetAddress, PendingPacketData>();
-
-        /* Pending Packets Ager Timer to go off every 6 seconds to implement pending packet aging */
-        pendingPacketsAgerTimer = new Timer();
-        pendingPacketsAgerTimer.schedule(new PendingPacketsAgerTimerHandler(), 6000, 6000);
-    }
-
-    /**
-     * Function called when the bundle gets stopped
-     *
-     */
-    public void shutDown() {
-        log.debug("Destroy all the host Rules given we are shutting down");
-        uninstallPerHostRules();
-        destroyCaches();
-    }
-
-    private void allocateCaches() {
-        if (this.clusterContainerService == null) {
-            log.trace("un-initialized clusterContainerService, can't create cache");
-            return;
-        }
-
-        try {
-            clusterContainerService.createCache(FORWARDING_RULES_CACHE_NAME,
-                    EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-        } catch (CacheExistException cee) {
-            log.error("\nCache already exists - destroy and recreate if needed");
-        } catch (CacheConfigException cce) {
-            log.error("\nCache configuration invalid - check cache mode");
-        }
-    }
-
-    @SuppressWarnings({ "unchecked" })
-    private void retrieveCaches() {
-        if (this.clusterContainerService == null) {
-            log.trace("un-initialized clusterContainerService, can't retrieve cache");
-            return;
-        }
-
-        rulesDB = (ConcurrentMap<HostNodePair, HashMap<NodeConnector, FlowEntry>>) clusterContainerService
-                .getCache(FORWARDING_RULES_CACHE_NAME);
-        if (rulesDB == null) {
-            log.error("\nFailed to get rulesDB handle");
-        }
-    }
-
-    private void destroyCaches() {
-        if (this.clusterContainerService == null) {
-            log.trace("un-initialized clusterContainerService, can't destroy cache");
-            return;
-        }
-
-        clusterContainerService.destroyCache(FORWARDING_RULES_CACHE_NAME);
-    }
-
-    /**
-     * Populates <tt>rulesDB</tt> with rules specifying how to reach
-     * <tt>host</tt> from <tt>currNode</tt> assuming that:
-     * <ul>
-     * <li><tt>host</tt> is attached to <tt>rootNode</tt>
-     * <li><tt>link</tt> is the next part of the path to reach <tt>rootNode</tt>
-     * from <tt>currNode</tt>
-     * <li><tt>rulesDB.get(key)</tt> represents the list of rules stored about
-     * <tt>host</tt> at <tt>currNode</tt>
-     * </ul>
-     *
-     * @param host
-     *            The host to be reached.
-     * @param currNode
-     *            The current node being processed.
-     * @param rootNode
-     *            The node to be reached. Really, the switch which host is
-     *            attached to.
-     * @param link
-     *            The link to follow from curNode to get to rootNode
-     * @param key
-     *            The key to store computed rules at in the rulesDB. For now,
-     *            this is a {@link HostNodePair} of host and currNode.
-     */
-    private void updatePerHostRuleInSW(HostNodeConnector host, Node currNode,
-            Node rootNode, Edge link, HostNodePair key) {
-
-        // only the link parameter is optional
-        if (host == null || key == null || currNode == null || rootNode == null) {
-            return;
-        }
-
-        Set<NodeConnector> ports = new HashSet<NodeConnector>();
-        // add a special port of type ALL and port 0 to represent the node
-        // without specifying a port on that node
-        ports.add(NodeConnectorCreator.createNodeConnector(
-                NodeConnectorIDType.ALL, NodeConnector.SPECIALNODECONNECTORID,
-                currNode));
-
-        HashMap<NodeConnector, FlowEntry> pos = this.rulesDB.get(key);
-        if (pos == null) {
-            pos = new HashMap<NodeConnector, FlowEntry>();
-        }
-
-        for (NodeConnector inPort : ports) {
-            // skip the port connected to the target host
-            if (currNode.equals(rootNode)
-                    && (host.getnodeConnector().equals(inPort))) {
-                continue;
-            }
-
-            // remove the current rule, if any
-            FlowEntry removed_po = pos.remove(inPort);
-            Match match = new Match();
-            List<Action> actions = new ArrayList<Action>();
-
-            // IP destination based forwarding on /32 entries only!
-            match.setField(MatchType.DL_TYPE, EtherTypes.IPv4.shortValue());
-            match.setField(MatchType.NW_DST, host.getNetworkAddress());
-
-            /* Action for the policy is to forward to a port except on the
-             * switch where the host sits, which is to rewrite also the MAC
-             * and to forward on the Host port */
-            NodeConnector outPort = null;
-
-            if (currNode.equals(rootNode)) {
-                /* If we're at the root node, then rewrite the DL addr and
-                 * possibly pop the VLAN tag. This allows for MAC rewriting
-                 * in the core of the network assuming we can uniquely ID
-                 * packets based on IP address. */
-
-                outPort = host.getnodeConnector();
-                if (inPort.equals(outPort)) {
-                    // TODO: isn't this code skipped already by the above continue?
-                    // skip the host port
-                    continue;
-                }
-                actions.add(new SetDlDst(host.getDataLayerAddressBytes()));
-
-                if (!inPort.getType().equals(NodeConnectorIDType.ALL)) {
-                    // Container mode: at the destination switch, we need to strip out the tag (VLAN)
-                    actions.add(new PopVlan());
-                }
-            } else {
-                // currNode is NOT the rootNode, find the next hop and create a rule
-                if (link != null) {
-                    outPort = link.getTailNodeConnector();
-                    if (inPort.equals(outPort)) {
-                        // skip the outgoing port
-                        continue;
-                    }
-
-                    // If outPort is network link, add VLAN tag
-                    if (topologyManager.isInternal(outPort)) {
-                        log.debug("outPort {}/{} is internal uplink port",
-                                currNode, outPort);
-                    } else {
-                        log.debug("outPort {}/{} is host facing port",
-                                currNode, outPort);
-                    }
-
-                    if ((!inPort.getType().equals(NodeConnectorIDType.ALL))
-                        && (topologyManager.isInternal(outPort))) {
-                        Node nextNode = link.getHeadNodeConnector()
-                                            .getNode();
-                        // TODO: Replace this with SAL equivalent
-                        //short tag = container.getTag((Long)nextNode.getNodeID());
-                        short tag = 0;
-                        if (tag != 0) {
-                            log.debug("adding SET_VLAN {} for traffic " +
-                                    "leaving {}/{} toward switch {}",
-                                    new Object[] { tag, currNode, outPort,
-                                    nextNode});
-                            actions.add(new SetVlanId(tag));
-                        } else {
-                            log.debug("No tag assigned to switch {}", nextNode);
-                        }
-                    }
-                }
-            }
-            if (outPort != null) {
-                actions.add(new Output(outPort));
-            }
-            if (!inPort.getType().equals(NodeConnectorIDType.ALL)) {
-                // include input port in the flow match field
-                match.setField(MatchType.IN_PORT, inPort);
-
-                if (topologyManager.isInternal(inPort)) {
-                    log.debug("inPort {}/{} is internal uplink port", currNode,
-                            inPort);
-                } else {
-                    log.debug("inPort {}/{} is host facing port", currNode,
-                            inPort);
-                }
-
-                // for incoming network link; if the VLAN tag is defined, include it for incoming flow matching
-                if (topologyManager.isInternal(inPort)) {
-                    // TODO: Replace this with SAL equivalent
-                    //short tag = container.getTag((Long)currNode.getNodeID());
-                    short tag = 0;
-                    if (tag != 0) {
-                        log.debug("adding MATCH VLAN {} for traffic entering" +
-                                "  {}/{}",
-                                new Object[] {tag, currNode, inPort});
-                        match.setField(MatchType.DL_VLAN, tag);
-                    } else {
-                        log.debug("No tag assigned to switch {}", currNode);
-                    }
-                }
-            }
-            // Make sure the priority for IP switch entries is
-            // set to a level just above default drop entries
-            Flow flow = new Flow(match, actions);
-            flow.setIdleTimeout((short) 0);
-            flow.setHardTimeout((short) 0);
-            flow.setPriority(DEFAULT_IPSWITCH_PRIORITY);
-
-            String policyName = host.getNetworkAddress().getHostAddress()
-                    + "/32";
-            String flowName = "["
-                    + (!inPort.getType().equals(NodeConnectorIDType.ALL) ?
-                       (inPort.getID()).toString()
-                       + "," : "")
-                    + host.getNetworkAddress().getHostAddress() + "/32 on N "
-                    + currNode + "]";
-            FlowEntry po = new FlowEntry(policyName, flowName, flow, currNode);
-
-            /* Now save the rule in the DB rule, so on updates from topology we
-             * can selectively */
-            pos.put(inPort, po);
-            this.rulesDB.put(key, pos);
-            if (!inPort.getType().equals(NodeConnectorIDType.ALL)) {
-                log.debug("Adding Match(inPort = {} , DIP = {})" +
-                        " Action(outPort= {}) to node {}",
-                        new Object[] { inPort,
-                        host.getNetworkAddress().getHostAddress(),
-                        outPort, currNode});
-                if ((removed_po != null)
-                        && (!po.getFlow().getMatch().equals(
-                                removed_po.getFlow().getMatch()))) {
-                    log.debug("Old Flow match: {}, New Flow match: {}",
-                            removed_po.getFlow().getMatch(), po.getFlow()
-                                    .getMatch());
-                    addTobePrunedPolicy(currNode, removed_po, po);
-                }
-
-            } else {
-                log.debug("Adding policyMatch(DIP = {}) Action(outPort= {}) " +
-                        "to node {}", new Object[] {
-                        host.getNetworkAddress().getHostAddress(), outPort,
-                        currNode});
-            }
-        }
-    }
-
-    /**
-     * Calculate the per-Host rules to be installed in the rulesDB,
-     * and that will later on be installed in HW, this routine will
-     * implicitly calculate the shortest path tree among the switch
-     * to which the host is attached and all the other switches in the
-     * network and will automatically create all the rules that allow
-     * a /32 destination IP based forwarding, as in traditional IP
-     * networks.
-     *
-     * @param host Host for which we are going to prepare the rules in the rulesDB
-     *
-     * @return A set of switches touched by the calculation
-     */
-    private Set<Node> preparePerHostRules(HostNodeConnector host) {
-        if (host == null) {
-            return null;
-        }
-
-        //TODO: race condition! unset* functions can make these null.
-        if (this.routing == null) {
-            return null;
-        }
-        if (this.switchManager == null) {
-            return null;
-        }
-        if (this.rulesDB == null) {
-            return null;
-        }
-
-        Node rootNode = host.getnodeconnectorNode();
-        Set<Node> nodes = this.switchManager.getNodes();
-        Set<Node> switchesToProgram = new HashSet<Node>();
-        HostNodePair key;
-        HashMap<NodeConnector, FlowEntry> pos;
-        FlowEntry po;
-
-        // for all nodes in the system
-        for (Node node : nodes) {
-            if (node.equals(rootNode)) {
-                // We skip it because for the node with host attached
-                // we will process in every case even if there are no
-                // routes
-                continue;
-            }
-            List<Edge> links;
-            Path res = this.routing.getRoute(node, rootNode);
-            if ((res == null) || ((links = res.getEdges()) == null)) {
-                // No route from node to rootNode can be found, back out any
-                // existing forwarding rules if they exist.
-                log.debug("NO Route/Path between SW[{}] --> SW[{}] cleaning " +
-                        "potentially existing entries", node, rootNode);
-                key = new HostNodePair(host, node);
-                pos = this.rulesDB.get(key);
-                if (pos != null) {
-                    for (Map.Entry<NodeConnector, FlowEntry> e : pos.entrySet()) {
-                        po = e.getValue();
-                        if (po != null) {
-                            // uninstall any existing rules we put in the
-                            // ForwardingRulesManager
-                            this.frm.uninstallFlowEntry(po);
-                        }
-                    }
-                    this.rulesDB.remove(key);
-                }
-                continue;
-            }
-
-            log.debug("Route between SW[{}] --> SW[{}]", node, rootNode);
-            Node currNode = node;
-            key = new HostNodePair(host, currNode);
-
-            // for each link in the route from here to there
-            for (Edge link : links) {
-                if (link == null) {
-                    log.error("Could not retrieve the Link");
-                    // TODO: should we keep going?
-                    continue;
-                }
-
-                log.debug(link.toString());
-
-                // Index all the switches to be programmed
-                updatePerHostRuleInSW(host, currNode, rootNode, link, key);
-                if ((this.rulesDB.get(key)) != null) {
-                    /* Calling updatePerHostRuleInSW() doesn't guarantee that
-                     * rules will be added in currNode (e.g, there is only one
-                     * link from currNode to rootNode This check makes sure that
-                     * there are some rules in the rulesDB for the given key
-                     * prior to adding switch to switchesToProgram
-                     */
-                    switchesToProgram.add(currNode);
-                }
-                currNode = link.getHeadNodeConnector().getNode();
-                key = new HostNodePair(host, currNode);
-            }
-        }
-
-        // This rule will be added no matter if any topology is built
-        // or no, it serve as a way to handle the case of a node with
-        // multiple hosts attached to it but not yet connected to the
-        // rest of the world
-        switchesToProgram.add(rootNode);
-        updatePerHostRuleInSW(host, rootNode, rootNode, null,
-                              new HostNodePair(host, rootNode));
-
-        //      log.debug("Getting out at the end!");
-        return switchesToProgram;
-    }
-
-    /**
-     * Calculate the per-Host rules to be installed in the rulesDB
-     * from a specific switch when a host facing port comes up.
-     * These rules will later on be installed in HW. This routine
-     * will implicitly calculate the shortest path from the switch
-     * where the port has come up to the switch where host is ,
-     * attached and will automatically create all the rules that allow
-     * a /32 destination IP based forwarding, as in traditional IP
-     * networks.
-     *
-     * @param host Host for which we are going to prepare the rules in the rulesDB
-     * @param swId Switch ID where the port has come up
-     *
-     * @return A set of switches touched by the calculation
-     */
-    private Set<Node> preparePerHostPerSwitchRules(HostNodeConnector host,
-            Node node, NodeConnector swport) {
-        if ((host == null) || (node == null)) {
-            return null;
-        }
-        if (this.routing == null) {
-            return null;
-        }
-        if (this.switchManager == null) {
-            return null;
-        }
-        if (this.rulesDB == null) {
-            return null;
-        }
-
-        Node rootNode = host.getnodeconnectorNode();
-        Set<Node> switchesToProgram = new HashSet<Node>();
-        HostNodePair key;
-        Map<NodeConnector, FlowEntry> pos;
-        FlowEntry po;
-        List<Edge> links;
-
-        Path res = this.routing.getRoute(node, rootNode);
-        if ((res == null) || ((links = res.getEdges()) == null)) {
-            // the routing service doesn't know how to get there from here
-            log.debug("NO Route/Path between SW[{}] --> SW[{}] cleaning " +
-                    "potentially existing entries", node, rootNode);
-            key = new HostNodePair(host, node);
-            pos = this.rulesDB.get(key);
-            if (pos != null) {
-                for (Map.Entry<NodeConnector, FlowEntry> e : pos.entrySet()) {
-                    po = e.getValue();
-                    if (po != null) {
-                        //Uninstall the policy
-                        this.frm.uninstallFlowEntry(po);
-                    }
-                }
-                this.rulesDB.remove(key);
-            }
-            return null;
-        }
-
-        log.debug("Route between SW[{}] --> SW[{}]", node, rootNode);
-        Integer curr;
-        Node currNode = node;
-        key = new HostNodePair(host, currNode);
-        Edge link;
-        for (curr = 0; curr < links.size(); curr++) {
-            link = links.get(curr);
-            if (link == null) {
-                log.error("Could not retrieve the Link");
-                continue;
-            }
-
-            log.debug("Link [{}/{}] --> [{}/{}]", new Object[] {
-                    currNode, link.getHeadNodeConnector(),
-                    link.getHeadNodeConnector().getNode(),
-                    link.getTailNodeConnector()});
-
-            // Index all the switches to be programmed
-            switchesToProgram.add(currNode);
-            updatePerHostRuleInSW(host, currNode, rootNode, link, key);
-            break; // come out of the loop for port up case, interested only in programming one switch
-        }
-
-        // This rule will be added no matter if any topology is built
-        // or no, it serve as a way to handle the case of a node with
-        // multiple hosts attached to it but not yet connected to the
-        // rest of the world
-        // switchesToProgram.add(rootNode);
-        //updatePerHostRuleInSW(host, rootNode,
-        //                                        rootNode, null,
-        //                                        new HostNodePair(host, rootNode),ports);
-
-        //      log.debug("Getting out at the end!");
-        return switchesToProgram;
-    }
-
-    /**
-     * Routine that fetch the per-Host rules from the rulesDB and
-     * install in HW, the one having the same match rules will be
-     * overwritten silently.
-     *
-     * @param host host for which we want to install in HW the per-Host rules
-     * @param switchesToProgram list of switches to be programmed in
-     * HW, usually are them all, but better to be explicit, that list
-     * may change with time based on new switch addition/removal
-     *
-     * @return a return code that convey the programming status of the HW
-     */
-    private RulesProgrammingReturnCode installPerHostRules(
-            HostNodeConnector host, Set<Node> switchesToProgram) {
-        RulesProgrammingReturnCode retCode = RulesProgrammingReturnCode.SUCCESS;
-        if (host == null || switchesToProgram == null) {
-            return RulesProgrammingReturnCode.FAILED_WRONG_PARAMS;
-        }
-        Map<NodeConnector, FlowEntry> pos;
-        FlowEntry po;
-        // Now program every single switch
-        log.debug("Inside installPerHostRules");
-        for (Node swId : switchesToProgram) {
-            HostNodePair key = new HostNodePair(host, swId);
-            pos = this.rulesDB.get(key);
-            if (pos == null) {
-                continue;
-            }
-            for (Map.Entry<NodeConnector, FlowEntry> e : pos.entrySet()) {
-                po = e.getValue();
-                if (po != null) {
-                    // Populate the Policy field now
-                    Status poStatus = this.frm.modifyOrAddFlowEntry(po);
-                    if (!poStatus.isSuccess()) {
-                        log.error("Failed to install policy: "
-                                + po.getGroupName() + " ("
-                                + poStatus.getDescription() + ")");
-
-                        retCode = RulesProgrammingReturnCode.FAILED_FEW_SWITCHES;
-                        // Remove the entry from the DB, it was not installed!
-                        this.rulesDB.remove(key);
-                    } else {
-                        log.debug("Successfully installed policy "
-                                + po.toString() + " on switch " + swId);
-                    }
-                } else {
-                    log.error("Cannot find a policy for SW:({}) Host: ({})",
-                              swId, host);
-                    /* // Now dump every single rule */
-                    /* for (HostNodePair dumpkey : this.rulesDB.keySet()) { */
-                    /*  po = this.rulesDB.get(dumpkey); */
-                    /*  log.debug("Dumping entry H{" + dumpkey.getHost() + "} S{" + dumpkey.getSwitchId() + "} = {" + (po == null ? "null policy" : po)); */
-                    /* } */
-                }
-            }
-        }
-        log.debug("Leaving installPerHostRules");
-        return retCode;
-    }
-
-    /**
-     * Cleanup all the host rules for a given host
-     *
-     * @param host Host for which the host rules need to be cleaned
-     * up, the host could be null in that case it match all the hosts
-     *
-     * @return a return code that convey the programming status of the HW
-     */
-    private RulesProgrammingReturnCode uninstallPerHostRules(HostNodeConnector host) {
-        RulesProgrammingReturnCode retCode = RulesProgrammingReturnCode.SUCCESS;
-        Map<NodeConnector, FlowEntry> pos;
-        FlowEntry po;
-        // Now program every single switch
-        for (HostNodePair key : this.rulesDB.keySet()) {
-            if (host == null || key.getHost().equals(host)) {
-                pos = this.rulesDB.get(key);
-                for (Map.Entry<NodeConnector, FlowEntry> e : pos.entrySet()) {
-                    po = e.getValue();
-                    if (po != null) {
-                        // Uninstall the policy
-                        this.frm.uninstallFlowEntry(po);
-                    }
-                }
-                this.rulesDB.remove(key);
-            }
-        }
-        return retCode;
-    }
-
-    /**
-     * Cleanup all the host rules for a given node, triggered when the
-     * switch disconnects, so there is no reason for Hw cleanup
-     * because it's disconnected anyhow
-     * TBD - Revisit above stmt in light of CSCus88743
-     * @param targetNode Node for which we want to do cleanup
-     *
-     */
-    private void uninstallPerNodeRules(Node targetNode) {
-        //RulesProgrammingReturnCode retCode = RulesProgrammingReturnCode.SUCCESS;
-        Map<NodeConnector, FlowEntry> pos;
-        FlowEntry po;
-
-        // Now program every single switch
-        for (HostNodePair key : this.rulesDB.keySet()) {
-            Node node = key.getNode();
-            if (targetNode == null || node.equals(targetNode)) {
-                log.debug("Work on {} host {}", node, key.getHost());
-                pos = this.rulesDB.get(key);
-                for (Map.Entry<NodeConnector, FlowEntry> e : pos.entrySet()) {
-                    po = e.getValue();
-                    if (po != null) {
-                        // Uninstall the policy
-                        this.frm.uninstallFlowEntry(po);
-                    }
-                }
-                log.debug("Remove {}", key);
-                this.rulesDB.remove(key);
-            }
-        }
-    }
-
-    /**
-     * Cleanup all the host rules currently present in the rulesDB
-     *
-     * @return a return code that convey the programming status of the HW
-     */
-    private RulesProgrammingReturnCode uninstallPerHostRules() {
-        return uninstallPerHostRules(null);
-    }
-
-    @Override
-    public void recalculateDone() {
-        if (this.hostTracker == null) {
-            //Not yet ready to process all the updates
-            //TODO: we should make sure that this call is executed eventually
-            return;
-        }
-        Set<HostNodeConnector> allHosts = this.hostTracker.getAllHosts();
-        for (HostNodeConnector host : allHosts) {
-            Set<Node> switches = preparePerHostRules(host);
-            if (switches != null) {
-                // This will refresh existing rules, by overwriting
-                // the previous ones
-                installPerHostRules(host, switches);
-                pruneExcessRules(switches);
-            }
-        }
-    }
-
-    void addTobePrunedPolicy(Node swId, FlowEntry po, FlowEntry new_po) {
-        List<FlowEntry> pl = tobePrunedPos.get(swId);
-        if (pl == null) {
-            pl = new LinkedList<FlowEntry>();
-            tobePrunedPos.put(swId, pl);
-        }
-        pl.add(po);
-        log.debug("Adding Pruned Policy for SwId: {}", swId);
-        log.debug("Old Policy: {}", po);
-        log.debug("New Policy: {}", new_po);
-    }
-
-    private void pruneExcessRules(Set<Node> switches) {
-        for (Node swId : switches) {
-            List<FlowEntry> pl = tobePrunedPos.get(swId);
-            if (pl != null) {
-                log.debug("Policies for Switch: {} in the list to be deleted: {}", swId, pl);
-                Iterator<FlowEntry> plIter = pl.iterator();
-                //for (Policy po: pl) {
-                while (plIter.hasNext()) {
-                    FlowEntry po = plIter.next();
-                    log.error("Removing Policy, Switch: {} Policy: {}", swId, po);
-                    this.frm.uninstallFlowEntry(po);
-                    plIter.remove();
-                }
-            }
-            // tobePrunedPos.remove(swId);
-        }
-    }
-
-    /**
-     * A Host facing port has come up in a container. Add rules on the switch where this
-     * port has come up for all the known hosts to the controller.
-     * @param swId switch id of the port where port came up
-     * @param swPort port which came up
-     */
-    private void updateRulesforHIFup(Node node, NodeConnector swPort) {
-        if (this.hostTracker == null) {
-            //Not yet ready to process all the updates
-            return;
-        }
-        log.debug("Host Facing Port in a container came up, install the rules for all hosts from this port !");
-        Set<HostNodeConnector> allHosts = this.hostTracker.getAllHosts();
-        for (HostNodeConnector host : allHosts) {
-            if (node.equals(host.getnodeconnectorNode())) {
-                /*
-                 * This host resides behind the same switch and port for which a port up
-                 * message is received. Ideally this should not happen, but if it does,
-                 * don't program any rules for this host
-                 */
-                continue;
-            }
-            Set<Node> switches = preparePerHostPerSwitchRules(host, node,
-                    swPort);
-            if (switches != null) {
-                // This will refresh existing rules, by overwriting
-                // the previous ones
-                installPerHostRules(host, switches);
-            }
-        }
-
-    }
-
-    @Override
-    public void notifyHTClient(HostNodeConnector host) {
-        if (host == null) {
-            return;
-        }
-        Set<Node> switches = preparePerHostRules(host);
-        if (switches != null) {
-            installPerHostRules(host, switches);
-
-            // Green light for sending pending packet to this host. Safe to call if there are none.
-            sendPendingPacket(host.getNetworkAddress());
-        }
-    }
-
-    @Override
-    public void notifyHTClientHostRemoved(HostNodeConnector host) {
-        if (host == null) {
-            return;
-        }
-        uninstallPerHostRules(host);
-    }
-
-    @Override
-    public void notifyNode(Node node, UpdateType type,
-            Map<String, Property> propMap) {
-        if (node == null) {
-            return;
-        }
-
-        switch (type) {
-        case REMOVED:
-            log.debug("Node {} gone, doing a cleanup", node);
-            uninstallPerNodeRules(node);
-            break;
-        default:
-            break;
-        }
-    }
-
-    @Override
-    public void notifyNodeConnector(NodeConnector nodeConnector,
-            UpdateType type, Map<String, Property> propMap) {
-        if (nodeConnector == null) {
-            return;
-        }
-
-        boolean up = false;
-        switch (type) {
-        case ADDED:
-            up = true;
-            break;
-        case REMOVED:
-            break;
-        case CHANGED:
-            State state = (State) propMap.get(State.StatePropName);
-            if ((state != null) && (state.getValue() == State.EDGE_UP)) {
-                up = true;
-            }
-            break;
-        default:
-            return;
-        }
-
-        if (up) {
-            handleNodeConnectorStatusUp(nodeConnector);
-        } else {
-            handleNodeConnectorStatusDown(nodeConnector);
-        }
-    }
-
-    private void handleNodeConnectorStatusUp(NodeConnector nodeConnector) {
-        if (topologyManager == null) {
-            log.debug("topologyManager is not set yet");
-            return;
-        }
-
-        if (topologyManager.isInternal(nodeConnector)) {
-            log.debug("{} is not a host facing link", nodeConnector);
-            return;
-        }
-
-        log.debug("{} is up", nodeConnector);
-        updateRulesforHIFup(nodeConnector.getNode(), nodeConnector);
-    }
-
-    private void handleNodeConnectorStatusDown(NodeConnector nodeConnector) {
-        log.debug("{} is down", nodeConnector);
-    }
-
-    void setClusterContainerService(IClusterContainerServices s) {
-        log.debug("Cluster Service set");
-        this.clusterContainerService = s;
-    }
-
-    void unsetClusterContainerService(IClusterContainerServices s) {
-        if (this.clusterContainerService == s) {
-            log.debug("Cluster Service removed!");
-            this.clusterContainerService = null;
-        }
-    }
-
-    /**
-     * Function called by the dependency manager when all the required
-     * dependencies are satisfied
-     *
-     */
-    void init() {
-        startUp();
-    }
-
-    /**
-     * Function called by the dependency manager when at least one
-     * dependency become unsatisfied or when the component is shutting
-     * down because for example bundle is being stopped.
-     *
-     */
-    void destroy() {
-    }
-
-    /**
-     * Function called by dependency manager after "init ()" is called
-     * and after the services provided by the class are registered in
-     * the service registry
-     *
-     */
-    void start() {
-    }
-
-    /**
-     * Function called by the dependency manager before the services
-     * exported by the component are unregistered, this will be
-     * followed by a "destroy ()" calls
-     *
-     */
-    void stop() {
-        pendingPacketsAgerTimer.cancel();
-        pendingPacketDestinations.clear();
-    }
-
-    public void setSwitchManager(ISwitchManager switchManager) {
-        this.switchManager = switchManager;
-    }
-
-    public void unsetSwitchManager(ISwitchManager switchManager) {
-        if (this.switchManager == switchManager) {
-            this.switchManager = null;
-        }
-    }
-
-    @Override
-    public PacketResult receiveDataPacket(RawPacket inPkt) {
-        if (inPkt == null) {
-            return PacketResult.IGNORED;
-        }
-        log.trace("Received a frame of size: {}", inPkt.getPacketData().length);
-        Packet formattedPak = this.dataPacketService.decodeDataPacket(inPkt);
-        if (formattedPak instanceof Ethernet) {
-            Object nextPak = formattedPak.getPayload();
-            if (nextPak instanceof IPv4) {
-                log.trace("Handle punted IP packet: {}", formattedPak);
-                handlePuntedIPPacket((IPv4) nextPak, inPkt.getIncomingNodeConnector(), true);
-            }
-        }
-        return PacketResult.IGNORED;
-
-    }
-
-    private void handlePuntedIPPacket(IPv4 pkt, NodeConnector incomingNodeConnector, boolean allowAddPending) {
-        InetAddress dIP = NetUtils.getInetAddress(pkt.getDestinationAddress());
-        if (dIP == null || hostTracker == null) {
-            log.debug("Invalid param(s) in handlePuntedIPPacket.. DestIP: {}. hostTracker: {}", dIP, hostTracker);
-            return;
-        }
-        HostNodeConnector destHost = hostTracker.hostFind(dIP);
-        /*
-         * In cases when incoming and outgoing connectors are in the same node, there is no need
-         * to verify that there is a route. Because of that, we will only need routing.getRoute()
-         * if we know that src and dst nodes are different.
-         */
-        if (destHost != null
-                && (incomingNodeConnector.getNode().equals(destHost.getnodeconnectorNode()) ||
-                    routing == null ||
-                    routing.getRoute(incomingNodeConnector.getNode(), destHost.getnodeconnectorNode()) != null)) {
-
-            log.trace("Host {} is at {}", dIP, destHost.getnodeConnector());
-
-            // If SimpleForwarding is aware of this host, it will try to install
-            // a path. Forward packet until it's done.
-            if (dataPacketService != null) {
-
-                /*
-                 * if we know where the host is and there's a path from where this
-                 * packet was punted to where the host is, then attempt best effort delivery to the host
-                 */
-                NodeConnector nc = destHost.getnodeConnector();
-                log.trace("Forwarding punted IP received at {} to {}", incomingNodeConnector, nc);
-                // re-encode the Ethernet packet (the parent of the IPv4 packet)
-                RawPacket rp = this.dataPacketService.encodeDataPacket(pkt.getParent());
-                rp.setOutgoingNodeConnector(nc);
-                this.dataPacketService.transmitDataPacket(rp);
-            }
-        } else if (allowAddPending) {
-            // If we made it here, let's hang on to the punted packet, with hopes that its destination
-            // will become available soon.
-            addToPendingPackets(dIP, pkt, incomingNodeConnector);
-        } else {
-            log.warn("Dropping punted IP packet received at {} to Host {}", incomingNodeConnector, dIP);
-        }
-    }
-}
diff --git a/opendaylight/adsal/samples/simpleforwarding/src/test/java/org/opendaylight/controller/samples/simpleforwarding/internal/HostSwitchTest.java b/opendaylight/adsal/samples/simpleforwarding/src/test/java/org/opendaylight/controller/samples/simpleforwarding/internal/HostSwitchTest.java
deleted file mode 100644 (file)
index 6627029..0000000
+++ /dev/null
@@ -1,380 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.samples.simpleforwarding.internal;
-
-import java.net.InetAddress;
-import java.net.UnknownHostException;
-import java.util.HashMap;
-import org.junit.Test;
-import org.junit.Assert;
-
-import org.opendaylight.controller.hosttracker.hostAware.HostNodeConnector;
-import org.opendaylight.controller.sal.core.ConstructionException;
-import org.opendaylight.controller.sal.utils.NodeCreator;
-import org.opendaylight.controller.samples.simpleforwarding.HostNodePair;
-
-
-public class HostSwitchTest {
-    @Test
-    public void TestEquality() {
-        HostNodeConnector h1 = null;
-        HostNodeConnector h2 = null;
-
-        InetAddress ip1 = null;
-        try {
-            ip1 = InetAddress.getByName("10.0.0.1");
-        } catch (UnknownHostException e) {
-            return;
-        }
-        InetAddress ip2 = null;
-        try {
-            ip2 = InetAddress.getByName("10.0.0.1");
-        } catch (UnknownHostException e) {
-            return;
-        }
-        try {
-            h1 = new HostNodeConnector(ip1);
-        } catch (ConstructionException e) {
-            return;
-        }
-        try {
-            h2 = new HostNodeConnector(ip2);
-        } catch (ConstructionException e) {
-            return;
-        }
-        HostNodePair hsw1 = new HostNodePair(h1, NodeCreator.createOFNode(1L));
-        HostNodePair hsw2 = new HostNodePair(h2, NodeCreator.createOFNode(1L));
-        Assert.assertTrue(hsw1.equals(hsw2));
-    }
-
-    @Test
-    public void TestDiversityHost() {
-        HostNodeConnector h1 = null;
-        HostNodeConnector h2 = null;
-        InetAddress ip1 = null;
-        try {
-            ip1 = InetAddress.getByName("10.0.0.1");
-        } catch (UnknownHostException e) {
-            return;
-        }
-        InetAddress ip2 = null;
-        try {
-            ip2 = InetAddress.getByName("10.0.0.2");
-        } catch (UnknownHostException e) {
-            return;
-        }
-        try {
-            h1 = new HostNodeConnector(ip1);
-        } catch (ConstructionException e) {
-            return;
-        }
-        try {
-            h2 = new HostNodeConnector(ip2);
-        } catch (ConstructionException e) {
-            return;
-        }
-
-        HostNodePair hsw1 = new HostNodePair(h1, NodeCreator.createOFNode(1L));
-        HostNodePair hsw2 = new HostNodePair(h2, NodeCreator.createOFNode(1L));
-        Assert.assertTrue(!hsw1.equals(hsw2));
-    }
-
-    @Test
-    public void TestDiversitySwitch() {
-        HostNodeConnector h1 = null;
-        HostNodeConnector h2 = null;
-        InetAddress ip1 = null;
-        try {
-            ip1 = InetAddress.getByName("10.0.0.1");
-        } catch (UnknownHostException e) {
-            return;
-        }
-        InetAddress ip2 = null;
-        try {
-            ip2 = InetAddress.getByName("10.0.0.1");
-        } catch (UnknownHostException e) {
-            return;
-        }
-        try {
-            h1 = new HostNodeConnector(ip1);
-        } catch (ConstructionException e) {
-            return;
-        }
-        try {
-            h2 = new HostNodeConnector(ip2);
-        } catch (ConstructionException e) {
-            return;
-        }
-
-        HostNodePair hsw1 = new HostNodePair(h1, NodeCreator.createOFNode(1L));
-        HostNodePair hsw2 = new HostNodePair(h2, NodeCreator.createOFNode(2L));
-        Assert.assertTrue(!hsw1.equals(hsw2));
-    }
-
-    @Test
-    public void TestDiversityAll() {
-        HostNodeConnector h1 = null;
-        HostNodeConnector h2 = null;
-        InetAddress ip1 = null;
-        try {
-            ip1 = InetAddress.getByName("10.0.0.1");
-        } catch (UnknownHostException e) {
-            return;
-        }
-        InetAddress ip2 = null;
-        try {
-            ip2 = InetAddress.getByName("10.0.0.2");
-        } catch (UnknownHostException e) {
-            return;
-        }
-        try {
-            h1 = new HostNodeConnector(ip1);
-        } catch (ConstructionException e) {
-            return;
-        }
-        try {
-            h2 = new HostNodeConnector(ip2);
-        } catch (ConstructionException e) {
-            return;
-        }
-
-        HostNodePair hsw1 = new HostNodePair(h1, NodeCreator.createOFNode(1L));
-        HostNodePair hsw2 = new HostNodePair(h2, NodeCreator.createOFNode(2L));
-        Assert.assertTrue(!hsw1.equals(hsw2));
-    }
-
-    @Test
-    public void TestEqualHashCode1() {
-        HostNodeConnector h1 = null;
-        HostNodeConnector h2 = null;
-        InetAddress ip1 = null;
-        try {
-            ip1 = InetAddress.getByName("10.0.0.1");
-        } catch (UnknownHostException e) {
-            return;
-        }
-        InetAddress ip2 = null;
-        try {
-            ip2 = InetAddress.getByName("10.0.0.1");
-        } catch (UnknownHostException e) {
-            return;
-        }
-        try {
-            h1 = new HostNodeConnector(ip1);
-        } catch (ConstructionException e) {
-            return;
-        }
-        try {
-            h2 = new HostNodeConnector(ip2);
-        } catch (ConstructionException e) {
-            return;
-        }
-        HostNodePair hsw1 = new HostNodePair(h1, NodeCreator.createOFNode(1L));
-        HostNodePair hsw2 = new HostNodePair(h2, NodeCreator.createOFNode(1L));
-        Assert.assertTrue(hsw1.hashCode() == hsw2.hashCode());
-    }
-
-    @Test
-    public void TestEqualHashCode2() {
-        HostNodeConnector h1 = null;
-        HostNodeConnector h2 = null;
-        InetAddress ip1 = null;
-        try {
-            ip1 = InetAddress.getByName("10.0.0.2");
-        } catch (UnknownHostException e) {
-            return;
-        }
-        InetAddress ip2 = null;
-        try {
-            ip2 = InetAddress.getByName("10.0.0.2");
-        } catch (UnknownHostException e) {
-            return;
-        }
-        try {
-            h1 = new HostNodeConnector(ip1);
-        } catch (ConstructionException e) {
-            return;
-        }
-        try {
-            h2 = new HostNodeConnector(ip2);
-        } catch (ConstructionException e) {
-            return;
-        }
-
-        HostNodePair hsw1 = new HostNodePair(h1, NodeCreator.createOFNode(1L));
-        HostNodePair hsw2 = new HostNodePair(h2, NodeCreator.createOFNode(1L));
-        Assert.assertTrue(hsw1.hashCode() == hsw2.hashCode());
-    }
-
-    @Test
-    public void TestDiverseHashCodeHost() {
-        HostNodeConnector h1 = null;
-        HostNodeConnector h2 = null;
-        InetAddress ip1 = null;
-        try {
-            ip1 = InetAddress.getByName("10.0.0.1");
-        } catch (UnknownHostException e) {
-            return;
-        }
-        InetAddress ip2 = null;
-        try {
-            ip2 = InetAddress.getByName("10.0.0.2");
-        } catch (UnknownHostException e) {
-            return;
-        }
-        try {
-            h1 = new HostNodeConnector(ip1);
-        } catch (ConstructionException e) {
-            return;
-        }
-        try {
-            h2 = new HostNodeConnector(ip2);
-        } catch (ConstructionException e) {
-            return;
-        }
-        HostNodePair hsw1 = new HostNodePair(h1, NodeCreator.createOFNode(1L));
-        HostNodePair hsw2 = new HostNodePair(h2, NodeCreator.createOFNode(1L));
-        Assert.assertTrue(hsw1.hashCode() != hsw2.hashCode());
-    }
-
-    @Test
-    public void TestDiverseHashCodeSwitch() {
-        HostNodeConnector h1 = null;
-        HostNodeConnector h2 = null;
-        InetAddress ip1 = null;
-        try {
-            ip1 = InetAddress.getByName("10.0.0.1");
-        } catch (UnknownHostException e) {
-            return;
-        }
-        InetAddress ip2 = null;
-        try {
-            ip2 = InetAddress.getByName("10.0.0.1");
-        } catch (UnknownHostException e) {
-            return;
-        }
-        try {
-            h1 = new HostNodeConnector(ip1);
-        } catch (ConstructionException e) {
-            return;
-        }
-        try {
-            h2 = new HostNodeConnector(ip2);
-        } catch (ConstructionException e) {
-            return;
-        }
-
-        HostNodePair hsw1 = new HostNodePair(h1, NodeCreator.createOFNode(1L));
-        HostNodePair hsw2 = new HostNodePair(h2, NodeCreator.createOFNode(2L));
-        Assert.assertTrue(hsw1.hashCode() != hsw2.hashCode());
-    }
-
-    @Test
-    public void TestDiverseHashCodeAll() {
-        HostNodeConnector h1 = null;
-        HostNodeConnector h2 = null;
-        InetAddress ip1 = null;
-        try {
-            ip1 = InetAddress.getByName("10.0.0.1");
-        } catch (UnknownHostException e) {
-            return;
-        }
-        InetAddress ip2 = null;
-        try {
-            ip2 = InetAddress.getByName("10.0.0.3");
-        } catch (UnknownHostException e) {
-            return;
-        }
-        try {
-            h1 = new HostNodeConnector(ip1);
-        } catch (ConstructionException e) {
-            return;
-        }
-        try {
-            h2 = new HostNodeConnector(ip2);
-        } catch (ConstructionException e) {
-            return;
-        }
-
-        HostNodePair hsw1 = new HostNodePair(h1, NodeCreator.createOFNode(1L));
-        HostNodePair hsw2 = new HostNodePair(h2, NodeCreator.createOFNode(2L));
-        Assert.assertTrue(hsw1.hashCode() != hsw2.hashCode());
-    }
-
-    @Test
-    public void TestUsageAsKey() {
-        HostNodeConnector h1 = null;
-        HostNodeConnector h2 = null;
-        InetAddress ip1 = null;
-        try {
-            ip1 = InetAddress.getByName("10.0.0.1");
-        } catch (UnknownHostException e) {
-            return;
-        }
-        InetAddress ip2 = null;
-        try {
-            ip2 = InetAddress.getByName("10.0.0.1");
-        } catch (UnknownHostException e) {
-            return;
-        }
-        try {
-            h1 = new HostNodeConnector(ip1);
-        } catch (ConstructionException e) {
-            return;
-        }
-        try {
-            h2 = new HostNodeConnector(ip2);
-        } catch (ConstructionException e) {
-            return;
-        }
-
-        HostNodePair hsw1 = new HostNodePair(h1, NodeCreator.createOFNode(1L));
-        HostNodePair hsw2 = new HostNodePair(h2, NodeCreator.createOFNode(1L));
-        HashMap<HostNodePair, Long> hm = new HashMap<HostNodePair, Long>();
-        hm.put(hsw1, new Long(10));
-        Assert.assertTrue(hm.get(hsw2) != null);
-        Assert.assertTrue(hm.get(hsw2).equals(new Long(10)));
-    }
-
-    @Test
-    public void TestUsageAsKeyChangingField() {
-        HostNodeConnector h1 = null;
-        HostNodeConnector h2 = null;
-        InetAddress ip1 = null;
-        try {
-            ip1 = InetAddress.getByName("10.0.0.1");
-        } catch (UnknownHostException e) {
-            return;
-        }
-        InetAddress ip2 = null;
-        try {
-            ip2 = InetAddress.getByName("10.0.0.1");
-        } catch (UnknownHostException e) {
-            return;
-        }
-        try {
-            h1 = new HostNodeConnector(ip1);
-        } catch (ConstructionException e) {
-            return;
-        }
-        try {
-            h2 = new HostNodeConnector(ip2);
-        } catch (ConstructionException e) {
-            return;
-        }
-        HostNodePair hsw1 = new HostNodePair(h1, null);
-        HostNodePair hsw2 = new HostNodePair(h2, NodeCreator.createOFNode(1L));
-        hsw1.setNode(NodeCreator.createOFNode(1L));
-        HashMap<HostNodePair, Long> hm = new HashMap<HostNodePair, Long>();
-        hm.put(hsw1, new Long(10));
-        Assert.assertTrue(hm.get(hsw2) != null);
-        Assert.assertTrue(hm.get(hsw2).equals(new Long(10)));
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/security/pom.xml b/opendaylight/adsal/security/pom.xml
deleted file mode 100644 (file)
index 4467aaf..0000000
+++ /dev/null
@@ -1,59 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>security</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>orbit</groupId>
-      <artifactId>org.apache.catalina</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>usermanager</artifactId>
-    </dependency>
-  </dependencies>
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Fragment-Host>org.apache.catalina</Fragment-Host>
-            <Import-Package>org.slf4j,
-              javax.servlet,
-              org.apache.catalina,
-              org.apache.catalina.connector,
-              org.apache.catalina.valves,
-              org.apache.catalina.realm,
-              org.opendaylight.controller.sal.utils,
-              org.opendaylight.controller.sal.authorization,
-              org.opendaylight.controller.usermanager</Import-Package>
-            <Export-Package>org.opendaylight.controller.security</Export-Package>
-          </instructions>
-          <manifestLocation>${project.basedir}/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/security/src/main/java/org/opendaylight/controller/security/ControllerCustomRealm.java b/opendaylight/adsal/security/src/main/java/org/opendaylight/controller/security/ControllerCustomRealm.java
deleted file mode 100644 (file)
index 1579094..0000000
+++ /dev/null
@@ -1,82 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.security;
-
-import java.security.Principal;
-import java.util.ArrayList;
-import java.util.List;
-
-import org.apache.catalina.realm.GenericPrincipal;
-import org.apache.catalina.realm.RealmBase;
-import org.opendaylight.controller.sal.authorization.AuthResultEnum;
-import org.opendaylight.controller.sal.authorization.UserLevel;
-import org.opendaylight.controller.sal.utils.ServiceHelper;
-import org.opendaylight.controller.usermanager.IUserManager;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-public class ControllerCustomRealm  extends RealmBase {
-
-    private static final String name = "ControllerCustomRealm";
-
-    private static final Logger logger = LoggerFactory
-            .getLogger(ControllerCustomRealm.class);
-
-    @Override
-    protected String getName() {
-        return name;
-    }
-
-    @Override
-    protected String getPassword(String username) {
-        IUserManager userManager = (IUserManager) ServiceHelper
-                .getGlobalInstance(IUserManager.class, this);
-        if (userManager != null) {
-            return userManager.getPassword(username);
-        } else {
-            throw new RuntimeException("User Manager reference is null");
-        }
-    }
-
-    @Override
-    protected Principal getPrincipal(String username) {
-        IUserManager userManager = (IUserManager) ServiceHelper
-                .getGlobalInstance(IUserManager.class, this);
-        if (userManager != null) {
-            List<String> controllerRoles = new ArrayList<String>();
-            for (UserLevel level : userManager.getUserLevels(username)) {
-                controllerRoles.add(level.toString());
-            }
-            return new GenericPrincipal(username, "", controllerRoles);
-        } else {
-            throw new RuntimeException("User Manager reference is null");
-        }
-    }
-
-    @Override
-    public Principal authenticate(String username, String credentials) {
-
-        IUserManager userManager = (IUserManager) ServiceHelper
-                .getGlobalInstance(IUserManager.class, this);
-        if (userManager != null) {
-            AuthResultEnum result = userManager.authenticate(username,
-                    credentials);
-            if (result.equals(AuthResultEnum.AUTHOR_PASS)
-                    || result.equals(AuthResultEnum.AUTH_ACCEPT_LOC)
-                    || result.equals(AuthResultEnum.AUTH_ACCEPT)) {
-                return this.getPrincipal(username);
-            } else {
-                logger.debug("Authentication failed for user " + username);
-                return null;
-            }
-        } else {
-            throw new RuntimeException("User Manager reference is null");
-        }
-    }
-
-}
diff --git a/opendaylight/adsal/statisticsmanager/api/pom.xml b/opendaylight/adsal/statisticsmanager/api/pom.xml
deleted file mode 100644 (file)
index a7c59df..0000000
+++ /dev/null
@@ -1,50 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>statisticsmanager</artifactId>
-  <version>0.7.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>forwardingrulesmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-  </dependencies>
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Import-Package>org.opendaylight.controller.forwardingrulesmanager,
-              org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.sal.flowprogrammer, org.slf4j,
-              org.opendaylight.controller.sal.reader,
-              org.apache.felix.dm</Import-Package>
-            <Export-Package>org.opendaylight.controller.statisticsmanager</Export-Package>
-          </instructions>
-          <manifestLocation>${project.basedir}/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/statisticsmanager/api/src/main/java/org/opendaylight/controller/statisticsmanager/IStatisticsManager.java b/opendaylight/adsal/statisticsmanager/api/src/main/java/org/opendaylight/controller/statisticsmanager/IStatisticsManager.java
deleted file mode 100644 (file)
index c717ccf..0000000
+++ /dev/null
@@ -1,120 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.statisticsmanager;
-
-import java.util.List;
-import java.util.Map;
-
-import org.opendaylight.controller.forwardingrulesmanager.FlowEntry;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.NodeTable;
-import org.opendaylight.controller.sal.reader.FlowOnNode;
-import org.opendaylight.controller.sal.reader.NodeConnectorStatistics;
-import org.opendaylight.controller.sal.reader.NodeDescription;
-import org.opendaylight.controller.sal.reader.NodeTableStatistics;
-
-/**
- * Interface which defines the available methods for retrieving
- * the network nodes statistics.
- */
-public interface IStatisticsManager {
-    /**
-     * Return all the statistics for all the flows present on the specified node
-     * in the current container context. If the context is the default
-     * container, the returned statistics are for all the flows installed on the
-     * node, regardless of the container they belong to
-     *
-     * @param node
-     *            The network node
-     * @return List of flows installed on the network node. Null if specified
-     *         node is null. Empty list if node/stat is not present.
-     */
-    List<FlowOnNode> getFlows(Node node);
-
-    /**
-     * Same as the getFlows method.
-     * The only difference is that this method does not return cached flows.
-     * It will always make a request to the node to get all the flows for that node.
-     * If the request times out or gets an error, we revert to getting the cached flows.
-     * @see IStatisticsManager#getFlows
-     * @param node
-     * @return List of flows installed on the network node.
-     */
-    List<FlowOnNode> getFlowsNoCache(Node node);
-
-    /**
-     * Returns the statistics for the flows specified in the list
-     *
-     * @param flows
-     * @return A map of flows per node installed on that node, empty map if
-     *         flows is null/empty.
-     */
-    Map<Node, List<FlowOnNode>> getFlowStatisticsForFlowList(List<FlowEntry> flows);
-
-    /**
-     * Returns the number of flows installed on the switch in the current
-     * container context If the context is the default container, the returned
-     * value is the number of all the flows installed on the switch regardless
-     * of the container they belong to
-     *
-     * @param node
-     * @return number of flows on specified node or (-1) if node was not found
-     */
-    int getFlowsNumber(Node node);
-
-    /**
-     * Returns the node description for the specified node retrieved by the
-     * protocol plugin component and cached by statistics manager.
-     * Null if node not found.
-     *
-     * @param node
-     * @return node description
-     */
-    NodeDescription getNodeDescription(Node node);
-
-    /**
-     * Returns the statistics for the specified node connector as it was
-     * retrieved by the protocol plugin component and cached by statistics
-     * manager.
-     *
-     * @param node
-     * @return Node connector statistics or null if requested stats was not
-     *         found.
-     */
-    NodeConnectorStatistics getNodeConnectorStatistics(NodeConnector nodeConnector);
-
-    /**
-     * Returns the statistics for all the node connector present on the
-     * specified network node
-     *
-     * @param node
-     * @return List of node connector statistics. Null if node is null. Empty
-     *         list if node/stats is not present.
-     */
-    List<NodeConnectorStatistics> getNodeConnectorStatistics(Node node);
-
-    /**
-     * Returns the statistics for the specified table of the node
-     *
-     * @param nodeTable
-     * @return Table statistics. Null if node table is null or stats not found.
-     */
-    NodeTableStatistics getNodeTableStatistics(NodeTable nodeTable);
-
-    /**
-     * Returns the statistics for all the tables of the node
-     *
-     * @param nodeTable
-     * @return List of table stats. Null if node is null. Empty list if
-     *         node/stats not found.
-     */
-    List <NodeTableStatistics> getNodeTableStatistics(Node node);
-}
diff --git a/opendaylight/adsal/statisticsmanager/implementation/pom.xml b/opendaylight/adsal/statisticsmanager/implementation/pom.xml
deleted file mode 100644 (file)
index f4334f3..0000000
+++ /dev/null
@@ -1,123 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>statisticsmanager.implementation</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <properties>
-    <!-- Sonar properties using jacoco to retrieve integration test results -->
-    <sonar.dynamicAnalysis>reuseReports</sonar.dynamicAnalysis>
-    <sonar.jacoco.itReportPath>target/jacoco-it.exec</sonar.jacoco.itReportPath>
-    <sonar.jacoco.reportpath>target/jacoco.exec</sonar.jacoco.reportpath>
-  </properties>
-  <dependencies>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>clustering.services</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>connectionmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>forwardingrulesmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal.connection</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>statisticsmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>switchmanager</artifactId>
-    </dependency>
-  </dependencies>
-  <build>
-    <pluginManagement>
-      <plugins>
-        <plugin>
-          <groupId>org.jacoco</groupId>
-          <artifactId>jacoco-maven-plugin</artifactId>
-          <version>${jacoco.version}</version>
-        </plugin>
-      </plugins>
-    </pluginManagement>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Import-Package>org.opendaylight.controller.clustering.services,
-              org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.sal.flowprogrammer,
-              org.opendaylight.controller.sal.reader,
-              org.opendaylight.controller.sal.utils,
-              org.slf4j,
-              org.opendaylight.controller.sal.inventory,
-              org.opendaylight.controller.sal.match,
-              org.opendaylight.controller.sal.connection,
-              org.opendaylight.controller.switchmanager,
-              org.opendaylight.controller.statisticsmanager,
-              org.opendaylight.controller.forwardingrulesmanager,
-              org.opendaylight.controller.connectionmanager,
-              org.apache.felix.dm</Import-Package>
-            <Bundle-Activator>org.opendaylight.controller.statisticsmanager.internal.Activator</Bundle-Activator>
-            <Export-Package></Export-Package>
-          </instructions>
-          <manifestLocation>${project.basedir}/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-      <plugin>
-        <groupId>org.jacoco</groupId>
-        <artifactId>jacoco-maven-plugin</artifactId>
-        <configuration>
-          <includes>
-            <include>org.opendaylight.controller.*</include>
-          </includes>
-        </configuration>
-        <executions>
-          <execution>
-            <id>pre-test</id>
-            <goals>
-              <goal>prepare-agent</goal>
-            </goals>
-          </execution>
-          <execution>
-            <id>post-test</id>
-            <goals>
-              <goal>report</goal>
-            </goals>
-            <phase>test</phase>
-          </execution>
-        </executions>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/statisticsmanager/implementation/src/main/java/org/opendaylight/controller/statisticsmanager/internal/Activator.java b/opendaylight/adsal/statisticsmanager/implementation/src/main/java/org/opendaylight/controller/statisticsmanager/internal/Activator.java
deleted file mode 100644 (file)
index 7eb32b0..0000000
+++ /dev/null
@@ -1,92 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.statisticsmanager.internal;
-
-import java.util.Dictionary;
-import java.util.HashSet;
-import java.util.Hashtable;
-import java.util.Set;
-
-import org.apache.felix.dm.Component;
-import org.opendaylight.controller.clustering.services.ICacheUpdateAware;
-import org.opendaylight.controller.clustering.services.IClusterContainerServices;
-import org.opendaylight.controller.connectionmanager.IConnectionManager;
-import org.opendaylight.controller.sal.core.ComponentActivatorAbstractBase;
-import org.opendaylight.controller.sal.core.IContainer;
-import org.opendaylight.controller.sal.inventory.IListenInventoryUpdates;
-import org.opendaylight.controller.sal.reader.IReadService;
-import org.opendaylight.controller.sal.reader.IReadServiceListener;
-import org.opendaylight.controller.statisticsmanager.IStatisticsManager;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-public class Activator extends ComponentActivatorAbstractBase {
-    protected static final Logger logger = LoggerFactory.getLogger(Activator.class);
-
-
-    /**
-     * Function that is used to communicate to dependency manager the list of
-     * known implementations for services inside a container
-     *
-     *
-     * @return An array containing all the CLASS objects that will be
-     *         instantiated in order to get an fully working implementation
-     *         Object
-     */
-    public Object[] getImplementations() {
-        Object[] res = { StatisticsManager.class };
-        return res;
-    }
-
-    /**
-     * Function that is called when configuration of the dependencies is
-     * required.
-     *
-     * @param c
-     *            dependency manager Component object, used for configuring the
-     *            dependencies exported and imported
-     * @param imp
-     *            Implementation class that is being configured, needed as long
-     *            as the same routine can configure multiple implementations
-     * @param containerName
-     *            The containerName being configured, this allow also optional
-     *            per-container different behavior if needed, usually should not
-     *            be the case though.
-     */
-    public void configureInstance(Component c, Object imp, String containerName) {
-        if (imp.equals(StatisticsManager.class)) {
-            // export the service
-            Dictionary<String, Object> props = new Hashtable<String, Object>();
-            Set<String> propSet = new HashSet<String>();
-            // trigger cache
-            propSet.add(StatisticsManager.TRIGGERS_CACHE);
-            // flow statistics cache
-            propSet.add(StatisticsManager.FLOW_STATISTICS_CACHE);
-            props.put("cachenames", propSet);
-
-            String interfaces[] = new String[] {
-                    IStatisticsManager.class.getName(),
-                    IReadServiceListener.class.getName(),
-                    IListenInventoryUpdates.class.getName(),
-                    ICacheUpdateAware.class.getName() };
-            c.setInterface(interfaces, props);
-
-            c.add(createContainerServiceDependency(containerName).setService(IReadService.class)
-                    .setCallbacks("setReaderService", "unsetReaderService").setRequired(true));
-            c.add(createContainerServiceDependency(containerName).setService(IClusterContainerServices.class)
-                    .setCallbacks("setClusterContainerService", "unsetClusterContainerService").setRequired(true));
-            c.add(createContainerServiceDependency(containerName).setService(IContainer.class)
-                    .setCallbacks("setIContainer", "unsetIContainer").setRequired(true));
-            c.add(createServiceDependency().setService(IConnectionManager.class)
-                    .setCallbacks("setIConnectionManager", "unsetIConnectionManager").setRequired(false));
-
-        }
-    }
-}
diff --git a/opendaylight/adsal/statisticsmanager/implementation/src/main/java/org/opendaylight/controller/statisticsmanager/internal/StatisticsManager.java b/opendaylight/adsal/statisticsmanager/implementation/src/main/java/org/opendaylight/controller/statisticsmanager/internal/StatisticsManager.java
deleted file mode 100644 (file)
index 2376b87..0000000
+++ /dev/null
@@ -1,594 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.statisticsmanager.internal;
-
-import java.util.ArrayList;
-import java.util.Collections;
-import java.util.EnumSet;
-import java.util.HashMap;
-import java.util.HashSet;
-import java.util.List;
-import java.util.Map;
-import java.util.Map.Entry;
-import java.util.Set;
-import java.util.concurrent.ConcurrentHashMap;
-import java.util.concurrent.ConcurrentMap;
-import java.util.concurrent.CountDownLatch;
-import java.util.concurrent.ExecutorService;
-import java.util.concurrent.Executors;
-import java.util.concurrent.TimeUnit;
-import java.util.concurrent.atomic.AtomicInteger;
-
-import org.opendaylight.controller.clustering.services.CacheConfigException;
-import org.opendaylight.controller.clustering.services.CacheExistException;
-import org.opendaylight.controller.clustering.services.ICacheUpdateAware;
-import org.opendaylight.controller.clustering.services.IClusterContainerServices;
-import org.opendaylight.controller.clustering.services.IClusterServices;
-import org.opendaylight.controller.connectionmanager.IConnectionManager;
-import org.opendaylight.controller.forwardingrulesmanager.FlowEntry;
-import org.opendaylight.controller.sal.connection.ConnectionLocality;
-import org.opendaylight.controller.sal.core.IContainer;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.NodeTable;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.core.UpdateType;
-import org.opendaylight.controller.sal.flowprogrammer.Flow;
-import org.opendaylight.controller.sal.inventory.IListenInventoryUpdates;
-import org.opendaylight.controller.sal.reader.FlowOnNode;
-import org.opendaylight.controller.sal.reader.IReadService;
-import org.opendaylight.controller.sal.reader.IReadServiceListener;
-import org.opendaylight.controller.sal.reader.NodeConnectorStatistics;
-import org.opendaylight.controller.sal.reader.NodeDescription;
-import org.opendaylight.controller.sal.reader.NodeTableStatistics;
-import org.opendaylight.controller.sal.utils.ServiceHelper;
-import org.opendaylight.controller.statisticsmanager.IStatisticsManager;
-import org.opendaylight.controller.switchmanager.ISwitchManager;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * The class caches latest network nodes statistics as notified by reader
- * services and provides API to retrieve them.
- */
-public class StatisticsManager implements IStatisticsManager, IReadServiceListener, IListenInventoryUpdates,
-    ICacheUpdateAware<Object,Object> {
-    private static final Logger log = LoggerFactory.getLogger(StatisticsManager.class);
-    private IContainer container;
-    private IClusterContainerServices clusterContainerService;
-    private IReadService reader;
-    private IConnectionManager connectionManager;
-    //statistics caches
-    private ConcurrentMap<Node, List<FlowOnNode>> flowStatistics;
-    private ConcurrentMap<Node, List<NodeConnectorStatistics>> nodeConnectorStatistics;
-    private ConcurrentMap<Node, List<NodeTableStatistics>> tableStatistics;
-    private ConcurrentMap<Node, NodeDescription> descriptionStatistics;
-
-    // data structure for latches
-    // this is not a cluster cache
-    private ConcurrentMap<Node, CountDownLatch> latches = new ConcurrentHashMap<Node, CountDownLatch>();
-    // 30 seconds is the timeout.
-    // the value of this can be tweaked based on performance tests.
-    private static long latchTimeout = 30;
-
-    // cache for flow stats refresh triggers
-    // an entry added to this map triggers the statistics manager
-    // to which the node is connected to get the latest flow stats from that node
-    // this is a cluster cache
-    private ConcurrentMap<Integer, Node> triggers;
-
-    // use an atomic integer for the triggers key
-    private AtomicInteger triggerKey = new AtomicInteger();
-
-    // single thread executor for the triggers
-    private ExecutorService triggerExecutor;
-
-    static final String TRIGGERS_CACHE = "statisticsmanager.triggers";
-    static final String FLOW_STATISTICS_CACHE = "statisticsmanager.flowStatistics";
-
-    private void nonClusterObjectCreate() {
-        flowStatistics = new ConcurrentHashMap<Node, List<FlowOnNode>>();
-        nodeConnectorStatistics = new ConcurrentHashMap<Node, List<NodeConnectorStatistics>>();
-        tableStatistics = new ConcurrentHashMap<Node, List<NodeTableStatistics>>();
-        descriptionStatistics = new ConcurrentHashMap<Node, NodeDescription>();
-        triggers = new ConcurrentHashMap<Integer, Node>();
-    }
-
-    private void allocateCaches() {
-        if (clusterContainerService == null) {
-            nonClusterObjectCreate();
-            log.error("Clustering service unavailable. Allocated non-cluster statistics manager cache.");
-            return;
-        }
-
-        try {
-            clusterContainerService.createCache(FLOW_STATISTICS_CACHE,
-                    EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-            clusterContainerService.createCache("statisticsmanager.nodeConnectorStatistics",
-                    EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-            clusterContainerService.createCache("statisticsmanager.tableStatistics",
-                    EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-            clusterContainerService.createCache("statisticsmanager.descriptionStatistics",
-                    EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-            clusterContainerService.createCache(TRIGGERS_CACHE,
-                    EnumSet.of(IClusterServices.cacheMode.NON_TRANSACTIONAL, IClusterServices.cacheMode.ASYNC));
-        } catch (CacheConfigException cce) {
-            log.error("Statistics cache configuration invalid - check cache mode");
-        } catch (CacheExistException ce) {
-            log.debug("Skipping statistics cache creation - already present");
-        }
-    }
-    @SuppressWarnings({ "unchecked" })
-    private void retrieveCaches() {
-        ConcurrentMap<?, ?> map;
-
-        if (this.clusterContainerService == null) {
-            log.warn("Can't retrieve statistics manager cache, Clustering service unavailable.");
-            return;
-        }
-
-        log.debug("Statistics Manager - retrieveCaches for Container {}", container);
-
-        map = clusterContainerService.getCache(FLOW_STATISTICS_CACHE);
-        if (map != null) {
-            this.flowStatistics = (ConcurrentMap<Node, List<FlowOnNode>>) map;
-        } else {
-            log.error("Cache allocation failed for statisticsmanager.flowStatistics in container {}", container.getName());
-        }
-
-        map = clusterContainerService.getCache("statisticsmanager.nodeConnectorStatistics");
-        if (map != null) {
-            this.nodeConnectorStatistics = (ConcurrentMap<Node, List<NodeConnectorStatistics>>) map;
-        } else {
-            log.error("Cache allocation failed for statisticsmanager.nodeConnectorStatistics in container {}", container.getName());
-        }
-
-        map = clusterContainerService.getCache("statisticsmanager.tableStatistics");
-        if (map != null) {
-            this.tableStatistics = (ConcurrentMap<Node, List<NodeTableStatistics>>) map;
-        } else {
-            log.error("Cache allocation failed for statisticsmanager.tableStatistics in container {}", container.getName());
-        }
-
-        map = clusterContainerService.getCache("statisticsmanager.descriptionStatistics");
-        if (map != null) {
-            this.descriptionStatistics = (ConcurrentMap<Node, NodeDescription>) map;
-        } else {
-            log.error("Cache allocation failed for statisticsmanager.descriptionStatistics in container {}", container.getName());
-        }
-
-        map = clusterContainerService.getCache(TRIGGERS_CACHE);
-        if (map != null) {
-            this.triggers = (ConcurrentMap<Integer, Node>) map;
-        } else {
-            log.error("Cache allocation failed for " + TRIGGERS_CACHE +" in container {}", container.getName());
-        }
-    }
-
-    /**
-     * Function called by the dependency manager when all the required
-     * dependencies are satisfied
-     *
-     */
-    void init() {
-        log.debug("INIT called!");
-        allocateCaches();
-        retrieveCaches();
-
-    }
-
-    /**
-     * Function called by the dependency manager when at least one
-     * dependency become unsatisfied or when the component is shutting
-     * down because for example bundle is being stopped.
-     *
-     */
-    void destroy() {
-        log.debug("DESTROY called!");
-    }
-
-    /**
-     * Function called by dependency manager after "init ()" is called
-     * and after the services provided by the class are registered in
-     * the service registry
-     *
-     */
-    void start() {
-        log.debug("START called!");
-        this.triggerExecutor = Executors.newSingleThreadExecutor();
-    }
-
-    /**
-     * Function called after registering the service in OSGi service registry.
-     */
-    void started(){
-        // Retrieve current statistics so we don't have to wait for next refresh
-        ISwitchManager switchManager = (ISwitchManager) ServiceHelper.getInstance(
-                ISwitchManager.class, container.getName(), this);
-        if ((reader != null) && (switchManager != null)) {
-            Set<Node> nodeSet = switchManager.getNodes();
-            for (Node node : nodeSet) {
-                List<FlowOnNode> flows = reader.readAllFlows(node);
-                if (flows != null) {
-                    flowStatistics.put(node, flows);
-                }
-                NodeDescription descr = reader.readDescription(node);
-                if (descr != null) {
-                    descriptionStatistics.put(node, descr);
-                }
-                List<NodeTableStatistics> tableStats = reader.readNodeTable(node);
-                if (tableStats != null) {
-                    tableStatistics.put(node, tableStats);
-                }
-                List<NodeConnectorStatistics> ncStats = reader.readNodeConnectors(node);
-                if (ncStats != null) {
-                    nodeConnectorStatistics.put(node, ncStats);
-                }
-            }
-
-        } else {
-            log.trace("Failed to retrieve current statistics. Statistics will not be immediately available!");
-        }
-    }
-
-    /**
-     * Function called by the dependency manager before the services
-     * exported by the component are unregistered, this will be
-     * followed by a "destroy ()" calls
-     *
-     */
-    void stop() {
-        log.debug("STOP called!");
-        this.triggerExecutor.shutdownNow();
-    }
-
-    void setClusterContainerService(IClusterContainerServices s) {
-        log.debug("Cluster Service set for Statistics Mgr");
-        this.clusterContainerService = s;
-    }
-
-    void unsetClusterContainerService(IClusterContainerServices s) {
-        if (this.clusterContainerService == s) {
-            log.debug("Cluster Service removed for Statistics Mgr!");
-            this.clusterContainerService = null;
-        }
-    }
-    void setIContainer(IContainer c){
-        container = c;
-    }
-    public void unsetIContainer(IContainer s) {
-        if (this.container == s) {
-            this.container = null;
-        }
-    }
-
-    public void setReaderService(IReadService service) {
-        log.debug("Got inventory service set request {}", service);
-        this.reader = service;
-    }
-
-    public void unsetReaderService(IReadService service) {
-        log.debug("Got a service UNset request {}", service);
-        this.reader = null;
-    }
-
-    @Override
-    public List<FlowOnNode> getFlows(Node node) {
-        if (node == null) {
-            return Collections.emptyList();
-        }
-
-        List<FlowOnNode> flowList = new ArrayList<FlowOnNode>();
-        List<FlowOnNode> cachedList = flowStatistics.get(node);
-        if (cachedList != null){
-            flowList.addAll(cachedList);
-        }
-        return flowList;
-    }
-
-    /**
-     * {@inheritDoc}
-     */
-    @Override
-    public List<FlowOnNode> getFlowsNoCache(Node node) {
-        if (node == null) {
-            return Collections.emptyList();
-        }
-        // check if the node is local to this controller
-        ConnectionLocality locality = ConnectionLocality.LOCAL;
-        if(this.connectionManager != null) {
-            locality = this.connectionManager.getLocalityStatus(node);
-        }
-        if (locality == ConnectionLocality.NOT_LOCAL) {
-            // send a trigger to all and wait for either a response or timeout
-            CountDownLatch newLatch = new CountDownLatch(1);
-            CountDownLatch oldLatch = this.latches.putIfAbsent(node, newLatch);
-            this.triggers.put(this.triggerKey.incrementAndGet(), node);
-            try {
-                boolean retStatus;
-                if(oldLatch != null) {
-                    retStatus = oldLatch.await(StatisticsManager.latchTimeout, TimeUnit.SECONDS);
-                } else {
-                    retStatus = newLatch.await(StatisticsManager.latchTimeout, TimeUnit.SECONDS);
-                }
-                // log the return code as it will give us, if
-                // the latch timed out.
-                log.debug("latch timed out {}", !retStatus);
-            } catch (InterruptedException e) {
-                // log the error and move on
-                log.warn("Waiting for statistics response interrupted", e);
-                // restore the interrupt status
-                // its a good practice to restore the interrupt status
-                // if you are not propagating the InterruptedException
-                Thread.currentThread().interrupt();
-            }
-            // now that the wait is over
-            // remove the latch entry
-            this.latches.remove(node);
-        } else {
-            // the node is local.
-            // call the read service
-            if (this.reader != null) {
-                List<FlowOnNode> flows = reader.nonCachedReadAllFlows(node);
-                if (flows != null) {
-                    nodeFlowStatisticsUpdated(node, flows);
-                }
-            }
-        }
-        // at this point we are ready to return the cached value.
-        // this cached value will be up to date with a very high probability
-        // due to what we have done previously ie:- send a trigger for cache update
-        // or refreshed the cache if the node is local.
-        return getFlows(node);
-    }
-
-    @Override
-    public Map<Node, List<FlowOnNode>> getFlowStatisticsForFlowList(List<FlowEntry> flowList) {
-        Map<Node, List<FlowOnNode>> statMapOutput = new HashMap<Node, List<FlowOnNode>>();
-
-        if (flowList == null || flowList.isEmpty()){
-            return statMapOutput;
-        }
-
-        Node node;
-        // Index FlowEntries' flows by node so we don't traverse entire flow list for each flowEntry
-        Map<Node, Set<Flow>> index = new HashMap<Node, Set<Flow>>();
-        for (FlowEntry flowEntry : flowList) {
-            node = flowEntry.getNode();
-            Set<Flow> set = (index.containsKey(node) ? index.get(node) : new HashSet<Flow>());
-            set.add(flowEntry.getFlow());
-            index.put(node, set);
-        }
-
-        // Iterate over flows per indexed node and add to output
-        for (Entry<Node, Set<Flow>> indexEntry : index.entrySet()) {
-            node = indexEntry.getKey();
-            List<FlowOnNode> flowsPerNode = flowStatistics.get(node);
-
-            if (flowsPerNode != null && !flowsPerNode.isEmpty()){
-                List<FlowOnNode> filteredFlows = statMapOutput.containsKey(node) ?
-                        statMapOutput.get(node) : new ArrayList<FlowOnNode>();
-
-                for (FlowOnNode flowOnNode : flowsPerNode) {
-                    if (indexEntry.getValue().contains(flowOnNode.getFlow())) {
-                        filteredFlows.add(flowOnNode);
-                    }
-                }
-                statMapOutput.put(node, filteredFlows);
-            }
-        }
-        return statMapOutput;
-    }
-
-    @Override
-    public int getFlowsNumber(Node node) {
-        List<FlowOnNode> l;
-        if (node == null || (l = flowStatistics.get(node)) == null){
-            return -1;
-        }
-        return l.size();
-    }
-
-    @Override
-    public NodeDescription getNodeDescription(Node node) {
-        if (node == null){
-            return null;
-        }
-        NodeDescription nd = descriptionStatistics.get(node);
-        return nd != null? nd.clone() : null;
-    }
-
-    @Override
-    public NodeConnectorStatistics getNodeConnectorStatistics(NodeConnector nodeConnector) {
-        if (nodeConnector == null){
-            return null;
-        }
-
-        List<NodeConnectorStatistics> statList = nodeConnectorStatistics.get(nodeConnector.getNode());
-        if (statList != null){
-            for (NodeConnectorStatistics stat : statList) {
-                if (stat.getNodeConnector().equals(nodeConnector)){
-                    return stat;
-                }
-            }
-        }
-        return null;
-    }
-
-    @Override
-    public List<NodeConnectorStatistics> getNodeConnectorStatistics(Node node) {
-        if (node == null){
-            return Collections.emptyList();
-        }
-
-        List<NodeConnectorStatistics> statList = new ArrayList<NodeConnectorStatistics>();
-        List<NodeConnectorStatistics> cachedList = nodeConnectorStatistics.get(node);
-        if (cachedList != null) {
-            statList.addAll(cachedList);
-        }
-        return statList;
-    }
-
-    @Override
-    public NodeTableStatistics getNodeTableStatistics(NodeTable nodeTable) {
-        if (nodeTable == null){
-            return null;
-        }
-        List<NodeTableStatistics> statList = tableStatistics.get(nodeTable.getNode());
-        if (statList != null){
-            for (NodeTableStatistics stat : statList) {
-                if (stat.getNodeTable().getID().equals(nodeTable.getID())){
-                    return stat;
-                }
-            }
-        }
-        return null;
-    }
-
-    @Override
-    public List<NodeTableStatistics> getNodeTableStatistics(Node node){
-        if (node == null){
-            return Collections.emptyList();
-        }
-        List<NodeTableStatistics> statList = new ArrayList<NodeTableStatistics>();
-        List<NodeTableStatistics> cachedList = tableStatistics.get(node);
-        if (cachedList != null) {
-            statList.addAll(cachedList);
-        }
-        return statList;
-    }
-
-    @Override
-    public void nodeFlowStatisticsUpdated(Node node, List<FlowOnNode> flowStatsList) {
-        // No equality check because duration fields change constantly
-        this.flowStatistics.put(node, flowStatsList);
-    }
-
-    @Override
-    public void nodeConnectorStatisticsUpdated(Node node, List<NodeConnectorStatistics> ncStatsList) {
-        List<NodeConnectorStatistics> currentStat = this.nodeConnectorStatistics.get(node);
-        if (! ncStatsList.equals(currentStat)){
-            this.nodeConnectorStatistics.put(node, ncStatsList);
-        }
-    }
-
-    @Override
-    public void nodeTableStatisticsUpdated(Node node, List<NodeTableStatistics> tableStatsList) {
-        List<NodeTableStatistics> currentStat = this.tableStatistics.get(node);
-        if (! tableStatsList.equals(currentStat)) {
-            this.tableStatistics.put(node, tableStatsList);
-        }
-    }
-
-    @Override
-    public void descriptionStatisticsUpdated(Node node, NodeDescription nodeDescription) {
-        NodeDescription currentDesc = this.descriptionStatistics.get(node);
-        if (! nodeDescription.equals(currentDesc)){
-            this.descriptionStatistics.put(node, nodeDescription);
-        }
-    }
-
-    @Override
-    public void updateNode(Node node, UpdateType type, Set<Property> props) {
-        // If node is removed, clean up stats mappings
-        if (type == UpdateType.REMOVED) {
-            flowStatistics.remove(node);
-            nodeConnectorStatistics.remove(node);
-            tableStatistics.remove(node);
-            descriptionStatistics.remove(node);
-        }
-    }
-
-    @Override
-    public void updateNodeConnector(NodeConnector nodeConnector, UpdateType type, Set<Property> props) {
-        // Not interested in this update
-    }
-
-    public void unsetIConnectionManager(IConnectionManager s) {
-        if (s == this.connectionManager) {
-            this.connectionManager = null;
-        }
-    }
-
-    public void setIConnectionManager(IConnectionManager s) {
-        this.connectionManager = s;
-    }
-
-    @Override
-    public void entryCreated(Object key, String cacheName, boolean originLocal) {
-        /*
-         * Do nothing
-         */
-    }
-
-    @Override
-    public void entryUpdated(Object key, Object new_value, String cacheName, boolean originLocal) {
-        if (originLocal) {
-            /*
-             * Local updates are of no interest
-             */
-            return;
-        }
-        if (cacheName.equals(TRIGGERS_CACHE)) {
-            log.trace("Got a trigger for key {} : value {}", key, new_value);
-            final Node n = (Node) new_value;
-            // check if the node is local to this controller
-            ConnectionLocality locality = ConnectionLocality.NOT_LOCAL;
-            if(this.connectionManager != null) {
-                locality = this.connectionManager.getLocalityStatus(n);
-            }
-            if (locality == ConnectionLocality.LOCAL) {
-                log.trace("trigger for node {} processes locally", n);
-                // delete the trigger and proceed with handling the trigger
-                this.triggers.remove(key);
-                // this is a potentially long running task
-                // off load it from the listener thread
-                Runnable r = new Runnable() {
-                    @Override
-                    public void run() {
-                        // the node is local.
-                        // call the read service
-                        if (reader != null) {
-                            List<FlowOnNode> flows = reader.nonCachedReadAllFlows(n);
-                            if (flows != null) {
-                                flowStatistics.put(n, flows);
-                            }
-                        }
-                    }
-                };
-                // submit the runnable for execution
-                if(this.triggerExecutor != null) {
-                    this.triggerExecutor.execute(r);
-                }
-            }
-        } else if (cacheName.equals(FLOW_STATISTICS_CACHE)) {
-            // flow statistics cache updated
-            // get the node
-            log.trace("Got a flow statistics cache update for key {}", key);
-            // this is a short running task
-            // no need of off loading from the listener thread
-            final Node n = (Node) key;
-            // check if an outstanding trigger exists for this node
-            CountDownLatch l = this.latches.get(n);
-            if(l != null) {
-                // someone was waiting for this update
-                // let him know
-                l.countDown();
-            }
-        }
-    }
-
-    @Override
-    public void entryDeleted(Object key, String cacheName, boolean originLocal) {
-        /*
-         * Do nothing
-         */
-    }
-}
diff --git a/opendaylight/adsal/statisticsmanager/implementation/src/test/java/org/opendaylight/controller/statisticsmanager/internal/StatisticsManagerTest.java b/opendaylight/adsal/statisticsmanager/implementation/src/test/java/org/opendaylight/controller/statisticsmanager/internal/StatisticsManagerTest.java
deleted file mode 100644 (file)
index a09876e..0000000
+++ /dev/null
@@ -1,26 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.statisticsmanager.internal;
-
-import org.junit.Test;
-
-public class StatisticsManagerTest {
-
-    @Test
-    public void test() {
-        StatisticsManager sm = new StatisticsManager();
-
-        sm.init();
-        sm.start();
-        sm.stop();
-        sm.destroy();
-
-    }
-
-}
diff --git a/opendaylight/adsal/statisticsmanager/integrationtest/pom.xml b/opendaylight/adsal/statisticsmanager/integrationtest/pom.xml
deleted file mode 100644 (file)
index 00670cd..0000000
+++ /dev/null
@@ -1,172 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.integrationtest</artifactId>
-    <version>0.7.0-SNAPSHOT</version>
-    <relativePath>../../commons/integrationtest</relativePath>
-  </parent>
-
-  <artifactId>statisticsmanager.integrationtest</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <properties>
-    <sonar.jacoco.itReportPath>../../implementation/target/jacoco-it.exec</sonar.jacoco.itReportPath>
-    <!-- Sonar jacoco plugin to get integration test coverage info -->
-    <sonar.jacoco.reportPath>../../implementation/target/jacoco.exec</sonar.jacoco.reportPath>
-  </properties>
-  <dependencies>
-    <dependency>
-      <groupId>ch.qos.logback</groupId>
-      <artifactId>logback-classic</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>ch.qos.logback</groupId>
-      <artifactId>logback-core</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>clustering.services</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>clustering.stub</artifactId>
-    </dependency>
-
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>configuration</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>configuration.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>connectionmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>connectionmanager.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>containermanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>containermanager.it.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>forwardingrulesmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>hosttracker</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>protocol_plugins.stub</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal.connection</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal.connection.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>statisticsmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>statisticsmanager.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>switchmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>switchmanager.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>topologymanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.slf4j</groupId>
-      <artifactId>log4j-over-slf4j</artifactId>
-    </dependency>
-    <!-- Add Pax Exam -->
-    <dependency>
-      <groupId>org.ops4j.pax.exam</groupId>
-      <artifactId>pax-exam-container-native</artifactId>
-      <scope>test</scope>
-    </dependency>
-    <dependency>
-      <groupId>org.ops4j.pax.exam</groupId>
-      <artifactId>pax-exam-junit4</artifactId>
-      <scope>test</scope>
-    </dependency>
-    <dependency>
-      <groupId>org.ops4j.pax.exam</groupId>
-      <artifactId>pax-exam-link-mvn</artifactId>
-      <scope>test</scope>
-    </dependency>
-    <dependency>
-      <groupId>org.ops4j.pax.url</groupId>
-      <artifactId>pax-url-aether</artifactId>
-      <scope>test</scope>
-    </dependency>
-  </dependencies>
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.jacoco</groupId>
-        <artifactId>jacoco-maven-plugin</artifactId>
-        <configuration>
-          <destFile>../../implementation/target/jacoco-it.exec</destFile>
-          <includes>
-            <include>org.opendaylight.controller.*</include>
-          </includes>
-        </configuration>
-        <executions>
-          <execution>
-            <id>pre-test</id>
-            <goals>
-              <goal>prepare-agent</goal>
-            </goals>
-          </execution>
-          <execution>
-            <id>post-test</id>
-            <configuration>
-              <skip>true</skip>
-            </configuration>
-          </execution>
-        </executions>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/statisticsmanager/integrationtest/src/test/java/org/opendaylight/controller/statisticsmanager/internal/StatisticsManagerIT.java b/opendaylight/adsal/statisticsmanager/integrationtest/src/test/java/org/opendaylight/controller/statisticsmanager/internal/StatisticsManagerIT.java
deleted file mode 100644 (file)
index 18cce74..0000000
+++ /dev/null
@@ -1,337 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.statisticsmanager.internal;
-
-import static org.junit.Assert.assertFalse;
-import static org.junit.Assert.assertNotNull;
-import static org.junit.Assert.fail;
-import static org.ops4j.pax.exam.CoreOptions.junitBundles;
-import static org.ops4j.pax.exam.CoreOptions.mavenBundle;
-import static org.ops4j.pax.exam.CoreOptions.options;
-import static org.ops4j.pax.exam.CoreOptions.systemPackages;
-import static org.ops4j.pax.exam.CoreOptions.systemProperty;
-
-import java.net.InetAddress;
-import java.net.UnknownHostException;
-import java.util.ArrayList;
-import java.util.List;
-import java.util.Map;
-
-import javax.inject.Inject;
-
-import org.junit.Assert;
-import org.junit.Before;
-import org.junit.Test;
-import org.junit.runner.RunWith;
-import org.opendaylight.controller.forwardingrulesmanager.FlowEntry;
-import org.opendaylight.controller.sal.action.Action;
-import org.opendaylight.controller.sal.action.Drop;
-import org.opendaylight.controller.sal.core.ConstructionException;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.flowprogrammer.Flow;
-import org.opendaylight.controller.sal.match.Match;
-import org.opendaylight.controller.sal.match.MatchType;
-import org.opendaylight.controller.sal.reader.FlowOnNode;
-import org.opendaylight.controller.sal.reader.NodeConnectorStatistics;
-import org.opendaylight.controller.sal.reader.NodeDescription;
-import org.opendaylight.controller.statisticsmanager.IStatisticsManager;
-import org.ops4j.pax.exam.Option;
-import org.ops4j.pax.exam.Configuration;
-import org.ops4j.pax.exam.junit.PaxExam;
-import org.ops4j.pax.exam.util.PathUtils;
-import org.osgi.framework.Bundle;
-import org.osgi.framework.BundleContext;
-import org.osgi.framework.ServiceReference;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-@RunWith(PaxExam.class)
-public class StatisticsManagerIT {
-    private Logger log = LoggerFactory
-            .getLogger(StatisticsManagerIT.class);
-    // get the OSGI bundle context
-    @Inject
-    private BundleContext bc;
-
-    private IStatisticsManager manager = null;
-
-    // Configure the OSGi container
-    @Configuration
-    public Option[] config() {
-        return options(
-                //
-                systemProperty("logback.configurationFile").value(
-                        "file:" + PathUtils.getBaseDir()
-                                + "/src/test/resources/logback.xml"),
-                // To start OSGi console for inspection remotely
-                systemProperty("osgi.console").value("2401"),
-                // Set the systemPackages (used by clustering)
-                systemPackages("sun.reflect", "sun.reflect.misc", "sun.misc"),
-                // List framework bundles
-                mavenBundle("equinoxSDK381", "org.eclipse.equinox.console").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "org.eclipse.equinox.util").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "org.eclipse.osgi.services").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "org.eclipse.equinox.ds").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "org.apache.felix.gogo.command").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "org.apache.felix.gogo.runtime").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "org.apache.felix.gogo.shell").versionAsInProject(),
-                // List logger bundles
-                mavenBundle("org.slf4j", "slf4j-api").versionAsInProject(),
-                mavenBundle("org.slf4j", "log4j-over-slf4j")
-                        .versionAsInProject(),
-                mavenBundle("ch.qos.logback", "logback-core")
-                        .versionAsInProject(),
-                mavenBundle("ch.qos.logback", "logback-classic")
-                        .versionAsInProject(),
-                // needed by statisticsmanager
-                mavenBundle("org.opendaylight.controller", "containermanager")
-                    .versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "containermanager.it.implementation")
-                    .versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "clustering.services")
-                    .versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "clustering.stub")
-                    .versionAsInProject(),
-                // needed by forwardingrulesmanager
-                mavenBundle("org.opendaylight.controller", "configuration")
-                    .versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "configuration.implementation")
-                    .versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "hosttracker")
-                    .versionAsInProject(),
-
-                // List all the bundles on which the test case depends
-                mavenBundle("org.opendaylight.controller", "sal")
-                    .versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "sal.implementation")
-                    .versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "protocol_plugins.stub")
-                    .versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "switchmanager")
-                    .versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "switchmanager.implementation")
-                    .versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "statisticsmanager")
-                    .versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "statisticsmanager.implementation")
-                    .versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "forwardingrulesmanager")
-                    .versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "connectionmanager.implementation").
-                    versionAsInProject(),
-                mavenBundle("org.opendaylight.controller",  "connectionmanager").
-                    versionAsInProject(),
-                mavenBundle("org.opendaylight.controller",  "sal.connection").
-                    versionAsInProject(),
-                mavenBundle("org.opendaylight.controller",  "sal.connection.implementation").
-                    versionAsInProject(),
-
-                // needed by hosttracker
-                mavenBundle("org.opendaylight.controller", "topologymanager")
-                        .versionAsInProject(),
-                mavenBundle("org.jboss.spec.javax.transaction",
-                        "jboss-transaction-api_1.1_spec").versionAsInProject(),
-                mavenBundle("org.apache.commons", "commons-lang3")
-                        .versionAsInProject(),
-                mavenBundle("org.apache.felix",
-                        "org.apache.felix.dependencymanager")
-                        .versionAsInProject(), junitBundles());
-    }
-
-    private String stateToString(int state) {
-        switch (state) {
-        case Bundle.ACTIVE:
-            return "ACTIVE";
-        case Bundle.INSTALLED:
-            return "INSTALLED";
-        case Bundle.RESOLVED:
-            return "RESOLVED";
-        case Bundle.UNINSTALLED:
-            return "UNINSTALLED";
-        default:
-            return "Not CONVERTED";
-        }
-    }
-
-    @Before
-    public void areWeReady() {
-        assertNotNull(bc);
-        boolean debugit = false;
-        Bundle b[] = bc.getBundles();
-        for (int i = 0; i < b.length; i++) {
-            int state = b[i].getState();
-            if (state != Bundle.ACTIVE && state != Bundle.RESOLVED) {
-                log.debug("Bundle:" + b[i].getSymbolicName() + " state:"
-                        + stateToString(state));
-                debugit = true;
-            }
-        }
-        if (debugit) {
-            log.debug("Do some debugging because some bundle is "
-                    + "unresolved");
-        }
-
-        // Assert if true, if false we are good to go!
-        assertFalse(debugit);
-
-        ServiceReference r = bc.getServiceReference(IStatisticsManager.class
-                .getName());
-        if (r != null) {
-            this.manager = (IStatisticsManager) bc.getService(r);
-        }
-        // If StatisticsManager is null, cannot run tests.
-        assertNotNull(this.manager);
-
-    }
-
-    @Test
-    public void testGetFlows() {
-        try {
-            Node node = new Node("STUB", new Integer(0xCAFE));
-            List<FlowOnNode> flows = this.manager.getFlows(node);
-            FlowOnNode fn = flows.get(0);
-            Assert.assertTrue(fn.getByteCount() == 100);
-            Assert.assertTrue(fn.getDurationNanoseconds() == 400);
-            Assert.assertTrue(fn.getDurationSeconds() == 40);
-            Assert.assertTrue(fn.getTableId() == (byte) 0x1);
-            Assert.assertTrue(fn.getPacketCount() == 200);
-
-            Match match = new Match();
-            try {
-                match.setField(MatchType.NW_DST,
-                        InetAddress.getByName("1.1.1.1"));
-            } catch (UnknownHostException e) {
-                fail("Couldn't create match");
-            }
-            Assert.assertTrue(match.equals(fn.getFlow().getMatch()));
-            Assert.assertTrue(fn.getFlow().getActions().get(0)
-                    .equals(new Drop()));
-        } catch (ConstructionException e) {
-            // Got an unexpected exception
-            Assert.assertTrue(false);
-        }
-
-    }
-
-    @Test
-    public void testGetFlowStatistics() {
-        Flow flow = new Flow();
-
-        Match match = new Match();
-        try {
-            match.setField(MatchType.NW_DST, InetAddress.getByName("1.1.1.1"));
-        } catch (UnknownHostException e) {
-        }
-        flow.setMatch(match);
-        Action action = new Drop();
-
-        List<Action> actions = new ArrayList<Action>();
-        actions.add(action);
-        flow.setActions(actions);
-        // as in stub
-        flow.setPriority((short) 3500);
-        flow.setIdleTimeout((short) 1000);
-        flow.setHardTimeout((short) 2000);
-        flow.setId(12345);
-
-        try {
-            Node node = new Node("STUB", 0xCAFE);
-            FlowEntry fe = new FlowEntry("g1", "f1", flow, node);
-            List<FlowEntry> list = new ArrayList<FlowEntry>();
-            list.add(fe);
-            FlowEntry fe2 = new FlowEntry("g1", "f2", flow, node);
-            list.add(fe2);
-
-            Map<Node, List<FlowOnNode>> result = this.manager
-                    .getFlowStatisticsForFlowList(null);
-            Assert.assertTrue(result.isEmpty());
-            result = this.manager.getFlowStatisticsForFlowList(list);
-            List<FlowOnNode> results = result.get(node);
-            FlowOnNode fn = results.get(0);
-            Assert.assertTrue(fn.getByteCount() == 100);
-            Assert.assertTrue(fn.getDurationNanoseconds() == 400);
-            Assert.assertTrue(fn.getDurationSeconds() == 40);
-            Assert.assertTrue(fn.getTableId() == (byte) 0x1);
-            Assert.assertTrue(fn.getPacketCount() == 200);
-            Assert.assertTrue(fn.getFlow().equals(flow));
-        } catch (ConstructionException e) {
-            Assert.assertTrue(false);
-        }
-
-    }
-
-    @Test
-    public void testGetFlowsNumber() {
-        try {
-            Node node = new Node("STUB", 0xCAFE);
-            Assert.assertEquals(21, this.manager.getFlowsNumber(node));
-        }catch(ConstructionException e){
-            Assert.assertTrue(false);
-        }
-    }
-
-    @Test
-    public void testGetNodeDescription() {
-        try {
-            Node node = new Node("STUB", 0xCAFE);
-            NodeDescription desc = this.manager.getNodeDescription(node);
-            Assert.assertTrue(desc.getDescription().equals(
-                    "This is a sample node description"));
-            Assert.assertTrue(desc.getHardware().equals("stub hardware"));
-            Assert.assertTrue(desc.getSoftware().equals("stub software"));
-            Assert.assertTrue(desc.getSerialNumber().equals("123"));
-            Assert.assertTrue(desc.getManufacturer().equals("opendaylight"));
-        } catch (ConstructionException e) {
-            Assert.assertTrue(false);
-        }
-
-    }
-
-    @Test
-    public void testGetNodeConnectorStatistics() {
-        try {
-            Node node = new Node("STUB", 0xCAFE);
-            List<NodeConnectorStatistics> stats = this.manager
-                    .getNodeConnectorStatistics(node);
-            NodeConnectorStatistics ns = stats.get(0);
-            Assert.assertTrue(ns.getCollisionCount() == 4);
-            Assert.assertTrue(ns.getReceiveByteCount() == 1000);
-            Assert.assertTrue(ns.getReceiveCRCErrorCount() == 1);
-            Assert.assertTrue(ns.getReceiveDropCount() == 2);
-            Assert.assertTrue(ns.getReceiveErrorCount() == 3);
-            Assert.assertTrue(ns.getReceiveFrameErrorCount() == 5);
-            Assert.assertTrue(ns.getReceiveOverRunErrorCount() == 6);
-            Assert.assertTrue(ns.getReceivePacketCount() == 250);
-            Assert.assertTrue(ns.getTransmitByteCount() == 5000);
-            Assert.assertTrue(ns.getTransmitDropCount() == 50);
-            Assert.assertTrue(ns.getTransmitErrorCount() == 10);
-            Assert.assertTrue(ns.getTransmitPacketCount() == 500);
-
-            NodeConnector nc = ns.getNodeConnector();
-            NodeConnectorStatistics ns2 = this.manager
-                    .getNodeConnectorStatistics(nc);
-            Assert.assertTrue(ns2.getCollisionCount() == 4);
-            Assert.assertTrue(ns2.getReceiveByteCount() == 1000);
-            Assert.assertTrue(ns2.getReceiveCRCErrorCount() == 1);
-            Assert.assertTrue(ns2.getReceiveDropCount() == 2);
-            Assert.assertTrue(ns2.getReceiveErrorCount() == 3);
-            Assert.assertTrue(ns2.getReceiveFrameErrorCount() == 5);
-            Assert.assertTrue(ns2.getReceiveOverRunErrorCount() == 6);
-            Assert.assertTrue(ns2.getReceivePacketCount() == 250);
-            Assert.assertTrue(ns2.getTransmitByteCount() == 5000);
-            Assert.assertTrue(ns2.getTransmitDropCount() == 50);
-            Assert.assertTrue(ns2.getTransmitErrorCount() == 10);
-            Assert.assertTrue(ns2.getTransmitPacketCount() == 500);
-
-        } catch (ConstructionException e) {
-            Assert.assertTrue(false);
-        }
-    }
-
-}
diff --git a/opendaylight/adsal/statisticsmanager/integrationtest/src/test/resources/logback.xml b/opendaylight/adsal/statisticsmanager/integrationtest/src/test/resources/logback.xml
deleted file mode 100644 (file)
index 2d63ce5..0000000
+++ /dev/null
@@ -1,13 +0,0 @@
-<configuration scan="true">
-
-  <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
-    <encoder>
-      <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n
-      </pattern>
-    </encoder>
-  </appender>
-
-  <root level="error">
-    <appender-ref ref="STDOUT" />
-  </root>
-</configuration>
diff --git a/opendaylight/adsal/switchmanager/api/pom.xml b/opendaylight/adsal/switchmanager/api/pom.xml
deleted file mode 100644 (file)
index a0824ce..0000000
+++ /dev/null
@@ -1,97 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>switchmanager</artifactId>
-  <version>0.9.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-
-  <properties>
-    <!-- Sonar properties using jacoco to retrieve integration test results -->
-    <sonar.dynamicAnalysis>reuseReports</sonar.dynamicAnalysis>
-    <sonar.jacoco.Reportpath>target/jacoco.exec</sonar.jacoco.Reportpath>
-    <sonar.jacoco.itReportPath>target/jacoco-it.exec</sonar.jacoco.itReportPath>
-  </properties>
-  <dependencies>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>configuration</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-      <scope>test</scope>
-    </dependency>
-  </dependencies>
-  <build>
-    <pluginManagement>
-      <plugins>
-        <plugin>
-          <groupId>org.jacoco</groupId>
-          <artifactId>jacoco-maven-plugin</artifactId>
-          <version>${jacoco.version}</version>
-        </plugin>
-      </plugins>
-    </pluginManagement>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Export-Package>org.opendaylight.controller.switchmanager</Export-Package>
-            <Import-Package>org.opendaylight.controller.configuration,
-              org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.sal.utils,
-              org.opendaylight.controller.sal.packet,
-              org.opendaylight.controller.sal.inventory,
-              org.slf4j,
-              javax.xml.bind.annotation</Import-Package>
-          </instructions>
-          <manifestLocation>${project.basedir}/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-      <plugin>
-        <groupId>org.jacoco</groupId>
-        <artifactId>jacoco-maven-plugin</artifactId>
-        <configuration>
-          <includes>
-            <include>org.opendaylight.controller.*</include>
-          </includes>
-        </configuration>
-        <executions>
-          <execution>
-            <id>pre-test</id>
-            <goals>
-              <goal>prepare-agent</goal>
-            </goals>
-          </execution>
-          <execution>
-            <id>post-test</id>
-            <goals>
-              <goal>report</goal>
-            </goals>
-            <phase>test</phase>
-          </execution>
-        </executions>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/switchmanager/api/src/main/java/org/opendaylight/controller/switchmanager/IInventoryListener.java b/opendaylight/adsal/switchmanager/api/src/main/java/org/opendaylight/controller/switchmanager/IInventoryListener.java
deleted file mode 100644 (file)
index 29d0a42..0000000
+++ /dev/null
@@ -1,46 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.switchmanager;
-
-import java.util.Map;
-
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.core.UpdateType;
-
-/**
- * Primary purpose of this interface is to provide methods to listen to inventory changes
- */
-public interface IInventoryListener {
-    /**
-     * This method is called when some properties of a node are added/deleted/changed.
-     *
-     * @param node                      {@link org.opendaylight.controller.sal.core.Node} being updated
-     * @param type              {@link org.opendaylight.controller.sal.core.UpdateType}
-     * @param propMap           map of {@link org.opendaylight.controller.sal.core.Property} such as
-     *                                          {@link org.opendaylight.controller.sal.core.Description} and/or
-     *                                          {@link org.opendaylight.controller.sal.core.Tier} etc.
-     */
-    public void notifyNode(Node node, UpdateType type,
-            Map<String, Property> propMap);
-
-    /**
-     * This method is called when some properties of a node connector are added/deleted/changed.
-     *
-     * @param nodeConnector {@link org.opendaylight.controller.sal.core.NodeConnector} being updated
-     * @param type              {@link org.opendaylight.controller.sal.core.UpdateType}
-     * @param propMap           map of {@link org.opendaylight.controller.sal.core.Property} such as
-     *                                          {@link org.opendaylight.controller.sal.core.Description} and/or
-     *                                          {@link org.opendaylight.controller.sal.core.State} etc.
-     */
-    public void notifyNodeConnector(NodeConnector nodeConnector,
-            UpdateType type, Map<String, Property> propMap);
-}
diff --git a/opendaylight/adsal/switchmanager/api/src/main/java/org/opendaylight/controller/switchmanager/ISpanAware.java b/opendaylight/adsal/switchmanager/api/src/main/java/org/opendaylight/controller/switchmanager/ISpanAware.java
deleted file mode 100644 (file)
index 1e4a79f..0000000
+++ /dev/null
@@ -1,30 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.switchmanager;
-
-import java.util.List;
-
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-
-/**
- * The interface provides the methods for notifying when span ports
- * are configured/unconfigured.
- */
-public interface ISpanAware {
-    /**
-     * This method is called when list of ports in a node are added/deleted as span ports.
-     *
-     * @param node      {@link org.opendaylight.controller.sal.core.Node} being updated
-     * @param portList  list of span {@link org.opendaylight.controller.sal.core.NodeConnector}
-     * @param add       true if add; false if delete.
-     */
-    public void spanUpdate(Node node, List<NodeConnector> portList, boolean add);
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/switchmanager/api/src/main/java/org/opendaylight/controller/switchmanager/ISwitchManager.java b/opendaylight/adsal/switchmanager/api/src/main/java/org/opendaylight/controller/switchmanager/ISwitchManager.java
deleted file mode 100644 (file)
index 072544c..0000000
+++ /dev/null
@@ -1,435 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.switchmanager;
-
-import java.net.InetAddress;
-import java.util.List;
-import java.util.Map;
-import java.util.Set;
-
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.utils.Status;
-
-/**
- * Primary purpose of this interface is to provide methods for application to
- * access various system resources and inventory data including nodes, node
- * connectors and their properties, Layer3 configurations, Span configurations,
- * node configurations, network device representations viewed by Controller Web
- * applications.
- */
-public interface ISwitchManager {
-    /**
-     * Add a subnet configuration
-     *
-     * @param  configObject refer to {@link Open Declaration org.opendaylight.controller.switchmanager.SubnetConfig}
-     * @return the Status object representing the result of the request
-     */
-    public Status addSubnet(SubnetConfig configObject);
-
-    /**
-     * Remove a subnet configuration
-     *
-     * @param  configObject refer to {@link Open Declaration org.opendaylight.controller.switchmanager.SubnetConfig}
-     * @return the Status object representing the result of the request
-     */
-    public Status removeSubnet(SubnetConfig configObject);
-
-    /**
-     * Modify a subnet configuration
-     *
-     * @param  configObject refer to {@link Open Declaration org.opendaylight.controller.switchmanager.SubnetConfig}
-     * @return the Status object representing the result of the request
-     */
-    public Status modifySubnet(SubnetConfig configObject);
-
-    /**
-     * Remove a subnet configuration given the name
-     *
-     * @param   name      subnet name
-     * @return  "Success" or failure reason
-     */
-    public Status removeSubnet(String name);
-
-    /**
-     * Return a list of all known devices in the system
-     *
-     * @return  returns a list of {@link org.opendaylight.controller.switchmanager.Switch}
-     */
-    public List<Switch> getNetworkDevices();
-
-    /**
-     * Return a Set of all configured devices that are not connected to the controller
-     *
-     * @return Set of {@link org.opendaylight.controller.switchmanager.Switch}
-     */
-    public Set<Switch> getConfiguredNotConnectedSwitches();
-
-    /**
-     * Return a list of subnet that were previously configured
-     *
-     * @return list of L3 interface {@link org.opendaylight.controller.switchmanager.SubnetConfig} configurations
-     */
-    public List<SubnetConfig> getSubnetsConfigList();
-
-    /**
-     * Return the subnet configuration
-     *
-     * @param   subnet      subnet
-     * @return a L3 interface {@link org.opendaylight.controller.switchmanager.SubnetConfig} configuration
-     */
-    public SubnetConfig getSubnetConfig(String subnet);
-
-    /**
-     * Return a subnet configuration given the network address
-     *
-     * @param networkAddress    the ip address in long format
-     * @return                                  the {@link org.opendaylight.controller.switchmanager.Subnet}
-     */
-    public Subnet getSubnetByNetworkAddress(InetAddress networkAddress);
-
-    /**
-     * Save the current switch configurations
-     *
-     * @return the status code
-     */
-    public Status saveSwitchConfig();
-
-    /**
-     * Add a span port configuration
-     *
-     * @param SpanConfig refer to {@link Open Declaration org.opendaylight.controller.switchmanager.SpanConfig}
-     * @return              status code
-     */
-    public Status addSpanConfig(SpanConfig configObject);
-
-    /**
-     * Remove a span port configuration
-     *
-     * @param SpanConfig refer to {@link Open Declaration org.opendaylight.controller.switchmanager.SpanConfig}
-     * @return              status code
-     */
-    public Status removeSpanConfig(SpanConfig cfgObject);
-
-    /**
-     * Return a list of span configurations that were configured previously
-     *
-     * @return list of {@link org.opendaylight.controller.switchmanager.SpanConfig} resources
-     */
-    public List<SpanConfig> getSpanConfigList();
-
-    /**
-     * Return the list of span ports of a given node
-     *
-     * @param node {@link org.opendaylight.controller.sal.core.Node}
-     * @return the list of span {@link org.opendaylight.controller.sal.core.NodeConnector} of the node
-     */
-    public List<NodeConnector> getSpanPorts(Node node);
-
-    /**
-     * Update Switch specific configuration such as Switch Name and Tier
-     *
-     * @param cfgConfig refer to {@link Open Declaration org.opendaylight.controller.switchmanager.SwitchConfig}
-     *
-     * @deprecated replaced by updateNodeConfig(switchConfig)
-     */
-    @Deprecated
-    public void updateSwitchConfig(SwitchConfig cfgObject);
-
-    /**
-     * Update Node specific configuration such as Node Name and Tier
-     *
-     * @param cfgConfig
-     *            refer to {@link Open Declaration
-     *            org.opendaylight.controller.switchmanager.SwitchConfig}
-     * @return "Success" or failure reason
-     */
-    public Status updateNodeConfig(SwitchConfig switchConfig);
-
-    /**
-     * Removes node properties configured by the user
-     *
-     * @param nodeId
-     *            Node Identifier as specified by
-     *            {@link org.opendaylight.controller.sal.core.Node}
-     * @return "Success" or failure reason
-     */
-    public Status removeNodeConfig(String nodeId);
-
-    /**
-     * Return the previously configured Switch Configuration given the node id
-     *
-     * @param nodeId
-     *            Node Identifier as specified by
-     *            {@link org.opendaylight.controller.sal.core.Node}
-     * @return {@link org.opendaylight.controller.switchmanager.SwitchConfig}
-     *         resources
-     */
-    public SwitchConfig getSwitchConfig(String nodeId);
-
-    /**
-     * Add node connectors to a subnet
-     *
-     * @param name The configured subnet name
-     * @param nodeConnectors list of string each representing a node connector as specified by {@link Open Declaration org.opendaylight.controller.sal.core.NodeConnector}
-     * @return The Status object indicating the result of this request
-     */
-    public Status addPortsToSubnet(String name, List<String> nodeConnectors);
-
-    /**
-     * Remove node connectors from a subnet
-     *
-     * @param name              the configured subnet name
-     * @param nodeConnectors    list of string each representing a node connector as specified by {@link Open Declaration org.opendaylight.controller.sal.core.NodeConnector}
-     * @return The Status object indicating the result of this request
-     */
-    public Status removePortsFromSubnet(String name, List<String> nodeConnectors);
-
-    /**
-     * Return the set of all the nodes
-     *
-     * @return set of {@link org.opendaylight.controller.sal.core.Node}
-     */
-    public Set<Node> getNodes();
-
-    /**
-     * Return all the properties of a node
-     *
-     * @param node {@link org.opendaylight.controller.sal.core.Node}
-     * @return map of {@link org.opendaylight.controller.sal.core.Property} such as
-     *             {@link org.opendaylight.controller.sal.core.Description} and/or
-     *             {@link org.opendaylight.controller.sal.core.Tier} etc.
-     */
-    public Map<String, Property> getNodeProps(Node node);
-
-    /**
-     * Return a specific property of a node given the property name
-     *
-     * @param node              {@link org.opendaylight.controller.sal.core.Node}
-     * @param propName  the property name specified by {@link org.opendaylight.controller.sal.core.Property} and its extended classes
-     * @return {@link org.opendaylight.controller.sal.core.Property}
-     */
-    public Property getNodeProp(Node node, String propName);
-
-    /**
-     * Set a specific property of a node
-     *
-     * @param node              {@link org.opendaylight.controller.sal.core.Node}
-     * @param prop              {@link org.opendaylight.controller.sal.core.Property}
-     */
-    public void setNodeProp(Node node, Property prop);
-
-    /**
-     * Remove a property of a node
-     *
-     * @param nc                {@link org.opendaylight.controller.sal.core.Node}
-     * @param propName  the property name specified by {@link org.opendaylight.controller.sal.core.Property} and its extended classes
-     * @return success or failed reason
-     */
-    public Status removeNodeProp(Node node, String propName);
-
-    /**
-     * Remove all the properties of a node
-     *
-     * @param node {@link org.opendaylight.controller.sal.core.Node}
-     * @return success or failed reason
-     */
-    public Status removeNodeAllProps(Node node);
-
-    /**
-     * Return all the node connectors in up state for a given node
-     *
-     * @param node {@link org.opendaylight.controller.sal.core.Node}
-     * @return set of {@link org.opendaylight.controller.sal.core.NodeConnector}
-     */
-    public Set<NodeConnector> getUpNodeConnectors(Node node);
-
-    /**
-     * Return all the node connectors including those special ones. Status of each node connector varies.
-     *
-     * @param node {@link org.opendaylight.controller.sal.core.Node}
-     * @return all listed {@link org.opendaylight.controller.sal.core.NodeConnector}
-     */
-    public Set<NodeConnector> getNodeConnectors(Node node);
-
-    /**
-     * Return all the physical node connectors of a node. Status of each node connector varies.
-     *
-     * @param node {@link org.opendaylight.controller.sal.core.Node}
-     * @return all physical {@link org.opendaylight.controller.sal.core.NodeConnector}
-     */
-    public Set<NodeConnector> getPhysicalNodeConnectors(Node node);
-
-    /**
-     * Return all the properties of a node connector
-     *
-     * @param nodeConnector {@link org.opendaylight.controller.sal.core.NodeConnector}
-     * @return map of {@link org.opendaylight.controller.sal.core.Property} such as
-     *             {@link org.opendaylight.controller.sal.core.Description} and/or
-     *             {@link org.opendaylight.controller.sal.core.State} etc.
-     */
-    public Map<String, Property> getNodeConnectorProps(
-            NodeConnector nodeConnector);
-
-    /**
-     * Return a specific property of a node connector given the property name
-     *
-     * @param nodeConnector {@link org.opendaylight.controller.sal.core.NodeConnector}
-     * @param propName property name specified by {@link org.opendaylight.controller.sal.core.Property} and its extended classes
-     * @return {@link org.opendaylight.controller.sal.core.Property}
-     */
-    public Property getNodeConnectorProp(NodeConnector nodeConnector,
-            String propName);
-
-    /**
-     * Add a node connector and its property
-     *
-     * @param nodeConnector {@link org.opendaylight.controller.sal.core.NodeConnector}
-     * @param prop {@link org.opendaylight.controller.sal.core.Property}
-     * @return success or failed reason
-     */
-    public Status addNodeConnectorProp(NodeConnector nodeConnector,
-            Property prop);
-
-    /**
-     * Remove a property of a node connector
-     *
-     * @param nc {@link org.opendaylight.controller.sal.core.NodeConnector}
-     * @param propName property name specified by {@link org.opendaylight.controller.sal.core.Property} and its extended classes
-     * @return success or failed reason
-     */
-    public Status removeNodeConnectorProp(NodeConnector nc, String propName);
-
-    /**
-     * Remove all the properties of a node connector
-     *
-     * @param nodeConnector {@link org.opendaylight.controller.sal.core.NodeConnector}
-     * @return success or failed reason
-     */
-    public Status removeNodeConnectorAllProps(NodeConnector nodeConnector);
-
-    /**
-     * Return the node connector given its name
-     *
-     * @param node                              {@link org.opendaylight.controller.sal.core.Node}
-     * @param nodeConnectorName node connector identifier specified by {@link org.opendaylight.controller.sal.core.NodeConnector}
-     * @return {@link org.opendaylight.controller.sal.core.NodeConnector}
-     */
-    public NodeConnector getNodeConnector(Node node, String nodeConnectorName);
-
-    /**
-     * Return whether the specified node connector is a special node port
-     * Example of node's special node connector are software stack, hardware path, controller...
-     *
-     * @param p {@link org.opendaylight.controller.sal.core.NodeConnector}
-     * @return true or false
-     */
-    public boolean isSpecial(NodeConnector p);
-
-    /**
-     * Check if the node connector is up running
-     *
-     * @param nodeConnector {@link org.opendaylight.controller.sal.core.NodeConnector}
-     * @return true or false
-     */
-    public Boolean isNodeConnectorEnabled(NodeConnector nodeConnector);
-
-    /**
-     * Test whether the given node connector exists.
-     *
-     * @param nc  {@link org.opendaylight.controller.sal.core.NodeConnector}
-     * @return    True if exists, false otherwise.
-     */
-    public boolean doesNodeConnectorExist(NodeConnector nc);
-
-    /**
-     * Return controller MAC address
-         *
-     * @return MAC address in byte array
-     */
-    public byte[] getControllerMAC();
-
-    /**
-     * Return MAC address for a given node
-     *
-     * @param node  {@link org.opendaylight.controller.sal.core.Node}
-     * @return MAC address in byte array
-     */
-    public byte[] getNodeMAC(Node node);
-
-    /**
-     * Create a Name/Tier/Bandwidth Property object based on given property name
-     * and value. Other property types are not supported yet.
-     *
-     * @param propName
-     *            Name of the Property specified by
-     *            {@link org.opendaylight.controller.sal.core.Property} and its
-     *            extended classes
-     * @param propValue
-     *            Value of the Property specified by
-     *            {@link org.opendaylight.controller.sal.core.Property} and its
-     *            extended classes
-     * @return {@link org.opendaylight.controller.sal.core.Property}
-     */
-    public Property createProperty(String propName, String propValue);
-
-    /**
-     * Returns the description for the specified node. It is either the one
-     * configured by user or the description advertised by the node.
-     *
-     * @param node the network node identifier
-     * @return the description of the specified node. If no description is
-     * configured and the network node does not provide its description,
-     * an empty string is returned.
-     */
-    @Deprecated
-    public String getNodeDescription(Node node);
-
-    /**
-     * Return all the properties of the controller
-     *
-     * @return map of {@link org.opendaylight.controller.sal.core.Property} such
-     *         as {@link org.opendaylight.controller.sal.core.Description}
-     *         and/or {@link org.opendaylight.controller.sal.core.Tier} etc.
-     */
-    public Map<String, Property> getControllerProperties();
-
-    /**
-     * Return a specific property of the controller given the property name
-     *
-     * @param propName
-     *            the property name specified by
-     *            {@link org.opendaylight.controller.sal.core.Property} and its
-     *            extended classes
-     * @return {@link org.opendaylight.controller.sal.core.Property}
-     */
-    public Property getControllerProperty(String propertyName);
-
-    /**
-     * Set a specific property of the controller
-     *
-     * @param property
-     *            {@link org.opendaylight.controller.sal.core.Property}
-     * @return
-     */
-    public Status setControllerProperty(Property property);
-
-    /**
-     * Remove a property of a node
-     *
-     * @param propertyName
-     *            the property name specified by
-     *            {@link org.opendaylight.controller.sal.core.Property} and its
-     *            extended classes
-     * @return success or failed reason
-     */
-    public Status removeControllerProperty(String propertyName);
-}
diff --git a/opendaylight/adsal/switchmanager/api/src/main/java/org/opendaylight/controller/switchmanager/ISwitchManagerAware.java b/opendaylight/adsal/switchmanager/api/src/main/java/org/opendaylight/controller/switchmanager/ISwitchManagerAware.java
deleted file mode 100644 (file)
index 4fde7a9..0000000
+++ /dev/null
@@ -1,35 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.switchmanager;
-
-import org.opendaylight.controller.sal.core.Node;
-
-
-/**
- * The interface provides methods to notify listeners about subnet and mode
- * changes.
- */
-public interface ISwitchManagerAware {
-    /**
-     * The method is called when subnet is added/deleted
-     *
-     * @param sub {@link org.opendaylight.controller.switchmanager.Subnet}
-     * @param add true if add; false if delete.
-     */
-    public void subnetNotify(Subnet sub, boolean add);
-
-    /**
-     * The method is called when proactive/reactive mode is changed in a node
-     *
-     * @param node {@link org.opendaylight.controller.sal.core.Node}
-     * @param proactive true if mode is set as proactive; false if mode is reactive.
-     */
-    public void modeChangeNotify(Node node, boolean proactive);
-}
diff --git a/opendaylight/adsal/switchmanager/api/src/main/java/org/opendaylight/controller/switchmanager/SpanConfig.java b/opendaylight/adsal/switchmanager/api/src/main/java/org/opendaylight/controller/switchmanager/SpanConfig.java
deleted file mode 100644 (file)
index eeccf10..0000000
+++ /dev/null
@@ -1,144 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.switchmanager;
-
-import java.io.Serializable;
-import java.lang.reflect.Field;
-import java.util.ArrayList;
-import java.util.List;
-
-import org.opendaylight.controller.configuration.ConfigurationObject;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.utils.GUIField;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * The class represents a Span Port configuration for a network node.
- */
-public class SpanConfig extends ConfigurationObject implements Serializable {
-    protected static final Logger logger = LoggerFactory
-    .getLogger(SpanConfig.class);
-    private static final long serialVersionUID = 1L;
-    private static final String guiFields[] = { GUIField.NODE.toString(),
-            GUIField.SPANPORTS.toString() };
-
-    // Order matters: JSP file expects following fields in the following order
-    private String nodeId;
-    private String spanPort;
-
-    public SpanConfig() {
-    }
-
-    public String getNodeId() {
-        return nodeId;
-    }
-
-    public String getSpanPort() {
-        return spanPort;
-    }
-
-    public Node getNode() {
-        return Node.fromString(nodeId);
-    }
-
-    private boolean hasValidNodeId() {
-        return (getNode() != null);
-    }
-
-    private boolean hasValidSpanPort() {
-        return (spanPort != null && !spanPort.isEmpty());
-    }
-
-    public boolean isValidConfig() {
-        return (hasValidNodeId() && hasValidSpanPort());
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + ((nodeId == null) ? 0 : nodeId.hashCode());
-        result = prime * result
-                + ((spanPort == null) ? 0 : spanPort.hashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        SpanConfig other = (SpanConfig) obj;
-        if (nodeId == null) {
-            if (other.nodeId != null) {
-                return false;
-            }
-        } else if (!nodeId.equals(other.nodeId)) {
-            return false;
-        }
-        if (spanPort == null) {
-            if (other.spanPort != null) {
-                return false;
-            }
-        } else if (!spanPort.equals(other.spanPort)) {
-            return false;
-        }
-        return true;
-    }
-
-    public static ArrayList<String> getFieldsNames() {
-        ArrayList<String> fieldList = new ArrayList<String>();
-        for (Field fld : SpanConfig.class.getDeclaredFields()) {
-            fieldList.add(fld.getName());
-        }
-        //remove the two static fields
-        for (short i = 0; i < 2; i++) {
-            fieldList.remove(0);
-        }
-        return fieldList;
-    }
-
-    public static List<String> getGuiFieldsNames() {
-        List<String> fieldList = new ArrayList<String>();
-        for (String str : guiFields) {
-            fieldList.add(str);
-        }
-        return fieldList;
-    }
-
-    public ArrayList<NodeConnector> getPortArrayList() {
-        ArrayList<NodeConnector> portList = new ArrayList<NodeConnector>();
-        String[] elemArray = spanPort.split(",");
-        for (String elem : elemArray) {
-            NodeConnector nodeConnector = NodeConnector.fromString(elem);
-            if (nodeConnector != null) {
-                portList.add(nodeConnector);
-            }
-        }
-        return portList;
-    }
-
-    public boolean matchNode(String nodeId) {
-        return this.nodeId.equals(nodeId);
-    }
-
-    @Override
-    public String toString() {
-        return ("SpanConfig [nodeId=" + nodeId + ", spanPort=" + spanPort + "]");
-    }
-}
diff --git a/opendaylight/adsal/switchmanager/api/src/main/java/org/opendaylight/controller/switchmanager/Subnet.java b/opendaylight/adsal/switchmanager/api/src/main/java/org/opendaylight/controller/switchmanager/Subnet.java
deleted file mode 100644 (file)
index 2794109..0000000
+++ /dev/null
@@ -1,262 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.switchmanager;
-
-import java.io.Serializable;
-import java.net.InetAddress;
-import java.net.UnknownHostException;
-import java.util.HashSet;
-import java.util.Set;
-
-import org.opendaylight.controller.sal.core.NodeConnector;
-
-/**
- * The class describes subnet information including L3 address, vlan and set of
- * ports associated with the subnet.
- */
-public class Subnet implements Cloneable, Serializable {
-    private static final long serialVersionUID = 1L;
-    // Key fields
-    private InetAddress networkAddress;
-    private transient InetAddress subnetPrefix;
-    private short subnetMaskLength;
-    // Property fields
-    private short vlan;
-    private final Set<NodeConnector> nodeConnectors;
-
-    public Subnet(InetAddress ip, short maskLen, short vlan) {
-        this.networkAddress = ip;
-        this.subnetMaskLength = maskLen;
-        this.vlan = vlan;
-        this.nodeConnectors = new HashSet<NodeConnector>();
-    }
-
-    public Subnet(SubnetConfig conf) {
-        networkAddress = conf.getIPAddress();
-        subnetMaskLength = conf.getIPMaskLen();
-        nodeConnectors = conf.getNodeConnectors();
-    }
-
-    public Subnet(Subnet subnet) {
-        networkAddress = subnet.networkAddress;
-        subnetMaskLength = subnet.subnetMaskLength;
-        vlan = subnet.vlan;
-        nodeConnectors = new HashSet<NodeConnector>(subnet.nodeConnectors);
-    }
-
-    /**
-     * Add NodeConnectors to a subnet
-     *
-     * @param sp Set of NodeConnectors to add to the subnet
-     */
-    public void addNodeConnectors(Set<NodeConnector> sp) {
-        if (sp != null) {
-            this.nodeConnectors.addAll(sp);
-        }
-    }
-
-    /**
-     * Delete NodeConnectors from subnet
-     *
-     * @param sp Set of NodeConnectors to add to the subnet
-     */
-    public void deleteNodeConnectors(Set<NodeConnector> sp) {
-        if (sp == null) {
-            return;
-        }
-        for (NodeConnector p : sp) {
-            this.nodeConnectors.remove(p);
-        }
-    }
-
-    /**
-     * Return the list of NodeConnectors configured for this subnet,
-     * could be also an empty set in case of all the known
-     * nodeconnectors.
-     *
-     *
-     * @return The list of NodeConnectors attached to the subnet
-     */
-    public Set<NodeConnector> getNodeConnectors() {
-        return this.nodeConnectors;
-    }
-
-    /**
-     * If the subnet has no node connectors attached to it then it
-     * means that is a whole L2 flat domain
-     *
-     *
-     * @return true if there are no node connectors configured for the
-     * subnet else false
-     */
-    public boolean isFlatLayer2() {
-        return nodeConnectors.isEmpty();
-    }
-
-    /**
-     * getter method
-     *
-     *
-     * @return the Network Address part of the subnet
-     */
-    public InetAddress getNetworkAddress() {
-        return networkAddress;
-    }
-
-    /**
-     * @param networkAddress the networkAddress to set
-     */
-    public Subnet setNetworkAddress(InetAddress networkAddress) {
-        this.networkAddress = networkAddress;
-        this.subnetPrefix = null;
-        return this;
-    }
-
-    /**
-     * getter method
-     *
-     *
-     * @return the subnet mask length
-     */
-    public short getSubnetMaskLength() {
-        return this.subnetMaskLength;
-    }
-
-    public Subnet setSubnetMaskLength(short m) {
-        this.subnetMaskLength = m;
-        return this;
-    }
-
-    /*
-     * returns the prefix of a given IP by applying this subnet's mask
-     */
-    private InetAddress getPrefixForAddress(InetAddress ip) {
-        int bytes = this.subnetMaskLength / 8;
-        int bits = this.subnetMaskLength % 8;
-        byte modifiedByte;
-        byte[] sn = ip.getAddress();
-        if (bits > 0) {
-            modifiedByte = (byte) (sn[bytes] >> (8 - bits));
-            sn[bytes] = (byte) (modifiedByte << (8 - bits));
-            bytes++;
-        }
-        for (; bytes < sn.length; bytes++) {
-            sn[bytes] = (byte) (0);
-        }
-        try {
-            return InetAddress.getByAddress(sn);
-        } catch (UnknownHostException e) {
-            return null;
-        }
-    }
-
-    public boolean isSubnetOf(InetAddress ip) {
-        if (ip == null) {
-            return false;
-        }
-        if(subnetPrefix == null) {
-            subnetPrefix = getPrefixForAddress(this.networkAddress);
-        }
-        InetAddress otherPrefix = getPrefixForAddress(ip);
-        boolean isSubnetOf = true;
-        if (((subnetPrefix == null) || (otherPrefix == null)) || (!subnetPrefix.equals(otherPrefix)) ) {
-            isSubnetOf = false;
-        }
-        return isSubnetOf;
-    }
-
-    public short getVlan() {
-        return this.vlan;
-    }
-
-    public Subnet setVlan(short i) {
-        this.vlan = i;
-        return this;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result
-                + ((networkAddress == null) ? 0 : networkAddress.hashCode());
-        result = prime * result
-                + ((nodeConnectors == null) ? 0 : nodeConnectors.hashCode());
-        result = prime * result + subnetMaskLength;
-        result = prime * result + vlan;
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        Subnet other = (Subnet) obj;
-        if (networkAddress == null) {
-            if (other.networkAddress != null) {
-                return false;
-            }
-        } else if (!networkAddress.equals(other.networkAddress)) {
-            return false;
-        }
-        if (nodeConnectors == null) {
-            if (other.nodeConnectors != null) {
-                return false;
-            }
-        } else if (!nodeConnectors.equals(other.nodeConnectors)) {
-            return false;
-        }
-        if (subnetMaskLength != other.subnetMaskLength) {
-            return false;
-        }
-        if (vlan != other.vlan) {
-            return false;
-        }
-        return true;
-    }
-
-    /* (non-Javadoc)
-     * @see java.lang.Object#toString()
-     */
-    @Override
-    public String toString() {
-        return ("Subnet [networkAddress=" + networkAddress.getHostAddress()
-                + "/" + subnetMaskLength
-                + ((vlan == 0) ? "" : (", vlan=" + vlan)) + ", "
-                + ((isFlatLayer2()) ? "{[*, *]}" : nodeConnectors.toString()) + "]");
-    }
-
-    public boolean hasNodeConnector(NodeConnector p) {
-        if (p == null) {
-            return false;
-        }
-        return isFlatLayer2() || nodeConnectors.contains(p);
-    }
-
-    public boolean isMutualExclusive(Subnet otherSubnet) {
-        return !(isSubnetOf(otherSubnet.getNetworkAddress()) || otherSubnet.isSubnetOf(getNetworkAddress()));
-    }
-
-    /**
-     * Implement clonable interface
-     */
-    @Override
-    public Subnet clone() {
-        return new Subnet(this);
-    }
-
-}
diff --git a/opendaylight/adsal/switchmanager/api/src/main/java/org/opendaylight/controller/switchmanager/SubnetConfig.java b/opendaylight/adsal/switchmanager/api/src/main/java/org/opendaylight/controller/switchmanager/SubnetConfig.java
deleted file mode 100644 (file)
index b3dead5..0000000
+++ /dev/null
@@ -1,261 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.switchmanager;
-
-import java.io.Serializable;
-import java.net.InetAddress;
-import java.net.UnknownHostException;
-import java.util.ArrayList;
-import java.util.List;
-import java.util.Set;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.configuration.ConfigurationObject;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.packet.BitBufferHelper;
-import org.opendaylight.controller.sal.utils.GUIField;
-import org.opendaylight.controller.sal.utils.NetUtils;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.sal.utils.StatusCode;
-
-/**
- * The class represents a subnet configuration.
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-public class SubnetConfig extends ConfigurationObject implements Cloneable, Serializable {
-    private static final long serialVersionUID = 1L;
-    private static final String prettyFields[] = { GUIField.NAME.toString(), GUIField.GATEWAYIP.toString(),
-            GUIField.NODEPORTS.toString() };
-
-    /**
-     * Name of the subnet
-     */
-    @XmlElement
-    private String name;
-    /**
-     * A.B.C.D/MM Where A.B.C.D is the Default Gateway IP (L3) or ARP Querier IP
-     * (L2)
-     */
-    @XmlElement
-    private String subnet;
-    /**
-     * Set of node connectors in the format: Port Type|Port Id@Node Type|Node Id
-     */
-    @XmlElement
-    private List<String> nodeConnectors;
-
-    public SubnetConfig() {
-    }
-
-    public SubnetConfig(String name, String subnet, List<String> nodeConnectors) {
-        this.name = name;
-        this.subnet = subnet;
-        this.nodeConnectors = nodeConnectors;
-    }
-
-    public SubnetConfig(SubnetConfig subnetConfig) {
-        name = subnetConfig.name;
-        subnet = subnetConfig.subnet;
-        nodeConnectors = (subnetConfig.nodeConnectors == null) ? null : new ArrayList<String>(
-                subnetConfig.nodeConnectors);
-    }
-
-    public String getName() {
-        return name;
-    }
-
-    public List<String> getNodePorts() {
-        return (nodeConnectors == null) ? new ArrayList<String>(0) : new ArrayList<String>(nodeConnectors);
-    }
-
-    public String getSubnet() {
-        return subnet;
-    }
-
-    public InetAddress getIPAddress() {
-        InetAddress ip = null;
-        try {
-            ip = InetAddress.getByName(subnet.split("/")[0]);
-        } catch (UnknownHostException e1) {
-            return null;
-        }
-        return ip;
-    }
-
-    public Short getIPMaskLen() {
-        Short maskLen = 0;
-        String[] s = subnet.split("/");
-
-        try {
-            maskLen = (s.length == 2) ? Short.valueOf(s[1]) : 32;
-        } catch (NumberFormatException e) {
-            maskLen = 32;
-        }
-        return maskLen;
-    }
-
-    private Status validateSubnetAddress() {
-        if (!NetUtils.isIPAddressValid(subnet)) {
-            return new Status(StatusCode.BADREQUEST, String.format("Invalid Subnet configuration: Invalid address: %s",
-                    subnet));
-        }
-        if ((this.getIPMaskLen() == 0) || (this.getIPMaskLen() == 32)) {
-            return new Status(StatusCode.BADREQUEST, String.format("Invalid Subnet configuration: Invalid mask: /%s",
-                    this.getIPMaskLen()));
-        }
-
-        //checks that address doesn't start with 0 or 255
-        String address = subnet.split("/")[0];
-        if (address.startsWith("0.") || address.startsWith("255.")) {
-            return  new Status(StatusCode.BADREQUEST, String.format("Invalid Subnet configuration: Invalid address: %s", address));
-        }
-
-        byte[] bytePrefix = NetUtils.getSubnetPrefix(this.getIPAddress(), this.getIPMaskLen()).getAddress();
-        long prefix = BitBufferHelper.getLong(bytePrefix);
-        if (prefix == 0) {
-            return new Status(StatusCode.BADREQUEST, "Invalid network source address: subnet zero");
-        }
-
-        //check that host is not set to all 0's or 1's
-        long hostAddress = BitBufferHelper.getLong(this.getIPAddress().getAddress()) - prefix;
-        if (hostAddress == 0 || hostAddress == Math.pow(2, 32-this.getIPMaskLen()) - 1) {
-            return new Status(StatusCode.BADREQUEST, String.format("Invalid subnet gateway address: /%s", subnet));
-        }
-
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    public static Status validatePorts(List<String> nodeConnectors) {
-        if (nodeConnectors != null) {
-            for (String port : nodeConnectors) {
-                if (null == NodeConnector.fromString(port)) {
-                    return new Status(StatusCode.BADREQUEST,
-                            "Invalid Subnet configuration: Not parsable node connector: " + port);
-                }
-            }
-        }
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    private Status validateName() {
-        if (!isValidResourceName(name)) {
-            return new Status(StatusCode.BADREQUEST, "Invalid name");
-        }
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    public Status validate() {
-        Status status = validateName();
-        if (status.isSuccess()) {
-            status = validateSubnetAddress();
-            if (status.isSuccess()) {
-                status = validatePorts(this.nodeConnectors);
-            }
-        }
-        return status;
-    }
-
-    public static List<String> getGuiFieldsNames() {
-        List<String> fieldList = new ArrayList<String>();
-        for (String str : prettyFields) {
-            fieldList.add(str);
-        }
-        return fieldList;
-    }
-
-    public Set<NodeConnector> getNodeConnectors() {
-        return NodeConnector.fromString(this.nodeConnectors);
-    }
-
-    public boolean isGlobal() {
-        // If no ports are specified to be part of the domain, then it's a
-        // global domain IP
-        return (nodeConnectors == null || nodeConnectors.isEmpty());
-    }
-
-    public void addNodeConnectors(List<String> nc) {
-        if (nc != null) {
-            if (nodeConnectors == null) {
-                nodeConnectors = new ArrayList<String>(nc);
-            } else {
-                nodeConnectors.addAll(nc);
-            }
-        }
-    }
-
-    public void removeNodeConnectors(List<String> nc) {
-        if (nc != null && nodeConnectors != null) {
-            nodeConnectors.removeAll(nc);
-        }
-    }
-
-    @Override
-    public String toString() {
-        return ("SubnetConfig [Name=" + name + ", Subnet=" + subnet + ", NodeConnectors=" + nodeConnectors + "]");
-    }
-
-    /**
-     * Implement clonable interface
-     */
-    @Override
-    public SubnetConfig clone() {
-        return new SubnetConfig(this);
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + ((name == null) ? 0 : name.hashCode());
-        result = prime * result + ((nodeConnectors == null) ? 0 : nodeConnectors.hashCode());
-        result = prime * result + ((subnet == null) ? 0 : subnet.hashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        SubnetConfig other = (SubnetConfig) obj;
-        if (name == null) {
-            if (other.name != null) {
-                return false;
-            }
-        } else if (!name.equals(other.name)) {
-            return false;
-        }
-        if (nodeConnectors == null) {
-            if (other.nodeConnectors != null) {
-                return false;
-            }
-        } else if (!nodeConnectors.equals(other.nodeConnectors)) {
-            return false;
-        }
-        if (subnet == null) {
-            if (other.subnet != null) {
-                return false;
-            }
-        } else if (!subnet.equals(other.subnet)) {
-            return false;
-        }
-        return true;
-    }
-}
diff --git a/opendaylight/adsal/switchmanager/api/src/main/java/org/opendaylight/controller/switchmanager/Switch.java b/opendaylight/adsal/switchmanager/api/src/main/java/org/opendaylight/controller/switchmanager/Switch.java
deleted file mode 100644 (file)
index e0c120a..0000000
+++ /dev/null
@@ -1,171 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.switchmanager;
-
-import java.io.Serializable;
-import java.util.ArrayList;
-import java.util.Arrays;
-import java.util.HashSet;
-import java.util.List;
-import java.util.Set;
-
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.utils.HexEncode;
-
-/**
- * The class describes switch related information including L2 address, ports,
- * span ports and associated node representation
- */
-public class Switch implements Serializable {
-    private static final long serialVersionUID = 1L;
-    private byte[] dataLayerAddress;
-    private Set<NodeConnector> nodeConnectors;
-    private final List<NodeConnector> spanPorts;
-    private Node node;
-
-    /*
-     * As we are adding switches on per event basis in a map, we do not need a default constructor
-     * This way we can keep the validations internal, in the proper constructor
-    public Switch() {
-        this.swPorts = new HashSet<SwitchPortTuple>();
-        this.spanPorts = new ArrayList<Short>(2);
-    }
-     */
-
-    public Switch(Node node) {
-        this.node = node;
-        this.nodeConnectors = new HashSet<NodeConnector>();
-        this.spanPorts = new ArrayList<NodeConnector>(2);
-        this.dataLayerAddress = null;
-    }
-
-    /**
-     * @return the dataLayerAddress
-     */
-    public byte[] getDataLayerAddress() {
-        return dataLayerAddress;
-    }
-
-    /**
-     * @param dataLayerAddress the dataLayerAddress to set
-     */
-    public void setDataLayerAddress(byte[] dataLayerAddress) {
-        this.dataLayerAddress = (dataLayerAddress == null) ? null
-                : dataLayerAddress.clone();
-    }
-
-    /**
-     * @return the nodeConnectors
-     */
-    public Set<NodeConnector> getNodeConnectors() {
-        return new HashSet<NodeConnector>(nodeConnectors);
-    }
-
-    /**
-     * @param nodeConnectors nodeConnector set
-     */
-    public void setNodeConnectors(Set<NodeConnector> nodeConnectors) {
-        this.nodeConnectors = nodeConnectors;
-    }
-
-    public void addNodeConnector(NodeConnector nodeConnector) {
-        if (!nodeConnectors.contains(nodeConnector)) {
-            nodeConnectors.add(nodeConnector);
-        }
-    }
-
-    public void removeNodeConnector(NodeConnector nodeConnector) {
-        nodeConnectors.remove(nodeConnector);
-    }
-
-    public List<NodeConnector> getSpanPorts() {
-        return new ArrayList<NodeConnector>(this.spanPorts);
-    }
-
-    public Node getNode() {
-        return node;
-    }
-
-    public void setNode(Node node) {
-        this.node = node;
-    }
-
-    public void addSpanPorts(List<NodeConnector> portList) {
-        for (NodeConnector port : portList) {
-            spanPorts.add(port);
-        }
-    }
-
-    public void removeSpanPorts(List<NodeConnector> portList) {
-        for (NodeConnector port : portList) {
-            spanPorts.remove(port);
-        }
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + Arrays.hashCode(dataLayerAddress);
-        result = prime * result + ((node == null) ? 0 : node.hashCode());
-        result = prime * result
-                + ((nodeConnectors == null) ? 0 : nodeConnectors.hashCode());
-        result = prime * result
-                + ((spanPorts == null) ? 0 : spanPorts.hashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        Switch other = (Switch) obj;
-        if (!Arrays.equals(dataLayerAddress, other.dataLayerAddress)) {
-            return false;
-        }
-        if (node == null) {
-            if (other.node != null) {
-                return false;
-            }
-        } else if (!node.equals(other.node)) {
-            return false;
-        }
-        if (nodeConnectors == null) {
-            if (other.nodeConnectors != null) {
-                return false;
-            }
-        } else if (!nodeConnectors.equals(other.nodeConnectors)) {
-            return false;
-        }
-        if (spanPorts == null) {
-            if (other.spanPorts != null) {
-                return false;
-            }
-        } else if (!spanPorts.equals(other.spanPorts)) {
-            return false;
-        }
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        return "Switch [dataLayerAddress=" + HexEncode.bytesToHexStringFormat(dataLayerAddress)
-                + ", nodeConnectors=" + nodeConnectors + ", spanPorts="
-                + spanPorts + ", node=" + node + "]";
-    }
-}
diff --git a/opendaylight/adsal/switchmanager/api/src/main/java/org/opendaylight/controller/switchmanager/SwitchConfig.java b/opendaylight/adsal/switchmanager/api/src/main/java/org/opendaylight/controller/switchmanager/SwitchConfig.java
deleted file mode 100644 (file)
index b8d022f..0000000
+++ /dev/null
@@ -1,197 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.switchmanager;
-
-import java.io.Serializable;
-import java.util.HashMap;
-import java.util.Map;
-
-import org.opendaylight.controller.configuration.ConfigurationObject;
-import org.opendaylight.controller.sal.core.Description;
-import org.opendaylight.controller.sal.core.ForwardingMode;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.core.Tier;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.sal.utils.StatusCode;
-
-/**
- * The class describes a switch configuration as a collection of properties
- */
-public class SwitchConfig extends ConfigurationObject implements Cloneable, Serializable {
-    private static final long serialVersionUID = 1L;
-    private final String nodeId;
-    private final Map<String, Property> nodeProperties;
-
-    public SwitchConfig(String nodeId, Map<String, Property> nodeProperties) {
-        this.nodeId = nodeId;
-        this.nodeProperties = (nodeProperties == null) ? new HashMap<String, Property>()
-                : new HashMap<String, Property>(nodeProperties);
-    }
-
-    @Deprecated
-    public SwitchConfig(String nodeId, String description, String tier, String mode) {
-        this.nodeId = nodeId;
-        this.nodeProperties = new HashMap<String, Property>();
-        Property desc = new Description(description);
-        this.nodeProperties.put(desc.getName(), desc);
-        Property nodeTier = new Tier(Integer.valueOf(tier));
-        this.nodeProperties.put(nodeTier.getName(), nodeTier);
-        Property forwardingMode = new ForwardingMode(Integer.valueOf(mode));
-        this.nodeProperties.put(forwardingMode.getName(), forwardingMode);
-    }
-
-    public String getNodeId() {
-        return this.nodeId;
-    }
-
-    public Map<String, Property> getNodeProperties() {
-        return new HashMap<String, Property>(this.nodeProperties);
-    }
-
-    public Property getProperty(String PropName) {
-        return nodeProperties.get(PropName);
-    }
-
-    /**
-     * This method returns the configured description of the node
-     *
-     * @return Configured description
-     *
-     * @deprecated replaced by getProperty(Description.propertyName)
-     */
-    @Deprecated
-    public String getNodeDescription() {
-        Description description = (Description) getProperty(Description.propertyName);
-        return (description == null) ? null : description.getValue();
-    }
-
-    /**
-     * This method returns the configured Tier of a node
-     *
-     * @return Configured tier
-     *
-     * @deprecated replaced by getProperty(Tier.TierPropName)
-     */
-    @Deprecated
-    public String getTier() {
-        Tier tier = (Tier) getProperty(Tier.TierPropName);
-        return (tier == null) ? null : String.valueOf(tier.getValue());
-    }
-
-    /**
-     * This method returns the configured Forwarding Mode of a node
-     *
-     * @return Configured Forwarding Mode
-     *
-     * @deprecated replaced by getProperty(ForwardingMode.name)
-     */
-    @Deprecated
-    public String getMode() {
-        ForwardingMode forwardingMode = (ForwardingMode) getProperty(ForwardingMode.name);
-        return (forwardingMode == null) ? null : String.valueOf(forwardingMode.getValue());
-    }
-
-    /**
-     * This method returns true, if the configured forwarding mode is proactive,
-     * else false
-     *
-     * @return true, if the configured forwarding mode is proactive, else false
-     *
-     * @deprecated replaced by isProactive() API of ForwardingMode property
-     */
-    @Deprecated
-    public boolean isProactive() {
-        return Integer.parseInt(getMode()) == ForwardingMode.PROACTIVE_FORWARDING;
-    }
-
-    public static long getSerialversionuid() {
-        return serialVersionUID;
-    }
-
-    public Status validate() {
-        Status validCheck = validateNodeId();
-        if (validCheck.isSuccess()) {
-            validCheck = validateNodeProperties();
-        }
-        return validCheck;
-    }
-
-    private Status validateNodeId() {
-        if (nodeId == null || nodeId.trim().isEmpty()) {
-            return new Status(StatusCode.BADREQUEST, "Invalid node id");
-        }
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    private Status validateNodeProperties() {
-        if (nodeProperties == null) {
-            return new Status(StatusCode.BADREQUEST, "Node properties must be specified");
-        }
-        if (nodeProperties.containsKey(Description.propertyName)) {
-            if (!isValidResourceName(((Description)nodeProperties.get(Description.propertyName)).getValue())) {
-                return new Status(StatusCode.BADREQUEST, "Invalid node description");
-            }
-        }
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + ((nodeId == null) ? 0 : nodeId.hashCode());
-        result = prime * result + ((nodeProperties == null) ? 0 : nodeProperties.hashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        SwitchConfig other = (SwitchConfig) obj;
-        if (nodeId == null) {
-            if (other.nodeId != null) {
-                return false;
-            }
-        } else if (!nodeId.equals(other.nodeId)) {
-            return false;
-        }
-        if (nodeProperties == null) {
-            if (other.nodeProperties != null) {
-                return false;
-            }
-        } else if (!nodeProperties.equals(other.nodeProperties)) {
-            return false;
-        }
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        return ("SwitchConfig [Node=" + nodeId + ", Properties=" + nodeProperties + "]");
-    }
-
-    /**
-     * Implement clonable interface
-     */
-    @Override
-    public SwitchConfig clone() {
-        Map<String, Property> nodeProperties = (this.nodeProperties == null) ? null : new HashMap<String, Property>(
-                this.nodeProperties);
-        return new SwitchConfig(this.nodeId, nodeProperties);
-    }
-
-}
diff --git a/opendaylight/adsal/switchmanager/api/src/test/java/org/opendaylight/controller/switchmanager/SubnetConfigTest.java b/opendaylight/adsal/switchmanager/api/src/test/java/org/opendaylight/controller/switchmanager/SubnetConfigTest.java
deleted file mode 100644 (file)
index df6ed74..0000000
+++ /dev/null
@@ -1,62 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.switchmanager;
-
-import java.util.ArrayList;
-import java.util.List;
-import org.junit.Assert;
-import org.junit.Test;
-import org.opendaylight.controller.sal.core.ConstructionException;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.utils.Status;
-
-public class SubnetConfigTest {
-
-    @Test
-    public void configuration() throws ConstructionException {
-        // Create the node connector string list
-        Node node1 = new Node(Node.NodeIDType.OPENFLOW, 1L);
-        Node node2 = new Node(Node.NodeIDType.OPENFLOW, 2L);
-        Node node3 = new Node(Node.NodeIDType.OPENFLOW, 3L);
-        NodeConnector nc1 = new NodeConnector(NodeConnector.NodeConnectorIDType.OPENFLOW, (short)1, node1);
-        NodeConnector nc2 = new NodeConnector(NodeConnector.NodeConnectorIDType.OPENFLOW, (short)2, node2);
-        NodeConnector nc3 = new NodeConnector(NodeConnector.NodeConnectorIDType.OPENFLOW, (short)3, node3);
-        List<String> portList = new ArrayList<String>();
-        portList.add(nc1.toString());
-        portList.add(nc2.toString());
-        portList.add(nc3.toString());
-
-        // Full subnet creation
-        SubnetConfig config = new SubnetConfig("eng", "11.1.1.254/16", portList);
-        Status status = config.validate();
-        Assert.assertTrue(status.isSuccess());
-
-        // No port set specified
-        config = new SubnetConfig("eng", "11.1.1.254/16", null);
-        status = config.validate();
-        Assert.assertTrue(status.isSuccess());
-
-        // Empty port set
-        config = new SubnetConfig("eng", "11.1.1.254/16", new ArrayList<String>(0));
-        status = config.validate();
-        Assert.assertTrue(status.isSuccess());
-
-        // Zero subnet
-        config = new SubnetConfig("eng", "1.2.3.254/1", null);
-        status = config.validate();
-        Assert.assertFalse(status.isSuccess());
-
-        // Port set with invalid port notation
-        List<String> badPortList = new ArrayList<String>();
-        badPortList.add("1/1");
-        config = new SubnetConfig("eng", "1.2.3.254/1", badPortList);
-        status = config.validate();
-        Assert.assertFalse(status.isSuccess());
-    }
-}
diff --git a/opendaylight/adsal/switchmanager/api/src/test/java/org/opendaylight/controller/switchmanager/SubnetTest.java b/opendaylight/adsal/switchmanager/api/src/test/java/org/opendaylight/controller/switchmanager/SubnetTest.java
deleted file mode 100644 (file)
index 8b6a149..0000000
+++ /dev/null
@@ -1,134 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.switchmanager;
-
-import static org.junit.Assert.fail;
-import static org.junit.Assert.assertFalse;
-import static org.junit.Assert.assertTrue;
-
-import java.net.Inet6Address;
-import java.net.InetAddress;
-import java.net.UnknownHostException;
-import java.util.HashSet;
-import java.util.Set;
-
-import org.junit.Assert;
-import org.junit.Test;
-import org.opendaylight.controller.sal.utils.NodeCreator;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.utils.NodeConnectorCreator;
-
-public class SubnetTest {
-
-    @Test
-    public void testSubnet() throws Exception {
-        InetAddress ipaddr = InetAddress.getByName("100.0.0.1");
-        Subnet subnet = new Subnet(ipaddr, (short) 24, (short) 5);
-        assertTrue(subnet.equals(subnet));
-        assertFalse(subnet.equals(null));
-        assertFalse(subnet.equals(ipaddr));
-        Subnet subnet2 = new Subnet(ipaddr, (short) 24, (short) 5);
-        Inet6Address ipv6 = (Inet6Address) Inet6Address
-                .getByName("1111::2222:3333:4444:5555:6666");
-        Subnet subnet3 = new Subnet(ipv6, (short) 24, (short) 5);
-        assertTrue(subnet.equals(subnet2));
-        assertFalse(subnet.isMutualExclusive(subnet2));
-        assertTrue(subnet.isMutualExclusive(subnet3));
-        InetAddress subnetAddr = InetAddress.getByName("200.0.0.100");
-
-        assertTrue(subnet.isFlatLayer2() == true);
-
-        Set<NodeConnector> ncSet = new HashSet<NodeConnector>();
-        Node node = NodeCreator.createOFNode(((long) 10));
-        NodeConnector nc0 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 20, node);
-        NodeConnector nc1 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 30, node);
-        NodeConnector nc2 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 40, node);
-
-        ncSet.add(nc0);
-        ncSet.add(nc1);
-        ncSet.add(nc2);
-
-        assertTrue(subnet.hasNodeConnector(nc0));
-        assertFalse(subnet.hasNodeConnector(null));
-        subnet.addNodeConnectors(ncSet);
-        assertTrue(subnet.hasNodeConnector(nc0));
-
-        Set<NodeConnector> resultncSet = subnet.getNodeConnectors();
-        Assert.assertEquals(resultncSet, ncSet);
-        subnet.addNodeConnectors(null);
-        Assert.assertEquals(subnet.getNodeConnectors(), ncSet);
-
-        subnet.deleteNodeConnectors(null);
-        Assert.assertEquals(subnet.getNodeConnectors(), ncSet);
-
-        Set<NodeConnector> ncSet2 = new HashSet<NodeConnector>();
-        ncSet2.add(nc0);
-        subnet.deleteNodeConnectors(ncSet2);
-        assertFalse(subnet.getNodeConnectors().contains(nc0));
-        assertFalse(subnet.hasNodeConnector(nc0));
-        assertTrue(subnet.getNodeConnectors().contains(nc1));
-        assertTrue(subnet.getNodeConnectors().contains(nc2));
-
-        subnet.deleteNodeConnectors(ncSet2);
-
-        subnet.setNetworkAddress(subnetAddr);
-        assertTrue(subnet.isMutualExclusive(subnet2));
-        assertTrue(subnet.getNetworkAddress().equals(subnetAddr));
-
-        subnet.setSubnetMaskLength((short) 16);
-        assertTrue(subnet.getSubnetMaskLength() == 16);
-
-        subnet.setVlan((short) 100);
-        assertTrue(subnet.getVlan() == 100);
-
-        assertTrue(subnet.isFlatLayer2() == false);
-    }
-
-    @Test
-    public void checkIsSubnetOfComparisonMatch() {
-        String host = "10.0.0.1";
-        InetAddress ipAddrForSubnetComparison = null;
-        try {
-            ipAddrForSubnetComparison = InetAddress.getByName(host);
-        } catch (UnknownHostException e) {
-            fail("Failed to create InetAddress object for" + host);
-        }
-        SubnetConfig subnetConf = new SubnetConfig("subnet", "10.0.0.254/24",null);
-        Subnet subnet = new Subnet(subnetConf);
-        assertTrue(subnet.isSubnetOf(ipAddrForSubnetComparison));
-    }
-
-    @Test
-    public void checkIsSubnetOfComparisonNoMatch() {
-        String host = "100.0.0.1";
-        InetAddress ipAddrForSubnetComparison = null;
-        try {
-            ipAddrForSubnetComparison = InetAddress.getByName(host);
-        } catch (UnknownHostException e) {
-            fail("Failed to create InetAddress object for" + host);
-        }
-        SubnetConfig subnetConf = new SubnetConfig("subnet", "10.0.0.254/24",null);
-        Subnet subnet = new Subnet(subnetConf);
-        assertFalse(subnet.isSubnetOf(ipAddrForSubnetComparison));
-    }
-
-    @Test
-    public void checkIsSubnetOfComparisonIpEmpty() {
-        SubnetConfig subnetConf = new SubnetConfig("subnet", "10.0.0.254/24",null);
-        Subnet subnet = new Subnet(subnetConf);
-        assertFalse(subnet.isSubnetOf(null));
-    }
-
-
-
-}
diff --git a/opendaylight/adsal/switchmanager/api/src/test/java/org/opendaylight/controller/switchmanager/SwitchTest.java b/opendaylight/adsal/switchmanager/api/src/test/java/org/opendaylight/controller/switchmanager/SwitchTest.java
deleted file mode 100644 (file)
index 64b57eb..0000000
+++ /dev/null
@@ -1,150 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.switchmanager;
-
-import static org.junit.Assert.fail;
-
-import java.util.ArrayList;
-import java.util.HashMap;
-import java.util.HashSet;
-import java.util.Map;
-import java.util.Set;
-
-import org.junit.Assert;
-import org.junit.Test;
-import org.opendaylight.controller.sal.core.Description;
-import org.opendaylight.controller.sal.core.ForwardingMode;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.core.Tier;
-import org.opendaylight.controller.sal.utils.NodeConnectorCreator;
-import org.opendaylight.controller.sal.utils.NodeCreator;
-
-public class SwitchTest {
-
-    @Test
-    public void testSwitchCreation() {
-
-        Node node = NodeCreator.createOFNode(((long) 10));
-        Node node2 = NodeCreator.createOFNode(((long) 11));
-        NodeConnector nc0 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 20, node);
-        NodeConnector nc1 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 30, node);
-        NodeConnector nc2 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 40, node);
-        NodeConnector nc3 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 50, node);
-        NodeConnector nc4 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 60, node);
-        NodeConnector nc5 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 70, node);
-
-        Set<NodeConnector> ncSet = new HashSet<NodeConnector>();
-        ArrayList<NodeConnector> portList = new ArrayList<NodeConnector>();
-
-        Switch sw = new Switch(node);
-        Switch sw2 = new Switch(node);
-        Assert.assertTrue(sw.equals(sw2));
-        sw2.setNode(node2);
-        Assert.assertTrue(sw2.getNode().equals(node2));
-        Assert.assertFalse(sw.equals(sw2));
-
-        ncSet.add(nc0);
-        ncSet.add(nc1);
-        ncSet.add(nc2);
-        sw.addNodeConnector(nc3);
-        try {
-            sw.addNodeConnector(nc3);
-        } catch (Exception e) {
-            fail("Attempted to add duplicate NodeConnector to set");
-        }
-
-        portList.add(nc4);
-        portList.add(nc5);
-
-        sw.setNodeConnectors(ncSet);
-        sw.addSpanPorts(portList);
-
-        sw.setDataLayerAddress(null);
-        Assert.assertNull(sw.getDataLayerAddress());
-        byte[] dlAddress = { (byte) 0x01, (byte) 0x02, (byte) 0x03,
-                (byte) 0x04, (byte) 0x05, (byte) 0x06 };
-        sw.setDataLayerAddress(dlAddress);
-
-        Node resultNode = sw.getNode();
-        Set<NodeConnector> resultncSet = sw.getNodeConnectors();
-        byte[] resultdlAddress = sw.getDataLayerAddress();
-        ArrayList<NodeConnector> resultSpanPort = (ArrayList<NodeConnector>) sw
-                .getSpanPorts();
-
-        Assert.assertEquals(node, resultNode);
-        for (int i = 0; i < dlAddress.length; i++) {
-            Assert.assertEquals(dlAddress[i], resultdlAddress[i]);
-        }
-
-        Assert.assertTrue(ncSet.equals(resultncSet));
-
-        for (int i = 0; i < portList.size(); i++) {
-            Assert.assertEquals(portList.get(i), resultSpanPort.get(i));
-        }
-    }
-
-    @Test
-    public void testSwitchAddRemovePort() {
-        Node node = NodeCreator.createOFNode(((long) 10));
-
-        NodeConnector nc0 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 20, node);
-        NodeConnector nc1 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 30, node);
-        NodeConnector nc4 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 60, node);
-        NodeConnector nc5 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 70, node);
-        ArrayList<NodeConnector> portList = new ArrayList<NodeConnector>();
-
-        portList.add(nc4);
-        portList.add(nc5);
-
-        Set<NodeConnector> ncSet = new HashSet<NodeConnector>();
-        ncSet.add(nc0);
-        ncSet.add(nc1);
-
-        Switch sw = new Switch(node);
-        sw.setNodeConnectors(ncSet);
-        sw.removeNodeConnector(nc0);
-        Assert.assertFalse(ncSet.contains(nc0));
-
-        sw.removeSpanPorts(portList);
-        Assert.assertTrue(sw.getSpanPorts().isEmpty());
-
-    }
-
-    @Test
-    public void testSwitchConfig(){
-        Map<String, Property> prop = new HashMap<String, Property>();
-        Property desc = new Description("swicth1");
-        prop.put(desc.getName(), desc);
-        Property tier = new Tier(1);
-        prop.put(tier.getName(), tier);
-        SwitchConfig sc1 = new SwitchConfig("123", prop);
-        SwitchConfig sc2 = new SwitchConfig("123", prop);
-        Property mode = new ForwardingMode(1);
-        prop.put(mode.getName(), mode);
-        SwitchConfig sc3 = new SwitchConfig("123", prop);
-        Assert.assertTrue(sc1.equals(sc2));
-        Assert.assertEquals(tier, sc1.getProperty(Tier.TierPropName));
-        Assert.assertFalse(sc1.equals(sc3));
-        Assert.assertTrue(sc1.hashCode() == sc2.hashCode());
-        Assert.assertTrue(sc1.getNodeProperties().equals(sc2.getNodeProperties()));
-    }
-
-}
diff --git a/opendaylight/adsal/switchmanager/implementation/pom.xml b/opendaylight/adsal/switchmanager/implementation/pom.xml
deleted file mode 100644 (file)
index 4aa92e6..0000000
+++ /dev/null
@@ -1,126 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>switchmanager.implementation</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-
-  <properties>
-    <!-- Sonar properties using jacoco to retrieve integration test results -->
-    <sonar.dynamicAnalysis>reuseReports</sonar.dynamicAnalysis>
-    <sonar.jacoco.Reportpath>target/jacoco.exec</sonar.jacoco.Reportpath>
-    <sonar.jacoco.itReportPath>target/jacoco-it.exec</sonar.jacoco.itReportPath>
-  </properties>
-  <dependencies>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>org.apache.felix.gogo.runtime</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>org.eclipse.osgi</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>clustering.services</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>configuration</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>statisticsmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>switchmanager</artifactId>
-    </dependency>
-  </dependencies>
-  <build>
-    <pluginManagement>
-      <plugins>
-        <plugin>
-          <groupId>org.jacoco</groupId>
-          <artifactId>jacoco-maven-plugin</artifactId>
-          <version>${jacoco.version}</version>
-        </plugin>
-      </plugins>
-    </pluginManagement>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Export-Package></Export-Package>
-            <Import-Package>org.opendaylight.controller.configuration,
-              org.opendaylight.controller.switchmanager,
-              org.opendaylight.controller.clustering.services,
-              org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.sal.utils,
-              org.opendaylight.controller.sal.packet,
-              org.opendaylight.controller.sal.reader,
-              org.opendaylight.controller.sal.inventory,
-              org.opendaylight.controller.statisticsmanager,
-              org.slf4j,
-              org.apache.felix.dm,
-              org.eclipse.osgi.framework.console,
-              org.osgi.framework,
-              org.apache.felix.service.command,
-              javax.xml.bind.annotation,
-              org.apache.commons.lang3.builder</Import-Package>
-            <Bundle-Activator>org.opendaylight.controller.switchmanager.internal.Activator</Bundle-Activator>
-          </instructions>
-          <manifestLocation>${project.basedir}/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-      <plugin>
-        <groupId>org.jacoco</groupId>
-        <artifactId>jacoco-maven-plugin</artifactId>
-        <configuration>
-          <includes>
-            <include>org.opendaylight.controller.*</include>
-          </includes>
-        </configuration>
-        <executions>
-          <execution>
-            <id>pre-test</id>
-            <goals>
-              <goal>prepare-agent</goal>
-            </goals>
-          </execution>
-          <execution>
-            <id>post-test</id>
-            <goals>
-              <goal>report</goal>
-            </goals>
-            <phase>test</phase>
-          </execution>
-        </executions>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/switchmanager/implementation/src/main/java/org/opendaylight/controller/switchmanager/internal/Activator.java b/opendaylight/adsal/switchmanager/implementation/src/main/java/org/opendaylight/controller/switchmanager/internal/Activator.java
deleted file mode 100644 (file)
index deecf26..0000000
+++ /dev/null
@@ -1,134 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.switchmanager.internal;
-
-import org.apache.felix.dm.Component;
-import org.opendaylight.controller.clustering.services.IClusterContainerServices;
-import org.opendaylight.controller.clustering.services.IClusterGlobalServices;
-import org.opendaylight.controller.configuration.IConfigurationContainerAware;
-import org.opendaylight.controller.configuration.IConfigurationContainerService;
-import org.opendaylight.controller.sal.core.ComponentActivatorAbstractBase;
-import org.opendaylight.controller.sal.inventory.IInventoryService;
-import org.opendaylight.controller.sal.inventory.IListenInventoryUpdates;
-import org.opendaylight.controller.statisticsmanager.IStatisticsManager;
-import org.opendaylight.controller.switchmanager.IInventoryListener;
-import org.opendaylight.controller.switchmanager.ISpanAware;
-import org.opendaylight.controller.switchmanager.ISwitchManager;
-import org.opendaylight.controller.switchmanager.ISwitchManagerAware;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * SwitchManager Bundle Activator
- *
- *
- */
-public class Activator extends ComponentActivatorAbstractBase {
-    protected static final Logger logger = LoggerFactory
-            .getLogger(Activator.class);
-
-
-    /**
-     * Function that is used to communicate to dependency manager the
-     * list of known implementations for services inside a container
-     *
-     *
-     * @return An array containing all the CLASS objects that will be
-     * instantiated in order to get an fully working implementation
-     * Object
-     */
-    @Override
-    public Object[] getImplementations() {
-        Object[] res = { SwitchManager.class };
-        return res;
-    }
-
-    /**
-     * Function that is called when configuration of the dependencies
-     * is required.
-     *
-     * @param c dependency manager Component object, used for
-     * configuring the dependencies exported and imported
-     * @param imp Implementation class that is being configured,
-     * needed as long as the same routine can configure multiple
-     * implementations
-     * @param containerName The containerName being configured, this allow
-     * also optional per-container different behavior if needed, usually
-     * should not be the case though.
-     */
-    @Override
-    public void configureInstance(Component c, Object imp, String containerName) {
-        if (imp.equals(SwitchManager.class)) {
-            // export the service
-            c.setInterface(new String[] {
-                    IListenInventoryUpdates.class.getName(),
-                    ISwitchManager.class.getName(),
-                    IConfigurationContainerAware.class.getName() }, null);
-
-            // Now lets add a service dependency to make sure the
-            // provider of service exists
-            c.add(createContainerServiceDependency(containerName).setService(
-                    IInventoryService.class).setCallbacks(
-                    "setInventoryService", "unsetInventoryService")
-                    .setRequired(true));
-            c.add(createContainerServiceDependency(containerName).setService(
-                    IStatisticsManager.class).setCallbacks(
-                    "setStatisticsManager", "unsetStatisticsManager")
-                    .setRequired(false));
-            c.add(createContainerServiceDependency(containerName).setService(
-                    ISwitchManagerAware.class).setCallbacks(
-                    "setSwitchManagerAware", "unsetSwitchManagerAware")
-                    .setRequired(false));
-            c.add(createContainerServiceDependency(containerName).setService(
-                    IInventoryListener.class).setCallbacks(
-                    "setInventoryListener", "unsetInventoryListener")
-                    .setRequired(false));
-            c.add(createContainerServiceDependency(containerName).setService(
-                    ISpanAware.class).setCallbacks("setSpanAware",
-                    "unsetSpanAware").setRequired(false));
-            c.add(createContainerServiceDependency(containerName).setService(
-                    IClusterContainerServices.class).setCallbacks(
-                    "setClusterContainerService",
-                    "unsetClusterContainerService").setRequired(true));
-            c.add(createContainerServiceDependency(containerName).setService(
-                    IConfigurationContainerService.class).setCallbacks(
-                    "setConfigurationContainerService",
-                    "unsetConfigurationContainerService").setRequired(true));
-            c.add(createServiceDependency()
-                    .setService(IControllerProperties.class)
-                    .setCallbacks("setControllerProperties", "unsetControllerProperties")
-                    .setRequired(true));
-        }
-    }
-
-    /**
-     * {@inheritDoc}
-     */
-    @Override
-    protected Object[] getGlobalImplementations() {
-        final Object[] res = { ControllerProperties.class, SwitchManagerCLI.class };
-        return res;
-    }
-
-    /**
-     * {@inheritDoc}
-     */
-    @Override
-    public void configureGlobalInstance(Component c, Object imp) {
-        if (imp.equals(ControllerProperties.class)) {
-            c.setInterface(new String[] { IControllerProperties.class.getName() }, null);
-
-            c.add(createServiceDependency()
-                    .setService(IClusterGlobalServices.class)
-                    .setCallbacks("setClusterService", "unsetClusterService")
-                    .setRequired(true));
-        }
-    }
-}
diff --git a/opendaylight/adsal/switchmanager/implementation/src/main/java/org/opendaylight/controller/switchmanager/internal/ControllerProperties.java b/opendaylight/adsal/switchmanager/implementation/src/main/java/org/opendaylight/controller/switchmanager/internal/ControllerProperties.java
deleted file mode 100644 (file)
index 4b319b8..0000000
+++ /dev/null
@@ -1,241 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.switchmanager.internal;
-
-import java.net.NetworkInterface;
-import java.net.SocketException;
-import java.util.EnumSet;
-import java.util.Enumeration;
-import java.util.HashMap;
-import java.util.Map;
-import java.util.concurrent.ConcurrentHashMap;
-import java.util.concurrent.ConcurrentMap;
-
-import org.apache.felix.dm.Component;
-import org.opendaylight.controller.clustering.services.CacheConfigException;
-import org.opendaylight.controller.clustering.services.CacheExistException;
-import org.opendaylight.controller.clustering.services.IClusterGlobalServices;
-import org.opendaylight.controller.clustering.services.IClusterServices;
-import org.opendaylight.controller.sal.core.MacAddress;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.utils.HexEncode;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.sal.utils.StatusCode;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * The class ControllerProperties
- * provides implementation for the ControllerProperties API
- */
-public class ControllerProperties implements IControllerProperties {
-
-    private IClusterGlobalServices clusterService = null;
-    private final Logger log = LoggerFactory
-            .getLogger(ControllerProperties.class);
-    private static final String controllerGlobalPropertiesCacheName = "switchmanager.controllerGlobalProperties";
-
-    private ConcurrentMap<String, Property> controllerGlobalProperties;
-
-    private void allocateCaches() {
-        if (this.clusterService == null) {
-            this.nonClusterObjectCreate();
-            log.warn("un-initialized clusterService, can't create cache");
-            return;
-        }
-        try {
-            this.clusterService.createCache(controllerGlobalPropertiesCacheName,
-                    EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-        } catch (CacheConfigException cce) {
-            log.error("\nCache configuration invalid - check cache mode");
-        } catch (CacheExistException ce) {
-            log.error("\nCache already exits - destroy and recreate if needed");
-        }
-    }
-
-    private void nonClusterObjectCreate() {
-        controllerGlobalProperties = new ConcurrentHashMap<String, Property>();
-    }
-
-    @SuppressWarnings({ "unchecked" })
-    private void retrieveCaches() {
-        if (this.clusterService == null) {
-            log.warn("un-initialized clusterService, can't create cache");
-            return;
-        }
-        controllerGlobalProperties = (ConcurrentMap<String, Property>) this.clusterService
-                .getCache(controllerGlobalPropertiesCacheName);
-        if (controllerGlobalProperties == null) {
-            log.error("\nFailed to get cache for controllerGlobalProperties");
-        }
-    }
-
-    /**
-     * Function called by the dependency manager when all the required
-     * dependencies are satisfied
-     *
-     * @param c Component
-     */
-    void init(Component c) {
-        // Instantiate cluster synced variables
-        allocateCaches();
-        retrieveCaches();
-    }
-
-    private void initializeProperties() {
-        byte controllerMac[] = getHardwareMAC();
-        if (controllerMac != null) {
-            Property existing = controllerGlobalProperties.putIfAbsent(MacAddress.name, new MacAddress(controllerMac));
-            if (existing == null && log.isTraceEnabled()) {
-                log.trace("Setting controller MAC address in the cluster: {}", HexEncode.bytesToHexStringFormat(controllerMac));
-            }
-        }
-    }
-
-    private byte[] getHardwareMAC() {
-        Enumeration<NetworkInterface> nis;
-        byte[] macAddress = null;
-
-        try {
-            nis = NetworkInterface.getNetworkInterfaces();
-        } catch (SocketException e) {
-            log.error("Failed to acquire controller MAC: ", e);
-            return macAddress;
-        }
-
-        while (nis.hasMoreElements()) {
-            NetworkInterface ni = nis.nextElement();
-            try {
-                macAddress = ni.getHardwareAddress();
-            } catch (SocketException e) {
-                log.error("Failed to acquire controller MAC: ", e);
-            }
-            if (macAddress != null && macAddress.length != 0) {
-                break;
-            }
-        }
-        if (macAddress == null) {
-            log.warn("Failed to acquire controller MAC: No physical interface found");
-            // This happens when running controller on windows VM, for example
-            // TODO: Try parsing the OS command output
-            // For now provide a quick fix for the release
-            macAddress = new byte[] { (byte) 0x00, (byte) 0x00, (byte) 0x0c, (byte) 0x60, (byte) 0x0D, (byte) 0x10 };
-            log.debug("Assigning custom MAC address to controller");
-        }
-        return macAddress;
-    }
-
-    /**
-     * Function called by dependency manager after "init ()" is called and after
-     * the services provided by the class are registered in the service registry
-     *
-     */
-    void start() {
-        // initialize required properties if first node in the cluster
-        if(this.clusterService.amICoordinator()) {
-            initializeProperties();
-        }
-    }
-
-    /**
-     * Function called after registered the service in OSGi service registry.
-     */
-    void started() {
-        // nothing to do
-    }
-
-    /**
-     * Function called before services of the component are removed
-     * from OSGi service registry.
-     */
-    void stopping() {
-        // nothing to do
-    }
-
-    /**
-     * Function called by the dependency manager before the services exported by
-     * the component are unregistered, this will be followed by a "destroy ()"
-     * calls
-     *
-     */
-    void stop() {
-        // nothing to do
-    }
-
-    /**
-     * Function called by the dependency manager when at least one dependency
-     * become unsatisfied or when the component is shutting down because for
-     * example bundle is being stopped.
-     *
-     */
-    void destroy() {
-        // nothing to do
-    }
-
-    /**
-     * {@inheritDoc}
-     */
-    @Override
-    public Map<String, Property> getControllerProperties() {
-        return new HashMap<String, Property>(this.controllerGlobalProperties);
-    }
-
-    /**
-     * {@inheritDoc}
-     */
-    @Override
-    public Property getControllerProperty(String propertyName) {
-        if (propertyName != null) {
-            return this.controllerGlobalProperties.get(propertyName);
-        }
-        return null;
-    }
-
-    /**
-     * {@inheritDoc}
-     */
-    @Override
-    public Status setControllerProperty(Property property) {
-        if (property != null) {
-            this.controllerGlobalProperties.put(property.getName(), property);
-            return new Status(StatusCode.SUCCESS);
-        }
-        return new Status(StatusCode.BADREQUEST, "Invalid property provided when setting property");
-    }
-
-    /**
-     * {@inheritDoc}
-     */
-    @Override
-    public Status removeControllerProperty(String propertyName) {
-        if (propertyName != null) {
-            this.controllerGlobalProperties.remove(propertyName);
-            return new Status(StatusCode.SUCCESS);
-        }
-        return new Status(StatusCode.BADREQUEST, "Invalid property provided when removing property");
-    }
-
-    /**
-     * setClusterService
-     * @param s
-     */
-    public void setClusterService(IClusterGlobalServices s) {
-        this.clusterService = s;
-    }
-
-    /**
-     * unsetClusterServices
-     * @param s
-     */
-    public void unsetClusterServices(IClusterGlobalServices s) {
-        if (this.clusterService == s) {
-            this.clusterService = null;
-        }
-    }
-
-}
diff --git a/opendaylight/adsal/switchmanager/implementation/src/main/java/org/opendaylight/controller/switchmanager/internal/IControllerProperties.java b/opendaylight/adsal/switchmanager/implementation/src/main/java/org/opendaylight/controller/switchmanager/internal/IControllerProperties.java
deleted file mode 100644 (file)
index f9301e2..0000000
+++ /dev/null
@@ -1,66 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.switchmanager.internal;
-
-import java.util.Map;
-
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.utils.Status;
-
-/**
- * The class ControllerProperties is a global store
- * for controller properties. Use this api to store/retrieve properties
- * that are container independent.
- *
- * This is visible only to switch manager. Hence its a part of
- * switch manager internal bundle.
- */
-public interface IControllerProperties {
-
-    /**
-     * Return all the global properties of the controller
-     *
-     * @return map of {@link org.opendaylight.controller.sal.core.Property} such
-     *         as {@link org.opendaylight.controller.sal.core.Description}
-     *         and/or {@link org.opendaylight.controller.sal.core.Tier} etc.
-     */
-    public Map<String, Property> getControllerProperties();
-
-    /**
-     * Return a specific property of the controller given the property name
-     *
-     * @param propertyName
-     *            the property name specified by
-     *            {@link org.opendaylight.controller.sal.core.Property} and its
-     *            extended classes
-     * @return {@link org.opendaylight.controller.sal.core.Property}
-     */
-    public Property getControllerProperty(String propertyName);
-
-    /**
-     * Set a specific property of the controller
-     *
-     * @param property
-     *            {@link org.opendaylight.controller.sal.core.Property}
-     * @return Status
-     */
-    public Status setControllerProperty(Property property);
-
-    /**
-     * Remove a property of a node
-     *
-     * @param propertyName
-     *            the property name specified by
-     *            {@link org.opendaylight.controller.sal.core.Property} and its
-     *            extended classes
-     * @return success or failed reason
-     */
-    public Status removeControllerProperty(String propertyName);
-
-}
diff --git a/opendaylight/adsal/switchmanager/implementation/src/main/java/org/opendaylight/controller/switchmanager/internal/SwitchManager.java b/opendaylight/adsal/switchmanager/implementation/src/main/java/org/opendaylight/controller/switchmanager/internal/SwitchManager.java
deleted file mode 100644 (file)
index 8372f88..0000000
+++ /dev/null
@@ -1,2180 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.switchmanager.internal;
-
-import java.io.FileNotFoundException;
-import java.io.IOException;
-import java.io.ObjectInputStream;
-import java.net.InetAddress;
-import java.util.ArrayList;
-import java.util.Collections;
-import java.util.Dictionary;
-import java.util.EnumSet;
-import java.util.HashMap;
-import java.util.HashSet;
-import java.util.List;
-import java.util.Map;
-import java.util.Set;
-import java.util.concurrent.ConcurrentHashMap;
-import java.util.concurrent.ConcurrentMap;
-import java.util.concurrent.CopyOnWriteArrayList;
-
-import org.apache.felix.dm.Component;
-import org.eclipse.osgi.framework.console.CommandInterpreter;
-import org.eclipse.osgi.framework.console.CommandProvider;
-import org.opendaylight.controller.clustering.services.CacheConfigException;
-import org.opendaylight.controller.clustering.services.CacheExistException;
-import org.opendaylight.controller.clustering.services.IClusterContainerServices;
-import org.opendaylight.controller.clustering.services.IClusterServices;
-import org.opendaylight.controller.configuration.ConfigurationObject;
-import org.opendaylight.controller.configuration.IConfigurationContainerAware;
-import org.opendaylight.controller.configuration.IConfigurationContainerService;
-import org.opendaylight.controller.sal.core.Bandwidth;
-import org.opendaylight.controller.sal.core.Config;
-import org.opendaylight.controller.sal.core.ConstructionException;
-import org.opendaylight.controller.sal.core.Description;
-import org.opendaylight.controller.sal.core.ForwardingMode;
-import org.opendaylight.controller.sal.core.MacAddress;
-import org.opendaylight.controller.sal.core.Name;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.NodeConnector.NodeConnectorIDType;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.core.State;
-import org.opendaylight.controller.sal.core.Tier;
-import org.opendaylight.controller.sal.core.UpdateType;
-import org.opendaylight.controller.sal.inventory.IInventoryService;
-import org.opendaylight.controller.sal.inventory.IListenInventoryUpdates;
-import org.opendaylight.controller.sal.reader.NodeDescription;
-import org.opendaylight.controller.sal.utils.GlobalConstants;
-import org.opendaylight.controller.sal.utils.IObjectReader;
-import org.opendaylight.controller.sal.utils.ServiceHelper;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.sal.utils.StatusCode;
-import org.opendaylight.controller.statisticsmanager.IStatisticsManager;
-import org.opendaylight.controller.switchmanager.IInventoryListener;
-import org.opendaylight.controller.switchmanager.ISpanAware;
-import org.opendaylight.controller.switchmanager.ISwitchManager;
-import org.opendaylight.controller.switchmanager.ISwitchManagerAware;
-import org.opendaylight.controller.switchmanager.SpanConfig;
-import org.opendaylight.controller.switchmanager.Subnet;
-import org.opendaylight.controller.switchmanager.SubnetConfig;
-import org.opendaylight.controller.switchmanager.Switch;
-import org.opendaylight.controller.switchmanager.SwitchConfig;
-import org.osgi.framework.BundleContext;
-import org.osgi.framework.FrameworkUtil;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * The class describes SwitchManager which is the central repository of all the
- * inventory data including nodes, node connectors, properties attached, Layer3
- * configurations, Span configurations, node configurations, network device
- * representations viewed by Controller Web applications. One SwitchManager
- * instance per container of the network. All the node/nodeConnector properties
- * are maintained in the default container only.
- */
-public class SwitchManager implements ISwitchManager, IConfigurationContainerAware,
-                                      IObjectReader, IListenInventoryUpdates, CommandProvider {
-    private static Logger log = LoggerFactory.getLogger(SwitchManager.class);
-    private static final String SUBNETS_FILE_NAME = "subnets.conf";
-    private static final String SPAN_FILE_NAME = "spanPorts.conf";
-    private static final String SWITCH_CONFIG_FILE_NAME = "switchConfig.conf";
-    private final List<NodeConnector> spanNodeConnectors = new CopyOnWriteArrayList<NodeConnector>();
-    // Collection of Subnets keyed by the InetAddress
-    private ConcurrentMap<InetAddress, Subnet> subnets;
-    private ConcurrentMap<String, SubnetConfig> subnetsConfigList;
-    private ConcurrentMap<SpanConfig, SpanConfig> spanConfigList;
-    // manually configured parameters for the node such as name, tier, mode
-    private ConcurrentMap<String, SwitchConfig> nodeConfigList;
-    private ConcurrentMap<Node, Map<String, Property>> nodeProps;
-    private ConcurrentMap<NodeConnector, Map<String, Property>> nodeConnectorProps;
-    private ConcurrentMap<Node, Map<String, NodeConnector>> nodeConnectorNames;
-    private ConcurrentMap<String, Property> controllerProps;
-    private IInventoryService inventoryService;
-    private IStatisticsManager statisticsManager;
-    private IControllerProperties controllerProperties;
-    private IConfigurationContainerService configurationService;
-    private final Set<ISwitchManagerAware> switchManagerAware = Collections
-            .synchronizedSet(new HashSet<ISwitchManagerAware>());
-    private final Set<IInventoryListener> inventoryListeners = Collections
-            .synchronizedSet(new HashSet<IInventoryListener>());
-    private final Set<ISpanAware> spanAware = Collections.synchronizedSet(new HashSet<ISpanAware>());
-    private IClusterContainerServices clusterContainerService = null;
-    private String containerName = null;
-    private boolean isDefaultContainer = true;
-    private static final int REPLACE_RETRY = 1;
-
-    /* Information about the default subnet. If there have been no configured subnets, i.e.,
-     * subnets.size() == 0 or subnetsConfigList.size() == 0, then this subnet will be the
-     * only subnet returned. As soon as a user-configured subnet is created this one will
-     * vanish.
-     */
-    private static final String DISABLE_DEFAULT_SUBNET_PROP = "switchmanager.disableDefaultSubnetGateway";
-    private static final String DISABLE_DEFAULT_SUBNET_PROP_VAL = System.getProperty(DISABLE_DEFAULT_SUBNET_PROP);
-    private static final boolean USE_DEFAULT_SUBNET_GW = !Boolean.valueOf(DISABLE_DEFAULT_SUBNET_PROP_VAL);
-    protected static final SubnetConfig DEFAULT_SUBNETCONFIG;
-    protected static final Subnet DEFAULT_SUBNET;
-    protected static final String DEFAULT_SUBNET_NAME = "default (cannot be modifed)";
-    static{
-        DEFAULT_SUBNETCONFIG = new SubnetConfig(DEFAULT_SUBNET_NAME, "0.0.0.0/0", new ArrayList<String>());
-        DEFAULT_SUBNET = new Subnet(DEFAULT_SUBNETCONFIG);
-    }
-
-    public void notifySubnetChange(Subnet sub, boolean add) {
-        synchronized (switchManagerAware) {
-            for (Object subAware : switchManagerAware) {
-                try {
-                    ((ISwitchManagerAware) subAware).subnetNotify(sub, add);
-                } catch (Exception e) {
-                    log.error("Failed to notify Subnet change {}",
-                            e.getMessage());
-                }
-            }
-        }
-    }
-
-    public void notifySpanPortChange(Node node, List<NodeConnector> ports, boolean add) {
-        synchronized (spanAware) {
-            for (Object sa : spanAware) {
-                try {
-                    ((ISpanAware) sa).spanUpdate(node, ports, add);
-                } catch (Exception e) {
-                    log.error("Failed to notify Span Interface change {}",
-                            e.getMessage());
-                }
-            }
-        }
-    }
-
-    private void notifyModeChange(Node node, boolean proactive) {
-        synchronized (switchManagerAware) {
-            for (ISwitchManagerAware service : switchManagerAware) {
-                try {
-                    service.modeChangeNotify(node, proactive);
-                } catch (Exception e) {
-                    log.error("Failed to notify Subnet change {}",
-                            e.getMessage());
-                }
-            }
-        }
-    }
-
-    public void startUp() {
-        // Instantiate cluster synced variables
-        allocateCaches();
-        retrieveCaches();
-
-        // Add controller MAC, if first node in the cluster
-        if ((!controllerProps.containsKey(MacAddress.name)) && (controllerProperties != null)) {
-            Property controllerMac = controllerProperties.getControllerProperty(MacAddress.name);
-            if (controllerMac != null) {
-                Property existing = controllerProps.putIfAbsent(MacAddress.name, controllerMac);
-                if (existing == null && log.isTraceEnabled()) {
-                    log.trace("Container {}: Setting controller MAC address in the cluster: {}", getContainerName(),
-                            controllerMac);
-                }
-            }
-        }
-    }
-
-    public void shutDown() {
-    }
-
-    private void allocateCaches() {
-        if (this.clusterContainerService == null) {
-            this.nonClusterObjectCreate();
-            log.warn("un-initialized clusterContainerService, can't create cache");
-            return;
-        }
-
-        try {
-            clusterContainerService.createCache(
-                    "switchmanager.subnetsConfigList",
-                    EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-            clusterContainerService.createCache("switchmanager.spanConfigList",
-                    EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-            clusterContainerService.createCache("switchmanager.nodeConfigList",
-                    EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-            clusterContainerService.createCache("switchmanager.subnets",
-                    EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-            clusterContainerService.createCache("switchmanager.nodeProps",
-                    EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-            clusterContainerService.createCache(
-                    "switchmanager.nodeConnectorProps",
-                    EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-            clusterContainerService.createCache(
-                    "switchmanager.nodeConnectorNames",
-                    EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-            clusterContainerService.createCache(
-                    "switchmanager.controllerProps",
-                    EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-        } catch (CacheConfigException cce) {
-            log.error("\nCache configuration invalid - check cache mode");
-        } catch (CacheExistException ce) {
-            log.error("\nCache already exits - destroy and recreate if needed");
-        }
-    }
-
-    @SuppressWarnings({ "unchecked" })
-    private void retrieveCaches() {
-        if (this.clusterContainerService == null) {
-            log.warn("un-initialized clusterContainerService, can't create cache");
-            return;
-        }
-
-        subnetsConfigList = (ConcurrentMap<String, SubnetConfig>) clusterContainerService
-                .getCache("switchmanager.subnetsConfigList");
-        if (subnetsConfigList == null) {
-            log.error("\nFailed to get cache for subnetsConfigList");
-        }
-
-        spanConfigList = (ConcurrentMap<SpanConfig, SpanConfig>) clusterContainerService
-                .getCache("switchmanager.spanConfigList");
-        if (spanConfigList == null) {
-            log.error("\nFailed to get cache for spanConfigList");
-        }
-
-        nodeConfigList = (ConcurrentMap<String, SwitchConfig>) clusterContainerService
-                .getCache("switchmanager.nodeConfigList");
-        if (nodeConfigList == null) {
-            log.error("\nFailed to get cache for nodeConfigList");
-        }
-
-        subnets = (ConcurrentMap<InetAddress, Subnet>) clusterContainerService
-                .getCache("switchmanager.subnets");
-        if (subnets == null) {
-            log.error("\nFailed to get cache for subnets");
-        }
-
-        nodeProps = (ConcurrentMap<Node, Map<String, Property>>) clusterContainerService
-                .getCache("switchmanager.nodeProps");
-        if (nodeProps == null) {
-            log.error("\nFailed to get cache for nodeProps");
-        }
-
-        nodeConnectorProps = (ConcurrentMap<NodeConnector, Map<String, Property>>) clusterContainerService
-                .getCache("switchmanager.nodeConnectorProps");
-        if (nodeConnectorProps == null) {
-            log.error("\nFailed to get cache for nodeConnectorProps");
-        }
-
-        nodeConnectorNames = (ConcurrentMap<Node, Map<String, NodeConnector>>) clusterContainerService
-                .getCache("switchmanager.nodeConnectorNames");
-        if (nodeConnectorNames == null) {
-            log.error("\nFailed to get cache for nodeConnectorNames");
-        }
-
-        controllerProps = (ConcurrentMap<String, Property>) clusterContainerService
-                .getCache("switchmanager.controllerProps");
-        if (controllerProps == null) {
-            log.error("\nFailed to get cache for controllerProps");
-        }
-    }
-
-    private void nonClusterObjectCreate() {
-        subnetsConfigList = new ConcurrentHashMap<String, SubnetConfig>();
-        spanConfigList = new ConcurrentHashMap<SpanConfig, SpanConfig>();
-        nodeConfigList = new ConcurrentHashMap<String, SwitchConfig>();
-        subnets = new ConcurrentHashMap<InetAddress, Subnet>();
-        nodeProps = new ConcurrentHashMap<Node, Map<String, Property>>();
-        nodeConnectorProps = new ConcurrentHashMap<NodeConnector, Map<String, Property>>();
-        nodeConnectorNames = new ConcurrentHashMap<Node, Map<String, NodeConnector>>();
-        controllerProps = new ConcurrentHashMap<String, Property>();
-    }
-
-    @Override
-    public List<SubnetConfig> getSubnetsConfigList() {
-        // if there are no subnets, return the default subnet
-        if (USE_DEFAULT_SUBNET_GW && subnetsConfigList.isEmpty()) {
-            return Collections.singletonList(DEFAULT_SUBNETCONFIG);
-        } else {
-            return new ArrayList<SubnetConfig>(subnetsConfigList.values());
-        }
-    }
-
-    @Override
-    public SubnetConfig getSubnetConfig(String subnet) {
-        // if there are no subnets, return the default subnet
-        if (USE_DEFAULT_SUBNET_GW && subnetsConfigList.isEmpty() && subnet.equalsIgnoreCase(DEFAULT_SUBNET_NAME)) {
-            return DEFAULT_SUBNETCONFIG;
-        } else {
-            return subnetsConfigList.get(subnet);
-        }
-    }
-
-    private List<SpanConfig> getSpanConfigList(Node node) {
-        List<SpanConfig> confList = new ArrayList<SpanConfig>();
-        String nodeId = node.toString();
-        for (SpanConfig conf : spanConfigList.values()) {
-            if (conf.matchNode(nodeId)) {
-                confList.add(conf);
-            }
-        }
-        return confList;
-    }
-
-    public List<SwitchConfig> getNodeConfigList() {
-        return new ArrayList<SwitchConfig>(nodeConfigList.values());
-    }
-
-    @Override
-    public SwitchConfig getSwitchConfig(String switchId) {
-        return nodeConfigList.get(switchId);
-    }
-
-    public Switch getSwitchByNode(Node node) {
-        Switch sw = new Switch(node);
-        sw.setNode(node);
-        MacAddress mac = (MacAddress) this.getNodeProp(node,
-                MacAddress.name);
-        if (mac != null) {
-            sw.setDataLayerAddress(mac.getMacAddress());
-        }
-        Set<NodeConnector> ncSet = getPhysicalNodeConnectors(node);
-        sw.setNodeConnectors(ncSet);
-
-        List<NodeConnector> ncList = new ArrayList<NodeConnector>();
-        for (NodeConnector nodeConnector : ncSet) {
-            if (spanNodeConnectors.contains(nodeConnector)) {
-                ncList.add(nodeConnector);
-            }
-        }
-        sw.addSpanPorts(ncList);
-
-        return sw;
-    }
-
-    @Override
-    public List<Switch> getNetworkDevices() {
-        List<Switch> swList = new ArrayList<Switch>();
-        for (Node node : getNodes()) {
-            swList.add(getSwitchByNode(node));
-        }
-        return swList;
-    }
-
-    private Status updateConfig(SubnetConfig conf, boolean add) {
-        if (add) {
-            if(subnetsConfigList.putIfAbsent(conf.getName(), conf) != null) {
-                String msg = "Cluster conflict: Subnet with name " + conf.getName() + "already exists.";
-                return new Status(StatusCode.CONFLICT, msg);
-            }
-        } else {
-            subnetsConfigList.remove(conf.getName());
-        }
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    private Status updateDatabase(SubnetConfig conf, boolean add) {
-        if (add) {
-            Subnet subnetCurr = subnets.get(conf.getIPAddress());
-            Subnet subnet;
-            if (subnetCurr == null) {
-                subnet = new Subnet(conf);
-            } else {
-                subnet = subnetCurr.clone();
-            }
-            // In case of API3 call we may receive the ports along with the
-            // subnet creation
-            if (!conf.isGlobal()) {
-                subnet.addNodeConnectors(conf.getNodeConnectors());
-            }
-            boolean putNewSubnet = false;
-            if(subnetCurr == null) {
-                if(subnets.putIfAbsent(conf.getIPAddress(), subnet) == null) {
-                    putNewSubnet = true;
-                }
-            } else {
-                putNewSubnet = subnets.replace(conf.getIPAddress(), subnetCurr, subnet);
-            }
-            if(!putNewSubnet) {
-                String msg = "Cluster conflict: Conflict while adding the subnet " + conf.getIPAddress();
-                return new Status(StatusCode.CONFLICT, msg);
-            }
-
-        // Subnet removal case
-        } else {
-            subnets.remove(conf.getIPAddress());
-        }
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    private Status semanticCheck(SubnetConfig conf) {
-        Set<InetAddress> IPs = subnets.keySet();
-        if (IPs == null) {
-            return new Status(StatusCode.SUCCESS);
-        }
-        Subnet newSubnet = new Subnet(conf);
-        for (InetAddress i : IPs) {
-            Subnet existingSubnet = subnets.get(i);
-            if ((existingSubnet != null) && !existingSubnet.isMutualExclusive(newSubnet)) {
-                return new Status(StatusCode.CONFLICT, "This subnet conflicts with an existing one.");
-            }
-        }
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    private Status addRemoveSubnet(SubnetConfig conf, boolean isAdding) {
-        // Valid configuration check
-        Status status = conf.validate();
-        if (!status.isSuccess()) {
-            log.warn(status.getDescription());
-            return status;
-        }
-
-        if (isAdding) {
-            // Presence check
-            if (subnetsConfigList.containsKey(conf.getName())) {
-                return new Status(StatusCode.CONFLICT,
-                        "Subnet with the specified name already exists.");
-            }
-            // Semantic check
-            status = semanticCheck(conf);
-            if (!status.isSuccess()) {
-                return status;
-            }
-        } else {
-            if (conf.getName().equalsIgnoreCase(DEFAULT_SUBNET_NAME)) {
-                return new Status(StatusCode.NOTALLOWED, "The specified subnet gateway cannot be removed");
-            }
-        }
-
-        // Update Database
-        status = updateDatabase(conf, isAdding);
-
-        if (status.isSuccess()) {
-            // Update Configuration
-            status = updateConfig(conf, isAdding);
-            if(!status.isSuccess()) {
-                updateDatabase(conf, (!isAdding));
-            } else {
-                // update the listeners
-                Subnet subnetCurr = subnets.get(conf.getIPAddress());
-                Subnet subnet;
-                if (subnetCurr == null) {
-                    subnet = new Subnet(conf);
-                } else {
-                    subnet = subnetCurr.clone();
-                }
-                notifySubnetChange(subnet, isAdding);
-            }
-        }
-
-        return status;
-    }
-
-    /**
-     * Adds Subnet configured in GUI or API3
-     */
-    @Override
-    public Status addSubnet(SubnetConfig conf) {
-        return this.addRemoveSubnet(conf, true);
-    }
-
-    @Override
-    public Status removeSubnet(SubnetConfig conf) {
-        return this.addRemoveSubnet(conf, false);
-    }
-
-    @Override
-    public Status removeSubnet(String name) {
-        if (name.equalsIgnoreCase(DEFAULT_SUBNET_NAME)) {
-            return new Status(StatusCode.NOTALLOWED, "The specified subnet gateway cannot be removed");
-        }
-        SubnetConfig conf = subnetsConfigList.get(name);
-        if (conf == null) {
-            return new Status(StatusCode.SUCCESS, "Subnet not present");
-        }
-        return this.addRemoveSubnet(conf, false);
-    }
-
-    @Override
-    public Status modifySubnet(SubnetConfig conf) {
-        // Sanity check
-        if (conf == null) {
-            return new Status(StatusCode.BADREQUEST, "Invalid Subnet configuration: null");
-        }
-
-        // Valid configuration check
-        Status status = conf.validate();
-        if (!status.isSuccess()) {
-            log.warn(status.getDescription());
-            return status;
-        }
-
-        // If a subnet configuration with this name does not exist, consider this is a creation
-        SubnetConfig target = subnetsConfigList.get(conf.getName());
-        if (target == null) {
-            return this.addSubnet(conf);
-        }
-
-        // No change
-        if (target.equals(conf)) {
-            return new Status(StatusCode.SUCCESS);
-        }
-
-        // Check not allowed modifications
-        if (!target.getSubnet().equals(conf.getSubnet())) {
-            return new Status(StatusCode.BADREQUEST, "IP address change is not allowed");
-        }
-
-        // Derive the set of node connectors that are being removed
-        Set<NodeConnector> toRemove = target.getNodeConnectors();
-        toRemove.removeAll(conf.getNodeConnectors());
-        List<String> nodeConnectorStrings = null;
-        if (!toRemove.isEmpty()) {
-            nodeConnectorStrings = new ArrayList<String>();
-            for (NodeConnector nc : toRemove) {
-                nodeConnectorStrings.add(nc.toString());
-            }
-            status = this.removePortsFromSubnet(conf.getName(), nodeConnectorStrings);
-            if (!status.isSuccess()) {
-                return status;
-            }
-        }
-
-        // Derive the set of node connectors that are being added
-        Set<NodeConnector> toAdd = conf.getNodeConnectors();
-        toAdd.removeAll(target.getNodeConnectors());
-        if (!toAdd.isEmpty()) {
-            List<String> nodeConnectorStringRemoved = nodeConnectorStrings;
-            nodeConnectorStrings = new ArrayList<String>();
-            for (NodeConnector nc : toAdd) {
-                nodeConnectorStrings.add(nc.toString());
-            }
-            status = this.addPortsToSubnet(conf.getName(), nodeConnectorStrings);
-            if (!status.isSuccess()) {
-                // If any port was removed, add it back as a best recovery effort
-                if (!toRemove.isEmpty()) {
-                    this.addPortsToSubnet(conf.getName(), nodeConnectorStringRemoved);
-                }
-                return status;
-            }
-        }
-
-        // Update Configuration
-        subnetsConfigList.put(conf.getName(), conf);
-
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    @Override
-    public Status addPortsToSubnet(String name, List<String> switchPorts) {
-        if (name == null) {
-            return new Status(StatusCode.BADREQUEST, "Null subnet name");
-        }
-        SubnetConfig confCurr = subnetsConfigList.get(name);
-        if (confCurr == null) {
-            return new Status(StatusCode.NOTFOUND, "Subnet does not exist");
-        }
-
-        if (switchPorts == null || switchPorts.isEmpty()) {
-            return new Status(StatusCode.BADREQUEST, "Null or empty port set");
-        }
-
-        Subnet subCurr = subnets.get(confCurr.getIPAddress());
-        if (subCurr == null) {
-            log.debug("Cluster conflict: Subnet entry {} is not present in the subnets cache.", confCurr.getIPAddress());
-            return new Status(StatusCode.NOTFOUND, "Subnet does not exist");
-        }
-
-        // Update Database
-        Subnet sub = subCurr.clone();
-        Set<NodeConnector> sp = NodeConnector.fromString(switchPorts);
-        sub.addNodeConnectors(sp);
-        boolean subnetsReplaced = subnets.replace(confCurr.getIPAddress(), subCurr, sub);
-        if (!subnetsReplaced) {
-            String msg = "Cluster conflict: Conflict while adding ports to the subnet " + name;
-            return new Status(StatusCode.CONFLICT, msg);
-        }
-
-        // Update Configuration
-        SubnetConfig conf = confCurr.clone();
-        conf.addNodeConnectors(switchPorts);
-        boolean configReplaced = subnetsConfigList.replace(name, confCurr, conf);
-        if (!configReplaced) {
-            // TODO: recovery using Transactionality
-            String msg = "Cluster conflict: Conflict while adding ports to the subnet " + name;
-            return new Status(StatusCode.CONFLICT, msg);
-        }
-
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    @Override
-    public Status removePortsFromSubnet(String name, List<String> switchPorts) {
-        if (name == null) {
-            return new Status(StatusCode.BADREQUEST, "Null subnet name");
-        }
-        SubnetConfig confCurr = subnetsConfigList.get(name);
-        if (confCurr == null) {
-            return new Status(StatusCode.NOTFOUND, "Subnet does not exist");
-        }
-
-        if (switchPorts == null || switchPorts.isEmpty()) {
-            return new Status(StatusCode.BADREQUEST, "Null or empty port set");
-        }
-
-        Subnet subCurr = subnets.get(confCurr.getIPAddress());
-        if (subCurr == null) {
-            log.debug("Cluster conflict: Subnet entry {} is not present in the subnets cache.", confCurr.getIPAddress());
-            return new Status(StatusCode.NOTFOUND, "Subnet does not exist");
-        }
-
-        // Validation check
-        Status status = SubnetConfig.validatePorts(switchPorts);
-        if (!status.isSuccess()) {
-            return status;
-        }
-        // Update Database
-        Subnet sub = subCurr.clone();
-        Set<NodeConnector> sp = NodeConnector.fromString(switchPorts);
-        sub.deleteNodeConnectors(sp);
-        boolean subnetsReplace = subnets.replace(confCurr.getIPAddress(), subCurr, sub);
-        if (!subnetsReplace) {
-            String msg = "Cluster conflict: Conflict while removing ports from the subnet " + name;
-            return new Status(StatusCode.CONFLICT, msg);
-        }
-
-        // Update Configuration
-        SubnetConfig conf = confCurr.clone();
-        conf.removeNodeConnectors(switchPorts);
-        boolean result = subnetsConfigList.replace(name, confCurr, conf);
-        if (!result) {
-            // TODO: recovery using Transactionality
-            String msg = "Cluster conflict: Conflict while removing ports from " + conf;
-            return new Status(StatusCode.CONFLICT, msg);
-        }
-
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    public String getContainerName() {
-        if (containerName == null) {
-            return GlobalConstants.DEFAULT.toString();
-        }
-        return containerName;
-    }
-
-    @Override
-    public Subnet getSubnetByNetworkAddress(InetAddress networkAddress) {
-        // if there are no subnets, return the default subnet
-        if (subnets.size() == 0) {
-            return DEFAULT_SUBNET;
-        }
-
-        for(Map.Entry<InetAddress,Subnet> subnetEntry : subnets.entrySet()) {
-            if(subnetEntry.getValue().isSubnetOf(networkAddress)) {
-                return subnetEntry.getValue();
-            }
-        }
-        return null;
-    }
-
-    @Override
-    public Object readObject(ObjectInputStream ois)
-            throws FileNotFoundException, IOException, ClassNotFoundException {
-        // Perform the class deserialization locally, from inside the package
-        // where the class is defined
-        return ois.readObject();
-    }
-
-    private void loadSubnetConfiguration() {
-        for (ConfigurationObject conf : configurationService.retrieveConfiguration(this, SUBNETS_FILE_NAME)) {
-            addSubnet((SubnetConfig) conf);
-        }
-    }
-
-    private void loadSpanConfiguration() {
-        for (ConfigurationObject conf : configurationService.retrieveConfiguration(this, SPAN_FILE_NAME)) {
-            addSpanConfig((SpanConfig) conf);
-        }
-    }
-
-    private void loadSwitchConfiguration() {
-        for (ConfigurationObject conf : configurationService.retrieveConfiguration(this, SWITCH_CONFIG_FILE_NAME)) {
-            updateNodeConfig((SwitchConfig) conf);
-        }
-    }
-
-    @SuppressWarnings("deprecation")
-    @Override
-    public void updateSwitchConfig(SwitchConfig cfgObject) {
-        // update default container only
-        if (!isDefaultContainer) {
-            return;
-        }
-
-        SwitchConfig sc = nodeConfigList.get(cfgObject.getNodeId());
-        if (sc == null) {
-            if (nodeConfigList.putIfAbsent(cfgObject.getNodeId(), cfgObject) != null) {
-                return;
-            }
-        } else {
-            if (!nodeConfigList.replace(cfgObject.getNodeId(), sc, cfgObject)) {
-                return;
-            }
-        }
-
-        boolean modeChange = false;
-
-        if ((sc == null) || !cfgObject.getMode().equals(sc.getMode())) {
-            modeChange = true;
-        }
-
-        String nodeId = cfgObject.getNodeId();
-        Node node = Node.fromString(nodeId);
-        Map<String, Property> propMapCurr = nodeProps.get(node);
-        if (propMapCurr == null) {
-            return;
-        }
-        Map<String, Property> propMap = new HashMap<String, Property>(propMapCurr);
-        Property desc = new Description(cfgObject.getNodeDescription());
-        propMap.put(desc.getName(), desc);
-        Property tier = new Tier(Integer.parseInt(cfgObject.getTier()));
-        propMap.put(tier.getName(), tier);
-
-        if (!nodeProps.replace(node, propMapCurr, propMap)) {
-            // TODO rollback using Transactionality
-            return;
-        }
-
-        log.trace("Set Node {}'s Mode to {}", nodeId, cfgObject.getMode());
-
-        if (modeChange) {
-            notifyModeChange(node, cfgObject.isProactive());
-        }
-    }
-
-    @Override
-    public Status updateNodeConfig(SwitchConfig switchConfig) {
-        Status status = switchConfig.validate();
-        if (!status.isSuccess()) {
-            return status;
-        }
-
-        Map<String, Property> updateProperties = switchConfig.getNodeProperties();
-        ForwardingMode mode = (ForwardingMode) updateProperties.get(ForwardingMode.name);
-        if (mode != null) {
-            if (isDefaultContainer) {
-                if (!mode.isValid()) {
-                    return new Status(StatusCode.BADREQUEST, "Invalid Forwarding Mode Value");
-                }
-            } else {
-                return new Status(StatusCode.NOTACCEPTABLE,
-                        "Forwarding Mode modification is allowed only in default container");
-            }
-        }
-
-        Description description = (Description) switchConfig.getProperty(Description.propertyName);
-        String nodeId = switchConfig.getNodeId();
-        Node node = Node.fromString(nodeId);
-        NodeDescription nodeDesc = (this.statisticsManager == null) ? null : this.statisticsManager
-                .getNodeDescription(node);
-        String advertisedDesc = (nodeDesc == null) ? "" : nodeDesc.getDescription();
-        if (description != null && description.getValue() != null) {
-            if (description.getValue().isEmpty() || description.getValue().equals(advertisedDesc)) {
-                updateProperties.remove(Description.propertyName);
-                switchConfig = new SwitchConfig(nodeId, updateProperties);
-            } else {
-                // check if description is configured or was published by any other node
-                for (Map.Entry<Node, Map<String, Property>> entry : nodeProps.entrySet()) {
-                    Node n = entry.getKey();
-                    Description desc = (Description) getNodeProp(n, Description.propertyName);
-                    NodeDescription nDesc = (this.statisticsManager == null) ? null : this.statisticsManager
-                            .getNodeDescription(n);
-                    String advDesc = (nDesc == null) ? "" : nDesc.getDescription();
-                    if ((description.equals(desc) || description.getValue().equals(advDesc)) && !node.equals(n)) {
-                        return new Status(StatusCode.CONFLICT, "Node name already in use");
-                    }
-                }
-            }
-        }
-
-        boolean modeChange = false;
-        SwitchConfig sc = nodeConfigList.get(nodeId);
-        Map<String, Property> prevNodeProperties = new HashMap<String, Property>();
-        if (sc == null) {
-            if ((mode != null) && mode.isProactive()) {
-                modeChange = true;
-            }
-            if (!updateProperties.isEmpty()) {
-                if (nodeConfigList.putIfAbsent(nodeId, switchConfig) != null) {
-                    return new Status(StatusCode.CONFLICT, "Cluster conflict: Unable to update node configuration");
-                }
-            }
-        } else {
-            prevNodeProperties = new HashMap<String, Property>(sc.getNodeProperties());
-            ForwardingMode prevMode = (ForwardingMode) sc.getProperty(ForwardingMode.name);
-            if (mode == null) {
-                if ((prevMode != null) && (prevMode.isProactive())) {
-                    modeChange = true;
-                }
-            } else {
-                if (((prevMode != null) && (prevMode.getValue() != mode.getValue()))
-                        || (prevMode == null && mode.isProactive())) {
-                    modeChange = true;
-                }
-            }
-            if (updateProperties.isEmpty()) {
-                nodeConfigList.remove(nodeId);
-            } else {
-                if (!nodeConfigList.replace(nodeId, sc, switchConfig)) {
-                    return new Status(StatusCode.CONFLICT, "Cluster conflict: Unable to update node configuration");
-                }
-            }
-        }
-        Map<String, Property> propMapCurr = nodeProps.get(node);
-        if (propMapCurr == null) {
-            return new Status(StatusCode.SUCCESS);
-        }
-        Map<String, Property> propMap = new HashMap<String, Property>(propMapCurr);
-        for (Map.Entry<String, Property> entry : prevNodeProperties.entrySet()) {
-            String prop = entry.getKey();
-            if (!updateProperties.containsKey(prop)) {
-                if (prop.equals(Description.propertyName)) {
-                    if (advertisedDesc != null) {
-                        if (!advertisedDesc.isEmpty()) {
-                            Property desc = new Description(advertisedDesc);
-                            propMap.put(Description.propertyName, desc);
-                        }
-                    }
-                    else {
-                        propMap.remove(prop);
-                    }
-                    continue;
-                } else if (prop.equals(ForwardingMode.name)) {
-                    Property defaultMode = new ForwardingMode(ForwardingMode.REACTIVE_FORWARDING);
-                    propMap.put(ForwardingMode.name, defaultMode);
-                    continue;
-                }
-                propMap.remove(prop);
-            }
-        }
-        propMap.putAll(updateProperties);
-        if (!nodeProps.replace(node, propMapCurr, propMap)) {
-            // TODO rollback using Transactionality
-            return new Status(StatusCode.CONFLICT, "Cluster conflict: Unable to update node configuration");
-        }
-        if (modeChange) {
-            notifyModeChange(node, (mode == null) ? false : mode.isProactive());
-        }
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    @Override
-    public Status removeNodeConfig(String nodeId) {
-        if ((nodeId == null) || (nodeId.isEmpty())) {
-            return new Status(StatusCode.BADREQUEST, "nodeId cannot be empty.");
-        }
-        Map<String, Property> nodeProperties = getSwitchConfig(nodeId).getNodeProperties();
-        Node node = Node.fromString(nodeId);
-        Map<String, Property> propMapCurr = nodeProps.get(node);
-        if ((propMapCurr != null) && (nodeProperties != null) && (!nodeProperties.isEmpty())) {
-            Map<String, Property> propMap = new HashMap<String, Property>(propMapCurr);
-            for (Map.Entry<String, Property> entry : nodeProperties.entrySet()) {
-                String prop = entry.getKey();
-                if (prop.equals(Description.propertyName)) {
-                    Map<Node, Map<String, Property>> nodeProp = this.inventoryService.getNodeProps();
-                    if (nodeProp.get(node) != null) {
-                        propMap.put(Description.propertyName, nodeProp.get(node).get(Description.propertyName));
-                        continue;
-                    }
-                }
-                propMap.remove(prop);
-            }
-            if (!nodeProps.replace(node, propMapCurr, propMap)) {
-                return new Status(StatusCode.CONFLICT, "Cluster conflict: Unable to update node configuration.");
-            }
-        }
-        if (nodeConfigList != null) {
-            nodeConfigList.remove(nodeId);
-        }
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    @Override
-    public Status saveSwitchConfig() {
-        return saveSwitchConfigInternal();
-    }
-
-    public Status saveSwitchConfigInternal() {
-        Status status;
-        short number = 0;
-        status = configurationService.persistConfiguration(
-                new ArrayList<ConfigurationObject>(subnetsConfigList.values()), SUBNETS_FILE_NAME);
-        if (status.isSuccess()) {
-            number++;
-        } else {
-            log.warn("Failed to save subnet gateway configurations: " + status.getDescription());
-        }
-        status = configurationService.persistConfiguration(new ArrayList<ConfigurationObject>(spanConfigList.values()),
-                SPAN_FILE_NAME);
-        if (status.isSuccess()) {
-            number++;
-        } else {
-            log.warn("Failed to save span port configurations: " + status.getDescription());
-        }
-        status = configurationService.persistConfiguration(new ArrayList<ConfigurationObject>(nodeConfigList.values()),
-                SWITCH_CONFIG_FILE_NAME);
-        if (status.isSuccess()) {
-            number++;
-        } else {
-            log.warn("Failed to save node configurations: " + status.getDescription());
-        }
-        if (number == 0) {
-            return new Status(StatusCode.INTERNALERROR, "Save failed");
-        }
-        if (number < 3) {
-            return new Status(StatusCode.INTERNALERROR, "Partial save failure");
-        }
-        return status;
-    }
-
-    @Override
-    public List<SpanConfig> getSpanConfigList() {
-        return new ArrayList<SpanConfig>(spanConfigList.values());
-    }
-
-    @Override
-    public Status addSpanConfig(SpanConfig conf) {
-        // Valid config check
-        if (!conf.isValidConfig()) {
-            String msg = "Invalid Span configuration";
-            log.warn(msg);
-            return new Status(StatusCode.BADREQUEST, msg);
-        }
-
-        // Presence check
-        if (spanConfigList.containsKey(conf)) {
-            return new Status(StatusCode.CONFLICT, "Same span config exists");
-        }
-
-        // Update configuration
-        if (spanConfigList.putIfAbsent(conf, conf) == null) {
-            // Update database and notify clients
-            addSpanPorts(conf.getNode(), conf.getPortArrayList());
-        }
-
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    @Override
-    public Status removeSpanConfig(SpanConfig conf) {
-        removeSpanPorts(conf.getNode(), conf.getPortArrayList());
-
-        // Update configuration
-        spanConfigList.remove(conf);
-
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    @Override
-    public List<NodeConnector> getSpanPorts(Node node) {
-        List<NodeConnector> ncList = new ArrayList<NodeConnector>();
-
-        for (NodeConnector nodeConnector : spanNodeConnectors) {
-            if (nodeConnector.getNode().equals(node)) {
-                ncList.add(nodeConnector);
-            }
-        }
-        return ncList;
-    }
-
-    private void addNode(Node node, Set<Property> props) {
-        log.trace("{} added, props: {}", node, props);
-        if (nodeProps == null) {
-            return;
-        }
-
-        Map<String, Property> propMapCurr = nodeProps.get(node);
-        Map<String, Property> propMap = (propMapCurr == null) ? new HashMap<String, Property>()
-                : new HashMap<String, Property>(propMapCurr);
-
-        // copy node properties from plugin
-        if (props != null) {
-            for (Property prop : props) {
-                propMap.put(prop.getName(), prop);
-            }
-        }
-
-        boolean forwardingModeChanged = false;
-
-        // copy node properties from config
-        if (nodeConfigList != null) {
-            String nodeId = node.toString();
-            SwitchConfig conf = nodeConfigList.get(nodeId);
-            if (conf != null && (conf.getNodeProperties() != null)) {
-                Map<String, Property> nodeProperties = conf.getNodeProperties();
-                propMap.putAll(nodeProperties);
-                if (nodeProperties.get(ForwardingMode.name) != null) {
-                    ForwardingMode mode = (ForwardingMode) nodeProperties.get(ForwardingMode.name);
-                    forwardingModeChanged = mode.isProactive();
-                }
-            } else if ((conf == null) &&  !(GlobalConstants.DEFAULT.toString().equals(containerName))) {
-                ISwitchManager defaultSwitchManager = (ISwitchManager) ServiceHelper.getInstance(ISwitchManager.class, GlobalConstants.DEFAULT.toString(), this);
-                if (defaultSwitchManager != null) {
-                    Property defaultContainerSwitchDesc = (Description) defaultSwitchManager.getNodeProp(node, Description.propertyName);
-                    if (defaultContainerSwitchDesc != null) {
-                        Map<String, Property> descPropMap = new HashMap<String, Property>();
-                        descPropMap.put(Description.propertyName, defaultContainerSwitchDesc);
-                        conf = new SwitchConfig(nodeId, descPropMap);
-                        updateNodeConfig(conf);
-                        propMap.put(Description.propertyName, defaultContainerSwitchDesc);
-                    }
-                }
-            }
-        }
-
-        if (!propMap.containsKey(ForwardingMode.name)) {
-            Property defaultMode = new ForwardingMode(ForwardingMode.REACTIVE_FORWARDING);
-            propMap.put(ForwardingMode.name, defaultMode);
-        }
-
-        boolean propsAdded = false;
-        // Attempt initial add
-        if (nodeProps.putIfAbsent(node, propMap) == null) {
-                propsAdded = true;
-
-                /* Notify listeners only for initial node addition
-                 * to avoid expensive tasks triggered by redundant notifications
-                 */
-                notifyNode(node, UpdateType.ADDED, propMap);
-        } else {
-
-            propsAdded = nodeProps.replace(node, propMapCurr, propMap);
-
-            // check whether forwarding mode changed
-            if (propMapCurr.get(ForwardingMode.name) != null) {
-                ForwardingMode mode = (ForwardingMode) propMapCurr.get(ForwardingMode.name);
-                forwardingModeChanged ^= mode.isProactive();
-            }
-        }
-        if (!propsAdded) {
-            log.debug("Cluster conflict while adding node {}. Overwriting with latest props: {}", node.getID(), props);
-            addNodeProps(node, propMap);
-        }
-
-        // check if span ports are configured
-        addSpanPorts(node);
-        // notify proactive mode forwarding
-        if (forwardingModeChanged) {
-            notifyModeChange(node, true);
-        }
-    }
-
-    private void removeNode(Node node) {
-        log.trace("{} removed", node);
-        if (nodeProps == null) {
-            return;
-        }
-
-        if (nodeProps.remove(node) == null) {
-            log.debug("Received redundant node REMOVED udate for {}. Skipping..", node);
-            return;
-        }
-
-        nodeConnectorNames.remove(node);
-        Set<NodeConnector> removeNodeConnectorSet = new HashSet<NodeConnector>();
-        for (Map.Entry<NodeConnector, Map<String, Property>> entry : nodeConnectorProps.entrySet()) {
-            NodeConnector nodeConnector = entry.getKey();
-            if (nodeConnector.getNode().equals(node)) {
-                removeNodeConnectorSet.add(nodeConnector);
-            }
-        }
-        for (NodeConnector nc : removeNodeConnectorSet) {
-            nodeConnectorProps.remove(nc);
-        }
-
-        // check if span ports need to be cleaned up
-        removeSpanPorts(node);
-
-        /* notify node listeners */
-        notifyNode(node, UpdateType.REMOVED, null);
-    }
-
-    private void updateNode(Node node, Set<Property> props) {
-        log.trace("{} updated, props: {}", node, props);
-        if (nodeProps == null || props == null) {
-            return;
-        }
-
-        Map<String, Property> propMapCurr = nodeProps.get(node);
-        Map<String, Property> propMap = (propMapCurr == null) ? new HashMap<String, Property>()
-                : new HashMap<String, Property>(propMapCurr);
-
-        // copy node properties from plugin
-        String nodeId = node.toString();
-        for (Property prop : props) {
-            if (nodeConfigList != null) {
-                SwitchConfig conf = nodeConfigList.get(nodeId);
-                if (conf != null && (conf.getNodeProperties() != null)
-                        && conf.getNodeProperties().containsKey(prop.getName())) {
-                    continue;
-                }
-            }
-            propMap.put(prop.getName(), prop);
-        }
-
-        if (propMapCurr == null) {
-            if (nodeProps.putIfAbsent(node, propMap) != null) {
-                log.debug("Cluster conflict: Conflict while updating the node. Node: {}  Properties: {}",
-                        node.getID(), props);
-                addNodeProps(node, propMap);
-            }
-        } else {
-            if (!nodeProps.replace(node, propMapCurr, propMap)) {
-                log.debug("Cluster conflict: Conflict while updating the node. Node: {}  Properties: {}",
-                        node.getID(), props);
-                addNodeProps(node, propMap);
-            }
-        }
-
-        /* notify node listeners */
-        notifyNode(node, UpdateType.CHANGED, propMap);
-    }
-
-    @Override
-    public void updateNode(Node node, UpdateType type, Set<Property> props) {
-        log.debug("updateNode: {} type {} props {} for container {}",
-                new Object[] { node, type, props, containerName });
-        switch (type) {
-        case ADDED:
-            addNode(node, props);
-            break;
-        case CHANGED:
-            updateNode(node, props);
-            break;
-        case REMOVED:
-            removeNode(node);
-            break;
-        default:
-            break;
-        }
-    }
-
-    @Override
-    public void updateNodeConnector(NodeConnector nodeConnector,
-            UpdateType type, Set<Property> props) {
-        Map<String, Property> propMap = new HashMap<String, Property>();
-        boolean update = true;
-
-        log.debug("updateNodeConnector: {} type {} props {} for container {}",
-                new Object[] { nodeConnector, type, props, containerName });
-
-        if (nodeConnectorProps == null) {
-            return;
-        }
-
-        switch (type) {
-        case ADDED:
-            // Skip redundant ADDED update (e.g. cluster switch-over)
-            if (nodeConnectorProps.containsKey(nodeConnector)) {
-                log.debug("Redundant nodeconnector ADDED for {}, props {} for container {}",
-                        nodeConnector, props, containerName);
-                update = false;
-            }
-
-            if (props != null) {
-                for (Property prop : props) {
-                    addNodeConnectorProp(nodeConnector, prop);
-                    propMap.put(prop.getName(), prop);
-                }
-            } else {
-                addNodeConnectorProp(nodeConnector, null);
-            }
-
-
-            addSpanPort(nodeConnector);
-            break;
-        case CHANGED:
-            if (!nodeConnectorProps.containsKey(nodeConnector) || (props == null)) {
-                update = false;
-            } else {
-                for (Property prop : props) {
-                    addNodeConnectorProp(nodeConnector, prop);
-                    propMap.put(prop.getName(), prop);
-                }
-            }
-            break;
-        case REMOVED:
-            if (!nodeConnectorProps.containsKey(nodeConnector)) {
-                update = false;
-            }
-            removeNodeConnectorAllProps(nodeConnector);
-
-            // clean up span config
-            removeSpanPort(nodeConnector);
-            break;
-        default:
-            update = false;
-            break;
-        }
-
-        if (update) {
-            notifyNodeConnector(nodeConnector, type, propMap);
-        }
-    }
-
-    @Override
-    public Set<Node> getNodes() {
-        return (nodeProps != null) ? new HashSet<Node>(nodeProps.keySet()) : new HashSet<Node>();
-    }
-
-    @Override
-    public Map<String, Property> getControllerProperties() {
-        return new HashMap<String, Property>(this.controllerProps);
-    }
-
-    @Override
-    public Property getControllerProperty(String propertyName) {
-        if (propertyName != null) {
-            HashMap<String, Property> propertyMap =  new HashMap<String, Property>(this.controllerProps);
-            return propertyMap.get(propertyName);
-        }
-        return null;
-    }
-
-    @Override
-    public Status setControllerProperty(Property property) {
-        if (property != null) {
-            this.controllerProps.put(property.getName(), property);
-            return new Status(StatusCode.SUCCESS);
-        }
-        return new Status(StatusCode.BADREQUEST, "Invalid property provided when setting property");
-    }
-
-    @Override
-    public Status removeControllerProperty(String propertyName) {
-        if (propertyName != null) {
-            if (this.controllerProps.containsKey(propertyName)) {
-                this.controllerProps.remove(propertyName);
-                if (!this.controllerProps.containsKey(propertyName)) {
-                    return new Status(StatusCode.SUCCESS);
-                }
-            }
-            String msg = "Unable to remove property " + propertyName + " from Controller";
-            return new Status(StatusCode.BADREQUEST, msg);
-        }
-        String msg = "Invalid property provided when removing property from Controller";
-        return new Status(StatusCode.BADREQUEST, msg);
-    }
-
-    /*
-     * Returns a copy of a list of properties for a given node
-     *
-     * (non-Javadoc)
-     *
-     * @see
-     * org.opendaylight.controller.switchmanager.ISwitchManager#getNodeProps
-     * (org.opendaylight.controller.sal.core.Node)
-     */
-    @Override
-    public Map<String, Property> getNodeProps(Node node) {
-        Map<String, Property> rv = new HashMap<String, Property>();
-        if (this.nodeProps != null) {
-            rv = this.nodeProps.get(node);
-            if (rv != null) {
-                /* make a copy of it */
-                rv = new HashMap<String, Property>(rv);
-            }
-        }
-        return rv;
-    }
-
-    @Override
-    public Property getNodeProp(Node node, String propName) {
-        Map<String, Property> propMap = getNodeProps(node);
-        return (propMap != null) ? propMap.get(propName) : null;
-    }
-
-    @Override
-    public void setNodeProp(Node node, Property prop) {
-
-        for (int i = 0; i <= REPLACE_RETRY; i++) {
-            /* Get a copy of the property map */
-            Map<String, Property> propMapCurr = getNodeProps(node);
-            if (propMapCurr == null) {
-                return;
-            }
-
-            Map<String, Property> propMap = new HashMap<String, Property>(propMapCurr);
-            propMap.put(prop.getName(), prop);
-
-            if (nodeProps.replace(node, propMapCurr, propMap)) {
-                return;
-            }
-        }
-        log.warn("Cluster conflict: Unable to add property {} to node {}.", prop.getName(), node.getID());
-    }
-
-    @Override
-    public Status removeNodeProp(Node node, String propName) {
-        for (int i = 0; i <= REPLACE_RETRY; i++) {
-            Map<String, Property> propMapCurr = getNodeProps(node);
-            if (propMapCurr != null) {
-                if (!propMapCurr.containsKey(propName)) {
-                    return new Status(StatusCode.SUCCESS);
-                }
-                Map<String, Property> propMap = new HashMap<String, Property>(propMapCurr);
-                propMap.remove(propName);
-                if (nodeProps.replace(node, propMapCurr, propMap)) {
-                    return new Status(StatusCode.SUCCESS);
-                }
-            } else {
-                return new Status(StatusCode.SUCCESS);
-            }
-        }
-        String msg = "Cluster conflict: Unable to remove property " + propName + " for node " + node.getID();
-        return new Status(StatusCode.CONFLICT, msg);
-    }
-
-    @Override
-    public Status removeNodeAllProps(Node node) {
-        this.nodeProps.remove(node);
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    @Override
-    public Set<NodeConnector> getUpNodeConnectors(Node node) {
-        if (nodeConnectorProps == null) {
-            return null;
-        }
-
-        Set<NodeConnector> nodeConnectorSet = new HashSet<NodeConnector>();
-        for (Map.Entry<NodeConnector, Map<String, Property>> entry : nodeConnectorProps.entrySet()) {
-            NodeConnector nodeConnector = entry.getKey();
-            if (!nodeConnector.getNode().equals(node)) {
-                continue;
-            }
-            if (isNodeConnectorEnabled(nodeConnector)) {
-                nodeConnectorSet.add(nodeConnector);
-            }
-        }
-
-        return nodeConnectorSet;
-    }
-
-    @Override
-    public Set<NodeConnector> getNodeConnectors(Node node) {
-        if (nodeConnectorProps == null) {
-            return null;
-        }
-
-        Set<NodeConnector> nodeConnectorSet = new HashSet<NodeConnector>();
-        for (Map.Entry<NodeConnector, Map<String, Property>> entry : nodeConnectorProps.entrySet()) {
-            NodeConnector nodeConnector = entry.getKey();
-            if (!nodeConnector.getNode().equals(node)) {
-                continue;
-            }
-            nodeConnectorSet.add(nodeConnector);
-        }
-
-        return nodeConnectorSet;
-    }
-
-    @Override
-    public Set<NodeConnector> getPhysicalNodeConnectors(Node node) {
-        if (nodeConnectorProps == null) {
-            return null;
-        }
-
-        Set<NodeConnector> nodeConnectorSet = new HashSet<NodeConnector>();
-        for (Map.Entry<NodeConnector, Map<String, Property>> entry : nodeConnectorProps.entrySet()) {
-            NodeConnector nodeConnector = entry.getKey();
-            if (!nodeConnector.getNode().equals(node)
-                    || isSpecial(nodeConnector)) {
-                continue;
-            }
-            nodeConnectorSet.add(nodeConnector);
-        }
-
-        return nodeConnectorSet;
-    }
-
-    @Override
-    public Map<String, Property> getNodeConnectorProps(NodeConnector nodeConnector) {
-        Map<String, Property> rv = new HashMap<String, Property>();
-        if (this.nodeConnectorProps != null) {
-            rv = this.nodeConnectorProps.get(nodeConnector);
-            if (rv != null) {
-                rv = new HashMap<String, Property>(rv);
-            }
-        }
-        return rv;
-    }
-
-    @Override
-    public Property getNodeConnectorProp(NodeConnector nodeConnector,
-            String propName) {
-        Map<String, Property> propMap = getNodeConnectorProps(nodeConnector);
-        return (propMap != null) ? propMap.get(propName) : null;
-    }
-
-    @Override
-    public byte[] getControllerMAC() {
-        MacAddress macProperty = (MacAddress)controllerProps.get(MacAddress.name);
-        return (macProperty == null) ? null : macProperty.getMacAddress();
-    }
-
-    @Override
-    public NodeConnector getNodeConnector(Node node, String nodeConnectorName) {
-        if (nodeConnectorNames == null) {
-            return null;
-        }
-
-        Map<String, NodeConnector> map = nodeConnectorNames.get(node);
-        if (map == null) {
-            return null;
-        }
-
-        return map.get(nodeConnectorName);
-    }
-
-    /**
-     * Adds a node connector and its property if any
-     *
-     * @param nodeConnector
-     *            {@link org.opendaylight.controller.sal.core.NodeConnector}
-     * @param propName
-     *            name of {@link org.opendaylight.controller.sal.core.Property}
-     * @return success or failed reason
-     */
-    @Override
-    public Status addNodeConnectorProp(NodeConnector nodeConnector,
-            Property prop) {
-        Map<String, Property> propMapCurr = getNodeConnectorProps(nodeConnector);
-        Map<String, Property> propMap = (propMapCurr == null) ? new HashMap<String, Property>()
-                : new HashMap<String, Property>(propMapCurr);
-
-        String msg = "Cluster conflict: Unable to add NodeConnector Property.";
-        // Just add the nodeConnector if prop is not available (in a non-default
-        // container)
-        if (prop == null) {
-            if (propMapCurr == null) {
-                if (nodeConnectorProps.putIfAbsent(nodeConnector, propMap) != null) {
-                    return new Status(StatusCode.CONFLICT, msg);
-                }
-            } else {
-                if (!nodeConnectorProps.replace(nodeConnector, propMapCurr, propMap)) {
-                    return new Status(StatusCode.CONFLICT, msg);
-                }
-            }
-            return new Status(StatusCode.SUCCESS);
-        }
-
-        propMap.put(prop.getName(), prop);
-        if (propMapCurr == null) {
-            if (nodeConnectorProps.putIfAbsent(nodeConnector, propMap) != null) {
-                return new Status(StatusCode.CONFLICT, msg);
-            }
-        } else {
-            if (!nodeConnectorProps.replace(nodeConnector, propMapCurr, propMap)) {
-                return new Status(StatusCode.CONFLICT, msg);
-            }
-        }
-
-        if (prop.getName().equals(Name.NamePropName)) {
-            if (nodeConnectorNames != null) {
-                Node node = nodeConnector.getNode();
-                Map<String, NodeConnector> mapCurr = nodeConnectorNames.get(node);
-                Map<String, NodeConnector> map = new HashMap<String, NodeConnector>();
-                if (mapCurr != null) {
-                    for (Map.Entry<String, NodeConnector> entry : mapCurr.entrySet()) {
-                        String s = entry.getKey();
-                        try {
-                            map.put(s, new NodeConnector(entry.getValue()));
-                        } catch (ConstructionException e) {
-                            log.error("An error occured",e);
-                        }
-                    }
-                }
-
-                map.put(((Name) prop).getValue(), nodeConnector);
-                if (mapCurr == null) {
-                    if (nodeConnectorNames.putIfAbsent(node, map) != null) {
-                        // TODO: recovery using Transactionality
-                        return new Status(StatusCode.CONFLICT, msg);
-                    }
-                } else {
-                    if (!nodeConnectorNames.replace(node, mapCurr, map)) {
-                        // TODO: recovery using Transactionality
-                        return new Status(StatusCode.CONFLICT, msg);
-                    }
-                }
-            }
-        }
-
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    /**
-     * Removes one property of a node connector
-     *
-     * @param nodeConnector
-     *            {@link org.opendaylight.controller.sal.core.NodeConnector}
-     * @param propName
-     *            name of {@link org.opendaylight.controller.sal.core.Property}
-     * @return success or failed reason
-     */
-    @Override
-    public Status removeNodeConnectorProp(NodeConnector nodeConnector, String propName) {
-        Map<String, Property> propMapCurr = getNodeConnectorProps(nodeConnector);
-
-        if (propMapCurr == null) {
-            /* Nothing to remove */
-            return new Status(StatusCode.SUCCESS);
-        }
-
-        Map<String, Property> propMap = new HashMap<String, Property>(propMapCurr);
-        propMap.remove(propName);
-        boolean result = nodeConnectorProps.replace(nodeConnector, propMapCurr, propMap);
-        String msg = "Cluster conflict: Unable to remove NodeConnector property.";
-        if (!result) {
-            return new Status(StatusCode.CONFLICT, msg);
-        }
-
-        if (propName.equals(Name.NamePropName)) {
-            if (nodeConnectorNames != null) {
-                Name name = ((Name) getNodeConnectorProp(nodeConnector, Name.NamePropName));
-                if (name != null) {
-                    Node node = nodeConnector.getNode();
-                    Map<String, NodeConnector> mapCurr = nodeConnectorNames.get(node);
-                    if (mapCurr != null) {
-                        Map<String, NodeConnector> map = new HashMap<String, NodeConnector>();
-                        for (Map.Entry<String, NodeConnector> entry : mapCurr.entrySet()) {
-                            String s = entry.getKey();
-                            try {
-                                map.put(s, new NodeConnector(entry.getValue()));
-                            } catch (ConstructionException e) {
-                                log.error("An error occured",e);
-                            }
-                        }
-                        map.remove(name.getValue());
-                        if (!nodeConnectorNames.replace(node, mapCurr, map)) {
-                            // TODO: recovery using Transactionality
-                            return new Status(StatusCode.CONFLICT, msg);
-                        }
-                    }
-                }
-            }
-        }
-
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    /**
-     * Removes all the properties of a node connector
-     *
-     * @param nodeConnector
-     *            {@link org.opendaylight.controller.sal.core.NodeConnector}
-     * @return success or failed reason
-     */
-    @Override
-    public Status removeNodeConnectorAllProps(NodeConnector nodeConnector) {
-        if (nodeConnectorNames != null) {
-            Name name = ((Name) getNodeConnectorProp(nodeConnector, Name.NamePropName));
-            if (name != null) {
-                Node node = nodeConnector.getNode();
-                Map<String, NodeConnector> mapCurr = nodeConnectorNames.get(node);
-                if (mapCurr != null) {
-                    Map<String, NodeConnector> map = new HashMap<String, NodeConnector>();
-                    for (Map.Entry<String, NodeConnector> entry : mapCurr.entrySet()) {
-                        String s = entry.getKey();
-                        try {
-                            map.put(s, new NodeConnector(entry.getValue()));
-                        } catch (ConstructionException e) {
-                            log.error("An error occured",e);
-                        }
-                    }
-                    map.remove(name.getValue());
-                    if (map.isEmpty()) {
-                        nodeConnectorNames.remove(node);
-                    } else {
-                        if (!nodeConnectorNames.replace(node, mapCurr, map)) {
-                            log.warn("Cluster conflict: Unable remove Name property of nodeconnector {}, skip.",
-                                    nodeConnector.getID());
-                        }
-                    }
-                }
-
-            }
-        }
-        nodeConnectorProps.remove(nodeConnector);
-
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    /**
-     * Function called by the dependency manager when all the required
-     * dependencies are satisfied
-     *
-     */
-    void init(Component c) {
-        Dictionary<?, ?> props = c.getServiceProperties();
-        if (props != null) {
-            this.containerName = (String) props.get("containerName");
-            log.trace("Running containerName: {}", this.containerName);
-        } else {
-            // In the Global instance case the containerName is empty
-            this.containerName = "";
-        }
-        isDefaultContainer = containerName.equals(GlobalConstants.DEFAULT
-                .toString());
-
-    }
-
-    /**
-     * Function called by the dependency manager when at least one dependency
-     * become unsatisfied or when the component is shutting down because for
-     * example bundle is being stopped.
-     *
-     */
-    void destroy() {
-        shutDown();
-    }
-
-    /**
-     * Function called by dependency manager after "init ()" is called and after
-     * the services provided by the class are registered in the service registry
-     *
-     */
-    void start() {
-        startUp();
-
-        /*
-         * Read startup and build database if we are the coordinator
-         */
-        loadSubnetConfiguration();
-        loadSpanConfiguration();
-        loadSwitchConfiguration();
-
-        // OSGI console
-        registerWithOSGIConsole();
-    }
-
-    /**
-     * Function called after registered the service in OSGi service registry.
-     */
-    void started() {
-        // solicit for existing inventories
-        getInventories();
-    }
-
-    /**
-     * Function called by the dependency manager before the services exported by
-     * the component are unregistered, this will be followed by a "destroy ()"
-     * calls
-     *
-     */
-    void stop() {
-    }
-
-    public void setConfigurationContainerService(IConfigurationContainerService service) {
-        log.trace("Got configuration service set request {}", service);
-        this.configurationService = service;
-    }
-
-    public void unsetConfigurationContainerService(IConfigurationContainerService service) {
-        log.trace("Got configuration service UNset request");
-        this.configurationService = null;
-    }
-
-    public void setInventoryService(IInventoryService service) {
-        log.trace("Got inventory service set request {}", service);
-        this.inventoryService = service;
-
-        // solicit for existing inventories
-        getInventories();
-    }
-
-    public void unsetInventoryService(IInventoryService service) {
-        log.trace("Got a service UNset request");
-        this.inventoryService = null;
-
-        // clear existing inventories
-        clearInventories();
-    }
-
-    public void setStatisticsManager(IStatisticsManager statisticsManager) {
-        log.trace("Got statistics manager set request {}", statisticsManager);
-        this.statisticsManager = statisticsManager;
-    }
-
-    public void unsetStatisticsManager(IStatisticsManager statisticsManager) {
-        log.trace("Got statistics manager UNset request");
-        this.statisticsManager = null;
-    }
-
-    public void setSwitchManagerAware(ISwitchManagerAware service) {
-        log.trace("Got inventory service set request {}", service);
-        if (this.switchManagerAware != null) {
-            this.switchManagerAware.add(service);
-        }
-
-        // bulk update for newly joined
-        switchManagerAwareNotify(service);
-    }
-
-    public void unsetSwitchManagerAware(ISwitchManagerAware service) {
-        log.trace("Got a service UNset request");
-        if (this.switchManagerAware != null) {
-            this.switchManagerAware.remove(service);
-        }
-    }
-
-    public void setInventoryListener(IInventoryListener service) {
-        log.trace("Got inventory listener set request {}", service);
-        if (this.inventoryListeners != null) {
-            this.inventoryListeners.add(service);
-        }
-
-        // bulk update for newly joined
-        bulkUpdateService(service);
-    }
-
-    public void unsetInventoryListener(IInventoryListener service) {
-        log.trace("Got a service UNset request");
-        if (this.inventoryListeners != null) {
-            this.inventoryListeners.remove(service);
-        }
-    }
-
-    public void setSpanAware(ISpanAware service) {
-        log.trace("Got SpanAware set request {}", service);
-        if (this.spanAware != null) {
-            this.spanAware.add(service);
-        }
-
-        // bulk update for newly joined
-        spanAwareNotify(service);
-    }
-
-    public void unsetSpanAware(ISpanAware service) {
-        log.trace("Got a service UNset request");
-        if (this.spanAware != null) {
-            this.spanAware.remove(service);
-        }
-    }
-
-    void setClusterContainerService(IClusterContainerServices s) {
-        log.trace("Cluster Service set");
-        this.clusterContainerService = s;
-    }
-
-    void unsetClusterContainerService(IClusterContainerServices s) {
-        if (this.clusterContainerService == s) {
-            log.trace("Cluster Service removed!");
-            this.clusterContainerService = null;
-        }
-    }
-
-    public void setControllerProperties(IControllerProperties controllerProperties) {
-        log.trace("Got controller properties set request {}", controllerProperties);
-        this.controllerProperties = controllerProperties;
-    }
-
-    public void unsetControllerProperties(IControllerProperties controllerProperties) {
-        log.trace("Got controller properties UNset request");
-        this.controllerProperties = null;
-    }
-
-    private void getInventories() {
-        if (inventoryService == null) {
-            log.trace("inventory service not avaiable");
-            return;
-        }
-
-        Map<Node, Map<String, Property>> nodeProp = this.inventoryService.getNodeProps();
-        for (Map.Entry<Node, Map<String, Property>> entry : nodeProp.entrySet()) {
-            Node node = entry.getKey();
-            log.debug("getInventories: {} added for container {}", new Object[] { node, containerName });
-            Map<String, Property> propMap = entry.getValue();
-            Set<Property> props = new HashSet<Property>();
-            for (Property property : propMap.values()) {
-                props.add(property);
-            }
-            addNode(node, props);
-        }
-
-        Map<NodeConnector, Map<String, Property>> nodeConnectorProp = this.inventoryService.getNodeConnectorProps();
-        for (Map.Entry<NodeConnector, Map<String, Property>> entry : nodeConnectorProp.entrySet()) {
-            Map<String, Property> propMap = entry.getValue();
-            for (Property property : propMap.values()) {
-                addNodeConnectorProp(entry.getKey(), property);
-            }
-        }
-    }
-
-    private void clearInventories() {
-        nodeProps.clear();
-        nodeConnectorProps.clear();
-        nodeConnectorNames.clear();
-        spanNodeConnectors.clear();
-    }
-
-    private void notifyNode(Node node, UpdateType type,
-            Map<String, Property> propMap) {
-        synchronized (inventoryListeners) {
-            for (IInventoryListener service : inventoryListeners) {
-                service.notifyNode(node, type, propMap);
-            }
-        }
-    }
-
-    private void notifyNodeConnector(NodeConnector nodeConnector,
-            UpdateType type, Map<String, Property> propMap) {
-        synchronized (inventoryListeners) {
-            for (IInventoryListener service : inventoryListeners) {
-                service.notifyNodeConnector(nodeConnector, type, propMap);
-            }
-        }
-    }
-
-    /*
-     * For those joined late, bring them up-to-date.
-     */
-    private void switchManagerAwareNotify(ISwitchManagerAware service) {
-        for (Subnet sub : subnets.values()) {
-            service.subnetNotify(sub, true);
-        }
-
-        for (Node node : getNodes()) {
-            SwitchConfig sc = getSwitchConfig(node.toString());
-            if ((sc != null) && isDefaultContainer) {
-                ForwardingMode mode = (ForwardingMode) sc.getProperty(ForwardingMode.name);
-                service.modeChangeNotify(node, (mode == null) ? false : mode.isProactive());
-            }
-        }
-    }
-
-    private void bulkUpdateService(IInventoryListener service) {
-        Map<String, Property> propMap;
-        UpdateType type = UpdateType.ADDED;
-
-        for (Node node : getNodes()) {
-            propMap = nodeProps.get(node);
-            service.notifyNode(node, type, propMap);
-        }
-
-        for (Map.Entry<NodeConnector, Map<String, Property>> entry : nodeConnectorProps.entrySet()) {
-            NodeConnector nodeConnector = entry.getKey();
-            propMap = nodeConnectorProps.get(nodeConnector);
-            service.notifyNodeConnector(nodeConnector, type, propMap);
-        }
-    }
-
-    private void spanAwareNotify(ISpanAware service) {
-        for (Node node : getNodes()) {
-            for (SpanConfig conf : getSpanConfigList(node)) {
-                service.spanUpdate(node, conf.getPortArrayList(), true);
-            }
-        }
-    }
-
-    private void registerWithOSGIConsole() {
-        BundleContext bundleContext = FrameworkUtil.getBundle(this.getClass())
-                .getBundleContext();
-        bundleContext.registerService(CommandProvider.class.getName(), this,
-                null);
-    }
-
-    @Override
-    public Boolean isNodeConnectorEnabled(NodeConnector nodeConnector) {
-        if (nodeConnector == null) {
-            return false;
-        }
-
-        Config config = (Config) getNodeConnectorProp(nodeConnector,
-                Config.ConfigPropName);
-        State state = (State) getNodeConnectorProp(nodeConnector,
-                State.StatePropName);
-        return ((config != null) && (config.getValue() == Config.ADMIN_UP)
-                && (state != null) && (state.getValue() == State.EDGE_UP));
-    }
-
-    @Override
-    public boolean doesNodeConnectorExist(NodeConnector nc) {
-        return (nc != null && nodeConnectorProps != null
-                && nodeConnectorProps.containsKey(nc));
-    }
-
-    @Override
-    public String getHelp() {
-        StringBuffer help = new StringBuffer();
-        help.append("---Switch Manager---\n");
-        help.append("\t pencs <node id>        - Print enabled node connectors for a given node\n");
-        help.append("\t pdm <node id>          - Print switch ports in device map\n");
-        return help.toString();
-    }
-
-    public void _pencs(CommandInterpreter ci) {
-        String st = ci.nextArgument();
-        if (st == null) {
-            ci.println("Please enter node id");
-            return;
-        }
-
-        Node node = Node.fromString(st);
-        if (node == null) {
-            ci.println("Please enter node id");
-            return;
-        }
-
-        Set<NodeConnector> nodeConnectorSet = getUpNodeConnectors(node);
-        if (nodeConnectorSet == null) {
-            return;
-        }
-        for (NodeConnector nodeConnector : nodeConnectorSet) {
-            if (nodeConnector == null) {
-                continue;
-            }
-            ci.println(nodeConnector);
-        }
-        ci.println("Total number of NodeConnectors: " + nodeConnectorSet.size());
-    }
-
-    public void _pdm(CommandInterpreter ci) {
-        String st = ci.nextArgument();
-        if (st == null) {
-            ci.println("Please enter node id");
-            return;
-        }
-
-        Node node = Node.fromString(st);
-        if (node == null) {
-            ci.println("Please enter node id");
-            return;
-        }
-
-        Switch sw = getSwitchByNode(node);
-
-        ci.println("          NodeConnector                        Name");
-
-        Set<NodeConnector> nodeConnectorSet = sw.getNodeConnectors();
-        String nodeConnectorName;
-        if (nodeConnectorSet != null && nodeConnectorSet.size() > 0) {
-            for (NodeConnector nodeConnector : nodeConnectorSet) {
-                Map<String, Property> propMap = getNodeConnectorProps(nodeConnector);
-                nodeConnectorName = (propMap == null) ? null : ((Name) propMap
-                        .get(Name.NamePropName)).getValue();
-                if (nodeConnectorName != null) {
-                    Node nd = nodeConnector.getNode();
-                    if (!nd.equals(node)) {
-                        log.debug("node not match {} {}", nd, node);
-                    }
-                    Map<String, NodeConnector> map = nodeConnectorNames
-                            .get(node);
-                    if (map != null) {
-                        NodeConnector nc = map.get(nodeConnectorName);
-                        if (nc == null) {
-                            log.debug("no nodeConnector named {}",
-                                    nodeConnectorName);
-                        } else if (!nc.equals(nodeConnector)) {
-                            log.debug("nodeConnector not match {} {}", nc,
-                                    nodeConnector);
-                        }
-                    }
-                }
-
-                ci.println(nodeConnector
-                        + "            "
-                        + ((nodeConnectorName == null) ? "" : nodeConnectorName)
-                        + "(" + nodeConnector.getID() + ")");
-            }
-            ci.println("Total number of NodeConnectors: "
-                    + nodeConnectorSet.size());
-        }
-    }
-
-    @Override
-    public byte[] getNodeMAC(Node node) {
-        MacAddress mac = (MacAddress) this.getNodeProp(node,
-                MacAddress.name);
-        return (mac != null) ? mac.getMacAddress() : null;
-    }
-
-    @Override
-    public boolean isSpecial(NodeConnector p) {
-        if (p.getType().equals(NodeConnectorIDType.CONTROLLER)
-                || p.getType().equals(NodeConnectorIDType.ALL)
-                || p.getType().equals(NodeConnectorIDType.SWSTACK)
-                || p.getType().equals(NodeConnectorIDType.HWPATH)) {
-            return true;
-        }
-        return false;
-    }
-
-    /*
-     * Add span configuration to local cache and notify clients
-     */
-    private void addSpanPorts(Node node, List<NodeConnector> nodeConnectors) {
-        List<NodeConnector> ncLists = new ArrayList<NodeConnector>();
-
-        for (NodeConnector nodeConnector : nodeConnectors) {
-            if (!spanNodeConnectors.contains(nodeConnector)) {
-                ncLists.add(nodeConnector);
-            }
-        }
-
-        if (ncLists.size() > 0) {
-            spanNodeConnectors.addAll(ncLists);
-            notifySpanPortChange(node, ncLists, true);
-        }
-    }
-
-    private void addSpanPorts(Node node) {
-        for (SpanConfig conf : getSpanConfigList(node)) {
-            addSpanPorts(node, conf.getPortArrayList());
-        }
-    }
-
-    private void addSpanPort(NodeConnector nodeConnector) {
-        // only add if span is configured on this nodeConnector
-        for (SpanConfig conf : getSpanConfigList(nodeConnector.getNode())) {
-            if (conf.getPortArrayList().contains(nodeConnector)) {
-                List<NodeConnector> ncList = new ArrayList<NodeConnector>();
-                ncList.add(nodeConnector);
-                addSpanPorts(nodeConnector.getNode(), ncList);
-                return;
-            }
-        }
-    }
-
-    /*
-     * Remove span configuration to local cache and notify clients
-     */
-    private void removeSpanPorts(Node node, List<NodeConnector> nodeConnectors) {
-        List<NodeConnector> ncLists = new ArrayList<NodeConnector>();
-
-        for (NodeConnector nodeConnector : nodeConnectors) {
-            if (spanNodeConnectors.contains(nodeConnector)) {
-                ncLists.add(nodeConnector);
-            }
-        }
-
-        if (ncLists.size() > 0) {
-            spanNodeConnectors.removeAll(ncLists);
-            notifySpanPortChange(node, ncLists, false);
-        }
-    }
-
-    private void removeSpanPorts(Node node) {
-        for (SpanConfig conf : getSpanConfigList(node)) {
-            addSpanPorts(node, conf.getPortArrayList());
-        }
-    }
-
-    private void removeSpanPort(NodeConnector nodeConnector) {
-        if (spanNodeConnectors.contains(nodeConnector)) {
-            List<NodeConnector> ncLists = new ArrayList<NodeConnector>();
-            ncLists.add(nodeConnector);
-            removeSpanPorts(nodeConnector.getNode(), ncLists);
-        }
-    }
-
-    private void addNodeProps(Node node, Map<String, Property> propMap) {
-        if (propMap == null) {
-            propMap = new HashMap<String, Property>();
-        }
-        nodeProps.put(node, propMap);
-    }
-
-    @Override
-    public Status saveConfiguration() {
-        return saveSwitchConfig();
-    }
-
-    /**
-     * Creates a Name/Tier/Bandwidth/MacAddress(controller property) Property
-     * object based on given property name and value. Other property types are
-     * not supported yet.
-     *
-     * @param propName
-     *            Name of the Property
-     * @param propValue
-     *            Value of the Property
-     * @return {@link org.opendaylight.controller.sal.core.Property}
-     */
-    @Override
-    public Property createProperty(String propName, String propValue) {
-        if (propName == null) {
-            log.debug("propName is null");
-            return null;
-        }
-        if (propValue == null) {
-            log.debug("propValue is null");
-            return null;
-        }
-
-        try {
-            if (propName.equalsIgnoreCase(Description.propertyName)) {
-                return new Description(propValue);
-            } else if (propName.equalsIgnoreCase(Tier.TierPropName)) {
-                int tier = Integer.parseInt(propValue);
-                return new Tier(tier);
-            } else if (propName.equalsIgnoreCase(Bandwidth.BandwidthPropName)) {
-                long bw = Long.parseLong(propValue);
-                return new Bandwidth(bw);
-            } else if (propName.equalsIgnoreCase(ForwardingMode.name)) {
-                int mode = Integer.parseInt(propValue);
-                return new ForwardingMode(mode);
-            } else if (propName.equalsIgnoreCase(MacAddress.name)){
-                return new MacAddress(propValue);
-            }
-            else {
-                log.debug("Not able to create {} property", propName);
-            }
-        } catch (Exception e) {
-            log.debug("createProperty caught exception {}", e.getMessage());
-        }
-
-        return null;
-    }
-
-
-    @SuppressWarnings("deprecation")
-    @Override
-    public String getNodeDescription(Node node) {
-        // Check first if user configured a name
-        SwitchConfig config = getSwitchConfig(node.toString());
-        if (config != null) {
-            String configuredDesc = config.getNodeDescription();
-            if (configuredDesc != null && !configuredDesc.isEmpty()) {
-                return configuredDesc;
-            }
-        }
-
-        // No name configured by user, get the node advertised name
-        Description desc = (Description) getNodeProp(node,
-                Description.propertyName);
-        return (desc == null /* || desc.getValue().equalsIgnoreCase("none") */) ? ""
-                : desc.getValue();
-    }
-
-    @Override
-    public Set<Switch> getConfiguredNotConnectedSwitches() {
-        Set<Switch> configuredNotConnectedSwitches = new HashSet<Switch>();
-        if (this.inventoryService == null) {
-            log.trace("inventory service not available");
-            return configuredNotConnectedSwitches;
-        }
-
-        Set<Node> configuredNotConnectedNodes = this.inventoryService.getConfiguredNotConnectedNodes();
-        if (configuredNotConnectedNodes != null) {
-            for (Node node : configuredNotConnectedNodes) {
-                Switch sw = getSwitchByNode(node);
-                configuredNotConnectedSwitches.add(sw);
-            }
-        }
-        return configuredNotConnectedSwitches;
-    }
-
-}
diff --git a/opendaylight/adsal/switchmanager/implementation/src/main/java/org/opendaylight/controller/switchmanager/internal/SwitchManagerCLI.java b/opendaylight/adsal/switchmanager/implementation/src/main/java/org/opendaylight/controller/switchmanager/internal/SwitchManagerCLI.java
deleted file mode 100644 (file)
index 268e45a..0000000
+++ /dev/null
@@ -1,147 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.switchmanager.internal;
-
-import java.util.ArrayList;
-import java.util.Collections;
-import java.util.Dictionary;
-import java.util.HashSet;
-import java.util.Hashtable;
-import java.util.List;
-import java.util.Map;
-import java.util.Set;
-
-import org.apache.felix.service.command.Descriptor;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.utils.GlobalConstants;
-import org.opendaylight.controller.sal.utils.ServiceHelper;
-import org.opendaylight.controller.switchmanager.ISwitchManager;
-import org.osgi.framework.ServiceRegistration;
-
-/**
- * This class provides osgi cli commands for developers to debug Switch Manager
- * functionality
- */
-public class SwitchManagerCLI {
-    @SuppressWarnings("rawtypes")
-    private ServiceRegistration sr = null;
-
-    public void init() {
-    }
-
-    public void destroy() {
-    }
-
-    public void start() {
-        final Dictionary<String, Object> props = new Hashtable<String, Object>();
-        props.put("osgi.command.scope", "odpcontroller");
-        props.put("osgi.command.function", new String[] { "showNodes", "showNodeConnectors" });
-        this.sr = ServiceHelper.registerGlobalServiceWReg(SwitchManagerCLI.class, this, props);
-    }
-
-    public void stop() {
-        if (this.sr != null) {
-            this.sr.unregister();
-            this.sr = null;
-        }
-    }
-
-    @Descriptor("Retrieves the nodes information present in Switch Manager DB")
-    public void showNodes(
-            @Descriptor("Container in which to query Switch Manager") String container) {
-        final ISwitchManager sm = (ISwitchManager) ServiceHelper.getInstance(ISwitchManager.class, container, this);
-
-        if (sm == null) {
-            System.out.println("Cannot find the switch manager instance on container: " + container);
-            return;
-        }
-
-        Set<Node> nodes = sm.getNodes();
-        if (nodes == null || nodes.isEmpty()) {
-            return;
-        }
-
-        Set<String> propertyList = new HashSet<String>();
-        for (Node node : nodes) {
-            Map<String, Property> propList = sm.getNodeProps(node);
-            propertyList.addAll(propList.keySet());
-        }
-        List<String> sortedProps = new ArrayList<String>(propertyList);
-        Collections.sort(sortedProps);
-        String properties = String.format("%-26s  ", "Node");
-        for (String s : sortedProps) {
-            properties = properties.concat(String.format("%-18s ", s));
-        }
-        System.out.println(properties);
-        for (Node node : nodes) {
-            String nodeProp = String.format("%-26s  ", node);
-            Map<String, Property> propList = sm.getNodeProps(node);
-            for (String s : sortedProps) {
-                if (propList.containsKey(s)) {
-                    nodeProp = nodeProp.concat(String.format("%-18s ", propList.get(s).getStringValue()));
-                } else {
-                    nodeProp = nodeProp.concat(String.format("%-18s ", "null"));
-                }
-            }
-            System.out.println(nodeProp);
-        }
-        System.out.println("Total number of Nodes: " + nodes.size());
-    }
-
-    @Descriptor("Retrieves the node connectors information present in Switch Manager DB for the specified node")
-    public void showNodeConnectors(@Descriptor("Container in which to query Switch Manager") String container,
-            @Descriptor("String representation of the Node, this need to be consumable from Node.fromString()") String node) {
-        final String containerName = (container == null) ? GlobalConstants.DEFAULT.toString() : container;
-        final ISwitchManager sm = (ISwitchManager) ServiceHelper.getInstance(ISwitchManager.class, containerName, this);
-
-        if (sm == null) {
-            System.out.println("Cannot find the switch manager instance on container: " + containerName);
-            return;
-        }
-
-        Node target = Node.fromString(node);
-        if (target == null) {
-            System.out.println("Please enter a valid node id");
-            return;
-        }
-
-        Set<NodeConnector> nodeConnectorSet = sm.getNodeConnectors(target);
-        if (nodeConnectorSet == null || nodeConnectorSet.isEmpty()) {
-            return;
-        }
-
-        Set<String> propertyList = new HashSet<String>();
-        for (NodeConnector nodeConnector : nodeConnectorSet) {
-            Map<String, Property> propList = sm.getNodeConnectorProps(nodeConnector);
-            propertyList.addAll(propList.keySet());
-        }
-        List<String> sortedProps = new ArrayList<String>(propertyList);
-        Collections.sort(sortedProps);
-        String properties = String.format("%-33s  ", "NodeConnector");
-        for (String s : sortedProps) {
-            properties = properties.concat(String.format("%-18s ", s));
-        }
-        System.out.println(properties);
-        for (NodeConnector nodeConnector : nodeConnectorSet) {
-            String ncProp = String.format("%-33s  ", nodeConnector);
-            Map<String, Property> ncProperties = sm.getNodeConnectorProps(nodeConnector);
-            for (String s : sortedProps) {
-                if (ncProperties.containsKey(s)) {
-                    ncProp = ncProp.concat(String.format("%-18s ", ncProperties.get(s).getStringValue()));
-                } else {
-                    ncProp = ncProp.concat(String.format("%-18s ", "null"));
-                }
-            }
-            System.out.println(ncProp);
-        }
-        System.out.println("Total number of NodeConnectors: " + nodeConnectorSet.size());
-    }
-}
diff --git a/opendaylight/adsal/switchmanager/implementation/src/test/java/org/opendaylight/controller/switchmanager/internal/SwitchManagerTest.java b/opendaylight/adsal/switchmanager/implementation/src/test/java/org/opendaylight/controller/switchmanager/internal/SwitchManagerTest.java
deleted file mode 100644 (file)
index e7dac9c..0000000
+++ /dev/null
@@ -1,171 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.switchmanager.internal;
-
-import java.util.ArrayList;
-import java.util.HashSet;
-import java.util.List;
-import java.util.Set;
-
-import org.junit.Assert;
-import org.junit.Test;
-import org.opendaylight.controller.sal.core.Bandwidth;
-import org.opendaylight.controller.sal.core.ConstructionException;
-import org.opendaylight.controller.sal.core.Latency;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.core.State;
-import org.opendaylight.controller.sal.core.UpdateType;
-import org.opendaylight.controller.sal.utils.NodeConnectorCreator;
-import org.opendaylight.controller.sal.utils.NodeCreator;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.switchmanager.SubnetConfig;
-
-public class SwitchManagerTest {
-
-    @Test
-    public void testSwitchManagerAddRemoveSubnet() throws ConstructionException {
-        SwitchManager switchmgr = new SwitchManager();
-        switchmgr.startUp();
-
-        // Create the node connector string list
-        Node node1 = new Node(Node.NodeIDType.OPENFLOW, 1L);
-        Node node2 = new Node(Node.NodeIDType.OPENFLOW, 2L);
-        NodeConnector nc1 = new NodeConnector(NodeConnector.NodeConnectorIDType.OPENFLOW, (short)1, node1);
-        NodeConnector nc2 = new NodeConnector(NodeConnector.NodeConnectorIDType.OPENFLOW, (short)2, node2);
-        NodeConnector nc3 = new NodeConnector(NodeConnector.NodeConnectorIDType.OPENFLOW, (short)3, node1);
-        List<String> portList = new ArrayList<String>();
-        portList.add(nc1.toString());
-        portList.add(nc2.toString());
-        portList.add(nc3.toString());
-
-
-        SubnetConfig subnet = new SubnetConfig("subnet", "10.0.0.254/16", portList);
-        Status addResult = (switchmgr.addSubnet(subnet));
-        Assert.assertTrue(addResult.isSuccess());
-
-        Status removeResult = (switchmgr.removeSubnet(subnet.getName()));
-        Assert.assertTrue(removeResult.isSuccess());
-
-        SubnetConfig subnetConfigResult = switchmgr.getSubnetConfig(subnet.getName());
-        Assert.assertNull(subnetConfigResult);
-
-        subnet = new SubnetConfig("hr", "0.0.0.0", portList);
-        Status status = switchmgr.addSubnet(subnet);
-        Assert.assertFalse(status.isSuccess());
-
-        subnet = new SubnetConfig("hr", "12.12.12.254/16", null);
-        status = switchmgr.addSubnet(subnet);
-        Assert.assertTrue(status.isSuccess());
-
-    }
-
-    @Test
-    public void testSwitchManagerAddRemovePortsToSubnet() {
-        SwitchManager switchmgr = new SwitchManager();
-        switchmgr.startUp();
-
-        List<String> portList = new ArrayList<String>();
-        portList.add("OF|1@OF|1");
-        portList.add("OF|2@OF|00:00:00:00:00:00:00:02");
-        portList.add("OF|3@OF|00:00:00:00:00:00:00:01");
-
-        SubnetConfig subnet = new SubnetConfig("eng", "11.1.1.254/16", portList);
-        Status status = (switchmgr.addSubnet(subnet));
-        Assert.assertTrue(status.isSuccess());
-
-
-        // Empty port set
-        List<String> badPortSet = new ArrayList<String>();
-        status = switchmgr.addPortsToSubnet("eng", badPortSet);
-        Assert.assertFalse(status.isSuccess());
-
-        // Non existant subnet
-        status = switchmgr.removePortsFromSubnet("hr", badPortSet);
-        Assert.assertFalse(status.isSuccess());
-
-        // Port set containing non conventional but parsable port
-        badPortSet.add("1/1");
-        status = switchmgr.addPortsToSubnet("eng", badPortSet);
-        Assert.assertTrue(status.isSuccess());
-
-        // Port set containing non parsable port
-        badPortSet.add("OF1/1");
-        status = switchmgr.addPortsToSubnet("eng", badPortSet);
-        Assert.assertTrue(status.isSuccess());
-    }
-
-    @Test
-    public void testSwitchManagerNodeConnectors() {
-        SwitchManager switchmgr = new SwitchManager();
-        switchmgr.startUp();
-
-        State state;
-        Bandwidth bw;
-        Latency l;
-
-        NodeConnector[] headnc = new NodeConnector[5];
-        NodeConnector[] tailnc = new NodeConnector[5];
-
-        Set<Property> props = new HashSet<Property>();
-        state = new State(State.EDGE_UP);
-        bw = new Bandwidth(Bandwidth.BW100Gbps);
-        l = new Latency(Latency.LATENCY100ns);
-        props.add(state);
-        props.add(bw);
-        props.add(l);
-
-        for (short i = 1; i < 6; i = (short) (i + 1)) {
-
-            headnc[i - 1] = NodeConnectorCreator.createOFNodeConnector(i,
-                    NodeCreator.createOFNode((long) i));
-            tailnc[i - 1] = NodeConnectorCreator
-                    .createOFNodeConnector((short) (i + 10),
-                            NodeCreator.createOFNode((long) (i + 10)));
-            switchmgr.updateNode(headnc[i - 1].getNode(), UpdateType.ADDED,
-                    props);
-            switchmgr.updateNode(tailnc[i - 1].getNode(), UpdateType.ADDED,
-                    props);
-
-            Assert.assertFalse(switchmgr.doesNodeConnectorExist(headnc[i - 1]));
-            switchmgr.updateNodeConnector(headnc[i - 1], UpdateType.ADDED,
-                    props);
-            Assert.assertTrue(switchmgr.doesNodeConnectorExist(headnc[i - 1]));
-
-            Assert.assertFalse(switchmgr.doesNodeConnectorExist(tailnc[i - 1]));
-            switchmgr.updateNodeConnector(tailnc[i - 1], UpdateType.ADDED,
-                    props);
-            Assert.assertTrue(switchmgr.doesNodeConnectorExist(tailnc[i - 1]));
-        }
-
-        for (int i = 0; i < 5; i++) {
-            Property bwProp = switchmgr.getNodeConnectorProp(headnc[i],
-                    Bandwidth.BandwidthPropName);
-            Assert.assertTrue(bwProp.equals(bw));
-            Property latencyProp = switchmgr.getNodeConnectorProp(tailnc[i],
-                    Latency.LatencyPropName);
-            Assert.assertEquals(latencyProp, l);
-        }
-
-        Set<Node> nodes = switchmgr.getNodes();
-        for (int i = 0; i < 5; i++) {
-            if (nodes.contains(headnc[i].getNode()) == true) {
-                nodes.remove(headnc[i].getNode());
-            }
-
-            if (nodes.contains(tailnc[i].getNode()) == true) {
-                nodes.remove(tailnc[i].getNode());
-            }
-
-        }
-        Assert.assertTrue(nodes.isEmpty());
-    }
-
-}
diff --git a/opendaylight/adsal/switchmanager/integrationtest/pom.xml b/opendaylight/adsal/switchmanager/integrationtest/pom.xml
deleted file mode 100644 (file)
index bfaf52c..0000000
+++ /dev/null
@@ -1,150 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.integrationtest</artifactId>
-    <version>0.7.0-SNAPSHOT</version>
-    <relativePath>../../commons/integrationtest</relativePath>
-  </parent>
-
-  <artifactId>switchmanager.integrationtest</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <properties>
-    <sonar.jacoco.itReportPath>../../implementation/target/jacoco-it.exec</sonar.jacoco.itReportPath>
-    <!-- Sonar jacoco plugin to get integration test coverage info -->
-    <sonar.jacoco.reportPath>../../implementation/target/jacoco.exec</sonar.jacoco.reportPath>
-  </properties>
-
-  <dependencies>
-    <dependency>
-      <groupId>ch.qos.logback</groupId>
-      <artifactId>logback-classic</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>ch.qos.logback</groupId>
-      <artifactId>logback-core</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>clustering.services</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>clustering.stub</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>configuration</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>configuration.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>containermanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>containermanager.it.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>hosttracker</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>hosttracker.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>protocol_plugins.stub</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>switchmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>switchmanager.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>topologymanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.slf4j</groupId>
-      <artifactId>log4j-over-slf4j</artifactId>
-    </dependency>
-    <!-- Add Pax Exam -->
-    <dependency>
-      <groupId>org.ops4j.pax.exam</groupId>
-      <artifactId>pax-exam-container-native</artifactId>
-      <scope>test</scope>
-    </dependency>
-    <dependency>
-      <groupId>org.ops4j.pax.exam</groupId>
-      <artifactId>pax-exam-junit4</artifactId>
-      <scope>test</scope>
-    </dependency>
-    <dependency>
-      <groupId>org.ops4j.pax.exam</groupId>
-      <artifactId>pax-exam-link-mvn</artifactId>
-      <scope>test</scope>
-    </dependency>
-    <dependency>
-      <groupId>org.ops4j.pax.url</groupId>
-      <artifactId>pax-url-aether</artifactId>
-      <scope>test</scope>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.jacoco</groupId>
-        <artifactId>jacoco-maven-plugin</artifactId>
-        <configuration>
-          <destFile>../../implementation/target/jacoco-it.exec</destFile>
-          <includes>
-            <include>org.opendaylight.controller.*</include>
-          </includes>
-        </configuration>
-        <executions>
-          <execution>
-            <id>pre-test</id>
-            <goals>
-              <goal>prepare-agent</goal>
-            </goals>
-          </execution>
-          <execution>
-            <id>post-test</id>
-            <configuration>
-              <skip>true</skip>
-            </configuration>
-          </execution>
-        </executions>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-
-</project>
diff --git a/opendaylight/adsal/switchmanager/integrationtest/src/test/java/org/opendaylight/controller/switchmanager/internal/SwitchManagerIT.java b/opendaylight/adsal/switchmanager/integrationtest/src/test/java/org/opendaylight/controller/switchmanager/internal/SwitchManagerIT.java
deleted file mode 100644 (file)
index 3963abf..0000000
+++ /dev/null
@@ -1,222 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.switchmanager.internal;
-
-import static org.junit.Assert.assertFalse;
-import static org.junit.Assert.assertNotNull;
-import static org.ops4j.pax.exam.CoreOptions.junitBundles;
-import static org.ops4j.pax.exam.CoreOptions.mavenBundle;
-import static org.ops4j.pax.exam.CoreOptions.options;
-import static org.ops4j.pax.exam.CoreOptions.systemPackages;
-import static org.ops4j.pax.exam.CoreOptions.systemProperty;
-
-import java.net.UnknownHostException;
-import java.util.Map;
-
-import javax.inject.Inject;
-
-import org.junit.Assert;
-import org.junit.Before;
-import org.junit.Test;
-import org.junit.runner.RunWith;
-import org.opendaylight.controller.sal.core.Actions;
-import org.opendaylight.controller.sal.core.Bandwidth;
-import org.opendaylight.controller.sal.core.Buffers;
-import org.opendaylight.controller.sal.core.Capabilities;
-import org.opendaylight.controller.sal.core.Capabilities.CapabilitiesType;
-import org.opendaylight.controller.sal.core.ConstructionException;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.core.State;
-import org.opendaylight.controller.sal.core.TimeStamp;
-import org.opendaylight.controller.switchmanager.ISwitchManager;
-import org.ops4j.pax.exam.Option;
-import org.ops4j.pax.exam.Configuration;
-import org.ops4j.pax.exam.junit.PaxExam;
-import org.ops4j.pax.exam.util.PathUtils;
-import org.osgi.framework.Bundle;
-import org.osgi.framework.BundleContext;
-import org.osgi.framework.ServiceReference;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-@RunWith(PaxExam.class)
-public class SwitchManagerIT {
-    private final Logger log = LoggerFactory.getLogger(SwitchManagerIT.class);
-    // get the OSGI bundle context
-    @Inject
-    private BundleContext bc;
-
-    private ISwitchManager switchManager = null;
-
-    // Configure the OSGi container
-    @Configuration
-    public Option[] config() {
-        return options(
-                systemProperty("logback.configurationFile").value(
-                        "file:" + PathUtils.getBaseDir()
-                                + "/src/test/resources/logback.xml"),
-                // To start OSGi console for inspection remotely
-                systemProperty("osgi.console").value("2401"),
-                // Set the systemPackages (used by clustering)
-                systemPackages("sun.reflect", "sun.reflect.misc", "sun.misc"),
-                // List framework bundles
-                mavenBundle("equinoxSDK381", "org.eclipse.equinox.console").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "org.eclipse.equinox.util").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "org.eclipse.osgi.services").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "org.eclipse.equinox.ds").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "org.apache.felix.gogo.command").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "org.apache.felix.gogo.runtime").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "org.apache.felix.gogo.shell").versionAsInProject(),
-                // List logger bundles
-                mavenBundle("org.slf4j", "slf4j-api").versionAsInProject(),
-                mavenBundle("org.slf4j", "log4j-over-slf4j")
-                        .versionAsInProject(),
-                mavenBundle("ch.qos.logback", "logback-core")
-                        .versionAsInProject(),
-                mavenBundle("ch.qos.logback", "logback-classic")
-                        .versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "clustering.stub")
-                        .versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "configuration")
-                        .versionAsInProject(),
-                mavenBundle("org.opendaylight.controller",
-                        "configuration.implementation").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "containermanager")
-                        .versionAsInProject(),
-                mavenBundle("org.opendaylight.controller",
-                        "containermanager.it.implementation").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller",
-                        "clustering.services").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "sal")
-                        .versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "sal.implementation")
-                        .versionAsInProject(),
-                mavenBundle("org.opendaylight.controller",
-                                "protocol_plugins.stub").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "switchmanager")
-                        .versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "topologymanager").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "hosttracker").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "forwardingrulesmanager").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "statisticsmanager").versionAsInProject(),
-                mavenBundle("org.opendaylight.controller",
-                        "switchmanager.implementation").versionAsInProject(),
-                mavenBundle("org.jboss.spec.javax.transaction",
-                        "jboss-transaction-api_1.1_spec").versionAsInProject(),
-                mavenBundle("org.apache.commons", "commons-lang3")
-                        .versionAsInProject(),
-                mavenBundle("org.apache.felix",
-                        "org.apache.felix.dependencymanager")
-                        .versionAsInProject(), junitBundles());
-    }
-
-    private String stateToString(int state) {
-        switch (state) {
-        case Bundle.ACTIVE:
-            return "ACTIVE";
-        case Bundle.INSTALLED:
-            return "INSTALLED";
-        case Bundle.RESOLVED:
-            return "RESOLVED";
-        case Bundle.UNINSTALLED:
-            return "UNINSTALLED";
-        default:
-            return "Not CONVERTED";
-        }
-    }
-
-    @Before
-    public void areWeReady() {
-        assertNotNull(bc);
-        boolean debugit = false;
-        Bundle b[] = bc.getBundles();
-        for (int i = 0; i < b.length; i++) {
-            int state = b[i].getState();
-            if (state != Bundle.ACTIVE && state != Bundle.RESOLVED) {
-                log.debug("Bundle:" + b[i].getSymbolicName() + " state:"
-                        + stateToString(state));
-                debugit = true;
-            }
-        }
-        if (debugit) {
-            log.debug("Do some debugging because some bundle is "
-                    + "unresolved");
-        }
-
-        // Assert if true, if false we are good to go!
-        assertFalse(debugit);
-
-        // Now lets create a hosttracker for testing purpose
-        ServiceReference<?> s = bc.getServiceReference(ISwitchManager.class
-                .getName());
-        if (s != null) {
-            this.switchManager = (ISwitchManager) bc.getService(s);
-        }
-
-        // If StatisticsManager is null, cannot run tests.
-        assertNotNull(this.switchManager);
-    }
-
-    @Test
-    public void testNodeProp() throws UnknownHostException {
-        assertNotNull(this.switchManager);
-
-        Node node;
-        try {
-            node = new Node("STUB", new Integer(0xCAFE));
-        } catch (ConstructionException e) {
-            // test failed if node cannot be created.
-            node = null;
-            Assert.assertTrue(false);
-        }
-        Map<String, Property> propMap = this.switchManager.getNodeProps(node);
-        Assert.assertFalse(propMap.isEmpty());
-
-        Assert.assertTrue(this.switchManager.getNodeProp(node,
-                Capabilities.CapabilitiesPropName).equals(
-                new Capabilities(3)));
-        Assert.assertTrue(this.switchManager.getNodeProp(node,
-                Actions.ActionsPropName).equals(new Actions(2)));
-        Assert.assertTrue(this.switchManager.getNodeProp(node,
-                Buffers.BuffersPropName).equals(new Buffers(1)));
-        Assert.assertTrue(this.switchManager.getNodeProp(node,
-                TimeStamp.TimeStampPropName).equals(
-                new TimeStamp(100000L, "connectedSince")));
-    }
-
-    @Test
-    public void testNodeConnectorProp() throws UnknownHostException {
-        assertNotNull(this.switchManager);
-        Node node;
-        NodeConnector nc;
-        try {
-            node = new Node("STUB", 0xCAFE);
-            nc = new NodeConnector("STUB", 0xCAFE, node);
-        } catch (ConstructionException e) {
-            node = null;
-            nc = null;
-            Assert.assertTrue(false);
-        }
-        Map<String, Property> propMap = this.switchManager
-                .getNodeConnectorProps(nc);
-        Assert.assertFalse(propMap.isEmpty());
-
-        Assert.assertTrue(this.switchManager.getNodeConnectorProp(nc,
-                Capabilities.CapabilitiesPropName).equals(
-                new Capabilities(CapabilitiesType.FLOW_STATS_CAPABILITY
-                        .getValue())));
-        Assert.assertTrue(this.switchManager.getNodeConnectorProp(nc,
-                Bandwidth.BandwidthPropName).equals(
-                new Bandwidth(Bandwidth.BW1Gbps)));
-        Assert.assertTrue(this.switchManager.getNodeConnectorProp(nc,
-                State.StatePropName).equals(new State(State.EDGE_UP)));
-    }
-}
diff --git a/opendaylight/adsal/switchmanager/integrationtest/src/test/resources/logback.xml b/opendaylight/adsal/switchmanager/integrationtest/src/test/resources/logback.xml
deleted file mode 100644 (file)
index 2d63ce5..0000000
+++ /dev/null
@@ -1,13 +0,0 @@
-<configuration scan="true">
-
-  <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
-    <encoder>
-      <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n
-      </pattern>
-    </encoder>
-  </appender>
-
-  <root level="error">
-    <appender-ref ref="STDOUT" />
-  </root>
-</configuration>
diff --git a/opendaylight/adsal/topologymanager/implementation/pom.xml b/opendaylight/adsal/topologymanager/implementation/pom.xml
deleted file mode 100644 (file)
index 9a056df..0000000
+++ /dev/null
@@ -1,79 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>topologymanager</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>org.eclipse.osgi</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>clustering.services</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>configuration</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>switchmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-      <scope>test</scope>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Export-Package>org.opendaylight.controller.topologymanager</Export-Package>
-            <Import-Package>javax.xml.bind.annotation,
-              org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.sal.utils,
-              org.opendaylight.controller.sal.packet,
-              org.opendaylight.controller.sal.topology,
-              org.opendaylight.controller.configuration,
-              org.opendaylight.controller.clustering.services,
-              org.opendaylight.controller.switchmanager,
-              org.osgi.service.component,
-              org.slf4j,
-              org.apache.felix.dm,
-              org.apache.commons.lang3.builder,
-              org.apache.commons.lang3.tuple,
-              org.eclipse.osgi.framework.console,
-              org.osgi.framework</Import-Package>
-            <Bundle-Activator>org.opendaylight.controller.topologymanager.internal.Activator</Bundle-Activator>
-          </instructions>
-          <manifestLocation>${project.basedir}/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/topologymanager/implementation/src/main/java/org/opendaylight/controller/topologymanager/ITopologyManager.java b/opendaylight/adsal/topologymanager/implementation/src/main/java/org/opendaylight/controller/topologymanager/ITopologyManager.java
deleted file mode 100644 (file)
index 1f37759..0000000
+++ /dev/null
@@ -1,125 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.topologymanager;
-
-import java.util.List;
-import java.util.Map;
-import java.util.Set;
-import java.util.concurrent.ConcurrentMap;
-
-import org.opendaylight.controller.sal.core.Edge;
-import org.opendaylight.controller.sal.core.Host;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.core.UpdateType;
-import org.opendaylight.controller.sal.utils.Status;
-
-/**
- * The Interface provides methods to interact with network topology database.
- */
-public interface ITopologyManager {
-    /**
-     * Query to determine if the specified NodeConnector is connected
-     * to another Node or is a leaf for the network
-     * @param p The node connector
-     * @return true if the NodeConnector is connected to another
-     * switch false otherwise
-     */
-    public boolean isInternal(NodeConnector p);
-
-    /**
-     * Retrieves a map of all known link connections between nodes
-     * including their properties
-     * @return the map as specified
-     */
-    public Map<Edge, Set<Property>> getEdges();
-
-    /**
-     * Returns an unmodifiable map indexed by the Node and reporting
-     * all the edges getting out/in from/to the Node
-     * @return the map as specified
-     */
-    public Map<Node, Set<Edge>> getNodeEdges();
-
-    /**
-     * Add or Update an Host port in the topology manager DB
-     *
-     * @param p NodeConnector to which an host is connected
-     * @param h the Host connected to the NodeConnector
-     * @param t type of update if Add/Delete/Update
-     */
-    public void updateHostLink(NodeConnector p, Host h, UpdateType t,
-            Set<Property> props);
-
-    /**
-     * Return a set of NodeConnector that have hosts attached to them
-     *
-     * @return A set with all the NodeConnectors known to have an host
-     * attached
-     */
-    public Set<NodeConnector> getNodeConnectorWithHost();
-
-    /**
-     * Return the Host attached to a NodeConnector with Host.
-     * Multiple hosts maybe attached to a node connector.
-     * This method returns the first one only. Hence it has been
-     * deprecated. Use the new method getHostsAttachedToNodeConnector
-     * that returns the complete list of hosts.
-     * @return The Host attached to a NodeConnector
-     */
-    @Deprecated
-    public Host getHostAttachedToNodeConnector(NodeConnector p);
-
-    /**
-     * Returns a list of hosts attached to a NodeConnector
-     * @param p NodeConnector
-     * @return The list of hosts attached to a NodeConnector
-     */
-    public List<Host> getHostsAttachedToNodeConnector(NodeConnector p);
-
-    /**
-     * Returns a copy map which associates every node with all the
-     * NodeConnectors of the node that have an Host attached to it
-     *
-     * @return A map of all the Nodes with NodeConnectors
-     */
-    public Map<Node, Set<NodeConnector>> getNodesWithNodeConnectorHost();
-
-    /**
-     * Adds user configured link
-     *
-     * @param link User configured link
-     * @return "Success" or error reason
-     */
-    public Status addUserLink(TopologyUserLinkConfig link);
-
-    /**
-     * Deletes user configured link
-     *
-     * @param linkName The name of the user configured link
-     * @return "Success" or error reason
-     */
-    public Status deleteUserLink(String linkName);
-
-    /**
-     * Saves user configured links into config file
-     *
-     * @return "Success" or error reason
-     */
-    public Status saveConfig();
-
-    /**
-     * Gets all the user configured links
-     *
-     * @return The map of the user configured links
-     */
-    public ConcurrentMap<String, TopologyUserLinkConfig> getUserLinks();
-}
diff --git a/opendaylight/adsal/topologymanager/implementation/src/main/java/org/opendaylight/controller/topologymanager/ITopologyManagerAware.java b/opendaylight/adsal/topologymanager/implementation/src/main/java/org/opendaylight/controller/topologymanager/ITopologyManagerAware.java
deleted file mode 100644 (file)
index a79da60..0000000
+++ /dev/null
@@ -1,20 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.topologymanager;
-
-import org.opendaylight.controller.sal.topology.IListenTopoUpdates;
-
-/**
- * Interface for all the listener of topology updates created by
- * Topology Manager, effectively speaking the updates are an extension
- * of the IListenTopoUpdates coming from SAL.
- */
-public interface ITopologyManagerAware extends IListenTopoUpdates {
-}
diff --git a/opendaylight/adsal/topologymanager/implementation/src/main/java/org/opendaylight/controller/topologymanager/ITopologyManagerClusterWideAware.java b/opendaylight/adsal/topologymanager/implementation/src/main/java/org/opendaylight/controller/topologymanager/ITopologyManagerClusterWideAware.java
deleted file mode 100644 (file)
index aa47b5f..0000000
+++ /dev/null
@@ -1,11 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others. All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.topologymanager;
-
-public interface ITopologyManagerClusterWideAware extends ITopologyManagerAware {
-}
diff --git a/opendaylight/adsal/topologymanager/implementation/src/main/java/org/opendaylight/controller/topologymanager/ITopologyManagerShell.java b/opendaylight/adsal/topologymanager/implementation/src/main/java/org/opendaylight/controller/topologymanager/ITopologyManagerShell.java
deleted file mode 100644 (file)
index 22bd9c0..0000000
+++ /dev/null
@@ -1,17 +0,0 @@
-/**
-* Copyright (c) 2014 Inocybe Technologies, and others. All rights reserved.
-*
-* This program and the accompanying materials are made available under the
-* terms of the Eclipse Public License v1.0 which accompanies this distribution,
-* and is available at http://www.eclipse.org/legal/epl-v10.html
-*/
-package org.opendaylight.controller.topologymanager;
-
-import java.util.List;
-
-public interface ITopologyManagerShell {
-    public List<String> printUserLink();
-    public List<String> addUserLink(String name, String ncStr1, String ncStr2);
-    public List<String> deleteUserLinkShell(String name);
-    public List<String> printNodeEdges();
-}
diff --git a/opendaylight/adsal/topologymanager/implementation/src/main/java/org/opendaylight/controller/topologymanager/TopologyUserLinkConfig.java b/opendaylight/adsal/topologymanager/implementation/src/main/java/org/opendaylight/controller/topologymanager/TopologyUserLinkConfig.java
deleted file mode 100644 (file)
index 3532ab7..0000000
+++ /dev/null
@@ -1,187 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.topologymanager;
-
-import java.io.Serializable;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.configuration.ConfigurationObject;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * The Interface provides methods to manipulate user configured link.
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-public class TopologyUserLinkConfig extends ConfigurationObject implements Serializable {
-    private static final long serialVersionUID = 1L;
-    private static final Logger logger = LoggerFactory.getLogger(TopologyUserLinkConfig.class);
-
-    public enum STATUS {
-        SUCCESS("Success"), LINKDOWN("Link Down"), INCORRECT(
-                "Incorrect Connection");
-        private STATUS(String name) {
-            this.name = name;
-        }
-
-        private String name;
-
-        @Override
-        public String toString() {
-            return name;
-        }
-
-        public static STATUS fromString(String str) {
-            if (str == null) {
-                return LINKDOWN;
-            }
-            if (str.equals(SUCCESS.toString())) {
-                return SUCCESS;
-            }
-            if (str.equals(LINKDOWN.toString())) {
-                return LINKDOWN;
-            }
-            if (str.equals(INCORRECT.toString())) {
-                return INCORRECT;
-            }
-            return LINKDOWN;
-        }
-    }
-
-    @XmlElement
-    private String status;
-    @XmlElement
-    private String name;
-    @XmlElement
-    private String srcNodeConnector;
-    @XmlElement
-    private String dstNodeConnector;
-
-    public TopologyUserLinkConfig() {
-        super();
-        status = STATUS.LINKDOWN.toString();
-    }
-
-    public TopologyUserLinkConfig(String name, String srcNodeConnector, String dstNodeConnector) {
-        super();
-        this.name = name;
-        this.srcNodeConnector = srcNodeConnector;
-        this.dstNodeConnector = dstNodeConnector;
-    }
-
-
-    public String getName() {
-        return name;
-    }
-
-    public void setName(String name) {
-        this.name = name;
-    }
-
-
-    public STATUS getStatus() {
-        return STATUS.fromString(status);
-    }
-
-    public void setStatus(STATUS s) {
-        this.status = s.toString();
-    }
-
-    public String getSrcNodeConnector() {
-        return srcNodeConnector;
-    }
-
-    public void setSrcNodeConnector(String srcNodeConnector) {
-        this.srcNodeConnector = srcNodeConnector;
-    }
-
-    public String getDstNodeConnector() {
-        return dstNodeConnector;
-    }
-
-    public void setDstNodeConnector(String dstNodeConnector) {
-        this.dstNodeConnector = dstNodeConnector;
-    }
-
-    public boolean isValidNodeConnector(String nodeConnectorStr) {
-        return (NodeConnector.fromString(nodeConnectorStr) != null);
-    }
-
-    public boolean isValid() {
-        if (!isValidResourceName(name)) {
-            logger.debug("Invalid name in user link: {}", name);
-            return false;
-        }
-
-        if (!isValidNodeConnector(srcNodeConnector) ||
-                !isValidNodeConnector(dstNodeConnector)) {
-            logger.debug("Invalid NodeConnector in user link: {}", name);
-            return false;
-        }
-
-        return true;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime
-                * result
-                + ((dstNodeConnector == null) ? 0 : dstNodeConnector.hashCode());
-        result = prime * result + ((name == null) ? 0 : name.hashCode());
-        result = prime
-                * result
-                + ((srcNodeConnector == null) ? 0 : srcNodeConnector.hashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        TopologyUserLinkConfig other = (TopologyUserLinkConfig) obj;
-        if (dstNodeConnector == null) {
-            if (other.dstNodeConnector != null) {
-                return false;
-            }
-        } else if (!dstNodeConnector.equals(other.dstNodeConnector)) {
-            return false;
-        }
-        if (srcNodeConnector == null) {
-            if (other.srcNodeConnector != null) {
-                return false;
-            }
-        } else if (!srcNodeConnector.equals(other.srcNodeConnector)) {
-            return false;
-        }
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        return "TopologyUserLinkConfig [status=" + status + ", name=" + name
-                + ", srcNodeConnector=" + srcNodeConnector
-                + ", dstNodeConnector=" + dstNodeConnector + "]";
-    }
-}
diff --git a/opendaylight/adsal/topologymanager/implementation/src/main/java/org/opendaylight/controller/topologymanager/internal/Activator.java b/opendaylight/adsal/topologymanager/implementation/src/main/java/org/opendaylight/controller/topologymanager/internal/Activator.java
deleted file mode 100644 (file)
index 8c422a5..0000000
+++ /dev/null
@@ -1,115 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.topologymanager.internal;
-
-import java.util.Dictionary;
-import java.util.HashSet;
-import java.util.Hashtable;
-import java.util.Set;
-
-import org.apache.felix.dm.Component;
-import org.opendaylight.controller.clustering.services.ICacheUpdateAware;
-import org.opendaylight.controller.clustering.services.IClusterContainerServices;
-import org.opendaylight.controller.configuration.IConfigurationContainerAware;
-import org.opendaylight.controller.configuration.IConfigurationContainerService;
-import org.opendaylight.controller.sal.core.ComponentActivatorAbstractBase;
-import org.opendaylight.controller.sal.topology.IListenTopoUpdates;
-import org.opendaylight.controller.sal.topology.ITopologyService;
-import org.opendaylight.controller.switchmanager.IInventoryListener;
-import org.opendaylight.controller.switchmanager.ISwitchManager;
-import org.opendaylight.controller.topologymanager.ITopologyManager;
-import org.opendaylight.controller.topologymanager.ITopologyManagerAware;
-import org.opendaylight.controller.topologymanager.ITopologyManagerClusterWideAware;
-import org.opendaylight.controller.topologymanager.ITopologyManagerShell;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-public class Activator extends ComponentActivatorAbstractBase {
-    protected static final Logger logger = LoggerFactory
-            .getLogger(Activator.class);
-
-
-    /**
-     * Function that is used to communicate to dependency manager the
-     * list of known implementations for services inside a container
-     *
-     *
-     * @return An array containing all the CLASS objects that will be
-     * instantiated in order to get an fully working implementation
-     * Object
-     */
-    @Override
-    public Object[] getImplementations() {
-        Object[] res = { TopologyManagerImpl.class };
-        return res;
-    }
-
-    /**
-     * Function that is called when configuration of the dependencies
-     * is required.
-     *
-     * @param c dependency manager Component object, used for
-     * configuring the dependencies exported and imported
-     * @param imp Implementation class that is being configured,
-     * needed as long as the same routine can configure multiple
-     * implementations
-     * @param containerName The containerName being configured, this allow
-     * also optional per-container different behavior if needed, usually
-     * should not be the case though.
-     */
-    @Override
-    public void configureInstance(Component c, Object imp, String containerName) {
-        if (imp.equals(TopologyManagerImpl.class)) {
-            // export the service needed to listen to topology updates
-            Dictionary<String, Set<String>> props = new Hashtable<String, Set<String>>();
-            Set<String> propSet = new HashSet<String>();
-            propSet.add(TopologyManagerImpl.TOPOEDGESDB);
-            props.put("cachenames", propSet);
-
-            c.setInterface(new String[] { IListenTopoUpdates.class.getName(),
-                    IInventoryListener.class.getName(),
-                    ITopologyManager.class.getName(),
-                    ITopologyManagerShell.class.getName(),
-                    IConfigurationContainerAware.class.getName(),
-                    ICacheUpdateAware.class.getName() }, props);
-
-            c.add(createContainerServiceDependency(containerName).setService(
-                    ITopologyService.class).setCallbacks("setTopoService",
-                    "unsetTopoService").setRequired(true));
-
-            c.add(createContainerServiceDependency(containerName).setService(
-                    ISwitchManager.class).setCallbacks("setSwitchManager",
-                    "unsetSwitchManager").setRequired(true));
-
-            // These are all the listeners for a topology manager
-            // updates, there could be many or none
-            c.add(createContainerServiceDependency(containerName).setService(
-                    ITopologyManagerAware.class).setCallbacks(
-                    "setTopologyManagerAware", "unsetTopologyManagerAware")
-                    .setRequired(false));
-
-            // These are all the listeners for a topology manager for the
-            // cluster wide events
-            // updates, there could be many or none
-            c.add(createContainerServiceDependency(containerName).setService(ITopologyManagerClusterWideAware.class)
-                    .setCallbacks("setTopologyManagerClusterWideAware", "unsetTopologyManagerClusterWideAware")
-                    .setRequired(false));
-
-            c.add(createContainerServiceDependency(containerName).setService(
-                    IClusterContainerServices.class).setCallbacks(
-                    "setClusterContainerService",
-                    "unsetClusterContainerService").setRequired(true));
-
-            c.add(createContainerServiceDependency(containerName).setService(
-                    IConfigurationContainerService.class).setCallbacks(
-                    "setConfigurationContainerService",
-                    "unsetConfigurationContainerService").setRequired(true));
-        }
-    }
-}
diff --git a/opendaylight/adsal/topologymanager/implementation/src/main/java/org/opendaylight/controller/topologymanager/internal/TopologyManagerImpl.java b/opendaylight/adsal/topologymanager/implementation/src/main/java/org/opendaylight/controller/topologymanager/internal/TopologyManagerImpl.java
deleted file mode 100644 (file)
index e1a0ca1..0000000
+++ /dev/null
@@ -1,1309 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.topologymanager.internal;
-
-import org.apache.commons.lang3.tuple.ImmutablePair;
-import org.apache.felix.dm.Component;
-import org.eclipse.osgi.framework.console.CommandInterpreter;
-import org.eclipse.osgi.framework.console.CommandProvider;
-import org.opendaylight.controller.clustering.services.CacheConfigException;
-import org.opendaylight.controller.clustering.services.CacheExistException;
-import org.opendaylight.controller.clustering.services.ICacheUpdateAware;
-import org.opendaylight.controller.clustering.services.IClusterContainerServices;
-import org.opendaylight.controller.clustering.services.IClusterServices;
-import org.opendaylight.controller.configuration.ConfigurationObject;
-import org.opendaylight.controller.configuration.IConfigurationContainerAware;
-import org.opendaylight.controller.configuration.IConfigurationContainerService;
-import org.opendaylight.controller.sal.core.Edge;
-import org.opendaylight.controller.sal.core.Host;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.core.TimeStamp;
-import org.opendaylight.controller.sal.core.UpdateType;
-import org.opendaylight.controller.sal.topology.IListenTopoUpdates;
-import org.opendaylight.controller.sal.topology.ITopologyService;
-import org.opendaylight.controller.sal.topology.TopoEdgeUpdate;
-import org.opendaylight.controller.sal.utils.IObjectReader;
-import org.opendaylight.controller.sal.utils.NodeConnectorCreator;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.sal.utils.StatusCode;
-import org.opendaylight.controller.switchmanager.IInventoryListener;
-import org.opendaylight.controller.switchmanager.ISwitchManager;
-import org.opendaylight.controller.topologymanager.ITopologyManager;
-import org.opendaylight.controller.topologymanager.ITopologyManagerAware;
-import org.opendaylight.controller.topologymanager.ITopologyManagerClusterWideAware;
-import org.opendaylight.controller.topologymanager.ITopologyManagerShell;
-import org.opendaylight.controller.topologymanager.TopologyUserLinkConfig;
-import org.osgi.framework.BundleContext;
-import org.osgi.framework.FrameworkUtil;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import java.io.FileNotFoundException;
-import java.io.IOException;
-import java.io.ObjectInputStream;
-import java.util.ArrayList;
-import java.util.Dictionary;
-import java.util.EnumSet;
-import java.util.HashMap;
-import java.util.HashSet;
-import java.util.Iterator;
-import java.util.LinkedList;
-import java.util.List;
-import java.util.Map;
-import java.util.Set;
-import java.util.Timer;
-import java.util.TimerTask;
-import java.util.concurrent.BlockingQueue;
-import java.util.concurrent.ConcurrentHashMap;
-import java.util.concurrent.ConcurrentMap;
-import java.util.concurrent.CopyOnWriteArraySet;
-import java.util.concurrent.LinkedBlockingQueue;
-
-/**
- * The class describes TopologyManager which is the central repository of the
- * network topology. It provides service for applications to interact with
- * topology database and notifies all the listeners of topology changes.
- */
-public class TopologyManagerImpl implements
-        ICacheUpdateAware<Object, Object>,
-        ITopologyManager,
-        ITopologyManagerShell,
-        IConfigurationContainerAware,
-        IListenTopoUpdates,
-        IObjectReader,
-        IInventoryListener,
-        CommandProvider {
-    protected static final String TOPOEDGESDB = "topologymanager.edgesDB";
-    protected static final String TOPOHOSTSDB = "topologymanager.hostsDB";
-    protected static final String TOPONODECONNECTORDB = "topologymanager.nodeConnectorDB";
-    protected static final String TOPOUSERLINKSDB = "topologymanager.userLinksDB";
-    private static final String USER_LINKS_FILE_NAME = "userTopology.conf";
-    private static final Logger log = LoggerFactory.getLogger(TopologyManagerImpl.class);
-    private static final long PENDING_UPDATE_TIMEOUT = 5000L;
-
-    private ITopologyService topoService;
-    private IClusterContainerServices clusterContainerService;
-    private IConfigurationContainerService configurationService;
-    private ISwitchManager switchManager;
-    // DB of all the Edges with properties which constitute our topology
-    private ConcurrentMap<Edge, Set<Property>> edgesDB;
-    // DB of all NodeConnector which are part of ISL Edges, meaning they
-    // are connected to another NodeConnector on the other side of an ISL link.
-    // NodeConnector of a Production Edge is not part of this DB.
-    private ConcurrentMap<NodeConnector, Set<Property>> nodeConnectorsDB;
-    // DB of all the NodeConnectors with an Host attached to it
-    private ConcurrentMap<NodeConnector, Set<ImmutablePair<Host, Set<Property>>>> hostsDB;
-    // Topology Manager Aware listeners
-    private Set<ITopologyManagerAware> topologyManagerAware = new CopyOnWriteArraySet<ITopologyManagerAware>();
-    // Topology Manager Aware listeners - for clusterwide updates
-    private Set<ITopologyManagerClusterWideAware> topologyManagerClusterWideAware =
-            new CopyOnWriteArraySet<ITopologyManagerClusterWideAware>();
-    private ConcurrentMap<String, TopologyUserLinkConfig> userLinksDB;
-    private BlockingQueue<TopoEdgeUpdate> notifyQ = new LinkedBlockingQueue<TopoEdgeUpdate>();
-    private volatile Boolean shuttingDown = false;
-    private Thread notifyThread;
-    private final Map<NodeConnector, List<PendingUpdateTask>> pendingUpdates =
-        new HashMap<NodeConnector, List<PendingUpdateTask>>();
-    private final BlockingQueue<TopoEdgeUpdate> updateQ =
-        new LinkedBlockingQueue<TopoEdgeUpdate>();
-    private Timer pendingTimer;
-    private Thread updateThread;
-
-    private class PendingEdgeUpdate extends TopoEdgeUpdate {
-        private PendingEdgeUpdate(Edge e, Set<Property> p, UpdateType t) {
-            super(e, p, t);
-        }
-    }
-
-    private class UpdateTopology implements Runnable {
-        @Override
-        public void run() {
-            log.trace("Start topology update thread");
-
-            while (!shuttingDown) {
-                try {
-                    List<TopoEdgeUpdate> list = new ArrayList<TopoEdgeUpdate>();
-                    TopoEdgeUpdate teu = updateQ.take();
-                    for (; teu != null; teu = updateQ.poll()) {
-                        list.add(teu);
-                    }
-
-                    if (!list.isEmpty()) {
-                        log.trace("Update edges: {}", list);
-                        doEdgeUpdate(list);
-                    }
-                } catch (InterruptedException e) {
-                    if (shuttingDown) {
-                        break;
-                    }
-                    log.warn("Topology update thread interrupted", e);
-                } catch (Exception e) {
-                    log.error("Exception on topology update thread", e);
-                }
-            }
-
-            log.trace("Exit topology update thread");
-        }
-    }
-
-    private class PendingUpdateTask extends TimerTask {
-        private final Edge  edge;
-        private final Set<Property>  props;
-        private final UpdateType  type;
-
-        private PendingUpdateTask(Edge e, Set<Property> p, UpdateType t) {
-            edge = e;
-            props = p;
-            type = t;
-        }
-
-        private NodeConnector getHeadNodeConnector() {
-            return edge.getHeadNodeConnector();
-        }
-
-        private void flush() {
-            log.info("Flush pending topology update: edge {}, type {}",
-                     edge, type);
-            updateQ.add(new PendingEdgeUpdate(edge, props, type));
-        }
-
-        @Override
-        public void run() {
-            if (removePendingEvent(this)) {
-                log.warn("Pending topology update timed out: edge{}, type {}",
-                         edge, type);
-            }
-        }
-    }
-
-    void nonClusterObjectCreate() {
-        edgesDB = new ConcurrentHashMap<Edge, Set<Property>>();
-        hostsDB = new ConcurrentHashMap<NodeConnector, Set<ImmutablePair<Host, Set<Property>>>>();
-        nodeConnectorsDB = new ConcurrentHashMap<NodeConnector, Set<Property>>();
-        userLinksDB = new ConcurrentHashMap<String, TopologyUserLinkConfig>();
-    }
-
-    void setTopologyManagerAware(ITopologyManagerAware s) {
-        if (this.topologyManagerAware != null) {
-            log.debug("Adding ITopologyManagerAware: {}", s);
-            this.topologyManagerAware.add(s);
-        }
-    }
-
-    void unsetTopologyManagerAware(ITopologyManagerAware s) {
-        if (this.topologyManagerAware != null) {
-            log.debug("Removing ITopologyManagerAware: {}", s);
-            this.topologyManagerAware.remove(s);
-        }
-    }
-
-    void setTopologyManagerClusterWideAware(ITopologyManagerClusterWideAware s) {
-        if (this.topologyManagerClusterWideAware != null) {
-            log.debug("Adding ITopologyManagerClusterWideAware: {}", s);
-            this.topologyManagerClusterWideAware.add(s);
-        }
-    }
-
-    void unsetTopologyManagerClusterWideAware(ITopologyManagerClusterWideAware s) {
-        if (this.topologyManagerClusterWideAware != null) {
-            log.debug("Removing ITopologyManagerClusterWideAware: {}", s);
-            this.topologyManagerClusterWideAware.remove(s);
-        }
-    }
-
-    void setTopoService(ITopologyService s) {
-        log.debug("Adding ITopologyService: {}", s);
-        this.topoService = s;
-    }
-
-    void unsetTopoService(ITopologyService s) {
-        if (this.topoService == s) {
-            log.debug("Removing ITopologyService: {}", s);
-            this.topoService = null;
-        }
-    }
-
-    void setClusterContainerService(IClusterContainerServices s) {
-        log.debug("Cluster Service set");
-        this.clusterContainerService = s;
-    }
-
-    void unsetClusterContainerService(IClusterContainerServices s) {
-        if (this.clusterContainerService == s) {
-            log.debug("Cluster Service removed!");
-            this.clusterContainerService = null;
-        }
-    }
-
-    public void setConfigurationContainerService(IConfigurationContainerService service) {
-        log.trace("Got configuration service set request {}", service);
-        this.configurationService = service;
-    }
-
-    public void unsetConfigurationContainerService(IConfigurationContainerService service) {
-        log.trace("Got configuration service UNset request");
-        this.configurationService = null;
-    }
-
-    void setSwitchManager(ISwitchManager s) {
-        log.debug("Adding ISwitchManager: {}", s);
-        this.switchManager = s;
-    }
-
-    void unsetSwitchManager(ISwitchManager s) {
-        if (this.switchManager == s) {
-            log.debug("Removing ISwitchManager: {}", s);
-            this.switchManager = null;
-        }
-    }
-
-    /**
-     * Function called by the dependency manager when all the required
-     * dependencies are satisfied
-     *
-     */
-    void init(Component c) {
-        allocateCaches();
-        retrieveCaches();
-        String containerName = null;
-        Dictionary<?, ?> props = c.getServiceProperties();
-        if (props != null) {
-            containerName = (String) props.get("containerName");
-        } else {
-            // In the Global instance case the containerName is empty
-            containerName = "UNKNOWN";
-        }
-
-        registerWithOSGIConsole();
-        loadConfiguration();
-
-        // Restore the shuttingDown status on init of the component
-        shuttingDown = false;
-        notifyThread = new Thread(new TopologyNotify(notifyQ));
-        pendingTimer = new Timer("Topology Pending Update Timer");
-        updateThread = new Thread(new UpdateTopology(), "Topology Update");
-    }
-
-    @SuppressWarnings({ "unchecked" })
-    private void allocateCaches() {
-            this.edgesDB =
-                    (ConcurrentMap<Edge, Set<Property>>) allocateCache(TOPOEDGESDB,EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-
-            this.hostsDB =
-                    (ConcurrentMap<NodeConnector, Set<ImmutablePair<Host, Set<Property>>>>) allocateCache(TOPOHOSTSDB, EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-
-            this.nodeConnectorsDB =
-                    (ConcurrentMap<NodeConnector, Set<Property>>) allocateCache(
-                            TOPONODECONNECTORDB, EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-            this.userLinksDB =
-                    (ConcurrentMap<String, TopologyUserLinkConfig>) allocateCache(
-                            TOPOUSERLINKSDB, EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-    }
-
-    private ConcurrentMap<?, ?> allocateCache(String cacheName, Set<IClusterServices.cacheMode> cacheModes) {
-        ConcurrentMap<?, ?> cache = null;
-        try {
-            cache = this.clusterContainerService.createCache(cacheName, cacheModes);
-        } catch (CacheExistException e) {
-            log.debug(cacheName + " cache already exists - destroy and recreate if needed");
-        } catch (CacheConfigException e) {
-            log.error(cacheName + " cache configuration invalid - check cache mode");
-        }
-        return cache;
-    }
-
-    @SuppressWarnings({ "unchecked" })
-    private void retrieveCaches() {
-        if (this.clusterContainerService == null) {
-            log.error("Cluster Services is null, can't retrieve caches.");
-            return;
-        }
-
-        this.edgesDB = (ConcurrentMap<Edge, Set<Property>>) this.clusterContainerService.getCache(TOPOEDGESDB);
-        if (edgesDB == null) {
-            log.error("Failed to get cache for " + TOPOEDGESDB);
-        }
-
-        this.hostsDB =
-                (ConcurrentMap<NodeConnector, Set<ImmutablePair<Host, Set<Property>>>>) this.clusterContainerService.getCache(TOPOHOSTSDB);
-        if (hostsDB == null) {
-            log.error("Failed to get cache for " + TOPOHOSTSDB);
-        }
-
-        this.nodeConnectorsDB =
-                (ConcurrentMap<NodeConnector, Set<Property>>) this.clusterContainerService.getCache(TOPONODECONNECTORDB);
-        if (nodeConnectorsDB == null) {
-            log.error("Failed to get cache for " + TOPONODECONNECTORDB);
-        }
-
-        this.userLinksDB =
-                (ConcurrentMap<String, TopologyUserLinkConfig>) this.clusterContainerService.getCache(TOPOUSERLINKSDB);
-        if (userLinksDB == null) {
-            log.error("Failed to get cache for " + TOPOUSERLINKSDB);
-        }
-    }
-
-    /**
-     * Function called after the topology manager has registered the service in
-     * OSGi service registry.
-     *
-     */
-    void started() {
-        updateThread.start();
-
-        // Start the batcher thread for the cluster wide topology updates
-        notifyThread.start();
-        // SollicitRefresh MUST be called here else if called at init
-        // time it may sollicit refresh too soon.
-        log.debug("Sollicit topology refresh");
-        topoService.sollicitRefresh();
-    }
-
-    void stop() {
-        shuttingDown = true;
-        updateThread.interrupt();
-        notifyThread.interrupt();
-        pendingTimer.cancel();
-    }
-
-    /**
-     * Function called by the dependency manager when at least one dependency
-     * become unsatisfied or when the component is shutting down because for
-     * example bundle is being stopped.
-     *
-     */
-    void destroy() {
-        updateQ.clear();
-        updateThread = null;
-        pendingTimer = null;
-        notifyQ.clear();
-        notifyThread = null;
-    }
-
-    private void loadConfiguration() {
-        for (ConfigurationObject conf : configurationService.retrieveConfiguration(this, USER_LINKS_FILE_NAME)) {
-            addUserLink((TopologyUserLinkConfig) conf);
-        }
-    }
-
-    @Override
-    public Status saveConfig() {
-        return saveConfigInternal();
-    }
-
-    public Status saveConfigInternal() {
-        Status saveStatus = configurationService.persistConfiguration(
-                new ArrayList<ConfigurationObject>(userLinksDB.values()), USER_LINKS_FILE_NAME);
-
-        if (!saveStatus.isSuccess()) {
-            return new Status(StatusCode.INTERNALERROR, "Topology save failed: " + saveStatus.getDescription());
-        }
-        return saveStatus;
-    }
-
-    @Override
-    public Map<Node, Set<Edge>> getNodeEdges() {
-        if (this.edgesDB == null) {
-            return null;
-        }
-
-        Map<Node, Set<Edge>> res = new HashMap<Node, Set<Edge>>();
-        for (Edge edge : this.edgesDB.keySet()) {
-            // Lets analyze the tail
-            Node node = edge.getTailNodeConnector().getNode();
-            Set<Edge> nodeEdges = res.get(node);
-            if (nodeEdges == null) {
-                nodeEdges = new HashSet<Edge>();
-                res.put(node, nodeEdges);
-            }
-            nodeEdges.add(edge);
-
-            // Lets analyze the head
-            node = edge.getHeadNodeConnector().getNode();
-            nodeEdges = res.get(node);
-            if (nodeEdges == null) {
-                nodeEdges = new HashSet<Edge>();
-                res.put(node, nodeEdges);
-            }
-            nodeEdges.add(edge);
-        }
-
-        return res;
-    }
-
-    @Override
-    public boolean isInternal(NodeConnector p) {
-        if (this.nodeConnectorsDB == null) {
-            return false;
-        }
-
-        // This is an internal NodeConnector if is connected to
-        // another Node i.e it's part of the nodeConnectorsDB
-        return (this.nodeConnectorsDB.get(p) != null);
-    }
-
-    /**
-     * This method returns true if the edge is an ISL link.
-     *
-     * @param e
-     *            The edge
-     * @return true if it is an ISL link
-     */
-    public boolean isISLink(Edge e) {
-        return (!isProductionLink(e));
-    }
-
-    /**
-     * This method returns true if the edge is a production link.
-     *
-     * @param e
-     *            The edge
-     * @return true if it is a production link
-     */
-    public boolean isProductionLink(Edge e) {
-        return (e.getHeadNodeConnector().getType().equals(NodeConnector.NodeConnectorIDType.PRODUCTION)
-                || e.getTailNodeConnector().getType().equals(NodeConnector.NodeConnectorIDType.PRODUCTION));
-    }
-
-    /**
-     * This method cross checks the determination of nodeConnector type by Discovery Service
-     * against the information in SwitchManager and updates it accordingly.
-     * @param e
-     *          The edge
-     */
-    private void crossCheckNodeConnectors(Edge e) {
-        NodeConnector nc;
-        if (e.getHeadNodeConnector().getType().equals(NodeConnector.NodeConnectorIDType.PRODUCTION)) {
-            nc = updateNCTypeFromSwitchMgr(e.getHeadNodeConnector());
-            if (nc != null) {
-                e.setHeadNodeConnector(nc);
-            }
-        }
-        if (e.getTailNodeConnector().getType().equals(NodeConnector.NodeConnectorIDType.PRODUCTION)) {
-            nc = updateNCTypeFromSwitchMgr(e.getTailNodeConnector());
-            if (nc != null) {
-                e.setTailNodeConnector(nc);
-            }
-        }
-    }
-
-    /**
-     * A NodeConnector may have been categorized as of type Production by Discovery Service.
-     * But at the time when this determination was made, only OF nodes were known to Discovery
-     * Service. This method checks if the node of nodeConnector is known to SwitchManager. If
-     * so, then it returns a new NodeConnector with correct type.
-     *
-     * @param nc
-     *       NodeConnector as passed on in the edge
-     * @return
-     *       If Node of the NodeConnector is in SwitchManager, then return a new NodeConnector
-     *       with correct type, null otherwise
-     */
-
-    private NodeConnector updateNCTypeFromSwitchMgr(NodeConnector nc) {
-
-        for (Node node : switchManager.getNodes()) {
-            String nodeName = node.getNodeIDString();
-            log.trace("Switch Manager Node Name: {}, NodeConnector Node Name: {}", nodeName,
-                    nc.getNode().getNodeIDString());
-            if (nodeName.equals(nc.getNode().getNodeIDString())) {
-                NodeConnector nodeConnector = NodeConnectorCreator
-                        .createNodeConnector(node.getType(), nc.getID(), node);
-                return nodeConnector;
-            }
-        }
-        return null;
-    }
-
-    /**
-     * The Map returned is a copy of the current topology hence if the topology
-     * changes the copy doesn't
-     *
-     * @return A Map representing the current topology expressed as edges of the
-     *         network
-     */
-    @Override
-    public Map<Edge, Set<Property>> getEdges() {
-        if (this.edgesDB == null) {
-            return null;
-        }
-
-        Map<Edge, Set<Property>> edgeMap = new HashMap<Edge, Set<Property>>();
-        Set<Property> props;
-        for (Map.Entry<Edge, Set<Property>> edgeEntry : edgesDB.entrySet()) {
-            // Sets of props are copied because the composition of
-            // those properties could change with time
-            props = new HashSet<Property>(edgeEntry.getValue());
-            // We can simply reuse the key because the object is
-            // immutable so doesn't really matter that we are
-            // referencing the only owned by a different table, the
-            // meaning is the same because doesn't change with time.
-            edgeMap.put(edgeEntry.getKey(), props);
-        }
-
-        return edgeMap;
-    }
-
-    @Override
-    public Set<NodeConnector> getNodeConnectorWithHost() {
-        if (this.hostsDB == null) {
-            return null;
-        }
-
-        return (new HashSet<NodeConnector>(this.hostsDB.keySet()));
-    }
-
-    @Override
-    public Map<Node, Set<NodeConnector>> getNodesWithNodeConnectorHost() {
-        if (this.hostsDB == null) {
-            return null;
-        }
-        HashMap<Node, Set<NodeConnector>> res = new HashMap<Node, Set<NodeConnector>>();
-        Node node;
-        Set<NodeConnector> portSet;
-        for (NodeConnector nc : this.hostsDB.keySet()) {
-            node = nc.getNode();
-            portSet = res.get(node);
-            if (portSet == null) {
-                // Create the HashSet if null
-                portSet = new HashSet<NodeConnector>();
-                res.put(node, portSet);
-            }
-
-            // Keep updating the HashSet, given this is not a
-            // clustered map we can just update the set without
-            // worrying to update the hashmap.
-            portSet.add(nc);
-        }
-
-        return (res);
-    }
-
-    @Override
-    public Host getHostAttachedToNodeConnector(NodeConnector port) {
-        List<Host> hosts = getHostsAttachedToNodeConnector(port);
-        if(hosts != null && !hosts.isEmpty()){
-            return hosts.get(0);
-        }
-        return null;
-    }
-
-    @Override
-    public List<Host> getHostsAttachedToNodeConnector(NodeConnector p) {
-        Set<ImmutablePair<Host, Set<Property>>> hosts;
-        if (this.hostsDB == null || (hosts = this.hostsDB.get(p)) == null) {
-            return null;
-        }
-        // create a list of hosts
-        List<Host> retHosts = new LinkedList<Host>();
-        for(ImmutablePair<Host, Set<Property>> host : hosts) {
-            retHosts.add(host.getLeft());
-        }
-        return retHosts;
-    }
-
-    @Override
-    public synchronized void updateHostLink(NodeConnector port, Host h, UpdateType t, Set<Property> props) {
-
-        // Clone the property set in case non null else just
-        // create an empty one. Caches allocated via infinispan
-        // don't allow null values
-        if (props == null) {
-            props = new HashSet<Property>();
-        } else {
-            props = new HashSet<Property>(props);
-        }
-        ImmutablePair<Host, Set<Property>> thisHost = new ImmutablePair<Host, Set<Property>>(h, props);
-
-        // get the host list
-        Set<ImmutablePair<Host, Set<Property>>> hostSet = this.hostsDB.get(port);
-        if(hostSet == null) {
-            hostSet = new HashSet<ImmutablePair<Host, Set<Property>>>();
-        }
-        switch (t) {
-        case ADDED:
-        case CHANGED:
-            hostSet.add(thisHost);
-            this.hostsDB.put(port, hostSet);
-            break;
-        case REMOVED:
-            hostSet.remove(thisHost);
-            if(hostSet.isEmpty()) {
-                //remove only if hasn't been concurrently modified
-                this.hostsDB.remove(port, hostSet);
-            } else {
-                this.hostsDB.put(port, hostSet);
-            }
-            break;
-        }
-    }
-
-    private boolean headNodeConnectorExist(Edge e) {
-        /*
-         * Only check the head end point which is supposed to be part of a
-         * network node we control (present in our inventory). If we checked the
-         * tail end point as well, we would not store the edges that connect to
-         * a non sdn enable port on a non sdn capable production switch. We want
-         * to be able to see these switches on the topology.
-         */
-        NodeConnector head = e.getHeadNodeConnector();
-        return (switchManager.doesNodeConnectorExist(head));
-    }
-
-    private void addPendingEvent(Edge e, Set<Property> p, UpdateType t) {
-        NodeConnector head = e.getHeadNodeConnector();
-        PendingUpdateTask task = new PendingUpdateTask(e, p, t);
-        synchronized (pendingUpdates) {
-            List<PendingUpdateTask> list = pendingUpdates.get(head);
-            if (list == null) {
-                list = new LinkedList<PendingUpdateTask>();
-                pendingUpdates.put(head, list);
-            }
-            list.add(task);
-            pendingTimer.schedule(task, PENDING_UPDATE_TIMEOUT);
-        }
-    }
-
-    private boolean enqueueEventIfPending(Edge e, Set<Property> p, UpdateType t) {
-        NodeConnector head = e.getHeadNodeConnector();
-        synchronized (pendingUpdates) {
-            List<PendingUpdateTask> list = pendingUpdates.get(head);
-            if (list != null) {
-                log.warn("Enqueue edge update: edge {}, type {}", e, t);
-                PendingUpdateTask task = new PendingUpdateTask(e, p, t);
-                list.add(task);
-                pendingTimer.schedule(task, PENDING_UPDATE_TIMEOUT);
-                return true;
-            }
-        }
-
-        return false;
-    }
-
-    private boolean removePendingEvent(PendingUpdateTask t) {
-        t.cancel();
-        NodeConnector head = t.getHeadNodeConnector();
-        boolean removed = false;
-
-        synchronized (pendingUpdates) {
-            List<PendingUpdateTask> list = pendingUpdates.get(head);
-            if (list != null) {
-                removed = list.remove(t);
-                if (list.isEmpty()) {
-                    pendingUpdates.remove(head);
-                }
-            }
-        }
-
-        return removed;
-    }
-
-    private void removePendingEvent(NodeConnector head, boolean doFlush) {
-        List<PendingUpdateTask> list;
-        synchronized (pendingUpdates) {
-            list = pendingUpdates.remove(head);
-        }
-
-        if (list != null) {
-            for (PendingUpdateTask task : list) {
-                if (task.cancel() && doFlush) {
-                    task.flush();
-                }
-            }
-            pendingTimer.purge();
-        }
-    }
-
-    private TopoEdgeUpdate edgeUpdate(Edge e, UpdateType type, Set<Property> props) {
-        return edgeUpdate(e, type, props, false);
-    }
-
-    private TopoEdgeUpdate edgeUpdate(Edge e, UpdateType type, Set<Property> props, boolean isPending) {
-        if (!type.equals(UpdateType.ADDED) &&
-            enqueueEventIfPending(e, props, type)) {
-            return null;
-        }
-
-        switch (type) {
-        case ADDED:
-            if (this.edgesDB.containsKey(e)) {
-                // Avoid redundant updates (e.g. cluster switch-over) as notifications trigger expensive tasks
-                log.trace("Skipping redundant edge addition: {}", e);
-                return null;
-            }
-
-            // Ensure that head node connector exists
-            if (!isPending) {
-                if (headNodeConnectorExist(e)) {
-                    removePendingEvent(e.getHeadNodeConnector(), true);
-                } else {
-                    log.warn("Ignore edge that contains invalid node connector: {}",
-                             e);
-                    addPendingEvent(e, props, type);
-                    return null;
-                }
-            }
-
-            // Make sure the props are non-null or create a copy
-            if (props == null) {
-                props = new HashSet<Property>();
-            } else {
-                props = new HashSet<Property>(props);
-            }
-
-            // Check if nodeConnectors of the edge were correctly categorized
-            // by protocol plugin
-            crossCheckNodeConnectors(e);
-
-            // Now make sure there is the creation timestamp for the
-            // edge, if not there, stamp with the first update
-            boolean found_create = false;
-            for (Property prop : props) {
-                if (prop instanceof TimeStamp) {
-                    TimeStamp t = (TimeStamp) prop;
-                    if (t.getTimeStampName().equals("creation")) {
-                        found_create = true;
-                        break;
-                    }
-                }
-            }
-
-            if (!found_create) {
-                TimeStamp t = new TimeStamp(System.currentTimeMillis(), "creation");
-                props.add(t);
-            }
-
-            // Now add this in the database eventually overriding
-            // something that may have been already existing
-            this.edgesDB.put(e, props);
-
-            // Now populate the DB of NodeConnectors
-            // NOTE WELL: properties are empty sets, not really needed
-            // for now.
-            // The DB only contains ISL ports
-            if (isISLink(e)) {
-                this.nodeConnectorsDB.put(e.getHeadNodeConnector(), new HashSet<Property>(1));
-                this.nodeConnectorsDB.put(e.getTailNodeConnector(), new HashSet<Property>(1));
-            }
-            log.trace("Edge {}  {}", e.toString(), type.name());
-            break;
-        case REMOVED:
-            // Now remove the edge from edgesDB
-            this.edgesDB.remove(e);
-
-            // Now lets update the NodeConnectors DB, the assumption
-            // here is that two NodeConnector are exclusively
-            // connected by 1 and only 1 edge, this is reasonable in
-            // the same plug (virtual of phisical) we can assume two
-            // cables won't be plugged. This could break only in case
-            // of devices in the middle that acts as hubs, but it
-            // should be safe to assume that won't happen.
-            this.nodeConnectorsDB.remove(e.getHeadNodeConnector());
-            this.nodeConnectorsDB.remove(e.getTailNodeConnector());
-            log.trace("Edge {}  {}", e.toString(), type.name());
-            break;
-        case CHANGED:
-            Set<Property> oldProps = this.edgesDB.get(e);
-
-            // When property(s) changes lets make sure we can change it
-            // all except the creation time stamp because that should
-            // be set only when the edge is created
-            TimeStamp timeStamp = null;
-            if (oldProps != null) {
-                for (Property prop : oldProps) {
-                    if (prop instanceof TimeStamp) {
-                        TimeStamp tsProp = (TimeStamp) prop;
-                        if (tsProp.getTimeStampName().equals("creation")) {
-                            timeStamp = tsProp;
-                            break;
-                        }
-                    }
-                }
-            }
-
-            // Now lets make sure new properties are non-null
-            if (props == null) {
-                props = new HashSet<Property>();
-            } else {
-                // Copy the set so noone is going to change the content
-                props = new HashSet<Property>(props);
-            }
-
-            // Now lets remove the creation property if exist in the
-            // new props
-            for (Iterator<Property> i = props.iterator(); i.hasNext();) {
-                Property prop = i.next();
-                if (prop instanceof TimeStamp) {
-                    TimeStamp t = (TimeStamp) prop;
-                    if (t.getTimeStampName().equals("creation")) {
-                        if (timeStamp != null) {
-                            i.remove();
-                        }
-                        break;
-                    }
-                }
-            }
-
-            // Now lets add the creation timestamp in it
-            if (timeStamp != null) {
-                props.add(timeStamp);
-            }
-
-            // Finally update
-            this.edgesDB.put(e, props);
-            log.trace("Edge {}  {}", e.toString(), type.name());
-            break;
-        }
-        return new TopoEdgeUpdate(e, props, type);
-    }
-
-    private void doEdgeUpdate(List<TopoEdgeUpdate> topoedgeupdateList) {
-        List<TopoEdgeUpdate> teuList = new ArrayList<TopoEdgeUpdate>();
-        for (TopoEdgeUpdate teu : topoedgeupdateList) {
-            boolean isPending = (teu instanceof PendingEdgeUpdate);
-            Edge e = teu.getEdge();
-            Set<Property> p = teu.getProperty();
-            UpdateType type = teu.getUpdateType();
-            TopoEdgeUpdate update = edgeUpdate(e, type, p, isPending);
-            if (update != null) {
-                teuList.add(update);
-            }
-        }
-
-        if (!teuList.isEmpty()) {
-            // Now update the listeners
-            for (ITopologyManagerAware s : this.topologyManagerAware) {
-                try {
-                    s.edgeUpdate(teuList);
-                } catch (Exception exc) {
-                    log.error("Exception on edge update:", exc);
-                }
-            }
-        }
-    }
-
-    @Override
-    public void edgeUpdate(List<TopoEdgeUpdate> topoedgeupdateList) {
-        updateQ.addAll(topoedgeupdateList);
-    }
-
-    private Edge getReverseLinkTuple(TopologyUserLinkConfig link) {
-        TopologyUserLinkConfig rLink = new TopologyUserLinkConfig(
-                link.getName(), link.getDstNodeConnector(), link.getSrcNodeConnector());
-        return getLinkTuple(rLink);
-    }
-
-
-    private Edge getLinkTuple(TopologyUserLinkConfig link) {
-        NodeConnector srcNodeConnector = NodeConnector.fromString(link.getSrcNodeConnector());
-        NodeConnector dstNodeConnector = NodeConnector.fromString(link.getDstNodeConnector());
-        try {
-            return new Edge(srcNodeConnector, dstNodeConnector);
-        } catch (Exception e) {
-            return null;
-        }
-    }
-
-    @Override
-    public ConcurrentMap<String, TopologyUserLinkConfig> getUserLinks() {
-        return new ConcurrentHashMap<String, TopologyUserLinkConfig>(userLinksDB);
-    }
-
-    @Override
-    public Status addUserLink(TopologyUserLinkConfig userLink) {
-        if (!userLink.isValid()) {
-            return new Status(StatusCode.BADREQUEST,
-                    "User link configuration invalid.");
-        }
-        userLink.setStatus(TopologyUserLinkConfig.STATUS.LINKDOWN);
-
-        //Check if this link already configured
-        //NOTE: infinispan cache doesn't support Map.containsValue()
-        // (which is linear time in most ConcurrentMap impl anyway)
-        for (TopologyUserLinkConfig existingLink : userLinksDB.values()) {
-            if (existingLink.equals(userLink)) {
-                return new Status(StatusCode.CONFLICT, "Link configuration exists");
-            }
-        }
-        //attempt put, if mapping for this key already existed return conflict
-        if (userLinksDB.putIfAbsent(userLink.getName(), userLink) != null) {
-            return new Status(StatusCode.CONFLICT, "Link with name : " + userLink.getName()
-                    + " already exists. Please use another name");
-        }
-
-        Edge linkTuple = getLinkTuple(userLink);
-        if (linkTuple != null) {
-            if (!isProductionLink(linkTuple)) {
-                TopoEdgeUpdate teu = edgeUpdate(linkTuple, UpdateType.ADDED,
-                                                new HashSet<Property>());
-                if (teu == null) {
-                    userLinksDB.remove(userLink.getName());
-                    return new Status(StatusCode.NOTFOUND,
-                           "Link configuration contains invalid node connector: "
-                           + userLink);
-                }
-            }
-
-            linkTuple = getReverseLinkTuple(userLink);
-            if (linkTuple != null) {
-                userLink.setStatus(TopologyUserLinkConfig.STATUS.SUCCESS);
-                if (!isProductionLink(linkTuple)) {
-                    edgeUpdate(linkTuple, UpdateType.ADDED, new HashSet<Property>());
-                }
-            }
-        }
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    @Override
-    public Status deleteUserLink(String linkName) {
-        if (linkName == null) {
-            return new Status(StatusCode.BADREQUEST, "User link name cannot be null.");
-        }
-
-        TopologyUserLinkConfig link = userLinksDB.remove(linkName);
-        Edge linkTuple;
-        if ((link != null) && ((linkTuple = getLinkTuple(link)) != null)) {
-            if (! isProductionLink(linkTuple)) {
-                edgeUpdate(linkTuple, UpdateType.REMOVED, null);
-            }
-
-            linkTuple = getReverseLinkTuple(link);
-            if (! isProductionLink(linkTuple)) {
-                edgeUpdate(linkTuple, UpdateType.REMOVED, null);
-            }
-        }
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    private void registerWithOSGIConsole() {
-        BundleContext bundleContext = FrameworkUtil.getBundle(this.getClass())
-                .getBundleContext();
-        bundleContext.registerService(CommandProvider.class.getName(), this,
-                null);
-    }
-
-    @Override
-    public String getHelp() {
-        StringBuffer help = new StringBuffer();
-        help.append("---Topology Manager---\n");
-        help.append("\t addUserLink <name> <node connector string> <node connector string>\n");
-        help.append("\t deleteUserLink <name>\n");
-        help.append("\t printUserLink\n");
-        help.append("\t printNodeEdges\n");
-        return help.toString();
-    }
-
-    public void _printUserLink(CommandInterpreter ci) {
-        for (String name : this.userLinksDB.keySet()) {
-            TopologyUserLinkConfig linkConfig = userLinksDB.get(name);
-            ci.println("Name : " + name);
-            ci.println(linkConfig);
-            ci.println("Edge " + getLinkTuple(linkConfig));
-            ci.println("Reverse Edge " + getReverseLinkTuple(linkConfig));
-        }
-    }
-
-    public void _addUserLink(CommandInterpreter ci) {
-        String name = ci.nextArgument();
-        if ((name == null)) {
-            ci.println("Please enter a valid Name");
-            return;
-        }
-
-        String ncStr1 = ci.nextArgument();
-        if (ncStr1 == null) {
-            ci.println("Please enter two node connector strings");
-            return;
-        }
-        String ncStr2 = ci.nextArgument();
-        if (ncStr2 == null) {
-            ci.println("Please enter second node connector string");
-            return;
-        }
-
-        NodeConnector nc1 = NodeConnector.fromString(ncStr1);
-        if (nc1 == null) {
-            ci.println("Invalid input node connector 1 string: " + ncStr1);
-            return;
-        }
-        NodeConnector nc2 = NodeConnector.fromString(ncStr2);
-        if (nc2 == null) {
-            ci.println("Invalid input node connector 2 string: " + ncStr2);
-            return;
-        }
-
-        TopologyUserLinkConfig config = new TopologyUserLinkConfig(name, ncStr1, ncStr2);
-        ci.println(this.addUserLink(config));
-    }
-
-    public void _deleteUserLink(CommandInterpreter ci) {
-        String name = ci.nextArgument();
-        if ((name == null)) {
-            ci.println("Please enter a valid Name");
-            return;
-        }
-        this.deleteUserLink(name);
-    }
-
-    public void _printNodeEdges(CommandInterpreter ci) {
-        Map<Node, Set<Edge>> nodeEdges = getNodeEdges();
-        if (nodeEdges == null) {
-            return;
-        }
-        Set<Node> nodeSet = nodeEdges.keySet();
-        if (nodeSet == null) {
-            return;
-        }
-        ci.println("        Node                                         Edge");
-        for (Node node : nodeSet) {
-            Set<Edge> edgeSet = nodeEdges.get(node);
-            if (edgeSet == null) {
-                continue;
-            }
-            for (Edge edge : edgeSet) {
-                ci.println(node + "             " + edge);
-            }
-        }
-    }
-
-    @Override
-    public Object readObject(ObjectInputStream ois)
-            throws FileNotFoundException, IOException, ClassNotFoundException {
-        return ois.readObject();
-    }
-
-    @Override
-    public Status saveConfiguration() {
-        return saveConfig();
-    }
-
-    @Override
-    public void edgeOverUtilized(Edge edge) {
-        log.warn("Link Utilization above normal: {}", edge);
-    }
-
-    @Override
-    public void edgeUtilBackToNormal(Edge edge) {
-        log.warn("Link Utilization back to normal: {}", edge);
-    }
-
-    private void edgeUpdateClusterWide(Edge e, UpdateType type, Set<Property> props, boolean isLocal) {
-        TopoEdgeUpdate upd = new TopoEdgeUpdate(e, props, type);
-        upd.setLocal(isLocal);
-        notifyQ.add(upd);
-    }
-
-    @Override
-    public void notifyNode(Node node, UpdateType type, Map<String, Property> propMap) {
-        // NOP
-    }
-
-    @Override
-    public void notifyNodeConnector(NodeConnector nc, UpdateType type, Map<String, Property> propMap) {
-        // Remove pending edge updates for the given node connector.
-        // Pending events should be notified if the node connector exists.
-        boolean doFlush = !type.equals(UpdateType.REMOVED);
-        removePendingEvent(nc, doFlush);
-    }
-
-    @Override
-    public void entryCreated(final Object key, final String cacheName, final boolean originLocal) {
-        if (cacheName.equals(TOPOEDGESDB)) {
-            // This is the case of an Edge being added to the topology DB
-            final Edge e = (Edge) key;
-            log.trace("Edge {} CREATED isLocal:{}", e, originLocal);
-            edgeUpdateClusterWide(e, UpdateType.ADDED, null, originLocal);
-        }
-    }
-
-    @Override
-    public void entryUpdated(final Object key, final Object new_value, final String cacheName, final boolean originLocal) {
-        if (cacheName.equals(TOPOEDGESDB)) {
-            final Edge e = (Edge) key;
-            log.trace("Edge {} UPDATED isLocal:{}", e, originLocal);
-            final Set<Property> props = (Set<Property>) new_value;
-            edgeUpdateClusterWide(e, UpdateType.CHANGED, props, originLocal);
-        }
-    }
-
-    @Override
-    public void entryDeleted(final Object key, final String cacheName, final boolean originLocal) {
-        if (cacheName.equals(TOPOEDGESDB)) {
-            final Edge e = (Edge) key;
-            log.trace("Edge {} DELETED isLocal:{}", e, originLocal);
-            edgeUpdateClusterWide(e, UpdateType.REMOVED, null, originLocal);
-        }
-    }
-
-    class TopologyNotify implements Runnable {
-        private final BlockingQueue<TopoEdgeUpdate> notifyQ;
-        private TopoEdgeUpdate entry;
-        private List<TopoEdgeUpdate> teuList = new ArrayList<TopoEdgeUpdate>();
-        private boolean notifyListeners;
-
-        TopologyNotify(BlockingQueue<TopoEdgeUpdate> notifyQ) {
-            this.notifyQ = notifyQ;
-        }
-
-        @Override
-        public void run() {
-            while (true) {
-                try {
-                    log.trace("New run of TopologyNotify");
-                    notifyListeners = false;
-                    // First we block waiting for an element to get in
-                    entry = notifyQ.take();
-                    // Then we drain the whole queue if elements are
-                    // in it without getting into any blocking condition
-                    for (; entry != null; entry = notifyQ.poll()) {
-                        teuList.add(entry);
-                        notifyListeners = true;
-                    }
-
-                    // Notify listeners only if there were updates drained else
-                    // give up
-                    if (notifyListeners) {
-                        log.trace("Notifier thread, notified a listener");
-                        // Now update the listeners
-                        for (ITopologyManagerClusterWideAware s : topologyManagerClusterWideAware) {
-                            try {
-                                s.edgeUpdate(teuList);
-                            } catch (Exception exc) {
-                                log.error("Exception on edge update:", exc);
-                            }
-                        }
-                    }
-                    teuList.clear();
-
-                    // Lets sleep for sometime to allow aggregation of event
-                    Thread.sleep(100);
-                } catch (InterruptedException e1) {
-                    if (shuttingDown) {
-                        return;
-                    }
-                    log.warn("TopologyNotify interrupted {}", e1.getMessage());
-                } catch (Exception e2) {
-                    log.error("", e2);
-                }
-            }
-        }
-    }
-
-    public List<String> printUserLink() {
-        List<String> result = new ArrayList<String>();
-        for (String name : this.userLinksDB.keySet()) {
-            TopologyUserLinkConfig linkConfig = userLinksDB.get(name);
-            result.add("Name : " + name);
-            result.add(linkConfig.toString());
-            result.add("Edge " + getLinkTuple(linkConfig));
-            result.add("Reverse Edge " + getReverseLinkTuple(linkConfig));
-        }
-        return result;
-    }
-
-    public List<String> addUserLink(String name, String ncStr1, String ncStr2) {
-        List<String> result = new ArrayList<String>();
-        if ((name == null)) {
-            result.add("Please enter a valid Name");
-            return result;
-        }
-
-        if (ncStr1 == null) {
-            result.add("Please enter two node connector strings");
-            return result;
-        }
-        if (ncStr2 == null) {
-            result.add("Please enter second node connector string");
-            return result;
-        }
-
-        NodeConnector nc1 = NodeConnector.fromString(ncStr1);
-        if (nc1 == null) {
-            result.add("Invalid input node connector 1 string: " + ncStr1);
-            return result;
-        }
-        NodeConnector nc2 = NodeConnector.fromString(ncStr2);
-        if (nc2 == null) {
-            result.add("Invalid input node connector 2 string: " + ncStr2);
-            return result;
-        }
-
-        TopologyUserLinkConfig config = new TopologyUserLinkConfig(name, ncStr1, ncStr2);
-        result.add(this.addUserLink(config).toString());
-        return result;
-    }
-
-    public List<String> deleteUserLinkShell(String name) {
-        List<String> result = new ArrayList<String>();
-        if ((name == null)) {
-            result.add("Please enter a valid Name");
-            return result;
-        }
-        this.deleteUserLink(name);
-        return result;
-    }
-
-    public List<String> printNodeEdges() {
-        List<String> result = new ArrayList<String>();
-        Map<Node, Set<Edge>> nodeEdges = getNodeEdges();
-        if (nodeEdges == null) {
-            return result;
-        }
-        Set<Node> nodeSet = nodeEdges.keySet();
-        if (nodeSet == null) {
-            return result;
-        }
-        result.add("        Node                                         Edge");
-        for (Node node : nodeSet) {
-            Set<Edge> edgeSet = nodeEdges.get(node);
-            if (edgeSet == null) {
-                continue;
-            }
-            for (Edge edge : edgeSet) {
-                result.add(node + "             " + edge);
-            }
-        }
-        return result;
-    }
-
-    // Only for unit test.
-    void startTest() {
-        pendingTimer = new Timer("Topology Pending Update Timer");
-        updateThread = new Thread(new UpdateTopology(), "Topology Update");
-        updateThread.start();
-    }
-
-    void stopTest() {
-        shuttingDown = true;
-        updateThread.interrupt();
-        pendingTimer.cancel();
-    }
-
-    boolean flushUpdateQueue(long timeout) {
-        long limit = System.currentTimeMillis() + timeout;
-        long cur;
-        do {
-            if (updateQ.peek() == null) {
-                return true;
-            }
-
-            try {
-                Thread.sleep(100);
-            } catch (InterruptedException e) {
-                break;
-            }
-            cur = System.currentTimeMillis();
-        } while (cur < limit);
-
-        return false;
-    }
-}
diff --git a/opendaylight/adsal/topologymanager/implementation/src/test/java/org/opendaylight/controller/topologymanager/internal/TopologyManagerImplTest.java b/opendaylight/adsal/topologymanager/implementation/src/test/java/org/opendaylight/controller/topologymanager/internal/TopologyManagerImplTest.java
deleted file mode 100644 (file)
index 2c57270..0000000
+++ /dev/null
@@ -1,885 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.topologymanager.internal;
-
-import java.net.InetAddress;
-import java.net.UnknownHostException;
-import java.util.ArrayList;
-import java.util.HashMap;
-import java.util.HashSet;
-import java.util.Iterator;
-import java.util.List;
-import java.util.Map;
-import java.util.Set;
-import java.util.concurrent.ConcurrentMap;
-import org.junit.After;
-import org.junit.Assert;
-import org.junit.Before;
-import org.junit.Test;
-import org.opendaylight.controller.sal.core.Bandwidth;
-import org.opendaylight.controller.sal.core.ConstructionException;
-import org.opendaylight.controller.sal.core.Description;
-import org.opendaylight.controller.sal.core.Edge;
-import org.opendaylight.controller.sal.core.Host;
-import org.opendaylight.controller.sal.core.Latency;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.Node.NodeIDType;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.NodeConnector.NodeConnectorIDType;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.core.State;
-import org.opendaylight.controller.sal.core.TimeStamp;
-import org.opendaylight.controller.sal.core.UpdateType;
-import org.opendaylight.controller.sal.packet.address.EthernetAddress;
-import org.opendaylight.controller.sal.topology.TopoEdgeUpdate;
-import org.opendaylight.controller.sal.utils.NodeConnectorCreator;
-import org.opendaylight.controller.sal.utils.NodeCreator;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.sal.utils.StatusCode;
-import org.opendaylight.controller.switchmanager.ISwitchManager;
-import org.opendaylight.controller.switchmanager.SpanConfig;
-import org.opendaylight.controller.switchmanager.Subnet;
-import org.opendaylight.controller.switchmanager.SubnetConfig;
-import org.opendaylight.controller.switchmanager.Switch;
-import org.opendaylight.controller.switchmanager.SwitchConfig;
-import org.opendaylight.controller.topologymanager.TopologyUserLinkConfig;
-
-public class TopologyManagerImplTest {
-    private TopologyManagerImpl topoManagerImpl;
-
-    /**
-     * Mockup of switch manager that only maintains existence of node
-     * connector.
-     */
-    private final class TestSwitchManager implements ISwitchManager {
-        private final Set<Node>  nodeSet = new HashSet<Node>();
-        private final Set<NodeConnector> nodeConnectorSet =
-                new HashSet<NodeConnector>();
-
-        private void addNodeConnectors(NodeConnector ... connectors) {
-            for (NodeConnector nc: connectors) {
-                if (nc != null) {
-                    nodeSet.add(nc.getNode());
-                    nodeConnectorSet.add(nc);
-                }
-            }
-        }
-
-        private void addNodeConnectors(TopologyUserLinkConfig ... links) {
-            for (TopologyUserLinkConfig link: links) {
-                NodeConnector src =
-                        NodeConnector.fromString(link.getSrcNodeConnector());
-                NodeConnector dst =
-                        NodeConnector.fromString(link.getDstNodeConnector());
-                addNodeConnectors(src, dst);
-            }
-        }
-
-        private void clear() {
-            nodeSet.clear();
-            nodeConnectorSet.clear();
-        }
-
-        @Override
-        public Status addSubnet(SubnetConfig configObject) {
-            return null;
-        }
-
-        @Override
-        public Status removeSubnet(SubnetConfig configObject) {
-            return null;
-        }
-
-        @Override
-        public Status modifySubnet(SubnetConfig configObject) {
-            return null;
-        }
-
-        @Override
-        public Status removeSubnet(String name) {
-            return null;
-        }
-
-        @Override
-        public List<Switch> getNetworkDevices() {
-            return null;
-        }
-
-        @Override
-        public List<SubnetConfig> getSubnetsConfigList() {
-            return null;
-        }
-
-        @Override
-        public SubnetConfig getSubnetConfig(String subnet) {
-            return null;
-        }
-
-        @Override
-        public Subnet getSubnetByNetworkAddress(InetAddress networkAddress) {
-            return null;
-        }
-
-        @Override
-        public Status saveSwitchConfig() {
-            return null;
-        }
-
-        @Override
-        public Status addSpanConfig(SpanConfig configObject) {
-            return null;
-        }
-
-        @Override
-        public Status removeSpanConfig(SpanConfig cfgObject) {
-            return null;
-        }
-
-        @Override
-        public List<SpanConfig> getSpanConfigList() {
-            return null;
-        }
-
-        @Override
-        public List<NodeConnector> getSpanPorts(Node node) {
-            return null;
-        }
-
-        @Override
-        public void updateSwitchConfig(SwitchConfig cfgObject) {
-        }
-
-        @Override
-        public Status updateNodeConfig(SwitchConfig switchConfig) {
-            return null;
-        }
-
-        @Override
-        public Status removeNodeConfig(String nodeId) {
-            return null;
-        }
-
-        @Override
-        public SwitchConfig getSwitchConfig(String nodeId) {
-            return null;
-        }
-
-        @Override
-        public Status addPortsToSubnet(String name, List<String> nodeConnectors) {
-            return null;
-        }
-
-        @Override
-        public Status removePortsFromSubnet(String name, List<String> nodeConnectors) {
-            return null;
-        }
-
-        @Override
-        public Set<Node> getNodes() {
-            return new HashSet<Node>(nodeSet);
-        }
-
-        @Override
-        public Map<String, Property> getNodeProps(Node node) {
-            return new HashMap<String, Property>();
-        }
-
-        @Override
-        public Property getNodeProp(Node node, String propName) {
-            return null;
-        }
-
-        @Override
-        public void setNodeProp(Node node, Property prop) {
-        }
-
-        @Override
-        public Status removeNodeProp(Node node, String propName) {
-            return null;
-        }
-
-        @Override
-        public Status removeNodeAllProps(Node node) {
-            return null;
-        }
-
-        @Override
-        public Set<NodeConnector> getUpNodeConnectors(Node node) {
-            return getNodeConnectors(node);
-        }
-
-        @Override
-        public Set<NodeConnector> getNodeConnectors(Node node) {
-            Set<NodeConnector> set = new HashSet<NodeConnector>();
-            for (NodeConnector nc: nodeConnectorSet) {
-                if (nc.getNode().equals(node)) {
-                    set.add(nc);
-                }
-            }
-
-            return set;
-        }
-
-        @Override
-        public Set<NodeConnector> getPhysicalNodeConnectors(Node node) {
-            return getNodeConnectors(node);
-        }
-
-        @Override
-        public Map<String, Property> getNodeConnectorProps(NodeConnector nodeConnector) {
-            return new HashMap<String, Property>();
-        }
-
-        @Override
-        public Property getNodeConnectorProp(NodeConnector nodeConnector, String propName) {
-            return null;
-        }
-
-        @Override
-        public Status addNodeConnectorProp(NodeConnector nodeConnector, Property prop) {
-            return null;
-        }
-
-        @Override
-        public Status removeNodeConnectorProp(NodeConnector nc, String propName) {
-            return null;
-        }
-
-        @Override
-        public Status removeNodeConnectorAllProps(NodeConnector nodeConnector) {
-            return null;
-        }
-
-        @Override
-        public NodeConnector getNodeConnector(Node node, String nodeConnectorName) {
-            return null;
-        }
-
-        @Override
-        public boolean isSpecial(NodeConnector p) {
-            String type = p.getType();
-            return (type.equals(NodeConnectorIDType.CONTROLLER)
-                    || type.equals(NodeConnectorIDType.ALL)
-                    || type.equals(NodeConnectorIDType.SWSTACK)
-                    || type.equals(NodeConnectorIDType.HWPATH));
-        }
-
-        @Override
-        public Boolean isNodeConnectorEnabled(NodeConnector nodeConnector) {
-            if (doesNodeConnectorExist(nodeConnector)) {
-                return Boolean.TRUE;
-            }
-            return Boolean.FALSE;
-        }
-
-        @Override
-        public boolean doesNodeConnectorExist(NodeConnector nc) {
-            return (nc != null && nodeConnectorSet.contains(nc));
-        }
-
-        @Override
-        public byte[] getControllerMAC() {
-            return new byte[6];
-        }
-
-        @Override
-        public byte[] getNodeMAC(Node node) {
-            return new byte[6];
-        }
-
-        @Override
-        public Property createProperty(String propName, String propValue) {
-            return null;
-        }
-
-        @Override
-        public String getNodeDescription(Node node) {
-            return null;
-        }
-
-        @Override
-        public Status removeControllerProperty(String propertyName){
-            return null;
-        }
-
-        @Override
-        public Set<Switch> getConfiguredNotConnectedSwitches() {
-            // TODO Auto-generated method stub
-            return null;
-        }
-
-        @Override
-        public Map<String, Property> getControllerProperties() {
-            // TODO Auto-generated method stub
-            return null;
-        }
-
-        @Override
-        public Property getControllerProperty(String propertyName) {
-            // TODO Auto-generated method stub
-            return null;
-        }
-
-        @Override
-        public Status setControllerProperty(Property property) {
-            // TODO Auto-generated method stub
-            return null;
-        }
-    }
-
-    @Before
-    public void setUp() {
-        topoManagerImpl = new TopologyManagerImpl();
-        topoManagerImpl.startTest();
-    }
-
-    @After
-    public void tearDown() {
-        if (topoManagerImpl != null) {
-            topoManagerImpl.stopTest();
-            topoManagerImpl = null;
-        }
-    }
-
-    /*
-     * Sets the node, edges and properties for edges here: Edge <SwitchId :
-     * NodeConnectorId> : <1:1>--><11:11>; <1:2>--><11:12>; <3:3>--><13:13>;
-     * <3:4>--><13:14>; <5:5>--><15:15>; <5:6>--><15:16>; Method used by two
-     * tests: testGetNodeEdges and testGetEdges
-     *
-     * @param topoManagerImpl
-     *
-     * @throws ConstructionException
-     */
-    public void setNodeEdges(TopologyManagerImpl topoManagerImpl, TestSwitchManager swMgr)
-            throws ConstructionException {
-        topoManagerImpl.nonClusterObjectCreate();
-
-        State state;
-        Bandwidth bw;
-        Latency l;
-
-        Set<Property> props = new HashSet<Property>();
-        state = new State(State.EDGE_UP);
-        bw = new Bandwidth(Bandwidth.BW100Gbps);
-        l = new Latency(Latency.LATENCY100ns);
-        props.add(state);
-        props.add(bw);
-        props.add(l);
-
-        for (short i = 1; i < 6; i = (short) (i + 2)) {
-            List<TopoEdgeUpdate> topoedgeupdateList = new ArrayList<TopoEdgeUpdate>();
-            NodeConnector headnc1 = NodeConnectorCreator.createOFNodeConnector(
-                    i, NodeCreator.createOFNode((long) i));
-            NodeConnector tailnc1 = NodeConnectorCreator
-                    .createOFNodeConnector((short) (i + 10),
-                            NodeCreator.createOFNode((long) (i + 10)));
-            swMgr.addNodeConnectors(tailnc1, headnc1);
-            Edge e1 = new Edge(tailnc1, headnc1);
-            TopoEdgeUpdate teu1 = new TopoEdgeUpdate(e1, props,
-                    UpdateType.ADDED);
-            topoedgeupdateList.add(teu1);
-
-            NodeConnector tailnc2 = NodeConnectorCreator.createOFNodeConnector(
-                    (short) (i + 1), headnc1.getNode());
-            NodeConnector headnc2 = NodeConnectorCreator.createOFNodeConnector(
-                    (short) (i + 11), tailnc1.getNode());
-            swMgr.addNodeConnectors(tailnc1, headnc2);
-            Edge e2 = new Edge(tailnc2, headnc2);
-            TopoEdgeUpdate teu2 = new TopoEdgeUpdate(e2, props,
-                    UpdateType.ADDED);
-            topoedgeupdateList.add(teu2);
-            topoManagerImpl.edgeUpdate(topoedgeupdateList);
-        }
-
-        Assert.assertTrue(topoManagerImpl.flushUpdateQueue(5000));
-    }
-
-    @Test
-    public void testGetNodeEdges() throws ConstructionException {
-        TestSwitchManager swMgr = new TestSwitchManager();
-        topoManagerImpl.setSwitchManager(swMgr);
-        setNodeEdges(topoManagerImpl, swMgr);
-
-        Map<Node, Set<Edge>> nodeEdgeMap = topoManagerImpl.getNodeEdges();
-        for (Iterator<Map.Entry<Node, Set<Edge>>> i = nodeEdgeMap.entrySet()
-                .iterator(); i.hasNext();) {
-            Map.Entry<Node, Set<Edge>> entry = i.next();
-            Node node = entry.getKey();
-            Long nodeId = ((Long) node.getID()).longValue();
-            Assert.assertTrue((node.getType().equals(NodeIDType.OPENFLOW)));
-
-            Set<Edge> edges = entry.getValue();
-            for (Edge edge : edges) {
-                Long headNcId = ((Short) edge.getHeadNodeConnector().getID())
-                        .longValue();
-                Long tailNcId = ((Short) edge.getTailNodeConnector().getID())
-                        .longValue();
-                Assert.assertTrue(
-                        (headNcId.equals(nodeId) && tailNcId.equals(nodeId + 10))
-                        || (headNcId.equals(nodeId + 11) && tailNcId.equals(nodeId + 1))
-                        || (headNcId.equals(nodeId + 1) && tailNcId.equals(nodeId - 9))
-                        || (headNcId.equals(nodeId - 10) && tailNcId.equals(nodeId))
-                        );
-            }
-            i.remove();
-        }
-        Assert.assertTrue(nodeEdgeMap.isEmpty());
-    }
-
-    @Test
-    public void testGetEdges() throws ConstructionException {
-        TestSwitchManager swMgr = new TestSwitchManager();
-        topoManagerImpl.setSwitchManager(swMgr);
-        setNodeEdges(topoManagerImpl, swMgr);
-
-        Map<Edge, Set<Property>> edgeProperty = topoManagerImpl.getEdges();
-
-        for (Iterator<Map.Entry<Edge, Set<Property>>> i = edgeProperty
-                .entrySet().iterator(); i.hasNext();) {
-            Map.Entry<Edge, Set<Property>> entry = i.next();
-            Edge e = entry.getKey();
-            NodeConnector headnc = e.getHeadNodeConnector();
-            NodeConnector tailnc = e.getTailNodeConnector();
-
-            Long headNodeId = (Long) headnc.getNode().getID();
-
-            Long headNcId = ((Short) headnc.getID()).longValue();
-            Long tailNcId = ((Short) tailnc.getID()).longValue();
-
-            if (headNodeId == 1 || headNodeId == 3 || headNodeId == 5) {
-                Assert.assertTrue((headNcId.equals(headNodeId) && tailNcId
-                        .equals(headNodeId + 10))
-                        || (headNcId.equals(headNodeId + 10) && tailNcId
-                                .equals(headNodeId))
-                                || (headNcId.equals(headNodeId + 1) && tailNcId
-                                        .equals(headNodeId + 11))
-                                        || (headNcId.equals(headNodeId + 11) && tailNcId
-                                                .equals(headNodeId + 1)));
-            } else if (headNodeId == 11 || headNodeId == 13 || headNodeId == 15) {
-                Assert.assertTrue((headNcId.equals(headNodeId) && tailNcId
-                        .equals(headNodeId - 10))
-                        || (headNcId.equals(headNodeId) && tailNcId
-                                .equals(headNodeId - 10))
-                                || (headNcId.equals(headNodeId - 9) && tailNcId
-                                        .equals(headNodeId + 1))
-                                        || (headNcId.equals(headNodeId + 1) && tailNcId
-                                                .equals(headNodeId - 9)));
-            }
-
-            Set<Property> prop = entry.getValue();
-            for (Property p : prop) {
-                String pName;
-                long pValue;
-                if (p instanceof Bandwidth) {
-                    Bandwidth b = (Bandwidth) p;
-                    pName = Bandwidth.BandwidthPropName;
-                    pValue = b.getValue();
-                    Assert.assertTrue(pName.equals(p.getName())
-                            && pValue == Bandwidth.BW100Gbps);
-                    continue;
-                }
-                if (p instanceof Latency) {
-                    Latency l = (Latency) p;
-                    pName = Latency.LatencyPropName;
-                    pValue = l.getValue();
-                    Assert.assertTrue(pName.equals(p.getName())
-                            && pValue == Latency.LATENCY100ns);
-                    continue;
-                }
-                if (p instanceof State) {
-                    State state = (State) p;
-                    pName = State.StatePropName;
-                    pValue = state.getValue();
-                    Assert.assertTrue(pName.equals(p.getName())
-                            && pValue == State.EDGE_UP);
-                    continue;
-                }
-            }
-            i.remove();
-        }
-        Assert.assertTrue(edgeProperty.isEmpty());
-    }
-
-    @Test
-    public void testAddDeleteUserLink() {
-        TopologyUserLinkConfig link1 = new TopologyUserLinkConfig("default1",
-                "OF|1@OF|2", "OF|1@OF|3");
-        TopologyUserLinkConfig link2 = new TopologyUserLinkConfig("default1",
-                "OF|10@OF|20", "OF|10@OF|30");
-        TopologyUserLinkConfig link3 = new TopologyUserLinkConfig("default2",
-                "OF|1@OF|2", "OF|1@OF|3");
-        TopologyUserLinkConfig link4 = new TopologyUserLinkConfig("default20",
-                "OF|10@OF|20", "OF|10@OF|30");
-
-        TestSwitchManager swMgr = new TestSwitchManager();
-        topoManagerImpl.setSwitchManager(swMgr);
-        topoManagerImpl.nonClusterObjectCreate();
-
-        swMgr.addNodeConnectors(link1, link2, link3, link4);
-
-        Assert.assertTrue(topoManagerImpl.addUserLink(link1).isSuccess());
-        Assert.assertTrue(topoManagerImpl.addUserLink(link2).getCode() == StatusCode.CONFLICT);
-        Assert.assertTrue(topoManagerImpl.addUserLink(link3).getCode() == StatusCode.CONFLICT);
-        Assert.assertTrue(topoManagerImpl.addUserLink(link4).isSuccess());
-
-        Assert.assertTrue(topoManagerImpl.deleteUserLink(null).getCode() == StatusCode.BADREQUEST);
-        Assert.assertTrue(topoManagerImpl.deleteUserLink(link1.getName())
-                .isSuccess());
-        Assert.assertTrue(topoManagerImpl.deleteUserLink(link4.getName())
-                .isSuccess());
-        Assert.assertTrue(topoManagerImpl.getUserLinks().isEmpty());
-
-        TopologyUserLinkConfig badlink1 =
-                new TopologyUserLinkConfig("bad1", "OF|1@OF|4", "OF|1@OF|5");
-        TopologyUserLinkConfig badlink2 =
-                new TopologyUserLinkConfig("bad2", "OF|10@OF|7", "OF|7@OF|13");
-        Assert.assertEquals(StatusCode.NOTFOUND,
-                topoManagerImpl.addUserLink(badlink1).getCode());
-        Assert.assertEquals(StatusCode.NOTFOUND,
-                topoManagerImpl.addUserLink(badlink2).getCode());
-    }
-
-    @Test
-    public void testGetUserLink() {
-        TopologyUserLinkConfig[] link = new TopologyUserLinkConfig[5];
-        TopologyUserLinkConfig[] reverseLink = new TopologyUserLinkConfig[5];
-        TestSwitchManager swMgr = new TestSwitchManager();
-        topoManagerImpl.setSwitchManager(swMgr);
-        topoManagerImpl.nonClusterObjectCreate();
-
-        String name = "Test";
-        String srcSwitchId = null;
-        String srcNodeConnectorIDType = null;
-        String srcPort = null;
-        String srcNodeIDType = null;
-        String dstNodeIDType = null;
-        String dstSwitchId = null;
-        String dstNodeConnectorIDType = null;
-        String dstPort = null;
-        String srcNodeConnector = null;
-        String dstNodeConnector = null;
-
-        /* Creating userlinks and checking for their validity */
-        link[0] = new TopologyUserLinkConfig(name, srcNodeConnector, dstNodeConnector);
-        Assert.assertTrue(link[0].isValid() == false);
-
-        srcNodeConnector = "OF|1@OF|1";
-        link[0] = new TopologyUserLinkConfig(name, srcNodeConnector, dstNodeConnector);
-        Assert.assertTrue(link[0].isValid() == false);
-
-        dstNodeConnector = "OF|1@OF|2";
-        link[0] = new TopologyUserLinkConfig(name, srcNodeConnector, dstNodeConnector);
-        Assert.assertTrue(link[0].isValid() == true);
-
-        Integer i;
-
-        for (i = 0; i < 5; i++) {
-            link[i] = new TopologyUserLinkConfig();
-
-            name = Integer.toString(i + 1);
-            srcSwitchId = Integer.toString(i + 1);
-            srcPort = Integer.toString(i + 1);
-            dstSwitchId = Integer.toString((i + 1) * 10);
-            dstPort = Integer.toString((i + 1) * 10);
-
-            link[i].setName(name);
-            srcNodeConnectorIDType = dstNodeConnectorIDType = "INCORRECT";
-            srcNodeConnector = srcNodeConnectorIDType+"|"+srcSwitchId+"@"+srcNodeConnectorIDType+"|"+srcPort;
-            dstNodeConnector = dstNodeConnectorIDType+"|"+dstSwitchId+"@"+dstNodeConnectorIDType+"|"+dstPort;
-
-            link[i].setSrcNodeConnector(srcNodeConnector);
-            Assert.assertTrue(link[i].isValid() == false);
-
-            srcNodeConnectorIDType = "OF";
-            srcNodeConnector = srcNodeConnectorIDType+"|"+srcSwitchId+"@"+srcNodeConnectorIDType+"|"+srcPort;
-            link[i].setSrcNodeConnector(srcNodeConnector);
-            Assert.assertTrue(link[i].isValid() == false);
-
-            dstNodeConnectorIDType = "OF";
-            dstNodeConnector = dstNodeConnectorIDType+"|"+dstSwitchId+"@"+dstNodeConnectorIDType+"|"+dstPort;
-            link[i].setDstNodeConnector(dstNodeConnector);
-            Assert.assertTrue(link[i].isValid() == true);
-
-            reverseLink[i] = new TopologyUserLinkConfig(name, dstNodeConnector, srcNodeConnector);
-
-            Assert.assertEquals(StatusCode.NOTFOUND,
-                    topoManagerImpl.addUserLink(link[i]).getCode());
-            swMgr.addNodeConnectors(link[i]);
-            Assert.assertTrue(topoManagerImpl.addUserLink(link[i]).isSuccess());
-        }
-
-        ConcurrentMap<String, TopologyUserLinkConfig> userLinks = topoManagerImpl
-                .getUserLinks();
-        TopologyUserLinkConfig resultLink;
-
-        for (i = 0; i < 5; i++) {
-            resultLink = userLinks.get(((Integer) (i + 1)).toString());
-
-            Assert.assertTrue(resultLink.getName().equals(
-                    reverseLink[i].getName()));
-            Assert.assertTrue(resultLink.getDstNodeConnector().equals(
-                    reverseLink[i].getSrcNodeConnector()));
-            Assert.assertTrue(resultLink.getSrcNodeConnector().equals(
-                    reverseLink[i].getDstNodeConnector()));
-        }
-    }
-
-    @Test
-    public void testHostLinkMethods() throws ConstructionException,
-    UnknownHostException {
-        TestSwitchManager swMgr = new TestSwitchManager();
-        topoManagerImpl.setSwitchManager(swMgr);
-        topoManagerImpl.nonClusterObjectCreate();
-        int hostCounter = 0;
-
-        State state;
-        Bandwidth bw;
-        Latency l;
-        Set<Property> props = new HashSet<Property>();
-        state = new State(State.EDGE_UP);
-        bw = new Bandwidth(Bandwidth.BW100Gbps);
-        l = new Latency(Latency.LATENCY100ns);
-        props.add(state);
-        props.add(bw);
-        props.add(l);
-
-        EthernetAddress ea;
-        InetAddress ip;
-        Host[] h = new Host[5];
-        NodeConnector[] nc = new NodeConnector[5];
-
-        /*
-         * Adding host, nodeConnector to hostsDB for the i = 0,1,2,3. No host
-         * added for i = 4
-         */
-        for (int i = 0; i < 5; i++) {
-            if (hostCounter < 4) {
-                ea = new EthernetAddress(new byte[] { (byte) 0x0, (byte) 0x0,
-                        (byte) 0x0, (byte) 0x0, (byte) 0x0, (byte) i });
-                String stringIP = new StringBuilder().append(i + 1).append(".")
-                        .append(i + 10).append(".").append(i + 20).append(".")
-                        .append(i + 30).toString();
-                ip = InetAddress.getByName(stringIP);
-                h[hostCounter] = new Host(ea, ip);
-            } else {
-                h[hostCounter] = null;
-            }
-            hostCounter++;
-            nc[i] = NodeConnectorCreator.createOFNodeConnector((short) (i + 1),
-                    NodeCreator.createOFNode((long) (i + 1)));
-            topoManagerImpl
-            .updateHostLink(nc[i], h[i], UpdateType.ADDED, props);
-        }
-
-        for (int i = 0; i < 5; i++) {
-            Host host = topoManagerImpl.getHostAttachedToNodeConnector(nc[i]);
-            if (i == 4) {
-                Assert.assertTrue(host == null);
-            } else {
-                Assert.assertTrue(host.equals(h[i]));
-            }
-        }
-
-        Set<NodeConnector> ncSet = topoManagerImpl.getNodeConnectorWithHost();
-        for (int i = 0; i < 5; i++) {
-            Assert.assertTrue(ncSet.remove(nc[i]));
-        }
-        Assert.assertTrue(ncSet.isEmpty());
-    }
-
-    @Test
-    public void testGetNodesWithNodeConnectorHost()
-            throws ConstructionException, UnknownHostException {
-        TestSwitchManager swMgr = new TestSwitchManager();
-        topoManagerImpl.setSwitchManager(swMgr);
-        topoManagerImpl.nonClusterObjectCreate();
-        int hostCounter = 0;
-
-        State state;
-        Bandwidth bw;
-        Latency l;
-        Set<Property> props = new HashSet<Property>();
-        state = new State(State.EDGE_UP);
-        bw = new Bandwidth(Bandwidth.BW100Gbps);
-        l = new Latency(Latency.LATENCY100ns);
-        props.add(state);
-        props.add(bw);
-        props.add(l);
-
-        EthernetAddress ea;
-        InetAddress ip;
-        Host[] h = new Host[5];
-        NodeConnector[] nc = new NodeConnector[5];
-
-        /*
-         * Adding host, nodeconnector, properties of edge to hostsDB for the
-         * first three nodes only
-         */
-        for (int i = 1; i < 6; i++) {
-            if (i < 4) {
-                ea = new EthernetAddress(new byte[] { (byte) 0x0, (byte) 0x0,
-                        (byte) 0x0, (byte) 0x0, (byte) 0x0, (byte) i });
-                String stringIP = new StringBuilder().append(i).append(".")
-                        .append(i + 10).append(".").append(i + 20).append(".")
-                        .append(i + 30).toString();
-                ip = InetAddress.getByName(stringIP);
-                h[hostCounter] = new Host(ea, ip);
-            } else {
-                h[hostCounter] = null;
-            }
-            hostCounter++;
-            nc[i - 1] = NodeConnectorCreator.createOFNodeConnector((short) i,
-                    NodeCreator.createOFNode((long) i));
-            topoManagerImpl.updateHostLink(nc[i - 1], h[i - 1],
-                    UpdateType.ADDED, props);
-        }
-
-        /* Get the nodes which have host connected to its nodeConnector */
-        Map<Node, Set<NodeConnector>> nodeNCmap = topoManagerImpl
-                .getNodesWithNodeConnectorHost();
-        for (int i = 1; i < 6; i++) {
-            Node node = nc[i - 1].getNode();
-            Set<NodeConnector> ncSet = nodeNCmap.get(nc[i - 1].getNode());
-
-            Assert.assertTrue(ncSet == nodeNCmap.remove(node));
-        }
-
-        Assert.assertTrue(nodeNCmap.isEmpty());
-    }
-
-    @Test
-    public void bug1348FixTest() throws ConstructionException,
-           InterruptedException {
-        TestSwitchManager swMgr = new TestSwitchManager();
-        topoManagerImpl.setSwitchManager(swMgr);
-        topoManagerImpl.nonClusterObjectCreate();
-
-        NodeConnector headnc1 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 1, NodeCreator.createOFNode(1000L));
-        NodeConnector tailnc1 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 2, NodeCreator.createOFNode(2000L));
-        Edge edge = new Edge(headnc1, tailnc1);
-        List<TopoEdgeUpdate> updatedEdges = new ArrayList<>();
-        Set<Property> edgeProps = new HashSet<>();
-        edgeProps.add(new TimeStamp(System.currentTimeMillis(), "creation"));
-        edgeProps.add(new Latency(Latency.LATENCY100ns));
-        edgeProps.add(new State(State.EDGE_UP));
-        edgeProps.add(new Bandwidth(Bandwidth.BW100Gbps));
-        edgeProps.add(new Description("Test edge"));
-        updatedEdges.add(new TopoEdgeUpdate(edge, edgeProps, UpdateType.CHANGED));
-
-        try {
-            topoManagerImpl.edgeUpdate(updatedEdges);
-        } catch (Exception e) {
-            Assert.fail("Exception was raised when trying to update edge properties: " + e.getMessage());
-        }
-
-        Assert.assertTrue(topoManagerImpl.flushUpdateQueue(5000));
-        verifyEdgesSize(1);
-        Assert.assertNotNull(topoManagerImpl.getEdges().get(edge));
-    }
-
-    private void verifyEdgesSize(int expSize) throws InterruptedException {
-        int timeout = 5000;
-        for(int i = 0; i < timeout / 50; i++) {
-            if(topoManagerImpl.getEdges().size() == expSize) {
-                return;
-            }
-
-            Thread.sleep(50);
-        }
-
-        Assert.fail(String.format("Expected edges size %d. Actual was %d",
-                topoManagerImpl.getEdges().size(), expSize));
-    }
-
-    @Test
-    public void testNotifyNodeConnector() throws Exception {
-        TestSwitchManager swMgr = new TestSwitchManager();
-        topoManagerImpl.setSwitchManager(swMgr);
-        topoManagerImpl.nonClusterObjectCreate();
-
-        // Test NodeConnector notification in the case that there are no
-        // related edge updates.
-        NodeConnector nc1 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 1, NodeCreator.createOFNode(1000L));
-        Map<String, Property> propMap = new HashMap<>();
-        swMgr.addNodeConnectors(nc1);
-        topoManagerImpl.notifyNodeConnector(nc1, UpdateType.ADDED, propMap);
-        verifyEdgesSize(0);
-
-        topoManagerImpl.notifyNodeConnector(nc1, UpdateType.CHANGED, propMap);
-        verifyEdgesSize(0);
-
-        swMgr.clear();
-        topoManagerImpl.notifyNodeConnector(nc1, UpdateType.REMOVED, propMap);
-        verifyEdgesSize(0);
-
-        // Test NodeConnector notification in the case that there is a related
-        // edge update just before the notification.
-        NodeConnector nc2 = NodeConnectorCreator.createOFNodeConnector(
-                (short) 2, NodeCreator.createOFNode(2000L));
-        Edge edge1 = new Edge(nc1, nc2);
-        Edge edge2 = new Edge(nc2, nc1);
-        Set<Property> props = new HashSet<Property>();
-        TopoEdgeUpdate teu1 = new TopoEdgeUpdate(edge1, props, UpdateType.ADDED);
-        TopoEdgeUpdate teu2 = new TopoEdgeUpdate(edge2, props, UpdateType.ADDED);
-        List<TopoEdgeUpdate> topoedgeupdateList = new ArrayList<TopoEdgeUpdate>();
-        topoedgeupdateList.add(teu1);
-        topoedgeupdateList.add(teu2);
-        topoManagerImpl.edgeUpdate(topoedgeupdateList);
-        swMgr.addNodeConnectors(nc1);
-        topoManagerImpl.notifyNodeConnector(nc1, UpdateType.ADDED, propMap);
-        swMgr.addNodeConnectors(nc2);
-        topoManagerImpl.notifyNodeConnector(nc2, UpdateType.CHANGED, propMap);
-        Assert.assertTrue(topoManagerImpl.flushUpdateQueue(5000));
-        verifyEdgesSize(2);
-
-        teu1 = new TopoEdgeUpdate(edge1, props, UpdateType.REMOVED);
-        teu2 = new TopoEdgeUpdate(edge2, props, UpdateType.REMOVED);
-        topoedgeupdateList = new ArrayList<TopoEdgeUpdate>();
-        topoedgeupdateList.add(teu1);
-        topoedgeupdateList.add(teu2);
-        topoManagerImpl.edgeUpdate(topoedgeupdateList);
-        Assert.assertTrue(topoManagerImpl.flushUpdateQueue(5000));
-        verifyEdgesSize(0);
-        topoManagerImpl.notifyNodeConnector(nc1, UpdateType.REMOVED, propMap);
-        topoManagerImpl.notifyNodeConnector(nc2, UpdateType.REMOVED, propMap);
-
-        swMgr.clear();
-
-        // Test NodeConnector notification in the case that there are multiple
-        // edge updates related to the NodeConnector just before the notification.
-        teu1 = new TopoEdgeUpdate(edge1, props, UpdateType.ADDED);
-        teu2 = new TopoEdgeUpdate(edge2, props, UpdateType.ADDED);
-        TopoEdgeUpdate teu3 = new TopoEdgeUpdate(edge1, props, UpdateType.CHANGED);
-        TopoEdgeUpdate teu4 = new TopoEdgeUpdate(edge2, props, UpdateType.CHANGED);
-        TopoEdgeUpdate teu5 = new TopoEdgeUpdate(edge1, props, UpdateType.REMOVED);
-        TopoEdgeUpdate teu6 = new TopoEdgeUpdate(edge2, props, UpdateType.REMOVED);
-        topoedgeupdateList = new ArrayList<TopoEdgeUpdate>();
-        topoedgeupdateList.add(teu1);
-        topoedgeupdateList.add(teu2);
-        topoedgeupdateList.add(teu3);
-        topoedgeupdateList.add(teu4);
-        topoedgeupdateList.add(teu5);
-        topoedgeupdateList.add(teu6);
-        topoManagerImpl.edgeUpdate(topoedgeupdateList);
-        swMgr.addNodeConnectors(nc1);
-        topoManagerImpl.notifyNodeConnector(nc1, UpdateType.ADDED, propMap);
-        swMgr.addNodeConnectors(nc2);
-        topoManagerImpl.notifyNodeConnector(nc2, UpdateType.CHANGED, propMap);
-        Assert.assertTrue(topoManagerImpl.flushUpdateQueue(5000));
-        verifyEdgesSize(0);
-        topoManagerImpl.notifyNodeConnector(nc1, UpdateType.REMOVED, propMap);
-        topoManagerImpl.notifyNodeConnector(nc2, UpdateType.REMOVED, propMap);
-        Assert.assertTrue(topoManagerImpl.flushUpdateQueue(5000));
-        verifyEdgesSize(0);
-    }
-}
diff --git a/opendaylight/adsal/topologymanager/integrationtest/pom.xml b/opendaylight/adsal/topologymanager/integrationtest/pom.xml
deleted file mode 100644 (file)
index 20fdc0b..0000000
+++ /dev/null
@@ -1,123 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.integrationtest</artifactId>
-    <version>0.7.0-SNAPSHOT</version>
-    <relativePath>../../commons/integrationtest</relativePath>
-  </parent>
-
-  <artifactId>topologymanager.integrationtest</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <properties>
-    <sonar.jacoco.itReportPath>../../implementaiton/target/jacoco-it.exec</sonar.jacoco.itReportPath>
-    <!-- Sonar jacoco plugin to get integration test coverage info -->
-    <sonar.jacoco.reportPath>../../implementation/target/jacoco.exec</sonar.jacoco.reportPath>
-  </properties>
-  <dependencies>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>clustering.services</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>clustering.stub</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>configuration</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>configuration.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>containermanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>containermanager.it.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>forwardingrulesmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>hosttracker</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>protocol_plugins.stub</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>statisticsmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>statisticsmanager.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>switchmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>switchmanager.implementation</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>topologymanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.ops4j.pax.exam</groupId>
-      <artifactId>pax-exam-container-native</artifactId>
-      <scope>test</scope>
-    </dependency>
-  </dependencies>
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.jacoco</groupId>
-        <artifactId>jacoco-maven-plugin</artifactId>
-        <configuration>
-          <destFile>../../implementation/target/jacoco-it.exec</destFile>
-          <includes>
-            <include>org.opendaylight.controller.*</include>
-          </includes>
-        </configuration>
-        <executions>
-          <execution>
-            <id>pre-test</id>
-            <goals>
-              <goal>prepare-agent</goal>
-            </goals>
-          </execution>
-          <execution>
-            <id>post-test</id>
-            <configuration>
-              <skip>true</skip>
-            </configuration>
-          </execution>
-        </executions>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/topologymanager/integrationtest/src/test/java/org/opendaylight/controller/topologymanager/TopologyManagerIT.java b/opendaylight/adsal/topologymanager/integrationtest/src/test/java/org/opendaylight/controller/topologymanager/TopologyManagerIT.java
deleted file mode 100644 (file)
index c2fc8aa..0000000
+++ /dev/null
@@ -1,178 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.topologymanager;
-
-import org.junit.Test;
-import org.junit.runner.RunWith;
-import org.opendaylight.controller.protocol_plugins.stub.internal.TopologyServices;
-import org.opendaylight.controller.sal.core.Edge;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.core.UpdateType;
-import org.opendaylight.controller.sal.topology.IPluginInTopologyService;
-import org.ops4j.pax.exam.Option;
-import org.ops4j.pax.exam.Configuration;
-import org.ops4j.pax.exam.junit.PaxExam;
-import org.ops4j.pax.exam.util.PathUtils;
-import org.osgi.framework.Bundle;
-import org.osgi.framework.BundleContext;
-import org.osgi.framework.ServiceReference;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import javax.inject.Inject;
-import java.util.HashSet;
-import java.util.Set;
-
-import static org.ops4j.pax.exam.CoreOptions.junitBundles;
-import static org.ops4j.pax.exam.CoreOptions.mavenBundle;
-import static org.ops4j.pax.exam.CoreOptions.options;
-import static org.ops4j.pax.exam.CoreOptions.systemPackages;
-import static org.ops4j.pax.exam.CoreOptions.systemProperty;
-
-
-@RunWith(PaxExam.class)
-public class TopologyManagerIT {
-    private Logger log = LoggerFactory
-            .getLogger(TopologyManagerIT.class);
-    // get the OSGI bundle context
-    @Inject
-    private BundleContext bc;
-    @Inject
-    private ITopologyManager manager = null;
-
-    // Configure the OSGi container
-    @Configuration
-    public Option[] config() {
-        return options(
-                //
-                systemProperty("logback.configurationFile").value(
-                        "file:" + PathUtils.getBaseDir()
-                                + "/src/test/resources/logback.xml"),
-                // To start OSGi console for inspection remotely
-                systemProperty("osgi.console").value("2401"),
-                // Set the systemPackages (used by clustering)
-                systemPackages("sun.reflect", "sun.reflect.misc", "sun.misc"),
-                // List framework bundles
-                mavenBundle("equinoxSDK381", "org.eclipse.equinox.console").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "org.eclipse.equinox.util").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "org.eclipse.osgi.services").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "org.eclipse.equinox.ds").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "org.apache.felix.gogo.command").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "org.apache.felix.gogo.runtime").versionAsInProject(),
-                mavenBundle("equinoxSDK381", "org.apache.felix.gogo.shell").versionAsInProject(),
-                // List logger bundles
-                mavenBundle("org.slf4j", "slf4j-api").versionAsInProject(),
-                mavenBundle("org.slf4j", "log4j-over-slf4j")
-                        .versionAsInProject(),
-                mavenBundle("ch.qos.logback", "logback-core")
-                        .versionAsInProject(),
-                mavenBundle("ch.qos.logback", "logback-classic")
-                        .versionAsInProject(),
-                // needed by statisticsmanager
-                mavenBundle("org.opendaylight.controller", "containermanager")
-                    .versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "containermanager.it.implementation")
-                    .versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "clustering.services")
-                    .versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "clustering.stub")
-                    .versionAsInProject(),
-                // needed by forwardingrulesmanager
-                mavenBundle("org.opendaylight.controller", "configuration")
-                    .versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "configuration.implementation")
-                    .versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "hosttracker")
-                    .versionAsInProject(),
-
-                // List all the bundles on which the test case depends
-                mavenBundle("org.opendaylight.controller", "sal")
-                    .versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "sal.implementation")
-                    .versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "protocol_plugins.stub")
-                    .versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "switchmanager")
-                    .versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "switchmanager.implementation")
-                    .versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "statisticsmanager")
-                    .versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "statisticsmanager.implementation")
-                    .versionAsInProject(),
-                mavenBundle("org.opendaylight.controller", "forwardingrulesmanager")
-                    .versionAsInProject(),
-
-                // needed by hosttracker
-                mavenBundle("org.opendaylight.controller", "topologymanager")
-                        .versionAsInProject(),
-                mavenBundle("org.jboss.spec.javax.transaction",
-                        "jboss-transaction-api_1.1_spec").versionAsInProject(),
-                mavenBundle("org.apache.commons", "commons-lang3")
-                        .versionAsInProject(),
-                mavenBundle("org.apache.felix",
-                        "org.apache.felix.dependencymanager")
-                        .versionAsInProject(), junitBundles());
-    }
-
-    private String stateToString(int state) {
-        switch (state) {
-        case Bundle.ACTIVE:
-            return "ACTIVE";
-        case Bundle.INSTALLED:
-            return "INSTALLED";
-        case Bundle.RESOLVED:
-            return "RESOLVED";
-        case Bundle.UNINSTALLED:
-            return "UNINSTALLED";
-        default:
-            return "Not CONVERTED";
-        }
-    }
-
-    /**
-     *  This test verifies that the isInternal method of the TopologyManager returns true when a node is internal and
-     *  not otherwise
-     *
-     *  To make a node interval we add a node using the plugin interface (TopologyServices.addEdge) this is to ensure
-     *  that when TopologyManager sees the edge is via it's dependency on the SAL ITopologyService.
-     *
-     * @throws Exception
-     */
-    @Test
-    public void testIsInternal() throws Exception{
-        Node node1 = new Node("STUB", 0xCAFE);
-        Node node2 = new Node("STUB", 0XFACE);
-
-        NodeConnector head = new NodeConnector("STUB", node1.getID(), node1);
-        NodeConnector tail = new NodeConnector("STUB", node2.getID(), node2);
-
-        assert(this.manager.isInternal(head));
-
-        Set<Property> properties = new HashSet<Property>();
-
-        ServiceReference<?> r = bc.getServiceReference(IPluginInTopologyService.class
-                .getName());
-        TopologyServices topologyServices = null;
-        if (r != null) {
-            if(bc.getService(r) instanceof TopologyServices) {
-                topologyServices = (TopologyServices) bc.getService(r);
-            } else {
-                throw new RuntimeException("topology service registered is not from the stub plugin implementation");
-            }
-        }
-
-        topologyServices.addEdge(new Edge(tail, head), properties, UpdateType.ADDED);
-
-        assert(this.manager.isInternal(head));
-    }
-
-}
diff --git a/opendaylight/adsal/topologymanager/integrationtest/src/test/resources/logback.xml b/opendaylight/adsal/topologymanager/integrationtest/src/test/resources/logback.xml
deleted file mode 100644 (file)
index 2d63ce5..0000000
+++ /dev/null
@@ -1,13 +0,0 @@
-<configuration scan="true">
-
-  <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
-    <encoder>
-      <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n
-      </pattern>
-    </encoder>
-  </appender>
-
-  <root level="error">
-    <appender-ref ref="STDOUT" />
-  </root>
-</configuration>
diff --git a/opendaylight/adsal/topologymanager/shell/pom.xml b/opendaylight/adsal/topologymanager/shell/pom.xml
deleted file mode 100644 (file)
index bc9d630..0000000
+++ /dev/null
@@ -1,50 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-  <artifactId>topologymanager.shell</artifactId>
-  <version>${topologymanager.shell.version}</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.apache.karaf.shell</groupId>
-      <artifactId>org.apache.karaf.shell.console</artifactId>
-      <version>${karaf.shell.version}</version>
-    </dependency>
-    <dependency>
-      <groupId>org.mockito</groupId>
-      <artifactId>mockito-all</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>topologymanager</artifactId>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <configuration>
-          <instructions>
-            <Import-Package>org.apache.felix.service.command,
-              org.apache.karaf.shell.commands,
-              org.apache.karaf.shell.console,
-              *</Import-Package>
-          </instructions>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-
-</project>
diff --git a/opendaylight/adsal/topologymanager/shell/src/main/java/org/opendaylight/controller/topologymanager/shell/AddUserLink.java b/opendaylight/adsal/topologymanager/shell/src/main/java/org/opendaylight/controller/topologymanager/shell/AddUserLink.java
deleted file mode 100644 (file)
index 92467c9..0000000
+++ /dev/null
@@ -1,39 +0,0 @@
-/**
-* Copyright (c) 2014 Inocybe Technologies, and others. All rights reserved.
-*
-* This program and the accompanying materials are made available under the
-* terms of the Eclipse Public License v1.0 which accompanies this distribution,
-* and is available at http://www.eclipse.org/legal/epl-v10.html
-*/
-package org.opendaylight.controller.topologymanager.shell;
-
-import org.apache.karaf.shell.commands.Command;
-import org.apache.karaf.shell.commands.Argument;
-import org.apache.karaf.shell.console.OsgiCommandSupport;
-import org.opendaylight.controller.topologymanager.ITopologyManagerShell;
-
-@Command(scope = "topologymanager", name = "addUserLink", description="Adds user link")
-public class AddUserLink extends OsgiCommandSupport{
-    private ITopologyManagerShell topologyManager;
-
-    @Argument(index=0, name="name", description="name", required=true, multiValued=false)
-    String name = null;
-
-    @Argument(index=1, name="ncStr1", description="ncStr1", required=true, multiValued=false)
-    String ncStr1 = null;
-
-    @Argument(index=2, name="ncStr2", description="ncStr2", required=true, multiValued=false)
-    String ncStr2 = null;
-
-    @Override
-    protected Object doExecute() throws Exception {
-        for(String p : topologyManager.addUserLink(name, ncStr1, ncStr2)) {
-            System.out.println(p);
-        }
-        return null;
-    }
-
-    public void setTopologyManager(ITopologyManagerShell topologyManager){
-        this.topologyManager = topologyManager;
-    }
-}
diff --git a/opendaylight/adsal/topologymanager/shell/src/main/java/org/opendaylight/controller/topologymanager/shell/DeleteUserLink.java b/opendaylight/adsal/topologymanager/shell/src/main/java/org/opendaylight/controller/topologymanager/shell/DeleteUserLink.java
deleted file mode 100644 (file)
index 2c3e93c..0000000
+++ /dev/null
@@ -1,33 +0,0 @@
-/**
-* Copyright (c) 2014 Inocybe Technologies, and others. All rights reserved.
-*
-* This program and the accompanying materials are made available under the
-* terms of the Eclipse Public License v1.0 which accompanies this distribution,
-* and is available at http://www.eclipse.org/legal/epl-v10.html
-*/
-package org.opendaylight.controller.topologymanager.shell;
-
-import org.apache.karaf.shell.commands.Command;
-import org.apache.karaf.shell.commands.Argument;
-import org.apache.karaf.shell.console.OsgiCommandSupport;
-import org.opendaylight.controller.topologymanager.ITopologyManagerShell;
-
-@Command(scope = "topologymanager", name = "deleteUserLink", description="deletes user link")
-public class DeleteUserLink extends OsgiCommandSupport{
-    private ITopologyManagerShell topologyManager;
-
-    @Argument(index=0, name="name", description="name", required=true, multiValued=false)
-    String name = null;
-
-    @Override
-    protected Object doExecute() throws Exception {
-        for(String p : topologyManager.deleteUserLinkShell(name)) {
-            System.out.println(p);
-        }
-        return null;
-    }
-
-    public void setTopologyManager(ITopologyManagerShell topologyManager){
-        this.topologyManager = topologyManager;
-    }
-}
diff --git a/opendaylight/adsal/topologymanager/shell/src/main/java/org/opendaylight/controller/topologymanager/shell/PrintNodeEdges.java b/opendaylight/adsal/topologymanager/shell/src/main/java/org/opendaylight/controller/topologymanager/shell/PrintNodeEdges.java
deleted file mode 100644 (file)
index 4a65a45..0000000
+++ /dev/null
@@ -1,29 +0,0 @@
-/**
-* Copyright (c) 2014 Inocybe Technologies, and others. All rights reserved.
-*
-* This program and the accompanying materials are made available under the
-* terms of the Eclipse Public License v1.0 which accompanies this distribution,
-* and is available at http://www.eclipse.org/legal/epl-v10.html
-*/
-package org.opendaylight.controller.topologymanager.shell;
-
-import org.apache.karaf.shell.commands.Command;
-import org.apache.karaf.shell.console.OsgiCommandSupport;
-import org.opendaylight.controller.topologymanager.ITopologyManagerShell;
-
-@Command(scope = "topologymanager", name = "printNodeEdges", description="Prints node edges")
-public class PrintNodeEdges extends OsgiCommandSupport{
-    private ITopologyManagerShell topologyManager;
-
-    @Override
-    protected Object doExecute() throws Exception {
-        for(String p : topologyManager.printNodeEdges()) {
-            System.out.println(p);
-        }
-        return null;
-    }
-
-    public void setTopologyManager(ITopologyManagerShell topologyManager){
-        this.topologyManager = topologyManager;
-    }
-}
diff --git a/opendaylight/adsal/topologymanager/shell/src/main/java/org/opendaylight/controller/topologymanager/shell/PrintUserLink.java b/opendaylight/adsal/topologymanager/shell/src/main/java/org/opendaylight/controller/topologymanager/shell/PrintUserLink.java
deleted file mode 100644 (file)
index e0976b0..0000000
+++ /dev/null
@@ -1,29 +0,0 @@
-/**
-* Copyright (c) 2014 Inocybe Technologies, and others. All rights reserved.
-*
-* This program and the accompanying materials are made available under the
-* terms of the Eclipse Public License v1.0 which accompanies this distribution,
-* and is available at http://www.eclipse.org/legal/epl-v10.html
-*/
-package org.opendaylight.controller.topologymanager.shell;
-
-import org.apache.karaf.shell.commands.Command;
-import org.apache.karaf.shell.console.OsgiCommandSupport;
-import org.opendaylight.controller.topologymanager.ITopologyManagerShell;
-
-@Command(scope = "topologymanager", name = "printUserLink", description="Prints user link")
-public class PrintUserLink extends OsgiCommandSupport{
-    private ITopologyManagerShell topologyManager;
-
-    @Override
-    protected Object doExecute() throws Exception {
-        for(String p : topologyManager.printUserLink()) {
-            System.out.println(p);
-        }
-        return null;
-    }
-
-    public void setTopologyManager(ITopologyManagerShell topologyManager){
-        this.topologyManager = topologyManager;
-    }
-}
diff --git a/opendaylight/adsal/topologymanager/shell/src/main/resources/OSGI-INF/blueprint/blueprint.xml b/opendaylight/adsal/topologymanager/shell/src/main/resources/OSGI-INF/blueprint/blueprint.xml
deleted file mode 100644 (file)
index 96b0b10..0000000
+++ /dev/null
@@ -1,33 +0,0 @@
-<blueprint xmlns="http://www.osgi.org/xmlns/blueprint/v1.0.0">
-
-    <reference id="topologyManagerRef" interface="org.opendaylight.controller.topologymanager.ITopologyManagerShell"/>
-    <command-bundle xmlns="http://karaf.apache.org/xmlns/shell/v1.1.0">
-
-        <command>
-        <action class="org.opendaylight.controller.topologymanager.shell.AddUserLink">
-            <property name="topologyManager" ref="topologyManagerRef"/>
-            </action>
-        </command>
-
-        <command>
-        <action class="org.opendaylight.controller.topologymanager.shell.DeleteUserLink">
-            <property name="topologyManager" ref="topologyManagerRef"/>
-            </action>
-        </command>
-
-        <command>
-        <action class="org.opendaylight.controller.topologymanager.shell.PrintNodeEdges">
-            <property name="topologyManager" ref="topologyManagerRef"/>
-            </action>
-        </command>
-
-        <command>
-        <action class="org.opendaylight.controller.topologymanager.shell.PrintUserLink">
-            <property name="topologyManager" ref="topologyManagerRef"/>
-            </action>
-        </command>
-
-    </command-bundle>
-
-
-</blueprint>
diff --git a/opendaylight/adsal/usermanager/api/pom.xml b/opendaylight/adsal/usermanager/api/pom.xml
deleted file mode 100644 (file)
index a1dcca4..0000000
+++ /dev/null
@@ -1,81 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>usermanager</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>javax.servlet</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>configuration</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <!-- Spring security -->
-    <dependency>
-      <groupId>org.springframework.security</groupId>
-      <artifactId>spring-security-core</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.springframework.security</groupId>
-      <artifactId>spring-security-web</artifactId>
-    </dependency>
-  </dependencies>
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Import-Package>org.opendaylight.controller.configuration,
-              org.opendaylight.controller.sal.authorization,
-              org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.sal.packet,
-              org.opendaylight.controller.sal.utils,
-              org.slf4j,
-              org.eclipse.osgi.framework.console,
-              org.osgi.framework,
-              org.apache.felix.dm,
-              org.apache.commons.logging,
-              javax.servlet,
-              javax.servlet.http,
-              org.springframework.security.web.context,
-              org.springframework.security.core,
-              org.springframework.security.core.context,
-              org.springframework.security.authentication,
-              org.springframework.security.core.authority,
-              org.springframework.security.core.userdetails,
-              javax.xml.bind.annotation</Import-Package>
-            <Export-Package>org.opendaylight.controller.usermanager,</Export-Package>
-          </instructions>
-          <manifestLocation>${project.basedir}/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/usermanager/api/src/main/java/org/opendaylight/controller/usermanager/AuthResponse.java b/opendaylight/adsal/usermanager/api/src/main/java/org/opendaylight/controller/usermanager/AuthResponse.java
deleted file mode 100644 (file)
index 062c358..0000000
+++ /dev/null
@@ -1,69 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.usermanager;
-
-import java.io.Serializable;
-import java.util.LinkedList;
-import java.util.List;
-
-import org.opendaylight.controller.sal.authorization.AuthResultEnum;
-
-/**
- * The class describes AAA response status and payload data
- */
-public class AuthResponse implements Serializable {
-    private static final long serialVersionUID = 1L;
-    private List<String> data;
-    private AuthResultEnum status;
-    private AuthResultEnum authorStatus;
-
-    public AuthResponse() {
-        this.data = new LinkedList<String>();
-        this.status = AuthResultEnum.AUTH_NONE;
-        this.authorStatus = AuthResultEnum.AUTH_NONE;
-    }
-
-    public void setData(List<String> data) {
-        this.data = data;
-    }
-
-    public void addData(String data) {
-        this.data.add(data);
-    }
-
-    public List<String> getData() {
-        return data;
-    }
-
-    public void setStatus(AuthResultEnum status) {
-        this.status = status;
-    }
-
-    public AuthResultEnum getStatus() {
-        return status;
-    }
-
-    public void setAuthorizationStatus(AuthResultEnum authorStatus) {
-        this.authorStatus = authorStatus;
-    }
-
-    public AuthResultEnum getAuthorizationStatus() {
-        return authorStatus;
-    }
-
-    public String toString() {
-        return ("\nReceived messages: " + data.toString() + "\nStatus: " + status);
-    }
-
-    public void resetData(String rolesData) {
-        // TODO Auto-generated method stub
-
-    }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/usermanager/api/src/main/java/org/opendaylight/controller/usermanager/AuthenticatedUser.java b/opendaylight/adsal/usermanager/api/src/main/java/org/opendaylight/controller/usermanager/AuthenticatedUser.java
deleted file mode 100644 (file)
index 809ca13..0000000
+++ /dev/null
@@ -1,69 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.usermanager;
-
-import java.io.Serializable;
-import java.util.ArrayList;
-import java.util.Collections;
-import java.util.Date;
-import java.util.List;
-
-import org.opendaylight.controller.sal.authorization.UserLevel;
-import org.springframework.security.core.GrantedAuthority;
-import org.springframework.security.core.authority.SimpleGrantedAuthority;
-
-/**
- * Represents a user that was successfully authenticated and authorized
- * It contains the user role for which the user was authorized and the
- * date on which it was authenticated and authorized
- */
-public class AuthenticatedUser implements Serializable {
-    private static final long serialVersionUID = 1L;
-    private List<String> userRoles;
-    private Date accessDate;
-
-    public AuthenticatedUser(String name) {
-        userRoles = null;
-        accessDate = new Date();
-    }
-
-    public void setRoleList(List<String> roleList) {
-        this.userRoles = roleList;
-    }
-
-    public void setRoleList(String[] roleArray) {
-        userRoles = new ArrayList<String>(roleArray.length);
-        for (String role : roleArray) {
-            String target = role.trim();
-            if (!target.isEmpty()) {
-                userRoles.add(target);
-            }
-        }
-    }
-
-    public List<String> getUserRoles() {
-        return userRoles == null ? Collections.<String> emptyList() : new ArrayList<String>(userRoles);
-    }
-
-    public void addUserRole(String string) {
-        userRoles.add(string);
-    }
-
-    public String getAccessDate() {
-        return accessDate.toString();
-    }
-
-    public List<GrantedAuthority> getGrantedAuthorities(UserLevel usrLvl) {
-        List<GrantedAuthority> roles = new ArrayList<GrantedAuthority>();
-        roles.add(new SimpleGrantedAuthority(new ODLUserLevel(usrLvl)
-                .getAuthority()));
-        return roles;
-    }
-
-}
diff --git a/opendaylight/adsal/usermanager/api/src/main/java/org/opendaylight/controller/usermanager/AuthorizationConfig.java b/opendaylight/adsal/usermanager/api/src/main/java/org/opendaylight/controller/usermanager/AuthorizationConfig.java
deleted file mode 100644 (file)
index a484943..0000000
+++ /dev/null
@@ -1,54 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.usermanager;
-
-import java.util.ArrayList;
-import java.util.List;
-
-import org.opendaylight.controller.sal.utils.Status;
-
-/**
- * Configuration Java Object which represents a Local configured Authorization
- * for a remote authenticated user for User Manager.
- */
-public class AuthorizationConfig extends UserConfig {
-    private static final long serialVersionUID = 1L;
-
-    public AuthorizationConfig() {
-        super();
-    }
-
-    // Constructor may be needed for autocontainer logic
-    public AuthorizationConfig(String user, List<String> roles) {
-        super();
-        this.user = user;
-        this.roles = (roles == null) ? new ArrayList<String>()
-                : new ArrayList<String>(roles);
-    }
-
-    @Override
-    public Status validate() {
-        Status status = validateUsername();
-        if (status.isSuccess()) {
-            status = validateRoles();
-        }
-        return status;
-    }
-
-    @Override
-    public String toString() {
-        return "AuthorizationConfig=[user: " + user + ", roles: " + roles + "]";
-    }
-
-    @Override
-    public String getRolesString() {
-        return super.getRolesString();
-    }
-
-}
diff --git a/opendaylight/adsal/usermanager/api/src/main/java/org/opendaylight/controller/usermanager/IAAAProvider.java b/opendaylight/adsal/usermanager/api/src/main/java/org/opendaylight/controller/usermanager/IAAAProvider.java
deleted file mode 100644 (file)
index 36a2c06..0000000
+++ /dev/null
@@ -1,42 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.usermanager;
-
-/**
- * IAAAProvider exposes a pluggable interface for 3rd party Authentication and
- * Authorization providers to support the UserManager with AAA management.
- */
-
-public interface IAAAProvider {
-
-    /**
-     * Authenticate user with AAA server and return authentication and
-     * authorization info using the Provider's mechanism
-     *
-     * @param userName
-     *            the username
-     * @param password
-     *            the password
-     * @param server
-     *            AAA server ip address in string form
-     * @param secretKey
-     *            shared secret between the AAA client and AAA server
-     * @return {@link org.opendaylight.controller.usermanager.AuthResponse}
-     *         Authentication and Authorization Response
-     */
-    public AuthResponse authService(String userName, String password,
-            String server, String secretKey);
-
-    /**
-     * Returns the Name of the Provider
-     *
-     * @return Name of the AAA provider
-     */
-    public String getName();
-}
diff --git a/opendaylight/adsal/usermanager/api/src/main/java/org/opendaylight/controller/usermanager/ISessionManager.java b/opendaylight/adsal/usermanager/api/src/main/java/org/opendaylight/controller/usermanager/ISessionManager.java
deleted file mode 100644 (file)
index 372462e..0000000
+++ /dev/null
@@ -1,29 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.usermanager;
-
-import javax.servlet.http.HttpSessionListener;
-
-/**
- *
- * This interface defines method(s) to invalidate a session.
- */
-public interface ISessionManager extends HttpSessionListener {
-
-    /**
-     * Invalidates the session for a given user and a session Id
-     *
-     * @param username
-     *            the username
-     * @param sessionId
-     *            the session Id
-     */
-    public void invalidateSessions(String username, String sessionId);
-
-}
diff --git a/opendaylight/adsal/usermanager/api/src/main/java/org/opendaylight/controller/usermanager/IUserManager.java b/opendaylight/adsal/usermanager/api/src/main/java/org/opendaylight/controller/usermanager/IUserManager.java
deleted file mode 100644 (file)
index aaf5cbd..0000000
+++ /dev/null
@@ -1,299 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.usermanager;
-
-import java.util.List;
-import java.util.Map;
-import java.util.Set;
-
-import org.opendaylight.controller.sal.authorization.AuthResultEnum;
-import org.opendaylight.controller.sal.authorization.UserLevel;
-import org.opendaylight.controller.sal.utils.Status;
-import org.springframework.security.core.userdetails.UserDetailsService;
-import org.springframework.security.web.context.SecurityContextRepository;
-
-/**
- * The Interface which describes the methods exposed by User Manager.
- */
-public interface IUserManager extends UserDetailsService {
-
-    /**
-     * Returns the list of roles associated to the passed user name
-     *
-     * @param userName
-     * @return the role associated to the user name
-     */
-    public List<String> getUserRoles(String userName);
-
-    /**
-     * Authenticate user with AAA server and return authentication and
-     * authorization info
-     *
-     * @param username
-     *            the username
-     * @param password
-     *            the password
-     * @return {@link org.opendaylight.controller.sal.authorization.AuthResultEnum}
-     *         authentication result
-     */
-    public AuthResultEnum authenticate(String username, String password);
-
-    /**
-     * Add/remove AAA server
-     *
-     * @param configObject
-     *            {@link org.opendaylight.controller.usermanager.internal.ServerConfig}
-     *            Server Configuration
-     * @return {@link org.opendaylight.controller.sal.utils.Status}
-     *         status of this action
-     */
-    public Status addAAAServer(ServerConfig configObject);
-
-    /**
-     * Remove AAA server
-     *
-     * @param configObject
-     *            refer to
-     *            {@link org.opendaylight.controller.usermanager.internal.ServerConfig}
-     *            Server Configuration
-     * @return {@link org.opendaylight.controller.sal.utils.Status}
-     *         status of this action
-     */
-    public Status removeAAAServer(ServerConfig configObject);
-
-    /**
-     * Add a local user
-     *
-     * @param configObject
-     *            {@link org.opendaylight.controller.usermanager.internal.UserConfig}
-     *            User Configuration
-     * @return refer to {@link org.opendaylight.controller.sal.utils.Status}
-     *         status code
-     */
-    public Status addLocalUser(UserConfig configObject);
-
-    /**
-     * Modify a local user
-     *
-     * @param configObject
-     *            {@link org.opendaylight.controller.usermanager.internal.UserConfig}
-     *            The new User Configuration
-     * @return refer to {@link org.opendaylight.controller.sal.utils.Status}
-     *         status code
-     */
-    public Status modifyLocalUser(UserConfig configObject);
-
-    /**
-     * Remove a local user
-     *
-     * @param configObject
-     *            {@link org.opendaylight.controller.usermanager.internal.UserConfig}
-     *            UserConfig
-     * @return {@link org.opendaylight.controller.sal.utils.Status}
-     *         status of this action
-     */
-    public Status removeLocalUser(UserConfig configObject);
-
-    /**
-     * Remove a local user
-     *
-     * @param userName
-     *            the user name
-     * @return {@link org.opendaylight.controller.sal.utils.Status}
-     *         status of this action
-     */
-    public Status removeLocalUser(String userName);
-
-    /**
-     * Add the authorization information for a user that gets authenticated
-     * remotely
-     *
-     * @param AAAconf
-     *            {@link org.opendaylight.controller.usermanager.internal.AuthorizationConfig}
-     *            Authorization Resources
-     * @return {@link org.opendaylight.controller.sal.utils.Status}
-     *         status of this action
-     */
-    public Status addAuthInfo(AuthorizationConfig AAAconf);
-
-    /**
-     * Remove the authorization information for a user that gets authenticated
-     * remotely
-     *
-     * @param AAAconf
-     *            {@link org.opendaylight.controller.usermanager.internal.AuthorizationConfig}
-     *            Authorization Resource
-     * @return {@link org.opendaylight.controller.sal.utils.Status}
-     *         status of this action
-     */
-    public Status removeAuthInfo(AuthorizationConfig AAAconf);
-
-    /**
-     * Return the list of authorization resources
-     *
-     * @return {@link org.opendaylight.controller.usermanager.internal.AuthorizationConfig}
-     *         List of Authorization Resource
-     */
-    public List<AuthorizationConfig> getAuthorizationList();
-
-    /**
-     * Returns a list of AAA Providers.
-     *
-     * @return Set of provider names.
-     */
-    public Set<String> getAAAProviderNames();
-
-    /**
-     * Change the current password for a locally configured user
-     *
-     * @param user
-     *            the username
-     * @param curPasssword
-     *            the current password
-     * @param newPassword
-     *            the new password
-     * @return {@link org.opendaylight.controller.sal.utils.Status}
-     *         status of this action
-     */
-    public Status changeLocalUserPassword(String user, String curPassword,
-            String newPassword);
-
-    /**
-     * Return a list of AAA servers currently configured
-     *
-     * @return {@link org.opendaylight.controller.usermanager.internal.ServerConfig}
-     *         List of ServerConfig
-     */
-    public List<ServerConfig> getAAAServerList();
-
-    /**
-     * Return a list of local users
-     *
-     * @return {@link org.opendaylight.controller.usermanager.internal.UserConfig}
-     *         List of UserConfig
-     */
-    public List<UserConfig> getLocalUserList();
-
-    /**
-     * Save the local users to disk
-     *
-     * @return {@link org.opendaylight.controller.sal.utils.Status}
-     *         status of this action
-     */
-    public Status saveLocalUserList();
-
-    /**
-     * Save the AAA server configurations to disk
-     *
-     * @return {@link org.opendaylight.controller.sal.utils.Status}
-     *         status of this action
-     */
-    public Status saveAAAServerList();
-
-    /**
-     * Save the Authorization configurations to disk
-     *
-     * @return {@link org.opendaylight.controller.sal.utils.Status}
-     *         status code
-     */
-    public Status saveAuthorizationList();
-
-    /**
-     * Remove user profile when user logs out
-     *
-     * @param username
-     *            the user name
-     */
-    public void userLogout(String username);
-
-    /**
-     * Remove user profile when user times out
-     *
-     * @param username
-     *            the user name
-     */
-    public void userTimedOut(String username);
-
-    /**
-     * Get the list of users currently logged in
-     *
-     * @return the list of users along with their administrative roles
-     */
-    public Map<String, List<String>> getUserLoggedIn();
-
-    /**
-     * Get date and time user was successfully authenticated
-     *
-     * @param user
-     * @return Date in String format
-     */
-    public String getAccessDate(String user);
-
-    /**
-     * Returns the highest user level for the passed user name. It checks the roles
-     * assigned to this user and checks against the well known Controller user
-     * roles to determines the highest user level associated with the user
-     *
-     * @param userName
-     *            the user name
-     * @return {@link org.opendaylight.controller.sal.authorization.UserLevel}
-     *         the highest user level for this user
-     */
-    public UserLevel getUserLevel(String userName);
-
-    /**
-     * Returns the list of user level for the passed user name. It checks the roles
-     * assigned to this user and checks against the well known Controller user
-     * roles to determines the corresponding list of user level associated with the user
-     *
-     * @param userName
-     *            the user name
-     * @return
-     *          the list of user level for this user
-     */
-    public List<UserLevel> getUserLevels(String userName);
-
-    /**
-     * Returns the Security Context
-     *
-     * @returns {@link org.springframework.security.web.context.SecurityContextRepository}
-     *          Security Context
-     */
-    public SecurityContextRepository getSecurityContextRepo();
-
-    /**
-     * Returns the Session Manager Interface Handler
-     *
-     * @return {@link org.opendaylight.controller.usermanager.ISessionManager}
-     *         session manager interface handler
-     */
-    public ISessionManager getSessionManager();
-
-    /**
-     * Checks if the specified role belongs to any application. Usually an
-     * application will call this function when configuring a role, to check if
-     * that role is already being used by another application.
-     *
-     * @param role
-     *            The role to check
-     * @return true if the specified role belongs to any application or if the
-     *         role is a well-known controller role, false otherwise.
-     */
-    public boolean isRoleInUse(String role);
-
-    /* non-Javadoc
-     * Returns the password for a given user
-     *
-     * @param username
-     *            the user name
-     * @return password for the username
-     */
-    public String getPassword(String username);
-
-}
diff --git a/opendaylight/adsal/usermanager/api/src/main/java/org/opendaylight/controller/usermanager/ODLUserLevel.java b/opendaylight/adsal/usermanager/api/src/main/java/org/opendaylight/controller/usermanager/ODLUserLevel.java
deleted file mode 100644 (file)
index 045002e..0000000
+++ /dev/null
@@ -1,30 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.usermanager;
-
-import java.util.Locale;
-
-import org.opendaylight.controller.sal.authorization.UserLevel;
-import org.springframework.security.core.GrantedAuthority;
-
-public class ODLUserLevel implements GrantedAuthority {
-        private static final long serialVersionUID = 1L;
-        UserLevel userLevel;
-
-    public ODLUserLevel(UserLevel userLevel) {
-        this.userLevel = userLevel;
-    }
-
-    @Override
-    public String getAuthority() {
-        return "ROLE_" + this.userLevel.toString().toUpperCase(Locale.ENGLISH);
-    }
-
-}
diff --git a/opendaylight/adsal/usermanager/api/src/main/java/org/opendaylight/controller/usermanager/ServerConfig.java b/opendaylight/adsal/usermanager/api/src/main/java/org/opendaylight/controller/usermanager/ServerConfig.java
deleted file mode 100644 (file)
index 3145f20..0000000
+++ /dev/null
@@ -1,100 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.usermanager;
-
-import java.io.Serializable;
-
-import org.opendaylight.controller.configuration.ConfigurationObject;
-
-/**
- * Configuration Java Object which represents a Remote AAA server configuration
- * information for User Manager.
- */
-public class ServerConfig extends ConfigurationObject implements Serializable {
-    private static final long serialVersionUID = 1L;
-
-    // Order matters: JSP file expects following fields in the following order
-    private String ip;
-    private String secret;
-    private String protocol;
-
-    public ServerConfig() {
-    }
-
-    public ServerConfig(String ip, String secret, String protocol) {
-        this.ip = ip;
-        this.secret = secret;
-        this.protocol = protocol;
-    }
-
-    public String getAddress() {
-        return ip;
-    }
-
-    public String getSecret() {
-        return secret;
-    }
-
-    public String getProtocol() {
-        return protocol;
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result + ((ip == null) ? 0 : ip.hashCode());
-        result = prime * result
-                + ((protocol == null) ? 0 : protocol.hashCode());
-        result = prime * result + ((secret == null) ? 0 : secret.hashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        ServerConfig other = (ServerConfig) obj;
-        if (ip == null) {
-            if (other.ip != null) {
-                return false;
-            }
-        } else if (!ip.equals(other.ip)) {
-            return false;
-        }
-        if (protocol == null) {
-            if (other.protocol != null) {
-                return false;
-            }
-        } else if (!protocol.equals(other.protocol)) {
-            return false;
-        }
-        if (secret == null) {
-            if (other.secret != null) {
-                return false;
-            }
-        } else if (!secret.equals(other.secret)) {
-            return false;
-        }
-        return true;
-    }
-
-    public boolean isValid() {
-        return (ip != null && !ip.isEmpty() && secret != null && !secret
-                .isEmpty());
-    }
-}
diff --git a/opendaylight/adsal/usermanager/api/src/main/java/org/opendaylight/controller/usermanager/UserConfig.java b/opendaylight/adsal/usermanager/api/src/main/java/org/opendaylight/controller/usermanager/UserConfig.java
deleted file mode 100644 (file)
index 8298f5b..0000000
+++ /dev/null
@@ -1,351 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.usermanager;
-
-import java.io.Serializable;
-import java.security.MessageDigest;
-import java.security.NoSuchAlgorithmException;
-import java.security.SecureRandom;
-import java.util.ArrayList;
-import java.util.Collections;
-import java.util.Iterator;
-import java.util.List;
-import java.util.regex.Matcher;
-import java.util.regex.Pattern;
-
-import javax.xml.bind.annotation.XmlAccessType;
-import javax.xml.bind.annotation.XmlAccessorType;
-import javax.xml.bind.annotation.XmlElement;
-import javax.xml.bind.annotation.XmlRootElement;
-
-import org.opendaylight.controller.configuration.ConfigurationObject;
-import org.opendaylight.controller.sal.authorization.AuthResultEnum;
-import org.opendaylight.controller.sal.packet.BitBufferHelper;
-import org.opendaylight.controller.sal.utils.HexEncode;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.sal.utils.StatusCode;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * Configuration Java Object which represents a Local AAA user configuration
- * information for User Manager.
- */
-@XmlRootElement
-@XmlAccessorType(XmlAccessType.NONE)
-public class UserConfig extends ConfigurationObject implements Serializable {
-    private static final long serialVersionUID = 1L;
-    private static Logger log = LoggerFactory.getLogger(UserConfig.class);
-    private static final boolean strongPasswordCheck = Boolean.getBoolean("enableStrongPasswordCheck");
-    private static final String DIGEST_ALGORITHM = "SHA-384";
-    private static final String BAD_PASSWORD = "Bad Password";
-    private static final int USERNAME_MAXLENGTH = 32;
-    protected static final String PASSWORD_REGEX = "(?=.*[^a-zA-Z0-9])(?=.*\\d)(?=.*[a-z])(?=.*[A-Z]).{8,256}$";
-    private static final Pattern INVALID_USERNAME_CHARACTERS = Pattern.compile("([/\\s\\.\\?#%;\\\\]+)");
-    private static MessageDigest oneWayFunction;
-    private static SecureRandom randomGenerator;
-
-    static {
-        try {
-            UserConfig.oneWayFunction = MessageDigest.getInstance(DIGEST_ALGORITHM);
-        } catch (NoSuchAlgorithmException e) {
-            log.error(String.format("Implementation of %s digest algorithm not found: %s", DIGEST_ALGORITHM,
-                    e.getMessage()));
-        }
-        UserConfig.randomGenerator = new SecureRandom(BitBufferHelper.toByteArray(System.currentTimeMillis()));
-    }
-
-    /**
-     * User Id
-     */
-    @XmlElement
-    protected String user;
-
-    /**
-     * List of roles a user can have
-     * example
-     * System-Admin
-     * Network-Admin
-     * Network-Operator
-     */
-    @XmlElement
-    protected List<String> roles;
-
-    /**
-     * Password
-     * Should be 8 to 256 characters long,
-     * contain both upper and lower case letters, at least one number,
-     * and at least one non alphanumeric character.
-     */
-    @XmlElement
-    private String password;
-
-    private byte[] salt;
-
-
-
-    public UserConfig() {
-    }
-
-    /**
-     * Construct a UserConfig object and takes care of hashing the user password
-     *
-     * @param user
-     *            the user name
-     * @param password
-     *            the plain text password
-     * @param roles
-     *            the list of roles
-     */
-    public UserConfig(String user, String password, List<String> roles) {
-        this.user = user;
-
-        /*
-         * Password validation to be done on clear text password. If fails, mark
-         * the password with a well known label, so that object validation can
-         * report the proper error. Only if password is a valid one, generate
-         * salt, concatenate it with clear text password and hash the
-         * resulting string. Hash result is going to be our stored password.
-         */
-        if (validateClearTextPassword(password).isSuccess()) {
-            this.salt = BitBufferHelper.toByteArray(randomGenerator.nextLong());
-            this.password = hash(salt, password);
-        } else {
-            this.salt = null;
-            this.password = BAD_PASSWORD;
-        }
-
-        this.roles = (roles == null) ? Collections.<String>emptyList() : new ArrayList<String>(roles);
-    }
-
-    public String getUser() {
-        return user;
-    }
-
-    public String getPassword() {
-        return password;
-    }
-
-    public List<String> getRoles() {
-        return new ArrayList<String>(roles);
-    }
-
-    public byte[] getSalt() {
-        return (salt == null) ? null : salt.clone();
-    }
-
-    @Override
-    public int hashCode() {
-        final int prime = 31;
-        int result = 1;
-        result = prime * result
-                + ((password == null) ? 0 : password.hashCode());
-        result = prime * result + ((roles == null) ? 0 : roles.hashCode());
-        result = prime * result + ((user == null) ? 0 : user.hashCode());
-        return result;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-        if (obj == null) {
-            return false;
-        }
-        if (getClass() != obj.getClass()) {
-            return false;
-        }
-        UserConfig other = (UserConfig) obj;
-        if (password == null) {
-            if (other.password != null) {
-                return false;
-            }
-        } else if (!password.equals(other.password)) {
-            return false;
-        }
-        if (roles == null) {
-            if (other.roles != null) {
-                return false;
-            }
-        } else if (!roles.equals(other.roles)) {
-            return false;
-        }
-        if (user == null) {
-            if (other.user != null) {
-                return false;
-            }
-        } else if (!user.equals(other.user)) {
-            return false;
-        }
-        return true;
-    }
-
-    @Override
-    public String toString() {
-        return "UserConfig[user=" + user + ", password=" + password + ", roles=" + roles +"]";
-    }
-
-    public Status validate() {
-        Status validCheck = validateUsername();
-        if (validCheck.isSuccess()) {
-            // Password validation was run at object construction time
-            validCheck = (!password.equals(BAD_PASSWORD)) ? new Status(StatusCode.SUCCESS) : new Status(
-                    StatusCode.BADREQUEST,
-                    "Password should be 8 to 256 characters long, contain both upper and lower case letters, "
-                            + "at least one number and at least one non alphanumeric character");
-        }
-        if (validCheck.isSuccess()) {
-            validCheck = validateRoles();
-        }
-        return validCheck;
-    }
-
-    protected Status validateUsername() {
-        if (user == null || user.isEmpty()) {
-            return new Status(StatusCode.BADREQUEST, "Username cannot be empty");
-        }
-
-        Matcher mUser = UserConfig.INVALID_USERNAME_CHARACTERS.matcher(user);
-        if (user.length() > UserConfig.USERNAME_MAXLENGTH || mUser.find() == true) {
-            return new Status(StatusCode.BADREQUEST,
-                    "Username can have 1-32 non-whitespace "
-                            + "alphanumeric characters and any special "
-                            + "characters except ./#%;?\\");
-        }
-
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    public static Status validateClearTextPassword(String password) {
-        if (password == null || password.isEmpty()) {
-            return new Status(StatusCode.BADREQUEST, "Password cannot be empty");
-        }
-
-        if (strongPasswordCheck && !password.matches(UserConfig.PASSWORD_REGEX)) {
-            return new Status(StatusCode.BADREQUEST, "Password should be 8 to 256 characters long, "
-                    + "contain both upper and lower case letters, at least one number "
-                    + "and at least one non alphanumeric character");
-        }
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    protected Status validateRoles() {
-        if (roles == null || roles.isEmpty()) {
-            return new Status(StatusCode.BADREQUEST, "No role specified");
-        }
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    public Status update(String currentPassword, String newPassword, List<String> newRoles) {
-
-        // To make any changes to a user configured profile, current password
-        // must always be provided
-        if (!isPasswordMatch(currentPassword)) {
-            return new Status(StatusCode.BADREQUEST, "Current password is incorrect");
-        }
-
-        // Create a new object with the proposed modifications
-        UserConfig proposed = new UserConfig();
-        proposed.user = this.user;
-        proposed.password = (newPassword == null)? this.password : hash(this.salt, newPassword);
-        proposed.roles = (newRoles == null)? this.roles : newRoles;
-
-        // Validate it
-        Status status = proposed.validate();
-        if (!status.isSuccess()) {
-            return status;
-        }
-
-        // Accept the modifications
-        this.user = proposed.user;
-        this.password = proposed.password;
-        this.roles = new ArrayList<String>(proposed.roles);
-
-        return status;
-    }
-
-    public boolean isPasswordMatch(String otherPass) {
-        return this.password.equals(hash(this.salt, otherPass));
-    }
-
-    public AuthResponse authenticate(String clearTextPassword) {
-        AuthResponse locResponse = new AuthResponse();
-        if (isPasswordMatch(clearTextPassword)) {
-            locResponse.setStatus(AuthResultEnum.AUTH_ACCEPT_LOC);
-            locResponse.addData(getRolesString());
-        } else {
-            locResponse.setStatus(AuthResultEnum.AUTH_REJECT_LOC);
-        }
-        return locResponse;
-    }
-
-    protected String getRolesString() {
-        StringBuffer buffer = new StringBuffer();
-        if (!roles.isEmpty()) {
-            Iterator<String> iter = roles.iterator();
-            buffer.append(iter.next());
-            while (iter.hasNext()) {
-                buffer.append(" ");
-                buffer.append(iter.next());
-            }
-        }
-        return buffer.toString();
-    }
-
-    private static byte[] concatenate(byte[] salt, String password) {
-        byte[] messageArray = password.getBytes();
-        byte[] concatenation = new byte[salt.length + password.length()];
-        System.arraycopy(salt, 0, concatenation, 0, salt.length);
-        System.arraycopy(messageArray, 0, concatenation, salt.length, messageArray.length);
-        return concatenation;
-    }
-
-    private static String hash(byte[] salt, String message) {
-        if (message == null) {
-            log.warn("Password hash requested but empty or no password provided");
-            return message;
-        }
-        if (salt == null || salt.length == 0) {
-            log.warn("Password hash requested but empty or no salt provided");
-            return message;
-        }
-
-        // Concatenate salt and password
-        byte[] messageArray = message.getBytes();
-        byte[] concatenation = new byte[salt.length + message.length()];
-        System.arraycopy(salt, 0, concatenation, 0, salt.length);
-        System.arraycopy(messageArray, 0, concatenation, salt.length, messageArray.length);
-
-        UserConfig.oneWayFunction.reset();
-        return HexEncode.bytesToHexString(UserConfig.oneWayFunction.digest(concatenate(salt, message)));
-    }
-
-    /**
-     * Returns UserConfig instance populated with the passed parameters. It does
-     * not run any checks on the passed parameters.
-     *
-     * @param userName
-     *            the user name
-     * @param password
-     *            the plain text password
-     * @param roles
-     *            the list of roles
-     * @return the UserConfig object populated with the passed parameters. No
-     *         validity check is run on the input parameters.
-     */
-    public static UserConfig getUncheckedUserConfig(String userName, String password, List<String> roles) {
-        UserConfig config = new UserConfig();
-        config.user = userName;
-        config.salt = BitBufferHelper.toByteArray(randomGenerator.nextLong());
-        config.password = hash(config.salt, password);
-        config.roles = roles;
-        return config;
-    }
-}
diff --git a/opendaylight/adsal/usermanager/api/src/test/java/org/opendaylight/controller/usermanager/AuthResponseTest.java b/opendaylight/adsal/usermanager/api/src/test/java/org/opendaylight/controller/usermanager/AuthResponseTest.java
deleted file mode 100644 (file)
index af68be6..0000000
+++ /dev/null
@@ -1,14 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.usermanager;
-
-public class AuthResponseTest{
-
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/usermanager/api/src/test/java/org/opendaylight/controller/usermanager/AuthenticatedUserTest.java b/opendaylight/adsal/usermanager/api/src/test/java/org/opendaylight/controller/usermanager/AuthenticatedUserTest.java
deleted file mode 100644 (file)
index d32799e..0000000
+++ /dev/null
@@ -1,72 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.usermanager;
-
-import java.util.Arrays;
-import java.util.List;
-
-import org.junit.Assert;
-import org.junit.BeforeClass;
-import org.junit.Test;
-import org.opendaylight.controller.sal.authorization.UserLevel;
-import org.springframework.security.core.GrantedAuthority;
-
-public class AuthenticatedUserTest {
-
-        static String[] roleArray;
-        static AuthenticatedUser user;
-
-        @BeforeClass
-        public static void testSetup() {
-                roleArray = new String[] { UserLevel.NETWORKOPERATOR.toString(),
-                                UserLevel.APPUSER.toString() };
-        }
-
-        @Test
-        public void testAuthenticatedUser() {
-                user = new AuthenticatedUser("auser");
-
-                Assert.assertFalse(user.getAccessDate().isEmpty());
-        Assert.assertNotNull(user.getUserRoles());
-        }
-
-        @Test
-        public void testSetUserRoleList() {
-                List<String> retrievedRoleList = null;
-                List<String> roleList = Arrays.asList(roleArray);
-
-                // list arg
-                user = new AuthenticatedUser("auser");
-                user.setRoleList(roleList);
-                retrievedRoleList = user.getUserRoles();
-                Assert.assertTrue(roleList.equals(retrievedRoleList));
-
-                // array arg
-                user = new AuthenticatedUser("auser");
-                user.setRoleList(roleArray);
-                retrievedRoleList = user.getUserRoles();
-                for (int i = 0; i < roleArray.length; i++)
-                        Assert.assertTrue(roleArray[i].equals(retrievedRoleList.get(i)));
-
-                // test addUserRole
-                user.addUserRole("AnotherRole");
-                Assert.assertTrue(user.getUserRoles().lastIndexOf("AnotherRole") != -1);
-
-        }
-
-        @Test
-        public void testGetGrantedAuthorities() {
-                user = new AuthenticatedUser("auser");
-                List<GrantedAuthority> gaList = user
-                                .getGrantedAuthorities(UserLevel.NETWORKOPERATOR);
-                Assert.assertTrue(gaList.get(0).getAuthority()
-                                .equals("ROLE_NETWORK-OPERATOR"));
-        }
-
-}
diff --git a/opendaylight/adsal/usermanager/api/src/test/java/org/opendaylight/controller/usermanager/AuthorizationUserConfigTest.java b/opendaylight/adsal/usermanager/api/src/test/java/org/opendaylight/controller/usermanager/AuthorizationUserConfigTest.java
deleted file mode 100644 (file)
index 8fc7f07..0000000
+++ /dev/null
@@ -1,148 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.usermanager;
-
-import static org.junit.Assert.assertFalse;
-import static org.junit.Assert.assertTrue;
-
-import java.util.ArrayList;
-import java.util.List;
-
-import org.junit.Test;
-import org.opendaylight.controller.sal.authorization.AuthResultEnum;
-import org.opendaylight.controller.sal.authorization.UserLevel;
-/*
- * This test case includes tests for UserConfig and the extending class AuthorizationConfig
- */
-public class AuthorizationUserConfigTest {
-
-    @Test
-    public void authorizationConfigTest() {
-        AuthorizationConfig authConfig;
-        List<String> roles = new ArrayList<String>();
-
-        // test isValid
-        roles.add(UserLevel.SYSTEMADMIN.toString());
-        authConfig = new AuthorizationConfig(null, roles);
-        assertFalse(authConfig.validate().isSuccess());
-        authConfig = new AuthorizationConfig("admin", new ArrayList<String>());
-        assertFalse(authConfig.validate().isSuccess());
-        authConfig = new AuthorizationConfig("admin", roles);
-        assertTrue(authConfig.validate().isSuccess());
-    }
-
-    @Test
-    public void userConfigTest() {
-        UserConfig userConfig;
-        List<String> roles = new ArrayList<String>();
-
-        roles.add(UserLevel.SYSTEMADMIN.toString());
-        userConfig = new UserConfig(null, "cisco", roles);
-        assertFalse(userConfig.validate().isSuccess());
-
-        roles.clear();
-        roles.add("cisco");
-        userConfig = new UserConfig("uname", "", roles);
-        assertFalse(userConfig.validate().isSuccess());
-
-        roles.clear();
-        roles.add(UserLevel.NETWORKOPERATOR.toString());
-        userConfig = new UserConfig("uname", "ciscocisco", roles);
-        assertTrue(userConfig.validate().isSuccess());
-
-        // currentPassword mismatch
-        assertFalse(userConfig.update("Cisco", "cisco123", roles).isSuccess());
-
-        // Role change only
-        roles.clear();
-        roles.add(UserLevel.NETWORKADMIN.toString());
-        assertTrue(userConfig.update("ciscocisco", null, roles).isSuccess());
-
-        // Role change and same new password
-        roles.clear();
-        roles.add(UserLevel.NETWORKOPERATOR.toString());
-        assertTrue(userConfig.update("ciscocisco", "ciscocisco", roles)
-                .isSuccess());
-
-        // New Password = null, No change in password
-        assertTrue(userConfig.authenticate("ciscocisco").getStatus().equals(AuthResultEnum.AUTH_ACCEPT_LOC));
-
-        // Password changed successfully, no change in user role
-        assertTrue(userConfig.update("ciscocisco", "cisco123", roles)
-                .isSuccess());
-        assertTrue(userConfig.authenticate("cisco123").getStatus().equals(AuthResultEnum.AUTH_ACCEPT_LOC));
-        assertTrue(userConfig.getRoles().get(0).equals(
-                UserLevel.NETWORKOPERATOR.toString()));
-
-        // Password not changed, role changed successfully
-        roles.clear();
-        roles.add(UserLevel.SYSTEMADMIN.toString());
-        assertTrue(userConfig.update("cisco123", "cisco123", roles)
-                .isSuccess());
-        assertTrue(userConfig.authenticate("cisco123").getStatus().equals(AuthResultEnum.AUTH_ACCEPT_LOC));
-        assertTrue(userConfig.getRoles().get(0)
-                .equals(UserLevel.SYSTEMADMIN.toString()));
-
-        // Password and role changed successfully
-        assertTrue(userConfig.update("cisco123", "ciscocisco", roles)
-                .isSuccess());
-        assertTrue(userConfig.authenticate("ciscocisco").getStatus().equals(AuthResultEnum.AUTH_ACCEPT_LOC));
-        assertTrue(userConfig.getRoles().get(0)
-                .equals(UserLevel.SYSTEMADMIN.toString()));
-
-        String username = userConfig.getUser();
-        assertTrue(username.equals("uname"));
-
-        // test authenticate
-        AuthResponse authresp = userConfig.authenticate("ciscocisco");
-        assertTrue(authresp.getStatus().equals(AuthResultEnum.AUTH_ACCEPT_LOC));
-        authresp = userConfig.authenticate("wrongPassword");
-        assertTrue(authresp.getStatus().equals(AuthResultEnum.AUTH_REJECT_LOC));
-    }
-
-    @Test
-    public void userConfigPasswordTest() {
-
-        String regex = UserConfig.PASSWORD_REGEX;
-        String password = null;
-
-        // Good password
-        password = "aBc@eF#h9";
-        assertTrue(password.matches(regex));
-        password = "^aBc@eF#h9$88ad*o&";
-        assertTrue(password.matches(regex));
-        password = "_^aBc@\":eF#h;9$\\8|8ad*o&-(){}/,.><?+-";
-        assertTrue(password.matches(regex));
-        password = "culonE1)";
-        assertTrue(password.matches(regex));
-
-        // Too short
-        password = "aB3@eF#";
-        assertFalse(password.matches(regex));
-
-        // No number
-        password = "#BeCCC#CeDfDf";
-        assertFalse(password.matches(regex));
-
-        // No lower case
-        password = "AB8C#CC@C4";
-        assertFalse(password.matches(regex));
-
-        // No upper case
-        password = "ab8defg9!";
-        assertFalse(password.matches(regex));
-
-        // No special characters
-        password = "aBc4ef7H8";
-        assertFalse(password.matches(regex));
-
-        // Underscore is a special character
-        password = "Azmb_123 ";
-        assertTrue(password.matches(regex));
-    }
-}
diff --git a/opendaylight/adsal/usermanager/api/src/test/java/org/opendaylight/controller/usermanager/ServerConfigTest.java b/opendaylight/adsal/usermanager/api/src/test/java/org/opendaylight/controller/usermanager/ServerConfigTest.java
deleted file mode 100644 (file)
index eaeca73..0000000
+++ /dev/null
@@ -1,12 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.usermanager;
-
-public class ServerConfigTest   {
-}
diff --git a/opendaylight/adsal/usermanager/implementation/pom.xml b/opendaylight/adsal/usermanager/implementation/pom.xml
deleted file mode 100644 (file)
index f272482..0000000
+++ /dev/null
@@ -1,103 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>usermanager.implementation</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>org.eclipse.osgi</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>clustering.services</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>configuration</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>containermanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>usermanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.slf4j</groupId>
-      <artifactId>jcl-over-slf4j</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.springframework.security</groupId>
-      <artifactId>spring-security-web</artifactId>
-    </dependency>
-
-  </dependencies>
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Import-Package>org.opendaylight.controller.configuration,
-              org.opendaylight.controller.clustering.services,
-              org.opendaylight.controller.sal.authorization,
-              org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.sal.packet,
-              org.opendaylight.controller.sal.utils,
-              org.opendaylight.controller.containermanager,
-              org.slf4j,
-              org.eclipse.osgi.framework.console,
-              org.osgi.framework,
-              org.apache.felix.dm,
-              org.apache.commons.lang3.builder,
-              org.apache.commons.logging,
-              javax.servlet,
-              javax.servlet.http,
-              org.springframework.security.web.context,
-              org.springframework.security.core,
-              org.springframework.security.core.context,
-              org.apache.commons.lang3,
-              org.springframework.security.authentication,
-              org.springframework.security.core.authority,
-              org.springframework.security.core.userdetails,
-              org.opendaylight.controller.usermanager</Import-Package>
-            <Export-Package>
-              <!--
-              org.opendaylight.controller.usermanager,
-              org.opendaylight.controller.usermanager.internal
-              -->
-            </Export-Package>
-            <Bundle-Activator>org.opendaylight.controller.usermanager.internal.Activator</Bundle-Activator>
-          </instructions>
-          <manifestLocation>${project.basedir}/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/usermanager/implementation/src/main/java/org/opendaylight/controller/usermanager/internal/Activator.java b/opendaylight/adsal/usermanager/implementation/src/main/java/org/opendaylight/controller/usermanager/internal/Activator.java
deleted file mode 100644 (file)
index 26e10a6..0000000
+++ /dev/null
@@ -1,126 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.usermanager.internal;
-
-import org.apache.felix.dm.Component;
-import org.opendaylight.controller.clustering.services.IClusterGlobalServices;
-import org.opendaylight.controller.configuration.IConfigurationAware;
-import org.opendaylight.controller.configuration.IConfigurationService;
-import org.opendaylight.controller.containermanager.IContainerAuthorization;
-import org.opendaylight.controller.sal.authorization.IResourceAuthorization;
-import org.opendaylight.controller.sal.core.ComponentActivatorAbstractBase;
-import org.opendaylight.controller.usermanager.IAAAProvider;
-import org.opendaylight.controller.usermanager.IUserManager;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * UserManager Bundle Activator
- *
- *
- */
-public class Activator extends ComponentActivatorAbstractBase {
-    protected static final Logger logger = LoggerFactory
-            .getLogger(Activator.class);
-
-
-    /**
-     * Function that is used to communicate to dependency manager the
-     * list of known implementations for services inside a container
-     *
-     *
-     * @return An array containing all the CLASS objects that will be
-     * instantiated in order to get an fully working implementation
-     * Object
-     */
-    @Override
-    public Object[] getImplementations() {
-        return new Object[]{};
-    }
-
-    /**
-     * Function that is called when configuration of the dependencies
-     * is required.
-     *
-     * @param c dependency manager Component object, used for
-     * configuring the dependencies exported and imported
-     * @param imp Implementation class that is being configured,
-     * needed as long as the same routine can configure multiple
-     * implementations
-     * @param containerName The containerName being configured, this allow
-     * also optional per-container different behavior if needed, usually
-     * should not be the case though.
-     */
-    @Override
-    public void configureInstance(Component c, Object imp, String containerName) {
-    }
-
-    /**
-     * Method which tells how many global implementations are
-     * supported by the bundle. This way we can tune the number of
-     * components created. This components will be created ONLY at the
-     * time of bundle startup and will be destroyed only at time of
-     * bundle destruction, this is the major difference with the
-     * implementation retrieved via getImplementations where all of
-     * them are assumed to be in a container !
-     *
-     *
-     * @return The list of implementations the bundle will support,
-     * in Global version
-     */
-    @Override
-    protected Object[] getGlobalImplementations() {
-        Object[] res = { UserManager.class };
-        return res;
-    }
-
-    /**
-     * Configure the dependency for a given instance Global
-     *
-     * @param c Component assigned for this instance, this will be
-     * what will be used for configuration
-     * @param imp implementation to be configured
-     * @param containerName container on which the configuration happens
-     */
-    @Override
-    protected void configureGlobalInstance(Component c, Object imp) {
-        if (imp.equals(UserManager.class)) {
-
-            // export the service
-            c.setInterface(new String[] {
-                    IUserManager.class.getName(),
-                    IConfigurationAware.class.getName() }, null);
-
-            c.add(createServiceDependency().setService(
-                    IClusterGlobalServices.class).setCallbacks(
-                    "setClusterGlobalService", "unsetClusterGlobalService")
-                    .setRequired(true));
-
-            c.add(createServiceDependency().setService(
-                    IConfigurationService.class).setCallbacks(
-                    "setConfigurationService",
-                    "unsetConfigurationService").setRequired(true));
-
-            c.add(createServiceDependency().setService(IAAAProvider.class)
-                    .setCallbacks("addAAAProvider", "removeAAAProvider")
-                    .setRequired(false));
-
-            c.add(createServiceDependency().setService(
-                    IContainerAuthorization.class).setCallbacks(
-                    "setContainerAuthClient", "unsetContainerAuthClient")
-                    .setRequired(false));
-
-            c.add(createServiceDependency().setService(
-                    IResourceAuthorization.class).setCallbacks(
-                    "setAppAuthClient", "unsetAppAuthClient")
-                    .setRequired(false));
-        }
-    }
-}
diff --git a/opendaylight/adsal/usermanager/implementation/src/main/java/org/opendaylight/controller/usermanager/internal/UserManager.java b/opendaylight/adsal/usermanager/implementation/src/main/java/org/opendaylight/controller/usermanager/internal/UserManager.java
deleted file mode 100644 (file)
index e7394f9..0000000
+++ /dev/null
@@ -1,1192 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.usermanager.internal;
-
-import java.io.BufferedReader;
-import java.io.File;
-import java.io.FileNotFoundException;
-import java.io.FileReader;
-import java.io.IOException;
-import java.io.ObjectInputStream;
-import java.util.ArrayList;
-import java.util.Collections;
-import java.util.EnumSet;
-import java.util.HashMap;
-import java.util.HashSet;
-import java.util.List;
-import java.util.Map;
-import java.util.Set;
-import java.util.concurrent.ConcurrentHashMap;
-import java.util.concurrent.ConcurrentMap;
-
-import org.apache.commons.lang3.StringUtils;
-import org.eclipse.osgi.framework.console.CommandInterpreter;
-import org.eclipse.osgi.framework.console.CommandProvider;
-import org.opendaylight.controller.clustering.services.CacheConfigException;
-import org.opendaylight.controller.clustering.services.CacheExistException;
-import org.opendaylight.controller.clustering.services.IClusterGlobalServices;
-import org.opendaylight.controller.clustering.services.IClusterServices;
-import org.opendaylight.controller.configuration.ConfigurationObject;
-import org.opendaylight.controller.configuration.IConfigurationAware;
-import org.opendaylight.controller.configuration.IConfigurationService;
-import org.opendaylight.controller.containermanager.IContainerAuthorization;
-import org.opendaylight.controller.sal.authorization.AuthResultEnum;
-import org.opendaylight.controller.sal.authorization.IResourceAuthorization;
-import org.opendaylight.controller.sal.authorization.UserLevel;
-import org.opendaylight.controller.sal.utils.IObjectReader;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.sal.utils.StatusCode;
-import org.opendaylight.controller.usermanager.AuthResponse;
-import org.opendaylight.controller.usermanager.AuthenticatedUser;
-import org.opendaylight.controller.usermanager.AuthorizationConfig;
-import org.opendaylight.controller.usermanager.IAAAProvider;
-import org.opendaylight.controller.usermanager.ISessionManager;
-import org.opendaylight.controller.usermanager.IUserManager;
-import org.opendaylight.controller.usermanager.ServerConfig;
-import org.opendaylight.controller.usermanager.UserConfig;
-import org.opendaylight.controller.usermanager.security.SessionManager;
-import org.opendaylight.controller.usermanager.security.UserSecurityContextRepository;
-import org.osgi.framework.BundleContext;
-import org.osgi.framework.BundleException;
-import org.osgi.framework.FrameworkUtil;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-import org.springframework.security.authentication.AuthenticationProvider;
-import org.springframework.security.authentication.AuthenticationServiceException;
-import org.springframework.security.authentication.BadCredentialsException;
-import org.springframework.security.authentication.UsernamePasswordAuthenticationToken;
-import org.springframework.security.core.Authentication;
-import org.springframework.security.core.AuthenticationException;
-import org.springframework.security.core.userdetails.User;
-import org.springframework.security.core.userdetails.UserDetails;
-import org.springframework.security.core.userdetails.UsernameNotFoundException;
-import org.springframework.security.web.context.SecurityContextRepository;
-
-/**
- * The internal implementation of the User Manager.
- */
-public class UserManager implements IUserManager, IObjectReader,
-        IConfigurationAware, CommandProvider, AuthenticationProvider {
-    private static final Logger logger = LoggerFactory.getLogger(UserManager.class);
-    private static final String DEFAULT_ADMIN = "admin";
-    private static final String DEFAULT_ADMIN_PASSWORD = "admin";
-    private static final String DEFAULT_ADMIN_ROLE = UserLevel.NETWORKADMIN.toString();
-    private static final String USERS_FILE_NAME = "users.conf";
-    private static final String SERVERS_FILE_NAME = "servers.conf";
-    private static final String AUTH_FILE_NAME = "authorization.conf";
-    private static final String RECOVERY_FILE = "NETWORK_ADMIN_PASSWORD_RECOVERY";
-    private static final boolean DISALLOW_DEFAULT_ADMIN_PASSWORD =
-        Boolean.getBoolean("usermanager.disable-default-admin-password");
-    private ConcurrentMap<String, UserConfig> localUserConfigList;
-    private ConcurrentMap<String, ServerConfig> remoteServerConfigList;
-    // local authorization info for remotely authenticated users
-    private ConcurrentMap<String, AuthorizationConfig> authorizationConfList;
-    private ConcurrentMap<String, AuthenticatedUser> activeUsers;
-    private ConcurrentMap<String, IAAAProvider> authProviders;
-    private IClusterGlobalServices clusterGlobalService = null;
-    private IConfigurationService configurationService;
-    private SecurityContextRepository securityContextRepo = new UserSecurityContextRepository();
-    private IContainerAuthorization containerAuthorizationClient;
-    private Set<IResourceAuthorization> applicationAuthorizationClients;
-    private ISessionManager sessionMgr = new SessionManager();
-    protected enum Command {
-        ADD("add", "added"),
-        MODIFY("modify", "modified"),
-        REMOVE("remove", "removed");
-        private final String action;
-        private final String postAction;
-        private Command(String action, String postAction) {
-            this.action = action;
-            this.postAction = postAction;
-        }
-
-        public String getAction() {
-            return action;
-        }
-
-        public String getPostAction() {
-            return postAction;
-        }
-    }
-
-    public boolean addAAAProvider(IAAAProvider provider) {
-        if (provider == null || provider.getName() == null
-                || provider.getName().trim().isEmpty()) {
-            return false;
-        }
-        if (authProviders.get(provider.getName()) != null) {
-            return false;
-        }
-
-        authProviders.put(provider.getName(), provider);
-        return true;
-    }
-
-    public void removeAAAProvider(IAAAProvider provider) {
-        authProviders.remove(provider.getName());
-    }
-
-    public IAAAProvider getAAAProvider(String name) {
-        return authProviders.get(name);
-    }
-
-    @Override
-    public Set<String> getAAAProviderNames() {
-        return authProviders.keySet();
-    }
-
-    private void allocateCaches() {
-        this.applicationAuthorizationClients = Collections.synchronizedSet(new HashSet<IResourceAuthorization>());
-        if (clusterGlobalService == null) {
-            logger.error("un-initialized clusterGlobalService, can't create cache");
-            return;
-        }
-
-        try {
-            clusterGlobalService.createCache("usermanager.localUserConfigList",
-                    EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-
-            clusterGlobalService.createCache(
-                    "usermanager.remoteServerConfigList",
-                    EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-
-            clusterGlobalService.createCache(
-                    "usermanager.authorizationConfList",
-                    EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-
-            clusterGlobalService.createCache("usermanager.activeUsers",
-                    EnumSet.of(IClusterServices.cacheMode.TRANSACTIONAL));
-        } catch (CacheConfigException cce) {
-            logger.error("Cache configuration invalid - check cache mode");
-        } catch (CacheExistException ce) {
-            logger.debug("Skipping cache creation as already present");
-        }
-    }
-
-    @SuppressWarnings({ "unchecked" })
-    private void retrieveCaches() {
-        if (clusterGlobalService == null) {
-            logger.error("un-initialized clusterService, can't retrieve cache");
-            return;
-        }
-
-        activeUsers = (ConcurrentMap<String, AuthenticatedUser>) clusterGlobalService
-                .getCache("usermanager.activeUsers");
-        if (activeUsers == null) {
-            logger.error("Failed to get cache for activeUsers");
-        }
-
-        localUserConfigList = (ConcurrentMap<String, UserConfig>) clusterGlobalService
-                .getCache("usermanager.localUserConfigList");
-        if (localUserConfigList == null) {
-            logger.error("Failed to get cache for localUserConfigList");
-        }
-
-        remoteServerConfigList = (ConcurrentMap<String, ServerConfig>) clusterGlobalService
-                .getCache("usermanager.remoteServerConfigList");
-        if (remoteServerConfigList == null) {
-            logger.error("Failed to get cache for remoteServerConfigList");
-        }
-
-        authorizationConfList = (ConcurrentMap<String, AuthorizationConfig>) clusterGlobalService
-                .getCache("usermanager.authorizationConfList");
-        if (authorizationConfList == null) {
-            logger.error("Failed to get cache for authorizationConfList");
-        }
-    }
-
-    private void loadConfigurations() {
-        // To encode and decode user and server configuration objects
-        loadSecurityKeys();
-        /*
-         * Do not load local startup file if we are not the coordinator
-         */
-        loadUserConfig();
-        loadServerConfig();
-        loadAuthConfig();
-    }
-
-    private void loadSecurityKeys() {
-
-    }
-
-    private void checkDefaultNetworkAdmin(String newPass) {
-        boolean usingFactoryPassword = false;
-        // network admin already configured.
-        if (localUserConfigList.containsKey(DEFAULT_ADMIN)) {
-            UserConfig uc =  localUserConfigList.get(DEFAULT_ADMIN);
-            if (!uc.isPasswordMatch(DEFAULT_ADMIN_PASSWORD)) {
-                return;
-            } else {
-                usingFactoryPassword = true;
-            }
-        }
-
-        List<String> defaultRoles = new ArrayList<String>(1);
-        defaultRoles.add(DEFAULT_ADMIN_ROLE);
-        if (newPass == null) {
-            if (!localUserConfigList.containsKey(DEFAULT_ADMIN)) {
-              // Need to skip the strong password check for the default admin
-                UserConfig defaultAdmin = UserConfig.getUncheckedUserConfig(
-                    UserManager.DEFAULT_ADMIN, UserManager.DEFAULT_ADMIN_PASSWORD,
-                    defaultRoles);
-                localUserConfigList.put(UserManager.DEFAULT_ADMIN, defaultAdmin);
-                usingFactoryPassword = true;
-            }
-        } else {
-            // use new password for admin
-            Status status = UserConfig.validateClearTextPassword(newPass);
-            if (status.isSuccess()) {
-                localUserConfigList.put(UserManager.DEFAULT_ADMIN,
-                    new UserConfig(UserManager.DEFAULT_ADMIN, newPass, defaultRoles));
-                logger.trace("Network Adminstrator password is reset.");
-                if (newPass.equals(DEFAULT_ADMIN_PASSWORD)) {
-                    usingFactoryPassword = true;
-                }
-            } else {
-                logger.warn("Password is invalid - {}. Network Adminstrator password " +
-                    "cannot be set.", status.getDescription());
-            }
-        }
-
-        if (usingFactoryPassword) {
-            if (DISALLOW_DEFAULT_ADMIN_PASSWORD) {
-                logger.warn("Network Administrator factory default password " +
-                    "is disallowed. Please set the password prior to starting " +
-                    "the controller. Shutting down now.");
-                // shutdown osgi
-                try {
-                    BundleContext bundleContext = FrameworkUtil.getBundle(
-                        getClass()).getBundleContext();
-                    bundleContext.getBundle(0).stop();
-                } catch (BundleException e) {
-                    logger.warn("Cannot stop framework ", e);
-                }
-            } else {
-                logger.warn("Network Administrator password is set to factory default. " +
-                    "Please change the password as soon as possible.");
-            }
-        }
-    }
-
-    private String checkPasswordRecovery() {
-        final String fileDescription = "Default Network Administrator password recovery file";
-        File recoveryFile = new File(UserManager.RECOVERY_FILE);
-        if (!recoveryFile.exists()) {
-            return null;
-        }
-        // read the recovery file
-        String pwd = null;
-        try {
-            BufferedReader reader = new BufferedReader(new FileReader(recoveryFile));
-            // read password from recovery file if it has one
-            pwd = reader.readLine();
-            if (pwd != null && pwd.trim().length() == 0) {
-                pwd = null;
-            }
-            reader.close();
-            /*
-             * Recovery file detected, remove current default network
-             * administrator entry from local users configuration list.
-             * Warn user and delete recovery file.
-             */
-            this.localUserConfigList.remove(UserManager.DEFAULT_ADMIN);
-            if (!recoveryFile.delete()) {
-                logger.warn("Failed to delete {}", fileDescription);
-            } else {
-                logger.trace("{} deleted", fileDescription);
-            }
-        } catch (IOException e) {
-            logger.warn("Failed to process file {}", fileDescription);
-        }
-        return pwd;
-    }
-
-    @Override
-    public AuthResultEnum authenticate(String userName, String password) {
-        IAAAProvider aaaClient;
-        AuthResponse rcResponse = null;
-        AuthenticatedUser result;
-        boolean remotelyAuthenticated = false;
-        boolean authorizationInfoIsPresent = false;
-        boolean authorized = false;
-
-        /*
-         * Attempt remote authentication first if server is configured
-         */
-        for (ServerConfig aaaServer : remoteServerConfigList.values()) {
-            String protocol = aaaServer.getProtocol();
-            aaaClient = this.getAAAProvider(protocol);
-            if (aaaClient != null) {
-                rcResponse = aaaClient.authService(userName, password,
-                        aaaServer.getAddress(), aaaServer.getSecret());
-                if (rcResponse.getStatus() == AuthResultEnum.AUTH_ACCEPT) {
-                    logger.trace(
-                            "Remote Authentication Succeeded for User: \"{}\", by Server: {}",
-                            userName, aaaServer.getAddress());
-                    remotelyAuthenticated = true;
-                    break;
-                } else if (rcResponse.getStatus() == AuthResultEnum.AUTH_REJECT) {
-                    logger.trace(
-                            "Remote Authentication Rejected User: \"{}\", from Server: {}, Reason:{}",
-                            new Object[] { userName, aaaServer.getAddress(),
-                                    rcResponse.getStatus().toString() });
-                } else {
-                    logger.trace(
-                            "Remote Authentication Failed for User: \"{}\", from Server: {}, Reason:{}",
-                            new Object[] { userName, aaaServer.getAddress(),
-                                    rcResponse.getStatus().toString() });
-                }
-            }
-        }
-
-        if (!remotelyAuthenticated) {
-            UserConfig localUser = this.localUserConfigList.get(userName);
-            if (localUser == null) {
-                logger.trace(
-                        "Local Authentication Failed for User:\"{}\", Reason: "
-                                + "user not found in Local Database", userName);
-                return (AuthResultEnum.AUTH_INVALID_LOC_USER);
-            }
-            rcResponse = localUser.authenticate(password);
-            if (rcResponse.getStatus() != AuthResultEnum.AUTH_ACCEPT_LOC) {
-                logger.trace(
-                        "Local Authentication Failed for User: \"{}\", Reason: {}",
-                        userName, rcResponse.getStatus().toString());
-
-                return (rcResponse.getStatus());
-            }
-            logger.trace("Local Authentication Succeeded for User: \"{}\"",
-                    userName);
-        }
-
-        /*
-         * Authentication succeeded
-         */
-        result = new AuthenticatedUser(userName);
-
-        /*
-         * Extract attributes from response All the information we are
-         * interested in is in the first Cisco VSA (vendor specific attribute).
-         * Just process the first VSA and return
-         */
-        String attributes = (rcResponse.getData() != null && !rcResponse
-                .getData().isEmpty()) ? rcResponse.getData().get(0) : null;
-
-        /*
-         * Check if the authorization information is present
-         */
-        authorizationInfoIsPresent = checkAuthorizationInfo(attributes);
-
-        /*
-         * The AAA server was only used to perform the authentication Look for
-         * locally stored authorization info for this user If found, add the
-         * data to the rcResponse
-         */
-        if (remotelyAuthenticated && !authorizationInfoIsPresent) {
-            logger.trace(
-                    "No Remote Authorization Info provided by Server for User: \"{}\"",
-                    userName);
-            logger.trace(
-                    "Looking for Local Authorization Info for User: \"{}\"",
-                    userName);
-
-            AuthorizationConfig resource = authorizationConfList.get(userName);
-            if (resource != null) {
-                logger.trace("Found Local Authorization Info for User: \"{}\"",
-                        userName);
-                attributes = resource.getRolesString();
-
-            }
-            authorizationInfoIsPresent = checkAuthorizationInfo(attributes);
-        }
-
-        /*
-         * Common response parsing for local & remote authenticated user Looking
-         * for authorized resources, detecting attributes' validity
-         */
-        if (authorizationInfoIsPresent) {
-            // Identifying the administrative role
-            result.setRoleList(attributes.split(" "));
-            authorized = true;
-        } else {
-            logger.trace("Not able to find Authorization Info for User: \"{}\"",
-                    userName);
-        }
-
-        /*
-         * Add profile for authenticated user
-         */
-        putUserInActiveList(userName, result);
-        if (authorized) {
-            logger.trace("User \"{}\" authorized for the following role(s): {}",
-                    userName, result.getUserRoles());
-        } else {
-            logger.trace("User \"{}\" Not Authorized for any role ", userName);
-        }
-
-        return rcResponse.getStatus();
-    }
-
-    // Check in the attributes string whether or not authorization information
-    // is present
-    private boolean checkAuthorizationInfo(String attributes) {
-        return (attributes != null && !attributes.isEmpty());
-    }
-
-    private void putUserInActiveList(String user, AuthenticatedUser result) {
-        activeUsers.put(user, result);
-    }
-
-    private void removeUserFromActiveList(String user) {
-        if (!activeUsers.containsKey(user)) {
-            // as cookie persists in cache, we can get logout for unexisting
-            // active users
-            return;
-        }
-        activeUsers.remove(user);
-    }
-
-    @Override
-    public Status saveLocalUserList() {
-        return saveLocalUserListInternal();
-    }
-
-    private Status saveLocalUserListInternal() {
-        return configurationService.persistConfiguration(
-                new ArrayList<ConfigurationObject>(localUserConfigList.values()), USERS_FILE_NAME);
-    }
-
-    @Override
-    public Status saveAAAServerList() {
-        return saveAAAServerListInternal();
-    }
-
-    private Status saveAAAServerListInternal() {
-        return configurationService.persistConfiguration(
-                new ArrayList<ConfigurationObject>(remoteServerConfigList.values()), SERVERS_FILE_NAME);
-    }
-
-    @Override
-    public Status saveAuthorizationList() {
-        return saveAuthorizationListInternal();
-    }
-
-    private Status saveAuthorizationListInternal() {
-        return configurationService.persistConfiguration(
-                new ArrayList<ConfigurationObject>(authorizationConfList.values()), AUTH_FILE_NAME);
-    }
-
-    @Override
-    public Object readObject(ObjectInputStream ois)
-            throws FileNotFoundException, IOException, ClassNotFoundException {
-        // Perform the class deserialization locally, from inside the package
-        // where the class is defined
-        return ois.readObject();
-    }
-
-    private void loadUserConfig() {
-        for (ConfigurationObject conf : configurationService.retrieveConfiguration(this, USERS_FILE_NAME)) {
-            addRemoveLocalUserInternal((UserConfig) conf, false);
-        }
-    }
-
-    private void loadServerConfig() {
-        for (ConfigurationObject conf : configurationService.retrieveConfiguration(this, SERVERS_FILE_NAME)) {
-            addAAAServer((ServerConfig) conf);
-        }
-    }
-
-    private void loadAuthConfig() {
-        for (ConfigurationObject conf : configurationService.retrieveConfiguration(this, AUTH_FILE_NAME)) {
-            addAuthInfo((AuthorizationConfig) conf);
-        }
-    }
-
-    /*
-     * Interaction with GUI START
-     */
-    private Status changeLocalUser(UserConfig AAAconf, Command command) {
-        // UserConfig Validation check
-        Status validCheck = AAAconf.validate();
-        if (!validCheck.isSuccess()) {
-            return validCheck;
-        }
-
-        String user = AAAconf.getUser();
-
-        // Check default admin user
-        if (user.equals(UserManager.DEFAULT_ADMIN)) {
-            String msg = String.format("Invalid Request: Default Network Admin  User cannot be %s", command.getPostAction());
-            logger.debug(msg);
-            return new Status(StatusCode.NOTALLOWED, msg);
-        }
-
-        // Check user presence/conflict
-        UserConfig currentAAAconf = localUserConfigList.get(user);
-        StatusCode statusCode = null;
-        String reason = null;
-        switch (command) {
-        case ADD:
-            if (currentAAAconf != null) {
-                reason = "already present";
-                statusCode = StatusCode.CONFLICT;
-            }
-            break;
-        case MODIFY:
-        case REMOVE:
-            if (currentAAAconf == null) {
-                reason = "not found";
-                statusCode = StatusCode.NOTFOUND;
-            }
-            break;
-        default:
-            break;
-
-        }
-        if (statusCode != null) {
-            String action = String.format("Failed to %s user %s: ", command.getAction(), user);
-            String msg = String.format("User %s %s in configuration database", user, reason);
-            logger.debug(action + msg);
-            return new Status(statusCode, msg);
-        }
-
-        switch (command) {
-        case ADD:
-            return addRemoveLocalUserInternal(AAAconf, false);
-        case MODIFY:
-            addRemoveLocalUserInternal(currentAAAconf, true);
-            return addRemoveLocalUserInternal(AAAconf, false);
-        case REMOVE:
-            return addRemoveLocalUserInternal(AAAconf, true);
-        default:
-            return new Status(StatusCode.INTERNALERROR, "Unknown action");
-        }
-    }
-
-    private Status addRemoveLocalUserInternal(UserConfig AAAconf, boolean delete) {
-        // Update Config database
-        if (delete) {
-            localUserConfigList.remove(AAAconf.getUser());
-            /*
-             * A user account has been removed form local database, we assume
-             * admin does not want this user to stay connected, in case he has
-             * an open session. So we clean the active list as well.
-             */
-            removeUserFromActiveList(AAAconf.getUser());
-        } else {
-            localUserConfigList.put(AAAconf.getUser(), AAAconf);
-        }
-
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    private Status addRemoveAAAServer(ServerConfig AAAconf, boolean delete) {
-        // Validation check
-        if (!AAAconf.isValid()) {
-            String msg = "Invalid Server configuration";
-            logger.warn(msg);
-            return new Status(StatusCode.BADREQUEST, msg);
-        }
-
-        // Update configuration database
-        if (delete) {
-            remoteServerConfigList.remove(AAAconf.getAddress());
-        } else {
-            remoteServerConfigList.put(AAAconf.getAddress(), AAAconf);
-        }
-
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    private Status addRemoveAuthInfo(AuthorizationConfig AAAconf, boolean delete) {
-        Status configCheck = AAAconf.validate();
-        if (!configCheck.isSuccess()) {
-            String msg = "Invalid Authorization configuration: "
-                    + configCheck.getDescription();
-            logger.warn(msg);
-            return new Status(StatusCode.BADREQUEST, msg);
-        }
-
-        // Update configuration database
-        if (delete) {
-            authorizationConfList.remove(AAAconf.getUser());
-        } else {
-            authorizationConfList.put(AAAconf.getUser(), AAAconf);
-        }
-
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    @Override
-    public Status addLocalUser(UserConfig AAAconf) {
-        return changeLocalUser(AAAconf, Command.ADD);
-    }
-
-    @Override
-    public Status modifyLocalUser(UserConfig AAAconf) {
-        return changeLocalUser(AAAconf, Command.MODIFY);
-    }
-
-    @Override
-    public Status removeLocalUser(UserConfig AAAconf) {
-        return changeLocalUser(AAAconf, Command.REMOVE);
-    }
-
-    @Override
-    public Status removeLocalUser(String userName) {
-        if (userName == null || userName.trim().isEmpty()) {
-            return new Status(StatusCode.BADREQUEST, "Invalid user name");
-        }
-
-        if (!localUserConfigList.containsKey(userName)) {
-            return new Status(StatusCode.NOTFOUND, "User does not exist");
-        }
-
-        return changeLocalUser(localUserConfigList.get(userName), Command.REMOVE);
-    }
-
-    @Override
-    public Status addAAAServer(ServerConfig AAAconf) {
-        return addRemoveAAAServer(AAAconf, false);
-    }
-
-    @Override
-    public Status removeAAAServer(ServerConfig AAAconf) {
-        return addRemoveAAAServer(AAAconf, true);
-    }
-
-    @Override
-    public Status addAuthInfo(AuthorizationConfig AAAconf) {
-        return addRemoveAuthInfo(AAAconf, false);
-    }
-
-    @Override
-    public Status removeAuthInfo(AuthorizationConfig AAAconf) {
-        return addRemoveAuthInfo(AAAconf, true);
-    }
-
-    @Override
-    public List<UserConfig> getLocalUserList() {
-        return new ArrayList<UserConfig>(localUserConfigList.values());
-    }
-
-    @Override
-    public List<ServerConfig> getAAAServerList() {
-        return new ArrayList<ServerConfig>(remoteServerConfigList.values());
-    }
-
-    @Override
-    public List<AuthorizationConfig> getAuthorizationList() {
-        return new ArrayList<AuthorizationConfig>(
-                authorizationConfList.values());
-    }
-
-    @Override
-    public Status changeLocalUserPassword(String user, String curPassword, String newPassword) {
-        UserConfig targetConfigEntry = null;
-
-        // update configuration entry
-        targetConfigEntry = localUserConfigList.get(user);
-        if (targetConfigEntry == null) {
-            return new Status(StatusCode.NOTFOUND, "User not found");
-        }
-        Status status = targetConfigEntry.update(curPassword, newPassword, null);
-        if (!status.isSuccess()) {
-            return status;
-        }
-        // Trigger cluster update
-        localUserConfigList.put(user, targetConfigEntry);
-
-        logger.trace("Password changed for User \"{}\"", user);
-
-        return status;
-    }
-
-    @Override
-    public void userLogout(String userName) {
-        // TODO: if user was authenticated through AAA server, send
-        // Acct-Status-Type=stop message to server with logout as reason
-        removeUserFromActiveList(userName);
-        logger.trace("User \"{}\" logged out", userName);
-    }
-
-    /*
-     * This function will get called by http session mgr when session times out
-     */
-    @Override
-    public void userTimedOut(String userName) {
-        // TODO: if user was authenticated through AAA server, send
-        // Acct-Status-Type=stop message to server with timeout as reason
-        removeUserFromActiveList(userName);
-        logger.trace("User \"{}\" timed out", userName);
-    }
-
-    @Override
-    public String getAccessDate(String user) {
-        return this.activeUsers.get(user).getAccessDate();
-    }
-
-    @Override
-    public synchronized Map<String, List<String>> getUserLoggedIn() {
-        Map<String, List<String>> loggedInList = new HashMap<String, List<String>>();
-        for (Map.Entry<String, AuthenticatedUser> user : activeUsers.entrySet()) {
-            String userNameShow = user.getKey();
-            loggedInList.put(userNameShow, user.getValue().getUserRoles());
-        }
-        return loggedInList;
-    }
-
-    public void _umAddUser(CommandInterpreter ci) {
-        String userName = ci.nextArgument();
-        String password = ci.nextArgument();
-        String role = ci.nextArgument();
-
-        List<String> roles = new ArrayList<String>();
-        while (role != null) {
-            if (!role.trim().isEmpty()) {
-                roles.add(role);
-            }
-            role = ci.nextArgument();
-        }
-
-        if (userName == null || userName.trim().isEmpty() || password == null || password.trim().isEmpty()
-                || roles.isEmpty()) {
-            ci.println("Invalid Arguments");
-            ci.println("umAddUser <user_name> <password> <user_role>");
-            return;
-        }
-        ci.print(this.addLocalUser(new UserConfig(userName, password, roles)));
-    }
-
-    public void _umRemUser(CommandInterpreter ci) {
-        String userName = ci.nextArgument();
-
-        if (userName == null || userName.trim().isEmpty()) {
-            ci.println("Invalid Arguments");
-            ci.println("umRemUser <user_name>");
-            return;
-        }
-        UserConfig target = localUserConfigList.get(userName);
-        if (target == null) {
-            ci.println("User not found");
-            return;
-        }
-        ci.println(this.removeLocalUser(target));
-    }
-
-    public void _umGetUsers(CommandInterpreter ci) {
-        for (UserConfig conf : this.getLocalUserList()) {
-            ci.println(conf.getUser() + " " + conf.getRoles());
-        }
-    }
-
-    public void _addAAAServer(CommandInterpreter ci) {
-        String server = ci.nextArgument();
-        String secret = ci.nextArgument();
-        String protocol = ci.nextArgument();
-
-        if (server == null || secret == null || protocol == null) {
-            ci.println("Usage : addAAAServer <server> <secret> <protocol>");
-            return;
-        }
-        ServerConfig s = new ServerConfig(server, secret, protocol);
-        addAAAServer(s);
-    }
-
-    public void _removeAAAServer(CommandInterpreter ci) {
-        String server = ci.nextArgument();
-        String secret = ci.nextArgument();
-        String protocol = ci.nextArgument();
-
-        if (server == null || secret == null || protocol == null) {
-            ci.println("Usage : addAAAServer <server> <secret> <protocol>");
-            return;
-        }
-        ServerConfig s = new ServerConfig(server, secret, protocol);
-        removeAAAServer(s);
-    }
-
-    public void _printAAAServers(CommandInterpreter ci) {
-        for (ServerConfig aaaServer : remoteServerConfigList.values()) {
-            ci.println(aaaServer.getAddress() + "-" + aaaServer.getProtocol());
-        }
-    }
-
-    @Override
-    public String getHelp() {
-        StringBuffer help = new StringBuffer();
-        return help.toString();
-    }
-
-    void setClusterGlobalService(IClusterGlobalServices s) {
-        logger.debug("Cluster Service Global set");
-        this.clusterGlobalService = s;
-    }
-
-    void unsetClusterGlobalService(IClusterGlobalServices s) {
-        if (this.clusterGlobalService == s) {
-            logger.debug("Cluster Service Global removed!");
-            this.clusterGlobalService = null;
-        }
-    }
-
-    public void setConfigurationService(IConfigurationService service) {
-        logger.trace("Got configuration service set request {}", service);
-        this.configurationService = service;
-    }
-
-    public void unsetConfigurationService(IConfigurationService service) {
-        logger.trace("Got configuration service UNset request");
-        this.configurationService = null;
-    }
-
-    void unsetContainerAuthClient(IContainerAuthorization s) {
-        if (this.containerAuthorizationClient == s) {
-            this.containerAuthorizationClient = null;
-        }
-    }
-
-    void setContainerAuthClient(IContainerAuthorization s) {
-        this.containerAuthorizationClient = s;
-    }
-
-    void setAppAuthClient(IResourceAuthorization s) {
-        this.applicationAuthorizationClients.add(s);
-    }
-
-    void unsetAppAuthClient(IResourceAuthorization s) {
-        this.applicationAuthorizationClients.remove(s);
-    }
-
-    /**
-     * Function called by the dependency manager when all the required
-     * dependencies are satisfied
-     *
-     */
-    void init() {
-    }
-
-    /**
-     * Function called by the dependency manager when at least one dependency
-     * become unsatisfied or when the component is shutting down because for
-     * example bundle is being stopped.
-     *
-     */
-    void destroy() {
-    }
-
-    /**
-     * Function called by dependency manager after "init ()" is called and after
-     * the services provided by the class are registered in the service registry
-     *
-     */
-    void start() {
-        authProviders = new ConcurrentHashMap<String, IAAAProvider>();
-        // Instantiate cluster synced variables
-        allocateCaches();
-        retrieveCaches();
-
-        // Read startup configuration and populate databases
-        loadConfigurations();
-
-        // Check if a password recovery was triggered for default network admin user
-        String pwd = checkPasswordRecovery();
-
-        // Make sure default Network Admin account is there
-        checkDefaultNetworkAdmin(pwd);
-
-        BundleContext bundleContext = FrameworkUtil.getBundle(this.getClass()).getBundleContext();
-        bundleContext.registerService(CommandProvider.class.getName(), this, null);
-    }
-
-    /**
-     * Function called by the dependency manager before the services exported by
-     * the component are unregistered, this will be followed by a "destroy ()"
-     * calls
-     *
-     */
-    void stop() {
-    }
-
-    @Override
-    public List<String> getUserRoles(String userName) {
-        List<String> roles = null;
-        if (userName != null) {
-            /*
-             * First look in active users then in local configured users,
-             * finally in local authorized users
-             */
-            if (activeUsers.containsKey(userName)) {
-                roles = activeUsers.get(userName).getUserRoles();
-            } else if (localUserConfigList.containsKey(userName)) {
-                roles = localUserConfigList.get(userName).getRoles();
-            } else if (authorizationConfList.containsKey(userName)) {
-                roles = authorizationConfList.get(userName).getRoles();
-            }
-        }
-        return (roles == null) ? new ArrayList<String>(0) : roles;
-    }
-
-    @Override
-    public UserLevel getUserLevel(String username) {
-        // Returns the highest controller user level for the passed user
-        List<String> rolesNames = getUserRoles(username);
-
-        if (rolesNames.isEmpty()) {
-            return UserLevel.NOUSER;
-        }
-
-        // Check against the well known controller roles first
-        if (rolesNames.contains(UserLevel.SYSTEMADMIN.toString())) {
-            return UserLevel.SYSTEMADMIN;
-        }
-        if (rolesNames.contains(UserLevel.NETWORKADMIN.toString())) {
-            return UserLevel.NETWORKADMIN;
-        }
-        if (rolesNames.contains(UserLevel.NETWORKOPERATOR.toString())) {
-            return UserLevel.NETWORKOPERATOR;
-        }
-        // Check if container user now
-        if (containerAuthorizationClient != null) {
-            for (String roleName : rolesNames) {
-                if (containerAuthorizationClient.isApplicationRole(roleName)) {
-                    return UserLevel.CONTAINERUSER;
-                }
-            }
-        }
-        // Finally check if application user
-        if (applicationAuthorizationClients != null) {
-            for (String roleName : rolesNames) {
-                for (IResourceAuthorization client : this.applicationAuthorizationClients) {
-                    if (client.isApplicationRole(roleName)) {
-                        return UserLevel.APPUSER;
-                    }
-                }
-            }
-        }
-        return UserLevel.NOUSER;
-    }
-
-
-    @Override
-    public List<UserLevel> getUserLevels(String username) {
-        // Returns the controller user levels for the passed user
-        List<String> rolesNames =  getUserRoles(username);
-        List<UserLevel> levels = new ArrayList<UserLevel>();
-
-        if (rolesNames.isEmpty()) {
-            return levels;
-        }
-
-        // Check against the well known controller roles first
-        if (rolesNames.contains(UserLevel.SYSTEMADMIN.toString())) {
-            levels.add(UserLevel.SYSTEMADMIN);
-        }
-        if (rolesNames.contains(UserLevel.NETWORKADMIN.toString())) {
-            levels.add(UserLevel.NETWORKADMIN);
-        }
-        if (rolesNames.contains(UserLevel.NETWORKOPERATOR.toString())) {
-            levels.add(UserLevel.NETWORKOPERATOR);
-        }
-        // Check if container user now
-        if (containerAuthorizationClient != null) {
-            for (String roleName : rolesNames) {
-                if (containerAuthorizationClient.isApplicationRole(roleName)) {
-                    levels.add(UserLevel.CONTAINERUSER);
-                    break;
-                }
-            }
-        }
-        // Finally check if application user
-        if (applicationAuthorizationClients != null) {
-            for (String roleName : rolesNames) {
-                for (IResourceAuthorization client : this.applicationAuthorizationClients) {
-                    if (client.isApplicationRole(roleName)) {
-                        levels.add(UserLevel.APPUSER);
-                        break;
-                    }
-                }
-            }
-        }
-        return levels;
-    }
-
-    @Override
-    public Status saveConfiguration() {
-        boolean success = true;
-        Status ret = saveLocalUserList();
-        if (!ret.isSuccess()) {
-            success = false;
-        }
-        ret = saveAAAServerList();
-        if (!ret.isSuccess()) {
-            success = false;
-        }
-        ret = saveAuthorizationList();
-        if (!ret.isSuccess()) {
-            success = false;
-        }
-
-        if (success) {
-            return new Status(StatusCode.SUCCESS);
-        }
-
-        return new Status(StatusCode.INTERNALERROR, "Failed to save user configurations");
-    }
-
-    @Override
-    public UserDetails loadUserByUsername(String username)
-            throws UsernameNotFoundException {
-        AuthenticatedUser user = activeUsers.get(username);
-
-        if (user != null) {
-            boolean enabled = true;
-            boolean accountNonExpired = true;
-            boolean credentialsNonExpired = true;
-            boolean accountNonLocked = true;
-
-            return new User(username, localUserConfigList.get(username)
-                    .getPassword(), enabled, accountNonExpired,
-                    credentialsNonExpired, accountNonLocked,
-                    user.getGrantedAuthorities(getUserLevel(username)));
-        } else {
-            throw new UsernameNotFoundException("User not found " + username);
-        }
-    }
-
-    @Override
-    public boolean supports(Class<?> authentication) {
-        return UsernamePasswordAuthenticationToken.class
-                .isAssignableFrom(authentication);
-
-    }
-
-    @Override
-    public SecurityContextRepository getSecurityContextRepo() {
-        return securityContextRepo;
-    }
-
-    public void setSecurityContextRepo(
-            SecurityContextRepository securityContextRepo) {
-        this.securityContextRepo = securityContextRepo;
-    }
-
-    @Override
-    public Authentication authenticate(Authentication authentication)
-            throws AuthenticationException {
-
-        if (StringUtils.isBlank((String) authentication.getCredentials())
-                || StringUtils.isBlank((String) authentication.getPrincipal())) {
-            throw new BadCredentialsException(
-                    "Username or credentials did not match");
-        }
-
-        AuthResultEnum result = authenticate(
-                (String) authentication.getPrincipal(),
-                (String) authentication.getCredentials());
-        if (result.equals(AuthResultEnum.AUTHOR_PASS)
-                || result.equals(AuthResultEnum.AUTH_ACCEPT_LOC)
-                || result.equals(AuthResultEnum.AUTH_ACCEPT)) {
-
-            AuthenticatedUser user = activeUsers.get(authentication
-                    .getPrincipal().toString());
-
-            if (user == null) {
-                throw new AuthenticationServiceException(
-                        "Authentication Failure");
-            }
-
-            authentication = new UsernamePasswordAuthenticationToken(
-                    authentication.getPrincipal(),
-                    authentication.getCredentials(),
-                    user.getGrantedAuthorities(getUserLevel(authentication
-                            .getName())));
-            return authentication;
-
-        } else {
-            throw new BadCredentialsException(
-                    "Username or credentials did not match");
-        }
-
-    }
-
-    // Following are setters for use in unit testing
-    void setLocalUserConfigList(ConcurrentMap<String, UserConfig> ucl) {
-        if (ucl != null) {
-            this.localUserConfigList = ucl;
-        }
-    }
-
-    void setRemoteServerConfigList(ConcurrentMap<String, ServerConfig> scl) {
-        if (scl != null) {
-            this.remoteServerConfigList = scl;
-        }
-    }
-
-    void setAuthorizationConfList(ConcurrentMap<String, AuthorizationConfig> acl) {
-        if (acl != null) {
-            this.authorizationConfList = acl;
-        }
-    }
-
-    void setActiveUsers(ConcurrentMap<String, AuthenticatedUser> au) {
-        if (au != null) {
-            this.activeUsers = au;
-        }
-    }
-
-    void setAuthProviders(ConcurrentMap<String, IAAAProvider> ap) {
-        if (ap != null) {
-            this.authProviders = ap;
-        }
-    }
-
-    @Override
-    public ISessionManager getSessionManager() {
-        return this.sessionMgr;
-    }
-
-    public void setSessionMgr(ISessionManager sessionMgr) {
-        this.sessionMgr = sessionMgr;
-    }
-
-    @Override
-    public String getPassword(String username) {
-        return localUserConfigList.get(username).getPassword();
-    }
-
-    @Override
-    public boolean isRoleInUse(String role) {
-        if (role == null || role.isEmpty()) {
-            return false;
-        }
-        // Check against controller roles
-        if (role.equals(UserLevel.SYSTEMADMIN.toString())
-                || role.equals(UserLevel.NETWORKADMIN.toString())
-                || role.equals(UserLevel.NETWORKOPERATOR.toString())) {
-            return true;
-        }
-        // Check if container roles
-        if (containerAuthorizationClient != null) {
-            if (containerAuthorizationClient.isApplicationRole(role)) {
-                return true;
-            }
-        }
-        // Finally if application role
-        if (applicationAuthorizationClients != null) {
-            for (IResourceAuthorization client : this.applicationAuthorizationClients) {
-                if (client.isApplicationRole(role)) {
-                    return true;
-                }
-            }
-        }
-        return false;
-    }
-}
diff --git a/opendaylight/adsal/usermanager/implementation/src/main/java/org/opendaylight/controller/usermanager/security/SessionManager.java b/opendaylight/adsal/usermanager/implementation/src/main/java/org/opendaylight/controller/usermanager/security/SessionManager.java
deleted file mode 100644 (file)
index 5201a6d..0000000
+++ /dev/null
@@ -1,104 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.usermanager.security;
-
-import java.util.ArrayList;
-import java.util.HashMap;
-import java.util.HashSet;
-import java.util.Iterator;
-import java.util.List;
-import java.util.Map;
-import java.util.Map.Entry;
-import java.util.Set;
-
-import javax.servlet.ServletContext;
-import javax.servlet.http.HttpSession;
-import javax.servlet.http.HttpSessionEvent;
-
-import org.opendaylight.controller.usermanager.ISessionManager;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-public class SessionManager implements ISessionManager {
-
-    private static final Logger logger = LoggerFactory
-            .getLogger(SessionManager.class);
-
-    private Map<ServletContext, Set<HttpSession>> sessionMap = new HashMap<ServletContext, Set<HttpSession>>();
-
-    @Override
-    public void sessionCreated(HttpSessionEvent se) {
-
-        ServletContext ctx = se.getSession().getServletContext();
-        String path = ctx.getContextPath();
-
-        logger.debug("Servlet Context Path created {}", path);
-        logger.debug("Session Id created for ctxt path {}",
-                se.getSession().getId());
-
-        synchronized (sessionMap) {
-            Set<HttpSession> set = sessionMap.get(ctx);
-            if (set == null) {
-                set = new HashSet<HttpSession>();
-                sessionMap.put(ctx, set);
-            }
-            set.add(se.getSession());
-        }
-    }
-
-    @Override
-    public void sessionDestroyed(HttpSessionEvent se) {
-        ServletContext ctx = se.getSession().getServletContext();
-        String path = ctx.getContextPath();
-        logger.debug("Servlet Context Path of destroyed session - {}", path);
-        logger.debug("Session Id destroyed {}", se.getSession().getId());
-
-        synchronized (sessionMap) {
-            Set<HttpSession> set = sessionMap.get(ctx);
-            if (set != null) {
-                set.remove(se.getSession());
-            }
-        }
-    }
-
-    @Override
-    public void invalidateSessions(String username, String sessionId) {
-
-        synchronized (sessionMap) {
-            List<HttpSession> sessionsList = new ArrayList<HttpSession>();
-            Iterator<Map.Entry<ServletContext, Set<HttpSession>>> sessMapIterator = sessionMap
-                    .entrySet().iterator();
-            while (sessMapIterator.hasNext()) {
-
-                Entry<ServletContext, Set<HttpSession>> val = sessMapIterator
-                        .next();
-                Iterator<HttpSession> sessIterator = val.getValue().iterator();
-
-                while (sessIterator.hasNext()) {
-                    HttpSession session = sessIterator.next();
-                    if (session != null && sessionId != null && session.getId() != null && !session.getId().equals(sessionId)) {
-                        sessionsList.add(session);
-                        sessIterator.remove();
-                    }
-                    else {
-                        logger.debug(" session or sessionId is null ");
-                    }
-                }
-            }
-
-            Iterator<HttpSession> sessionIt = sessionsList.iterator();
-            while (sessionIt.hasNext()) {
-                HttpSession session = sessionIt.next();
-                sessionIt.remove();
-                session.invalidate();
-            }
-        }
-    }
-
-}
diff --git a/opendaylight/adsal/usermanager/implementation/src/main/java/org/opendaylight/controller/usermanager/security/UserSecurityContextRepository.java b/opendaylight/adsal/usermanager/implementation/src/main/java/org/opendaylight/controller/usermanager/security/UserSecurityContextRepository.java
deleted file mode 100644 (file)
index 655f77d..0000000
+++ /dev/null
@@ -1,42 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.usermanager.security;
-
-import javax.servlet.http.HttpServletRequest;
-import javax.servlet.http.HttpServletResponse;
-
-import org.springframework.security.core.context.SecurityContext;
-import org.springframework.security.web.context.HttpRequestResponseHolder;
-import org.springframework.security.web.context.HttpSessionSecurityContextRepository;
-import org.springframework.security.web.context.SecurityContextRepository;
-
-public class UserSecurityContextRepository implements
-        SecurityContextRepository {
-
-    HttpSessionSecurityContextRepository securityContextRepository = new HttpSessionSecurityContextRepository();
-
-    @Override
-    public SecurityContext loadContext(
-            HttpRequestResponseHolder requestResponseHolder) {
-        return securityContextRepository.loadContext(requestResponseHolder);
-    }
-
-    @Override
-    public void saveContext(SecurityContext context,
-            HttpServletRequest request, HttpServletResponse response) {
-        securityContextRepository.saveContext(context, request, response);
-    }
-
-    @Override
-    public boolean containsContext(HttpServletRequest request) {
-        return securityContextRepository.containsContext(request);
-    }
-
-}
diff --git a/opendaylight/adsal/usermanager/implementation/src/test/java/org/opendaylight/controller/usermanager/internal/UserManagerImplTest.java b/opendaylight/adsal/usermanager/implementation/src/test/java/org/opendaylight/controller/usermanager/internal/UserManagerImplTest.java
deleted file mode 100644 (file)
index f2cbe78..0000000
+++ /dev/null
@@ -1,276 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.usermanager.internal;
-
-import static org.junit.Assert.assertEquals;
-import static org.junit.Assert.assertFalse;
-import static org.junit.Assert.assertTrue;
-
-import java.util.ArrayList;
-import java.util.List;
-import java.util.concurrent.ConcurrentHashMap;
-
-import org.junit.Assert;
-import org.junit.BeforeClass;
-import org.junit.Test;
-import org.opendaylight.controller.sal.authorization.AuthResultEnum;
-import org.opendaylight.controller.sal.authorization.UserLevel;
-import org.opendaylight.controller.sal.utils.ServiceHelper;
-import org.opendaylight.controller.usermanager.AuthResponse;
-import org.opendaylight.controller.usermanager.AuthenticatedUser;
-import org.opendaylight.controller.usermanager.IAAAProvider;
-import org.opendaylight.controller.usermanager.IUserManager;
-import org.opendaylight.controller.usermanager.ServerConfig;
-import org.opendaylight.controller.usermanager.UserConfig;
-import org.opendaylight.controller.usermanager.AuthorizationConfig;
-
-/**
- * Unit Tests for UserManager
- */
-public class UserManagerImplTest {
-
-    private static UserManager um;
-
-    /**
-     * @throws java.lang.Exception
-     */
-    @BeforeClass
-    public static void setUpBeforeClass() throws Exception {
-
-        IUserManager userManager = (IUserManager) ServiceHelper
-                .getGlobalInstance(IUserManager.class, new Object());
-        if (userManager instanceof UserManager) {
-            um = (UserManager) userManager;
-        } else {
-            um = new UserManager();
-            um.setAuthProviders(new ConcurrentHashMap<String, IAAAProvider>());
-
-            // mock up a remote server list with a dummy server
-            um.setRemoteServerConfigList(new ConcurrentHashMap<String, ServerConfig>() {
-                static final long serialVersionUID = 1L;
-                {
-                    put("dummyServerConfig", new ServerConfig() {
-                        // Server config can't be empty
-                        static final long serialVersionUID = 8645L;
-
-                        @Override
-                        public String getAddress() {
-                            return "1.1.1.1";
-                        }
-
-                        @Override
-                        public String getSecret() {
-                            return "secret";
-                        }
-
-                        @Override
-                        public String getProtocol() {
-                            return "IPv4";
-                        }
-                    });
-                }
-            });
-
-            // mock up a localUserConfigList with an admin user
-            um.setLocalUserConfigList(new ConcurrentHashMap<String, UserConfig>() {
-                static final long serialVersionUID = 2L;
-                {
-                    List<String> roles = new ArrayList<String>(1);
-                    roles.add(UserLevel.SYSTEMADMIN.toString());
-                    put("admin", new UserConfig("admin",
-                            "7029,7455,8165,7029,7881", roles));
-                }
-            });
-
-            um.setAuthorizationConfList(new ConcurrentHashMap<String, AuthorizationConfig>() {
-                static final long serialVersionUID = 2L;
-                {
-                    List<String> roles = new ArrayList<String>(3);
-                    roles.add(UserLevel.NETWORKOPERATOR.toString());
-                    roles.add("Container1-Admin");
-                    roles.add("Application2-User");
-
-                    put("Andrew", new AuthorizationConfig("Andrew", roles));
-                }
-            });
-            // instantiate an empty activeUser collection
-            um.setActiveUsers(new ConcurrentHashMap<String, AuthenticatedUser>());
-        }
-    }
-
-    private IAAAProvider getAnonymousAAAProvider(final String providerName) {
-        // instantiate an anonymous AAAProvider
-        return new IAAAProvider() {
-
-            @Override
-            public AuthResponse authService(String userName, String password,
-                    String server, String secretKey) {
-                return new AuthResponse();
-            };
-
-            @Override
-            public String getName() {
-                return providerName;
-            }
-        };
-    }
-
-    /**
-     * Test method for
-     * {@link org.opendaylight.controller.usermanager.internal.UserManager#addAAAProvider(org.opendaylight.controller.usermanager.IAAAProvider)}
-     * and for
-     * {@link org.opendaylight.controller.usermanager.internal.UserManager#removeAAAProvider(org.opendaylight.controller.usermanager.IAAAProvider)}
-     * and
-     * {@link org.opendaylight.controller.usermanager.internal.UserManager#getAAAProvider(java.lang.String)}
-     */
-    @Test
-    public void testAddGetRemoveAAAProvider() {
-        final String providerName = "dummyAAAProvider";
-        IAAAProvider a3p = getAnonymousAAAProvider(providerName);
-        um.addAAAProvider(a3p);
-        assertEquals(a3p, um.getAAAProvider(providerName));
-        um.removeAAAProvider(um.getAAAProvider(providerName));
-        assertTrue(um.getAAAProviderNames().isEmpty());
-    }
-
-    /**
-     * Test method for
-     * {@link org.opendaylight.controller.usermanager.internal.UserManager#authenticate(java.lang.String, java.lang.String)}
-     * .
-     */
-    @Test
-    public void testAuthenticateStringString() {
-        List<String> roles = new ArrayList<String>(1);
-        roles.add(UserLevel.SYSTEMADMIN.toString());
-        UserConfig uc = new UserConfig("administrator", "admin", roles);
-        um.addLocalUser(uc);
-        AuthResultEnum authResult = um.authenticate("administrator", "admin");
-        assertEquals(authResult, AuthResultEnum.AUTH_ACCEPT_LOC);
-    }
-
-    /**
-     * Test method for
-     * {@link org.opendaylight.controller.usermanager.internal.UserManager#addRemoveLocalUser(org.opendaylight.controller.usermanager.org.opendaylight.controller.usermanager.internal.UserConfig, boolean)}
-     * .
-     */
-    @Test
-    public void testAddRemoveLocalUser() {
-        List<String> roles = new ArrayList<String>(1);
-        roles.add(UserLevel.SYSTEMADMIN.toString());
-        UserConfig uc = new UserConfig("sysadmin", "7029,7455,8165,7029,7881",
-                roles);
-        um.addLocalUser(uc);
-        assertTrue(um.getLocalUserList().contains(uc));
-        um.removeLocalUser(uc);
-        assertFalse(um.getLocalUserList().contains(uc));
-    }
-
-    /**
-     * Test method for
-     * {@link org.opendaylight.controller.usermanager.internal.UserManager#changeLocalUserPassword(java.lang.String, java.lang.String, java.lang.String)}
-     * .
-     */
-    @Test
-    public void testChangeLocalUserPassword() {
-        // fail("Not yet implemented");
-    }
-
-    /**
-     * Test method for
-     * {@link org.opendaylight.controller.usermanager.internal.UserManager#userLogout(java.lang.String)}
-     * .
-     */
-    @Test
-    public void testUserLogout() {
-        // fail("Not yet implemented");
-    }
-
-    /**
-     * Test method for
-     * {@link org.opendaylight.controller.usermanager.internal.UserManager#userTimedOut(java.lang.String)}
-     * .
-     */
-    @Test
-    public void testUserTimedOut() {
-        // fail("Not yet implemented");
-    }
-
-    /**
-     * Test method for
-     * {@link org.opendaylight.controller.usermanager.internal.UserManager#authenticate(org.springframework.security.core.Authentication)}
-     * .
-     */
-    @Test
-    public void testAuthenticateAuthentication() {
-        // fail("Not yet implemented");
-    }
-
-    /**
-     * Test method for
-     * {@link org.opendaylight.controller.usermanager.internal.UserManager#saveLocalUserList()}
-     * .
-     */
-    @Test
-    public void testSaveLocalUserList() {
-        // fail("Not yet implemented");
-    }
-
-    /**
-     * Test method for
-     * {@link org.opendaylight.controller.usermanager.internal.UserManager#saveAAAServerList()}
-     * .
-     */
-    @Test
-    public void testSaveAAAServerList() {
-        // fail("Not yet implemented");
-    }
-
-    /**
-     * Test method for
-     * {@link org.opendaylight.controller.usermanager.internal.UserManager#saveAuthorizationList()}
-     * .
-     */
-    @Test
-    public void testSaveAuthorizationList() {
-        // fail("Not yet implemented");
-    }
-
-    /**
-     * Test method for
-     * {@link org.opendaylight.controller.usermanager.internal.UserManager#readObject(java.io.ObjectInputStream)}
-     * .
-     */
-    @Test
-    public void testReadObject() {
-        // fail("Not yet implemented");
-    }
-
-    @Test
-    public void testGetUserLevel() {
-        List<String> roles = new ArrayList<String>(2);
-        roles.add(UserLevel.SYSTEMADMIN.toString());
-        roles.add("App1_supervisor");
-        um.addLocalUser(new UserConfig("Jack", "password", roles));
-        um.authenticate("Jack", "password");
-
-        roles.clear();
-        roles.add("App2Admin");
-        roles.add(UserLevel.NETWORKOPERATOR.toString());
-        um.addLocalUser(new UserConfig("John", "password", roles));
-
-        // Run the check on authenticated user
-        Assert.assertTrue(um.getUserLevel("Jack") == UserLevel.SYSTEMADMIN);
-        // Run the check on configured users
-        Assert.assertTrue(um.getUserLevel("John") == UserLevel.NETWORKOPERATOR);
-        // Run the check on local authorized users
-        Assert.assertTrue(um.getUserLevel("Andrew") == UserLevel.NETWORKOPERATOR);
-        // Non locally known user
-        Assert.assertTrue(um.getUserLevel("Tom") == UserLevel.NOUSER);
-    }
-}
diff --git a/opendaylight/adsal/web/brandfragment/pom.xml b/opendaylight/adsal/web/brandfragment/pom.xml
deleted file mode 100644 (file)
index 171ac3f..0000000
+++ /dev/null
@@ -1,39 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
-         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-
-    <modelVersion>4.0.0</modelVersion>
-    <parent>
-        <groupId>org.opendaylight.controller</groupId>
-        <artifactId>commons.opendaylight</artifactId>
-        <version>1.6.0-SNAPSHOT</version>
-        <relativePath>../../../commons/opendaylight</relativePath>
-    </parent>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>web.brandfragment</artifactId>
-    <version>0.6.0-SNAPSHOT</version>
-    <packaging>bundle</packaging>
-
-    <build>
-        <plugins>
-            <plugin>
-                <groupId>org.apache.felix</groupId>
-                <artifactId>maven-bundle-plugin</artifactId>
-                <version>${bundle.plugin.version}</version>
-                <extensions>true</extensions>
-                <configuration>
-                    <instructions>
-                        <Fragment-Host>org.opendaylight.controller.web</Fragment-Host>
-                        <Web-ContextPath>/</Web-ContextPath>
-                    </instructions>
-                </configuration>
-            </plugin>
-        </plugins>
-    </build>
-</project>
diff --git a/opendaylight/adsal/web/brandfragment/src/main/resources/WEB-INF/jsp/customerror.jsp b/opendaylight/adsal/web/brandfragment/src/main/resources/WEB-INF/jsp/customerror.jsp
deleted file mode 100644 (file)
index 47de972..0000000
+++ /dev/null
@@ -1,3 +0,0 @@
-<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
-<c:set var="title" value="Open Daylight - Error" scope="application"/>
-<link rel="stylesheet/less" type="text/css" href="/css/customlogin.less">
diff --git a/opendaylight/adsal/web/brandfragment/src/main/resources/WEB-INF/jsp/customlogin.jsp b/opendaylight/adsal/web/brandfragment/src/main/resources/WEB-INF/jsp/customlogin.jsp
deleted file mode 100644 (file)
index f2adf1f..0000000
+++ /dev/null
@@ -1,3 +0,0 @@
-<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
-<c:set var="title" value="Open Daylight - Login" scope="application"/>
-<link rel="stylesheet/less" type="text/css" href="/css/customlogin.less">
diff --git a/opendaylight/adsal/web/brandfragment/src/main/resources/WEB-INF/jsp/custommain.jsp b/opendaylight/adsal/web/brandfragment/src/main/resources/WEB-INF/jsp/custommain.jsp
deleted file mode 100644 (file)
index f079c82..0000000
+++ /dev/null
@@ -1,4 +0,0 @@
-<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
-<c:set var="version" value="Version 0.1" scope="application"/>
-<c:set var="name" value="Open Daylight" scope="application"/>
-<link rel="stylesheet/less" type="text/css" href="/css/custommain.less">
diff --git a/opendaylight/adsal/web/brandfragment/src/main/resources/css/customlogin.less b/opendaylight/adsal/web/brandfragment/src/main/resources/css/customlogin.less
deleted file mode 100644 (file)
index cdaba23..0000000
+++ /dev/null
@@ -1,53 +0,0 @@
-.reset {
-       padding: 0;
-       margin: 0;
-}
-
-html , body {
-       .reset;
-       height: 100%;
-       width: 100%;
-       background-color: #eee;
-}
-
-html {
-       display: table;
-}
-
-body {
-       display: table-cell;
-       vertical-align: middle;
-       padding-bottom: 10%;
-}
-
-.container {
-       width: 650px;
-       .content {
-               padding: 25px;
-               background-color: #fff;
-               -webkit-border-radius: 10px;
-               -moz-border-radius: 10px;
-               border-radius: 10px;
-               -webkit-box-shadow: 0 1px 2px rgba(0, 0, 0, .15);
-               -moz-box-shadow: 0 1px 2px rgba(0, 0, 0, .15);
-               box-shadow: 0 1px 2px rgba(0, 0, 0, .15);
-               text-align: center;
-               .login-form {
-                       #logo {
-                               background-repeat: no-repeat;
-                               background-position: center;
-                               background-image: url('');
-                               width: 400px;
-                               height: 175px;
-                               margin: 0 auto 20px;
-                       }
-                       .icon-login {
-                               width: 20px;
-                               height: 16px;
-                               background-position: left center;
-                               background-repeat: no-repeat;
-                               background-image: url('');
-                       }
-               }
-       }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/web/brandfragment/src/main/resources/css/custommain.less b/opendaylight/adsal/web/brandfragment/src/main/resources/css/custommain.less
deleted file mode 100644 (file)
index cb6fbc5..0000000
+++ /dev/null
@@ -1,260 +0,0 @@
-// properties
-@mainTop: 43px;
-@mainBottom: 41px;
-
-@minWidth: 640px;
-@minHeight: 480px;
-
-@topologyOffset: -4px; // ensure calibration
-
-// mixins
-.dash-size (@width, @height) {
-       width: @width;
-       height: @height;
-}
-.position (@type, @top, @right, @bottom, @left) {
-       position: @type;
-       top: @top;
-       right: @right;
-       bottom: @bottom;
-       left: @left;
-}
-.dash-position (@top, @right, @bottom, @left) {
-       .position(absolute, @top, @right, @bottom, @left);
-}
-.icon {
-       width: 22px;
-       height: 16px;
-       background-position: left center;
-       background-repeat: no-repeat;
-}
-.dashlet-elements {
-       width: 98%;
-       margin: 5px auto;
-}
-
-// header
-#menu {
-       .navbar-inner {
-               .brand {
-                       font-size: 1.4em;
-                       font-variant: small-caps;
-                       margin: 0 12px;
-                       padding: 10px 0 10px 45px;
-                       background-image: url('../img/logo.png');
-                       background-position: left center;
-                       background-repeat: no-repeat;
-               }
-               ul {
-                       margin-top: 10px;
-                       border-bottom: transparent;
-                       li {
-                               a {
-                                       padding: 5px 15px;
-                                       &:hover {
-                                               border-color: transparent;
-                                       }
-                               }
-                       }
-                       .active {
-                               a {
-                                       border-radius: 1px;
-                                       background: #f6f6f6;
-                                       &:hover {
-                                               border-top: 1px solid #ddd;
-                                               border-right: 1px solid #ddd;
-                                               border-left: 1px solid #ddd;
-                                       }
-                               }
-                       }
-               }
-               #toolbar {
-                       position: absolute;
-                       right: 10px;
-                       .dropdown-menu {
-                               right: 0;
-                               left: auto;
-                               min-width: 120px;
-                       }
-                       .icon-user {
-                               .icon;
-                               background-image: url('../img/user_0020_16.png');
-                       }
-                       .icon-users {
-                               .icon;
-                               background-image: url('../img/user_group_0107_16.png');
-                       }
-                       .icon-save {
-                               .icon;
-                               background-image: url('../img/save_as_0106_16.png');
-                       }
-                       .icon-logout {
-                               .icon;
-                               background-image: url('../img/open_1054_16.png');
-                       }
-               }
-       }
-}
-
-// footer
-#footer {
-       #alert {
-               margin: 0;
-               p {
-                       padding: 0;
-                       margin: 0;
-               }
-       }
-}
-
-// main
-#main {
-       position: fixed;
-       top: @mainTop;
-       right: 0;
-       bottom: @mainBottom;
-       left: 0;
-       min-width: @minWidth;
-       min-height: @minHeight;
-
-       // topology
-       #topology {
-               position: absolute;
-               top: @topologyOffset;
-               right: 0;
-               bottom: @topologyOffset;
-               left: 0;
-               background: #ddd;
-       }
-
-       // left
-       #left {
-               .dash-size(30%, 100%);
-               float: left;
-
-               #left-top {
-                       .dash-size(100%, 60%);
-
-                       .dash { 
-                               .dash-position(5px, 5px, 5px, 5px);
-                       }
-               }
-
-               #left-bottom {
-                       .dash-size(100%, 40%);
-
-                       .dash {
-                               .dash-position(0, 5px, 5px, 5px);
-                       }
-               }
-       }
-
-       // right
-       #right {
-               .dash-size(70%, 100%);
-               float: right;
-
-               #right-top {
-                       .dash-size(100%, 60%);
-
-                       .dash {
-                               .dash-position(5px, 5px, 5px, 0);
-                       }
-               }
-
-               #right-bottom {
-                       .dash-size(100%, 40%);
-
-                       .dash {
-                               .dash-position(0, 5px, 5px, 0);
-                       }
-               }
-       }
-
-       #left-top, #left-bottom,
-       #right-top, #right-bottom {
-               position: relative;
-       }
-
-       // dashentries
-       .dash {
-               border-radius: 1px;
-               background: #fff;
-               border: 1px solid #ddd;
-
-               .nav {
-                       padding: 2px;
-                       padding-bottom: 0;
-                       margin: 0;
-               }
-
-               .nav-tabs {
-                       background: #eee;
-                       li {
-                               a {
-                                       background: #ddd;
-                                       padding: 4px 8px;
-                                       margin-right: 3px;
-                                       border-radius: 1px;
-                                       &:hover {
-                                               border-color: transparent;
-                                       }
-                               }
-                       }
-                       .active {
-                               a {
-                                       background: #fff;
-                                       border-radius: 1px;
-                                       &:hover {
-                                               border-top: 1px solid #ddd;
-                                               border-left: 1px solid #ddd;
-                                               border-right: 1px solid #ddd;
-                                       }
-                               }
-                       }
-               }
-
-               .dashlet {
-                       overflow: auto;
-                       .dash-position(45px,0,0,0);
-
-                       h4 {
-                               .dashlet-elements;
-                       }
-
-                       p {
-                               .dashlet-elements;
-                       }
-
-                       table {
-                               .dashlet-elements;
-                       }
-                       
-                       .btn-group {
-                               margin: 5px;
-                       }
-                       
-                       .none {
-                               margin: 0 auto;
-                               padding-top: 128px;
-                               background-position: center;
-                               background-repeat: no-repeat;
-                               background-image: url('../img/alert_unreachable_2008_128.png');
-                               text-align: center;
-                               p {
-                                       cursor: default;
-                               }
-                       }
-               }
-       }
-
-       // defaults for visual topology
-       #right-top .dash {
-               background: #ddd;
-               overflow: hidden;
-       }
-}
-
-.table-cursor tr:hover {
-       cursor: pointer;
-}
diff --git a/opendaylight/adsal/web/brandfragment/src/main/resources/img/logo.png b/opendaylight/adsal/web/brandfragment/src/main/resources/img/logo.png
deleted file mode 100644 (file)
index 46c02e2..0000000
Binary files a/opendaylight/adsal/web/brandfragment/src/main/resources/img/logo.png and /dev/null differ
diff --git a/opendaylight/adsal/web/devices/pom.xml b/opendaylight/adsal/web/devices/pom.xml
deleted file mode 100644 (file)
index 56ad7e7..0000000
+++ /dev/null
@@ -1,122 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>devices.web</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>com.fasterxml.jackson.core</groupId>
-      <artifactId>jackson-databind</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>connectionmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>containermanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>forwarding.staticrouting</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>forwardingrulesmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>switchmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>web</artifactId>
-    </dependency>
-  </dependencies>
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Export-Package></Export-Package>
-            <Import-Package>org.opendaylight.controller.forwardingrulesmanager,
-              org.opendaylight.controller.sal.authorization,
-              org.opendaylight.controller.sal.action,
-              org.opendaylight.controller.sal.connection,
-              org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.sal.utils,
-              org.opendaylight.controller.containermanager,
-              org.opendaylight.controller.connectionmanager,
-              org.opendaylight.controller.switchmanager,
-              org.opendaylight.controller.forwarding.staticrouting,
-              org.opendaylight.controller.usermanager,
-              org.opendaylight.controller.web,
-              com.google.gson,
-              com.google.gson.reflect,
-              javax.annotation,
-              javax.naming,
-              javax.servlet,
-              javax.servlet.annotation,
-              javax.servlet.http,
-              javax.servlet.jsp,
-              javax.servlet.jsp.el,
-              javax.servlet.jsp.jstl.core,
-              javax.servlet.jsp.jstl.fmt,
-              javax.servlet.jsp.jstl.tlv,
-              javax.servlet.jsp.tagext,
-              javax.servlet.resources,
-              javax.xml.parsers,
-              javax.xml.transform,
-              org.apache.commons.logging,
-              org.apache.taglibs.standard.functions,
-              org.apache.taglibs.standard.resources,
-              org.apache.taglibs.standard.tag.common.core,
-              org.apache.taglibs.standard.tag.common.fmt,
-              org.apache.taglibs.standard.tag.rt.core,
-              org.apache.taglibs.standard.tag.rt.fmt,
-              org.apache.taglibs.standard.tei,
-              org.apache.taglibs.standard.tlv,
-              com.fasterxml.jackson.databind,
-              com.fasterxml.jackson.annotation,
-              org.osgi.framework,
-              org.slf4j,
-              org.springframework.beans,
-              org.springframework.beans.factory.xml,
-              org.springframework.context.config,
-              org.springframework.stereotype,
-              org.springframework.web,
-              org.springframework.web.bind.annotation,
-              org.springframework.web.servlet,
-              org.springframework.web.servlet.config,
-              org.springframework.web.servlet.view,
-              org.springframework.web.filter,
-              org.springframework.web.context</Import-Package>
-            <Web-ContextPath>/controller/web/devices</Web-ContextPath>
-          </instructions>
-          <manifestLocation>${project.basedir}/src/main/resources/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/web/devices/src/main/java/org/opendaylight/controller/devices/web/Devices.java b/opendaylight/adsal/web/devices/src/main/java/org/opendaylight/controller/devices/web/Devices.java
deleted file mode 100644 (file)
index a9f11fa..0000000
+++ /dev/null
@@ -1,869 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.devices.web;
-
-import java.lang.reflect.Type;
-import java.util.ArrayList;
-import java.util.HashMap;
-import java.util.Iterator;
-import java.util.LinkedList;
-import java.util.List;
-import java.util.Map;
-import java.util.Map.Entry;
-import java.util.Set;
-import java.util.TreeMap;
-import java.util.concurrent.ConcurrentMap;
-
-import javax.servlet.http.HttpServletRequest;
-import javax.servlet.http.HttpServletResponse;
-
-import org.opendaylight.controller.connectionmanager.IConnectionManager;
-import org.opendaylight.controller.forwarding.staticrouting.IForwardingStaticRouting;
-import org.opendaylight.controller.forwarding.staticrouting.StaticRouteConfig;
-import org.opendaylight.controller.sal.authorization.Privilege;
-import org.opendaylight.controller.sal.authorization.UserLevel;
-import org.opendaylight.controller.sal.connection.ConnectionConstants;
-import org.opendaylight.controller.sal.core.Config;
-import org.opendaylight.controller.sal.core.Description;
-import org.opendaylight.controller.sal.core.ForwardingMode;
-import org.opendaylight.controller.sal.core.Name;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.core.State;
-import org.opendaylight.controller.sal.core.Tier;
-import org.opendaylight.controller.sal.utils.GlobalConstants;
-import org.opendaylight.controller.sal.utils.HexEncode;
-import org.opendaylight.controller.sal.utils.NetUtils;
-import org.opendaylight.controller.sal.utils.ServiceHelper;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.sal.utils.StatusCode;
-import org.opendaylight.controller.sal.utils.TierHelper;
-import org.opendaylight.controller.switchmanager.ISwitchManager;
-import org.opendaylight.controller.switchmanager.SpanConfig;
-import org.opendaylight.controller.switchmanager.SubnetConfig;
-import org.opendaylight.controller.switchmanager.Switch;
-import org.opendaylight.controller.switchmanager.SwitchConfig;
-import org.opendaylight.controller.web.DaylightWebUtil;
-import org.opendaylight.controller.web.IDaylightWeb;
-import org.springframework.stereotype.Controller;
-import org.springframework.web.bind.annotation.PathVariable;
-import org.springframework.web.bind.annotation.RequestMapping;
-import org.springframework.web.bind.annotation.RequestMethod;
-import org.springframework.web.bind.annotation.RequestParam;
-import org.springframework.web.bind.annotation.ResponseBody;
-
-import com.fasterxml.jackson.databind.ObjectMapper;
-import com.google.gson.Gson;
-import com.google.gson.reflect.TypeToken;
-
-@Controller
-@RequestMapping("/")
-public class Devices implements IDaylightWeb {
-    private static final UserLevel AUTH_LEVEL = UserLevel.CONTAINERUSER;
-    private static final String WEB_NAME = "Devices";
-    private static final String WEB_ID = "devices";
-    private static final short WEB_ORDER = 1;
-
-    public Devices() {
-        ServiceHelper.registerGlobalService(IDaylightWeb.class, this, null);
-    }
-
-    @Override
-    public String getWebName() {
-        return WEB_NAME;
-    }
-
-    @Override
-    public String getWebId() {
-        return WEB_ID;
-    }
-
-    @Override
-    public short getWebOrder() {
-        return WEB_ORDER;
-    }
-
-    @Override
-    public boolean isAuthorized(UserLevel userLevel) {
-        return userLevel.ordinal() <= AUTH_LEVEL.ordinal();
-    }
-
-    @RequestMapping(value = "/nodesLearnt", method = RequestMethod.GET)
-    @ResponseBody
-    public DevicesJsonBean getNodesLearnt(HttpServletRequest request, @RequestParam(required = false) String container) {
-        Gson gson = new Gson();
-        String containerName = (container == null) ? GlobalConstants.DEFAULT.toString() : container;
-
-        // Derive the privilege this user has on the current container
-        String userName = request.getUserPrincipal().getName();
-        Privilege privilege = DaylightWebUtil.getContainerPrivilege(userName, containerName, this);
-
-        ISwitchManager switchManager = (ISwitchManager) ServiceHelper.getInstance(ISwitchManager.class, containerName,
-                this);
-        List<Map<String, String>> nodeData = new ArrayList<Map<String, String>>();
-        if (switchManager != null && privilege != Privilege.NONE) {
-            for (Switch device : switchManager.getNetworkDevices()) {
-                HashMap<String, String> nodeDatum = new HashMap<String, String>();
-                Node node = device.getNode();
-                Tier tier = (Tier) switchManager.getNodeProp(node, Tier.TierPropName);
-                nodeDatum.put("containerName", containerName);
-                Description description = (Description) switchManager.getNodeProp(node, Description.propertyName);
-                String desc = (description == null) ? "" : description.getValue();
-                nodeDatum.put("nodeName", desc);
-                nodeDatum.put("nodeId", node.toString());
-                int tierNumber = (tier == null) ? TierHelper.unknownTierNumber : tier.getValue();
-                nodeDatum.put("tierName", TierHelper.getTierName(tierNumber) + " (Tier-" + tierNumber + ")");
-                nodeDatum.put("tier", tierNumber + "");
-                String modeStr = "0";
-                ForwardingMode mode = null;
-                if (!containerName.equals(GlobalConstants.DEFAULT.toString())) {
-                    ISwitchManager switchManagerDefault = (ISwitchManager) ServiceHelper.getInstance(
-                            ISwitchManager.class, GlobalConstants.DEFAULT.toString(), this);
-                    mode = (ForwardingMode) switchManagerDefault.getNodeProp(node, ForwardingMode.name);
-                } else {
-                    mode = (ForwardingMode) switchManager.getNodeProp(node, ForwardingMode.name);
-                }
-                if (mode != null) {
-                    modeStr = String.valueOf(mode.getValue());
-                }
-                nodeDatum.put("mode", modeStr);
-
-                nodeDatum.put("json", gson.toJson(nodeDatum));
-                nodeDatum.put("mac", HexEncode.bytesToHexStringFormat(device.getDataLayerAddress()));
-                StringBuffer sb1 = new StringBuffer();
-                Set<NodeConnector> nodeConnectorSet = device.getNodeConnectors();
-                if (nodeConnectorSet != null && nodeConnectorSet.size() > 0) {
-                    Map<Short, String> portList = new HashMap<Short, String>();
-                    List<String> intfList = new ArrayList<String>();
-                    for (NodeConnector nodeConnector : nodeConnectorSet) {
-                        String nodeConnectorNumberToStr = nodeConnector.getID().toString();
-                        Name ncName = ((Name) switchManager.getNodeConnectorProp(nodeConnector, Name.NamePropName));
-                        Config portConfig = ((Config) switchManager.getNodeConnectorProp(nodeConnector,
-                                Config.ConfigPropName));
-                        State portState = ((State) switchManager.getNodeConnectorProp(nodeConnector,
-                                State.StatePropName));
-                        String nodeConnectorName = (ncName != null) ? ncName.getValue() : "";
-                        nodeConnectorName += " (" + nodeConnector.getID() + ")";
-
-                        if (portConfig != null) {
-                            if (portConfig.getValue() == Config.ADMIN_UP) {
-                                if (portState != null && portState.getValue() == State.EDGE_UP) {
-                                    nodeConnectorName = "<span class='admin-up'>" + nodeConnectorName + "</span>";
-                                } else if (portState == null || portState.getValue() == State.EDGE_DOWN) {
-                                    nodeConnectorName = "<span class='edge-down'>" + nodeConnectorName + "</span>";
-                                }
-                            } else if (portConfig.getValue() == Config.ADMIN_DOWN) {
-                                nodeConnectorName = "<span class='admin-down'>" + nodeConnectorName + "</span>";
-                            }
-                        }
-
-                        Class<?> idClass = nodeConnector.getID().getClass();
-                        if (idClass.equals(Short.class)) {
-                            portList.put(Short.parseShort(nodeConnectorNumberToStr), nodeConnectorName);
-                        } else {
-                            intfList.add(nodeConnectorName);
-                        }
-                    }
-
-                    if (portList.size() > 0) {
-                        Map<Short, String> sortedPortList = new TreeMap<Short, String>(portList);
-
-                        for (Entry<Short, String> e : sortedPortList.entrySet()) {
-                            sb1.append(e.getValue());
-                            sb1.append("<br>");
-                        }
-                    } else if (intfList.size() > 0) {
-                        for (String intf : intfList) {
-                            sb1.append(intf);
-                            sb1.append("<br>");
-                        }
-                    }
-                }
-                nodeDatum.put("ports", sb1.toString());
-                nodeData.add(nodeDatum);
-            }
-        }
-
-        DevicesJsonBean result = new DevicesJsonBean();
-        result.setNodeData(nodeData);
-        result.setPrivilege(privilege);
-        List<String> columnNames = new ArrayList<String>();
-        columnNames.add("Node ID");
-        columnNames.add("Node Name");
-        columnNames.add("Tier");
-        columnNames.add("Mac Address");
-        columnNames.add("Ports");
-        columnNames.add("Port Status");
-
-        result.setColumnNames(columnNames);
-        return result;
-    }
-
-    @RequestMapping(value = "/tiers", method = RequestMethod.GET)
-    @ResponseBody
-    public List<String> getTiers() {
-        return TierHelper.getTiers();
-    }
-
-    @RequestMapping(value = "/nodesLearnt/update", method = RequestMethod.GET)
-    @ResponseBody
-    public StatusJsonBean updateLearntNode(@RequestParam("nodeName") String nodeName,
-            @RequestParam("nodeId") String nodeId, @RequestParam("tier") String tier,
-            @RequestParam("operationMode") String operationMode, HttpServletRequest request,
-            @RequestParam(required = false) String container) {
-        String containerName = (container == null) ? GlobalConstants.DEFAULT.toString() : container;
-
-        // Authorization check
-        String userName = request.getUserPrincipal().getName();
-        if (DaylightWebUtil.getContainerPrivilege(userName, containerName, this) != Privilege.WRITE) {
-            return unauthorizedMessage();
-        }
-
-        StatusJsonBean resultBean = new StatusJsonBean();
-        try {
-            ISwitchManager switchManager = (ISwitchManager) ServiceHelper.getInstance(ISwitchManager.class,
-                    containerName, this);
-            Map<String, Property> nodeProperties = new HashMap<String, Property>();
-            Property desc = new Description(nodeName);
-            nodeProperties.put(desc.getName(), desc);
-            Property nodeTier = new Tier(Integer.parseInt(tier));
-            nodeProperties.put(nodeTier.getName(), nodeTier);
-            if (containerName.equals(GlobalConstants.DEFAULT.toString())) {
-                Property mode = new ForwardingMode(Integer.parseInt(operationMode));
-                nodeProperties.put(mode.getName(), mode);
-            }
-            SwitchConfig cfg = new SwitchConfig(nodeId, nodeProperties);
-            Status result = switchManager.updateNodeConfig(cfg);
-            if (!result.isSuccess()) {
-                resultBean.setStatus(false);
-                resultBean.setMessage(result.getDescription());
-            } else {
-                resultBean.setStatus(true);
-                resultBean.setMessage("Updated node information successfully");
-                DaylightWebUtil.auditlog("Property", userName, "updated",
-                        "of Node " + DaylightWebUtil.getNodeDesc(Node.fromString(nodeId), switchManager));
-            }
-        } catch (Exception e) {
-            resultBean.setStatus(false);
-            resultBean.setMessage("Error updating node information. " + e.getMessage());
-        }
-        return resultBean;
-    }
-
-    @RequestMapping(value = "/staticRoutes", method = RequestMethod.GET)
-    @ResponseBody
-    public DevicesJsonBean getStaticRoutes(HttpServletRequest request, @RequestParam(required = false) String container) {
-        Gson gson = new Gson();
-        String containerName = (container == null) ? GlobalConstants.DEFAULT.toString() : container;
-
-        // Derive the privilege this user has on the current container
-        String userName = request.getUserPrincipal().getName();
-        Privilege privilege = DaylightWebUtil.getContainerPrivilege(userName, containerName, this);
-
-        IForwardingStaticRouting staticRouting = (IForwardingStaticRouting) ServiceHelper.getInstance(
-                IForwardingStaticRouting.class, containerName, this);
-        if (staticRouting == null) {
-            return null;
-        }
-        List<Map<String, String>> staticRoutes = new ArrayList<Map<String, String>>();
-        ConcurrentMap<String, StaticRouteConfig> routeConfigs = staticRouting.getStaticRouteConfigs();
-        if (routeConfigs == null) {
-            return null;
-        }
-        if (privilege != Privilege.NONE) {
-            for (StaticRouteConfig conf : routeConfigs.values()) {
-                Map<String, String> staticRoute = new HashMap<String, String>();
-                staticRoute.put("name", conf.getName());
-                staticRoute.put("staticRoute", conf.getStaticRoute());
-                staticRoute.put("nextHopType", conf.getNextHopType());
-                staticRoute.put("nextHop", conf.getNextHop());
-                staticRoute.put("json", gson.toJson(conf));
-                staticRoutes.add(staticRoute);
-            }
-        }
-        DevicesJsonBean result = new DevicesJsonBean();
-        result.setPrivilege(privilege);
-        result.setColumnNames(StaticRouteConfig.getGuiFieldsNames());
-        result.setNodeData(staticRoutes);
-        return result;
-    }
-
-    @RequestMapping(value = "/staticRoute/add", method = RequestMethod.GET)
-    @ResponseBody
-    public StatusJsonBean addStaticRoute(@RequestParam("routeName") String routeName,
-            @RequestParam("staticRoute") String staticRoute, @RequestParam("nextHop") String nextHop,
-            HttpServletRequest request, @RequestParam(required = false) String container) {
-        String containerName = (container == null) ? GlobalConstants.DEFAULT.toString() : container;
-
-        // Authorization check
-        String userName = request.getUserPrincipal().getName();
-        if (DaylightWebUtil.getContainerPrivilege(userName, containerName, this) != Privilege.WRITE) {
-            return unauthorizedMessage();
-        }
-
-        StatusJsonBean result = new StatusJsonBean();
-        try {
-            IForwardingStaticRouting staticRouting = (IForwardingStaticRouting) ServiceHelper.getInstance(
-                    IForwardingStaticRouting.class, containerName, this);
-            StaticRouteConfig config = new StaticRouteConfig();
-            config.setName(routeName);
-            config.setStaticRoute(staticRoute);
-            config.setNextHop(nextHop);
-            Status addStaticRouteResult = staticRouting.addStaticRoute(config);
-            if (addStaticRouteResult.isSuccess()) {
-                result.setStatus(true);
-                result.setMessage("Static Route saved successfully");
-                DaylightWebUtil.auditlog("Static Route", userName, "added", routeName, containerName);
-            } else {
-                result.setStatus(false);
-                result.setMessage(addStaticRouteResult.getDescription());
-            }
-        } catch (Exception e) {
-            result.setStatus(false);
-            result.setMessage("Error - " + e.getMessage());
-        }
-        return result;
-    }
-
-    @RequestMapping(value = "/staticRoute/delete", method = RequestMethod.GET)
-    @ResponseBody
-    public StatusJsonBean deleteStaticRoute(@RequestParam("routesToDelete") String routesToDelete,
-            HttpServletRequest request, @RequestParam(required = false) String container) {
-        String containerName = (container == null) ? GlobalConstants.DEFAULT.toString() : container;
-
-        // Authorization check
-        String userName = request.getUserPrincipal().getName();
-        if (DaylightWebUtil.getContainerPrivilege(userName, containerName, this) != Privilege.WRITE) {
-            return unauthorizedMessage();
-        }
-
-        StatusJsonBean resultBean = new StatusJsonBean();
-        try {
-            IForwardingStaticRouting staticRouting = (IForwardingStaticRouting) ServiceHelper.getInstance(
-                    IForwardingStaticRouting.class, containerName, this);
-            String[] routes = routesToDelete.split(",");
-            Status result;
-            resultBean.setStatus(true);
-            resultBean.setMessage("Successfully deleted selected static routes");
-            for (String route : routes) {
-                result = staticRouting.removeStaticRoute(route);
-                if (!result.isSuccess()) {
-                    resultBean.setStatus(false);
-                    resultBean.setMessage(result.getDescription());
-                    break;
-                }
-                DaylightWebUtil.auditlog("Static Route", userName, "removed", route, containerName);
-            }
-        } catch (Exception e) {
-            resultBean.setStatus(false);
-            resultBean.setMessage("Error occurred while deleting static routes. " + e.getMessage());
-        }
-        return resultBean;
-    }
-
-    @RequestMapping(value = "/subnets", method = RequestMethod.GET)
-    @ResponseBody
-    public DevicesJsonBean getSubnetGateways(HttpServletRequest request,
-            @RequestParam(required = false) String container) {
-        Gson gson = new Gson();
-        List<Map<String, String>> subnets = new ArrayList<Map<String, String>>();
-        String containerName = (container == null) ? GlobalConstants.DEFAULT.toString() : container;
-
-        // Derive the privilege this user has on the current container
-        String userName = request.getUserPrincipal().getName();
-        Privilege privilege = DaylightWebUtil.getContainerPrivilege(userName, containerName, this);
-
-        if (privilege != Privilege.NONE) {
-            ISwitchManager switchManager = (ISwitchManager) ServiceHelper.getInstance(ISwitchManager.class,
-                    containerName, this);
-            if (switchManager != null) {
-                for (SubnetConfig conf : switchManager.getSubnetsConfigList()) {
-                    Map<String, String> subnet = new HashMap<String, String>();
-                    subnet.put("name", conf.getName());
-                    subnet.put("subnet", conf.getSubnet());
-                    List<SubnetGatewayPortBean> portsList = new ArrayList<SubnetGatewayPortBean>();
-                    Iterator<NodeConnector> itor = conf.getNodeConnectors().iterator();
-                    while (itor.hasNext()) {
-                        SubnetGatewayPortBean bean = new SubnetGatewayPortBean();
-                        NodeConnector nodeConnector = itor.next();
-                        String nodeName = getNodeDesc(nodeConnector.getNode().toString(), containerName);
-                        Name ncName = ((Name) switchManager.getNodeConnectorProp(nodeConnector, Name.NamePropName));
-                        String nodeConnectorName = (ncName != null) ? ncName.getValue() : "";
-                        bean.setNodeName(nodeName);
-                        bean.setNodePortName(nodeConnectorName);
-                        bean.setNodeId(nodeConnector.getNode().toString());
-                        bean.setNodePortId(nodeConnector.toString());
-                        portsList.add(bean);
-                    }
-                    subnet.put("nodePorts", gson.toJson(portsList));
-                    subnets.add(subnet);
-                }
-            }
-        }
-        DevicesJsonBean result = new DevicesJsonBean();
-        result.setPrivilege(privilege);
-        result.setColumnNames(SubnetConfig.getGuiFieldsNames());
-        result.setNodeData(subnets);
-        return result;
-    }
-
-    @RequestMapping(value = "/subnetGateway/add", method = RequestMethod.GET)
-    @ResponseBody
-    public StatusJsonBean addSubnetGateways(@RequestParam("gatewayName") String gatewayName,
-            @RequestParam("gatewayIPAddress") String gatewayIPAddress, HttpServletRequest request,
-            @RequestParam(required = false) String container) {
-        String containerName = (container == null) ? GlobalConstants.DEFAULT.toString() : container;
-
-        // Authorization check
-        String userName = request.getUserPrincipal().getName();
-        if (DaylightWebUtil.getContainerPrivilege(userName, containerName, this) != Privilege.WRITE) {
-            return unauthorizedMessage();
-        }
-
-        StatusJsonBean resultBean = new StatusJsonBean();
-        try {
-            ISwitchManager switchManager = (ISwitchManager) ServiceHelper.getInstance(ISwitchManager.class,
-                    containerName, this);
-            SubnetConfig cfgObject = new SubnetConfig(gatewayName, gatewayIPAddress, new ArrayList<String>());
-            Status result = switchManager.addSubnet(cfgObject);
-            if (result.isSuccess()) {
-                resultBean.setStatus(true);
-                resultBean.setMessage("Added gateway address successfully");
-                DaylightWebUtil.auditlog("Subnet Gateway", userName, "added", gatewayName, containerName);
-            } else {
-                resultBean.setStatus(false);
-                resultBean.setMessage(result.getDescription());
-            }
-        } catch (Exception e) {
-            resultBean.setStatus(false);
-            resultBean.setMessage(e.getMessage());
-        }
-        return resultBean;
-    }
-
-    @RequestMapping(value = "/subnetGateway/delete", method = RequestMethod.GET)
-    @ResponseBody
-    public StatusJsonBean deleteSubnetGateways(@RequestParam("gatewaysToDelete") String gatewaysToDelete,
-            HttpServletRequest request, @RequestParam(required = false) String container) {
-        String containerName = (container == null) ? GlobalConstants.DEFAULT.toString() : container;
-
-        // Authorization check
-        String userName = request.getUserPrincipal().getName();
-        if (DaylightWebUtil.getContainerPrivilege(userName, container, this) != Privilege.WRITE) {
-            return unauthorizedMessage();
-        }
-
-        StatusJsonBean resultBean = new StatusJsonBean();
-        try {
-            ISwitchManager switchManager = (ISwitchManager) ServiceHelper.getInstance(ISwitchManager.class,
-                    containerName, this);
-            String[] subnets = gatewaysToDelete.split(",");
-            resultBean.setStatus(true);
-            resultBean.setMessage("Added gateway address successfully");
-            for (String subnet : subnets) {
-                Status result = switchManager.removeSubnet(subnet);
-                if (!result.isSuccess()) {
-                    resultBean.setStatus(false);
-                    resultBean.setMessage(result.getDescription());
-                    break;
-                }
-                DaylightWebUtil.auditlog("Subnet Gateway", userName, "removed", subnet, containerName);
-            }
-        } catch (Exception e) {
-            resultBean.setStatus(false);
-            resultBean.setMessage(e.getMessage());
-        }
-        return resultBean;
-    }
-
-    @RequestMapping(value = "/subnetGateway/ports/add", method = RequestMethod.GET)
-    @ResponseBody
-    public StatusJsonBean addSubnetGatewayPort(@RequestParam("portsName") String portsName,
-            @RequestParam("ports") String ports, @RequestParam("nodeId") String nodeId, HttpServletRequest request,
-            @RequestParam(required = false) String container) {
-        String containerName = (container == null) ? GlobalConstants.DEFAULT.toString() : container;
-
-        // Authorization check
-        String userName = request.getUserPrincipal().getName();
-        if (DaylightWebUtil.getContainerPrivilege(userName, containerName, this) != Privilege.WRITE) {
-            return unauthorizedMessage();
-        }
-
-        StatusJsonBean resultBean = new StatusJsonBean();
-        try {
-            ISwitchManager switchManager = (ISwitchManager) ServiceHelper.getInstance(ISwitchManager.class,
-                    containerName, this);
-            List<String> toAdd = new ArrayList<String>();
-            for (String port : ports.split(",")) {
-                toAdd.add(port);
-            }
-            Status result = switchManager.addPortsToSubnet(portsName, toAdd);
-
-            if (result.isSuccess()) {
-                resultBean.setStatus(true);
-                resultBean.setMessage("Added ports to subnet gateway address successfully");
-                for (String port : toAdd) {
-                    DaylightWebUtil.auditlog("Port", userName, "added",
-                            DaylightWebUtil.getPortName(NodeConnector.fromString(port), switchManager)
-                            + " to Subnet Gateway " + portsName, containerName);
-                }
-            } else {
-                resultBean.setStatus(false);
-                resultBean.setMessage(result.getDescription());
-            }
-        } catch (Exception e) {
-            resultBean.setStatus(false);
-            resultBean.setMessage(e.getMessage());
-        }
-        return resultBean;
-    }
-
-    @RequestMapping(value = "/subnetGateway/ports/delete", method = RequestMethod.GET)
-    @ResponseBody
-    public StatusJsonBean deleteSubnetGatewayPort(@RequestParam("gatewayName") String gatewayName,
-            @RequestParam("nodePort") String nodePort, HttpServletRequest request,
-            @RequestParam(required = false) String container) {
-        String containerName = (container == null) ? GlobalConstants.DEFAULT.toString() : container;
-
-        // Authorization check
-        String userName = request.getUserPrincipal().getName();
-        if (DaylightWebUtil.getContainerPrivilege(userName, containerName, this) != Privilege.WRITE) {
-            return unauthorizedMessage();
-        }
-
-        StatusJsonBean resultBean = new StatusJsonBean();
-        try {
-            ISwitchManager switchManager = (ISwitchManager) ServiceHelper.getInstance(ISwitchManager.class,
-                    containerName, this);
-            List<String> toRemove = new ArrayList<String>();
-            for (String port : nodePort.split(",")) {
-                toRemove.add(port);
-            }
-            Status result = switchManager.removePortsFromSubnet(gatewayName, toRemove);
-
-            if (result.isSuccess()) {
-                resultBean.setStatus(true);
-                resultBean.setMessage("Deleted port from subnet gateway address successfully");
-                for (String port : toRemove) {
-                    DaylightWebUtil.auditlog("Port", userName, "removed",
-                            DaylightWebUtil.getPortName(NodeConnector.fromString(port), switchManager)
-                            + " from Subnet Gateway " + gatewayName, containerName);
-                }
-            } else {
-                resultBean.setStatus(false);
-                resultBean.setMessage(result.getDescription());
-            }
-        } catch (Exception e) {
-            resultBean.setStatus(false);
-            resultBean.setMessage(e.getMessage());
-        }
-        return resultBean;
-    }
-
-    @RequestMapping(value = "/spanPorts", method = RequestMethod.GET)
-    @ResponseBody
-    public DevicesJsonBean getSpanPorts(HttpServletRequest request, @RequestParam(required = false) String container) {
-        Gson gson = new Gson();
-        List<Map<String, String>> spanConfigs = new ArrayList<Map<String, String>>();
-        String containerName = (container == null) ? GlobalConstants.DEFAULT.toString() : container;
-
-        // Derive the privilege this user has on the current container
-        String userName = request.getUserPrincipal().getName();
-        Privilege privilege = DaylightWebUtil.getContainerPrivilege(userName, containerName, this);
-
-        if (privilege != Privilege.NONE) {
-            List<String> spanConfigs_json = new ArrayList<String>();
-            ISwitchManager switchManager = (ISwitchManager) ServiceHelper.getInstance(ISwitchManager.class,
-                    containerName, this);
-            if (switchManager != null) {
-                for (SpanConfig conf : switchManager.getSpanConfigList()) {
-                    spanConfigs_json.add(gson.toJson(conf));
-                }
-            }
-            ObjectMapper mapper = new ObjectMapper();
-
-            for (String config_json : spanConfigs_json) {
-                try {
-                    @SuppressWarnings("unchecked")
-                    Map<String, String> config_data = mapper.readValue(config_json, HashMap.class);
-                    Map<String, String> config = new HashMap<String, String>();
-                    for (String name : config_data.keySet()) {
-                        config.put(name, config_data.get(name));
-                        // Add switch portName value (non-configuration field)
-                        config.put("nodeName", getNodeDesc(config_data.get("nodeId"), containerName));
-                        NodeConnector spanPortNodeConnector = NodeConnector.fromString(config_data.get("spanPort"));
-                        Name ncName = ((Name) switchManager.getNodeConnectorProp(spanPortNodeConnector,
-                                Name.NamePropName));
-                        String spanPortName = (ncName != null) ? ncName.getValue() : "";
-                        config.put("spanPortName", spanPortName);
-                    }
-                    config.put("json", config_json);
-                    spanConfigs.add(config);
-                } catch (Exception e) {
-                    // TODO: Handle the exception.
-                }
-            }
-        }
-
-        DevicesJsonBean result = new DevicesJsonBean();
-        result.setPrivilege(privilege);
-        result.setColumnNames(SpanConfig.getGuiFieldsNames());
-        result.setNodeData(spanConfigs);
-        return result;
-    }
-
-    @RequestMapping(value = "/nodeports")
-    @ResponseBody
-    public String getNodePorts(HttpServletRequest request, @RequestParam(required = false) String container) {
-        String containerName = (container == null) ? GlobalConstants.DEFAULT.toString() : container;
-
-        // Derive the privilege this user has on the current container
-        String userName = request.getUserPrincipal().getName();
-        if (DaylightWebUtil.getContainerPrivilege(userName, containerName, this) == Privilege.NONE) {
-            return null;
-        }
-
-        ISwitchManager switchManager = (ISwitchManager) ServiceHelper.getInstance(ISwitchManager.class, containerName,
-                this);
-        if (switchManager == null) {
-            return null;
-        }
-        List<NodeJsonBean> nodeJsonBeans = new ArrayList<NodeJsonBean>();
-
-        for (Switch node : switchManager.getNetworkDevices()) {
-            NodeJsonBean nodeJsonBean = new NodeJsonBean();
-            List<PortJsonBean> port = new ArrayList<PortJsonBean>();
-            Set<NodeConnector> nodeConnectorSet = node.getNodeConnectors();
-            if (nodeConnectorSet != null) {
-                for (NodeConnector nodeConnector : nodeConnectorSet) {
-                    String nodeConnectorName = ((Name) switchManager.getNodeConnectorProp(nodeConnector,
-                            Name.NamePropName)).getValue();
-                    port.add(new PortJsonBean(nodeConnector.getID().toString(), nodeConnectorName, nodeConnector
-                            .toString()));
-                }
-            }
-            nodeJsonBean.setNodeId(node.getNode().toString());
-            nodeJsonBean.setNodeName(getNodeDesc(node.getNode().toString(), containerName));
-            nodeJsonBean.setNodePorts(port);
-            nodeJsonBeans.add(nodeJsonBean);
-        }
-
-        return new Gson().toJson(nodeJsonBeans);
-    }
-
-    @RequestMapping(value = "/spanPorts/add", method = RequestMethod.GET)
-    @ResponseBody
-    public StatusJsonBean addSpanPort(@RequestParam("jsonData") String jsonData, HttpServletRequest request,
-            @RequestParam(required = false) String container) {
-        String containerName = (container == null) ? GlobalConstants.DEFAULT.toString() : container;
-
-        // Authorization check
-        String userName = request.getUserPrincipal().getName();
-        if (DaylightWebUtil.getContainerPrivilege(userName, containerName, this) != Privilege.WRITE) {
-            return unauthorizedMessage();
-        }
-
-        StatusJsonBean resultBean = new StatusJsonBean();
-        try {
-            Gson gson = new Gson();
-            ISwitchManager switchManager = (ISwitchManager) ServiceHelper.getInstance(ISwitchManager.class,
-                    containerName, this);
-            SpanConfig cfgObject = gson.fromJson(jsonData, SpanConfig.class);
-            Status result = switchManager.addSpanConfig(cfgObject);
-            if (result.isSuccess()) {
-                resultBean.setStatus(true);
-                resultBean.setMessage("SPAN Port added successfully");
-                DaylightWebUtil.auditlog("SPAN Port", userName, "added",
-                        DaylightWebUtil.getPortName(NodeConnector.fromString(cfgObject.getSpanPort()), switchManager),
-                        containerName);
-            } else {
-                resultBean.setStatus(false);
-                resultBean.setMessage(result.getDescription());
-            }
-        } catch (Exception e) {
-            resultBean.setStatus(false);
-            resultBean.setMessage("Error occurred while adding span port. " + e.getMessage());
-        }
-        return resultBean;
-    }
-
-    @RequestMapping(value = "/spanPorts/delete", method = RequestMethod.GET)
-    @ResponseBody
-    public StatusJsonBean deleteSpanPorts(@RequestParam("spanPortsToDelete") String spanPortsToDelete,
-            HttpServletRequest request, @RequestParam(required = false) String container) {
-        String containerName = (container == null) ? GlobalConstants.DEFAULT.toString() : container;
-
-        // Authorization check
-        String userName = request.getUserPrincipal().getName();
-        if (DaylightWebUtil.getContainerPrivilege(userName, containerName, this) != Privilege.WRITE) {
-            return unauthorizedMessage();
-        }
-
-        StatusJsonBean resultBean = new StatusJsonBean();
-        try {
-            Gson gson = new Gson();
-            ISwitchManager switchManager = (ISwitchManager) ServiceHelper.getInstance(ISwitchManager.class,
-                    containerName, this);
-            Type collectionType = new TypeToken<List<SpanPortJsonBean>>() {
-            }.getType();
-            List<SpanPortJsonBean> jsonBeanList = gson.fromJson(spanPortsToDelete, collectionType);
-            for (SpanPortJsonBean jsonBean : jsonBeanList) {
-                SpanConfig cfgObject = gson.fromJson(gson.toJson(jsonBean), SpanConfig.class);
-                Status result = switchManager.removeSpanConfig(cfgObject);
-                if (!result.isSuccess()) {
-                    resultBean.setStatus(false);
-                    resultBean.setMessage(result.getDescription());
-                    break;
-                }
-                DaylightWebUtil.auditlog("SPAN Port", userName, "removed",
-                        DaylightWebUtil.getPortName(NodeConnector.fromString(cfgObject.getSpanPort()), switchManager),
-                        containerName);
-            }
-            resultBean.setStatus(true);
-            resultBean.setMessage("SPAN Port(s) deleted successfully");
-        } catch (Exception e) {
-            resultBean.setStatus(false);
-            resultBean.setMessage("Error occurred while deleting span port. " + e.getMessage());
-        }
-        return resultBean;
-    }
-
-    @RequestMapping(value = "/connect/nodes", method = RequestMethod.GET)
-    @ResponseBody
-    public List<NodeJsonBean> getNodes(HttpServletRequest request) {
-        IConnectionManager connectionManager = (IConnectionManager) ServiceHelper.getGlobalInstance(
-                IConnectionManager.class, this);
-        if (connectionManager == null) {
-            return null;
-        }
-        ISwitchManager switchManager = (ISwitchManager) ServiceHelper.getInstance(ISwitchManager.class,
-                GlobalConstants.DEFAULT.toString(), this);
-        if (switchManager == null) {
-            return null;
-        }
-
-        Set<Node> nodes = connectionManager.getLocalNodes();
-        List<NodeJsonBean> result = new LinkedList<NodeJsonBean>();
-        if (nodes == null) {
-            return result;
-        }
-        for (Node node : nodes) {
-            Description descriptionProperty = (Description) switchManager.getNodeProp(node, "description");
-            String description = node.toString();
-            if (descriptionProperty != null) {
-                description = descriptionProperty.getValue();
-            }
-            NodeJsonBean nodeBean = new NodeJsonBean();
-            nodeBean.setNodeId(node.getNodeIDString());
-            nodeBean.setNodeType(node.getType());
-            if (description.equals("None")) {
-                nodeBean.setNodeName(node.toString());
-            } else {
-                nodeBean.setNodeName(description);
-            }
-            result.add(nodeBean);
-        }
-
-        return result;
-    }
-
-    @RequestMapping(value = "/connect/{nodeId:.+}", method = RequestMethod.POST)
-    @ResponseBody
-    public Status addNode(HttpServletRequest request, @PathVariable("nodeId") String nodeId,
-            @RequestParam(required = true) String ipAddress, @RequestParam(required = true) String port,
-            @RequestParam(required = false) String nodeType) {
-        IConnectionManager connectionManager = (IConnectionManager) ServiceHelper.getGlobalInstance(
-                IConnectionManager.class, this);
-        if (connectionManager == null) {
-            return new Status(StatusCode.NOTFOUND, "Service not found");
-        }
-
-        if (!NetUtils.isIPv4AddressValid(ipAddress)) {
-            return new Status(StatusCode.NOTACCEPTABLE, "Invalid IP Address: " + ipAddress);
-        }
-
-        try {
-            Integer.parseInt(port);
-        } catch (Exception e) {
-            return new Status(StatusCode.NOTACCEPTABLE, "Invalid Layer 4 Port: " + port);
-        }
-
-        Map<ConnectionConstants, String> params = new HashMap<ConnectionConstants, String>();
-        params.put(ConnectionConstants.ADDRESS, ipAddress);
-        params.put(ConnectionConstants.PORT, port);
-
-        Node node = null;
-        if (nodeType != null) {
-            node = connectionManager.connect(nodeType, nodeId, params);
-        } else {
-            node = connectionManager.connect(nodeId, params);
-        }
-        if (node == null) {
-            return new Status(StatusCode.NOTFOUND, "Failed to connect to Node at " + ipAddress + ":" + port);
-        }
-        return new Status(StatusCode.SUCCESS);
-    }
-
-    @RequestMapping(value = "/disconnect/{nodeId:.+}", method = RequestMethod.POST)
-    @ResponseBody
-    public Status removeNode(HttpServletRequest request, @PathVariable("nodeId") String nodeId,
-            @RequestParam(required = true) String nodeType) {
-        IConnectionManager connectionManager = (IConnectionManager) ServiceHelper.getGlobalInstance(
-                IConnectionManager.class, this);
-        if (connectionManager == null) {
-            return new Status(StatusCode.NOTFOUND, "Service not found");
-        }
-
-        try {
-            Node node = new Node(nodeType, nodeId);
-            return connectionManager.disconnect(node);
-        } catch (Exception e) {
-            return new Status(StatusCode.NOTFOUND, "Resource not found");
-        }
-    }
-
-    private String getNodeDesc(String nodeId, String containerName) {
-        ISwitchManager switchManager = (ISwitchManager) ServiceHelper.getInstance(ISwitchManager.class, containerName,
-                this);
-        String description = "";
-        if (switchManager != null) {
-            Description desc = (Description) switchManager.getNodeProp(Node.fromString(nodeId),
-                    Description.propertyName);
-            if (desc != null) {
-                description = desc.getValue();
-            }
-        }
-        return (description.isEmpty() || description.equalsIgnoreCase("none")) ? nodeId : description;
-    }
-
-    private StatusJsonBean unauthorizedMessage() {
-        StatusJsonBean message = new StatusJsonBean();
-        message.setStatus(false);
-        message.setMessage("Operation not authorized");
-        return message;
-    }
-
-    @RequestMapping(value = "login")
-    public String login(final HttpServletRequest request, final HttpServletResponse response) {
-        /*
-         * IUserManager userManager = (IUserManager) ServiceHelper
-         * .getGlobalInstance(IUserManager.class, this); if (userManager ==
-         * null) { return "User Manager is not available"; }
-         *
-         * String username = request.getUserPrincipal().getName();
-         *
-         *
-         * model.addAttribute("username", username); model.addAttribute("role",
-         * userManager.getUserLevel(username).toNumber());
-         */
-        return "forward:" + "/";
-    }
-
-}
diff --git a/opendaylight/adsal/web/devices/src/main/java/org/opendaylight/controller/devices/web/DevicesJsonBean.java b/opendaylight/adsal/web/devices/src/main/java/org/opendaylight/controller/devices/web/DevicesJsonBean.java
deleted file mode 100644 (file)
index ce0b376..0000000
+++ /dev/null
@@ -1,44 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.devices.web;
-
-import java.util.List;
-import java.util.Map;
-
-import org.opendaylight.controller.sal.authorization.Privilege;
-
-public class DevicesJsonBean {
-    private List<String> columnNames;
-    private List<Map<String, String>> nodeData;
-    private Privilege privilege;
-
-    public List<String> getColumnNames() {
-        return columnNames;
-    }
-
-    public void setColumnNames(List<String> columnNames) {
-        this.columnNames = columnNames;
-    }
-
-    public List<Map<String, String>> getNodeData() {
-        return nodeData;
-    }
-
-    public void setNodeData(List<Map<String, String>> nodeData) {
-        this.nodeData = nodeData;
-    }
-
-    public void setPrivilege(Privilege privilege) {
-        this.privilege = privilege;
-    }
-
-    public Privilege getPrivilege() {
-        return privilege;
-    }
-}
diff --git a/opendaylight/adsal/web/devices/src/main/java/org/opendaylight/controller/devices/web/NodeJsonBean.java b/opendaylight/adsal/web/devices/src/main/java/org/opendaylight/controller/devices/web/NodeJsonBean.java
deleted file mode 100644 (file)
index e5f2b6a..0000000
+++ /dev/null
@@ -1,51 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.devices.web;
-
-import java.util.List;
-
-public class NodeJsonBean {
-    String nodeId;
-    String nodeName;
-    String nodeType;
-    List<PortJsonBean> nodePorts;
-
-    public String getNodeId() {
-        return nodeId;
-    }
-
-    public String getNodeName() {
-        return nodeName;
-    }
-
-    public String getNodeType() {
-        return nodeType;
-    }
-
-    public List<PortJsonBean> getNodePorts() {
-        return nodePorts;
-    }
-
-    public void setNodeId(String nodeId) {
-        this.nodeId = nodeId;
-    }
-
-    public void setNodeName(String nodeName) {
-        this.nodeName = nodeName;
-    }
-
-    public void setNodeType(String nodeType) {
-        this.nodeType = nodeType;
-    }
-
-    public void setNodePorts(List<PortJsonBean> port) {
-        this.nodePorts = port;
-    }
-
-}
diff --git a/opendaylight/adsal/web/devices/src/main/java/org/opendaylight/controller/devices/web/PortJsonBean.java b/opendaylight/adsal/web/devices/src/main/java/org/opendaylight/controller/devices/web/PortJsonBean.java
deleted file mode 100644 (file)
index 09b90d0..0000000
+++ /dev/null
@@ -1,27 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.devices.web;
-
-public class PortJsonBean {
-    String portId;
-    String portName;
-    String internalPortName;
-
-    public PortJsonBean() {
-        this.portId = null;
-        this.portName = null;
-        this.internalPortName = null;
-    }
-
-    public PortJsonBean(String id, String name, String internalName) {
-        this.portId = id;
-        this.portName = (name == null) ? internalName : name;
-        this.internalPortName = internalName;
-    }
-}
diff --git a/opendaylight/adsal/web/devices/src/main/java/org/opendaylight/controller/devices/web/SpanPortJsonBean.java b/opendaylight/adsal/web/devices/src/main/java/org/opendaylight/controller/devices/web/SpanPortJsonBean.java
deleted file mode 100644 (file)
index b9be40b..0000000
+++ /dev/null
@@ -1,32 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.devices.web;
-
-public class SpanPortJsonBean {
-
-    private String nodeId;
-    private String spanPort;
-
-    public String getNodeId() {
-        return nodeId;
-    }
-
-    public void setNodeId(String nodeId) {
-        this.nodeId = nodeId;
-    }
-
-    public String getSpanPort() {
-        return spanPort;
-    }
-
-    public void setSpanPort(String spanPort) {
-        this.spanPort = spanPort;
-    }
-
-}
diff --git a/opendaylight/adsal/web/devices/src/main/java/org/opendaylight/controller/devices/web/StatusJsonBean.java b/opendaylight/adsal/web/devices/src/main/java/org/opendaylight/controller/devices/web/StatusJsonBean.java
deleted file mode 100644 (file)
index a354603..0000000
+++ /dev/null
@@ -1,29 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.devices.web;
-
-public class StatusJsonBean {
-    private boolean status;
-    private String message;
-
-    public boolean isStatus() {
-        return status;
-    }
-
-    public void setStatus(boolean status) {
-        this.status = status;
-    }
-
-    public String getMessage() {
-        return message;
-    }
-
-    public void setMessage(String message) {
-        this.message = message;
-    }
-}
diff --git a/opendaylight/adsal/web/devices/src/main/java/org/opendaylight/controller/devices/web/SubnetGatewayPortBean.java b/opendaylight/adsal/web/devices/src/main/java/org/opendaylight/controller/devices/web/SubnetGatewayPortBean.java
deleted file mode 100644 (file)
index ba0d2a2..0000000
+++ /dev/null
@@ -1,41 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.devices.web;
-
-public class SubnetGatewayPortBean {
-    private String nodeName;
-    private String nodeId;
-    private PortJsonBean port;
-    private String nodePortId;
-    private String nodePortName;
-
-    public String getNodeName() {
-        return nodeName;
-    }
-    public void setNodeName(String nodeName) {
-        this.nodeName = nodeName;
-    }
-    public String getNodeId() {
-        return nodeId;
-    }
-    public void setNodeId(String nodeId) {
-        this.nodeId = nodeId;
-    }
-    public String getNodePortId() {
-        return nodePortId;
-    }
-    public void setNodePortId(String nodePortId) {
-        this.nodePortId = nodePortId;
-    }
-    public String getNodePortName() {
-        return nodePortName;
-    }
-    public void setNodePortName(String nodePortName) {
-        this.nodePortName = nodePortName;
-    }
-}
diff --git a/opendaylight/adsal/web/devices/src/main/resources/META-INF/spring.factories b/opendaylight/adsal/web/devices/src/main/resources/META-INF/spring.factories
deleted file mode 100644 (file)
index 93db02e..0000000
+++ /dev/null
@@ -1 +0,0 @@
-org.springframework.beans.BeanInfoFactory=org.springframework.beans.ExtendedBeanInfoFactory
diff --git a/opendaylight/adsal/web/devices/src/main/resources/META-INF/spring.handlers b/opendaylight/adsal/web/devices/src/main/resources/META-INF/spring.handlers
deleted file mode 100644 (file)
index 957af91..0000000
+++ /dev/null
@@ -1,10 +0,0 @@
-http\://www.springframework.org/schema/context=org.springframework.context.config.ContextNamespaceHandler
-http\://www.springframework.org/schema/jee=org.springframework.ejb.config.JeeNamespaceHandler
-http\://www.springframework.org/schema/lang=org.springframework.scripting.config.LangNamespaceHandler
-http\://www.springframework.org/schema/task=org.springframework.scheduling.config.TaskNamespaceHandler
-http\://www.springframework.org/schema/cache=org.springframework.cache.config.CacheNamespaceHandler
-http\://www.springframework.org/schema/c=org.springframework.beans.factory.xml.SimpleConstructorNamespaceHandler
-http\://www.springframework.org/schema/p=org.springframework.beans.factory.xml.SimplePropertyNamespaceHandler
-http\://www.springframework.org/schema/util=org.springframework.beans.factory.xml.UtilNamespaceHandler
-http\://www.springframework.org/schema/mvc=org.springframework.web.servlet.config.MvcNamespaceHandler
-http\://www.springframework.org/schema/security=org.springframework.security.config.SecurityNamespaceHandler
diff --git a/opendaylight/adsal/web/devices/src/main/resources/META-INF/spring.schemas b/opendaylight/adsal/web/devices/src/main/resources/META-INF/spring.schemas
deleted file mode 100644 (file)
index d865edc..0000000
+++ /dev/null
@@ -1,49 +0,0 @@
-http\://www.springframework.org/schema/beans/spring-beans-2.0.xsd=org/springframework/beans/factory/xml/spring-beans-2.0.xsd
-http\://www.springframework.org/schema/beans/spring-beans-2.5.xsd=org/springframework/beans/factory/xml/spring-beans-2.5.xsd
-http\://www.springframework.org/schema/beans/spring-beans-3.0.xsd=org/springframework/beans/factory/xml/spring-beans-3.0.xsd
-http\://www.springframework.org/schema/beans/spring-beans-3.1.xsd=org/springframework/beans/factory/xml/spring-beans-3.1.xsd
-http\://www.springframework.org/schema/beans/spring-beans-3.2.xsd=org/springframework/beans/factory/xml/spring-beans-3.2.xsd
-http\://www.springframework.org/schema/beans/spring-beans.xsd=org/springframework/beans/factory/xml/spring-beans-3.2.xsd
-http\://www.springframework.org/schema/tool/spring-tool-2.0.xsd=org/springframework/beans/factory/xml/spring-tool-2.0.xsd
-http\://www.springframework.org/schema/tool/spring-tool-2.5.xsd=org/springframework/beans/factory/xml/spring-tool-2.5.xsd
-http\://www.springframework.org/schema/tool/spring-tool-3.0.xsd=org/springframework/beans/factory/xml/spring-tool-3.0.xsd
-http\://www.springframework.org/schema/tool/spring-tool-3.1.xsd=org/springframework/beans/factory/xml/spring-tool-3.1.xsd
-http\://www.springframework.org/schema/tool/spring-tool-3.2.xsd=org/springframework/beans/factory/xml/spring-tool-3.2.xsd
-http\://www.springframework.org/schema/tool/spring-tool.xsd=org/springframework/beans/factory/xml/spring-tool-3.2.xsd
-http\://www.springframework.org/schema/util/spring-util-2.0.xsd=org/springframework/beans/factory/xml/spring-util-2.0.xsd
-http\://www.springframework.org/schema/util/spring-util-2.5.xsd=org/springframework/beans/factory/xml/spring-util-2.5.xsd
-http\://www.springframework.org/schema/util/spring-util-3.0.xsd=org/springframework/beans/factory/xml/spring-util-3.0.xsd
-http\://www.springframework.org/schema/util/spring-util-3.1.xsd=org/springframework/beans/factory/xml/spring-util-3.1.xsd
-http\://www.springframework.org/schema/util/spring-util-3.2.xsd=org/springframework/beans/factory/xml/spring-util-3.2.xsd
-http\://www.springframework.org/schema/util/spring-util.xsd=org/springframework/beans/factory/xml/spring-util-3.2.xsd
-http\://www.springframework.org/schema/context/spring-context-2.5.xsd=org/springframework/context/config/spring-context-2.5.xsd
-http\://www.springframework.org/schema/context/spring-context-3.0.xsd=org/springframework/context/config/spring-context-3.0.xsd
-http\://www.springframework.org/schema/context/spring-context-3.1.xsd=org/springframework/context/config/spring-context-3.1.xsd
-http\://www.springframework.org/schema/context/spring-context-3.2.xsd=org/springframework/context/config/spring-context-3.2.xsd
-http\://www.springframework.org/schema/context/spring-context.xsd=org/springframework/context/config/spring-context-3.2.xsd
-http\://www.springframework.org/schema/jee/spring-jee-2.0.xsd=org/springframework/ejb/config/spring-jee-2.0.xsd
-http\://www.springframework.org/schema/jee/spring-jee-2.5.xsd=org/springframework/ejb/config/spring-jee-2.5.xsd
-http\://www.springframework.org/schema/jee/spring-jee-3.0.xsd=org/springframework/ejb/config/spring-jee-3.0.xsd
-http\://www.springframework.org/schema/jee/spring-jee-3.1.xsd=org/springframework/ejb/config/spring-jee-3.1.xsd
-http\://www.springframework.org/schema/jee/spring-jee-3.2.xsd=org/springframework/ejb/config/spring-jee-3.2.xsd
-http\://www.springframework.org/schema/jee/spring-jee.xsd=org/springframework/ejb/config/spring-jee-3.2.xsd
-http\://www.springframework.org/schema/lang/spring-lang-2.0.xsd=org/springframework/scripting/config/spring-lang-2.0.xsd
-http\://www.springframework.org/schema/lang/spring-lang-2.5.xsd=org/springframework/scripting/config/spring-lang-2.5.xsd
-http\://www.springframework.org/schema/lang/spring-lang-3.0.xsd=org/springframework/scripting/config/spring-lang-3.0.xsd
-http\://www.springframework.org/schema/lang/spring-lang-3.1.xsd=org/springframework/scripting/config/spring-lang-3.1.xsd
-http\://www.springframework.org/schema/lang/spring-lang-3.2.xsd=org/springframework/scripting/config/spring-lang-3.2.xsd
-http\://www.springframework.org/schema/lang/spring-lang.xsd=org/springframework/scripting/config/spring-lang-3.2.xsd
-http\://www.springframework.org/schema/task/spring-task-3.0.xsd=org/springframework/scheduling/config/spring-task-3.0.xsd
-http\://www.springframework.org/schema/task/spring-task-3.1.xsd=org/springframework/scheduling/config/spring-task-3.1.xsd
-http\://www.springframework.org/schema/task/spring-task-3.2.xsd=org/springframework/scheduling/config/spring-task-3.2.xsd
-http\://www.springframework.org/schema/task/spring-task.xsd=org/springframework/scheduling/config/spring-task-3.2.xsd
-http\://www.springframework.org/schema/cache/spring-cache-3.1.xsd=org/springframework/cache/config/spring-cache-3.1.xsd
-http\://www.springframework.org/schema/cache/spring-cache-3.2.xsd=org/springframework/cache/config/spring-cache-3.2.xsd
-http\://www.springframework.org/schema/cache/spring-cache.xsd=org/springframework/cache/config/spring-cache-3.2.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd=org/springframework/web/servlet/config/spring-mvc-3.0.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc-3.1.xsd=org/springframework/web/servlet/config/spring-mvc-3.1.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc-3.2.xsd=org/springframework/web/servlet/config/spring-mvc-3.2.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc.xsd=org/springframework/web/servlet/config/spring-mvc-3.2.xsd
-http\://www.springframework.org/schema/security/spring-security-3.1.xsd=org/springframework/security/config/spring-security-3.1.xsd
-http\://www.springframework.org/schema/security/spring-security-3.2.xsd=org/springframework/security/config/spring-security-3.2.xsd
-
diff --git a/opendaylight/adsal/web/devices/src/main/resources/META-INF/spring.tooling b/opendaylight/adsal/web/devices/src/main/resources/META-INF/spring.tooling
deleted file mode 100644 (file)
index 057d834..0000000
+++ /dev/null
@@ -1,39 +0,0 @@
-# Tooling related information for the beans namespace
-http\://www.springframework.org/schema/beans@name=beans Namespace
-http\://www.springframework.org/schema/beans@prefix=beans
-http\://www.springframework.org/schema/beans@icon=org/springframework/beans/factory/xml/spring-beans.gif
-
-# Tooling related information for the util namespace
-http\://www.springframework.org/schema/util@name=util Namespace
-http\://www.springframework.org/schema/util@prefix=util
-http\://www.springframework.org/schema/util@icon=org/springframework/beans/factory/xml/spring-util.gif
-
-# Tooling related information for the context namespace
-http\://www.springframework.org/schema/context@name=context Namespace
-http\://www.springframework.org/schema/context@prefix=context
-http\://www.springframework.org/schema/context@icon=org/springframework/context/config/spring-context.gif
-
-# Tooling related information for the jee namespace
-http\://www.springframework.org/schema/jee@name=jee Namespace
-http\://www.springframework.org/schema/jee@prefix=jee
-http\://www.springframework.org/schema/jee@icon=org/springframework/ejb/config/spring-jee.gif
-
-# Tooling related information for the scheduling namespace
-http\://www.springframework.org/schema/task@name=task Namespace
-http\://www.springframework.org/schema/task@prefix=task
-http\://www.springframework.org/schema/task@icon=org/springframework/scheduling/config/spring-task.gif
-
-# Tooling related information for the lang namespace
-http\://www.springframework.org/schema/lang@name=lang Namespace
-http\://www.springframework.org/schema/lang@prefix=lang
-http\://www.springframework.org/schema/lang@icon=org/springframework/scripting/config/spring-lang.gif
-
-# Tooling related information for the cache namespace
-http\://www.springframework.org/schema/cache@name=cache Namespace
-http\://www.springframework.org/schema/cache@prefix=cache
-http\://www.springframework.org/schema/cache@icon=org/springframework/cache/config/spring-cache.gif
-
-# Tooling related information for the mvc namespace
-http\://www.springframework.org/schema/mvc@name=mvc Namespace
-http\://www.springframework.org/schema/mvc@prefix=mvc
-http\://www.springframework.org/schema/mvc@icon=org/springframework/web/servlet/config/spring-mvc.gif
diff --git a/opendaylight/adsal/web/devices/src/main/resources/WEB-INF/Devices-servlet.xml b/opendaylight/adsal/web/devices/src/main/resources/WEB-INF/Devices-servlet.xml
deleted file mode 100644 (file)
index af5cd8d..0000000
+++ /dev/null
@@ -1,21 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>\r
-<beans xmlns="http://www.springframework.org/schema/beans"\r
-  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"\r
-  xmlns:context="http://www.springframework.org/schema/context"\r
-  xmlns:mvc="http://www.springframework.org/schema/mvc"\r
-  xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd\r
-                      http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd\r
-                      http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd">\r
-\r
-  <context:component-scan base-package="org.opendaylight.controller.devices.web"/>\r
-\r
-  <mvc:resources mapping="/js/**" location="/js/" />\r
-  <mvc:resources mapping="/css/**" location="/css/" />\r
-  <mvc:resources mapping="/img/**" location="/img/" />\r
-  <mvc:annotation-driven/>\r
-\r
-  <bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">\r
-        <property name="prefix" value="/WEB-INF/jsp/"/>\r
-        <property name="suffix" value=".jsp"/>\r
-  </bean>\r
-</beans>\r
diff --git a/opendaylight/adsal/web/devices/src/main/resources/WEB-INF/jsp/autherror.jsp b/opendaylight/adsal/web/devices/src/main/resources/WEB-INF/jsp/autherror.jsp
deleted file mode 100644 (file)
index 127a5a0..0000000
+++ /dev/null
@@ -1,55 +0,0 @@
-<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
-<%@ page import="java.net.URL" %>
-<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
-
-<!DOCTYPE html>
-<html>
-  <head>
-    <meta charset="utf-8">
-
-    <!-- Bootstrap CSS - 1 -->
-    <link href="/css/bootstrap.min.css" rel="stylesheet" media="screen">
-    
-    <!-- Login CSS - 2 -->
-    <link rel="stylesheet/less" type="text/css" href="/css/login.less">
-
-<c:set var="title" value="OpenDaylight login error" scope="application"/>
-<%
-    String filePath = "/WEB-INF/jsp/customerror.jsp"; 
-       URL fileURL = pageContext.getServletContext().getResource(filePath);
-       if(fileURL!=null) {
-%>
-         <jsp:include page="<%=filePath%>" flush="true"/>
-<% } %>
-       <title>${title}</title>
-    <!-- Bootstrap JS - 1 -->
-    <script src="/js/bootstrap.min.js"></script>
-    
-    <!-- LESS - 2 -->
-    <script type="text/javascript">
-        less = {
-            env: "production"
-        };
-    </script>
-    <script src="/js/less-1.3.3.min.js"></script>
-</head>
-<body>
-        <form action="<c:url value='/' />" id="form" method="post">
-
-  <div class="container">
-    <div class="content">
-       <div class="login-form">
-         <div id="logo"></div>
-           <fieldset>
-            <p>You are not authorized to access this resource.<p>
-            <p>Please contact your administrator to resolve your Role privileges.</p>
-            <br/>
-             <button class="btn btn-primary" type="submit" value="Log In" >Go To Login Page</button>
-           </fieldset>
-       </div>
-    </div>
-  </div> 
-  </form>
-  <% if (session != null) session.invalidate(); %>  
-</body>
-</html>
diff --git a/opendaylight/adsal/web/devices/src/main/resources/WEB-INF/jsp/error.jsp b/opendaylight/adsal/web/devices/src/main/resources/WEB-INF/jsp/error.jsp
deleted file mode 100644 (file)
index 270d793..0000000
+++ /dev/null
@@ -1,8 +0,0 @@
-<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
-<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
-<%@taglib prefix="fn" uri="http://java.sun.com/jsp/jstl/functions" %>
-<c:set var="req" value="${pageContext.request}" />
-<c:set var="uri" value="${req.requestURI}" />
-<c:set var="replaceWith" value="/" />
-<c:set var="redirectUrl" value="${fn:replace(req.requestURL, req.contextPath , replaceWith)}" />
-<c:import url="${redirectUrl}" />
\ No newline at end of file
diff --git a/opendaylight/adsal/web/devices/src/main/resources/WEB-INF/jsp/login.jsp b/opendaylight/adsal/web/devices/src/main/resources/WEB-INF/jsp/login.jsp
deleted file mode 100644 (file)
index 270d793..0000000
+++ /dev/null
@@ -1,8 +0,0 @@
-<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
-<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
-<%@taglib prefix="fn" uri="http://java.sun.com/jsp/jstl/functions" %>
-<c:set var="req" value="${pageContext.request}" />
-<c:set var="uri" value="${req.requestURI}" />
-<c:set var="replaceWith" value="/" />
-<c:set var="redirectUrl" value="${fn:replace(req.requestURL, req.contextPath , replaceWith)}" />
-<c:import url="${redirectUrl}" />
\ No newline at end of file
diff --git a/opendaylight/adsal/web/devices/src/main/resources/WEB-INF/web.xml b/opendaylight/adsal/web/devices/src/main/resources/WEB-INF/web.xml
deleted file mode 100644 (file)
index 6294a9f..0000000
+++ /dev/null
@@ -1,75 +0,0 @@
-<?xml version="1.0" encoding="ISO-8859-1"?>
-<web-app xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
-        xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
-        version="3.0">
-        <security-constraint>
-                <web-resource-collection>
-                        <web-resource-name>free access</web-resource-name>
-                        <url-pattern>/js/*</url-pattern>
-                        <url-pattern>/images/*</url-pattern>
-                        <url-pattern>/css/*</url-pattern>
-                        <url-pattern>/favicon.ico</url-pattern>
-                </web-resource-collection>
-        </security-constraint>
-
-        <security-constraint>
-                <display-name>DevicesApp</display-name>
-                <web-resource-collection>
-                        <web-resource-name>DevicesGUI</web-resource-name>
-                        <url-pattern>/*</url-pattern>
-                </web-resource-collection>
-                <auth-constraint>
-                        <role-name>System-Admin</role-name>
-                        <role-name>Network-Admin</role-name>
-                        <role-name>Network-Operator</role-name>
-                        <role-name>Container-User</role-name>
-                </auth-constraint>
-        </security-constraint>
-
-        <security-role>
-                <role-name>System-Admin</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Network-Admin</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Network-Operator</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Container-User</role-name>
-        </security-role>
-
-        <login-config>
-                <auth-method>FORM</auth-method>
-                <form-login-config>
-                        <form-login-page>/WEB-INF/jsp/login.jsp</form-login-page>
-                        <form-error-page>/WEB-INF/jsp/error.jsp</form-error-page>
-                </form-login-config>
-        </login-config>
-
-    <error-page>
-            <error-code>403</error-code>
-            <location>/WEB-INF/jsp/autherror.jsp</location>
-    </error-page>
-
-        <servlet>
-                <servlet-name>Devices</servlet-name>
-                <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
-                <load-on-startup>1</load-on-startup>
-        </servlet>
-
-        <servlet-mapping>
-                <servlet-name>Devices</servlet-name>
-                <url-pattern>/</url-pattern>
-        </servlet-mapping>
-
-        <listener>
-                <listener-class>org.opendaylight.controller.web.ControllerUISessionManager</listener-class>
-        </listener>
-        <session-config>
-                <cookie-config>
-                        <path>/</path>
-                </cookie-config>
-        </session-config>
-
-</web-app>
diff --git a/opendaylight/adsal/web/devices/src/main/resources/js/page.js b/opendaylight/adsal/web/devices/src/main/resources/js/page.js
deleted file mode 100644 (file)
index 935354e..0000000
+++ /dev/null
@@ -1,1814 +0,0 @@
-/* 
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved. 
- * 
- * This program and the accompanying materials are made available under the 
- * terms of the Eclipse Public License v1.0 which accompanies this distribution, 
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-//PAGE Devices
-one.f = {};
-
-// specify dashlets and layouts
-
-one.f.dashlet = {
-  nodesLearnt : {
-    id : 'nodesLearnt',
-    name : 'Nodes Learned'
-  },
-  staticRouteConfig : {
-    id : 'staticRouteConfig',
-    name : 'Static Route Configuration'
-  },
-  subnetGatewayConfig : {
-    id : 'subnetGatewayConfig',
-    name : 'Subnet Gateway Configuration'
-  },
-  spanPortConfig : {
-    id : 'spanPortConfig',
-    name : 'SPAN Port Configuration'
-  },
-  connection : {
-    id : 'connection',
-    name : 'Connection Manager'
-  }
-};
-
-one.f.menu = {
-  left : {
-    top : [
-      one.f.dashlet.nodesLearnt
-      ],
-    bottom : [
-      one.f.dashlet.staticRouteConfig,
-      one.f.dashlet.connection
-      ]
-  },
-  right : {
-    top : [],
-    bottom : [
-      one.f.dashlet.subnetGatewayConfig,
-    one.f.dashlet.spanPortConfig
-      ]
-  }
-};
-
-/**Devices Modules */
-one.f.switchmanager = {
-  rootUrl: "controller/web/devices",
-  createTable: function(columnNames, body) {
-    var tableAttributes = ["table-striped", "table-bordered", "table-condensed"];
-    var $table = one.lib.dashlet.table.table(tableAttributes);
-    var tableHeaders = columnNames;
-    var $thead = one.lib.dashlet.table.header(tableHeaders);
-    var $tbody = one.lib.dashlet.table.body(body, tableHeaders);
-    $table.append($thead)
-      .append($tbody);
-    return $table;
-  },
-  validateName: function(name) {
-    return (name.length < 256);
-  }
-};
-
-one.f.switchmanager.nodesLearnt = {
-  id: {
-    dashlet: {
-      popout: "one_f_switchmanager_nodesLearnt_id_dashlet_popout",
-      datagrid: "one_f_switchmanager_nodesLearnt_id_dashlet_datagrid"
-    },
-    modal: {
-      modal: "one_f_switchmanager_nodesLearnt_id_modal_modal",
-      configure: "one_f_switchmanager_nodesLearnt_id_modal_configure",
-      ports: "one_f_switchmanager_nodesLearnt_id_modal_ports",
-      save: "one_f_switchmanager_nodesLearnt_id_modal_save",
-      datagrid: "one_f_switchmanager_nodesLearnt_id_modal_datagrid",
-      portsDatagrid: "one_f_switchmanager_nodesLearnt_id_modal_portsDatagrid",
-      form: {
-        nodeId: "one_f_switchmanager_nodesLearnt_id_modal_form_nodeid",
-        nodeName : "one_f_switchmanager_nodesLearnt_id_modal_form_nodename",
-        portStatus : "one_f_switchmanager_nodesLearnt_id_modal_form_portstatus",
-        tier: "one_f_switchmanager_nodesLearnt_id_modal_form_tier",
-        operationMode: "one_f_switchmanager_nodesLearnt_id_modal_form_opmode"
-      }
-    }
-  },
-  dashlet: function($dashlet) {
-    var url = one.f.switchmanager.rootUrl + "/nodesLearnt";
-    one.lib.dashlet.empty($dashlet);
-    $dashlet.append(one.lib.dashlet.header(one.f.dashlet.nodesLearnt.name));
-
-    one.f.switchmanager.nodesLearnt.ajax.main(url, function(content) {
-      var $gridHTML = one.lib.dashlet.datagrid.init(one.f.switchmanager.nodesLearnt.id.dashlet.datagrid, {
-        searchable: true,
-          filterable: false,
-          pagination: true,
-          flexibleRowsPerPage: true
-      }, "table-striped table-condensed");
-      $dashlet.append($gridHTML);
-      var dataSource = one.f.switchmanager.nodesLearnt.data.gridDataSource.abridged(content);
-      $("#" + one.f.switchmanager.nodesLearnt.id.dashlet.datagrid).datagrid({dataSource: dataSource}).on("loaded", function() {
-        $(this).find("tbody a").click(one.f.switchmanager.nodesLearnt.modal.initialize.updateNode);
-      });
-
-      $("#" + one.f.switchmanager.nodesLearnt.id.dashlet.datagrid).datagrid({dataSource: dataSource}).on("loaded", function() {
-        $(this).find("tbody span").click(function(){
-          one.f.switchmanager.nodesLearnt.modal.initialize.displayPorts($(this));
-        });
-      });
-
-    });
-  },
-  ajax : {
-    main : function(url, callback) {
-      $.getJSON(url, function(data) {
-        callback(data);
-      });
-    }
-  },
-  modal : {
-    registry : { callback:undefined },
-    initialize: {
-      updateNode: function(evt) {
-        one.f.switchmanager.nodesLearnt.ajax.main(one.f.switchmanager.rootUrl + "/tiers", function(tiers) {
-
-          var nodeId = decodeURIComponent(evt.target.id);
-          var h3;
-          var footer = [];
-          var $body = one.f.switchmanager.nodesLearnt.modal.body.updateNode(nodeId, JSON.parse(decodeURIComponent(evt.target.getAttribute("switchDetails"))), tiers);
-          if (evt.target.getAttribute("privilege") == 'WRITE'){
-            h3 = "Update Node Information";
-            footer = one.f.switchmanager.nodesLearnt.modal.footer.updateNode();
-          } else { //disable node edit
-            $body.find('*').attr('disabled', 'disabled');
-            h3 = 'Node Information';
-          }
-
-          var $modal = one.lib.modal.spawn(one.f.switchmanager.nodesLearnt.id.modal.configure, h3, "", footer);
-          // bind save button
-          $('#' + one.f.switchmanager.nodesLearnt.id.modal.save, $modal).click(function() {
-            one.f.switchmanager.nodesLearnt.modal.save($modal);
-          });
-
-          // inject body (nodePorts)
-          one.lib.modal.inject.body($modal, $body);
-
-          $modal.modal().on("shown",function() {
-              var callback = one.f.switchmanager.nodesLearnt.modal.registry.callback;
-              if( callback !== undefined && $.isFunction(callback)) {
-                 callback();
-              }
-          });
-        });
-      },
-      popout: function() {
-        var h3 = "Nodes Learned";
-        var footer = one.f.switchmanager.nodesLearnt.modal.footer.popout();
-        var $modal = one.lib.modal.spawn(one.f.switchmanager.nodesLearnt.id.modal.modal, h3, "", footer);
-        var $body = one.f.switchmanager.nodesLearnt.modal.body.popout($modal);
-        return $modal;
-      },
-      displayPorts: function(ports) {
-        var content = JSON.parse(decodeURIComponent(ports.attr("ports")));
-
-        var h3 = ((ports.attr("nodeName") == "None")? ports.attr("nodeId") : ports.attr("nodeName"))
-          var footer = [];
-        var $modal = one.lib.modal.spawn(one.f.switchmanager.nodesLearnt.id.modal.ports, h3, "", footer);
-
-        var $gridHTML = one.lib.dashlet.datagrid.init(one.f.switchmanager.nodesLearnt.id.modal.portsDatagrid, {
-          searchable: true,
-            filterable: false,
-            pagination: true,
-            flexibleRowsPerPage: true,
-            popout: true
-        }, "table-striped table-condensed");
-        one.lib.modal.inject.body($modal, $gridHTML);
-        $modal.on("shown", function() {
-          var dataSource = one.f.switchmanager.nodesLearnt.data.gridDataSource.displayPorts(content);
-          $("#" + one.f.switchmanager.nodesLearnt.id.modal.portsDatagrid).datagrid({
-            dataSource: dataSource,
-            stretchHeight: false
-          });
-        });
-        $modal.modal();
-      }
-    },
-    body: {
-      updateNode: function(nodeId, switchDetails, tiers) {
-        var $form = $(document.createElement('form'));
-        var $fieldset = $(document.createElement('fieldset'));
-        // node ID. not editable.
-        var $label = one.lib.form.label("Node ID");
-        var $input = one.lib.form.input("node id");
-        $input.attr('id', one.f.switchmanager.nodesLearnt.id.modal.form.nodeId);
-        $input.attr("disabled", true);
-        $input.attr("value", nodeId);
-        $fieldset.append($label).append($input);
-        // node name
-        var $label = one.lib.form.label("Node Name");
-        var $input = one.lib.form.input("Node Name");
-        $input.attr('id', one.f.switchmanager.nodesLearnt.id.modal.form.nodeName);
-        if(switchDetails["nodeName"] != null) {
-          $input.attr('value', switchDetails["nodeName"]);
-        }
-        $fieldset.append($label).append($input);
-        // node tier
-        var $label = one.lib.form.label("Tier");
-        var $select = one.lib.form.select.create(tiers);
-        $select.attr('id', one.f.switchmanager.nodesLearnt.id.modal.form.tier);
-        $select.val(switchDetails["tier"]);
-        $fieldset.append($label).append($select);
-        // operation mode
-        var $label = one.lib.form.label("Operation Mode");
-        var $select = one.lib.form.select.create(
-            ["Allow reactive forwarding", "Proactive forwarding only"]);
-        $select.attr('id', one.f.switchmanager.nodesLearnt.id.modal.form.operationMode);
-        if ((one.main.registry != undefined) && (one.main.registry.container != 'default')) {
-          $select.attr("disabled", true);
-        }
-        $select.val(switchDetails["mode"]);
-        $fieldset.append($label).append($select);
-        $form.append($fieldset);
-        return $form;
-      },
-      popout: function($modal) {
-        var $gridHTML = one.lib.dashlet.datagrid.init(one.f.switchmanager.nodesLearnt.id.modal.datagrid, {
-          searchable: true,
-        filterable: false,
-        pagination: true,
-        flexibleRowsPerPage: true,
-        popout: true
-        }, "table-striped table-condensed");
-        one.lib.modal.inject.body($modal, $gridHTML);
-        // attach to shown event of modal 
-        $modal.on("shown", function() {
-          var url = one.f.switchmanager.rootUrl + "/nodesLearnt";
-          one.f.switchmanager.nodesLearnt.ajax.main(url, function(content) {
-            var dataSource = one.f.switchmanager.nodesLearnt.data.gridDataSource.popout(content);
-            $("#" + one.f.switchmanager.nodesLearnt.id.modal.datagrid).datagrid({
-              dataSource: dataSource,
-              stretchHeight: false
-            })
-            .on("loaded", function() {
-              $("#" + one.f.switchmanager.nodesLearnt.id.modal.datagrid).find("tbody span").click(function(){
-                one.f.switchmanager.nodesLearnt.modal.initialize.displayPorts($(this));
-              });
-            });
-          });
-        });
-      }
-    },
-    save: function($modal) {
-      var result = {};
-      result['nodeName'] = $('#' + one.f.switchmanager.nodesLearnt.id.modal.form.nodeName, $modal).val();
-      if(!one.f.switchmanager.validateName(result['nodeName'])) {
-        alert("Node name can contain upto 255 characters");
-        return;
-      }
-      result['nodeId'] = $('#' + one.f.switchmanager.nodesLearnt.id.modal.form.nodeId, $modal).val();
-      result['tier'] = $('#' + one.f.switchmanager.nodesLearnt.id.modal.form.tier, $modal).val();
-      result['operationMode'] = $('#' + one.f.switchmanager.nodesLearnt.id.modal.form.operationMode, $modal).val();
-      one.f.switchmanager.nodesLearnt.modal.ajax(result, 
-          function(response) {
-            if(response.status == true) {
-              $modal.modal('hide');
-              one.topology.update(); // refresh visual topology with new name
-              // TODO: Identify dashlet by inserting a nodesLearnt div 
-              // in the dashlet() instead
-              one.f.switchmanager.nodesLearnt.dashlet($("#left-top .dashlet"));
-            } else {
-              alert(response.message);
-            }
-
-          });
-    },
-    ajax: function(requestData, callback) {
-      $.getJSON(one.f.switchmanager.rootUrl + "/nodesLearnt/update", requestData, function(response) {
-        callback(response);
-      });
-    },
-    footer: {
-      updateNode: function() {
-        var footer = [];
-        var saveButton = one.lib.dashlet.button.single("Save", one.f.switchmanager.nodesLearnt.id.modal.save, "btn-primary", "");
-        var $saveButton = one.lib.dashlet.button.button(saveButton);
-        footer.push($saveButton);
-
-        return footer;
-      },
-      popout: function() {
-        // TODO: Maybe put a close button in the footer?
-        return [];
-      }
-    }
-  },
-  // data functions
-  data : {
-    gridDataSource: {
-      abridged: function(data) {
-        var source = new StaticDataSource({
-          columns: [
-        {
-          property: 'nodeName',
-        label: 'Node Name',
-        sortable: true
-        },
-        {
-          property: 'nodeId',
-        label: 'Node ID',
-        sortable: true
-        },
-        {
-          property: 'ports',
-        label: 'Ports',
-        sortable: true
-        }
-        ],
-        data: data.nodeData,
-        formatter: function(items) {
-          $.each(items, function (index, item) {
-            var nodeName = item.nodeName;
-            var nodeNameEntry = item.nodeName ? item.nodeName : "Click to update";
-            item.nodeName = '<a href="#" id="' + item.nodeId + '" switchDetails=' + encodeURIComponent(JSON.stringify(item)) + 
-            ' privilege=' + data.privilege + '>' + nodeNameEntry + '</a>';
-
-          var ports = item.ports;
-          var portsMatch = ports.match(/<\/span>/g);
-          var portsLength = 0;
-          if (portsMatch != null) {
-            portsLength = portsMatch.length;
-          }
-          item.ports = '<span class="nodePorts" style="cursor:pointer;color: #08c" ports='+encodeURIComponent(JSON.stringify(item.ports)) + ' nodeId="' + item.nodeId
-            + '" nodeName="' + nodeName
-            + '">' + portsLength +'</span>';
-          }); 
-        },
-        delay: 0
-        });
-        return source;
-
-      },
-      popout: function(data) {
-        var source = new StaticDataSource({
-          columns: [
-        {
-          property: 'nodeName',
-        label: 'Node Name',
-        sortable: true
-        },
-        {
-          property: 'nodeId',
-        label: 'Node ID',
-        sortable: true
-        },
-        {
-          property: 'tierName',
-        label: 'Tier Name',
-        sortable: true
-        },
-        {
-          property: 'mac',
-        label: 'MAC Address',
-        sortable: true
-        },
-        {
-          property: 'ports',
-          label: 'Ports',
-          sortable: true
-        }
-        ],
-          data: data.nodeData,
-          formatter: function(items) {
-            $.each(items, function (index, item) {
-              var ports = item.ports;
-              var portsMatch = ports.match(/<\/span>/g);
-              var portsLength = 0;
-              if (portsMatch != null) {
-                portsLength = portsMatch.length;
-              }
-              item.ports = '<span class="nodePorts" style="cursor: pointer;color: #08c" ports='+encodeURIComponent(JSON.stringify(item.ports)) + ' nodeId="' + item.nodeId
-              + '" nodeName="' + item.nodeName
-              + '">' + portsLength +'</span>';
-            }); 
-          },
-          delay: 0
-        });
-        return source;
-      },
-      displayPorts: function(content){
-        var data=[];
-        var start=0;;
-        var finish=content.indexOf("<br>",start);
-        while(finish != -1){
-          data.push({"ports":content.substring(start,finish)});
-          start=finish+4
-            finish=content.indexOf("<br>",start);
-        }
-        var source = new StaticDataSource({
-          columns: [
-        {
-          property: 'ports',
-            label: 'Ports',
-            sortable: true
-        }
-        ],
-            data:data,
-            delay: 0
-        });
-
-        return source;
-      }
-    },
-    abridged : function(data) {
-      var result = [];
-      $.each(data.nodeData, function(key, value) {
-        var tr = {};
-        var entry = [];
-        var nodeNameEntry = value["nodeName"] ? value["nodeName"] : "Click to update";
-
-        // TODO: Move anchor tag creation to one.lib.form.
-        var aTag;
-        aTag = document.createElement("a");
-        aTag.privilege = data.privilege;
-        aTag.addEventListener("click", one.f.switchmanager.nodesLearnt.modal.initialize.updateNode);
-        aTag.addEventListener("mouseover", function(evt) {
-          evt.target.style.cursor = "pointer";
-        }, false);
-        aTag.setAttribute("id", encodeURIComponent(value["nodeId"]));
-        aTag.switchDetails = value;
-        aTag.innerHTML = nodeNameEntry;
-        entry.push(aTag);
-        entry.push(value["nodeId"]);
-        entry.push(value["ports"]);
-        tr.entry = entry;
-        result.push(tr);
-      });
-      return result;
-    },
-    popout : function(data) {
-      var result = [];
-      $.each(data.nodeData, function(key, value) {
-        var tr = {};
-        // fill up all the td's
-        var entry = [];
-        var nodenameentry = value["nodeName"] ? value["nodeName"] : "No name provided";
-        entry.push(nodenameentry);
-        entry.push(value["nodeId"]);
-        entry.push(value["tierName"]);
-        entry.push(value["mac"]);
-        entry.push(value["ports"]);
-        tr.entry = entry;
-        result.push(tr);
-      });
-      return result;
-    }
-  }
-};
-
-one.f.switchmanager.subnetGatewayConfig = {
-  id: {
-    dashlet: {
-      addIPAddress: "one_f_switchmanager_subnetGatewayConfig_id_dashlet_addIP",
-      addPorts: "one_f_switchmanager_subnetGatewayConfig_id_dashlet_addPorts",
-      removeIPAddress: "one_f_switchmanager_subnetGatewayConfig_id_dashlet_removeIP",
-      datagrid: "one_f_switchmanager_subnetGatewayConfig_id_dashlet_datagrid",
-      selectAll: "one_f_switchmanager_subnetGatewayConfig_id_dashlet_selectAll"
-    }, 
-    modal: {
-      modal: "one_f_switchmanager_subnetGatewayConfig_id_modal_modal",
-      ports : "one_f_switchmanager_subnetGatewayConfig_id_modal_ports",
-      save: "one_f_switchmanager_subnetGatewayConfig_id_modal_save",
-      remove: "one_f_switchmanager_subnetGatewayConfig_id_modal_remove",
-      cancel: "one_f_switchmanager_subnetGatewayConfig_id_modal_cancel",
-      form: {
-        name : "one_f_switchmanager_subnetGatewayConfig_id_modal_form_gatewayname",
-        gatewayIPAddress : "one_f_switchmanager_subnetGatewayConfig_id_modal_form_gatewayipaddress",
-        nodeId: "one_f_switchmanager_subnetGatewayConfig_id_modal_form_nodeid",
-        ports: "one_f_switchmanager_subnetGatewayConfig_id_modal_form_ports"
-      }
-    }
-  },
-  // device ajax calls
-  dashlet: function($dashlet) {
-    one.lib.dashlet.empty($dashlet);
-    $dashlet.append(one.lib.dashlet.header(one.f.dashlet.subnetGatewayConfig.name));
-    // Add gateway IP Address button
-    var url = one.f.switchmanager.rootUrl + "/subnets";
-    one.f.switchmanager.subnetGatewayConfig.ajax.main(url, {}, function(content) {
-
-      if (content.privilege === 'WRITE') {
-        var button = one.lib.dashlet.button.single("Add Gateway IP Address",
-          one.f.switchmanager.subnetGatewayConfig.id.dashlet.addIPAddress, "btn-primary", "btn-mini");
-        var $button = one.lib.dashlet.button.button(button);
-        $button.click(function() {
-          var $modal = one.f.switchmanager.subnetGatewayConfig.modal.initialize.gateway();
-          $modal.modal();
-        });
-        $dashlet.append($button);
-
-        // Delete gateway ip address button
-        var button = one.lib.dashlet.button.single("Remove Gateway IP Address",
-          one.f.switchmanager.subnetGatewayConfig.id.dashlet.removeIPAddress, "btn-danger", "btn-mini");
-        var $button = one.lib.dashlet.button.button(button);
-        $button.click(function() {
-          var gatewaysToDelete = [];
-          var checkedCheckBoxes = $("#" + one.f.switchmanager.subnetGatewayConfig.id.dashlet.datagrid).find("tbody input:checked")
-          checkedCheckBoxes.each(function(index, value) {
-            gatewaysToDelete.push(checkedCheckBoxes[index].id);
-          });
-        if (checkedCheckBoxes.size() === 0) {
-          return false;
-        }
-        one.f.switchmanager.subnetGatewayConfig.modal.removeMultiple.dialog(gatewaysToDelete)
-        });
-        $dashlet.append($button);
-
-        // Add Ports button
-        var button = one.lib.dashlet.button.single("Add Ports",
-            one.f.switchmanager.subnetGatewayConfig.id.dashlet.addPorts, "btn-primary", "btn-mini");
-        var $button = one.lib.dashlet.button.button(button);
-        $button.click(function() {
-          if (one.f.switchmanager.subnetGatewayConfig.registry.gateways.length === 0) {
-            alert('No Gateways Exist');
-            return false;
-          }
-          var $modal = one.f.switchmanager.subnetGatewayConfig.modal.initialize.ports();
-          $modal.modal();
-        });
-        $dashlet.append($button);
-      }
-      var $gridHTML = one.lib.dashlet.datagrid.init(one.f.switchmanager.subnetGatewayConfig.id.dashlet.datagrid, {
-        searchable: true,
-          filterable: false,
-          pagination: true,
-          flexibleRowsPerPage: true
-      }, "table-striped table-condensed");
-      $dashlet.append($gridHTML);
-      var dataSource = one.f.switchmanager.subnetGatewayConfig.data.devicesgrid(content);
-      $("#" + one.f.switchmanager.subnetGatewayConfig.id.dashlet.datagrid).datagrid({dataSource: dataSource})
-        .on("loaded", function() {
-          $("#"+one.f.switchmanager.subnetGatewayConfig.id.dashlet.selectAll).click(function() {
-            $("#" + one.f.switchmanager.subnetGatewayConfig.id.dashlet.datagrid).find(':checkbox').prop('checked',
-              $("#"+one.f.switchmanager.subnetGatewayConfig.id.dashlet.selectAll).is(':checked'));
-          });
-          $(".subnetGatewayConfig").click(function(e){
-            if (!$('.subnetGatewayConfig[type=checkbox]:not(:checked)').length) {
-              $("#"+one.f.switchmanager.subnetGatewayConfig.id.dashlet.selectAll)
-            .prop("checked",
-              true);
-            } else {
-              $("#"+one.f.switchmanager.subnetGatewayConfig.id.dashlet.selectAll)
-            .prop("checked",
-              false);
-            }
-            e.stopPropagation();
-          });
-        });
-    });
-  },
-  ajax : {
-    main : function(url, requestData, callback) {
-      $.getJSON(url, requestData, function(data) {
-        callback(data);
-      });
-    }
-  },
-  registry: {},
-  modal : {
-    initialize: {
-      gateway: function() {
-        var h3 = "Add Gateway IP Address";
-        var footer = one.f.switchmanager.subnetGatewayConfig.modal.footer();
-        var $modal = one.lib.modal.spawn(one.f.switchmanager.subnetGatewayConfig.id.modal.modal, h3, "", footer);
-        // bind save button
-        $('#' + one.f.switchmanager.subnetGatewayConfig.id.modal.save, $modal).click(function() {
-          one.f.switchmanager.subnetGatewayConfig.modal.save.gateway($modal);
-        });
-        var $body = one.f.switchmanager.subnetGatewayConfig.modal.body.gateway();
-        one.lib.modal.inject.body($modal, $body);
-        return $modal;
-      },
-      ports: function() {
-        var h3 = "Add Ports";
-        var footer = one.f.switchmanager.subnetGatewayConfig.modal.footer();
-        var $modal = one.lib.modal.spawn(one.f.switchmanager.subnetGatewayConfig.id.modal.ports, h3, "", footer);
-        // bind save button
-        $('#' + one.f.switchmanager.subnetGatewayConfig.id.modal.save, $modal).click(function() {
-          one.f.switchmanager.subnetGatewayConfig.modal.save.ports($modal);
-        });
-
-        // TODO: Change to subnetGateway instead.
-        one.f.switchmanager.spanPortConfig.modal.ajax.nodes(function(nodes, nodeports) {
-          var $body = one.f.switchmanager.subnetGatewayConfig.modal.body.ports(nodes, nodeports);
-          one.lib.modal.inject.body($modal, $body);
-        });
-        return $modal;
-      }
-    },
-    save: {
-      gateway: function($modal) {
-        var result = {};
-        result['gatewayName'] = $('#' + one.f.switchmanager.subnetGatewayConfig.id.modal.form.name, $modal).val();
-        if(!one.f.switchmanager.validateName(result['gatewayName'])) {
-          alert("Gateway name can contain upto 255 characters");
-          return;
-        }
-        result['gatewayIPAddress'] = $('#' + one.f.switchmanager.subnetGatewayConfig.id.modal.form.gatewayIPAddress, $modal).val();
-        one.f.switchmanager.subnetGatewayConfig.modal.ajax.gateway(result, 
-            function(response) {
-              if(response.status == true) {
-                $modal.modal('hide');
-                one.f.switchmanager.subnetGatewayConfig.dashlet($("#right-bottom .dashlet"));
-              } else {
-                alert(response.message);
-              }
-            });
-      },
-      ports: function($modal) {
-        var result = {};
-        var gatewayRegistryIndex = $('#' + one.f.switchmanager.subnetGatewayConfig.id.modal.form.name, $modal).val();
-        result['portsName'] = one.f.switchmanager.subnetGatewayConfig.registry.gateways[gatewayRegistryIndex];
-        result['nodeId'] = $('#' + one.f.switchmanager.subnetGatewayConfig.id.modal.form.nodeId, $modal).val();
-        result['ports'] = $('#' + one.f.switchmanager.subnetGatewayConfig.id.modal.form.ports, $modal).val();
-        if(!result['portsName'] || result['portsName'] == "") {
-          alert("No gateway chosen. Cannot add port");
-          return;
-        }
-        if(!result['nodeId'] || result['nodeId'] == "") {
-          alert("Please select a node.");
-          return;
-        }
-        if(!result['ports'] || result['ports'] == "") {
-          alert("Please choose a port.");
-          return;
-        }
-        one.f.switchmanager.subnetGatewayConfig.modal.ajax.ports(result, 
-            function(response) {
-              if(response.status == true) {
-                $modal.modal('hide');
-                one.f.switchmanager.subnetGatewayConfig.dashlet($("#right-bottom .dashlet"));
-              } else {
-                alert(response.message);
-              }
-            });
-      }
-    },
-    body: {
-      gateway: function() {
-        var $form = $(document.createElement('form'));
-        var $fieldset = $(document.createElement('fieldset'));
-        // gateway name
-        var $label = one.lib.form.label("Name");
-        var $input = one.lib.form.input("Name");
-        $input.attr('id', one.f.switchmanager.subnetGatewayConfig.id.modal.form.name);
-        $fieldset.append($label).append($input);
-        // gateway IP Mask 
-        var $label = one.lib.form.label("Gateway IP Address/Mask");
-        var $input = one.lib.form.input("Gateway IP Address/Mask");
-        var $help = one.lib.form.help('Example: 192.168.10.254/16');
-        $input.attr('id', one.f.switchmanager.subnetGatewayConfig.id.modal.form.gatewayIPAddress);
-        $fieldset.append($label).append($input).append($help);
-
-        $form.append($fieldset);
-        return $form;
-      },
-      ports: function(nodes, nodeports) {
-        var $form = $(document.createElement('form'));
-        var $fieldset = $(document.createElement('fieldset'));
-        // gateways drop down
-        var $label = one.lib.form.label("Gateway Name");
-        var $select = one.lib.form.select.create(one.f.switchmanager.subnetGatewayConfig.registry.gateways);
-        $select.attr('id', one.f.switchmanager.subnetGatewayConfig.id.modal.form.name);
-        one.lib.form.select.prepend($select, { '' : 'Please Select a Gateway' });
-        $select.val($select.find("option:first").val());
-        $fieldset.append($label).append($select);
-
-        // node ID
-        var $label = one.lib.form.label("Node ID");
-        var $select = one.lib.form.select.create(nodes);
-        $select.attr('id', one.f.switchmanager.subnetGatewayConfig.id.modal.form.nodeId);
-        one.lib.form.select.prepend($select, { '' : 'Please Select a Node' });
-        $select.val($select.find("option:first").val());
-        $fieldset.append($label).append($select);
-
-        // bind onchange
-        $select.change(function() {
-          // retrieve port value
-          var node = $(this).find('option:selected').attr('value');
-          one.f.switchmanager.subnetGatewayConfig.registry['currentNode'] = node;
-          var $ports = $('#' + one.f.switchmanager.subnetGatewayConfig.id.modal.form.ports);
-          var ports = nodeports[node];
-          var options = {};
-          $(ports).each(function(idx, val) {
-            options[val.internalPortName] = val.portName+' ('+val.portId+')'; 
-              });
-            one.lib.form.select.inject($ports, options);
-            one.lib.form.select.prepend($ports, { '' : 'Please Select a Port' });
-            $ports.val($ports.find("option:first").val());
-            });
-
-          // ports
-          var $label = one.lib.form.label("Select Port");
-          var $select = one.lib.form.select.create();
-          one.lib.form.select.prepend($select, { '' : 'Please Select a Port' });
-          $select.attr('id', one.f.switchmanager.subnetGatewayConfig.id.modal.form.ports);
-          $fieldset.append($label).append($select);
-
-          $form.append($fieldset);
-          return $form;
-      }
-    },
-    ajax: {
-      gateway: function(requestData, callback) {
-        $.getJSON(one.f.switchmanager.rootUrl + "/subnetGateway/add", requestData, function(data) {
-          callback(data);
-        });
-      },
-      ports: function(requestData, callback) {
-        $.getJSON(one.f.switchmanager.rootUrl + "/subnetGateway/ports/add", requestData, function(data) {
-          callback(data);
-        });
-      }
-    },
-    footer : function() {
-      var footer = [];
-      var saveButton = one.lib.dashlet.button.single("Save", one.f.switchmanager.subnetGatewayConfig.id.modal.save, "btn-primary", "");
-      var $saveButton = one.lib.dashlet.button.button(saveButton);
-      footer.push($saveButton);
-      return footer;
-    },
-    removeMultiple: {
-      dialog: function(gatewaysToDelete) {
-        var h3 = 'Remove Gateway IP Address';
-
-        var footer = one.f.switchmanager.subnetGatewayConfig.modal.removeMultiple.footer();
-        var $body = one.f.switchmanager.subnetGatewayConfig.modal.removeMultiple.body(gatewaysToDelete);
-        var $modal = one.lib.modal.spawn(one.f.switchmanager.subnetGatewayConfig.id.modal.modal, h3, $body, footer);
-
-        // bind close button
-        $('#'+one.f.switchmanager.subnetGatewayConfig.id.modal.cancel, $modal).click(function() {
-          $modal.modal('hide');
-        });
-
-        // bind remove rule button
-        $('#'+one.f.switchmanager.subnetGatewayConfig.id.modal.remove, $modal).click(this, function(e) {
-          var requestData = {};
-          if (gatewaysToDelete.length > 0) {
-            requestData["gatewaysToDelete"] = gatewaysToDelete.toString();
-            var url = one.f.switchmanager.rootUrl + "/subnetGateway/delete";
-            one.f.switchmanager.subnetGatewayConfig.ajax.main(url, requestData, function(response) {
-              $modal.modal('hide');
-              if (response.status == true) {
-                // refresh dashlet by passing dashlet div as param 
-                one.lib.alert("Gateway IP Address(es) successfully removed");
-              } else {
-                alert(response.message);
-              }
-              one.f.switchmanager.subnetGatewayConfig.dashlet($("#right-bottom .dashlet"));
-            });
-          }
-        });
-        $modal.modal();
-      },
-      footer : function() {
-        var footer = [];
-        var remove = one.lib.dashlet.button.single('Remove Gateway IP Address',one.f.switchmanager.subnetGatewayConfig.id.modal.remove, 'btn-danger', '');
-        var $remove = one.lib.dashlet.button.button(remove);
-        footer.push($remove);
-
-        var cancel = one.lib.dashlet.button.single('Cancel', one.f.switchmanager.subnetGatewayConfig.id.modal.cancel, '', '');
-        var $cancel = one.lib.dashlet.button.button(cancel);
-        footer.push($cancel);
-
-        return footer;
-      },
-      body : function (gatewayList) {
-        var $p = $(document.createElement('p'));
-        var p = 'Remove the following Gateway IP Address(es)?';
-        //creata a BS label for each rule and append to list
-        $(gatewayList).each(function(){
-          var $span = $(document.createElement('span'));
-          $span.append(this);
-          p += '<br/>' + $span[0].outerHTML;
-        });
-        $p.append(p);
-        return $p;
-      }
-    }
-  },
-  // data functions
-  data : {
-    devicesgrid: function(data) {
-      one.f.switchmanager.subnetGatewayConfig.registry.gateways = [];
-      var source = new StaticDataSource({
-        columns: [
-      {
-        property: 'selector',
-          label: "<input type='checkbox'  id='"
-        +one.f.switchmanager.subnetGatewayConfig.id.dashlet.selectAll+"'/>",
-          sortable: false
-      },
-          {
-            property: 'name',
-          label: 'Name',
-          sortable: true
-          },
-          {
-            property: 'subnet',
-          label: 'Gateway IP Address/Mask',
-          sortable: true
-          },
-          {
-            property: 'nodePorts',
-          label: 'Ports',
-          sortable: false
-          }
-      ],
-        data: data.nodeData,
-        formatter: function(items) {
-          $.each(items, function(index, tableRow) {
-            tableRow["selector"] = '<input type="checkbox" class="subnetGatewayConfig" id="'
-            + tableRow["name"] + '"></input>';
-          var json = tableRow["nodePorts"];
-          var nodePorts = JSON.parse(json);
-          var nodePortHtml = "<div>";
-          $.each(nodePorts, function(index, nodePort) {
-            nodePortHtml += nodePort["nodePortName"] + " @ " + nodePort["nodeName"];
-            nodePortHtml += "&nbsp;";
-            nodePortHtml += '<a href="#" id="' + encodeURIComponent(nodePort["nodePortId"]) +
-            '" gatewayName="' + tableRow["name"] +
-            '" onclick="javascript:one.f.switchmanager.subnetGatewayConfig.actions.deleteNodePort(this);">Remove</a>';
-          nodePortHtml += "<br/>";
-          });
-          nodePortHtml += "</div>";
-          tableRow["nodePorts"] = nodePortHtml;
-          });
-
-        },
-        delay: 0
-      });
-      // populate the registry with subnet names
-      one.f.switchmanager.subnetGatewayConfig.registry.gateways = [];
-      $.each(data.nodeData, function(key, value) {
-        one.f.switchmanager.subnetGatewayConfig.registry.gateways.push(value["name"]);
-      });
-      return source;          
-    },
-    devices : function(data) {
-      var result = [];
-      one.f.switchmanager.subnetGatewayConfig.registry.gateways = [];
-      $.each(data.nodeData, function(key, value) {
-        var tr = {};
-        // fill up all the td's
-        var subnetConfigObject = $.parseJSON(value["json"]);
-        var nodePorts = subnetConfigObject.nodePorts;
-        var $nodePortsContainer = $(document.createElement("div"));
-
-        for(var i = 0; i < nodePorts.length; i++) {
-          var nodePort = nodePorts[i];
-          $nodePortsContainer.append(nodePort + " ");
-          // add delete anchor tag to delete ports
-          var aTag = document.createElement("a");
-          aTag.setAttribute("id", encodeURIComponent(nodePort));
-          aTag.gatewayName = value["name"];
-          aTag.addEventListener("click", function(evt) {
-            var htmlPortAnchor = evt.target;
-            var requestData = {};
-            requestData["gatewayName"] = evt.target.gatewayName;
-            requestData["nodePort"] = decodeURIComponent(evt.target.id);
-            // make ajax call to delete port
-            var url = one.f.switchmanager.rootUrl + "/subnetGateway/ports/delete";
-            one.f.switchmanager.subnetGatewayConfig.ajax.main(url, requestData, function(response) {
-              if(response.status == true) {
-                // refresh dashlet by passing dashlet div as param
-                one.f.switchmanager.subnetGatewayConfig.dashlet($("#right-bottom .dashlet"));
-              } else {
-                alert(response.message);
-              }
-            });
-
-          });
-          aTag.addEventListener("mouseover", function(evt) {
-            evt.target.style.cursor = "pointer";
-          }, false);
-          aTag.innerHTML = "Remove";
-          $nodePortsContainer.append(aTag);
-          $nodePortsContainer.append("<br/>");
-        }
-
-        // store gateways in the registry so that they can be used in the add ports popup
-        one.f.switchmanager.subnetGatewayConfig.registry.gateways.push(value["name"]);
-        var entry = [];
-        var checkbox = document.createElement("input");
-        checkbox.setAttribute("type", "checkbox");
-        checkbox.setAttribute("id", value["name"]);
-        entry.push(checkbox);
-        entry.push(value["name"]);
-        entry.push(value["subnet"]);
-        entry.push($nodePortsContainer);
-        tr.entry = entry;
-        result.push(tr);
-      });
-      return result;
-    }
-  },
-  actions: {
-    deleteNodePort: function(htmlPortAnchor) {
-      var requestData = {};
-      requestData["gatewayName"] = htmlPortAnchor.getAttribute("gatewayName");
-      requestData["nodePort"] = decodeURIComponent(htmlPortAnchor.id);
-      // make ajax call to delete port
-      var url = one.f.switchmanager.rootUrl + "/subnetGateway/ports/delete";
-      one.f.switchmanager.subnetGatewayConfig.ajax.main(url, requestData, function(response) {
-        if(response.status == true) {
-          // refresh dashlet by passing dashlet div as param
-          one.f.switchmanager.subnetGatewayConfig.dashlet($("#right-bottom .dashlet"));
-        } else {
-          alert(response.message);
-        }
-      });
-    }
-  }
-}
-
-one.f.switchmanager.staticRouteConfig = {
-  id: {
-    dashlet: {
-      add: "one_f_switchmanager_staticRouteConfig_id_dashlet_add",
-      remove: "one_f_switchmanager_staticRouteConfig_id_dashlet_remove",
-      datagrid: "one_f_switchmanager_staticRouteConfig_id_dashlet_datagrid",
-      selectAll: "one_f_switchmanager_staticRouteConfig_id_dashlet_selectAll"
-    }, 
-    modal: {
-      modal: "one_f_switchmanager_staticRouteConfig_id_modal_modal",
-      save: "one_f_switchmanager_staticRouteConfig_id_modal_save",
-      cancel: "one_f_switchmanager_staticRouteConfig_id_modal_cancel",
-      remove: "one_f_switchmanager_staticRouteConfig_id_modal_remove",
-      form: {
-        routeName : "one_f_switchmanager_staticRouteConfig_id_modal_form_routename",
-        staticRoute : "one_f_switchmanager_staticRouteConfig_id_modal_form_staticroute",
-        nextHop : "one_f_switchmanager_staticRouteConfig_id_modal_form_nexthop",
-      }
-    }
-  },
-  dashlet: function($dashlet) {
-    one.lib.dashlet.empty($dashlet);
-    var url = one.f.switchmanager.rootUrl + "/staticRoutes";
-    one.f.switchmanager.staticRouteConfig.ajax.main(url, {}, function(content) {
-
-      if (content.privilege === 'WRITE') {
-        // Add static route button
-        var button = one.lib.dashlet.button.single("Add Static Route", one.f.switchmanager.staticRouteConfig.id.dashlet.add, "btn-primary", "btn-mini");
-        var $button = one.lib.dashlet.button.button(button);
-        $button.click(function() {
-          var $modal = one.f.switchmanager.staticRouteConfig.modal.initialize();
-          $modal.modal();
-        });
-        $dashlet.append(one.lib.dashlet.header(one.f.dashlet.staticRouteConfig.name));
-        $dashlet.append($button);
-
-        // Delete static route button
-        var button = one.lib.dashlet.button.single("Remove Static Route", one.f.switchmanager.staticRouteConfig.id.dashlet.remove, "btn-danger", "btn-mini");
-        var $button = one.lib.dashlet.button.button(button);
-        $button.click(function() {
-          var routesToDelete = [];
-          var checkedCheckBoxes = $("#" + one.f.switchmanager.staticRouteConfig.id.dashlet.datagrid).find("tbody input:checked");
-          checkedCheckBoxes.each(function(index, value) {
-            routesToDelete.push(checkedCheckBoxes[index].id);
-          });
-          if (checkedCheckBoxes.size() === 0) {
-            return false;
-          }
-          one.f.switchmanager.staticRouteConfig.modal.removeMultiple.dialog(routesToDelete);
-        });
-        $dashlet.append($button);
-      }
-      var $gridHTML = one.lib.dashlet.datagrid.init(one.f.switchmanager.staticRouteConfig.id.dashlet.datagrid, {
-        searchable: true,
-          filterable: false,
-          pagination: true,
-          flexibleRowsPerPage: true
-      }, "table-striped table-condensed");
-      $dashlet.append($gridHTML);
-      var dataSource = one.f.switchmanager.staticRouteConfig.data.staticRouteConfigGrid(content);
-      $("#" + one.f.switchmanager.staticRouteConfig.id.dashlet.datagrid).datagrid({dataSource: dataSource})
-        .on("loaded", function() {
-          $("#"+one.f.switchmanager.staticRouteConfig.id.dashlet.selectAll).click(function() {
-            $("#" + one.f.switchmanager.staticRouteConfig.id.dashlet.datagrid).find(':checkbox').prop('checked',
-              $("#"+one.f.switchmanager.staticRouteConfig.id.dashlet.selectAll).is(':checked'));
-          });
-          $(".staticRoute").click(function(e){
-            if (!$('.staticRoute[type=checkbox]:not(:checked)').length) {
-              $("#"+one.f.switchmanager.staticRouteConfig.id.dashlet.selectAll)
-            .prop("checked",
-              true);
-            } else {
-              $("#"+one.f.switchmanager.staticRouteConfig.id.dashlet.selectAll)
-            .prop("checked",
-              false);
-            }
-            e.stopPropagation();
-          });
-        });
-    });
-  },
-  // device ajax calls
-  ajax : {
-    main : function(url, requestData, callback) {
-      $.getJSON(url, requestData, function(data) {
-        callback(data);
-      });
-    }
-  },
-  registry: {},
-  modal : {
-    initialize: function() {
-      var h3 = "Add Static Route";
-      var footer = one.f.switchmanager.staticRouteConfig.modal.footer();
-      var $modal = one.lib.modal.spawn(one.f.switchmanager.staticRouteConfig.id.modal.modal, h3, "", footer);
-      // bind save button
-      $('#' + one.f.switchmanager.staticRouteConfig.id.modal.save, $modal).click(function() {
-        one.f.switchmanager.staticRouteConfig.modal.save($modal);
-      });
-      var $body = one.f.switchmanager.staticRouteConfig.modal.body();
-      one.lib.modal.inject.body($modal, $body);
-      return $modal;
-    },
-    save: function($modal) {
-      var result = {};
-      result['routeName'] = $('#' + one.f.switchmanager.staticRouteConfig.id.modal.form.routeName, $modal).val();
-      result['staticRoute'] = $('#' + one.f.switchmanager.staticRouteConfig.id.modal.form.staticRoute, $modal).val();
-      result['nextHop'] = $('#' + one.f.switchmanager.staticRouteConfig.id.modal.form.nextHop, $modal).val();
-      one.f.switchmanager.staticRouteConfig.modal.ajax.staticRouteConfig(result, function(response) {
-        if(response.status == true) {
-          $modal.modal('hide');
-          // refresh dashlet by passing dashlet div as param
-          one.f.switchmanager.staticRouteConfig.dashlet($("#left-bottom .dashlet"));
-        } else {
-          // TODO: Show error message in a error message label instead.
-          alert(response.message);
-        }
-      });
-    },
-    body: function() {
-      var $form = $(document.createElement('form'));
-      var $fieldset = $(document.createElement('fieldset'));
-      // static route name
-      var $label = one.lib.form.label("Name");
-      var $input = one.lib.form.input("Name");
-      $input.attr('id', one.f.switchmanager.staticRouteConfig.id.modal.form.routeName);
-      $fieldset.append($label).append($input);
-      // static route IP Mask 
-      var $label = one.lib.form.label("Static Route");
-      var $input = one.lib.form.input("Static Route");
-      var $help = one.lib.form.help('Example: 53.55.0.0/16');
-      $input.attr('id', one.f.switchmanager.staticRouteConfig.id.modal.form.staticRoute);
-      $fieldset.append($label).append($input).append($help);
-      // static route IP Mask 
-      var $label = one.lib.form.label("Next Hop");
-      var $input = one.lib.form.input("Next Hop");
-      var $help = one.lib.form.help('Example: 192.168.10.254');
-      $input.attr('id', one.f.switchmanager.staticRouteConfig.id.modal.form.nextHop);
-      $fieldset.append($label).append($input).append($help);
-      // return
-      $form.append($fieldset);
-      return $form;
-    },
-    ajax: {
-      staticRouteConfig: function(requestData, callback) {
-        $.getJSON(one.f.switchmanager.rootUrl + "/staticRoute/add", requestData, function(data) {
-          callback(data);
-        });
-      }
-    },
-    data : {
-
-    },
-    footer : function() {
-      var footer = [];
-      var saveButton = one.lib.dashlet.button.single("Save", one.f.switchmanager.staticRouteConfig.id.modal.save, "btn-primary", "");
-      var $saveButton = one.lib.dashlet.button.button(saveButton);
-      footer.push($saveButton);
-      return footer;
-    },
-    removeMultiple: {
-      dialog: function(routesToDelete) {
-        var h3 = 'Remove Static Route';
-
-        var footer = one.f.switchmanager.staticRouteConfig.modal.removeMultiple.footer();
-        var $body = one.f.switchmanager.staticRouteConfig.modal.removeMultiple.body(routesToDelete);
-        var $modal = one.lib.modal.spawn(one.f.switchmanager.staticRouteConfig.id.modal.modal, h3, $body, footer);
-
-        // bind close button
-        $('#'+one.f.switchmanager.staticRouteConfig.id.modal.cancel, $modal).click(function() {
-          $modal.modal('hide');
-        });
-
-        // bind remove rule button
-        $('#'+one.f.switchmanager.staticRouteConfig.id.modal.remove, $modal).click(this, function(e) {
-          if (routesToDelete.length > 0) {
-            var requestData = {};
-            requestData["routesToDelete"] = routesToDelete.toString();
-            var url = one.f.switchmanager.rootUrl + "/staticRoute/delete";
-            one.f.switchmanager.staticRouteConfig.ajax.main(url, requestData, function(response) {
-              $modal.modal('hide');
-              if (response.status == true) {
-                // refresh dashlet by passing dashlet div as param 
-                one.lib.alert("Static Route(s) successfully removed");
-              } else {
-                alert(response.message);
-              }
-              one.f.switchmanager.staticRouteConfig.dashlet($("#left-bottom .dashlet"));
-            });
-          }
-        });
-        $modal.modal();
-      },
-      footer : function() {
-        var footer = [];
-        var remove = one.lib.dashlet.button.single('Remove Static Route',one.f.switchmanager.staticRouteConfig.id.modal.remove, 'btn-danger', '');
-        var $remove = one.lib.dashlet.button.button(remove);
-        footer.push($remove);
-
-        var cancel = one.lib.dashlet.button.single('Cancel', one.f.switchmanager.staticRouteConfig.id.modal.cancel, '', '');
-        var $cancel = one.lib.dashlet.button.button(cancel);
-        footer.push($cancel);
-
-        return footer;
-      },
-      body : function (staticRouteList) {
-        var $p = $(document.createElement('p'));
-        var p = 'Remove the following Static Route(s)?';
-        //creata a BS label for each rule and append to list
-        $(staticRouteList).each(function(){
-          var $span = $(document.createElement('span'));
-          $span.append(this);
-          p += '<br/>' + $span[0].outerHTML;
-        });
-        $p.append(p);
-        return $p;
-      }
-    }
-  },
-  // data functions
-  data : {
-    staticRouteConfigGrid: function(data) {
-      var source = new StaticDataSource({
-        columns: [
-      {
-        property: 'selector',
-      label: "<input type='checkbox'  id='"
-        +one.f.switchmanager.staticRouteConfig.id.dashlet.selectAll+"'/>",
-      sortable: false
-      },
-      {
-        property: 'name',
-      label: 'Name',
-      sortable: true
-      },
-      {
-        property: 'staticRoute',
-      label: 'Static Route',
-      sortable: true
-      },
-      {
-        property: 'nextHop',
-          label: 'Next Hop Address',
-          sortable: true
-      }
-      ],
-        data: data.nodeData,
-        formatter: function(items) {
-          $.each(items, function(index, item) {
-            item["selector"] = '<input type="checkbox" class="staticRoute" id="' + item["name"] + '"></input>';
-          });
-
-        },
-        delay: 0
-      });
-      return source;              
-    },
-    staticRouteConfig : function(data) {
-      var result = [];
-      $.each(data.nodeData, function(key, value) {
-        var tr = {};
-        // fill up all the td's
-        var entry = [];
-        var checkbox = document.createElement("input");
-        checkbox.setAttribute("type", "checkbox");
-        checkbox.setAttribute("id", value["name"]);
-        entry.push(checkbox);
-        entry.push(value["name"]);
-        entry.push(value["staticRoute"]);
-        entry.push(value["nextHop"]);
-        tr.entry = entry;
-        result.push(tr);
-      });
-      return result;
-    }
-  }
-}
-
-one.f.switchmanager.spanPortConfig = {
-  id: {
-    dashlet: {
-      add: "one_f_switchmanager_spanPortConfig_id_dashlet_add",
-      remove: "one_f_switchmanager_spanPortConfig_id_dashlet_remove",
-      datagrid: "one_f_switchmanager_spanPortConfig_id_dashlet_datagrid",
-      selectAllFlows: "one_f_switchmanager_spanPortConfig_id_dashlet_selectAllFlows"
-    }, 
-    modal: {
-      modal: "one_f_switchmanager_spanPortConfig_id_modal_modal",
-      save: "one_f_switchmanager_spanPortConfig_id_modal_save",
-      cancel: "one_f_switchmanager_spanPortConfig_id_modal_cancel",
-      remove: "one_f_switchmanager_spanPortConfig_id_modal_remove",
-      form: {
-        name : "one_f_switchmanager_spanPortConfig_id_modal_form_name",
-        nodes : "one_f_switchmanager_spanPortConfig_id_modal_form_nodes",
-        port : "one_f_switchmanager_spanPortConfig_id_modal_form_port",
-      }
-    }
-  },
-  dashlet: function($dashlet) {
-    one.lib.dashlet.empty($dashlet);
-
-    //populate table in dashlet
-    var url = one.f.switchmanager.rootUrl + "/spanPorts";
-    one.f.switchmanager.spanPortConfig.ajax.main(url, {}, function(content) {
-
-      if (content.privilege === 'WRITE') {
-
-        // Add span port button
-        var button = one.lib.dashlet.button.single("Add SPAN Port", one.f.switchmanager.spanPortConfig.id.dashlet.add, "btn-primary", "btn-mini");
-        var $button = one.lib.dashlet.button.button(button);
-
-        $button.click(function() {
-          var $modal = one.f.switchmanager.spanPortConfig.modal.initialize();
-          $modal.modal();
-        });
-        $dashlet.append(one.lib.dashlet.header(one.f.dashlet.spanPortConfig.name));
-        $dashlet.append($button);
-
-        // Delete span port button
-        var button = one.lib.dashlet.button.single("Remove SPAN Port", one.f.switchmanager.spanPortConfig.id.dashlet.remove, "btn-danger", "btn-mini");
-        var $button = one.lib.dashlet.button.button(button);
-        $button.click(function() {
-          var spanPortsToDelete = [];
-          var checkedCheckBoxes = $("#" + one.f.switchmanager.spanPortConfig.id.dashlet.datagrid).find("tbody input:checked");
-
-          if (checkedCheckBoxes.size() === 0) {
-            return false;
-          }
-          checkedCheckBoxes.each(function(index, value) {
-            var spanPortObj = {};
-            spanPortObj['spanPortJson'] = decodeURIComponent(checkedCheckBoxes[index].getAttribute("spanPort"));
-            spanPortObj['spanPortNodeName'] = checkedCheckBoxes[index].getAttribute("spanPortNode");
-            spanPortObj['spanPortPortName'] = checkedCheckBoxes[index].getAttribute("spanPortPort");
-
-            spanPortsToDelete.push(spanPortObj);
-          });
-          one.f.switchmanager.spanPortConfig.modal.removeMultiple.dialog(spanPortsToDelete);
-        });
-        $dashlet.append($button);
-      }
-      var $gridHTML = one.lib.dashlet.datagrid.init(one.f.switchmanager.spanPortConfig.id.dashlet.datagrid, {
-        searchable: true,
-          filterable: false,
-          pagination: true,
-          flexibleRowsPerPage: true
-      }, "table-striped table-condensed");
-      $dashlet.append($gridHTML);
-      var dataSource = one.f.switchmanager.spanPortConfig.data.spanPortConfigGrid(content);
-      $("#" + one.f.switchmanager.spanPortConfig.id.dashlet.datagrid).datagrid({dataSource: dataSource})
-        .on("loaded", function() {
-          $("#"+one.f.switchmanager.spanPortConfig.id.dashlet.selectAll).click(function() {
-            $("#" + one.f.switchmanager.spanPortConfig.id.dashlet.datagrid).find(':checkbox').prop('checked',
-              $("#"+one.f.switchmanager.spanPortConfig.id.dashlet.selectAll).is(':checked'));
-          });
-          $(".spanPortConfig").click(function(e){
-            if (!$('.spanPortConfig[type=checkbox]:not(:checked)').length) {
-              $("#"+one.f.switchmanager.spanPortConfig.id.dashlet.selectAll)
-            .prop("checked",
-              true);
-            } else {
-              $("#"+one.f.switchmanager.spanPortConfig.id.dashlet.selectAll)
-            .prop("checked",
-              false);
-            }
-            e.stopPropagation();
-          });
-        });
-    });
-  },
-  // device ajax calls
-  ajax : {
-    main : function(url, requestData, callback) {
-      $.getJSON(url, requestData, function(data) {
-        callback(data);
-      });
-    }
-  },
-  registry: {},
-  modal : {
-    initialize: function() {
-      var h3 = "Add SPAN Port";
-      var footer = one.f.switchmanager.spanPortConfig.modal.footer();
-      var $modal = one.lib.modal.spawn(one.f.switchmanager.spanPortConfig.id.modal.modal, h3, "", footer);
-      // bind save button
-      $('#' + one.f.switchmanager.spanPortConfig.id.modal.save, $modal).click(function() {
-        one.f.switchmanager.spanPortConfig.modal.save($modal);
-      });
-
-      one.f.switchmanager.spanPortConfig.modal.ajax.nodes(function(nodes, nodeports) {
-        var $body = one.f.switchmanager.spanPortConfig.modal.body(nodes, nodeports);
-        one.lib.modal.inject.body($modal, $body);
-      });
-      return $modal;
-    },
-    save: function($modal) {
-      var result = {};
-      result['nodeId'] = $('#' + one.f.switchmanager.spanPortConfig.id.modal.form.nodes, $modal).val();
-      result['spanPort'] = $('#' + one.f.switchmanager.spanPortConfig.id.modal.form.port, $modal).val();
-      one.f.switchmanager.spanPortConfig.modal.ajax.saveSpanPortConfig(result, 
-          function(response) {
-            if(response.status == true) {
-              $modal.modal('hide');
-              one.f.switchmanager.spanPortConfig.dashlet($("#right-bottom .dashlet"));
-            } else {
-              alert(response.message);
-            }
-
-          });
-    },
-    body: function(nodes, nodeports) {
-      var $form = $(document.createElement('form'));
-      var $fieldset = $(document.createElement('fieldset'));
-      // node
-      var $label = one.lib.form.label("Node");
-      var $select = one.lib.form.select.create(nodes);
-      one.lib.form.select.prepend($select, { '' : 'Please Select a Node' });
-      $select.val($select.find("option:first").val());
-      $select.attr('id', one.f.switchmanager.spanPortConfig.id.modal.form.nodes);
-
-      // bind onchange
-      $select.change(function() {
-        // retrieve port value
-        var nodeId = $(this).find('option:selected').attr('value');
-        one.f.switchmanager.spanPortConfig.registry['currentNode'] = nodeId;
-        var $ports = $('#'+one.f.switchmanager.spanPortConfig.id.modal.form.port);
-        var ports = one.f.switchmanager.spanPortConfig.registry['nodePorts'][nodeId]
-        var options = {};
-      $(ports).each(function(idx, val) {
-        options[val.internalPortName] = val.portName+' ('+val.portId+')'; 
-          });
-        one.lib.form.select.inject($ports, options); 
-        one.lib.form.select.prepend($ports, {'':'Please Select a Port'});
-        $ports.val($ports.find('option:first').val());
-        });
-
-      $fieldset.append($label).append($select);
-      // input port
-      var $label = one.lib.form.label("Port");
-      var $select = one.lib.form.select.create();
-      one.lib.form.select.prepend($select, {'':'None'});
-      $select.attr('id', one.f.switchmanager.spanPortConfig.id.modal.form.port);
-      $select.val($select.find('option:first').val());
-      $fieldset.append($label).append($select);
-
-      // return
-      $form.append($fieldset);
-      return $form;
-    },
-    ajax: {
-      nodes: function(callback) {
-        $.getJSON(one.f.switchmanager.rootUrl + "/nodeports", function(data) {
-          var nodes = {};
-          var nodePorts = {};
-          $(data).each(function(index, node) {
-            nodes[node.nodeId] = node.nodeName;
-            nodePorts[node.nodeId] = node.nodePorts;
-          });
-          one.f.switchmanager.spanPortConfig.registry['nodePorts'] = nodePorts;
-          callback(nodes, nodePorts);
-        });
-      },
-      saveSpanPortConfig: function(requestData, callback) {
-        var resource = {};
-        resource["jsonData"] = JSON.stringify(requestData);
-        $.getJSON(one.f.switchmanager.rootUrl + "/spanPorts/add", resource, function(data) {
-          callback(data);
-        });
-      }
-    },
-    footer : function() {
-      var footer = [];
-      var saveButton = one.lib.dashlet.button.single("Save", one.f.switchmanager.spanPortConfig.id.modal.save, "btn-primary", "");
-      var $saveButton = one.lib.dashlet.button.button(saveButton);
-      footer.push($saveButton);
-      return footer;
-    },
-    removeMultiple: {
-      dialog: function(spanPortsToDelete) {
-        var h3 = 'Remove SPAN Port';
-
-        var footer = one.f.switchmanager.spanPortConfig.modal.removeMultiple.footer();
-        var $body = one.f.switchmanager.spanPortConfig.modal.removeMultiple.body(spanPortsToDelete);
-        var $modal = one.lib.modal.spawn(one.f.switchmanager.spanPortConfig.id.modal.modal, h3, $body, footer);
-
-        // bind close button
-        $('#'+one.f.switchmanager.spanPortConfig.id.modal.cancel, $modal).click(function() {
-          $modal.modal('hide');
-        });
-
-        // bind remove rule button
-        $('#'+one.f.switchmanager.spanPortConfig.id.modal.remove, $modal).click(this, function(e) {
-          var requestData = {};
-          var spanPorts = [];
-          $(spanPortsToDelete).each(function(index, spanPort) {
-            spanPorts.push(JSON.parse(spanPort.spanPortJson));
-          });
-          requestData["spanPortsToDelete"] = JSON.stringify(spanPorts);
-
-          var url = one.f.switchmanager.rootUrl + "/spanPorts/delete";
-          one.f.switchmanager.spanPortConfig.ajax.main(url, requestData, function(response) {
-            $modal.modal('hide');
-            if (response.status == true) {
-              // refresh dashlet by passing dashlet div as param
-              one.lib.alert("Span Port(s) successfully removed");
-            } else {
-              alert(response.message);
-            }
-            one.f.switchmanager.spanPortConfig.dashlet($("#right-bottom .dashlet"));
-          });
-        });
-        $modal.modal();
-      },
-      footer : function() {
-        var footer = [];
-        var remove = one.lib.dashlet.button.single('Remove SPAN Port',one.f.switchmanager.spanPortConfig.id.modal.remove, 'btn-danger', '');
-        var $remove = one.lib.dashlet.button.button(remove);
-        footer.push($remove);
-
-        var cancel = one.lib.dashlet.button.single('Cancel', one.f.switchmanager.spanPortConfig.id.modal.cancel, '', '');
-        var $cancel = one.lib.dashlet.button.button(cancel);
-        footer.push($cancel);
-
-        return footer;
-      },
-      body : function (spanPortToDelete) {
-        var $p = $(document.createElement('p'));
-        var p = 'Remove the following Span Port(s)?';
-        //creata a BS label for each rule and append to list
-
-        $(spanPortToDelete).each(function(index, spanPortItem) {
-          var $span = $(document.createElement('span'));
-          $span.append(this.spanPortNodeName+"-"+this.spanPortPortName);
-          p += '<br/>' + $span[0].outerHTML;
-        });
-        $p.append(p);
-        return $p;
-      }
-    }
-  },
-  // data functions
-  data : {
-    spanPortConfigGrid: function(data) {
-      var source = new StaticDataSource({
-        columns: [
-      {
-        property: 'selector',
-      label: "<input type='checkbox'  id='"
-        +one.f.switchmanager.spanPortConfig.id.dashlet.selectAll+"'/>",
-      sortable: false
-      },
-      {
-        property: 'nodeName',
-      label: 'Node',
-      sortable: true
-      },
-      {
-        property: 'spanPortName',
-      label: 'SPAN Port',
-      sortable: true
-      },
-      ],
-      data: data.nodeData,
-      formatter: function(items) {
-        $.each(items, function(index, item) {
-          item["selector"] = '<input type="checkbox" class="spanPortConfig" spanPort=' + encodeURIComponent(item["json"]) + ' spanPortNode="' + item["nodeName"] + '" spanPortPort="' + item["spanPortName"] + '"></input>';
-        });
-      },
-      delay: 0
-      });
-      return source;              
-    },
-    devices : function(data) {
-      var result = [];
-      $.each(data.nodeData, function(key, value) {
-        var tr = {};
-        // fill up all the td's
-        var entry = [];
-        var checkbox = document.createElement("input");
-        checkbox.setAttribute("type", "checkbox");
-        checkbox.spanPort = value.json;
-        entry.push(checkbox);
-        entry.push(value["nodeName"]);
-        entry.push(value["spanPort"]);
-        tr.entry = entry;
-        result.push(tr);
-      });
-      return result;
-    }
-  }
-}
-
-one.f.connection = {
-  id : { // one.f.connection.id
-    datagrid : 'one-f-connection-id-datagrid',
-    add : 'one-f-connection-id-add'
-  },
-  dashlet: function($dashlet) {
-    one.lib.dashlet.empty($dashlet);
-    // heading
-    $dashlet.append(one.lib.dashlet.header(one.f.dashlet.connection.name));
-    // add button
-    var add = one.lib.dashlet.button.single('Add Node', one.f.connection.id.add, 'btn-primary', 'btn-mini');
-    var $add = one.lib.dashlet.button.button(add);
-    $add.click(function() {
-      one.f.connection.add.initialize();
-    });
-    $dashlet.append($add);
-    // load table
-    var url = one.f.switchmanager.rootUrl+'/connect/nodes';
-    $.getJSON(url, function(data) {
-      var $gridHTML = one.lib.dashlet.datagrid.init(one.f.connection.id.datagrid, {
-        searchable: true,
-        filterable: false,
-        pagination: true,
-        flexibleRowsPerPage: true
-      }, 'table-striped table-condensed table-cursor');
-      $dashlet.append($gridHTML);
-      var dataSource = one.f.connection.data(data);
-      $('#'+one.f.connection.id.datagrid, $dashlet).datagrid({dataSource:dataSource})
-        .on('loaded', function() {
-          $(this).find('tbody tr').click(function() {
-            var nodeId = $(this).find('.nodeId').text();
-            var nodeType = $(this).find('.nodeType').text();
-            var nodeName = $(this).find('.nodeName').text();
-            one.f.connection.remove.initialize(nodeId, nodeName, nodeType);
-          });
-        });
-    });
-  },
-  data : function(data) {
-    var source = new StaticDataSource({
-      columns: [
-      {
-        property: 'nodeName',
-        label: 'Node',
-        sortable: true
-      }
-      ],
-      data: data,
-      formatter: function(items) {
-        $.each(items, function(index, item) {
-          var $nodeId = $(document.createElement('span'));
-          $nodeId.css('display', 'none');
-          var $nodeType = $nodeId.clone();
-          var $nodeName = $nodeId.clone();
-          $nodeId.append(item.nodeId).addClass('nodeId');
-          $nodeType.append(item.nodeType).addClass('nodeType');
-          $nodeName.append(item.nodeName).addClass('nodeName');
-          item.nodeName += $nodeId[0].outerHTML+$nodeType[0].outerHTML+$nodeName[0].outerHTML;
-        });
-      },
-      delay: 0
-    });
-    return source;              
-  },
-  add : {
-    id : { // one.f.connection.add.id
-      modal : 'one-f-connection-add-id-modal',
-      add : 'one-f-connection-add-id-add',
-      cancel : 'one-f-connection-add-id-cancel',
-      form : {
-        nodeId : 'one-f-connection-add-id-form-nodeId',
-        ipAddress : 'one-f-connection-add-id-form-ipAddress',
-        port : 'one-f-connection-add-id-form-port',
-        nodeType : 'one-f-connection-add-id-form-nodeType'
-      }
-    },
-    initialize : function() {
-      var h3 = 'Add Node';
-      var footer = one.f.connection.add.footer();
-      var $body = one.f.connection.add.body();;
-      var $modal = one.lib.modal.spawn(one.f.connection.add.id.modal, h3, $body, footer);
-      // bind add buton
-      $('#'+one.f.connection.add.id.add, $modal).click(function() {
-        var nodeId = $('#'+one.f.connection.add.id.form.nodeId, $modal).val();
-        if (nodeId === '') {
-          alert('Please enter a node ID');
-          return false;
-        }
-        var resources = {};
-        resources.ipAddress = $('#'+one.f.connection.add.id.form.ipAddress, $modal).val();
-        if (resources.ipAddress === '') {
-          alert('Please enter an IP Address');
-          return false;
-        }
-        resources.port = $('#'+one.f.connection.add.id.form.port, $modal).val();
-        if (resources.port === '') {
-          alert('Please enter a port');
-          return false;
-        }
-        var nodeType = $('#'+one.f.connection.add.id.form.nodeType, $modal).val();
-        if (nodeType !== '') {
-          resources.nodeType = nodeType;
-        }
-        var url = one.f.switchmanager.rootUrl+'/connect/'+encodeURI(nodeId);
-        $.post(url, resources, function(result) {
-          if (result.success === true) {
-            $modal.modal('hide');
-            one.lib.alert(result.description);
-          } else {
-            alert(result.code+': '+result.description);
-          }
-        });
-      });
-      // bind cancel button
-      $('#'+one.f.connection.add.id.cancel, $modal).click(function() {
-        $modal.modal('hide');
-      });
-      $modal.modal();
-    },
-    body : function() {
-      var $form = $(document.createElement('form'));
-      var $fieldset = $(document.createElement('fieldset'));
-      // node id
-      var $label = one.lib.form.label('Node ID');
-      var $input = one.lib.form.input('Node ID');
-      $input.attr('id', one.f.connection.add.id.form.nodeId);
-      $fieldset.append($label).append($input);
-      // ip address
-      $label = one.lib.form.label('IP Address');
-      $input = one.lib.form.input('IP Address');
-      $input.attr('id', one.f.connection.add.id.form.ipAddress);
-      $fieldset.append($label).append($input);
-      // port
-      $label = one.lib.form.label('Port');
-      $input = one.lib.form.input('Port');
-      $input.attr('id', one.f.connection.add.id.form.port);
-      var $help = one.lib.form.help('Enter a number');
-      $fieldset.append($label).append($input).append($help);
-      // node type
-      $label = one.lib.form.label('Node Type');
-      $input = one.lib.form.input('Node Type');
-      $input.attr('id', one.f.connection.add.id.form.nodeType);
-      $help = one.lib.form.help('Optional');
-      $fieldset.append($label).append($input).append($help);
-      $form.append($fieldset);
-      return $form;
-    },
-    footer : function() {
-      var footer = [];
-      var add = one.lib.dashlet.button.single('Submit', one.f.connection.add.id.add, 'btn-primary', '');
-      var $add = one.lib.dashlet.button.button(add);
-      footer.push($add);
-      var cancel = one.lib.dashlet.button.single('Cancel', one.f.connection.add.id.cancel, '', '');
-      var $cancel = one.lib.dashlet.button.button(cancel);
-      footer.push($cancel);
-      return footer;
-    }
-  },
-  remove : {
-    id : { // one.f.connection.remove.id
-      modal : 'one-f-connection-remove-id-modal',
-      remove : 'one-f-connection-remove-id-remove',
-      cancel : 'one-f-connection-remove-id-cancel'
-    },
-    initialize : function(nodeId, nodeName, nodeType) {
-      var h3 = 'Remove Node';
-      var footer = one.f.connection.remove.footer();
-      var $body = one.f.connection.remove.body(nodeName);
-      var $modal = one.lib.modal.spawn(one.f.connection.remove.id.modal, h3, $body, footer);
-      // bind remove buton
-      $('#'+one.f.connection.remove.id.remove, $modal).click(function() {
-        var resources = {};
-        resources.nodeType = nodeType;
-        var url = one.f.switchmanager.rootUrl+'/disconnect/'+encodeURI(nodeId);
-        $.post(url, resources, function(result) {
-          if (result.success === true) {
-            $modal.modal('hide');
-            one.lib.alert(result.description);
-          } else {
-            alert(result.code+': '+result.description);
-          }
-        }).fail(function() { debugger; });
-      });
-      // bind cancel button
-      $('#'+one.f.connection.remove.id.cancel, $modal).click(function() {
-        $modal.modal('hide');
-      });
-      $modal.modal();
-    },
-    body : function(nodeName) {
-      var $p = $(document.createElement('p'));
-      $p.append('Remove the following node? ');
-      var $span = $(document.createElement('span'));
-      $span.addClass('label label-info');
-      $span.append(nodeName);
-      $p.append($span[0].outerHTML);
-      return $p;
-    },
-    footer : function() {
-      var footer = [];
-      var remove = one.lib.dashlet.button.single('Remove', one.f.connection.remove.id.remove, 'btn-danger', '');
-      var $remove = one.lib.dashlet.button.button(remove);
-      footer.push($remove);
-      var cancel = one.lib.dashlet.button.single('Cancel', one.f.connection.remove.id.cancel, '', '');
-      var $cancel = one.lib.dashlet.button.button(cancel);
-      footer.push($cancel);
-      return footer;
-    }
-  }
-}
-
-/** INIT **/
-// populate nav tabs
-$(one.f.menu.left.top).each(function(index, value) {
-  var $nav = $(".nav", "#left-top");
-  one.main.page.dashlet($nav, value);
-});
-
-$(one.f.menu.left.bottom).each(function(index, value) {
-  var $nav = $(".nav", "#left-bottom");
-  one.main.page.dashlet($nav, value);
-});
-
-$(one.f.menu.right.bottom).each(function(index, value) {
-  var $nav = $(".nav", "#right-bottom");
-  one.main.page.dashlet($nav, value);
-});
-
-one.f.addPopOut = function() {
-  $img1 = $(document.createElement("img"));
-  $img1.attr("src", "/img/Expand16T.png");
-  $img1.attr("style", "float: right;");
-  $img1.hover(function() {
-    $img1.css("cursor", "pointer");
-  });
-  $img1.click(function() {
-    var $modal = one.f.switchmanager.nodesLearnt.modal.initialize.popout();
-    $modal.css({
-      'margin-left': '-45%',
-      'margin-top': '-3%',
-      'width':$(document).width() * 0.8,
-      'height':$(document).height() * 0.9
-    });
-    $(".modal-body", $modal).css({
-      "max-height": $(document).height() * 0.75,
-    });
-    $modal.modal();
-  });
-  $dash1 = $($("#left-top .nav")[0]);
-  $dash1.append($img1);
-};
-one.f.addPopOut();
-
-// bind dashlet nav
-$('.dash .nav a', '#main').click(function() {
-  // de/activation
-  var $li = $(this).parent();
-  var $ul = $li.parent();
-  one.lib.nav.unfocus($ul);
-  $li.addClass('active');
-  // clear respective dashlet
-  var $dashlet = $ul.parent().find('.dashlet');
-  one.lib.dashlet.empty($dashlet);
-
-  // callback based on menu
-  var id = $(this).attr('id');
-  var menu = one.f.dashlet;
-  switch (id) {
-    case menu.nodesLearnt.id:
-      one.f.switchmanager.nodesLearnt.dashlet($dashlet);
-      break;
-    case menu.staticRouteConfig.id:
-      one.f.switchmanager.staticRouteConfig.dashlet($dashlet);
-      break;
-    case menu.subnetGatewayConfig.id:
-      one.f.switchmanager.subnetGatewayConfig.dashlet($dashlet);
-      break;
-    case menu.spanPortConfig.id:
-      one.f.switchmanager.spanPortConfig.dashlet($dashlet);
-      break;
-    case menu.connection.id:
-      one.f.connection.dashlet($dashlet);
-      break;
-  };
-});
-
-// activate first tab on each dashlet
-$('.dash .nav').each(function(index, value) {
-  $($(value).find('li')[0]).find('a').click();
-});
diff --git a/opendaylight/adsal/web/flows/pom.xml b/opendaylight/adsal/web/flows/pom.xml
deleted file mode 100644 (file)
index 14fe753..0000000
+++ /dev/null
@@ -1,112 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>flows.web</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>containermanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>forwardingrulesmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>switchmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>usermanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>web</artifactId>
-    </dependency>
-  </dependencies>
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Export-Package></Export-Package>
-            <Import-Package>org.opendaylight.controller.forwardingrulesmanager,
-              org.opendaylight.controller.sal.authorization,
-              org.opendaylight.controller.sal.action,
-              org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.sal.flowprogrammer,
-              org.opendaylight.controller.sal.utils,
-              org.opendaylight.controller.containermanager,
-              org.opendaylight.controller.switchmanager,
-              org.opendaylight.controller.usermanager,
-              org.opendaylight.controller.web,
-              com.google.gson,
-              javax.annotation,
-              javax.naming,
-              javax.servlet,
-              javax.servlet.annotation,
-              javax.servlet.http,
-              javax.servlet.jsp,
-              javax.servlet.jsp.el,
-              javax.servlet.jsp.jstl.core,
-              javax.servlet.jsp.jstl.fmt,
-              javax.servlet.jsp.jstl.tlv,
-              javax.servlet.jsp.tagext,
-              javax.servlet.resources,
-              javax.xml.parsers,
-              javax.xml.transform,
-              org.apache.commons.logging,
-              org.apache.taglibs.standard.functions,
-              org.apache.taglibs.standard.resources,
-              org.apache.taglibs.standard.tag.common.core,
-              org.apache.taglibs.standard.tag.common.fmt,
-              org.apache.taglibs.standard.tag.rt.core,
-              org.apache.taglibs.standard.tag.rt.fmt,
-              org.apache.taglibs.standard.tei,
-              org.apache.taglibs.standard.tlv,
-              com.fasterxml.jackson.core,
-              com.fasterxml.jackson.annotation,
-              com.fasterxml.jackson.databind,
-              org.osgi.framework,
-              org.slf4j,
-              org.springframework.beans,
-              org.springframework.beans.factory.xml,
-              org.springframework.context.config,
-              org.springframework.stereotype,
-              org.springframework.web,
-              org.springframework.web.bind.annotation,
-              org.springframework.web.servlet,
-              org.springframework.web.servlet.config,
-              org.springframework.web.servlet.view,
-              org.springframework.web.filter,
-              org.springframework.web.context</Import-Package>
-            <Web-ContextPath>/controller/web/flows</Web-ContextPath>
-          </instructions>
-          <manifestLocation>${project.basedir}/src/main/resources/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/web/flows/src/main/java/org/opendaylight/controller/flows/web/Flows.java b/opendaylight/adsal/web/flows/src/main/java/org/opendaylight/controller/flows/web/Flows.java
deleted file mode 100644 (file)
index 9c3c895..0000000
+++ /dev/null
@@ -1,426 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.flows.web;
-
-import java.util.ArrayList;
-import java.util.HashMap;
-import java.util.HashSet;
-import java.util.List;
-import java.util.Map;
-import java.util.Set;
-import java.util.TreeMap;
-
-import javax.servlet.http.HttpServletRequest;
-
-import org.opendaylight.controller.forwardingrulesmanager.FlowConfig;
-import org.opendaylight.controller.forwardingrulesmanager.IForwardingRulesManager;
-import org.opendaylight.controller.sal.action.Action;
-import org.opendaylight.controller.sal.action.ActionType;
-import org.opendaylight.controller.sal.action.SupportedFlowActions;
-import org.opendaylight.controller.sal.authorization.Privilege;
-import org.opendaylight.controller.sal.authorization.UserLevel;
-import org.opendaylight.controller.sal.core.Description;
-import org.opendaylight.controller.sal.core.Name;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.utils.GlobalConstants;
-import org.opendaylight.controller.sal.utils.ServiceHelper;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.sal.utils.StatusCode;
-import org.opendaylight.controller.switchmanager.ISwitchManager;
-import org.opendaylight.controller.switchmanager.Switch;
-import org.opendaylight.controller.switchmanager.SwitchConfig;
-import org.opendaylight.controller.web.DaylightWebUtil;
-import org.opendaylight.controller.web.IDaylightWeb;
-import org.springframework.stereotype.Controller;
-import org.springframework.web.bind.annotation.PathVariable;
-import org.springframework.web.bind.annotation.RequestMapping;
-import org.springframework.web.bind.annotation.RequestMethod;
-import org.springframework.web.bind.annotation.RequestParam;
-import org.springframework.web.bind.annotation.ResponseBody;
-
-import com.google.gson.Gson;
-
-@Controller
-@RequestMapping("/")
-public class Flows implements IDaylightWeb {
-    private static final UserLevel AUTH_LEVEL = UserLevel.CONTAINERUSER;
-    private static final String WEB_NAME = "Flows";
-
-    private static final String WEB_ID = "flows";
-    private static final short WEB_ORDER = 2;
-
-    private final Gson gson;
-
-    public Flows() {
-        ServiceHelper.registerGlobalService(IDaylightWeb.class, this, null);
-        gson = new Gson();
-    }
-
-    @Override
-    public String getWebName() {
-        return WEB_NAME;
-    }
-
-    @Override
-    public String getWebId() {
-        return WEB_ID;
-    }
-
-    @Override
-    public short getWebOrder() {
-        return WEB_ORDER;
-    }
-
-    @Override
-    public boolean isAuthorized(UserLevel userLevel) {
-        return userLevel.ordinal() <= AUTH_LEVEL.ordinal();
-    }
-
-    @RequestMapping(value = "/main")
-    @ResponseBody
-    public Map<String, Object> getFlows(HttpServletRequest request, @RequestParam(required = false) String container) {
-        String containerName = (container == null) ? GlobalConstants.DEFAULT.toString() : container;
-
-        // Derive the privilege this user has on the current container
-        String userName = request.getUserPrincipal().getName();
-        Privilege privilege = DaylightWebUtil.getContainerPrivilege(userName, containerName, this);
-        if (privilege == Privilege.NONE) {
-            return null;
-        }
-
-        // fetch frm
-        IForwardingRulesManager frm = (IForwardingRulesManager) ServiceHelper.getInstance(
-                IForwardingRulesManager.class, containerName, this);
-        if (frm == null) {
-            return null;
-        }
-
-        // fetch sm
-        ISwitchManager switchManager = (ISwitchManager) ServiceHelper.getInstance(ISwitchManager.class, containerName,
-                this);
-        if (switchManager == null) {
-            return null;
-        }
-
-        // get static flow list
-        List<FlowConfig> staticFlowList = frm.getStaticFlows();
-        Set<Map<String, Object>> flowSet = new HashSet<Map<String, Object>>();
-        for (FlowConfig flowConfig : staticFlowList) {
-            Map<String, Object> entry = new HashMap<String, Object>();
-            entry.put("flow", flowConfig);
-            entry.put("name", flowConfig.getName());
-            Node node = flowConfig.getNode();
-            entry.put("node", getNodeDesc(node, switchManager));
-            entry.put("nodeId", node.toString());
-            flowSet.add(entry);
-        }
-
-        Map<String, Object> output = new HashMap<String, Object>(2);
-        output.put("flows", flowSet);
-        output.put("privilege", privilege);
-        return output;
-    }
-
-    @RequestMapping(value = "/node-ports")
-    @ResponseBody
-    public Map<String, Object> getNodePorts(HttpServletRequest request, @RequestParam(required = false) String container) {
-        String containerName = (container == null) ? GlobalConstants.DEFAULT.toString() : container;
-
-        // Derive the privilege this user has on the current container
-        String userName = request.getUserPrincipal().getName();
-        if (DaylightWebUtil.getContainerPrivilege(userName, containerName, this) == Privilege.NONE) {
-            return null;
-        }
-
-        ISwitchManager switchManager = (ISwitchManager) ServiceHelper.getInstance(ISwitchManager.class, containerName,
-                this);
-        if (switchManager == null) {
-            return null;
-        }
-
-        Map<String, Object> nodes = new HashMap<String, Object>();
-        Map<String, String> port;
-
-        for (Switch node : switchManager.getNetworkDevices()) {
-            port = new HashMap<String, String>(); // new port
-            Set<NodeConnector> nodeConnectorSet = node.getNodeConnectors();
-
-            if (nodeConnectorSet != null) {
-                for (NodeConnector nodeConnector : nodeConnectorSet) {
-                    String nodeConnectorName = ((Name) switchManager.getNodeConnectorProp(nodeConnector,
-                            Name.NamePropName)).getValue();
-                    port.put( nodeConnector.getID().toString(),
-                            nodeConnectorName + "(" + nodeConnector.getNodeConnectorIDString() + ")");
-                }
-            }
-
-            // add ports
-            Map<String, Object> entry = new HashMap<String, Object>();
-            entry.put("ports", port);
-
-            // add name
-            entry.put("name", getNodeDesc(node.getNode(), switchManager));
-
-            // add to the node
-            nodes.put(node.getNode().toString(), entry);
-        }
-
-        return nodes;
-    }
-
-    @RequestMapping(value = "/node-flows")
-    @ResponseBody
-    public Map<String, Object> getNodeFlows(HttpServletRequest request, @RequestParam(required = false) String container) {
-        String containerName = (container == null) ? GlobalConstants.DEFAULT.toString() : container;
-
-        // Derive the privilege this user has on the current container
-        String userName = request.getUserPrincipal().getName();
-        if (DaylightWebUtil.getContainerPrivilege(userName, containerName, this) == Privilege.NONE) {
-            return null;
-        }
-
-        ISwitchManager switchManager = (ISwitchManager) ServiceHelper.getInstance(ISwitchManager.class, containerName,
-                this);
-        if (switchManager == null) {
-            return null;
-        }
-        IForwardingRulesManager frm = (IForwardingRulesManager) ServiceHelper.getInstance(
-                IForwardingRulesManager.class, containerName, this);
-        if (frm == null) {
-            return null;
-        }
-
-        Map<String, Object> nodes = new HashMap<String, Object>();
-
-        for (Switch sw : switchManager.getNetworkDevices()) {
-            Node node = sw.getNode();
-
-            List<FlowConfig> flows = frm.getStaticFlows(node);
-
-            String nodeDesc = node.toString();
-            SwitchConfig config = switchManager.getSwitchConfig(node.toString());
-            if ((config != null) && (config.getProperty(Description.propertyName) != null)) {
-                nodeDesc = ((Description) config.getProperty(Description.propertyName)).getValue();
-            }
-
-            nodes.put(nodeDesc, flows.size());
-        }
-
-        return nodes;
-    }
-
-    @RequestMapping(value = "/flow", method = RequestMethod.POST)
-    @ResponseBody
-    public String actionFlow(@RequestParam(required = true) String action, @RequestParam(required = false) String body,
-            @RequestParam(required = true) String nodeId, HttpServletRequest request,
-            @RequestParam(required = false) String container) {
-        String containerName = (container == null) ? GlobalConstants.DEFAULT.toString() : container;
-
-        // Authorization check
-        String userName = request.getUserPrincipal().getName();
-        if (DaylightWebUtil.getContainerPrivilege(userName, containerName, this) != Privilege.WRITE) {
-            return "Operation not authorized";
-        }
-
-        IForwardingRulesManager frm = (IForwardingRulesManager) ServiceHelper.getInstance(
-                IForwardingRulesManager.class, containerName, this);
-        if (frm == null) {
-            return null;
-        }
-
-        FlowConfig flow = gson.fromJson(body, FlowConfig.class);
-
-        Node node = Node.fromString(nodeId);
-        flow.setNode(node);
-
-        Status result = new Status(StatusCode.BADREQUEST, "Invalid request");
-        if (action.equals("add")) {
-            result = frm.addStaticFlow(flow);
-            if (result.isSuccess()) {
-                DaylightWebUtil.auditlog("Flow Entry", userName, "added", flow.getName() + " on Node "
-                        + DaylightWebUtil.getNodeDesc(node, containerName, this), containerName);
-            }
-        } else if (action.equals("edit")){
-            result = frm.modifyStaticFlow(flow);
-            if (result.isSuccess()) {
-                DaylightWebUtil.auditlog("Flow Entry", userName, "updated", flow.getName() + " on Node "
-                        + DaylightWebUtil.getNodeDesc(node, containerName, this), containerName);
-            }
-        }
-
-        return (result.isSuccess()) ? StatusCode.SUCCESS.toString() : result.getDescription();
-    }
-
-    @RequestMapping(value = "/flow/{nodeId}/{name:.*}", method = RequestMethod.POST)
-    @ResponseBody
-    public String removeFlow(@PathVariable("nodeId") String nodeId, @PathVariable("name") String name,
-            @RequestParam(required = true) String action, HttpServletRequest request,
-            @RequestParam(required = false) String container) {
-        String containerName = (container == null) ? GlobalConstants.DEFAULT.toString() : container;
-
-        // Authorization check
-        String userName = request.getUserPrincipal().getName();
-        if (DaylightWebUtil.getContainerPrivilege(userName, containerName, this) != Privilege.WRITE) {
-            return "Operation not authorized";
-        }
-
-        IForwardingRulesManager frm = (IForwardingRulesManager) ServiceHelper.getInstance(
-                IForwardingRulesManager.class, containerName, this);
-        if (frm == null) {
-            return null;
-        }
-
-        Status result = null;
-        Node node = Node.fromString(nodeId);
-        if (node == null) {
-            return null;
-        }
-        if (action.equals("remove")) {
-            result = frm.removeStaticFlow(name, node);
-            if (result.isSuccess()) {
-                DaylightWebUtil.auditlog("Flow Entry", userName, "removed",
-                        name + " on Node " + DaylightWebUtil.getNodeDesc(node, containerName, this), containerName);
-            }
-        } else if (action.equals("toggle")) {
-            result = frm.toggleStaticFlowStatus(name, node);
-            if (result.isSuccess()) {
-                DaylightWebUtil.auditlog("Flow Entry", userName, "toggled",
-                        name + " on Node " + DaylightWebUtil.getNodeDesc(node, containerName, this), containerName);
-            }
-        } else {
-            result = new Status(StatusCode.BADREQUEST, "Unknown action");
-        }
-
-        return (result.isSuccess()) ? StatusCode.SUCCESS.toString() : result.getDescription();
-    }
-
-    @SuppressWarnings("unchecked")
-    @RequestMapping(value = "/flow/deleteFlows", method = RequestMethod.POST)
-    @ResponseBody
-    public String removeSelectedFlows(@RequestParam(required = false) String body, HttpServletRequest request,
-            @RequestParam(required = false) String container) {
-        String containerName = (container == null) ? GlobalConstants.DEFAULT.toString() : container;
-
-        // Authorization check
-        String userName = request.getUserPrincipal().getName();
-        if (DaylightWebUtil.getContainerPrivilege(userName, containerName, this) != Privilege.WRITE) {
-            return "Operation not authorized";
-        }
-        IForwardingRulesManager frm = (IForwardingRulesManager) ServiceHelper.getInstance(
-                IForwardingRulesManager.class, containerName, this);
-        if (frm == null) {
-            return "Forwarding Rules Manager is not available";
-        }
-
-        List<Map<String, String>> flowList = new ArrayList<Map<String, String>>();
-        flowList = gson.fromJson(body, flowList.getClass());
-        Status result = new Status(StatusCode.BADREQUEST, "Invalid request");
-        String status = "";
-        for (Map<String, String> flowEntry : flowList) {
-            Node node = Node.fromString(flowEntry.get("node"));
-            result = frm.removeStaticFlow(flowEntry.get("name"), node);
-            if (result.isSuccess()) {
-                DaylightWebUtil.auditlog("Flow Entry", userName, "removed", flowEntry.get("name") + " on Node "
-                        + DaylightWebUtil.getNodeDesc(node, containerName, this), containerName);
-            } else {
-                status = flowEntry.get("name") + ", " + status;
-            }
-        }
-        if (!status.equals("")) {
-            return "Could not remove " + status.substring(0, status.length() - 2) + " Flow(s)";
-        } else {
-            return "Success";
-        }
-    }
-
-    @RequestMapping(value = "/valid-flows/{nodeId}")
-    @ResponseBody
-    public Object getValidActions(HttpServletRequest request, @RequestParam(required = false) String container,
-            @PathVariable("nodeId") String nodeId) {
-        String containerName = (container == null) ? GlobalConstants.DEFAULT.toString() : container;
-
-        // Authorization check
-        String userName = request.getUserPrincipal().getName();
-        if (DaylightWebUtil.getContainerPrivilege(userName, containerName, this) != Privilege.WRITE) {
-            return "Operation not authorized";
-        }
-
-        ISwitchManager switchManager = (ISwitchManager) ServiceHelper.getInstance(ISwitchManager.class, containerName, this);
-        if (switchManager == null) {
-            return null;
-        }
-
-        Map<String, String> result = new TreeMap<String, String>();
-
-        Node node = Node.fromString(nodeId);
-        SupportedFlowActions supportedFlows = (SupportedFlowActions) switchManager.getNodeProp(node, "supportedFlowActions");
-        List<Class<? extends Action>> actions = supportedFlows.getActions();
-        for (Class<? extends Action> action : actions) {
-            if (action.isAssignableFrom(org.opendaylight.controller.sal.action.Drop.class)) {
-                result.put(ActionType.DROP.toString(), "Drop");
-            } else if (action.isAssignableFrom(org.opendaylight.controller.sal.action.Loopback.class)) {
-                result.put(ActionType.LOOPBACK.toString(), "Loopback");
-            } else if (action.isAssignableFrom(org.opendaylight.controller.sal.action.Flood.class)) {
-                result.put(ActionType.FLOOD.toString(), "Flood");
-            } else if (action.isAssignableFrom(org.opendaylight.controller.sal.action.FloodAll.class)) {
-                result.put(ActionType.FLOOD_ALL.toString(), "Flood All");
-            } else if (action.isAssignableFrom(org.opendaylight.controller.sal.action.Controller.class)) {
-                result.put(ActionType.CONTROLLER.toString(), "Controller");
-            } else if (action.isAssignableFrom(org.opendaylight.controller.sal.action.SwPath.class)) {
-                result.put(ActionType.SW_PATH.toString(), "Software Path");
-            } else if (action.isAssignableFrom(org.opendaylight.controller.sal.action.HwPath.class)) {
-                result.put(ActionType.HW_PATH.toString(), "Hardware Path");
-            } else if (action.isAssignableFrom(org.opendaylight.controller.sal.action.Output.class)) {
-                result.put(ActionType.OUTPUT.toString(), "Output");
-            } else if (action.isAssignableFrom(org.opendaylight.controller.sal.action.Enqueue.class)) {
-                result.put(ActionType.ENQUEUE.toString(), "Enqueue");
-            } else if (action.isAssignableFrom(org.opendaylight.controller.sal.action.SetDlSrc.class)) {
-                result.put(ActionType.SET_DL_SRC.toString(), "Set Datalayer Source Address");
-            } else if (action.isAssignableFrom(org.opendaylight.controller.sal.action.SetDlDst.class)) {
-                result.put(ActionType.SET_DL_DST.toString(), "Set Datalayer Destination Address");
-            } else if (action.isAssignableFrom(org.opendaylight.controller.sal.action.SetVlanId.class)) {
-                result.put(ActionType.SET_VLAN_ID.toString(), "Set VLAN ID");
-            } else if (action.isAssignableFrom(org.opendaylight.controller.sal.action.SetVlanPcp.class)) {
-                result.put(ActionType.SET_VLAN_PCP.toString(), "Set VLAN Priority");
-            } else if (action.isAssignableFrom(org.opendaylight.controller.sal.action.SetVlanCfi.class)) {
-                result.put(ActionType.SET_VLAN_CFI.toString(), "Set VLAN CFI");
-            } else if (action.isAssignableFrom(org.opendaylight.controller.sal.action.PopVlan.class)) {
-                result.put(ActionType.POP_VLAN.toString(), "Pop VLAN");
-            } else if (action.isAssignableFrom(org.opendaylight.controller.sal.action.PushVlan.class)) {
-                result.put(ActionType.PUSH_VLAN.toString(), "Push VLAN");
-            } else if (action.isAssignableFrom(org.opendaylight.controller.sal.action.SetDlType.class)) {
-                result.put(ActionType.SET_DL_TYPE.toString(), "Set EtherType");
-            } else if (action.isAssignableFrom(org.opendaylight.controller.sal.action.SetNwSrc.class)) {
-                result.put(ActionType.SET_NW_SRC.toString(), "Set Network Source Address");
-            } else if (action.isAssignableFrom(org.opendaylight.controller.sal.action.SetNwDst.class)) {
-                result.put(ActionType.SET_NW_DST.toString(), "Set Network Destination Address");
-            } else if (action.isAssignableFrom(org.opendaylight.controller.sal.action.SetNwTos.class)) {
-                result.put(ActionType.SET_NW_TOS.toString(), "Modify ToS Bits");
-            } else if (action.isAssignableFrom(org.opendaylight.controller.sal.action.SetTpSrc.class)) {
-                result.put(ActionType.SET_TP_SRC.toString(), "Modify Transport Source Port");
-            } else if (action.isAssignableFrom(org.opendaylight.controller.sal.action.SetTpDst.class)) {
-                result.put(ActionType.SET_TP_DST.toString(), "Modify Transport Destination Port");
-            }
-        }
-
-        return result;
-    }
-
-    private boolean actionCompare(String name, ActionType type) {
-        return name.equals(type.getId().toLowerCase());
-    }
-
-    private String getNodeDesc(Node node, ISwitchManager switchManager) {
-        Description desc = (Description) switchManager.getNodeProp(node, Description.propertyName);
-        String description = (desc == null) ? "" : desc.getValue();
-        return (description.isEmpty() || description.equalsIgnoreCase("none")) ? node.toString() : description;
-    }
-
-}
diff --git a/opendaylight/adsal/web/flows/src/main/resources/META-INF/spring.factories b/opendaylight/adsal/web/flows/src/main/resources/META-INF/spring.factories
deleted file mode 100644 (file)
index 93db02e..0000000
+++ /dev/null
@@ -1 +0,0 @@
-org.springframework.beans.BeanInfoFactory=org.springframework.beans.ExtendedBeanInfoFactory
diff --git a/opendaylight/adsal/web/flows/src/main/resources/META-INF/spring.handlers b/opendaylight/adsal/web/flows/src/main/resources/META-INF/spring.handlers
deleted file mode 100644 (file)
index 957af91..0000000
+++ /dev/null
@@ -1,10 +0,0 @@
-http\://www.springframework.org/schema/context=org.springframework.context.config.ContextNamespaceHandler
-http\://www.springframework.org/schema/jee=org.springframework.ejb.config.JeeNamespaceHandler
-http\://www.springframework.org/schema/lang=org.springframework.scripting.config.LangNamespaceHandler
-http\://www.springframework.org/schema/task=org.springframework.scheduling.config.TaskNamespaceHandler
-http\://www.springframework.org/schema/cache=org.springframework.cache.config.CacheNamespaceHandler
-http\://www.springframework.org/schema/c=org.springframework.beans.factory.xml.SimpleConstructorNamespaceHandler
-http\://www.springframework.org/schema/p=org.springframework.beans.factory.xml.SimplePropertyNamespaceHandler
-http\://www.springframework.org/schema/util=org.springframework.beans.factory.xml.UtilNamespaceHandler
-http\://www.springframework.org/schema/mvc=org.springframework.web.servlet.config.MvcNamespaceHandler
-http\://www.springframework.org/schema/security=org.springframework.security.config.SecurityNamespaceHandler
diff --git a/opendaylight/adsal/web/flows/src/main/resources/META-INF/spring.schemas b/opendaylight/adsal/web/flows/src/main/resources/META-INF/spring.schemas
deleted file mode 100644 (file)
index d865edc..0000000
+++ /dev/null
@@ -1,49 +0,0 @@
-http\://www.springframework.org/schema/beans/spring-beans-2.0.xsd=org/springframework/beans/factory/xml/spring-beans-2.0.xsd
-http\://www.springframework.org/schema/beans/spring-beans-2.5.xsd=org/springframework/beans/factory/xml/spring-beans-2.5.xsd
-http\://www.springframework.org/schema/beans/spring-beans-3.0.xsd=org/springframework/beans/factory/xml/spring-beans-3.0.xsd
-http\://www.springframework.org/schema/beans/spring-beans-3.1.xsd=org/springframework/beans/factory/xml/spring-beans-3.1.xsd
-http\://www.springframework.org/schema/beans/spring-beans-3.2.xsd=org/springframework/beans/factory/xml/spring-beans-3.2.xsd
-http\://www.springframework.org/schema/beans/spring-beans.xsd=org/springframework/beans/factory/xml/spring-beans-3.2.xsd
-http\://www.springframework.org/schema/tool/spring-tool-2.0.xsd=org/springframework/beans/factory/xml/spring-tool-2.0.xsd
-http\://www.springframework.org/schema/tool/spring-tool-2.5.xsd=org/springframework/beans/factory/xml/spring-tool-2.5.xsd
-http\://www.springframework.org/schema/tool/spring-tool-3.0.xsd=org/springframework/beans/factory/xml/spring-tool-3.0.xsd
-http\://www.springframework.org/schema/tool/spring-tool-3.1.xsd=org/springframework/beans/factory/xml/spring-tool-3.1.xsd
-http\://www.springframework.org/schema/tool/spring-tool-3.2.xsd=org/springframework/beans/factory/xml/spring-tool-3.2.xsd
-http\://www.springframework.org/schema/tool/spring-tool.xsd=org/springframework/beans/factory/xml/spring-tool-3.2.xsd
-http\://www.springframework.org/schema/util/spring-util-2.0.xsd=org/springframework/beans/factory/xml/spring-util-2.0.xsd
-http\://www.springframework.org/schema/util/spring-util-2.5.xsd=org/springframework/beans/factory/xml/spring-util-2.5.xsd
-http\://www.springframework.org/schema/util/spring-util-3.0.xsd=org/springframework/beans/factory/xml/spring-util-3.0.xsd
-http\://www.springframework.org/schema/util/spring-util-3.1.xsd=org/springframework/beans/factory/xml/spring-util-3.1.xsd
-http\://www.springframework.org/schema/util/spring-util-3.2.xsd=org/springframework/beans/factory/xml/spring-util-3.2.xsd
-http\://www.springframework.org/schema/util/spring-util.xsd=org/springframework/beans/factory/xml/spring-util-3.2.xsd
-http\://www.springframework.org/schema/context/spring-context-2.5.xsd=org/springframework/context/config/spring-context-2.5.xsd
-http\://www.springframework.org/schema/context/spring-context-3.0.xsd=org/springframework/context/config/spring-context-3.0.xsd
-http\://www.springframework.org/schema/context/spring-context-3.1.xsd=org/springframework/context/config/spring-context-3.1.xsd
-http\://www.springframework.org/schema/context/spring-context-3.2.xsd=org/springframework/context/config/spring-context-3.2.xsd
-http\://www.springframework.org/schema/context/spring-context.xsd=org/springframework/context/config/spring-context-3.2.xsd
-http\://www.springframework.org/schema/jee/spring-jee-2.0.xsd=org/springframework/ejb/config/spring-jee-2.0.xsd
-http\://www.springframework.org/schema/jee/spring-jee-2.5.xsd=org/springframework/ejb/config/spring-jee-2.5.xsd
-http\://www.springframework.org/schema/jee/spring-jee-3.0.xsd=org/springframework/ejb/config/spring-jee-3.0.xsd
-http\://www.springframework.org/schema/jee/spring-jee-3.1.xsd=org/springframework/ejb/config/spring-jee-3.1.xsd
-http\://www.springframework.org/schema/jee/spring-jee-3.2.xsd=org/springframework/ejb/config/spring-jee-3.2.xsd
-http\://www.springframework.org/schema/jee/spring-jee.xsd=org/springframework/ejb/config/spring-jee-3.2.xsd
-http\://www.springframework.org/schema/lang/spring-lang-2.0.xsd=org/springframework/scripting/config/spring-lang-2.0.xsd
-http\://www.springframework.org/schema/lang/spring-lang-2.5.xsd=org/springframework/scripting/config/spring-lang-2.5.xsd
-http\://www.springframework.org/schema/lang/spring-lang-3.0.xsd=org/springframework/scripting/config/spring-lang-3.0.xsd
-http\://www.springframework.org/schema/lang/spring-lang-3.1.xsd=org/springframework/scripting/config/spring-lang-3.1.xsd
-http\://www.springframework.org/schema/lang/spring-lang-3.2.xsd=org/springframework/scripting/config/spring-lang-3.2.xsd
-http\://www.springframework.org/schema/lang/spring-lang.xsd=org/springframework/scripting/config/spring-lang-3.2.xsd
-http\://www.springframework.org/schema/task/spring-task-3.0.xsd=org/springframework/scheduling/config/spring-task-3.0.xsd
-http\://www.springframework.org/schema/task/spring-task-3.1.xsd=org/springframework/scheduling/config/spring-task-3.1.xsd
-http\://www.springframework.org/schema/task/spring-task-3.2.xsd=org/springframework/scheduling/config/spring-task-3.2.xsd
-http\://www.springframework.org/schema/task/spring-task.xsd=org/springframework/scheduling/config/spring-task-3.2.xsd
-http\://www.springframework.org/schema/cache/spring-cache-3.1.xsd=org/springframework/cache/config/spring-cache-3.1.xsd
-http\://www.springframework.org/schema/cache/spring-cache-3.2.xsd=org/springframework/cache/config/spring-cache-3.2.xsd
-http\://www.springframework.org/schema/cache/spring-cache.xsd=org/springframework/cache/config/spring-cache-3.2.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd=org/springframework/web/servlet/config/spring-mvc-3.0.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc-3.1.xsd=org/springframework/web/servlet/config/spring-mvc-3.1.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc-3.2.xsd=org/springframework/web/servlet/config/spring-mvc-3.2.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc.xsd=org/springframework/web/servlet/config/spring-mvc-3.2.xsd
-http\://www.springframework.org/schema/security/spring-security-3.1.xsd=org/springframework/security/config/spring-security-3.1.xsd
-http\://www.springframework.org/schema/security/spring-security-3.2.xsd=org/springframework/security/config/spring-security-3.2.xsd
-
diff --git a/opendaylight/adsal/web/flows/src/main/resources/META-INF/spring.tooling b/opendaylight/adsal/web/flows/src/main/resources/META-INF/spring.tooling
deleted file mode 100644 (file)
index 057d834..0000000
+++ /dev/null
@@ -1,39 +0,0 @@
-# Tooling related information for the beans namespace
-http\://www.springframework.org/schema/beans@name=beans Namespace
-http\://www.springframework.org/schema/beans@prefix=beans
-http\://www.springframework.org/schema/beans@icon=org/springframework/beans/factory/xml/spring-beans.gif
-
-# Tooling related information for the util namespace
-http\://www.springframework.org/schema/util@name=util Namespace
-http\://www.springframework.org/schema/util@prefix=util
-http\://www.springframework.org/schema/util@icon=org/springframework/beans/factory/xml/spring-util.gif
-
-# Tooling related information for the context namespace
-http\://www.springframework.org/schema/context@name=context Namespace
-http\://www.springframework.org/schema/context@prefix=context
-http\://www.springframework.org/schema/context@icon=org/springframework/context/config/spring-context.gif
-
-# Tooling related information for the jee namespace
-http\://www.springframework.org/schema/jee@name=jee Namespace
-http\://www.springframework.org/schema/jee@prefix=jee
-http\://www.springframework.org/schema/jee@icon=org/springframework/ejb/config/spring-jee.gif
-
-# Tooling related information for the scheduling namespace
-http\://www.springframework.org/schema/task@name=task Namespace
-http\://www.springframework.org/schema/task@prefix=task
-http\://www.springframework.org/schema/task@icon=org/springframework/scheduling/config/spring-task.gif
-
-# Tooling related information for the lang namespace
-http\://www.springframework.org/schema/lang@name=lang Namespace
-http\://www.springframework.org/schema/lang@prefix=lang
-http\://www.springframework.org/schema/lang@icon=org/springframework/scripting/config/spring-lang.gif
-
-# Tooling related information for the cache namespace
-http\://www.springframework.org/schema/cache@name=cache Namespace
-http\://www.springframework.org/schema/cache@prefix=cache
-http\://www.springframework.org/schema/cache@icon=org/springframework/cache/config/spring-cache.gif
-
-# Tooling related information for the mvc namespace
-http\://www.springframework.org/schema/mvc@name=mvc Namespace
-http\://www.springframework.org/schema/mvc@prefix=mvc
-http\://www.springframework.org/schema/mvc@icon=org/springframework/web/servlet/config/spring-mvc.gif
diff --git a/opendaylight/adsal/web/flows/src/main/resources/WEB-INF/Flows-servlet.xml b/opendaylight/adsal/web/flows/src/main/resources/WEB-INF/Flows-servlet.xml
deleted file mode 100644 (file)
index 293fa77..0000000
+++ /dev/null
@@ -1,21 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>\r
-<beans xmlns="http://www.springframework.org/schema/beans"\r
-  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"\r
-  xmlns:context="http://www.springframework.org/schema/context"\r
-  xmlns:mvc="http://www.springframework.org/schema/mvc"\r
-  xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd\r
-                      http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd\r
-                      http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd">\r
-\r
-  <context:component-scan base-package="org.opendaylight.controller.flows.web"/>\r
-\r
-  <mvc:resources mapping="/js/**" location="/js/" />\r
-  <mvc:resources mapping="/css/**" location="/css/" />\r
-  <mvc:resources mapping="/img/**" location="/img/" />\r
-  <mvc:annotation-driven/>\r
-\r
-  <bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">\r
-        <property name="prefix" value="/WEB-INF/jsp/"/>\r
-        <property name="suffix" value=".jsp"/>\r
-  </bean>\r
-</beans>\r
diff --git a/opendaylight/adsal/web/flows/src/main/resources/WEB-INF/jsp/autherror.jsp b/opendaylight/adsal/web/flows/src/main/resources/WEB-INF/jsp/autherror.jsp
deleted file mode 100644 (file)
index 127a5a0..0000000
+++ /dev/null
@@ -1,55 +0,0 @@
-<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
-<%@ page import="java.net.URL" %>
-<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
-
-<!DOCTYPE html>
-<html>
-  <head>
-    <meta charset="utf-8">
-
-    <!-- Bootstrap CSS - 1 -->
-    <link href="/css/bootstrap.min.css" rel="stylesheet" media="screen">
-    
-    <!-- Login CSS - 2 -->
-    <link rel="stylesheet/less" type="text/css" href="/css/login.less">
-
-<c:set var="title" value="OpenDaylight login error" scope="application"/>
-<%
-    String filePath = "/WEB-INF/jsp/customerror.jsp"; 
-       URL fileURL = pageContext.getServletContext().getResource(filePath);
-       if(fileURL!=null) {
-%>
-         <jsp:include page="<%=filePath%>" flush="true"/>
-<% } %>
-       <title>${title}</title>
-    <!-- Bootstrap JS - 1 -->
-    <script src="/js/bootstrap.min.js"></script>
-    
-    <!-- LESS - 2 -->
-    <script type="text/javascript">
-        less = {
-            env: "production"
-        };
-    </script>
-    <script src="/js/less-1.3.3.min.js"></script>
-</head>
-<body>
-        <form action="<c:url value='/' />" id="form" method="post">
-
-  <div class="container">
-    <div class="content">
-       <div class="login-form">
-         <div id="logo"></div>
-           <fieldset>
-            <p>You are not authorized to access this resource.<p>
-            <p>Please contact your administrator to resolve your Role privileges.</p>
-            <br/>
-             <button class="btn btn-primary" type="submit" value="Log In" >Go To Login Page</button>
-           </fieldset>
-       </div>
-    </div>
-  </div> 
-  </form>
-  <% if (session != null) session.invalidate(); %>  
-</body>
-</html>
diff --git a/opendaylight/adsal/web/flows/src/main/resources/WEB-INF/jsp/error.jsp b/opendaylight/adsal/web/flows/src/main/resources/WEB-INF/jsp/error.jsp
deleted file mode 100644 (file)
index 270d793..0000000
+++ /dev/null
@@ -1,8 +0,0 @@
-<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
-<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
-<%@taglib prefix="fn" uri="http://java.sun.com/jsp/jstl/functions" %>
-<c:set var="req" value="${pageContext.request}" />
-<c:set var="uri" value="${req.requestURI}" />
-<c:set var="replaceWith" value="/" />
-<c:set var="redirectUrl" value="${fn:replace(req.requestURL, req.contextPath , replaceWith)}" />
-<c:import url="${redirectUrl}" />
\ No newline at end of file
diff --git a/opendaylight/adsal/web/flows/src/main/resources/WEB-INF/jsp/login.jsp b/opendaylight/adsal/web/flows/src/main/resources/WEB-INF/jsp/login.jsp
deleted file mode 100644 (file)
index 270d793..0000000
+++ /dev/null
@@ -1,8 +0,0 @@
-<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
-<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
-<%@taglib prefix="fn" uri="http://java.sun.com/jsp/jstl/functions" %>
-<c:set var="req" value="${pageContext.request}" />
-<c:set var="uri" value="${req.requestURI}" />
-<c:set var="replaceWith" value="/" />
-<c:set var="redirectUrl" value="${fn:replace(req.requestURL, req.contextPath , replaceWith)}" />
-<c:import url="${redirectUrl}" />
\ No newline at end of file
diff --git a/opendaylight/adsal/web/flows/src/main/resources/WEB-INF/web.xml b/opendaylight/adsal/web/flows/src/main/resources/WEB-INF/web.xml
deleted file mode 100644 (file)
index c5d2479..0000000
+++ /dev/null
@@ -1,80 +0,0 @@
-<?xml version="1.0" encoding="ISO-8859-1"?>
-<web-app xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
-        xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
-        version="3.0">
-
-
-        <servlet>
-                <servlet-name>Flows</servlet-name>
-                <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
-                <load-on-startup>1</load-on-startup>
-        </servlet>
-
-        <servlet-mapping>
-                <servlet-name>Flows</servlet-name>
-                <url-pattern>/</url-pattern>
-        </servlet-mapping>
-
-
-        <security-constraint>
-                <web-resource-collection>
-                        <web-resource-name>free access</web-resource-name>
-                        <url-pattern>/js/*</url-pattern>
-                        <url-pattern>/images/*</url-pattern>
-                        <url-pattern>/css/*</url-pattern>
-                        <url-pattern>/favicon.ico</url-pattern>
-                </web-resource-collection>
-        </security-constraint>
-
-        <security-constraint>
-                <display-name>FlowApp</display-name>
-                <web-resource-collection>
-                        <web-resource-name>FlowMgrGUI</web-resource-name>
-                        <url-pattern>/*</url-pattern>
-                </web-resource-collection>
-                <auth-constraint>
-                        <role-name>System-Admin</role-name>
-                        <role-name>Network-Admin</role-name>
-                        <role-name>Network-Operator</role-name>
-                        <role-name>Container-User</role-name>
-                </auth-constraint>
-        </security-constraint>
-        <security-role>
-                <role-name>System-Admin</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Network-Admin</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Network-Operator</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Container-User</role-name>
-        </security-role>
-
-        <login-config>
-                <auth-method>FORM</auth-method>
-                <form-login-config>
-                        <form-login-page>/WEB-INF/jsp/login.jsp</form-login-page>
-                        <form-error-page>/WEB-INF/jsp/error.jsp</form-error-page>
-                </form-login-config>
-        </login-config>
-
-    <error-page>
-            <error-code>403</error-code>
-            <location>/WEB-INF/jsp/autherror.jsp</location>
-    </error-page>
-
-        <listener>
-                <listener-class>org.opendaylight.controller.web.ControllerUISessionManager</listener-class>
-        </listener>
-
-        <session-config>
-                <cookie-config>
-                        <path>/</path>
-                </cookie-config>
-        </session-config>
-
-
-
-</web-app>
diff --git a/opendaylight/adsal/web/flows/src/main/resources/js/page.js b/opendaylight/adsal/web/flows/src/main/resources/js/page.js
deleted file mode 100644 (file)
index 5e638cf..0000000
+++ /dev/null
@@ -1,1733 +0,0 @@
-/*
- * Copyright (c) 2013-2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-//PAGE flows
-one.f = {};
-
-// specify dashlets and layouts
-one.f.dashlet = {
-  flows : {
-    id : 'flows',
-    name : 'Flow Entries'
-  },
-  nodes : {
-    id : 'nodes',
-    name : 'Nodes'
-  },
-  detail : {
-    id : 'detail',
-    name : 'Flow Detail'
-  }
-};
-
-one.f.menu = {
-  left : {
-    top : [
-      one.f.dashlet.flows
-      ],
-    bottom : [
-      one.f.dashlet.nodes
-      ]
-  },
-  right : {
-    top : [],
-    bottom : [
-      one.f.dashlet.detail
-      ]
-  }
-};
-
-one.f.address = {
-  root : "/controller/web/flows",
-  flows : {
-    main : "/main",
-    flows : "/node-flows",
-    nodes : "/node-ports",
-    flow : "/flow",
-    modifyFlow : "/modifyFlow",
-    deleteFlows:"/flow/deleteFlows"
-  }
-}
-
-/** NODES **/
-one.f.nodes = {
-  id : {
-    dashlet: {
-      datagrid: "one_f_nodes_id_dashlet_datagrid"
-    }
-  },
-  registry : {},
-  dashlet : function($dashlet) {
-    var $h4 = one.lib.dashlet.header("Nodes");
-    $dashlet.append($h4);
-
-    one.f.nodes.ajax.dashlet(function(data) {
-      var $gridHTML = one.lib.dashlet.datagrid.init(one.f.nodes.id.dashlet.datagrid, {
-        searchable: true,
-          filterable: false,
-          pagination: true,
-          flexibleRowsPerPage: true
-      }, "table-striped table-condensed");
-      $dashlet.append($gridHTML);
-      var dataSource = one.f.nodes.data.nodesDataGrid(data);
-      $("#" + one.f.nodes.id.dashlet.datagrid).datagrid({dataSource: dataSource});
-    });
-  },
-  ajax : {
-    dashlet : function(callback) {
-      $.getJSON(one.f.address.root+one.f.address.flows.flows, function(data) {
-        callback(data);
-      });
-    }
-  },
-  data : {
-    nodesDataGrid: function(data) {
-      var gridData = [];
-      $.each(data, function(nodeName, flow) {
-        var nodeFlowObject = {};
-        nodeFlowObject["nodeName"] = nodeName;
-        nodeFlowObject["flows"] = flow;
-        nodeFlowObject["rowData"] = nodeName + flow + "-foobar";
-        gridData.push(nodeFlowObject);
-      });
-
-      var source = new StaticDataSource({
-        columns: [
-      {
-        property: 'nodeName',
-          label: 'Node',
-          sortable: true
-      },
-          {
-            property: 'flows',
-          label: 'Flows',
-          sortable: true
-          }
-      ],
-          data: gridData,
-          delay: 0
-      });
-      return source;
-    }
-  },
-  body : {
-    dashlet : function(body, callback) {
-      var attributes = ['table-striped', 'table-bordered', 'table-hover', 'table-condensed'];
-      var $table = one.lib.dashlet.table.table(attributes);
-
-      var headers = ['Node', 'Flows'];
-      var $thead = one.lib.dashlet.table.header(headers);
-      $table.append($thead);
-
-      var $tbody = one.lib.dashlet.table.body(body);
-      $table.append($tbody);
-
-      return $table;
-    }
-  }
-}
-
-/** FLOW DETAIL **/
-one.f.detail = {
-  id : {},
-  registry : {},
-  dashlet : function($dashlet, details) {
-    var $h4 = one.lib.dashlet.header("Flow Details");
-    $dashlet.append($h4);
-
-    // details
-    if (details == undefined) {
-      var $none = $(document.createElement('div'));
-      $none.addClass('none');
-      var $p = $(document.createElement('p'));
-      $p.text('Please select a flow');
-      $p.addClass('text-center').addClass('text-info');
-
-      $dashlet.append($none)
-        .append($p);
-    }
-  },
-  data : {
-    dashlet : function(data) {
-      var body = [];
-      var tr = {};
-      var entry = [];
-
-      entry.push(data['name']);
-      entry.push(data['node']);
-      entry.push(data['flow']['priority']);
-      entry.push(data['flow']['hardTimeout']);
-      entry.push(data['flow']['idleTimeout']);
-
-      tr.entry = entry;
-      body.push(tr);
-      return body;
-    },
-    description : function(data) {
-      var body = [];
-      var tr = {};
-      var entry = [];
-      entry.push(data['flow']['ingressPort']);
-      entry.push(data['flow']['etherType']);
-      entry.push(data['flow']['vlanId']);
-      entry.push(data['flow']['vlanPriority']);
-      entry.push(data['flow']['srcMac']);
-      entry.push(data['flow']['dstMac']);
-      entry.push(data['flow']['srcIp']);
-      entry.push(data['flow']['dstIp']);
-      entry.push(data['flow']['tosBits']);
-      entry.push(data['flow']['srcPort']);
-      entry.push(data['flow']['dstPort']);
-      entry.push(data['flow']['protocol']);
-      entry.push(data['flow']['cookie']);
-
-      tr.entry = entry;
-      body.push(tr);
-      return body;
-    },
-    actions : function(data) {
-      var body = [];
-      var tr = {};
-      var entry = [];
-      var actions = '';
-
-      $(data['flow']['actions']).each(function(index, value) {
-        var locEqualTo = value.indexOf("=");
-        if ( locEqualTo == -1 ) {
-          actions += value + ', ';
-        } else {
-          var action = value.substr(0,locEqualTo);
-          if( action == "OUTPUT") {
-            var portIds = value.substr(locEqualTo+1).split(",");
-            actions += action + "=";
-            var allPorts = one.f.flows.registry.nodeports[one.f.flows.registry.selectedNode]['ports'];
-            for(var i =0; i < portIds.length ; i++) {
-              var portName = allPorts[portIds[i]];
-              actions += portName + ", ";
-            }
-          } else {
-            actions += value + ', ';
-          }
-        }
-      });
-      actions = actions.slice(0,-2);
-      entry.push(actions);
-
-      tr.entry = entry;
-      body.push(tr);
-      return body;
-    }
-  },
-  body : {
-    dashlet : function(body) {
-      // create table
-      var header = ['Flow Name', 'Node', 'Priority', 'Hard Timeout', 'Idle Timeout'];
-      var $thead = one.lib.dashlet.table.header(header);
-      var attributes = ['table-striped', 'table-bordered', 'table-condensed'];
-      var $table = one.lib.dashlet.table.table(attributes);
-      $table.append($thead);
-
-      var $tbody = one.lib.dashlet.table.body(body);
-      $table.append($tbody);
-
-      return $table;
-    },
-    description : function(body) {
-      var header = ['Input Port', 'Ethernet Type', 'VLAN ID', 'VLAN Priority', 'Source MAC', 'Dest MAC', 'Source IP', 'Dest IP', 'ToS', 'Source Port', 'Dest Port', 'Protocol', 'Cookie'];
-      var $thead = one.lib.dashlet.table.header(header);
-      var attributes = ['table-striped', 'table-bordered', 'table-condensed'];
-      var $table = one.lib.dashlet.table.table(attributes);
-      $table.append($thead);
-
-      var $tbody = one.lib.dashlet.table.body(body);
-      $table.append($tbody);
-
-      return $table;
-    },
-    actions : function(body) {
-      var header = ['Actions'];
-      var $thead = one.lib.dashlet.table.header(header);
-      var attributes = ['table-striped', 'table-bordered', 'table-condensed'];
-      var $table = one.lib.dashlet.table.table(attributes);
-      $table.append($thead);
-
-      var $tbody = one.lib.dashlet.table.body(body);
-      $table.append($tbody);
-
-      return $table;
-    }
-  }
-}
-
-/** FLOW ENTRIES **/
-one.f.flows = {
-  id : {
-    dashlet : {
-      add : "one_f_flows_id_dashlet_add",
-      removeMultiple : "one_f_flows_id_dashlet_removeMultiple",
-      remove : "one_f_flows_id_dashlet_remove",
-      toggle : "one_f_flows_id_dashlet_toggle",
-      edit : "one_f_flows_id_dashlet_edit",
-      datagrid : "one_f_flows_id_dashlet_datagrid",
-      selectAllFlows : "one_f_flows_id_dashlet_selectAllFlows"
-    },
-    modal : {
-      install : "one_f_flows_id_modal_install",
-      edit : "one_f_flows_id_modal_edit",
-      add : "one_f_flows_id_modal_add",
-      close : "one_f_flows_id_modal_close",
-      modal : "one_f_flows_id_modal_modal",
-      dialog : {
-        modal : "one_f_flows_id_modal_dialog_modal",
-        remove : "one_f_flows_id_modal_dialog_remove",
-        close : "one_f_flows_id_modal_dialog_close"
-      },
-      action : {
-        button : "one_f_flows_id_modal_action_button",
-        modal : "one_f_flows_id_modal_action_modal",
-        add : "one_f_flows_id_modal_action_add",
-        close : "one_f_flows_id_modal_action_close",
-        table : "one_f_flows_id_modal_action_table",
-        addOutputPorts : "one_f_flows_id_modal_action_addOutputPorts",
-        setVlanId : "one_f_flows_id_modal_action_setVlanId",
-        setVlanPriority : "one_f_flows_id_modal_action_setVlanPriority",
-        modifyDatalayerSourceAddress : "one_f_flows_id_modal_action_modifyDatalayerSourceAddress",
-        modifyDatalayerDestinationAddress : "one_f_flows_id_modal_action_modifyDatalayerDestinationAddress",
-        modifyNetworkSourceAddress : "one_f_flows_modal_action_modifyNetworkSourceAddress",
-        modifyNetworkDestinationAddress : "one_f_flows_modal_action_modifyNetworkDestinationAddress",
-        modifyTosBits : "one_f_flows_modal_action_modifyTosBits",
-        modifyTransportSourcePort : "one_f_flows_modal_action_modifyTransportSourcePort",
-        modifyTransportDestinationPort : "one_f_flows_modal_action_modifyTransportDestinationPort",
-        enqueue : 'one-f-flows-modal-action-enqueue',
-        queue : 'one-f-flows-modal-action-queue',
-        setEthertype : 'one-f-flows-modal-action-setEthertype',
-        pushVlan : 'one-f-flows-modal-action-pushVlan',
-        setVlanCfi : 'one-f-flows-modal-action-setVlanCfi',
-        modal : {
-          modal : "one_f_flows_modal_action_modal_modal",
-          remove : "one_f_flows_modal_action_modal_remove",
-          cancel : "one_f_flows_modal_action_modal_cancel"
-        }
-      },
-      form : {
-        name : "one_f_flows_id_modal_form_name",
-        nodes : "one_f_flows_id_modal_form_nodes",
-        port : "one_f_flows_id_modal_form_port",
-        priority : "one_f_flows_id_modal_form_priority",
-        hardTimeout : "one_f_flows_id_modal_form_hardTimeout",
-        idleTimeout : "one_f_flows_id_modal_form_idleTimeout",
-        cookie : "one_f_flows_id_modal_form_cookie",
-        etherType : "one_f_flows_id_modal_form_etherType",
-        vlanId : "one_f_flows_id_modal_form_vlanId",
-        vlanPriority : "one_f_flows_id_modal_form_vlanPriority",
-        srcMac : "one_f_flows_id_modal_form_srcMac",
-        dstMac : "one_f_flows_id_modal_form_dstMac",
-        srcIp : "one_f_flows_id_modal_form_srcIp",
-        dstIp : "one_f_flows_id_modal_form_dstIp",
-        tosBits : "one_f_flows_id_modal_form_tosBits",
-        srcPort : "one_f_flows_id_modal_form_srcPort",
-        dstPort : "one_f_flows_id_modal_form_dstPort",
-        protocol : "one_f_flows_id_modal_form_protocol",
-        action : 'one-f-flows-id-modal-form-action'
-      }
-    }
-  },
-  registry : {},
-  dashlet : function($dashlet, callback) {
-    // load body
-    one.f.flows.ajax.dashlet(function(data) {
-      var $h4 = one.lib.dashlet.header("Flow Entries");
-      $dashlet.append($h4);
-      if (one.f.flows.registry.privilege === 'WRITE') {
-        var button = one.lib.dashlet.button.single("Add Flow Entry", one.f.flows.id.dashlet.add, "btn-primary", "btn-mini");
-        var $button = one.lib.dashlet.button.button(button);
-
-        $button.click(function() {
-          var $modal = one.f.flows.modal.initialize();
-          $modal.modal();
-        });
-        $dashlet.append($button);
-        var button = one.lib.dashlet.button.single("Remove Flow Entry", one.f.flows.id.dashlet.removeMultiple, "btn-danger", "btn-mini");
-        var $button = one.lib.dashlet.button.button(button);
-
-        $button.click(function() {
-          var checkedCheckBoxes = $('.flowEntry[type=checkbox]:checked');
-          if (checkedCheckBoxes.size() === 0) {
-            return false;
-          }
-
-          var requestData = [];
-
-          checkedCheckBoxes.each(function(index, value) {
-            var flowEntry = {};
-            flowEntry['name'] = checkedCheckBoxes[index].name;
-            flowEntry['node'] = checkedCheckBoxes[index].getAttribute("node");
-            requestData.push(flowEntry);  
-          });
-          one.f.flows.modal.removeMultiple.dialog(requestData);
-        });
-        $dashlet.append($button);
-
-      }
-      var $gridHTML = one.lib.dashlet.datagrid.init(one.f.flows.id.dashlet.datagrid, {
-        searchable: true,
-          filterable: false,
-          pagination: true,
-          flexibleRowsPerPage: true
-      }, "table-striped table-condensed");
-      $dashlet.append($gridHTML);
-      var dataSource = one.f.flows.data.flowsDataGrid(data);
-      $("#" + one.f.flows.id.dashlet.datagrid).datagrid({dataSource: dataSource}).on("loaded", function() {
-        $("#"+one.f.flows.id.dashlet.datagrid.selectAllFlows).click(function() {
-          $("#" + one.f.flows.id.dashlet.datagrid).find(':checkbox').prop('checked',
-            $("#"+one.f.flows.id.dashlet.datagrid.selectAllFlows).is(':checked'));
-        });
-
-        $("#" + one.f.flows.id.dashlet.datagrid).find("tbody tr").each(function(index, tr) {
-          $tr = $(tr);
-          $span = $("td span", $tr);
-          var flowstatus = $span.data("flowstatus");
-          if($span.data("installinhw") != null) {
-            var installInHw = $span.data("installinhw").toString();
-            if(installInHw == "true" && flowstatus == "Success") {
-              $tr.addClass("success");
-            } else {
-              $tr.addClass("warning");
-            }
-          }
-          // attach mouseover to show pointer cursor
-          $tr.mouseover(function() {
-            $(this).css("cursor", "pointer");
-          });
-          // attach click event
-          $tr.click(function() {
-            var $td = $($(this).find("td")[1]);
-            var id = $td.text();
-            var node = $td.find("span").data("nodeid");
-            one.f.flows.detail(id, node);
-          });
-          $(".flowEntry").click(function(e){
-            if (!$('.flowEntry[type=checkbox]:not(:checked)').length) {
-              $("#"+one.f.flows.id.dashlet.datagrid.selectAllFlows)
-            .prop("checked",
-              true);
-            } else {
-              $("#"+one.f.flows.id.dashlet.datagrid.selectAllFlows)
-            .prop("checked",
-              false);
-            }
-            e.stopPropagation();
-          });
-        });
-      });
-
-      // details callback
-      if(callback != undefined) callback();
-    });
-  },
-  detail : function(id, node) {
-    // clear flow details
-    var $detailDashlet = one.main.dashlet.right.bottom;
-    $detailDashlet.empty();
-    var $h4 = one.lib.dashlet.header("Flow Overview");
-    $detailDashlet.append($h4);
-
-    // details
-    var flows = one.f.flows.registry.flows;
-    one.f.flows.registry['selectedId'] = id;
-    one.f.flows.registry['selectedNode'] = node;
-    var flow;
-    $(flows).each(function(index, value) {
-      if (value.name == id && value.nodeId == node) {
-        flow = value;
-      }
-    });
-    if (one.f.flows.registry.privilege === 'WRITE') {
-      // remove button
-      var button = one.lib.dashlet.button.single("Remove Flow", one.f.flows.id.dashlet.remove, "btn-danger", "btn-mini");
-      var $button = one.lib.dashlet.button.button(button);
-      $button.click(function() {
-        var $modal = one.f.flows.modal.dialog.initialize(id, node);
-        $modal.modal();
-      });
-      // edit button
-      var editButton = one.lib.dashlet.button.single("Edit Flow", one.f.flows.id.dashlet.edit, "btn-primary", "btn-mini");
-      var $editButton = one.lib.dashlet.button.button(editButton);
-      $editButton.click(function() {
-        var install = flow['flow']['installInHw'];
-        var $modal = one.f.flows.modal.initialize(true,install);
-        $modal.modal().on('shown',function(){
-          var $port = $('#'+one.f.flows.id.modal.form.port);
-          $('#'+one.f.flows.id.modal.form.nodes).trigger("change");
-        });
-      });
-      // toggle button
-      var toggle;
-      if (flow['flow']['installInHw'] == 'true' && flow['flow']['status'] == 'Success') {
-        toggle = one.lib.dashlet.button.single("Uninstall Flow", one.f.flows.id.dashlet.toggle, "btn-warning", "btn-mini");
-      } else {
-        toggle = one.lib.dashlet.button.single("Install Flow", one.f.flows.id.dashlet.toggle, "btn-success", "btn-mini");
-      }
-      var $toggle = one.lib.dashlet.button.button(toggle);
-      $toggle.click(function() {
-        one.f.flows.modal.ajax.toggleflow(id, node, function(data) {
-          if(data == "Success") {
-            one.main.dashlet.right.bottom.empty();
-            one.f.detail.dashlet(one.main.dashlet.right.bottom);
-            one.main.dashlet.left.top.empty();
-            one.f.flows.dashlet(one.main.dashlet.left.top, function() {
-              // checks are backwards due to stale registry
-              if(flow['flow']['installInHw'] == 'true') {
-                one.lib.alert('Uninstalled Flow');
-              } else {
-                one.lib.alert('Installed Flow');
-              }
-              one.f.flows.detail(id, node)
-            });
-          } else {
-            one.lib.alert('Cannot toggle flow: '+data);
-          }
-        });
-      });
-
-      $detailDashlet.append($button).append($editButton).append($toggle);
-    }
-    // append details
-    var body = one.f.detail.data.dashlet(flow);
-    var $body = one.f.detail.body.dashlet(body);
-    $detailDashlet.append($body);
-    var body = one.f.detail.data.description(flow);
-    var $body = one.f.detail.body.description(body);
-    $detailDashlet.append($body);
-    var body = one.f.detail.data.actions(flow);
-    var $body = one.f.detail.body.actions(body);
-    $detailDashlet.append($body);
-  },
-  modal : {
-    dialog : {
-      initialize : function(id, node) {
-        var h3 = "Remove Flow";
-        var $p = one.f.flows.modal.dialog.body(id);
-        var footer = one.f.flows.modal.dialog.footer();
-        var $modal = one.lib.modal.spawn(one.f.flows.id.modal.dialog.modal, h3, $p, footer);
-        $('#'+one.f.flows.id.modal.dialog.close, $modal).click(function() {
-          $modal.modal('hide');
-        });
-        $('#'+one.f.flows.id.modal.dialog.remove, $modal).click(function() {
-          one.f.flows.modal.ajax.removeflow(id, node, function(data) {
-            if (data == "Success") {
-              $modal.modal('hide');
-              one.main.dashlet.right.bottom.empty();
-              one.f.detail.dashlet(one.main.dashlet.right.bottom);
-              one.main.dashlet.left.top.empty();
-              one.f.flows.dashlet(one.main.dashlet.left.top);
-              one.lib.alert('Flow removed');
-            } else {
-              one.lib.alert('Cannot remove flow: '+data);
-            }
-          });
-        });
-        return $modal;
-      },
-      footer : function() {
-        var footer = [];
-
-        var removeButton = one.lib.dashlet.button.single("Remove Flow", one.f.flows.id.modal.dialog.remove, "btn-danger", "");
-        var $removeButton = one.lib.dashlet.button.button(removeButton);
-        footer.push($removeButton);
-
-        var closeButton = one.lib.dashlet.button.single("Cancel", one.f.flows.id.modal.dialog.close, "", "");
-        var $closeButton = one.lib.dashlet.button.button(closeButton);
-        footer.push($closeButton);
-
-        return footer;
-      },
-      body : function(id) {
-        var $p = $(document.createElement('p'));
-        $p.append('Remove flow '+id+'?');
-        return $p;
-      }
-    },
-    initialize : function(edit,install) {
-      var h3;
-      if(edit) {
-        h3 = "Edit Flow Entry";
-        var footer = one.f.flows.modal.footerEdit();
-
-      } else {
-        h3 = "Add Flow Entry";
-        var footer = one.f.flows.modal.footer();
-      }
-
-      var $modal = one.lib.modal.spawn(one.f.flows.id.modal.modal, h3, "", footer);
-
-      // bind close button
-      $('#'+one.f.flows.id.modal.close, $modal).click(function() {
-        $modal.modal('hide');
-      });
-
-      if (edit) {
-        // bind edit flow button
-        $('#'+one.f.flows.id.modal.edit, $modal).click(function() {
-          one.f.flows.modal.save($modal, install, true);
-        });
-      } else {
-        // bind add flow button
-        $('#'+one.f.flows.id.modal.add, $modal).click(function() {
-          one.f.flows.modal.save($modal, 'false');
-        });
-
-        // bind install flow button
-        $('#'+one.f.flows.id.modal.install, $modal).click(function() {
-          one.f.flows.modal.save($modal, 'true');
-        });
-      }
-
-      var nodes = one.f.flows.registry.nodes;
-      var nodeports = one.f.flows.registry.nodeports;
-      var $body = one.f.flows.modal.body(nodes, nodeports, edit);
-      one.lib.modal.inject.body($modal, $body,edit);
-
-      return $modal;
-    },
-    save : function($modal, install, edit) {
-      var result = {};
-
-      result['name'] = $('#'+one.f.flows.id.modal.form.name, $modal).val();
-      result['ingressPort'] = $('#'+one.f.flows.id.modal.form.port, $modal).val();
-      result['priority'] = $('#'+one.f.flows.id.modal.form.priority, $modal).val();
-      result['hardTimeout'] = $('#'+one.f.flows.id.modal.form.hardTimeout, $modal).val();
-      result['idleTimeout'] = $('#'+one.f.flows.id.modal.form.idleTimeout, $modal).val();
-      result['cookie'] = $('#'+one.f.flows.id.modal.form.cookie, $modal).val();
-      result['etherType'] = $('#'+one.f.flows.id.modal.form.etherType, $modal).val();
-      result['vlanId'] = $('#'+one.f.flows.id.modal.form.vlanId, $modal).val();
-      result['vlanPriority'] = $('#'+one.f.flows.id.modal.form.vlanPriority, $modal).val();
-      result['dlSrc'] = $('#'+one.f.flows.id.modal.form.srcMac, $modal).val();
-      result['dlDst'] = $('#'+one.f.flows.id.modal.form.dstMac, $modal).val();
-      result['nwSrc'] = $('#'+one.f.flows.id.modal.form.srcIp, $modal).val();
-      result['nwDst'] = $('#'+one.f.flows.id.modal.form.dstIp, $modal).val();
-      result['tosBits'] = $('#'+one.f.flows.id.modal.form.tosBits, $modal).val();
-      result['tpSrc'] = $('#'+one.f.flows.id.modal.form.srcPort, $modal).val();
-      result['tpDst'] = $('#'+one.f.flows.id.modal.form.dstPort, $modal).val();
-      result['protocol'] = $('#'+one.f.flows.id.modal.form.protocol, $modal).val();
-      result['installInHw'] = install;
-
-      var nodeId = $('#'+one.f.flows.id.modal.form.nodes, $modal).val();
-
-      $.each(result, function(key, value) {
-        if (value == "") delete result[key];
-      });
-
-      var action = [];
-      var $table = $('#'+one.f.flows.id.modal.action.table, $modal);
-      $($table.find('tbody').find('tr')).each(function(index, value) {
-        if (!$(this).find('td').hasClass('empty')) {
-          action.push($(value).data('action'));
-        }
-      });
-      result['actions'] = action;
-
-      // frontend validation
-      if (result['name'] == undefined) {
-        alert('Need flow name');
-        return;
-      }
-      if (nodeId == '') {
-        alert('Select node');
-        return;
-      }
-      if (action.length == 0) {
-        alert('Please specify an action');
-        return;
-      }
-
-      // package for ajax call
-      var resource = {};
-      resource['body'] = JSON.stringify(result);
-      if(edit){
-        resource['action'] = 'edit';
-      } else {
-        resource['action'] = 'add';
-      }
-
-      resource['nodeId'] = nodeId;
-
-      if (edit) {
-        one.f.flows.modal.ajax.saveflow(resource, function(data) {
-          if (data == "Success") {
-            $modal.modal('hide').on('hidden', function () {
-              one.f.flows.detail(result['name'], nodeId);
-            });
-            one.lib.alert('Flow Entry edited');
-            one.main.dashlet.left.top.empty();
-            one.f.flows.dashlet(one.main.dashlet.left.top);
-          } else {
-            alert('Could not edit flow: '+data);
-          }
-        });
-      } else {
-        one.f.flows.modal.ajax.saveflow(resource, function(data) {
-          if (data == "Success") {
-            $modal.modal('hide');
-            one.lib.alert('Flow Entry added');
-            one.main.dashlet.left.top.empty();
-            one.f.flows.dashlet(one.main.dashlet.left.top);
-          } else {
-            alert('Could not add flow: '+data);
-          }
-        });
-      }
-    },
-    ajax : {
-      nodes : function(successCallback) {
-        $.getJSON(one.f.address.root+one.f.address.flows.nodes, function(data) {
-          var nodes = one.f.flows.modal.data.nodes(data);
-          var nodeports = data;
-          one.f.flows.registry['nodes'] = nodes;
-          one.f.flows.registry['nodeports'] = nodeports;
-
-          successCallback(nodes, nodeports);
-        });
-      },
-      saveflow : function(resource, callback) {
-        $.post(one.f.address.root+one.f.address.flows.flow, resource, function(data) {
-          callback(data);
-        });
-      },
-      removeflow : function(id, node, callback) {
-        resource = {};
-        resource['action'] = 'remove';
-        $.post(one.f.address.root+one.f.address.flows.flow+'/'+node+'/'+id, resource, function(data) {
-          callback(data);
-        });
-      },
-      toggleflow : function(id, node, callback) {
-        resource = {};
-        resource['action'] = 'toggle';
-        $.post(one.f.address.root+one.f.address.flows.flow+'/'+node+'/'+id, resource, function(data) {
-          callback(data);
-        });
-      }
-    },
-    data : {
-      nodes : function(data) {
-        result = {};
-        $.each(data, function(key, value) {
-          result[key] = value['name'];
-        });
-        return result;
-      }
-    },
-    body : function(nodes, nodeports, edit) {
-      var $form = $(document.createElement('form'));
-      var $fieldset = $(document.createElement('fieldset'));
-      var existingFlow;
-      // flow description
-      var $legend = one.lib.form.legend("");
-      $legend.css('visibility', 'hidden');
-      $fieldset.append($legend);
-      // name
-      var $label = one.lib.form.label("Name");
-      var $input = one.lib.form.input("Flow Name");
-      $input.attr('id', one.f.flows.id.modal.form.name);
-      if(edit) {
-        $input.attr('disabled', 'disabled');
-        var flows = one.f.flows.registry.flows;
-        $(flows).each(function(index, value) {
-          if (value.name == one.f.flows.registry.selectedId && value.nodeId == one.f.flows.registry.selectedNode) {
-            existingFlow = value.flow;
-          }
-        });
-        $input.val(existingFlow.name);
-      }
-
-      $fieldset.append($label).append($input);
-      // node
-      var $label = one.lib.form.label("Node");
-      var $select = one.lib.form.select.create(nodes);
-      one.lib.form.select.prepend($select, { '' : 'Please Select a Node' });
-      $select.val($select.find("option:first").val());
-      $select.attr('id', one.f.flows.id.modal.form.nodes);
-      if(edit) {
-        $select.attr('disabled', 'disabled');
-        $select.val(existingFlow.node.type + "|"+ existingFlow.node.nodeIDString);
-      }
-
-      // bind onchange
-      $select.change(function() {
-        // retrieve port value
-        var node = $(this).find('option:selected').attr('value');
-        var $ports = $('#'+one.f.flows.id.modal.form.port);
-        if (node == '') {
-          one.lib.form.select.inject($ports, {});
-          return;
-        }
-        one.f.flows.registry['currentNode'] = node;
-        var ports = nodeports[node]['ports'];
-        one.lib.form.select.inject($ports, ports);
-        one.lib.form.select.prepend($ports, { '' : 'Please Select a Port' });
-        $ports.val($ports.find("option:first").val());
-        if(edit) {
-          $ports.val( existingFlow.ingressPort );
-        }
-        $.getJSON(one.f.address.root+'/valid-flows/'+node, function(response) {
-          var $select = $('#'+one.f.flows.id.modal.form.action, $fieldset);
-          one.lib.form.select.inject($select, response);
-          one.lib.form.select.prepend($select, {'' : 'Please Select an Action'});
-          // when selecting an action
-          $select.change(function() {
-            var action = $(this).find('option:selected');
-            one.f.flows.modal.action.parse(action.attr('value'));
-            $select[0].selectedIndex = 0;
-          });
-        });
-      });
-
-      $fieldset.append($label).append($select);
-      // input port
-      var $label = one.lib.form.label("Input Port");
-      var $select = one.lib.form.select.create();
-
-      $select.attr('id', one.f.flows.id.modal.form.port);
-      $fieldset.append($label).append($select);
-      // priority
-      var $label = one.lib.form.label("Priority");
-      var $input = one.lib.form.input("Priority");
-      $input.attr('id', one.f.flows.id.modal.form.priority);
-      $input.val('500');
-      $fieldset.append($label).append($input);
-      if(edit) {
-        $input.val(existingFlow.priority);
-      }
-      // hardTimeout
-      var $label = one.lib.form.label("Hard Timeout");
-      var $input = one.lib.form.input("Hard Timeout");
-      $input.attr('id', one.f.flows.id.modal.form.hardTimeout);
-      if(edit) {
-        $input.val(existingFlow.hardTimeout);
-      }
-      $fieldset.append($label).append($input);
-
-      // idleTimeout
-      var $label = one.lib.form.label("Idle Timeout");
-      var $input = one.lib.form.input("Idle Timeout");
-      $input.attr('id', one.f.flows.id.modal.form.idleTimeout);
-      $fieldset.append($label).append($input);
-      if(edit) {
-        $input.val(existingFlow.idleTimeout);
-      }
-      // cookie
-      var $label = one.lib.form.label("Cookie");
-      var $input = one.lib.form.input("Cookie");
-      $input.attr('id', one.f.flows.id.modal.form.cookie);
-      $fieldset.append($label).append($input);
-      if(edit) {
-        $input.val(existingFlow.cookie);
-      }
-
-      // layer 2
-      var $legend = one.lib.form.legend("Layer 2");
-      $fieldset.append($legend);
-      // etherType
-      var $label = one.lib.form.label("Ethernet Type");
-      var $input = one.lib.form.input("Ethernet Type");
-      $input.attr('id', one.f.flows.id.modal.form.etherType);
-      $input.val('0x800');
-      $fieldset.append($label).append($input);
-      if(edit) {
-        $input.val(existingFlow.etherType);
-      }
-      // vlanId
-      var $label = one.lib.form.label("VLAN Identification Number");
-      var $input = one.lib.form.input("VLAN Identification Number");
-      $input.attr('id', one.f.flows.id.modal.form.vlanId);
-      var $help = one.lib.form.help("Range: 0 - 4095");
-      $fieldset.append($label).append($input).append($help);
-      if(edit) {
-        $input.val(existingFlow.vlanId);
-      }
-
-      // vlanPriority
-      var $label = one.lib.form.label("VLAN Priority");
-      var $input = one.lib.form.input("VLAN Priority");
-      $input.attr('id', one.f.flows.id.modal.form.vlanPriority);
-      var $help = one.lib.form.help("Range: 0 - 7");
-      $fieldset.append($label).append($input).append($help);
-      if(edit) {
-        $input.val(existingFlow.vlanPriority);
-      }
-
-      // srcMac
-      var $label = one.lib.form.label("Source MAC Address");
-      var $input = one.lib.form.input("3c:97:0e:75:c3:f7");
-      $input.attr('id', one.f.flows.id.modal.form.srcMac);
-      $fieldset.append($label).append($input);
-      if(edit) {
-        $input.val(existingFlow.srcMac);
-      }
-      // dstMac
-      var $label = one.lib.form.label("Destination MAC Address");
-      var $input = one.lib.form.input("7c:d1:c3:e8:e6:99");
-      $input.attr('id', one.f.flows.id.modal.form.dstMac);
-      $fieldset.append($label).append($input);
-      if(edit) {
-        $input.val(existingFlow.dstMac);
-      }
-      // layer 3
-      var $legend = one.lib.form.legend("Layer 3");
-      $fieldset.append($legend);
-
-      // srcIp
-      var $label = one.lib.form.label("Source IP Address");
-      var $input = one.lib.form.input("192.168.3.128");
-      $input.attr('id', one.f.flows.id.modal.form.srcIp);
-      $fieldset.append($label).append($input);
-      if(edit) {
-        $input.val(existingFlow.srcIp);
-      }
-      // dstIp
-      var $label = one.lib.form.label("Destination IP Address");
-      var $input = one.lib.form.input("2001:2334::0/32");
-      $input.attr('id', one.f.flows.id.modal.form.dstIp);
-      $fieldset.append($label).append($input);
-      if(edit) {
-        $input.val(existingFlow.dstIp);
-      }
-      // tosBits
-      var $label = one.lib.form.label("ToS Bits");
-      var $input = one.lib.form.input("ToS Bits");
-      $input.attr('id', one.f.flows.id.modal.form.tosBits);
-      var $help = one.lib.form.help("Range: 0 - 63");
-      $fieldset.append($label).append($input).append($help);
-      if(edit) {
-        $input.val(existingFlow.tosBits);
-      }
-
-      // layer 4
-      var $legend = one.lib.form.legend("Layer 4");
-      $fieldset.append($legend);
-      // srcPort
-      var $label = one.lib.form.label("Source Port");
-      var $input = one.lib.form.input("Source Port");
-      $input.attr('id', one.f.flows.id.modal.form.srcPort);
-      var $help = one.lib.form.help("Range: 0 - 65535");
-      $fieldset.append($label).append($input).append($help);
-      if(edit) {
-        $input.val(existingFlow.srcPort);
-      }
-      // dstPort
-      var $label = one.lib.form.label("Destination Port");
-      var $input = one.lib.form.input("Destination Port");
-      $input.attr('id', one.f.flows.id.modal.form.dstPort);
-      var $help = one.lib.form.help("Range: 0 - 65535");
-      $fieldset.append($label).append($input).append($help);
-      if(edit) {
-        $input.val(existingFlow.dstPort);
-      }
-      // protocol
-      var $label = one.lib.form.label("Protocol");
-      var $input = one.lib.form.input("Protocol");
-      $input.attr('id', one.f.flows.id.modal.form.protocol);
-      $fieldset.append($label).append($input);
-      if(edit) {
-        $input.val(existingFlow.protocol);
-      }
-      // actions
-      var $legend = one.lib.form.label("Actions");
-      $fieldset.append($legend);
-      // actions table
-      var tableAttributes = ["table-striped", "table-bordered", "table-condensed", "table-hover", "table-cursor"];
-      var $table = one.lib.dashlet.table.table(tableAttributes);
-      $table.attr('id', one.f.flows.id.modal.action.table);
-      var tableHeaders = ["Action", "Data"];
-      var $thead = one.lib.dashlet.table.header(tableHeaders);
-      var $tbody = one.lib.dashlet.table.body("", tableHeaders);
-      $table.append($thead).append($tbody);
-      // actions
-      var actions = {
-        "" : "Please Select an Action",
-        "DROP" : "Drop",
-        "LOOPBACK" : "Loopback",
-        "FLOOD" : "Flood",
-        "FLOOD_ALL" : "Flood All",
-        "CONTROLLER" : "Controller",
-        "SW_PATH" : "Software Path",
-        "HW_PATH" : "Hardware Path",
-        "OUTPUT" : "Add Output Ports",
-        "ENQUEUE" : "Enqueue",
-        "SET_VLAN_ID" : "Set VLAN ID",
-        "SET_VLAN_PCP" : "Set VLAN Priority",
-        "SET_VLAN_CFI" : "Set VLAN CFI",
-        "POP_VLAN" : "Strip VLAN Header",
-        "PUSH_VLAN" : "Push VLAN",
-        "SET_DL_SRC" : "Modify Datalayer Source Address",
-        "SET_DL_DST" : "Modify Datalayer Destination Address",
-        "SET_DL_TYPE" : "Set Ethertype",
-        "SET_NW_SRC" : "Modify Network Source Address",
-        "SET_NW_DST" :"Modify Network Destination Address",
-        "SET_NW_TOS" : "Modify ToS Bits",
-        "SET_TP_SRC" : "Modify Transport Source Port",
-        "SET_TP_DST" : "Modify Transport Destination Port"
-      };
-      var $select = one.lib.form.select.create(actions);
-      $select.attr('id', one.f.flows.id.modal.form.action);
-      // when selecting an action
-      $select.change(function() {
-        var action = $(this).find('option:selected');
-        one.f.flows.modal.action.parse(action.attr('value'));
-        $select[0].selectedIndex = 0;
-      });
-
-      if(edit) {
-        $(existingFlow.actions).each(function(index, value){
-          setTimeout(function(){
-            var locEqualTo = value.indexOf("=");
-            if ( locEqualTo == -1 ) {
-              one.f.flows.modal.action.add.add(actions[value], value);
-            } else {
-              var action = value.substr(0,locEqualTo);
-              if( action == "OUTPUT") {
-                var portIds = value.substr(locEqualTo+1).split(",");
-                var ports = [];
-                var allPorts = one.f.flows.registry.nodeports[one.f.flows.registry.currentNode]['ports'];
-                for(var i =0; i < portIds.length ; i++) {
-                  var portName = allPorts[portIds[i]];
-                  ports.push(portName);
-                }
-                one.f.flows.modal.action.add.addPortsToTable(ports.join(", "), portIds.join(","));
-              } else {
-                var val = value.substr(locEqualTo+1);
-                one.f.flows.modal.action.add.addDataToTable(actions[action], val, action)
-              }
-            }
-          }, 1000)
-        });
-      }
-      $fieldset.append($select).append($table);
-
-      // return
-      $form.append($fieldset);
-      return $form;
-    },
-    action : {
-      parse : function(option) {
-        switch (option) {
-          case "OUTPUT" :
-            var h3 = "Add Output Port";
-            var $modal = one.f.flows.modal.action.initialize(h3, one.f.flows.modal.action.body.addOutputPorts, one.f.flows.modal.action.add.addOutputPorts);
-            $modal.modal();
-            break;
-          case "SET_VLAN_ID" :
-            var h3 = "Set VLAN ID";
-            var placeholder = "VLAN Identification Number";
-            var id = one.f.flows.id.modal.action.setVlanId;
-            var help = "Range: 0 - 4095";
-            var action = 'SET_VLAN_ID';
-            var name = "VLAN ID";
-            var body = function() {
-              return one.f.flows.modal.action.body.set(h3, placeholder, id, help);
-            };
-            var add = function($modal) {
-              one.f.flows.modal.action.add.set(name, id, action, $modal);
-            };
-            var $modal = one.f.flows.modal.action.initialize(h3, body, add);
-            $modal.modal();
-            break;
-          case "SET_VLAN_PCP" :
-            var h3 = "Set VLAN Priority";
-            var placeholder = "VLAN Priority";
-            var id = one.f.flows.id.modal.action.setVlanPriority;
-            var help = "Range: 0 - 7";
-            var action = 'SET_VLAN_PCP';
-            var name = "VLAN Priority";
-            var body = function() {
-              return one.f.flows.modal.action.body.set(h3, placeholder, id, help);
-            };
-            var add = function($modal) {
-              one.f.flows.modal.action.add.set(name, id, action, $modal);
-            };
-            var $modal = one.f.flows.modal.action.initialize(h3, body, add);
-            $modal.modal();
-            break;
-          case "SET_VLAN_CFI" :
-            var h3 = "Set VLAN CFI";
-            var placeholder = "VLAN CFI";
-            var id = one.f.flows.id.modal.action.setVlanCfi;
-            var help = "Range: 0 - 1";
-            var action = 'SET_VLAN_CFI';
-            var name = "VLAN CFI";
-            var body = function() {
-              return one.f.flows.modal.action.body.set(h3, placeholder, id, help);
-            };
-            var add = function($modal) {
-              one.f.flows.modal.action.add.set(name, id, action, $modal);
-            };
-            var $modal = one.f.flows.modal.action.initialize(h3, body, add);
-            $modal.modal();
-            break;
-          case "POP_VLAN" :
-            var name = "Strip VLAN Header";
-            var action = 'POP_VLAN';
-            one.f.flows.modal.action.add.add(name, action);
-            break;
-          case "PUSH_VLAN" :
-            var h3 = "Push VLAN";
-            var placeholder = "VLAN";
-            var id = one.f.flows.id.modal.action.pushVlan;
-            var help = "Range: 0 - 4095";
-            var action = 'PUSH_VLAN';
-            var name = "VLAN";
-            var body = function() {
-              return one.f.flows.modal.action.body.set(h3, placeholder, id, help);
-            };
-            var add = function($modal) {
-              one.f.flows.modal.action.add.set(name, id, action, $modal);
-            };
-            var $modal = one.f.flows.modal.action.initialize(h3, body, add);
-            $modal.modal();
-            break;
-          case "SET_DL_SRC" :
-            var h3 = "Set Source MAC Address";
-            var placeholder = "Source MAC Address";
-            var id = one.f.flows.id.modal.action.modifyDatalayerSourceAddress;
-            var help = "Example: 00:11:22:aa:bb:cc";
-            var action = 'SET_DL_SRC';
-            var name = "Source MAC";
-            var body = function() {
-              return one.f.flows.modal.action.body.set(h3, placeholder, id, help);
-            };
-            var add = function($modal) {
-              one.f.flows.modal.action.add.set(name, id, action, $modal);
-            };
-            var $modal = one.f.flows.modal.action.initialize(h3, body, add);
-            $modal.modal();
-            break;
-          case "SET_DL_DST" :
-            var h3 = "Set Destination MAC Address";
-            var placeholder = "Destination MAC Address";
-            var id = one.f.flows.id.modal.action.modifyDatalayerDestinationAddress;
-            var help = "Example: 00:11:22:aa:bb:cc";
-            var action = 'SET_DL_DST';
-            var name = "Destination MAC";
-            var body = function() {
-              return one.f.flows.modal.action.body.set(h3, placeholder, id, help);
-            };
-            var add = function($modal) {
-              one.f.flows.modal.action.add.set(name, id, action, $modal);
-            };
-            var $modal = one.f.flows.modal.action.initialize(h3, body, add);
-            $modal.modal();
-            break;
-          case "SET_DL_TYPE" :
-            var h3 = "Set Ethertype";
-            var placeholder = "Ethertype";
-            var id = one.f.flows.id.modal.action.setEthertype;
-            var help = "Range: 0 - 65535";
-            var action = 'SET_DL_TYPE';
-            var name = "Ethertype";
-            var body = function() {
-              return one.f.flows.modal.action.body.set(h3, placeholder, id, help);
-            };
-            var add = function($modal) {
-              one.f.flows.modal.action.add.set(name, id, action, $modal);
-            };
-            var $modal = one.f.flows.modal.action.initialize(h3, body, add);
-            $modal.modal();
-            break;
-          case "SET_NW_SRC" :
-            var h3 = "Set IP Source Address";
-            var placeholder = "Source IP Address";
-            var id = one.f.flows.id.modal.action.modifyNetworkSourceAddress;
-            var help = "Example: 127.0.0.1";
-            var action = 'SET_NW_SRC';
-            var name = "Source IP";
-            var body = function() {
-              return one.f.flows.modal.action.body.set(h3, placeholder, id, help);
-            };
-            var add = function($modal) {
-              one.f.flows.modal.action.add.set(name, id, action, $modal);
-            };
-            var $modal = one.f.flows.modal.action.initialize(h3, body, add);
-            $modal.modal();
-            break;
-          case "SET_NW_DST" :
-            var h3 = "Set IP Destination Address";
-            var placeholder = "Destination IP Address";
-            var id = one.f.flows.id.modal.action.modifyNetworkDestinationAddress;
-            var help = "Example: 127.0.0.1";
-            var action = 'SET_NW_DST';
-            var name = "Destination IP";
-            var body = function() {
-              return one.f.flows.modal.action.body.set(h3, placeholder, id, help);
-            };
-            var add = function($modal) {
-              one.f.flows.modal.action.add.set(name, id, action, $modal);
-            };
-            var $modal = one.f.flows.modal.action.initialize(h3, body, add);
-            $modal.modal();
-            break;
-          case "SET_NW_TOS" :
-            var h3 = "Set IPv4 ToS";
-            var placeholder = "IPv4 ToS";
-            var id = one.f.flows.id.modal.action.modifyTosBits;
-            var help = "Range: 0 - 63";
-            var action = 'SET_NW_TOS';
-            var name = "ToS Bits";
-            var body = function() {
-              return one.f.flows.modal.action.body.set(h3, placeholder, id, help);
-            };
-            var add = function($modal) {
-              one.f.flows.modal.action.add.set(name, id, action, $modal);
-            };
-            var $modal = one.f.flows.modal.action.initialize(h3, body, add);
-            $modal.modal();
-            break;
-          case "SET_TP_SRC" :
-            var h3 = "Set Transport Source Port";
-            var placeholder = "Transport Source Port";
-            var id = one.f.flows.id.modal.action.modifyTransportSourcePort;
-            var help = "Range: 0 - 65535";
-            var action = 'SET_TP_SRC';
-            var name = "Source Port";
-            var body = function() {
-              return one.f.flows.modal.action.body.set(h3, placeholder, id, help);
-            };
-            var add = function($modal) {
-              one.f.flows.modal.action.add.set(name, id, action, $modal);
-            };
-            var $modal = one.f.flows.modal.action.initialize(h3, body, add);
-            $modal.modal();
-            break;
-          case "SET_TP_DST" :
-            var h3 = "Set Transport Destination Port";
-            var placeholder = "Transport Destination Port";
-            var id = one.f.flows.id.modal.action.modifyTransportDestinationPort;
-            var help = "Range: 0 - 65535";
-            var action = 'SET_TP_DST';
-            var name = "Destination Port";
-            var body = function() {
-              return one.f.flows.modal.action.body.set(h3, placeholder, id, help);
-            };
-            var add = function($modal) {
-              one.f.flows.modal.action.add.set(name, id, action, $modal);
-            };
-            var $modal = one.f.flows.modal.action.initialize(h3, body, add);
-            $modal.modal();
-            break;
-          case "ENQUEUE" :
-            var h3 = "Enqueue";
-            var placeholder = "Enqueue";
-            var id = one.f.flows.id.modal.action.enqueue;
-            var $modal = one.f.flows.modal.action.initialize(h3, one.f.flows.modal.action.body.addEnqueue, one.f.flows.modal.action.add.addEnqueue);
-            $modal.modal();
-            break;
-          case "DROP" :
-            var name = "Drop";
-            var action = 'DROP';
-            one.f.flows.modal.action.add.add(name, action);
-            break;
-          case "LOOPBACK" :
-            var name = "Loopback";
-            var action = 'LOOPBACK';
-            one.f.flows.modal.action.add.add(name, action);
-            break;
-          case "FLOOD" :
-            var name = "Flood";
-            var action = 'FLOOD';
-            one.f.flows.modal.action.add.add(name, action);
-            break;
-          case "FLOOD_ALL" :
-            var name = "Flood All";
-            var action = 'FLOOD_ALL';
-            one.f.flows.modal.action.add.add(name, action);
-            break;
-          case "SW_PATH" :
-            var name = "Software Path";
-            var action = 'SW_PATH';
-            one.f.flows.modal.action.add.add(name, action);
-            break;
-          case "HW_PATH" :
-            var name = "Hardware Path";
-            var action = 'HW_PATH';
-            one.f.flows.modal.action.add.add(name, action);
-            break;
-          case "CONTROLLER" :
-            var name = "Controller";
-            var action = 'CONTROLLER';
-            one.f.flows.modal.action.add.add(name, action);
-            break;
-        }
-      },
-      initialize : function(h3, bodyCallback, addCallback) {
-        var footer = one.f.flows.modal.action.footer();
-        var $body = bodyCallback();
-        var $modal = one.lib.modal.spawn(one.f.flows.id.modal.action.modal, h3, $body, footer);
-        // bind close button
-        $('#'+one.f.flows.id.modal.action.close, $modal).click(function() {
-          $modal.modal('hide');
-        });
-        // bind add flow button
-        $('#'+one.f.flows.id.modal.action.add, $modal).click(function() {
-          addCallback($modal);
-        });
-        return $modal;
-      },
-      add : {
-        addOutputPorts : function($modal) {
-          var $options = $('#'+one.f.flows.id.modal.action.addOutputPorts).find('option:selected');
-          var ports = '';
-          var pid = '';
-          $options.each(function(index, value) {
-            ports = ports+$(value).text()+", ";
-            pid = pid+$(value).attr('value')+",";
-          });
-          ports = ports.slice(0,-2);
-          pid = pid.slice(0,-1);
-          one.f.flows.modal.action.add.addPortsToTable(ports, pid);
-          $modal.modal('hide');
-        },
-        addEnqueue : function($modal) {
-          var $options = $('#'+one.f.flows.id.modal.action.addOutputPorts).find('option:selected');
-          var ports = '';
-          var pid = '';
-          $options.each(function(index, value) {
-            ports = ports+$(value).text()+", ";
-            pid = pid+$(value).attr('value')+",";
-          });
-          var $input = $('#'+one.f.flows.id.modal.action.queue);
-          var queue = $input.val();
-          ports = ports.slice(0,-2);
-          pid = pid.slice(0,-1);
-          one.f.flows.modal.action.add.addEnqueueToTable(ports, pid, queue);
-          $modal.modal('hide');
-        },
-        addEnqueueToTable : function(ports, pid, queue) {
-          if (queue !== '' && queue >= 0) {
-            ports += ':'+queue;
-          }
-          var $tr = one.f.flows.modal.action.table.add("Enqueue", ports);
-          $tr.attr('id', 'ENQUEUE');
-          if (queue !== '' && queue >= 0) {
-            $tr.data('action', 'ENQUEUE='+pid+':'+queue);
-          } else {
-            $tr.data('action', 'ENQUEUE='+pid+':0'); // default queue to 0
-          }
-          $tr.click(function() {
-            one.f.flows.modal.action.add.modal.initialize(this);
-          });
-          one.f.flows.modal.action.table.append($tr);
-        },
-        addPortsToTable : function(ports, pid){
-          var $tr = one.f.flows.modal.action.table.add("Add Output Ports", ports);
-          $tr.attr('id', 'OUTPUT');
-          $tr.data('action', 'OUTPUT='+pid);
-          $tr.click(function() {
-            one.f.flows.modal.action.add.modal.initialize(this);
-          });
-          one.f.flows.modal.action.table.append($tr);
-        },
-        add : function(name, action) {
-          var $tr = one.f.flows.modal.action.table.add(name);
-          $tr.attr('id', action);
-          $tr.data('action', action);
-          $tr.click(function() {
-            one.f.flows.modal.action.add.modal.initialize(this);
-          });
-          one.f.flows.modal.action.table.append($tr);
-        },
-        set : function(name, id, action, $modal) {
-          var $input = $('#'+id);
-          var value = $input.val();
-          one.f.flows.modal.action.add.addDataToTable(name,value,action)
-            $modal.modal('hide');
-        },
-        addDataToTable : function(name,value,action) {
-          var $tr = one.f.flows.modal.action.table.add(name, value);
-          $tr.attr('id', action);
-          $tr.data('action', action+'='+value);
-          $tr.click(function() {
-            one.f.flows.modal.action.add.modal.initialize(this);
-          });
-          one.f.flows.modal.action.table.append($tr);
-        },
-        remove : function(that) {
-          $(that).remove();
-          var $table = $('#'+one.f.flows.id.modal.action.table);
-          if ($table.find('tbody').find('tr').size() == 0) {
-            var $tr = $(document.createElement('tr'));
-            var $td = $(document.createElement('td'));
-            $td.attr('colspan', '3');
-            $tr.addClass('empty');
-            $td.text('No data available');
-            $tr.append($td);
-            $table.find('tbody').append($tr);
-          }
-        },
-        modal : {
-          initialize : function(that) {
-            var h3 = "Remove Action";
-            var footer = one.f.flows.modal.action.add.modal.footer();
-            var $body = one.f.flows.modal.action.add.modal.body();
-            var $modal = one.lib.modal.spawn(one.f.flows.id.modal.action.modal.modal, h3, $body, footer);
-
-            // bind cancel button
-            $('#'+one.f.flows.id.modal.action.modal.cancel, $modal).click(function() {
-              $modal.modal('hide');
-            });
-
-            // bind remove button
-            $('#'+one.f.flows.id.modal.action.modal.remove, $modal).click(function() {
-              one.f.flows.modal.action.add.remove(that);
-              $modal.modal('hide');
-            });
-
-            $modal.modal();
-          },
-          body : function() {
-            var $p = $(document.createElement('p'));
-            $p.append("Remove this action?");
-            return $p;
-          },
-          footer : function() {
-            var footer = [];
-
-            var removeButton = one.lib.dashlet.button.single("Remove Action", one.f.flows.id.modal.action.modal.remove, "btn-danger", "");
-            var $removeButton = one.lib.dashlet.button.button(removeButton);
-            footer.push($removeButton);
-
-            var cancelButton = one.lib.dashlet.button.single("Cancel", one.f.flows.id.modal.action.modal.cancel, "", "");
-            var $cancelButton = one.lib.dashlet.button.button(cancelButton);
-            footer.push($cancelButton);
-
-            return footer;
-          }
-        }
-      },
-      table : {
-        add : function(action, data) {
-          var $tr = $(document.createElement('tr'));
-          var $td = $(document.createElement('td'));
-          $td.append(action);
-          $tr.append($td);
-          var $td = $(document.createElement('td'));
-          if (data != undefined) $td.append(data);
-          $tr.append($td);
-          return $tr;
-        },
-        append : function($tr) {
-          var $table = $('#'+one.f.flows.id.modal.action.table);
-          var $empty = $table.find('.empty').parent();
-          if ($empty.size() > 0) $empty.remove();
-          $table.append($tr);
-        }
-      },
-      body : {
-        common : function() {
-          var $form = $(document.createElement('form'));
-          var $fieldset = $(document.createElement('fieldset'));
-          return [$form, $fieldset];
-        },
-        addOutputPorts : function() {
-          var common = one.f.flows.modal.action.body.common();
-          var $form = common[0];
-          var $fieldset = common[1];
-          // output port
-          $label = one.lib.form.label("Select Output Ports");
-          if (one.f.flows.registry.currentNode == undefined){
-            return; //Selecting Output ports without selecting node throws an exception
-          }
-          var ports = one.f.flows.registry.nodeports[one.f.flows.registry.currentNode]['ports'];
-          $select = one.lib.form.select.create(ports, true);
-          $select.attr('id', one.f.flows.id.modal.action.addOutputPorts);
-          $fieldset.append($label).append($select);
-          $form.append($fieldset);
-          return $form;
-        },
-        addEnqueue : function() {
-          var common = one.f.flows.modal.action.body.common();
-          var $form = common[0];
-          var $fieldset = common[1];
-          // output port
-          $label = one.lib.form.label("Select Output Ports");
-          if (one.f.flows.registry.currentNode == undefined){
-            return; //Selecting Output ports without selecting node throws an exception
-          }
-          var ports = one.f.flows.registry.nodeports[one.f.flows.registry.currentNode]['ports'];
-          $select = one.lib.form.select.create(ports);
-          $select.attr('id', one.f.flows.id.modal.action.addOutputPorts);
-          $fieldset.append($label).append($select);
-          $label = one.lib.form.label('Queue (Optional)');
-          $input = one.lib.form.input('Queue')
-          .attr('id', one.f.flows.id.modal.action.queue);
-          $help = one.lib.form.help('Range: 1 - 2147483647');
-          $fieldset.append($label).append($input).append($help);
-          $form.append($fieldset);
-          return $form;
-        },
-        set : function(label, placeholder, id, help) {
-          var common = one.f.flows.modal.action.body.common();
-          var $form = common[0];
-          var $fieldset = common[1];
-          // input
-          $label = one.lib.form.label(label);
-          $input = one.lib.form.input(placeholder);
-          $input.attr('id', id);
-          $help = one.lib.form.help(help);
-          // append
-          $fieldset.append($label).append($input).append($help);
-          $form.append($fieldset);
-          return $form;
-        }
-      },
-      footer : function() {
-        var footer = [];
-        var addButton = one.lib.dashlet.button.single("Add Action", one.f.flows.id.modal.action.add, "btn-primary", "");
-        var $addButton = one.lib.dashlet.button.button(addButton);
-        footer.push($addButton);
-
-        var closeButton = one.lib.dashlet.button.single("Close", one.f.flows.id.modal.action.close, "", "");
-        var $closeButton = one.lib.dashlet.button.button(closeButton);
-        footer.push($closeButton);
-
-        return footer;
-      }
-    },
-    footer : function() {
-      var footer = [];
-
-      var installButton = one.lib.dashlet.button.single("Install Flow", one.f.flows.id.modal.install, "btn-success", "");
-      var $installButton = one.lib.dashlet.button.button(installButton);
-      footer.push($installButton);
-
-      var addButton = one.lib.dashlet.button.single("Save Flow", one.f.flows.id.modal.add, "btn-primary", "");
-      var $addButton = one.lib.dashlet.button.button(addButton);
-      footer.push($addButton);
-
-      var closeButton = one.lib.dashlet.button.single("Close", one.f.flows.id.modal.close, "", "");
-      var $closeButton = one.lib.dashlet.button.button(closeButton);
-      footer.push($closeButton);
-
-      return footer;
-    },
-    footerEdit : function() {
-      var footer = [];
-
-      var editButton = one.lib.dashlet.button.single("Save Flow", one.f.flows.id.modal.edit, "btn-success", "");
-      var $editButton = one.lib.dashlet.button.button(editButton);
-      footer.push($editButton);
-
-      var closeButton = one.lib.dashlet.button.single("Close", one.f.flows.id.modal.close, "", "");
-      var $closeButton = one.lib.dashlet.button.button(closeButton);
-      footer.push($closeButton);
-
-      return footer;
-    },
-    removeMultiple: {
-      dialog: function(flows) {
-        var h3 = 'Remove Flow Entry';
-        var flowList = [];
-        for (var i = 0; i < flows.length; i++) {
-          flowList.push(flows[i]["name"]);
-        }
-        var footer = one.f.flows.modal.removeMultiple.footer();
-        var $body = one.f.flows.modal.removeMultiple.body(flowList);
-        var $modal = one.lib.modal.spawn(one.f.flows.id.modal.dialog.modal, h3, $body, footer);
-
-        // bind close button
-        $('#'+one.f.flows.id.modal.dialog.close, $modal).click(function() {
-          $modal.modal('hide');
-        });
-
-        // bind remove rule button
-        $('#'+one.f.flows.id.modal.dialog.remove, $modal).click(this, function(e) {
-          var resource = {};
-          resource['body'] = JSON.stringify(flows);
-
-          $.post(one.f.address.root+one.f.address.flows.deleteFlows, resource, function(response) {
-            $modal.modal('hide');
-            if(response == "Success") {
-              one.lib.alert("Flow Entry(s) successfully removed");
-            } else {
-              one.lib.alert(response);
-            }
-            one.main.dashlet.right.bottom.empty();
-            one.f.detail.dashlet(one.main.dashlet.right.bottom);
-            one.main.dashlet.left.top.empty();
-            one.f.flows.dashlet(one.main.dashlet.left.top);
-          });
-        });
-        $modal.modal();
-      },
-      footer : function() {
-        var footer = [];
-        var remove = one.lib.dashlet.button.single('Remove Flow Entry',one.f.flows.id.modal.dialog.remove, 'btn-danger', '');
-        var $remove = one.lib.dashlet.button.button(remove);
-        footer.push($remove);
-
-        var cancel = one.lib.dashlet.button.single('Cancel', one.f.flows.id.modal.dialog.close, '', '');
-        var $cancel = one.lib.dashlet.button.button(cancel);
-        footer.push($cancel);
-
-        return footer;
-      },
-      body : function (flows) {
-        var $p = $(document.createElement('p'));
-        var p = 'Remove the following Flow Entry(s)?';
-        //creata a BS label for each rule and append to list
-        $(flows).each(function(){
-          var $span = $(document.createElement('span'));
-          $span.append(this);
-          p += '<br/>' + $span[0].outerHTML;
-        });
-        $p.append(p);
-        return $p;
-      }
-    }
-  },
-  ajax : {
-    dashlet : function(callback) {
-      $.getJSON(one.f.address.root+one.f.address.flows.main, function(data) {
-        one.f.flows.registry['flows'] = data.flows;
-        one.f.flows.registry['privilege'] = data.privilege;
-        one.f.flows.modal.ajax.nodes(function(){/*Empty function. Do nothing. */})
-
-        callback(data);
-      });
-    }
-  },
-  data : {
-    flowsDataGrid: function(data) {
-      var source = new StaticDataSource({
-        columns: [
-      {
-        property: 'selector',
-      label: "<input type='checkbox' id='"+one.f.flows.id.dashlet.datagrid.selectAllFlows+"'/>",
-      sortable: false
-      },
-      {
-        property: 'name',
-      label: 'Flow Name',
-      sortable: true
-      },
-      {
-        property: 'node',
-      label: 'Node',
-      sortable: true
-      }
-      ],
-      data: data.flows,
-      formatter: function(items) {
-        $.each(items, function(index, item) {
-          var $checkbox = document.createElement("input");
-          $checkbox.setAttribute("type", "checkbox");
-          $checkbox.setAttribute("name", item.name);
-          $checkbox.setAttribute("node", item.nodeId);
-          $checkbox.setAttribute('class','flowEntry')
-          item.selector = $checkbox.outerHTML;
-        item["name"] = '<span data-installInHw=' + item["flow"]["installInHw"] + 
-          ' data-flowstatus=' + item["flow"]["status"] + 
-          ' data-nodeId=' + item["nodeId"] + '>' + item["name"] + '</span>';
-        });
-
-      },
-      delay: 0
-      });
-      return source;
-    },
-    dashlet : function(data) {
-      var body = [];
-      $(data).each(function(index, value) {
-        var tr = {};
-        var entry = [];
-
-
-        entry.push(value['name']);
-        entry.push(value['node']);
-        if (value['flow']['installInHw'] == 'true' && value['flow']['status'] == 'Success')
-        tr['type'] = ['success'];
-        else if (value['flow']['installInHw'] == 'false' && value['flow']['status'] == 'Success')
-        tr['type'] = ['warning'];
-        else 
-        tr['type'] = ['warning'];
-      tr['entry'] = entry;
-      tr['id'] = value['nodeId'];
-
-      body.push(tr);
-      });
-      return body;
-    }
-  },
-  body : {
-    dashlet : function(body, callback) {
-      var attributes = ['table-striped', 'table-bordered', 'table-hover', 'table-condensed', 'table-cursor'];
-      var $table = one.lib.dashlet.table.table(attributes);
-
-      var headers = ['Flow Name', 'Node'];
-
-      var $thead = one.lib.dashlet.table.header(headers);
-      $table.append($thead);
-
-      var $tbody = one.lib.dashlet.table.body(body);
-      $table.append($tbody);
-      return $table;
-    }
-  }
-}
-
-/** INIT **/
-// populate nav tabs
-$(one.f.menu.left.top).each(function(index, value) {
-  var $nav = $(".nav", "#left-top");
-  one.main.page.dashlet($nav, value);
-});
-
-$(one.f.menu.left.bottom).each(function(index, value) {
-  var $nav = $(".nav", "#left-bottom");
-  one.main.page.dashlet($nav, value);
-});
-
-$(one.f.menu.right.bottom).each(function(index, value) {
-  var $nav = $(".nav", "#right-bottom");
-  one.main.page.dashlet($nav, value);
-});
-
-one.f.populate = function($dashlet, header) {
-  var $h4 = one.lib.dashlet.header(header);
-  $dashlet.append($h4);
-};
-
-// bind dashlet nav
-$('.dash .nav a', '#main').click(function() {
-  // de/activation
-  var $li = $(this).parent();
-  var $ul = $li.parent();
-  one.lib.nav.unfocus($ul);
-  $li.addClass('active');
-  // clear respective dashlet
-  var $dashlet = $ul.parent().find('.dashlet');
-  one.lib.dashlet.empty($dashlet);
-  // callback based on menu
-  var id = $(this).attr('id');
-  var menu = one.f.dashlet;
-  switch (id) {
-    case menu.flows.id:
-      one.f.flows.dashlet($dashlet);
-      break;
-    case menu.nodes.id:
-      one.f.nodes.dashlet($dashlet);
-      break;
-    case menu.detail.id:
-      one.f.detail.dashlet($dashlet);
-      break;
-  };
-});
-
-// activate first tab on each dashlet
-$('.dash .nav').each(function(index, value) {
-  $($(value).find('li')[0]).find('a').click();
-});
diff --git a/opendaylight/adsal/web/osgi-brandfragment/pom.xml b/opendaylight/adsal/web/osgi-brandfragment/pom.xml
deleted file mode 100644 (file)
index 31e1bf8..0000000
+++ /dev/null
@@ -1,32 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>osgi-brandfragment.web</artifactId>
-  <version>0.2.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <description>OSGi management web application brand fragment</description>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Fragment-Host>org.apache.felix.webconsole</Fragment-Host>
-          </instructions>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-
-</project>
diff --git a/opendaylight/adsal/web/osgi-brandfragment/src/main/resources/META-INF/webconsole.properties b/opendaylight/adsal/web/osgi-brandfragment/src/main/resources/META-INF/webconsole.properties
deleted file mode 100644 (file)
index 2cc8e91..0000000
+++ /dev/null
@@ -1,11 +0,0 @@
-webconsole.brand.name = OpenDaylight
-webconsole.product.name = OpenDaylight Controller
-webconsole.product.url = http://www.opendaylight.org/
-webconsole.product.image = /res/imgs/odl/logo.png
-webconsole.favicon = /res/imgs/odl/favicon.ico
-#To disable web console authentication clear default username
-webconsole.username =
-# webconsole.vendor.name = Linux Foundation
-# webconsole.vendor.url = http://www.linuxfoundation.org/
-# webconsole.vendor.image = /res/imgs/vendor.png
-# webconsole.stylesheet = /res/css/my.css
diff --git a/opendaylight/adsal/web/osgi-brandfragment/src/main/resources/res/imgs/odl/favicon.ico b/opendaylight/adsal/web/osgi-brandfragment/src/main/resources/res/imgs/odl/favicon.ico
deleted file mode 100644 (file)
index 59f0ec6..0000000
Binary files a/opendaylight/adsal/web/osgi-brandfragment/src/main/resources/res/imgs/odl/favicon.ico and /dev/null differ
diff --git a/opendaylight/adsal/web/osgi-brandfragment/src/main/resources/res/imgs/odl/logo.png b/opendaylight/adsal/web/osgi-brandfragment/src/main/resources/res/imgs/odl/logo.png
deleted file mode 100644 (file)
index 103520b..0000000
Binary files a/opendaylight/adsal/web/osgi-brandfragment/src/main/resources/res/imgs/odl/logo.png and /dev/null differ
diff --git a/opendaylight/adsal/web/root/pom.xml b/opendaylight/adsal/web/root/pom.xml
deleted file mode 100644 (file)
index 992f9b3..0000000
+++ /dev/null
@@ -1,142 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>web</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>com.google.code.gson</groupId>
-      <artifactId>gson</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>equinoxSDK381</groupId>
-      <artifactId>javax.servlet</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>commons-io</groupId>
-      <artifactId>commons-io</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>clustering.services</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>configuration</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>connectionmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>containermanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>switchmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>usermanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.springframework</groupId>
-      <artifactId>org.springframework.web</artifactId>
-    </dependency>
-  </dependencies>
-
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Import-Package>org.opendaylight.controller.configuration,
-              org.opendaylight.controller.sal.authorization,
-              org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.sal.utils,
-              org.opendaylight.controller.usermanager,
-              org.opendaylight.controller.containermanager,
-              org.opendaylight.controller.clustering.services,
-              org.opendaylight.controller.connectionmanager,
-              org.opendaylight.controller.switchmanager,
-              com.google.gson,
-              javax.annotation,
-              javax.naming,
-              javax.servlet,
-              javax.servlet.annotation,
-              javax.servlet.http,
-              javax.servlet.jsp,
-              javax.servlet.jsp.el,
-              javax.servlet.jsp.jstl.core,
-              javax.servlet.jsp.jstl.fmt,
-              javax.servlet.jsp.jstl.tlv,
-              javax.servlet.jsp.tagext,
-              javax.servlet.resources,
-              javax.xml.parsers,
-              javax.xml.transform,
-              org.apache.commons.io,
-              org.apache.commons.logging,
-              org.apache.taglibs.standard.functions,
-              org.apache.taglibs.standard.resources,
-              org.apache.taglibs.standard.tag.common.core,
-              org.apache.taglibs.standard.tag.common.fmt,
-              org.apache.taglibs.standard.tag.rt.core,
-              org.apache.taglibs.standard.tag.rt.fmt,
-              org.apache.taglibs.standard.tei,
-              org.apache.taglibs.standard.tlv,
-              com.fasterxml.jackson.core,
-              com.fasterxml.jackson.databind,
-              com.fasterxml.jackson.annotation,
-              org.osgi.framework,
-              org.slf4j,
-              org.springframework.beans,
-              org.springframework.beans.factory.xml,
-              org.springframework.context.config,
-              org.springframework.core,
-              org.springframework.stereotype,
-              org.springframework.ui,
-              org.springframework.web,
-              org.springframework.web.bind.annotation,
-              org.springframework.web.servlet,
-              org.springframework.web.servlet.config,
-              org.springframework.web.servlet.view,
-              org.springframework.web.servlet.view.json,
-              org.springframework.web.filter,
-              org.springframework.web.context,
-              org.springframework.util,
-              org.apache.catalina.filters</Import-Package>
-            <Export-Package>org.opendaylight.controller.web</Export-Package>
-            <Web-ContextPath>/</Web-ContextPath>
-          </instructions>
-          <manifestLocation>${project.basedir}/src/main/resources/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/web/root/src/main/java/org/opendaylight/controller/web/ClusterNodeBean.java b/opendaylight/adsal/web/root/src/main/java/org/opendaylight/controller/web/ClusterNodeBean.java
deleted file mode 100644 (file)
index 974fdee..0000000
+++ /dev/null
@@ -1,65 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.web;
-
-import java.net.InetAddress;
-
-/**
- * Information about a clustered controller to send to the UI frontend
- * @author andrekim
- */
-public class ClusterNodeBean {
-    private final byte[] address;
-    private final String name;
-    private final Boolean me;
-    private final Boolean coordinator;
-    private final Integer numConnectedNodes;
-
-    public static class Builder {
-        // required params
-        private final byte[] address;
-        private final String name;
-
-        // optional params
-        private Boolean me = null;
-        private Boolean coordinator = null;
-        private Integer numConnectedNodes = null;
-
-        public Builder(InetAddress address) {
-            this.address = address.getAddress();
-            this.name = address.getHostAddress();
-        }
-
-        public Builder highlightMe() {
-            this.me = true;
-            return this;
-        }
-
-        public Builder iAmCoordinator() {
-            this.coordinator = true;
-            return this;
-        }
-
-        public Builder nodesConnected(int numNodes) {
-            this.numConnectedNodes = numNodes;
-            return this;
-        }
-
-        public ClusterNodeBean build() {
-            return new ClusterNodeBean(this);
-        }
-    }
-
-    private ClusterNodeBean(Builder builder) {
-        this.address = builder.address;
-        this.name = builder.name;
-        this.me = builder.me;
-        this.coordinator = builder.coordinator;
-        this.numConnectedNodes = builder.numConnectedNodes;
-    }
-}
diff --git a/opendaylight/adsal/web/root/src/main/java/org/opendaylight/controller/web/ControllerUISessionManager.java b/opendaylight/adsal/web/root/src/main/java/org/opendaylight/controller/web/ControllerUISessionManager.java
deleted file mode 100644 (file)
index 72b9d6b..0000000
+++ /dev/null
@@ -1,43 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.web;
-
-import javax.servlet.http.HttpSessionEvent;
-import javax.servlet.http.HttpSessionListener;
-
-import org.opendaylight.controller.sal.utils.ServiceHelper;
-import org.opendaylight.controller.usermanager.IUserManager;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-public class ControllerUISessionManager implements HttpSessionListener {
-
-    private static final Logger logger = LoggerFactory.getLogger(ControllerUISessionManager.class);
-
-    @Override
-    public void sessionCreated(HttpSessionEvent se) {
-        IUserManager userManager = (IUserManager) ServiceHelper.getGlobalInstance(IUserManager.class, this);
-        if (userManager != null) {
-            ((HttpSessionListener) userManager.getSessionManager()).sessionCreated(se);
-        } else {
-            logger.warn("User Manager is currently unavailable. Unable to register UI session.");
-        }
-    }
-
-    @Override
-    public void sessionDestroyed(HttpSessionEvent se) {
-        IUserManager userManager = (IUserManager) ServiceHelper.getGlobalInstance(IUserManager.class, this);
-        if (userManager != null) {
-            ((HttpSessionListener) userManager.getSessionManager()).sessionDestroyed(se);
-        } else {
-            logger.warn("User Manager is currently unavailable. Unable to destroy UI session.");
-        }
-    }
-
-}
diff --git a/opendaylight/adsal/web/root/src/main/java/org/opendaylight/controller/web/DaylightWeb.java b/opendaylight/adsal/web/root/src/main/java/org/opendaylight/controller/web/DaylightWeb.java
deleted file mode 100644 (file)
index 090efec..0000000
+++ /dev/null
@@ -1,209 +0,0 @@
-/*
- * Copyright (c) 2013, 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.web;
-
-import java.io.FileInputStream;
-import java.io.IOException;
-import java.util.HashMap;
-import java.util.Map;
-import java.util.Properties;
-import java.util.Set;
-
-import javax.servlet.http.HttpServletRequest;
-import javax.servlet.http.HttpServletResponse;
-import javax.servlet.http.HttpSession;
-
-import org.apache.commons.io.IOUtils;
-import org.opendaylight.controller.configuration.IConfigurationContainerService;
-import org.opendaylight.controller.configuration.IConfigurationService;
-import org.opendaylight.controller.containermanager.IContainerAuthorization;
-import org.opendaylight.controller.sal.authorization.Privilege;
-import org.opendaylight.controller.sal.authorization.Resource;
-import org.opendaylight.controller.sal.authorization.UserLevel;
-import org.opendaylight.controller.sal.utils.ServiceHelper;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.sal.utils.StatusCode;
-import org.opendaylight.controller.usermanager.IUserManager;
-import org.springframework.stereotype.Controller;
-import org.springframework.ui.Model;
-import org.springframework.web.bind.annotation.PathVariable;
-import org.springframework.web.bind.annotation.RequestMapping;
-import org.springframework.web.bind.annotation.RequestMethod;
-import org.springframework.web.bind.annotation.ResponseBody;
-
-@Controller
-@RequestMapping("/")
-public class DaylightWeb {
-    @RequestMapping(value = "")
-    public String index(Model model, HttpServletRequest request) {
-        IUserManager userManager = (IUserManager) ServiceHelper
-                .getGlobalInstance(IUserManager.class, this);
-        if (userManager == null) {
-            return "User Manager is not available";
-        }
-
-        String username = request.getUserPrincipal().getName();
-
-        model.addAttribute("username", username);
-        model.addAttribute("role", userManager.getUserLevel(username)
-                .toNumber());
-
-        return "main";
-    }
-
-    /**
-     * Read the version.properties file for the property
-     *
-     * @param request
-     * @return String value configured in the version.properties file
-     */
-    @RequestMapping(value="/versionProperty/{property}", method = RequestMethod.GET)
-    @ResponseBody
-    public String getVersion(HttpServletRequest request, @PathVariable("property") String property) {
-        Properties prop = new Properties();
-        FileInputStream propertiesFile = null;
-        try {
-            propertiesFile = new FileInputStream("version.properties");
-            prop.load(propertiesFile);
-            return prop.getProperty(property+".version");
-        } catch (IOException e) {
-            // TODO: We should be logging the exception here
-            //       "Failed to open version.properties."
-            return null;
-        } finally {
-            IOUtils.closeQuietly(propertiesFile);
-        }
-    }
-    @RequestMapping(value = "web.json")
-    @ResponseBody
-    public Map<String, Map<String, Object>> bundles(HttpServletRequest request) {
-        Object[] instances = ServiceHelper.getGlobalInstances(
-                IDaylightWeb.class, this, null);
-        Map<String, Map<String, Object>> bundles = new HashMap<String, Map<String, Object>>();
-        Map<String, Object> entry;
-        IDaylightWeb bundle;
-        String username = request.getUserPrincipal().getName();
-        IUserManager userManger = (IUserManager) ServiceHelper
-                .getGlobalInstance(IUserManager.class, this);
-        for (Object instance : instances) {
-            bundle = (IDaylightWeb) instance;
-            if (userManger != null
-                    && bundle.isAuthorized(userManger.getUserLevel(username))) {
-                entry = new HashMap<String, Object>();
-                entry.put("name", bundle.getWebName());
-                entry.put("order", bundle.getWebOrder());
-                bundles.put(bundle.getWebId(), entry);
-            }
-        }
-        return bundles;
-    }
-
-    @RequestMapping(value = "save", method = RequestMethod.POST)
-    @ResponseBody
-    public String save(HttpServletRequest request) {
-        String username = request.getUserPrincipal().getName();
-        IUserManager userManager = (IUserManager) ServiceHelper.getGlobalInstance(IUserManager.class, this);
-        if (userManager == null) {
-            return "User Manager is not available";
-        }
-        UserLevel level = userManager.getUserLevel(username);
-        Status status;
-        switch (level) {
-        case SYSTEMADMIN:
-        case NETWORKADMIN:
-            IConfigurationService configService = (IConfigurationService) ServiceHelper.getGlobalInstance(
-                    IConfigurationService.class, this);
-            if (configService != null) {
-                status = configService.saveConfigurations();
-            } else {
-                status = new Status(StatusCode.NOSERVICE, "Configuration Service is not available");
-            }
-            break;
-        case NETWORKOPERATOR:
-        case CONTAINERUSER:
-            IContainerAuthorization containerAuth = (IContainerAuthorization) ServiceHelper.getGlobalInstance(
-                    IContainerAuthorization.class, this);
-            if (containerAuth != null) {
-                boolean oneSaved = false;
-                Set<Resource> authorizedContainers = containerAuth.getAllResourcesforUser(username);
-                if (authorizedContainers.isEmpty()) {
-                    status = new Status(StatusCode.UNAUTHORIZED, "User is not authorized for any container");
-                } else {
-                    for (Resource container : authorizedContainers) {
-                        if (container.getPrivilege() == Privilege.WRITE) {
-                            String containerName = (String)container.getResource();
-                            IConfigurationContainerService containerConfigService = (IConfigurationContainerService) ServiceHelper
-                                    .getInstance(IConfigurationContainerService.class, containerName, this);
-                            if (containerConfigService != null) {
-                                status = containerConfigService.saveConfigurations();
-                                if (status.isSuccess()) {
-                                    oneSaved = true;
-                                }
-                            }
-                        }
-                    }
-                    if (oneSaved) {
-                        status = new Status(StatusCode.SUCCESS);
-                    } else {
-                        status = new Status(StatusCode.UNAUTHORIZED, "Operation not allowed for current user");
-                    }
-                }
-            } else {
-                status = new Status(StatusCode.NOSERVICE, "Container Authorization Service is not available");
-            }
-            break;
-        case APPUSER:
-        case NOUSER:
-        default:
-            status = new Status(StatusCode.UNAUTHORIZED, "Operation not allowed for current user");
-            break;
-        }
-        // This function will eventually return a Status
-        return status.getDescription();
-    }
-
-    @RequestMapping(value = "logout")
-    public String logout(Map<String, Object> model, final HttpServletRequest request) {
-
-        IUserManager userManager = (IUserManager) ServiceHelper
-                .getGlobalInstance(IUserManager.class, this);
-        if (userManager == null) {
-            return "User Manager is not available";
-        }
-        String username = request.getUserPrincipal().getName();
-        HttpSession session = request.getSession(false);
-        if (session != null) {
-            if (username != null) {
-                userManager.userLogout(username);
-            }
-            session.invalidate();
-
-        }
-        return "redirect:" + "/";
-    }
-
-    @RequestMapping(value = "login")
-    public String login(Model model, final HttpServletRequest request,
-            final HttpServletResponse response) {
-        // response.setHeader("X-Page-Location", "/login");
-        IUserManager userManager = (IUserManager) ServiceHelper
-                .getGlobalInstance(IUserManager.class, this);
-        if (userManager == null) {
-            return "User Manager is not available";
-        }
-
-        String username = request.getUserPrincipal().getName();
-
-        model.addAttribute("username", username);
-        model.addAttribute("role", userManager.getUserLevel(username)
-                .toNumber());
-        return "forward:" + "/";
-    }
-
-}
diff --git a/opendaylight/adsal/web/root/src/main/java/org/opendaylight/controller/web/DaylightWebAdmin.java b/opendaylight/adsal/web/root/src/main/java/org/opendaylight/controller/web/DaylightWebAdmin.java
deleted file mode 100644 (file)
index b6a4d0d..0000000
+++ /dev/null
@@ -1,348 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.web;
-
-import java.net.InetAddress;
-import java.net.UnknownHostException;
-import java.util.ArrayList;
-import java.util.List;
-import java.util.Set;
-
-import javax.servlet.http.HttpServletRequest;
-import javax.servlet.http.HttpSession;
-
-import org.opendaylight.controller.clustering.services.IClusterGlobalServices;
-import org.opendaylight.controller.connectionmanager.IConnectionManager;
-import org.opendaylight.controller.sal.authorization.UserLevel;
-import org.opendaylight.controller.sal.core.Description;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.utils.GlobalConstants;
-import org.opendaylight.controller.sal.utils.ServiceHelper;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.sal.utils.StatusCode;
-import org.opendaylight.controller.switchmanager.ISwitchManager;
-import org.opendaylight.controller.usermanager.IUserManager;
-import org.opendaylight.controller.usermanager.UserConfig;
-import org.springframework.stereotype.Controller;
-import org.springframework.web.bind.annotation.PathVariable;
-import org.springframework.web.bind.annotation.RequestMapping;
-import org.springframework.web.bind.annotation.RequestMethod;
-import org.springframework.web.bind.annotation.RequestParam;
-import org.springframework.web.bind.annotation.ResponseBody;
-
-import com.google.gson.Gson;
-
-@Controller
-@RequestMapping("/admin")
-public class DaylightWebAdmin {
-    Gson gson = new Gson();
-
-    /**
-     * Returns list of clustered controllers. Highlights "this" controller and
-     * if controller is coordinator
-     *
-     * @return List<ClusterBean>
-     */
-    @RequestMapping("/cluster")
-    @ResponseBody
-    public String getClusteredControllers() {
-        IClusterGlobalServices clusterServices = (IClusterGlobalServices) ServiceHelper.getGlobalInstance(
-                IClusterGlobalServices.class, this);
-        if (clusterServices == null) {
-            return null;
-        }
-        IConnectionManager connectionManager = (IConnectionManager) ServiceHelper.getGlobalInstance(
-                IConnectionManager.class, this);
-        if (connectionManager == null) {
-            return null;
-        }
-
-        List<ClusterNodeBean> clusterNodes = new ArrayList<ClusterNodeBean>();
-
-        List<InetAddress> controllers = clusterServices.getClusteredControllers();
-        for (InetAddress controller : controllers) {
-            ClusterNodeBean.Builder clusterBeanBuilder = new ClusterNodeBean.Builder(controller);
-
-            // get number of connected nodes
-            Set<Node> connectedNodes = connectionManager.getNodes(controller);
-            int numNodes = connectedNodes == null ? 0 : connectedNodes.size();
-            clusterBeanBuilder.nodesConnected(numNodes);
-
-            // determine if this is the executing controller
-            if (controller.equals(clusterServices.getMyAddress())) {
-                clusterBeanBuilder.highlightMe();
-            }
-
-            // determine whether this is coordinator
-            if (clusterServices.getCoordinatorAddress().equals(controller)) {
-                clusterBeanBuilder.iAmCoordinator();
-            }
-            clusterNodes.add(clusterBeanBuilder.build());
-        }
-
-        return gson.toJson(clusterNodes);
-    }
-
-    /**
-     * Return nodes connected to controller {controller}
-     *
-     * @param controller
-     *            - byte[] of the address of the controller
-     * @return List<NodeBean>
-     */
-    @RequestMapping("/cluster/controller/{controller}")
-    @ResponseBody
-    public String getNodesConnectedToController(@PathVariable("controller") String controller) {
-        IClusterGlobalServices clusterServices = (IClusterGlobalServices) ServiceHelper.getGlobalInstance(
-                IClusterGlobalServices.class, this);
-        if (clusterServices == null) {
-            return null;
-        }
-        IConnectionManager connectionManager = (IConnectionManager) ServiceHelper.getGlobalInstance(
-                IConnectionManager.class, this);
-        if (connectionManager == null) {
-            return null;
-        }
-        ISwitchManager switchManager = (ISwitchManager) ServiceHelper.getInstance(ISwitchManager.class,
-                GlobalConstants.DEFAULT.toString(), this);
-        if (switchManager == null) {
-            return null;
-        }
-
-        byte[] address = gson.fromJson(controller, byte[].class);
-        InetAddress controllerAddress = null;
-        try {
-            controllerAddress = InetAddress.getByAddress(address);
-        } catch (UnknownHostException e) {
-            return null;
-        }
-
-        List<NodeBean> result = new ArrayList<NodeBean>();
-
-        Set<Node> nodes = connectionManager.getNodes(controllerAddress);
-        if (nodes == null) {
-            return gson.toJson(result);
-        }
-        for (Node node : nodes) {
-            Description description = (Description) switchManager.getNodeProp(node, Description.propertyName);
-            NodeBean nodeBean;
-            if (description == null || description.getValue().equals("None")) {
-                nodeBean = new NodeBean(node);
-            } else {
-                nodeBean = new NodeBean(node, description.getValue());
-            }
-            result.add(nodeBean);
-        }
-
-        return gson.toJson(result);
-    }
-
-    @RequestMapping(value = "/users", method = RequestMethod.GET)
-    @ResponseBody
-    public List<UserBean> getUsers() {
-        IUserManager userManager = (IUserManager) ServiceHelper.getGlobalInstance(IUserManager.class, this);
-        if (userManager == null) {
-            return null;
-        }
-
-        List<UserBean> result = new ArrayList<UserBean>();
-        List<UserConfig> configs = userManager.getLocalUserList();
-        for (UserConfig config : configs) {
-            UserBean bean = new UserBean(config);
-            result.add(bean);
-        }
-
-        return result;
-    }
-
-    /*
-     * Password in clear text, moving to HTTP/SSL soon
-     */
-    @RequestMapping(value = "/users", method = RequestMethod.POST)
-    @ResponseBody
-    public Status saveLocalUserConfig(@RequestParam(required = true) String json,
-            @RequestParam(required = true) String action, HttpServletRequest request) {
-
-        IUserManager userManager = (IUserManager) ServiceHelper.getGlobalInstance(IUserManager.class, this);
-        if (userManager == null) {
-            return new Status(StatusCode.NOSERVICE, "User Manager unavailable");
-        }
-
-        if (!authorize(userManager, UserLevel.NETWORKADMIN, request)) {
-            return new Status(StatusCode.UNAUTHORIZED, "Operation not permitted");
-        }
-
-        Gson gson = new Gson();
-        UserConfig plainConfig = gson.fromJson(json, UserConfig.class);
-        // Recreate using the proper constructor which will hash the password
-        UserConfig config = new UserConfig(plainConfig.getUser(), plainConfig.getPassword(), plainConfig.getRoles());
-
-        Status result = (action.equals("add")) ? userManager.addLocalUser(config) : userManager.removeLocalUser(config);
-        if (result.isSuccess()) {
-            if (action.equals("add")) {
-                DaylightWebUtil.auditlog("User", request.getUserPrincipal().getName(), "added", config.getUser()
-                        + " as " + config.getRoles().toString());
-            } else {
-                DaylightWebUtil.auditlog("User", request.getUserPrincipal().getName(), "removed", config.getUser());
-            }
-        }
-        return result;
-    }
-
-    @RequestMapping(value = "/user/modify", method = RequestMethod.POST)
-    @ResponseBody
-    public Status modifyUser(@RequestParam(required = true) String json,
-            @RequestParam(required = true) String action, HttpServletRequest request) {
-
-        IUserManager userManager = (IUserManager) ServiceHelper.getGlobalInstance(IUserManager.class, this);
-        if (userManager == null) {
-            return new Status(StatusCode.NOSERVICE, "User Manager unavailable");
-        }
-
-        if (!authorize(userManager, UserLevel.NETWORKADMIN, request)) {
-            return new Status(StatusCode.UNAUTHORIZED, "Operation not permitted");
-        }
-
-        UserConfig newConfig = gson.fromJson(json, UserConfig.class);
-        List<UserConfig> currentUserConfig = userManager.getLocalUserList();
-        String password = null;
-        byte[] salt = null;
-        String user = newConfig.getUser();
-        for (UserConfig userConfig : currentUserConfig) {
-            if(userConfig.getUser().equals(user)){
-                password = userConfig.getPassword();
-                salt = userConfig.getSalt();
-                break;
-            }
-        }
-        if (password == null) {
-            String msg = String.format("User %s not found in configuration database", user);
-            return new Status(StatusCode.NOTFOUND, msg);
-        }
-
-        //While modifying a user role, the password is not provided from GUI for any user.
-        //The password is stored in hash mode, hence it cannot be retrieved and added to UserConfig object
-        //The hashed password is injected below to the json string containing username and new roles before
-        //converting to UserConfig object.
-        Gson gson = new Gson();
-        json = json.replace("\"roles\"", "\"salt\":" + gson.toJson(salt, salt.getClass()) + ",\"password\":\""+ password + "\",\"roles\"");
-
-        newConfig = gson.fromJson(json, UserConfig.class);
-
-        Status result = userManager.modifyLocalUser(newConfig);
-        if (result.isSuccess()) {
-            DaylightWebUtil.auditlog("Roles of", request.getUserPrincipal().getName(), "updated", newConfig.getUser()
-                    + " to " + newConfig.getRoles().toString());
-        }
-        return result;
-    }
-
-
-    @RequestMapping(value = "/users/{username}", method = RequestMethod.POST)
-    @ResponseBody
-    public Status removeLocalUser(@PathVariable("username") String userName, HttpServletRequest request) {
-
-        String loggedInUser = request.getUserPrincipal().getName();
-        if (loggedInUser.equals(userName)) {
-            String msg = "Invalid Request: User cannot delete itself";
-            return new Status(StatusCode.NOTALLOWED, msg);
-        }
-
-        IUserManager userManager = (IUserManager) ServiceHelper.getGlobalInstance(IUserManager.class, this);
-        if (userManager == null) {
-            return new Status(StatusCode.NOSERVICE, "User Manager unavailable");
-        }
-
-        if (!authorize(userManager, UserLevel.NETWORKADMIN, request)) {
-            return new Status(StatusCode.UNAUTHORIZED, "Operation not permitted");
-        }
-
-        Status status = userManager.removeLocalUser(userName);
-        if (status.isSuccess()) {
-            DaylightWebUtil.auditlog("User", request.getUserPrincipal().getName(), "removed", userName);
-            return status;
-        }
-        return status;
-    }
-
-    @RequestMapping(value = "/users/password/{username}", method = RequestMethod.POST)
-    @ResponseBody
-    public Status changePassword(
-            @PathVariable("username") String username, HttpServletRequest request,
-            @RequestParam(value = "currentPassword", required=false) String currentPassword,
-            @RequestParam("newPassword") String newPassword) {
-        IUserManager userManager = (IUserManager) ServiceHelper.getGlobalInstance(IUserManager.class, this);
-        if (userManager == null) {
-            return new Status(StatusCode.NOSERVICE, "User Manager unavailable");
-        }
-
-        Status status;
-        String requestingUser = request.getUserPrincipal().getName();
-
-        //changing own password
-        if (requestingUser.equals(username) ) {
-            status = userManager.changeLocalUserPassword(username, currentPassword, newPassword);
-            //enforce the user to re-login with new password
-            if (status.isSuccess() && !newPassword.equals(currentPassword)) {
-                userManager.userLogout(username);
-                HttpSession session = request.getSession(false);
-                if ( session != null) {
-                    session.invalidate();
-                }
-            }
-
-        //admin level user resetting other's password
-        } else if (authorize(userManager, UserLevel.NETWORKADMIN, request)) {
-
-            //Since User Manager doesn't have an unprotected password change API,
-            //we re-create the user with the new password (and current roles).
-            List<String> roles = userManager.getUserRoles(username);
-            UserConfig newConfig = new UserConfig(username, newPassword, roles);
-
-            //validate before removing existing config, so we don't remove but fail to add
-            status = newConfig.validate();
-            if (!status.isSuccess()) {
-                return status;
-            }
-
-            userManager.userLogout(username);
-            status = userManager.removeLocalUser(username);
-            if (!status.isSuccess()) {
-                return status;
-            }
-            if (userManager.addLocalUser(newConfig).isSuccess()) {
-                status = new Status(StatusCode.SUCCESS, "Password for user " + username + " reset successfully.");
-            } else {
-                //unexpected
-                status = new Status(StatusCode.INTERNALERROR, "Failed resetting password for user " + username + ". User is now removed.");
-            }
-
-        //unauthorized
-        } else {
-            status = new Status(StatusCode.UNAUTHORIZED, "Operation not permitted");
-        }
-
-        if (status.isSuccess()) {
-            DaylightWebUtil.auditlog("User", request.getUserPrincipal().getName(), "changed password for",
-                    username);
-        }
-        return status;
-    }
-
-    /**
-     * Is the operation permitted for the given level
-     *
-     * @param level
-     */
-    private boolean authorize(IUserManager userManager, UserLevel level, HttpServletRequest request) {
-        String username = request.getUserPrincipal().getName();
-        UserLevel userLevel = userManager.getUserLevel(username);
-        return userLevel.toNumber() <= level.toNumber();
-    }
-}
diff --git a/opendaylight/adsal/web/root/src/main/java/org/opendaylight/controller/web/DaylightWebUtil.java b/opendaylight/adsal/web/root/src/main/java/org/opendaylight/controller/web/DaylightWebUtil.java
deleted file mode 100644 (file)
index e889836..0000000
+++ /dev/null
@@ -1,140 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.web;
-
-import org.opendaylight.controller.containermanager.IContainerAuthorization;
-import org.opendaylight.controller.sal.authorization.Privilege;
-import org.opendaylight.controller.sal.core.Description;
-import org.opendaylight.controller.sal.core.Name;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.utils.GlobalConstants;
-import org.opendaylight.controller.sal.utils.ServiceHelper;
-import org.opendaylight.controller.switchmanager.ISwitchManager;
-import org.opendaylight.controller.usermanager.IUserManager;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-public class DaylightWebUtil {
-
-    private static final String AUDIT = "audit";
-    private static final Logger logger = LoggerFactory.getLogger(AUDIT);
-
-    /**
-     * Returns the access privilege the user has on the specified container
-     *
-     * @param userName
-     *            The user name
-     * @param container
-     *            The container name. If null, the default container will be assumed
-     * @param bundle
-     *            The bundle originating the request
-     * @return The access privilege the user is granted on the container
-     */
-    public static Privilege getContainerPrivilege(String userName,
-            String container, Object bundle) {
-        // Derive the target resource
-        String resource = (container == null) ? GlobalConstants.DEFAULT.toString() : container;
-
-        // Retrieve the Container Authorization service
-        IContainerAuthorization auth = (IContainerAuthorization) ServiceHelper
-                .getGlobalInstance(IContainerAuthorization.class, bundle);
-        if (auth != null) {
-            return auth.getResourcePrivilege(userName, resource);
-        }
-
-        /*
-         * Container Authorization service not available. We can only derive the
-         * access privilege to the default container based on user level
-         */
-        if (resource.equals(GlobalConstants.DEFAULT.toString())) {
-            IUserManager userManager = (IUserManager) ServiceHelper
-                    .getGlobalInstance(IUserManager.class, bundle);
-            if (userManager != null) {
-                switch (userManager.getUserLevel(userName)) {
-                case NETWORKADMIN:
-                    return Privilege.WRITE;
-                case NETWORKOPERATOR:
-                    return Privilege.READ;
-                default:
-                    return Privilege.NONE;
-                }
-            }
-        }
-
-        return Privilege.NONE;
-    }
-
-    public static void auditlog(String moduleName, String user, String action, String resource,
-            String containerName) {
-        String auditMsg = "";
-        String mode = "UI";
-        if (containerName != null) {
-            auditMsg = "Mode: " + mode + " User " + user + " "  + action + " " + moduleName + " " + resource + " in container "
-                    + containerName;
-        } else {
-            auditMsg = "Mode: " + mode + " User " + user + " "  + action + " " + moduleName + " " + resource;
-        }
-        logger.trace(auditMsg);
-    }
-
-    public static void auditlog(String moduleName, String user, String action, String resource) {
-        auditlog(moduleName, user, action, resource, null);
-    }
-
-    public static String getNodeDesc(Node node, ISwitchManager switchManager) {
-        Description desc = (Description) switchManager.getNodeProp(node,
-                Description.propertyName);
-        String description = (desc == null) ? "" : desc.getValue();
-        return (description.isEmpty() || description.equalsIgnoreCase("none")) ? node
-                .toString() : description;
-    }
-
-    public static String getNodeDesc(Node node, String containerName,
-            Object bundle) {
-        ISwitchManager switchManager = (ISwitchManager) ServiceHelper
-                .getInstance(ISwitchManager.class, containerName, bundle);
-        if (switchManager == null) {
-            return null;
-        }
-
-        return getNodeDesc(node, switchManager);
-    }
-
-    public static String getNodeDesc(Node node, Object bundle) {
-        ISwitchManager switchManager = (ISwitchManager) ServiceHelper
-                .getInstance(ISwitchManager.class,
-                        GlobalConstants.DEFAULT.toString(), bundle);
-        if (switchManager == null) {
-            return null;
-        }
-
-        return getNodeDesc(node, switchManager);
-    }
-
-    public static String getPortName(NodeConnector nodeConnector,
-            String container, Object bundle) {
-        ISwitchManager switchManager = (ISwitchManager) ServiceHelper
-                .getInstance(ISwitchManager.class, container, bundle);
-        return getPortName(nodeConnector, switchManager);
-    }
-
-    public static String getPortName(NodeConnector nodeConnector, Object bundle) {
-        return getPortName(nodeConnector, GlobalConstants.DEFAULT.toString(), bundle);
-    }
-
-    public static String getPortName(NodeConnector nodeConnector,
-            ISwitchManager switchManager) {
-        Name ncName = ((Name) switchManager.getNodeConnectorProp(nodeConnector,
-                Name.NamePropName));
-        String nodeConnectorName = (ncName != null) ? ncName.getValue() : nodeConnector.getNodeConnectorIdAsString();
-        nodeConnectorName = nodeConnectorName + "@"
-                + getNodeDesc(nodeConnector.getNode(), switchManager);
-        return nodeConnectorName.substring(0, nodeConnectorName.length());
-    }
-}
diff --git a/opendaylight/adsal/web/root/src/main/java/org/opendaylight/controller/web/IDaylightWeb.java b/opendaylight/adsal/web/root/src/main/java/org/opendaylight/controller/web/IDaylightWeb.java
deleted file mode 100644 (file)
index 7421759..0000000
+++ /dev/null
@@ -1,45 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.web;
-
-import org.opendaylight.controller.sal.authorization.UserLevel;
-
-public interface IDaylightWeb {
-    /**
-     * Returns the name of the bundle. In the GUI, this name will be displayed
-     * on the tab.
-     *
-     * @return Name assigned to the bundle.
-     */
-    public String getWebName();
-
-    /**
-     * Returns the Id assigned to the web bundle.
-     *
-     * @return Id assigned to the web bundle.
-     */
-    public String getWebId();
-
-    /**
-     * Returns the position where the bundle tab will be placed in the GUI.
-     *
-     * @return Position number for the bundle tab.
-     */
-    public short getWebOrder();
-
-    /**
-     * This method checks if the user is authorized to access the bundle.
-     *
-     * @param userLevel
-     *            user role level in the controller space.
-     *
-     * @return true, if user is authorized to access the bundle, else false.
-     */
-    public boolean isAuthorized(UserLevel userLevel);
-}
diff --git a/opendaylight/adsal/web/root/src/main/java/org/opendaylight/controller/web/NodeBean.java b/opendaylight/adsal/web/root/src/main/java/org/opendaylight/controller/web/NodeBean.java
deleted file mode 100644 (file)
index 6ef1efc..0000000
+++ /dev/null
@@ -1,28 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.web;
-
-import org.opendaylight.controller.sal.core.Node;
-
-/**
- * Information about a node connected to a controller to send to the UI frontend
- * @author andrekim
- */
-public class NodeBean {
-    private final String node;
-    private final String description;
-
-    public NodeBean(Node node) {
-        this(node, node.toString());
-    }
-
-    public NodeBean(Node node, String description) {
-        this.node = node.toString();
-        this.description = description;
-    }
-}
diff --git a/opendaylight/adsal/web/root/src/main/java/org/opendaylight/controller/web/UserBean.java b/opendaylight/adsal/web/root/src/main/java/org/opendaylight/controller/web/UserBean.java
deleted file mode 100644 (file)
index b4e4cd6..0000000
+++ /dev/null
@@ -1,34 +0,0 @@
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.controller.web;
-
-import java.util.List;
-
-import org.opendaylight.controller.usermanager.UserConfig;
-
-public class UserBean {
-    private String user;
-    private List<String> roles;
-
-    public UserBean(String user, List<String> roles) {
-        this.user = user;
-        this.roles = roles;
-    }
-
-    public UserBean(UserConfig config) {
-        this(config.getUser(), config.getRoles());
-    }
-
-    public String getUser() {
-        return user;
-    }
-
-    public List<String> getRoles() {
-        return roles;
-    }
-}
diff --git a/opendaylight/adsal/web/root/src/main/resources/META-INF/spring.factories b/opendaylight/adsal/web/root/src/main/resources/META-INF/spring.factories
deleted file mode 100644 (file)
index 93db02e..0000000
+++ /dev/null
@@ -1 +0,0 @@
-org.springframework.beans.BeanInfoFactory=org.springframework.beans.ExtendedBeanInfoFactory
diff --git a/opendaylight/adsal/web/root/src/main/resources/META-INF/spring.handlers b/opendaylight/adsal/web/root/src/main/resources/META-INF/spring.handlers
deleted file mode 100644 (file)
index 957af91..0000000
+++ /dev/null
@@ -1,10 +0,0 @@
-http\://www.springframework.org/schema/context=org.springframework.context.config.ContextNamespaceHandler
-http\://www.springframework.org/schema/jee=org.springframework.ejb.config.JeeNamespaceHandler
-http\://www.springframework.org/schema/lang=org.springframework.scripting.config.LangNamespaceHandler
-http\://www.springframework.org/schema/task=org.springframework.scheduling.config.TaskNamespaceHandler
-http\://www.springframework.org/schema/cache=org.springframework.cache.config.CacheNamespaceHandler
-http\://www.springframework.org/schema/c=org.springframework.beans.factory.xml.SimpleConstructorNamespaceHandler
-http\://www.springframework.org/schema/p=org.springframework.beans.factory.xml.SimplePropertyNamespaceHandler
-http\://www.springframework.org/schema/util=org.springframework.beans.factory.xml.UtilNamespaceHandler
-http\://www.springframework.org/schema/mvc=org.springframework.web.servlet.config.MvcNamespaceHandler
-http\://www.springframework.org/schema/security=org.springframework.security.config.SecurityNamespaceHandler
diff --git a/opendaylight/adsal/web/root/src/main/resources/META-INF/spring.schemas b/opendaylight/adsal/web/root/src/main/resources/META-INF/spring.schemas
deleted file mode 100644 (file)
index d865edc..0000000
+++ /dev/null
@@ -1,49 +0,0 @@
-http\://www.springframework.org/schema/beans/spring-beans-2.0.xsd=org/springframework/beans/factory/xml/spring-beans-2.0.xsd
-http\://www.springframework.org/schema/beans/spring-beans-2.5.xsd=org/springframework/beans/factory/xml/spring-beans-2.5.xsd
-http\://www.springframework.org/schema/beans/spring-beans-3.0.xsd=org/springframework/beans/factory/xml/spring-beans-3.0.xsd
-http\://www.springframework.org/schema/beans/spring-beans-3.1.xsd=org/springframework/beans/factory/xml/spring-beans-3.1.xsd
-http\://www.springframework.org/schema/beans/spring-beans-3.2.xsd=org/springframework/beans/factory/xml/spring-beans-3.2.xsd
-http\://www.springframework.org/schema/beans/spring-beans.xsd=org/springframework/beans/factory/xml/spring-beans-3.2.xsd
-http\://www.springframework.org/schema/tool/spring-tool-2.0.xsd=org/springframework/beans/factory/xml/spring-tool-2.0.xsd
-http\://www.springframework.org/schema/tool/spring-tool-2.5.xsd=org/springframework/beans/factory/xml/spring-tool-2.5.xsd
-http\://www.springframework.org/schema/tool/spring-tool-3.0.xsd=org/springframework/beans/factory/xml/spring-tool-3.0.xsd
-http\://www.springframework.org/schema/tool/spring-tool-3.1.xsd=org/springframework/beans/factory/xml/spring-tool-3.1.xsd
-http\://www.springframework.org/schema/tool/spring-tool-3.2.xsd=org/springframework/beans/factory/xml/spring-tool-3.2.xsd
-http\://www.springframework.org/schema/tool/spring-tool.xsd=org/springframework/beans/factory/xml/spring-tool-3.2.xsd
-http\://www.springframework.org/schema/util/spring-util-2.0.xsd=org/springframework/beans/factory/xml/spring-util-2.0.xsd
-http\://www.springframework.org/schema/util/spring-util-2.5.xsd=org/springframework/beans/factory/xml/spring-util-2.5.xsd
-http\://www.springframework.org/schema/util/spring-util-3.0.xsd=org/springframework/beans/factory/xml/spring-util-3.0.xsd
-http\://www.springframework.org/schema/util/spring-util-3.1.xsd=org/springframework/beans/factory/xml/spring-util-3.1.xsd
-http\://www.springframework.org/schema/util/spring-util-3.2.xsd=org/springframework/beans/factory/xml/spring-util-3.2.xsd
-http\://www.springframework.org/schema/util/spring-util.xsd=org/springframework/beans/factory/xml/spring-util-3.2.xsd
-http\://www.springframework.org/schema/context/spring-context-2.5.xsd=org/springframework/context/config/spring-context-2.5.xsd
-http\://www.springframework.org/schema/context/spring-context-3.0.xsd=org/springframework/context/config/spring-context-3.0.xsd
-http\://www.springframework.org/schema/context/spring-context-3.1.xsd=org/springframework/context/config/spring-context-3.1.xsd
-http\://www.springframework.org/schema/context/spring-context-3.2.xsd=org/springframework/context/config/spring-context-3.2.xsd
-http\://www.springframework.org/schema/context/spring-context.xsd=org/springframework/context/config/spring-context-3.2.xsd
-http\://www.springframework.org/schema/jee/spring-jee-2.0.xsd=org/springframework/ejb/config/spring-jee-2.0.xsd
-http\://www.springframework.org/schema/jee/spring-jee-2.5.xsd=org/springframework/ejb/config/spring-jee-2.5.xsd
-http\://www.springframework.org/schema/jee/spring-jee-3.0.xsd=org/springframework/ejb/config/spring-jee-3.0.xsd
-http\://www.springframework.org/schema/jee/spring-jee-3.1.xsd=org/springframework/ejb/config/spring-jee-3.1.xsd
-http\://www.springframework.org/schema/jee/spring-jee-3.2.xsd=org/springframework/ejb/config/spring-jee-3.2.xsd
-http\://www.springframework.org/schema/jee/spring-jee.xsd=org/springframework/ejb/config/spring-jee-3.2.xsd
-http\://www.springframework.org/schema/lang/spring-lang-2.0.xsd=org/springframework/scripting/config/spring-lang-2.0.xsd
-http\://www.springframework.org/schema/lang/spring-lang-2.5.xsd=org/springframework/scripting/config/spring-lang-2.5.xsd
-http\://www.springframework.org/schema/lang/spring-lang-3.0.xsd=org/springframework/scripting/config/spring-lang-3.0.xsd
-http\://www.springframework.org/schema/lang/spring-lang-3.1.xsd=org/springframework/scripting/config/spring-lang-3.1.xsd
-http\://www.springframework.org/schema/lang/spring-lang-3.2.xsd=org/springframework/scripting/config/spring-lang-3.2.xsd
-http\://www.springframework.org/schema/lang/spring-lang.xsd=org/springframework/scripting/config/spring-lang-3.2.xsd
-http\://www.springframework.org/schema/task/spring-task-3.0.xsd=org/springframework/scheduling/config/spring-task-3.0.xsd
-http\://www.springframework.org/schema/task/spring-task-3.1.xsd=org/springframework/scheduling/config/spring-task-3.1.xsd
-http\://www.springframework.org/schema/task/spring-task-3.2.xsd=org/springframework/scheduling/config/spring-task-3.2.xsd
-http\://www.springframework.org/schema/task/spring-task.xsd=org/springframework/scheduling/config/spring-task-3.2.xsd
-http\://www.springframework.org/schema/cache/spring-cache-3.1.xsd=org/springframework/cache/config/spring-cache-3.1.xsd
-http\://www.springframework.org/schema/cache/spring-cache-3.2.xsd=org/springframework/cache/config/spring-cache-3.2.xsd
-http\://www.springframework.org/schema/cache/spring-cache.xsd=org/springframework/cache/config/spring-cache-3.2.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd=org/springframework/web/servlet/config/spring-mvc-3.0.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc-3.1.xsd=org/springframework/web/servlet/config/spring-mvc-3.1.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc-3.2.xsd=org/springframework/web/servlet/config/spring-mvc-3.2.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc.xsd=org/springframework/web/servlet/config/spring-mvc-3.2.xsd
-http\://www.springframework.org/schema/security/spring-security-3.1.xsd=org/springframework/security/config/spring-security-3.1.xsd
-http\://www.springframework.org/schema/security/spring-security-3.2.xsd=org/springframework/security/config/spring-security-3.2.xsd
-
diff --git a/opendaylight/adsal/web/root/src/main/resources/META-INF/spring.tooling b/opendaylight/adsal/web/root/src/main/resources/META-INF/spring.tooling
deleted file mode 100644 (file)
index 057d834..0000000
+++ /dev/null
@@ -1,39 +0,0 @@
-# Tooling related information for the beans namespace
-http\://www.springframework.org/schema/beans@name=beans Namespace
-http\://www.springframework.org/schema/beans@prefix=beans
-http\://www.springframework.org/schema/beans@icon=org/springframework/beans/factory/xml/spring-beans.gif
-
-# Tooling related information for the util namespace
-http\://www.springframework.org/schema/util@name=util Namespace
-http\://www.springframework.org/schema/util@prefix=util
-http\://www.springframework.org/schema/util@icon=org/springframework/beans/factory/xml/spring-util.gif
-
-# Tooling related information for the context namespace
-http\://www.springframework.org/schema/context@name=context Namespace
-http\://www.springframework.org/schema/context@prefix=context
-http\://www.springframework.org/schema/context@icon=org/springframework/context/config/spring-context.gif
-
-# Tooling related information for the jee namespace
-http\://www.springframework.org/schema/jee@name=jee Namespace
-http\://www.springframework.org/schema/jee@prefix=jee
-http\://www.springframework.org/schema/jee@icon=org/springframework/ejb/config/spring-jee.gif
-
-# Tooling related information for the scheduling namespace
-http\://www.springframework.org/schema/task@name=task Namespace
-http\://www.springframework.org/schema/task@prefix=task
-http\://www.springframework.org/schema/task@icon=org/springframework/scheduling/config/spring-task.gif
-
-# Tooling related information for the lang namespace
-http\://www.springframework.org/schema/lang@name=lang Namespace
-http\://www.springframework.org/schema/lang@prefix=lang
-http\://www.springframework.org/schema/lang@icon=org/springframework/scripting/config/spring-lang.gif
-
-# Tooling related information for the cache namespace
-http\://www.springframework.org/schema/cache@name=cache Namespace
-http\://www.springframework.org/schema/cache@prefix=cache
-http\://www.springframework.org/schema/cache@icon=org/springframework/cache/config/spring-cache.gif
-
-# Tooling related information for the mvc namespace
-http\://www.springframework.org/schema/mvc@name=mvc Namespace
-http\://www.springframework.org/schema/mvc@prefix=mvc
-http\://www.springframework.org/schema/mvc@icon=org/springframework/web/servlet/config/spring-mvc.gif
diff --git a/opendaylight/adsal/web/root/src/main/resources/WEB-INF/RootGUI-servlet.xml b/opendaylight/adsal/web/root/src/main/resources/WEB-INF/RootGUI-servlet.xml
deleted file mode 100644 (file)
index a8cb864..0000000
+++ /dev/null
@@ -1,21 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<beans xmlns="http://www.springframework.org/schema/beans"
-  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
-  xmlns:context="http://www.springframework.org/schema/context"
-  xmlns:mvc="http://www.springframework.org/schema/mvc"
-  xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
-                      http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd
-                      http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd">
-
-  <context:component-scan base-package="org.opendaylight.controller.web"/>
-
-  <mvc:resources mapping="/js/**" location="/js/" />
-  <mvc:resources mapping="/css/**" location="/css/" />
-  <mvc:resources mapping="/img/**" location="/img/" />
-  <mvc:annotation-driven/>
-
-  <bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
-        <property name="prefix" value="/WEB-INF/jsp/"/>
-        <property name="suffix" value=".jsp"/>
-  </bean>
-</beans>
\ No newline at end of file
diff --git a/opendaylight/adsal/web/root/src/main/resources/WEB-INF/jsp/autherror.jsp b/opendaylight/adsal/web/root/src/main/resources/WEB-INF/jsp/autherror.jsp
deleted file mode 100644 (file)
index a2fa428..0000000
+++ /dev/null
@@ -1,55 +0,0 @@
-<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
-<%@ page import="java.net.URL" %>
-<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
-
-<!DOCTYPE html>
-<html>
-  <head>
-    <meta charset="utf-8">
-
-    <!-- Bootstrap CSS - 1 -->
-    <link href="/css/bootstrap.min.css" rel="stylesheet" media="screen">
-    
-    <!-- Login CSS - 2 -->
-    <link rel="stylesheet/less" type="text/css" href="/css/login.less">
-
-<c:set var="title" value="OpenDaylight login error" scope="application"/>
-<%
-    String filePath = "/WEB-INF/jsp/customerror.jsp"; 
-       URL fileURL = pageContext.getServletContext().getResource(filePath);
-       if(fileURL!=null) {
-%>
-         <jsp:include page="<%=filePath%>" flush="true"/>
-<% } %>
-       <title>${title}</title>
-    <!-- Bootstrap JS - 1 -->
-    <script src="/js/bootstrap.min.js"></script>
-    
-    <!-- LESS - 2 -->
-    <script type="text/javascript">
-        less = {
-            env: "production"
-        };
-    </script>
-    <script src="/js/less-1.3.3.min.js"></script>
-</head>
-<body>
-        <form action="<c:url value='/' />" id="form" method="post">
-
-  <div class="container">
-    <div class="content">
-       <div class="login-form">
-         <div id="logo"></div>
-           <fieldset>
-            <p>You are not authorized to access this resource.<p>
-            <p>Please contact your administrator to resolve your Role privileges.</p>
-            <br/>
-             <button class="btn btn-primary" type="submit" value="Log In" >Go To Login Page</button>
-           </fieldset>
-       </div>
-    </div>
-  </div> 
-  </form>
-  <% if (session != null) session.invalidate(); %>
-</body>
-</html>
diff --git a/opendaylight/adsal/web/root/src/main/resources/WEB-INF/jsp/error.jsp b/opendaylight/adsal/web/root/src/main/resources/WEB-INF/jsp/error.jsp
deleted file mode 100644 (file)
index d288969..0000000
+++ /dev/null
@@ -1,54 +0,0 @@
-<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
-<%@ page import="java.net.URL" %>
-<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
-
-<!DOCTYPE html>
-<html>
-  <head>
-    <meta charset="utf-8">
-
-    <!-- Bootstrap CSS - 1 -->
-    <link href="/css/bootstrap.min.css" rel="stylesheet" media="screen">
-    
-    <!-- Login CSS - 2 -->
-    <link rel="stylesheet/less" type="text/css" href="/css/login.less">
-
-<c:set var="title" value="OpenDaylight login error" scope="application"/>
-<%
-    String filePath = "/WEB-INF/jsp/customerror.jsp"; 
-       URL fileURL = pageContext.getServletContext().getResource(filePath);
-       if(fileURL!=null) {
-%>
-         <jsp:include page="<%=filePath%>" flush="true"/>
-<% } %>
-       <title>${title}</title>
-    <!-- Bootstrap JS - 1 -->
-    <script src="/js/bootstrap.min.js"></script>
-    
-    <!-- LESS - 2 -->
-    <script type="text/javascript">
-        less = {
-            env: "production"
-        };
-    </script>
-    <script src="/js/less-1.3.3.min.js"></script>
-</head>
-<body>
-        <form action="<c:url value='/' />" id="form" method="post">
-
-  <div class="container">
-    <div class="content">
-       <div class="login-form">
-         <div id="logo"></div>
-           <fieldset>
-            <p>Login failed or session might have timed out.<p>
-            <p>Please go back to the login page and try again.</p>
-            <br/>
-             <button class="btn btn-primary" type="submit" value="Log In" >Go To Login Page</button>
-           </fieldset>
-       </div>
-    </div>
-  </div> 
-  </form>
-</body>
-</html>
diff --git a/opendaylight/adsal/web/root/src/main/resources/WEB-INF/jsp/login.jsp b/opendaylight/adsal/web/root/src/main/resources/WEB-INF/jsp/login.jsp
deleted file mode 100644 (file)
index e2d1dd3..0000000
+++ /dev/null
@@ -1,57 +0,0 @@
-<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
-<%@ page import="java.net.URL" %>
-<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
-
-<!DOCTYPE html>
-<html>
-  <head>
-    <meta charset="utf-8">
-
-    <!-- Bootstrap CSS - 1 -->
-       <link href="/css/bootstrap.min.css" rel="stylesheet" media="screen">
-
-       <!-- Login CSS - 2 -->
-       <link rel="stylesheet/less" type="text/css" href="/css/login.less">
-
-<c:set var="title" value="OpenDaylight - Login" scope="application"/>
-<%
-    String filePath = "/WEB-INF/jsp/customlogin.jsp"; 
-       URL fileURL = pageContext.getServletContext().getResource(filePath);
-       if(fileURL!=null) {
-%>
-         <jsp:include page="<%=filePath%>" flush="true"/>
-<% } %>
-       <title>${title}</title>
-       <!-- Bootstrap JS - 1 -->
-       <script src="/js/bootstrap.min.js"></script>
-       
-       <!-- LESS - 2 -->
-       <script type="text/javascript">
-               less = {
-                       env: "production"
-               };
-       </script>
-       <script src="/js/less-1.3.3.min.js"></script>
-</head>
-<body>
-  <form action="<c:url value='j_security_check' />" id="form" method="post">
-
-  <div class="container">
-    <div class="content">
-       <div class="login-form">
-         <div id="logo"></div>
-           <fieldset>
-             <div class="control-group">
-               <input type="text" name="j_username" placeholder="Username">
-             </div>
-             <div class="control-group">
-               <input type="password" name="j_password" placeholder="Password">
-             </div>
-             <button class="btn btn-primary" type="submit" value="Log In" ><div class="icon-login"></div> Log In</button>
-           </fieldset>
-       </div>
-    </div>
-  </div> 
-  </form>
-</body>
-</html>
diff --git a/opendaylight/adsal/web/root/src/main/resources/WEB-INF/jsp/main.jsp b/opendaylight/adsal/web/root/src/main/resources/WEB-INF/jsp/main.jsp
deleted file mode 100644 (file)
index 5dfbc46..0000000
+++ /dev/null
@@ -1,198 +0,0 @@
-<%--
- - Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved. 
- - 
- - This program and the accompanying materials are made available under the 
- - terms of the Eclipse Public License v1.0 which accompanies this distribution, 
- - and is available at http://www.eclipse.org/legal/epl-v10.html
---%>
-<%@ page import="java.net.URL"%>
-<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>
-
-<!DOCTYPE html>
-<html>
-
-<head>
-<meta name="viewport" content="width=device-width, initial-scale=1.0">
-
-<!-- Bootstrap CSS - 1 -->
-<link href="/css/bootstrap.min.css" rel="stylesheet" media="screen">
-<link rel="stylesheet" type="text/css" href="/css/fuelux.min.css">
-<link rel="stylesheet" type="text/css" href="/css/opendaylight.css">
-
-<!-- Core CSS - 2 -->
-<link rel="stylesheet/less" type="text/css" href="/css/one.less">
-
-<c:set var="version" value="Version 0.1" scope="application" />
-<c:set var="name" value="OpenDaylight" scope="application" />
-
-<%
-    String filePath = "/WEB-INF/jsp/custommain.jsp";
-    URL fileURL = pageContext.getServletContext().getResource(filePath);
-    if (fileURL != null) {
-%>
-<jsp:include page="<%=filePath%>" flush="true" />
-<%
-    }
-%>
-
-<title>${name}</title>
-<!-- jQuery - 1 -->
-<script src="/js/jquery-1.9.1.min.js"></script>
-
-<!-- Bootstrap JS - 2 -->
-<script src="/js/underscore-min.js"></script>
-<script src="/js/fuelux/loader.min.js"></script>
-<script src="/js/datasource.js"></script>
-
-<!-- LESS - 3 -->
-<script type="text/javascript">
-    less = {
-        env : "production"
-    };
-</script>
-<script src="/js/less-1.3.3.min.js"></script>
-
-<!-- Topology - 4 -->
-<script src="/js/jit.js"></script>
-</head>
-<body>
-
- <!-- #menu -->
- <div id="menu" class="navbar navbar-fixed-top">
-  <div class="navbar-inner row-fluid">
-   <div class="span9">
-    <a class="brand" href="/" title="${version}">${name}</a>
-    <ul class="nav nav-tabs">
-    </ul>
-   </div>
-   <div class="span3">
-    <div id="toolbar" class="btn-group">
-    <input type="hidden" id="currentuser" value="${username}" data-role="${role}">
-     <a class="btn dropdown-toggle" data-toggle="dropdown" href="#">
-      <div class="icon-user"></div> ${username} <span class="caret"></span>
-     </a>
-     <ul class="dropdown-menu">
-      <li><a href="#admin" id="admin" data-role="${role}"><div class="icon-users"></div> Users</a></li>
-      <li><a href="#cluster" id="cluster"><div class="icon-cluster"></div>Cluster</a></li>
-      <li><a href="#osgi" id="osgi"><div class="icon-default"></div>OSGi</a></li>
-      <li><a href="#save" id="save"><div class="icon-save"></div>Save</a></li>
-      <li><a href="#logout" id="logout"><div class="icon-logout"></div> Logout</a></li>
-     </ul>
-    </div>
-   </div>
-  </div>
- </div>
- <!-- END #menu -->
-
- <!-- #footer -->
- <div id="footer" class="navbar navbar-fixed-bottom">
-  <div class="navbar-inner row-fluid">
-   <div class="alert hide" id="alert">
-    <button type="button" class="close">&times;</button>
-    <p></p>
-   </div>
-  </div>
- </div>
- <!-- END #footer -->
-
- <!-- #main -->
- <div id="main">
-
-  <!-- #left -->
-  <div id="left">
-
-   <!-- #left-top -->
-   <div id="left-top">
-
-    <div class="dash">
-     <ul class="nav nav-tabs">
-     </ul>
-     <div class="dashlet row-fluid"></div>
-    </div>
-
-   </div>
-   <!-- END #left-top -->
-
-   <!-- #left-bottom -->
-   <div id="left-bottom">
-
-    <div class="dash">
-     <ul class="nav nav-tabs">
-     </ul>
-     <div class="dashlet row-fluid"></div>
-    </div>
-
-   </div>
-   <!-- END #left-bottom -->
-
-  </div>
-  <!-- END #left -->
-
-  <!-- #right -->
-  <div id="right">
-
-   <!-- #right-top -->
-   <div id="right-top">
-
-    <div class="dash">
-     <div id="topology"></div>
-    </div>
-
-   </div>
-   <!-- END #right-top -->
-
-   <!-- #right-bottom -->
-   <div id="right-bottom">
-
-    <div class="dash">
-     <ul class="nav nav-tabs">
-     </ul>
-     <div class="dashlet row-fluid"></div>
-    </div>
-
-   </div>
-   <!-- END #right-bottom -->
-
-  </div>
-  <!-- END #right -->
-
- </div>
- <!-- END #main -->
-
- <!-- modal -->
- <div id="modal" class="modal hide fade">
-  <div class="modal-header">
-   <button type="button" class="close" data-dismiss="modal"
-    aria-hidden="true">&times;</button>
-   <button type="button" class="help" aria-hidden="true"
-    >?</button>
-   <h3></h3>
-  </div>
-  <div class="modal-body"></div>
-  <div class="modal-footer"></div>
- </div>
- <!-- END modal -->
-
- <!-- Lib JS - 6 -->
- <script src="/js/lib.js"></script>
- <%
-     String jsPath = "/WEB-INF/jsp/customjs.jsp";
-     URL jsURL = pageContext.getServletContext().getResource(jsPath);
-     if (jsURL != null) {
- %>
- <jsp:include page="<%=jsPath%>" flush="true" />
- <%
-     } else {
- %>
- <!-- Core JS - 7 -->
- <script src="/js/open.js"></script>
-
- <!-- Topology JS - 8 -->
- <script src="/js/open-topology.js"></script>
- <%
-     }
- %>
-
-</body>
-
-</html>
diff --git a/opendaylight/adsal/web/root/src/main/resources/WEB-INF/spring/servlet/security.xml b/opendaylight/adsal/web/root/src/main/resources/WEB-INF/spring/servlet/security.xml
deleted file mode 100644 (file)
index a649b08..0000000
+++ /dev/null
@@ -1,120 +0,0 @@
-<beans:beans xmlns="http://www.springframework.org/schema/security"
-        xmlns:beans="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
-        xsi:schemaLocation="http://www.springframework.org/schema/beans
-           http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
-           http://www.springframework.org/schema/security
-           http://www.springframework.org/schema/security/spring-security-3.1.xsd">
-
-
-        <http pattern="/css/**" security="none" />
-        <http pattern="/js/**" security="none" />
-        <http pattern="/img/**" security="none" />
-        <http pattern="/favicon.ico" security="none" />
-        <http pattern="/controller/web/css/**" security="none" />
-        <http pattern="/controller/web/js/**" security="none" />
-        <http pattern="/controller/web/img/**" security="none" />
-
-
-        <http auto-config="false" authentication-manager-ref="authenticationManager"
-                security-context-repository-ref="securityContextRepo" entry-point-ref="loginUrlAuthenticationEntryPoint">
-                <intercept-url pattern="/login*" access="IS_AUTHENTICATED_ANONYMOUSLY" />
-                <intercept-url pattern="/logout*" access="IS_AUTHENTICATED_ANONYMOUSLY" />
-
-
-                <intercept-url pattern="/**"
-                        access="ROLE_SYSTEM-ADMIN, ROLE_NETWORK-ADMIN, ROLE_NETWORK-OPERATOR, ROLE_CONTAINER-USER" />
-                <custom-filter ref="authenticationFilter" position="FORM_LOGIN_FILTER" />
-                <custom-filter position="LOGOUT_FILTER" ref="logoutFilter" />
-                <custom-filter position="LAST" ref="controllerFilter" />
-                <remember-me services-ref="rememberMeServices" key="SDN" />
-        </http>
-
-        <beans:bean id="controllerFilter"
-                class="org.opendaylight.controller.web.ControllerCustomFilter" />
-
-        <authentication-manager id="authenticationManager">
-                <authentication-provider ref="authenticationProviderWrapper" />
-        </authentication-manager>
-
-        <beans:bean id="authenticationFilter"
-                class="org.springframework.security.web.authentication.UsernamePasswordAuthenticationFilter">
-                <beans:property name="authenticationManager" ref="authenticationManager" />
-                <beans:property name="authenticationFailureHandler"
-                        ref="authenticationFailureHandler" />
-                <beans:property name="authenticationSuccessHandler">
-                        <beans:bean
-                                class="org.opendaylight.controller.web.ControllerAuthenticationSuccessHandler">
-                                <beans:property name="targetUrlParameter" value="x-page-url" />
-                                <beans:property name="defaultTargetUrl" value="/" />
-                        </beans:bean>
-                </beans:property>
-                <beans:property name="rememberMeServices" ref="rememberMeServices" />
-        </beans:bean>
-
-        <beans:bean id="securityContextRepo"
-                class="org.opendaylight.controller.web.ControllerWebSecurityContextRepository" />
-
-        <beans:bean id="authenticationFailureHandler"
-                class="org.springframework.security.web.authentication.SimpleUrlAuthenticationFailureHandler">
-                <beans:property name="useForward" value="false" />
-                <beans:property name="defaultFailureUrl" value="/login" />
-        </beans:bean>
-
-        <beans:bean id="loginUrlAuthenticationEntryPoint"
-                class="org.opendaylight.controller.web.ControllerLoginUrlAuthEntryPoint">
-                <beans:property name="loginFormUrl" value="/login" />
-        </beans:bean>
-
-        <beans:bean id="authenticationProviderWrapper"
-                class="org.opendaylight.controller.web.AuthenticationProviderWrapper" />
-
-    <!-- logout related -->
-
-    <beans:bean id="logoutHandler"
-        class="org.opendaylight.controller.web.ControllerLogoutHandler" />
-
-    <beans:bean id="securityContextLogoutHandler"
-        class="org.springframework.security.web.authentication.logout.SecurityContextLogoutHandler" />
-
-
-    <beans:bean id="logoutFilter" class="org.springframework.security.web.authentication.logout.LogoutFilter">
-        <!-- if logout succeed then this is the URL -->
-        <beans:constructor-arg value="/login" />
-        <beans:constructor-arg>
-            <beans:list>
-                <beans:ref bean="logoutHandler"/>
-                <beans:ref bean="rememberMeServices"/>
-                <beans:ref bean="securityContextLogoutHandler"/>
-            </beans:list>
-        </beans:constructor-arg>
-        <beans:property name="filterProcessesUrl" value="/logout" />
-    </beans:bean>
-
-
-
-
-        <!-- remember me related -->
-        <beans:bean id="rememberMeFilter"
-                class="org.springframework.security.web.authentication.rememberme.RememberMeAuthenticationFilter">
-                <beans:property name="rememberMeServices" ref="rememberMeServices" />
-                <beans:property name="authenticationManager" ref="authenticationManager" />
-        </beans:bean>
-
-        <beans:bean id="rememberMeServices"
-                class="org.springframework.security.web.authentication.rememberme.TokenBasedRememberMeServices">
-                <beans:property name="userDetailsService" ref="userDetailsServiceRef" />
-                <beans:property name="key" value="SDN" />
-                <beans:property name="alwaysRemember" value="true"></beans:property>
-                <beans:property name="tokenValiditySeconds" value="3600" />
-                <beans:property name="cookieName" value="SDN-Controller" />
-        </beans:bean>
-
-        <beans:bean id="userDetailsServiceRef" class="org.opendaylight.controller.web.ControllerUserDetailsService" />
-
-
-        <beans:bean id="rememberMeAuthenticationProvider"
-                class="org.springframework.security.authentication.RememberMeAuthenticationProvider">
-                <beans:property name="key" value="SDN" />
-        </beans:bean>
-
-</beans:beans>
diff --git a/opendaylight/adsal/web/root/src/main/resources/WEB-INF/web.xml b/opendaylight/adsal/web/root/src/main/resources/WEB-INF/web.xml
deleted file mode 100644 (file)
index 062766d..0000000
+++ /dev/null
@@ -1,123 +0,0 @@
-<?xml version="1.0" encoding="ISO-8859-1"?>
-<!-- <web-app xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
-        xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd"
-        version="2.4"> -->
-<web-app xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
-        xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
-        version="3.0">
-
-        <filter>
-          <filter-name>CorsFilter</filter-name>
-          <filter-class>org.apache.catalina.filters.CorsFilter</filter-class>
-          <init-param>
-            <param-name>cors.allowed.origins</param-name>
-            <param-value>*</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.allowed.methods</param-name>
-            <param-value>GET,POST,HEAD,OPTIONS,PUT,DELETE</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.allowed.headers</param-name>
-            <param-value>Content-Type,X-Requested-With,accept,authorization, origin,Origin,Access-Control-Request-Method,Access-Control-Request-Headers</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.exposed.headers</param-name>
-            <param-value>Access-Control-Allow-Origin,Access-Control-Allow-Credentials</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.support.credentials</param-name>
-            <param-value>true</param-value>
-          </init-param>
-          <init-param>
-            <param-name>cors.preflight.maxage</param-name>
-            <param-value>10</param-value>
-          </init-param>
-        </filter>
-        <filter-mapping>
-          <filter-name>CorsFilter</filter-name>
-          <url-pattern>/*</url-pattern>
-        </filter-mapping>
-
-        <security-constraint>
-          <web-resource-collection>
-             <web-resource-name>free access</web-resource-name>
-             <url-pattern>/js/*</url-pattern>
-             <url-pattern>/img/*</url-pattern>
-             <url-pattern>/css/*</url-pattern>
-             <url-pattern>/favicon.ico</url-pattern>
-             <url-pattern>/versionProperty/*</url-pattern>
-          </web-resource-collection>
-        </security-constraint>
-
-        <security-constraint>
-           <display-name>RootApp</display-name>
-           <web-resource-collection>
-              <web-resource-name>RootGUI</web-resource-name>
-              <url-pattern>/*</url-pattern>
-              <http-method>POST</http-method>
-              <http-method>GET</http-method>
-              <http-method>PUT</http-method>
-              <http-method>DELETE</http-method>
-              <http-method>HEAD</http-method>
-           </web-resource-collection>
-           <auth-constraint>
-               <role-name>System-Admin</role-name>
-               <role-name>Network-Admin</role-name>
-               <role-name>Network-Operator</role-name>
-               <role-name>Container-User</role-name>
-           </auth-constraint>
-        </security-constraint>
-
-        <security-role>
-                <role-name>System-Admin</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Network-Admin</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Network-Operator</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Container-User</role-name>
-        </security-role>
-
-
-        <login-config>
-                <auth-method>FORM</auth-method>
-                <form-login-config>
-                        <form-login-page>/WEB-INF/jsp/login.jsp</form-login-page>
-                        <form-error-page>/WEB-INF/jsp/error.jsp</form-error-page>
-                </form-login-config>
-        </login-config>
-
-    <error-page>
-            <error-code>403</error-code>
-            <location>/WEB-INF/jsp/autherror.jsp</location>
-    </error-page>
-
-        <servlet>
-                <servlet-name>RootGUI</servlet-name>
-                <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
-                <load-on-startup>1</load-on-startup>
-        </servlet>
-
-        <servlet-mapping>
-                <servlet-name>RootGUI</servlet-name>
-                <url-pattern>/</url-pattern>
-        </servlet-mapping>
-
-        <display-name>OpenDaylight Controller</display-name>
-        <description>OpenDaylight Controller</description>
-
-        <listener>
-                <listener-class>org.opendaylight.controller.web.ControllerUISessionManager</listener-class>
-        </listener>
-
-        <session-config>
-                <cookie-config>
-                        <path>/</path>
-                </cookie-config>
-        </session-config>
-
-</web-app>
diff --git a/opendaylight/adsal/web/root/src/main/resources/css/bootstrap.min.css b/opendaylight/adsal/web/root/src/main/resources/css/bootstrap.min.css
deleted file mode 100644 (file)
index fd5ed73..0000000
+++ /dev/null
@@ -1,9 +0,0 @@
-/*!
- * Bootstrap v2.3.0
- *
- * Copyright 2012 Twitter, Inc
- * Licensed under the Apache License v2.0
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Designed and built with all the love in the world @twitter by @mdo and @fat.
- */.clearfix{*zoom:1}.clearfix:before,.clearfix:after{display:table;line-height:0;content:""}.clearfix:after{clear:both}.hide-text{font:0/0 a;color:transparent;text-shadow:none;background-color:transparent;border:0}.input-block-level{display:block;width:100%;min-height:30px;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}article,aside,details,figcaption,figure,footer,header,hgroup,nav,section{display:block}audio,canvas,video{display:inline-block;*display:inline;*zoom:1}audio:not([controls]){display:none}html{font-size:100%;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%}a:focus{outline:thin dotted #333;outline:5px auto -webkit-focus-ring-color;outline-offset:-2px}a:hover,a:active{outline:0}sub,sup{position:relative;font-size:75%;line-height:0;vertical-align:baseline}sup{top:-0.5em}sub{bottom:-0.25em}img{width:auto\9;height:auto;max-width:100%;vertical-align:middle;border:0;-ms-interpolation-mode:bicubic}#map_canvas img,.google-maps img{max-width:none}button,input,select,textarea{margin:0;font-size:100%;vertical-align:middle}button,input{*overflow:visible;line-height:normal}button::-moz-focus-inner,input::-moz-focus-inner{padding:0;border:0}button,html input[type="button"],input[type="reset"],input[type="submit"]{cursor:pointer;-webkit-appearance:button}label,select,button,input[type="button"],input[type="reset"],input[type="submit"],input[type="radio"],input[type="checkbox"]{cursor:pointer}input[type="search"]{-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box;-webkit-appearance:textfield}input[type="search"]::-webkit-search-decoration,input[type="search"]::-webkit-search-cancel-button{-webkit-appearance:none}textarea{overflow:auto;vertical-align:top}@media print{*{color:#000!important;text-shadow:none!important;background:transparent!important;box-shadow:none!important}a,a:visited{text-decoration:underline}a[href]:after{content:" (" attr(href) ")"}abbr[title]:after{content:" (" attr(title) ")"}.ir a:after,a[href^="javascript:"]:after,a[href^="#"]:after{content:""}pre,blockquote{border:1px solid #999;page-break-inside:avoid}thead{display:table-header-group}tr,img{page-break-inside:avoid}img{max-width:100%!important}@page{margin:.5cm}p,h2,h3{orphans:3;widows:3}h2,h3{page-break-after:avoid}}body{margin:0;font-family:"Helvetica Neue",Helvetica,Arial,sans-serif;font-size:14px;line-height:20px;color:#333;background-color:#fff}a{color:#08c;text-decoration:none}a:hover,a:focus{color:#005580;text-decoration:underline}.img-rounded{-webkit-border-radius:6px;-moz-border-radius:6px;border-radius:6px}.img-polaroid{padding:4px;background-color:#fff;border:1px solid #ccc;border:1px solid rgba(0,0,0,0.2);-webkit-box-shadow:0 1px 3px rgba(0,0,0,0.1);-moz-box-shadow:0 1px 3px rgba(0,0,0,0.1);box-shadow:0 1px 3px rgba(0,0,0,0.1)}.img-circle{-webkit-border-radius:500px;-moz-border-radius:500px;border-radius:500px}.row{margin-left:-20px;*zoom:1}.row:before,.row:after{display:table;line-height:0;content:""}.row:after{clear:both}[class*="span"]{float:left;min-height:1px;margin-left:20px}.container,.navbar-static-top .container,.navbar-fixed-top .container,.navbar-fixed-bottom .container{width:940px}.span12{width:940px}.span11{width:860px}.span10{width:780px}.span9{width:700px}.span8{width:620px}.span7{width:540px}.span6{width:460px}.span5{width:380px}.span4{width:300px}.span3{width:220px}.span2{width:140px}.span1{width:60px}.offset12{margin-left:980px}.offset11{margin-left:900px}.offset10{margin-left:820px}.offset9{margin-left:740px}.offset8{margin-left:660px}.offset7{margin-left:580px}.offset6{margin-left:500px}.offset5{margin-left:420px}.offset4{margin-left:340px}.offset3{margin-left:260px}.offset2{margin-left:180px}.offset1{margin-left:100px}.row-fluid{width:100%;*zoom:1}.row-fluid:before,.row-fluid:after{display:table;line-height:0;content:""}.row-fluid:after{clear:both}.row-fluid [class*="span"]{display:block;float:left;width:100%;min-height:30px;margin-left:2.127659574468085%;*margin-left:2.074468085106383%;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}.row-fluid [class*="span"]:first-child{margin-left:0}.row-fluid .controls-row [class*="span"]+[class*="span"]{margin-left:2.127659574468085%}.row-fluid .span12{width:100%;*width:99.94680851063829%}.row-fluid .span11{width:91.48936170212765%;*width:91.43617021276594%}.row-fluid .span10{width:82.97872340425532%;*width:82.92553191489361%}.row-fluid .span9{width:74.46808510638297%;*width:74.41489361702126%}.row-fluid .span8{width:65.95744680851064%;*width:65.90425531914893%}.row-fluid .span7{width:57.44680851063829%;*width:57.39361702127659%}.row-fluid .span6{width:48.93617021276595%;*width:48.88297872340425%}.row-fluid .span5{width:40.42553191489362%;*width:40.37234042553192%}.row-fluid .span4{width:31.914893617021278%;*width:31.861702127659576%}.row-fluid .span3{width:23.404255319148934%;*width:23.351063829787233%}.row-fluid .span2{width:14.893617021276595%;*width:14.840425531914894%}.row-fluid .span1{width:6.382978723404255%;*width:6.329787234042553%}.row-fluid .offset12{margin-left:104.25531914893617%;*margin-left:104.14893617021275%}.row-fluid .offset12:first-child{margin-left:102.12765957446808%;*margin-left:102.02127659574467%}.row-fluid .offset11{margin-left:95.74468085106382%;*margin-left:95.6382978723404%}.row-fluid .offset11:first-child{margin-left:93.61702127659574%;*margin-left:93.51063829787232%}.row-fluid .offset10{margin-left:87.23404255319149%;*margin-left:87.12765957446807%}.row-fluid .offset10:first-child{margin-left:85.1063829787234%;*margin-left:84.99999999999999%}.row-fluid .offset9{margin-left:78.72340425531914%;*margin-left:78.61702127659572%}.row-fluid .offset9:first-child{margin-left:76.59574468085106%;*margin-left:76.48936170212764%}.row-fluid .offset8{margin-left:70.2127659574468%;*margin-left:70.10638297872339%}.row-fluid .offset8:first-child{margin-left:68.08510638297872%;*margin-left:67.9787234042553%}.row-fluid .offset7{margin-left:61.70212765957446%;*margin-left:61.59574468085106%}.row-fluid .offset7:first-child{margin-left:59.574468085106375%;*margin-left:59.46808510638297%}.row-fluid .offset6{margin-left:53.191489361702125%;*margin-left:53.085106382978715%}.row-fluid .offset6:first-child{margin-left:51.063829787234035%;*margin-left:50.95744680851063%}.row-fluid .offset5{margin-left:44.68085106382979%;*margin-left:44.57446808510638%}.row-fluid .offset5:first-child{margin-left:42.5531914893617%;*margin-left:42.4468085106383%}.row-fluid .offset4{margin-left:36.170212765957444%;*margin-left:36.06382978723405%}.row-fluid .offset4:first-child{margin-left:34.04255319148936%;*margin-left:33.93617021276596%}.row-fluid .offset3{margin-left:27.659574468085104%;*margin-left:27.5531914893617%}.row-fluid .offset3:first-child{margin-left:25.53191489361702%;*margin-left:25.425531914893618%}.row-fluid .offset2{margin-left:19.148936170212764%;*margin-left:19.04255319148936%}.row-fluid .offset2:first-child{margin-left:17.02127659574468%;*margin-left:16.914893617021278%}.row-fluid .offset1{margin-left:10.638297872340425%;*margin-left:10.53191489361702%}.row-fluid .offset1:first-child{margin-left:8.51063829787234%;*margin-left:8.404255319148938%}[class*="span"].hide,.row-fluid [class*="span"].hide{display:none}[class*="span"].pull-right,.row-fluid [class*="span"].pull-right{float:right}.container{margin-right:auto;margin-left:auto;*zoom:1}.container:before,.container:after{display:table;line-height:0;content:""}.container:after{clear:both}.container-fluid{padding-right:20px;padding-left:20px;*zoom:1}.container-fluid:before,.container-fluid:after{display:table;line-height:0;content:""}.container-fluid:after{clear:both}p{margin:0 0 10px}.lead{margin-bottom:20px;font-size:21px;font-weight:200;line-height:30px}small{font-size:85%}strong{font-weight:bold}em{font-style:italic}cite{font-style:normal}.muted{color:#999}a.muted:hover,a.muted:focus{color:#808080}.text-warning{color:#c09853}a.text-warning:hover,a.text-warning:focus{color:#a47e3c}.text-error{color:#b94a48}a.text-error:hover,a.text-error:focus{color:#953b39}.text-info{color:#3a87ad}a.text-info:hover,a.text-info:focus{color:#2d6987}.text-success{color:#468847}a.text-success:hover,a.text-success:focus{color:#356635}.text-left{text-align:left}.text-right{text-align:right}.text-center{text-align:center}h1,h2,h3,h4,h5,h6{margin:10px 0;font-family:inherit;font-weight:bold;line-height:20px;color:inherit;text-rendering:optimizelegibility}h1 small,h2 small,h3 small,h4 small,h5 small,h6 small{font-weight:normal;line-height:1;color:#999}h1,h2,h3{line-height:40px}h1{font-size:38.5px}h2{font-size:31.5px}h3{font-size:24.5px}h4{font-size:17.5px}h5{font-size:14px}h6{font-size:11.9px}h1 small{font-size:24.5px}h2 small{font-size:17.5px}h3 small{font-size:14px}h4 small{font-size:14px}.page-header{padding-bottom:9px;margin:20px 0 30px;border-bottom:1px solid #eee}ul,ol{padding:0;margin:0 0 10px 25px}ul ul,ul ol,ol ol,ol ul{margin-bottom:0}li{line-height:20px}ul.unstyled,ol.unstyled{margin-left:0;list-style:none}ul.inline,ol.inline{margin-left:0;list-style:none}ul.inline>li,ol.inline>li{display:inline-block;*display:inline;padding-right:5px;padding-left:5px;*zoom:1}dl{margin-bottom:20px}dt,dd{line-height:20px}dt{font-weight:bold}dd{margin-left:10px}.dl-horizontal{*zoom:1}.dl-horizontal:before,.dl-horizontal:after{display:table;line-height:0;content:""}.dl-horizontal:after{clear:both}.dl-horizontal dt{float:left;width:160px;overflow:hidden;clear:left;text-align:right;text-overflow:ellipsis;white-space:nowrap}.dl-horizontal dd{margin-left:180px}hr{margin:20px 0;border:0;border-top:1px solid #eee;border-bottom:1px solid #fff}abbr[title],abbr[data-original-title]{cursor:help;border-bottom:1px dotted #999}abbr.initialism{font-size:90%;text-transform:uppercase}blockquote{padding:0 0 0 15px;margin:0 0 20px;border-left:5px solid #eee}blockquote p{margin-bottom:0;font-size:17.5px;font-weight:300;line-height:1.25}blockquote small{display:block;line-height:20px;color:#999}blockquote small:before{content:'\2014 \00A0'}blockquote.pull-right{float:right;padding-right:15px;padding-left:0;border-right:5px solid #eee;border-left:0}blockquote.pull-right p,blockquote.pull-right small{text-align:right}blockquote.pull-right small:before{content:''}blockquote.pull-right small:after{content:'\00A0 \2014'}q:before,q:after,blockquote:before,blockquote:after{content:""}address{display:block;margin-bottom:20px;font-style:normal;line-height:20px}code,pre{padding:0 3px 2px;font-family:Monaco,Menlo,Consolas,"Courier New",monospace;font-size:12px;color:#333;-webkit-border-radius:3px;-moz-border-radius:3px;border-radius:3px}code{padding:2px 4px;color:#d14;white-space:nowrap;background-color:#f7f7f9;border:1px solid #e1e1e8}pre{display:block;padding:9.5px;margin:0 0 10px;font-size:13px;line-height:20px;word-break:break-all;word-wrap:break-word;white-space:pre;white-space:pre-wrap;background-color:#f5f5f5;border:1px solid #ccc;border:1px solid rgba(0,0,0,0.15);-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px}pre.prettyprint{margin-bottom:20px}pre code{padding:0;color:inherit;white-space:pre;white-space:pre-wrap;background-color:transparent;border:0}.pre-scrollable{max-height:340px;overflow-y:scroll}form{margin:0 0 20px}fieldset{padding:0;margin:0;border:0}legend{display:block;width:100%;padding:0;margin-bottom:20px;font-size:21px;line-height:40px;color:#333;border:0;border-bottom:1px solid #e5e5e5}legend small{font-size:15px;color:#999}label,input,button,select,textarea{font-size:14px;font-weight:normal;line-height:20px}input,button,select,textarea{font-family:"Helvetica Neue",Helvetica,Arial,sans-serif}label{display:block;margin-bottom:5px}select,textarea,input[type="text"],input[type="password"],input[type="datetime"],input[type="datetime-local"],input[type="date"],input[type="month"],input[type="time"],input[type="week"],input[type="number"],input[type="email"],input[type="url"],input[type="search"],input[type="tel"],input[type="color"],.uneditable-input{display:inline-block;height:20px;padding:4px 6px;margin-bottom:10px;font-size:14px;line-height:20px;color:#555;vertical-align:middle;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px}input,textarea,.uneditable-input{width:206px}textarea{height:auto}textarea,input[type="text"],input[type="password"],input[type="datetime"],input[type="datetime-local"],input[type="date"],input[type="month"],input[type="time"],input[type="week"],input[type="number"],input[type="email"],input[type="url"],input[type="search"],input[type="tel"],input[type="color"],.uneditable-input{background-color:#fff;border:1px solid #ccc;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075);-moz-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075);box-shadow:inset 0 1px 1px rgba(0,0,0,0.075);-webkit-transition:border linear .2s,box-shadow linear .2s;-moz-transition:border linear .2s,box-shadow linear .2s;-o-transition:border linear .2s,box-shadow linear .2s;transition:border linear .2s,box-shadow linear .2s}textarea:focus,input[type="text"]:focus,input[type="password"]:focus,input[type="datetime"]:focus,input[type="datetime-local"]:focus,input[type="date"]:focus,input[type="month"]:focus,input[type="time"]:focus,input[type="week"]:focus,input[type="number"]:focus,input[type="email"]:focus,input[type="url"]:focus,input[type="search"]:focus,input[type="tel"]:focus,input[type="color"]:focus,.uneditable-input:focus{border-color:rgba(82,168,236,0.8);outline:0;outline:thin dotted \9;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 8px rgba(82,168,236,0.6);-moz-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 8px rgba(82,168,236,0.6);box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 8px rgba(82,168,236,0.6)}input[type="radio"],input[type="checkbox"]{margin:4px 0 0;margin-top:1px \9;*margin-top:0;line-height:normal}input[type="file"],input[type="image"],input[type="submit"],input[type="reset"],input[type="button"],input[type="radio"],input[type="checkbox"]{width:auto}select,input[type="file"]{height:30px;*margin-top:4px;line-height:30px}select{width:220px;background-color:#fff;border:1px solid #ccc}select[multiple],select[size]{height:auto}select:focus,input[type="file"]:focus,input[type="radio"]:focus,input[type="checkbox"]:focus{outline:thin dotted #333;outline:5px auto -webkit-focus-ring-color;outline-offset:-2px}.uneditable-input,.uneditable-textarea{color:#999;cursor:not-allowed;background-color:#fcfcfc;border-color:#ccc;-webkit-box-shadow:inset 0 1px 2px rgba(0,0,0,0.025);-moz-box-shadow:inset 0 1px 2px rgba(0,0,0,0.025);box-shadow:inset 0 1px 2px rgba(0,0,0,0.025)}.uneditable-input{overflow:hidden;white-space:nowrap}.uneditable-textarea{width:auto;height:auto}input:-moz-placeholder,textarea:-moz-placeholder{color:#999}input:-ms-input-placeholder,textarea:-ms-input-placeholder{color:#999}input::-webkit-input-placeholder,textarea::-webkit-input-placeholder{color:#999}.radio,.checkbox{min-height:20px;padding-left:20px}.radio input[type="radio"],.checkbox input[type="checkbox"]{float:left;margin-left:-20px}.controls>.radio:first-child,.controls>.checkbox:first-child{padding-top:5px}.radio.inline,.checkbox.inline{display:inline-block;padding-top:5px;margin-bottom:0;vertical-align:middle}.radio.inline+.radio.inline,.checkbox.inline+.checkbox.inline{margin-left:10px}.input-mini{width:60px}.input-small{width:90px}.input-medium{width:150px}.input-large{width:210px}.input-xlarge{width:270px}.input-xxlarge{width:530px}input[class*="span"],select[class*="span"],textarea[class*="span"],.uneditable-input[class*="span"],.row-fluid input[class*="span"],.row-fluid select[class*="span"],.row-fluid textarea[class*="span"],.row-fluid .uneditable-input[class*="span"]{float:none;margin-left:0}.input-append input[class*="span"],.input-append .uneditable-input[class*="span"],.input-prepend input[class*="span"],.input-prepend .uneditable-input[class*="span"],.row-fluid input[class*="span"],.row-fluid select[class*="span"],.row-fluid textarea[class*="span"],.row-fluid .uneditable-input[class*="span"],.row-fluid .input-prepend [class*="span"],.row-fluid .input-append [class*="span"]{display:inline-block}input,textarea,.uneditable-input{margin-left:0}.controls-row [class*="span"]+[class*="span"]{margin-left:20px}input.span12,textarea.span12,.uneditable-input.span12{width:926px}input.span11,textarea.span11,.uneditable-input.span11{width:846px}input.span10,textarea.span10,.uneditable-input.span10{width:766px}input.span9,textarea.span9,.uneditable-input.span9{width:686px}input.span8,textarea.span8,.uneditable-input.span8{width:606px}input.span7,textarea.span7,.uneditable-input.span7{width:526px}input.span6,textarea.span6,.uneditable-input.span6{width:446px}input.span5,textarea.span5,.uneditable-input.span5{width:366px}input.span4,textarea.span4,.uneditable-input.span4{width:286px}input.span3,textarea.span3,.uneditable-input.span3{width:206px}input.span2,textarea.span2,.uneditable-input.span2{width:126px}input.span1,textarea.span1,.uneditable-input.span1{width:46px}.controls-row{*zoom:1}.controls-row:before,.controls-row:after{display:table;line-height:0;content:""}.controls-row:after{clear:both}.controls-row [class*="span"],.row-fluid .controls-row [class*="span"]{float:left}.controls-row .checkbox[class*="span"],.controls-row .radio[class*="span"]{padding-top:5px}input[disabled],select[disabled],textarea[disabled],input[readonly],select[readonly],textarea[readonly]{cursor:not-allowed;background-color:#eee}input[type="radio"][disabled],input[type="checkbox"][disabled],input[type="radio"][readonly],input[type="checkbox"][readonly]{background-color:transparent}.control-group.warning .control-label,.control-group.warning .help-block,.control-group.warning .help-inline{color:#c09853}.control-group.warning .checkbox,.control-group.warning .radio,.control-group.warning input,.control-group.warning select,.control-group.warning textarea{color:#c09853}.control-group.warning input,.control-group.warning select,.control-group.warning textarea{border-color:#c09853;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075);-moz-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075);box-shadow:inset 0 1px 1px rgba(0,0,0,0.075)}.control-group.warning input:focus,.control-group.warning select:focus,.control-group.warning textarea:focus{border-color:#a47e3c;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 6px #dbc59e;-moz-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 6px #dbc59e;box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 6px #dbc59e}.control-group.warning .input-prepend .add-on,.control-group.warning .input-append .add-on{color:#c09853;background-color:#fcf8e3;border-color:#c09853}.control-group.error .control-label,.control-group.error .help-block,.control-group.error .help-inline{color:#b94a48}.control-group.error .checkbox,.control-group.error .radio,.control-group.error input,.control-group.error select,.control-group.error textarea{color:#b94a48}.control-group.error input,.control-group.error select,.control-group.error textarea{border-color:#b94a48;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075);-moz-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075);box-shadow:inset 0 1px 1px rgba(0,0,0,0.075)}.control-group.error input:focus,.control-group.error select:focus,.control-group.error textarea:focus{border-color:#953b39;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 6px #d59392;-moz-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 6px #d59392;box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 6px #d59392}.control-group.error .input-prepend .add-on,.control-group.error .input-append .add-on{color:#b94a48;background-color:#f2dede;border-color:#b94a48}.control-group.success .control-label,.control-group.success .help-block,.control-group.success .help-inline{color:#468847}.control-group.success .checkbox,.control-group.success .radio,.control-group.success input,.control-group.success select,.control-group.success textarea{color:#468847}.control-group.success input,.control-group.success select,.control-group.success textarea{border-color:#468847;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075);-moz-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075);box-shadow:inset 0 1px 1px rgba(0,0,0,0.075)}.control-group.success input:focus,.control-group.success select:focus,.control-group.success textarea:focus{border-color:#356635;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 6px #7aba7b;-moz-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 6px #7aba7b;box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 6px #7aba7b}.control-group.success .input-prepend .add-on,.control-group.success .input-append .add-on{color:#468847;background-color:#dff0d8;border-color:#468847}.control-group.info .control-label,.control-group.info .help-block,.control-group.info .help-inline{color:#3a87ad}.control-group.info .checkbox,.control-group.info .radio,.control-group.info input,.control-group.info select,.control-group.info textarea{color:#3a87ad}.control-group.info input,.control-group.info select,.control-group.info textarea{border-color:#3a87ad;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075);-moz-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075);box-shadow:inset 0 1px 1px rgba(0,0,0,0.075)}.control-group.info input:focus,.control-group.info select:focus,.control-group.info textarea:focus{border-color:#2d6987;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 6px #7ab5d3;-moz-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 6px #7ab5d3;box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 6px #7ab5d3}.control-group.info .input-prepend .add-on,.control-group.info .input-append .add-on{color:#3a87ad;background-color:#d9edf7;border-color:#3a87ad}input:focus:invalid,textarea:focus:invalid,select:focus:invalid{color:#b94a48;border-color:#ee5f5b}input:focus:invalid:focus,textarea:focus:invalid:focus,select:focus:invalid:focus{border-color:#e9322d;-webkit-box-shadow:0 0 6px #f8b9b7;-moz-box-shadow:0 0 6px #f8b9b7;box-shadow:0 0 6px #f8b9b7}.form-actions{padding:19px 20px 20px;margin-top:20px;margin-bottom:20px;background-color:#f5f5f5;border-top:1px solid #e5e5e5;*zoom:1}.form-actions:before,.form-actions:after{display:table;line-height:0;content:""}.form-actions:after{clear:both}.help-block,.help-inline{color:#595959}.help-block{display:block;margin-bottom:10px}.help-inline{display:inline-block;*display:inline;padding-left:5px;vertical-align:middle;*zoom:1}.input-append,.input-prepend{display:inline-block;margin-bottom:10px;font-size:0;white-space:nowrap;vertical-align:middle}.input-append input,.input-prepend input,.input-append select,.input-prepend select,.input-append .uneditable-input,.input-prepend .uneditable-input,.input-append .dropdown-menu,.input-prepend .dropdown-menu,.input-append .popover,.input-prepend .popover{font-size:14px}.input-append input,.input-prepend input,.input-append select,.input-prepend select,.input-append .uneditable-input,.input-prepend .uneditable-input{position:relative;margin-bottom:0;*margin-left:0;vertical-align:top;-webkit-border-radius:0 4px 4px 0;-moz-border-radius:0 4px 4px 0;border-radius:0 4px 4px 0}.input-append input:focus,.input-prepend input:focus,.input-append select:focus,.input-prepend select:focus,.input-append .uneditable-input:focus,.input-prepend .uneditable-input:focus{z-index:2}.input-append .add-on,.input-prepend .add-on{display:inline-block;width:auto;height:20px;min-width:16px;padding:4px 5px;font-size:14px;font-weight:normal;line-height:20px;text-align:center;text-shadow:0 1px 0 #fff;background-color:#eee;border:1px solid #ccc}.input-append .add-on,.input-prepend .add-on,.input-append .btn,.input-prepend .btn,.input-append .btn-group>.dropdown-toggle,.input-prepend .btn-group>.dropdown-toggle{vertical-align:top;-webkit-border-radius:0;-moz-border-radius:0;border-radius:0}.input-append .active,.input-prepend .active{background-color:#a9dba9;border-color:#46a546}.input-prepend .add-on,.input-prepend .btn{margin-right:-1px}.input-prepend .add-on:first-child,.input-prepend .btn:first-child{-webkit-border-radius:4px 0 0 4px;-moz-border-radius:4px 0 0 4px;border-radius:4px 0 0 4px}.input-append input,.input-append select,.input-append .uneditable-input{-webkit-border-radius:4px 0 0 4px;-moz-border-radius:4px 0 0 4px;border-radius:4px 0 0 4px}.input-append input+.btn-group .btn:last-child,.input-append select+.btn-group .btn:last-child,.input-append .uneditable-input+.btn-group .btn:last-child{-webkit-border-radius:0 4px 4px 0;-moz-border-radius:0 4px 4px 0;border-radius:0 4px 4px 0}.input-append .add-on,.input-append .btn,.input-append .btn-group{margin-left:-1px}.input-append .add-on:last-child,.input-append .btn:last-child,.input-append .btn-group:last-child>.dropdown-toggle{-webkit-border-radius:0 4px 4px 0;-moz-border-radius:0 4px 4px 0;border-radius:0 4px 4px 0}.input-prepend.input-append input,.input-prepend.input-append select,.input-prepend.input-append .uneditable-input{-webkit-border-radius:0;-moz-border-radius:0;border-radius:0}.input-prepend.input-append input+.btn-group .btn,.input-prepend.input-append select+.btn-group .btn,.input-prepend.input-append .uneditable-input+.btn-group .btn{-webkit-border-radius:0 4px 4px 0;-moz-border-radius:0 4px 4px 0;border-radius:0 4px 4px 0}.input-prepend.input-append .add-on:first-child,.input-prepend.input-append .btn:first-child{margin-right:-1px;-webkit-border-radius:4px 0 0 4px;-moz-border-radius:4px 0 0 4px;border-radius:4px 0 0 4px}.input-prepend.input-append .add-on:last-child,.input-prepend.input-append .btn:last-child{margin-left:-1px;-webkit-border-radius:0 4px 4px 0;-moz-border-radius:0 4px 4px 0;border-radius:0 4px 4px 0}.input-prepend.input-append .btn-group:first-child{margin-left:0}input.search-query{padding-right:14px;padding-right:4px \9;padding-left:14px;padding-left:4px \9;margin-bottom:0;-webkit-border-radius:15px;-moz-border-radius:15px;border-radius:15px}.form-search .input-append .search-query,.form-search .input-prepend .search-query{-webkit-border-radius:0;-moz-border-radius:0;border-radius:0}.form-search .input-append .search-query{-webkit-border-radius:14px 0 0 14px;-moz-border-radius:14px 0 0 14px;border-radius:14px 0 0 14px}.form-search .input-append .btn{-webkit-border-radius:0 14px 14px 0;-moz-border-radius:0 14px 14px 0;border-radius:0 14px 14px 0}.form-search .input-prepend .search-query{-webkit-border-radius:0 14px 14px 0;-moz-border-radius:0 14px 14px 0;border-radius:0 14px 14px 0}.form-search .input-prepend .btn{-webkit-border-radius:14px 0 0 14px;-moz-border-radius:14px 0 0 14px;border-radius:14px 0 0 14px}.form-search input,.form-inline input,.form-horizontal input,.form-search textarea,.form-inline textarea,.form-horizontal textarea,.form-search select,.form-inline select,.form-horizontal select,.form-search .help-inline,.form-inline .help-inline,.form-horizontal .help-inline,.form-search .uneditable-input,.form-inline .uneditable-input,.form-horizontal .uneditable-input,.form-search .input-prepend,.form-inline .input-prepend,.form-horizontal .input-prepend,.form-search .input-append,.form-inline .input-append,.form-horizontal .input-append{display:inline-block;*display:inline;margin-bottom:0;vertical-align:middle;*zoom:1}.form-search .hide,.form-inline .hide,.form-horizontal .hide{display:none}.form-search label,.form-inline label,.form-search .btn-group,.form-inline .btn-group{display:inline-block}.form-search .input-append,.form-inline .input-append,.form-search .input-prepend,.form-inline .input-prepend{margin-bottom:0}.form-search .radio,.form-search .checkbox,.form-inline .radio,.form-inline .checkbox{padding-left:0;margin-bottom:0;vertical-align:middle}.form-search .radio input[type="radio"],.form-search .checkbox input[type="checkbox"],.form-inline .radio input[type="radio"],.form-inline .checkbox input[type="checkbox"]{float:left;margin-right:3px;margin-left:0}.control-group{margin-bottom:10px}legend+.control-group{margin-top:20px;-webkit-margin-top-collapse:separate}.form-horizontal .control-group{margin-bottom:20px;*zoom:1}.form-horizontal .control-group:before,.form-horizontal .control-group:after{display:table;line-height:0;content:""}.form-horizontal .control-group:after{clear:both}.form-horizontal .control-label{float:left;width:160px;padding-top:5px;text-align:right}.form-horizontal .controls{*display:inline-block;*padding-left:20px;margin-left:180px;*margin-left:0}.form-horizontal .controls:first-child{*padding-left:180px}.form-horizontal .help-block{margin-bottom:0}.form-horizontal input+.help-block,.form-horizontal select+.help-block,.form-horizontal textarea+.help-block,.form-horizontal .uneditable-input+.help-block,.form-horizontal .input-prepend+.help-block,.form-horizontal .input-append+.help-block{margin-top:10px}.form-horizontal .form-actions{padding-left:180px}table{max-width:100%;background-color:transparent;border-collapse:collapse;border-spacing:0}.table{width:100%;margin-bottom:20px}.table th,.table td{padding:8px;line-height:20px;text-align:left;vertical-align:top;border-top:1px solid #ddd}.table th{font-weight:bold}.table thead th{vertical-align:bottom}.table caption+thead tr:first-child th,.table caption+thead tr:first-child td,.table colgroup+thead tr:first-child th,.table colgroup+thead tr:first-child td,.table thead:first-child tr:first-child th,.table thead:first-child tr:first-child td{border-top:0}.table tbody+tbody{border-top:2px solid #ddd}.table .table{background-color:#fff}.table-condensed th,.table-condensed td{padding:4px 5px}.table-bordered{border:1px solid #ddd;border-collapse:separate;*border-collapse:collapse;border-left:0;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px}.table-bordered th,.table-bordered td{border-left:1px solid #ddd}.table-bordered caption+thead tr:first-child th,.table-bordered caption+tbody tr:first-child th,.table-bordered caption+tbody tr:first-child td,.table-bordered colgroup+thead tr:first-child th,.table-bordered colgroup+tbody tr:first-child th,.table-bordered colgroup+tbody tr:first-child td,.table-bordered thead:first-child tr:first-child th,.table-bordered tbody:first-child tr:first-child th,.table-bordered tbody:first-child tr:first-child td{border-top:0}.table-bordered thead:first-child tr:first-child>th:first-child,.table-bordered tbody:first-child tr:first-child>td:first-child,.table-bordered tbody:first-child tr:first-child>th:first-child{-webkit-border-top-left-radius:4px;border-top-left-radius:4px;-moz-border-radius-topleft:4px}.table-bordered thead:first-child tr:first-child>th:last-child,.table-bordered tbody:first-child tr:first-child>td:last-child,.table-bordered tbody:first-child tr:first-child>th:last-child{-webkit-border-top-right-radius:4px;border-top-right-radius:4px;-moz-border-radius-topright:4px}.table-bordered thead:last-child tr:last-child>th:first-child,.table-bordered tbody:last-child tr:last-child>td:first-child,.table-bordered tbody:last-child tr:last-child>th:first-child,.table-bordered tfoot:last-child tr:last-child>td:first-child,.table-bordered tfoot:last-child tr:last-child>th:first-child{-webkit-border-bottom-left-radius:4px;border-bottom-left-radius:4px;-moz-border-radius-bottomleft:4px}.table-bordered thead:last-child tr:last-child>th:last-child,.table-bordered tbody:last-child tr:last-child>td:last-child,.table-bordered tbody:last-child tr:last-child>th:last-child,.table-bordered tfoot:last-child tr:last-child>td:last-child,.table-bordered tfoot:last-child tr:last-child>th:last-child{-webkit-border-bottom-right-radius:4px;border-bottom-right-radius:4px;-moz-border-radius-bottomright:4px}.table-bordered tfoot+tbody:last-child tr:last-child td:first-child{-webkit-border-bottom-left-radius:0;border-bottom-left-radius:0;-moz-border-radius-bottomleft:0}.table-bordered tfoot+tbody:last-child tr:last-child td:last-child{-webkit-border-bottom-right-radius:0;border-bottom-right-radius:0;-moz-border-radius-bottomright:0}.table-bordered caption+thead tr:first-child th:first-child,.table-bordered caption+tbody tr:first-child td:first-child,.table-bordered colgroup+thead tr:first-child th:first-child,.table-bordered colgroup+tbody tr:first-child td:first-child{-webkit-border-top-left-radius:4px;border-top-left-radius:4px;-moz-border-radius-topleft:4px}.table-bordered caption+thead tr:first-child th:last-child,.table-bordered caption+tbody tr:first-child td:last-child,.table-bordered colgroup+thead tr:first-child th:last-child,.table-bordered colgroup+tbody tr:first-child td:last-child{-webkit-border-top-right-radius:4px;border-top-right-radius:4px;-moz-border-radius-topright:4px}.table-striped tbody>tr:nth-child(odd)>td,.table-striped tbody>tr:nth-child(odd)>th{background-color:#f9f9f9}.table-hover tbody tr:hover>td,.table-hover tbody tr:hover>th{background-color:#f5f5f5}table td[class*="span"],table th[class*="span"],.row-fluid table td[class*="span"],.row-fluid table th[class*="span"]{display:table-cell;float:none;margin-left:0}.table td.span1,.table th.span1{float:none;width:44px;margin-left:0}.table td.span2,.table th.span2{float:none;width:124px;margin-left:0}.table td.span3,.table th.span3{float:none;width:204px;margin-left:0}.table td.span4,.table th.span4{float:none;width:284px;margin-left:0}.table td.span5,.table th.span5{float:none;width:364px;margin-left:0}.table td.span6,.table th.span6{float:none;width:444px;margin-left:0}.table td.span7,.table th.span7{float:none;width:524px;margin-left:0}.table td.span8,.table th.span8{float:none;width:604px;margin-left:0}.table td.span9,.table th.span9{float:none;width:684px;margin-left:0}.table td.span10,.table th.span10{float:none;width:764px;margin-left:0}.table td.span11,.table th.span11{float:none;width:844px;margin-left:0}.table td.span12,.table th.span12{float:none;width:924px;margin-left:0}.table tbody tr.success>td{background-color:#dff0d8}.table tbody tr.error>td{background-color:#f2dede}.table tbody tr.warning>td{background-color:#fcf8e3}.table tbody tr.info>td{background-color:#d9edf7}.table-hover tbody tr.success:hover>td{background-color:#d0e9c6}.table-hover tbody tr.error:hover>td{background-color:#ebcccc}.table-hover tbody tr.warning:hover>td{background-color:#faf2cc}.table-hover tbody tr.info:hover>td{background-color:#c4e3f3}[class^="icon-"],[class*=" icon-"]{display:inline-block;width:14px;height:14px;margin-top:1px;*margin-right:.3em;line-height:14px;vertical-align:text-top;background-image:url("../img/glyphicons-halflings.png");background-position:14px 14px;background-repeat:no-repeat}.icon-white,.nav-pills>.active>a>[class^="icon-"],.nav-pills>.active>a>[class*=" icon-"],.nav-list>.active>a>[class^="icon-"],.nav-list>.active>a>[class*=" icon-"],.navbar-inverse .nav>.active>a>[class^="icon-"],.navbar-inverse .nav>.active>a>[class*=" icon-"],.dropdown-menu>li>a:hover>[class^="icon-"],.dropdown-menu>li>a:focus>[class^="icon-"],.dropdown-menu>li>a:hover>[class*=" icon-"],.dropdown-menu>li>a:focus>[class*=" icon-"],.dropdown-menu>.active>a>[class^="icon-"],.dropdown-menu>.active>a>[class*=" icon-"],.dropdown-submenu:hover>a>[class^="icon-"],.dropdown-submenu:focus>a>[class^="icon-"],.dropdown-submenu:hover>a>[class*=" icon-"],.dropdown-submenu:focus>a>[class*=" icon-"]{background-image:url("../img/glyphicons-halflings-white.png")}.icon-glass{background-position:0 0}.icon-music{background-position:-24px 0}.icon-search{background-position:-48px 0}.icon-envelope{background-position:-72px 0}.icon-heart{background-position:-96px 0}.icon-star{background-position:-120px 0}.icon-star-empty{background-position:-144px 0}.icon-user{background-position:-168px 0}.icon-film{background-position:-192px 0}.icon-th-large{background-position:-216px 0}.icon-th{background-position:-240px 0}.icon-th-list{background-position:-264px 0}.icon-ok{background-position:-288px 0}.icon-remove{background-position:-312px 0}.icon-zoom-in{background-position:-336px 0}.icon-zoom-out{background-position:-360px 0}.icon-off{background-position:-384px 0}.icon-signal{background-position:-408px 0}.icon-cog{background-position:-432px 0}.icon-trash{background-position:-456px 0}.icon-home{background-position:0 -24px}.icon-file{background-position:-24px -24px}.icon-time{background-position:-48px -24px}.icon-road{background-position:-72px -24px}.icon-download-alt{background-position:-96px -24px}.icon-download{background-position:-120px -24px}.icon-upload{background-position:-144px -24px}.icon-inbox{background-position:-168px -24px}.icon-play-circle{background-position:-192px -24px}.icon-repeat{background-position:-216px -24px}.icon-refresh{background-position:-240px -24px}.icon-list-alt{background-position:-264px -24px}.icon-lock{background-position:-287px -24px}.icon-flag{background-position:-312px -24px}.icon-headphones{background-position:-336px -24px}.icon-volume-off{background-position:-360px -24px}.icon-volume-down{background-position:-384px -24px}.icon-volume-up{background-position:-408px -24px}.icon-qrcode{background-position:-432px -24px}.icon-barcode{background-position:-456px -24px}.icon-tag{background-position:0 -48px}.icon-tags{background-position:-25px -48px}.icon-book{background-position:-48px -48px}.icon-bookmark{background-position:-72px -48px}.icon-print{background-position:-96px -48px}.icon-camera{background-position:-120px -48px}.icon-font{background-position:-144px -48px}.icon-bold{background-position:-167px -48px}.icon-italic{background-position:-192px -48px}.icon-text-height{background-position:-216px -48px}.icon-text-width{background-position:-240px -48px}.icon-align-left{background-position:-264px -48px}.icon-align-center{background-position:-288px -48px}.icon-align-right{background-position:-312px -48px}.icon-align-justify{background-position:-336px -48px}.icon-list{background-position:-360px -48px}.icon-indent-left{background-position:-384px -48px}.icon-indent-right{background-position:-408px -48px}.icon-facetime-video{background-position:-432px -48px}.icon-picture{background-position:-456px -48px}.icon-pencil{background-position:0 -72px}.icon-map-marker{background-position:-24px -72px}.icon-adjust{background-position:-48px -72px}.icon-tint{background-position:-72px -72px}.icon-edit{background-position:-96px -72px}.icon-share{background-position:-120px -72px}.icon-check{background-position:-144px -72px}.icon-move{background-position:-168px -72px}.icon-step-backward{background-position:-192px -72px}.icon-fast-backward{background-position:-216px -72px}.icon-backward{background-position:-240px -72px}.icon-play{background-position:-264px -72px}.icon-pause{background-position:-288px -72px}.icon-stop{background-position:-312px -72px}.icon-forward{background-position:-336px -72px}.icon-fast-forward{background-position:-360px -72px}.icon-step-forward{background-position:-384px -72px}.icon-eject{background-position:-408px -72px}.icon-chevron-left{background-position:-432px -72px}.icon-chevron-right{background-position:-456px -72px}.icon-plus-sign{background-position:0 -96px}.icon-minus-sign{background-position:-24px -96px}.icon-remove-sign{background-position:-48px -96px}.icon-ok-sign{background-position:-72px -96px}.icon-question-sign{background-position:-96px -96px}.icon-info-sign{background-position:-120px -96px}.icon-screenshot{background-position:-144px -96px}.icon-remove-circle{background-position:-168px -96px}.icon-ok-circle{background-position:-192px -96px}.icon-ban-circle{background-position:-216px -96px}.icon-arrow-left{background-position:-240px -96px}.icon-arrow-right{background-position:-264px -96px}.icon-arrow-up{background-position:-289px -96px}.icon-arrow-down{background-position:-312px -96px}.icon-share-alt{background-position:-336px -96px}.icon-resize-full{background-position:-360px -96px}.icon-resize-small{background-position:-384px -96px}.icon-plus{background-position:-408px -96px}.icon-minus{background-position:-433px -96px}.icon-asterisk{background-position:-456px -96px}.icon-exclamation-sign{background-position:0 -120px}.icon-gift{background-position:-24px -120px}.icon-leaf{background-position:-48px -120px}.icon-fire{background-position:-72px -120px}.icon-eye-open{background-position:-96px -120px}.icon-eye-close{background-position:-120px -120px}.icon-warning-sign{background-position:-144px -120px}.icon-plane{background-position:-168px -120px}.icon-calendar{background-position:-192px -120px}.icon-random{width:16px;background-position:-216px -120px}.icon-comment{background-position:-240px -120px}.icon-magnet{background-position:-264px -120px}.icon-chevron-up{background-position:-288px -120px}.icon-chevron-down{background-position:-313px -119px}.icon-retweet{background-position:-336px -120px}.icon-shopping-cart{background-position:-360px -120px}.icon-folder-close{width:16px;background-position:-384px -120px}.icon-folder-open{width:16px;background-position:-408px -120px}.icon-resize-vertical{background-position:-432px -119px}.icon-resize-horizontal{background-position:-456px -118px}.icon-hdd{background-position:0 -144px}.icon-bullhorn{background-position:-24px -144px}.icon-bell{background-position:-48px -144px}.icon-certificate{background-position:-72px -144px}.icon-thumbs-up{background-position:-96px -144px}.icon-thumbs-down{background-position:-120px -144px}.icon-hand-right{background-position:-144px -144px}.icon-hand-left{background-position:-168px -144px}.icon-hand-up{background-position:-192px -144px}.icon-hand-down{background-position:-216px -144px}.icon-circle-arrow-right{background-position:-240px -144px}.icon-circle-arrow-left{background-position:-264px -144px}.icon-circle-arrow-up{background-position:-288px -144px}.icon-circle-arrow-down{background-position:-312px -144px}.icon-globe{background-position:-336px -144px}.icon-wrench{background-position:-360px -144px}.icon-tasks{background-position:-384px -144px}.icon-filter{background-position:-408px -144px}.icon-briefcase{background-position:-432px -144px}.icon-fullscreen{background-position:-456px -144px}.dropup,.dropdown{position:relative}.dropdown-toggle{*margin-bottom:-3px}.dropdown-toggle:active,.open .dropdown-toggle{outline:0}.caret{display:inline-block;width:0;height:0;vertical-align:top;border-top:4px solid #000;border-right:4px solid transparent;border-left:4px solid transparent;content:""}.dropdown .caret{margin-top:8px;margin-left:2px}.dropdown-menu{position:absolute;top:100%;left:0;z-index:1000;display:none;float:left;min-width:160px;padding:5px 0;margin:2px 0 0;list-style:none;background-color:#fff;border:1px solid #ccc;border:1px solid rgba(0,0,0,0.2);*border-right-width:2px;*border-bottom-width:2px;-webkit-border-radius:6px;-moz-border-radius:6px;border-radius:6px;-webkit-box-shadow:0 5px 10px rgba(0,0,0,0.2);-moz-box-shadow:0 5px 10px rgba(0,0,0,0.2);box-shadow:0 5px 10px rgba(0,0,0,0.2);-webkit-background-clip:padding-box;-moz-background-clip:padding;background-clip:padding-box}.dropdown-menu.pull-right{right:0;left:auto}.dropdown-menu .divider{*width:100%;height:1px;margin:9px 1px;*margin:-5px 0 5px;overflow:hidden;background-color:#e5e5e5;border-bottom:1px solid #fff}.dropdown-menu>li>a{display:block;padding:3px 20px;clear:both;font-weight:normal;line-height:20px;color:#333;white-space:nowrap}.dropdown-menu>li>a:hover,.dropdown-menu>li>a:focus,.dropdown-submenu:hover>a,.dropdown-submenu:focus>a{color:#fff;text-decoration:none;background-color:#0081c2;background-image:-moz-linear-gradient(top,#08c,#0077b3);background-image:-webkit-gradient(linear,0 0,0 100%,from(#08c),to(#0077b3));background-image:-webkit-linear-gradient(top,#08c,#0077b3);background-image:-o-linear-gradient(top,#08c,#0077b3);background-image:linear-gradient(to bottom,#08c,#0077b3);background-repeat:repeat-x;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff0088cc',endColorstr='#ff0077b3',GradientType=0)}.dropdown-menu>.active>a,.dropdown-menu>.active>a:hover,.dropdown-menu>.active>a:focus{color:#fff;text-decoration:none;background-color:#0081c2;background-image:-moz-linear-gradient(top,#08c,#0077b3);background-image:-webkit-gradient(linear,0 0,0 100%,from(#08c),to(#0077b3));background-image:-webkit-linear-gradient(top,#08c,#0077b3);background-image:-o-linear-gradient(top,#08c,#0077b3);background-image:linear-gradient(to bottom,#08c,#0077b3);background-repeat:repeat-x;outline:0;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff0088cc',endColorstr='#ff0077b3',GradientType=0)}.dropdown-menu>.disabled>a,.dropdown-menu>.disabled>a:hover,.dropdown-menu>.disabled>a:focus{color:#999}.dropdown-menu>.disabled>a:hover,.dropdown-menu>.disabled>a:focus{text-decoration:none;cursor:default;background-color:transparent;background-image:none;filter:progid:DXImageTransform.Microsoft.gradient(enabled=false)}.open{*z-index:1000}.open>.dropdown-menu{display:block}.pull-right>.dropdown-menu{right:0;left:auto}.dropup .caret,.navbar-fixed-bottom .dropdown .caret{border-top:0;border-bottom:4px solid #000;content:""}.dropup .dropdown-menu,.navbar-fixed-bottom .dropdown .dropdown-menu{top:auto;bottom:100%;margin-bottom:1px}.dropdown-submenu{position:relative}.dropdown-submenu>.dropdown-menu{top:0;left:100%;margin-top:-6px;margin-left:-1px;-webkit-border-radius:0 6px 6px 6px;-moz-border-radius:0 6px 6px 6px;border-radius:0 6px 6px 6px}.dropdown-submenu:hover>.dropdown-menu{display:block}.dropup .dropdown-submenu>.dropdown-menu{top:auto;bottom:0;margin-top:0;margin-bottom:-2px;-webkit-border-radius:5px 5px 5px 0;-moz-border-radius:5px 5px 5px 0;border-radius:5px 5px 5px 0}.dropdown-submenu>a:after{display:block;float:right;width:0;height:0;margin-top:5px;margin-right:-10px;border-color:transparent;border-left-color:#ccc;border-style:solid;border-width:5px 0 5px 5px;content:" "}.dropdown-submenu:hover>a:after{border-left-color:#fff}.dropdown-submenu.pull-left{float:none}.dropdown-submenu.pull-left>.dropdown-menu{left:-100%;margin-left:10px;-webkit-border-radius:6px 0 6px 6px;-moz-border-radius:6px 0 6px 6px;border-radius:6px 0 6px 6px}.dropdown .dropdown-menu .nav-header{padding-right:20px;padding-left:20px}.typeahead{z-index:1051;margin-top:2px;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px}.well{min-height:20px;padding:19px;margin-bottom:20px;background-color:#f5f5f5;border:1px solid #e3e3e3;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,0.05);-moz-box-shadow:inset 0 1px 1px rgba(0,0,0,0.05);box-shadow:inset 0 1px 1px rgba(0,0,0,0.05)}.well blockquote{border-color:#ddd;border-color:rgba(0,0,0,0.15)}.well-large{padding:24px;-webkit-border-radius:6px;-moz-border-radius:6px;border-radius:6px}.well-small{padding:9px;-webkit-border-radius:3px;-moz-border-radius:3px;border-radius:3px}.fade{opacity:0;-webkit-transition:opacity .15s linear;-moz-transition:opacity .15s linear;-o-transition:opacity .15s linear;transition:opacity .15s linear}.fade.in{opacity:1}.collapse{position:relative;height:0;overflow:hidden;-webkit-transition:height .35s ease;-moz-transition:height .35s ease;-o-transition:height .35s ease;transition:height .35s ease}.collapse.in{height:auto}.close{float:right;font-size:20px;font-weight:bold;line-height:20px;color:#000;text-shadow:0 1px 0 #fff;opacity:.2;filter:alpha(opacity=20)}.close:hover,.close:focus{color:#000;text-decoration:none;cursor:pointer;opacity:.4;filter:alpha(opacity=40)}button.close{padding:0;cursor:pointer;background:transparent;border:0;-webkit-appearance:none}.btn{display:inline-block;*display:inline;padding:4px 12px;margin-bottom:0;*margin-left:.3em;font-size:14px;line-height:20px;color:#333;text-align:center;text-shadow:0 1px 1px rgba(255,255,255,0.75);vertical-align:middle;cursor:pointer;background-color:#f5f5f5;*background-color:#e6e6e6;background-image:-moz-linear-gradient(top,#fff,#e6e6e6);background-image:-webkit-gradient(linear,0 0,0 100%,from(#fff),to(#e6e6e6));background-image:-webkit-linear-gradient(top,#fff,#e6e6e6);background-image:-o-linear-gradient(top,#fff,#e6e6e6);background-image:linear-gradient(to bottom,#fff,#e6e6e6);background-repeat:repeat-x;border:1px solid #ccc;*border:0;border-color:#e6e6e6 #e6e6e6 #bfbfbf;border-color:rgba(0,0,0,0.1) rgba(0,0,0,0.1) rgba(0,0,0,0.25);border-bottom-color:#b3b3b3;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffffffff',endColorstr='#ffe6e6e6',GradientType=0);filter:progid:DXImageTransform.Microsoft.gradient(enabled=false);*zoom:1;-webkit-box-shadow:inset 0 1px 0 rgba(255,255,255,0.2),0 1px 2px rgba(0,0,0,0.05);-moz-box-shadow:inset 0 1px 0 rgba(255,255,255,0.2),0 1px 2px rgba(0,0,0,0.05);box-shadow:inset 0 1px 0 rgba(255,255,255,0.2),0 1px 2px rgba(0,0,0,0.05)}.btn:hover,.btn:focus,.btn:active,.btn.active,.btn.disabled,.btn[disabled]{color:#333;background-color:#e6e6e6;*background-color:#d9d9d9}.btn:active,.btn.active{background-color:#ccc \9}.btn:first-child{*margin-left:0}.btn:hover,.btn:focus{color:#333;text-decoration:none;background-position:0 -15px;-webkit-transition:background-position .1s linear;-moz-transition:background-position .1s linear;-o-transition:background-position .1s linear;transition:background-position .1s linear}.btn:focus{outline:thin dotted #333;outline:5px auto -webkit-focus-ring-color;outline-offset:-2px}.btn.active,.btn:active{background-image:none;outline:0;-webkit-box-shadow:inset 0 2px 4px rgba(0,0,0,0.15),0 1px 2px rgba(0,0,0,0.05);-moz-box-shadow:inset 0 2px 4px rgba(0,0,0,0.15),0 1px 2px rgba(0,0,0,0.05);box-shadow:inset 0 2px 4px rgba(0,0,0,0.15),0 1px 2px rgba(0,0,0,0.05)}.btn.disabled,.btn[disabled]{cursor:default;background-image:none;opacity:.65;filter:alpha(opacity=65);-webkit-box-shadow:none;-moz-box-shadow:none;box-shadow:none}.btn-large{padding:11px 19px;font-size:17.5px;-webkit-border-radius:6px;-moz-border-radius:6px;border-radius:6px}.btn-large [class^="icon-"],.btn-large [class*=" icon-"]{margin-top:4px}.btn-small{padding:2px 10px;font-size:11.9px;-webkit-border-radius:3px;-moz-border-radius:3px;border-radius:3px}.btn-small [class^="icon-"],.btn-small [class*=" icon-"]{margin-top:0}.btn-mini [class^="icon-"],.btn-mini [class*=" icon-"]{margin-top:-1px}.btn-mini{padding:0 6px;font-size:10.5px;-webkit-border-radius:3px;-moz-border-radius:3px;border-radius:3px}.btn-block{display:block;width:100%;padding-right:0;padding-left:0;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}.btn-block+.btn-block{margin-top:5px}input[type="submit"].btn-block,input[type="reset"].btn-block,input[type="button"].btn-block{width:100%}.btn-primary.active,.btn-warning.active,.btn-danger.active,.btn-success.active,.btn-info.active,.btn-inverse.active{color:rgba(255,255,255,0.75)}.btn-primary{color:#fff;text-shadow:0 -1px 0 rgba(0,0,0,0.25);background-color:#006dcc;*background-color:#04c;background-image:-moz-linear-gradient(top,#08c,#04c);background-image:-webkit-gradient(linear,0 0,0 100%,from(#08c),to(#04c));background-image:-webkit-linear-gradient(top,#08c,#04c);background-image:-o-linear-gradient(top,#08c,#04c);background-image:linear-gradient(to bottom,#08c,#04c);background-repeat:repeat-x;border-color:#04c #04c #002a80;border-color:rgba(0,0,0,0.1) rgba(0,0,0,0.1) rgba(0,0,0,0.25);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff0088cc',endColorstr='#ff0044cc',GradientType=0);filter:progid:DXImageTransform.Microsoft.gradient(enabled=false)}.btn-primary:hover,.btn-primary:focus,.btn-primary:active,.btn-primary.active,.btn-primary.disabled,.btn-primary[disabled]{color:#fff;background-color:#04c;*background-color:#003bb3}.btn-primary:active,.btn-primary.active{background-color:#039 \9}.btn-warning{color:#fff;text-shadow:0 -1px 0 rgba(0,0,0,0.25);background-color:#faa732;*background-color:#f89406;background-image:-moz-linear-gradient(top,#fbb450,#f89406);background-image:-webkit-gradient(linear,0 0,0 100%,from(#fbb450),to(#f89406));background-image:-webkit-linear-gradient(top,#fbb450,#f89406);background-image:-o-linear-gradient(top,#fbb450,#f89406);background-image:linear-gradient(to bottom,#fbb450,#f89406);background-repeat:repeat-x;border-color:#f89406 #f89406 #ad6704;border-color:rgba(0,0,0,0.1) rgba(0,0,0,0.1) rgba(0,0,0,0.25);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#fffbb450',endColorstr='#fff89406',GradientType=0);filter:progid:DXImageTransform.Microsoft.gradient(enabled=false)}.btn-warning:hover,.btn-warning:focus,.btn-warning:active,.btn-warning.active,.btn-warning.disabled,.btn-warning[disabled]{color:#fff;background-color:#f89406;*background-color:#df8505}.btn-warning:active,.btn-warning.active{background-color:#c67605 \9}.btn-danger{color:#fff;text-shadow:0 -1px 0 rgba(0,0,0,0.25);background-color:#da4f49;*background-color:#bd362f;background-image:-moz-linear-gradient(top,#ee5f5b,#bd362f);background-image:-webkit-gradient(linear,0 0,0 100%,from(#ee5f5b),to(#bd362f));background-image:-webkit-linear-gradient(top,#ee5f5b,#bd362f);background-image:-o-linear-gradient(top,#ee5f5b,#bd362f);background-image:linear-gradient(to bottom,#ee5f5b,#bd362f);background-repeat:repeat-x;border-color:#bd362f #bd362f #802420;border-color:rgba(0,0,0,0.1) rgba(0,0,0,0.1) rgba(0,0,0,0.25);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffee5f5b',endColorstr='#ffbd362f',GradientType=0);filter:progid:DXImageTransform.Microsoft.gradient(enabled=false)}.btn-danger:hover,.btn-danger:focus,.btn-danger:active,.btn-danger.active,.btn-danger.disabled,.btn-danger[disabled]{color:#fff;background-color:#bd362f;*background-color:#a9302a}.btn-danger:active,.btn-danger.active{background-color:#942a25 \9}.btn-success{color:#fff;text-shadow:0 -1px 0 rgba(0,0,0,0.25);background-color:#5bb75b;*background-color:#51a351;background-image:-moz-linear-gradient(top,#62c462,#51a351);background-image:-webkit-gradient(linear,0 0,0 100%,from(#62c462),to(#51a351));background-image:-webkit-linear-gradient(top,#62c462,#51a351);background-image:-o-linear-gradient(top,#62c462,#51a351);background-image:linear-gradient(to bottom,#62c462,#51a351);background-repeat:repeat-x;border-color:#51a351 #51a351 #387038;border-color:rgba(0,0,0,0.1) rgba(0,0,0,0.1) rgba(0,0,0,0.25);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff62c462',endColorstr='#ff51a351',GradientType=0);filter:progid:DXImageTransform.Microsoft.gradient(enabled=false)}.btn-success:hover,.btn-success:focus,.btn-success:active,.btn-success.active,.btn-success.disabled,.btn-success[disabled]{color:#fff;background-color:#51a351;*background-color:#499249}.btn-success:active,.btn-success.active{background-color:#408140 \9}.btn-info{color:#fff;text-shadow:0 -1px 0 rgba(0,0,0,0.25);background-color:#49afcd;*background-color:#2f96b4;background-image:-moz-linear-gradient(top,#5bc0de,#2f96b4);background-image:-webkit-gradient(linear,0 0,0 100%,from(#5bc0de),to(#2f96b4));background-image:-webkit-linear-gradient(top,#5bc0de,#2f96b4);background-image:-o-linear-gradient(top,#5bc0de,#2f96b4);background-image:linear-gradient(to bottom,#5bc0de,#2f96b4);background-repeat:repeat-x;border-color:#2f96b4 #2f96b4 #1f6377;border-color:rgba(0,0,0,0.1) rgba(0,0,0,0.1) rgba(0,0,0,0.25);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff5bc0de',endColorstr='#ff2f96b4',GradientType=0);filter:progid:DXImageTransform.Microsoft.gradient(enabled=false)}.btn-info:hover,.btn-info:focus,.btn-info:active,.btn-info.active,.btn-info.disabled,.btn-info[disabled]{color:#fff;background-color:#2f96b4;*background-color:#2a85a0}.btn-info:active,.btn-info.active{background-color:#24748c \9}.btn-inverse{color:#fff;text-shadow:0 -1px 0 rgba(0,0,0,0.25);background-color:#363636;*background-color:#222;background-image:-moz-linear-gradient(top,#444,#222);background-image:-webkit-gradient(linear,0 0,0 100%,from(#444),to(#222));background-image:-webkit-linear-gradient(top,#444,#222);background-image:-o-linear-gradient(top,#444,#222);background-image:linear-gradient(to bottom,#444,#222);background-repeat:repeat-x;border-color:#222 #222 #000;border-color:rgba(0,0,0,0.1) rgba(0,0,0,0.1) rgba(0,0,0,0.25);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff444444',endColorstr='#ff222222',GradientType=0);filter:progid:DXImageTransform.Microsoft.gradient(enabled=false)}.btn-inverse:hover,.btn-inverse:focus,.btn-inverse:active,.btn-inverse.active,.btn-inverse.disabled,.btn-inverse[disabled]{color:#fff;background-color:#222;*background-color:#151515}.btn-inverse:active,.btn-inverse.active{background-color:#080808 \9}button.btn,input[type="submit"].btn{*padding-top:3px;*padding-bottom:3px}button.btn::-moz-focus-inner,input[type="submit"].btn::-moz-focus-inner{padding:0;border:0}button.btn.btn-large,input[type="submit"].btn.btn-large{*padding-top:7px;*padding-bottom:7px}button.btn.btn-small,input[type="submit"].btn.btn-small{*padding-top:3px;*padding-bottom:3px}button.btn.btn-mini,input[type="submit"].btn.btn-mini{*padding-top:1px;*padding-bottom:1px}.btn-link,.btn-link:active,.btn-link[disabled]{background-color:transparent;background-image:none;-webkit-box-shadow:none;-moz-box-shadow:none;box-shadow:none}.btn-link{color:#08c;cursor:pointer;border-color:transparent;-webkit-border-radius:0;-moz-border-radius:0;border-radius:0}.btn-link:hover,.btn-link:focus{color:#005580;text-decoration:underline;background-color:transparent}.btn-link[disabled]:hover,.btn-link[disabled]:focus{color:#333;text-decoration:none}.btn-group{position:relative;display:inline-block;*display:inline;*margin-left:.3em;font-size:0;white-space:nowrap;vertical-align:middle;*zoom:1}.btn-group:first-child{*margin-left:0}.btn-group+.btn-group{margin-left:5px}.btn-toolbar{margin-top:10px;margin-bottom:10px;font-size:0}.btn-toolbar>.btn+.btn,.btn-toolbar>.btn-group+.btn,.btn-toolbar>.btn+.btn-group{margin-left:5px}.btn-group>.btn{position:relative;-webkit-border-radius:0;-moz-border-radius:0;border-radius:0}.btn-group>.btn+.btn{margin-left:-1px}.btn-group>.btn,.btn-group>.dropdown-menu,.btn-group>.popover{font-size:14px}.btn-group>.btn-mini{font-size:10.5px}.btn-group>.btn-small{font-size:11.9px}.btn-group>.btn-large{font-size:17.5px}.btn-group>.btn:first-child{margin-left:0;-webkit-border-bottom-left-radius:4px;border-bottom-left-radius:4px;-webkit-border-top-left-radius:4px;border-top-left-radius:4px;-moz-border-radius-bottomleft:4px;-moz-border-radius-topleft:4px}.btn-group>.btn:last-child,.btn-group>.dropdown-toggle{-webkit-border-top-right-radius:4px;border-top-right-radius:4px;-webkit-border-bottom-right-radius:4px;border-bottom-right-radius:4px;-moz-border-radius-topright:4px;-moz-border-radius-bottomright:4px}.btn-group>.btn.large:first-child{margin-left:0;-webkit-border-bottom-left-radius:6px;border-bottom-left-radius:6px;-webkit-border-top-left-radius:6px;border-top-left-radius:6px;-moz-border-radius-bottomleft:6px;-moz-border-radius-topleft:6px}.btn-group>.btn.large:last-child,.btn-group>.large.dropdown-toggle{-webkit-border-top-right-radius:6px;border-top-right-radius:6px;-webkit-border-bottom-right-radius:6px;border-bottom-right-radius:6px;-moz-border-radius-topright:6px;-moz-border-radius-bottomright:6px}.btn-group>.btn:hover,.btn-group>.btn:focus,.btn-group>.btn:active,.btn-group>.btn.active{z-index:2}.btn-group .dropdown-toggle:active,.btn-group.open .dropdown-toggle{outline:0}.btn-group>.btn+.dropdown-toggle{*padding-top:5px;padding-right:8px;*padding-bottom:5px;padding-left:8px;-webkit-box-shadow:inset 1px 0 0 rgba(255,255,255,0.125),inset 0 1px 0 rgba(255,255,255,0.2),0 1px 2px rgba(0,0,0,0.05);-moz-box-shadow:inset 1px 0 0 rgba(255,255,255,0.125),inset 0 1px 0 rgba(255,255,255,0.2),0 1px 2px rgba(0,0,0,0.05);box-shadow:inset 1px 0 0 rgba(255,255,255,0.125),inset 0 1px 0 rgba(255,255,255,0.2),0 1px 2px rgba(0,0,0,0.05)}.btn-group>.btn-mini+.dropdown-toggle{*padding-top:2px;padding-right:5px;*padding-bottom:2px;padding-left:5px}.btn-group>.btn-small+.dropdown-toggle{*padding-top:5px;*padding-bottom:4px}.btn-group>.btn-large+.dropdown-toggle{*padding-top:7px;padding-right:12px;*padding-bottom:7px;padding-left:12px}.btn-group.open .dropdown-toggle{background-image:none;-webkit-box-shadow:inset 0 2px 4px rgba(0,0,0,0.15),0 1px 2px rgba(0,0,0,0.05);-moz-box-shadow:inset 0 2px 4px rgba(0,0,0,0.15),0 1px 2px rgba(0,0,0,0.05);box-shadow:inset 0 2px 4px rgba(0,0,0,0.15),0 1px 2px rgba(0,0,0,0.05)}.btn-group.open .btn.dropdown-toggle{background-color:#e6e6e6}.btn-group.open .btn-primary.dropdown-toggle{background-color:#04c}.btn-group.open .btn-warning.dropdown-toggle{background-color:#f89406}.btn-group.open .btn-danger.dropdown-toggle{background-color:#bd362f}.btn-group.open .btn-success.dropdown-toggle{background-color:#51a351}.btn-group.open .btn-info.dropdown-toggle{background-color:#2f96b4}.btn-group.open .btn-inverse.dropdown-toggle{background-color:#222}.btn .caret{margin-top:8px;margin-left:0}.btn-large .caret{margin-top:6px}.btn-large .caret{border-top-width:5px;border-right-width:5px;border-left-width:5px}.btn-mini .caret,.btn-small .caret{margin-top:8px}.dropup .btn-large .caret{border-bottom-width:5px}.btn-primary .caret,.btn-warning .caret,.btn-danger .caret,.btn-info .caret,.btn-success .caret,.btn-inverse .caret{border-top-color:#fff;border-bottom-color:#fff}.btn-group-vertical{display:inline-block;*display:inline;*zoom:1}.btn-group-vertical>.btn{display:block;float:none;max-width:100%;-webkit-border-radius:0;-moz-border-radius:0;border-radius:0}.btn-group-vertical>.btn+.btn{margin-top:-1px;margin-left:0}.btn-group-vertical>.btn:first-child{-webkit-border-radius:4px 4px 0 0;-moz-border-radius:4px 4px 0 0;border-radius:4px 4px 0 0}.btn-group-vertical>.btn:last-child{-webkit-border-radius:0 0 4px 4px;-moz-border-radius:0 0 4px 4px;border-radius:0 0 4px 4px}.btn-group-vertical>.btn-large:first-child{-webkit-border-radius:6px 6px 0 0;-moz-border-radius:6px 6px 0 0;border-radius:6px 6px 0 0}.btn-group-vertical>.btn-large:last-child{-webkit-border-radius:0 0 6px 6px;-moz-border-radius:0 0 6px 6px;border-radius:0 0 6px 6px}.alert{padding:8px 35px 8px 14px;margin-bottom:20px;text-shadow:0 1px 0 rgba(255,255,255,0.5);background-color:#fcf8e3;border:1px solid #fbeed5;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px}.alert,.alert h4{color:#c09853}.alert h4{margin:0}.alert .close{position:relative;top:-2px;right:-21px;line-height:20px}.alert-success{color:#468847;background-color:#dff0d8;border-color:#d6e9c6}.alert-success h4{color:#468847}.alert-danger,.alert-error{color:#b94a48;background-color:#f2dede;border-color:#eed3d7}.alert-danger h4,.alert-error h4{color:#b94a48}.alert-info{color:#3a87ad;background-color:#d9edf7;border-color:#bce8f1}.alert-info h4{color:#3a87ad}.alert-block{padding-top:14px;padding-bottom:14px}.alert-block>p,.alert-block>ul{margin-bottom:0}.alert-block p+p{margin-top:5px}.nav{margin-bottom:20px;margin-left:0;list-style:none}.nav>li>a{display:block}.nav>li>a:hover,.nav>li>a:focus{text-decoration:none;background-color:#eee}.nav>li>a>img{max-width:none}.nav>.pull-right{float:right}.nav-header{display:block;padding:3px 15px;font-size:11px;font-weight:bold;line-height:20px;color:#999;text-shadow:0 1px 0 rgba(255,255,255,0.5);text-transform:uppercase}.nav li+.nav-header{margin-top:9px}.nav-list{padding-right:15px;padding-left:15px;margin-bottom:0}.nav-list>li>a,.nav-list .nav-header{margin-right:-15px;margin-left:-15px;text-shadow:0 1px 0 rgba(255,255,255,0.5)}.nav-list>li>a{padding:3px 15px}.nav-list>.active>a,.nav-list>.active>a:hover,.nav-list>.active>a:focus{color:#fff;text-shadow:0 -1px 0 rgba(0,0,0,0.2);background-color:#08c}.nav-list [class^="icon-"],.nav-list [class*=" icon-"]{margin-right:2px}.nav-list .divider{*width:100%;height:1px;margin:9px 1px;*margin:-5px 0 5px;overflow:hidden;background-color:#e5e5e5;border-bottom:1px solid #fff}.nav-tabs,.nav-pills{*zoom:1}.nav-tabs:before,.nav-pills:before,.nav-tabs:after,.nav-pills:after{display:table;line-height:0;content:""}.nav-tabs:after,.nav-pills:after{clear:both}.nav-tabs>li,.nav-pills>li{float:left}.nav-tabs>li>a,.nav-pills>li>a{padding-right:12px;padding-left:12px;margin-right:2px;line-height:14px}.nav-tabs{border-bottom:1px solid #ddd}.nav-tabs>li{margin-bottom:-1px}.nav-tabs>li>a{padding-top:8px;padding-bottom:8px;line-height:20px;border:1px solid transparent;-webkit-border-radius:4px 4px 0 0;-moz-border-radius:4px 4px 0 0;border-radius:4px 4px 0 0}.nav-tabs>li>a:hover,.nav-tabs>li>a:focus{border-color:#eee #eee #ddd}.nav-tabs>.active>a,.nav-tabs>.active>a:hover,.nav-tabs>.active>a:focus{color:#555;cursor:default;background-color:#fff;border:1px solid #ddd;border-bottom-color:transparent}.nav-pills>li>a{padding-top:8px;padding-bottom:8px;margin-top:2px;margin-bottom:2px;-webkit-border-radius:5px;-moz-border-radius:5px;border-radius:5px}.nav-pills>.active>a,.nav-pills>.active>a:hover,.nav-pills>.active>a:focus{color:#fff;background-color:#08c}.nav-stacked>li{float:none}.nav-stacked>li>a{margin-right:0}.nav-tabs.nav-stacked{border-bottom:0}.nav-tabs.nav-stacked>li>a{border:1px solid #ddd;-webkit-border-radius:0;-moz-border-radius:0;border-radius:0}.nav-tabs.nav-stacked>li:first-child>a{-webkit-border-top-right-radius:4px;border-top-right-radius:4px;-webkit-border-top-left-radius:4px;border-top-left-radius:4px;-moz-border-radius-topright:4px;-moz-border-radius-topleft:4px}.nav-tabs.nav-stacked>li:last-child>a{-webkit-border-bottom-right-radius:4px;border-bottom-right-radius:4px;-webkit-border-bottom-left-radius:4px;border-bottom-left-radius:4px;-moz-border-radius-bottomright:4px;-moz-border-radius-bottomleft:4px}.nav-tabs.nav-stacked>li>a:hover,.nav-tabs.nav-stacked>li>a:focus{z-index:2;border-color:#ddd}.nav-pills.nav-stacked>li>a{margin-bottom:3px}.nav-pills.nav-stacked>li:last-child>a{margin-bottom:1px}.nav-tabs .dropdown-menu{-webkit-border-radius:0 0 6px 6px;-moz-border-radius:0 0 6px 6px;border-radius:0 0 6px 6px}.nav-pills .dropdown-menu{-webkit-border-radius:6px;-moz-border-radius:6px;border-radius:6px}.nav .dropdown-toggle .caret{margin-top:6px;border-top-color:#08c;border-bottom-color:#08c}.nav .dropdown-toggle:hover .caret,.nav .dropdown-toggle:focus .caret{border-top-color:#005580;border-bottom-color:#005580}.nav-tabs .dropdown-toggle .caret{margin-top:8px}.nav .active .dropdown-toggle .caret{border-top-color:#fff;border-bottom-color:#fff}.nav-tabs .active .dropdown-toggle .caret{border-top-color:#555;border-bottom-color:#555}.nav>.dropdown.active>a:hover,.nav>.dropdown.active>a:focus{cursor:pointer}.nav-tabs .open .dropdown-toggle,.nav-pills .open .dropdown-toggle,.nav>li.dropdown.open.active>a:hover,.nav>li.dropdown.open.active>a:focus{color:#fff;background-color:#999;border-color:#999}.nav li.dropdown.open .caret,.nav li.dropdown.open.active .caret,.nav li.dropdown.open a:hover .caret,.nav li.dropdown.open a:focus .caret{border-top-color:#fff;border-bottom-color:#fff;opacity:1;filter:alpha(opacity=100)}.tabs-stacked .open>a:hover,.tabs-stacked .open>a:focus{border-color:#999}.tabbable{*zoom:1}.tabbable:before,.tabbable:after{display:table;line-height:0;content:""}.tabbable:after{clear:both}.tab-content{overflow:auto}.tabs-below>.nav-tabs,.tabs-right>.nav-tabs,.tabs-left>.nav-tabs{border-bottom:0}.tab-content>.tab-pane,.pill-content>.pill-pane{display:none}.tab-content>.active,.pill-content>.active{display:block}.tabs-below>.nav-tabs{border-top:1px solid #ddd}.tabs-below>.nav-tabs>li{margin-top:-1px;margin-bottom:0}.tabs-below>.nav-tabs>li>a{-webkit-border-radius:0 0 4px 4px;-moz-border-radius:0 0 4px 4px;border-radius:0 0 4px 4px}.tabs-below>.nav-tabs>li>a:hover,.tabs-below>.nav-tabs>li>a:focus{border-top-color:#ddd;border-bottom-color:transparent}.tabs-below>.nav-tabs>.active>a,.tabs-below>.nav-tabs>.active>a:hover,.tabs-below>.nav-tabs>.active>a:focus{border-color:transparent #ddd #ddd #ddd}.tabs-left>.nav-tabs>li,.tabs-right>.nav-tabs>li{float:none}.tabs-left>.nav-tabs>li>a,.tabs-right>.nav-tabs>li>a{min-width:74px;margin-right:0;margin-bottom:3px}.tabs-left>.nav-tabs{float:left;margin-right:19px;border-right:1px solid #ddd}.tabs-left>.nav-tabs>li>a{margin-right:-1px;-webkit-border-radius:4px 0 0 4px;-moz-border-radius:4px 0 0 4px;border-radius:4px 0 0 4px}.tabs-left>.nav-tabs>li>a:hover,.tabs-left>.nav-tabs>li>a:focus{border-color:#eee #ddd #eee #eee}.tabs-left>.nav-tabs .active>a,.tabs-left>.nav-tabs .active>a:hover,.tabs-left>.nav-tabs .active>a:focus{border-color:#ddd transparent #ddd #ddd;*border-right-color:#fff}.tabs-right>.nav-tabs{float:right;margin-left:19px;border-left:1px solid #ddd}.tabs-right>.nav-tabs>li>a{margin-left:-1px;-webkit-border-radius:0 4px 4px 0;-moz-border-radius:0 4px 4px 0;border-radius:0 4px 4px 0}.tabs-right>.nav-tabs>li>a:hover,.tabs-right>.nav-tabs>li>a:focus{border-color:#eee #eee #eee #ddd}.tabs-right>.nav-tabs .active>a,.tabs-right>.nav-tabs .active>a:hover,.tabs-right>.nav-tabs .active>a:focus{border-color:#ddd #ddd #ddd transparent;*border-left-color:#fff}.nav>.disabled>a{color:#999}.nav>.disabled>a:hover,.nav>.disabled>a:focus{text-decoration:none;cursor:default;background-color:transparent}.navbar{*position:relative;*z-index:2;margin-bottom:20px;overflow:visible}.navbar-inner{min-height:40px;padding-right:20px;padding-left:20px;background-color:#fafafa;background-image:-moz-linear-gradient(top,#fff,#f2f2f2);background-image:-webkit-gradient(linear,0 0,0 100%,from(#fff),to(#f2f2f2));background-image:-webkit-linear-gradient(top,#fff,#f2f2f2);background-image:-o-linear-gradient(top,#fff,#f2f2f2);background-image:linear-gradient(to bottom,#fff,#f2f2f2);background-repeat:repeat-x;border:1px solid #d4d4d4;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffffffff',endColorstr='#fff2f2f2',GradientType=0);*zoom:1;-webkit-box-shadow:0 1px 4px rgba(0,0,0,0.065);-moz-box-shadow:0 1px 4px rgba(0,0,0,0.065);box-shadow:0 1px 4px rgba(0,0,0,0.065)}.navbar-inner:before,.navbar-inner:after{display:table;line-height:0;content:""}.navbar-inner:after{clear:both}.navbar .container{width:auto}.nav-collapse.collapse{height:auto;overflow:visible}.navbar .brand{display:block;float:left;padding:10px 20px 10px;margin-left:-20px;font-size:20px;font-weight:200;color:#777;text-shadow:0 1px 0 #fff}.navbar .brand:hover,.navbar .brand:focus{text-decoration:none}.navbar-text{margin-bottom:0;line-height:40px;color:#777}.navbar-link{color:#777}.navbar-link:hover,.navbar-link:focus{color:#333}.navbar .divider-vertical{height:40px;margin:0 9px;border-right:1px solid #fff;border-left:1px solid #f2f2f2}.navbar .btn,.navbar .btn-group{margin-top:5px}.navbar .btn-group .btn,.navbar .input-prepend .btn,.navbar .input-append .btn,.navbar .input-prepend .btn-group,.navbar .input-append .btn-group{margin-top:0}.navbar-form{margin-bottom:0;*zoom:1}.navbar-form:before,.navbar-form:after{display:table;line-height:0;content:""}.navbar-form:after{clear:both}.navbar-form input,.navbar-form select,.navbar-form .radio,.navbar-form .checkbox{margin-top:5px}.navbar-form input,.navbar-form select,.navbar-form .btn{display:inline-block;margin-bottom:0}.navbar-form input[type="image"],.navbar-form input[type="checkbox"],.navbar-form input[type="radio"]{margin-top:3px}.navbar-form .input-append,.navbar-form .input-prepend{margin-top:5px;white-space:nowrap}.navbar-form .input-append input,.navbar-form .input-prepend input{margin-top:0}.navbar-search{position:relative;float:left;margin-top:5px;margin-bottom:0}.navbar-search .search-query{padding:4px 14px;margin-bottom:0;font-family:"Helvetica Neue",Helvetica,Arial,sans-serif;font-size:13px;font-weight:normal;line-height:1;-webkit-border-radius:15px;-moz-border-radius:15px;border-radius:15px}.navbar-static-top{position:static;margin-bottom:0}.navbar-static-top .navbar-inner{-webkit-border-radius:0;-moz-border-radius:0;border-radius:0}.navbar-fixed-top,.navbar-fixed-bottom{position:fixed;right:0;left:0;z-index:1030;margin-bottom:0}.navbar-fixed-top .navbar-inner,.navbar-static-top .navbar-inner{border-width:0 0 1px}.navbar-fixed-bottom .navbar-inner{border-width:1px 0 0}.navbar-fixed-top .navbar-inner,.navbar-fixed-bottom .navbar-inner{padding-right:0;padding-left:0;-webkit-border-radius:0;-moz-border-radius:0;border-radius:0}.navbar-static-top .container,.navbar-fixed-top .container,.navbar-fixed-bottom .container{width:940px}.navbar-fixed-top{top:0}.navbar-fixed-top .navbar-inner,.navbar-static-top .navbar-inner{-webkit-box-shadow:0 1px 10px rgba(0,0,0,0.1);-moz-box-shadow:0 1px 10px rgba(0,0,0,0.1);box-shadow:0 1px 10px rgba(0,0,0,0.1)}.navbar-fixed-bottom{bottom:0}.navbar-fixed-bottom .navbar-inner{-webkit-box-shadow:0 -1px 10px rgba(0,0,0,0.1);-moz-box-shadow:0 -1px 10px rgba(0,0,0,0.1);box-shadow:0 -1px 10px rgba(0,0,0,0.1)}.navbar .nav{position:relative;left:0;display:block;float:left;margin:0 10px 0 0}.navbar .nav.pull-right{float:right;margin-right:0}.navbar .nav>li{float:left}.navbar .nav>li>a{float:none;padding:10px 15px 10px;color:#777;text-decoration:none;text-shadow:0 1px 0 #fff}.navbar .nav .dropdown-toggle .caret{margin-top:8px}.navbar .nav>li>a:focus,.navbar .nav>li>a:hover{color:#333;text-decoration:none;background-color:transparent}.navbar .nav>.active>a,.navbar .nav>.active>a:hover,.navbar .nav>.active>a:focus{color:#555;text-decoration:none;background-color:#e5e5e5;-webkit-box-shadow:inset 0 3px 8px rgba(0,0,0,0.125);-moz-box-shadow:inset 0 3px 8px rgba(0,0,0,0.125);box-shadow:inset 0 3px 8px rgba(0,0,0,0.125)}.navbar .btn-navbar{display:none;float:right;padding:7px 10px;margin-right:5px;margin-left:5px;color:#fff;text-shadow:0 -1px 0 rgba(0,0,0,0.25);background-color:#ededed;*background-color:#e5e5e5;background-image:-moz-linear-gradient(top,#f2f2f2,#e5e5e5);background-image:-webkit-gradient(linear,0 0,0 100%,from(#f2f2f2),to(#e5e5e5));background-image:-webkit-linear-gradient(top,#f2f2f2,#e5e5e5);background-image:-o-linear-gradient(top,#f2f2f2,#e5e5e5);background-image:linear-gradient(to bottom,#f2f2f2,#e5e5e5);background-repeat:repeat-x;border-color:#e5e5e5 #e5e5e5 #bfbfbf;border-color:rgba(0,0,0,0.1) rgba(0,0,0,0.1) rgba(0,0,0,0.25);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#fff2f2f2',endColorstr='#ffe5e5e5',GradientType=0);filter:progid:DXImageTransform.Microsoft.gradient(enabled=false);-webkit-box-shadow:inset 0 1px 0 rgba(255,255,255,0.1),0 1px 0 rgba(255,255,255,0.075);-moz-box-shadow:inset 0 1px 0 rgba(255,255,255,0.1),0 1px 0 rgba(255,255,255,0.075);box-shadow:inset 0 1px 0 rgba(255,255,255,0.1),0 1px 0 rgba(255,255,255,0.075)}.navbar .btn-navbar:hover,.navbar .btn-navbar:focus,.navbar .btn-navbar:active,.navbar .btn-navbar.active,.navbar .btn-navbar.disabled,.navbar .btn-navbar[disabled]{color:#fff;background-color:#e5e5e5;*background-color:#d9d9d9}.navbar .btn-navbar:active,.navbar .btn-navbar.active{background-color:#ccc \9}.navbar .btn-navbar .icon-bar{display:block;width:18px;height:2px;background-color:#f5f5f5;-webkit-border-radius:1px;-moz-border-radius:1px;border-radius:1px;-webkit-box-shadow:0 1px 0 rgba(0,0,0,0.25);-moz-box-shadow:0 1px 0 rgba(0,0,0,0.25);box-shadow:0 1px 0 rgba(0,0,0,0.25)}.btn-navbar .icon-bar+.icon-bar{margin-top:3px}.navbar .nav>li>.dropdown-menu:before{position:absolute;top:-7px;left:9px;display:inline-block;border-right:7px solid transparent;border-bottom:7px solid #ccc;border-left:7px solid transparent;border-bottom-color:rgba(0,0,0,0.2);content:''}.navbar .nav>li>.dropdown-menu:after{position:absolute;top:-6px;left:10px;display:inline-block;border-right:6px solid transparent;border-bottom:6px solid #fff;border-left:6px solid transparent;content:''}.navbar-fixed-bottom .nav>li>.dropdown-menu:before{top:auto;bottom:-7px;border-top:7px solid #ccc;border-bottom:0;border-top-color:rgba(0,0,0,0.2)}.navbar-fixed-bottom .nav>li>.dropdown-menu:after{top:auto;bottom:-6px;border-top:6px solid #fff;border-bottom:0}.navbar .nav li.dropdown>a:hover .caret,.navbar .nav li.dropdown>a:focus .caret{border-top-color:#333;border-bottom-color:#333}.navbar .nav li.dropdown.open>.dropdown-toggle,.navbar .nav li.dropdown.active>.dropdown-toggle,.navbar .nav li.dropdown.open.active>.dropdown-toggle{color:#555;background-color:#e5e5e5}.navbar .nav li.dropdown>.dropdown-toggle .caret{border-top-color:#777;border-bottom-color:#777}.navbar .nav li.dropdown.open>.dropdown-toggle .caret,.navbar .nav li.dropdown.active>.dropdown-toggle .caret,.navbar .nav li.dropdown.open.active>.dropdown-toggle .caret{border-top-color:#555;border-bottom-color:#555}.navbar .pull-right>li>.dropdown-menu,.navbar .nav>li>.dropdown-menu.pull-right{right:0;left:auto}.navbar .pull-right>li>.dropdown-menu:before,.navbar .nav>li>.dropdown-menu.pull-right:before{right:12px;left:auto}.navbar .pull-right>li>.dropdown-menu:after,.navbar .nav>li>.dropdown-menu.pull-right:after{right:13px;left:auto}.navbar .pull-right>li>.dropdown-menu .dropdown-menu,.navbar .nav>li>.dropdown-menu.pull-right .dropdown-menu{right:100%;left:auto;margin-right:-1px;margin-left:0;-webkit-border-radius:6px 0 6px 6px;-moz-border-radius:6px 0 6px 6px;border-radius:6px 0 6px 6px}.navbar-inverse .navbar-inner{background-color:#1b1b1b;background-image:-moz-linear-gradient(top,#222,#111);background-image:-webkit-gradient(linear,0 0,0 100%,from(#222),to(#111));background-image:-webkit-linear-gradient(top,#222,#111);background-image:-o-linear-gradient(top,#222,#111);background-image:linear-gradient(to bottom,#222,#111);background-repeat:repeat-x;border-color:#252525;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff222222',endColorstr='#ff111111',GradientType=0)}.navbar-inverse .brand,.navbar-inverse .nav>li>a{color:#999;text-shadow:0 -1px 0 rgba(0,0,0,0.25)}.navbar-inverse .brand:hover,.navbar-inverse .nav>li>a:hover,.navbar-inverse .brand:focus,.navbar-inverse .nav>li>a:focus{color:#fff}.navbar-inverse .brand{color:#999}.navbar-inverse .navbar-text{color:#999}.navbar-inverse .nav>li>a:focus,.navbar-inverse .nav>li>a:hover{color:#fff;background-color:transparent}.navbar-inverse .nav .active>a,.navbar-inverse .nav .active>a:hover,.navbar-inverse .nav .active>a:focus{color:#fff;background-color:#111}.navbar-inverse .navbar-link{color:#999}.navbar-inverse .navbar-link:hover,.navbar-inverse .navbar-link:focus{color:#fff}.navbar-inverse .divider-vertical{border-right-color:#222;border-left-color:#111}.navbar-inverse .nav li.dropdown.open>.dropdown-toggle,.navbar-inverse .nav li.dropdown.active>.dropdown-toggle,.navbar-inverse .nav li.dropdown.open.active>.dropdown-toggle{color:#fff;background-color:#111}.navbar-inverse .nav li.dropdown>a:hover .caret,.navbar-inverse .nav li.dropdown>a:focus .caret{border-top-color:#fff;border-bottom-color:#fff}.navbar-inverse .nav li.dropdown>.dropdown-toggle .caret{border-top-color:#999;border-bottom-color:#999}.navbar-inverse .nav li.dropdown.open>.dropdown-toggle .caret,.navbar-inverse .nav li.dropdown.active>.dropdown-toggle .caret,.navbar-inverse .nav li.dropdown.open.active>.dropdown-toggle .caret{border-top-color:#fff;border-bottom-color:#fff}.navbar-inverse .navbar-search .search-query{color:#fff;background-color:#515151;border-color:#111;-webkit-box-shadow:inset 0 1px 2px rgba(0,0,0,0.1),0 1px 0 rgba(255,255,255,0.15);-moz-box-shadow:inset 0 1px 2px rgba(0,0,0,0.1),0 1px 0 rgba(255,255,255,0.15);box-shadow:inset 0 1px 2px rgba(0,0,0,0.1),0 1px 0 rgba(255,255,255,0.15);-webkit-transition:none;-moz-transition:none;-o-transition:none;transition:none}.navbar-inverse .navbar-search .search-query:-moz-placeholder{color:#ccc}.navbar-inverse .navbar-search .search-query:-ms-input-placeholder{color:#ccc}.navbar-inverse .navbar-search .search-query::-webkit-input-placeholder{color:#ccc}.navbar-inverse .navbar-search .search-query:focus,.navbar-inverse .navbar-search .search-query.focused{padding:5px 15px;color:#333;text-shadow:0 1px 0 #fff;background-color:#fff;border:0;outline:0;-webkit-box-shadow:0 0 3px rgba(0,0,0,0.15);-moz-box-shadow:0 0 3px rgba(0,0,0,0.15);box-shadow:0 0 3px rgba(0,0,0,0.15)}.navbar-inverse .btn-navbar{color:#fff;text-shadow:0 -1px 0 rgba(0,0,0,0.25);background-color:#0e0e0e;*background-color:#040404;background-image:-moz-linear-gradient(top,#151515,#040404);background-image:-webkit-gradient(linear,0 0,0 100%,from(#151515),to(#040404));background-image:-webkit-linear-gradient(top,#151515,#040404);background-image:-o-linear-gradient(top,#151515,#040404);background-image:linear-gradient(to bottom,#151515,#040404);background-repeat:repeat-x;border-color:#040404 #040404 #000;border-color:rgba(0,0,0,0.1) rgba(0,0,0,0.1) rgba(0,0,0,0.25);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff151515',endColorstr='#ff040404',GradientType=0);filter:progid:DXImageTransform.Microsoft.gradient(enabled=false)}.navbar-inverse .btn-navbar:hover,.navbar-inverse .btn-navbar:focus,.navbar-inverse .btn-navbar:active,.navbar-inverse .btn-navbar.active,.navbar-inverse .btn-navbar.disabled,.navbar-inverse .btn-navbar[disabled]{color:#fff;background-color:#040404;*background-color:#000}.navbar-inverse .btn-navbar:active,.navbar-inverse .btn-navbar.active{background-color:#000 \9}.breadcrumb{padding:8px 15px;margin:0 0 20px;list-style:none;background-color:#f5f5f5;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px}.breadcrumb>li{display:inline-block;*display:inline;text-shadow:0 1px 0 #fff;*zoom:1}.breadcrumb>li>.divider{padding:0 5px;color:#ccc}.breadcrumb>.active{color:#999}.pagination{margin:20px 0}.pagination ul{display:inline-block;*display:inline;margin-bottom:0;margin-left:0;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px;*zoom:1;-webkit-box-shadow:0 1px 2px rgba(0,0,0,0.05);-moz-box-shadow:0 1px 2px rgba(0,0,0,0.05);box-shadow:0 1px 2px rgba(0,0,0,0.05)}.pagination ul>li{display:inline}.pagination ul>li>a,.pagination ul>li>span{float:left;padding:4px 12px;line-height:20px;text-decoration:none;background-color:#fff;border:1px solid #ddd;border-left-width:0}.pagination ul>li>a:hover,.pagination ul>li>a:focus,.pagination ul>.active>a,.pagination ul>.active>span{background-color:#f5f5f5}.pagination ul>.active>a,.pagination ul>.active>span{color:#999;cursor:default}.pagination ul>.disabled>span,.pagination ul>.disabled>a,.pagination ul>.disabled>a:hover,.pagination ul>.disabled>a:focus{color:#999;cursor:default;background-color:transparent}.pagination ul>li:first-child>a,.pagination ul>li:first-child>span{border-left-width:1px;-webkit-border-bottom-left-radius:4px;border-bottom-left-radius:4px;-webkit-border-top-left-radius:4px;border-top-left-radius:4px;-moz-border-radius-bottomleft:4px;-moz-border-radius-topleft:4px}.pagination ul>li:last-child>a,.pagination ul>li:last-child>span{-webkit-border-top-right-radius:4px;border-top-right-radius:4px;-webkit-border-bottom-right-radius:4px;border-bottom-right-radius:4px;-moz-border-radius-topright:4px;-moz-border-radius-bottomright:4px}.pagination-centered{text-align:center}.pagination-right{text-align:right}.pagination-large ul>li>a,.pagination-large ul>li>span{padding:11px 19px;font-size:17.5px}.pagination-large ul>li:first-child>a,.pagination-large ul>li:first-child>span{-webkit-border-bottom-left-radius:6px;border-bottom-left-radius:6px;-webkit-border-top-left-radius:6px;border-top-left-radius:6px;-moz-border-radius-bottomleft:6px;-moz-border-radius-topleft:6px}.pagination-large ul>li:last-child>a,.pagination-large ul>li:last-child>span{-webkit-border-top-right-radius:6px;border-top-right-radius:6px;-webkit-border-bottom-right-radius:6px;border-bottom-right-radius:6px;-moz-border-radius-topright:6px;-moz-border-radius-bottomright:6px}.pagination-mini ul>li:first-child>a,.pagination-small ul>li:first-child>a,.pagination-mini ul>li:first-child>span,.pagination-small ul>li:first-child>span{-webkit-border-bottom-left-radius:3px;border-bottom-left-radius:3px;-webkit-border-top-left-radius:3px;border-top-left-radius:3px;-moz-border-radius-bottomleft:3px;-moz-border-radius-topleft:3px}.pagination-mini ul>li:last-child>a,.pagination-small ul>li:last-child>a,.pagination-mini ul>li:last-child>span,.pagination-small ul>li:last-child>span{-webkit-border-top-right-radius:3px;border-top-right-radius:3px;-webkit-border-bottom-right-radius:3px;border-bottom-right-radius:3px;-moz-border-radius-topright:3px;-moz-border-radius-bottomright:3px}.pagination-small ul>li>a,.pagination-small ul>li>span{padding:2px 10px;font-size:11.9px}.pagination-mini ul>li>a,.pagination-mini ul>li>span{padding:0 6px;font-size:10.5px}.pager{margin:20px 0;text-align:center;list-style:none;*zoom:1}.pager:before,.pager:after{display:table;line-height:0;content:""}.pager:after{clear:both}.pager li{display:inline}.pager li>a,.pager li>span{display:inline-block;padding:5px 14px;background-color:#fff;border:1px solid #ddd;-webkit-border-radius:15px;-moz-border-radius:15px;border-radius:15px}.pager li>a:hover,.pager li>a:focus{text-decoration:none;background-color:#f5f5f5}.pager .next>a,.pager .next>span{float:right}.pager .previous>a,.pager .previous>span{float:left}.pager .disabled>a,.pager .disabled>a:hover,.pager .disabled>a:focus,.pager .disabled>span{color:#999;cursor:default;background-color:#fff}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1040;background-color:#000}.modal-backdrop.fade{opacity:0}.modal-backdrop,.modal-backdrop.fade.in{opacity:.8;filter:alpha(opacity=80)}.modal{position:fixed;top:10%;left:50%;z-index:1050;width:560px;margin-left:-280px;background-color:#fff;border:1px solid #999;border:1px solid rgba(0,0,0,0.3);*border:1px solid #999;-webkit-border-radius:6px;-moz-border-radius:6px;border-radius:6px;outline:0;-webkit-box-shadow:0 3px 7px rgba(0,0,0,0.3);-moz-box-shadow:0 3px 7px rgba(0,0,0,0.3);box-shadow:0 3px 7px rgba(0,0,0,0.3);-webkit-background-clip:padding-box;-moz-background-clip:padding-box;background-clip:padding-box}.modal.fade{top:-25%;-webkit-transition:opacity .3s linear,top .3s ease-out;-moz-transition:opacity .3s linear,top .3s ease-out;-o-transition:opacity .3s linear,top .3s ease-out;transition:opacity .3s linear,top .3s ease-out}.modal.fade.in{top:10%}.modal-header{padding:9px 15px;border-bottom:1px solid #eee}.modal-header .close{margin-top:2px}.modal-header h3{margin:0;line-height:30px}.modal-body{position:relative;max-height:400px;padding:15px;overflow-y:auto}.modal-form{margin-bottom:0}.modal-footer{padding:14px 15px 15px;margin-bottom:0;text-align:right;background-color:#f5f5f5;border-top:1px solid #ddd;-webkit-border-radius:0 0 6px 6px;-moz-border-radius:0 0 6px 6px;border-radius:0 0 6px 6px;*zoom:1;-webkit-box-shadow:inset 0 1px 0 #fff;-moz-box-shadow:inset 0 1px 0 #fff;box-shadow:inset 0 1px 0 #fff}.modal-footer:before,.modal-footer:after{display:table;line-height:0;content:""}.modal-footer:after{clear:both}.modal-footer .btn+.btn{margin-bottom:0;margin-left:5px}.modal-footer .btn-group .btn+.btn{margin-left:-1px}.modal-footer .btn-block+.btn-block{margin-left:0}.tooltip{position:absolute;z-index:1030;display:block;font-size:11px;line-height:1.4;opacity:0;filter:alpha(opacity=0);visibility:visible}.tooltip.in{opacity:.8;filter:alpha(opacity=80)}.tooltip.top{padding:5px 0;margin-top:-3px}.tooltip.right{padding:0 5px;margin-left:3px}.tooltip.bottom{padding:5px 0;margin-top:3px}.tooltip.left{padding:0 5px;margin-left:-3px}.tooltip-inner{max-width:200px;padding:8px;color:#fff;text-align:center;text-decoration:none;background-color:#000;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px}.tooltip-arrow{position:absolute;width:0;height:0;border-color:transparent;border-style:solid}.tooltip.top .tooltip-arrow{bottom:0;left:50%;margin-left:-5px;border-top-color:#000;border-width:5px 5px 0}.tooltip.right .tooltip-arrow{top:50%;left:0;margin-top:-5px;border-right-color:#000;border-width:5px 5px 5px 0}.tooltip.left .tooltip-arrow{top:50%;right:0;margin-top:-5px;border-left-color:#000;border-width:5px 0 5px 5px}.tooltip.bottom .tooltip-arrow{top:0;left:50%;margin-left:-5px;border-bottom-color:#000;border-width:0 5px 5px}.popover{position:absolute;top:0;left:0;z-index:1010;display:none;max-width:276px;padding:1px;text-align:left;white-space:normal;background-color:#fff;border:1px solid #ccc;border:1px solid rgba(0,0,0,0.2);-webkit-border-radius:6px;-moz-border-radius:6px;border-radius:6px;-webkit-box-shadow:0 5px 10px rgba(0,0,0,0.2);-moz-box-shadow:0 5px 10px rgba(0,0,0,0.2);box-shadow:0 5px 10px rgba(0,0,0,0.2);-webkit-background-clip:padding-box;-moz-background-clip:padding;background-clip:padding-box}.popover.top{margin-top:-10px}.popover.right{margin-left:10px}.popover.bottom{margin-top:10px}.popover.left{margin-left:-10px}.popover-title{padding:8px 14px;margin:0;font-size:14px;font-weight:normal;line-height:18px;background-color:#f7f7f7;border-bottom:1px solid #ebebeb;-webkit-border-radius:5px 5px 0 0;-moz-border-radius:5px 5px 0 0;border-radius:5px 5px 0 0}.popover-title:empty{display:none}.popover-content{padding:9px 14px}.popover .arrow,.popover .arrow:after{position:absolute;display:block;width:0;height:0;border-color:transparent;border-style:solid}.popover .arrow{border-width:11px}.popover .arrow:after{border-width:10px;content:""}.popover.top .arrow{bottom:-11px;left:50%;margin-left:-11px;border-top-color:#999;border-top-color:rgba(0,0,0,0.25);border-bottom-width:0}.popover.top .arrow:after{bottom:1px;margin-left:-10px;border-top-color:#fff;border-bottom-width:0}.popover.right .arrow{top:50%;left:-11px;margin-top:-11px;border-right-color:#999;border-right-color:rgba(0,0,0,0.25);border-left-width:0}.popover.right .arrow:after{bottom:-10px;left:1px;border-right-color:#fff;border-left-width:0}.popover.bottom .arrow{top:-11px;left:50%;margin-left:-11px;border-bottom-color:#999;border-bottom-color:rgba(0,0,0,0.25);border-top-width:0}.popover.bottom .arrow:after{top:1px;margin-left:-10px;border-bottom-color:#fff;border-top-width:0}.popover.left .arrow{top:50%;right:-11px;margin-top:-11px;border-left-color:#999;border-left-color:rgba(0,0,0,0.25);border-right-width:0}.popover.left .arrow:after{right:1px;bottom:-10px;border-left-color:#fff;border-right-width:0}.thumbnails{margin-left:-20px;list-style:none;*zoom:1}.thumbnails:before,.thumbnails:after{display:table;line-height:0;content:""}.thumbnails:after{clear:both}.row-fluid .thumbnails{margin-left:0}.thumbnails>li{float:left;margin-bottom:20px;margin-left:20px}.thumbnail{display:block;padding:4px;line-height:20px;border:1px solid #ddd;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px;-webkit-box-shadow:0 1px 3px rgba(0,0,0,0.055);-moz-box-shadow:0 1px 3px rgba(0,0,0,0.055);box-shadow:0 1px 3px rgba(0,0,0,0.055);-webkit-transition:all .2s ease-in-out;-moz-transition:all .2s ease-in-out;-o-transition:all .2s ease-in-out;transition:all .2s ease-in-out}a.thumbnail:hover,a.thumbnail:focus{border-color:#08c;-webkit-box-shadow:0 1px 4px rgba(0,105,214,0.25);-moz-box-shadow:0 1px 4px rgba(0,105,214,0.25);box-shadow:0 1px 4px rgba(0,105,214,0.25)}.thumbnail>img{display:block;max-width:100%;margin-right:auto;margin-left:auto}.thumbnail .caption{padding:9px;color:#555}.media,.media-body{overflow:hidden;*overflow:visible;zoom:1}.media,.media .media{margin-top:15px}.media:first-child{margin-top:0}.media-object{display:block}.media-heading{margin:0 0 5px}.media>.pull-left{margin-right:10px}.media>.pull-right{margin-left:10px}.media-list{margin-left:0;list-style:none}.label,.badge{display:inline-block;padding:2px 4px;font-size:11.844px;font-weight:bold;line-height:14px;color:#fff;text-shadow:0 -1px 0 rgba(0,0,0,0.25);white-space:nowrap;vertical-align:baseline;background-color:#999}.label{-webkit-border-radius:3px;-moz-border-radius:3px;border-radius:3px}.badge{padding-right:9px;padding-left:9px;-webkit-border-radius:9px;-moz-border-radius:9px;border-radius:9px}.label:empty,.badge:empty{display:none}a.label:hover,a.label:focus,a.badge:hover,a.badge:focus{color:#fff;text-decoration:none;cursor:pointer}.label-important,.badge-important{background-color:#b94a48}.label-important[href],.badge-important[href]{background-color:#953b39}.label-warning,.badge-warning{background-color:#f89406}.label-warning[href],.badge-warning[href]{background-color:#c67605}.label-success,.badge-success{background-color:#468847}.label-success[href],.badge-success[href]{background-color:#356635}.label-info,.badge-info{background-color:#3a87ad}.label-info[href],.badge-info[href]{background-color:#2d6987}.label-inverse,.badge-inverse{background-color:#333}.label-inverse[href],.badge-inverse[href]{background-color:#1a1a1a}.btn .label,.btn .badge{position:relative;top:-1px}.btn-mini .label,.btn-mini .badge{top:0}@-webkit-keyframes progress-bar-stripes{from{background-position:40px 0}to{background-position:0 0}}@-moz-keyframes progress-bar-stripes{from{background-position:40px 0}to{background-position:0 0}}@-ms-keyframes progress-bar-stripes{from{background-position:40px 0}to{background-position:0 0}}@-o-keyframes progress-bar-stripes{from{background-position:0 0}to{background-position:40px 0}}@keyframes progress-bar-stripes{from{background-position:40px 0}to{background-position:0 0}}.progress{height:20px;margin-bottom:20px;overflow:hidden;background-color:#f7f7f7;background-image:-moz-linear-gradient(top,#f5f5f5,#f9f9f9);background-image:-webkit-gradient(linear,0 0,0 100%,from(#f5f5f5),to(#f9f9f9));background-image:-webkit-linear-gradient(top,#f5f5f5,#f9f9f9);background-image:-o-linear-gradient(top,#f5f5f5,#f9f9f9);background-image:linear-gradient(to bottom,#f5f5f5,#f9f9f9);background-repeat:repeat-x;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#fff5f5f5',endColorstr='#fff9f9f9',GradientType=0);-webkit-box-shadow:inset 0 1px 2px rgba(0,0,0,0.1);-moz-box-shadow:inset 0 1px 2px rgba(0,0,0,0.1);box-shadow:inset 0 1px 2px rgba(0,0,0,0.1)}.progress .bar{float:left;width:0;height:100%;font-size:12px;color:#fff;text-align:center;text-shadow:0 -1px 0 rgba(0,0,0,0.25);background-color:#0e90d2;background-image:-moz-linear-gradient(top,#149bdf,#0480be);background-image:-webkit-gradient(linear,0 0,0 100%,from(#149bdf),to(#0480be));background-image:-webkit-linear-gradient(top,#149bdf,#0480be);background-image:-o-linear-gradient(top,#149bdf,#0480be);background-image:linear-gradient(to bottom,#149bdf,#0480be);background-repeat:repeat-x;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff149bdf',endColorstr='#ff0480be',GradientType=0);-webkit-box-shadow:inset 0 -1px 0 rgba(0,0,0,0.15);-moz-box-shadow:inset 0 -1px 0 rgba(0,0,0,0.15);box-shadow:inset 0 -1px 0 rgba(0,0,0,0.15);-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;-webkit-transition:width .6s ease;-moz-transition:width .6s ease;-o-transition:width .6s ease;transition:width .6s ease}.progress .bar+.bar{-webkit-box-shadow:inset 1px 0 0 rgba(0,0,0,0.15),inset 0 -1px 0 rgba(0,0,0,0.15);-moz-box-shadow:inset 1px 0 0 rgba(0,0,0,0.15),inset 0 -1px 0 rgba(0,0,0,0.15);box-shadow:inset 1px 0 0 rgba(0,0,0,0.15),inset 0 -1px 0 rgba(0,0,0,0.15)}.progress-striped .bar{background-color:#149bdf;background-image:-webkit-gradient(linear,0 100%,100% 0,color-stop(0.25,rgba(255,255,255,0.15)),color-stop(0.25,transparent),color-stop(0.5,transparent),color-stop(0.5,rgba(255,255,255,0.15)),color-stop(0.75,rgba(255,255,255,0.15)),color-stop(0.75,transparent),to(transparent));background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-moz-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-o-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);-webkit-background-size:40px 40px;-moz-background-size:40px 40px;-o-background-size:40px 40px;background-size:40px 40px}.progress.active .bar{-webkit-animation:progress-bar-stripes 2s linear infinite;-moz-animation:progress-bar-stripes 2s linear infinite;-ms-animation:progress-bar-stripes 2s linear infinite;-o-animation:progress-bar-stripes 2s linear infinite;animation:progress-bar-stripes 2s linear infinite}.progress-danger .bar,.progress .bar-danger{background-color:#dd514c;background-image:-moz-linear-gradient(top,#ee5f5b,#c43c35);background-image:-webkit-gradient(linear,0 0,0 100%,from(#ee5f5b),to(#c43c35));background-image:-webkit-linear-gradient(top,#ee5f5b,#c43c35);background-image:-o-linear-gradient(top,#ee5f5b,#c43c35);background-image:linear-gradient(to bottom,#ee5f5b,#c43c35);background-repeat:repeat-x;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffee5f5b',endColorstr='#ffc43c35',GradientType=0)}.progress-danger.progress-striped .bar,.progress-striped .bar-danger{background-color:#ee5f5b;background-image:-webkit-gradient(linear,0 100%,100% 0,color-stop(0.25,rgba(255,255,255,0.15)),color-stop(0.25,transparent),color-stop(0.5,transparent),color-stop(0.5,rgba(255,255,255,0.15)),color-stop(0.75,rgba(255,255,255,0.15)),color-stop(0.75,transparent),to(transparent));background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-moz-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-o-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent)}.progress-success .bar,.progress .bar-success{background-color:#5eb95e;background-image:-moz-linear-gradient(top,#62c462,#57a957);background-image:-webkit-gradient(linear,0 0,0 100%,from(#62c462),to(#57a957));background-image:-webkit-linear-gradient(top,#62c462,#57a957);background-image:-o-linear-gradient(top,#62c462,#57a957);background-image:linear-gradient(to bottom,#62c462,#57a957);background-repeat:repeat-x;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff62c462',endColorstr='#ff57a957',GradientType=0)}.progress-success.progress-striped .bar,.progress-striped .bar-success{background-color:#62c462;background-image:-webkit-gradient(linear,0 100%,100% 0,color-stop(0.25,rgba(255,255,255,0.15)),color-stop(0.25,transparent),color-stop(0.5,transparent),color-stop(0.5,rgba(255,255,255,0.15)),color-stop(0.75,rgba(255,255,255,0.15)),color-stop(0.75,transparent),to(transparent));background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-moz-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-o-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent)}.progress-info .bar,.progress .bar-info{background-color:#4bb1cf;background-image:-moz-linear-gradient(top,#5bc0de,#339bb9);background-image:-webkit-gradient(linear,0 0,0 100%,from(#5bc0de),to(#339bb9));background-image:-webkit-linear-gradient(top,#5bc0de,#339bb9);background-image:-o-linear-gradient(top,#5bc0de,#339bb9);background-image:linear-gradient(to bottom,#5bc0de,#339bb9);background-repeat:repeat-x;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff5bc0de',endColorstr='#ff339bb9',GradientType=0)}.progress-info.progress-striped .bar,.progress-striped .bar-info{background-color:#5bc0de;background-image:-webkit-gradient(linear,0 100%,100% 0,color-stop(0.25,rgba(255,255,255,0.15)),color-stop(0.25,transparent),color-stop(0.5,transparent),color-stop(0.5,rgba(255,255,255,0.15)),color-stop(0.75,rgba(255,255,255,0.15)),color-stop(0.75,transparent),to(transparent));background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-moz-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-o-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent)}.progress-warning .bar,.progress .bar-warning{background-color:#faa732;background-image:-moz-linear-gradient(top,#fbb450,#f89406);background-image:-webkit-gradient(linear,0 0,0 100%,from(#fbb450),to(#f89406));background-image:-webkit-linear-gradient(top,#fbb450,#f89406);background-image:-o-linear-gradient(top,#fbb450,#f89406);background-image:linear-gradient(to bottom,#fbb450,#f89406);background-repeat:repeat-x;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#fffbb450',endColorstr='#fff89406',GradientType=0)}.progress-warning.progress-striped .bar,.progress-striped .bar-warning{background-color:#fbb450;background-image:-webkit-gradient(linear,0 100%,100% 0,color-stop(0.25,rgba(255,255,255,0.15)),color-stop(0.25,transparent),color-stop(0.5,transparent),color-stop(0.5,rgba(255,255,255,0.15)),color-stop(0.75,rgba(255,255,255,0.15)),color-stop(0.75,transparent),to(transparent));background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-moz-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-o-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent)}.accordion{margin-bottom:20px}.accordion-group{margin-bottom:2px;border:1px solid #e5e5e5;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px}.accordion-heading{border-bottom:0}.accordion-heading .accordion-toggle{display:block;padding:8px 15px}.accordion-toggle{cursor:pointer}.accordion-inner{padding:9px 15px;border-top:1px solid #e5e5e5}.carousel{position:relative;margin-bottom:20px;line-height:1}.carousel-inner{position:relative;width:100%;overflow:hidden}.carousel-inner>.item{position:relative;display:none;-webkit-transition:.6s ease-in-out left;-moz-transition:.6s ease-in-out left;-o-transition:.6s ease-in-out left;transition:.6s ease-in-out left}.carousel-inner>.item>img,.carousel-inner>.item>a>img{display:block;line-height:1}.carousel-inner>.active,.carousel-inner>.next,.carousel-inner>.prev{display:block}.carousel-inner>.active{left:0}.carousel-inner>.next,.carousel-inner>.prev{position:absolute;top:0;width:100%}.carousel-inner>.next{left:100%}.carousel-inner>.prev{left:-100%}.carousel-inner>.next.left,.carousel-inner>.prev.right{left:0}.carousel-inner>.active.left{left:-100%}.carousel-inner>.active.right{left:100%}.carousel-control{position:absolute;top:40%;left:15px;width:40px;height:40px;margin-top:-20px;font-size:60px;font-weight:100;line-height:30px;color:#fff;text-align:center;background:#222;border:3px solid #fff;-webkit-border-radius:23px;-moz-border-radius:23px;border-radius:23px;opacity:.5;filter:alpha(opacity=50)}.carousel-control.right{right:15px;left:auto}.carousel-control:hover,.carousel-control:focus{color:#fff;text-decoration:none;opacity:.9;filter:alpha(opacity=90)}.carousel-indicators{position:absolute;top:15px;right:15px;z-index:5;margin:0;list-style:none}.carousel-indicators li{display:block;float:left;width:10px;height:10px;margin-left:5px;text-indent:-999px;background-color:#ccc;background-color:rgba(255,255,255,0.25);border-radius:5px}.carousel-indicators .active{background-color:#fff}.carousel-caption{position:absolute;right:0;bottom:0;left:0;padding:15px;background:#333;background:rgba(0,0,0,0.75)}.carousel-caption h4,.carousel-caption p{line-height:20px;color:#fff}.carousel-caption h4{margin:0 0 5px}.carousel-caption p{margin-bottom:0}.hero-unit{padding:60px;margin-bottom:30px;font-size:18px;font-weight:200;line-height:30px;color:inherit;background-color:#eee;-webkit-border-radius:6px;-moz-border-radius:6px;border-radius:6px}.hero-unit h1{margin-bottom:0;font-size:60px;line-height:1;letter-spacing:-1px;color:inherit}.hero-unit li{line-height:30px}.pull-right{float:right}.pull-left{float:left}.hide{display:none}.show{display:block}.invisible{visibility:hidden}.affix{position:fixed}
diff --git a/opendaylight/adsal/web/root/src/main/resources/css/fuelux-responsive.min.css b/opendaylight/adsal/web/root/src/main/resources/css/fuelux-responsive.min.css
deleted file mode 100755 (executable)
index 1dbe323..0000000
+++ /dev/null
@@ -1,9 +0,0 @@
-/*!
- * Bootstrap Responsive v2.3.2
- *
- * Copyright 2012 Twitter, Inc
- * Licensed under the Apache License v2.0
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Designed and built with all the love in the world @twitter by @mdo and @fat.
- */.fuelux .clearfix{*zoom:1}.fuelux .clearfix:before,.fuelux .clearfix:after{display:table;line-height:0;content:""}.fuelux .clearfix:after{clear:both}.fuelux .hide-text{font:0/0 a;color:transparent;text-shadow:none;background-color:transparent;border:0}.fuelux .input-block-level{display:block;width:100%;min-height:30px;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}@-ms-viewport{width:device-width}.fuelux .hidden{display:none;visibility:hidden}.fuelux .visible-phone{display:none!important}.fuelux .visible-tablet{display:none!important}.fuelux .hidden-desktop{display:none!important}.fuelux .visible-desktop{display:inherit!important}@media(min-width:768px) and (max-width:979px){.fuelux .hidden-desktop{display:inherit!important}.fuelux .visible-desktop{display:none!important}.fuelux .visible-tablet{display:inherit!important}.fuelux .hidden-tablet{display:none!important}}@media(max-width:767px){.fuelux .hidden-desktop{display:inherit!important}.fuelux .visible-desktop{display:none!important}.fuelux .visible-phone{display:inherit!important}.fuelux .hidden-phone{display:none!important}}.fuelux .visible-print{display:none!important}@media print{.fuelux .visible-print{display:inherit!important}.fuelux .hidden-print{display:none!important}}@media(min-width:1200px){.fuelux .row{margin-left:-30px;*zoom:1}.fuelux .row:before,.fuelux .row:after{display:table;line-height:0;content:""}.fuelux .row:after{clear:both}.fuelux [class*="span"]{float:left;min-height:1px;margin-left:30px}.fuelux .container,.fuelux .navbar-static-top .container,.fuelux .navbar-fixed-top .container,.fuelux .navbar-fixed-bottom .container{width:1170px}.fuelux .span12{width:1170px}.fuelux .span11{width:1070px}.fuelux .span10{width:970px}.fuelux .span9{width:870px}.fuelux .span8{width:770px}.fuelux .span7{width:670px}.fuelux .span6{width:570px}.fuelux .span5{width:470px}.fuelux .span4{width:370px}.fuelux .span3{width:270px}.fuelux .span2{width:170px}.fuelux .span1{width:70px}.fuelux .offset12{margin-left:1230px}.fuelux .offset11{margin-left:1130px}.fuelux .offset10{margin-left:1030px}.fuelux .offset9{margin-left:930px}.fuelux .offset8{margin-left:830px}.fuelux .offset7{margin-left:730px}.fuelux .offset6{margin-left:630px}.fuelux .offset5{margin-left:530px}.fuelux .offset4{margin-left:430px}.fuelux .offset3{margin-left:330px}.fuelux .offset2{margin-left:230px}.fuelux .offset1{margin-left:130px}.fuelux .row-fluid{width:100%;*zoom:1}.fuelux .row-fluid:before,.fuelux .row-fluid:after{display:table;line-height:0;content:""}.fuelux .row-fluid:after{clear:both}.fuelux .row-fluid [class*="span"]{display:block;float:left;width:100%;min-height:30px;margin-left:2.564102564102564%;*margin-left:2.5109110747408616%;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}.fuelux .row-fluid [class*="span"]:first-child{margin-left:0}.fuelux .row-fluid .controls-row [class*="span"]+[class*="span"]{margin-left:2.564102564102564%}.fuelux .row-fluid .span12{width:100%;*width:99.94680851063829%}.fuelux .row-fluid .span11{width:91.45299145299145%;*width:91.39979996362975%}.fuelux .row-fluid .span10{width:82.90598290598291%;*width:82.8527914166212%}.fuelux .row-fluid .span9{width:74.35897435897436%;*width:74.30578286961266%}.fuelux .row-fluid .span8{width:65.81196581196582%;*width:65.75877432260411%}.fuelux .row-fluid .span7{width:57.26495726495726%;*width:57.21176577559556%}.fuelux .row-fluid .span6{width:48.717948717948715%;*width:48.664757228587014%}.fuelux .row-fluid .span5{width:40.17094017094017%;*width:40.11774868157847%}.fuelux .row-fluid .span4{width:31.623931623931625%;*width:31.570740134569924%}.fuelux .row-fluid .span3{width:23.076923076923077%;*width:23.023731587561375%}.fuelux .row-fluid .span2{width:14.52991452991453%;*width:14.476723040552828%}.fuelux .row-fluid .span1{width:5.982905982905983%;*width:5.929714493544281%}.fuelux .row-fluid .offset12{margin-left:105.12820512820512%;*margin-left:105.02182214948171%}.fuelux .row-fluid .offset12:first-child{margin-left:102.56410256410257%;*margin-left:102.45771958537915%}.fuelux .row-fluid .offset11{margin-left:96.58119658119658%;*margin-left:96.47481360247316%}.fuelux .row-fluid .offset11:first-child{margin-left:94.01709401709402%;*margin-left:93.91071103837061%}.fuelux .row-fluid .offset10{margin-left:88.03418803418803%;*margin-left:87.92780505546462%}.fuelux .row-fluid .offset10:first-child{margin-left:85.47008547008548%;*margin-left:85.36370249136206%}.fuelux .row-fluid .offset9{margin-left:79.48717948717949%;*margin-left:79.38079650845607%}.fuelux .row-fluid .offset9:first-child{margin-left:76.92307692307693%;*margin-left:76.81669394435352%}.fuelux .row-fluid .offset8{margin-left:70.94017094017094%;*margin-left:70.83378796144753%}.fuelux .row-fluid .offset8:first-child{margin-left:68.37606837606839%;*margin-left:68.26968539734497%}.fuelux .row-fluid .offset7{margin-left:62.393162393162385%;*margin-left:62.28677941443899%}.fuelux .row-fluid .offset7:first-child{margin-left:59.82905982905982%;*margin-left:59.72267685033642%}.fuelux .row-fluid .offset6{margin-left:53.84615384615384%;*margin-left:53.739770867430444%}.fuelux .row-fluid .offset6:first-child{margin-left:51.28205128205128%;*margin-left:51.175668303327875%}.fuelux .row-fluid .offset5{margin-left:45.299145299145295%;*margin-left:45.1927623204219%}.fuelux .row-fluid .offset5:first-child{margin-left:42.73504273504273%;*margin-left:42.62865975631933%}.fuelux .row-fluid .offset4{margin-left:36.75213675213675%;*margin-left:36.645753773413354%}.fuelux .row-fluid .offset4:first-child{margin-left:34.18803418803419%;*margin-left:34.081651209310785%}.fuelux .row-fluid .offset3{margin-left:28.205128205128204%;*margin-left:28.0987452264048%}.fuelux .row-fluid .offset3:first-child{margin-left:25.641025641025642%;*margin-left:25.53464266230224%}.fuelux .row-fluid .offset2{margin-left:19.65811965811966%;*margin-left:19.551736679396257%}.fuelux .row-fluid .offset2:first-child{margin-left:17.094017094017094%;*margin-left:16.98763411529369%}.fuelux .row-fluid .offset1{margin-left:11.11111111111111%;*margin-left:11.004728132387708%}.fuelux .row-fluid .offset1:first-child{margin-left:8.547008547008547%;*margin-left:8.440625568285142%}.fuelux input,.fuelux textarea,.fuelux .uneditable-input{margin-left:0}.fuelux .controls-row [class*="span"]+[class*="span"]{margin-left:30px}.fuelux input.span12,textarea.span12,.uneditable-input.span12{width:1156px}.fuelux input.span11,textarea.span11,.uneditable-input.span11{width:1056px}.fuelux input.span10,textarea.span10,.uneditable-input.span10{width:956px}.fuelux input.span9,textarea.span9,.uneditable-input.span9{width:856px}.fuelux input.span8,textarea.span8,.uneditable-input.span8{width:756px}.fuelux input.span7,textarea.span7,.uneditable-input.span7{width:656px}.fuelux input.span6,textarea.span6,.uneditable-input.span6{width:556px}.fuelux input.span5,textarea.span5,.uneditable-input.span5{width:456px}.fuelux input.span4,textarea.span4,.uneditable-input.span4{width:356px}.fuelux input.span3,textarea.span3,.uneditable-input.span3{width:256px}.fuelux input.span2,textarea.span2,.uneditable-input.span2{width:156px}.fuelux input.span1,textarea.span1,.uneditable-input.span1{width:56px}.fuelux .thumbnails{margin-left:-30px}.fuelux .thumbnails>li{margin-left:30px}.fuelux .row-fluid .thumbnails{margin-left:0}}@media(min-width:768px) and (max-width:979px){.fuelux .row{margin-left:-20px;*zoom:1}.fuelux .row:before,.fuelux .row:after{display:table;line-height:0;content:""}.fuelux .row:after{clear:both}.fuelux [class*="span"]{float:left;min-height:1px;margin-left:20px}.fuelux .container,.fuelux .navbar-static-top .container,.fuelux .navbar-fixed-top .container,.fuelux .navbar-fixed-bottom .container{width:724px}.fuelux .span12{width:724px}.fuelux .span11{width:662px}.fuelux .span10{width:600px}.fuelux .span9{width:538px}.fuelux .span8{width:476px}.fuelux .span7{width:414px}.fuelux .span6{width:352px}.fuelux .span5{width:290px}.fuelux .span4{width:228px}.fuelux .span3{width:166px}.fuelux .span2{width:104px}.fuelux .span1{width:42px}.fuelux .offset12{margin-left:764px}.fuelux .offset11{margin-left:702px}.fuelux .offset10{margin-left:640px}.fuelux .offset9{margin-left:578px}.fuelux .offset8{margin-left:516px}.fuelux .offset7{margin-left:454px}.fuelux .offset6{margin-left:392px}.fuelux .offset5{margin-left:330px}.fuelux .offset4{margin-left:268px}.fuelux .offset3{margin-left:206px}.fuelux .offset2{margin-left:144px}.fuelux .offset1{margin-left:82px}.fuelux .row-fluid{width:100%;*zoom:1}.fuelux .row-fluid:before,.fuelux .row-fluid:after{display:table;line-height:0;content:""}.fuelux .row-fluid:after{clear:both}.fuelux .row-fluid [class*="span"]{display:block;float:left;width:100%;min-height:30px;margin-left:2.7624309392265194%;*margin-left:2.709239449864817%;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}.fuelux .row-fluid [class*="span"]:first-child{margin-left:0}.fuelux .row-fluid .controls-row [class*="span"]+[class*="span"]{margin-left:2.7624309392265194%}.fuelux .row-fluid .span12{width:100%;*width:99.94680851063829%}.fuelux .row-fluid .span11{width:91.43646408839778%;*width:91.38327259903608%}.fuelux .row-fluid .span10{width:82.87292817679558%;*width:82.81973668743387%}.fuelux .row-fluid .span9{width:74.30939226519337%;*width:74.25620077583166%}.fuelux .row-fluid .span8{width:65.74585635359117%;*width:65.69266486422946%}.fuelux .row-fluid .span7{width:57.18232044198895%;*width:57.12912895262725%}.fuelux .row-fluid .span6{width:48.61878453038674%;*width:48.56559304102504%}.fuelux .row-fluid .span5{width:40.05524861878453%;*width:40.00205712942283%}.fuelux .row-fluid .span4{width:31.491712707182323%;*width:31.43852121782062%}.fuelux .row-fluid .span3{width:22.92817679558011%;*width:22.87498530621841%}.fuelux .row-fluid .span2{width:14.3646408839779%;*width:14.311449394616199%}.fuelux .row-fluid .span1{width:5.801104972375691%;*width:5.747913483013988%}.fuelux .row-fluid .offset12{margin-left:105.52486187845304%;*margin-left:105.41847889972962%}.fuelux .row-fluid .offset12:first-child{margin-left:102.76243093922652%;*margin-left:102.6560479605031%}.fuelux .row-fluid .offset11{margin-left:96.96132596685082%;*margin-left:96.8549429881274%}.fuelux .row-fluid .offset11:first-child{margin-left:94.1988950276243%;*margin-left:94.09251204890089%}.fuelux .row-fluid .offset10{margin-left:88.39779005524862%;*margin-left:88.2914070765252%}.fuelux .row-fluid .offset10:first-child{margin-left:85.6353591160221%;*margin-left:85.52897613729868%}.fuelux .row-fluid .offset9{margin-left:79.8342541436464%;*margin-left:79.72787116492299%}.fuelux .row-fluid .offset9:first-child{margin-left:77.07182320441989%;*margin-left:76.96544022569647%}.fuelux .row-fluid .offset8{margin-left:71.2707182320442%;*margin-left:71.16433525332079%}.fuelux .row-fluid .offset8:first-child{margin-left:68.50828729281768%;*margin-left:68.40190431409427%}.fuelux .row-fluid .offset7{margin-left:62.70718232044199%;*margin-left:62.600799341718584%}.fuelux .row-fluid .offset7:first-child{margin-left:59.94475138121547%;*margin-left:59.838368402492065%}.fuelux .row-fluid .offset6{margin-left:54.14364640883978%;*margin-left:54.037263430116376%}.fuelux .row-fluid .offset6:first-child{margin-left:51.38121546961326%;*margin-left:51.27483249088986%}.fuelux .row-fluid .offset5{margin-left:45.58011049723757%;*margin-left:45.47372751851417%}.fuelux .row-fluid .offset5:first-child{margin-left:42.81767955801105%;*margin-left:42.71129657928765%}.fuelux .row-fluid .offset4{margin-left:37.01657458563536%;*margin-left:36.91019160691196%}.fuelux .row-fluid .offset4:first-child{margin-left:34.25414364640884%;*margin-left:34.14776066768544%}.fuelux .row-fluid .offset3{margin-left:28.45303867403315%;*margin-left:28.346655695309746%}.fuelux .row-fluid .offset3:first-child{margin-left:25.69060773480663%;*margin-left:25.584224756083227%}.fuelux .row-fluid .offset2{margin-left:19.88950276243094%;*margin-left:19.783119783707537%}.fuelux .row-fluid .offset2:first-child{margin-left:17.12707182320442%;*margin-left:17.02068884448102%}.fuelux .row-fluid .offset1{margin-left:11.32596685082873%;*margin-left:11.219583872105325%}.fuelux .row-fluid .offset1:first-child{margin-left:8.56353591160221%;*margin-left:8.457152932878806%}.fuelux input,.fuelux textarea,.fuelux .uneditable-input{margin-left:0}.fuelux .controls-row [class*="span"]+[class*="span"]{margin-left:20px}.fuelux input.span12,textarea.span12,.uneditable-input.span12{width:710px}.fuelux input.span11,textarea.span11,.uneditable-input.span11{width:648px}.fuelux input.span10,textarea.span10,.uneditable-input.span10{width:586px}.fuelux input.span9,textarea.span9,.uneditable-input.span9{width:524px}.fuelux input.span8,textarea.span8,.uneditable-input.span8{width:462px}.fuelux input.span7,textarea.span7,.uneditable-input.span7{width:400px}.fuelux input.span6,textarea.span6,.uneditable-input.span6{width:338px}.fuelux input.span5,textarea.span5,.uneditable-input.span5{width:276px}.fuelux input.span4,textarea.span4,.uneditable-input.span4{width:214px}.fuelux input.span3,textarea.span3,.uneditable-input.span3{width:152px}.fuelux input.span2,textarea.span2,.uneditable-input.span2{width:90px}.fuelux input.span1,textarea.span1,.uneditable-input.span1{width:28px}}@media(max-width:767px){.fuelux body{padding-right:20px;padding-left:20px}.fuelux .navbar-fixed-top,.fuelux .navbar-fixed-bottom,.fuelux .navbar-static-top{margin-right:-20px;margin-left:-20px}.fuelux .container-fluid{padding:0}.fuelux .dl-horizontal dt{float:none;width:auto;clear:none;text-align:left}.fuelux .dl-horizontal dd{margin-left:0}.fuelux .container{width:auto}.fuelux .row-fluid{width:100%}.fuelux .row,.fuelux .thumbnails{margin-left:0}.fuelux .thumbnails>li{float:none;margin-left:0}.fuelux [class*="span"],.fuelux .uneditable-input[class*="span"],.fuelux .row-fluid [class*="span"]{display:block;float:none;width:100%;margin-left:0;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}.fuelux .span12,.fuelux .row-fluid .span12{width:100%;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}.fuelux .row-fluid [class*="offset"]:first-child{margin-left:0}.fuelux .input-large,.fuelux .input-xlarge,.fuelux .input-xxlarge,.fuelux input[class*="span"],.fuelux select[class*="span"],.fuelux textarea[class*="span"],.fuelux .uneditable-input{display:block;width:100%;min-height:30px;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}.fuelux .input-prepend input,.fuelux .input-append input,.fuelux .input-prepend input[class*="span"],.fuelux .input-append input[class*="span"]{display:inline-block;width:auto}.fuelux .controls-row [class*="span"]+[class*="span"]{margin-left:0}.fuelux .modal{position:fixed;top:20px;right:20px;left:20px;width:auto;margin:0}.fuelux .modal.fade{top:-100px}.fuelux .modal.fade.in{top:20px}}@media(max-width:480px){.fuelux .nav-collapse{-webkit-transform:translate3d(0,0,0)}.fuelux .page-header h1 small{display:block;line-height:20px}.fuelux input[type="checkbox"],.fuelux input[type="radio"]{border:1px solid #ccc}.fuelux .form-horizontal .control-label{float:none;width:auto;padding-top:0;text-align:left}.fuelux .form-horizontal .controls{margin-left:0}.fuelux .form-horizontal .control-list{padding-top:0}.fuelux .form-horizontal .form-actions{padding-right:10px;padding-left:10px}.fuelux .media .pull-left,.fuelux .media .pull-right{display:block;float:none;margin-bottom:10px}.fuelux .media-object{margin-right:0;margin-left:0}.fuelux .modal{top:10px;right:10px;left:10px}.fuelux .modal-header .close{padding:10px;margin:-10px}.fuelux .carousel-caption{position:static}}@media(max-width:979px){.fuelux body{padding-top:0}.fuelux .navbar-fixed-top,.fuelux .navbar-fixed-bottom{position:static}.fuelux .navbar-fixed-top{margin-bottom:20px}.fuelux .navbar-fixed-bottom{margin-top:20px}.fuelux .navbar-fixed-top .navbar-inner,.fuelux .navbar-fixed-bottom .navbar-inner{padding:5px}.fuelux .navbar .container{width:auto;padding:0}.fuelux .navbar .brand{padding-right:10px;padding-left:10px;margin:0 0 0 -5px}.fuelux .nav-collapse{clear:both}.fuelux .nav-collapse .nav{float:none;margin:0 0 10px}.fuelux .nav-collapse .nav>li{float:none}.fuelux .nav-collapse .nav>li>a{margin-bottom:2px}.fuelux .nav-collapse .nav>.divider-vertical{display:none}.fuelux .nav-collapse .nav .nav-header{color:#777;text-shadow:none}.fuelux .nav-collapse .nav>li>a,.fuelux .nav-collapse .dropdown-menu a{padding:9px 15px;font-weight:bold;color:#777;-webkit-border-radius:3px;-moz-border-radius:3px;border-radius:3px}.fuelux .nav-collapse .btn{padding:4px 10px 4px;font-weight:normal;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px}.fuelux .nav-collapse .dropdown-menu li+li a{margin-bottom:2px}.fuelux .nav-collapse .nav>li>a:hover,.fuelux .nav-collapse .nav>li>a:focus,.fuelux .nav-collapse .dropdown-menu a:hover,.fuelux .nav-collapse .dropdown-menu a:focus{background-color:#f2f2f2}.fuelux .navbar-inverse .nav-collapse .nav>li>a,.fuelux .navbar-inverse .nav-collapse .dropdown-menu a{color:#999}.fuelux .navbar-inverse .nav-collapse .nav>li>a:hover,.fuelux .navbar-inverse .nav-collapse .nav>li>a:focus,.fuelux .navbar-inverse .nav-collapse .dropdown-menu a:hover,.fuelux .navbar-inverse .nav-collapse .dropdown-menu a:focus{background-color:#111}.fuelux .nav-collapse.in .btn-group{padding:0;margin-top:5px}.fuelux .nav-collapse .dropdown-menu{position:static;top:auto;left:auto;display:none;float:none;max-width:none;padding:0;margin:0 15px;background-color:transparent;border:0;-webkit-border-radius:0;-moz-border-radius:0;border-radius:0;-webkit-box-shadow:none;-moz-box-shadow:none;box-shadow:none}.fuelux .nav-collapse .open>.dropdown-menu{display:block}.fuelux .nav-collapse .dropdown-menu:before,.fuelux .nav-collapse .dropdown-menu:after{display:none}.fuelux .nav-collapse .dropdown-menu .divider{display:none}.fuelux .nav-collapse .nav>li>.dropdown-menu:before,.fuelux .nav-collapse .nav>li>.dropdown-menu:after{display:none}.fuelux .nav-collapse .navbar-form,.fuelux .nav-collapse .navbar-search{float:none;padding:10px 15px;margin:10px 0;border-top:1px solid #f2f2f2;border-bottom:1px solid #f2f2f2;-webkit-box-shadow:inset 0 1px 0 rgba(255,255,255,0.1),0 1px 0 rgba(255,255,255,0.1);-moz-box-shadow:inset 0 1px 0 rgba(255,255,255,0.1),0 1px 0 rgba(255,255,255,0.1);box-shadow:inset 0 1px 0 rgba(255,255,255,0.1),0 1px 0 rgba(255,255,255,0.1)}.fuelux .navbar-inverse .nav-collapse .navbar-form,.fuelux .navbar-inverse .nav-collapse .navbar-search{border-top-color:#111;border-bottom-color:#111}.fuelux .navbar .nav-collapse .nav.pull-right{float:none;margin-left:0}.fuelux .nav-collapse,.fuelux .nav-collapse.collapse{height:0;overflow:hidden}.fuelux .navbar .btn-navbar{display:block}.fuelux .navbar-static .navbar-inner{padding-right:10px;padding-left:10px}}@media(min-width:980px){.fuelux .nav-collapse.collapse{height:auto!important;overflow:visible!important}}
\ No newline at end of file
diff --git a/opendaylight/adsal/web/root/src/main/resources/css/fuelux.min.css b/opendaylight/adsal/web/root/src/main/resources/css/fuelux.min.css
deleted file mode 100755 (executable)
index 314f3dc..0000000
+++ /dev/null
@@ -1,9 +0,0 @@
-/*!
- * Bootstrap v2.3.2
- *
- * Copyright 2012 Twitter, Inc
- * Licensed under the Apache License v2.0
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Designed and built with all the love in the world @twitter by @mdo and @fat.
- */.fuelux .clearfix{*zoom:1}.fuelux .clearfix:before,.fuelux .clearfix:after{display:table;line-height:0;content:""}.fuelux .clearfix:after{clear:both}.fuelux .hide-text{font:0/0 a;color:transparent;text-shadow:none;background-color:transparent;border:0}.fuelux .input-block-level{display:block;width:100%;min-height:30px;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}.fuelux article,.fuelux aside,.fuelux details,.fuelux figcaption,.fuelux figure,.fuelux footer,.fuelux header,.fuelux hgroup,.fuelux nav,.fuelux section{display:block}.fuelux audio,.fuelux canvas,.fuelux video{display:inline-block;*display:inline;*zoom:1}.fuelux audio:not([controls]){display:none}.fuelux html{font-size:100%;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%}.fuelux a:focus{outline:thin dotted #333;outline:5px auto -webkit-focus-ring-color;outline-offset:-2px}.fuelux a:hover,.fuelux a:active{outline:0}.fuelux sub,.fuelux sup{position:relative;font-size:75%;line-height:0;vertical-align:baseline}.fuelux sup{top:-0.5em}.fuelux sub{bottom:-0.25em}.fuelux img{width:auto\9;height:auto;max-width:100%;vertical-align:middle;border:0;-ms-interpolation-mode:bicubic}.fuelux #map_canvas img,.fuelux .google-maps img{max-width:none}.fuelux button,.fuelux input,.fuelux select,.fuelux textarea{margin:0;font-size:100%;vertical-align:middle}.fuelux button,.fuelux input{*overflow:visible;line-height:normal}.fuelux button::-moz-focus-inner,.fuelux input::-moz-focus-inner{padding:0;border:0}.fuelux button,.fuelux html input[type="button"],.fuelux input[type="reset"],.fuelux input[type="submit"]{cursor:pointer;-webkit-appearance:button}.fuelux label,.fuelux select,.fuelux button,.fuelux input[type="button"],.fuelux input[type="reset"],.fuelux input[type="submit"],.fuelux input[type="radio"],.fuelux input[type="checkbox"]{cursor:pointer}.fuelux input[type="search"]{-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box;-webkit-appearance:textfield}.fuelux input[type="search"]::-webkit-search-decoration,.fuelux input[type="search"]::-webkit-search-cancel-button{-webkit-appearance:none}.fuelux textarea{overflow:auto;vertical-align:top}@media print{.fuelux *{color:#000!important;text-shadow:none!important;background:transparent!important;box-shadow:none!important}.fuelux a,.fuelux a:visited{text-decoration:underline}.fuelux a[href]:after{content:" (" attr(href) ")"}.fuelux abbr[title]:after{content:" (" attr(title) ")"}.fuelux .ir a:after,.fuelux a[href^="javascript:"]:after,.fuelux a[href^="#"]:after{content:""}.fuelux pre,.fuelux blockquote{border:1px solid #999;page-break-inside:avoid}.fuelux thead{display:table-header-group}.fuelux tr,.fuelux img{page-break-inside:avoid}.fuelux img{max-width:100%!important}@page{margin:.5cm}.fuelux p,.fuelux h2,.fuelux h3{widows:3;orphans:3}.fuelux h2,.fuelux h3{page-break-after:avoid}}.fuelux body{margin:0;font-family:"Helvetica Neue",Helvetica,Arial,sans-serif;font-size:14px;line-height:20px;color:#333;background-color:#fff}.fuelux a{color:#08c;text-decoration:none}.fuelux a:hover,.fuelux a:focus{color:#005580;text-decoration:underline}.fuelux .img-rounded{-webkit-border-radius:6px;-moz-border-radius:6px;border-radius:6px}.fuelux .img-polaroid{padding:4px;background-color:#fff;border:1px solid #ccc;border:1px solid rgba(0,0,0,0.2);-webkit-box-shadow:0 1px 3px rgba(0,0,0,0.1);-moz-box-shadow:0 1px 3px rgba(0,0,0,0.1);box-shadow:0 1px 3px rgba(0,0,0,0.1)}.fuelux .img-circle{-webkit-border-radius:500px;-moz-border-radius:500px;border-radius:500px}.fuelux .row{margin-left:-20px;*zoom:1}.fuelux .row:before,.fuelux .row:after{display:table;line-height:0;content:""}.fuelux .row:after{clear:both}.fuelux [class*="span"]{float:left;min-height:1px;margin-left:20px}.fuelux .container,.fuelux .navbar-static-top .container,.fuelux .navbar-fixed-top .container,.fuelux .navbar-fixed-bottom .container{width:940px}.fuelux .span12{width:940px}.fuelux .span11{width:860px}.fuelux .span10{width:780px}.fuelux .span9{width:700px}.fuelux .span8{width:620px}.fuelux .span7{width:540px}.fuelux .span6{width:460px}.fuelux .span5{width:380px}.fuelux .span4{width:300px}.fuelux .span3{width:220px}.fuelux .span2{width:140px}.fuelux .span1{width:60px}.fuelux .offset12{margin-left:980px}.fuelux .offset11{margin-left:900px}.fuelux .offset10{margin-left:820px}.fuelux .offset9{margin-left:740px}.fuelux .offset8{margin-left:660px}.fuelux .offset7{margin-left:580px}.fuelux .offset6{margin-left:500px}.fuelux .offset5{margin-left:420px}.fuelux .offset4{margin-left:340px}.fuelux .offset3{margin-left:260px}.fuelux .offset2{margin-left:180px}.fuelux .offset1{margin-left:100px}.fuelux .row-fluid{width:100%;*zoom:1}.fuelux .row-fluid:before,.fuelux .row-fluid:after{display:table;line-height:0;content:""}.fuelux .row-fluid:after{clear:both}.fuelux .row-fluid [class*="span"]{display:block;float:left;width:100%;min-height:30px;margin-left:2.127659574468085%;*margin-left:2.074468085106383%;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}.fuelux .row-fluid [class*="span"]:first-child{margin-left:0}.fuelux .row-fluid .controls-row [class*="span"]+[class*="span"]{margin-left:2.127659574468085%}.fuelux .row-fluid .span12{width:100%;*width:99.94680851063829%}.fuelux .row-fluid .span11{width:91.48936170212765%;*width:91.43617021276594%}.fuelux .row-fluid .span10{width:82.97872340425532%;*width:82.92553191489361%}.fuelux .row-fluid .span9{width:74.46808510638297%;*width:74.41489361702126%}.fuelux .row-fluid .span8{width:65.95744680851064%;*width:65.90425531914893%}.fuelux .row-fluid .span7{width:57.44680851063829%;*width:57.39361702127659%}.fuelux .row-fluid .span6{width:48.93617021276595%;*width:48.88297872340425%}.fuelux .row-fluid .span5{width:40.42553191489362%;*width:40.37234042553192%}.fuelux .row-fluid .span4{width:31.914893617021278%;*width:31.861702127659576%}.fuelux .row-fluid .span3{width:23.404255319148934%;*width:23.351063829787233%}.fuelux .row-fluid .span2{width:14.893617021276595%;*width:14.840425531914894%}.fuelux .row-fluid .span1{width:6.382978723404255%;*width:6.329787234042553%}.fuelux .row-fluid .offset12{margin-left:104.25531914893617%;*margin-left:104.14893617021275%}.fuelux .row-fluid .offset12:first-child{margin-left:102.12765957446808%;*margin-left:102.02127659574467%}.fuelux .row-fluid .offset11{margin-left:95.74468085106382%;*margin-left:95.6382978723404%}.fuelux .row-fluid .offset11:first-child{margin-left:93.61702127659574%;*margin-left:93.51063829787232%}.fuelux .row-fluid .offset10{margin-left:87.23404255319149%;*margin-left:87.12765957446807%}.fuelux .row-fluid .offset10:first-child{margin-left:85.1063829787234%;*margin-left:84.99999999999999%}.fuelux .row-fluid .offset9{margin-left:78.72340425531914%;*margin-left:78.61702127659572%}.fuelux .row-fluid .offset9:first-child{margin-left:76.59574468085106%;*margin-left:76.48936170212764%}.fuelux .row-fluid .offset8{margin-left:70.2127659574468%;*margin-left:70.10638297872339%}.fuelux .row-fluid .offset8:first-child{margin-left:68.08510638297872%;*margin-left:67.9787234042553%}.fuelux .row-fluid .offset7{margin-left:61.70212765957446%;*margin-left:61.59574468085106%}.fuelux .row-fluid .offset7:first-child{margin-left:59.574468085106375%;*margin-left:59.46808510638297%}.fuelux .row-fluid .offset6{margin-left:53.191489361702125%;*margin-left:53.085106382978715%}.fuelux .row-fluid .offset6:first-child{margin-left:51.063829787234035%;*margin-left:50.95744680851063%}.fuelux .row-fluid .offset5{margin-left:44.68085106382979%;*margin-left:44.57446808510638%}.fuelux .row-fluid .offset5:first-child{margin-left:42.5531914893617%;*margin-left:42.4468085106383%}.fuelux .row-fluid .offset4{margin-left:36.170212765957444%;*margin-left:36.06382978723405%}.fuelux .row-fluid .offset4:first-child{margin-left:34.04255319148936%;*margin-left:33.93617021276596%}.fuelux .row-fluid .offset3{margin-left:27.659574468085104%;*margin-left:27.5531914893617%}.fuelux .row-fluid .offset3:first-child{margin-left:25.53191489361702%;*margin-left:25.425531914893618%}.fuelux .row-fluid .offset2{margin-left:19.148936170212764%;*margin-left:19.04255319148936%}.fuelux .row-fluid .offset2:first-child{margin-left:17.02127659574468%;*margin-left:16.914893617021278%}.fuelux .row-fluid .offset1{margin-left:10.638297872340425%;*margin-left:10.53191489361702%}.fuelux .row-fluid .offset1:first-child{margin-left:8.51063829787234%;*margin-left:8.404255319148938%}.fuelux [class*="span"].hide,.fuelux .row-fluid [class*="span"].hide{display:none}.fuelux [class*="span"].pull-right,.fuelux .row-fluid [class*="span"].pull-right{float:right}.fuelux .container{margin-right:auto;margin-left:auto;*zoom:1}.fuelux .container:before,.fuelux .container:after{display:table;line-height:0;content:""}.fuelux .container:after{clear:both}.fuelux .container-fluid{padding-right:20px;padding-left:20px;*zoom:1}.fuelux .container-fluid:before,.fuelux .container-fluid:after{display:table;line-height:0;content:""}.fuelux .container-fluid:after{clear:both}.fuelux p{margin:0 0 10px}.fuelux .lead{margin-bottom:20px;font-size:21px;font-weight:200;line-height:30px}.fuelux small{font-size:85%}.fuelux strong{font-weight:bold}.fuelux em{font-style:italic}.fuelux cite{font-style:normal}.fuelux .muted{color:#999}.fuelux a.muted:hover,.fuelux a.muted:focus{color:#808080}.fuelux .text-warning{color:#c09853}.fuelux a.text-warning:hover,.fuelux a.text-warning:focus{color:#a47e3c}.fuelux .text-error{color:#b94a48}.fuelux a.text-error:hover,.fuelux a.text-error:focus{color:#953b39}.fuelux .text-info{color:#3a87ad}.fuelux a.text-info:hover,.fuelux a.text-info:focus{color:#2d6987}.fuelux .text-success{color:#468847}.fuelux a.text-success:hover,.fuelux a.text-success:focus{color:#356635}.fuelux .text-left{text-align:left}.fuelux .text-right{text-align:right}.fuelux .text-center{text-align:center}.fuelux h1,.fuelux h2,.fuelux h3,.fuelux h4,.fuelux h5,.fuelux h6{margin:10px 0;font-family:inherit;font-weight:bold;line-height:20px;color:inherit;text-rendering:optimizelegibility}.fuelux h1 small,.fuelux h2 small,.fuelux h3 small,.fuelux h4 small,.fuelux h5 small,.fuelux h6 small{font-weight:normal;line-height:1;color:#999}.fuelux h1,.fuelux h2,.fuelux h3{line-height:40px}.fuelux h1{font-size:38.5px}.fuelux h2{font-size:31.5px}.fuelux h3{font-size:24.5px}.fuelux h4{font-size:17.5px}.fuelux h5{font-size:14px}.fuelux h6{font-size:11.9px}.fuelux h1 small{font-size:24.5px}.fuelux h2 small{font-size:17.5px}.fuelux h3 small{font-size:14px}.fuelux h4 small{font-size:14px}.fuelux .page-header{padding-bottom:9px;margin:20px 0 30px;border-bottom:1px solid #eee}.fuelux ul,.fuelux ol{padding:0;margin:0 0 10px 25px}.fuelux ul ul,.fuelux ul ol,.fuelux ol ol,.fuelux ol ul{margin-bottom:0}.fuelux li{line-height:20px}.fuelux ul.unstyled,.fuelux ol.unstyled{margin-left:0;list-style:none}.fuelux ul.inline,.fuelux ol.inline{margin-left:0;list-style:none}.fuelux ul.inline>li,.fuelux ol.inline>li{display:inline-block;*display:inline;padding-right:5px;padding-left:5px;*zoom:1}.fuelux dl{margin-bottom:20px}.fuelux dt,.fuelux dd{line-height:20px}.fuelux dt{font-weight:bold}.fuelux dd{margin-left:10px}.fuelux .dl-horizontal{*zoom:1}.fuelux .dl-horizontal:before,.fuelux .dl-horizontal:after{display:table;line-height:0;content:""}.fuelux .dl-horizontal:after{clear:both}.fuelux .dl-horizontal dt{float:left;width:160px;overflow:hidden;clear:left;text-align:right;text-overflow:ellipsis;white-space:nowrap}.fuelux .dl-horizontal dd{margin-left:180px}.fuelux hr{margin:20px 0;border:0;border-top:1px solid #eee;border-bottom:1px solid #fff}.fuelux abbr[title],.fuelux abbr[data-original-title]{cursor:help;border-bottom:1px dotted #999}.fuelux abbr.initialism{font-size:90%;text-transform:uppercase}.fuelux blockquote{padding:0 0 0 15px;margin:0 0 20px;border-left:5px solid #eee}.fuelux blockquote p{margin-bottom:0;font-size:17.5px;font-weight:300;line-height:1.25}.fuelux blockquote small{display:block;line-height:20px;color:#999}.fuelux blockquote small:before{content:'\2014 \00A0'}.fuelux blockquote.pull-right{float:right;padding-right:15px;padding-left:0;border-right:5px solid #eee;border-left:0}.fuelux blockquote.pull-right p,.fuelux blockquote.pull-right small{text-align:right}.fuelux blockquote.pull-right small:before{content:''}.fuelux blockquote.pull-right small:after{content:'\00A0 \2014'}.fuelux q:before,.fuelux q:after,.fuelux blockquote:before,.fuelux blockquote:after{content:""}.fuelux address{display:block;margin-bottom:20px;font-style:normal;line-height:20px}.fuelux code,.fuelux pre{padding:0 3px 2px;font-family:Monaco,Menlo,Consolas,"Courier New",monospace;font-size:12px;color:#333;-webkit-border-radius:3px;-moz-border-radius:3px;border-radius:3px}.fuelux code{padding:2px 4px;color:#d14;white-space:nowrap;background-color:#f7f7f9;border:1px solid #e1e1e8}.fuelux pre{display:block;padding:9.5px;margin:0 0 10px;font-size:13px;line-height:20px;word-break:break-all;word-wrap:break-word;white-space:pre;white-space:pre-wrap;background-color:#f5f5f5;border:1px solid #ccc;border:1px solid rgba(0,0,0,0.15);-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px}.fuelux pre.prettyprint{margin-bottom:20px}.fuelux pre code{padding:0;color:inherit;white-space:pre;white-space:pre-wrap;background-color:transparent;border:0}.fuelux .pre-scrollable{max-height:340px;overflow-y:scroll}.fuelux form{margin:0 0 20px}.fuelux fieldset{padding:0;margin:0;border:0}.fuelux legend{display:block;width:100%;padding:0;margin-bottom:20px;font-size:21px;line-height:40px;color:#333;border:0;border-bottom:1px solid #e5e5e5}.fuelux legend small{font-size:15px;color:#999}.fuelux label,.fuelux input,.fuelux button,.fuelux select,.fuelux textarea{font-size:14px;font-weight:normal;line-height:20px}.fuelux input,.fuelux button,.fuelux select,.fuelux textarea{font-family:"Helvetica Neue",Helvetica,Arial,sans-serif}.fuelux label{display:block;margin-bottom:5px}.fuelux select,.fuelux textarea,.fuelux input[type="text"],.fuelux input[type="password"],.fuelux input[type="datetime"],.fuelux input[type="datetime-local"],.fuelux input[type="date"],.fuelux input[type="month"],.fuelux input[type="time"],.fuelux input[type="week"],.fuelux input[type="number"],.fuelux input[type="email"],.fuelux input[type="url"],.fuelux input[type="search"],.fuelux input[type="tel"],.fuelux input[type="color"],.fuelux .uneditable-input{display:inline-block;height:20px;padding:4px 6px;margin-bottom:10px;font-size:14px;line-height:20px;color:#555;vertical-align:middle;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px}.fuelux input,.fuelux textarea,.fuelux .uneditable-input{width:206px}.fuelux textarea{height:auto}.fuelux textarea,.fuelux input[type="text"],.fuelux input[type="password"],.fuelux input[type="datetime"],.fuelux input[type="datetime-local"],.fuelux input[type="date"],.fuelux input[type="month"],.fuelux input[type="time"],.fuelux input[type="week"],.fuelux input[type="number"],.fuelux input[type="email"],.fuelux input[type="url"],.fuelux input[type="search"],.fuelux input[type="tel"],.fuelux input[type="color"],.fuelux .uneditable-input{background-color:#fff;border:1px solid #ccc;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075);-moz-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075);box-shadow:inset 0 1px 1px rgba(0,0,0,0.075);-webkit-transition:border linear .2s,box-shadow linear .2s;-moz-transition:border linear .2s,box-shadow linear .2s;-o-transition:border linear .2s,box-shadow linear .2s;transition:border linear .2s,box-shadow linear .2s}.fuelux textarea:focus,.fuelux input[type="text"]:focus,.fuelux input[type="password"]:focus,.fuelux input[type="datetime"]:focus,.fuelux input[type="datetime-local"]:focus,.fuelux input[type="date"]:focus,.fuelux input[type="month"]:focus,.fuelux input[type="time"]:focus,.fuelux input[type="week"]:focus,.fuelux input[type="number"]:focus,.fuelux input[type="email"]:focus,.fuelux input[type="url"]:focus,.fuelux input[type="search"]:focus,.fuelux input[type="tel"]:focus,.fuelux input[type="color"]:focus,.fuelux .uneditable-input:focus{border-color:rgba(82,168,236,0.8);outline:0;outline:thin dotted \9;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 8px rgba(82,168,236,0.6);-moz-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 8px rgba(82,168,236,0.6);box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 8px rgba(82,168,236,0.6)}.fuelux input[type="radio"],.fuelux input[type="checkbox"]{margin:4px 0 0;margin-top:1px \9;*margin-top:0;line-height:normal}.fuelux input[type="file"],.fuelux input[type="image"],.fuelux input[type="submit"],.fuelux input[type="reset"],.fuelux input[type="button"],.fuelux input[type="radio"],.fuelux input[type="checkbox"]{width:auto}.fuelux select,.fuelux input[type="file"]{height:30px;*margin-top:4px;line-height:30px}.fuelux select{width:220px;background-color:#fff;border:1px solid #ccc}.fuelux select[multiple],.fuelux select[size]{height:auto}.fuelux select:focus,.fuelux input[type="file"]:focus,.fuelux input[type="radio"]:focus,.fuelux input[type="checkbox"]:focus{outline:thin dotted #333;outline:5px auto -webkit-focus-ring-color;outline-offset:-2px}.fuelux .uneditable-input,.fuelux .uneditable-textarea{color:#999;cursor:not-allowed;background-color:#fcfcfc;border-color:#ccc;-webkit-box-shadow:inset 0 1px 2px rgba(0,0,0,0.025);-moz-box-shadow:inset 0 1px 2px rgba(0,0,0,0.025);box-shadow:inset 0 1px 2px rgba(0,0,0,0.025)}.fuelux .uneditable-input{overflow:hidden;white-space:nowrap}.fuelux .uneditable-textarea{width:auto;height:auto}.fuelux input:-moz-placeholder,.fuelux textarea:-moz-placeholder{color:#999}.fuelux input:-ms-input-placeholder,.fuelux textarea:-ms-input-placeholder{color:#999}.fuelux input::-webkit-input-placeholder,.fuelux textarea::-webkit-input-placeholder{color:#999}.fuelux .radio,.fuelux .checkbox{min-height:20px;padding-left:20px}.fuelux .radio input[type="radio"],.fuelux .checkbox input[type="checkbox"]{float:left;margin-left:-20px}.fuelux .controls>.radio:first-child,.fuelux .controls>.checkbox:first-child{padding-top:5px}.fuelux .radio.inline,.fuelux .checkbox.inline{display:inline-block;padding-top:5px;margin-bottom:0;vertical-align:middle}.fuelux .radio.inline+.radio.inline,.fuelux .checkbox.inline+.checkbox.inline{margin-left:10px}.fuelux .input-mini{width:60px}.fuelux .input-small{width:90px}.fuelux .input-medium{width:150px}.fuelux .input-large{width:210px}.fuelux .input-xlarge{width:270px}.fuelux .input-xxlarge{width:530px}.fuelux input[class*="span"],.fuelux select[class*="span"],.fuelux textarea[class*="span"],.fuelux .uneditable-input[class*="span"],.fuelux .row-fluid input[class*="span"],.fuelux .row-fluid select[class*="span"],.fuelux .row-fluid textarea[class*="span"],.fuelux .row-fluid .uneditable-input[class*="span"]{float:none;margin-left:0}.fuelux .input-append input[class*="span"],.fuelux .input-append .uneditable-input[class*="span"],.fuelux .input-prepend input[class*="span"],.fuelux .input-prepend .uneditable-input[class*="span"],.fuelux .row-fluid input[class*="span"],.fuelux .row-fluid select[class*="span"],.fuelux .row-fluid textarea[class*="span"],.fuelux .row-fluid .uneditable-input[class*="span"],.fuelux .row-fluid .input-prepend [class*="span"],.fuelux .row-fluid .input-append [class*="span"]{display:inline-block}.fuelux input,.fuelux textarea,.fuelux .uneditable-input{margin-left:0}.fuelux .controls-row [class*="span"]+[class*="span"]{margin-left:20px}.fuelux input.span12,textarea.span12,.uneditable-input.span12{width:926px}.fuelux input.span11,textarea.span11,.uneditable-input.span11{width:846px}.fuelux input.span10,textarea.span10,.uneditable-input.span10{width:766px}.fuelux input.span9,textarea.span9,.uneditable-input.span9{width:686px}.fuelux input.span8,textarea.span8,.uneditable-input.span8{width:606px}.fuelux input.span7,textarea.span7,.uneditable-input.span7{width:526px}.fuelux input.span6,textarea.span6,.uneditable-input.span6{width:446px}.fuelux input.span5,textarea.span5,.uneditable-input.span5{width:366px}.fuelux input.span4,textarea.span4,.uneditable-input.span4{width:286px}.fuelux input.span3,textarea.span3,.uneditable-input.span3{width:206px}.fuelux input.span2,textarea.span2,.uneditable-input.span2{width:126px}.fuelux input.span1,textarea.span1,.uneditable-input.span1{width:46px}.fuelux .controls-row{*zoom:1}.fuelux .controls-row:before,.fuelux .controls-row:after{display:table;line-height:0;content:""}.fuelux .controls-row:after{clear:both}.fuelux .controls-row [class*="span"],.fuelux .row-fluid .controls-row [class*="span"]{float:left}.fuelux .controls-row .checkbox[class*="span"],.fuelux .controls-row .radio[class*="span"]{padding-top:5px}.fuelux input[disabled],.fuelux select[disabled],.fuelux textarea[disabled],.fuelux input[readonly],.fuelux select[readonly],.fuelux textarea[readonly]{cursor:not-allowed;background-color:#eee}.fuelux input[type="radio"][disabled],.fuelux input[type="checkbox"][disabled],.fuelux input[type="radio"][readonly],.fuelux input[type="checkbox"][readonly]{background-color:transparent}.fuelux .control-group.warning .control-label,.fuelux .control-group.warning .help-block,.fuelux .control-group.warning .help-inline{color:#c09853}.fuelux .control-group.warning .checkbox,.fuelux .control-group.warning .radio,.fuelux .control-group.warning input,.fuelux .control-group.warning select,.fuelux .control-group.warning textarea{color:#c09853}.fuelux .control-group.warning input,.fuelux .control-group.warning select,.fuelux .control-group.warning textarea{border-color:#c09853;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075);-moz-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075);box-shadow:inset 0 1px 1px rgba(0,0,0,0.075)}.fuelux .control-group.warning input:focus,.fuelux .control-group.warning select:focus,.fuelux .control-group.warning textarea:focus{border-color:#a47e3c;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 6px #dbc59e;-moz-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 6px #dbc59e;box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 6px #dbc59e}.fuelux .control-group.warning .input-prepend .add-on,.fuelux .control-group.warning .input-append .add-on{color:#c09853;background-color:#fcf8e3;border-color:#c09853}.fuelux .control-group.error .control-label,.fuelux .control-group.error .help-block,.fuelux .control-group.error .help-inline{color:#b94a48}.fuelux .control-group.error .checkbox,.fuelux .control-group.error .radio,.fuelux .control-group.error input,.fuelux .control-group.error select,.fuelux .control-group.error textarea{color:#b94a48}.fuelux .control-group.error input,.fuelux .control-group.error select,.fuelux .control-group.error textarea{border-color:#b94a48;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075);-moz-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075);box-shadow:inset 0 1px 1px rgba(0,0,0,0.075)}.fuelux .control-group.error input:focus,.fuelux .control-group.error select:focus,.fuelux .control-group.error textarea:focus{border-color:#953b39;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 6px #d59392;-moz-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 6px #d59392;box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 6px #d59392}.fuelux .control-group.error .input-prepend .add-on,.fuelux .control-group.error .input-append .add-on{color:#b94a48;background-color:#f2dede;border-color:#b94a48}.fuelux .control-group.success .control-label,.fuelux .control-group.success .help-block,.fuelux .control-group.success .help-inline{color:#468847}.fuelux .control-group.success .checkbox,.fuelux .control-group.success .radio,.fuelux .control-group.success input,.fuelux .control-group.success select,.fuelux .control-group.success textarea{color:#468847}.fuelux .control-group.success input,.fuelux .control-group.success select,.fuelux .control-group.success textarea{border-color:#468847;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075);-moz-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075);box-shadow:inset 0 1px 1px rgba(0,0,0,0.075)}.fuelux .control-group.success input:focus,.fuelux .control-group.success select:focus,.fuelux .control-group.success textarea:focus{border-color:#356635;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 6px #7aba7b;-moz-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 6px #7aba7b;box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 6px #7aba7b}.fuelux .control-group.success .input-prepend .add-on,.fuelux .control-group.success .input-append .add-on{color:#468847;background-color:#dff0d8;border-color:#468847}.fuelux .control-group.info .control-label,.fuelux .control-group.info .help-block,.fuelux .control-group.info .help-inline{color:#3a87ad}.fuelux .control-group.info .checkbox,.fuelux .control-group.info .radio,.fuelux .control-group.info input,.fuelux .control-group.info select,.fuelux .control-group.info textarea{color:#3a87ad}.fuelux .control-group.info input,.fuelux .control-group.info select,.fuelux .control-group.info textarea{border-color:#3a87ad;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075);-moz-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075);box-shadow:inset 0 1px 1px rgba(0,0,0,0.075)}.fuelux .control-group.info input:focus,.fuelux .control-group.info select:focus,.fuelux .control-group.info textarea:focus{border-color:#2d6987;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 6px #7ab5d3;-moz-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 6px #7ab5d3;box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 6px #7ab5d3}.fuelux .control-group.info .input-prepend .add-on,.fuelux .control-group.info .input-append .add-on{color:#3a87ad;background-color:#d9edf7;border-color:#3a87ad}.fuelux input:focus:invalid,.fuelux textarea:focus:invalid,.fuelux select:focus:invalid{color:#b94a48;border-color:#ee5f5b}.fuelux input:focus:invalid:focus,.fuelux textarea:focus:invalid:focus,.fuelux select:focus:invalid:focus{border-color:#e9322d;-webkit-box-shadow:0 0 6px #f8b9b7;-moz-box-shadow:0 0 6px #f8b9b7;box-shadow:0 0 6px #f8b9b7}.fuelux .form-actions{padding:19px 20px 20px;margin-top:20px;margin-bottom:20px;background-color:#f5f5f5;border-top:1px solid #e5e5e5;*zoom:1}.fuelux .form-actions:before,.fuelux .form-actions:after{display:table;line-height:0;content:""}.fuelux .form-actions:after{clear:both}.fuelux .help-block,.fuelux .help-inline{color:#595959}.fuelux .help-block{display:block;margin-bottom:10px}.fuelux .help-inline{display:inline-block;*display:inline;padding-left:5px;vertical-align:middle;*zoom:1}.fuelux .input-append,.fuelux .input-prepend{display:inline-block;margin-bottom:10px;font-size:0;white-space:nowrap;vertical-align:middle}.fuelux .input-append input,.fuelux .input-prepend input,.fuelux .input-append select,.fuelux .input-prepend select,.fuelux .input-append .uneditable-input,.fuelux .input-prepend .uneditable-input,.fuelux .input-append .dropdown-menu,.fuelux .input-prepend .dropdown-menu,.fuelux .input-append .popover,.fuelux .input-prepend .popover{font-size:14px}.fuelux .input-append input,.fuelux .input-prepend input,.fuelux .input-append select,.fuelux .input-prepend select,.fuelux .input-append .uneditable-input,.fuelux .input-prepend .uneditable-input{position:relative;margin-bottom:0;*margin-left:0;vertical-align:top;-webkit-border-radius:0 4px 4px 0;-moz-border-radius:0 4px 4px 0;border-radius:0 4px 4px 0}.fuelux .input-append input:focus,.fuelux .input-prepend input:focus,.fuelux .input-append select:focus,.fuelux .input-prepend select:focus,.fuelux .input-append .uneditable-input:focus,.fuelux .input-prepend .uneditable-input:focus{z-index:2}.fuelux .input-append .add-on,.fuelux .input-prepend .add-on{display:inline-block;width:auto;height:20px;min-width:16px;padding:4px 5px;font-size:14px;font-weight:normal;line-height:20px;text-align:center;text-shadow:0 1px 0 #fff;background-color:#eee;border:1px solid #ccc}.fuelux .input-append .add-on,.fuelux .input-prepend .add-on,.fuelux .input-append .btn,.fuelux .input-prepend .btn,.fuelux .input-append .btn-group>.dropdown-toggle,.fuelux .input-prepend .btn-group>.dropdown-toggle{vertical-align:top;-webkit-border-radius:0;-moz-border-radius:0;border-radius:0}.fuelux .input-append .active,.fuelux .input-prepend .active{background-color:#a9dba9;border-color:#46a546}.fuelux .input-prepend .add-on,.fuelux .input-prepend .btn{margin-right:-1px}.fuelux .input-prepend .add-on:first-child,.fuelux .input-prepend .btn:first-child{-webkit-border-radius:4px 0 0 4px;-moz-border-radius:4px 0 0 4px;border-radius:4px 0 0 4px}.fuelux .input-append input,.fuelux .input-append select,.fuelux .input-append .uneditable-input{-webkit-border-radius:4px 0 0 4px;-moz-border-radius:4px 0 0 4px;border-radius:4px 0 0 4px}.fuelux .input-append input+.btn-group .btn:last-child,.fuelux .input-append select+.btn-group .btn:last-child,.fuelux .input-append .uneditable-input+.btn-group .btn:last-child{-webkit-border-radius:0 4px 4px 0;-moz-border-radius:0 4px 4px 0;border-radius:0 4px 4px 0}.fuelux .input-append .add-on,.fuelux .input-append .btn,.fuelux .input-append .btn-group{margin-left:-1px}.fuelux .input-append .add-on:last-child,.fuelux .input-append .btn:last-child,.fuelux .input-append .btn-group:last-child>.dropdown-toggle{-webkit-border-radius:0 4px 4px 0;-moz-border-radius:0 4px 4px 0;border-radius:0 4px 4px 0}.fuelux .input-prepend.input-append input,.fuelux .input-prepend.input-append select,.fuelux .input-prepend.input-append .uneditable-input{-webkit-border-radius:0;-moz-border-radius:0;border-radius:0}.fuelux .input-prepend.input-append input+.btn-group .btn,.fuelux .input-prepend.input-append select+.btn-group .btn,.fuelux .input-prepend.input-append .uneditable-input+.btn-group .btn{-webkit-border-radius:0 4px 4px 0;-moz-border-radius:0 4px 4px 0;border-radius:0 4px 4px 0}.fuelux .input-prepend.input-append .add-on:first-child,.fuelux .input-prepend.input-append .btn:first-child{margin-right:-1px;-webkit-border-radius:4px 0 0 4px;-moz-border-radius:4px 0 0 4px;border-radius:4px 0 0 4px}.fuelux .input-prepend.input-append .add-on:last-child,.fuelux .input-prepend.input-append .btn:last-child{margin-left:-1px;-webkit-border-radius:0 4px 4px 0;-moz-border-radius:0 4px 4px 0;border-radius:0 4px 4px 0}.fuelux .input-prepend.input-append .btn-group:first-child{margin-left:0}.fuelux input.search-query{padding-right:14px;padding-right:4px \9;padding-left:14px;padding-left:4px \9;margin-bottom:0;-webkit-border-radius:15px;-moz-border-radius:15px;border-radius:15px}.fuelux .form-search .input-append .search-query,.fuelux .form-search .input-prepend .search-query{-webkit-border-radius:0;-moz-border-radius:0;border-radius:0}.fuelux .form-search .input-append .search-query{-webkit-border-radius:14px 0 0 14px;-moz-border-radius:14px 0 0 14px;border-radius:14px 0 0 14px}.fuelux .form-search .input-append .btn{-webkit-border-radius:0 14px 14px 0;-moz-border-radius:0 14px 14px 0;border-radius:0 14px 14px 0}.fuelux .form-search .input-prepend .search-query{-webkit-border-radius:0 14px 14px 0;-moz-border-radius:0 14px 14px 0;border-radius:0 14px 14px 0}.fuelux .form-search .input-prepend .btn{-webkit-border-radius:14px 0 0 14px;-moz-border-radius:14px 0 0 14px;border-radius:14px 0 0 14px}.fuelux .form-search input,.fuelux .form-inline input,.fuelux .form-horizontal input,.fuelux .form-search textarea,.fuelux .form-inline textarea,.fuelux .form-horizontal textarea,.fuelux .form-search select,.fuelux .form-inline select,.fuelux .form-horizontal select,.fuelux .form-search .help-inline,.fuelux .form-inline .help-inline,.fuelux .form-horizontal .help-inline,.fuelux .form-search .uneditable-input,.fuelux .form-inline .uneditable-input,.fuelux .form-horizontal .uneditable-input,.fuelux .form-search .input-prepend,.fuelux .form-inline .input-prepend,.fuelux .form-horizontal .input-prepend,.fuelux .form-search .input-append,.fuelux .form-inline .input-append,.fuelux .form-horizontal .input-append{display:inline-block;*display:inline;margin-bottom:0;vertical-align:middle;*zoom:1}.fuelux .form-search .hide,.fuelux .form-inline .hide,.fuelux .form-horizontal .hide{display:none}.fuelux .form-search label,.fuelux .form-inline label,.fuelux .form-search .btn-group,.fuelux .form-inline .btn-group{display:inline-block}.fuelux .form-search .input-append,.fuelux .form-inline .input-append,.fuelux .form-search .input-prepend,.fuelux .form-inline .input-prepend{margin-bottom:0}.fuelux .form-search .radio,.fuelux .form-search .checkbox,.fuelux .form-inline .radio,.fuelux .form-inline .checkbox{padding-left:0;margin-bottom:0;vertical-align:middle}.fuelux .form-search .radio input[type="radio"],.fuelux .form-search .checkbox input[type="checkbox"],.fuelux .form-inline .radio input[type="radio"],.fuelux .form-inline .checkbox input[type="checkbox"]{float:left;margin-right:3px;margin-left:0}.fuelux .control-group{margin-bottom:10px}.fuelux legend+.control-group{margin-top:20px;-webkit-margin-top-collapse:separate}.fuelux .form-horizontal .control-group{margin-bottom:20px;*zoom:1}.fuelux .form-horizontal .control-group:before,.fuelux .form-horizontal .control-group:after{display:table;line-height:0;content:""}.fuelux .form-horizontal .control-group:after{clear:both}.fuelux .form-horizontal .control-label{float:left;width:160px;padding-top:5px;text-align:right}.fuelux .form-horizontal .controls{*display:inline-block;*padding-left:20px;margin-left:180px;*margin-left:0}.fuelux .form-horizontal .controls:first-child{*padding-left:180px}.fuelux .form-horizontal .help-block{margin-bottom:0}.fuelux .form-horizontal input+.help-block,.fuelux .form-horizontal select+.help-block,.fuelux .form-horizontal textarea+.help-block,.fuelux .form-horizontal .uneditable-input+.help-block,.fuelux .form-horizontal .input-prepend+.help-block,.fuelux .form-horizontal .input-append+.help-block{margin-top:10px}.fuelux .form-horizontal .form-actions{padding-left:180px}.fuelux table{max-width:100%;background-color:transparent;border-collapse:collapse;border-spacing:0}.fuelux .table{width:100%;margin-bottom:20px}.fuelux .table th,.fuelux .table td{padding:8px;line-height:20px;text-align:left;vertical-align:top;border-top:1px solid #ddd}.fuelux .table th{font-weight:bold}.fuelux .table thead th{vertical-align:bottom}.fuelux .table caption+thead tr:first-child th,.fuelux .table caption+thead tr:first-child td,.fuelux .table colgroup+thead tr:first-child th,.fuelux .table colgroup+thead tr:first-child td,.fuelux .table thead:first-child tr:first-child th,.fuelux .table thead:first-child tr:first-child td{border-top:0}.fuelux .table tbody+tbody{border-top:2px solid #ddd}.fuelux .table .table{background-color:#fff}.fuelux .table-condensed th,.fuelux .table-condensed td{padding:4px 5px}.fuelux .table-bordered{border:1px solid #ddd;border-collapse:separate;*border-collapse:collapse;border-left:0;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px}.fuelux .table-bordered th,.fuelux .table-bordered td{border-left:1px solid #ddd}.fuelux .table-bordered caption+thead tr:first-child th,.fuelux .table-bordered caption+tbody tr:first-child th,.fuelux .table-bordered caption+tbody tr:first-child td,.fuelux .table-bordered colgroup+thead tr:first-child th,.fuelux .table-bordered colgroup+tbody tr:first-child th,.fuelux .table-bordered colgroup+tbody tr:first-child td,.fuelux .table-bordered thead:first-child tr:first-child th,.fuelux .table-bordered tbody:first-child tr:first-child th,.fuelux .table-bordered tbody:first-child tr:first-child td{border-top:0}.fuelux .table-bordered thead:first-child tr:first-child>th:first-child,.fuelux .table-bordered tbody:first-child tr:first-child>td:first-child,.fuelux .table-bordered tbody:first-child tr:first-child>th:first-child{-webkit-border-top-left-radius:4px;border-top-left-radius:4px;-moz-border-radius-topleft:4px}.fuelux .table-bordered thead:first-child tr:first-child>th:last-child,.fuelux .table-bordered tbody:first-child tr:first-child>td:last-child,.fuelux .table-bordered tbody:first-child tr:first-child>th:last-child{-webkit-border-top-right-radius:4px;border-top-right-radius:4px;-moz-border-radius-topright:4px}.fuelux .table-bordered thead:last-child tr:last-child>th:first-child,.fuelux .table-bordered tbody:last-child tr:last-child>td:first-child,.fuelux .table-bordered tbody:last-child tr:last-child>th:first-child,.fuelux .table-bordered tfoot:last-child tr:last-child>td:first-child,.fuelux .table-bordered tfoot:last-child tr:last-child>th:first-child{-webkit-border-bottom-left-radius:4px;border-bottom-left-radius:4px;-moz-border-radius-bottomleft:4px}.fuelux .table-bordered thead:last-child tr:last-child>th:last-child,.fuelux .table-bordered tbody:last-child tr:last-child>td:last-child,.fuelux .table-bordered tbody:last-child tr:last-child>th:last-child,.fuelux .table-bordered tfoot:last-child tr:last-child>td:last-child,.fuelux .table-bordered tfoot:last-child tr:last-child>th:last-child{-webkit-border-bottom-right-radius:4px;border-bottom-right-radius:4px;-moz-border-radius-bottomright:4px}.fuelux .table-bordered tfoot+tbody:last-child tr:last-child td:first-child{-webkit-border-bottom-left-radius:0;border-bottom-left-radius:0;-moz-border-radius-bottomleft:0}.fuelux .table-bordered tfoot+tbody:last-child tr:last-child td:last-child{-webkit-border-bottom-right-radius:0;border-bottom-right-radius:0;-moz-border-radius-bottomright:0}.fuelux .table-bordered caption+thead tr:first-child th:first-child,.fuelux .table-bordered caption+tbody tr:first-child td:first-child,.fuelux .table-bordered colgroup+thead tr:first-child th:first-child,.fuelux .table-bordered colgroup+tbody tr:first-child td:first-child{-webkit-border-top-left-radius:4px;border-top-left-radius:4px;-moz-border-radius-topleft:4px}.fuelux .table-bordered caption+thead tr:first-child th:last-child,.fuelux .table-bordered caption+tbody tr:first-child td:last-child,.fuelux .table-bordered colgroup+thead tr:first-child th:last-child,.fuelux .table-bordered colgroup+tbody tr:first-child td:last-child{-webkit-border-top-right-radius:4px;border-top-right-radius:4px;-moz-border-radius-topright:4px}.fuelux .table-striped tbody>tr:nth-child(odd)>td,.fuelux .table-striped tbody>tr:nth-child(odd)>th{background-color:#f9f9f9}.fuelux .table-hover tbody tr:hover>td,.fuelux .table-hover tbody tr:hover>th{background-color:#f5f5f5}.fuelux table td[class*="span"],.fuelux table th[class*="span"],.fuelux .row-fluid table td[class*="span"],.fuelux .row-fluid table th[class*="span"]{display:table-cell;float:none;margin-left:0}.fuelux .table td.span1,.fuelux .table th.span1{float:none;width:44px;margin-left:0}.fuelux .table td.span2,.fuelux .table th.span2{float:none;width:124px;margin-left:0}.fuelux .table td.span3,.fuelux .table th.span3{float:none;width:204px;margin-left:0}.fuelux .table td.span4,.fuelux .table th.span4{float:none;width:284px;margin-left:0}.fuelux .table td.span5,.fuelux .table th.span5{float:none;width:364px;margin-left:0}.fuelux .table td.span6,.fuelux .table th.span6{float:none;width:444px;margin-left:0}.fuelux .table td.span7,.fuelux .table th.span7{float:none;width:524px;margin-left:0}.fuelux .table td.span8,.fuelux .table th.span8{float:none;width:604px;margin-left:0}.fuelux .table td.span9,.fuelux .table th.span9{float:none;width:684px;margin-left:0}.fuelux .table td.span10,.fuelux .table th.span10{float:none;width:764px;margin-left:0}.fuelux .table td.span11,.fuelux .table th.span11{float:none;width:844px;margin-left:0}.fuelux .table td.span12,.fuelux .table th.span12{float:none;width:924px;margin-left:0}.fuelux .table tbody tr.success>td{background-color:#dff0d8}.fuelux .table tbody tr.error>td{background-color:#f2dede}.fuelux .table tbody tr.warning>td{background-color:#fcf8e3}.fuelux .table tbody tr.info>td{background-color:#d9edf7}.fuelux .table-hover tbody tr.success:hover>td{background-color:#d0e9c6}.fuelux .table-hover tbody tr.error:hover>td{background-color:#ebcccc}.fuelux .table-hover tbody tr.warning:hover>td{background-color:#faf2cc}.fuelux .table-hover tbody tr.info:hover>td{background-color:#c4e3f3}.fuelux [class^="icon-"],.fuelux [class*=" icon-"]{display:inline-block;width:14px;height:14px;margin-top:1px;*margin-right:.3em;line-height:14px;vertical-align:text-top;background-image:url("../img/glyphicons-halflings.png");background-position:14px 14px;background-repeat:no-repeat}.fuelux .icon-white,.fuelux .nav-pills>.active>a>[class^="icon-"],.fuelux .nav-pills>.active>a>[class*=" icon-"],.fuelux .nav-list>.active>a>[class^="icon-"],.fuelux .nav-list>.active>a>[class*=" icon-"],.fuelux .navbar-inverse .nav>.active>a>[class^="icon-"],.fuelux .navbar-inverse .nav>.active>a>[class*=" icon-"],.fuelux .dropdown-menu>li>a:hover>[class^="icon-"],.fuelux .dropdown-menu>li>a:focus>[class^="icon-"],.fuelux .dropdown-menu>li>a:hover>[class*=" icon-"],.fuelux .dropdown-menu>li>a:focus>[class*=" icon-"],.fuelux .dropdown-menu>.active>a>[class^="icon-"],.fuelux .dropdown-menu>.active>a>[class*=" icon-"],.fuelux .dropdown-submenu:hover>a>[class^="icon-"],.fuelux .dropdown-submenu:focus>a>[class^="icon-"],.fuelux .dropdown-submenu:hover>a>[class*=" icon-"],.fuelux .dropdown-submenu:focus>a>[class*=" icon-"]{background-image:url("../img/glyphicons-halflings-white.png")}.fuelux .icon-glass{background-position:0 0}.fuelux .icon-music{background-position:-24px 0}.fuelux .icon-search{background-position:-48px 0}.fuelux .icon-envelope{background-position:-72px 0}.fuelux .icon-heart{background-position:-96px 0}.fuelux .icon-star{background-position:-120px 0}.fuelux .icon-star-empty{background-position:-144px 0}.fuelux .icon-user{background-position:-168px 0}.fuelux .icon-film{background-position:-192px 0}.fuelux .icon-th-large{background-position:-216px 0}.fuelux .icon-th{background-position:-240px 0}.fuelux .icon-th-list{background-position:-264px 0}.fuelux .icon-ok{background-position:-288px 0}.fuelux .icon-remove{background-position:-312px 0}.fuelux .icon-zoom-in{background-position:-336px 0}.fuelux .icon-zoom-out{background-position:-360px 0}.fuelux .icon-off{background-position:-384px 0}.fuelux .icon-signal{background-position:-408px 0}.fuelux .icon-cog{background-position:-432px 0}.fuelux .icon-trash{background-position:-456px 0}.fuelux .icon-home{background-position:0 -24px}.fuelux .icon-file{background-position:-24px -24px}.fuelux .icon-time{background-position:-48px -24px}.fuelux .icon-road{background-position:-72px -24px}.fuelux .icon-download-alt{background-position:-96px -24px}.fuelux .icon-download{background-position:-120px -24px}.fuelux .icon-upload{background-position:-144px -24px}.fuelux .icon-inbox{background-position:-168px -24px}.fuelux .icon-play-circle{background-position:-192px -24px}.fuelux .icon-repeat{background-position:-216px -24px}.fuelux .icon-refresh{background-position:-240px -24px}.fuelux .icon-list-alt{background-position:-264px -24px}.fuelux .icon-lock{background-position:-287px -24px}.fuelux .icon-flag{background-position:-312px -24px}.fuelux .icon-headphones{background-position:-336px -24px}.fuelux .icon-volume-off{background-position:-360px -24px}.fuelux .icon-volume-down{background-position:-384px -24px}.fuelux .icon-volume-up{background-position:-408px -24px}.fuelux .icon-qrcode{background-position:-432px -24px}.fuelux .icon-barcode{background-position:-456px -24px}.fuelux .icon-tag{background-position:0 -48px}.fuelux .icon-tags{background-position:-25px -48px}.fuelux .icon-book{background-position:-48px -48px}.fuelux .icon-bookmark{background-position:-72px -48px}.fuelux .icon-print{background-position:-96px -48px}.fuelux .icon-camera{background-position:-120px -48px}.fuelux .icon-font{background-position:-144px -48px}.fuelux .icon-bold{background-position:-167px -48px}.fuelux .icon-italic{background-position:-192px -48px}.fuelux .icon-text-height{background-position:-216px -48px}.fuelux .icon-text-width{background-position:-240px -48px}.fuelux .icon-align-left{background-position:-264px -48px}.fuelux .icon-align-center{background-position:-288px -48px}.fuelux .icon-align-right{background-position:-312px -48px}.fuelux .icon-align-justify{background-position:-336px -48px}.fuelux .icon-list{background-position:-360px -48px}.fuelux .icon-indent-left{background-position:-384px -48px}.fuelux .icon-indent-right{background-position:-408px -48px}.fuelux .icon-facetime-video{background-position:-432px -48px}.fuelux .icon-picture{background-position:-456px -48px}.fuelux .icon-pencil{background-position:0 -72px}.fuelux .icon-map-marker{background-position:-24px -72px}.fuelux .icon-adjust{background-position:-48px -72px}.fuelux .icon-tint{background-position:-72px -72px}.fuelux .icon-edit{background-position:-96px -72px}.fuelux .icon-share{background-position:-120px -72px}.fuelux .icon-check{background-position:-144px -72px}.fuelux .icon-move{background-position:-168px -72px}.fuelux .icon-step-backward{background-position:-192px -72px}.fuelux .icon-fast-backward{background-position:-216px -72px}.fuelux .icon-backward{background-position:-240px -72px}.fuelux .icon-play{background-position:-264px -72px}.fuelux .icon-pause{background-position:-288px -72px}.fuelux .icon-stop{background-position:-312px -72px}.fuelux .icon-forward{background-position:-336px -72px}.fuelux .icon-fast-forward{background-position:-360px -72px}.fuelux .icon-step-forward{background-position:-384px -72px}.fuelux .icon-eject{background-position:-408px -72px}.fuelux .icon-chevron-left{background-position:-432px -72px}.fuelux .icon-chevron-right{background-position:-456px -72px}.fuelux .icon-plus-sign{background-position:0 -96px}.fuelux .icon-minus-sign{background-position:-24px -96px}.fuelux .icon-remove-sign{background-position:-48px -96px}.fuelux .icon-ok-sign{background-position:-72px -96px}.fuelux .icon-question-sign{background-position:-96px -96px}.fuelux .icon-info-sign{background-position:-120px -96px}.fuelux .icon-screenshot{background-position:-144px -96px}.fuelux .icon-remove-circle{background-position:-168px -96px}.fuelux .icon-ok-circle{background-position:-192px -96px}.fuelux .icon-ban-circle{background-position:-216px -96px}.fuelux .icon-arrow-left{background-position:-240px -96px}.fuelux .icon-arrow-right{background-position:-264px -96px}.fuelux .icon-arrow-up{background-position:-289px -96px}.fuelux .icon-arrow-down{background-position:-312px -96px}.fuelux .icon-share-alt{background-position:-336px -96px}.fuelux .icon-resize-full{background-position:-360px -96px}.fuelux .icon-resize-small{background-position:-384px -96px}.fuelux .icon-plus{background-position:-408px -96px}.fuelux .icon-minus{background-position:-433px -96px}.fuelux .icon-asterisk{background-position:-456px -96px}.fuelux .icon-exclamation-sign{background-position:0 -120px}.fuelux .icon-gift{background-position:-24px -120px}.fuelux .icon-leaf{background-position:-48px -120px}.fuelux .icon-fire{background-position:-72px -120px}.fuelux .icon-eye-open{background-position:-96px -120px}.fuelux .icon-eye-close{background-position:-120px -120px}.fuelux .icon-warning-sign{background-position:-144px -120px}.fuelux .icon-plane{background-position:-168px -120px}.fuelux .icon-calendar{background-position:-192px -120px}.fuelux .icon-random{width:16px;background-position:-216px -120px}.fuelux .icon-comment{background-position:-240px -120px}.fuelux .icon-magnet{background-position:-264px -120px}.fuelux .icon-chevron-up{background-position:-288px -120px}.fuelux .icon-chevron-down{background-position:-313px -119px}.fuelux .icon-retweet{background-position:-336px -120px}.fuelux .icon-shopping-cart{background-position:-360px -120px}.fuelux .icon-folder-close{width:16px;background-position:-384px -120px}.fuelux .icon-folder-open{width:16px;background-position:-408px -120px}.fuelux .icon-resize-vertical{background-position:-432px -119px}.fuelux .icon-resize-horizontal{background-position:-456px -118px}.fuelux .icon-hdd{background-position:0 -144px}.fuelux .icon-bullhorn{background-position:-24px -144px}.fuelux .icon-bell{background-position:-48px -144px}.fuelux .icon-certificate{background-position:-72px -144px}.fuelux .icon-thumbs-up{background-position:-96px -144px}.fuelux .icon-thumbs-down{background-position:-120px -144px}.fuelux .icon-hand-right{background-position:-144px -144px}.fuelux .icon-hand-left{background-position:-168px -144px}.fuelux .icon-hand-up{background-position:-192px -144px}.fuelux .icon-hand-down{background-position:-216px -144px}.fuelux .icon-circle-arrow-right{background-position:-240px -144px}.fuelux .icon-circle-arrow-left{background-position:-264px -144px}.fuelux .icon-circle-arrow-up{background-position:-288px -144px}.fuelux .icon-circle-arrow-down{background-position:-312px -144px}.fuelux .icon-globe{background-position:-336px -144px}.fuelux .icon-wrench{background-position:-360px -144px}.fuelux .icon-tasks{background-position:-384px -144px}.fuelux .icon-filter{background-position:-408px -144px}.fuelux .icon-briefcase{background-position:-432px -144px}.fuelux .icon-fullscreen{background-position:-456px -144px}.fuelux .dropup,.fuelux .dropdown{position:relative}.fuelux .dropdown-toggle{*margin-bottom:-3px}.fuelux .dropdown-toggle:active,.fuelux .open .dropdown-toggle{outline:0}.fuelux .caret{display:inline-block;width:0;height:0;vertical-align:top;border-top:4px solid #000;border-right:4px solid transparent;border-left:4px solid transparent;content:""}.fuelux .dropdown .caret{margin-top:8px;margin-left:2px}.fuelux .dropdown-menu{position:absolute;top:100%;left:0;z-index:1000;display:none;float:left;min-width:160px;padding:5px 0;margin:2px 0 0;list-style:none;background-color:#fff;border:1px solid #ccc;border:1px solid rgba(0,0,0,0.2);*border-right-width:2px;*border-bottom-width:2px;-webkit-border-radius:6px;-moz-border-radius:6px;border-radius:6px;-webkit-box-shadow:0 5px 10px rgba(0,0,0,0.2);-moz-box-shadow:0 5px 10px rgba(0,0,0,0.2);box-shadow:0 5px 10px rgba(0,0,0,0.2);-webkit-background-clip:padding-box;-moz-background-clip:padding;background-clip:padding-box}.fuelux .dropdown-menu.pull-right{right:0;left:auto}.fuelux .dropdown-menu .divider{*width:100%;height:1px;margin:9px 1px;*margin:-5px 0 5px;overflow:hidden;background-color:#e5e5e5;border-bottom:1px solid #fff}.fuelux .dropdown-menu>li>a{display:block;padding:3px 20px;clear:both;font-weight:normal;line-height:20px;color:#333;white-space:nowrap}.fuelux .dropdown-menu>li>a:hover,.fuelux .dropdown-menu>li>a:focus,.fuelux .dropdown-submenu:hover>a,.fuelux .dropdown-submenu:focus>a{color:#fff;text-decoration:none;background-color:#0081c2;background-image:-moz-linear-gradient(top,#08c,#0077b3);background-image:-webkit-gradient(linear,0 0,0 100%,from(#08c),to(#0077b3));background-image:-webkit-linear-gradient(top,#08c,#0077b3);background-image:-o-linear-gradient(top,#08c,#0077b3);background-image:linear-gradient(to bottom,#08c,#0077b3);background-repeat:repeat-x;filter:progid:dximagetransform.microsoft.gradient(startColorstr='#ff0088cc',endColorstr='#ff0077b3',GradientType=0)}.fuelux .dropdown-menu>.active>a,.fuelux .dropdown-menu>.active>a:hover,.fuelux .dropdown-menu>.active>a:focus{color:#fff;text-decoration:none;background-color:#0081c2;background-image:-webkit-gradient(linear,0 0,0 100%,from(#08c),to(#0077b3));background-image:-moz-linear-gradient(top,#08c,#0077b3);background-image:linear-gradient(to bottom,#08c,#0077b3);background-image:-webkit-linear-gradient(top,#08c,#0077b3);background-image:-o-linear-gradient(top,#08c,#0077b3);background-repeat:repeat-x;outline:0;filter:progid:dximagetransform.microsoft.gradient(startColorstr='#ff0088cc',endColorstr='#ff0077b3',GradientType=0)}.fuelux .dropdown-menu>.disabled>a,.fuelux .dropdown-menu>.disabled>a:hover,.fuelux .dropdown-menu>.disabled>a:focus{color:#999}.fuelux .dropdown-menu>.disabled>a:hover,.fuelux .dropdown-menu>.disabled>a:focus{text-decoration:none;cursor:default;background-color:transparent;background-image:none;filter:progid:dximagetransform.microsoft.gradient(enabled=false)}.fuelux .open{*z-index:1000}.fuelux .open>.dropdown-menu{display:block}.fuelux .dropdown-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:990}.fuelux .pull-right>.dropdown-menu{right:0;left:auto}.fuelux .dropup .caret,.fuelux .navbar-fixed-bottom .dropdown .caret{border-top:0;border-bottom:4px solid #000;content:""}.fuelux .dropup .dropdown-menu,.fuelux .navbar-fixed-bottom .dropdown .dropdown-menu{top:auto;bottom:100%;margin-bottom:1px}.fuelux .dropdown-submenu{position:relative}.fuelux .dropdown-submenu>.dropdown-menu{top:0;left:100%;margin-top:-6px;margin-left:-1px;-webkit-border-radius:0 6px 6px 6px;-moz-border-radius:0 6px 6px 6px;border-radius:0 6px 6px 6px}.fuelux .dropdown-submenu:hover>.dropdown-menu{display:block}.fuelux .dropup .dropdown-submenu>.dropdown-menu{top:auto;bottom:0;margin-top:0;margin-bottom:-2px;-webkit-border-radius:5px 5px 5px 0;-moz-border-radius:5px 5px 5px 0;border-radius:5px 5px 5px 0}.fuelux .dropdown-submenu>a:after{display:block;float:right;width:0;height:0;margin-top:5px;margin-right:-10px;border-color:transparent;border-left-color:#ccc;border-style:solid;border-width:5px 0 5px 5px;content:" "}.fuelux .dropdown-submenu:hover>a:after{border-left-color:#fff}.fuelux .dropdown-submenu.pull-left{float:none}.fuelux .dropdown-submenu.pull-left>.dropdown-menu{left:-100%;margin-left:10px;-webkit-border-radius:6px 0 6px 6px;-moz-border-radius:6px 0 6px 6px;border-radius:6px 0 6px 6px}.fuelux .dropdown .dropdown-menu .nav-header{padding-right:20px;padding-left:20px}.fuelux .typeahead{z-index:1051;margin-top:2px;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px}.fuelux .well{min-height:20px;padding:19px;margin-bottom:20px;background-color:#f5f5f5;border:1px solid #e3e3e3;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,0.05);-moz-box-shadow:inset 0 1px 1px rgba(0,0,0,0.05);box-shadow:inset 0 1px 1px rgba(0,0,0,0.05)}.fuelux .well blockquote{border-color:#ddd;border-color:rgba(0,0,0,0.15)}.fuelux .well-large{padding:24px;-webkit-border-radius:6px;-moz-border-radius:6px;border-radius:6px}.fuelux .well-small{padding:9px;-webkit-border-radius:3px;-moz-border-radius:3px;border-radius:3px}.fuelux .fade{opacity:0;-webkit-transition:opacity .15s linear;-moz-transition:opacity .15s linear;-o-transition:opacity .15s linear;transition:opacity .15s linear}.fuelux .fade.in{opacity:1}.fuelux .collapse{position:relative;height:0;overflow:hidden;-webkit-transition:height .35s ease;-moz-transition:height .35s ease;-o-transition:height .35s ease;transition:height .35s ease}.fuelux .collapse.in{height:auto}.fuelux .close{float:right;font-size:20px;font-weight:bold;line-height:20px;color:#000;text-shadow:0 1px 0 #fff;opacity:.2;filter:alpha(opacity=20)}.fuelux .close:hover,.fuelux .close:focus{color:#000;text-decoration:none;cursor:pointer;opacity:.4;filter:alpha(opacity=40)}.fuelux button.close{padding:0;cursor:pointer;background:transparent;border:0;-webkit-appearance:none}.fuelux .btn{display:inline-block;*display:inline;padding:4px 12px;margin-bottom:0;*margin-left:.3em;font-size:14px;line-height:20px;color:#333;text-align:center;text-shadow:0 1px 1px rgba(255,255,255,0.75);vertical-align:middle;cursor:pointer;background-color:#f5f5f5;*background-color:#e6e6e6;background-image:-webkit-gradient(linear,0 0,0 100%,from(#fff),to(#e6e6e6));background-image:-webkit-linear-gradient(top,#fff,#e6e6e6);background-image:-o-linear-gradient(top,#fff,#e6e6e6);background-image:linear-gradient(to bottom,#fff,#e6e6e6);background-image:-moz-linear-gradient(top,#fff,#e6e6e6);background-repeat:repeat-x;border:1px solid #ccc;*border:0;border-color:rgba(0,0,0,0.1) rgba(0,0,0,0.1) rgba(0,0,0,0.25);border-color:#e6e6e6 #e6e6e6 #bfbfbf;border-bottom-color:#b3b3b3;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px;filter:progid:dximagetransform.microsoft.gradient(startColorstr='#ffffffff',endColorstr='#ffe6e6e6',GradientType=0);filter:progid:dximagetransform.microsoft.gradient(enabled=false);*zoom:1;-webkit-box-shadow:inset 0 1px 0 rgba(255,255,255,0.2),0 1px 2px rgba(0,0,0,0.05);-moz-box-shadow:inset 0 1px 0 rgba(255,255,255,0.2),0 1px 2px rgba(0,0,0,0.05);box-shadow:inset 0 1px 0 rgba(255,255,255,0.2),0 1px 2px rgba(0,0,0,0.05)}.fuelux .btn:hover,.fuelux .btn:focus,.fuelux .btn:active,.fuelux .btn.active,.fuelux .btn.disabled,.fuelux .btn[disabled]{color:#333;background-color:#e6e6e6;*background-color:#d9d9d9}.fuelux .btn:active,.fuelux .btn.active{background-color:#ccc \9}.fuelux .btn:first-child{*margin-left:0}.fuelux .btn:hover,.fuelux .btn:focus{color:#333;text-decoration:none;background-position:0 -15px;-webkit-transition:background-position .1s linear;-moz-transition:background-position .1s linear;-o-transition:background-position .1s linear;transition:background-position .1s linear}.fuelux .btn:focus{outline:thin dotted #333;outline:5px auto -webkit-focus-ring-color;outline-offset:-2px}.fuelux .btn.active,.fuelux .btn:active{background-image:none;outline:0;-webkit-box-shadow:inset 0 2px 4px rgba(0,0,0,0.15),0 1px 2px rgba(0,0,0,0.05);-moz-box-shadow:inset 0 2px 4px rgba(0,0,0,0.15),0 1px 2px rgba(0,0,0,0.05);box-shadow:inset 0 2px 4px rgba(0,0,0,0.15),0 1px 2px rgba(0,0,0,0.05)}.fuelux .btn.disabled,.fuelux .btn[disabled]{cursor:default;background-image:none;opacity:.65;filter:alpha(opacity=65);-webkit-box-shadow:none;-moz-box-shadow:none;box-shadow:none}.fuelux .btn-large{padding:11px 19px;font-size:17.5px;-webkit-border-radius:6px;-moz-border-radius:6px;border-radius:6px}.fuelux .btn-large [class^="icon-"],.fuelux .btn-large [class*=" icon-"]{margin-top:4px}.fuelux .btn-small{padding:2px 10px;font-size:11.9px;-webkit-border-radius:3px;-moz-border-radius:3px;border-radius:3px}.fuelux .btn-small [class^="icon-"],.fuelux .btn-small [class*=" icon-"]{margin-top:0}.fuelux .btn-mini [class^="icon-"],.fuelux .btn-mini [class*=" icon-"]{margin-top:-1px}.fuelux .btn-mini{padding:0 6px;font-size:10.5px;-webkit-border-radius:3px;-moz-border-radius:3px;border-radius:3px}.fuelux .btn-block{display:block;width:100%;padding-right:0;padding-left:0;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}.fuelux .btn-block+.btn-block{margin-top:5px}.fuelux input[type="submit"].btn-block,.fuelux input[type="reset"].btn-block,.fuelux input[type="button"].btn-block{width:100%}.fuelux .btn-primary.active,.fuelux .btn-warning.active,.fuelux .btn-danger.active,.fuelux .btn-success.active,.fuelux .btn-info.active,.fuelux .btn-inverse.active{color:rgba(255,255,255,0.75)}.fuelux .btn-primary{color:#fff;text-shadow:0 -1px 0 rgba(0,0,0,0.25);background-color:#006dcc;*background-color:#04c;background-image:-webkit-gradient(linear,0 0,0 100%,from(#08c),to(#04c));background-image:-webkit-linear-gradient(top,#08c,#04c);background-image:-o-linear-gradient(top,#08c,#04c);background-image:linear-gradient(to bottom,#08c,#04c);background-image:-moz-linear-gradient(top,#08c,#04c);background-repeat:repeat-x;border-color:#04c #04c #002a80;border-color:rgba(0,0,0,0.1) rgba(0,0,0,0.1) rgba(0,0,0,0.25);filter:progid:dximagetransform.microsoft.gradient(startColorstr='#ff0088cc',endColorstr='#ff0044cc',GradientType=0);filter:progid:dximagetransform.microsoft.gradient(enabled=false)}.fuelux .btn-primary:hover,.fuelux .btn-primary:focus,.fuelux .btn-primary:active,.fuelux .btn-primary.active,.fuelux .btn-primary.disabled,.fuelux .btn-primary[disabled]{color:#fff;background-color:#04c;*background-color:#003bb3}.fuelux .btn-primary:active,.fuelux .btn-primary.active{background-color:#039 \9}.fuelux .btn-warning{color:#fff;text-shadow:0 -1px 0 rgba(0,0,0,0.25);background-color:#faa732;*background-color:#f89406;background-image:-webkit-gradient(linear,0 0,0 100%,from(#fbb450),to(#f89406));background-image:-webkit-linear-gradient(top,#fbb450,#f89406);background-image:-o-linear-gradient(top,#fbb450,#f89406);background-image:linear-gradient(to bottom,#fbb450,#f89406);background-image:-moz-linear-gradient(top,#fbb450,#f89406);background-repeat:repeat-x;border-color:#f89406 #f89406 #ad6704;border-color:rgba(0,0,0,0.1) rgba(0,0,0,0.1) rgba(0,0,0,0.25);filter:progid:dximagetransform.microsoft.gradient(startColorstr='#fffbb450',endColorstr='#fff89406',GradientType=0);filter:progid:dximagetransform.microsoft.gradient(enabled=false)}.fuelux .btn-warning:hover,.fuelux .btn-warning:focus,.fuelux .btn-warning:active,.fuelux .btn-warning.active,.fuelux .btn-warning.disabled,.fuelux .btn-warning[disabled]{color:#fff;background-color:#f89406;*background-color:#df8505}.fuelux .btn-warning:active,.fuelux .btn-warning.active{background-color:#c67605 \9}.fuelux .btn-danger{color:#fff;text-shadow:0 -1px 0 rgba(0,0,0,0.25);background-color:#da4f49;*background-color:#bd362f;background-image:-webkit-gradient(linear,0 0,0 100%,from(#ee5f5b),to(#bd362f));background-image:-webkit-linear-gradient(top,#ee5f5b,#bd362f);background-image:-o-linear-gradient(top,#ee5f5b,#bd362f);background-image:linear-gradient(to bottom,#ee5f5b,#bd362f);background-image:-moz-linear-gradient(top,#ee5f5b,#bd362f);background-repeat:repeat-x;border-color:#bd362f #bd362f #802420;border-color:rgba(0,0,0,0.1) rgba(0,0,0,0.1) rgba(0,0,0,0.25);filter:progid:dximagetransform.microsoft.gradient(startColorstr='#ffee5f5b',endColorstr='#ffbd362f',GradientType=0);filter:progid:dximagetransform.microsoft.gradient(enabled=false)}.fuelux .btn-danger:hover,.fuelux .btn-danger:focus,.fuelux .btn-danger:active,.fuelux .btn-danger.active,.fuelux .btn-danger.disabled,.fuelux .btn-danger[disabled]{color:#fff;background-color:#bd362f;*background-color:#a9302a}.fuelux .btn-danger:active,.fuelux .btn-danger.active{background-color:#942a25 \9}.fuelux .btn-success{color:#fff;text-shadow:0 -1px 0 rgba(0,0,0,0.25);background-color:#5bb75b;*background-color:#51a351;background-image:-webkit-gradient(linear,0 0,0 100%,from(#62c462),to(#51a351));background-image:-webkit-linear-gradient(top,#62c462,#51a351);background-image:-o-linear-gradient(top,#62c462,#51a351);background-image:linear-gradient(to bottom,#62c462,#51a351);background-image:-moz-linear-gradient(top,#62c462,#51a351);background-repeat:repeat-x;border-color:#51a351 #51a351 #387038;border-color:rgba(0,0,0,0.1) rgba(0,0,0,0.1) rgba(0,0,0,0.25);filter:progid:dximagetransform.microsoft.gradient(startColorstr='#ff62c462',endColorstr='#ff51a351',GradientType=0);filter:progid:dximagetransform.microsoft.gradient(enabled=false)}.fuelux .btn-success:hover,.fuelux .btn-success:focus,.fuelux .btn-success:active,.fuelux .btn-success.active,.fuelux .btn-success.disabled,.fuelux .btn-success[disabled]{color:#fff;background-color:#51a351;*background-color:#499249}.fuelux .btn-success:active,.fuelux .btn-success.active{background-color:#408140 \9}.fuelux .btn-info{color:#fff;text-shadow:0 -1px 0 rgba(0,0,0,0.25);background-color:#49afcd;*background-color:#2f96b4;background-image:-webkit-gradient(linear,0 0,0 100%,from(#5bc0de),to(#2f96b4));background-image:-webkit-linear-gradient(top,#5bc0de,#2f96b4);background-image:-o-linear-gradient(top,#5bc0de,#2f96b4);background-image:linear-gradient(to bottom,#5bc0de,#2f96b4);background-image:-moz-linear-gradient(top,#5bc0de,#2f96b4);background-repeat:repeat-x;border-color:#2f96b4 #2f96b4 #1f6377;border-color:rgba(0,0,0,0.1) rgba(0,0,0,0.1) rgba(0,0,0,0.25);filter:progid:dximagetransform.microsoft.gradient(startColorstr='#ff5bc0de',endColorstr='#ff2f96b4',GradientType=0);filter:progid:dximagetransform.microsoft.gradient(enabled=false)}.fuelux .btn-info:hover,.fuelux .btn-info:focus,.fuelux .btn-info:active,.fuelux .btn-info.active,.fuelux .btn-info.disabled,.fuelux .btn-info[disabled]{color:#fff;background-color:#2f96b4;*background-color:#2a85a0}.fuelux .btn-info:active,.fuelux .btn-info.active{background-color:#24748c \9}.fuelux .btn-inverse{color:#fff;text-shadow:0 -1px 0 rgba(0,0,0,0.25);background-color:#363636;*background-color:#222;background-image:-webkit-gradient(linear,0 0,0 100%,from(#444),to(#222));background-image:-webkit-linear-gradient(top,#444,#222);background-image:-o-linear-gradient(top,#444,#222);background-image:linear-gradient(to bottom,#444,#222);background-image:-moz-linear-gradient(top,#444,#222);background-repeat:repeat-x;border-color:#222 #222 #000;border-color:rgba(0,0,0,0.1) rgba(0,0,0,0.1) rgba(0,0,0,0.25);filter:progid:dximagetransform.microsoft.gradient(startColorstr='#ff444444',endColorstr='#ff222222',GradientType=0);filter:progid:dximagetransform.microsoft.gradient(enabled=false)}.fuelux .btn-inverse:hover,.fuelux .btn-inverse:focus,.fuelux .btn-inverse:active,.fuelux .btn-inverse.active,.fuelux .btn-inverse.disabled,.fuelux .btn-inverse[disabled]{color:#fff;background-color:#222;*background-color:#151515}.fuelux .btn-inverse:active,.fuelux .btn-inverse.active{background-color:#080808 \9}.fuelux button.btn,.fuelux input[type="submit"].btn{*padding-top:3px;*padding-bottom:3px}.fuelux button.btn::-moz-focus-inner,.fuelux input[type="submit"].btn::-moz-focus-inner{padding:0;border:0}.fuelux button.btn.btn-large,.fuelux input[type="submit"].btn.btn-large{*padding-top:7px;*padding-bottom:7px}.fuelux button.btn.btn-small,.fuelux input[type="submit"].btn.btn-small{*padding-top:3px;*padding-bottom:3px}.fuelux button.btn.btn-mini,.fuelux input[type="submit"].btn.btn-mini{*padding-top:1px;*padding-bottom:1px}.fuelux .btn-link,.fuelux .btn-link:active,.fuelux .btn-link[disabled]{background-color:transparent;background-image:none;-webkit-box-shadow:none;-moz-box-shadow:none;box-shadow:none}.fuelux .btn-link{color:#08c;cursor:pointer;border-color:transparent;-webkit-border-radius:0;-moz-border-radius:0;border-radius:0}.fuelux .btn-link:hover,.fuelux .btn-link:focus{color:#005580;text-decoration:underline;background-color:transparent}.fuelux .btn-link[disabled]:hover,.fuelux .btn-link[disabled]:focus{color:#333;text-decoration:none}.fuelux .btn-group{position:relative;display:inline-block;*display:inline;*margin-left:.3em;font-size:0;white-space:nowrap;vertical-align:middle;*zoom:1}.fuelux .btn-group:first-child{*margin-left:0}.fuelux .btn-group+.btn-group{margin-left:5px}.fuelux .btn-toolbar{margin-top:10px;margin-bottom:10px;font-size:0}.fuelux .btn-toolbar>.btn+.btn,.fuelux .btn-toolbar>.btn-group+.btn,.fuelux .btn-toolbar>.btn+.btn-group{margin-left:5px}.fuelux .btn-group>.btn{position:relative;-webkit-border-radius:0;-moz-border-radius:0;border-radius:0}.fuelux .btn-group>.btn+.btn{margin-left:-1px}.fuelux .btn-group>.btn,.fuelux .btn-group>.dropdown-menu,.fuelux .btn-group>.popover{font-size:14px}.fuelux .btn-group>.btn-mini{font-size:10.5px}.fuelux .btn-group>.btn-small{font-size:11.9px}.fuelux .btn-group>.btn-large{font-size:17.5px}.fuelux .btn-group>.btn:first-child{margin-left:0;-webkit-border-bottom-left-radius:4px;border-bottom-left-radius:4px;-webkit-border-top-left-radius:4px;border-top-left-radius:4px;-moz-border-radius-bottomleft:4px;-moz-border-radius-topleft:4px}.fuelux .btn-group>.btn:last-child,.fuelux .btn-group>.dropdown-toggle{-webkit-border-top-right-radius:4px;border-top-right-radius:4px;-webkit-border-bottom-right-radius:4px;border-bottom-right-radius:4px;-moz-border-radius-topright:4px;-moz-border-radius-bottomright:4px}.fuelux .btn-group>.btn.large:first-child{margin-left:0;-webkit-border-bottom-left-radius:6px;border-bottom-left-radius:6px;-webkit-border-top-left-radius:6px;border-top-left-radius:6px;-moz-border-radius-bottomleft:6px;-moz-border-radius-topleft:6px}.fuelux .btn-group>.btn.large:last-child,.fuelux .btn-group>.large.dropdown-toggle{-webkit-border-top-right-radius:6px;border-top-right-radius:6px;-webkit-border-bottom-right-radius:6px;border-bottom-right-radius:6px;-moz-border-radius-topright:6px;-moz-border-radius-bottomright:6px}.fuelux .btn-group>.btn:hover,.fuelux .btn-group>.btn:focus,.fuelux .btn-group>.btn:active,.fuelux .btn-group>.btn.active{z-index:2}.fuelux .btn-group .dropdown-toggle:active,.fuelux .btn-group.open .dropdown-toggle{outline:0}.fuelux .btn-group>.btn+.dropdown-toggle{*padding-top:5px;padding-right:8px;*padding-bottom:5px;padding-left:8px;-webkit-box-shadow:inset 1px 0 0 rgba(255,255,255,0.125),inset 0 1px 0 rgba(255,255,255,0.2),0 1px 2px rgba(0,0,0,0.05);-moz-box-shadow:inset 1px 0 0 rgba(255,255,255,0.125),inset 0 1px 0 rgba(255,255,255,0.2),0 1px 2px rgba(0,0,0,0.05);box-shadow:inset 1px 0 0 rgba(255,255,255,0.125),inset 0 1px 0 rgba(255,255,255,0.2),0 1px 2px rgba(0,0,0,0.05)}.fuelux .btn-group>.btn-mini+.dropdown-toggle{*padding-top:2px;padding-right:5px;*padding-bottom:2px;padding-left:5px}.fuelux .btn-group>.btn-small+.dropdown-toggle{*padding-top:5px;*padding-bottom:4px}.fuelux .btn-group>.btn-large+.dropdown-toggle{*padding-top:7px;padding-right:12px;*padding-bottom:7px;padding-left:12px}.fuelux .btn-group.open .dropdown-toggle{background-image:none;-webkit-box-shadow:inset 0 2px 4px rgba(0,0,0,0.15),0 1px 2px rgba(0,0,0,0.05);-moz-box-shadow:inset 0 2px 4px rgba(0,0,0,0.15),0 1px 2px rgba(0,0,0,0.05);box-shadow:inset 0 2px 4px rgba(0,0,0,0.15),0 1px 2px rgba(0,0,0,0.05)}.fuelux .btn-group.open .btn.dropdown-toggle{background-color:#e6e6e6}.fuelux .btn-group.open .btn-primary.dropdown-toggle{background-color:#04c}.fuelux .btn-group.open .btn-warning.dropdown-toggle{background-color:#f89406}.fuelux .btn-group.open .btn-danger.dropdown-toggle{background-color:#bd362f}.fuelux .btn-group.open .btn-success.dropdown-toggle{background-color:#51a351}.fuelux .btn-group.open .btn-info.dropdown-toggle{background-color:#2f96b4}.fuelux .btn-group.open .btn-inverse.dropdown-toggle{background-color:#222}.fuelux .btn .caret{margin-top:8px;margin-left:0}.fuelux .btn-large .caret{margin-top:6px}.fuelux .btn-large .caret{border-top-width:5px;border-right-width:5px;border-left-width:5px}.fuelux .btn-mini .caret,.fuelux .btn-small .caret{margin-top:8px}.fuelux .dropup .btn-large .caret{border-bottom-width:5px}.fuelux .btn-primary .caret,.fuelux .btn-warning .caret,.fuelux .btn-danger .caret,.fuelux .btn-info .caret,.fuelux .btn-success .caret,.fuelux .btn-inverse .caret{border-top-color:#fff;border-bottom-color:#fff}.fuelux .btn-group-vertical{display:inline-block;*display:inline;*zoom:1}.fuelux .btn-group-vertical>.btn{display:block;float:none;max-width:100%;-webkit-border-radius:0;-moz-border-radius:0;border-radius:0}.fuelux .btn-group-vertical>.btn+.btn{margin-top:-1px;margin-left:0}.fuelux .btn-group-vertical>.btn:first-child{-webkit-border-radius:4px 4px 0 0;-moz-border-radius:4px 4px 0 0;border-radius:4px 4px 0 0}.fuelux .btn-group-vertical>.btn:last-child{-webkit-border-radius:0 0 4px 4px;-moz-border-radius:0 0 4px 4px;border-radius:0 0 4px 4px}.fuelux .btn-group-vertical>.btn-large:first-child{-webkit-border-radius:6px 6px 0 0;-moz-border-radius:6px 6px 0 0;border-radius:6px 6px 0 0}.fuelux .btn-group-vertical>.btn-large:last-child{-webkit-border-radius:0 0 6px 6px;-moz-border-radius:0 0 6px 6px;border-radius:0 0 6px 6px}.fuelux .alert{padding:8px 35px 8px 14px;margin-bottom:20px;text-shadow:0 1px 0 rgba(255,255,255,0.5);background-color:#fcf8e3;border:1px solid #fbeed5;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px}.fuelux .alert,.fuelux .alert h4{color:#c09853}.fuelux .alert h4{margin:0}.fuelux .alert .close{position:relative;top:-2px;right:-21px;line-height:20px}.fuelux .alert-success{color:#468847;background-color:#dff0d8;border-color:#d6e9c6}.fuelux .alert-success h4{color:#468847}.fuelux .alert-danger,.fuelux .alert-error{color:#b94a48;background-color:#f2dede;border-color:#eed3d7}.fuelux .alert-danger h4,.fuelux .alert-error h4{color:#b94a48}.fuelux .alert-info{color:#3a87ad;background-color:#d9edf7;border-color:#bce8f1}.fuelux .alert-info h4{color:#3a87ad}.fuelux .alert-block{padding-top:14px;padding-bottom:14px}.fuelux .alert-block>p,.fuelux .alert-block>ul{margin-bottom:0}.fuelux .alert-block p+p{margin-top:5px}.fuelux .nav{margin-bottom:20px;margin-left:0;list-style:none}.fuelux .nav>li>a{display:block}.fuelux .nav>li>a:hover,.fuelux .nav>li>a:focus{text-decoration:none;background-color:#eee}.fuelux .nav>li>a>img{max-width:none}.fuelux .nav>.pull-right{float:right}.fuelux .nav-header{display:block;padding:3px 15px;font-size:11px;font-weight:bold;line-height:20px;color:#999;text-shadow:0 1px 0 rgba(255,255,255,0.5);text-transform:uppercase}.fuelux .nav li+.nav-header{margin-top:9px}.fuelux .nav-list{padding-right:15px;padding-left:15px;margin-bottom:0}.fuelux .nav-list>li>a,.fuelux .nav-list .nav-header{margin-right:-15px;margin-left:-15px;text-shadow:0 1px 0 rgba(255,255,255,0.5)}.fuelux .nav-list>li>a{padding:3px 15px}.fuelux .nav-list>.active>a,.fuelux .nav-list>.active>a:hover,.fuelux .nav-list>.active>a:focus{color:#fff;text-shadow:0 -1px 0 rgba(0,0,0,0.2);background-color:#08c}.fuelux .nav-list [class^="icon-"],.fuelux .nav-list [class*=" icon-"]{margin-right:2px}.fuelux .nav-list .divider{*width:100%;height:1px;margin:9px 1px;*margin:-5px 0 5px;overflow:hidden;background-color:#e5e5e5;border-bottom:1px solid #fff}.fuelux .nav-tabs,.fuelux .nav-pills{*zoom:1}.fuelux .nav-tabs:before,.fuelux .nav-pills:before,.fuelux .nav-tabs:after,.fuelux .nav-pills:after{display:table;line-height:0;content:""}.fuelux .nav-tabs:after,.fuelux .nav-pills:after{clear:both}.fuelux .nav-tabs>li,.fuelux .nav-pills>li{float:left}.fuelux .nav-tabs>li>a,.fuelux .nav-pills>li>a{padding-right:12px;padding-left:12px;margin-right:2px;line-height:14px}.fuelux .nav-tabs{border-bottom:1px solid #ddd}.fuelux .nav-tabs>li{margin-bottom:-1px}.fuelux .nav-tabs>li>a{padding-top:8px;padding-bottom:8px;line-height:20px;border:1px solid transparent;-webkit-border-radius:4px 4px 0 0;-moz-border-radius:4px 4px 0 0;border-radius:4px 4px 0 0}.fuelux .nav-tabs>li>a:hover,.fuelux .nav-tabs>li>a:focus{border-color:#eee #eee #ddd}.fuelux .nav-tabs>.active>a,.fuelux .nav-tabs>.active>a:hover,.fuelux .nav-tabs>.active>a:focus{color:#555;cursor:default;background-color:#fff;border:1px solid #ddd;border-bottom-color:transparent}.fuelux .nav-pills>li>a{padding-top:8px;padding-bottom:8px;margin-top:2px;margin-bottom:2px;-webkit-border-radius:5px;-moz-border-radius:5px;border-radius:5px}.fuelux .nav-pills>.active>a,.fuelux .nav-pills>.active>a:hover,.fuelux .nav-pills>.active>a:focus{color:#fff;background-color:#08c}.fuelux .nav-stacked>li{float:none}.fuelux .nav-stacked>li>a{margin-right:0}.fuelux .nav-tabs.nav-stacked{border-bottom:0}.fuelux .nav-tabs.nav-stacked>li>a{border:1px solid #ddd;-webkit-border-radius:0;-moz-border-radius:0;border-radius:0}.fuelux .nav-tabs.nav-stacked>li:first-child>a{-webkit-border-top-right-radius:4px;border-top-right-radius:4px;-webkit-border-top-left-radius:4px;border-top-left-radius:4px;-moz-border-radius-topright:4px;-moz-border-radius-topleft:4px}.fuelux .nav-tabs.nav-stacked>li:last-child>a{-webkit-border-bottom-right-radius:4px;border-bottom-right-radius:4px;-webkit-border-bottom-left-radius:4px;border-bottom-left-radius:4px;-moz-border-radius-bottomright:4px;-moz-border-radius-bottomleft:4px}.fuelux .nav-tabs.nav-stacked>li>a:hover,.fuelux .nav-tabs.nav-stacked>li>a:focus{z-index:2;border-color:#ddd}.fuelux .nav-pills.nav-stacked>li>a{margin-bottom:3px}.fuelux .nav-pills.nav-stacked>li:last-child>a{margin-bottom:1px}.fuelux .nav-tabs .dropdown-menu{-webkit-border-radius:0 0 6px 6px;-moz-border-radius:0 0 6px 6px;border-radius:0 0 6px 6px}.fuelux .nav-pills .dropdown-menu{-webkit-border-radius:6px;-moz-border-radius:6px;border-radius:6px}.fuelux .nav .dropdown-toggle .caret{margin-top:6px;border-top-color:#08c;border-bottom-color:#08c}.fuelux .nav .dropdown-toggle:hover .caret,.fuelux .nav .dropdown-toggle:focus .caret{border-top-color:#005580;border-bottom-color:#005580}.fuelux .nav-tabs .dropdown-toggle .caret{margin-top:8px}.fuelux .nav .active .dropdown-toggle .caret{border-top-color:#fff;border-bottom-color:#fff}.fuelux .nav-tabs .active .dropdown-toggle .caret{border-top-color:#555;border-bottom-color:#555}.fuelux .nav>.dropdown.active>a:hover,.fuelux .nav>.dropdown.active>a:focus{cursor:pointer}.fuelux .nav-tabs .open .dropdown-toggle,.fuelux .nav-pills .open .dropdown-toggle,.fuelux .nav>li.dropdown.open.active>a:hover,.fuelux .nav>li.dropdown.open.active>a:focus{color:#fff;background-color:#999;border-color:#999}.fuelux .nav li.dropdown.open .caret,.fuelux .nav li.dropdown.open.active .caret,.fuelux .nav li.dropdown.open a:hover .caret,.fuelux .nav li.dropdown.open a:focus .caret{border-top-color:#fff;border-bottom-color:#fff;opacity:1;filter:alpha(opacity=100)}.fuelux .tabs-stacked .open>a:hover,.fuelux .tabs-stacked .open>a:focus{border-color:#999}.fuelux .tabbable{*zoom:1}.fuelux .tabbable:before,.fuelux .tabbable:after{display:table;line-height:0;content:""}.fuelux .tabbable:after{clear:both}.fuelux .tab-content{overflow:auto}.fuelux .tabs-below>.nav-tabs,.fuelux .tabs-right>.nav-tabs,.fuelux .tabs-left>.nav-tabs{border-bottom:0}.fuelux .tab-content>.tab-pane,.fuelux .pill-content>.pill-pane{display:none}.fuelux .tab-content>.active,.fuelux .pill-content>.active{display:block}.fuelux .tabs-below>.nav-tabs{border-top:1px solid #ddd}.fuelux .tabs-below>.nav-tabs>li{margin-top:-1px;margin-bottom:0}.fuelux .tabs-below>.nav-tabs>li>a{-webkit-border-radius:0 0 4px 4px;-moz-border-radius:0 0 4px 4px;border-radius:0 0 4px 4px}.fuelux .tabs-below>.nav-tabs>li>a:hover,.fuelux .tabs-below>.nav-tabs>li>a:focus{border-top-color:#ddd;border-bottom-color:transparent}.fuelux .tabs-below>.nav-tabs>.active>a,.fuelux .tabs-below>.nav-tabs>.active>a:hover,.fuelux .tabs-below>.nav-tabs>.active>a:focus{border-color:transparent #ddd #ddd #ddd}.fuelux .tabs-left>.nav-tabs>li,.fuelux .tabs-right>.nav-tabs>li{float:none}.fuelux .tabs-left>.nav-tabs>li>a,.fuelux .tabs-right>.nav-tabs>li>a{min-width:74px;margin-right:0;margin-bottom:3px}.fuelux .tabs-left>.nav-tabs{float:left;margin-right:19px;border-right:1px solid #ddd}.fuelux .tabs-left>.nav-tabs>li>a{margin-right:-1px;-webkit-border-radius:4px 0 0 4px;-moz-border-radius:4px 0 0 4px;border-radius:4px 0 0 4px}.fuelux .tabs-left>.nav-tabs>li>a:hover,.fuelux .tabs-left>.nav-tabs>li>a:focus{border-color:#eee #ddd #eee #eee}.fuelux .tabs-left>.nav-tabs .active>a,.fuelux .tabs-left>.nav-tabs .active>a:hover,.fuelux .tabs-left>.nav-tabs .active>a:focus{border-color:#ddd transparent #ddd #ddd;*border-right-color:#fff}.fuelux .tabs-right>.nav-tabs{float:right;margin-left:19px;border-left:1px solid #ddd}.fuelux .tabs-right>.nav-tabs>li>a{margin-left:-1px;-webkit-border-radius:0 4px 4px 0;-moz-border-radius:0 4px 4px 0;border-radius:0 4px 4px 0}.fuelux .tabs-right>.nav-tabs>li>a:hover,.fuelux .tabs-right>.nav-tabs>li>a:focus{border-color:#eee #eee #eee #ddd}.fuelux .tabs-right>.nav-tabs .active>a,.fuelux .tabs-right>.nav-tabs .active>a:hover,.fuelux .tabs-right>.nav-tabs .active>a:focus{border-color:#ddd #ddd #ddd transparent;*border-left-color:#fff}.fuelux .nav>.disabled>a{color:#999}.fuelux .nav>.disabled>a:hover,.fuelux .nav>.disabled>a:focus{text-decoration:none;cursor:default;background-color:transparent}.fuelux .navbar{*position:relative;*z-index:2;margin-bottom:20px;overflow:visible}.fuelux .navbar-inner{min-height:40px;padding-right:20px;padding-left:20px;background-color:#fafafa;background-image:-moz-linear-gradient(top,#fff,#f2f2f2);background-image:-webkit-gradient(linear,0 0,0 100%,from(#fff),to(#f2f2f2));background-image:-webkit-linear-gradient(top,#fff,#f2f2f2);background-image:-o-linear-gradient(top,#fff,#f2f2f2);background-image:linear-gradient(to bottom,#fff,#f2f2f2);background-repeat:repeat-x;border:1px solid #d4d4d4;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px;filter:progid:dximagetransform.microsoft.gradient(startColorstr='#ffffffff',endColorstr='#fff2f2f2',GradientType=0);*zoom:1;-webkit-box-shadow:0 1px 4px rgba(0,0,0,0.065);-moz-box-shadow:0 1px 4px rgba(0,0,0,0.065);box-shadow:0 1px 4px rgba(0,0,0,0.065)}.fuelux .navbar-inner:before,.fuelux .navbar-inner:after{display:table;line-height:0;content:""}.fuelux .navbar-inner:after{clear:both}.fuelux .navbar .container{width:auto}.fuelux .nav-collapse.collapse{height:auto;overflow:visible}.fuelux .navbar .brand{display:block;float:left;padding:10px 20px 10px;margin-left:-20px;font-size:20px;font-weight:200;color:#777;text-shadow:0 1px 0 #fff}.fuelux .navbar .brand:hover,.fuelux .navbar .brand:focus{text-decoration:none}.fuelux .navbar-text{margin-bottom:0;line-height:40px;color:#777}.fuelux .navbar-link{color:#777}.fuelux .navbar-link:hover,.fuelux .navbar-link:focus{color:#333}.fuelux .navbar .divider-vertical{height:40px;margin:0 9px;border-right:1px solid #fff;border-left:1px solid #f2f2f2}.fuelux .navbar .btn,.fuelux .navbar .btn-group{margin-top:5px}.fuelux .navbar .btn-group .btn,.fuelux .navbar .input-prepend .btn,.fuelux .navbar .input-append .btn,.fuelux .navbar .input-prepend .btn-group,.fuelux .navbar .input-append .btn-group{margin-top:0}.fuelux .navbar-form{margin-bottom:0;*zoom:1}.fuelux .navbar-form:before,.fuelux .navbar-form:after{display:table;line-height:0;content:""}.fuelux .navbar-form:after{clear:both}.fuelux .navbar-form input,.fuelux .navbar-form select,.fuelux .navbar-form .radio,.fuelux .navbar-form .checkbox{margin-top:5px}.fuelux .navbar-form input,.fuelux .navbar-form select,.fuelux .navbar-form .btn{display:inline-block;margin-bottom:0}.fuelux .navbar-form input[type="image"],.fuelux .navbar-form input[type="checkbox"],.fuelux .navbar-form input[type="radio"]{margin-top:3px}.fuelux .navbar-form .input-append,.fuelux .navbar-form .input-prepend{margin-top:5px;white-space:nowrap}.fuelux .navbar-form .input-append input,.fuelux .navbar-form .input-prepend input{margin-top:0}.fuelux .navbar-search{position:relative;float:left;margin-top:5px;margin-bottom:0}.fuelux .navbar-search .search-query{padding:4px 14px;margin-bottom:0;font-family:"Helvetica Neue",Helvetica,Arial,sans-serif;font-size:13px;font-weight:normal;line-height:1;-webkit-border-radius:15px;-moz-border-radius:15px;border-radius:15px}.fuelux .navbar-static-top{position:static;margin-bottom:0}.fuelux .navbar-static-top .navbar-inner{-webkit-border-radius:0;-moz-border-radius:0;border-radius:0}.fuelux .navbar-fixed-top,.fuelux .navbar-fixed-bottom{position:fixed;right:0;left:0;z-index:1030;margin-bottom:0}.fuelux .navbar-fixed-top .navbar-inner,.fuelux .navbar-static-top .navbar-inner{border-width:0 0 1px}.fuelux .navbar-fixed-bottom .navbar-inner{border-width:1px 0 0}.fuelux .navbar-fixed-top .navbar-inner,.fuelux .navbar-fixed-bottom .navbar-inner{padding-right:0;padding-left:0;-webkit-border-radius:0;-moz-border-radius:0;border-radius:0}.fuelux .navbar-static-top .container,.fuelux .navbar-fixed-top .container,.fuelux .navbar-fixed-bottom .container{width:940px}.fuelux .navbar-fixed-top{top:0}.fuelux .navbar-fixed-top .navbar-inner,.fuelux .navbar-static-top .navbar-inner{-webkit-box-shadow:0 1px 10px rgba(0,0,0,0.1);-moz-box-shadow:0 1px 10px rgba(0,0,0,0.1);box-shadow:0 1px 10px rgba(0,0,0,0.1)}.fuelux .navbar-fixed-bottom{bottom:0}.fuelux .navbar-fixed-bottom .navbar-inner{-webkit-box-shadow:0 -1px 10px rgba(0,0,0,0.1);-moz-box-shadow:0 -1px 10px rgba(0,0,0,0.1);box-shadow:0 -1px 10px rgba(0,0,0,0.1)}.fuelux .navbar .nav{position:relative;left:0;display:block;float:left;margin:0 10px 0 0}.fuelux .navbar .nav.pull-right{float:right;margin-right:0}.fuelux .navbar .nav>li{float:left}.fuelux .navbar .nav>li>a{float:none;padding:10px 15px 10px;color:#777;text-decoration:none;text-shadow:0 1px 0 #fff}.fuelux .navbar .nav .dropdown-toggle .caret{margin-top:8px}.fuelux .navbar .nav>li>a:focus,.fuelux .navbar .nav>li>a:hover{color:#333;text-decoration:none;background-color:transparent}.fuelux .navbar .nav>.active>a,.fuelux .navbar .nav>.active>a:hover,.fuelux .navbar .nav>.active>a:focus{color:#555;text-decoration:none;background-color:#e5e5e5;-webkit-box-shadow:inset 0 3px 8px rgba(0,0,0,0.125);-moz-box-shadow:inset 0 3px 8px rgba(0,0,0,0.125);box-shadow:inset 0 3px 8px rgba(0,0,0,0.125)}.fuelux .navbar .btn-navbar{display:none;float:right;padding:7px 10px;margin-right:5px;margin-left:5px;color:#fff;text-shadow:0 -1px 0 rgba(0,0,0,0.25);background-color:#ededed;*background-color:#e5e5e5;background-image:-webkit-gradient(linear,0 0,0 100%,from(#f2f2f2),to(#e5e5e5));background-image:-webkit-linear-gradient(top,#f2f2f2,#e5e5e5);background-image:-o-linear-gradient(top,#f2f2f2,#e5e5e5);background-image:linear-gradient(to bottom,#f2f2f2,#e5e5e5);background-image:-moz-linear-gradient(top,#f2f2f2,#e5e5e5);background-repeat:repeat-x;border-color:#e5e5e5 #e5e5e5 #bfbfbf;border-color:rgba(0,0,0,0.1) rgba(0,0,0,0.1) rgba(0,0,0,0.25);filter:progid:dximagetransform.microsoft.gradient(startColorstr='#fff2f2f2',endColorstr='#ffe5e5e5',GradientType=0);filter:progid:dximagetransform.microsoft.gradient(enabled=false);-webkit-box-shadow:inset 0 1px 0 rgba(255,255,255,0.1),0 1px 0 rgba(255,255,255,0.075);-moz-box-shadow:inset 0 1px 0 rgba(255,255,255,0.1),0 1px 0 rgba(255,255,255,0.075);box-shadow:inset 0 1px 0 rgba(255,255,255,0.1),0 1px 0 rgba(255,255,255,0.075)}.fuelux .navbar .btn-navbar:hover,.fuelux .navbar .btn-navbar:focus,.fuelux .navbar .btn-navbar:active,.fuelux .navbar .btn-navbar.active,.fuelux .navbar .btn-navbar.disabled,.fuelux .navbar .btn-navbar[disabled]{color:#fff;background-color:#e5e5e5;*background-color:#d9d9d9}.fuelux .navbar .btn-navbar:active,.fuelux .navbar .btn-navbar.active{background-color:#ccc \9}.fuelux .navbar .btn-navbar .icon-bar{display:block;width:18px;height:2px;background-color:#f5f5f5;-webkit-border-radius:1px;-moz-border-radius:1px;border-radius:1px;-webkit-box-shadow:0 1px 0 rgba(0,0,0,0.25);-moz-box-shadow:0 1px 0 rgba(0,0,0,0.25);box-shadow:0 1px 0 rgba(0,0,0,0.25)}.fuelux .btn-navbar .icon-bar+.icon-bar{margin-top:3px}.fuelux .navbar .nav>li>.dropdown-menu:before{position:absolute;top:-7px;left:9px;display:inline-block;border-right:7px solid transparent;border-bottom:7px solid #ccc;border-left:7px solid transparent;border-bottom-color:rgba(0,0,0,0.2);content:''}.fuelux .navbar .nav>li>.dropdown-menu:after{position:absolute;top:-6px;left:10px;display:inline-block;border-right:6px solid transparent;border-bottom:6px solid #fff;border-left:6px solid transparent;content:''}.fuelux .navbar-fixed-bottom .nav>li>.dropdown-menu:before{top:auto;bottom:-7px;border-top:7px solid #ccc;border-bottom:0;border-top-color:rgba(0,0,0,0.2)}.fuelux .navbar-fixed-bottom .nav>li>.dropdown-menu:after{top:auto;bottom:-6px;border-top:6px solid #fff;border-bottom:0}.fuelux .navbar .nav li.dropdown>a:hover .caret,.fuelux .navbar .nav li.dropdown>a:focus .caret{border-top-color:#333;border-bottom-color:#333}.fuelux .navbar .nav li.dropdown.open>.dropdown-toggle,.fuelux .navbar .nav li.dropdown.active>.dropdown-toggle,.fuelux .navbar .nav li.dropdown.open.active>.dropdown-toggle{color:#555;background-color:#e5e5e5}.fuelux .navbar .nav li.dropdown>.dropdown-toggle .caret{border-top-color:#777;border-bottom-color:#777}.fuelux .navbar .nav li.dropdown.open>.dropdown-toggle .caret,.fuelux .navbar .nav li.dropdown.active>.dropdown-toggle .caret,.fuelux .navbar .nav li.dropdown.open.active>.dropdown-toggle .caret{border-top-color:#555;border-bottom-color:#555}.fuelux .navbar .pull-right>li>.dropdown-menu,.fuelux .navbar .nav>li>.dropdown-menu.pull-right{right:0;left:auto}.fuelux .navbar .pull-right>li>.dropdown-menu:before,.fuelux .navbar .nav>li>.dropdown-menu.pull-right:before{right:12px;left:auto}.fuelux .navbar .pull-right>li>.dropdown-menu:after,.fuelux .navbar .nav>li>.dropdown-menu.pull-right:after{right:13px;left:auto}.fuelux .navbar .pull-right>li>.dropdown-menu .dropdown-menu,.fuelux .navbar .nav>li>.dropdown-menu.pull-right .dropdown-menu{right:100%;left:auto;margin-right:-1px;margin-left:0;-webkit-border-radius:6px 0 6px 6px;-moz-border-radius:6px 0 6px 6px;border-radius:6px 0 6px 6px}.fuelux .navbar-inverse .navbar-inner{background-color:#1b1b1b;background-image:-moz-linear-gradient(top,#222,#111);background-image:-webkit-gradient(linear,0 0,0 100%,from(#222),to(#111));background-image:-webkit-linear-gradient(top,#222,#111);background-image:-o-linear-gradient(top,#222,#111);background-image:linear-gradient(to bottom,#222,#111);background-repeat:repeat-x;border-color:#252525;filter:progid:dximagetransform.microsoft.gradient(startColorstr='#ff222222',endColorstr='#ff111111',GradientType=0)}.fuelux .navbar-inverse .brand,.fuelux .navbar-inverse .nav>li>a{color:#999;text-shadow:0 -1px 0 rgba(0,0,0,0.25)}.fuelux .navbar-inverse .brand:hover,.fuelux .navbar-inverse .nav>li>a:hover,.fuelux .navbar-inverse .brand:focus,.fuelux .navbar-inverse .nav>li>a:focus{color:#fff}.fuelux .navbar-inverse .brand{color:#999}.fuelux .navbar-inverse .navbar-text{color:#999}.fuelux .navbar-inverse .nav>li>a:focus,.fuelux .navbar-inverse .nav>li>a:hover{color:#fff;background-color:transparent}.fuelux .navbar-inverse .nav .active>a,.fuelux .navbar-inverse .nav .active>a:hover,.fuelux .navbar-inverse .nav .active>a:focus{color:#fff;background-color:#111}.fuelux .navbar-inverse .navbar-link{color:#999}.fuelux .navbar-inverse .navbar-link:hover,.fuelux .navbar-inverse .navbar-link:focus{color:#fff}.fuelux .navbar-inverse .divider-vertical{border-right-color:#222;border-left-color:#111}.fuelux .navbar-inverse .nav li.dropdown.open>.dropdown-toggle,.fuelux .navbar-inverse .nav li.dropdown.active>.dropdown-toggle,.fuelux .navbar-inverse .nav li.dropdown.open.active>.dropdown-toggle{color:#fff;background-color:#111}.fuelux .navbar-inverse .nav li.dropdown>a:hover .caret,.fuelux .navbar-inverse .nav li.dropdown>a:focus .caret{border-top-color:#fff;border-bottom-color:#fff}.fuelux .navbar-inverse .nav li.dropdown>.dropdown-toggle .caret{border-top-color:#999;border-bottom-color:#999}.fuelux .navbar-inverse .nav li.dropdown.open>.dropdown-toggle .caret,.fuelux .navbar-inverse .nav li.dropdown.active>.dropdown-toggle .caret,.fuelux .navbar-inverse .nav li.dropdown.open.active>.dropdown-toggle .caret{border-top-color:#fff;border-bottom-color:#fff}.fuelux .navbar-inverse .navbar-search .search-query{color:#fff;background-color:#515151;border-color:#111;-webkit-box-shadow:inset 0 1px 2px rgba(0,0,0,0.1),0 1px 0 rgba(255,255,255,0.15);-moz-box-shadow:inset 0 1px 2px rgba(0,0,0,0.1),0 1px 0 rgba(255,255,255,0.15);box-shadow:inset 0 1px 2px rgba(0,0,0,0.1),0 1px 0 rgba(255,255,255,0.15);-webkit-transition:none;-moz-transition:none;-o-transition:none;transition:none}.fuelux .navbar-inverse .navbar-search .search-query:-moz-placeholder{color:#ccc}.fuelux .navbar-inverse .navbar-search .search-query:-ms-input-placeholder{color:#ccc}.fuelux .navbar-inverse .navbar-search .search-query::-webkit-input-placeholder{color:#ccc}.fuelux .navbar-inverse .navbar-search .search-query:focus,.fuelux .navbar-inverse .navbar-search .search-query.focused{padding:5px 15px;color:#333;text-shadow:0 1px 0 #fff;background-color:#fff;border:0;outline:0;-webkit-box-shadow:0 0 3px rgba(0,0,0,0.15);-moz-box-shadow:0 0 3px rgba(0,0,0,0.15);box-shadow:0 0 3px rgba(0,0,0,0.15)}.fuelux .navbar-inverse .btn-navbar{color:#fff;text-shadow:0 -1px 0 rgba(0,0,0,0.25);background-color:#0e0e0e;*background-color:#040404;background-image:-webkit-gradient(linear,0 0,0 100%,from(#151515),to(#040404));background-image:-webkit-linear-gradient(top,#151515,#040404);background-image:-o-linear-gradient(top,#151515,#040404);background-image:linear-gradient(to bottom,#151515,#040404);background-image:-moz-linear-gradient(top,#151515,#040404);background-repeat:repeat-x;border-color:#040404 #040404 #000;border-color:rgba(0,0,0,0.1) rgba(0,0,0,0.1) rgba(0,0,0,0.25);filter:progid:dximagetransform.microsoft.gradient(startColorstr='#ff151515',endColorstr='#ff040404',GradientType=0);filter:progid:dximagetransform.microsoft.gradient(enabled=false)}.fuelux .navbar-inverse .btn-navbar:hover,.fuelux .navbar-inverse .btn-navbar:focus,.fuelux .navbar-inverse .btn-navbar:active,.fuelux .navbar-inverse .btn-navbar.active,.fuelux .navbar-inverse .btn-navbar.disabled,.fuelux .navbar-inverse .btn-navbar[disabled]{color:#fff;background-color:#040404;*background-color:#000}.fuelux .navbar-inverse .btn-navbar:active,.fuelux .navbar-inverse .btn-navbar.active{background-color:#000 \9}.fuelux .breadcrumb{padding:8px 15px;margin:0 0 20px;list-style:none;background-color:#f5f5f5;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px}.fuelux .breadcrumb>li{display:inline-block;*display:inline;text-shadow:0 1px 0 #fff;*zoom:1}.fuelux .breadcrumb>li>.divider{padding:0 5px;color:#ccc}.fuelux .breadcrumb>.active{color:#999}.fuelux .pagination{margin:20px 0}.fuelux .pagination ul{display:inline-block;*display:inline;margin-bottom:0;margin-left:0;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px;*zoom:1;-webkit-box-shadow:0 1px 2px rgba(0,0,0,0.05);-moz-box-shadow:0 1px 2px rgba(0,0,0,0.05);box-shadow:0 1px 2px rgba(0,0,0,0.05)}.fuelux .pagination ul>li{display:inline}.fuelux .pagination ul>li>a,.fuelux .pagination ul>li>span{float:left;padding:4px 12px;line-height:20px;text-decoration:none;background-color:#fff;border:1px solid #ddd;border-left-width:0}.fuelux .pagination ul>li>a:hover,.fuelux .pagination ul>li>a:focus,.fuelux .pagination ul>.active>a,.fuelux .pagination ul>.active>span{background-color:#f5f5f5}.fuelux .pagination ul>.active>a,.fuelux .pagination ul>.active>span{color:#999;cursor:default}.fuelux .pagination ul>.disabled>span,.fuelux .pagination ul>.disabled>a,.fuelux .pagination ul>.disabled>a:hover,.fuelux .pagination ul>.disabled>a:focus{color:#999;cursor:default;background-color:transparent}.fuelux .pagination ul>li:first-child>a,.fuelux .pagination ul>li:first-child>span{border-left-width:1px;-webkit-border-bottom-left-radius:4px;border-bottom-left-radius:4px;-webkit-border-top-left-radius:4px;border-top-left-radius:4px;-moz-border-radius-bottomleft:4px;-moz-border-radius-topleft:4px}.fuelux .pagination ul>li:last-child>a,.fuelux .pagination ul>li:last-child>span{-webkit-border-top-right-radius:4px;border-top-right-radius:4px;-webkit-border-bottom-right-radius:4px;border-bottom-right-radius:4px;-moz-border-radius-topright:4px;-moz-border-radius-bottomright:4px}.fuelux .pagination-centered{text-align:center}.fuelux .pagination-right{text-align:right}.fuelux .pagination-large ul>li>a,.fuelux .pagination-large ul>li>span{padding:11px 19px;font-size:17.5px}.fuelux .pagination-large ul>li:first-child>a,.fuelux .pagination-large ul>li:first-child>span{-webkit-border-bottom-left-radius:6px;border-bottom-left-radius:6px;-webkit-border-top-left-radius:6px;border-top-left-radius:6px;-moz-border-radius-bottomleft:6px;-moz-border-radius-topleft:6px}.fuelux .pagination-large ul>li:last-child>a,.fuelux .pagination-large ul>li:last-child>span{-webkit-border-top-right-radius:6px;border-top-right-radius:6px;-webkit-border-bottom-right-radius:6px;border-bottom-right-radius:6px;-moz-border-radius-topright:6px;-moz-border-radius-bottomright:6px}.fuelux .pagination-mini ul>li:first-child>a,.fuelux .pagination-small ul>li:first-child>a,.fuelux .pagination-mini ul>li:first-child>span,.fuelux .pagination-small ul>li:first-child>span{-webkit-border-bottom-left-radius:3px;border-bottom-left-radius:3px;-webkit-border-top-left-radius:3px;border-top-left-radius:3px;-moz-border-radius-bottomleft:3px;-moz-border-radius-topleft:3px}.fuelux .pagination-mini ul>li:last-child>a,.fuelux .pagination-small ul>li:last-child>a,.fuelux .pagination-mini ul>li:last-child>span,.fuelux .pagination-small ul>li:last-child>span{-webkit-border-top-right-radius:3px;border-top-right-radius:3px;-webkit-border-bottom-right-radius:3px;border-bottom-right-radius:3px;-moz-border-radius-topright:3px;-moz-border-radius-bottomright:3px}.fuelux .pagination-small ul>li>a,.fuelux .pagination-small ul>li>span{padding:2px 10px;font-size:11.9px}.fuelux .pagination-mini ul>li>a,.fuelux .pagination-mini ul>li>span{padding:0 6px;font-size:10.5px}.fuelux .pager{margin:20px 0;text-align:center;list-style:none;*zoom:1}.fuelux .pager:before,.fuelux .pager:after{display:table;line-height:0;content:""}.fuelux .pager:after{clear:both}.fuelux .pager li{display:inline}.fuelux .pager li>a,.fuelux .pager li>span{display:inline-block;padding:5px 14px;background-color:#fff;border:1px solid #ddd;-webkit-border-radius:15px;-moz-border-radius:15px;border-radius:15px}.fuelux .pager li>a:hover,.fuelux .pager li>a:focus{text-decoration:none;background-color:#f5f5f5}.fuelux .pager .next>a,.fuelux .pager .next>span{float:right}.fuelux .pager .previous>a,.fuelux .pager .previous>span{float:left}.fuelux .pager .disabled>a,.fuelux .pager .disabled>a:hover,.fuelux .pager .disabled>a:focus,.fuelux .pager .disabled>span{color:#999;cursor:default;background-color:#fff}.fuelux .modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1040;background-color:#000}.fuelux .modal-backdrop.fade{opacity:0}.fuelux .modal-backdrop,.fuelux .modal-backdrop.fade.in{opacity:.8;filter:alpha(opacity=80)}.fuelux .modal{position:fixed;top:10%;left:50%;z-index:1050;width:560px;margin-left:-280px;background-color:#fff;border:1px solid #999;border:1px solid rgba(0,0,0,0.3);*border:1px solid #999;-webkit-border-radius:6px;-moz-border-radius:6px;border-radius:6px;outline:0;-webkit-box-shadow:0 3px 7px rgba(0,0,0,0.3);-moz-box-shadow:0 3px 7px rgba(0,0,0,0.3);box-shadow:0 3px 7px rgba(0,0,0,0.3);-webkit-background-clip:padding-box;-moz-background-clip:padding-box;background-clip:padding-box}.fuelux .modal.fade{top:-25%;-webkit-transition:opacity .3s linear,top .3s ease-out;-moz-transition:opacity .3s linear,top .3s ease-out;-o-transition:opacity .3s linear,top .3s ease-out;transition:opacity .3s linear,top .3s ease-out}.fuelux .modal.fade.in{top:10%}.fuelux .modal-header{padding:9px 15px;border-bottom:1px solid #eee}.fuelux .modal-header .close{margin-top:2px}.fuelux .modal-header h3{margin:0;line-height:30px}.fuelux .modal-body{position:relative;max-height:400px;padding:15px;overflow-y:auto}.fuelux .modal-form{margin-bottom:0}.fuelux .modal-footer{padding:14px 15px 15px;margin-bottom:0;text-align:right;background-color:#f5f5f5;border-top:1px solid #ddd;-webkit-border-radius:0 0 6px 6px;-moz-border-radius:0 0 6px 6px;border-radius:0 0 6px 6px;*zoom:1;-webkit-box-shadow:inset 0 1px 0 #fff;-moz-box-shadow:inset 0 1px 0 #fff;box-shadow:inset 0 1px 0 #fff}.fuelux .modal-footer:before,.fuelux .modal-footer:after{display:table;line-height:0;content:""}.fuelux .modal-footer:after{clear:both}.fuelux .modal-footer .btn+.btn{margin-bottom:0;margin-left:5px}.fuelux .modal-footer .btn-group .btn+.btn{margin-left:-1px}.fuelux .modal-footer .btn-block+.btn-block{margin-left:0}.fuelux .tooltip{position:absolute;z-index:1030;display:block;font-size:11px;line-height:1.4;opacity:0;filter:alpha(opacity=0);visibility:visible}.fuelux .tooltip.in{opacity:.8;filter:alpha(opacity=80)}.fuelux .tooltip.top{padding:5px 0;margin-top:-3px}.fuelux .tooltip.right{padding:0 5px;margin-left:3px}.fuelux .tooltip.bottom{padding:5px 0;margin-top:3px}.fuelux .tooltip.left{padding:0 5px;margin-left:-3px}.fuelux .tooltip-inner{max-width:200px;padding:8px;color:#fff;text-align:center;text-decoration:none;background-color:#000;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px}.fuelux .tooltip-arrow{position:absolute;width:0;height:0;border-color:transparent;border-style:solid}.fuelux .tooltip.top .tooltip-arrow{bottom:0;left:50%;margin-left:-5px;border-top-color:#000;border-width:5px 5px 0}.fuelux .tooltip.right .tooltip-arrow{top:50%;left:0;margin-top:-5px;border-right-color:#000;border-width:5px 5px 5px 0}.fuelux .tooltip.left .tooltip-arrow{top:50%;right:0;margin-top:-5px;border-left-color:#000;border-width:5px 0 5px 5px}.fuelux .tooltip.bottom .tooltip-arrow{top:0;left:50%;margin-left:-5px;border-bottom-color:#000;border-width:0 5px 5px}.fuelux .popover{position:absolute;top:0;left:0;z-index:1010;display:none;max-width:276px;padding:1px;text-align:left;white-space:normal;background-color:#fff;border:1px solid #ccc;border:1px solid rgba(0,0,0,0.2);-webkit-border-radius:6px;-moz-border-radius:6px;border-radius:6px;-webkit-box-shadow:0 5px 10px rgba(0,0,0,0.2);-moz-box-shadow:0 5px 10px rgba(0,0,0,0.2);box-shadow:0 5px 10px rgba(0,0,0,0.2);-webkit-background-clip:padding-box;-moz-background-clip:padding;background-clip:padding-box}.fuelux .popover.top{margin-top:-10px}.fuelux .popover.right{margin-left:10px}.fuelux .popover.bottom{margin-top:10px}.fuelux .popover.left{margin-left:-10px}.fuelux .popover-title{padding:8px 14px;margin:0;font-size:14px;font-weight:normal;line-height:18px;background-color:#f7f7f7;border-bottom:1px solid #ebebeb;-webkit-border-radius:5px 5px 0 0;-moz-border-radius:5px 5px 0 0;border-radius:5px 5px 0 0}.fuelux .popover-title:empty{display:none}.fuelux .popover-content{padding:9px 14px}.fuelux .popover .arrow,.fuelux .popover .arrow:after{position:absolute;display:block;width:0;height:0;border-color:transparent;border-style:solid}.fuelux .popover .arrow{border-width:11px}.fuelux .popover .arrow:after{border-width:10px;content:""}.fuelux .popover.top .arrow{bottom:-11px;left:50%;margin-left:-11px;border-top-color:#999;border-top-color:rgba(0,0,0,0.25);border-bottom-width:0}.fuelux .popover.top .arrow:after{bottom:1px;margin-left:-10px;border-top-color:#fff;border-bottom-width:0}.fuelux .popover.right .arrow{top:50%;left:-11px;margin-top:-11px;border-right-color:#999;border-right-color:rgba(0,0,0,0.25);border-left-width:0}.fuelux .popover.right .arrow:after{bottom:-10px;left:1px;border-right-color:#fff;border-left-width:0}.fuelux .popover.bottom .arrow{top:-11px;left:50%;margin-left:-11px;border-bottom-color:#999;border-bottom-color:rgba(0,0,0,0.25);border-top-width:0}.fuelux .popover.bottom .arrow:after{top:1px;margin-left:-10px;border-bottom-color:#fff;border-top-width:0}.fuelux .popover.left .arrow{top:50%;right:-11px;margin-top:-11px;border-left-color:#999;border-left-color:rgba(0,0,0,0.25);border-right-width:0}.fuelux .popover.left .arrow:after{right:1px;bottom:-10px;border-left-color:#fff;border-right-width:0}.fuelux .thumbnails{margin-left:-20px;list-style:none;*zoom:1}.fuelux .thumbnails:before,.fuelux .thumbnails:after{display:table;line-height:0;content:""}.fuelux .thumbnails:after{clear:both}.fuelux .row-fluid .thumbnails{margin-left:0}.fuelux .thumbnails>li{float:left;margin-bottom:20px;margin-left:20px}.fuelux .thumbnail{display:block;padding:4px;line-height:20px;border:1px solid #ddd;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px;-webkit-box-shadow:0 1px 3px rgba(0,0,0,0.055);-moz-box-shadow:0 1px 3px rgba(0,0,0,0.055);box-shadow:0 1px 3px rgba(0,0,0,0.055);-webkit-transition:all .2s ease-in-out;-moz-transition:all .2s ease-in-out;-o-transition:all .2s ease-in-out;transition:all .2s ease-in-out}.fuelux a.thumbnail:hover,.fuelux a.thumbnail:focus{border-color:#08c;-webkit-box-shadow:0 1px 4px rgba(0,105,214,0.25);-moz-box-shadow:0 1px 4px rgba(0,105,214,0.25);box-shadow:0 1px 4px rgba(0,105,214,0.25)}.fuelux .thumbnail>img{display:block;max-width:100%;margin-right:auto;margin-left:auto}.fuelux .thumbnail .caption{padding:9px;color:#555}.fuelux .media,.fuelux .media-body{overflow:hidden;*overflow:visible;zoom:1}.fuelux .media,.fuelux .media .media{margin-top:15px}.fuelux .media:first-child{margin-top:0}.fuelux .media-object{display:block}.fuelux .media-heading{margin:0 0 5px}.fuelux .media>.pull-left{margin-right:10px}.fuelux .media>.pull-right{margin-left:10px}.fuelux .media-list{margin-left:0;list-style:none}.fuelux .label,.fuelux .badge{display:inline-block;padding:2px 4px;font-size:11.844px;font-weight:bold;line-height:14px;color:#fff;text-shadow:0 -1px 0 rgba(0,0,0,0.25);white-space:nowrap;vertical-align:baseline;background-color:#999}.fuelux .label{-webkit-border-radius:3px;-moz-border-radius:3px;border-radius:3px}.fuelux .badge{padding-right:9px;padding-left:9px;-webkit-border-radius:9px;-moz-border-radius:9px;border-radius:9px}.fuelux .label:empty,.fuelux .badge:empty{display:none}.fuelux a.label:hover,.fuelux a.label:focus,.fuelux a.badge:hover,.fuelux a.badge:focus{color:#fff;text-decoration:none;cursor:pointer}.fuelux .label-important,.fuelux .badge-important{background-color:#b94a48}.fuelux .label-important[href],.fuelux .badge-important[href]{background-color:#953b39}.fuelux .label-warning,.fuelux .badge-warning{background-color:#f89406}.fuelux .label-warning[href],.fuelux .badge-warning[href]{background-color:#c67605}.fuelux .label-success,.fuelux .badge-success{background-color:#468847}.fuelux .label-success[href],.fuelux .badge-success[href]{background-color:#356635}.fuelux .label-info,.fuelux .badge-info{background-color:#3a87ad}.fuelux .label-info[href],.fuelux .badge-info[href]{background-color:#2d6987}.fuelux .label-inverse,.fuelux .badge-inverse{background-color:#333}.fuelux .label-inverse[href],.fuelux .badge-inverse[href]{background-color:#1a1a1a}.fuelux .btn .label,.fuelux .btn .badge{position:relative;top:-1px}.fuelux .btn-mini .label,.fuelux .btn-mini .badge{top:0}@-webkit-keyframes progress-bar-stripes{from{background-position:40px 0}to{background-position:0 0}}@-moz-keyframes progress-bar-stripes{from{background-position:40px 0}to{background-position:0 0}}@-ms-keyframes progress-bar-stripes{from{background-position:40px 0}to{background-position:0 0}}@-o-keyframes progress-bar-stripes{from{background-position:0 0}to{background-position:40px 0}}@keyframes progress-bar-stripes{from{background-position:40px 0}to{background-position:0 0}}.fuelux .progress{height:20px;margin-bottom:20px;overflow:hidden;background-color:#f7f7f7;background-image:-moz-linear-gradient(top,#f5f5f5,#f9f9f9);background-image:-webkit-gradient(linear,0 0,0 100%,from(#f5f5f5),to(#f9f9f9));background-image:-webkit-linear-gradient(top,#f5f5f5,#f9f9f9);background-image:-o-linear-gradient(top,#f5f5f5,#f9f9f9);background-image:linear-gradient(to bottom,#f5f5f5,#f9f9f9);background-repeat:repeat-x;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px;filter:progid:dximagetransform.microsoft.gradient(startColorstr='#fff5f5f5',endColorstr='#fff9f9f9',GradientType=0);-webkit-box-shadow:inset 0 1px 2px rgba(0,0,0,0.1);-moz-box-shadow:inset 0 1px 2px rgba(0,0,0,0.1);box-shadow:inset 0 1px 2px rgba(0,0,0,0.1)}.fuelux .progress .bar{float:left;width:0;height:100%;font-size:12px;color:#fff;text-align:center;text-shadow:0 -1px 0 rgba(0,0,0,0.25);background-color:#0e90d2;background-image:-moz-linear-gradient(top,#149bdf,#0480be);background-image:-webkit-gradient(linear,0 0,0 100%,from(#149bdf),to(#0480be));background-image:-webkit-linear-gradient(top,#149bdf,#0480be);background-image:-o-linear-gradient(top,#149bdf,#0480be);background-image:linear-gradient(to bottom,#149bdf,#0480be);background-repeat:repeat-x;filter:progid:dximagetransform.microsoft.gradient(startColorstr='#ff149bdf',endColorstr='#ff0480be',GradientType=0);-webkit-box-shadow:inset 0 -1px 0 rgba(0,0,0,0.15);-moz-box-shadow:inset 0 -1px 0 rgba(0,0,0,0.15);box-shadow:inset 0 -1px 0 rgba(0,0,0,0.15);-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;-webkit-transition:width .6s ease;-moz-transition:width .6s ease;-o-transition:width .6s ease;transition:width .6s ease}.fuelux .progress .bar+.bar{-webkit-box-shadow:inset 1px 0 0 rgba(0,0,0,0.15),inset 0 -1px 0 rgba(0,0,0,0.15);-moz-box-shadow:inset 1px 0 0 rgba(0,0,0,0.15),inset 0 -1px 0 rgba(0,0,0,0.15);box-shadow:inset 1px 0 0 rgba(0,0,0,0.15),inset 0 -1px 0 rgba(0,0,0,0.15)}.fuelux .progress-striped .bar{background-color:#149bdf;background-image:-webkit-gradient(linear,0 100%,100% 0,color-stop(0.25,rgba(255,255,255,0.15)),color-stop(0.25,transparent),color-stop(0.5,transparent),color-stop(0.5,rgba(255,255,255,0.15)),color-stop(0.75,rgba(255,255,255,0.15)),color-stop(0.75,transparent),to(transparent));background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-moz-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-o-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);-webkit-background-size:40px 40px;-moz-background-size:40px 40px;-o-background-size:40px 40px;background-size:40px 40px}.fuelux .progress.active .bar{-webkit-animation:progress-bar-stripes 2s linear infinite;-moz-animation:progress-bar-stripes 2s linear infinite;-ms-animation:progress-bar-stripes 2s linear infinite;-o-animation:progress-bar-stripes 2s linear infinite;animation:progress-bar-stripes 2s linear infinite}.fuelux .progress-danger .bar,.fuelux .progress .bar-danger{background-color:#dd514c;background-image:-moz-linear-gradient(top,#ee5f5b,#c43c35);background-image:-webkit-gradient(linear,0 0,0 100%,from(#ee5f5b),to(#c43c35));background-image:-webkit-linear-gradient(top,#ee5f5b,#c43c35);background-image:-o-linear-gradient(top,#ee5f5b,#c43c35);background-image:linear-gradient(to bottom,#ee5f5b,#c43c35);background-repeat:repeat-x;filter:progid:dximagetransform.microsoft.gradient(startColorstr='#ffee5f5b',endColorstr='#ffc43c35',GradientType=0)}.fuelux .progress-danger.progress-striped .bar,.fuelux .progress-striped .bar-danger{background-color:#ee5f5b;background-image:-webkit-gradient(linear,0 100%,100% 0,color-stop(0.25,rgba(255,255,255,0.15)),color-stop(0.25,transparent),color-stop(0.5,transparent),color-stop(0.5,rgba(255,255,255,0.15)),color-stop(0.75,rgba(255,255,255,0.15)),color-stop(0.75,transparent),to(transparent));background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-moz-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-o-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent)}.fuelux .progress-success .bar,.fuelux .progress .bar-success{background-color:#5eb95e;background-image:-moz-linear-gradient(top,#62c462,#57a957);background-image:-webkit-gradient(linear,0 0,0 100%,from(#62c462),to(#57a957));background-image:-webkit-linear-gradient(top,#62c462,#57a957);background-image:-o-linear-gradient(top,#62c462,#57a957);background-image:linear-gradient(to bottom,#62c462,#57a957);background-repeat:repeat-x;filter:progid:dximagetransform.microsoft.gradient(startColorstr='#ff62c462',endColorstr='#ff57a957',GradientType=0)}.fuelux .progress-success.progress-striped .bar,.fuelux .progress-striped .bar-success{background-color:#62c462;background-image:-webkit-gradient(linear,0 100%,100% 0,color-stop(0.25,rgba(255,255,255,0.15)),color-stop(0.25,transparent),color-stop(0.5,transparent),color-stop(0.5,rgba(255,255,255,0.15)),color-stop(0.75,rgba(255,255,255,0.15)),color-stop(0.75,transparent),to(transparent));background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-moz-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-o-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent)}.fuelux .progress-info .bar,.fuelux .progress .bar-info{background-color:#4bb1cf;background-image:-moz-linear-gradient(top,#5bc0de,#339bb9);background-image:-webkit-gradient(linear,0 0,0 100%,from(#5bc0de),to(#339bb9));background-image:-webkit-linear-gradient(top,#5bc0de,#339bb9);background-image:-o-linear-gradient(top,#5bc0de,#339bb9);background-image:linear-gradient(to bottom,#5bc0de,#339bb9);background-repeat:repeat-x;filter:progid:dximagetransform.microsoft.gradient(startColorstr='#ff5bc0de',endColorstr='#ff339bb9',GradientType=0)}.fuelux .progress-info.progress-striped .bar,.fuelux .progress-striped .bar-info{background-color:#5bc0de;background-image:-webkit-gradient(linear,0 100%,100% 0,color-stop(0.25,rgba(255,255,255,0.15)),color-stop(0.25,transparent),color-stop(0.5,transparent),color-stop(0.5,rgba(255,255,255,0.15)),color-stop(0.75,rgba(255,255,255,0.15)),color-stop(0.75,transparent),to(transparent));background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-moz-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-o-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent)}.fuelux .progress-warning .bar,.fuelux .progress .bar-warning{background-color:#faa732;background-image:-moz-linear-gradient(top,#fbb450,#f89406);background-image:-webkit-gradient(linear,0 0,0 100%,from(#fbb450),to(#f89406));background-image:-webkit-linear-gradient(top,#fbb450,#f89406);background-image:-o-linear-gradient(top,#fbb450,#f89406);background-image:linear-gradient(to bottom,#fbb450,#f89406);background-repeat:repeat-x;filter:progid:dximagetransform.microsoft.gradient(startColorstr='#fffbb450',endColorstr='#fff89406',GradientType=0)}.fuelux .progress-warning.progress-striped .bar,.fuelux .progress-striped .bar-warning{background-color:#fbb450;background-image:-webkit-gradient(linear,0 100%,100% 0,color-stop(0.25,rgba(255,255,255,0.15)),color-stop(0.25,transparent),color-stop(0.5,transparent),color-stop(0.5,rgba(255,255,255,0.15)),color-stop(0.75,rgba(255,255,255,0.15)),color-stop(0.75,transparent),to(transparent));background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-moz-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-o-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent)}.fuelux .accordion{margin-bottom:20px}.fuelux .accordion-group{margin-bottom:2px;border:1px solid #e5e5e5;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px}.fuelux .accordion-heading{border-bottom:0}.fuelux .accordion-heading .accordion-toggle{display:block;padding:8px 15px}.fuelux .accordion-toggle{cursor:pointer}.fuelux .accordion-inner{padding:9px 15px;border-top:1px solid #e5e5e5}.fuelux .carousel{position:relative;margin-bottom:20px;line-height:1}.fuelux .carousel-inner{position:relative;width:100%;overflow:hidden}.fuelux .carousel-inner>.item{position:relative;display:none;-webkit-transition:.6s ease-in-out left;-moz-transition:.6s ease-in-out left;-o-transition:.6s ease-in-out left;transition:.6s ease-in-out left}.fuelux .carousel-inner>.item>img,.fuelux .carousel-inner>.item>a>img{display:block;line-height:1}.fuelux .carousel-inner>.active,.fuelux .carousel-inner>.next,.fuelux .carousel-inner>.prev{display:block}.fuelux .carousel-inner>.active{left:0}.fuelux .carousel-inner>.next,.fuelux .carousel-inner>.prev{position:absolute;top:0;width:100%}.fuelux .carousel-inner>.next{left:100%}.fuelux .carousel-inner>.prev{left:-100%}.fuelux .carousel-inner>.next.left,.fuelux .carousel-inner>.prev.right{left:0}.fuelux .carousel-inner>.active.left{left:-100%}.fuelux .carousel-inner>.active.right{left:100%}.fuelux .carousel-control{position:absolute;top:40%;left:15px;width:40px;height:40px;margin-top:-20px;font-size:60px;font-weight:100;line-height:30px;color:#fff;text-align:center;background:#222;border:3px solid #fff;-webkit-border-radius:23px;-moz-border-radius:23px;border-radius:23px;opacity:.5;filter:alpha(opacity=50)}.fuelux .carousel-control.right{right:15px;left:auto}.fuelux .carousel-control:hover,.fuelux .carousel-control:focus{color:#fff;text-decoration:none;opacity:.9;filter:alpha(opacity=90)}.fuelux .carousel-indicators{position:absolute;top:15px;right:15px;z-index:5;margin:0;list-style:none}.fuelux .carousel-indicators li{display:block;float:left;width:10px;height:10px;margin-left:5px;text-indent:-999px;background-color:#ccc;background-color:rgba(255,255,255,0.25);border-radius:5px}.fuelux .carousel-indicators .active{background-color:#fff}.fuelux .carousel-caption{position:absolute;right:0;bottom:0;left:0;padding:15px;background:#333;background:rgba(0,0,0,0.75)}.fuelux .carousel-caption h4,.fuelux .carousel-caption p{line-height:20px;color:#fff}.fuelux .carousel-caption h4{margin:0 0 5px}.fuelux .carousel-caption p{margin-bottom:0}.fuelux .hero-unit{padding:60px;margin-bottom:30px;font-size:18px;font-weight:200;line-height:30px;color:inherit;background-color:#eee;-webkit-border-radius:6px;-moz-border-radius:6px;border-radius:6px}.fuelux .hero-unit h1{margin-bottom:0;font-size:60px;line-height:1;letter-spacing:-1px;color:inherit}.fuelux .hero-unit li{line-height:30px}.fuelux .pull-right{float:right}.fuelux .pull-left{float:left}.fuelux .hide{display:none}.fuelux .show{display:block}.fuelux .invisible{visibility:hidden}.fuelux .affix{position:fixed}.fuelux .form-inline .checkbox-custom{padding-left:20px}.fuelux .form-inline .checkbox-custom .checkbox{padding-left:16px}.fuelux .checkbox-custom input[type=checkbox]{position:relative;top:-99999px}.fuelux .checkbox-custom i{width:16px;height:16px;padding-left:16px;margin-right:4px;margin-left:-20px;background-image:url(../img/form.png);background-position:0 1px;background-repeat:no-repeat}.fuelux .checkbox-custom i.checked{background-position:-48px 1px}.fuelux .checkbox-custom i.disabled{background-position:-64px 1px}.fuelux .checkbox-custom i.disabled.checked{background-position:-80px 1px}.fuelux .checkbox-custom:hover i{background-position:-16px 1px}.fuelux .checkbox-custom:hover i.checked{background-position:-32px 1px}.fuelux .checkbox-custom:hover i.disabled{background-position:-64px 1px}.fuelux .checkbox-custom:hover i.disabled.checked{background-position:-80px 1px}.fuelux .combobox{display:inline-block}.fuelux .combobox a{font-size:14px}.fuelux .combobox button.btn{border-radius:0 4px 4px 0}.fuelux .datagrid thead{background-color:#f9f9f9}.fuelux .datagrid thead .datagrid-header-title{float:left;margin-right:10px;font-size:14px;font-weight:normal;line-height:28px}.fuelux .datagrid thead .datagrid-header-left{float:left}.fuelux .datagrid thead .datagrid-header-right{float:right}.fuelux .datagrid thead .datagrid-header-right .search,.fuelux .datagrid thead .datagrid-header-left .search,.fuelux .datagrid thead .datagrid-header-right .filter,.fuelux .datagrid thead .datagrid-header-left .filter{margin-bottom:0;margin-left:8px}.fuelux .datagrid thead .datagrid-header-right .search .dropdown-menu,.fuelux .datagrid thead .datagrid-header-left .search .dropdown-menu,.fuelux .datagrid thead .datagrid-header-right .filter .dropdown-menu,.fuelux .datagrid thead .datagrid-header-left .filter .dropdown-menu{top:auto;left:auto}.fuelux .datagrid thead .sorted{padding-right:30px;color:#333;text-shadow:'none';background-color:#f1f1f1;background-image:-webkit-gradient(linear,0 0,0 100%,from(#f9f9f9),to(#e5e5e5));background-image:-webkit-linear-gradient(top,#f9f9f9,#e5e5e5);background-image:-o-linear-gradient(top,#f9f9f9,#e5e5e5);background-image:-moz-linear-gradient(top,#f9f9f9,#e5e5e5);background-image:linear-gradient(to bottom,#f9f9f9,#e5e5e5);background-repeat:repeat-x;border-color:#e5e5e5 #e5e5e5 #bebebe;border-color:rgba(0,0,0,0.1) rgba(0,0,0,0.1) rgba(0,0,0,0.25);filter:progid:dximagetransform.microsoft.gradient(startColorstr='#fff9f9f9',endColorstr='#ffe5e5e5',GradientType=0)}.fuelux .datagrid thead .sorted i{float:right;margin-top:2px;margin-right:-22px}.fuelux .datagrid thead .sortable{cursor:pointer}.fuelux .datagrid thead .sortable:hover{color:#333;text-shadow:'none';background-color:#f1f1f1;background-image:-moz-linear-gradient(top,#f9f9f9,#e5e5e5);background-image:-webkit-gradient(linear,0 0,0 100%,from(#f9f9f9),to(#e5e5e5));background-image:-webkit-linear-gradient(top,#f9f9f9,#e5e5e5);background-image:-o-linear-gradient(top,#f9f9f9,#e5e5e5);background-image:linear-gradient(to bottom,#f9f9f9,#e5e5e5);background-repeat:repeat-x;border-color:#e5e5e5 #e5e5e5 #bebebe;border-color:rgba(0,0,0,0.1) rgba(0,0,0,0.1) rgba(0,0,0,0.25);filter:progid:dximagetransform.microsoft.gradient(startColorstr='#fff9f9f9',endColorstr='#ffe5e5e5',GradientType=0)}.fuelux .datagrid tfoot{background-color:#f9f9f9}.fuelux .datagrid tfoot .datagrid-footer-left{float:left}.fuelux .datagrid tfoot .datagrid-footer-left .grid-controls{margin-top:7px}.fuelux .datagrid tfoot .datagrid-footer-left .grid-controls select{width:60px;margin:0 5px 1px}.fuelux .datagrid tfoot .datagrid-footer-left .grid-controls .grid-pagesize{display:inline-block;margin-bottom:5px;vertical-align:middle}.fuelux .datagrid tfoot .datagrid-footer-left .grid-controls .grid-pagesize .dropdown-menu{top:auto;left:auto}.fuelux .datagrid tfoot .datagrid-footer-left .grid-controls span{font-weight:normal}.fuelux .datagrid tfoot .datagrid-footer-right{float:right}.fuelux .datagrid tfoot .datagrid-footer-right .grid-pager>span{position:relative;top:8px;font-weight:normal}.fuelux .datagrid tfoot .datagrid-footer-right .grid-pager .dropdown-menu{min-width:50px}.fuelux .datagrid tfoot .datagrid-footer-right .grid-pager .combobox{position:relative;top:-2px;display:inline-block;margin-bottom:4px;vertical-align:baseline}.fuelux .datagrid tfoot .datagrid-footer-right .grid-pager>button{position:relative;top:7px}.fuelux .datagrid-stretch-header{margin-bottom:0;border-bottom:0;-webkit-border-bottom-right-radius:0;border-bottom-right-radius:0;-webkit-border-bottom-left-radius:0;border-bottom-left-radius:0;-moz-border-radius-bottomright:0;-moz-border-radius-bottomleft:0}.fuelux .datagrid-stretch-header thead:last-child tr:last-child>th:first-child,.fuelux .datagrid-stretch-header thead:last-child tr:last-child>th:last-child{-webkit-border-bottom-right-radius:0;border-bottom-right-radius:0;-webkit-border-bottom-left-radius:0;border-bottom-left-radius:0;-moz-border-radius-bottomright:0;-moz-border-radius-bottomleft:0}.fuelux .datagrid-stretch-wrapper{overflow:auto;border:1px solid #ddd}.fuelux .datagrid-stretch-wrapper .datagrid{margin-bottom:0;border:0;border-collapse:collapse;-webkit-border-radius:0;-moz-border-radius:0;border-radius:0}.fuelux .datagrid-stretch-wrapper .datagrid td,.fuelux .datagrid-stretch-wrapper .datagrid th{border-bottom:1px solid #ddd}.fuelux .datagrid-stretch-wrapper .datagrid td:first-child,.fuelux .datagrid-stretch-wrapper .datagrid th:first-child{border-left:none;-webkit-border-radius:0;-moz-border-radius:0;border-radius:0}.fuelux .datagrid-stretch-footer{border-top:0;-webkit-border-top-right-radius:0;border-top-right-radius:0;-webkit-border-top-left-radius:0;border-top-left-radius:0;-moz-border-radius-topright:0;-moz-border-radius-topleft:0}.fuelux .datagrid-stretch-footer th{border-top:0}.fuelux .pillbox{padding:3px}.fuelux .pillbox ul{display:inline-block;margin:0}.fuelux .pillbox li{display:inline-block;float:left;padding:1px 4px 2px;margin:2px;font-size:11.844px;font-weight:bold;line-height:21px;color:#fff;text-shadow:0 -1px 0 rgba(0,0,0,0.25);vertical-align:baseline;cursor:pointer;background-color:#999;-webkit-border-radius:3px;-moz-border-radius:3px;border-radius:3px}.fuelux .pillbox li:after{position:relative;top:-2px;float:right;padding-left:4px;font-size:20px;font-weight:bold;line-height:20px;color:#000;text-shadow:0 1px 0 #fff;content:" \00D7";opacity:.2;filter:alpha(opacity=20)}.fuelux .pillbox li:hover:after{opacity:.4;filter:alpha(opacity=40)}.fuelux .pillbox li.status-important{background-color:#b94a48}.fuelux .pillbox li.status-warning{background-color:#f89406}.fuelux .pillbox li.status-success{background-color:#468847}.fuelux .pillbox li.status-info{background-color:#3a87ad}.fuelux .radio-custom input[type=radio]{display:none}.fuelux .radio-custom i{width:16px;height:16px;padding-left:16px;margin-right:4px;margin-left:-20px;background-image:url(../img/form.png);background-position:0 -15px;background-repeat:no-repeat}.fuelux .radio-custom i.checked{background-position:-48px -15px}.fuelux .radio-custom i.disabled{background-position:-64px -15px}.fuelux .radio-custom i.disabled.checked{background-position:-80px -15px}.fuelux .radio-custom:hover i{background-position:-16px -15px}.fuelux .radio-custom:hover i.checked{background-position:-32px -15px}.fuelux .radio-custom:hover i.disabled{background-position:-64px -15px}.fuelux .radio-custom:hover i.disabled.checked{background-position:-80px -15px}.fuelux .spinner input{float:left;width:43px}.fuelux .spinner .btn{position:relative;width:20px;height:14px;padding-top:0;padding-right:9px;padding-left:9px}.fuelux .spinner .btn.disabled{cursor:not-allowed}.fuelux .spinner .spinner-buttons{position:relative;left:-22px;float:left;width:20px;height:28px}.fuelux .spinner .spinner-up{top:2px;padding:0 0 4px 1px}.fuelux .spinner .spinner-up i{position:relative;top:-4px}.fuelux .spinner .spinner-down{top:2px;height:13px;padding:0 0 4px 1px}.fuelux .spinner .spinner-down i{position:relative;top:-5px}.fuelux .search{display:inline-block}.fuelux .select .dropdown-label{display:inline-block;padding:0 10px 0 0;margin:0;font-weight:normal;color:#333;text-align:left}.fuelux #selectTextSize{position:absolute;top:0;display:inline-block;visibility:hidden}.fuelux .tree{position:relative;padding:10px 15px 0 15px;overflow-x:hidden;overflow-y:auto;border:1px solid #bbb;border-radius:4px 4px 4px 4px}.fuelux .tree .tree-folder{width:100%;min-height:20px;margin-top:1px;cursor:pointer}.fuelux .tree .tree-folder .tree-folder-header{position:relative;height:20px;-webkit-border-radius:6px;-moz-border-radius:6px;border-radius:6px}.fuelux .tree .tree-folder .tree-folder-header:hover{background-color:#dfeef5}.fuelux .tree .tree-folder .tree-folder-header i{position:absolute;top:1px;left:5px;float:left}.fuelux .tree .tree-folder .tree-folder-header .tree-folder-name{padding-left:29px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.fuelux .tree .tree-folder .tree-folder-content{margin-left:23px}.fuelux .tree .tree-item{position:relative;width:100%;height:20px;margin-top:1px;cursor:pointer;-webkit-border-radius:6px;-moz-border-radius:6px;border-radius:6px}.fuelux .tree .tree-item:hover{background-color:#dfeef5}.fuelux .tree .tree-item .tree-item-name{position:absolute;left:29px}.fuelux .tree .tree-item .tree-dot{position:absolute;top:8px;left:10px;display:block;width:4px;height:4px;background-color:#333;-webkit-border-radius:6px;-moz-border-radius:6px;border-radius:6px}.fuelux .tree .tree-item .icon-ok{position:absolute;top:1px;left:5px}.fuelux .tree .tree-selected{background-color:#b9dff1}.fuelux .tree .tree-selected:hover{background-color:#b9dff1}.fuelux .wizard{background-color:#f9f9f9;border:1px solid #d4d4d4;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px;*zoom:1;-webkit-box-shadow:0 1px 4px rgba(0,0,0,0.065);-moz-box-shadow:0 1px 4px rgba(0,0,0,0.065);box-shadow:0 1px 4px rgba(0,0,0,0.065)}.fuelux .wizard:before,.fuelux .wizard:after{display:table;line-height:0;content:""}.fuelux .wizard:after{clear:both}.fuelux .wizard ul{padding:0;margin:0;list-style:none outside none}.fuelux .wizard ul li{position:relative;float:left;height:46px;padding:0 20px 0 30px;margin:0;font-size:16px;line-height:46px;color:#999;cursor:default;background:#ededed}.fuelux .wizard ul li .chevron{position:absolute;top:0;right:-14px;display:block;border:24px solid transparent;border-right:0;border-left:14px solid #d4d4d4}.fuelux .wizard ul li .chevron:before{position:absolute;top:-24px;right:1px;display:block;border:24px solid transparent;border-right:0;border-left:14px solid #ededed;content:""}.fuelux .wizard ul li.complete{color:#468847;background:#f3f4f5}.fuelux .wizard ul li.complete:hover{cursor:pointer;background:#e7eff8}.fuelux .wizard ul li.complete:hover .chevron:before{border-left:14px solid #e7eff8}.fuelux .wizard ul li.complete .chevron:before{border-left:14px solid #f3f4f5}.fuelux .wizard ul li.active{color:#3a87ad;background:#f1f6fc}.fuelux .wizard ul li.active .chevron:before{border-left:14px solid #f1f6fc}.fuelux .wizard ul li .badge{margin-right:8px}.fuelux .wizard ul li:nth-child(1){z-index:10;padding-left:20px;border-radius:4px 0 0 4px}.fuelux .wizard ul li:nth-child(2){z-index:9}.fuelux .wizard ul li:nth-child(3){z-index:8}.fuelux .wizard ul li:nth-child(4){z-index:7}.fuelux .wizard ul li:nth-child(5){z-index:6}.fuelux .wizard ul li:nth-child(6){z-index:5}.fuelux .wizard ul li:nth-child(7){z-index:4}.fuelux .wizard ul li:nth-child(8){z-index:3}.fuelux .wizard ul li:nth-child(9){z-index:2}.fuelux .wizard ul li:nth-child(10){z-index:1}.fuelux .wizard .actions{float:right;padding-right:15px;line-height:44px;vertical-align:middle}.fuelux .wizard .actions a{margin-right:8px;font-size:12px;line-height:45px}.fuelux .wizard .actions .btn-prev i{margin-right:5px}.fuelux .wizard .actions .btn-next i{margin-left:5px}.fuelux .step-content .step-pane{display:none}.fuelux .step-content .active{display:block}.fuelux .step-content .active .btn-group .active{display:inline-block}
\ No newline at end of file
diff --git a/opendaylight/adsal/web/root/src/main/resources/css/login.less b/opendaylight/adsal/web/root/src/main/resources/css/login.less
deleted file mode 100644 (file)
index cdaba23..0000000
+++ /dev/null
@@ -1,53 +0,0 @@
-.reset {
-       padding: 0;
-       margin: 0;
-}
-
-html , body {
-       .reset;
-       height: 100%;
-       width: 100%;
-       background-color: #eee;
-}
-
-html {
-       display: table;
-}
-
-body {
-       display: table-cell;
-       vertical-align: middle;
-       padding-bottom: 10%;
-}
-
-.container {
-       width: 650px;
-       .content {
-               padding: 25px;
-               background-color: #fff;
-               -webkit-border-radius: 10px;
-               -moz-border-radius: 10px;
-               border-radius: 10px;
-               -webkit-box-shadow: 0 1px 2px rgba(0, 0, 0, .15);
-               -moz-box-shadow: 0 1px 2px rgba(0, 0, 0, .15);
-               box-shadow: 0 1px 2px rgba(0, 0, 0, .15);
-               text-align: center;
-               .login-form {
-                       #logo {
-                               background-repeat: no-repeat;
-                               background-position: center;
-                               background-image: url('');
-                               width: 400px;
-                               height: 175px;
-                               margin: 0 auto 20px;
-                       }
-                       .icon-login {
-                               width: 20px;
-                               height: 16px;
-                               background-position: left center;
-                               background-repeat: no-repeat;
-                               background-image: url('');
-                       }
-               }
-       }
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/web/root/src/main/resources/css/one.less b/opendaylight/adsal/web/root/src/main/resources/css/one.less
deleted file mode 100644 (file)
index e19733f..0000000
+++ /dev/null
@@ -1,292 +0,0 @@
-// properties
-@mainTop: 43px;
-@mainBottom: 41px;
-
-@minWidth: 640px;
-@minHeight: 480px;
-
-@topologyOffset: -4px; // ensure calibration
-
-@interface-admin-up: #46A040;
-@interface-admin-down: #C41230;
-@interface-edge-down: #F58025;
-
-// mixins
-.dash-size (@width, @height) {
-       width: @width;
-       height: @height;
-}
-.position (@type, @top, @right, @bottom, @left) {
-       position: @type;
-       top: @top;
-       right: @right;
-       bottom: @bottom;
-       left: @left;
-}
-.dash-position (@top, @right, @bottom, @left) {
-       .position(absolute, @top, @right, @bottom, @left);
-}
-.icon {
-       width: 22px;
-       height: 16px;
-       background-position: left center;
-       background-repeat: no-repeat;
-}
-.dashlet-elements {
-       width: 98%;
-       margin: 5px auto;
-}
-
-// header
-#menu {
-       .navbar-inner {
-               .brand {
-                       font-size: 1.4em;
-                       font-variant: small-caps;
-                       margin: 0 12px;
-                       padding: 10px 0 10px 45px;
-                       background-image: url('../img/logo.png');
-                       background-position: left center;
-                       background-repeat: no-repeat;
-               }
-               ul {
-                       margin-top: 10px;
-                       border-bottom: transparent;
-                       li {
-                               a {
-                                       padding: 5px 15px;
-                                       &:hover {
-                                               border-color: transparent;
-                                       }
-                               }
-                       }
-                       .active {
-                               a {
-                                       border-radius: 1px;
-                                       background: #f6f6f6;
-                                       &:hover {
-                                               border-top: 1px solid #ddd;
-                                               border-right: 1px solid #ddd;
-                                               border-left: 1px solid #ddd;
-                                       }
-                               }
-                       }
-               }
-               #toolbar {
-                       position: absolute;
-                       right: 10px;
-                       .dropdown-menu {
-                               right: 0;
-                               left: auto;
-                               min-width: 120px;
-                       }
-                       .icon-user {
-                               .icon;
-                               background-image: url('../img/user_0020_16.png');
-                       }
-                       .icon-users {
-                               .icon;
-                               background-image: url('../img/user_group_0107_16.png');
-                       }
-                       .icon-cluster {
-                               .icon;
-                               background-image: url('../img/topology_view_1033_16.png');
-                       }
-                       .icon-default {
-                               .icon;
-                               background-image: url('../img/logo_16.png');
-                       }
-                       .icon-save {
-                               .icon;
-                               background-image: url('../img/save_as_0106_16.png');
-                       }
-                       .icon-logout {
-                               .icon;
-                               background-image: url('../img/open_1054_16.png');
-                       }
-               }
-       }
-}
-
-// footer
-#footer {
-       #alert {
-               margin: 0;
-               p {
-                       padding: 0;
-                       margin: 0;
-               }
-       }
-}
-
-// main
-#main {
-       position: fixed;
-       top: @mainTop;
-       right: 0;
-       bottom: @mainBottom;
-       left: 0;
-       min-width: @minWidth;
-       min-height: @minHeight;
-
-       // topology
-       #topology {
-               position: absolute;
-               top: @topologyOffset;
-               right: 0;
-               bottom: @topologyOffset;
-               left: 0;
-               background: #ddd;
-       }
-
-       // left
-       #left {
-               .dash-size(30%, 100%);
-               float: left;
-
-               #left-top {
-                       .dash-size(100%, 60%);
-
-                       .dash { 
-                               .dash-position(5px, 5px, 5px, 5px);
-                       }
-               }
-
-               #left-bottom {
-                       .dash-size(100%, 40%);
-
-                       .dash {
-                               .dash-position(0, 5px, 5px, 5px);
-                       }
-               }
-       }
-
-       // right
-       #right {
-               .dash-size(70%, 100%);
-               float: right;
-
-               #right-top {
-                       .dash-size(100%, 60%);
-
-                       .dash {
-                               .dash-position(5px, 5px, 5px, 0);
-                       }
-               }
-
-               #right-bottom {
-                       .dash-size(100%, 40%);
-
-                       .dash {
-                               .dash-position(0, 5px, 5px, 0);
-                       }
-               }
-       }
-
-       #left-top, #left-bottom,
-       #right-top, #right-bottom {
-               position: relative;
-       }
-
-       // dashentries
-       .dash {
-               border-radius: 1px;
-               background: #fff;
-               border: 1px solid #ddd;
-
-               .nav {
-                       padding: 2px;
-                       padding-bottom: 0;
-                       margin: 0;
-               }
-
-               .nav-tabs {
-                       background: #eee;
-                       li {
-                               a {
-                                       background: #ddd;
-                                       padding: 4px 8px;
-                                       margin-right: 3px;
-                                       border-radius: 1px;
-                                       &:hover {
-                                               border-color: transparent;
-                                       }
-                               }
-                       }
-                       .active {
-                               a {
-                                       background: #fff;
-                                       border-radius: 1px;
-                                       &:hover {
-                                               border-top: 1px solid #ddd;
-                                               border-left: 1px solid #ddd;
-                                               border-right: 1px solid #ddd;
-                                       }
-                               }
-                       }
-               }
-
-               .dashlet {
-                       overflow: auto;
-                       .dash-position(45px,0,0,0);
-
-                       h4 {
-                               .dashlet-elements;
-                       }
-
-                       p {
-                               .dashlet-elements;
-                       }
-
-                       table {
-                               .dashlet-elements;
-                       }
-                       
-                       .btn-group {
-                               margin: 5px;
-                       }
-                       
-                       .none {
-                               margin: 0 auto;
-                               padding-top: 128px;
-                               background-position: center;
-                               background-repeat: no-repeat;
-                               background-image: url('../img/alert_unreachable_2008_128.png');
-                               text-align: center;
-                               p {
-                                       cursor: default;
-                               }
-                       }
-               }
-       }
-
-       // defaults for visual topology
-       #right-top .dash {
-               background: #ddd;
-               overflow: hidden;
-       }
-}
-
-.table-cursor tr:hover {
-       cursor: pointer;
-}
-
-// interfaces
-table {
-       .admin-up {
-               color: @interface-admin-up;
-       }
-       .admin-down {
-               color: @interface-admin-down;
-       }
-       .edge-down {
-               color: @interface-edge-down;
-       }
-}
-
-// hide
-.modal {
-       .help {
-               display: none;
-       }
-}
diff --git a/opendaylight/adsal/web/root/src/main/resources/css/opendaylight.css b/opendaylight/adsal/web/root/src/main/resources/css/opendaylight.css
deleted file mode 100644 (file)
index 296bdf7..0000000
+++ /dev/null
@@ -1,93 +0,0 @@
-.fuelux [class^="icon-"],
-.fuelux [class*=" icon-"] {
-  display: inline-block;
-  width: 14px;
-  height: 14px;
-  margin-top: 1px;
-  *margin-right: .3em;
-  line-height: 14px;
-  vertical-align: text-top;
-  background-position: 14px 14px;
-  background-repeat: no-repeat;
-}
-
-.fuelux .icon-white,
-.fuelux .nav-pills > .active > a > [class^="icon-"],
-.fuelux .nav-pills > .active > a > [class*=" icon-"],
-.fuelux .nav-list > .active > a > [class^="icon-"],
-.fuelux .nav-list > .active > a > [class*=" icon-"],
-.fuelux .navbar-inverse .nav > .active > a > [class^="icon-"],
-.fuelux .navbar-inverse .nav > .active > a > [class*=" icon-"],
-.fuelux .dropdown-menu > li > a:hover > [class^="icon-"],
-.fuelux .dropdown-menu > li > a:focus > [class^="icon-"],
-.fuelux .dropdown-menu > li > a:hover > [class*=" icon-"],
-.fuelux .dropdown-menu > li > a:focus > [class*=" icon-"],
-.fuelux .dropdown-menu > .active > a > [class^="icon-"],
-.fuelux .dropdown-menu > .active > a > [class*=" icon-"],
-.fuelux .dropdown-submenu:hover > a > [class^="icon-"],
-.fuelux .dropdown-submenu:focus > a > [class^="icon-"],
-.fuelux .dropdown-submenu:hover > a > [class*=" icon-"],
-.fuelux .dropdown-submenu:focus > a > [class*=" icon-"] {
-}
-
-.fuelux .icon-search {
-  background:url('../img/search.png') 0 0 no-repeat;
-  height: 16px;
-  line-height: 16px;
-  width: 16px;
-}
-.fuelux .icon-remove {
-  background:url('../img/searchremove.png') 0 0 no-repeat;
-  height: 16px;
-  line-height: 16px;
-  width: 16px;
-}
-
-.fuelux .icon-chevron-up {
-  background:url('../img/sort_up.png') 0 0 no-repeat;
-  height: 16px;
-  line-height: 16px;
-  width: 16px;
-}
-
-.fuelux .icon-chevron-down {
-  background:url('../img/sort_down.png') 0 0 no-repeat;
-  height: 16px;
-  line-height: 16px;
-  width: 16px;
-}
-
-.fuelux .icon-chevron-left {
-  background:url('../img/nextpageleft.png') 0 0 no-repeat;
-  height: 16px;
-  line-height: 16px;
-  width: 16px;
-}
-
-.fuelux .icon-chevron-right {
-  background:url('../img/nextpageright.png') 0 0 no-repeat;
-  height: 16px;
-  line-height: 16px;
-  width: 16px;
-}
-
-.fuelux .icon-chevron-right {
-  background:url('../img/nextpageright.png') 0 0 no-repeat;
-  height: 16px;
-  line-height: 16px;
-  width: 16px;
-}
-
-.tip {
-   background-color: white;
-   border: 1px solid #CCCCCC;
-   box-shadow: 2px 2px 8px #555555;
-   color: #111111;
-   font-family: Verdana,Geneva,Arial,Helvetica,sans-serif;
-   font-size: 14px;
-   opacity: 0.9;
-   padding: 7px;
-   width: 260px;
-   border-radius: 8px;
-}
-
diff --git a/opendaylight/adsal/web/root/src/main/resources/img/Device_pc_3045_default_64.png b/opendaylight/adsal/web/root/src/main/resources/img/Device_pc_3045_default_64.png
deleted file mode 100644 (file)
index cd4fff6..0000000
Binary files a/opendaylight/adsal/web/root/src/main/resources/img/Device_pc_3045_default_64.png and /dev/null differ
diff --git a/opendaylight/adsal/web/root/src/main/resources/img/Device_switch_3062_unknown_64.png b/opendaylight/adsal/web/root/src/main/resources/img/Device_switch_3062_unknown_64.png
deleted file mode 100644 (file)
index c55127d..0000000
Binary files a/opendaylight/adsal/web/root/src/main/resources/img/Device_switch_3062_unknown_64.png and /dev/null differ
diff --git a/opendaylight/adsal/web/root/src/main/resources/img/Expand16T.png b/opendaylight/adsal/web/root/src/main/resources/img/Expand16T.png
deleted file mode 100644 (file)
index 489a4d6..0000000
Binary files a/opendaylight/adsal/web/root/src/main/resources/img/Expand16T.png and /dev/null differ
diff --git a/opendaylight/adsal/web/root/src/main/resources/img/Key_0024_16.png b/opendaylight/adsal/web/root/src/main/resources/img/Key_0024_16.png
deleted file mode 100644 (file)
index 1faeb82..0000000
Binary files a/opendaylight/adsal/web/root/src/main/resources/img/Key_0024_16.png and /dev/null differ
diff --git a/opendaylight/adsal/web/root/src/main/resources/img/alert_unreachable_2008_128.png b/opendaylight/adsal/web/root/src/main/resources/img/alert_unreachable_2008_128.png
deleted file mode 100644 (file)
index cb0e446..0000000
Binary files a/opendaylight/adsal/web/root/src/main/resources/img/alert_unreachable_2008_128.png and /dev/null differ
diff --git a/opendaylight/adsal/web/root/src/main/resources/img/form.png b/opendaylight/adsal/web/root/src/main/resources/img/form.png
deleted file mode 100755 (executable)
index ce846da..0000000
Binary files a/opendaylight/adsal/web/root/src/main/resources/img/form.png and /dev/null differ
diff --git a/opendaylight/adsal/web/root/src/main/resources/img/logo.png b/opendaylight/adsal/web/root/src/main/resources/img/logo.png
deleted file mode 100644 (file)
index 46c02e2..0000000
Binary files a/opendaylight/adsal/web/root/src/main/resources/img/logo.png and /dev/null differ
diff --git a/opendaylight/adsal/web/root/src/main/resources/img/logo_16.png b/opendaylight/adsal/web/root/src/main/resources/img/logo_16.png
deleted file mode 100644 (file)
index e9833ac..0000000
Binary files a/opendaylight/adsal/web/root/src/main/resources/img/logo_16.png and /dev/null differ
diff --git a/opendaylight/adsal/web/root/src/main/resources/img/nextpageleft.png b/opendaylight/adsal/web/root/src/main/resources/img/nextpageleft.png
deleted file mode 100644 (file)
index 62126b1..0000000
Binary files a/opendaylight/adsal/web/root/src/main/resources/img/nextpageleft.png and /dev/null differ
diff --git a/opendaylight/adsal/web/root/src/main/resources/img/nextpageright.png b/opendaylight/adsal/web/root/src/main/resources/img/nextpageright.png
deleted file mode 100644 (file)
index 2a71a14..0000000
Binary files a/opendaylight/adsal/web/root/src/main/resources/img/nextpageright.png and /dev/null differ
diff --git a/opendaylight/adsal/web/root/src/main/resources/img/open_1054_16.png b/opendaylight/adsal/web/root/src/main/resources/img/open_1054_16.png
deleted file mode 100644 (file)
index 62ee475..0000000
Binary files a/opendaylight/adsal/web/root/src/main/resources/img/open_1054_16.png and /dev/null differ
diff --git a/opendaylight/adsal/web/root/src/main/resources/img/open_1054_24.png b/opendaylight/adsal/web/root/src/main/resources/img/open_1054_24.png
deleted file mode 100644 (file)
index 055cc3c..0000000
Binary files a/opendaylight/adsal/web/root/src/main/resources/img/open_1054_24.png and /dev/null differ
diff --git a/opendaylight/adsal/web/root/src/main/resources/img/save_as_0106_16.png b/opendaylight/adsal/web/root/src/main/resources/img/save_as_0106_16.png
deleted file mode 100644 (file)
index 9316622..0000000
Binary files a/opendaylight/adsal/web/root/src/main/resources/img/save_as_0106_16.png and /dev/null differ
diff --git a/opendaylight/adsal/web/root/src/main/resources/img/save_as_0106_24.png b/opendaylight/adsal/web/root/src/main/resources/img/save_as_0106_24.png
deleted file mode 100644 (file)
index 1afce22..0000000
Binary files a/opendaylight/adsal/web/root/src/main/resources/img/save_as_0106_24.png and /dev/null differ
diff --git a/opendaylight/adsal/web/root/src/main/resources/img/search.png b/opendaylight/adsal/web/root/src/main/resources/img/search.png
deleted file mode 100644 (file)
index b8742d2..0000000
Binary files a/opendaylight/adsal/web/root/src/main/resources/img/search.png and /dev/null differ
diff --git a/opendaylight/adsal/web/root/src/main/resources/img/searchremove.png b/opendaylight/adsal/web/root/src/main/resources/img/searchremove.png
deleted file mode 100644 (file)
index 3809f51..0000000
Binary files a/opendaylight/adsal/web/root/src/main/resources/img/searchremove.png and /dev/null differ
diff --git a/opendaylight/adsal/web/root/src/main/resources/img/sort_down.png b/opendaylight/adsal/web/root/src/main/resources/img/sort_down.png
deleted file mode 100644 (file)
index 708e44e..0000000
Binary files a/opendaylight/adsal/web/root/src/main/resources/img/sort_down.png and /dev/null differ
diff --git a/opendaylight/adsal/web/root/src/main/resources/img/sort_up.png b/opendaylight/adsal/web/root/src/main/resources/img/sort_up.png
deleted file mode 100644 (file)
index 0b5c041..0000000
Binary files a/opendaylight/adsal/web/root/src/main/resources/img/sort_up.png and /dev/null differ
diff --git a/opendaylight/adsal/web/root/src/main/resources/img/topology_view_1033_128.png b/opendaylight/adsal/web/root/src/main/resources/img/topology_view_1033_128.png
deleted file mode 100644 (file)
index de0d641..0000000
Binary files a/opendaylight/adsal/web/root/src/main/resources/img/topology_view_1033_128.png and /dev/null differ
diff --git a/opendaylight/adsal/web/root/src/main/resources/img/topology_view_1033_16.png b/opendaylight/adsal/web/root/src/main/resources/img/topology_view_1033_16.png
deleted file mode 100644 (file)
index 1a13254..0000000
Binary files a/opendaylight/adsal/web/root/src/main/resources/img/topology_view_1033_16.png and /dev/null differ
diff --git a/opendaylight/adsal/web/root/src/main/resources/img/user_0020_16.png b/opendaylight/adsal/web/root/src/main/resources/img/user_0020_16.png
deleted file mode 100644 (file)
index 1ed7a09..0000000
Binary files a/opendaylight/adsal/web/root/src/main/resources/img/user_0020_16.png and /dev/null differ
diff --git a/opendaylight/adsal/web/root/src/main/resources/img/user_0020_24.png b/opendaylight/adsal/web/root/src/main/resources/img/user_0020_24.png
deleted file mode 100644 (file)
index b8c3715..0000000
Binary files a/opendaylight/adsal/web/root/src/main/resources/img/user_0020_24.png and /dev/null differ
diff --git a/opendaylight/adsal/web/root/src/main/resources/img/user_group_0107_16.png b/opendaylight/adsal/web/root/src/main/resources/img/user_group_0107_16.png
deleted file mode 100644 (file)
index a0e017b..0000000
Binary files a/opendaylight/adsal/web/root/src/main/resources/img/user_group_0107_16.png and /dev/null differ
diff --git a/opendaylight/adsal/web/root/src/main/resources/img/user_group_0107_24.png b/opendaylight/adsal/web/root/src/main/resources/img/user_group_0107_24.png
deleted file mode 100644 (file)
index 427a871..0000000
Binary files a/opendaylight/adsal/web/root/src/main/resources/img/user_group_0107_24.png and /dev/null differ
diff --git a/opendaylight/adsal/web/root/src/main/resources/js/bootstrap.min.js b/opendaylight/adsal/web/root/src/main/resources/js/bootstrap.min.js
deleted file mode 100644 (file)
index 95c5ac5..0000000
+++ /dev/null
@@ -1,6 +0,0 @@
-/*!
-* Bootstrap.js by @fat & @mdo
-* Copyright 2012 Twitter, Inc.
-* http://www.apache.org/licenses/LICENSE-2.0.txt
-*/
-!function(e){"use strict";e(function(){e.support.transition=function(){var e=function(){var e=document.createElement("bootstrap"),t={WebkitTransition:"webkitTransitionEnd",MozTransition:"transitionend",OTransition:"oTransitionEnd otransitionend",transition:"transitionend"},n;for(n in t)if(e.style[n]!==undefined)return t[n]}();return e&&{end:e}}()})}(window.jQuery),!function(e){"use strict";var t='[data-dismiss="alert"]',n=function(n){e(n).on("click",t,this.close)};n.prototype.close=function(t){function s(){i.trigger("closed").remove()}var n=e(this),r=n.attr("data-target"),i;r||(r=n.attr("href"),r=r&&r.replace(/.*(?=#[^\s]*$)/,"")),i=e(r),t&&t.preventDefault(),i.length||(i=n.hasClass("alert")?n:n.parent()),i.trigger(t=e.Event("close"));if(t.isDefaultPrevented())return;i.removeClass("in"),e.support.transition&&i.hasClass("fade")?i.on(e.support.transition.end,s):s()};var r=e.fn.alert;e.fn.alert=function(t){return this.each(function(){var r=e(this),i=r.data("alert");i||r.data("alert",i=new n(this)),typeof t=="string"&&i[t].call(r)})},e.fn.alert.Constructor=n,e.fn.alert.noConflict=function(){return e.fn.alert=r,this},e(document).on("click.alert.data-api",t,n.prototype.close)}(window.jQuery),!function(e){"use strict";var t=function(t,n){this.$element=e(t),this.options=e.extend({},e.fn.button.defaults,n)};t.prototype.setState=function(e){var t="disabled",n=this.$element,r=n.data(),i=n.is("input")?"val":"html";e+="Text",r.resetText||n.data("resetText",n[i]()),n[i](r[e]||this.options[e]),setTimeout(function(){e=="loadingText"?n.addClass(t).attr(t,t):n.removeClass(t).removeAttr(t)},0)},t.prototype.toggle=function(){var e=this.$element.closest('[data-toggle="buttons-radio"]');e&&e.find(".active").removeClass("active"),this.$element.toggleClass("active")};var n=e.fn.button;e.fn.button=function(n){return this.each(function(){var r=e(this),i=r.data("button"),s=typeof n=="object"&&n;i||r.data("button",i=new t(this,s)),n=="toggle"?i.toggle():n&&i.setState(n)})},e.fn.button.defaults={loadingText:"loading..."},e.fn.button.Constructor=t,e.fn.button.noConflict=function(){return e.fn.button=n,this},e(document).on("click.button.data-api","[data-toggle^=button]",function(t){var n=e(t.target);n.hasClass("btn")||(n=n.closest(".btn")),n.button("toggle")})}(window.jQuery),!function(e){"use strict";var t=function(t,n){this.$element=e(t),this.$indicators=this.$element.find(".carousel-indicators"),this.options=n,this.options.pause=="hover"&&this.$element.on("mouseenter",e.proxy(this.pause,this)).on("mouseleave",e.proxy(this.cycle,this))};t.prototype={cycle:function(t){return t||(this.paused=!1),this.interval&&clearInterval(this.interval),this.options.interval&&!this.paused&&(this.interval=setInterval(e.proxy(this.next,this),this.options.interval)),this},getActiveIndex:function(){return this.$active=this.$element.find(".item.active"),this.$items=this.$active.parent().children(),this.$items.index(this.$active)},to:function(t){var n=this.getActiveIndex(),r=this;if(t>this.$items.length-1||t<0)return;return this.sliding?this.$element.one("slid",function(){r.to(t)}):n==t?this.pause().cycle():this.slide(t>n?"next":"prev",e(this.$items[t]))},pause:function(t){return t||(this.paused=!0),this.$element.find(".next, .prev").length&&e.support.transition.end&&(this.$element.trigger(e.support.transition.end),this.cycle(!0)),clearInterval(this.interval),this.interval=null,this},next:function(){if(this.sliding)return;return this.slide("next")},prev:function(){if(this.sliding)return;return this.slide("prev")},slide:function(t,n){var r=this.$element.find(".item.active"),i=n||r[t](),s=this.interval,o=t=="next"?"left":"right",u=t=="next"?"first":"last",a=this,f;this.sliding=!0,s&&this.pause(),i=i.length?i:this.$element.find(".item")[u](),f=e.Event("slide",{relatedTarget:i[0],direction:o});if(i.hasClass("active"))return;this.$indicators.length&&(this.$indicators.find(".active").removeClass("active"),this.$element.one("slid",function(){var t=e(a.$indicators.children()[a.getActiveIndex()]);t&&t.addClass("active")}));if(e.support.transition&&this.$element.hasClass("slide")){this.$element.trigger(f);if(f.isDefaultPrevented())return;i.addClass(t),i[0].offsetWidth,r.addClass(o),i.addClass(o),this.$element.one(e.support.transition.end,function(){i.removeClass([t,o].join(" ")).addClass("active"),r.removeClass(["active",o].join(" ")),a.sliding=!1,setTimeout(function(){a.$element.trigger("slid")},0)})}else{this.$element.trigger(f);if(f.isDefaultPrevented())return;r.removeClass("active"),i.addClass("active"),this.sliding=!1,this.$element.trigger("slid")}return s&&this.cycle(),this}};var n=e.fn.carousel;e.fn.carousel=function(n){return this.each(function(){var r=e(this),i=r.data("carousel"),s=e.extend({},e.fn.carousel.defaults,typeof n=="object"&&n),o=typeof n=="string"?n:s.slide;i||r.data("carousel",i=new t(this,s)),typeof n=="number"?i.to(n):o?i[o]():s.interval&&i.pause().cycle()})},e.fn.carousel.defaults={interval:5e3,pause:"hover"},e.fn.carousel.Constructor=t,e.fn.carousel.noConflict=function(){return e.fn.carousel=n,this},e(document).on("click.carousel.data-api","[data-slide], [data-slide-to]",function(t){var n=e(this),r,i=e(n.attr("data-target")||(r=n.attr("href"))&&r.replace(/.*(?=#[^\s]+$)/,"")),s=e.extend({},i.data(),n.data()),o;i.carousel(s),(o=n.attr("data-slide-to"))&&i.data("carousel").pause().to(o).cycle(),t.preventDefault()})}(window.jQuery),!function(e){"use strict";var t=function(t,n){this.$element=e(t),this.options=e.extend({},e.fn.collapse.defaults,n),this.options.parent&&(this.$parent=e(this.options.parent)),this.options.toggle&&this.toggle()};t.prototype={constructor:t,dimension:function(){var e=this.$element.hasClass("width");return e?"width":"height"},show:function(){var t,n,r,i;if(this.transitioning||this.$element.hasClass("in"))return;t=this.dimension(),n=e.camelCase(["scroll",t].join("-")),r=this.$parent&&this.$parent.find("> .accordion-group > .in");if(r&&r.length){i=r.data("collapse");if(i&&i.transitioning)return;r.collapse("hide"),i||r.data("collapse",null)}this.$element[t](0),this.transition("addClass",e.Event("show"),"shown"),e.support.transition&&this.$element[t](this.$element[0][n])},hide:function(){var t;if(this.transitioning||!this.$element.hasClass("in"))return;t=this.dimension(),this.reset(this.$element[t]()),this.transition("removeClass",e.Event("hide"),"hidden"),this.$element[t](0)},reset:function(e){var t=this.dimension();return this.$element.removeClass("collapse")[t](e||"auto")[0].offsetWidth,this.$element[e!==null?"addClass":"removeClass"]("collapse"),this},transition:function(t,n,r){var i=this,s=function(){n.type=="show"&&i.reset(),i.transitioning=0,i.$element.trigger(r)};this.$element.trigger(n);if(n.isDefaultPrevented())return;this.transitioning=1,this.$element[t]("in"),e.support.transition&&this.$element.hasClass("collapse")?this.$element.one(e.support.transition.end,s):s()},toggle:function(){this[this.$element.hasClass("in")?"hide":"show"]()}};var n=e.fn.collapse;e.fn.collapse=function(n){return this.each(function(){var r=e(this),i=r.data("collapse"),s=e.extend({},e.fn.collapse.defaults,r.data(),typeof n=="object"&&n);i||r.data("collapse",i=new t(this,s)),typeof n=="string"&&i[n]()})},e.fn.collapse.defaults={toggle:!0},e.fn.collapse.Constructor=t,e.fn.collapse.noConflict=function(){return e.fn.collapse=n,this},e(document).on("click.collapse.data-api","[data-toggle=collapse]",function(t){var n=e(this),r,i=n.attr("data-target")||t.preventDefault()||(r=n.attr("href"))&&r.replace(/.*(?=#[^\s]+$)/,""),s=e(i).data("collapse")?"toggle":n.data();n[e(i).hasClass("in")?"addClass":"removeClass"]("collapsed"),e(i).collapse(s)})}(window.jQuery),!function(e){"use strict";function r(){e(t).each(function(){i(e(this)).removeClass("open")})}function i(t){var n=t.attr("data-target"),r;n||(n=t.attr("href"),n=n&&/#/.test(n)&&n.replace(/.*(?=#[^\s]*$)/,"")),r=n&&e(n);if(!r||!r.length)r=t.parent();return r}var t="[data-toggle=dropdown]",n=function(t){var n=e(t).on("click.dropdown.data-api",this.toggle);e("html").on("click.dropdown.data-api",function(){n.parent().removeClass("open")})};n.prototype={constructor:n,toggle:function(t){var n=e(this),s,o;if(n.is(".disabled, :disabled"))return;return s=i(n),o=s.hasClass("open"),r(),o||s.toggleClass("open"),n.focus(),!1},keydown:function(n){var r,s,o,u,a,f;if(!/(38|40|27)/.test(n.keyCode))return;r=e(this),n.preventDefault(),n.stopPropagation();if(r.is(".disabled, :disabled"))return;u=i(r),a=u.hasClass("open");if(!a||a&&n.keyCode==27)return n.which==27&&u.find(t).focus(),r.click();s=e("[role=menu] li:not(.divider):visible a",u);if(!s.length)return;f=s.index(s.filter(":focus")),n.keyCode==38&&f>0&&f--,n.keyCode==40&&f<s.length-1&&f++,~f||(f=0),s.eq(f).focus()}};var s=e.fn.dropdown;e.fn.dropdown=function(t){return this.each(function(){var r=e(this),i=r.data("dropdown");i||r.data("dropdown",i=new n(this)),typeof t=="string"&&i[t].call(r)})},e.fn.dropdown.Constructor=n,e.fn.dropdown.noConflict=function(){return e.fn.dropdown=s,this},e(document).on("click.dropdown.data-api",r).on("click.dropdown.data-api",".dropdown form",function(e){e.stopPropagation()}).on("click.dropdown-menu",function(e){e.stopPropagation()}).on("click.dropdown.data-api",t,n.prototype.toggle).on("keydown.dropdown.data-api",t+", [role=menu]",n.prototype.keydown)}(window.jQuery),!function(e){"use strict";var t=function(t,n){this.options=n,this.$element=e(t).delegate('[data-dismiss="modal"]',"click.dismiss.modal",e.proxy(this.hide,this)),this.options.remote&&this.$element.find(".modal-body").load(this.options.remote)};t.prototype={constructor:t,toggle:function(){return this[this.isShown?"hide":"show"]()},show:function(){var t=this,n=e.Event("show");this.$element.trigger(n);if(this.isShown||n.isDefaultPrevented())return;this.isShown=!0,this.escape(),this.backdrop(function(){var n=e.support.transition&&t.$element.hasClass("fade");t.$element.parent().length||t.$element.appendTo(document.body),t.$element.show(),n&&t.$element[0].offsetWidth,t.$element.addClass("in").attr("aria-hidden",!1),t.enforceFocus(),n?t.$element.one(e.support.transition.end,function(){t.$element.focus().trigger("shown")}):t.$element.focus().trigger("shown")})},hide:function(t){t&&t.preventDefault();var n=this;t=e.Event("hide"),this.$element.trigger(t);if(!this.isShown||t.isDefaultPrevented())return;this.isShown=!1,this.escape(),e(document).off("focusin.modal"),this.$element.removeClass("in").attr("aria-hidden",!0),e.support.transition&&this.$element.hasClass("fade")?this.hideWithTransition():this.hideModal()},enforceFocus:function(){var t=this;e(document).on("focusin.modal",function(e){t.$element[0]!==e.target&&!t.$element.has(e.target).length&&t.$element.focus()})},escape:function(){var e=this;this.isShown&&this.options.keyboard?this.$element.on("keyup.dismiss.modal",function(t){t.which==27&&e.hide()}):this.isShown||this.$element.off("keyup.dismiss.modal")},hideWithTransition:function(){var t=this,n=setTimeout(function(){t.$element.off(e.support.transition.end),t.hideModal()},500);this.$element.one(e.support.transition.end,function(){clearTimeout(n),t.hideModal()})},hideModal:function(){var e=this;this.$element.hide(),this.backdrop(function(){e.removeBackdrop(),e.$element.trigger("hidden")})},removeBackdrop:function(){this.$backdrop&&this.$backdrop.remove(),this.$backdrop=null},backdrop:function(t){var n=this,r=this.$element.hasClass("fade")?"fade":"";if(this.isShown&&this.options.backdrop){var i=e.support.transition&&r;this.$backdrop=e('<div class="modal-backdrop '+r+'" />').appendTo(document.body),this.$backdrop.click(this.options.backdrop=="static"?e.proxy(this.$element[0].focus,this.$element[0]):e.proxy(this.hide,this)),i&&this.$backdrop[0].offsetWidth,this.$backdrop.addClass("in");if(!t)return;i?this.$backdrop.one(e.support.transition.end,t):t()}else!this.isShown&&this.$backdrop?(this.$backdrop.removeClass("in"),e.support.transition&&this.$element.hasClass("fade")?this.$backdrop.one(e.support.transition.end,t):t()):t&&t()}};var n=e.fn.modal;e.fn.modal=function(n){return this.each(function(){var r=e(this),i=r.data("modal"),s=e.extend({},e.fn.modal.defaults,r.data(),typeof n=="object"&&n);i||r.data("modal",i=new t(this,s)),typeof n=="string"?i[n]():s.show&&i.show()})},e.fn.modal.defaults={backdrop:!0,keyboard:!0,show:!0},e.fn.modal.Constructor=t,e.fn.modal.noConflict=function(){return e.fn.modal=n,this},e(document).on("click.modal.data-api",'[data-toggle="modal"]',function(t){var n=e(this),r=n.attr("href"),i=e(n.attr("data-target")||r&&r.replace(/.*(?=#[^\s]+$)/,"")),s=i.data("modal")?"toggle":e.extend({remote:!/#/.test(r)&&r},i.data(),n.data());t.preventDefault(),i.modal(s).one("hide",function(){n.focus()})})}(window.jQuery),!function(e){"use strict";var t=function(e,t){this.init("tooltip",e,t)};t.prototype={constructor:t,init:function(t,n,r){var i,s,o,u,a;this.type=t,this.$element=e(n),this.options=this.getOptions(r),this.enabled=!0,o=this.options.trigger.split(" ");for(a=o.length;a--;)u=o[a],u=="click"?this.$element.on("click."+this.type,this.options.selector,e.proxy(this.toggle,this)):u!="manual"&&(i=u=="hover"?"mouseenter":"focus",s=u=="hover"?"mouseleave":"blur",this.$element.on(i+"."+this.type,this.options.selector,e.proxy(this.enter,this)),this.$element.on(s+"."+this.type,this.options.selector,e.proxy(this.leave,this)));this.options.selector?this._options=e.extend({},this.options,{trigger:"manual",selector:""}):this.fixTitle()},getOptions:function(t){return t=e.extend({},e.fn[this.type].defaults,this.$element.data(),t),t.delay&&typeof t.delay=="number"&&(t.delay={show:t.delay,hide:t.delay}),t},enter:function(t){var n=e.fn[this.type].defaults,r={},i;this._options&&e.each(this._options,function(e,t){n[e]!=t&&(r[e]=t)},this),i=e(t.currentTarget)[this.type](r).data(this.type);if(!i.options.delay||!i.options.delay.show)return i.show();clearTimeout(this.timeout),i.hoverState="in",this.timeout=setTimeout(function(){i.hoverState=="in"&&i.show()},i.options.delay.show)},leave:function(t){var n=e(t.currentTarget)[this.type](this._options).data(this.type);this.timeout&&clearTimeout(this.timeout);if(!n.options.delay||!n.options.delay.hide)return n.hide();n.hoverState="out",this.timeout=setTimeout(function(){n.hoverState=="out"&&n.hide()},n.options.delay.hide)},show:function(){var t,n,r,i,s,o,u=e.Event("show");if(this.hasContent()&&this.enabled){this.$element.trigger(u);if(u.isDefaultPrevented())return;t=this.tip(),this.setContent(),this.options.animation&&t.addClass("fade"),s=typeof this.options.placement=="function"?this.options.placement.call(this,t[0],this.$element[0]):this.options.placement,t.detach().css({top:0,left:0,display:"block"}),this.options.container?t.appendTo(this.options.container):t.insertAfter(this.$element),n=this.getPosition(),r=t[0].offsetWidth,i=t[0].offsetHeight;switch(s){case"bottom":o={top:n.top+n.height,left:n.left+n.width/2-r/2};break;case"top":o={top:n.top-i,left:n.left+n.width/2-r/2};break;case"left":o={top:n.top+n.height/2-i/2,left:n.left-r};break;case"right":o={top:n.top+n.height/2-i/2,left:n.left+n.width}}this.applyPlacement(o,s),this.$element.trigger("shown")}},applyPlacement:function(e,t){var n=this.tip(),r=n[0].offsetWidth,i=n[0].offsetHeight,s,o,u,a;n.offset(e).addClass(t).addClass("in"),s=n[0].offsetWidth,o=n[0].offsetHeight,t=="top"&&o!=i&&(e.top=e.top+i-o,a=!0),t=="bottom"||t=="top"?(u=0,e.left<0&&(u=e.left*-2,e.left=0,n.offset(e),s=n[0].offsetWidth,o=n[0].offsetHeight),this.replaceArrow(u-r+s,s,"left")):this.replaceArrow(o-i,o,"top"),a&&n.offset(e)},replaceArrow:function(e,t,n){this.arrow().css(n,e?50*(1-e/t)+"%":"")},setContent:function(){var e=this.tip(),t=this.getTitle();e.find(".tooltip-inner")[this.options.html?"html":"text"](t),e.removeClass("fade in top bottom left right")},hide:function(){function i(){var t=setTimeout(function(){n.off(e.support.transition.end).detach()},500);n.one(e.support.transition.end,function(){clearTimeout(t),n.detach()})}var t=this,n=this.tip(),r=e.Event("hide");this.$element.trigger(r);if(r.isDefaultPrevented())return;return n.removeClass("in"),e.support.transition&&this.$tip.hasClass("fade")?i():n.detach(),this.$element.trigger("hidden"),this},fixTitle:function(){var e=this.$element;(e.attr("title")||typeof e.attr("data-original-title")!="string")&&e.attr("data-original-title",e.attr("title")||"").attr("title","")},hasContent:function(){return this.getTitle()},getPosition:function(){var t=this.$element[0];return e.extend({},typeof t.getBoundingClientRect=="function"?t.getBoundingClientRect():{width:t.offsetWidth,height:t.offsetHeight},this.$element.offset())},getTitle:function(){var e,t=this.$element,n=this.options;return e=t.attr("data-original-title")||(typeof n.title=="function"?n.title.call(t[0]):n.title),e},tip:function(){return this.$tip=this.$tip||e(this.options.template)},arrow:function(){return this.$arrow=this.$arrow||this.tip().find(".tooltip-arrow")},validate:function(){this.$element[0].parentNode||(this.hide(),this.$element=null,this.options=null)},enable:function(){this.enabled=!0},disable:function(){this.enabled=!1},toggleEnabled:function(){this.enabled=!this.enabled},toggle:function(t){var n=t?e(t.currentTarget)[this.type](this._options).data(this.type):this;n.tip().hasClass("in")?n.hide():n.show()},destroy:function(){this.hide().$element.off("."+this.type).removeData(this.type)}};var n=e.fn.tooltip;e.fn.tooltip=function(n){return this.each(function(){var r=e(this),i=r.data("tooltip"),s=typeof n=="object"&&n;i||r.data("tooltip",i=new t(this,s)),typeof n=="string"&&i[n]()})},e.fn.tooltip.Constructor=t,e.fn.tooltip.defaults={animation:!0,placement:"top",selector:!1,template:'<div class="tooltip"><div class="tooltip-arrow"></div><div class="tooltip-inner"></div></div>',trigger:"hover focus",title:"",delay:0,html:!1,container:!1},e.fn.tooltip.noConflict=function(){return e.fn.tooltip=n,this}}(window.jQuery),!function(e){"use strict";var t=function(e,t){this.init("popover",e,t)};t.prototype=e.extend({},e.fn.tooltip.Constructor.prototype,{constructor:t,setContent:function(){var e=this.tip(),t=this.getTitle(),n=this.getContent();e.find(".popover-title")[this.options.html?"html":"text"](t),e.find(".popover-content")[this.options.html?"html":"text"](n),e.removeClass("fade top bottom left right in")},hasContent:function(){return this.getTitle()||this.getContent()},getContent:function(){var e,t=this.$element,n=this.options;return e=(typeof n.content=="function"?n.content.call(t[0]):n.content)||t.attr("data-content"),e},tip:function(){return this.$tip||(this.$tip=e(this.options.template)),this.$tip},destroy:function(){this.hide().$element.off("."+this.type).removeData(this.type)}});var n=e.fn.popover;e.fn.popover=function(n){return this.each(function(){var r=e(this),i=r.data("popover"),s=typeof n=="object"&&n;i||r.data("popover",i=new t(this,s)),typeof n=="string"&&i[n]()})},e.fn.popover.Constructor=t,e.fn.popover.defaults=e.extend({},e.fn.tooltip.defaults,{placement:"right",trigger:"click",content:"",template:'<div class="popover"><div class="arrow"></div><h3 class="popover-title"></h3><div class="popover-content"></div></div>'}),e.fn.popover.noConflict=function(){return e.fn.popover=n,this}}(window.jQuery),!function(e){"use strict";function t(t,n){var r=e.proxy(this.process,this),i=e(t).is("body")?e(window):e(t),s;this.options=e.extend({},e.fn.scrollspy.defaults,n),this.$scrollElement=i.on("scroll.scroll-spy.data-api",r),this.selector=(this.options.target||(s=e(t).attr("href"))&&s.replace(/.*(?=#[^\s]+$)/,"")||"")+" .nav li > a",this.$body=e("body"),this.refresh(),this.process()}t.prototype={constructor:t,refresh:function(){var t=this,n;this.offsets=e([]),this.targets=e([]),n=this.$body.find(this.selector).map(function(){var n=e(this),r=n.data("target")||n.attr("href"),i=/^#\w/.test(r)&&e(r);return i&&i.length&&[[i.position().top+(!e.isWindow(t.$scrollElement.get(0))&&t.$scrollElement.scrollTop()),r]]||null}).sort(function(e,t){return e[0]-t[0]}).each(function(){t.offsets.push(this[0]),t.targets.push(this[1])})},process:function(){var e=this.$scrollElement.scrollTop()+this.options.offset,t=this.$scrollElement[0].scrollHeight||this.$body[0].scrollHeight,n=t-this.$scrollElement.height(),r=this.offsets,i=this.targets,s=this.activeTarget,o;if(e>=n)return s!=(o=i.last()[0])&&this.activate(o);for(o=r.length;o--;)s!=i[o]&&e>=r[o]&&(!r[o+1]||e<=r[o+1])&&this.activate(i[o])},activate:function(t){var n,r;this.activeTarget=t,e(this.selector).parent(".active").removeClass("active"),r=this.selector+'[data-target="'+t+'"],'+this.selector+'[href="'+t+'"]',n=e(r).parent("li").addClass("active"),n.parent(".dropdown-menu").length&&(n=n.closest("li.dropdown").addClass("active")),n.trigger("activate")}};var n=e.fn.scrollspy;e.fn.scrollspy=function(n){return this.each(function(){var r=e(this),i=r.data("scrollspy"),s=typeof n=="object"&&n;i||r.data("scrollspy",i=new t(this,s)),typeof n=="string"&&i[n]()})},e.fn.scrollspy.Constructor=t,e.fn.scrollspy.defaults={offset:10},e.fn.scrollspy.noConflict=function(){return e.fn.scrollspy=n,this},e(window).on("load",function(){e('[data-spy="scroll"]').each(function(){var t=e(this);t.scrollspy(t.data())})})}(window.jQuery),!function(e){"use strict";var t=function(t){this.element=e(t)};t.prototype={constructor:t,show:function(){var t=this.element,n=t.closest("ul:not(.dropdown-menu)"),r=t.attr("data-target"),i,s,o;r||(r=t.attr("href"),r=r&&r.replace(/.*(?=#[^\s]*$)/,""));if(t.parent("li").hasClass("active"))return;i=n.find(".active:last a")[0],o=e.Event("show",{relatedTarget:i}),t.trigger(o);if(o.isDefaultPrevented())return;s=e(r),this.activate(t.parent("li"),n),this.activate(s,s.parent(),function(){t.trigger({type:"shown",relatedTarget:i})})},activate:function(t,n,r){function o(){i.removeClass("active").find("> .dropdown-menu > .active").removeClass("active"),t.addClass("active"),s?(t[0].offsetWidth,t.addClass("in")):t.removeClass("fade"),t.parent(".dropdown-menu")&&t.closest("li.dropdown").addClass("active"),r&&r()}var i=n.find("> .active"),s=r&&e.support.transition&&i.hasClass("fade");s?i.one(e.support.transition.end,o):o(),i.removeClass("in")}};var n=e.fn.tab;e.fn.tab=function(n){return this.each(function(){var r=e(this),i=r.data("tab");i||r.data("tab",i=new t(this)),typeof n=="string"&&i[n]()})},e.fn.tab.Constructor=t,e.fn.tab.noConflict=function(){return e.fn.tab=n,this},e(document).on("click.tab.data-api",'[data-toggle="tab"], [data-toggle="pill"]',function(t){t.preventDefault(),e(this).tab("show")})}(window.jQuery),!function(e){"use strict";var t=function(t,n){this.$element=e(t),this.options=e.extend({},e.fn.typeahead.defaults,n),this.matcher=this.options.matcher||this.matcher,this.sorter=this.options.sorter||this.sorter,this.highlighter=this.options.highlighter||this.highlighter,this.updater=this.options.updater||this.updater,this.source=this.options.source,this.$menu=e(this.options.menu),this.shown=!1,this.listen()};t.prototype={constructor:t,select:function(){var e=this.$menu.find(".active").attr("data-value");return this.$element.val(this.updater(e)).change(),this.hide()},updater:function(e){return e},show:function(){var t=e.extend({},this.$element.position(),{height:this.$element[0].offsetHeight});return this.$menu.insertAfter(this.$element).css({top:t.top+t.height,left:t.left}).show(),this.shown=!0,this},hide:function(){return this.$menu.hide(),this.shown=!1,this},lookup:function(t){var n;return this.query=this.$element.val(),!this.query||this.query.length<this.options.minLength?this.shown?this.hide():this:(n=e.isFunction(this.source)?this.source(this.query,e.proxy(this.process,this)):this.source,n?this.process(n):this)},process:function(t){var n=this;return t=e.grep(t,function(e){return n.matcher(e)}),t=this.sorter(t),t.length?this.render(t.slice(0,this.options.items)).show():this.shown?this.hide():this},matcher:function(e){return~e.toLowerCase().indexOf(this.query.toLowerCase())},sorter:function(e){var t=[],n=[],r=[],i;while(i=e.shift())i.toLowerCase().indexOf(this.query.toLowerCase())?~i.indexOf(this.query)?n.push(i):r.push(i):t.push(i);return t.concat(n,r)},highlighter:function(e){var t=this.query.replace(/[\-\[\]{}()*+?.,\\\^$|#\s]/g,"\\$&");return e.replace(new RegExp("("+t+")","ig"),function(e,t){return"<strong>"+t+"</strong>"})},render:function(t){var n=this;return t=e(t).map(function(t,r){return t=e(n.options.item).attr("data-value",r),t.find("a").html(n.highlighter(r)),t[0]}),t.first().addClass("active"),this.$menu.html(t),this},next:function(t){var n=this.$menu.find(".active").removeClass("active"),r=n.next();r.length||(r=e(this.$menu.find("li")[0])),r.addClass("active")},prev:function(e){var t=this.$menu.find(".active").removeClass("active"),n=t.prev();n.length||(n=this.$menu.find("li").last()),n.addClass("active")},listen:function(){this.$element.on("focus",e.proxy(this.focus,this)).on("blur",e.proxy(this.blur,this)).on("keypress",e.proxy(this.keypress,this)).on("keyup",e.proxy(this.keyup,this)),this.eventSupported("keydown")&&this.$element.on("keydown",e.proxy(this.keydown,this)),this.$menu.on("click",e.proxy(this.click,this)).on("mouseenter","li",e.proxy(this.mouseenter,this)).on("mouseleave","li",e.proxy(this.mouseleave,this))},eventSupported:function(e){var t=e in this.$element;return t||(this.$element.setAttribute(e,"return;"),t=typeof this.$element[e]=="function"),t},move:function(e){if(!this.shown)return;switch(e.keyCode){case 9:case 13:case 27:e.preventDefault();break;case 38:e.preventDefault(),this.prev();break;case 40:e.preventDefault(),this.next()}e.stopPropagation()},keydown:function(t){this.suppressKeyPressRepeat=~e.inArray(t.keyCode,[40,38,9,13,27]),this.move(t)},keypress:function(e){if(this.suppressKeyPressRepeat)return;this.move(e)},keyup:function(e){switch(e.keyCode){case 40:case 38:case 16:case 17:case 18:break;case 9:case 13:if(!this.shown)return;this.select();break;case 27:if(!this.shown)return;this.hide();break;default:this.lookup()}e.stopPropagation(),e.preventDefault()},focus:function(e){this.focused=!0},blur:function(e){this.focused=!1,!this.mousedover&&this.shown&&this.hide()},click:function(e){e.stopPropagation(),e.preventDefault(),this.select(),this.$element.focus()},mouseenter:function(t){this.mousedover=!0,this.$menu.find(".active").removeClass("active"),e(t.currentTarget).addClass("active")},mouseleave:function(e){this.mousedover=!1,!this.focused&&this.shown&&this.hide()}};var n=e.fn.typeahead;e.fn.typeahead=function(n){return this.each(function(){var r=e(this),i=r.data("typeahead"),s=typeof n=="object"&&n;i||r.data("typeahead",i=new t(this,s)),typeof n=="string"&&i[n]()})},e.fn.typeahead.defaults={source:[],items:8,menu:'<ul class="typeahead dropdown-menu"></ul>',item:'<li><a href="#"></a></li>',minLength:1},e.fn.typeahead.Constructor=t,e.fn.typeahead.noConflict=function(){return e.fn.typeahead=n,this},e(document).on("focus.typeahead.data-api",'[data-provide="typeahead"]',function(t){var n=e(this);if(n.data("typeahead"))return;n.typeahead(n.data())})}(window.jQuery),!function(e){"use strict";var t=function(t,n){this.options=e.extend({},e.fn.affix.defaults,n),this.$window=e(window).on("scroll.affix.data-api",e.proxy(this.checkPosition,this)).on("click.affix.data-api",e.proxy(function(){setTimeout(e.proxy(this.checkPosition,this),1)},this)),this.$element=e(t),this.checkPosition()};t.prototype.checkPosition=function(){if(!this.$element.is(":visible"))return;var t=e(document).height(),n=this.$window.scrollTop(),r=this.$element.offset(),i=this.options.offset,s=i.bottom,o=i.top,u="affix affix-top affix-bottom",a;typeof i!="object"&&(s=o=i),typeof o=="function"&&(o=i.top()),typeof s=="function"&&(s=i.bottom()),a=this.unpin!=null&&n+this.unpin<=r.top?!1:s!=null&&r.top+this.$element.height()>=t-s?"bottom":o!=null&&n<=o?"top":!1;if(this.affixed===a)return;this.affixed=a,this.unpin=a=="bottom"?r.top-n:null,this.$element.removeClass(u).addClass("affix"+(a?"-"+a:""))};var n=e.fn.affix;e.fn.affix=function(n){return this.each(function(){var r=e(this),i=r.data("affix"),s=typeof n=="object"&&n;i||r.data("affix",i=new t(this,s)),typeof n=="string"&&i[n]()})},e.fn.affix.Constructor=t,e.fn.affix.defaults={offset:0},e.fn.affix.noConflict=function(){return e.fn.affix=n,this},e(window).on("load",function(){e('[data-spy="affix"]').each(function(){var t=e(this),n=t.data();n.offset=n.offset||{},n.offsetBottom&&(n.offset.bottom=n.offsetBottom),n.offsetTop&&(n.offset.top=n.offsetTop),t.affix(n)})})}(window.jQuery);
\ No newline at end of file
diff --git a/opendaylight/adsal/web/root/src/main/resources/js/datasource.js b/opendaylight/adsal/web/root/src/main/resources/js/datasource.js
deleted file mode 100755 (executable)
index 8226df0..0000000
+++ /dev/null
@@ -1,95 +0,0 @@
-/*
- * Fuel UX Data components - static data source
- * https://github.com/ExactTarget/fuelux-data
- *
- * Copyright (c) 2012 ExactTarget
- * Licensed under the MIT license.
- */
-
-(function (root, factory) {
-       if (typeof define === 'function' && define.amd) {
-               define(['underscore'], factory);
-       } else {
-               root.StaticDataSource = factory();
-       }
-}(this, function () {
-
-       var StaticDataSource = function (options) {
-               this._formatter = options.formatter;
-               this._columns = options.columns;
-               this._delay = options.delay || 0;
-               this._data = options.data;
-       };
-
-       StaticDataSource.prototype = {
-
-               columns: function () {
-                       return this._columns;
-               },
-
-               data: function (options, callback) {
-                       var self = this;
-
-                       setTimeout(function () {
-                               var data = $.extend(true, [], self._data);
-
-                               // SEARCHING
-                               if (options.search) {
-                                       data = _.filter(data, function (item) {
-                                               var match = false;
-
-                                               _.each(item, function (prop) {
-                                                       if (_.isString(prop) || _.isFinite(prop)) {
-                                                               if (prop.toString().toLowerCase().indexOf(options.search.toLowerCase()) !== -1) match = true;
-                                                       }
-                                               });
-
-                                               return match;
-                                       });
-                               }
-
-                               // FILTERING
-                               if (options.filter) {
-                                       data = _.filter(data, function (item) {
-                                               switch(options.filter.value) {
-                                                       case 'lt5m':
-                                                               if(item.population < 5000000) return true;
-                                                               break;
-                                                       case 'gte5m':
-                                                               if(item.population >= 5000000) return true;
-                                                               break;
-                                                       default:
-                                                               return true;
-                                                               break;
-                                               }
-                                       });
-                               }
-
-                               var count = data.length;
-
-                               // SORTING
-                               if (options.sortProperty) {
-                                       data = _.sortBy(data, options.sortProperty);
-                                       if (options.sortDirection === 'desc') data.reverse();
-                               }
-
-                               // PAGING
-                               var startIndex = options.pageIndex * options.pageSize;
-                               var endIndex = startIndex + options.pageSize;
-                               var end = (endIndex > count) ? count : endIndex;
-                               var pages = Math.ceil(count / options.pageSize);
-                               var page = options.pageIndex + 1;
-                               var start = startIndex + 1;
-
-                               data = data.slice(startIndex, endIndex);
-
-                               if (self._formatter) self._formatter(data);
-
-                               callback({ data: data, start: start, end: end, count: count, pages: pages, page: page });
-
-                       }, this._delay)
-               }
-       };
-
-       return StaticDataSource;
-}));
diff --git a/opendaylight/adsal/web/root/src/main/resources/js/fuelux/COPYING b/opendaylight/adsal/web/root/src/main/resources/js/fuelux/COPYING
deleted file mode 100644 (file)
index 9b8ce79..0000000
+++ /dev/null
@@ -1,33 +0,0 @@
-Copyright (C) 2012, ExactTarget, Inc.
-All rights reserved.
-
-Permission is hereby granted, free of charge, to any person obtaining a copy of
-this software and associated documentation files (the "Software"), to deal in the
-Software without restriction, including without limitation the rights to use, copy,
-modify, merge, publish, distribute, sublicense, and/or sell copies of the Software,
-and to permit persons to whom the Software is furnished to do so, subject to the
-following conditions:
-
-The above copyright notice and this permission notice shall be included in all
-copies or substantial portions of the Software.
-
-THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED,
-INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A
-PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
-HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
-CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE
-OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
-
-====================================================================
-
-The above license does not apply to the following bundled components:
-
-Â¥      jQuery located at lib/jquery.js
-Â¥      Bootstrap Apache 2.0 Located under lib/bootstrap
-Â¥      RequireJS located at lib/require.js
-Â¥      QUnit located under lib/qunit
-Â¥      Grunt located under node-modules/grunt
-Â¥      Grunt-contrib located under node-modules/grunt-contrib
-Â¥      Grunt-recess located under node-modules/grunt-recess
-
-Licensing information regarding the above packages can be found in the THIRD-PARTY file.
\ No newline at end of file
diff --git a/opendaylight/adsal/web/root/src/main/resources/js/fuelux/all.min.js b/opendaylight/adsal/web/root/src/main/resources/js/fuelux/all.min.js
deleted file mode 100755 (executable)
index 2f9e721..0000000
+++ /dev/null
@@ -1,4 +0,0 @@
-/*! Fuel UX - v2.3.1 - 2013-08-02
-* https://github.com/ExactTarget/fuelux
-* Copyright (c) 2013 ExactTarget; Licensed MIT */
-(function(){(function(a){var b;define("bootstrap/bootstrap-transition",["jquery"],function(){return function(){!function(a){a(function(){a.support.transition=function(){var a=function(){var a=document.createElement("bootstrap"),b={WebkitTransition:"webkitTransitionEnd",MozTransition:"transitionend",OTransition:"oTransitionEnd otransitionend",transition:"transitionend"},c;for(c in b)if(a.style[c]!==undefined)return b[c]}();return a&&{end:a}}()})}(window.jQuery)}.call(a),b})})(this),function(a){var b;define("bootstrap/bootstrap-affix",["bootstrap/bootstrap-transition"],function(){return function(){!function(a){var b=function(b,c){this.options=a.extend({},a.fn.affix.defaults,c),this.$window=a(window).on("scroll.affix.data-api",a.proxy(this.checkPosition,this)).on("click.affix.data-api",a.proxy(function(){setTimeout(a.proxy(this.checkPosition,this),1)},this)),this.$element=a(b),this.checkPosition()};b.prototype.checkPosition=function(){if(!this.$element.is(":visible"))return;var b=a(document).height(),c=this.$window.scrollTop(),d=this.$element.offset(),e=this.options.offset,f=e.bottom,g=e.top,h="affix affix-top affix-bottom",i;typeof e!="object"&&(f=g=e),typeof g=="function"&&(g=e.top()),typeof f=="function"&&(f=e.bottom()),i=this.unpin!=null&&c+this.unpin<=d.top?!1:f!=null&&d.top+this.$element.height()>=b-f?"bottom":g!=null&&c<=g?"top":!1;if(this.affixed===i)return;this.affixed=i,this.unpin=i=="bottom"?d.top-c:null,this.$element.removeClass(h).addClass("affix"+(i?"-"+i:""))};var c=a.fn.affix;a.fn.affix=function(c){return this.each(function(){var d=a(this),e=d.data("affix"),f=typeof c=="object"&&c;e||d.data("affix",e=new b(this,f)),typeof c=="string"&&e[c]()})},a.fn.affix.Constructor=b,a.fn.affix.defaults={offset:0},a.fn.affix.noConflict=function(){return a.fn.affix=c,this},a(window).on("load",function(){a('[data-spy="affix"]').each(function(){var b=a(this),c=b.data();c.offset=c.offset||{},c.offsetBottom&&(c.offset.bottom=c.offsetBottom),c.offsetTop&&(c.offset.top=c.offsetTop),b.affix(c)})})}(window.jQuery)}.call(a),b})}(this),function(a){var b;define("bootstrap/bootstrap-alert",["bootstrap/bootstrap-transition"],function(){return function(){!function(a){var b='[data-dismiss="alert"]',c=function(c){a(c).on("click",b,this.close)};c.prototype.close=function(b){function f(){e.trigger("closed").remove()}var c=a(this),d=c.attr("data-target"),e;d||(d=c.attr("href"),d=d&&d.replace(/.*(?=#[^\s]*$)/,"")),e=a(d),b&&b.preventDefault(),e.length||(e=c.hasClass("alert")?c:c.parent()),e.trigger(b=a.Event("close"));if(b.isDefaultPrevented())return;e.removeClass("in"),a.support.transition&&e.hasClass("fade")?e.on(a.support.transition.end,f):f()};var d=a.fn.alert;a.fn.alert=function(b){return this.each(function(){var d=a(this),e=d.data("alert");e||d.data("alert",e=new c(this)),typeof b=="string"&&e[b].call(d)})},a.fn.alert.Constructor=c,a.fn.alert.noConflict=function(){return a.fn.alert=d,this},a(document).on("click.alert.data-api",b,c.prototype.close)}(window.jQuery)}.call(a),b})}(this),function(a){var b;define("bootstrap/bootstrap-button",["bootstrap/bootstrap-transition"],function(){return function(){!function(a){var b=function(b,c){this.$element=a(b),this.options=a.extend({},a.fn.button.defaults,c)};b.prototype.setState=function(a){var b="disabled",c=this.$element,d=c.data(),e=c.is("input")?"val":"html";a=a+"Text",d.resetText||c.data("resetText",c[e]()),c[e](d[a]||this.options[a]),setTimeout(function(){a=="loadingText"?c.addClass(b).attr(b,b):c.removeClass(b).removeAttr(b)},0)},b.prototype.toggle=function(){var a=this.$element.closest('[data-toggle="buttons-radio"]');a&&a.find(".active").removeClass("active"),this.$element.toggleClass("active")};var c=a.fn.button;a.fn.button=function(c){return this.each(function(){var d=a(this),e=d.data("button"),f=typeof c=="object"&&c;e||d.data("button",e=new b(this,f)),c=="toggle"?e.toggle():c&&e.setState(c)})},a.fn.button.defaults={loadingText:"loading..."},a.fn.button.Constructor=b,a.fn.button.noConflict=function(){return a.fn.button=c,this},a(document).on("click.button.data-api","[data-toggle^=button]",function(b){var c=a(b.target);c.hasClass("btn")||(c=c.closest(".btn")),c.button("toggle")})}(window.jQuery)}.call(a),b})}(this),function(a){var b;define("bootstrap/bootstrap-carousel",["bootstrap/bootstrap-transition"],function(){return function(){!function(a){var b=function(b,c){this.$element=a(b),this.$indicators=this.$element.find(".carousel-indicators"),this.options=c,this.options.pause=="hover"&&this.$element.on("mouseenter",a.proxy(this.pause,this)).on("mouseleave",a.proxy(this.cycle,this))};b.prototype={cycle:function(b){return b||(this.paused=!1),this.interval&&clearInterval(this.interval),this.options.interval&&!this.paused&&(this.interval=setInterval(a.proxy(this.next,this),this.options.interval)),this},getActiveIndex:function(){return this.$active=this.$element.find(".item.active"),this.$items=this.$active.parent().children(),this.$items.index(this.$active)},to:function(b){var c=this.getActiveIndex(),d=this;if(b>this.$items.length-1||b<0)return;return this.sliding?this.$element.one("slid",function(){d.to(b)}):c==b?this.pause().cycle():this.slide(b>c?"next":"prev",a(this.$items[b]))},pause:function(b){return b||(this.paused=!0),this.$element.find(".next, .prev").length&&a.support.transition.end&&(this.$element.trigger(a.support.transition.end),this.cycle(!0)),clearInterval(this.interval),this.interval=null,this},next:function(){if(this.sliding)return;return this.slide("next")},prev:function(){if(this.sliding)return;return this.slide("prev")},slide:function(b,c){var d=this.$element.find(".item.active"),e=c||d[b](),f=this.interval,g=b=="next"?"left":"right",h=b=="next"?"first":"last",i=this,j;this.sliding=!0,f&&this.pause(),e=e.length?e:this.$element.find(".item")[h](),j=a.Event("slide",{relatedTarget:e[0],direction:g});if(e.hasClass("active"))return;this.$indicators.length&&(this.$indicators.find(".active").removeClass("active"),this.$element.one("slid",function(){var b=a(i.$indicators.children()[i.getActiveIndex()]);b&&b.addClass("active")}));if(a.support.transition&&this.$element.hasClass("slide")){this.$element.trigger(j);if(j.isDefaultPrevented())return;e.addClass(b),e[0].offsetWidth,d.addClass(g),e.addClass(g),this.$element.one(a.support.transition.end,function(){e.removeClass([b,g].join(" ")).addClass("active"),d.removeClass(["active",g].join(" ")),i.sliding=!1,setTimeout(function(){i.$element.trigger("slid")},0)})}else{this.$element.trigger(j);if(j.isDefaultPrevented())return;d.removeClass("active"),e.addClass("active"),this.sliding=!1,this.$element.trigger("slid")}return f&&this.cycle(),this}};var c=a.fn.carousel;a.fn.carousel=function(c){return this.each(function(){var d=a(this),e=d.data("carousel"),f=a.extend({},a.fn.carousel.defaults,typeof c=="object"&&c),g=typeof c=="string"?c:f.slide;e||d.data("carousel",e=new b(this,f)),typeof c=="number"?e.to(c):g?e[g]():f.interval&&e.pause().cycle()})},a.fn.carousel.defaults={interval:5e3,pause:"hover"},a.fn.carousel.Constructor=b,a.fn.carousel.noConflict=function(){return a.fn.carousel=c,this},a(document).on("click.carousel.data-api","[data-slide], [data-slide-to]",function(b){var c=a(this),d,e=a(c.attr("data-target")||(d=c.attr("href"))&&d.replace(/.*(?=#[^\s]+$)/,"")),f=a.extend({},e.data(),c.data()),g;e.carousel(f),(g=c.attr("data-slide-to"))&&e.data("carousel").pause().to(g).cycle(),b.preventDefault()})}(window.jQuery)}.call(a),b})}(this),function(a){var b;define("bootstrap/bootstrap-collapse",["bootstrap/bootstrap-transition"],function(){return function(){!function(a){var b=function(b,c){this.$element=a(b),this.options=a.extend({},a.fn.collapse.defaults,c),this.options.parent&&(this.$parent=a(this.options.parent)),this.options.toggle&&this.toggle()};b.prototype={constructor:b,dimension:function(){var a=this.$element.hasClass("width");return a?"width":"height"},show:function(){var b,c,d,e;if(this.transitioning||this.$element.hasClass("in"))return;b=this.dimension(),c=a.camelCase(["scroll",b].join("-")),d=this.$parent&&this.$parent.find("> .accordion-group > .in");if(d&&d.length){e=d.data("collapse");if(e&&e.transitioning)return;d.collapse("hide"),e||d.data("collapse",null)}this.$element[b](0),this.transition("addClass",a.Event("show"),"shown"),a.support.transition&&this.$element[b](this.$element[0][c])},hide:function(){var b;if(this.transitioning||!this.$element.hasClass("in"))return;b=this.dimension(),this.reset(this.$element[b]()),this.transition("removeClass",a.Event("hide"),"hidden"),this.$element[b](0)},reset:function(a){var b=this.dimension();return this.$element.removeClass("collapse")[b](a||"auto")[0].offsetWidth,this.$element[a!==null?"addClass":"removeClass"]("collapse"),this},transition:function(b,c,d){var e=this,f=function(){c.type=="show"&&e.reset(),e.transitioning=0,e.$element.trigger(d)};this.$element.trigger(c);if(c.isDefaultPrevented())return;this.transitioning=1,this.$element[b]("in"),a.support.transition&&this.$element.hasClass("collapse")?this.$element.one(a.support.transition.end,f):f()},toggle:function(){this[this.$element.hasClass("in")?"hide":"show"]()}};var c=a.fn.collapse;a.fn.collapse=function(c){return this.each(function(){var d=a(this),e=d.data("collapse"),f=a.extend({},a.fn.collapse.defaults,d.data(),typeof c=="object"&&c);e||d.data("collapse",e=new b(this,f)),typeof c=="string"&&e[c]()})},a.fn.collapse.defaults={toggle:!0},a.fn.collapse.Constructor=b,a.fn.collapse.noConflict=function(){return a.fn.collapse=c,this},a(document).on("click.collapse.data-api","[data-toggle=collapse]",function(b){var c=a(this),d,e=c.attr("data-target")||b.preventDefault()||(d=c.attr("href"))&&d.replace(/.*(?=#[^\s]+$)/,""),f=a(e).data("collapse")?"toggle":c.data();c[a(e).hasClass("in")?"addClass":"removeClass"]("collapsed"),a(e).collapse(f)})}(window.jQuery)}.call(a),b})}(this),function(a){var b;define("bootstrap/bootstrap-dropdown",["bootstrap/bootstrap-transition"],function(){return function(){!function(a){function d(){a(".dropdown-backdrop").remove(),a(b).each(function(){e(a(this)).removeClass("open")})}function e(b){var c=b.attr("data-target"),d;c||(c=b.attr("href"),c=c&&/#/.test(c)&&c.replace(/.*(?=#[^\s]*$)/,"")),d=c&&a(c);if(!d||!d.length)d=b.parent();return d}var b="[data-toggle=dropdown]",c=function(b){var c=a(b).on("click.dropdown.data-api",this.toggle);a("html").on("click.dropdown.data-api",function(){c.parent().removeClass("open")})};c.prototype={constructor:c,toggle:function(b){var c=a(this),f,g;if(c.is(".disabled, :disabled"))return;return f=e(c),g=f.hasClass("open"),d(),g||("ontouchstart"in document.documentElement&&a('<div class="dropdown-backdrop"/>').insertBefore(a(this)).on("click",d),f.toggleClass("open")),c.focus(),!1},keydown:function(c){var d,f,g,h,i,j;if(!/(38|40|27)/.test(c.keyCode))return;d=a(this),c.preventDefault(),c.stopPropagation();if(d.is(".disabled, :disabled"))return;h=e(d),i=h.hasClass("open");if(!i||i&&c.keyCode==27)return c.which==27&&h.find(b).focus(),d.click();f=a("[role=menu] li:not(.divider):visible a",h);if(!f.length)return;j=f.index(f.filter(":focus")),c.keyCode==38&&j>0&&j--,c.keyCode==40&&j<f.length-1&&j++,~j||(j=0),f.eq(j).focus()}};var f=a.fn.dropdown;a.fn.dropdown=function(b){return this.each(function(){var d=a(this),e=d.data("dropdown");e||d.data("dropdown",e=new c(this)),typeof b=="string"&&e[b].call(d)})},a.fn.dropdown.Constructor=c,a.fn.dropdown.noConflict=function(){return a.fn.dropdown=f,this},a(document).on("click.dropdown.data-api",d).on("click.dropdown.data-api",".dropdown form",function(a){a.stopPropagation()}).on("click.dropdown.data-api",b,c.prototype.toggle).on("keydown.dropdown.data-api",b+", [role=menu]",c.prototype.keydown)}(window.jQuery)}.call(a),b})}(this),function(a){var b;define("bootstrap/bootstrap-modal",["bootstrap/bootstrap-transition"],function(){return function(){!function(a){var b=function(b,c){this.options=c,this.$element=a(b).delegate('[data-dismiss="modal"]',"click.dismiss.modal",a.proxy(this.hide,this)),this.options.remote&&this.$element.find(".modal-body").load(this.options.remote)};b.prototype={constructor:b,toggle:function(){return this[this.isShown?"hide":"show"]()},show:function(){var b=this,c=a.Event("show");this.$element.trigger(c);if(this.isShown||c.isDefaultPrevented())return;this.isShown=!0,this.escape(),this.backdrop(function(){var c=a.support.transition&&b.$element.hasClass("fade");b.$element.parent().length||b.$element.appendTo(document.body),b.$element.show(),c&&b.$element[0].offsetWidth,b.$element.addClass("in").attr("aria-hidden",!1),b.enforceFocus(),c?b.$element.one(a.support.transition.end,function(){b.$element.focus().trigger("shown")}):b.$element.focus().trigger("shown")})},hide:function(b){b&&b.preventDefault();var c=this;b=a.Event("hide"),this.$element.trigger(b);if(!this.isShown||b.isDefaultPrevented())return;this.isShown=!1,this.escape(),a(document).off("focusin.modal"),this.$element.removeClass("in").attr("aria-hidden",!0),a.support.transition&&this.$element.hasClass("fade")?this.hideWithTransition():this.hideModal()},enforceFocus:function(){var b=this;a(document).on("focusin.modal",function(a){b.$element[0]!==a.target&&!b.$element.has(a.target).length&&b.$element.focus()})},escape:function(){var a=this;this.isShown&&this.options.keyboard?this.$element.on("keyup.dismiss.modal",function(b){b.which==27&&a.hide()}):this.isShown||this.$element.off("keyup.dismiss.modal")},hideWithTransition:function(){var b=this,c=setTimeout(function(){b.$element.off(a.support.transition.end),b.hideModal()},500);this.$element.one(a.support.transition.end,function(){clearTimeout(c),b.hideModal()})},hideModal:function(){var a=this;this.$element.hide(),this.backdrop(function(){a.removeBackdrop(),a.$element.trigger("hidden")})},removeBackdrop:function(){this.$backdrop&&this.$backdrop.remove(),this.$backdrop=null},backdrop:function(b){var c=this,d=this.$element.hasClass("fade")?"fade":"";if(this.isShown&&this.options.backdrop){var e=a.support.transition&&d;this.$backdrop=a('<div class="modal-backdrop '+d+'" />').appendTo(document.body),this.$backdrop.click(this.options.backdrop=="static"?a.proxy(this.$element[0].focus,this.$element[0]):a.proxy(this.hide,this)),e&&this.$backdrop[0].offsetWidth,this.$backdrop.addClass("in");if(!b)return;e?this.$backdrop.one(a.support.transition.end,b):b()}else!this.isShown&&this.$backdrop?(this.$backdrop.removeClass("in"),a.support.transition&&this.$element.hasClass("fade")?this.$backdrop.one(a.support.transition.end,b):b()):b&&b()}};var c=a.fn.modal;a.fn.modal=function(c){return this.each(function(){var d=a(this),e=d.data("modal"),f=a.extend({},a.fn.modal.defaults,d.data(),typeof c=="object"&&c);e||d.data("modal",e=new b(this,f)),typeof c=="string"?e[c]():f.show&&e.show()})},a.fn.modal.defaults={backdrop:!0,keyboard:!0,show:!0},a.fn.modal.Constructor=b,a.fn.modal.noConflict=function(){return a.fn.modal=c,this},a(document).on("click.modal.data-api",'[data-toggle="modal"]',function(b){var c=a(this),d=c.attr("href"),e=a(c.attr("data-target")||d&&d.replace(/.*(?=#[^\s]+$)/,"")),f=e.data("modal")?"toggle":a.extend({remote:!/#/.test(d)&&d},e.data(),c.data());b.preventDefault(),e.modal(f).one("hide",function(){c.focus()})})}(window.jQuery)}.call(a),b})}(this),function(a){var b;define("bootstrap/bootstrap-tooltip",["bootstrap/bootstrap-transition"],function(){return function(){!function(a){var b=function(a,b){this.init("tooltip",a,b)};b.prototype={constructor:b,init:function(b,c,d){var e,f,g,h,i;this.type=b,this.$element=a(c),this.options=this.getOptions(d),this.enabled=!0,g=this.options.trigger.split(" ");for(i=g.length;i--;)h=g[i],h=="click"?this.$element.on("click."+this.type,this.options.selector,a.proxy(this.toggle,this)):h!="manual"&&(e=h=="hover"?"mouseenter":"focus",f=h=="hover"?"mouseleave":"blur",this.$element.on(e+"."+this.type,this.options.selector,a.proxy(this.enter,this)),this.$element.on(f+"."+this.type,this.options.selector,a.proxy(this.leave,this)));this.options.selector?this._options=a.extend({},this.options,{trigger:"manual",selector:""}):this.fixTitle()},getOptions:function(b){return b=a.extend({},a.fn[this.type].defaults,this.$element.data(),b),b.delay&&typeof b.delay=="number"&&(b.delay={show:b.delay,hide:b.delay}),b},enter:function(b){var c=a.fn[this.type].defaults,d={},e;this._options&&a.each(this._options,function(a,b){c[a]!=b&&(d[a]=b)}),e=a(b.currentTarget)[this.type](d).data(this.type);if(!e.options.delay||!e.options.delay.show)return e.show();clearTimeout(this.timeout),e.hoverState="in",this.timeout=setTimeout(function(){e.hoverState=="in"&&e.show()},e.options.delay.show)},leave:function(b){var c=a(b.currentTarget)[this.type](this._options).data(this.type);this.timeout&&clearTimeout(this.timeout);if(!c.options.delay||!c.options.delay.hide)return c.hide();c.hoverState="out",this.timeout=setTimeout(function(){c.hoverState=="out"&&c.hide()},c.options.delay.hide)},show:function(){var b,c,d,e,f,g,h=a.Event("show");if(this.hasContent()&&this.enabled){this.$element.trigger(h);if(h.isDefaultPrevented())return;b=this.tip(),this.setContent(),this.options.animation&&b.addClass("fade"),f=typeof this.options.placement=="function"?this.options.placement.call(this,b[0],this.$element[0]):this.options.placement,b.detach().css({top:0,left:0,display:"block"}),this.options.container?b.appendTo(this.options.container):b.insertAfter(this.$element),c=this.getPosition(),d=b[0].offsetWidth,e=b[0].offsetHeight;switch(f){case"bottom":g={top:c.top+c.height,left:c.left+c.width/2-d/2};break;case"top":g={top:c.top-e,left:c.left+c.width/2-d/2};break;case"left":g={top:c.top+c.height/2-e/2,left:c.left-d};break;case"right":g={top:c.top+c.height/2-e/2,left:c.left+c.width}}this.applyPlacement(g,f),this.$element.trigger("shown")}},applyPlacement:function(a,b){var c=this.tip(),d=c[0].offsetWidth,e=c[0].offsetHeight,f,g,h,i;c.offset(a).addClass(b).addClass("in"),f=c[0].offsetWidth,g=c[0].offsetHeight,b=="top"&&g!=e&&(a.top=a.top+e-g,i=!0),b=="bottom"||b=="top"?(h=0,a.left<0&&(h=a.left*-2,a.left=0,c.offset(a),f=c[0].offsetWidth,g=c[0].offsetHeight),this.replaceArrow(h-d+f,f,"left")):this.replaceArrow(g-e,g,"top"),i&&c.offset(a)},replaceArrow:function(a,b,c){this.arrow().css(c,a?50*(1-a/b)+"%":"")},setContent:function(){var a=this.tip(),b=this.getTitle();a.find(".tooltip-inner")[this.options.html?"html":"text"](b),a.removeClass("fade in top bottom left right")},hide:function(){function e(){var b=setTimeout(function(){c.off(a.support.transition.end).detach()},500);c.one(a.support.transition.end,function(){clearTimeout(b),c.detach()})}var b=this,c=this.tip(),d=a.Event("hide");this.$element.trigger(d);if(d.isDefaultPrevented())return;return c.removeClass("in"),a.support.transition&&this.$tip.hasClass("fade")?e():c.detach(),this.$element.trigger("hidden"),this},fixTitle:function(){var a=this.$element;(a.attr("title")||typeof a.attr("data-original-title")!="string")&&a.attr("data-original-title",a.attr("title")||"").attr("title","")},hasContent:function(){return this.getTitle()},getPosition:function(){var b=this.$element[0];return a.extend({},typeof b.getBoundingClientRect=="function"?b.getBoundingClientRect():{width:b.offsetWidth,height:b.offsetHeight},this.$element.offset())},getTitle:function(){var a,b=this.$element,c=this.options;return a=b.attr("data-original-title")||(typeof c.title=="function"?c.title.call(b[0]):c.title),a},tip:function(){return this.$tip=this.$tip||a(this.options.template)},arrow:function(){return this.$arrow=this.$arrow||this.tip().find(".tooltip-arrow")},validate:function(){this.$element[0].parentNode||(this.hide(),this.$element=null,this.options=null)},enable:function(){this.enabled=!0},disable:function(){this.enabled=!1},toggleEnabled:function(){this.enabled=!this.enabled},toggle:function(b){var c=b?a(b.currentTarget)[this.type](this._options).data(this.type):this;c.tip().hasClass("in")?c.hide():c.show()},destroy:function(){this.hide().$element.off("."+this.type).removeData(this.type)}};var c=a.fn.tooltip;a.fn.tooltip=function(c){return this.each(function(){var d=a(this),e=d.data("tooltip"),f=typeof c=="object"&&c;e||d.data("tooltip",e=new b(this,f)),typeof c=="string"&&e[c]()})},a.fn.tooltip.Constructor=b,a.fn.tooltip.defaults={animation:!0,placement:"top",selector:!1,template:'<div class="tooltip"><div class="tooltip-arrow"></div><div class="tooltip-inner"></div></div>',trigger:"hover focus",title:"",delay:0,html:!1,container:!1},a.fn.tooltip.noConflict=function(){return a.fn.tooltip=c,this}}(window.jQuery)}.call(a),b})}(this),function(a){var b;define("bootstrap/bootstrap-popover",["bootstrap/bootstrap-transition","bootstrap/bootstrap-tooltip"],function(){return function(){!function(a){var b=function(a,b){this.init("popover",a,b)};b.prototype=a.extend({},a.fn.tooltip.Constructor.prototype,{constructor:b,setContent:function(){var a=this.tip(),b=this.getTitle(),c=this.getContent();a.find(".popover-title")[this.options.html?"html":"text"](b),a.find(".popover-content")[this.options.html?"html":"text"](c),a.removeClass("fade top bottom left right in")},hasContent:function(){return this.getTitle()||this.getContent()},getContent:function(){var a,b=this.$element,c=this.options;return a=(typeof c.content=="function"?c.content.call(b[0]):c.content)||b.attr("data-content"),a},tip:function(){return this.$tip||(this.$tip=a(this.options.template)),this.$tip},destroy:function(){this.hide().$element.off("."+this.type).removeData(this.type)}});var c=a.fn.popover;a.fn.popover=function(c){return this.each(function(){var d=a(this),e=d.data("popover"),f=typeof c=="object"&&c;e||d.data("popover",e=new b(this,f)),typeof c=="string"&&e[c]()})},a.fn.popover.Constructor=b,a.fn.popover.defaults=a.extend({},a.fn.tooltip.defaults,{placement:"right",trigger:"click",content:"",template:'<div class="popover"><div class="arrow"></div><h3 class="popover-title"></h3><div class="popover-content"></div></div>'}),a.fn.popover.noConflict=function(){return a.fn.popover=c,this}}(window.jQuery)}.call(a),b})}(this),function(a){var b;define("bootstrap/bootstrap-scrollspy",["bootstrap/bootstrap-transition"],function(){return function(){!function(a){function b(b,c){var d=a.proxy(this.process,this),e=a(b).is("body")?a(window):a(b),f;this.options=a.extend({},a.fn.scrollspy.defaults,c),this.$scrollElement=e.on("scroll.scroll-spy.data-api",d),this.selector=(this.options.target||(f=a(b).attr("href"))&&f.replace(/.*(?=#[^\s]+$)/,"")||"")+" .nav li > a",this.$body=a("body"),this.refresh(),this.process()}b.prototype={constructor:b,refresh:function(){var b=this,c;this.offsets=a([]),this.targets=a([]),c=this.$body.find(this.selector).map(function(){var c=a(this),d=c.data("target")||c.attr("href"),e=/^#\w/.test(d)&&a(d);return e&&e.length&&[[e.position().top+(!a.isWindow(b.$scrollElement.get(0))&&b.$scrollElement.scrollTop()),d]]||null}).sort(function(a,b){return a[0]-b[0]}).each(function(){b.offsets.push(this[0]),b.targets.push(this[1])})},process:function(){var a=this.$scrollElement.scrollTop()+this.options.offset,b=this.$scrollElement[0].scrollHeight||this.$body[0].scrollHeight,c=b-this.$scrollElement.height(),d=this.offsets,e=this.targets,f=this.activeTarget,g;if(a>=c)return f!=(g=e.last()[0])&&this.activate(g);for(g=d.length;g--;)f!=e[g]&&a>=d[g]&&(!d[g+1]||a<=d[g+1])&&this.activate(e[g])},activate:function(b){var c,d;this.activeTarget=b,a(this.selector).parent(".active").removeClass("active"),d=this.selector+'[data-target="'+b+'"],'+this.selector+'[href="'+b+'"]',c=a(d).parent("li").addClass("active"),c.parent(".dropdown-menu").length&&(c=c.closest("li.dropdown").addClass("active")),c.trigger("activate")}};var c=a.fn.scrollspy;a.fn.scrollspy=function(c){return this.each(function(){var d=a(this),e=d.data("scrollspy"),f=typeof c=="object"&&c;e||d.data("scrollspy",e=new b(this,f)),typeof c=="string"&&e[c]()})},a.fn.scrollspy.Constructor=b,a.fn.scrollspy.defaults={offset:10},a.fn.scrollspy.noConflict=function(){return a.fn.scrollspy=c,this},a(window).on("load",function(){a('[data-spy="scroll"]').each(function(){var b=a(this);b.scrollspy(b.data())})})}(window.jQuery)}.call(a),b})}(this),function(a){var b;define("bootstrap/bootstrap-tab",["bootstrap/bootstrap-transition"],function(){return function(){!function(a){var b=function(b){this.element=a(b)};b.prototype={constructor:b,show:function(){var b=this.element,c=b.closest("ul:not(.dropdown-menu)"),d=b.attr("data-target"),e,f,g;d||(d=b.attr("href"),d=d&&d.replace(/.*(?=#[^\s]*$)/,""));if(b.parent("li").hasClass("active"))return;e=c.find(".active:last a")[0],g=a.Event("show",{relatedTarget:e}),b.trigger(g);if(g.isDefaultPrevented())return;f=a(d),this.activate(b.parent("li"),c),this.activate(f,f.parent(),function(){b.trigger({type:"shown",relatedTarget:e})})},activate:function(b,c,d){function g(){e.removeClass("active").find("> .dropdown-menu > .active").removeClass("active"),b.addClass("active"),f?(b[0].offsetWidth,b.addClass("in")):b.removeClass("fade"),b.parent(".dropdown-menu")&&b.closest("li.dropdown").addClass("active"),d&&d()}var e=c.find("> .active"),f=d&&a.support.transition&&e.hasClass("fade");f?e.one(a.support.transition.end,g):g(),e.removeClass("in")}};var c=a.fn.tab;a.fn.tab=function(c){return this.each(function(){var d=a(this),e=d.data("tab");e||d.data("tab",e=new b(this)),typeof c=="string"&&e[c]()})},a.fn.tab.Constructor=b,a.fn.tab.noConflict=function(){return a.fn.tab=c,this},a(document).on("click.tab.data-api",'[data-toggle="tab"], [data-toggle="pill"]',function(b){b.preventDefault(),a(this).tab("show")})}(window.jQuery)}.call(a),b})}(this),function(a){var b;define("bootstrap/bootstrap-typeahead",["bootstrap/bootstrap-transition"],function(){return function(){!function(a){var b=function(b,c){this.$element=a(b),this.options=a.extend({},a.fn.typeahead.defaults,c),this.matcher=this.options.matcher||this.matcher,this.sorter=this.options.sorter||this.sorter,this.highlighter=this.options.highlighter||this.highlighter,this.updater=this.options.updater||this.updater,this.source=this.options.source,this.$menu=a(this.options.menu),this.shown=!1,this.listen()};b.prototype={constructor:b,select:function(){var a=this.$menu.find(".active").attr("data-value");return this.$element.val(this.updater(a)).change(),this.hide()},updater:function(a){return a},show:function(){var b=a.extend({},this.$element.position(),{height:this.$element[0].offsetHeight});return this.$menu.insertAfter(this.$element).css({top:b.top+b.height,left:b.left}).show(),this.shown=!0,this},hide:function(){return this.$menu.hide(),this.shown=!1,this},lookup:function(b){var c;return this.query=this.$element.val(),!this.query||this.query.length<this.options.minLength?this.shown?this.hide():this:(c=a.isFunction(this.source)?this.source(this.query,a.proxy(this.process,this)):this.source,c?this.process(c):this)},process:function(b){var c=this;return b=a.grep(b,function(a){return c.matcher(a)}),b=this.sorter(b),b.length?this.render(b.slice(0,this.options.items)).show():this.shown?this.hide():this},matcher:function(a){return~a.toLowerCase().indexOf(this.query.toLowerCase())},sorter:function(a){var b=[],c=[],d=[],e;while(e=a.shift())e.toLowerCase().indexOf(this.query.toLowerCase())?~e.indexOf(this.query)?c.push(e):d.push(e):b.push(e);return b.concat(c,d)},highlighter:function(a){var b=this.query.replace(/[\-\[\]{}()*+?.,\\\^$|#\s]/g,"\\$&");return a.replace(new RegExp("("+b+")","ig"),function(a,b){return"<strong>"+b+"</strong>"})},render:function(b){var c=this;return b=a(b).map(function(b,d){return b=a(c.options.item).attr("data-value",d),b.find("a").html(c.highlighter(d)),b[0]}),b.first().addClass("active"),this.$menu.html(b),this},next:function(b){var c=this.$menu.find(".active").removeClass("active"),d=c.next();d.length||(d=a(this.$menu.find("li")[0])),d.addClass("active")},prev:function(a){var b=this.$menu.find(".active").removeClass("active"),c=b.prev();c.length||(c=this.$menu.find("li").last()),c.addClass("active")},listen:function(){this.$element.on("focus",a.proxy(this.focus,this)).on("blur",a.proxy(this.blur,this)).on("keypress",a.proxy(this.keypress,this)).on("keyup",a.proxy(this.keyup,this)),this.eventSupported("keydown")&&this.$element.on("keydown",a.proxy(this.keydown,this)),this.$menu.on("click",a.proxy(this.click,this)).on("mouseenter","li",a.proxy(this.mouseenter,this)).on("mouseleave","li",a.proxy(this.mouseleave,this))},eventSupported:function(a){var b=a in this.$element;return b||(this.$element.setAttribute(a,"return;"),b=typeof this.$element[a]=="function"),b},move:function(a){if(!this.shown)return;switch(a.keyCode){case 9:case 13:case 27:a.preventDefault();break;case 38:a.preventDefault(),this.prev();break;case 40:a.preventDefault(),this.next()}a.stopPropagation()},keydown:function(b){this.suppressKeyPressRepeat=~a.inArray(b.keyCode,[40,38,9,13,27]),this.move(b)},keypress:function(a){if(this.suppressKeyPressRepeat)return;this.move(a)},keyup:function(a){switch(a.keyCode){case 40:case 38:case 16:case 17:case 18:break;case 9:case 13:if(!this.shown)return;this.select();break;case 27:if(!this.shown)return;this.hide();break;default:this.lookup()}a.stopPropagation(),a.preventDefault()},focus:function(a){this.focused=!0},blur:function(a){this.focused=!1,!this.mousedover&&this.shown&&this.hide()},click:function(a){a.stopPropagation(),a.preventDefault(),this.select(),this.$element.focus()},mouseenter:function(b){this.mousedover=!0,this.$menu.find(".active").removeClass("active"),a(b.currentTarget).addClass("active")},mouseleave:function(a){this.mousedover=!1,!this.focused&&this.shown&&this.hide()}};var c=a.fn.typeahead;a.fn.typeahead=function(c){return this.each(function(){var d=a(this),e=d.data("typeahead"),f=typeof c=="object"&&c;e||d.data("typeahead",e=new b(this,f)),typeof c=="string"&&e[c]()})},a.fn.typeahead.defaults={source:[],items:8,menu:'<ul class="typeahead dropdown-menu"></ul>',item:'<li><a href="#"></a></li>',minLength:1},a.fn.typeahead.Constructor=b,a.fn.typeahead.noConflict=function(){return a.fn.typeahead=c,this},a(document).on("focus.typeahead.data-api",'[data-provide="typeahead"]',function(b){var c=a(this);if(c.data("typeahead"))return;c.typeahead(c.data())})}(window.jQuery)}.call(a),b})}(this),define("fuelux/checkbox",["require","jquery"],function(a){var b=a("jquery"),c=function(a,c){this.$element=b(a),this.options=b.extend({},b.fn.checkbox.defaults,c),this.$label=this.$element.parent(),this.$icon=this.$label.find("i"),this.$chk=this.$label.find("input[type=checkbox]"),this.setState(this.$chk),this.$chk.on("change",b.proxy(this.itemchecked,this))};c.prototype={constructor:c,setState:function(a){var b=a.is(":checked"),c=a.is(":disabled");this.$icon.removeClass("checked").removeClass("disabled"),b===!0&&this.$icon.addClass("checked"),c===!0&&this.$icon.addClass("disabled")},enable:function(){this.$chk.attr("disabled",!1),this.$icon.removeClass("disabled")},disable:function(){this.$chk.attr("disabled",!0),this.$icon.addClass("disabled")},toggle:function(){this.$chk.click()},itemchecked:function(a){var c=b(a.target);this.setState(c)}},b.fn.checkbox=function(a,d){var e,f=this.each(function(){var f=b(this),g=f.data("checkbox"),h=typeof a=="object"&&a;g||f.data("checkbox",g=new c(this,h)),typeof a=="string"&&(e=g[a](d))});return e===undefined?f:e},b.fn.checkbox.defaults={},b.fn.checkbox.Constructor=c,b(function(){b(window).on("load",function(){b(".checkbox-custom > input[type=checkbox]").each(function(){var a=b(this);if(a.data("checkbox"))return;a.checkbox(a.data())})})})}),define("fuelux/util",["require","jquery"],function(a){function c(a,c){return(a.textContent||a.innerText||b(a).text()||"").toLowerCase()===(c||"").toLowerCase()}var b=a("jquery");b.expr[":"].fuelTextExactCI=b.expr.createPseudo?b.expr.createPseudo(function(a){return function(b){return c(b,a)}}):function(a,b,d){return c(a,d[3])}}),define("fuelux/combobox",["require","jquery","./util"],function(a){var b=a("jquery");a("./util");var c=function(a,c){this.$element=b(a),this.options=b.extend({},b.fn.combobox.defaults,c),this.$element.on("click","a",b.proxy(this.itemclicked,this)),this.$element.on("change","input",b.proxy(this.inputchanged,this)),this.$input=this.$element.find("input"),this.$button=this.$element.find(".btn"),this.setDefaultSelection()};c.prototype={constructor:c,selectedItem:function(){var a=this.$selectedItem,c={};if(a){var d=this.$selectedItem.text();c=b.extend({text:d},this.$selectedItem.data())}else c={text:this.$input.val()};return c},selectByText:function(a){var b="li:fuelTextExactCI("+a+")";this.selectBySelector(b)},selectByValue:function(a){var b='li[data-value="'+a+'"]';this.selectBySelector(b)},selectByIndex:function(a){var b="li:eq("+a+")";this.selectBySelector(b)},selectBySelector:function(a){var b=this.$element.find(a);typeof b[0]!="undefined"?(this.$selectedItem=b,this.$input.val(this.$selectedItem.text())):this.$selectedItem=null},setDefaultSelection:function(){var a="li[data-selected=true]:first",b=this.$element.find(a);b.length>0&&(this.selectBySelector(a),b.removeData("selected"),b.removeAttr("data-selected"))},enable:function(){this.$input.removeAttr("disabled"),this.$button.removeClass("disabled")},disable:function(){this.$input.attr("disabled",!0),this.$button.addClass("disabled")},itemclicked:function(a){this.$selectedItem=b(a.target).parent(),this.$input.val(this.$selectedItem.text()).trigger("change",{synthetic:!0});var c=this.selectedItem();this.$element.trigger("changed",c),a.preventDefault()},inputchanged:function(a,c){if(c&&c.synthetic)return;var d=b(a.target).val();this.selectByText(d);var e=this.selectedItem();e.text.length===0&&(e={text:d}),this.$element.trigger("changed",e)}},b.fn.combobox=function(a,d){var e,f=this.each(function(){var f=b(this),g=f.data("combobox"),h=typeof a=="object"&&a;g||f.data("combobox",g=new c(this,h)),typeof a=="string"&&(e=g[a](d))});return e===undefined?f:e},b.fn.combobox.defaults={},b.fn.combobox.Constructor=c,b(function(){b(window).on("load",function(){b(".combobox").each(function(){var a=b(this);if(a.data("combobox"))return;a.combobox(a.data())})}),b("body").on("mousedown.combobox.data-api",".combobox",function(a){var c=b(this);if(c.data("combobox"))return;c.combobox(c.data())})})}),define("fuelux/datagrid",["require","jquery"],function(a){var b=a("jquery"),c=22,d=function(a,c){this.$element=b(a),this.$thead=this.$element.find("thead"),this.$tfoot=this.$element.find("tfoot"),this.$footer=this.$element.find("tfoot th"),this.$footerchildren=this.$footer.children().show().css("visibility","hidden"),this.$topheader=this.$element.find("thead th"),this.$searchcontrol=this.$element.find(".datagrid-search"),this.$filtercontrol=this.$element.find(".filter"),this.$pagesize=this.$element.find(".grid-pagesize"),this.$pageinput=this.$element.find(".grid-pager input"),this.$pagedropdown=this.$element.find(".grid-pager .dropdown-menu"),this.$prevpagebtn=this.$element.find(".grid-prevpage"),this.$nextpagebtn=this.$element.find(".grid-nextpage"),this.$pageslabel=this.$element.find(".grid-pages"),this.$countlabel=this.$element.find(".grid-count"),this.$startlabel=this.$element.find(".grid-start"),this.$endlabel=this.$element.find(".grid-end"),this.$tbody=b("<tbody>").insertAfter(this.$thead),this.$colheader=b("<tr>").appendTo(this.$thead),this.options=b.extend(!0,{},b.fn.datagrid.defaults,c),this.$pagesize.hasClass("select")?this.options.dataOptions.pageSize=parseInt(this.$pagesize.select("selectedItem").value,10):this.options.dataOptions.pageSize=parseInt(this.$pagesize.val(),10),this.$searchcontrol.length<=0&&(this.$searchcontrol=this.$element.find(".search")),this.columns=this.options.dataSource.columns(),this.$nextpagebtn.on("click",b.proxy(this.next,this)),this.$prevpagebtn.on("click",b.proxy(this.previous,this)),this.$searchcontrol.on("searched cleared",b.proxy(this.searchChanged,this)),this.$filtercontrol.on("changed",b.proxy(this.filterChanged,this)),this.$colheader.on("click","th",b.proxy(this.headerClicked,this)),this.$pagesize.hasClass("select")?this.$pagesize.on("changed",b.proxy(this.pagesizeChanged,this)):this.$pagesize.on("change",b.proxy(this.pagesizeChanged,this)),this.$pageinput.on("change",b.proxy(this.pageChanged,this)),this.renderColumns(),this.options.stretchHeight&&this.initStretchHeight(),this.renderData()};d.prototype={constructor:d,renderColumns:function(){var a=this;this.$footer.attr("colspan",this.columns.length),this.$topheader.attr("colspan",this.columns.length);var c="";b.each(this.columns,function(a,b){c+='<th data-property="'+b.property+'"',b.sortable&&(c+=' class="sortable"'),c+=">"+b.label+"</th>"}),a.$colheader.append(c)},updateColumns:function(a,b){this._updateColumns(this.$colheader,a,b),this.$sizingHeader&&this._updateColumns(this.$sizingHeader,this.$sizingHeader.find("th").eq(a.index()),b)},_updateColumns:function(a,c,d){var e=d==="asc"?"icon-chevron-up":"icon-chevron-down";a.find("i.datagrid-sort").remove(),a.find("th").removeClass("sorted"),b("<i>").addClass(e+" datagrid-sort").appendTo(c),c.addClass("sorted")},updatePageDropdown:function(a){var b="";for(var c=1;c<=a.pages;c++)b+="<li><a>"+c+"</a></li>";this.$pagedropdown.html(b)},updatePageButtons:function(a){a.page===1?this.$prevpagebtn.attr("disabled","disabled"):this.$prevpagebtn.removeAttr("disabled"),a.page===a.pages?this.$nextpagebtn.attr("disabled","disabled"):this.$nextpagebtn.removeAttr("disabled")},renderData:function(){var a=this;this.$tbody.html(this.placeholderRowHTML(this.options.loadingHTML)),this.options.dataSource.data(this.options.dataOptions,function(c){var d=c.count===1?a.options.itemText:a.options.itemsText,e="";a.$footerchildren.css("visibility",function(){return c.count>0?"visible":"hidden"}),a.$pageinput.val(c.page),a.$pageslabel.text(c.pages),a.$countlabel.text(c.count+" "+d),a.$startlabel.text(c.start),a.$endlabel.text(c.end),a.updatePageDropdown(c),a.updatePageButtons(c),b.each(c.data,function(c,d){e+="<tr>",b.each(a.columns,function(a,b){e+="<td>"+d[b.property]+"</td>"}),e+="</tr>"}),e||(e=a.placeholderRowHTML("0 "+a.options.itemsText)),a.$tbody.html(e),a.stretchHeight(),a.$element.trigger("loaded")})},placeholderRowHTML:function(a){return'<tr><td style="text-align:center;padding:20px;border-bottom:none;" colspan="'+this.columns.length+'">'+a+"</td></tr>"},headerClicked:function(a){var c=b(a.target);if(!c.hasClass("sortable"))return;var d=this.options.dataOptions.sortDirection,e=this.options.dataOptions.sortProperty,f=c.data("property");e===f?this.options.dataOptions.sortDirection=d==="asc"?"desc":"asc":(this.options.dataOptions.sortDirection="asc",this.options.dataOptions.sortProperty=f),this.options.dataOptions.pageIndex=0,this.updateColumns(c,this.options.dataOptions.sortDirection),this.renderData()},pagesizeChanged:function(a,c){c?this.options.dataOptions.pageSize=parseInt(c.value,10):this.options.dataOptions.pageSize=parseInt(b(a.target).val(),10),this.options.dataOptions.pageIndex=0,this.renderData()},pageChanged:function(a){var c=parseInt(b(a.target).val(),10);c=isNaN(c)?1:c;var d=this.$pageslabel.text();this.options.dataOptions.pageIndex=c>d?d-1:c-1,this.renderData()},searchChanged:function(a,b){this.options.dataOptions.search=b,this.options.dataOptions.pageIndex=0,this.renderData()},filterChanged:function(a,b){this.options.dataOptions.filter=b,this.options.dataOptions.pageIndex=0,this.renderData()},previous:function(){this.$nextpagebtn.attr("disabled","disabled"),this.$prevpagebtn.attr("disabled","disabled"),this.options.dataOptions.pageIndex--,this.renderData()},next:function(){this.$nextpagebtn.attr("disabled","disabled"),this.$prevpagebtn.attr("disabled","disabled"),this.options.dataOptions.pageIndex++,this.renderData()},reload:function(){this.options.dataOptions.pageIndex=0,this.renderData()},initStretchHeight:function(){this.$gridContainer=this.$element.parent(),this.$element.wrap('<div class="datagrid-stretch-wrapper">'),this.$stretchWrapper=this.$element.parent(),this.$headerTable=b("<table>").attr("class",this.$element.attr("class")),this.$footerTable=this.$headerTable.clone(),this.$headerTable.prependTo(this.$gridContainer).addClass("datagrid-stretch-header"),this.$thead.detach().appendTo(this.$headerTable),this.$sizingHeader=this.$thead.clone(),this.$sizingHeader.find("tr:first").remove(),this.$footerTable.appendTo(this.$gridContainer).addClass("datagrid-stretch-footer"),this.$tfoot.detach().appendTo(this.$footerTable)},stretchHeight:function(){if(!this.$gridContainer)return;this.setColumnWidths();var a=this.$gridContainer.height(),b=this.$headerTable.outerHeight(),c=this.$footerTable.outerHeight(),d=b+c;this.$stretchWrapper.height(a-d)},setColumnWidths:function(){function e(e,f){if(e===d-1)return;var g=b(f),h=a.eq(e),i=h.width();h.hasClass("sorted")&&g.prop("tagName")==="TD"&&(i=i+c),g.width(i)}if(!this.$sizingHeader)return;this.$element.prepend(this.$sizingHeader);var a=this.$sizingHeader.find("th"),d=a.length;this.$colheader.find("th").each(e),this.$tbody.find("tr:first > td").each(e),this.$sizingHeader.detach()}},b.fn.datagrid=function(a){return this.each(function(){var c=b(this),e=c.data("datagrid"),f=typeof a=="object"&&a;e||c.data("datagrid",e=new d(this,f)),typeof a=="string"&&e[a]()})},b.fn.datagrid.defaults={dataOptions:{pageIndex:0,pageSize:10},loadingHTML:'<div class="progress progress-striped active" style="width:50%;margin:auto;"><div class="bar" style="width:100%;"></div></div>',itemsText:"items",itemText:"item"},b.fn.datagrid.Constructor=d}),define("fuelux/pillbox",["require","jquery"],function(a){var b=a("jquery"),c=function(a,c){this.$element=b(a),this.options=b.extend({},b.fn.pillbox.defaults,c),this.$element.on("click","li",b.proxy(this.itemclicked,this))};c.prototype={constructor:c,items:function(){return this.$element.find("li").map(function(){var a=b(this);return b.extend({text:a.text()},a.data())}).get()},itemclicked:function(a){b(a.currentTarget).remove(),a.preventDefault()}},b.fn.pillbox=function(a){var d,e=this.each(function(){var e=b(this),f=e.data("pillbox"),g=typeof a=="object"&&a;f||e.data("pillbox",f=new c(this,g)),typeof a=="string"&&(d=f[a]())});return d===undefined?e:d},b.fn.pillbox.defaults={},b.fn.pillbox.Constructor=c,b(function(){b("body").on("mousedown.pillbox.data-api",".pillbox",function(a){var c=b(this);if(c.data("pillbox"))return;c.pillbox(c.data())})})}),define("fuelux/radio",["require","jquery"],function(a){var b=a("jquery"),c=function(a,c){this.$element=b(a),this.options=b.extend({},b.fn.radio.defaults,c),this.$label=this.$element.parent(),this.$icon=this.$label.find("i"),this.$radio=this.$label.find("input[type=radio]"),this.groupName=this.$radio.attr("name"),this.setState(this.$radio),this.$radio.on("change",b.proxy(this.itemchecked,this))};c.prototype={constructor:c,setState:function(a,b){var c=a.is(":checked"),d=a.is(":disabled");c===!0&&this.$icon.addClass("checked"),d===!0&&this.$icon.addClass("disabled")},resetGroup:function(){b("input[name="+this.groupName+"]").next().removeClass("checked")},enable:function(){this.$radio.attr("disabled",!1),this.$icon.removeClass("disabled")},disable:function(){this.$radio.attr("disabled",!0),this.$icon.addClass("disabled")},itemchecked:function(a){var c=b(a.target);this.resetGroup(),this.setState(c)}},b.fn.radio=function(a,d){var e,f=this.each(function(){var f=b(this),g=f.data("radio"),h=typeof a=="object"&&a;g||f.data("radio",g=new c(this,h)),typeof a=="string"&&(e=g[a](d))});return e===undefined?f:e},b.fn.radio.defaults={},b.fn.radio.Constructor=c,b(function(){b(window).on("load",function(){b(".radio-custom > input[type=radio]").each(function(){var a=b(this);if(a.data("radio"))return;a.radio(a.data())})})})}),define("fuelux/search",["require","jquery"],function(a){var b=a("jquery"),c=function(a,c){this.$element=b(a),this.options=b.extend({},b.fn.search.defaults,c),this.$button=this.$element.find("button").on("click",b.proxy(this.buttonclicked,this)),this.$input=this.$element.find("input").on("keydown",b.proxy(this.keypress,this)).on("keyup",b.proxy(this.keypressed,this)),this.$icon=this.$element.find("i"),this.activeSearch=""};c.prototype={constructor:c,search:function(a){this.$icon.attr("class","icon-remove"),this.activeSearch=a,this.$element.trigger("searched",a)},clear:function(){this.$icon.attr("class","icon-search"),this.activeSearch="",this.$input.val(""),this.$element.trigger("cleared")},action:function(){var a=this.$input.val(),b=a===""||a===this.activeSearch;this.activeSearch&&b?this.clear():a&&this.search(a)},buttonclicked:function(a){a.preventDefault();if(b(a.currentTarget).is(".disabled, :disabled"))return;this.action()},keypress:function(a){a.which===13&&a.preventDefault()},keypressed:function(a){var b,c;a.which===13?(a.preventDefault(),this.action()):(b=this.$input.val(),c=b&&b===this.activeSearch,this.$icon.attr("class",c?"icon-remove":"icon-search"))},disable:function(){this.$input.attr("disabled","disabled"),this.$button.addClass("disabled")},enable:function(){this.$input.removeAttr("disabled"),this.$button.removeClass("disabled")}},b.fn.search=function(a){return this.each(function(){var d=b(this),e=d.data("search"),f=typeof a=="object"&&a;e||d.data("search",e=new c(this,f)),typeof a=="string"&&e[a]()})},b.fn.search.defaults={},b.fn.search.Constructor=c,b(function(){b("body").on("mousedown.search.data-api",".search",function(){var a=b(this);if(a.data("search"))return;a.search(a.data())})})}),define("fuelux/spinner",["require","jquery"],function(a){var b=a("jquery"),c=function(a,c){this.$element=b(a),this.options=b.extend({},b.fn.spinner.defaults,c),this.$input=this.$element.find(".spinner-input"),this.$element.on("keyup",this.$input,b.proxy(this.change,this)),this.options.hold?(this.$element.on("mousedown",".spinner-up",b.proxy(function(){this.startSpin(!0)},this)),this.$element.on("mouseup",".spinner-up, .spinner-down",b.proxy(this.stopSpin,this)),this.$element.on("mouseout",".spinner-up, .spinner-down",b.proxy(this.stopSpin,this)),this.$element.on("mousedown",".spinner-down",b.proxy(function(){this.startSpin(!1)},this))):(this.$element.on("click",".spinner-up",b.proxy(function(){this.step(!0)},this)),this.$element.on("click",".spinner-down",b.proxy(function(){this.step(!1)},this))),this.switches={count:1,enabled:!0},this.options.speed==="medium"?this.switches.speed=300:this.options.speed==="fast"?this.switches.speed=100:this.switches.speed=500,this.lastValue=null,this.render(),this.options.disabled&&this.disable()};c.prototype={constructor:c,render:function(){this.$input.val(this.options.value),this.$input.attr("maxlength",(this.options.max+"").split("").length)},change:function(){var a=this.$input.val();a/1?this.options.value=a/1:(a=a.replace(/[^0-9]/g,""),this.$input.val(a),this.options.value=a/1),this.triggerChangedEvent()},stopSpin:function(){clearTimeout(this.switches.timeout),this.switches.count=1,this.triggerChangedEvent()},triggerChangedEvent:function(){var a=this.value();if(a===this.lastValue)return;this.lastValue=a,this.$element.trigger("changed",a),this.$element.trigger("change")},startSpin:function(a){if(!this.options.disabled){var c=this.switches.count;c===1?(this.step(a),c=1):c<3?c=1.5:c<8?c=2.5:c=4,this.switches.timeout=setTimeout(b.proxy(function(){this.iterator(a)},this),this.switches.speed/c),this.switches.count++}},iterator:function(a){this.step(a),this.startSpin(a)},step:function(a){var b=this.options.value,c=a?this.options.max:this.options.min;if(a?b<c:b>c){var d=b+(a?1:-1)*this.options.step;(a?d>c:d<c)?this.value(c):this.value(d)}},value:function(a){return!isNaN(parseFloat(a))&&isFinite(a)?(a=parseFloat(a),this.options.value=a,this.$input.val(a),this):this.options.value},disable:function(){this.options.disabled=!0,this.$input.attr("disabled",""),this.$element.find("button").addClass("disabled")},enable:function(){this.options.disabled=!1,this.$input.removeAttr("disabled"),this.$element.find("button").removeClass("disabled")}},b.fn.spinner=function(a,d){var e,f=this.each(function(){var f=b(this),g=f.data("spinner"),h=typeof a=="object"&&a;g||f.data("spinner",g=new c(this,h)),typeof a=="string"&&(e=g[a](d))});return e===undefined?f:e},b.fn.spinner.defaults={value:1,min:1,max:999,step:1,hold:!0,speed:"medium",disabled:!1},b.fn.spinner.Constructor=c,b(function(){b("body").on("mousedown.spinner.data-api",".spinner",function(a){var c=b(this);if(c.data("spinner"))return;c.spinner(c.data())})})}),define("fuelux/select",["require","jquery","./util"],function(a){var b=a("jquery");a("./util");var c=function(a,c){this.$element=b(a),this.options=b.extend({},b.fn.select.defaults,c),this.$element.on("click","a",b.proxy(this.itemclicked,this)),this.$button=this.$element.find(".btn"),this.$label=this.$element.find(".dropdown-label"),this.setDefaultSelection(),c.resize==="auto"&&this.resize()};c.prototype={constructor:c,itemclicked:function(a){this.$selectedItem=b(a.target).parent(),this.$label.text(this.$selectedItem.text());var c=this.selectedItem();this.$element.trigger("changed",c),a.preventDefault()},resize:function(){var a=b("#selectTextSize")[0];a||b("<div/>").attr({id:"selectTextSize"}).appendTo("body");var c=0,d=0;this.$element.find("a").each(function(){var a=b(this),e=a.text(),f=b("#selectTextSize");f.text(e),d=f.outerWidth(),d>c&&(c=d)}),this.$label.width(c)},selectedItem:function(){var a=this.$selectedItem.text();return b.extend({text:a},this.$selectedItem.data())},selectByText:function(a){var b="li a:fuelTextExactCI("+a+")";this.selectBySelector(b)},selectByValue:function(a){var b='li[data-value="'+a+'"]';this.selectBySelector(b)},selectByIndex:function(a){var b="li:eq("+a+")";this.selectBySelector(b)},selectBySelector:function(a){var b=this.$element.find(a);this.$selectedItem=b,this.$label.text(this.$selectedItem.text())},setDefaultSelection:function(){var a="li[data-selected=true]:first",b=this.$element.find(a);b.length===0?this.selectByIndex(0):(this.selectBySelector(a),b.removeData("selected"),b.removeAttr("data-selected"))},enable:function(){this.$button.removeClass("disabled")},disable:function(){this.$button.addClass("disabled")}},b.fn.select=function(a,d){var e,f=this.each(function(){var f=b(this),g=f.data("select"),h=typeof a=="object"&&a;g||f.data("select",g=new c(this,h)),typeof a=="string"&&(e=g[a](d))});return e===undefined?f:e},b.fn.select.defaults={},b.fn.select.Constructor=c,b(function(){b(window).on("load",function(){b(".select").each(function(){var a=b(this);if(a.data("select"))return;a.select(a.data())})}),b("body").on("mousedown.select.data-api",".select",function(a){var c=b(this);if(c.data("select"))return;c.select(c.data())})})}),define("fuelux/tree",["require","jquery"],function(a){var b=a("jquery"),c=function(a,c){this.$element=b(a),this.options=b.extend({},b.fn.tree.defaults,c),this.$element.on("click",".tree-item",b.proxy(function(a){this.selectItem(a.currentTarget)},this)),this.$element.on("click",".tree-folder-header",b.proxy(function(a){this.selectFolder(a.currentTarget)},this)),this.render()};c.prototype={constructor:c,render:function(){this.populate(this.$element)},populate:function(a){var c=this,d=a.parent().find(".tree-loader:eq(0)");d.show(),this.options.dataSource.data(a.data(),function(e){d.hide(),b.each(e.data,function(b,d){var e;d.type==="folder"?(e=c.$element.find(".tree-folder:eq(0)").clone().show(),e.find(".tree-folder-name").html(d.name),e.find(".tree-loader").html(c.options.loadingHTML),e.find(".tree-folder-header").data(d)):d.type==="item"&&(e=c.$element.find(".tree-item:eq(0)").clone().show(),e.find(".tree-item-name").html(d.name),e.data(d)),a.hasClass("tree-folder-header")?a.parent().find(".tree-folder-content:eq(0)").append(e):a.append(e)}),c.$element.trigger("loaded")})},selectItem:function(a){var c=b(a),d=this.$element.find(".tree-selected"),e=[];this.options.multiSelect?b.each(d,function(a,d){var f=b(d);f[0]!==c[0]&&e.push(b(d).data())}):d[0]!==c[0]&&(d.removeClass("tree-selected").find("i").removeClass("icon-ok").addClass("tree-dot"),e.push(c.data())),c.hasClass("tree-selected")?(c.removeClass("tree-selected"),c.find("i").removeClass("icon-ok").addClass("tree-dot")):(c.addClass("tree-selected"),c.find("i").removeClass("tree-dot").addClass("icon-ok"),this.options.multiSelect&&e.push(c.data())),e.length&&this.$element.trigger("selected",{info:e})},selectFolder:function(a){var c=b(a),d=c.parent();c.find(".icon-folder-close").length?(d.find(".tree-folder-content").children().length?d.find(".tree-folder-content:eq(0)").show():this.populate(c),d.find(".icon-folder-close:eq(0)").removeClass("icon-folder-close").addClass("icon-folder-open"),this.$element.trigger("opened",c.data())):(this.options.cacheItems?d.find(".tree-folder-content:eq(0)").hide():d.find(".tree-folder-content:eq(0)").empty(),d.find(".icon-folder-open:eq(0)").removeClass("icon-folder-open").addClass("icon-folder-close"),this.$element.trigger("closed",c.data()))},selectedItems:function(){var a=this.$element.find(".tree-selected"),c=[];return b.each(a,function(a,d){c.push(b(d).data())}),c}},b.fn.tree=function(a,d){var e,f=this.each(function(){var f=b(this),g=f.data("tree"),h=typeof a=="object"&&a;g||f.data("tree",g=new c(this,h)),typeof a=="string"&&(e=g[a](d))});return e===undefined?f:e},b.fn.tree.defaults={multiSelect:!1,loadingHTML:"<div>Loading...</div>",cacheItems:!0},b.fn.tree.Constructor=c}),define("fuelux/wizard",["require","jquery"],function(a){var b=a("jquery"),c=function(a,c){var d;this.$element=b(a),this.options=b.extend({},b.fn.wizard.defaults,c),this.currentStep=1,this.numSteps=this.$element.find("li").length,this.$prevBtn=this.$element.find("button.btn-prev"),this.$nextBtn=this.$element.find("button.btn-next"),d=this.$nextBtn.children().detach(),this.nextText=b.trim(this.$nextBtn.text()),this.$nextBtn.append(d),this.$prevBtn.on("click",b.proxy(this.previous,this)),this.$nextBtn.on("click",b.proxy(this.next,this)),this.$element.on("click","li.complete",b.proxy(this.stepclicked,this))};c.prototype={constructor:c,setState:function(){var a=this.currentStep>1,c=this.currentStep===1,d=this.currentStep===this.numSteps;this.$prevBtn.attr("disabled",c===!0||a===!1);var e=this.$nextBtn.data();if(e&&e.last){this.lastText=e.last;if(typeof this.lastText!="undefined"){var f=d!==!0?this.nextText:this.lastText,g=this.$nextBtn.children().detach();this.$nextBtn.text(f).append(g)}}var h=this.$element.find("li");h.removeClass("active").removeClass("complete"),h.find("span.badge").removeClass("badge-info").removeClass("badge-success");var i="li:lt("+(this.currentStep-1)+")",j=this.$element.find(i);j.addClass("complete"),j.find("span.badge").addClass("badge-success");var k="li:eq("+(this.currentStep-1)+")",l=this.$element.find(k);l.addClass("active"),l.find("span.badge").addClass("badge-info");var m=l.data().target;b(".step-pane").removeClass("active"),b(m).addClass("active"),this.$element.trigger("changed")},stepclicked:function(a){var c=b(a.currentTarget),d=b(".steps li").index(c),e=b.Event("stepclick");this.$element.trigger(e,{step:d+1});if(e.isDefaultPrevented())return;this.currentStep=d+1,this.setState()},previous:function(){var a=this.currentStep>1;if(a){var c=b.Event("change");this.$element.trigger(c,{step:this.currentStep,direction:"previous"});if(c.isDefaultPrevented())return;this.currentStep-=1,this.setState()}},next:function(){var a=this.currentStep+1<=this.numSteps,c=this.currentStep===this.numSteps;if(a){var d=b.Event("change");this.$element.trigger(d,{step:this.currentStep,direction:"next"});if(d.isDefaultPrevented())return;this.currentStep+=1,this.setState()}else c&&this.$element.trigger("finished")},selectedItem:function(a){return{step:this.currentStep}}},b.fn.wizard=function(a,d){var e,f=this.each(function(){var f=b(this),g=f.data("wizard"),h=typeof a=="object"&&a;g||f.data("wizard",g=new c(this,h)),typeof a=="string"&&(e=g[a](d))});return e===undefined?f:e},b.fn.wizard.defaults={},b.fn.wizard.Constructor=c,b(function(){b("body").on("mousedown.wizard.data-api",".wizard",function(){var a=b(this);if(a.data("wizard"))return;a.wizard(a.data())})})}),define("fuelux/all",["require","jquery","bootstrap/bootstrap-affix","bootstrap/bootstrap-alert","bootstrap/bootstrap-button","bootstrap/bootstrap-carousel","bootstrap/bootstrap-collapse","bootstrap/bootstrap-dropdown","bootstrap/bootstrap-modal","bootstrap/bootstrap-popover","bootstrap/bootstrap-scrollspy","bootstrap/bootstrap-tab","bootstrap/bootstrap-tooltip","bootstrap/bootstrap-transition","bootstrap/bootstrap-typeahead","fuelux/checkbox","fuelux/combobox","fuelux/datagrid","fuelux/pillbox","fuelux/radio","fuelux/search","fuelux/spinner","fuelux/select","fuelux/tree","fuelux/wizard"],function(a){a("jquery"),a("bootstrap/bootstrap-affix"),a("bootstrap/bootstrap-alert"),a("bootstrap/bootstrap-button"),a("bootstrap/bootstrap-carousel"),a("bootstrap/bootstrap-collapse"),a("bootstrap/bootstrap-dropdown"),a("bootstrap/bootstrap-modal"),a("bootstrap/bootstrap-popover"),a("bootstrap/bootstrap-scrollspy"),a("bootstrap/bootstrap-tab"),a("bootstrap/bootstrap-tooltip"),a("bootstrap/bootstrap-transition"),a("bootstrap/bootstrap-typeahead"),a("fuelux/checkbox"),a("fuelux/combobox"),a("fuelux/datagrid"),a("fuelux/pillbox"),a("fuelux/radio"),a("fuelux/search"),a("fuelux/spinner"),a("fuelux/select"),a("fuelux/tree"),a("fuelux/wizard")})})();
\ No newline at end of file
diff --git a/opendaylight/adsal/web/root/src/main/resources/js/fuelux/checkbox.js b/opendaylight/adsal/web/root/src/main/resources/js/fuelux/checkbox.js
deleted file mode 100755 (executable)
index 639300e..0000000
+++ /dev/null
@@ -1,109 +0,0 @@
-/*
- * Fuel UX Checkbox
- * https://github.com/ExactTarget/fuelux
- *
- * Copyright (c) 2012 ExactTarget
- * Licensed under the MIT license.
- */
-
-define(['require','jquery'],function (require) {
-
-       var $ = require('jquery');
-
-
-       // CHECKBOX CONSTRUCTOR AND PROTOTYPE
-
-       var Checkbox = function (element, options) {
-
-               this.$element = $(element);
-               this.options = $.extend({}, $.fn.checkbox.defaults, options);
-
-               // cache elements
-               this.$label = this.$element.parent();
-               this.$icon = this.$label.find('i');
-               this.$chk = this.$label.find('input[type=checkbox]');
-
-               // set default state
-               this.setState(this.$chk);
-
-               // handle events
-               this.$chk.on('change', $.proxy(this.itemchecked, this));
-       };
-
-       Checkbox.prototype = {
-
-               constructor: Checkbox,
-
-               setState: function ($chk) {
-                       var checked = $chk.is(':checked');
-                       var disabled = $chk.is(':disabled');
-
-                       // reset classes
-                       this.$icon.removeClass('checked').removeClass('disabled');
-
-                       // set state of checkbox
-                       if (checked === true) {
-                               this.$icon.addClass('checked');
-                       }
-                       if (disabled === true) {
-                               this.$icon.addClass('disabled');
-                       }
-               },
-
-               enable: function () {
-                       this.$chk.attr('disabled', false);
-                       this.$icon.removeClass('disabled');
-               },
-
-               disable: function () {
-                       this.$chk.attr('disabled', true);
-                       this.$icon.addClass('disabled');
-               },
-
-               toggle: function () {
-                       this.$chk.click();
-               },
-
-               itemchecked: function (e) {
-                       var chk = $(e.target);
-                       this.setState(chk);
-               }
-       };
-
-
-       // CHECKBOX PLUGIN DEFINITION
-
-       $.fn.checkbox = function (option, value) {
-               var methodReturn;
-
-               var $set = this.each(function () {
-                       var $this = $(this);
-                       var data = $this.data('checkbox');
-                       var options = typeof option === 'object' && option;
-
-                       if (!data) $this.data('checkbox', (data = new Checkbox(this, options)));
-                       if (typeof option === 'string') methodReturn = data[option](value);
-               });
-
-               return (methodReturn === undefined) ? $set : methodReturn;
-       };
-
-       $.fn.checkbox.defaults = {};
-
-       $.fn.checkbox.Constructor = Checkbox;
-
-
-       // CHECKBOX DATA-API
-
-       $(function () {
-               $(window).on('load', function () {
-                       //$('i.checkbox').each(function () {
-                       $('.checkbox-custom > input[type=checkbox]').each(function () {
-                               var $this = $(this);
-                               if ($this.data('checkbox')) return;
-                               $this.checkbox($this.data());
-                       });
-               });
-       });
-
-});
diff --git a/opendaylight/adsal/web/root/src/main/resources/js/fuelux/combobox.js b/opendaylight/adsal/web/root/src/main/resources/js/fuelux/combobox.js
deleted file mode 100755 (executable)
index 1d0a132..0000000
+++ /dev/null
@@ -1,178 +0,0 @@
-/*
- * Fuel UX Combobox
- * https://github.com/ExactTarget/fuelux
- *
- * Copyright (c) 2012 ExactTarget
- * Licensed under the MIT license.
- */
-
-define(['require','jquery','./util'],function (require) {
-
-       var $ = require('jquery');
-       require('./util');
-
-       // COMBOBOX CONSTRUCTOR AND PROTOTYPE
-
-       var Combobox = function (element, options) {
-               this.$element = $(element);
-               this.options = $.extend({}, $.fn.combobox.defaults, options);
-               this.$element.on('click', 'a', $.proxy(this.itemclicked, this));
-               this.$element.on('change', 'input', $.proxy(this.inputchanged, this));
-               this.$input = this.$element.find('input');
-               this.$button = this.$element.find('.btn');
-
-               // set default selection
-               this.setDefaultSelection();
-       };
-
-       Combobox.prototype = {
-
-               constructor: Combobox,
-
-               selectedItem: function () {
-                       var item = this.$selectedItem;
-                       var data = {};
-
-                       if (item) {
-                               var txt = this.$selectedItem.text();
-                               data = $.extend({ text: txt }, this.$selectedItem.data());
-                       }
-                       else {
-                               data = { text: this.$input.val()};
-                       }
-
-                       return data;
-               },
-
-               selectByText: function (text) {
-                       var selector = 'li:fuelTextExactCI(' + text + ')';
-                       this.selectBySelector(selector);
-               },
-
-               selectByValue: function (value) {
-                       var selector = 'li[data-value="' + value + '"]';
-                       this.selectBySelector(selector);
-               },
-
-               selectByIndex: function (index) {
-                       // zero-based index
-                       var selector = 'li:eq(' + index + ')';
-                       this.selectBySelector(selector);
-               },
-
-               selectBySelector: function (selector) {
-                       var $item = this.$element.find(selector);
-
-                       if (typeof $item[0] !== 'undefined') {
-                               this.$selectedItem = $item;
-                               this.$input.val(this.$selectedItem.text());
-                       }
-                       else {
-                               this.$selectedItem = null;
-                       }
-               },
-
-               setDefaultSelection: function () {
-                       var selector = 'li[data-selected=true]:first';
-                       var item = this.$element.find(selector);
-
-                       if (item.length > 0) {
-                               // select by data-attribute
-                               this.selectBySelector(selector);
-                               item.removeData('selected');
-                               item.removeAttr('data-selected');
-                       }
-               },
-
-               enable: function () {
-                       this.$input.removeAttr('disabled');
-                       this.$button.removeClass('disabled');
-               },
-
-               disable: function () {
-                       this.$input.attr('disabled', true);
-                       this.$button.addClass('disabled');
-               },
-
-               itemclicked: function (e) {
-                       this.$selectedItem = $(e.target).parent();
-
-                       // set input text and trigger input change event marked as synthetic
-                       this.$input.val(this.$selectedItem.text()).trigger('change', { synthetic: true });
-
-                       // pass object including text and any data-attributes
-                       // to onchange event
-                       var data = this.selectedItem();
-
-                       // trigger changed event
-                       this.$element.trigger('changed', data);
-
-                       e.preventDefault();
-               },
-
-               inputchanged: function (e, extra) {
-
-                       // skip processing for internally-generated synthetic event
-                       // to avoid double processing
-                       if (extra && extra.synthetic) return;
-
-                       var val = $(e.target).val();
-                       this.selectByText(val);
-
-                       // find match based on input
-                       // if no match, pass the input value
-                       var data = this.selectedItem();
-                       if (data.text.length === 0) {
-                               data = { text: val };
-                       }
-
-                       // trigger changed event
-                       this.$element.trigger('changed', data);
-
-               }
-
-       };
-
-
-       // COMBOBOX PLUGIN DEFINITION
-
-       $.fn.combobox = function (option, value) {
-               var methodReturn;
-
-               var $set = this.each(function () {
-                       var $this = $(this);
-                       var data = $this.data('combobox');
-                       var options = typeof option === 'object' && option;
-
-                       if (!data) $this.data('combobox', (data = new Combobox(this, options)));
-                       if (typeof option === 'string') methodReturn = data[option](value);
-               });
-
-               return (methodReturn === undefined) ? $set : methodReturn;
-       };
-
-       $.fn.combobox.defaults = {};
-
-       $.fn.combobox.Constructor = Combobox;
-
-
-       // COMBOBOX DATA-API
-
-       $(function () {
-
-               $(window).on('load', function () {
-                       $('.combobox').each(function () {
-                               var $this = $(this);
-                               if ($this.data('combobox')) return;
-                               $this.combobox($this.data());
-                       });
-               });
-
-               $('body').on('mousedown.combobox.data-api', '.combobox', function (e) {
-                       var $this = $(this);
-                       if ($this.data('combobox')) return;
-                       $this.combobox($this.data());
-               });
-       });
-
-});
diff --git a/opendaylight/adsal/web/root/src/main/resources/js/fuelux/datagrid.js b/opendaylight/adsal/web/root/src/main/resources/js/fuelux/datagrid.js
deleted file mode 100755 (executable)
index e051928..0000000
+++ /dev/null
@@ -1,340 +0,0 @@
-/*
- * Fuel UX Datagrid
- * https://github.com/ExactTarget/fuelux
- *
- * Copyright (c) 2012 ExactTarget
- * Licensed under the MIT license.
- */
-
-define(['require','jquery'],function(require) {
-
-       var $ = require('jquery');
-
-       // Relates to thead .sorted styles in datagrid.less
-       var SORTED_HEADER_OFFSET = 22;
-
-
-       // DATAGRID CONSTRUCTOR AND PROTOTYPE
-
-       var Datagrid = function (element, options) {
-               this.$element = $(element);
-               this.$thead = this.$element.find('thead');
-               this.$tfoot = this.$element.find('tfoot');
-               this.$footer = this.$element.find('tfoot th');
-               this.$footerchildren = this.$footer.children().show().css('visibility', 'hidden');
-               this.$topheader = this.$element.find('thead th');
-               this.$searchcontrol = this.$element.find('.datagrid-search');
-               this.$filtercontrol = this.$element.find('.filter');
-               this.$pagesize = this.$element.find('.grid-pagesize');
-               this.$pageinput = this.$element.find('.grid-pager input');
-               this.$pagedropdown = this.$element.find('.grid-pager .dropdown-menu');
-               this.$prevpagebtn = this.$element.find('.grid-prevpage');
-               this.$nextpagebtn = this.$element.find('.grid-nextpage');
-               this.$pageslabel = this.$element.find('.grid-pages');
-               this.$countlabel = this.$element.find('.grid-count');
-               this.$startlabel = this.$element.find('.grid-start');
-               this.$endlabel = this.$element.find('.grid-end');
-
-               this.$tbody = $('<tbody>').insertAfter(this.$thead);
-               this.$colheader = $('<tr>').appendTo(this.$thead);
-
-               this.options = $.extend(true, {}, $.fn.datagrid.defaults, options);
-
-               // Shim until v3 -- account for FuelUX select or native select for page size:
-               if (this.$pagesize.hasClass('select')) {
-                       this.options.dataOptions.pageSize = parseInt(this.$pagesize.select('selectedItem').value, 10);
-               } else {
-                       this.options.dataOptions.pageSize = parseInt(this.$pagesize.val(), 10);
-               }
-
-               // Shim until v3 -- account for older search class:
-               if (this.$searchcontrol.length <= 0) {
-                       this.$searchcontrol = this.$element.find('.search');
-               }
-
-               this.columns = this.options.dataSource.columns();
-
-               this.$nextpagebtn.on('click', $.proxy(this.next, this));
-               this.$prevpagebtn.on('click', $.proxy(this.previous, this));
-               this.$searchcontrol.on('searched cleared', $.proxy(this.searchChanged, this));
-               this.$filtercontrol.on('changed', $.proxy(this.filterChanged, this));
-               this.$colheader.on('click', 'th', $.proxy(this.headerClicked, this));
-
-               if(this.$pagesize.hasClass('select')) {
-                       this.$pagesize.on('changed', $.proxy(this.pagesizeChanged, this));
-               } else {
-                       this.$pagesize.on('change', $.proxy(this.pagesizeChanged, this));
-               }
-
-               this.$pageinput.on('change', $.proxy(this.pageChanged, this));
-
-               this.renderColumns();
-
-               if (this.options.stretchHeight) this.initStretchHeight();
-
-               this.renderData();
-       };
-
-       Datagrid.prototype = {
-
-               constructor: Datagrid,
-
-               renderColumns: function () {
-                       var self = this;
-
-                       this.$footer.attr('colspan', this.columns.length);
-                       this.$topheader.attr('colspan', this.columns.length);
-
-                       var colHTML = '';
-
-                       $.each(this.columns, function (index, column) {
-                               colHTML += '<th data-property="' + column.property + '"';
-                               if (column.sortable) colHTML += ' class="sortable"';
-                               colHTML += '>' + column.label + '</th>';
-                       });
-
-                       self.$colheader.append(colHTML);
-               },
-
-               updateColumns: function ($target, direction) {
-                       this._updateColumns(this.$colheader, $target, direction);
-
-                       if (this.$sizingHeader) {
-                               this._updateColumns(this.$sizingHeader, this.$sizingHeader.find('th').eq($target.index()), direction);
-                       }
-               },
-
-               _updateColumns: function ($header, $target, direction) {
-                       var className = (direction === 'asc') ? 'icon-chevron-up' : 'icon-chevron-down';
-                       $header.find('i.datagrid-sort').remove();
-                       $header.find('th').removeClass('sorted');
-                       $('<i>').addClass(className + ' datagrid-sort').appendTo($target);
-                       $target.addClass('sorted');
-               },
-
-               updatePageDropdown: function (data) {
-                       var pageHTML = '';
-
-                       for (var i = 1; i <= data.pages; i++) {
-                               pageHTML += '<li><a>' + i + '</a></li>';
-                       }
-
-                       this.$pagedropdown.html(pageHTML);
-               },
-
-               updatePageButtons: function (data) {
-                       if (data.page === 1) {
-                               this.$prevpagebtn.attr('disabled', 'disabled');
-                       } else {
-                               this.$prevpagebtn.removeAttr('disabled');
-                       }
-
-                       if (data.page === data.pages) {
-                               this.$nextpagebtn.attr('disabled', 'disabled');
-                       } else {
-                               this.$nextpagebtn.removeAttr('disabled');
-                       }
-               },
-
-               renderData: function () {
-                       var self = this;
-
-                       this.$tbody.html(this.placeholderRowHTML(this.options.loadingHTML));
-
-                       this.options.dataSource.data(this.options.dataOptions, function (data) {
-                               var itemdesc = (data.count === 1) ? self.options.itemText : self.options.itemsText;
-                               var rowHTML = '';
-
-                               self.$footerchildren.css('visibility', function () {
-                                       return (data.count > 0) ? 'visible' : 'hidden';
-                               });
-
-                               self.$pageinput.val(data.page);
-                               self.$pageslabel.text(data.pages);
-                               self.$countlabel.text(data.count + ' ' + itemdesc);
-                               self.$startlabel.text(data.start);
-                               self.$endlabel.text(data.end);
-
-                               self.updatePageDropdown(data);
-                               self.updatePageButtons(data);
-
-                               $.each(data.data, function (index, row) {
-                                       rowHTML += '<tr>';
-                                       $.each(self.columns, function (index, column) {
-                                               rowHTML += '<td>' + row[column.property] + '</td>';
-                                       });
-                                       rowHTML += '</tr>';
-                               });
-
-                               if (!rowHTML) rowHTML = self.placeholderRowHTML('0 ' + self.options.itemsText);
-
-                               self.$tbody.html(rowHTML);
-                               self.stretchHeight();
-
-                               self.$element.trigger('loaded');
-                       });
-
-               },
-
-               placeholderRowHTML: function (content) {
-                       return '<tr><td style="text-align:center;padding:20px;border-bottom:none;" colspan="' +
-                               this.columns.length + '">' + content + '</td></tr>';
-               },
-
-               headerClicked: function (e) {
-                       var $target = $(e.target);
-                       if (!$target.hasClass('sortable')) return;
-
-                       var direction = this.options.dataOptions.sortDirection;
-                       var sort = this.options.dataOptions.sortProperty;
-                       var property = $target.data('property');
-
-                       if (sort === property) {
-                               this.options.dataOptions.sortDirection = (direction === 'asc') ? 'desc' : 'asc';
-                       } else {
-                               this.options.dataOptions.sortDirection = 'asc';
-                               this.options.dataOptions.sortProperty = property;
-                       }
-
-                       this.options.dataOptions.pageIndex = 0;
-                       this.updateColumns($target, this.options.dataOptions.sortDirection);
-                       this.renderData();
-               },
-
-               pagesizeChanged: function (e, pageSize) {
-                       if(pageSize) {
-                               this.options.dataOptions.pageSize = parseInt(pageSize.value, 10);
-                       } else {
-                               this.options.dataOptions.pageSize = parseInt($(e.target).val(), 10);
-                       }
-
-                       this.options.dataOptions.pageIndex = 0;
-                       this.renderData();
-               },
-
-               pageChanged: function (e) {
-                       var pageRequested = parseInt($(e.target).val(), 10);
-                       pageRequested = (isNaN(pageRequested)) ? 1 : pageRequested;
-                       var maxPages = this.$pageslabel.text();
-               
-                       this.options.dataOptions.pageIndex = 
-                               (pageRequested > maxPages) ? maxPages - 1 : pageRequested - 1;
-
-                       this.renderData();
-               },
-
-               searchChanged: function (e, search) {
-                       this.options.dataOptions.search = search;
-                       this.options.dataOptions.pageIndex = 0;
-                       this.renderData();
-               },
-
-               filterChanged: function (e, filter) {
-                       this.options.dataOptions.filter = filter;
-                       this.options.dataOptions.pageIndex = 0;
-                       this.renderData();
-               },
-
-               previous: function () {
-                       this.$nextpagebtn.attr('disabled', 'disabled');
-                       this.$prevpagebtn.attr('disabled', 'disabled');
-                       this.options.dataOptions.pageIndex--;
-                       this.renderData();
-               },
-
-               next: function () {
-                       this.$nextpagebtn.attr('disabled', 'disabled');
-                       this.$prevpagebtn.attr('disabled', 'disabled');
-                       this.options.dataOptions.pageIndex++;
-                       this.renderData();
-               },
-
-               reload: function () {
-                       this.options.dataOptions.pageIndex = 0;
-                       this.renderData();
-               },
-
-               initStretchHeight: function () {
-                       this.$gridContainer = this.$element.parent();
-
-                       this.$element.wrap('<div class="datagrid-stretch-wrapper">');
-                       this.$stretchWrapper = this.$element.parent();
-
-                       this.$headerTable = $('<table>').attr('class', this.$element.attr('class'));
-                       this.$footerTable = this.$headerTable.clone();
-
-                       this.$headerTable.prependTo(this.$gridContainer).addClass('datagrid-stretch-header');
-                       this.$thead.detach().appendTo(this.$headerTable);
-
-                       this.$sizingHeader = this.$thead.clone();
-                       this.$sizingHeader.find('tr:first').remove();
-
-                       this.$footerTable.appendTo(this.$gridContainer).addClass('datagrid-stretch-footer');
-                       this.$tfoot.detach().appendTo(this.$footerTable);
-               },
-
-               stretchHeight: function () {
-                       if (!this.$gridContainer) return;
-
-                       this.setColumnWidths();
-
-                       var targetHeight = this.$gridContainer.height();
-                       var headerHeight = this.$headerTable.outerHeight();
-                       var footerHeight = this.$footerTable.outerHeight();
-                       var overhead = headerHeight + footerHeight;
-
-                       this.$stretchWrapper.height(targetHeight - overhead);
-               },
-
-               setColumnWidths: function () {
-                       if (!this.$sizingHeader) return;
-
-                       this.$element.prepend(this.$sizingHeader);
-
-                       var $sizingCells = this.$sizingHeader.find('th');
-                       var columnCount = $sizingCells.length;
-
-                       function matchSizingCellWidth(i, el) {
-                               if (i === columnCount - 1) return;
-
-                               var $el = $(el);
-                               var $sourceCell = $sizingCells.eq(i);
-                               var width = $sourceCell.width();
-
-                               // TD needs extra width to match sorted column header
-                               if ($sourceCell.hasClass('sorted') && $el.prop('tagName') === 'TD') width = width + SORTED_HEADER_OFFSET;
-
-                               $el.width(width);
-                       }
-
-                       this.$colheader.find('th').each(matchSizingCellWidth);
-                       this.$tbody.find('tr:first > td').each(matchSizingCellWidth);
-
-                       this.$sizingHeader.detach();
-               }
-       };
-
-
-       // DATAGRID PLUGIN DEFINITION
-
-       $.fn.datagrid = function (option) {
-               return this.each(function () {
-                       var $this = $(this);
-                       var data = $this.data('datagrid');
-                       var options = typeof option === 'object' && option;
-
-                       if (!data) $this.data('datagrid', (data = new Datagrid(this, options)));
-                       if (typeof option === 'string') data[option]();
-               });
-       };
-
-       $.fn.datagrid.defaults = {
-               dataOptions: { pageIndex: 0, pageSize: 10 },
-               loadingHTML: '<div class="progress progress-striped active" style="width:50%;margin:auto;"><div class="bar" style="width:100%;"></div></div>',
-               itemsText: 'items',
-               itemText: 'item'
-       };
-
-       $.fn.datagrid.Constructor = Datagrid;
-
-});
diff --git a/opendaylight/adsal/web/root/src/main/resources/js/fuelux/loader.min.js b/opendaylight/adsal/web/root/src/main/resources/js/fuelux/loader.min.js
deleted file mode 100755 (executable)
index fe68290..0000000
+++ /dev/null
@@ -1,4 +0,0 @@
-/*! Fuel UX - v2.3.1 - 2013-08-02
-* https://github.com/ExactTarget/fuelux
-* Copyright (c) 2013 ExactTarget; Licensed MIT */
-(function(){var a,b,c;(function(d){function l(a,b){var c,d,e,f,g,h,j,k,l,m,n=b&&b.split("/"),o=i.map,p=o&&o["*"]||{};if(a&&a.charAt(0)==="."&&b){n=n.slice(0,n.length-1),a=n.concat(a.split("/"));for(k=0;k<a.length;k+=1){m=a[k];if(m===".")a.splice(k,1),k-=1;else if(m==="..")if(k!==1||a[2]!==".."&&a[0]!=="..")k>0&&(a.splice(k-1,2),k-=2);else break}a=a.join("/")}if((n||p)&&o){c=a.split("/");for(k=c.length;k>0;k-=1){d=c.slice(0,k).join("/");if(n)for(l=n.length;l>0;l-=1){e=o[n.slice(0,l).join("/")];if(e){e=e[d];if(e){f=e,g=k;break}}}if(f)break;!h&&p&&p[d]&&(h=p[d],j=k)}!f&&h&&(f=h,g=j),f&&(c.splice(0,g,f),a=c.join("/"))}return a}function m(a,b){return function(){return f.apply(d,k.call(arguments,0).concat([a,b]))}}function n(a){return function(b){return l(b,a)}}function o(a){return function(b){g[a]=b}}function p(a){if(h.hasOwnProperty(a)){var b=h[a];delete h[a],j[a]=!0,e.apply(d,b)}if(!g.hasOwnProperty(a))throw new Error("No "+a);return g[a]}function q(a,b){var c,d,e=a.indexOf("!");return e!==-1?(c=l(a.slice(0,e),b),a=a.slice(e+1),d=p(c),d&&d.normalize?a=d.normalize(a,n(b)):a=l(a,b)):a=l(a,b),{f:c?c+"!"+a:a,n:a,p:d}}function r(a){return function(){return i&&i.config&&i.config[a]||{}}}var e,f,g={},h={},i={},j={},k=[].slice;e=function(a,b,c,e){var f,i,k,l,n,s=[],t;e=e||a;if(typeof c=="function"){b=!b.length&&c.length?["require","exports","module"]:b;for(n=0;n<b.length;n+=1){l=q(b[n],e),i=l.f;if(i==="require")s[n]=m(a);else if(i==="exports")s[n]=g[a]={},t=!0;else if(i==="module")f=s[n]={id:a,uri:"",exports:g[a],config:r(a)};else if(g.hasOwnProperty(i)||h.hasOwnProperty(i))s[n]=p(i);else if(l.p)l.p.load(l.n,m(e,!0),o(i),{}),s[n]=g[i];else if(!j[i])throw new Error(a+" missing "+i)}k=c.apply(g[a],s);if(a)if(f&&f.exports!==d&&f.exports!==g[a])g[a]=f.exports;else if(k!==d||!t)g[a]=k}else a&&(g[a]=c)},a=b=f=function(a,b,c,g,h){return typeof a=="string"?p(q(a,b).f):(a.splice||(i=a,b.splice?(a=b,b=c,c=null):a=d),b=b||function(){},typeof c=="function"&&(c=g,g=h),g?e(d,a,b,c):setTimeout(function(){e(d,a,b,c)},15),f)},f.config=function(a){return i=a,f},c=function(a,b,c){b.splice||(c=b,b=[]),h[a]=[a,b,c]},c.amd={jQuery:!0}})(),c("almond",function(){}),function(a){var b;c("bootstrap/bootstrap-transition",["jquery"],function(){return function(){!function(a){a(function(){a.support.transition=function(){var a=function(){var a=document.createElement("bootstrap"),b={WebkitTransition:"webkitTransitionEnd",MozTransition:"transitionend",OTransition:"oTransitionEnd otransitionend",transition:"transitionend"},c;for(c in b)if(a.style[c]!==undefined)return b[c]}();return a&&{end:a}}()})}(window.jQuery)}.call(a),b})}(this),function(a){var b;c("bootstrap/bootstrap-affix",["bootstrap/bootstrap-transition"],function(){return function(){!function(a){var b=function(b,c){this.options=a.extend({},a.fn.affix.defaults,c),this.$window=a(window).on("scroll.affix.data-api",a.proxy(this.checkPosition,this)).on("click.affix.data-api",a.proxy(function(){setTimeout(a.proxy(this.checkPosition,this),1)},this)),this.$element=a(b),this.checkPosition()};b.prototype.checkPosition=function(){if(!this.$element.is(":visible"))return;var b=a(document).height(),c=this.$window.scrollTop(),d=this.$element.offset(),e=this.options.offset,f=e.bottom,g=e.top,h="affix affix-top affix-bottom",i;typeof e!="object"&&(f=g=e),typeof g=="function"&&(g=e.top()),typeof f=="function"&&(f=e.bottom()),i=this.unpin!=null&&c+this.unpin<=d.top?!1:f!=null&&d.top+this.$element.height()>=b-f?"bottom":g!=null&&c<=g?"top":!1;if(this.affixed===i)return;this.affixed=i,this.unpin=i=="bottom"?d.top-c:null,this.$element.removeClass(h).addClass("affix"+(i?"-"+i:""))};var c=a.fn.affix;a.fn.affix=function(c){return this.each(function(){var d=a(this),e=d.data("affix"),f=typeof c=="object"&&c;e||d.data("affix",e=new b(this,f)),typeof c=="string"&&e[c]()})},a.fn.affix.Constructor=b,a.fn.affix.defaults={offset:0},a.fn.affix.noConflict=function(){return a.fn.affix=c,this},a(window).on("load",function(){a('[data-spy="affix"]').each(function(){var b=a(this),c=b.data();c.offset=c.offset||{},c.offsetBottom&&(c.offset.bottom=c.offsetBottom),c.offsetTop&&(c.offset.top=c.offsetTop),b.affix(c)})})}(window.jQuery)}.call(a),b})}(this),function(a){var b;c("bootstrap/bootstrap-alert",["bootstrap/bootstrap-transition"],function(){return function(){!function(a){var b='[data-dismiss="alert"]',c=function(c){a(c).on("click",b,this.close)};c.prototype.close=function(b){function f(){e.trigger("closed").remove()}var c=a(this),d=c.attr("data-target"),e;d||(d=c.attr("href"),d=d&&d.replace(/.*(?=#[^\s]*$)/,"")),e=a(d),b&&b.preventDefault(),e.length||(e=c.hasClass("alert")?c:c.parent()),e.trigger(b=a.Event("close"));if(b.isDefaultPrevented())return;e.removeClass("in"),a.support.transition&&e.hasClass("fade")?e.on(a.support.transition.end,f):f()};var d=a.fn.alert;a.fn.alert=function(b){return this.each(function(){var d=a(this),e=d.data("alert");e||d.data("alert",e=new c(this)),typeof b=="string"&&e[b].call(d)})},a.fn.alert.Constructor=c,a.fn.alert.noConflict=function(){return a.fn.alert=d,this},a(document).on("click.alert.data-api",b,c.prototype.close)}(window.jQuery)}.call(a),b})}(this),function(a){var b;c("bootstrap/bootstrap-button",["bootstrap/bootstrap-transition"],function(){return function(){!function(a){var b=function(b,c){this.$element=a(b),this.options=a.extend({},a.fn.button.defaults,c)};b.prototype.setState=function(a){var b="disabled",c=this.$element,d=c.data(),e=c.is("input")?"val":"html";a=a+"Text",d.resetText||c.data("resetText",c[e]()),c[e](d[a]||this.options[a]),setTimeout(function(){a=="loadingText"?c.addClass(b).attr(b,b):c.removeClass(b).removeAttr(b)},0)},b.prototype.toggle=function(){var a=this.$element.closest('[data-toggle="buttons-radio"]');a&&a.find(".active").removeClass("active"),this.$element.toggleClass("active")};var c=a.fn.button;a.fn.button=function(c){return this.each(function(){var d=a(this),e=d.data("button"),f=typeof c=="object"&&c;e||d.data("button",e=new b(this,f)),c=="toggle"?e.toggle():c&&e.setState(c)})},a.fn.button.defaults={loadingText:"loading..."},a.fn.button.Constructor=b,a.fn.button.noConflict=function(){return a.fn.button=c,this},a(document).on("click.button.data-api","[data-toggle^=button]",function(b){var c=a(b.target);c.hasClass("btn")||(c=c.closest(".btn")),c.button("toggle")})}(window.jQuery)}.call(a),b})}(this),function(a){var b;c("bootstrap/bootstrap-carousel",["bootstrap/bootstrap-transition"],function(){return function(){!function(a){var b=function(b,c){this.$element=a(b),this.$indicators=this.$element.find(".carousel-indicators"),this.options=c,this.options.pause=="hover"&&this.$element.on("mouseenter",a.proxy(this.pause,this)).on("mouseleave",a.proxy(this.cycle,this))};b.prototype={cycle:function(b){return b||(this.paused=!1),this.interval&&clearInterval(this.interval),this.options.interval&&!this.paused&&(this.interval=setInterval(a.proxy(this.next,this),this.options.interval)),this},getActiveIndex:function(){return this.$active=this.$element.find(".item.active"),this.$items=this.$active.parent().children(),this.$items.index(this.$active)},to:function(b){var c=this.getActiveIndex(),d=this;if(b>this.$items.length-1||b<0)return;return this.sliding?this.$element.one("slid",function(){d.to(b)}):c==b?this.pause().cycle():this.slide(b>c?"next":"prev",a(this.$items[b]))},pause:function(b){return b||(this.paused=!0),this.$element.find(".next, .prev").length&&a.support.transition.end&&(this.$element.trigger(a.support.transition.end),this.cycle(!0)),clearInterval(this.interval),this.interval=null,this},next:function(){if(this.sliding)return;return this.slide("next")},prev:function(){if(this.sliding)return;return this.slide("prev")},slide:function(b,c){var d=this.$element.find(".item.active"),e=c||d[b](),f=this.interval,g=b=="next"?"left":"right",h=b=="next"?"first":"last",i=this,j;this.sliding=!0,f&&this.pause(),e=e.length?e:this.$element.find(".item")[h](),j=a.Event("slide",{relatedTarget:e[0],direction:g});if(e.hasClass("active"))return;this.$indicators.length&&(this.$indicators.find(".active").removeClass("active"),this.$element.one("slid",function(){var b=a(i.$indicators.children()[i.getActiveIndex()]);b&&b.addClass("active")}));if(a.support.transition&&this.$element.hasClass("slide")){this.$element.trigger(j);if(j.isDefaultPrevented())return;e.addClass(b),e[0].offsetWidth,d.addClass(g),e.addClass(g),this.$element.one(a.support.transition.end,function(){e.removeClass([b,g].join(" ")).addClass("active"),d.removeClass(["active",g].join(" ")),i.sliding=!1,setTimeout(function(){i.$element.trigger("slid")},0)})}else{this.$element.trigger(j);if(j.isDefaultPrevented())return;d.removeClass("active"),e.addClass("active"),this.sliding=!1,this.$element.trigger("slid")}return f&&this.cycle(),this}};var c=a.fn.carousel;a.fn.carousel=function(c){return this.each(function(){var d=a(this),e=d.data("carousel"),f=a.extend({},a.fn.carousel.defaults,typeof c=="object"&&c),g=typeof c=="string"?c:f.slide;e||d.data("carousel",e=new b(this,f)),typeof c=="number"?e.to(c):g?e[g]():f.interval&&e.pause().cycle()})},a.fn.carousel.defaults={interval:5e3,pause:"hover"},a.fn.carousel.Constructor=b,a.fn.carousel.noConflict=function(){return a.fn.carousel=c,this},a(document).on("click.carousel.data-api","[data-slide], [data-slide-to]",function(b){var c=a(this),d,e=a(c.attr("data-target")||(d=c.attr("href"))&&d.replace(/.*(?=#[^\s]+$)/,"")),f=a.extend({},e.data(),c.data()),g;e.carousel(f),(g=c.attr("data-slide-to"))&&e.data("carousel").pause().to(g).cycle(),b.preventDefault()})}(window.jQuery)}.call(a),b})}(this),function(a){var b;c("bootstrap/bootstrap-collapse",["bootstrap/bootstrap-transition"],function(){return function(){!function(a){var b=function(b,c){this.$element=a(b),this.options=a.extend({},a.fn.collapse.defaults,c),this.options.parent&&(this.$parent=a(this.options.parent)),this.options.toggle&&this.toggle()};b.prototype={constructor:b,dimension:function(){var a=this.$element.hasClass("width");return a?"width":"height"},show:function(){var b,c,d,e;if(this.transitioning||this.$element.hasClass("in"))return;b=this.dimension(),c=a.camelCase(["scroll",b].join("-")),d=this.$parent&&this.$parent.find("> .accordion-group > .in");if(d&&d.length){e=d.data("collapse");if(e&&e.transitioning)return;d.collapse("hide"),e||d.data("collapse",null)}this.$element[b](0),this.transition("addClass",a.Event("show"),"shown"),a.support.transition&&this.$element[b](this.$element[0][c])},hide:function(){var b;if(this.transitioning||!this.$element.hasClass("in"))return;b=this.dimension(),this.reset(this.$element[b]()),this.transition("removeClass",a.Event("hide"),"hidden"),this.$element[b](0)},reset:function(a){var b=this.dimension();return this.$element.removeClass("collapse")[b](a||"auto")[0].offsetWidth,this.$element[a!==null?"addClass":"removeClass"]("collapse"),this},transition:function(b,c,d){var e=this,f=function(){c.type=="show"&&e.reset(),e.transitioning=0,e.$element.trigger(d)};this.$element.trigger(c);if(c.isDefaultPrevented())return;this.transitioning=1,this.$element[b]("in"),a.support.transition&&this.$element.hasClass("collapse")?this.$element.one(a.support.transition.end,f):f()},toggle:function(){this[this.$element.hasClass("in")?"hide":"show"]()}};var c=a.fn.collapse;a.fn.collapse=function(c){return this.each(function(){var d=a(this),e=d.data("collapse"),f=a.extend({},a.fn.collapse.defaults,d.data(),typeof c=="object"&&c);e||d.data("collapse",e=new b(this,f)),typeof c=="string"&&e[c]()})},a.fn.collapse.defaults={toggle:!0},a.fn.collapse.Constructor=b,a.fn.collapse.noConflict=function(){return a.fn.collapse=c,this},a(document).on("click.collapse.data-api","[data-toggle=collapse]",function(b){var c=a(this),d,e=c.attr("data-target")||b.preventDefault()||(d=c.attr("href"))&&d.replace(/.*(?=#[^\s]+$)/,""),f=a(e).data("collapse")?"toggle":c.data();c[a(e).hasClass("in")?"addClass":"removeClass"]("collapsed"),a(e).collapse(f)})}(window.jQuery)}.call(a),b})}(this),function(a){var b;c("bootstrap/bootstrap-dropdown",["bootstrap/bootstrap-transition"],function(){return function(){!function(a){function d(){a(".dropdown-backdrop").remove(),a(b).each(function(){e(a(this)).removeClass("open")})}function e(b){var c=b.attr("data-target"),d;c||(c=b.attr("href"),c=c&&/#/.test(c)&&c.replace(/.*(?=#[^\s]*$)/,"")),d=c&&a(c);if(!d||!d.length)d=b.parent();return d}var b="[data-toggle=dropdown]",c=function(b){var c=a(b).on("click.dropdown.data-api",this.toggle);a("html").on("click.dropdown.data-api",function(){c.parent().removeClass("open")})};c.prototype={constructor:c,toggle:function(b){var c=a(this),f,g;if(c.is(".disabled, :disabled"))return;return f=e(c),g=f.hasClass("open"),d(),g||("ontouchstart"in document.documentElement&&a('<div class="dropdown-backdrop"/>').insertBefore(a(this)).on("click",d),f.toggleClass("open")),c.focus(),!1},keydown:function(c){var d,f,g,h,i,j;if(!/(38|40|27)/.test(c.keyCode))return;d=a(this),c.preventDefault(),c.stopPropagation();if(d.is(".disabled, :disabled"))return;h=e(d),i=h.hasClass("open");if(!i||i&&c.keyCode==27)return c.which==27&&h.find(b).focus(),d.click();f=a("[role=menu] li:not(.divider):visible a",h);if(!f.length)return;j=f.index(f.filter(":focus")),c.keyCode==38&&j>0&&j--,c.keyCode==40&&j<f.length-1&&j++,~j||(j=0),f.eq(j).focus()}};var f=a.fn.dropdown;a.fn.dropdown=function(b){return this.each(function(){var d=a(this),e=d.data("dropdown");e||d.data("dropdown",e=new c(this)),typeof b=="string"&&e[b].call(d)})},a.fn.dropdown.Constructor=c,a.fn.dropdown.noConflict=function(){return a.fn.dropdown=f,this},a(document).on("click.dropdown.data-api",d).on("click.dropdown.data-api",".dropdown form",function(a){a.stopPropagation()}).on("click.dropdown.data-api",b,c.prototype.toggle).on("keydown.dropdown.data-api",b+", [role=menu]",c.prototype.keydown)}(window.jQuery)}.call(a),b})}(this),function(a){var b;c("bootstrap/bootstrap-modal",["bootstrap/bootstrap-transition"],function(){return function(){!function(a){var b=function(b,c){this.options=c,this.$element=a(b).delegate('[data-dismiss="modal"]',"click.dismiss.modal",a.proxy(this.hide,this)),this.options.remote&&this.$element.find(".modal-body").load(this.options.remote)};b.prototype={constructor:b,toggle:function(){return this[this.isShown?"hide":"show"]()},show:function(){var b=this,c=a.Event("show");this.$element.trigger(c);if(this.isShown||c.isDefaultPrevented())return;this.isShown=!0,this.escape(),this.backdrop(function(){var c=a.support.transition&&b.$element.hasClass("fade");b.$element.parent().length||b.$element.appendTo(document.body),b.$element.show(),c&&b.$element[0].offsetWidth,b.$element.addClass("in").attr("aria-hidden",!1),b.enforceFocus(),c?b.$element.one(a.support.transition.end,function(){b.$element.focus().trigger("shown")}):b.$element.focus().trigger("shown")})},hide:function(b){b&&b.preventDefault();var c=this;b=a.Event("hide"),this.$element.trigger(b);if(!this.isShown||b.isDefaultPrevented())return;this.isShown=!1,this.escape(),a(document).off("focusin.modal"),this.$element.removeClass("in").attr("aria-hidden",!0),a.support.transition&&this.$element.hasClass("fade")?this.hideWithTransition():this.hideModal()},enforceFocus:function(){var b=this;a(document).on("focusin.modal",function(a){b.$element[0]!==a.target&&!b.$element.has(a.target).length&&b.$element.focus()})},escape:function(){var a=this;this.isShown&&this.options.keyboard?this.$element.on("keyup.dismiss.modal",function(b){b.which==27&&a.hide()}):this.isShown||this.$element.off("keyup.dismiss.modal")},hideWithTransition:function(){var b=this,c=setTimeout(function(){b.$element.off(a.support.transition.end),b.hideModal()},500);this.$element.one(a.support.transition.end,function(){clearTimeout(c),b.hideModal()})},hideModal:function(){var a=this;this.$element.hide(),this.backdrop(function(){a.removeBackdrop(),a.$element.trigger("hidden")})},removeBackdrop:function(){this.$backdrop&&this.$backdrop.remove(),this.$backdrop=null},backdrop:function(b){var c=this,d=this.$element.hasClass("fade")?"fade":"";if(this.isShown&&this.options.backdrop){var e=a.support.transition&&d;this.$backdrop=a('<div class="modal-backdrop '+d+'" />').appendTo(document.body),this.$backdrop.click(this.options.backdrop=="static"?a.proxy(this.$element[0].focus,this.$element[0]):a.proxy(this.hide,this)),e&&this.$backdrop[0].offsetWidth,this.$backdrop.addClass("in");if(!b)return;e?this.$backdrop.one(a.support.transition.end,b):b()}else!this.isShown&&this.$backdrop?(this.$backdrop.removeClass("in"),a.support.transition&&this.$element.hasClass("fade")?this.$backdrop.one(a.support.transition.end,b):b()):b&&b()}};var c=a.fn.modal;a.fn.modal=function(c){return this.each(function(){var d=a(this),e=d.data("modal"),f=a.extend({},a.fn.modal.defaults,d.data(),typeof c=="object"&&c);e||d.data("modal",e=new b(this,f)),typeof c=="string"?e[c]():f.show&&e.show()})},a.fn.modal.defaults={backdrop:!0,keyboard:!0,show:!0},a.fn.modal.Constructor=b,a.fn.modal.noConflict=function(){return a.fn.modal=c,this},a(document).on("click.modal.data-api",'[data-toggle="modal"]',function(b){var c=a(this),d=c.attr("href"),e=a(c.attr("data-target")||d&&d.replace(/.*(?=#[^\s]+$)/,"")),f=e.data("modal")?"toggle":a.extend({remote:!/#/.test(d)&&d},e.data(),c.data());b.preventDefault(),e.modal(f).one("hide",function(){c.focus()})})}(window.jQuery)}.call(a),b})}(this),function(a){var b;c("bootstrap/bootstrap-tooltip",["bootstrap/bootstrap-transition"],function(){return function(){!function(a){var b=function(a,b){this.init("tooltip",a,b)};b.prototype={constructor:b,init:function(b,c,d){var e,f,g,h,i;this.type=b,this.$element=a(c),this.options=this.getOptions(d),this.enabled=!0,g=this.options.trigger.split(" ");for(i=g.length;i--;)h=g[i],h=="click"?this.$element.on("click."+this.type,this.options.selector,a.proxy(this.toggle,this)):h!="manual"&&(e=h=="hover"?"mouseenter":"focus",f=h=="hover"?"mouseleave":"blur",this.$element.on(e+"."+this.type,this.options.selector,a.proxy(this.enter,this)),this.$element.on(f+"."+this.type,this.options.selector,a.proxy(this.leave,this)));this.options.selector?this._options=a.extend({},this.options,{trigger:"manual",selector:""}):this.fixTitle()},getOptions:function(b){return b=a.extend({},a.fn[this.type].defaults,this.$element.data(),b),b.delay&&typeof b.delay=="number"&&(b.delay={show:b.delay,hide:b.delay}),b},enter:function(b){var c=a.fn[this.type].defaults,d={},e;this._options&&a.each(this._options,function(a,b){c[a]!=b&&(d[a]=b)}),e=a(b.currentTarget)[this.type](d).data(this.type);if(!e.options.delay||!e.options.delay.show)return e.show();clearTimeout(this.timeout),e.hoverState="in",this.timeout=setTimeout(function(){e.hoverState=="in"&&e.show()},e.options.delay.show)},leave:function(b){var c=a(b.currentTarget)[this.type](this._options).data(this.type);this.timeout&&clearTimeout(this.timeout);if(!c.options.delay||!c.options.delay.hide)return c.hide();c.hoverState="out",this.timeout=setTimeout(function(){c.hoverState=="out"&&c.hide()},c.options.delay.hide)},show:function(){var b,c,d,e,f,g,h=a.Event("show");if(this.hasContent()&&this.enabled){this.$element.trigger(h);if(h.isDefaultPrevented())return;b=this.tip(),this.setContent(),this.options.animation&&b.addClass("fade"),f=typeof this.options.placement=="function"?this.options.placement.call(this,b[0],this.$element[0]):this.options.placement,b.detach().css({top:0,left:0,display:"block"}),this.options.container?b.appendTo(this.options.container):b.insertAfter(this.$element),c=this.getPosition(),d=b[0].offsetWidth,e=b[0].offsetHeight;switch(f){case"bottom":g={top:c.top+c.height,left:c.left+c.width/2-d/2};break;case"top":g={top:c.top-e,left:c.left+c.width/2-d/2};break;case"left":g={top:c.top+c.height/2-e/2,left:c.left-d};break;case"right":g={top:c.top+c.height/2-e/2,left:c.left+c.width}}this.applyPlacement(g,f),this.$element.trigger("shown")}},applyPlacement:function(a,b){var c=this.tip(),d=c[0].offsetWidth,e=c[0].offsetHeight,f,g,h,i;c.offset(a).addClass(b).addClass("in"),f=c[0].offsetWidth,g=c[0].offsetHeight,b=="top"&&g!=e&&(a.top=a.top+e-g,i=!0),b=="bottom"||b=="top"?(h=0,a.left<0&&(h=a.left*-2,a.left=0,c.offset(a),f=c[0].offsetWidth,g=c[0].offsetHeight),this.replaceArrow(h-d+f,f,"left")):this.replaceArrow(g-e,g,"top"),i&&c.offset(a)},replaceArrow:function(a,b,c){this.arrow().css(c,a?50*(1-a/b)+"%":"")},setContent:function(){var a=this.tip(),b=this.getTitle();a.find(".tooltip-inner")[this.options.html?"html":"text"](b),a.removeClass("fade in top bottom left right")},hide:function(){function e(){var b=setTimeout(function(){c.off(a.support.transition.end).detach()},500);c.one(a.support.transition.end,function(){clearTimeout(b),c.detach()})}var b=this,c=this.tip(),d=a.Event("hide");this.$element.trigger(d);if(d.isDefaultPrevented())return;return c.removeClass("in"),a.support.transition&&this.$tip.hasClass("fade")?e():c.detach(),this.$element.trigger("hidden"),this},fixTitle:function(){var a=this.$element;(a.attr("title")||typeof a.attr("data-original-title")!="string")&&a.attr("data-original-title",a.attr("title")||"").attr("title","")},hasContent:function(){return this.getTitle()},getPosition:function(){var b=this.$element[0];return a.extend({},typeof b.getBoundingClientRect=="function"?b.getBoundingClientRect():{width:b.offsetWidth,height:b.offsetHeight},this.$element.offset())},getTitle:function(){var a,b=this.$element,c=this.options;return a=b.attr("data-original-title")||(typeof c.title=="function"?c.title.call(b[0]):c.title),a},tip:function(){return this.$tip=this.$tip||a(this.options.template)},arrow:function(){return this.$arrow=this.$arrow||this.tip().find(".tooltip-arrow")},validate:function(){this.$element[0].parentNode||(this.hide(),this.$element=null,this.options=null)},enable:function(){this.enabled=!0},disable:function(){this.enabled=!1},toggleEnabled:function(){this.enabled=!this.enabled},toggle:function(b){var c=b?a(b.currentTarget)[this.type](this._options).data(this.type):this;c.tip().hasClass("in")?c.hide():c.show()},destroy:function(){this.hide().$element.off("."+this.type).removeData(this.type)}};var c=a.fn.tooltip;a.fn.tooltip=function(c){return this.each(function(){var d=a(this),e=d.data("tooltip"),f=typeof c=="object"&&c;e||d.data("tooltip",e=new b(this,f)),typeof c=="string"&&e[c]()})},a.fn.tooltip.Constructor=b,a.fn.tooltip.defaults={animation:!0,placement:"top",selector:!1,template:'<div class="tooltip"><div class="tooltip-arrow"></div><div class="tooltip-inner"></div></div>',trigger:"hover focus",title:"",delay:0,html:!1,container:!1},a.fn.tooltip.noConflict=function(){return a.fn.tooltip=c,this}}(window.jQuery)}.call(a),b})}(this),function(a){var b;c("bootstrap/bootstrap-popover",["bootstrap/bootstrap-transition","bootstrap/bootstrap-tooltip"],function(){return function(){!function(a){var b=function(a,b){this.init("popover",a,b)};b.prototype=a.extend({},a.fn.tooltip.Constructor.prototype,{constructor:b,setContent:function(){var a=this.tip(),b=this.getTitle(),c=this.getContent();a.find(".popover-title")[this.options.html?"html":"text"](b),a.find(".popover-content")[this.options.html?"html":"text"](c),a.removeClass("fade top bottom left right in")},hasContent:function(){return this.getTitle()||this.getContent()},getContent:function(){var a,b=this.$element,c=this.options;return a=(typeof c.content=="function"?c.content.call(b[0]):c.content)||b.attr("data-content"),a},tip:function(){return this.$tip||(this.$tip=a(this.options.template)),this.$tip},destroy:function(){this.hide().$element.off("."+this.type).removeData(this.type)}});var c=a.fn.popover;a.fn.popover=function(c){return this.each(function(){var d=a(this),e=d.data("popover"),f=typeof c=="object"&&c;e||d.data("popover",e=new b(this,f)),typeof c=="string"&&e[c]()})},a.fn.popover.Constructor=b,a.fn.popover.defaults=a.extend({},a.fn.tooltip.defaults,{placement:"right",trigger:"click",content:"",template:'<div class="popover"><div class="arrow"></div><h3 class="popover-title"></h3><div class="popover-content"></div></div>'}),a.fn.popover.noConflict=function(){return a.fn.popover=c,this}}(window.jQuery)}.call(a),b})}(this),function(a){var b;c("bootstrap/bootstrap-scrollspy",["bootstrap/bootstrap-transition"],function(){return function(){!function(a){function b(b,c){var d=a.proxy(this.process,this),e=a(b).is("body")?a(window):a(b),f;this.options=a.extend({},a.fn.scrollspy.defaults,c),this.$scrollElement=e.on("scroll.scroll-spy.data-api",d),this.selector=(this.options.target||(f=a(b).attr("href"))&&f.replace(/.*(?=#[^\s]+$)/,"")||"")+" .nav li > a",this.$body=a("body"),this.refresh(),this.process()}b.prototype={constructor:b,refresh:function(){var b=this,c;this.offsets=a([]),this.targets=a([]),c=this.$body.find(this.selector).map(function(){var c=a(this),d=c.data("target")||c.attr("href"),e=/^#\w/.test(d)&&a(d);return e&&e.length&&[[e.position().top+(!a.isWindow(b.$scrollElement.get(0))&&b.$scrollElement.scrollTop()),d]]||null}).sort(function(a,b){return a[0]-b[0]}).each(function(){b.offsets.push(this[0]),b.targets.push(this[1])})},process:function(){var a=this.$scrollElement.scrollTop()+this.options.offset,b=this.$scrollElement[0].scrollHeight||this.$body[0].scrollHeight,c=b-this.$scrollElement.height(),d=this.offsets,e=this.targets,f=this.activeTarget,g;if(a>=c)return f!=(g=e.last()[0])&&this.activate(g);for(g=d.length;g--;)f!=e[g]&&a>=d[g]&&(!d[g+1]||a<=d[g+1])&&this.activate(e[g])},activate:function(b){var c,d;this.activeTarget=b,a(this.selector).parent(".active").removeClass("active"),d=this.selector+'[data-target="'+b+'"],'+this.selector+'[href="'+b+'"]',c=a(d).parent("li").addClass("active"),c.parent(".dropdown-menu").length&&(c=c.closest("li.dropdown").addClass("active")),c.trigger("activate")}};var c=a.fn.scrollspy;a.fn.scrollspy=function(c){return this.each(function(){var d=a(this),e=d.data("scrollspy"),f=typeof c=="object"&&c;e||d.data("scrollspy",e=new b(this,f)),typeof c=="string"&&e[c]()})},a.fn.scrollspy.Constructor=b,a.fn.scrollspy.defaults={offset:10},a.fn.scrollspy.noConflict=function(){return a.fn.scrollspy=c,this},a(window).on("load",function(){a('[data-spy="scroll"]').each(function(){var b=a(this);b.scrollspy(b.data())})})}(window.jQuery)}.call(a),b})}(this),function(a){var b;c("bootstrap/bootstrap-tab",["bootstrap/bootstrap-transition"],function(){return function(){!function(a){var b=function(b){this.element=a(b)};b.prototype={constructor:b,show:function(){var b=this.element,c=b.closest("ul:not(.dropdown-menu)"),d=b.attr("data-target"),e,f,g;d||(d=b.attr("href"),d=d&&d.replace(/.*(?=#[^\s]*$)/,""));if(b.parent("li").hasClass("active"))return;e=c.find(".active:last a")[0],g=a.Event("show",{relatedTarget:e}),b.trigger(g);if(g.isDefaultPrevented())return;f=a(d),this.activate(b.parent("li"),c),this.activate(f,f.parent(),function(){b.trigger({type:"shown",relatedTarget:e})})},activate:function(b,c,d){function g(){e.removeClass("active").find("> .dropdown-menu > .active").removeClass("active"),b.addClass("active"),f?(b[0].offsetWidth,b.addClass("in")):b.removeClass("fade"),b.parent(".dropdown-menu")&&b.closest("li.dropdown").addClass("active"),d&&d()}var e=c.find("> .active"),f=d&&a.support.transition&&e.hasClass("fade");f?e.one(a.support.transition.end,g):g(),e.removeClass("in")}};var c=a.fn.tab;a.fn.tab=function(c){return this.each(function(){var d=a(this),e=d.data("tab");e||d.data("tab",e=new b(this)),typeof c=="string"&&e[c]()})},a.fn.tab.Constructor=b,a.fn.tab.noConflict=function(){return a.fn.tab=c,this},a(document).on("click.tab.data-api",'[data-toggle="tab"], [data-toggle="pill"]',function(b){b.preventDefault(),a(this).tab("show")})}(window.jQuery)}.call(a),b})}(this),function(a){var b;c("bootstrap/bootstrap-typeahead",["bootstrap/bootstrap-transition"],function(){return function(){!function(a){var b=function(b,c){this.$element=a(b),this.options=a.extend({},a.fn.typeahead.defaults,c),this.matcher=this.options.matcher||this.matcher,this.sorter=this.options.sorter||this.sorter,this.highlighter=this.options.highlighter||this.highlighter,this.updater=this.options.updater||this.updater,this.source=this.options.source,this.$menu=a(this.options.menu),this.shown=!1,this.listen()};b.prototype={constructor:b,select:function(){var a=this.$menu.find(".active").attr("data-value");return this.$element.val(this.updater(a)).change(),this.hide()},updater:function(a){return a},show:function(){var b=a.extend({},this.$element.position(),{height:this.$element[0].offsetHeight});return this.$menu.insertAfter(this.$element).css({top:b.top+b.height,left:b.left}).show(),this.shown=!0,this},hide:function(){return this.$menu.hide(),this.shown=!1,this},lookup:function(b){var c;return this.query=this.$element.val(),!this.query||this.query.length<this.options.minLength?this.shown?this.hide():this:(c=a.isFunction(this.source)?this.source(this.query,a.proxy(this.process,this)):this.source,c?this.process(c):this)},process:function(b){var c=this;return b=a.grep(b,function(a){return c.matcher(a)}),b=this.sorter(b),b.length?this.render(b.slice(0,this.options.items)).show():this.shown?this.hide():this},matcher:function(a){return~a.toLowerCase().indexOf(this.query.toLowerCase())},sorter:function(a){var b=[],c=[],d=[],e;while(e=a.shift())e.toLowerCase().indexOf(this.query.toLowerCase())?~e.indexOf(this.query)?c.push(e):d.push(e):b.push(e);return b.concat(c,d)},highlighter:function(a){var b=this.query.replace(/[\-\[\]{}()*+?.,\\\^$|#\s]/g,"\\$&");return a.replace(new RegExp("("+b+")","ig"),function(a,b){return"<strong>"+b+"</strong>"})},render:function(b){var c=this;return b=a(b).map(function(b,d){return b=a(c.options.item).attr("data-value",d),b.find("a").html(c.highlighter(d)),b[0]}),b.first().addClass("active"),this.$menu.html(b),this},next:function(b){var c=this.$menu.find(".active").removeClass("active"),d=c.next();d.length||(d=a(this.$menu.find("li")[0])),d.addClass("active")},prev:function(a){var b=this.$menu.find(".active").removeClass("active"),c=b.prev();c.length||(c=this.$menu.find("li").last()),c.addClass("active")},listen:function(){this.$element.on("focus",a.proxy(this.focus,this)).on("blur",a.proxy(this.blur,this)).on("keypress",a.proxy(this.keypress,this)).on("keyup",a.proxy(this.keyup,this)),this.eventSupported("keydown")&&this.$element.on("keydown",a.proxy(this.keydown,this)),this.$menu.on("click",a.proxy(this.click,this)).on("mouseenter","li",a.proxy(this.mouseenter,this)).on("mouseleave","li",a.proxy(this.mouseleave,this))},eventSupported:function(a){var b=a in this.$element;return b||(this.$element.setAttribute(a,"return;"),b=typeof this.$element[a]=="function"),b},move:function(a){if(!this.shown)return;switch(a.keyCode){case 9:case 13:case 27:a.preventDefault();break;case 38:a.preventDefault(),this.prev();break;case 40:a.preventDefault(),this.next()}a.stopPropagation()},keydown:function(b){this.suppressKeyPressRepeat=~a.inArray(b.keyCode,[40,38,9,13,27]),this.move(b)},keypress:function(a){if(this.suppressKeyPressRepeat)return;this.move(a)},keyup:function(a){switch(a.keyCode){case 40:case 38:case 16:case 17:case 18:break;case 9:case 13:if(!this.shown)return;this.select();break;case 27:if(!this.shown)return;this.hide();break;default:this.lookup()}a.stopPropagation(),a.preventDefault()},focus:function(a){this.focused=!0},blur:function(a){this.focused=!1,!this.mousedover&&this.shown&&this.hide()},click:function(a){a.stopPropagation(),a.preventDefault(),this.select(),this.$element.focus()},mouseenter:function(b){this.mousedover=!0,this.$menu.find(".active").removeClass("active"),a(b.currentTarget).addClass("active")},mouseleave:function(a){this.mousedover=!1,!this.focused&&this.shown&&this.hide()}};var c=a.fn.typeahead;a.fn.typeahead=function(c){return this.each(function(){var d=a(this),e=d.data("typeahead"),f=typeof c=="object"&&c;e||d.data("typeahead",e=new b(this,f)),typeof c=="string"&&e[c]()})},a.fn.typeahead.defaults={source:[],items:8,menu:'<ul class="typeahead dropdown-menu"></ul>',item:'<li><a href="#"></a></li>',minLength:1},a.fn.typeahead.Constructor=b,a.fn.typeahead.noConflict=function(){return a.fn.typeahead=c,this},a(document).on("focus.typeahead.data-api",'[data-provide="typeahead"]',function(b){var c=a(this);if(c.data("typeahead"))return;c.typeahead(c.data())})}(window.jQuery)}.call(a),b})}(this),c("fuelux/checkbox",["require","jquery"],function(a){var b=a("jquery"),c=function(a,c){this.$element=b(a),this.options=b.extend({},b.fn.checkbox.defaults,c),this.$label=this.$element.parent(),this.$icon=this.$label.find("i"),this.$chk=this.$label.find("input[type=checkbox]"),this.setState(this.$chk),this.$chk.on("change",b.proxy(this.itemchecked,this))};c.prototype={constructor:c,setState:function(a){var b=a.is(":checked"),c=a.is(":disabled");this.$icon.removeClass("checked").removeClass("disabled"),b===!0&&this.$icon.addClass("checked"),c===!0&&this.$icon.addClass("disabled")},enable:function(){this.$chk.attr("disabled",!1),this.$icon.removeClass("disabled")},disable:function(){this.$chk.attr("disabled",!0),this.$icon.addClass("disabled")},toggle:function(){this.$chk.click()},itemchecked:function(a){var c=b(a.target);this.setState(c)}},b.fn.checkbox=function(a,d){var e,f=this.each(function(){var f=b(this),g=f.data("checkbox"),h=typeof a=="object"&&a;g||f.data("checkbox",g=new c(this,h)),typeof a=="string"&&(e=g[a](d))});return e===undefined?f:e},b.fn.checkbox.defaults={},b.fn.checkbox.Constructor=c,b(function(){b(window).on("load",function(){b(".checkbox-custom > input[type=checkbox]").each(function(){var a=b(this);if(a.data("checkbox"))return;a.checkbox(a.data())})})})}),c("fuelux/util",["require","jquery"],function(a){function c(a,c){return(a.textContent||a.innerText||b(a).text()||"").toLowerCase()===(c||"").toLowerCase()}var b=a("jquery");b.expr[":"].fuelTextExactCI=b.expr.createPseudo?b.expr.createPseudo(function(a){return function(b){return c(b,a)}}):function(a,b,d){return c(a,d[3])}}),c("fuelux/combobox",["require","jquery","./util"],function(a){var b=a("jquery");a("./util");var c=function(a,c){this.$element=b(a),this.options=b.extend({},b.fn.combobox.defaults,c),this.$element.on("click","a",b.proxy(this.itemclicked,this)),this.$element.on("change","input",b.proxy(this.inputchanged,this)),this.$input=this.$element.find("input"),this.$button=this.$element.find(".btn"),this.setDefaultSelection()};c.prototype={constructor:c,selectedItem:function(){var a=this.$selectedItem,c={};if(a){var d=this.$selectedItem.text();c=b.extend({text:d},this.$selectedItem.data())}else c={text:this.$input.val()};return c},selectByText:function(a){var b="li:fuelTextExactCI("+a+")";this.selectBySelector(b)},selectByValue:function(a){var b='li[data-value="'+a+'"]';this.selectBySelector(b)},selectByIndex:function(a){var b="li:eq("+a+")";this.selectBySelector(b)},selectBySelector:function(a){var b=this.$element.find(a);typeof b[0]!="undefined"?(this.$selectedItem=b,this.$input.val(this.$selectedItem.text())):this.$selectedItem=null},setDefaultSelection:function(){var a="li[data-selected=true]:first",b=this.$element.find(a);b.length>0&&(this.selectBySelector(a),b.removeData("selected"),b.removeAttr("data-selected"))},enable:function(){this.$input.removeAttr("disabled"),this.$button.removeClass("disabled")},disable:function(){this.$input.attr("disabled",!0),this.$button.addClass("disabled")},itemclicked:function(a){this.$selectedItem=b(a.target).parent(),this.$input.val(this.$selectedItem.text()).trigger("change",{synthetic:!0});var c=this.selectedItem();this.$element.trigger("changed",c),a.preventDefault()},inputchanged:function(a,c){if(c&&c.synthetic)return;var d=b(a.target).val();this.selectByText(d);var e=this.selectedItem();e.text.length===0&&(e={text:d}),this.$element.trigger("changed",e)}},b.fn.combobox=function(a,d){var e,f=this.each(function(){var f=b(this),g=f.data("combobox"),h=typeof a=="object"&&a;g||f.data("combobox",g=new c(this,h)),typeof a=="string"&&(e=g[a](d))});return e===undefined?f:e},b.fn.combobox.defaults={},b.fn.combobox.Constructor=c,b(function(){b(window).on("load",function(){b(".combobox").each(function(){var a=b(this);if(a.data("combobox"))return;a.combobox(a.data())})}),b("body").on("mousedown.combobox.data-api",".combobox",function(a){var c=b(this);if(c.data("combobox"))return;c.combobox(c.data())})})}),c("fuelux/datagrid",["require","jquery"],function(a){var b=a("jquery"),c=22,d=function(a,c){this.$element=b(a),this.$thead=this.$element.find("thead"),this.$tfoot=this.$element.find("tfoot"),this.$footer=this.$element.find("tfoot th"),this.$footerchildren=this.$footer.children().show().css("visibility","hidden"),this.$topheader=this.$element.find("thead th"),this.$searchcontrol=this.$element.find(".datagrid-search"),this.$filtercontrol=this.$element.find(".filter"),this.$pagesize=this.$element.find(".grid-pagesize"),this.$pageinput=this.$element.find(".grid-pager input"),this.$pagedropdown=this.$element.find(".grid-pager .dropdown-menu"),this.$prevpagebtn=this.$element.find(".grid-prevpage"),this.$nextpagebtn=this.$element.find(".grid-nextpage"),this.$pageslabel=this.$element.find(".grid-pages"),this.$countlabel=this.$element.find(".grid-count"),this.$startlabel=this.$element.find(".grid-start"),this.$endlabel=this.$element.find(".grid-end"),this.$tbody=b("<tbody>").insertAfter(this.$thead),this.$colheader=b("<tr>").appendTo(this.$thead),this.options=b.extend(!0,{},b.fn.datagrid.defaults,c),this.$pagesize.hasClass("select")?this.options.dataOptions.pageSize=parseInt(this.$pagesize.select("selectedItem").value,10):this.options.dataOptions.pageSize=parseInt(this.$pagesize.val(),10),this.$searchcontrol.length<=0&&(this.$searchcontrol=this.$element.find(".search")),this.columns=this.options.dataSource.columns(),this.$nextpagebtn.on("click",b.proxy(this.next,this)),this.$prevpagebtn.on("click",b.proxy(this.previous,this)),this.$searchcontrol.on("searched cleared",b.proxy(this.searchChanged,this)),this.$filtercontrol.on("changed",b.proxy(this.filterChanged,this)),this.$colheader.on("click","th",b.proxy(this.headerClicked,this)),this.$pagesize.hasClass("select")?this.$pagesize.on("changed",b.proxy(this.pagesizeChanged,this)):this.$pagesize.on("change",b.proxy(this.pagesizeChanged,this)),this.$pageinput.on("change",b.proxy(this.pageChanged,this)),this.renderColumns(),this.options.stretchHeight&&this.initStretchHeight(),this.renderData()};d.prototype={constructor:d,renderColumns:function(){var a=this;this.$footer.attr("colspan",this.columns.length),this.$topheader.attr("colspan",this.columns.length);var c="";b.each(this.columns,function(a,b){c+='<th data-property="'+b.property+'"',b.sortable&&(c+=' class="sortable"'),c+=">"+b.label+"</th>"}),a.$colheader.append(c)},updateColumns:function(a,b){this._updateColumns(this.$colheader,a,b),this.$sizingHeader&&this._updateColumns(this.$sizingHeader,this.$sizingHeader.find("th").eq(a.index()),b)},_updateColumns:function(a,c,d){var e=d==="asc"?"icon-chevron-up":"icon-chevron-down";a.find("i.datagrid-sort").remove(),a.find("th").removeClass("sorted"),b("<i>").addClass(e+" datagrid-sort").appendTo(c),c.addClass("sorted")},updatePageDropdown:function(a){var b="";for(var c=1;c<=a.pages;c++)b+="<li><a>"+c+"</a></li>";this.$pagedropdown.html(b)},updatePageButtons:function(a){a.page===1?this.$prevpagebtn.attr("disabled","disabled"):this.$prevpagebtn.removeAttr("disabled"),a.page===a.pages?this.$nextpagebtn.attr("disabled","disabled"):this.$nextpagebtn.removeAttr("disabled")},renderData:function(){var a=this;this.$tbody.html(this.placeholderRowHTML(this.options.loadingHTML)),this.options.dataSource.data(this.options.dataOptions,function(c){var d=c.count===1?a.options.itemText:a.options.itemsText,e="";a.$footerchildren.css("visibility",function(){return c.count>0?"visible":"hidden"}),a.$pageinput.val(c.page),a.$pageslabel.text(c.pages),a.$countlabel.text(c.count+" "+d),a.$startlabel.text(c.start),a.$endlabel.text(c.end),a.updatePageDropdown(c),a.updatePageButtons(c),b.each(c.data,function(c,d){e+="<tr>",b.each(a.columns,function(a,b){e+="<td>"+d[b.property]+"</td>"}),e+="</tr>"}),e||(e=a.placeholderRowHTML("0 "+a.options.itemsText)),a.$tbody.html(e),a.stretchHeight(),a.$element.trigger("loaded")})},placeholderRowHTML:function(a){return'<tr><td style="text-align:center;padding:20px;border-bottom:none;" colspan="'+this.columns.length+'">'+a+"</td></tr>"},headerClicked:function(a){var c=b(a.target);if(!c.hasClass("sortable"))return;var d=this.options.dataOptions.sortDirection,e=this.options.dataOptions.sortProperty,f=c.data("property");e===f?this.options.dataOptions.sortDirection=d==="asc"?"desc":"asc":(this.options.dataOptions.sortDirection="asc",this.options.dataOptions.sortProperty=f),this.options.dataOptions.pageIndex=0,this.updateColumns(c,this.options.dataOptions.sortDirection),this.renderData()},pagesizeChanged:function(a,c){c?this.options.dataOptions.pageSize=parseInt(c.value,10):this.options.dataOptions.pageSize=parseInt(b(a.target).val(),10),this.options.dataOptions.pageIndex=0,this.renderData()},pageChanged:function(a){var c=parseInt(b(a.target).val(),10);c=isNaN(c)?1:c;var d=this.$pageslabel.text();this.options.dataOptions.pageIndex=c>d?d-1:c-1,this.renderData()},searchChanged:function(a,b){this.options.dataOptions.search=b,this.options.dataOptions.pageIndex=0,this.renderData()},filterChanged:function(a,b){this.options.dataOptions.filter=b,this.options.dataOptions.pageIndex=0,this.renderData()},previous:function(){this.$nextpagebtn.attr("disabled","disabled"),this.$prevpagebtn.attr("disabled","disabled"),this.options.dataOptions.pageIndex--,this.renderData()},next:function(){this.$nextpagebtn.attr("disabled","disabled"),this.$prevpagebtn.attr("disabled","disabled"),this.options.dataOptions.pageIndex++,this.renderData()},reload:function(){this.options.dataOptions.pageIndex=0,this.renderData()},initStretchHeight:function(){this.$gridContainer=this.$element.parent(),this.$element.wrap('<div class="datagrid-stretch-wrapper">'),this.$stretchWrapper=this.$element.parent(),this.$headerTable=b("<table>").attr("class",this.$element.attr("class")),this.$footerTable=this.$headerTable.clone(),this.$headerTable.prependTo(this.$gridContainer).addClass("datagrid-stretch-header"),this.$thead.detach().appendTo(this.$headerTable),this.$sizingHeader=this.$thead.clone(),this.$sizingHeader.find("tr:first").remove(),this.$footerTable.appendTo(this.$gridContainer).addClass("datagrid-stretch-footer"),this.$tfoot.detach().appendTo(this.$footerTable)},stretchHeight:function(){if(!this.$gridContainer)return;this.setColumnWidths();var a=this.$gridContainer.height(),b=this.$headerTable.outerHeight(),c=this.$footerTable.outerHeight(),d=b+c;this.$stretchWrapper.height(a-d)},setColumnWidths:function(){function e(e,f){if(e===d-1)return;var g=b(f),h=a.eq(e),i=h.width();h.hasClass("sorted")&&g.prop("tagName")==="TD"&&(i=i+c),g.width(i)}if(!this.$sizingHeader)return;this.$element.prepend(this.$sizingHeader);var a=this.$sizingHeader.find("th"),d=a.length;this.$colheader.find("th").each(e),this.$tbody.find("tr:first > td").each(e),this.$sizingHeader.detach()}},b.fn.datagrid=function(a){return this.each(function(){var c=b(this),e=c.data("datagrid"),f=typeof a=="object"&&a;e||c.data("datagrid",e=new d(this,f)),typeof a=="string"&&e[a]()})},b.fn.datagrid.defaults={dataOptions:{pageIndex:0,pageSize:10},loadingHTML:'<div class="progress progress-striped active" style="width:50%;margin:auto;"><div class="bar" style="width:100%;"></div></div>',itemsText:"items",itemText:"item"},b.fn.datagrid.Constructor=d}),c("fuelux/pillbox",["require","jquery"],function(a){var b=a("jquery"),c=function(a,c){this.$element=b(a),this.options=b.extend({},b.fn.pillbox.defaults,c),this.$element.on("click","li",b.proxy(this.itemclicked,this))};c.prototype={constructor:c,items:function(){return this.$element.find("li").map(function(){var a=b(this);return b.extend({text:a.text()},a.data())}).get()},itemclicked:function(a){b(a.currentTarget).remove(),a.preventDefault()}},b.fn.pillbox=function(a){var d,e=this.each(function(){var e=b(this),f=e.data("pillbox"),g=typeof a=="object"&&a;f||e.data("pillbox",f=new c(this,g)),typeof a=="string"&&(d=f[a]())});return d===undefined?e:d},b.fn.pillbox.defaults={},b.fn.pillbox.Constructor=c,b(function(){b("body").on("mousedown.pillbox.data-api",".pillbox",function(a){var c=b(this);if(c.data("pillbox"))return;c.pillbox(c.data())})})}),c("fuelux/radio",["require","jquery"],function(a){var b=a("jquery"),c=function(a,c){this.$element=b(a),this.options=b.extend({},b.fn.radio.defaults,c),this.$label=this.$element.parent(),this.$icon=this.$label.find("i"),this.$radio=this.$label.find("input[type=radio]"),this.groupName=this.$radio.attr("name"),this.setState(this.$radio),this.$radio.on("change",b.proxy(this.itemchecked,this))};c.prototype={constructor:c,setState:function(a,b){var c=a.is(":checked"),d=a.is(":disabled");c===!0&&this.$icon.addClass("checked"),d===!0&&this.$icon.addClass("disabled")},resetGroup:function(){b("input[name="+this.groupName+"]").next().removeClass("checked")},enable:function(){this.$radio.attr("disabled",!1),this.$icon.removeClass("disabled")},disable:function(){this.$radio.attr("disabled",!0),this.$icon.addClass("disabled")},itemchecked:function(a){var c=b(a.target);this.resetGroup(),this.setState(c)}},b.fn.radio=function(a,d){var e,f=this.each(function(){var f=b(this),g=f.data("radio"),h=typeof a=="object"&&a;g||f.data("radio",g=new c(this,h)),typeof a=="string"&&(e=g[a](d))});return e===undefined?f:e},b.fn.radio.defaults={},b.fn.radio.Constructor=c,b(function(){b(window).on("load",function(){b(".radio-custom > input[type=radio]").each(function(){var a=b(this);if(a.data("radio"))return;a.radio(a.data())})})})}),c("fuelux/search",["require","jquery"],function(a){var b=a("jquery"),c=function(a,c){this.$element=b(a),this.options=b.extend({},b.fn.search.defaults,c),this.$button=this.$element.find("button").on("click",b.proxy(this.buttonclicked,this)),this.$input=this.$element.find("input").on("keydown",b.proxy(this.keypress,this)).on("keyup",b.proxy(this.keypressed,this)),this.$icon=this.$element.find("i"),this.activeSearch=""};c.prototype={constructor:c,search:function(a){this.$icon.attr("class","icon-remove"),this.activeSearch=a,this.$element.trigger("searched",a)},clear:function(){this.$icon.attr("class","icon-search"),this.activeSearch="",this.$input.val(""),this.$element.trigger("cleared")},action:function(){var a=this.$input.val(),b=a===""||a===this.activeSearch;this.activeSearch&&b?this.clear():a&&this.search(a)},buttonclicked:function(a){a.preventDefault();if(b(a.currentTarget).is(".disabled, :disabled"))return;this.action()},keypress:function(a){a.which===13&&a.preventDefault()},keypressed:function(a){var b,c;a.which===13?(a.preventDefault(),this.action()):(b=this.$input.val(),c=b&&b===this.activeSearch,this.$icon.attr("class",c?"icon-remove":"icon-search"))},disable:function(){this.$input.attr("disabled","disabled"),this.$button.addClass("disabled")},enable:function(){this.$input.removeAttr("disabled"),this.$button.removeClass("disabled")}},b.fn.search=function(a){return this.each(function(){var d=b(this),e=d.data("search"),f=typeof a=="object"&&a;e||d.data("search",e=new c(this,f)),typeof a=="string"&&e[a]()})},b.fn.search.defaults={},b.fn.search.Constructor=c,b(function(){b("body").on("mousedown.search.data-api",".search",function(){var a=b(this);if(a.data("search"))return;a.search(a.data())})})}),c("fuelux/spinner",["require","jquery"],function(a){var b=a("jquery"),c=function(a,c){this.$element=b(a),this.options=b.extend({},b.fn.spinner.defaults,c),this.$input=this.$element.find(".spinner-input"),this.$element.on("keyup",this.$input,b.proxy(this.change,this)),this.options.hold?(this.$element.on("mousedown",".spinner-up",b.proxy(function(){this.startSpin(!0)},this)),this.$element.on("mouseup",".spinner-up, .spinner-down",b.proxy(this.stopSpin,this)),this.$element.on("mouseout",".spinner-up, .spinner-down",b.proxy(this.stopSpin,this)),this.$element.on("mousedown",".spinner-down",b.proxy(function(){this.startSpin(!1)},this))):(this.$element.on("click",".spinner-up",b.proxy(function(){this.step(!0)},this)),this.$element.on("click",".spinner-down",b.proxy(function(){this.step(!1)},this))),this.switches={count:1,enabled:!0},this.options.speed==="medium"?this.switches.speed=300:this.options.speed==="fast"?this.switches.speed=100:this.switches.speed=500,this.lastValue=null,this.render(),this.options.disabled&&this.disable()};c.prototype={constructor:c,render:function(){this.$input.val(this.options.value),this.$input.attr("maxlength",(this.options.max+"").split("").length)},change:function(){var a=this.$input.val();a/1?this.options.value=a/1:(a=a.replace(/[^0-9]/g,""),this.$input.val(a),this.options.value=a/1),this.triggerChangedEvent()},stopSpin:function(){clearTimeout(this.switches.timeout),this.switches.count=1,this.triggerChangedEvent()},triggerChangedEvent:function(){var a=this.value();if(a===this.lastValue)return;this.lastValue=a,this.$element.trigger("changed",a),this.$element.trigger("change")},startSpin:function(a){if(!this.options.disabled){var c=this.switches.count;c===1?(this.step(a),c=1):c<3?c=1.5:c<8?c=2.5:c=4,this.switches.timeout=setTimeout(b.proxy(function(){this.iterator(a)},this),this.switches.speed/c),this.switches.count++}},iterator:function(a){this.step(a),this.startSpin(a)},step:function(a){var b=this.options.value,c=a?this.options.max:this.options.min;if(a?b<c:b>c){var d=b+(a?1:-1)*this.options.step;(a?d>c:d<c)?this.value(c):this.value(d)}},value:function(a){return!isNaN(parseFloat(a))&&isFinite(a)?(a=parseFloat(a),this.options.value=a,this.$input.val(a),this):this.options.value},disable:function(){this.options.disabled=!0,this.$input.attr("disabled",""),this.$element.find("button").addClass("disabled")},enable:function(){this.options.disabled=!1,this.$input.removeAttr("disabled"),this.$element.find("button").removeClass("disabled")}},b.fn.spinner=function(a,d){var e,f=this.each(function(){var f=b(this),g=f.data("spinner"),h=typeof a=="object"&&a;g||f.data("spinner",g=new c(this,h)),typeof a=="string"&&(e=g[a](d))});return e===undefined?f:e},b.fn.spinner.defaults={value:1,min:1,max:999,step:1,hold:!0,speed:"medium",disabled:!1},b.fn.spinner.Constructor=c,b(function(){b("body").on("mousedown.spinner.data-api",".spinner",function(a){var c=b(this);if(c.data("spinner"))return;c.spinner(c.data())})})}),c("fuelux/select",["require","jquery","./util"],function(a){var b=a("jquery");a("./util");var c=function(a,c){this.$element=b(a),this.options=b.extend({},b.fn.select.defaults,c),this.$element.on("click","a",b.proxy(this.itemclicked,this)),this.$button=this.$element.find(".btn"),this.$label=this.$element.find(".dropdown-label"),this.setDefaultSelection(),c.resize==="auto"&&this.resize()};c.prototype={constructor:c,itemclicked:function(a){this.$selectedItem=b(a.target).parent(),this.$label.text(this.$selectedItem.text());var c=this.selectedItem();this.$element.trigger("changed",c),a.preventDefault()},resize:function(){var a=b("#selectTextSize")[0];a||b("<div/>").attr({id:"selectTextSize"}).appendTo("body");var c=0,d=0;this.$element.find("a").each(function(){var a=b(this),e=a.text(),f=b("#selectTextSize");f.text(e),d=f.outerWidth(),d>c&&(c=d)}),this.$label.width(c)},selectedItem:function(){var a=this.$selectedItem.text();return b.extend({text:a},this.$selectedItem.data())},selectByText:function(a){var b="li a:fuelTextExactCI("+a+")";this.selectBySelector(b)},selectByValue:function(a){var b='li[data-value="'+a+'"]';this.selectBySelector(b)},selectByIndex:function(a){var b="li:eq("+a+")";this.selectBySelector(b)},selectBySelector:function(a){var b=this.$element.find(a);this.$selectedItem=b,this.$label.text(this.$selectedItem.text())},setDefaultSelection:function(){var a="li[data-selected=true]:first",b=this.$element.find(a);b.length===0?this.selectByIndex(0):(this.selectBySelector(a),b.removeData("selected"),b.removeAttr("data-selected"))},enable:function(){this.$button.removeClass("disabled")},disable:function(){this.$button.addClass("disabled")}},b.fn.select=function(a,d){var e,f=this.each(function(){var f=b(this),g=f.data("select"),h=typeof a=="object"&&a;g||f.data("select",g=new c(this,h)),typeof a=="string"&&(e=g[a](d))});return e===undefined?f:e},b.fn.select.defaults={},b.fn.select.Constructor=c,b(function(){b(window).on("load",function(){b(".select").each(function(){var a=b(this);if(a.data("select"))return;a.select(a.data())})}),b("body").on("mousedown.select.data-api",".select",function(a){var c=b(this);if(c.data("select"))return;c.select(c.data())})})}),c("fuelux/tree",["require","jquery"],function(a){var b=a("jquery"),c=function(a,c){this.$element=b(a),this.options=b.extend({},b.fn.tree.defaults,c),this.$element.on("click",".tree-item",b.proxy(function(a){this.selectItem(a.currentTarget)},this)),this.$element.on("click",".tree-folder-header",b.proxy(function(a){this.selectFolder(a.currentTarget)},this)),this.render()};c.prototype={constructor:c,render:function(){this.populate(this.$element)},populate:function(a){var c=this,d=a.parent().find(".tree-loader:eq(0)");d.show(),this.options.dataSource.data(a.data(),function(e){d.hide(),b.each(e.data,function(b,d){var e;d.type==="folder"?(e=c.$element.find(".tree-folder:eq(0)").clone().show(),e.find(".tree-folder-name").html(d.name),e.find(".tree-loader").html(c.options.loadingHTML),e.find(".tree-folder-header").data(d)):d.type==="item"&&(e=c.$element.find(".tree-item:eq(0)").clone().show(),e.find(".tree-item-name").html(d.name),e.data(d)),a.hasClass("tree-folder-header")?a.parent().find(".tree-folder-content:eq(0)").append(e):a.append(e)}),c.$element.trigger("loaded")})},selectItem:function(a){var c=b(a),d=this.$element.find(".tree-selected"),e=[];this.options.multiSelect?b.each(d,function(a,d){var f=b(d);f[0]!==c[0]&&e.push(b(d).data())}):d[0]!==c[0]&&(d.removeClass("tree-selected").find("i").removeClass("icon-ok").addClass("tree-dot"),e.push(c.data())),c.hasClass("tree-selected")?(c.removeClass("tree-selected"),c.find("i").removeClass("icon-ok").addClass("tree-dot")):(c.addClass("tree-selected"),c.find("i").removeClass("tree-dot").addClass("icon-ok"),this.options.multiSelect&&e.push(c.data())),e.length&&this.$element.trigger("selected",{info:e})},selectFolder:function(a){var c=b(a),d=c.parent();c.find(".icon-folder-close").length?(d.find(".tree-folder-content").children().length?d.find(".tree-folder-content:eq(0)").show():this.populate(c),d.find(".icon-folder-close:eq(0)").removeClass("icon-folder-close").addClass("icon-folder-open"),this.$element.trigger("opened",c.data())):(this.options.cacheItems?d.find(".tree-folder-content:eq(0)").hide():d.find(".tree-folder-content:eq(0)").empty(),d.find(".icon-folder-open:eq(0)").removeClass("icon-folder-open").addClass("icon-folder-close"),this.$element.trigger("closed",c.data()))},selectedItems:function(){var a=this.$element.find(".tree-selected"),c=[];return b.each(a,function(a,d){c.push(b(d).data())}),c}},b.fn.tree=function(a,d){var e,f=this.each(function(){var f=b(this),g=f.data("tree"),h=typeof a=="object"&&a;g||f.data("tree",g=new c(this,h)),typeof a=="string"&&(e=g[a](d))});return e===undefined?f:e},b.fn.tree.defaults={multiSelect:!1,loadingHTML:"<div>Loading...</div>",cacheItems:!0},b.fn.tree.Constructor=c}),c("fuelux/wizard",["require","jquery"],function(a){var b=a("jquery"),c=function(a,c){var d;this.$element=b(a),this.options=b.extend({},b.fn.wizard.defaults,c),this.currentStep=1,this.numSteps=this.$element.find("li").length,this.$prevBtn=this.$element.find("button.btn-prev"),this.$nextBtn=this.$element.find("button.btn-next"),d=this.$nextBtn.children().detach(),this.nextText=b.trim(this.$nextBtn.text()),this.$nextBtn.append(d),this.$prevBtn.on("click",b.proxy(this.previous,this)),this.$nextBtn.on("click",b.proxy(this.next,this)),this.$element.on("click","li.complete",b.proxy(this.stepclicked,this))};c.prototype={constructor:c,setState:function(){var a=this.currentStep>1,c=this.currentStep===1,d=this.currentStep===this.numSteps;this.$prevBtn.attr("disabled",c===!0||a===!1);var e=this.$nextBtn.data();if(e&&e.last){this.lastText=e.last;if(typeof this.lastText!="undefined"){var f=d!==!0?this.nextText:this.lastText,g=this.$nextBtn.children().detach();this.$nextBtn.text(f).append(g)}}var h=this.$element.find("li");h.removeClass("active").removeClass("complete"),h.find("span.badge").removeClass("badge-info").removeClass("badge-success");var i="li:lt("+(this.currentStep-1)+")",j=this.$element.find(i);j.addClass("complete"),j.find("span.badge").addClass("badge-success");var k="li:eq("+(this.currentStep-1)+")",l=this.$element.find(k);l.addClass("active"),l.find("span.badge").addClass("badge-info");var m=l.data().target;b(".step-pane").removeClass("active"),b(m).addClass("active"),this.$element.trigger("changed")},stepclicked:function(a){var c=b(a.currentTarget),d=b(".steps li").index(c),e=b.Event("stepclick");this.$element.trigger(e,{step:d+1});if(e.isDefaultPrevented())return;this.currentStep=d+1,this.setState()},previous:function(){var a=this.currentStep>1;if(a){var c=b.Event("change");this.$element.trigger(c,{step:this.currentStep,direction:"previous"});if(c.isDefaultPrevented())return;this.currentStep-=1,this.setState()}},next:function(){var a=this.currentStep+1<=this.numSteps,c=this.currentStep===this.numSteps;if(a){var d=b.Event("change");this.$element.trigger(d,{step:this.currentStep,direction:"next"});if(d.isDefaultPrevented())return;this.currentStep+=1,this.setState()}else c&&this.$element.trigger("finished")},selectedItem:function(a){return{step:this.currentStep}}},b.fn.wizard=function(a,d){var e,f=this.each(function(){var f=b(this),g=f.data("wizard"),h=typeof a=="object"&&a;g||f.data("wizard",g=new c(this,h)),typeof a=="string"&&(e=g[a](d))});return e===undefined?f:e},b.fn.wizard.defaults={},b.fn.wizard.Constructor=c,b(function(){b("body").on("mousedown.wizard.data-api",".wizard",function(){var a=b(this);if(a.data("wizard"))return;a.wizard(a.data())})})}),c("fuelux/all",["require","jquery","bootstrap/bootstrap-affix","bootstrap/bootstrap-alert","bootstrap/bootstrap-button","bootstrap/bootstrap-carousel","bootstrap/bootstrap-collapse","bootstrap/bootstrap-dropdown","bootstrap/bootstrap-modal","bootstrap/bootstrap-popover","bootstrap/bootstrap-scrollspy","bootstrap/bootstrap-tab","bootstrap/bootstrap-tooltip","bootstrap/bootstrap-transition","bootstrap/bootstrap-typeahead","fuelux/checkbox","fuelux/combobox","fuelux/datagrid","fuelux/pillbox","fuelux/radio","fuelux/search","fuelux/spinner","fuelux/select","fuelux/tree","fuelux/wizard"],function(a){a("jquery"),a("bootstrap/bootstrap-affix"),a("bootstrap/bootstrap-alert"),a("bootstrap/bootstrap-button"),a("bootstrap/bootstrap-carousel"),a("bootstrap/bootstrap-collapse"),a("bootstrap/bootstrap-dropdown"),a("bootstrap/bootstrap-modal"),a("bootstrap/bootstrap-popover"),a("bootstrap/bootstrap-scrollspy"),a("bootstrap/bootstrap-tab"),a("bootstrap/bootstrap-tooltip"),a("bootstrap/bootstrap-transition"),a("bootstrap/bootstrap-typeahead"),a("fuelux/checkbox"),a("fuelux/combobox"),a("fuelux/datagrid"),a("fuelux/pillbox"),a("fuelux/radio"),a("fuelux/search"),a("fuelux/spinner"),a("fuelux/select"),a("fuelux/tree"),a("fuelux/wizard")}),c("jquery",[],function(){return jQuery}),c("fuelux/loader",["fuelux/all"],function(){}),b("fuelux/loader")})();
\ No newline at end of file
diff --git a/opendaylight/adsal/web/root/src/main/resources/js/fuelux/pillbox.js b/opendaylight/adsal/web/root/src/main/resources/js/fuelux/pillbox.js
deleted file mode 100755 (executable)
index d61f60b..0000000
+++ /dev/null
@@ -1,72 +0,0 @@
-/*
- * Fuel UX Pillbox
- * https://github.com/ExactTarget/fuelux
- *
- * Copyright (c) 2012 ExactTarget
- * Licensed under the MIT license.
- */
-
-define(['require','jquery'],function(require) {
-       
-       var $ = require('jquery');
-
-
-       // PILLBOX CONSTRUCTOR AND PROTOTYPE
-
-       var Pillbox = function (element, options) {
-               this.$element = $(element);
-               this.options = $.extend({}, $.fn.pillbox.defaults, options);
-               this.$element.on('click', 'li', $.proxy(this.itemclicked, this));
-       };
-
-       Pillbox.prototype = {
-               constructor: Pillbox,
-
-               items: function() {
-                       return this.$element.find('li').map(function() {
-                               var $this = $(this);
-                               return $.extend({ text: $this.text() }, $this.data());
-                       }).get();
-               },
-
-               itemclicked: function (e) {
-                       $(e.currentTarget).remove();
-                       e.preventDefault();
-               }
-       };
-
-
-       // PILLBOX PLUGIN DEFINITION
-
-       $.fn.pillbox = function (option) {
-               var methodReturn;
-
-               var $set = this.each(function () {
-                       var $this = $(this);
-                       var data = $this.data('pillbox');
-                       var options = typeof option === 'object' && option;
-
-                       if (!data) $this.data('pillbox', (data = new Pillbox(this, options)));
-                       if (typeof option === 'string') methodReturn = data[option]();
-               });
-
-               return (methodReturn === undefined) ? $set : methodReturn;
-       };
-
-       $.fn.pillbox.defaults = {};
-
-       $.fn.pillbox.Constructor = Pillbox;
-
-
-       // PILLBOX DATA-API
-
-       $(function () {
-               $('body').on('mousedown.pillbox.data-api', '.pillbox', function (e) {
-                       var $this = $(this);
-                       if ($this.data('pillbox')) return;
-                       $this.pillbox($this.data());
-               });
-       });
-       
-});
-
diff --git a/opendaylight/adsal/web/root/src/main/resources/js/fuelux/radio.js b/opendaylight/adsal/web/root/src/main/resources/js/fuelux/radio.js
deleted file mode 100755 (executable)
index a09c07f..0000000
+++ /dev/null
@@ -1,109 +0,0 @@
-/*
- * Fuel UX Radio
- * https://github.com/ExactTarget/fuelux
- *
- * Copyright (c) 2012 ExactTarget
- * Licensed under the MIT license.
- */
-
-define(['require','jquery'],function (require) {
-
-       var $ = require('jquery');
-
-
-       // RADIO CONSTRUCTOR AND PROTOTYPE
-
-       var Radio = function (element, options) {
-               this.$element = $(element);
-               this.options = $.extend({}, $.fn.radio.defaults, options);
-
-               // cache elements
-               this.$label = this.$element.parent();
-               this.$icon = this.$label.find('i');
-               this.$radio = this.$label.find('input[type=radio]');
-               this.groupName = this.$radio.attr('name');
-
-               // set default state
-               this.setState(this.$radio);
-
-               // handle events
-               this.$radio.on('change', $.proxy(this.itemchecked, this));
-       };
-
-       Radio.prototype = {
-
-               constructor: Radio,
-
-               setState: function ($radio, resetGroupState) {
-                       var checked = $radio.is(':checked');
-                       var disabled = $radio.is(':disabled');
-
-                       // set state of radio
-                       if (checked === true) {
-                               this.$icon.addClass('checked');
-                       }
-                       if (disabled === true) {
-                               this.$icon.addClass('disabled');
-                       }
-               },
-
-               resetGroup: function () {
-                       // reset all radio buttons in group
-                       $('input[name=' + this.groupName + ']').next().removeClass('checked');
-               },
-
-               enable: function () {
-                       this.$radio.attr('disabled', false);
-                       this.$icon.removeClass('disabled');
-               },
-
-               disable: function () {
-                       this.$radio.attr('disabled', true);
-                       this.$icon.addClass('disabled');
-               },
-
-               itemchecked: function (e) {
-                       var radio = $(e.target);
-
-                       this.resetGroup();
-                       this.setState(radio);
-               }
-       };
-
-
-       // RADIO PLUGIN DEFINITION
-
-       $.fn.radio = function (option, value) {
-               var methodReturn;
-
-               var $set = this.each(function () {
-                       var $this = $(this);
-                       var data = $this.data('radio');
-                       var options = typeof option === 'object' && option;
-
-                       if (!data) $this.data('radio', (data = new Radio(this, options)));
-                       if (typeof option === 'string') methodReturn = data[option](value);
-               });
-
-               return (methodReturn === undefined) ? $set : methodReturn;
-       };
-
-       $.fn.radio.defaults = {};
-
-       $.fn.radio.Constructor = Radio;
-
-
-       // RADIO DATA-API
-
-       $(function () {
-               $(window).on('load', function () {
-                       //$('i.radio').each(function () {
-                       $('.radio-custom > input[type=radio]').each(function () {
-                               var $this = $(this);
-                               if ($this.data('radio')) return;
-                               $this.radio($this.data());
-                       });
-               });
-       });
-
-});
diff --git a/opendaylight/adsal/web/root/src/main/resources/js/fuelux/search.js b/opendaylight/adsal/web/root/src/main/resources/js/fuelux/search.js
deleted file mode 100755 (executable)
index 7f6a27b..0000000
+++ /dev/null
@@ -1,125 +0,0 @@
-/*
- * Fuel UX Search
- * https://github.com/ExactTarget/fuelux
- *
- * Copyright (c) 2012 ExactTarget
- * Licensed under the MIT license.
- */
-
-define(['require','jquery'],function(require) {
-
-       var $ = require('jquery');
-
-
-       // SEARCH CONSTRUCTOR AND PROTOTYPE
-
-       var Search = function (element, options) {
-               this.$element = $(element);
-               this.options = $.extend({}, $.fn.search.defaults, options);
-
-               this.$button = this.$element.find('button')
-                       .on('click', $.proxy(this.buttonclicked, this));
-
-               this.$input = this.$element.find('input')
-                       .on('keydown', $.proxy(this.keypress, this))
-                       .on('keyup', $.proxy(this.keypressed, this));
-
-               this.$icon = this.$element.find('i');
-               this.activeSearch = '';
-       };
-
-       Search.prototype = {
-
-               constructor: Search,
-
-               search: function (searchText) {
-                       this.$icon.attr('class', 'icon-remove');
-                       this.activeSearch = searchText;
-                       this.$element.trigger('searched', searchText);
-               },
-
-               clear: function () {
-                       this.$icon.attr('class', 'icon-search');
-                       this.activeSearch = '';
-                       this.$input.val('');
-                       this.$element.trigger('cleared');
-               },
-
-               action: function () {
-                       var val = this.$input.val();
-                       var inputEmptyOrUnchanged = val === '' || val === this.activeSearch;
-
-                       if (this.activeSearch && inputEmptyOrUnchanged) {
-                               this.clear();
-                       } else if (val) {
-                               this.search(val);
-                       }
-               },
-
-               buttonclicked: function (e) {
-                       e.preventDefault();
-                       if ($(e.currentTarget).is('.disabled, :disabled')) return;
-                       this.action();
-               },
-
-               keypress: function (e) {
-                       if (e.which === 13) {
-                               e.preventDefault();
-                       }
-               },
-
-               keypressed: function (e) {
-                       var val, inputPresentAndUnchanged;
-
-                       if (e.which === 13) {
-                               e.preventDefault();
-                               this.action();
-                       } else {
-                               val = this.$input.val();
-                               inputPresentAndUnchanged = val && (val === this.activeSearch);
-                               this.$icon.attr('class', inputPresentAndUnchanged ? 'icon-remove' : 'icon-search');
-                       }
-               },
-
-               disable: function () {
-                       this.$input.attr('disabled', 'disabled');
-                       this.$button.addClass('disabled');
-               },
-
-               enable: function () {
-                       this.$input.removeAttr('disabled');
-                       this.$button.removeClass('disabled');
-               }
-
-       };
-
-
-       // SEARCH PLUGIN DEFINITION
-
-       $.fn.search = function (option) {
-               return this.each(function () {
-                       var $this = $(this);
-                       var data = $this.data('search');
-                       var options = typeof option === 'object' && option;
-
-                       if (!data) $this.data('search', (data = new Search(this, options)));
-                       if (typeof option === 'string') data[option]();
-               });
-       };
-
-       $.fn.search.defaults = {};
-
-       $.fn.search.Constructor = Search;
-
-
-       // SEARCH DATA-API
-
-       $(function () {
-               $('body').on('mousedown.search.data-api', '.search', function () {
-                       var $this = $(this);
-                       if ($this.data('search')) return;
-                       $this.search($this.data());
-               });
-       });
-
-});
diff --git a/opendaylight/adsal/web/root/src/main/resources/js/fuelux/select.js b/opendaylight/adsal/web/root/src/main/resources/js/fuelux/select.js
deleted file mode 100755 (executable)
index 38e6a60..0000000
+++ /dev/null
@@ -1,169 +0,0 @@
-/*
- * Fuel UX Select
- * https://github.com/ExactTarget/fuelux
- *
- * Copyright (c) 2012 ExactTarget
- * Licensed under the MIT license.
- */
-
-define(['require','jquery','./util'],function(require) {
-
-    var $ = require('jquery');
-       require('./util');
-
-    // SELECT CONSTRUCTOR AND PROTOTYPE
-
-    var Select = function (element, options) {
-        this.$element = $(element);
-        this.options = $.extend({}, $.fn.select.defaults, options);
-        this.$element.on('click', 'a', $.proxy(this.itemclicked, this));
-        this.$button = this.$element.find('.btn');
-        this.$label = this.$element.find('.dropdown-label');
-        this.setDefaultSelection();
-
-        if (options.resize === 'auto') {
-            this.resize();
-        }
-    };
-
-    Select.prototype = {
-
-        constructor: Select,
-
-        itemclicked: function (e) {
-            this.$selectedItem = $(e.target).parent();
-            this.$label.text(this.$selectedItem.text());
-
-            // pass object including text and any data-attributes
-            // to onchange event
-            var data = this.selectedItem();
-
-            // trigger changed event
-            this.$element.trigger('changed', data);
-
-            e.preventDefault();
-        },
-
-        resize: function() {
-            var el = $('#selectTextSize')[0];
-
-            // create element if it doesn't exist
-            // used to calculate the length of the longest string
-            if(!el) {
-                $('<div/>').attr({id:'selectTextSize'}).appendTo('body');
-            }
-
-            var width = 0;
-            var newWidth = 0;
-
-            // iterate through each item to find longest string
-            this.$element.find('a').each(function () {
-                var $this = $(this);
-                var txt = $this.text();
-                var $txtSize = $('#selectTextSize');
-                $txtSize.text(txt);
-                newWidth = $txtSize.outerWidth();
-                if(newWidth > width) {
-                    width = newWidth;
-                }
-            });
-
-            this.$label.width(width);
-        },
-
-        selectedItem: function() {
-            var txt = this.$selectedItem.text();
-            return $.extend({ text: txt }, this.$selectedItem.data());
-        },
-
-        selectByText: function(text) {
-            var selector = 'li a:fuelTextExactCI(' + text + ')';
-            this.selectBySelector(selector);
-        },
-
-        selectByValue: function(value) {
-            var selector = 'li[data-value="' + value + '"]';
-            this.selectBySelector(selector);
-        },
-
-        selectByIndex: function(index) {
-            // zero-based index
-            var selector = 'li:eq(' + index + ')';
-            this.selectBySelector(selector);
-        },
-
-        selectBySelector: function(selector) {
-            var item = this.$element.find(selector);
-
-            this.$selectedItem = item;
-            this.$label.text(this.$selectedItem.text());
-        },
-
-        setDefaultSelection: function() {
-            var selector = 'li[data-selected=true]:first';
-            var item = this.$element.find(selector);
-            if(item.length === 0) {
-                // select first item
-                this.selectByIndex(0);
-            }
-            else {
-                // select by data-attribute
-                this.selectBySelector(selector);
-                item.removeData('selected');
-                item.removeAttr('data-selected');
-            }
-        },
-
-        enable: function() {
-            this.$button.removeClass('disabled');
-        },
-
-        disable: function() {
-            this.$button.addClass('disabled');
-        }
-
-    };
-
-
-    // SELECT PLUGIN DEFINITION
-
-    $.fn.select = function (option,value) {
-        var methodReturn;
-
-        var $set = this.each(function () {
-            var $this = $(this);
-            var data = $this.data('select');
-            var options = typeof option === 'object' && option;
-
-            if (!data) $this.data('select', (data = new Select(this, options)));
-            if (typeof option === 'string') methodReturn = data[option](value);
-        });
-
-        return (methodReturn === undefined) ? $set : methodReturn;
-    };
-
-    $.fn.select.defaults = {};
-
-    $.fn.select.Constructor = Select;
-
-
-    // SELECT DATA-API
-
-    $(function () {
-
-        $(window).on('load', function () {
-            $('.select').each(function () {
-                var $this = $(this);
-                if ($this.data('select')) return;
-                $this.select($this.data());
-            });
-        });
-
-        $('body').on('mousedown.select.data-api', '.select', function (e) {
-            var $this = $(this);
-            if ($this.data('select')) return;
-            $this.select($this.data());
-        });
-    });
-
-});
diff --git a/opendaylight/adsal/web/root/src/main/resources/js/fuelux/spinner.js b/opendaylight/adsal/web/root/src/main/resources/js/fuelux/spinner.js
deleted file mode 100755 (executable)
index 97720ee..0000000
+++ /dev/null
@@ -1,201 +0,0 @@
-/*\r
- * Fuel UX Spinner\r
- * https://github.com/ExactTarget/fuelux\r
- *\r
- * Copyright (c) 2012 ExactTarget\r
- * Licensed under the MIT license.\r
- */\r
-\r
-define(['require','jquery'],function(require) {\r
-\r
-       var $ = require('jquery');\r
-\r
-\r
-       // SPINNER CONSTRUCTOR AND PROTOTYPE\r
-\r
-       var Spinner = function (element, options) {\r
-               this.$element = $(element);\r
-               this.options = $.extend({}, $.fn.spinner.defaults, options);\r
-               this.$input = this.$element.find('.spinner-input');\r
-               this.$element.on('keyup', this.$input, $.proxy(this.change, this));\r
-\r
-               if (this.options.hold) {\r
-                       this.$element.on('mousedown', '.spinner-up', $.proxy(function() { this.startSpin(true); } , this));\r
-                       this.$element.on('mouseup', '.spinner-up, .spinner-down', $.proxy(this.stopSpin, this));\r
-                       this.$element.on('mouseout', '.spinner-up, .spinner-down', $.proxy(this.stopSpin, this));\r
-                       this.$element.on('mousedown', '.spinner-down', $.proxy(function() {this.startSpin(false);} , this));\r
-               } else {\r
-                       this.$element.on('click', '.spinner-up', $.proxy(function() { this.step(true); } , this));\r
-                       this.$element.on('click', '.spinner-down', $.proxy(function() { this.step(false); }, this));\r
-               }\r
-\r
-               this.switches = {\r
-                       count: 1,\r
-                       enabled: true\r
-               };\r
-\r
-               if (this.options.speed === 'medium') {\r
-                       this.switches.speed = 300;\r
-               } else if (this.options.speed === 'fast') {\r
-                       this.switches.speed = 100;\r
-               } else {\r
-                       this.switches.speed = 500;\r
-               }\r
-\r
-               this.lastValue = null;\r
-\r
-               this.render();\r
-\r
-               if (this.options.disabled) {\r
-                       this.disable();\r
-               }\r
-       };\r
-\r
-       Spinner.prototype = {\r
-               constructor: Spinner,\r
-\r
-               render: function () {\r
-                       this.$input.val(this.options.value);\r
-                       this.$input.attr('maxlength',(this.options.max + '').split('').length);\r
-               },\r
-\r
-               change: function () {\r
-                       var newVal = this.$input.val();\r
-\r
-                       if(newVal/1){\r
-                               this.options.value = newVal/1;\r
-                       }else{\r
-                               newVal = newVal.replace(/[^0-9]/g,'');\r
-                               this.$input.val(newVal);\r
-                               this.options.value = newVal/1;\r
-                       }\r
-\r
-                       this.triggerChangedEvent();\r
-               },\r
-\r
-               stopSpin: function () {\r
-                       clearTimeout(this.switches.timeout);\r
-                       this.switches.count = 1;\r
-                       this.triggerChangedEvent();\r
-               },\r
-\r
-               triggerChangedEvent: function () {\r
-                       var currentValue = this.value();\r
-                       if (currentValue === this.lastValue) return;\r
-\r
-                       this.lastValue = currentValue;\r
-\r
-                       // Primary changed event\r
-                       this.$element.trigger('changed', currentValue);\r
-\r
-                       // Undocumented, kept for backward compatibility\r
-                       this.$element.trigger('change');\r
-               },\r
-\r
-               startSpin: function (type) {\r
-\r
-                       if (!this.options.disabled) {\r
-                               var divisor = this.switches.count;\r
-\r
-                               if (divisor === 1) {\r
-                                       this.step(type);\r
-                                       divisor = 1;\r
-                               } else if (divisor < 3){\r
-                                       divisor = 1.5;\r
-                               } else if (divisor < 8){\r
-                                       divisor = 2.5;\r
-                               } else {\r
-                                       divisor = 4;\r
-                               }\r
-\r
-                               this.switches.timeout = setTimeout($.proxy(function() {this.iterator(type);} ,this),this.switches.speed/divisor);\r
-                               this.switches.count++;\r
-                       }\r
-               },\r
-\r
-               iterator: function (type) {\r
-                       this.step(type);\r
-                       this.startSpin(type);\r
-               },\r
-\r
-               step: function (dir) {\r
-                       var curValue = this.options.value;\r
-                       var limValue = dir ? this.options.max : this.options.min;\r
-\r
-                       if ((dir ? curValue < limValue : curValue > limValue)) {\r
-                               var newVal = curValue + (dir ? 1 : -1) * this.options.step;\r
-\r
-                               if (dir ? newVal > limValue : newVal < limValue) {\r
-                                       this.value(limValue);\r
-                               } else {\r
-                                       this.value(newVal);\r
-                               }\r
-                       }\r
-               },\r
-\r
-               value: function (value) {\r
-                       if (!isNaN(parseFloat(value)) && isFinite(value)) {\r
-                               value = parseFloat(value);\r
-                               this.options.value = value;\r
-                               this.$input.val(value);\r
-                               return this;\r
-                       } else {\r
-                               return this.options.value;\r
-                       }\r
-               },\r
-\r
-               disable: function () {\r
-                       this.options.disabled = true;\r
-                       this.$input.attr('disabled','');\r
-                       this.$element.find('button').addClass('disabled');\r
-               },\r
-\r
-               enable: function () {\r
-                       this.options.disabled = false;\r
-                       this.$input.removeAttr("disabled");\r
-                       this.$element.find('button').removeClass('disabled');\r
-               }\r
-       };\r
-\r
-\r
-       // SPINNER PLUGIN DEFINITION\r
-\r
-       $.fn.spinner = function (option,value) {\r
-               var methodReturn;\r
-\r
-               var $set = this.each(function () {\r
-                       var $this = $(this);\r
-                       var data = $this.data('spinner');\r
-                       var options = typeof option === 'object' && option;\r
-\r
-                       if (!data) $this.data('spinner', (data = new Spinner(this, options)));\r
-                       if (typeof option === 'string') methodReturn = data[option](value);\r
-               });\r
-\r
-               return (methodReturn === undefined) ? $set : methodReturn;\r
-       };\r
-\r
-       $.fn.spinner.defaults = {\r
-               value: 1,\r
-               min: 1,\r
-               max: 999,\r
-               step: 1,\r
-               hold: true,\r
-               speed: 'medium',\r
-               disabled: false\r
-       };\r
-\r
-       $.fn.spinner.Constructor = Spinner;\r
-\r
-\r
-       // SPINNER DATA-API\r
-\r
-       $(function () {\r
-               $('body').on('mousedown.spinner.data-api', '.spinner', function (e) {\r
-                       var $this = $(this);\r
-                       if ($this.data('spinner')) return;\r
-                       $this.spinner($this.data());\r
-               });\r
-       });\r
-\r
-});\r
diff --git a/opendaylight/adsal/web/root/src/main/resources/js/fuelux/tree.js b/opendaylight/adsal/web/root/src/main/resources/js/fuelux/tree.js
deleted file mode 100755 (executable)
index b243719..0000000
+++ /dev/null
@@ -1,169 +0,0 @@
-/*\r
- * Fuel UX Tree\r
- * https://github.com/ExactTarget/fuelux\r
- *\r
- * Copyright (c) 2012 ExactTarget\r
- * Licensed under the MIT license.\r
- */\r
-\r
-define(['require','jquery'],function(require) {\r
-\r
-       var $ = require('jquery');\r
-\r
-\r
-       // TREE CONSTRUCTOR AND PROTOTYPE\r
-\r
-       var Tree = function (element, options) {\r
-               this.$element = $(element);\r
-               this.options = $.extend({}, $.fn.tree.defaults, options);\r
-\r
-               this.$element.on('click', '.tree-item', $.proxy( function(ev) { this.selectItem(ev.currentTarget); } ,this));\r
-               this.$element.on('click', '.tree-folder-header', $.proxy( function(ev) { this.selectFolder(ev.currentTarget); }, this));\r
-\r
-               this.render();\r
-       };\r
-\r
-       Tree.prototype = {\r
-               constructor: Tree,\r
-\r
-               render: function () {\r
-                       this.populate(this.$element);\r
-               },\r
-\r
-               populate: function ($el) {\r
-                       var self = this;\r
-                       var loader = $el.parent().find('.tree-loader:eq(0)');\r
-\r
-                       loader.show();\r
-                       this.options.dataSource.data($el.data(), function (items) {\r
-                               loader.hide();\r
-\r
-                               $.each( items.data, function(index, value) {\r
-                                       var $entity;\r
-\r
-                                       if(value.type === "folder") {\r
-                                               $entity = self.$element.find('.tree-folder:eq(0)').clone().show();\r
-                                               $entity.find('.tree-folder-name').html(value.name);\r
-                                               $entity.find('.tree-loader').html(self.options.loadingHTML);\r
-                                               $entity.find('.tree-folder-header').data(value);\r
-                                       } else if (value.type === "item") {\r
-                                               $entity = self.$element.find('.tree-item:eq(0)').clone().show();\r
-                                               $entity.find('.tree-item-name').html(value.name);\r
-                                               $entity.data(value);\r
-                                       }\r
-\r
-                                       if($el.hasClass('tree-folder-header')) {\r
-                                               $el.parent().find('.tree-folder-content:eq(0)').append($entity);\r
-                                       } else {\r
-                                               $el.append($entity);\r
-                                       }\r
-                               });\r
-\r
-                               self.$element.trigger('loaded');\r
-                       });\r
-               },\r
-\r
-               selectItem: function (el) {\r
-                       var $el = $(el);\r
-                       var $all = this.$element.find('.tree-selected');\r
-                       var data = [];\r
-\r
-                       if (this.options.multiSelect) {\r
-                               $.each($all, function(index, value) {\r
-                                       var $val = $(value);\r
-                                       if($val[0] !== $el[0]) {\r
-                                               data.push( $(value).data() );\r
-                                       }\r
-                               });\r
-                       } else if ($all[0] !== $el[0]) {\r
-                               $all.removeClass('tree-selected')\r
-                                       .find('i').removeClass('icon-ok').addClass('tree-dot');\r
-                               data.push($el.data());\r
-                       }\r
-\r
-                       if($el.hasClass('tree-selected')) {\r
-                               $el.removeClass('tree-selected');\r
-                               $el.find('i').removeClass('icon-ok').addClass('tree-dot');\r
-                       } else {\r
-                               $el.addClass ('tree-selected');\r
-                               $el.find('i').removeClass('tree-dot').addClass('icon-ok');\r
-                               if (this.options.multiSelect) {\r
-                                       data.push( $el.data() );\r
-                               }\r
-                       }\r
-\r
-                       if(data.length) {\r
-                               this.$element.trigger('selected', {info: data});\r
-                       }\r
-\r
-               },\r
-\r
-               selectFolder: function (el) {\r
-                       var $el = $(el);\r
-                       var $par = $el.parent();\r
-\r
-                       if($el.find('.icon-folder-close').length) {\r
-                               if ($par.find('.tree-folder-content').children().length) {\r
-                                       $par.find('.tree-folder-content:eq(0)').show();\r
-                               } else {\r
-                                       this.populate( $el );\r
-                               }\r
-\r
-                               $par.find('.icon-folder-close:eq(0)')\r
-                                       .removeClass('icon-folder-close')\r
-                                       .addClass('icon-folder-open');\r
-\r
-                               this.$element.trigger('opened', $el.data());\r
-                       } else {\r
-                               if(this.options.cacheItems) {\r
-                                       $par.find('.tree-folder-content:eq(0)').hide();\r
-                               } else {\r
-                                       $par.find('.tree-folder-content:eq(0)').empty();\r
-                               }\r
-\r
-                               $par.find('.icon-folder-open:eq(0)')\r
-                                       .removeClass('icon-folder-open')\r
-                                       .addClass('icon-folder-close');\r
-\r
-                               this.$element.trigger('closed', $el.data());\r
-                       }\r
-               },\r
-\r
-               selectedItems: function () {\r
-                       var $sel = this.$element.find('.tree-selected');\r
-                       var data = [];\r
-\r
-                       $.each($sel, function (index, value) {\r
-                               data.push($(value).data());\r
-                       });\r
-                       return data;\r
-               }\r
-       };\r
-\r
-\r
-       // TREE PLUGIN DEFINITION\r
-\r
-       $.fn.tree = function (option, value) {\r
-               var methodReturn;\r
-\r
-               var $set = this.each(function () {\r
-                       var $this = $(this);\r
-                       var data = $this.data('tree');\r
-                       var options = typeof option === 'object' && option;\r
-\r
-                       if (!data) $this.data('tree', (data = new Tree(this, options)));\r
-                       if (typeof option === 'string') methodReturn = data[option](value);\r
-               });\r
-\r
-               return (methodReturn === undefined) ? $set : methodReturn;\r
-       };\r
-\r
-       $.fn.tree.defaults = {\r
-               multiSelect: false,\r
-               loadingHTML: '<div>Loading...</div>',\r
-               cacheItems: true\r
-       };\r
-\r
-       $.fn.tree.Constructor = Tree;\r
-\r
-});\r
diff --git a/opendaylight/adsal/web/root/src/main/resources/js/fuelux/util.js b/opendaylight/adsal/web/root/src/main/resources/js/fuelux/util.js
deleted file mode 100755 (executable)
index 469e9db..0000000
+++ /dev/null
@@ -1,28 +0,0 @@
-/*
- * Fuel UX Utilities
- * https://github.com/ExactTarget/fuelux
- *
- * Copyright (c) 2012 ExactTarget
- * Licensed under the MIT license.
- */
-
-define(['require','jquery'],function (require) {
-
-       var $ = require('jquery');
-
-       // custom case-insensitive match expression
-       function fuelTextExactCI(elem, text) {
-               return (elem.textContent || elem.innerText || $(elem).text() || '').toLowerCase() === (text || '').toLowerCase();
-       }
-
-       $.expr[':'].fuelTextExactCI = $.expr.createPseudo ?
-               $.expr.createPseudo(function (text) {
-                       return function (elem) {
-                               return fuelTextExactCI(elem, text);
-                       };
-               }) :
-               function (elem, i, match) {
-                       return fuelTextExactCI(elem, match[3]);
-               };
-
-});
\ No newline at end of file
diff --git a/opendaylight/adsal/web/root/src/main/resources/js/fuelux/wizard.js b/opendaylight/adsal/web/root/src/main/resources/js/fuelux/wizard.js
deleted file mode 100755 (executable)
index 31b9d80..0000000
+++ /dev/null
@@ -1,168 +0,0 @@
-/*
- * Fuel UX Wizard
- * https://github.com/ExactTarget/fuelux
- *
- * Copyright (c) 2012 ExactTarget
- * Licensed under the MIT license.
- */
-
-define(['require','jquery'],function (require) {
-
-       var $ = require('jquery');
-
-
-       // WIZARD CONSTRUCTOR AND PROTOTYPE
-
-       var Wizard = function (element, options) {
-               var kids;
-
-               this.$element = $(element);
-               this.options = $.extend({}, $.fn.wizard.defaults, options);
-               this.currentStep = 1;
-               this.numSteps = this.$element.find('li').length;
-               this.$prevBtn = this.$element.find('button.btn-prev');
-               this.$nextBtn = this.$element.find('button.btn-next');
-
-               kids = this.$nextBtn.children().detach();
-               this.nextText = $.trim(this.$nextBtn.text());
-               this.$nextBtn.append(kids);
-
-               // handle events
-               this.$prevBtn.on('click', $.proxy(this.previous, this));
-               this.$nextBtn.on('click', $.proxy(this.next, this));
-               this.$element.on('click', 'li.complete', $.proxy(this.stepclicked, this));
-       };
-
-       Wizard.prototype = {
-
-               constructor: Wizard,
-
-               setState: function () {
-                       var canMovePrev = (this.currentStep > 1);
-                       var firstStep = (this.currentStep === 1);
-                       var lastStep = (this.currentStep === this.numSteps);
-
-                       // disable buttons based on current step
-                       this.$prevBtn.attr('disabled', (firstStep === true || canMovePrev === false));
-
-                       // change button text of last step, if specified
-                       var data = this.$nextBtn.data();
-                       if (data && data.last) {
-                               this.lastText = data.last;
-                               if (typeof this.lastText !== 'undefined') {
-                                       // replace text
-                                       var text = (lastStep !== true) ? this.nextText : this.lastText;
-                                       var kids = this.$nextBtn.children().detach();
-                                       this.$nextBtn.text(text).append(kids);
-                               }
-                       }
-
-                       // reset classes for all steps
-                       var $steps = this.$element.find('li');
-                       $steps.removeClass('active').removeClass('complete');
-                       $steps.find('span.badge').removeClass('badge-info').removeClass('badge-success');
-
-                       // set class for all previous steps
-                       var prevSelector = 'li:lt(' + (this.currentStep - 1) + ')';
-                       var $prevSteps = this.$element.find(prevSelector);
-                       $prevSteps.addClass('complete');
-                       $prevSteps.find('span.badge').addClass('badge-success');
-
-                       // set class for current step
-                       var currentSelector = 'li:eq(' + (this.currentStep - 1) + ')';
-                       var $currentStep = this.$element.find(currentSelector);
-                       $currentStep.addClass('active');
-                       $currentStep.find('span.badge').addClass('badge-info');
-
-                       // set display of target element
-                       var target = $currentStep.data().target;
-                       $('.step-pane').removeClass('active');
-                       $(target).addClass('active');
-
-                       this.$element.trigger('changed');
-               },
-
-               stepclicked: function (e) {
-                       var li = $(e.currentTarget);
-
-                       var index = $('.steps li').index(li);
-
-                       var evt = $.Event('stepclick');
-                       this.$element.trigger(evt, {step: index + 1});
-                       if (evt.isDefaultPrevented()) return;
-
-                       this.currentStep = (index + 1);
-                       this.setState();
-               },
-
-               previous: function () {
-                       var canMovePrev = (this.currentStep > 1);
-                       if (canMovePrev) {
-                               var e = $.Event('change');
-                               this.$element.trigger(e, {step: this.currentStep, direction: 'previous'});
-                               if (e.isDefaultPrevented()) return;
-
-                               this.currentStep -= 1;
-                               this.setState();
-                       }
-               },
-
-               next: function () {
-                       var canMoveNext = (this.currentStep + 1 <= this.numSteps);
-                       var lastStep = (this.currentStep === this.numSteps);
-
-                       if (canMoveNext) {
-                               var e = $.Event('change');
-                               this.$element.trigger(e, {step: this.currentStep, direction: 'next'});
-
-                               if (e.isDefaultPrevented()) return;
-
-                               this.currentStep += 1;
-                               this.setState();
-                       }
-                       else if (lastStep) {
-                               this.$element.trigger('finished');
-                       }
-               },
-
-               selectedItem: function (val) {
-                       return {
-                               step: this.currentStep
-                       };
-               }
-       };
-
-
-       // WIZARD PLUGIN DEFINITION
-
-       $.fn.wizard = function (option, value) {
-               var methodReturn;
-
-               var $set = this.each(function () {
-                       var $this = $(this);
-                       var data = $this.data('wizard');
-                       var options = typeof option === 'object' && option;
-
-                       if (!data) $this.data('wizard', (data = new Wizard(this, options)));
-                       if (typeof option === 'string') methodReturn = data[option](value);
-               });
-
-               return (methodReturn === undefined) ? $set : methodReturn;
-       };
-
-       $.fn.wizard.defaults = {};
-
-       $.fn.wizard.Constructor = Wizard;
-
-
-       // WIZARD DATA-API
-
-       $(function () {
-               $('body').on('mousedown.wizard.data-api', '.wizard', function () {
-                       var $this = $(this);
-                       if ($this.data('wizard')) return;
-                       $this.wizard($this.data());
-               });
-       });
-
-});
diff --git a/opendaylight/adsal/web/root/src/main/resources/js/jit.js b/opendaylight/adsal/web/root/src/main/resources/js/jit.js
deleted file mode 100644 (file)
index dce2d2f..0000000
+++ /dev/null
@@ -1,9843 +0,0 @@
-/*
-Copyright (c) 2012 Sencha Inc. - Author: Nicolas Garcia Belmonte (http://philogb.github.com/)
-
-Permission is hereby granted, free of charge, to any person obtaining a copy
-of this software and associated documentation files (the "Software"), to deal
-in the Software without restriction, including without limitation the rights
-to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
-copies of the Software, and to permit persons to whom the Software is
-furnished to do so, subject to the following conditions:
-
-The above copyright notice and this permission notice shall be included in
-all copies or substantial portions of the Software.
-
-THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
-IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
-FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
-AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
-LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
-OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
-THE SOFTWARE.
-
- */
- (function () { 
-
-/*
-  File: Core.js
-
- */
-
-/*
- Object: $jit
-
- Defines the namespace for all library Classes and Objects.
- This variable is the *only* global variable defined in the Toolkit.
- There are also other interesting properties attached to this variable described below.
- */
-this.$jit = function(w) {
-  w = w || window;
-  for(var k in $jit) {
-    if($jit[k].$extend) {
-      w[k] = $jit[k];
-    }
-  }
-};
-
-$jit.version = '2.0.1';
-/*
-  Object: $jit.id
-
-  Works just like *document.getElementById*
-
-  Example:
-  (start code js)
-  var element = $jit.id('elementId');
-  (end code)
-
-*/
-
-/*
- Object: $jit.util
-
- Contains utility functions.
-
- Some of the utility functions and the Class system were based in the MooTools Framework
- <http://mootools.net>. Copyright (c) 2006-2010 Valerio Proietti, <http://mad4milk.net/>.
- MIT license <http://mootools.net/license.txt>.
-
- These methods are generally also implemented in DOM manipulation frameworks like JQuery, MooTools and Prototype.
- I'd suggest you to use the functions from those libraries instead of using these, since their functions
- are widely used and tested in many different platforms/browsers. Use these functions only if you have to.
-
- */
-var $ = function(d) {
-  return document.getElementById(d);
-};
-
-$.empty = function() {
-};
-
-/*
-  Method: extend
-
-  Augment an object by appending another object's properties.
-
-  Parameters:
-
-  original - (object) The object to be extended.
-  extended - (object) An object which properties are going to be appended to the original object.
-
-  Example:
-  (start code js)
-  $jit.util.extend({ 'a': 1, 'b': 2 }, { 'b': 3, 'c': 4 }); //{ 'a':1, 'b': 3, 'c': 4 }
-  (end code)
-*/
-$.extend = function(original, extended) {
-  for ( var key in (extended || {}))
-    original[key] = extended[key];
-  return original;
-};
-
-$.lambda = function(value) {
-  return (typeof value == 'function') ? value : function() {
-    return value;
-  };
-};
-
-$.time = Date.now || function() {
-  return +new Date;
-};
-
-/*
-  Method: splat
-
-  Returns an array wrapping *obj* if *obj* is not an array. Returns *obj* otherwise.
-
-  Parameters:
-
-  obj - (mixed) The object to be wrapped in an array.
-
-  Example:
-  (start code js)
-  $jit.util.splat(3);   //[3]
-  $jit.util.splat([3]); //[3]
-  (end code)
-*/
-$.splat = function(obj) {
-  var type = $.type(obj);
-  return type ? ((type != 'array') ? [ obj ] : obj) : [];
-};
-
-$.type = function(elem) {
-  var type = $.type.s.call(elem).match(/^\[object\s(.*)\]$/)[1].toLowerCase();
-  if(type != 'object') return type;
-  if(elem && elem.$$family) return elem.$$family;
-  if(elem && elem.nodeType == 9) return 'htmldocument';
-  return (elem && elem.nodeName && elem.nodeType == 1)? 'element' : type;
-};
-$.type.s = Object.prototype.toString;
-
-/*
-  Method: each
-
-  Iterates through an iterable applying *f*.
-
-  Parameters:
-
-  iterable - (array) The original array.
-  fn - (function) The function to apply to the array elements.
-
-  Example:
-  (start code js)
-  $jit.util.each([3, 4, 5], function(n) { alert('number ' + n); });
-  (end code)
-*/
-$.each = function(iterable, fn) {
-  var type = $.type(iterable);
-  if (type == 'object') {
-    for ( var key in iterable)
-      fn(iterable[key], key);
-  } else {
-    for ( var i = 0, l = iterable.length; i < l; i++)
-      fn(iterable[i], i);
-  }
-};
-
-$.indexOf = function(array, item) {
-  if(array.indexOf) return array.indexOf(item);
-  for(var i=0,l=array.length; i<l; i++) {
-    if(array[i] === item) return i;
-  }
-  return -1;
-};
-
-/*
-  Method: map
-
-  Maps or collects an array by applying *f*.
-
-  Parameters:
-
-  array - (array) The original array.
-  f - (function) The function to apply to the array elements.
-
-  Example:
-  (start code js)
-  $jit.util.map([3, 4, 5], function(n) { return n*n; }); //[9, 16, 25]
-  (end code)
-*/
-$.map = function(array, f) {
-  var ans = [];
-  $.each(array, function(elem, i) {
-    ans.push(f(elem, i));
-  });
-  return ans;
-};
-
-/*
-  Method: reduce
-
-  Iteratively applies the binary function *f* storing the result in an accumulator.
-
-  Parameters:
-
-  array - (array) The original array.
-  f - (function) The function to apply to the array elements.
-  opt - (optional|mixed) The starting value for the acumulator.
-
-  Example:
-  (start code js)
-  $jit.util.reduce([3, 4, 5], function(x, y) { return x + y; }, 0); //12
-  (end code)
-*/
-$.reduce = function(array, f, opt) {
-  var l = array.length;
-  if(l==0) return opt;
-  var acum = arguments.length == 3? opt : array[--l];
-  while(l--) {
-    acum = f(acum, array[l]);
-  }
-  return acum;
-};
-
-/*
-  Method: merge
-
-  Merges n-objects and their sub-objects creating a new, fresh object.
-
-  Parameters:
-
-  An arbitrary number of objects.
-
-  Example:
-  (start code js)
-  $jit.util.merge({ 'a': 1, 'b': 2 }, { 'b': 3, 'c': 4 }); //{ 'a':1, 'b': 3, 'c': 4 }
-  (end code)
-*/
-$.merge = function() {
-  var mix = {};
-  for ( var i = 0, l = arguments.length; i < l; i++) {
-    var object = arguments[i];
-    if ($.type(object) != 'object')
-      continue;
-    for ( var key in object) {
-      var op = object[key], mp = mix[key];
-      mix[key] = (mp && $.type(op) == 'object' && $.type(mp) == 'object') ? $
-          .merge(mp, op) : $.unlink(op);
-    }
-  }
-  return mix;
-};
-
-$.unlink = function(object) {
-  var unlinked;
-  switch ($.type(object)) {
-  case 'object':
-    unlinked = {};
-    for ( var p in object)
-      unlinked[p] = $.unlink(object[p]);
-    break;
-  case 'array':
-    unlinked = [];
-    for ( var i = 0, l = object.length; i < l; i++)
-      unlinked[i] = $.unlink(object[i]);
-    break;
-  default:
-    return object;
-  }
-  return unlinked;
-};
-
-$.zip = function() {
-  if(arguments.length === 0) return [];
-  for(var j=0, ans=[], l=arguments.length, ml=arguments[0].length; j<ml; j++) {
-    for(var i=0, row=[]; i<l; i++) {
-      row.push(arguments[i][j]);
-    }
-    ans.push(row);
-  }
-  return ans;
-};
-
-/*
-  Method: rgbToHex
-
-  Converts an RGB array into a Hex string.
-
-  Parameters:
-
-  srcArray - (array) An array with R, G and B values
-
-  Example:
-  (start code js)
-  $jit.util.rgbToHex([255, 255, 255]); //'#ffffff'
-  (end code)
-*/
-$.rgbToHex = function(srcArray, array) {
-  if (srcArray.length < 3)
-    return null;
-  if (srcArray.length == 4 && srcArray[3] == 0 && !array)
-    return 'transparent';
-  var hex = [];
-  for ( var i = 0; i < 3; i++) {
-    var bit = (srcArray[i] - 0).toString(16);
-    hex.push(bit.length == 1 ? '0' + bit : bit);
-  }
-  return array ? hex : '#' + hex.join('');
-};
-
-/*
-  Method: hexToRgb
-
-  Converts an Hex color string into an RGB array.
-
-  Parameters:
-
-  hex - (string) A color hex string.
-
-  Example:
-  (start code js)
-  $jit.util.hexToRgb('#fff'); //[255, 255, 255]
-  (end code)
-*/
-$.hexToRgb = function(hex) {
-  if (hex.length != 7) {
-    hex = hex.match(/^#?(\w{1,2})(\w{1,2})(\w{1,2})$/);
-    hex.shift();
-    if (hex.length != 3)
-      return null;
-    var rgb = [];
-    for ( var i = 0; i < 3; i++) {
-      var value = hex[i];
-      if (value.length == 1)
-        value += value;
-      rgb.push(parseInt(value, 16));
-    }
-    return rgb;
-  } else {
-    hex = parseInt(hex.slice(1), 16);
-    return [ hex >> 16, hex >> 8 & 0xff, hex & 0xff ];
-  }
-};
-
-$.destroy = function(elem) {
-  $.clean(elem);
-  if (elem.parentNode)
-    elem.parentNode.removeChild(elem);
-  if (elem.clearAttributes)
-    elem.clearAttributes();
-};
-
-$.clean = function(elem) {
-  for (var ch = elem.childNodes, i = 0, l = ch.length; i < l; i++) {
-    $.destroy(ch[i]);
-  }
-};
-
-/*
-  Method: addEvent
-
-  Cross-browser add event listener.
-
-  Parameters:
-
-  obj - (obj) The Element to attach the listener to.
-  type - (string) The listener type. For example 'click', or 'mousemove'.
-  fn - (function) The callback function to be used when the event is fired.
-
-  Example:
-  (start code js)
-  $jit.util.addEvent(elem, 'click', function(){ alert('hello'); });
-  (end code)
-*/
-$.addEvent = function(obj, type, fn) {
-  if (obj.addEventListener)
-    obj.addEventListener(type, fn, false);
-  else
-    obj.attachEvent('on' + type, fn);
-};
-
-$.addEvents = function(obj, typeObj) {
-  for(var type in typeObj) {
-    $.addEvent(obj, type, typeObj[type]);
-  }
-};
-
-$.hasClass = function(obj, klass) {
-  return (' ' + obj.className + ' ').indexOf(' ' + klass + ' ') > -1;
-};
-
-$.addClass = function(obj, klass) {
-  if (!$.hasClass(obj, klass))
-    obj.className = (obj.className + " " + klass);
-};
-
-$.removeClass = function(obj, klass) {
-  obj.className = obj.className.replace(new RegExp(
-      '(^|\\s)' + klass + '(?:\\s|$)'), '$1');
-};
-
-$.getPos = function(elem) {
-  var offset = getOffsets(elem);
-  var scroll = getScrolls(elem);
-  return {
-    x: offset.x - scroll.x,
-    y: offset.y - scroll.y
-  };
-
-  function getOffsets(elem) {
-    var position = {
-      x: 0,
-      y: 0
-    };
-    while (elem && !isBody(elem)) {
-      position.x += elem.offsetLeft;
-      position.y += elem.offsetTop;
-      elem = elem.offsetParent;
-    }
-    return position;
-  }
-
-  function getScrolls(elem) {
-    var position = {
-      x: 0,
-      y: 0
-    };
-    while (elem && !isBody(elem)) {
-      position.x += elem.scrollLeft;
-      position.y += elem.scrollTop;
-      elem = elem.parentNode;
-    }
-    return position;
-  }
-
-  function isBody(element) {
-    return (/^(?:body|html)$/i).test(element.tagName);
-  }
-};
-
-$.event = {
-  get: function(e, win) {
-    win = win || window;
-    return e || win.event;
-  },
-  getWheel: function(e) {
-    return e.wheelDelta? e.wheelDelta / 120 : -(e.detail || 0) / 3;
-  },
-  isRightClick: function(e) {
-    return (e.which == 3 || e.button == 2);
-  },
-  getPos: function(e, win) {
-    // get mouse position
-    win = win || window;
-    e = e || win.event;
-    var doc = win.document;
-    doc = doc.documentElement || doc.body;
-    //TODO(nico): make touch event handling better
-    if(e.touches && e.touches.length) {
-      e = e.touches[0];
-    }
-    var page = {
-      x: e.pageX || (e.clientX + doc.scrollLeft),
-      y: e.pageY || (e.clientY + doc.scrollTop)
-    };
-    return page;
-  },
-  stop: function(e) {
-    if (e.stopPropagation) e.stopPropagation();
-    e.cancelBubble = true;
-    if (e.preventDefault) e.preventDefault();
-    else e.returnValue = false;
-  }
-};
-
-$jit.util = $jit.id = $;
-
-var Class = function(properties) {
-  properties = properties || {};
-  var klass = function() {
-    for ( var key in this) {
-      if (typeof this[key] != 'function')
-        this[key] = $.unlink(this[key]);
-    }
-    this.constructor = klass;
-    if (Class.prototyping)
-      return this;
-    var instance = this.initialize ? this.initialize.apply(this, arguments)
-        : this;
-    //typize
-    this.$$family = 'class';
-    return instance;
-  };
-
-  for ( var mutator in Class.Mutators) {
-    if (!properties[mutator])
-      continue;
-    properties = Class.Mutators[mutator](properties, properties[mutator]);
-    delete properties[mutator];
-  }
-
-  $.extend(klass, this);
-  klass.constructor = Class;
-  klass.prototype = properties;
-  return klass;
-};
-
-Class.Mutators = {
-
-  Implements: function(self, klasses) {
-    $.each($.splat(klasses), function(klass) {
-      Class.prototyping = klass;
-      var instance = (typeof klass == 'function') ? new klass : klass;
-      for ( var prop in instance) {
-        if (!(prop in self)) {
-          self[prop] = instance[prop];
-        }
-      }
-      delete Class.prototyping;
-    });
-    return self;
-  }
-
-};
-
-$.extend(Class, {
-
-  inherit: function(object, properties) {
-    for ( var key in properties) {
-      var override = properties[key];
-      var previous = object[key];
-      var type = $.type(override);
-      if (previous && type == 'function') {
-        if (override != previous) {
-          Class.override(object, key, override);
-        }
-      } else if (type == 'object') {
-        object[key] = $.merge(previous, override);
-      } else {
-        object[key] = override;
-      }
-    }
-    return object;
-  },
-
-  override: function(object, name, method) {
-    var parent = Class.prototyping;
-    if (parent && object[name] != parent[name])
-      parent = null;
-    var override = function() {
-      var previous = this.parent;
-      this.parent = parent ? parent[name] : object[name];
-      var value = method.apply(this, arguments);
-      this.parent = previous;
-      return value;
-    };
-    object[name] = override;
-  }
-
-});
-
-Class.prototype.implement = function() {
-  var proto = this.prototype;
-  $.each(Array.prototype.slice.call(arguments || []), function(properties) {
-    Class.inherit(proto, properties);
-  });
-  return this;
-};
-
-$jit.Class = Class;
-
-/*
-  Object: $jit.json
-
-  Provides JSON utility functions.
-
-  Most of these functions are JSON-tree traversal and manipulation functions.
-*/
-$jit.json = {
-  /*
-     Method: prune
-
-     Clears all tree nodes having depth greater than maxLevel.
-
-     Parameters:
-
-        tree - (object) A JSON tree object. For more information please see <Loader.loadJSON>.
-        maxLevel - (number) An integer specifying the maximum level allowed for this tree. All nodes having depth greater than max level will be deleted.
-
-  */
-  prune: function(tree, maxLevel) {
-    this.each(tree, function(elem, i) {
-      if (i == maxLevel && elem.children) {
-        delete elem.children;
-        elem.children = [];
-      }
-    });
-  },
-  /*
-     Method: getParent
-
-     Returns the parent node of the node having _id_ as id.
-
-     Parameters:
-
-        tree - (object) A JSON tree object. See also <Loader.loadJSON>.
-        id - (string) The _id_ of the child node whose parent will be returned.
-
-    Returns:
-
-        A tree JSON node if any, or false otherwise.
-
-  */
-  getParent: function(tree, id) {
-    if (tree.id == id)
-      return false;
-    var ch = tree.children;
-    if (ch && ch.length > 0) {
-      for ( var i = 0; i < ch.length; i++) {
-        if (ch[i].id == id)
-          return tree;
-        else {
-          var ans = this.getParent(ch[i], id);
-          if (ans)
-            return ans;
-        }
-      }
-    }
-    return false;
-  },
-  /*
-     Method: getSubtree
-
-     Returns the subtree that matches the given id.
-
-     Parameters:
-
-        tree - (object) A JSON tree object. See also <Loader.loadJSON>.
-        id - (string) A node *unique* identifier.
-
-     Returns:
-
-        A subtree having a root node matching the given id. Returns null if no subtree matching the id is found.
-
-  */
-  getSubtree: function(tree, id) {
-    if (tree.id == id)
-      return tree;
-    for ( var i = 0, ch = tree.children; ch && i < ch.length; i++) {
-      var t = this.getSubtree(ch[i], id);
-      if (t != null)
-        return t;
-    }
-    return null;
-  },
-  /*
-     Method: eachLevel
-
-      Iterates on tree nodes with relative depth less or equal than a specified level.
-
-     Parameters:
-
-        tree - (object) A JSON tree or subtree. See also <Loader.loadJSON>.
-        initLevel - (number) An integer specifying the initial relative level. Usually zero.
-        toLevel - (number) An integer specifying a top level. This method will iterate only through nodes with depth less than or equal this number.
-        action - (function) A function that receives a node and an integer specifying the actual level of the node.
-
-    Example:
-   (start code js)
-     $jit.json.eachLevel(tree, 0, 3, function(node, depth) {
-        alert(node.name + ' ' + depth);
-     });
-   (end code)
-  */
-  eachLevel: function(tree, initLevel, toLevel, action) {
-    if (initLevel <= toLevel) {
-      action(tree, initLevel);
-      if(!tree.children) return;
-      for ( var i = 0, ch = tree.children; i < ch.length; i++) {
-        this.eachLevel(ch[i], initLevel + 1, toLevel, action);
-      }
-    }
-  },
-  /*
-     Method: each
-
-      A JSON tree iterator.
-
-     Parameters:
-
-        tree - (object) A JSON tree or subtree. See also <Loader.loadJSON>.
-        action - (function) A function that receives a node.
-
-    Example:
-    (start code js)
-      $jit.json.each(tree, function(node) {
-        alert(node.name);
-      });
-    (end code)
-
-  */
-  each: function(tree, action) {
-    this.eachLevel(tree, 0, Number.MAX_VALUE, action);
-  }
-};
-
-
-/*
-     An object containing multiple type of transformations. 
-*/
-
-$jit.Trans = {
-  $extend: true,
-  
-  linear: function(p){
-    return p;
-  }
-};
-
-var Trans = $jit.Trans;
-
-(function(){
-
-  var makeTrans = function(transition, params){
-    params = $.splat(params);
-    return $.extend(transition, {
-      easeIn: function(pos){
-        return transition(pos, params);
-      },
-      easeOut: function(pos){
-        return 1 - transition(1 - pos, params);
-      },
-      easeInOut: function(pos){
-        return (pos <= 0.5)? transition(2 * pos, params) / 2 : (2 - transition(
-            2 * (1 - pos), params)) / 2;
-      }
-    });
-  };
-
-  var transitions = {
-
-    Pow: function(p, x){
-      return Math.pow(p, x[0] || 6);
-    },
-
-    Expo: function(p){
-      return Math.pow(2, 8 * (p - 1));
-    },
-
-    Circ: function(p){
-      return 1 - Math.sin(Math.acos(p));
-    },
-
-    Sine: function(p){
-      return 1 - Math.sin((1 - p) * Math.PI / 2);
-    },
-
-    Back: function(p, x){
-      x = x[0] || 1.618;
-      return Math.pow(p, 2) * ((x + 1) * p - x);
-    },
-
-    Bounce: function(p){
-      var value;
-      for ( var a = 0, b = 1; 1; a += b, b /= 2) {
-        if (p >= (7 - 4 * a) / 11) {
-          value = b * b - Math.pow((11 - 6 * a - 11 * p) / 4, 2);
-          break;
-        }
-      }
-      return value;
-    },
-
-    Elastic: function(p, x){
-      return Math.pow(2, 10 * --p)
-          * Math.cos(20 * p * Math.PI * (x[0] || 1) / 3);
-    }
-
-  };
-
-  $.each(transitions, function(val, key){
-    Trans[key] = makeTrans(val);
-  });
-
-  $.each( [
-      'Quad', 'Cubic', 'Quart', 'Quint'
-  ], function(elem, i){
-    Trans[elem] = makeTrans(function(p){
-      return Math.pow(p, [
-        i + 2
-      ]);
-    });
-  });
-
-})();
-
-/*
-   A Class that can perform animations for generic objects.
-
-   If you are looking for animation transitions please take a look at the <Trans> object.
-
-   Used by:
-
-   <Graph.Plot>
-   
-   Based on:
-   
-   The Animation class is based in the MooTools Framework <http://mootools.net>. Copyright (c) 2006-2009 Valerio Proietti, <http://mad4milk.net/>. MIT license <http://mootools.net/license.txt>.
-
-*/
-
-var Animation = new Class( {
-
-  initialize: function(options){
-    this.setOptions(options);
-  },
-
-  setOptions: function(options){
-    var opt = {
-      duration: 2500,
-      fps: 40,
-      transition: Trans.Quart.easeInOut,
-      compute: $.empty,
-      complete: $.empty,
-      link: 'ignore'
-    };
-    this.opt = $.merge(opt, options || {});
-    return this;
-  },
-
-  step: function(){
-    var time = $.time(), opt = this.opt;
-    if (time < this.time + opt.duration) {
-      var delta = opt.transition((time - this.time) / opt.duration);
-      opt.compute(delta);
-    } else {
-      this.timer = clearInterval(this.timer);
-      opt.compute(1);
-      opt.complete();
-    }
-  },
-
-  start: function(){
-    if (!this.check())
-      return this;
-    this.time = 0;
-    this.startTimer();
-    return this;
-  },
-
-  startTimer: function(){
-    var that = this, fps = this.opt.fps;
-    if (this.timer)
-      return false;
-    this.time = $.time() - this.time;
-    this.timer = setInterval((function(){
-      that.step();
-    }), Math.round(1000 / fps));
-    return true;
-  },
-
-  pause: function(){
-    this.stopTimer();
-    return this;
-  },
-
-  resume: function(){
-    this.startTimer();
-    return this;
-  },
-
-  stopTimer: function(){
-    if (!this.timer)
-      return false;
-    this.time = $.time() - this.time;
-    this.timer = clearInterval(this.timer);
-    return true;
-  },
-
-  check: function(){
-    if (!this.timer)
-      return true;
-    if (this.opt.link == 'cancel') {
-      this.stopTimer();
-      return true;
-    }
-    return false;
-  }
-});
-
-
-var Options = function() {
-  var args = arguments;
-  for(var i=0, l=args.length, ans={}; i<l; i++) {
-    var opt = Options[args[i]];
-    if(opt.$extend) {
-      $.extend(ans, opt);
-    } else {
-      ans[args[i]] = opt;  
-    }
-  }
-  return ans;
-};
-
-/*
- * File: Options.Canvas.js
- *
-*/
-
-/*
-  Object: Options.Canvas
-  
-  These are Canvas general options, like where to append it in the DOM, its dimensions, background, 
-  and other more advanced options.
-  
-  Syntax:
-  
-  (start code js)
-
-  Options.Canvas = {
-    injectInto: 'id',
-    type: '2D', //'3D'
-    width: false,
-    height: false,
-    useCanvas: false,
-    withLabels: true,
-    background: false
-  };  
-  (end code)
-  
-  Example:
-  
-  (start code js)
-  var viz = new $jit.Viz({
-    injectInto: 'someContainerId',
-    width: 500,
-    height: 700
-  });
-  (end code)
-  
-  Parameters:
-  
-  injectInto - *required* (string|element) The id of the DOM container for the visualization. It can also be an Element provided that it has an id.
-  type - (string) Context type. Default's 2D but can be 3D for webGL enabled browsers.
-  width - (number) Default's to the *container's offsetWidth*. The width of the canvas.
-  height - (number) Default's to the *container's offsetHeight*. The height of the canvas.
-  useCanvas - (boolean|object) Default's *false*. You can pass another <Canvas> instance to be used by the visualization.
-  withLabels - (boolean) Default's *true*. Whether to use a label container for the visualization.
-  background - (boolean|object) Default's *false*. An object containing information about the rendering of a background canvas.
-*/
-
-Options.Canvas = {
-    $extend: true,
-    
-    injectInto: 'id',
-    type: '2D',
-    width: false,
-    height: false,
-    useCanvas: false,
-    withLabels: true,
-    background: false,
-    
-    Scene: {
-      Lighting: {
-        enable: false,
-        ambient: [1, 1, 1],
-        directional: {
-          direction: { x: -100, y: -100, z: -100 },
-          color: [0.5, 0.3, 0.1]
-        }
-      }
-    }
-};
-
-/*
- * File: Options.Node.js
- *
-*/
-
-/*
-  Object: Options.Node
-
-  Provides Node rendering options for Tree and Graph based visualizations.
-
-  Syntax:
-    
-  (start code js)
-  Options.Node = {
-    overridable: false,
-    type: 'circle',
-    color: '#ccb',
-    alpha: 1,
-    dim: 3,
-    height: 20,
-    width: 90,
-    autoHeight: false,
-    autoWidth: false,
-    lineWidth: 1,
-    transform: true,
-    align: "center",
-    angularWidth:1,
-    span:1,
-    CanvasStyles: {}
-  };
-  (end code)
-  
-  Example:
-  
-  (start code js)
-  var viz = new $jit.Viz({
-    Node: {
-      overridable: true,
-      width: 30,
-      autoHeight: true,
-      type: 'rectangle'
-    }
-  });
-  (end code)
-  
-  Parameters:
-
-  overridable - (boolean) Default's *false*. Determine whether or not general node properties can be overridden by a particular <Graph.Node>.
-  type - (string) Default's *circle*. Node's shape. Node built-in types include 'circle', 'rectangle', 'square', 'ellipse', 'triangle', 'star'. The default Node type might vary in each visualization. You can also implement (non built-in) custom Node types into your visualizations.
-  color - (string) Default's *#ccb*. Node color.
-  alpha - (number) Default's *1*. The Node's alpha value. *1* is for full opacity.
-  dim - (number) Default's *3*. An extra parameter used by 'circle', 'square', 'triangle' and 'star' node types. Depending on each shape, this parameter can set the radius of a circle, half the length of the side of a square, half the base and half the height of a triangle or the length of a side of a star (concave decagon).
-  height - (number) Default's *20*. Used by 'rectangle' and 'ellipse' node types. The height of the node shape.
-  width - (number) Default's *90*. Used by 'rectangle' and 'ellipse' node types. The width of the node shape.
-  autoHeight - (boolean) Default's *false*. Whether to set an auto height for the node depending on the content of the Node's label.
-  autoWidth - (boolean) Default's *false*. Whether to set an auto width for the node depending on the content of the Node's label.
-  lineWidth - (number) Default's *1*. Used only by some Node shapes. The line width of the strokes of a node.
-  transform - (boolean) Default's *true*. Only used by the <Hypertree> visualization. Whether to scale the nodes according to the moebius transformation.
-  align - (string) Default's *center*. Possible values are 'center', 'left' or 'right'. Used only by the <ST> visualization, these parameters are used for aligning nodes when some of they dimensions vary.
-  angularWidth - (number) Default's *1*. Used in radial layouts (like <RGraph> or <Sunburst> visualizations). The amount of relative 'space' set for a node.
-  span - (number) Default's *1*. Used in radial layouts (like <RGraph> or <Sunburst> visualizations). The angle span amount set for a node.
-  CanvasStyles - (object) Default's an empty object (i.e. {}). Attach any other canvas specific property that you'd set to the canvas context before plotting a Node.
-
-*/
-Options.Node = {
-  $extend: false,
-  
-  overridable: false,
-  type: 'circle',
-  color: '#ccb',
-  alpha: 1,
-  dim: 3,
-  height: 20,
-  width: 90,
-  autoHeight: false,
-  autoWidth: false,
-  lineWidth: 1,
-  transform: true,
-  align: "center",
-  angularWidth:1,
-  span:1,
-  //Raw canvas styles to be
-  //applied to the context instance
-  //before plotting a node
-  CanvasStyles: {}
-};
-
-
-/*
- * File: Options.Edge.js
- *
-*/
-
-/*
-  Object: Options.Edge
-
-  Provides Edge rendering options for Tree and Graph based visualizations.
-
-  Syntax:
-    
-  (start code js)
-  Options.Edge = {
-    overridable: false,
-    type: 'line',
-    color: '#ccb',
-    lineWidth: 1,
-    dim:15,
-    alpha: 1,
-    CanvasStyles: {}
-  };
-  (end code)
-  
-  Example:
-  
-  (start code js)
-  var viz = new $jit.Viz({
-    Edge: {
-      overridable: true,
-      type: 'line',
-      color: '#fff',
-      CanvasStyles: {
-        shadowColor: '#ccc',
-        shadowBlur: 10
-      }
-    }
-  });
-  (end code)
-  
-  Parameters:
-    
-   overridable - (boolean) Default's *false*. Determine whether or not general edges properties can be overridden by a particular <Graph.Adjacence>.
-   type - (string) Default's 'line'. Edge styles include 'line', 'hyperline', 'arrow'. The default Edge type might vary in each visualization. You can also implement custom Edge types.
-   color - (string) Default's '#ccb'. Edge color.
-   lineWidth - (number) Default's *1*. Line/Edge width.
-   alpha - (number) Default's *1*. The Edge's alpha value. *1* is for full opacity.
-   dim - (number) Default's *15*. An extra parameter used by other complex shapes such as quadratic, bezier or arrow, to determine the shape's diameter.
-   epsilon - (number) Default's *7*. Only used when using *enableForEdges* in <Options.Events>. This dimension is used to create an area for the line where the contains method for the edge returns *true*.
-   CanvasStyles - (object) Default's an empty object (i.e. {}). Attach any other canvas specific property that you'd set to the canvas context before plotting an Edge.
-
-  See also:
-   
-   If you want to know more about how to customize Node/Edge data per element, in the JSON or programmatically, take a look at this article.
-*/
-Options.Edge = {
-  $extend: false,
-  
-  overridable: false,
-  type: 'line',
-  color: '#ccb',
-  lineWidth: 1,
-  dim:15,
-  alpha: 1,
-  epsilon: 7,
-
-  //Raw canvas styles to be
-  //applied to the context instance
-  //before plotting an edge
-  CanvasStyles: {}
-};
-
-
-/*
- * File: Options.Fx.js
- *
-*/
-
-/*
-  Object: Options.Fx
-
-  Provides animation options like duration of the animations, frames per second and animation transitions.  
-
-  Syntax:
-  
-  (start code js)
-    Options.Fx = {
-      fps:40,
-      duration: 2500,
-      transition: $jit.Trans.Quart.easeInOut,
-      clearCanvas: true
-    };
-  (end code)
-  
-  Example:
-  
-  (start code js)
-  var viz = new $jit.Viz({
-    duration: 1000,
-    fps: 35,
-    transition: $jit.Trans.linear
-  });
-  (end code)
-  
-  Parameters:
-  
-  clearCanvas - (boolean) Default's *true*. Whether to clear the frame/canvas when the viz is plotted or animated.
-  duration - (number) Default's *2500*. Duration of the animation in milliseconds.
-  fps - (number) Default's *40*. Frames per second.
-  transition - (object) Default's *$jit.Trans.Quart.easeInOut*. The transition used for the animations. See below for a more detailed explanation.
-  
-  Object: $jit.Trans
-  
-  This object is used for specifying different animation transitions in all visualizations.
-
-  There are many different type of animation transitions.
-
-  linear:
-
-  Displays a linear transition
-
-  >Trans.linear
-  
-  (see Linear.png)
-
-  Quad:
-
-  Displays a Quadratic transition.
-
-  >Trans.Quad.easeIn
-  >Trans.Quad.easeOut
-  >Trans.Quad.easeInOut
-  
- (see Quad.png)
-
- Cubic:
-
- Displays a Cubic transition.
-
- >Trans.Cubic.easeIn
- >Trans.Cubic.easeOut
- >Trans.Cubic.easeInOut
-
- (see Cubic.png)
-
- Quart:
-
- Displays a Quartetic transition.
-
- >Trans.Quart.easeIn
- >Trans.Quart.easeOut
- >Trans.Quart.easeInOut
-
- (see Quart.png)
-
- Quint:
-
- Displays a Quintic transition.
-
- >Trans.Quint.easeIn
- >Trans.Quint.easeOut
- >Trans.Quint.easeInOut
-
- (see Quint.png)
-
- Expo:
-
- Displays an Exponential transition.
-
- >Trans.Expo.easeIn
- >Trans.Expo.easeOut
- >Trans.Expo.easeInOut
-
- (see Expo.png)
-
- Circ:
-
- Displays a Circular transition.
-
- >Trans.Circ.easeIn
- >Trans.Circ.easeOut
- >Trans.Circ.easeInOut
-
- (see Circ.png)
-
- Sine:
-
- Displays a Sineousidal transition.
-
- >Trans.Sine.easeIn
- >Trans.Sine.easeOut
- >Trans.Sine.easeInOut
-
- (see Sine.png)
-
- Back:
-
- >Trans.Back.easeIn
- >Trans.Back.easeOut
- >Trans.Back.easeInOut
-
- (see Back.png)
-
- Bounce:
-
- Bouncy transition.
-
- >Trans.Bounce.easeIn
- >Trans.Bounce.easeOut
- >Trans.Bounce.easeInOut
-
- (see Bounce.png)
-
- Elastic:
-
- Elastic curve.
-
- >Trans.Elastic.easeIn
- >Trans.Elastic.easeOut
- >Trans.Elastic.easeInOut
-
- (see Elastic.png)
- Based on:
-     
- Easing and Transition animation methods are based in the MooTools Framework <http://mootools.net>. Copyright (c) 2006-2010 Valerio Proietti, <http://mad4milk.net/>. MIT license <http://mootools.net/license.txt>.
-
-
-*/
-Options.Fx = {
-  $extend: true,
-  
-  fps:40,
-  duration: 2500,
-  transition: $jit.Trans.Quart.easeInOut,
-  clearCanvas: true
-};
-
-/*
- * File: Options.Label.js
- *
-*/
-/*
-  Object: Options.Label
-
-  Provides styling for Labels such as font size, family, etc. Also sets Node labels as HTML, SVG or Native canvas elements.  
-
-  Syntax:
-  
-  (start code js)
-    Options.Label = {
-      overridable: false,
-      type: 'HTML', //'SVG', 'Native'
-      style: ' ',
-      size: 10,
-      family: 'sans-serif',
-      textAlign: 'center',
-      textBaseline: 'alphabetic',
-      color: '#fff'
-    };
-  (end code)
-  
-  Example:
-  
-  (start code js)
-  var viz = new $jit.Viz({
-    Label: {
-      type: 'Native',
-      size: 11,
-      color: '#ccc'
-    }
-  });
-  (end code)
-  
-  Parameters:
-    
-  overridable - (boolean) Default's *false*. Determine whether or not general label properties can be overridden by a particular <Graph.Node>.
-  type - (string) Default's *HTML*. The type for the labels. Can be 'HTML', 'SVG' or 'Native' canvas labels.
-  style - (string) Default's *empty string*. Can be 'italic' or 'bold'. This parameter is only taken into account when using 'Native' canvas labels. For DOM based labels the className *node* is added to the DOM element for styling via CSS. You can also use <Options.Controller> methods to style individual labels.
-  size - (number) Default's *10*. The font's size. This parameter is only taken into account when using 'Native' canvas labels. For DOM based labels the className *node* is added to the DOM element for styling via CSS. You can also use <Options.Controller> methods to style individual labels.
-  family - (string) Default's *sans-serif*. The font's family. This parameter is only taken into account when using 'Native' canvas labels. For DOM based labels the className *node* is added to the DOM element for styling via CSS. You can also use <Options.Controller> methods to style individual labels.
-  color - (string) Default's *#fff*. The font's color. This parameter is only taken into account when using 'Native' canvas labels. For DOM based labels the className *node* is added to the DOM element for styling via CSS. You can also use <Options.Controller> methods to style individual labels.
-*/
-Options.Label = {
-  $extend: false,
-  
-  overridable: false,
-  type: 'HTML', //'SVG', 'Native'
-  style: ' ',
-  size: 10,
-  family: 'sans-serif',
-  textAlign: 'center',
-  textBaseline: 'alphabetic',
-  color: '#fff'
-};
-
-
-/*
- * File: Options.Tips.js
- *
- */
-
-/*
-  Object: Options.Tips
-  
-  Tips options
-  
-  Syntax:
-    
-  (start code js)
-  Options.Tips = {
-    enable: false,
-    type: 'auto',
-    offsetX: 20,
-    offsetY: 20,
-    onShow: $.empty,
-    onHide: $.empty
-  };
-  (end code)
-  
-  Example:
-  
-  (start code js)
-  var viz = new $jit.Viz({
-    Tips: {
-      enable: true,
-      type: 'Native',
-      offsetX: 10,
-      offsetY: 10,
-      onShow: function(tip, node) {
-        tip.innerHTML = node.name;
-      }
-    }
-  });
-  (end code)
-
-  Parameters:
-
-  enable - (boolean) Default's *false*. If *true*, a tooltip will be shown when a node is hovered. The tooltip is a div DOM element having "tip" as CSS class. 
-  type - (string) Default's *auto*. Defines where to attach the MouseEnter/Leave tooltip events. Possible values are 'Native' to attach them to the canvas or 'HTML' to attach them to DOM label elements (if defined). 'auto' sets this property to the value of <Options.Label>'s *type* property.
-  offsetX - (number) Default's *20*. An offset added to the current tooltip x-position (which is the same as the current mouse position). Default's 20.
-  offsetY - (number) Default's *20*. An offset added to the current tooltip y-position (which is the same as the current mouse position). Default's 20.
-  onShow(tip, node) - This callack is used right before displaying a tooltip. The first formal parameter is the tip itself (which is a DivElement). The second parameter may be a <Graph.Node> for graph based visualizations or an object with label, value properties for charts.
-  onHide() - This callack is used when hiding a tooltip.
-
-*/
-Options.Tips = {
-  $extend: false,
-  
-  enable: false,
-  type: 'auto',
-  offsetX: 20,
-  offsetY: 20,
-  force: false,
-  onShow: $.empty,
-  onHide: $.empty
-};
-
-
-/*
- * File: Options.NodeStyles.js
- *
- */
-
-/*
-  Object: Options.NodeStyles
-  
-  Apply different styles when a node is hovered or selected.
-  
-  Syntax:
-    
-  (start code js)
-  Options.NodeStyles = {
-    enable: false,
-    type: 'auto',
-    stylesHover: false,
-    stylesClick: false
-  };
-  (end code)
-  
-  Example:
-  
-  (start code js)
-  var viz = new $jit.Viz({
-    NodeStyles: {
-      enable: true,
-      type: 'Native',
-      stylesHover: {
-        dim: 30,
-        color: '#fcc'
-      },
-      duration: 600
-    }
-  });
-  (end code)
-
-  Parameters:
-  
-  enable - (boolean) Default's *false*. Whether to enable this option.
-  type - (string) Default's *auto*. Use this to attach the hover/click events in the nodes or the nodes labels (if they have been defined as DOM elements: 'HTML' or 'SVG', see <Options.Label> for more details). The default 'auto' value will set NodeStyles to the same type defined for <Options.Label>.
-  stylesHover - (boolean|object) Default's *false*. An object with node styles just like the ones defined for <Options.Node> or *false* otherwise.
-  stylesClick - (boolean|object) Default's *false*. An object with node styles just like the ones defined for <Options.Node> or *false* otherwise.
-*/
-
-Options.NodeStyles = {
-  $extend: false,
-  
-  enable: false,
-  type: 'auto',
-  stylesHover: false,
-  stylesClick: false
-};
-
-
-/*
- * File: Options.Events.js
- *
-*/
-
-/*
-  Object: Options.Events
-  
-  Configuration for adding mouse/touch event handlers to Nodes.
-  
-  Syntax:
-  
-  (start code js)
-  Options.Events = {
-    enable: false,
-    enableForEdges: false,
-    type: 'auto',
-    onClick: $.empty,
-    onRightClick: $.empty,
-    onMouseMove: $.empty,
-    onMouseEnter: $.empty,
-    onMouseLeave: $.empty,
-    onDragStart: $.empty,
-    onDragMove: $.empty,
-    onDragCancel: $.empty,
-    onDragEnd: $.empty,
-    onTouchStart: $.empty,
-    onTouchMove: $.empty,
-    onTouchEnd: $.empty,
-    onTouchCancel: $.empty,
-    onMouseWheel: $.empty
-  };
-  (end code)
-  
-  Example:
-  
-  (start code js)
-  var viz = new $jit.Viz({
-    Events: {
-      enable: true,
-      onClick: function(node, eventInfo, e) {
-        viz.doSomething();
-      },
-      onMouseEnter: function(node, eventInfo, e) {
-        viz.canvas.getElement().style.cursor = 'pointer';
-      },
-      onMouseLeave: function(node, eventInfo, e) {
-        viz.canvas.getElement().style.cursor = '';
-      }
-    }
-  });
-  (end code)
-  
-  Parameters:
-  
-  enable - (boolean) Default's *false*. Whether to enable the Event system.
-  enableForEdges - (boolean) Default's *false*. Whether to track events also in arcs. If *true* the same callbacks -described below- are used for nodes *and* edges. A simple duck type check for edges is to check for *node.nodeFrom*.
-  type - (string) Default's 'auto'. Whether to attach the events onto the HTML labels (via event delegation) or to use the custom 'Native' canvas Event System of the library. 'auto' is set when you let the <Options.Label> *type* parameter decide this.
-  onClick(node, eventInfo, e) - Triggered when a user performs a click in the canvas. *node* is the <Graph.Node> clicked or false if no node has been clicked. *e* is the grabbed event (should return the native event in a cross-browser manner). *eventInfo* is an object containing useful methods like *getPos* to get the mouse position relative to the canvas. 
-  onRightClick(node, eventInfo, e) - Triggered when a user performs a right click in the canvas. *node* is the <Graph.Node> right clicked or false if no node has been clicked. *e* is the grabbed event (should return the native event in a cross-browser manner). *eventInfo* is an object containing useful methods like *getPos* to get the mouse position relative to the canvas. 
-  onMouseMove(node, eventInfo, e) - Triggered when the user moves the mouse. *node* is the <Graph.Node> under the cursor as it's moving over the canvas or false if no node has been clicked. *e* is the grabbed event (should return the native event in a cross-browser manner).  *eventInfo* is an object containing useful methods like *getPos* to get the mouse position relative to the canvas.
-  onMouseEnter(node, eventInfo, e) - Triggered when a user moves the mouse over a node. *node* is the <Graph.Node> that the mouse just entered. *e* is the grabbed event (should return the native event in a cross-browser manner). *eventInfo* is an object containing useful methods like *getPos* to get the mouse position relative to the canvas. 
-  onMouseLeave(node, eventInfo, e) - Triggered when the user mouse-outs a node. *node* is the <Graph.Node> 'mouse-outed'. *e* is the grabbed event (should return the native event in a cross-browser manner). *eventInfo* is an object containing useful methods like *getPos* to get the mouse position relative to the canvas. 
-  onDragStart(node, eventInfo, e) - Triggered when the user mouse-downs over a node. *node* is the <Graph.Node> being pressed. *e* is the grabbed event (should return the native event in a cross-browser manner). *eventInfo* is an object containing useful methods like *getPos* to get the mouse position relative to the canvas. 
-  onDragMove(node, eventInfo, e) - Triggered when a user, after pressing the mouse button over a node, moves the mouse around. *node* is the <Graph.Node> being dragged. *e* is the grabbed event (should return the native event in a cross-browser manner). *eventInfo* is an object containing useful methods like *getPos* to get the mouse position relative to the canvas. 
-  onDragEnd(node, eventInfo, e) - Triggered when a user finished dragging a node. *node* is the <Graph.Node> being dragged. *e* is the grabbed event (should return the native event in a cross-browser manner). *eventInfo* is an object containing useful methods like *getPos* to get the mouse position relative to the canvas. 
-  onDragCancel(node, eventInfo, e) - Triggered when the user releases the mouse button over a <Graph.Node> that wasn't dragged (i.e. the user didn't perform any mouse movement after pressing the mouse button). *node* is the <Graph.Node> being dragged. *e* is the grabbed event (should return the native event in a cross-browser manner). *eventInfo* is an object containing useful methods like *getPos* to get the mouse position relative to the canvas. 
-  onTouchStart(node, eventInfo, e) - Behaves just like onDragStart. 
-  onTouchMove(node, eventInfo, e) - Behaves just like onDragMove. 
-  onTouchEnd(node, eventInfo, e) - Behaves just like onDragEnd. 
-  onTouchCancel(node, eventInfo, e) - Behaves just like onDragCancel.
-  onMouseWheel(delta, e) - Triggered when the user uses the mouse scroll over the canvas. *delta* is 1 or -1 depending on the sense of the mouse scroll.
-*/
-
-Options.Events = {
-  $extend: false,
-  
-  enable: false,
-  enableForEdges: false,
-  type: 'auto',
-  onClick: $.empty,
-  onRightClick: $.empty,
-  onMouseMove: $.empty,
-  onMouseEnter: $.empty,
-  onMouseLeave: $.empty,
-  onDragStart: $.empty,
-  onDragMove: $.empty,
-  onDragCancel: $.empty,
-  onDragEnd: $.empty,
-  onTouchStart: $.empty,
-  onTouchMove: $.empty,
-  onTouchEnd: $.empty,
-  onMouseWheel: $.empty
-};
-
-/*
- * File: Options.Navigation.js
- *
-*/
-
-/*
-  Object: Options.Navigation
-  
-  Panning and zooming options for Graph/Tree based visualizations. These options are implemented 
-  by all visualizations except charts (<AreaChart>, <BarChart> and <PieChart>).
-  
-  Syntax:
-  
-  (start code js)
-
-  Options.Navigation = {
-    enable: false,
-    type: 'auto',
-    panning: false, //true, 'avoid nodes'
-    zooming: false
-  };
-  
-  (end code)
-  
-  Example:
-    
-  (start code js)
-  var viz = new $jit.Viz({
-    Navigation: {
-      enable: true,
-      panning: 'avoid nodes',
-      zooming: 20
-    }
-  });
-  (end code)
-  
-  Parameters:
-  
-  enable - (boolean) Default's *false*. Whether to enable Navigation capabilities.
-  type - (string) Default's 'auto'. Whether to attach the navigation events onto the HTML labels (via event delegation) or to use the custom 'Native' canvas Event System of the library. When 'auto' set when you let the <Options.Label> *type* parameter decide this.
-  panning - (boolean|string) Default's *false*. Set this property to *true* if you want to add Drag and Drop panning support to the visualization. You can also set this parameter to 'avoid nodes' to enable DnD panning but disable it if the DnD is taking place over a node. This is useful when some other events like Drag & Drop for nodes are added to <Graph.Nodes>.
-  zooming - (boolean|number) Default's *false*. Set this property to a numeric value to turn mouse-scroll zooming on. The number will be proportional to the mouse-scroll sensitivity.
-  
-*/
-
-Options.Navigation = {
-  $extend: false,
-  
-  enable: false,
-  type: 'auto',
-  panning: false, //true | 'avoid nodes'
-  zooming: false
-};
-
-/*
- * File: Options.Controller.js
- *
-*/
-
-/*
-  Object: Options.Controller
-  
-  Provides controller methods. Controller methods are callback functions that get called at different stages 
-  of the animation, computing or plotting of the visualization.
-  
-  Implemented by:
-    
-  All visualizations except charts (<AreaChart>, <BarChart> and <PieChart>).
-  
-  Syntax:
-  
-  (start code js)
-
-  Options.Controller = {
-    onBeforeCompute: $.empty,
-    onAfterCompute:  $.empty,
-    onCreateLabel:   $.empty,
-    onPlaceLabel:    $.empty,
-    onComplete:      $.empty,
-    onBeforePlotLine:$.empty,
-    onAfterPlotLine: $.empty,
-    onBeforePlotNode:$.empty,
-    onAfterPlotNode: $.empty,
-    request:         false
-  };
-  
-  (end code)
-  
-  Example:
-    
-  (start code js)
-  var viz = new $jit.Viz({
-    onBeforePlotNode: function(node) {
-      if(node.selected) {
-        node.setData('color', '#ffc');
-      } else {
-        node.removeData('color');
-      }
-    },
-    onBeforePlotLine: function(adj) {
-      if(adj.nodeFrom.selected && adj.nodeTo.selected) {
-        adj.setData('color', '#ffc');
-      } else {
-        adj.removeData('color');
-      }
-    },
-    onAfterCompute: function() {
-      alert("computed!");
-    }
-  });
-  (end code)
-  
-  Parameters:
-
-   onBeforeCompute(node) - This method is called right before performing all computations and animations. The selected <Graph.Node> is passed as parameter.
-   onAfterCompute() - This method is triggered after all animations or computations ended.
-   onCreateLabel(domElement, node) - This method receives a new label DIV element as first parameter, and the corresponding <Graph.Node> as second parameter. This method will only be called once for each label. This method is useful when adding events or styles to the labels used by the JIT.
-   onPlaceLabel(domElement, node) - This method receives a label DIV element as first parameter and the corresponding <Graph.Node> as second parameter. This method is called each time a label has been placed in the visualization, for example at each step of an animation, and thus it allows you to update the labels properties, such as size or position. Note that onPlaceLabel will be triggered after updating the labels positions. That means that, for example, the left and top css properties are already updated to match the nodes positions. Width and height properties are not set however.
-   onBeforePlotNode(node) - This method is triggered right before plotting each <Graph.Node>. This method is useful for changing a node style right before plotting it.
-   onAfterPlotNode(node) - This method is triggered right after plotting each <Graph.Node>.
-   onBeforePlotLine(adj) - This method is triggered right before plotting a <Graph.Adjacence>. This method is useful for adding some styles to a particular edge before being plotted.
-   onAfterPlotLine(adj) - This method is triggered right after plotting a <Graph.Adjacence>.
-   onBeforeRemoveNode(node) - This method is triggered right before removing each <Graph.Node>.
-   
-    *Used in <ST>, <TM.Base> and <Icicle> visualizations*
-    
-    request(nodeId, level, onComplete) - This method is used for buffering information into the visualization. When clicking on an empty node, the visualization will make a request for this node's subtrees, specifying a given level for this subtree (defined by _levelsToShow_). Once the request is completed, the onComplete callback should be called with the given result. This is useful to provide on-demand information into the visualizations withought having to load the entire information from start. The parameters used by this method are _nodeId_, which is the id of the root of the subtree to request, _level_ which is the depth of the subtree to be requested (0 would mean just the root node). _onComplete_ is an object having the callback method _onComplete.onComplete(json)_ that should be called once the json has been retrieved.  
- */
-Options.Controller = {
-  $extend: true,
-  
-  onBeforeCompute:   $.empty,
-  onAfterCompute:    $.empty,
-  onCreateLabel:     $.empty,
-  onPlaceLabel:      $.empty,
-  onComplete:        $.empty,
-  onBeforePlotLine:  $.empty,
-  onAfterPlotLine:   $.empty,
-  onBeforePlotNode:  $.empty,
-  onAfterPlotNode:   $.empty,
-  onBeforeRemoveNode:$.empty,
-  request:         false
-};
-
-
-/*
- * File: Extras.js
- * 
- * Provides Extras such as Tips and Style Effects.
- * 
- * Description:
- * 
- * Provides the <Tips> and <NodeStyles> classes and functions.
- *
- */
-
-/*
- * Manager for mouse events (clicking and mouse moving).
- * 
- * This class is used for registering objects implementing onClick
- * and onMousemove methods. These methods are called when clicking or
- * moving the mouse around  the Canvas.
- * For now, <Tips> and <NodeStyles> are classes implementing these methods.
- * 
- */
-var MultiExtrasInitializer = {
-  initialize: function(className, viz) {
-    this.viz = viz;
-    this.canvas = viz.canvas;
-    this.config = viz.config[className];
-    this.nodeTypes = viz.fx.nodeTypes;
-    var type = this.config.type;
-    this.dom = type == 'auto'? (viz.config.Label.type != 'Native') : (type != 'Native');
-    this.labelContainer = this.dom && viz.labels.getLabelContainer();
-    this.isEnabled() && this.initializePost();
-  },
-  initializePost: $.empty,
-  setAsProperty: $.lambda(false),
-  isEnabled: function() {
-    return this.config.enable;
-  },
-  isLabel: function(e, win, group) {
-    e = $.event.get(e, win);
-    var labelContainer = this.labelContainer,
-        target = e.target || e.srcElement,
-        related = e.relatedTarget;
-    if(group) {
-      return related && related == this.viz.canvas.getCtx().canvas 
-          && !!target && this.isDescendantOf(target, labelContainer);
-    } else {
-      return this.isDescendantOf(target, labelContainer);
-    }
-  },
-  isDescendantOf: function(elem, par) {
-    while(elem && elem.parentNode) {
-      if(elem.parentNode == par)
-        return elem;
-      elem = elem.parentNode;
-    }
-    return false;
-  }
-};
-
-var MultiEventsInterface = {
-  onMouseUp: $.empty,
-  onMouseDown: $.empty,
-  onMouseMove: $.empty,
-  onMouseOver: $.empty,
-  onMouseOut: $.empty,
-  onMouseWheel: $.empty,
-  onTouchStart: $.empty,
-  onTouchMove: $.empty,
-  onTouchEnd: $.empty,
-  onTouchCancel: $.empty
-};
-
-var MouseEventsManager = new Class({
-  initialize: function(viz) {
-    this.viz = viz;
-    this.canvas = viz.canvas;
-    this.node = false;
-    this.edge = false;
-    this.registeredObjects = [];
-    this.attachEvents();
-  },
-  
-  attachEvents: function() {
-    var htmlCanvas = this.canvas.getElement(), 
-        that = this;
-    htmlCanvas.oncontextmenu = $.lambda(false);
-    $.addEvents(htmlCanvas, {
-      'mouseup': function(e, win) {
-        var event = $.event.get(e, win);
-        that.handleEvent('MouseUp', e, win, 
-            that.makeEventObject(e, win), 
-            $.event.isRightClick(event));
-      },
-      'mousedown': function(e, win) {
-        var event = $.event.get(e, win);
-        that.handleEvent('MouseDown', e, win, that.makeEventObject(e, win), 
-            $.event.isRightClick(event));
-      },
-      'mousemove': function(e, win) {
-        that.handleEvent('MouseMove', e, win, that.makeEventObject(e, win));
-      },
-      'mouseover': function(e, win) {
-        that.handleEvent('MouseOver', e, win, that.makeEventObject(e, win));
-      },
-      'mouseout': function(e, win) {
-        that.handleEvent('MouseOut', e, win, that.makeEventObject(e, win));
-      },
-      'touchstart': function(e, win) {
-        that.handleEvent('TouchStart', e, win, that.makeEventObject(e, win));
-      },
-      'touchmove': function(e, win) {
-        that.handleEvent('TouchMove', e, win, that.makeEventObject(e, win));
-      },
-      'touchend': function(e, win) {
-        that.handleEvent('TouchEnd', e, win, that.makeEventObject(e, win));
-      }
-    });
-    //attach mousewheel event
-    var handleMouseWheel = function(e, win) {
-      var event = $.event.get(e, win);
-      var wheel = $.event.getWheel(event);
-      that.handleEvent('MouseWheel', e, win, wheel);
-    };
-    //TODO(nico): this is a horrible check for non-gecko browsers!
-    if(!document.getBoxObjectFor && window.mozInnerScreenX == null) {
-      $.addEvent(htmlCanvas, 'mousewheel', handleMouseWheel);
-    } else {
-      htmlCanvas.addEventListener('DOMMouseScroll', handleMouseWheel, false);
-    }
-  },
-  
-  register: function(obj) {
-    this.registeredObjects.push(obj);
-  },
-  
-  handleEvent: function() {
-    var args = Array.prototype.slice.call(arguments),
-        type = args.shift();
-    for(var i=0, regs=this.registeredObjects, l=regs.length; i<l; i++) {
-      regs[i]['on' + type].apply(regs[i], args);
-    }
-  },
-  
-  makeEventObject: function(e, win) {
-    var that = this,
-        graph = this.viz.graph,
-        fx = this.viz.fx,
-        ntypes = fx.nodeTypes,
-        etypes = fx.edgeTypes;
-    return {
-      pos: false,
-      node: false,
-      edge: false,
-      contains: false,
-      getNodeCalled: false,
-      getEdgeCalled: false,
-      getPos: function() {
-        //TODO(nico): check why this can't be cache anymore when using edge detection
-        //if(this.pos) return this.pos;
-        var canvas = that.viz.canvas,
-            s = canvas.getSize(),
-            p = canvas.getPos(),
-            ox = canvas.translateOffsetX,
-            oy = canvas.translateOffsetY,
-            sx = canvas.scaleOffsetX,
-            sy = canvas.scaleOffsetY,
-            pos = $.event.getPos(e, win);
-        this.pos = {
-          x: (pos.x - p.x - s.width/2 - ox) * 1/sx,
-          y: (pos.y - p.y - s.height/2 - oy) * 1/sy
-        };
-        return this.pos;
-      },
-      getNode: function() {
-        if(this.getNodeCalled) return this.node;
-        this.getNodeCalled = true;
-        for(var id in graph.nodes) {
-          var n = graph.nodes[id],
-              geom = n && ntypes[n.getData('type')],
-              contains = geom && geom.contains && geom.contains.call(fx, n, this.getPos());
-          if(contains) {
-            this.contains = contains;
-            return that.node = this.node = n;
-          }
-        }
-        return that.node = this.node = false;
-      },
-      getEdge: function() {
-               if(this.getEdgeCalled) return this.edge;
-               this.getEdgeCalled = true;
-
-                 var checkDupEdge = function(e) {
-                       var skip = false;
-                       for(var d in graph.dup) {
-                               var ee = graph.dup[d];
-                               if(e.nodeTo.id == ee.nodeTo.id && e.nodeFrom.id == ee.nodeFrom.id) {
-                                       if(e.portTo == ee.portTo && e.portFrom == ee.portFrom) {
-                                               skip = true;
-                                               break; // NOTE: does this break the outer for loop?
-                                       }
-                               }
-                       }
-                       return skip;
-                 };
-  
-               // you want to go through all the edges in this graph
-               for(var id in graph.edges) {
-                       var edgeFrom = graph.edges[id];
-
-                       for(var edgeId in edgeFrom) {
-                               // proceed with contains check
-                               var total = edgeFrom[edgeId].length;
-                               if (total == 1) {
-                                       var e = edgeFrom[edgeId][0];
-
-                                       if(checkDupEdge(e)) continue; // skip this edge if it is a dup
-
-                                       var geom = e && etypes[e.getData('type')],
-                                               contains = geom && geom.contains && geom.contains.call(fx, e, 0, this.getPos(), that.canvas);
-
-                                       if (contains) {
-                                               this.contains = contains;
-                                               return that.edge = this.edge = e;
-                                       }
-                               } else {
-                                       for(var idj in edgeFrom[edgeId]) {
-                                               var e = edgeFrom[edgeId][idj];
-
-                                               if(checkDupEdge(e)) continue; // skip this edge if it is a dup
-
-                                               var alpha = parseInt(idj,10);
-                                               var start = (0.5-(total/2));
-                                               alpha += start;
-
-                                               var geom = e && etypes[e.getData('type')],
-                                                       contains = geom && geom.contains && geom.contains.call(fx, e, alpha, this.getPos(), that.canvas);
-                                               if (contains) {
-                                                       this.contains = contains;
-                                                       return that.edge = this.edge = e;
-                                               }
-                                       }
-                               }
-                       }
-               }
-               return that.edge = this.edge = false;
-
-               /*
-        if(this.getEdgeCalled) return this.edge;
-        this.getEdgeCalled = true;
-        var hashset = {};
-        for(var id in graph.edges) {
-          var edgeFrom = graph.edges[id];
-          hashset[id] = true;
-          for(var edgeId in edgeFrom) {
-            if(edgeId in hashset) continue;
-            var e = edgeFrom[edgeId],
-                geom = e && etypes[e.getData('type')],
-                contains = geom && geom.contains && geom.contains.call(fx, e, this.getPos());
-            if(contains) {
-              this.contains = contains;
-              return that.edge = this.edge = e;
-            }
-          }
-        }
-        return that.edge = this.edge = false;
-               */
-      },
-      getContains: function() {
-        if(this.getNodeCalled) return this.contains;
-        this.getNode();
-        return this.contains;
-      }
-    };
-  }
-});
-
-/* 
- * Provides the initialization function for <NodeStyles> and <Tips> implemented 
- * by all main visualizations.
- *
- */
-var MultiExtras = {
-  initializeExtras: function() {
-    var mem = new MouseEventsManager(this), that = this;
-    $.each(['NodeStyles', 'Tips', 'Navigation', 'Events'], function(k) {
-      var obj = new MultiExtras.Classes[k](k, that);
-      if(obj.isEnabled()) {
-        mem.register(obj);
-      }
-      if(obj.setAsProperty()) {
-        that[k.toLowerCase()] = obj;
-      }
-    });
-  }   
-};
-
-MultiExtras.Classes = {};
-/*
-  Class: Events
-   
-  This class defines an Event API to be accessed by the user.
-  The methods implemented are the ones defined in the <Options.Events> object.
-*/
-
-MultiExtras.Classes.Events = new Class({
-  Implements: [MultiExtrasInitializer, MultiEventsInterface],
-  
-  initializePost: function() {
-    this.fx = this.viz.fx;
-    this.ntypes = this.viz.fx.nodeTypes;
-    this.etypes = this.viz.fx.edgeTypes;
-    
-    this.hovered = false;
-    this.pressed = false;
-    this.touched = false;
-
-    this.touchMoved = false;
-    this.moved = false;
-    
-  },
-  
-  setAsProperty: $.lambda(true),
-
-  onMouseUp: function(e, win, event, isRightClick) {
-    var evt = $.event.get(e, win);
-    if(!this.moved) {
-      if(isRightClick) {
-        this.config.onRightClick(this.hovered, event, evt);
-      } else {
-        this.config.onClick(this.pressed, event, evt);
-      }
-    }
-    if(this.pressed) {
-      if(this.moved) {
-        this.config.onDragEnd(this.pressed, event, evt);
-      } else {
-        this.config.onDragCancel(this.pressed, event, evt);
-      }
-      this.pressed = this.moved = false;
-    }
-  },
-
-  onMouseOut: function(e, win, event) {
-   //mouseout a label
-   var evt = $.event.get(e, win), label;
-   if(this.dom && (label = this.isLabel(e, win, true))) {
-     this.config.onMouseLeave(this.viz.graph.getNode(label.id),
-                              event, evt);
-     this.hovered = false;
-     return;
-   }
-   //mouseout canvas
-   var rt = evt.relatedTarget,
-       canvasWidget = this.canvas.getElement();
-   while(rt && rt.parentNode) {
-     if(canvasWidget == rt.parentNode) return;
-     rt = rt.parentNode;
-   }
-   if(this.hovered) {
-     this.config.onMouseLeave(this.hovered,
-         event, evt);
-     this.hovered = false;
-   }
-  },
-  
-  onMouseOver: function(e, win, event) {
-    //mouseover a label
-    var evt = $.event.get(e, win), label;
-    if(this.dom && (label = this.isLabel(e, win, true))) {
-      this.hovered = this.viz.graph.getNode(label.id);
-      this.config.onMouseEnter(this.hovered,
-                               event, evt);
-    }
-  },
-  
-  onMouseMove: function(e, win, event) {
-   var label, evt = $.event.get(e, win);
-   if(this.pressed) {
-     this.moved = true;
-     this.config.onDragMove(this.pressed, event, evt);
-     return;
-   }
-   if(this.dom) {
-     this.config.onMouseMove(this.hovered, event, evt);
-   } else {
-     if(this.hovered) { // if there is a hovered element
-               if(this.hovered.id == undefined) { // if this is an edge
-                       var hn = this.hovered;
-                       var geom = this.etypes[hn.getData('type')];
-                       var contains = false;
-
-                       // find alpha and total
-                       var list = this.viz.graph.edges[hn.nodeFrom.id][hn.nodeTo.id];
-                       if (list != undefined || list.length != 0) {
-                               var total = list.length;
-                               for(var idj = 0; idj < total; idj++) {
-                                       var e = list[idj];
-
-                                       // check if we need to skip this dup edge
-                                       // NOTE: is this even needed, if getEdge() already fulfills this action?
-                                       var skip = false;
-                                       for(var d in this.viz.graph.dup) {
-                                               var ee = this.viz.graph.dup[d];
-                                               if(e.nodeTo.id == ee.nodeTo.id && e.nodeFrom.id == ee.nodeFrom.id) {
-                                                       if(e.portTo == ee.portTo && e.portFrom == ee.portFrom) {
-                                                               skip = true;
-                                                               break;
-                                                       }
-                                               }
-                                       }
-                                       if(skip) continue; // skip this edge if it is a dup
-
-                                       var alpha = parseInt(idj,10);
-                                       var start = (0.5-(total/2));
-                                       alpha += start;
-
-                                       if(list[idj].portFrom == hn.portFrom
-                                       && list[idj].portTo == hn.portTo) {
-                                               contains = geom.contains.call(this.fx, hn, alpha, event.getPos(), this.canvas);
-                                               break;
-                                       }
-                               }
-                       }
-
-                       if (contains) {
-                               this.config.onMouseEnter(this.hovered, event, evt);
-                               return;
-                       } else {
-                               this.config.onMouseLeave(hn, event, evt);
-                               this.hovered = false;
-                       }
-               } else { // if this is a node
-                  var hn = this.hovered;
-                  var geom = hn.nodeFrom? this.etypes[hn.getData('type')] : this.ntypes[hn.getData('type')];
-                  var contains = geom && geom.contains 
-                        && geom.contains.call(this.fx, hn, event.getPos());
-                  if(contains) {
-                        this.config.onMouseMove(hn, event, evt);
-                        return;
-                  } else {
-                        this.config.onMouseLeave(hn, event, evt);
-                        this.hovered = false;
-                  }
-                }
-        }
-
-     if(this.hovered = event.getNode()) {
-       this.config.onMouseEnter(this.hovered, event, evt);
-        } else if (this.hovered = event.getEdge()) { // event for edges
-               this.config.onMouseEnter(this.hovered, event, evt);
-     } else {
-       this.config.onMouseMove(false, event, evt);
-     }
-   }
-  },
-  
-  onMouseWheel: function(e, win, delta) {
-    this.config.onMouseWheel(delta, $.event.get(e, win));
-  },
-  
-  onMouseDown: function(e, win, event) {
-    var evt = $.event.get(e, win), label;
-    if(this.dom) {
-      if(label = this.isLabel(e, win)) {
-        this.pressed = this.viz.graph.getNode(label.id);
-      }
-    } else {
-      this.pressed = event.getNode() || (this.config.enableForEdges && event.getEdge());
-    }
-    this.pressed && this.config.onDragStart(this.pressed, event, evt);
-  },
-  
-  onTouchStart: function(e, win, event) {
-    var evt = $.event.get(e, win), label;
-    if(this.dom && (label = this.isLabel(e, win))) {
-      this.touched = this.viz.graph.getNode(label.id);
-    } else {
-      this.touched = event.getNode() || (this.config.enableForEdges && event.getEdge());
-    }
-    this.touched && this.config.onTouchStart(this.touched, event, evt);
-  },
-  
-  onTouchMove: function(e, win, event) {
-    var evt = $.event.get(e, win);
-    if(this.touched) {
-      this.touchMoved = true;
-      this.config.onTouchMove(this.touched, event, evt);
-    }
-  },
-  
-  onTouchEnd: function(e, win, event) {
-    var evt = $.event.get(e, win);
-    if(this.touched) {
-      if(this.touchMoved) {
-        this.config.onTouchEnd(this.touched, event, evt);
-      } else {
-        this.config.onTouchCancel(this.touched, event, evt);
-      }
-      this.touched = this.touchMoved = false;
-    }
-  }
-});
-
-/*
-   Class: Tips
-    
-   A class containing tip related functions. This class is used internally.
-   
-   Used by:
-   
-   <ST>, <Sunburst>, <Hypertree>, <RGraph>, <TM>, <ForceDirected>, <Icicle>
-   
-   See also:
-   
-   <Options.Tips>
-*/
-
-MultiExtras.Classes.Tips = new Class({
-  Implements: [MultiExtrasInitializer, MultiEventsInterface],
-  
-  initializePost: function() {
-    //add DOM tooltip
-    if(document.body) {
-      var tip = $('_tooltip') || document.createElement('div');
-      tip.id = '_tooltip';
-      tip.className = 'tip';
-      $.extend(tip.style, {
-        position: 'absolute',
-        display: 'none',
-        zIndex: 13000
-      });
-      document.body.appendChild(tip);
-      this.tip = tip;
-      this.node = false;
-    }
-  },
-  
-  setAsProperty: $.lambda(true),
-  
-  onMouseOut: function(e, win) {
-    //mouseout a label
-    var evt = $.event.get(e, win);
-    if(this.dom && this.isLabel(e, win, true)) {
-      this.hide(true);
-      return;
-    }
-    //mouseout canvas
-    var rt = e.relatedTarget,
-        canvasWidget = this.canvas.getElement();
-    while(rt && rt.parentNode) {
-      if(canvasWidget == rt.parentNode) return;
-      rt = rt.parentNode;
-    }
-    this.hide(false);
-  },
-  
-  onMouseOver: function(e, win) {
-    //mouseover a label
-    var label;
-    if(this.dom && (label = this.isLabel(e, win, false))) {
-      this.node = this.viz.graph.getNode(label.id);
-      this.config.onShow(this.tip, this.node, label);
-    }
-  },
-  
-  onMouseMove: function(e, win, opt) {
-    if(this.dom && this.isLabel(e, win)) {
-      this.setTooltipPosition($.event.getPos(e, win));
-    }
-    if(!this.dom) {
-      var node = opt.getNode();
-         var edge = opt.getEdge();
-      if(!node && !edge) { // additionally for edge
-        this.hide(true);
-        return;
-      }
-      /*if(this.config.force || !this.node || this.node.id != node.id) {
-        this.node = node;
-        this.config.onShow(this.tip, node, opt.getContains());
-      }*/
-               if (node != false) {    
-                       if (this.config.force || !this.node || this.node.id != node.id) {
-                               this.node = node;
-                               this.edge = false;
-                               this.config.onShow(this.tip, node, opt.getContains());
-                       }
-               } else if (edge != false) {
-                       this.edge = edge;
-                       this.node = false;
-                       this.config.onShow(this.tip, edge, opt.getContains());
-               }
-      this.setTooltipPosition($.event.getPos(e, win));
-    }
-  },
-  
-  setTooltipPosition: function(pos) {
-    var tip = this.tip, 
-        style = tip.style, 
-        cont = this.config;
-    style.display = '';
-    //get viewport dimensions
-    var elem = document.compatMode === "CSS1Compat" && document.documentElement ||
-               document.body ||
-               document.documentElement;
-    var view = {
-      'width': elem.clientWidth,
-      'height': elem.clientHeight,
-      'x': window.pageXOffset ||
-           document.documentElement && document.documentElement.scrollLeft ||
-           document.body && document.body.scrollLeft ||
-           0,
-      'y': window.pageYOffset ||
-           document.documentElement && document.documentElement.scrollTop ||
-           document.body && document.body.scrollTop ||
-           0
-    };
-    //get tooltip dimensions
-    var obj = {
-      'width': tip.offsetWidth,
-      'height': tip.offsetHeight  
-    };
-    //set tooltip position
-    var x = cont.offsetX, y = cont.offsetY;
-    style.top = ((pos.y + obj.height + y > view.height + view.y)?
-        (pos.y - obj.height - y) : pos.y + y) + 'px';
-    style.left = ((pos.x + obj.width + x > view.width + view.x)?
-        (pos.x - obj.width - x) : pos.x + x) + 'px';
-  },
-  
-  hide: function(triggerCallback) {
-    this.tip.style.display = 'none';
-    triggerCallback && this.config.onHide();
-  }
-});
-
-/*
-  Class: NodeStyles
-   
-  Change node styles when clicking or hovering a node. This class is used internally.
-  
-  Used by:
-  
-  <ST>, <Sunburst>, <Hypertree>, <RGraph>, <TM>, <ForceDirected>, <Icicle>
-  
-  See also:
-  
-  <Options.NodeStyles>
-*/
-MultiExtras.Classes.NodeStyles = new Class({
-  Implements: [MultiExtrasInitializer, MultiEventsInterface],
-  
-  initializePost: function() {
-    this.fx = this.viz.fx;
-    this.types = this.viz.fx.nodeTypes;
-    this.nStyles = this.config;
-    this.nodeStylesOnHover = this.nStyles.stylesHover;
-    this.nodeStylesOnClick = this.nStyles.stylesClick;
-    this.hoveredNode = false;
-    this.fx.nodeFxAnimation = new Animation();
-    
-    this.down = false;
-    this.move = false;
-  },
-  
-  onMouseOut: function(e, win) {
-    this.down = this.move = false;
-    if(!this.hoveredNode) return;
-    //mouseout a label
-    if(this.dom && this.isLabel(e, win, true)) {
-      this.toggleStylesOnHover(this.hoveredNode, false);
-    }
-    //mouseout canvas
-    var rt = e.relatedTarget,
-        canvasWidget = this.canvas.getElement();
-    while(rt && rt.parentNode) {
-      if(canvasWidget == rt.parentNode) return;
-      rt = rt.parentNode;
-    }
-    this.toggleStylesOnHover(this.hoveredNode, false);
-    this.hoveredNode = false;
-  },
-  
-  onMouseOver: function(e, win) {
-    //mouseover a label
-    var label;
-    if(this.dom && (label = this.isLabel(e, win, true))) {
-      var node = this.viz.graph.getNode(label.id);
-      if(node.selected) return;
-      this.hoveredNode = node;
-      this.toggleStylesOnHover(this.hoveredNode, true);
-    }
-  },
-  
-  onMouseDown: function(e, win, event, isRightClick) {
-    if(isRightClick) return;
-    var label;
-    if(this.dom && (label = this.isLabel(e, win))) {
-      this.down = this.viz.graph.getNode(label.id);
-    } else if(!this.dom) {
-      this.down = event.getNode();
-    }
-    this.move = false;
-  },
-  
-  onMouseUp: function(e, win, event, isRightClick) {
-    if(isRightClick) return;
-    if(!this.move) {
-      this.onClick(event.getNode());
-    }
-    this.down = this.move = false;
-  },
-  
-  getRestoredStyles: function(node, type) {
-    var restoredStyles = {}, 
-        nStyles = this['nodeStylesOn' + type];
-    for(var prop in nStyles) {
-      restoredStyles[prop] = node.styles['$' + prop];
-    }
-    return restoredStyles;
-  },
-  
-  toggleStylesOnHover: function(node, set) {
-    if(this.nodeStylesOnHover) {
-      this.toggleStylesOn('Hover', node, set);
-    }
-  },
-
-  toggleStylesOnClick: function(node, set) {
-    if(this.nodeStylesOnClick) {
-      this.toggleStylesOn('Click', node, set);
-    }
-  },
-  
-  toggleStylesOn: function(type, node, set) {
-    var viz = this.viz;
-    var nStyles = this.nStyles;
-    if(set) {
-      var that = this;
-      if(!node.styles) {
-        node.styles = $.merge(node.data, {});
-      }
-      for(var s in this['nodeStylesOn' + type]) {
-        var $s = '$' + s;
-        if(!($s in node.styles)) {
-            node.styles[$s] = node.getData(s); 
-        }
-      }
-      viz.fx.nodeFx($.extend({
-        'elements': {
-          'id': node.id,
-          'properties': that['nodeStylesOn' + type]
-         },
-         transition: Trans.Quart.easeOut,
-         duration:300,
-         fps:40
-      }, this.config));
-    } else {
-      var restoredStyles = this.getRestoredStyles(node, type);
-      viz.fx.nodeFx($.extend({
-        'elements': {
-          'id': node.id,
-          'properties': restoredStyles
-         },
-         transition: Trans.Quart.easeOut,
-         duration:300,
-         fps:40
-      }, this.config));
-    }
-  },
-
-  onClick: function(node) {
-    if(!node) return;
-    var nStyles = this.nodeStylesOnClick;
-    if(!nStyles) return;
-    //if the node is selected then unselect it
-    if(node.selected) {
-      this.toggleStylesOnClick(node, false);
-      delete node.selected;
-    } else {
-      //unselect all selected nodes...
-      this.viz.graph.eachNode(function(n) {
-        if(n.selected) {
-          for(var s in nStyles) {
-            n.setData(s, n.styles['$' + s], 'end');
-          }
-          delete n.selected;
-        }
-      });
-      //select clicked node
-      this.toggleStylesOnClick(node, true);
-      node.selected = true;
-      delete node.hovered;
-      this.hoveredNode = false;
-    }
-  },
-  
-  onMouseMove: function(e, win, event) {
-    //if mouse button is down and moving set move=true
-    if(this.down) this.move = true;
-    //already handled by mouseover/out
-    if(this.dom && this.isLabel(e, win)) return;
-    var nStyles = this.nodeStylesOnHover;
-    if(!nStyles) return;
-    
-    if(!this.dom) {
-      if(this.hoveredNode) {
-        var geom = this.types[this.hoveredNode.getData('type')];
-        var contains = geom && geom.contains && geom.contains.call(this.fx, 
-            this.hoveredNode, event.getPos());
-        if(contains) return;
-      }
-      var node = event.getNode();
-      //if no node is being hovered then just exit
-      if(!this.hoveredNode && !node) return;
-      //if the node is hovered then exit
-      if(node.hovered) return;
-      //select hovered node
-      if(node && !node.selected) {
-        //check if an animation is running and exit it
-        this.fx.nodeFxAnimation.stopTimer();
-        //unselect all hovered nodes...
-        this.viz.graph.eachNode(function(n) {
-          if(n.hovered && !n.selected) {
-            for(var s in nStyles) {
-              n.setData(s, n.styles['$' + s], 'end');
-            }
-            delete n.hovered;
-          }
-        });
-        //select hovered node
-        node.hovered = true;
-        this.hoveredNode = node;
-        this.toggleStylesOnHover(node, true);
-      } else if(this.hoveredNode && !this.hoveredNode.selected) {
-        //check if an animation is running and exit it
-        this.fx.nodeFxAnimation.stopTimer();
-        //unselect hovered node
-        this.toggleStylesOnHover(this.hoveredNode, false);
-        delete this.hoveredNode.hovered;
-        this.hoveredNode = false;
-      }
-    }
-  }
-});
-
-MultiExtras.Classes.Navigation = new Class({
-  Implements: [MultiExtrasInitializer, MultiEventsInterface],
-  
-  initializePost: function() {
-    this.pos = false;
-    this.pressed = false;
-  },
-  
-  onMouseWheel: function(e, win, scroll) {
-    if(!this.config.zooming) return;
-    $.event.stop($.event.get(e, win));
-    var val = this.config.zooming / 1000,
-        ans = 1 + scroll * val;
-    this.canvas.scale(ans, ans);
-  },
-  
-  onMouseDown: function(e, win, eventInfo) {
-    if(!this.config.panning) return;
-    e.preventDefault ? e.preventDefault() : e.returnValue = false;
-    $.addClass(this.canvas.getElement(), 'grabbing');
-    if(this.config.panning == 'avoid nodes' && (this.dom? this.isLabel(e, win) : eventInfo.getNode())) return;
-    this.pressed = true;
-    this.pos = eventInfo.getPos();
-    var canvas = this.canvas,
-        ox = canvas.translateOffsetX,
-        oy = canvas.translateOffsetY,
-        sx = canvas.scaleOffsetX,
-        sy = canvas.scaleOffsetY;
-    this.pos.x *= sx;
-    this.pos.x += ox;
-    this.pos.y *= sy;
-    this.pos.y += oy;
-  },
-  
-  onMouseMove: function(e, win, eventInfo) {
-    if(!this.config.panning) return;
-    if(!this.pressed) return;
-    if(this.config.panning == 'avoid nodes' && (this.dom? this.isLabel(e, win) : eventInfo.getNode())) return;
-    var thispos = this.pos, 
-        currentPos = eventInfo.getPos(),
-        canvas = this.canvas,
-        ox = canvas.translateOffsetX,
-        oy = canvas.translateOffsetY,
-        sx = canvas.scaleOffsetX,
-        sy = canvas.scaleOffsetY;
-    currentPos.x *= sx;
-    currentPos.y *= sy;
-    currentPos.x += ox;
-    currentPos.y += oy;
-    var x = currentPos.x - thispos.x,
-        y = currentPos.y - thispos.y;
-    this.pos = currentPos;
-    this.canvas.translate(x * 1/sx, y * 1/sy);
-  },
-  
-  onMouseUp: function(e, win, eventInfo, isRightClick) {
-    if(!this.config.panning) return;
-    $.removeClass(this.canvas.getElement(), 'grabbing');
-    this.pressed = false;
-  }
-});
-
-
-/*
- * File: Canvas.js
- *
- */
-
-/*
- Class: Canvas
-       A canvas widget used by all visualizations. The canvas object can be accessed by doing *viz.canvas*. If you want to 
-       know more about <Canvas> options take a look at <Options.Canvas>.
- A canvas widget is a set of DOM elements that wrap the native canvas DOM Element providing a consistent API and behavior 
- across all browsers. It can also include Elements to add DOM (SVG or HTML) label support to all visualizations.
- Example:
- Suppose we have this HTML
- (start code xml)
-       <div id="infovis"></div>
- (end code)
- Now we create a new Visualization
- (start code js)
-       var viz = new $jit.Viz({
-               //Where to inject the canvas. Any div container will do.
-               'injectInto':'infovis',
-                //width and height for canvas. 
-                //Default's to the container offsetWidth and Height.
-                'width': 900,
-                'height':500
-        });
- (end code)
-
- The generated HTML will look like this
- (start code xml)
- <div id="infovis">
-       <div id="infovis-canvaswidget" style="position:relative;">
-       <canvas id="infovis-canvas" width=900 height=500
-       style="position:absolute; top:0; left:0; width:900px; height:500px;" />
-       <div id="infovis-label"
-       style="overflow:visible; position:absolute; top:0; left:0; width:900px; height:0px">
-       </div>
-       </div>
- </div>
- (end code)
- As you can see, the generated HTML consists of a canvas DOM Element of id *infovis-canvas* and a div label container
- of id *infovis-label*, wrapped in a main div container of id *infovis-canvaswidget*.
- */
-
-var Canvas;
-(function() {
-  //check for native canvas support
-  var canvasType = typeof HTMLCanvasElement,
-      supportsCanvas = (canvasType == 'object' || canvasType == 'function');
-  //create element function
-  function $E(tag, props) {
-    var elem = document.createElement(tag);
-    for(var p in props) {
-      if(typeof props[p] == "object") {
-        $.extend(elem[p], props[p]);
-      } else {
-        elem[p] = props[p];
-      }
-    }
-    if (tag == "canvas" && !supportsCanvas && G_vmlCanvasManager) {
-      elem = G_vmlCanvasManager.initElement(document.body.appendChild(elem));
-    }
-    return elem;
-  }
-  //canvas widget which we will call just Canvas
-  $jit.Canvas = Canvas = new Class({
-    canvases: [],
-    pos: false,
-    element: false,
-    labelContainer: false,
-    translateOffsetX: 0,
-    translateOffsetY: 0,
-    scaleOffsetX: 1,
-    scaleOffsetY: 1,
-    
-    initialize: function(viz, opt) {
-      this.viz = viz;
-      this.opt = this.config = opt;
-      var id = $.type(opt.injectInto) == 'string'? 
-          opt.injectInto:opt.injectInto.id,
-          type = opt.type,
-          idLabel = id + "-label", 
-          wrapper = $(id),
-          width = opt.width || wrapper.offsetWidth,
-          height = opt.height || wrapper.offsetHeight;
-      this.id = id;
-      //canvas options
-      var canvasOptions = {
-        injectInto: id,
-        width: width,
-        height: height
-      };
-      //create main wrapper
-      this.element = $E('div', {
-        'id': id + '-canvaswidget',
-        'style': {
-          'position': 'relative',
-          'width': width + 'px',
-          'height': height + 'px'
-        }
-      });
-      //create label container
-      this.labelContainer = this.createLabelContainer(opt.Label.type, 
-          idLabel, canvasOptions);
-      //create primary canvas
-      this.canvases.push(new Canvas.Base[type]({
-        config: $.extend({idSuffix: '-canvas'}, canvasOptions),
-        plot: function(base) {
-          viz.fx.plot();
-        },
-        resize: function() {
-          viz.refresh();
-        }
-      }));
-      //create secondary canvas
-      var back = opt.background;
-      if(back) {
-        var backCanvas = new Canvas.Background[back.type](viz, $.extend(back, canvasOptions));
-        this.canvases.push(new Canvas.Base[type](backCanvas));
-      }
-      //insert canvases
-      var len = this.canvases.length;
-      while(len--) {
-        this.element.appendChild(this.canvases[len].canvas);
-        if(len > 0) {
-          this.canvases[len].plot();
-        }
-      }
-      this.element.appendChild(this.labelContainer);
-      wrapper.appendChild(this.element);
-      //Update canvas position when the page is scrolled.
-      var timer = null, that = this;
-      $.addEvent(window, 'scroll', function() {
-        clearTimeout(timer);
-        timer = setTimeout(function() {
-          that.getPos(true); //update canvas position
-        }, 500);
-      });
-    },
-    /*
-      Method: getCtx
-      
-      Returns the main canvas context object
-      
-      Example:
-      
-      (start code js)
-       var ctx = canvas.getCtx();
-       //Now I can use the native canvas context
-       //and for example change some canvas styles
-       ctx.globalAlpha = 1;
-      (end code)
-    */
-    getCtx: function(i) {
-      return this.canvases[i || 0].getCtx();
-    },
-    /*
-      Method: getConfig
-      
-      Returns the current Configuration for this Canvas Widget.
-      
-      Example:
-      
-      (start code js)
-       var config = canvas.getConfig();
-      (end code)
-    */
-    getConfig: function() {
-      return this.opt;
-    },
-    /*
-      Method: getElement
-
-      Returns the main Canvas DOM wrapper
-      
-      Example:
-      
-      (start code js)
-       var wrapper = canvas.getElement();
-       //Returns <div id="infovis-canvaswidget" ... >...</div> as element
-      (end code)
-    */
-    getElement: function() {
-      return this.element;
-    },
-    /*
-      Method: getSize
-      
-      Returns canvas dimensions.
-      
-      Returns:
-      
-      An object with *width* and *height* properties.
-      
-      Example:
-      (start code js)
-      canvas.getSize(); //returns { width: 900, height: 500 }
-      (end code)
-    */
-    getSize: function(i) {
-      return this.canvases[i || 0].getSize();
-    },
-    /*
-      Method: resize
-      
-      Resizes the canvas.
-      
-      Parameters:
-      
-      width - New canvas width.
-      height - New canvas height.
-      
-      Example:
-      
-      (start code js)
-       canvas.resize(width, height);
-      (end code)
-    
-    */
-    resize: function(width, height) {
-      this.getPos(true);
-      this.translateOffsetX = this.translateOffsetY = 0;
-      this.scaleOffsetX = this.scaleOffsetY = 1;
-      for(var i=0, l=this.canvases.length; i<l; i++) {
-        this.canvases[i].resize(width, height);
-      }
-      var style = this.element.style;
-      style.width = width + 'px';
-      style.height = height + 'px';
-      if(this.labelContainer)
-        this.labelContainer.style.width = width + 'px';
-    },
-    /*
-      Method: translate
-      
-      Applies a translation to the canvas.
-      
-      Parameters:
-      
-      x - (number) x offset.
-      y - (number) y offset.
-      disablePlot - (boolean) Default's *false*. Set this to *true* if you don't want to refresh the visualization.
-      
-      Example:
-      
-      (start code js)
-       canvas.translate(30, 30);
-      (end code)
-    
-    */
-    translate: function(x, y, disablePlot) {
-      this.translateOffsetX += x*this.scaleOffsetX;
-      this.translateOffsetY += y*this.scaleOffsetY;
-      for(var i=0, l=this.canvases.length; i<l; i++) {
-        this.canvases[i].translate(x, y, disablePlot);
-      }
-    },
-    /*
-      Method: scale
-      
-      Scales the canvas.
-      
-      Parameters:
-      
-      x - (number) scale value.
-      y - (number) scale value.
-      disablePlot - (boolean) Default's *false*. Set this to *true* if you don't want to refresh the visualization.
-      
-      Example:
-      
-      (start code js)
-       canvas.scale(0.5, 0.5);
-      (end code)
-    
-    */
-    scale: function(x, y, disablePlot) {
-      var px = this.scaleOffsetX * x,
-          py = this.scaleOffsetY * y;
-      var dx = this.translateOffsetX * (x -1) / px,
-          dy = this.translateOffsetY * (y -1) / py;
-      this.scaleOffsetX = px;
-      this.scaleOffsetY = py;
-      for(var i=0, l=this.canvases.length; i<l; i++) {
-        this.canvases[i].scale(x, y, true);
-      }
-      this.translate(dx, dy, false);
-    },
-    /*
-      Method: getZoom
-
-      Returns canvas zooming factors. *1* means initial zoom.
-
-      Returns:
-
-      An object with *x* and *y* properties.
-    */
-    getZoom: function() {
-      return new Complex(this.scaleOffsetX, this.scaleOffsetY);
-    },
-    /*
-      Method: setZoom
-
-      Sets the zoom to given factors. *1* means initial zoom.
-
-      Parameters:
-
-      x - (number) zooming factor
-      y - (number) zooming factor
-      disablePlot - (boolean) Default's *false*. Set this to *true* if you don't want to refresh the visualization.
-
-      Example:
-      (start code js)
-      canvas.setZoom(2, 2); //sets 2x zoom
-      (end code)
-    */
-    setZoom: function(x, y, disablePlot) {
-      var cur = this.getZoom(),
-          px = x / cur.x,
-          py = y / cur.y;
-      this.scale(px, py, disablePlot);
-    },
-    /*
-      Method: getPos
-      
-      Returns the canvas position as an *x, y* object.
-      
-      Parameters:
-      
-      force - (boolean) Default's *false*. Set this to *true* if you want to recalculate the position without using any cache information.
-      
-      Returns:
-      
-      An object with *x* and *y* properties.
-      
-      Example:
-      (start code js)
-      canvas.getPos(true); //returns { x: 900, y: 500 }
-      (end code)
-    */
-    getPos: function(force){
-      if(force || !this.pos) {
-        return this.pos = $.getPos(this.getElement());
-      }
-      return this.pos;
-    },
-    /*
-       Method: clear
-       
-       Clears the canvas.
-    */
-    clear: function(i){
-      this.canvases[i||0].clear();
-    },
-    
-    path: function(type, action){
-      var ctx = this.canvases[0].getCtx();
-      ctx.beginPath();
-      action(ctx);
-      ctx[type]();
-      ctx.closePath();
-    },
-    
-    createLabelContainer: function(type, idLabel, dim) {
-      var NS = 'http://www.w3.org/2000/svg';
-      if(type == 'HTML' || type == 'Native') {
-        return $E('div', {
-          'id': idLabel,
-          'style': {
-            'overflow': 'visible',
-            'position': 'absolute',
-            'top': 0,
-            'left': 0,
-            'width': dim.width + 'px',
-            'height': 0
-          }
-        });
-      } else if(type == 'SVG') {
-        var svgContainer = document.createElementNS(NS, 'svg:svg');
-        svgContainer.setAttribute("width", dim.width);
-        svgContainer.setAttribute('height', dim.height);
-        var style = svgContainer.style;
-        style.position = 'absolute';
-        style.left = style.top = '0px';
-        var labelContainer = document.createElementNS(NS, 'svg:g');
-        labelContainer.setAttribute('width', dim.width);
-        labelContainer.setAttribute('height', dim.height);
-        labelContainer.setAttribute('x', 0);
-        labelContainer.setAttribute('y', 0);
-        labelContainer.setAttribute('id', idLabel);
-        svgContainer.appendChild(labelContainer);
-        return svgContainer;
-      }
-    }
-  });
-  //base canvas wrapper
-  Canvas.Base = {};
-  Canvas.Base['2D'] = new Class({
-    translateOffsetX: 0,
-    translateOffsetY: 0,
-    scaleOffsetX: 1,
-    scaleOffsetY: 1,
-
-    initialize: function(viz) {
-      this.viz = viz;
-      this.opt = viz.config;
-      this.size = false;
-      this.createCanvas();
-      this.translateToCenter();
-    },
-    createCanvas: function() {
-      var opt = this.opt,
-          width = opt.width,
-          height = opt.height;
-      this.canvas = $E('canvas', {
-        'id': opt.injectInto + opt.idSuffix,
-        'width': width,
-        'height': height,
-        'style': {
-          'position': 'absolute',
-          'top': 0,
-          'left': 0,
-          'width': width + 'px',
-          'height': height + 'px'
-        }
-      });
-    },
-    getCtx: function() {
-      if(!this.ctx) 
-        return this.ctx = this.canvas.getContext('2d');
-      return this.ctx;
-    },
-    getSize: function() {
-      if(this.size) return this.size;
-      var canvas = this.canvas;
-      return this.size = {
-        width: canvas.width,
-        height: canvas.height
-      };
-    },
-    translateToCenter: function(ps) {
-      var size = this.getSize(),
-          width = ps? (size.width - ps.width - this.translateOffsetX*2) : size.width;
-          height = ps? (size.height - ps.height - this.translateOffsetY*2) : size.height;
-      var ctx = this.getCtx();
-      ps && ctx.scale(1/this.scaleOffsetX, 1/this.scaleOffsetY);
-      ctx.translate(width/2, height/2);
-    },
-    resize: function(width, height) {
-      var size = this.getSize(),
-          canvas = this.canvas,
-          styles = canvas.style;
-      this.size = false;
-      canvas.width = width;
-      canvas.height = height;
-      styles.width = width + "px";
-      styles.height = height + "px";
-      //small ExCanvas fix
-      if(!supportsCanvas) {
-        this.translateToCenter(size);
-      } else {
-        this.translateToCenter();
-      }
-      this.translateOffsetX =
-        this.translateOffsetY = 0;
-      this.scaleOffsetX = 
-        this.scaleOffsetY = 1;
-      this.clear();
-      this.viz.resize(width, height, this);
-    },
-    translate: function(x, y, disablePlot) {
-      var sx = this.scaleOffsetX,
-          sy = this.scaleOffsetY;
-      this.translateOffsetX += x*sx;
-      this.translateOffsetY += y*sy;
-      this.getCtx().translate(x, y);
-      !disablePlot && this.plot();
-    },
-    scale: function(x, y, disablePlot) {
-      this.scaleOffsetX *= x;
-      this.scaleOffsetY *= y;
-      this.getCtx().scale(x, y);
-      !disablePlot && this.plot();
-    },
-    clear: function(){
-      var size = this.getSize(),
-          ox = this.translateOffsetX,
-          oy = this.translateOffsetY,
-          sx = this.scaleOffsetX,
-          sy = this.scaleOffsetY;
-      this.getCtx().clearRect((-size.width / 2 - ox) * 1/sx, 
-                              (-size.height / 2 - oy) * 1/sy, 
-                              size.width * 1/sx, size.height * 1/sy);
-    },
-    plot: function() {
-      this.clear();
-      this.viz.plot(this);
-    }
-  });
-  //background canvases
-  //TODO(nico): document this!
-  Canvas.Background = {};
-  Canvas.Background.Circles = new Class({
-    initialize: function(viz, options) {
-      this.viz = viz;
-      this.config = $.merge({
-        idSuffix: '-bkcanvas',
-        levelDistance: 100,
-        numberOfCircles: 6,
-        CanvasStyles: {},
-        offset: 0
-      }, options);
-    },
-    resize: function(width, height, base) {
-      this.plot(base);
-    },
-    plot: function(base) {
-      var canvas = base.canvas,
-          ctx = base.getCtx(),
-          conf = this.config,
-          styles = conf.CanvasStyles;
-      //set canvas styles
-      for(var s in styles) ctx[s] = styles[s];
-      var n = conf.numberOfCircles,
-          rho = conf.levelDistance;
-      for(var i=1; i<=n; i++) {
-        ctx.beginPath();
-        ctx.arc(0, 0, rho * i, 0, 2 * Math.PI, false);
-        ctx.stroke();
-        ctx.closePath();
-      }
-      //TODO(nico): print labels too!
-    }
-  });
-})();
-
-
-/*
- * File: Polar.js
- * 
- * Defines the <Polar> class.
- *
- * Description:
- *
- * The <Polar> class, just like the <Complex> class, is used by the <Hypertree>, <ST> and <RGraph> as a 2D point representation.
- *
- * See also:
- *
- * <http://en.wikipedia.org/wiki/Polar_coordinates>
- *
-*/
-
-/*
-   Class: Polar
-
-   A multi purpose polar representation.
-
-   Description:
-   The <Polar> class, just like the <Complex> class, is used by the <Hypertree>, <ST> and <RGraph> as a 2D point representation.
-   See also:
-   <http://en.wikipedia.org/wiki/Polar_coordinates>
-   Parameters:
-
-      theta - An angle.
-      rho - The norm.
-*/
-
-var Polar = function(theta, rho) {
-  this.theta = theta || 0;
-  this.rho = rho || 0;
-};
-
-$jit.Polar = Polar;
-
-Polar.prototype = {
-    /*
-       Method: getc
-    
-       Returns a complex number.
-    
-       Parameters:
-
-       simple - _optional_ If *true*, this method will return only an object holding x and y properties and not a <Complex> instance. Default's *false*.
-
-      Returns:
-    
-          A complex number.
-    */
-    getc: function(simple) {
-        return this.toComplex(simple);
-    },
-
-    /*
-       Method: getp
-    
-       Returns a <Polar> representation.
-    
-       Returns:
-    
-          A variable in polar coordinates.
-    */
-    getp: function() {
-        return this;
-    },
-
-
-    /*
-       Method: set
-    
-       Sets a number.
-
-       Parameters:
-
-       v - A <Complex> or <Polar> instance.
-    
-    */
-    set: function(v) {
-        v = v.getp();
-        this.theta = v.theta; this.rho = v.rho;
-    },
-
-    /*
-       Method: setc
-    
-       Sets a <Complex> number.
-
-       Parameters:
-
-       x - A <Complex> number real part.
-       y - A <Complex> number imaginary part.
-    
-    */
-    setc: function(x, y) {
-        this.rho = Math.sqrt(x * x + y * y);
-        this.theta = Math.atan2(y, x);
-        if(this.theta < 0) this.theta += Math.PI * 2;
-    },
-
-    /*
-       Method: setp
-    
-       Sets a polar number.
-
-       Parameters:
-
-       theta - A <Polar> number angle property.
-       rho - A <Polar> number rho property.
-    
-    */
-    setp: function(theta, rho) {
-        this.theta = theta; 
-        this.rho = rho;
-    },
-
-    /*
-       Method: clone
-    
-       Returns a copy of the current object.
-    
-       Returns:
-    
-          A copy of the real object.
-    */
-    clone: function() {
-        return new Polar(this.theta, this.rho);
-    },
-
-    /*
-       Method: toComplex
-    
-        Translates from polar to cartesian coordinates and returns a new <Complex> instance.
-    
-        Parameters:
-
-        simple - _optional_ If *true* this method will only return an object with x and y properties (and not the whole <Complex> instance). Default's *false*.
-        Returns:
-    
-          A new <Complex> instance.
-    */
-    toComplex: function(simple) {
-        var x = Math.cos(this.theta) * this.rho;
-        var y = Math.sin(this.theta) * this.rho;
-        if(simple) return { 'x': x, 'y': y};
-        return new Complex(x, y);
-    },
-
-    /*
-       Method: add
-    
-        Adds two <Polar> instances.
-    
-       Parameters:
-
-       polar - A <Polar> number.
-
-       Returns:
-    
-          A new Polar instance.
-    */
-    add: function(polar) {
-        return new Polar(this.theta + polar.theta, this.rho + polar.rho);
-    },
-    
-    /*
-       Method: scale
-    
-        Scales a polar norm.
-    
-        Parameters:
-
-        number - A scale factor.
-        
-        Returns:
-    
-          A new Polar instance.
-    */
-    scale: function(number) {
-        return new Polar(this.theta, this.rho * number);
-    },
-    
-    /*
-       Method: equals
-    
-       Comparison method.
-
-       Returns *true* if the theta and rho properties are equal.
-
-       Parameters:
-
-       c - A <Polar> number.
-
-       Returns:
-
-       *true* if the theta and rho parameters for these objects are equal. *false* otherwise.
-    */
-    equals: function(c) {
-        return this.theta == c.theta && this.rho == c.rho;
-    },
-    
-    /*
-       Method: $add
-    
-        Adds two <Polar> instances affecting the current object.
-    
-       Paramters:
-
-       polar - A <Polar> instance.
-
-       Returns:
-    
-          The changed object.
-    */
-    $add: function(polar) {
-        this.theta = this.theta + polar.theta; this.rho += polar.rho;
-        return this;
-    },
-
-    /*
-       Method: $madd
-    
-        Adds two <Polar> instances affecting the current object. The resulting theta angle is modulo 2pi.
-    
-       Parameters:
-
-       polar - A <Polar> instance.
-
-       Returns:
-    
-          The changed object.
-    */
-    $madd: function(polar) {
-        this.theta = (this.theta + polar.theta) % (Math.PI * 2); this.rho += polar.rho;
-        return this;
-    },
-
-    
-    /*
-       Method: $scale
-    
-        Scales a polar instance affecting the object.
-    
-      Parameters:
-
-      number - A scaling factor.
-
-      Returns:
-    
-          The changed object.
-    */
-    $scale: function(number) {
-        this.rho *= number;
-        return this;
-    },
-    
-    /*
-      Method: isZero
-   
-      Returns *true* if the number is zero.
-   
-   */
-    isZero: function () {
-      var almostZero = 0.0001, abs = Math.abs;
-      return abs(this.theta) < almostZero && abs(this.rho) < almostZero;
-    },
-
-    /*
-       Method: interpolate
-    
-        Calculates a polar interpolation between two points at a given delta moment.
-
-        Parameters:
-      
-        elem - A <Polar> instance.
-        delta - A delta factor ranging [0, 1].
-    
-       Returns:
-    
-          A new <Polar> instance representing an interpolation between _this_ and _elem_
-    */
-    interpolate: function(elem, delta) {
-        var pi = Math.PI, pi2 = pi * 2;
-        var ch = function(t) {
-            var a =  (t < 0)? (t % pi2) + pi2 : t % pi2;
-            return a;
-        };
-        var tt = this.theta, et = elem.theta;
-        var sum, diff = Math.abs(tt - et);
-        if(diff == pi) {
-          if(tt > et) {
-            sum = ch((et + ((tt - pi2) - et) * delta)) ;
-          } else {
-            sum = ch((et - pi2 + (tt - (et)) * delta));
-          }
-        } else if(diff >= pi) {
-          if(tt > et) {
-            sum = ch((et + ((tt - pi2) - et) * delta)) ;
-          } else {
-            sum = ch((et - pi2 + (tt - (et - pi2)) * delta));
-          }
-        } else {  
-          sum = ch((et + (tt - et) * delta)) ;
-        }
-        var r = (this.rho - elem.rho) * delta + elem.rho;
-        return {
-          'theta': sum,
-          'rho': r
-        };
-    }
-};
-
-
-var $P = function(a, b) { return new Polar(a, b); };
-
-Polar.KER = $P(0, 0);
-
-
-
-/*
- * File: Complex.js
- * 
- * Defines the <Complex> class.
- *
- * Description:
- *
- * The <Complex> class, just like the <Polar> class, is used by the <Hypertree>, <ST> and <RGraph> as a 2D point representation.
- *
- * See also:
- *
- * <http://en.wikipedia.org/wiki/Complex_number>
- *
-*/
-
-/*
-   Class: Complex
-    
-   A multi-purpose Complex Class with common methods.
-   Description:
-   The <Complex> class, just like the <Polar> class, is used by the <Hypertree>, <ST> and <RGraph> as a 2D point representation.
-   See also:
-   <http://en.wikipedia.org/wiki/Complex_number>
-
-   Parameters:
-
-   x - _optional_ A Complex number real part.
-   y - _optional_ A Complex number imaginary part.
-*/
-
-var Complex = function(x, y) {
-  this.x = x || 0;
-  this.y = y || 0;
-};
-
-$jit.Complex = Complex;
-
-Complex.prototype = {
-    /*
-       Method: getc
-    
-       Returns a complex number.
-    
-       Returns:
-    
-          A complex number.
-    */
-    getc: function() {
-        return this;
-    },
-
-    /*
-       Method: getp
-    
-       Returns a <Polar> representation of this number.
-    
-       Parameters:
-
-       simple - _optional_ If *true*, this method will return only an object holding theta and rho properties and not a <Polar> instance. Default's *false*.
-
-       Returns:
-    
-          A variable in <Polar> coordinates.
-    */
-    getp: function(simple) {
-        return this.toPolar(simple);
-    },
-
-
-    /*
-       Method: set
-    
-       Sets a number.
-
-       Parameters:
-
-       c - A <Complex> or <Polar> instance.
-    
-    */
-    set: function(c) {
-      c = c.getc(true);
-      this.x = c.x; 
-      this.y = c.y;
-    },
-
-    /*
-       Method: setc
-    
-       Sets a complex number.
-
-       Parameters:
-
-       x - A <Complex> number Real part.
-       y - A <Complex> number Imaginary part.
-    
-    */
-    setc: function(x, y) {
-        this.x = x; 
-        this.y = y;
-    },
-
-    /*
-       Method: setp
-    
-       Sets a polar number.
-
-       Parameters:
-
-       theta - A <Polar> number theta property.
-       rho - A <Polar> number rho property.
-    
-    */
-    setp: function(theta, rho) {
-        this.x = Math.cos(theta) * rho;
-        this.y = Math.sin(theta) * rho;
-    },
-
-    /*
-       Method: clone
-    
-       Returns a copy of the current object.
-    
-       Returns:
-    
-          A copy of the real object.
-    */
-    clone: function() {
-        return new Complex(this.x, this.y);
-    },
-
-    /*
-       Method: toPolar
-    
-       Transforms cartesian to polar coordinates.
-    
-       Parameters:
-
-       simple - _optional_ If *true* this method will only return an object with theta and rho properties (and not the whole <Polar> instance). Default's *false*.
-       
-       Returns:
-    
-          A new <Polar> instance.
-    */
-    
-    toPolar: function(simple) {
-        var rho = this.norm();
-        var atan = Math.atan2(this.y, this.x);
-        if(atan < 0) atan += Math.PI * 2;
-        if(simple) return { 'theta': atan, 'rho': rho };
-        return new Polar(atan, rho);
-    },
-    /*
-       Method: norm
-    
-       Calculates a <Complex> number norm.
-    
-       Returns:
-    
-          A real number representing the complex norm.
-    */
-    norm: function () {
-        return Math.sqrt(this.squaredNorm());
-    },
-    
-    /*
-       Method: squaredNorm
-    
-       Calculates a <Complex> number squared norm.
-    
-       Returns:
-    
-          A real number representing the complex squared norm.
-    */
-    squaredNorm: function () {
-        return this.x*this.x + this.y*this.y;
-    },
-
-    /*
-       Method: add
-    
-       Returns the result of adding two complex numbers.
-       
-       Does not alter the original object.
-
-       Parameters:
-    
-          pos - A <Complex> instance.
-    
-       Returns:
-    
-         The result of adding two complex numbers.
-    */
-    add: function(pos) {
-        return new Complex(this.x + pos.x, this.y + pos.y);
-    },
-
-    /*
-       Method: prod
-    
-       Returns the result of multiplying two <Complex> numbers.
-       
-       Does not alter the original object.
-
-       Parameters:
-    
-          pos - A <Complex> instance.
-    
-       Returns:
-    
-         The result of multiplying two complex numbers.
-    */
-    prod: function(pos) {
-        return new Complex(this.x*pos.x - this.y*pos.y, this.y*pos.x + this.x*pos.y);
-    },
-
-    /*
-       Method: conjugate
-    
-       Returns the conjugate of this <Complex> number.
-
-       Does not alter the original object.
-
-       Returns:
-    
-         The conjugate of this <Complex> number.
-    */
-    conjugate: function() {
-        return new Complex(this.x, -this.y);
-    },
-
-
-    /*
-       Method: scale
-    
-       Returns the result of scaling a <Complex> instance.
-       
-       Does not alter the original object.
-
-       Parameters:
-    
-          factor - A scale factor.
-    
-       Returns:
-    
-         The result of scaling this complex to a factor.
-    */
-    scale: function(factor) {
-        return new Complex(this.x * factor, this.y * factor);
-    },
-
-    /*
-       Method: equals
-    
-       Comparison method.
-
-       Returns *true* if both real and imaginary parts are equal.
-
-       Parameters:
-
-       c - A <Complex> instance.
-
-       Returns:
-
-       A boolean instance indicating if both <Complex> numbers are equal.
-    */
-    equals: function(c) {
-        return this.x == c.x && this.y == c.y;
-    },
-
-    /*
-       Method: $add
-    
-       Returns the result of adding two <Complex> numbers.
-       
-       Alters the original object.
-
-       Parameters:
-    
-          pos - A <Complex> instance.
-    
-       Returns:
-    
-         The result of adding two complex numbers.
-    */
-    $add: function(pos) {
-        this.x += pos.x; this.y += pos.y;
-        return this;    
-    },
-    
-    /*
-       Method: $prod
-    
-       Returns the result of multiplying two <Complex> numbers.
-       
-       Alters the original object.
-
-       Parameters:
-    
-          pos - A <Complex> instance.
-    
-       Returns:
-    
-         The result of multiplying two complex numbers.
-    */
-    $prod:function(pos) {
-        var x = this.x, y = this.y;
-        this.x = x*pos.x - y*pos.y;
-        this.y = y*pos.x + x*pos.y;
-        return this;
-    },
-    
-    /*
-       Method: $conjugate
-    
-       Returns the conjugate for this <Complex>.
-       
-       Alters the original object.
-
-       Returns:
-    
-         The conjugate for this complex.
-    */
-    $conjugate: function() {
-        this.y = -this.y;
-        return this;
-    },
-    
-    /*
-       Method: $scale
-    
-       Returns the result of scaling a <Complex> instance.
-       
-       Alters the original object.
-
-       Parameters:
-    
-          factor - A scale factor.
-    
-       Returns:
-    
-         The result of scaling this complex to a factor.
-    */
-    $scale: function(factor) {
-        this.x *= factor; this.y *= factor;
-        return this;
-    },
-    
-    /*
-       Method: $div
-    
-       Returns the division of two <Complex> numbers.
-       
-       Alters the original object.
-
-       Parameters:
-    
-          pos - A <Complex> number.
-    
-       Returns:
-    
-         The result of scaling this complex to a factor.
-    */
-    $div: function(pos) {
-        var x = this.x, y = this.y;
-        var sq = pos.squaredNorm();
-        this.x = x * pos.x + y * pos.y; this.y = y * pos.x - x * pos.y;
-        return this.$scale(1 / sq);
-    },
-
-    /*
-      Method: isZero
-   
-      Returns *true* if the number is zero.
-   
-   */
-    isZero: function () {
-      var almostZero = 0.0001, abs = Math.abs;
-      return abs(this.x) < almostZero && abs(this.y) < almostZero;
-    }
-};
-
-var $C = function(a, b) { return new Complex(a, b); };
-
-Complex.KER = $C(0, 0);
-Complex.IM = $C(0, 1);
-
-
-
-/*
- * File: Graph.js
- *
-*/
-
-/*
- Class: Graph
-
- A Graph Class that provides useful manipulation functions. You can find more manipulation methods in the <Graph.Util> object.
-
- An instance of this class can be accessed by using the *graph* parameter of any tree or graph visualization.
- Example:
-
- (start code js)
-   //create new visualization
-   var viz = new $jit.Viz(options);
-   //load JSON data
-   viz.loadJSON(json);
-   //access model
-   viz.graph; //<Graph> instance
- (end code)
- Implements:
- The following <Graph.Util> methods are implemented in <Graph>
-  - <Graph.Util.getNode>
-  - <Graph.Util.eachNode>
-  - <Graph.Util.computeLevels>
-  - <Graph.Util.eachBFS>
-  - <Graph.Util.clean>
-  - <Graph.Util.getClosestNodeToPos>
-  - <Graph.Util.getClosestNodeToOrigin>
-*/  
-
-$jit.MultiGraph = new Class({
-
-  initialize: function(opt, Node, Edge, Label) {
-    var innerOptions = {
-    'klass': Complex,
-    'Node': {}
-    };
-    this.Node = Node;
-    this.Edge = Edge;
-    this.Label = Label;
-    this.opt = $.merge(innerOptions, opt || {});
-    this.nodes = {};
-    this.edges = {};
-       this.dup = []; // duplicate (bidirectional) edges
-    
-    //add nodeList methods
-    var that = this;
-    this.nodeList = {};
-    for(var p in Accessors) {
-      that.nodeList[p] = (function(p) {
-        return function() {
-          var args = Array.prototype.slice.call(arguments);
-          that.eachNode(function(n) {
-            n[p].apply(n, args);
-          });
-        };
-      })(p);
-    }
-
- },
-
-/*
-     Method: getNode
-    
-     Returns a <Graph.Node> by *id*.
-
-     Parameters:
-
-     id - (string) A <Graph.Node> id.
-
-     Example:
-
-     (start code js)
-       var node = graph.getNode('nodeId');
-     (end code)
-*/  
- getNode: function(id) {
-    if(this.hasNode(id)) return this.nodes[id];
-    return false;
- },
-
- /*
-     Method: get
-    
-     An alias for <Graph.Util.getNode>. Returns a node by *id*.
-    
-     Parameters:
-    
-     id - (string) A <Graph.Node> id.
-    
-     Example:
-    
-     (start code js)
-       var node = graph.get('nodeId');
-     (end code)
-*/  
-  get: function(id) {
-    return this.getNode(id);
-  },
-
- /*
-   Method: getByName
-  
-   Returns a <Graph.Node> by *name*.
-  
-   Parameters:
-  
-   name - (string) A <Graph.Node> name.
-  
-   Example:
-  
-   (start code js)
-     var node = graph.getByName('someName');
-   (end code)
-  */  
-  getByName: function(name) {
-    for(var id in this.nodes) {
-      var n = this.nodes[id];
-      if(n.name == name) return n;
-    }
-    return false;
-  },
-
-/*
-   Method: getAdjacence
-  
-   Returns a <Graph.Adjacence> object connecting nodes with ids *id* and *id2*.
-
-   Parameters:
-
-   id - (string) A <Graph.Node> id.
-   id2 - (string) A <Graph.Node> id.
-*/  
-  getAdjacence: function (id, id2) {
-    if(id in this.edges) {
-      return this.edges[id][id2];
-    }
-    return false;
- },
-
-    /*
-     Method: addNode
-    
-     Adds a node.
-     
-     Parameters:
-    
-      obj - An object with the properties described below
-
-      id - (string) A node id
-      name - (string) A node's name
-      data - (object) A node's data hash
-
-    See also:
-    <Graph.Node>
-
-  */  
-  addNode: function(obj) { 
-   if(!this.nodes[obj.id]) {  
-     var edges = this.edges[obj.id] = {};
-     this.nodes[obj.id] = new MultiGraph.Node($.extend({
-        'id': obj.id,
-        'name': obj.name,
-        'data': $.merge(obj.data || {}, {}),
-        'adjacencies': edges 
-      }, this.opt.Node), 
-      this.opt.klass, 
-      this.Node, 
-      this.Edge,
-      this.Label);
-    }
-    return this.nodes[obj.id];
-  },
-  
-    /*
-     Method: addAdjacence
-    
-     Connects nodes specified by *obj* and *obj2*. If not found, nodes are created.
-     
-     Parameters:
-    
-      obj - (object) A <Graph.Node> object.
-      obj2 - (object) Another <Graph.Node> object.
-      data - (object) A data object. Used to store some extra information in the <Graph.Adjacence> object created.
-
-    See also:
-
-    <Graph.Node>, <Graph.Adjacence>
-    */  
-  addAdjacence: function (obj, obj2, data) {
-       if (obj.id == obj2.id) return null; // skip if node loops back to itself
-
-       var portFrom = data["$nodeFromPort"];
-       var portTo = data["$nodeToPort"];
-
-    if(!this.hasNode(obj.id)) { this.addNode(obj); }
-    if(!this.hasNode(obj2.id)) { this.addNode(obj2); }
-    obj = this.nodes[obj.id]; obj2 = this.nodes[obj2.id];
-    if(!obj.adjacentTo(obj2, portTo)) {
-      var adjsObj = this.edges[obj.id] = this.edges[obj.id] || {};
-      var adjsObj2 = this.edges[obj2.id] = this.edges[obj2.id] || {};
-         
-         adjsObj[obj2.id] = adjsObj[obj2.id] || [];
-         adjsObj2[obj.id] = adjsObj2[obj.id] || [];
-
-         var adj = new MultiGraph.Adjacence(obj, obj2, portFrom, portTo, data, this.Edge, this.Label);
-
-         // if dup, then add to dup list
-         for(var edge in adjsObj2[obj.id]) { // iterate through the adj for the other node
-               var e = adjsObj2[obj.id][edge];
-               if(e.nodeFrom.id == adj.nodeTo.id && e.nodeTo.id == adj.nodeFrom.id) {
-                       if(e.portFrom == adj.portTo && e.portTo == adj.portFrom) {
-                               this.dup.push(adj); // if the other node contains the edge, then add it to the dup list for later filtering
-                       }
-               }
-         }
-
-         // add this adjacency into the current edges object
-         adjsObj[obj2.id].push(adj);
-         if (adj.nodeFrom.data["$type"] != "switch") {
-               // if this is not a switch (e.g. host), then add it to the switch because it will never be added by itself
-               adjsObj2[obj.id].push(adj);
-         }
-
-         return adj;
-      //adjsObj[obj2.id] = adjsObj2[obj.id] = new MultiGraph.Adjacence(obj, obj2, data["$nodeFromPort"], data["$nodeToPort"], data, this.Edge, this.Label);
-      //return adjsObj[obj2.id];
-    }
-    return this.edges[obj.id][obj2.id];
- },
-
-    /*
-     Method: removeNode
-    
-     Removes a <Graph.Node> matching the specified *id*.
-
-     Parameters:
-
-     id - (string) A node's id.
-
-    */  
-  removeNode: function(id) {
-    if(this.hasNode(id)) {
-      delete this.nodes[id];
-      var adjs = this.edges[id];
-      for(var to in adjs) {
-        delete this.edges[to][id];
-      }
-      delete this.edges[id];
-    }
-  },
-  
-/*
-     Method: removeAdjacence
-    
-     Removes a <Graph.Adjacence> matching *id1* and *id2*.
-
-     Parameters:
-
-     id1 - (string) A <Graph.Node> id.
-     id2 - (string) A <Graph.Node> id.
-*/  
-  removeAdjacence: function(id1, id2) {
-    delete this.edges[id1][id2];
-    delete this.edges[id2][id1];
-  },
-
-   /*
-     Method: hasNode
-    
-     Returns a boolean indicating if the node belongs to the <Graph> or not.
-     
-     Parameters:
-    
-        id - (string) Node id.
-   */  
-  hasNode: function(id) {
-    return id in this.nodes;
-  },
-  
-  /*
-    Method: empty
-
-    Empties the Graph
-
-  */
-  empty: function() { this.nodes = {}; this.edges = {};}
-
-});
-
-var MultiGraph = $jit.MultiGraph;
-
-/*
- Object: Accessors
- Defines a set of methods for data, canvas and label styles manipulation implemented by <Graph.Node> and <Graph.Adjacence> instances.
- */
-var Accessors;
-
-(function () {
-  var getDataInternal = function(prefix, prop, type, force, prefixConfig) {
-    var data;
-    type = type || 'current';
-    prefix = "$" + (prefix ? prefix + "-" : "");
-
-    if(type == 'current') {
-      data = this.data;
-    } else if(type == 'start') {
-      data = this.startData;
-    } else if(type == 'end') {
-      data = this.endData;
-    }
-
-    var dollar = prefix + prop;
-
-    if(force) {
-      return data[dollar];
-    }
-
-    if(!this.Config.overridable)
-      return prefixConfig[prop] || 0;
-
-    return (dollar in data) ?
-      data[dollar] : ((dollar in this.data) ? this.data[dollar] : (prefixConfig[prop] || 0));
-  }
-
-  var setDataInternal = function(prefix, prop, value, type) {
-    type = type || 'current';
-    prefix = '$' + (prefix ? prefix + '-' : '');
-
-    var data;
-
-    if(type == 'current') {
-      data = this.data;
-    } else if(type == 'start') {
-      data = this.startData;
-    } else if(type == 'end') {
-      data = this.endData;
-    }
-
-    data[prefix + prop] = value;
-  }
-
-  var removeDataInternal = function(prefix, properties) {
-    prefix = '$' + (prefix ? prefix + '-' : '');
-    var that = this;
-    $.each(properties, function(prop) {
-      var pref = prefix + prop;
-      delete that.data[pref];
-      delete that.endData[pref];
-      delete that.startData[pref];
-    });
-  }
-
-  Accessors = {
-    /*
-    Method: getData
-
-    Returns the specified data value property.
-    This is useful for querying special/reserved <Graph.Node> data properties
-    (i.e dollar prefixed properties).
-
-    Parameters:
-
-      prop  - (string) The name of the property. The dollar sign is not needed. For
-              example *getData(width)* will return *data.$width*.
-      type  - (string) The type of the data property queried. Default's "current". You can access *start* and *end* 
-              data properties also. These properties are used when making animations.
-      force - (boolean) Whether to obtain the true value of the property (equivalent to
-              *data.$prop*) or to check for *node.overridable = true* first.
-
-    Returns:
-
-      The value of the dollar prefixed property or the global Node/Edge property
-      value if *overridable=false*
-
-    Example:
-    (start code js)
-     node.getData('width'); //will return node.data.$width if Node.overridable=true;
-    (end code)
-    */
-    getData: function(prop, type, force) {
-      return getDataInternal.call(this, "", prop, type, force, this.Config);
-    },
-
-
-    /*
-    Method: setData
-
-    Sets the current data property with some specific value.
-    This method is only useful for reserved (dollar prefixed) properties.
-
-    Parameters:
-
-      prop  - (string) The name of the property. The dollar sign is not necessary. For
-              example *setData(width)* will set *data.$width*.
-      value - (mixed) The value to store.
-      type  - (string) The type of the data property to store. Default's "current" but
-              can also be "start" or "end".
-
-    Example:
-    
-    (start code js)
-     node.setData('width', 30);
-    (end code)
-    
-    If we were to make an animation of a node/edge width then we could do
-    
-    (start code js)
-      var node = viz.getNode('nodeId');
-      //set start and end values
-      node.setData('width', 10, 'start');
-      node.setData('width', 30, 'end');
-      //will animate nodes width property
-      viz.fx.animate({
-        modes: ['node-property:width'],
-        duration: 1000
-      });
-    (end code)
-    */
-    setData: function(prop, value, type) {
-      setDataInternal.call(this, "", prop, value, type);
-    },
-
-    /*
-    Method: setDataset
-
-    Convenience method to set multiple data values at once.
-    
-    Parameters:
-    
-    types - (array|string) A set of 'current', 'end' or 'start' values.
-    obj - (object) A hash containing the names and values of the properties to be altered.
-
-    Example:
-    (start code js)
-      node.setDataset(['current', 'end'], {
-        'width': [100, 5],
-        'color': ['#fff', '#ccc']
-      });
-      //...or also
-      node.setDataset('end', {
-        'width': 5,
-        'color': '#ccc'
-      });
-    (end code)
-    
-    See also: 
-    
-    <Accessors.setData>
-    
-    */
-    setDataset: function(types, obj) {
-      types = $.splat(types);
-      for(var attr in obj) {
-        for(var i=0, val = $.splat(obj[attr]), l=types.length; i<l; i++) {
-          this.setData(attr, val[i], types[i]);
-        }
-      }
-    },
-    
-    /*
-    Method: removeData
-
-    Remove data properties.
-
-    Parameters:
-
-    One or more property names as arguments. The dollar sign is not needed.
-
-    Example:
-    (start code js)
-    node.removeData('width'); //now the default width value is returned
-    (end code)
-    */
-    removeData: function() {
-      removeDataInternal.call(this, "", Array.prototype.slice.call(arguments));
-    },
-
-    /*
-    Method: getCanvasStyle
-
-    Returns the specified canvas style data value property. This is useful for
-    querying special/reserved <Graph.Node> canvas style data properties (i.e.
-    dollar prefixed properties that match with $canvas-<name of canvas style>).
-
-    Parameters:
-
-      prop  - (string) The name of the property. The dollar sign is not needed. For
-              example *getCanvasStyle(shadowBlur)* will return *data[$canvas-shadowBlur]*.
-      type  - (string) The type of the data property queried. Default's *current*. You can access *start* and *end* 
-              data properties also.
-              
-    Example:
-    (start code js)
-      node.getCanvasStyle('shadowBlur');
-    (end code)
-    
-    See also:
-    
-    <Accessors.getData>
-    */
-    getCanvasStyle: function(prop, type, force) {
-      return getDataInternal.call(
-          this, 'canvas', prop, type, force, this.Config.CanvasStyles);
-    },
-
-    /*
-    Method: setCanvasStyle
-
-    Sets the canvas style data property with some specific value.
-    This method is only useful for reserved (dollar prefixed) properties.
-    
-    Parameters:
-    
-    prop - (string) Name of the property. Can be any canvas property like 'shadowBlur', 'shadowColor', 'strokeStyle', etc.
-    value - (mixed) The value to set to the property.
-    type - (string) Default's *current*. Whether to set *start*, *current* or *end* type properties.
-    
-    Example:
-    
-    (start code js)
-     node.setCanvasStyle('shadowBlur', 30);
-    (end code)
-    
-    If we were to make an animation of a node/edge shadowBlur canvas style then we could do
-    
-    (start code js)
-      var node = viz.getNode('nodeId');
-      //set start and end values
-      node.setCanvasStyle('shadowBlur', 10, 'start');
-      node.setCanvasStyle('shadowBlur', 30, 'end');
-      //will animate nodes canvas style property for nodes
-      viz.fx.animate({
-        modes: ['node-style:shadowBlur'],
-        duration: 1000
-      });
-    (end code)
-    
-    See also:
-    
-    <Accessors.setData>.
-    */
-    setCanvasStyle: function(prop, value, type) {
-      setDataInternal.call(this, 'canvas', prop, value, type);
-    },
-
-    /*
-    Method: setCanvasStyles
-
-    Convenience method to set multiple styles at once.
-
-    Parameters:
-    
-    types - (array|string) A set of 'current', 'end' or 'start' values.
-    obj - (object) A hash containing the names and values of the properties to be altered.
-
-    See also:
-    
-    <Accessors.setDataset>.
-    */
-    setCanvasStyles: function(types, obj) {
-      types = $.splat(types);
-      for(var attr in obj) {
-        for(var i=0, val = $.splat(obj[attr]), l=types.length; i<l; i++) {
-          this.setCanvasStyle(attr, val[i], types[i]);
-        }
-      }
-    },
-
-    /*
-    Method: removeCanvasStyle
-
-    Remove canvas style properties from data.
-
-    Parameters:
-    
-    A variable number of canvas style strings.
-
-    See also:
-    
-    <Accessors.removeData>.
-    */
-    removeCanvasStyle: function() {
-      removeDataInternal.call(this, 'canvas', Array.prototype.slice.call(arguments));
-    },
-
-    /*
-    Method: getLabelData
-
-    Returns the specified label data value property. This is useful for
-    querying special/reserved <Graph.Node> label options (i.e.
-    dollar prefixed properties that match with $label-<name of label style>).
-
-    Parameters:
-
-      prop  - (string) The name of the property. The dollar sign prefix is not needed. For
-              example *getLabelData(size)* will return *data[$label-size]*.
-      type  - (string) The type of the data property queried. Default's *current*. You can access *start* and *end* 
-              data properties also.
-              
-    See also:
-    
-    <Accessors.getData>.
-    */
-    getLabelData: function(prop, type, force) {
-      return getDataInternal.call(
-          this, 'label', prop, type, force, this.Label);
-    },
-
-    /*
-    Method: setLabelData
-
-    Sets the current label data with some specific value.
-    This method is only useful for reserved (dollar prefixed) properties.
-
-    Parameters:
-    
-    prop - (string) Name of the property. Can be any canvas property like 'shadowBlur', 'shadowColor', 'strokeStyle', etc.
-    value - (mixed) The value to set to the property.
-    type - (string) Default's *current*. Whether to set *start*, *current* or *end* type properties.
-    
-    Example:
-    
-    (start code js)
-     node.setLabelData('size', 30);
-    (end code)
-    
-    If we were to make an animation of a node label size then we could do
-    
-    (start code js)
-      var node = viz.getNode('nodeId');
-      //set start and end values
-      node.setLabelData('size', 10, 'start');
-      node.setLabelData('size', 30, 'end');
-      //will animate nodes label size
-      viz.fx.animate({
-        modes: ['label-property:size'],
-        duration: 1000
-      });
-    (end code)
-    
-    See also:
-    
-    <Accessors.setData>.
-    */
-    setLabelData: function(prop, value, type) {
-      setDataInternal.call(this, 'label', prop, value, type);
-    },
-
-    /*
-    Method: setLabelDataset
-
-    Convenience function to set multiple label data at once.
-
-    Parameters:
-    
-    types - (array|string) A set of 'current', 'end' or 'start' values.
-    obj - (object) A hash containing the names and values of the properties to be altered.
-
-    See also:
-    
-    <Accessors.setDataset>.
-    */
-    setLabelDataset: function(types, obj) {
-      types = $.splat(types);
-      for(var attr in obj) {
-        for(var i=0, val = $.splat(obj[attr]), l=types.length; i<l; i++) {
-          this.setLabelData(attr, val[i], types[i]);
-        }
-      }
-    },
-
-    /*
-    Method: removeLabelData
-
-    Remove label properties from data.
-    
-    Parameters:
-    
-    A variable number of label property strings.
-
-    See also:
-    
-    <Accessors.removeData>.
-    */
-    removeLabelData: function() {
-      removeDataInternal.call(this, 'label', Array.prototype.slice.call(arguments));
-    }
-  };
-})();
-
-/*
-     Class: Graph.Node
-
-     A <Graph> node.
-     
-     Implements:
-     
-     <Accessors> methods.
-     
-     The following <Graph.Util> methods are implemented by <Graph.Node>
-     
-    - <Graph.Util.eachAdjacency>
-    - <Graph.Util.eachLevel>
-    - <Graph.Util.eachSubgraph>
-    - <Graph.Util.eachSubnode>
-    - <Graph.Util.anySubnode>
-    - <Graph.Util.getSubnodes>
-    - <Graph.Util.getParents>
-    - <Graph.Util.isDescendantOf>     
-*/
-MultiGraph.Node = new Class({
-    
-  initialize: function(opt, klass, Node, Edge, Label) {
-    var innerOptions = {
-      'id': '',
-      'name': '',
-      'data': {},
-      'startData': {},
-      'endData': {},
-      'adjacencies': {},
-
-      'selected': false,
-      'drawn': false,
-      'exist': false,
-
-      'angleSpan': {
-        'begin': 0,
-        'end' : 0
-      },
-
-      'pos': new klass,
-      'startPos': new klass,
-      'endPos': new klass
-    };
-    
-    $.extend(this, $.extend(innerOptions, opt));
-    this.Config = this.Node = Node;
-    this.Edge = Edge;
-    this.Label = Label;
-  },
-
-    /*
-       Method: adjacentTo
-    
-       Indicates if the node is adjacent to the node specified by id
-
-       Parameters:
-    
-          id - (string) A node id.
-    
-       Example:
-       (start code js)
-        node.adjacentTo('nodeId') == true;
-       (end code)
-    */
-    adjacentTo: function(node, port) {
-               return false;
-               /*
-               if (this.adjacencies[node.id] != undefined) {
-                       for(var i = 0, il = this.adjacencies[node.id].length; i < il; i++) {
-                               if (this.adjacencies[node.id][i]["portFrom"] == port)
-                                       return true;
-                       }
-               }
-               return false;
-               */
-        //return node.id in this.adjacencies;
-    },
-
-    /*
-     Method: adjacentWithDirectionTo
-
-     Indicates if the node has a directed edge to the node specified by id
-
-     Parameters:
-
-     id - (string) A node id.
-
-     Example:
-     (start code js)
-     node.adjacentWithDirectionTo('nodeId') == true;
-     (end code)
-     */
-    adjacentWithDirectionTo: function(node) {
-        var areNeighbors = node.id in this.adjacencies;
-        if (!areNeighbors) {
-            return false;
-        }
-
-        var direction = this.adjacencies[node.id].data.$direction;
-        return direction[0] === this.id ;
-    },
-
-    /*
-       Method: getAdjacency
-    
-       Returns a <Graph.Adjacence> object connecting the current <Graph.Node> and the node having *id* as id.
-
-       Parameters:
-    
-          id - (string) A node id.
-    */  
-    getAdjacency: function(id) {
-        return this.adjacencies[id];
-    },
-
-    /*
-      Method: getPos
-   
-      Returns the position of the node.
-  
-      Parameters:
-   
-         type - (string) Default's *current*. Possible values are "start", "end" or "current".
-   
-      Returns:
-   
-        A <Complex> or <Polar> instance.
-  
-      Example:
-      (start code js)
-       var pos = node.getPos('end');
-      (end code)
-   */
-   getPos: function(type) {
-       type = type || "current";
-       if(type == "current") {
-         return this.pos;
-       } else if(type == "end") {
-         return this.endPos;
-       } else if(type == "start") {
-         return this.startPos;
-       }
-   },
-   /*
-     Method: setPos
-  
-     Sets the node's position.
-  
-     Parameters:
-  
-        value - (object) A <Complex> or <Polar> instance.
-        type - (string) Default's *current*. Possible values are "start", "end" or "current".
-  
-     Example:
-     (start code js)
-      node.setPos(new $jit.Complex(0, 0), 'end');
-     (end code)
-  */
-  setPos: function(value, type) {
-      type = type || "current";
-      var pos;
-      if(type == "current") {
-        pos = this.pos;
-      } else if(type == "end") {
-        pos = this.endPos;
-      } else if(type == "start") {
-        pos = this.startPos;
-      }
-      pos.set(value);
-  }
-});
-
-MultiGraph.Node.implement(Accessors);
-
-/*
-     Class: Graph.Adjacence
-
-     A <Graph> adjacence (or edge) connecting two <Graph.Nodes>.
-     
-     Implements:
-     
-     <Accessors> methods.
-
-     See also:
-
-     <Graph>, <Graph.Node>
-
-     Properties:
-     
-      nodeFrom - A <Graph.Node> connected by this edge.
-      nodeTo - Another  <Graph.Node> connected by this edge.
-      data - Node data property containing a hash (i.e {}) with custom options.
-*/
-MultiGraph.Adjacence = new Class({
-  
-  initialize: function(nodeFrom, nodeTo, portFrom, portTo, data, Edge, Label) {
-    this.nodeFrom = nodeFrom;
-    this.nodeTo = nodeTo;
-    this.data = data || {};
-    this.startData = {};
-    this.endData = {};
-    this.Config = this.Edge = Edge;
-    this.Label = Label;
-
-       this.portFrom = portFrom;
-       this.portTo = portTo;
-  }
-});
-
-MultiGraph.Adjacence.implement(Accessors);
-
-/*
-   Object: Graph.Util
-
-   <Graph> traversal and processing utility object.
-   
-   Note:
-   
-   For your convenience some of these methods have also been appended to <Graph> and <Graph.Node> classes.
-*/
-MultiGraph.Util = {
-    /*
-       filter
-    
-       For internal use only. Provides a filtering function based on flags.
-    */
-    filter: function(param) {
-        if(!param || !($.type(param) == 'string')) return function() { return true; };
-        var props = param.split(" ");
-        return function(elem) {
-            for(var i=0; i<props.length; i++) { 
-              if(elem[props[i]]) { 
-                return false; 
-              }
-            }
-            return true;
-        };
-    },
-    /*
-       Method: getNode
-    
-       Returns a <Graph.Node> by *id*.
-       
-       Also implemented by:
-       
-       <Graph>
-
-       Parameters:
-
-       graph - (object) A <Graph> instance.
-       id - (string) A <Graph.Node> id.
-
-       Example:
-
-       (start code js)
-         $jit.Graph.Util.getNode(graph, 'nodeid');
-         //or...
-         graph.getNode('nodeid');
-       (end code)
-    */
-    getNode: function(graph, id) {
-        return graph.nodes[id];
-    },
-    
-    /*
-       Method: eachNode
-    
-       Iterates over <Graph> nodes performing an *action*.
-       
-       Also implemented by:
-       
-       <Graph>.
-
-       Parameters:
-
-       graph - (object) A <Graph> instance.
-       action - (function) A callback function having a <Graph.Node> as first formal parameter.
-
-       Example:
-       (start code js)
-         $jit.Graph.Util.eachNode(graph, function(node) {
-          alert(node.name);
-         });
-         //or...
-         graph.eachNode(function(node) {
-           alert(node.name);
-         });
-       (end code)
-    */
-    eachNode: function(graph, action, flags) {
-        var filter = this.filter(flags);
-        for(var i in graph.nodes) {
-          if(filter(graph.nodes[i])) action(graph.nodes[i]);
-        } 
-    },
-    
-    /*
-      Method: each
-   
-      Iterates over <Graph> nodes performing an *action*. It's an alias for <Graph.Util.eachNode>.
-      
-      Also implemented by:
-      
-      <Graph>.
-  
-      Parameters:
-  
-      graph - (object) A <Graph> instance.
-      action - (function) A callback function having a <Graph.Node> as first formal parameter.
-  
-      Example:
-      (start code js)
-        $jit.Graph.Util.each(graph, function(node) {
-         alert(node.name);
-        });
-        //or...
-        graph.each(function(node) {
-          alert(node.name);
-        });
-      (end code)
-   */
-   each: function(graph, action, flags) {
-      this.eachNode(graph, action, flags); 
-   },
-
-   eachAdjacencyBatch: function(node, action, flags) {
-               var adj = node.adjacencies;
-
-               for(var id in adj) {
-                       var a = adj[id];
-                       action(a, id);
-               }
-   },
-
- /*
-       Method: eachAdjacency
-    
-       Iterates over <Graph.Node> adjacencies applying the *action* function.
-       
-       Also implemented by:
-       
-       <Graph.Node>.
-
-       Parameters:
-
-       node - (object) A <Graph.Node>.
-       action - (function) A callback function having <Graph.Adjacence> as first formal parameter.
-
-       Example:
-       (start code js)
-         $jit.Graph.Util.eachAdjacency(node, function(adj) {
-          alert(adj.nodeTo.name);
-         });
-         //or...
-         node.eachAdjacency(function(adj) {
-           alert(adj.nodeTo.name);
-         });
-       (end code)
-    */
-    eachAdjacency: function(node, action, flags) {
-               var adj = node.adjacencies, filter = this.filter(flags);
-
-               for(var id in adj) {
-                       var a = adj[id];
-                       for(var idj in a) {
-                               action(a[idj], id);
-                       }
-               }
-
-        /*var adj = node.adjacencies, filter = this.filter(flags);
-        for(var id in adj) {
-          var a = adj[id];
-          if(filter(a)) {
-            if(a.nodeFrom != node) {
-              var tmp = a.nodeFrom;
-              a.nodeFrom = a.nodeTo;
-              a.nodeTo = tmp;
-            }
-            action(a, id);
-          }
-        }*/
-    },
-
-     /*
-       Method: computeLevels
-    
-       Performs a BFS traversal setting the correct depth for each node.
-        
-       Also implemented by:
-       
-       <Graph>.
-       
-       Note:
-       
-       The depth of each node can then be accessed by 
-       >node._depth
-
-       Parameters:
-
-       graph - (object) A <Graph>.
-       id - (string) A starting node id for the BFS traversal.
-       startDepth - (optional|number) A minimum depth value. Default's 0.
-
-    */
-    computeLevels: function(graph, id, startDepth, flags) {
-        startDepth = startDepth || 0;
-        var filter = this.filter(flags);
-        this.eachNode(graph, function(elem) {
-            elem._flag = false;
-            elem._depth = -1;
-        }, flags);
-        var root = graph.getNode(id);
-        root._depth = startDepth;
-        var queue = [root];
-        while(queue.length != 0) {
-            var node = queue.pop();
-            node._flag = true;
-            this.eachAdjacency(node, function(adj) {
-                var n = adj.nodeTo;
-                if(n._flag == false && filter(n) && !adj._hiding) {
-                    if(n._depth < 0) n._depth = node._depth + 1 + startDepth;
-                    queue.unshift(n);
-                }
-            }, flags);
-        }
-    },
-
-    /*
-       Method: eachBFS
-    
-       Performs a BFS traversal applying *action* to each <Graph.Node>.
-       
-       Also implemented by:
-       
-       <Graph>.
-
-       Parameters:
-
-       graph - (object) A <Graph>.
-       id - (string) A starting node id for the BFS traversal.
-       action - (function) A callback function having a <Graph.Node> as first formal parameter.
-
-       Example:
-       (start code js)
-         $jit.Graph.Util.eachBFS(graph, 'mynodeid', function(node) {
-          alert(node.name);
-         });
-         //or...
-         graph.eachBFS('mynodeid', function(node) {
-           alert(node.name);
-         });
-       (end code)
-    */
-    eachBFS: function(graph, id, action, flags) {
-        var filter = this.filter(flags);
-        this.clean(graph);
-        var queue = [graph.getNode(id)];
-        while(queue.length != 0) {
-            var node = queue.pop();
-            if (!node) return;
-            node._flag = true;
-            action(node, node._depth);
-            this.eachAdjacency(node, function(adj) {
-                var n = adj.nodeTo;
-                if(n._flag == false && filter(n) && !adj._hiding) {
-                    n._flag = true;
-                    queue.unshift(n);
-                }
-            }, flags);
-        }
-    },
-    
-    /*
-       Method: eachLevel
-    
-       Iterates over a node's subgraph applying *action* to the nodes of relative depth between *levelBegin* and *levelEnd*.
-       In case you need to break the iteration, *action* should return false.
-       
-       Also implemented by:
-       
-       <Graph.Node>.
-
-       Parameters:
-       
-       node - (object) A <Graph.Node>.
-       levelBegin - (number) A relative level value.
-       levelEnd - (number) A relative level value.
-       action - (function) A callback function having a <Graph.Node> as first formal parameter.
-
-    */
-    eachLevel: function(node, levelBegin, levelEnd, action, flags) {
-        var d = node._depth, filter = this.filter(flags), that = this, shouldContinue = true;
-        levelEnd = levelEnd === false? Number.MAX_VALUE -d : levelEnd;
-        (function loopLevel(node, levelBegin, levelEnd) {
-            if(!shouldContinue) return;
-            var d = node._depth, ret;
-            if(d >= levelBegin && d <= levelEnd && filter(node)) ret = action(node, d);
-            if(typeof ret !== "undefined") shouldContinue = ret;
-            if(shouldContinue && d < levelEnd) {
-                that.eachAdjacency(node, function(adj) {
-                    var n = adj.nodeTo;
-                    if(n._depth > d) loopLevel(n, levelBegin, levelEnd);
-                });
-            }
-        })(node, levelBegin + d, levelEnd + d);
-    },
-
-    /*
-       Method: eachSubgraph
-    
-       Iterates over a node's children recursively.
-       
-       Also implemented by:
-       
-       <Graph.Node>.
-
-       Parameters:
-       node - (object) A <Graph.Node>.
-       action - (function) A callback function having a <Graph.Node> as first formal parameter.
-
-       Example:
-       (start code js)
-         $jit.Graph.Util.eachSubgraph(node, function(node) {
-           alert(node.name);
-         });
-         //or...
-         node.eachSubgraph(function(node) {
-           alert(node.name);
-         });
-       (end code)
-    */
-    eachSubgraph: function(node, action, flags) {
-      this.eachLevel(node, 0, false, action, flags);
-    },
-
-    /*
-       Method: eachSubnode
-    
-       Iterates over a node's children (without deeper recursion).
-       
-       Also implemented by:
-       
-       <Graph.Node>.
-       
-       Parameters:
-       node - (object) A <Graph.Node>.
-       action - (function) A callback function having a <Graph.Node> as first formal parameter.
-
-       Example:
-       (start code js)
-         $jit.Graph.Util.eachSubnode(node, function(node) {
-          alert(node.name);
-         });
-         //or...
-         node.eachSubnode(function(node) {
-           alert(node.name);
-         });
-       (end code)
-    */
-    eachSubnode: function(node, action, flags) {
-        this.eachLevel(node, 1, 1, action, flags);
-    },
-
-    /*
-       Method: anySubnode
-    
-       Returns *true* if any subnode matches the given condition.
-       
-       Also implemented by:
-       
-       <Graph.Node>.
-
-       Parameters:
-       node - (object) A <Graph.Node>.
-       cond - (function) A callback function returning a Boolean instance. This function has as first formal parameter a <Graph.Node>.
-
-       Example:
-       (start code js)
-         $jit.Graph.Util.anySubnode(node, function(node) { return node.name == "mynodename"; });
-         //or...
-         node.anySubnode(function(node) { return node.name == 'mynodename'; });
-       (end code)
-    */
-    anySubnode: function(node, cond, flags) {
-      var flag = false;
-      cond = cond || $.lambda(true);
-      var c = $.type(cond) == 'string'? function(n) { return n[cond]; } : cond;
-      this.eachSubnode(node, function(elem) {
-        if(c(elem)) flag = true;
-      }, flags);
-      return flag;
-    },
-  
-    /*
-       Method: getSubnodes
-    
-       Collects all subnodes for a specified node. 
-       The *level* parameter filters nodes having relative depth of *level* from the root node. 
-       
-       Also implemented by:
-       
-       <Graph.Node>.
-
-       Parameters:
-       node - (object) A <Graph.Node>.
-       level - (optional|number) Default's *0*. A starting relative depth for collecting nodes.
-
-       Returns:
-       An array of nodes.
-
-    */
-    getSubnodes: function(node, level, flags) {
-        var ans = [], that = this;
-        level = level || 0;
-        var levelStart, levelEnd;
-        if($.type(level) == 'array') {
-            levelStart = level[0];
-            levelEnd = level[1];
-        } else {
-            levelStart = level;
-            levelEnd = Number.MAX_VALUE - node._depth;
-        }
-        this.eachLevel(node, levelStart, levelEnd, function(n) {
-            ans.push(n);
-        }, flags);
-        return ans;
-    },
-  
-  
-    /*
-       Method: getParents
-    
-       Returns an Array of <Graph.Nodes> which are parents of the given node.
-       
-       Also implemented by:
-       
-       <Graph.Node>.
-
-       Parameters:
-       node - (object) A <Graph.Node>.
-
-       Returns:
-       An Array of <Graph.Nodes>.
-
-       Example:
-       (start code js)
-         var pars = $jit.Graph.Util.getParents(node);
-         //or...
-         var pars = node.getParents();
-         
-         if(pars.length > 0) {
-           //do stuff with parents
-         }
-       (end code)
-    */
-    getParents: function(node) {
-        var ans = [];
-        this.eachAdjacency(node, function(adj) {
-            var n = adj.nodeTo;
-            if(n._depth < node._depth) ans.push(n);
-        });
-        return ans;
-    },
-    
-    /*
-    Method: isDescendantOf
-    Returns a boolean indicating if some node is descendant of the node with the given id. 
-
-    Also implemented by:
-    
-    <Graph.Node>.
-    
-    
-    Parameters:
-    node - (object) A <Graph.Node>.
-    id - (string) A <Graph.Node> id.
-
-    Example:
-    (start code js)
-      $jit.Graph.Util.isDescendantOf(node, "nodeid"); //true|false
-      //or...
-      node.isDescendantOf('nodeid');//true|false
-    (end code)
- */
- isDescendantOf: function(node, id) {
-    if(node.id == id) return true;
-    var pars = this.getParents(node), ans = false;
-    for ( var i = 0; !ans && i < pars.length; i++) {
-    ans = ans || this.isDescendantOf(pars[i], id);
-  }
-    return ans;
- },
-
- /*
-     Method: clean
-  
-     Cleans flags from nodes.
-
-     Also implemented by:
-     
-     <Graph>.
-     
-     Parameters:
-     graph - A <Graph> instance.
-  */
-  clean: function(graph) { this.eachNode(graph, function(elem) { elem._flag = false; }); },
-  
-  /* 
-    Method: getClosestNodeToOrigin 
-  
-    Returns the closest node to the center of canvas.
-  
-    Also implemented by:
-    
-    <Graph>.
-    
-    Parameters:
-   
-     graph - (object) A <Graph> instance.
-     prop - (optional|string) Default's 'current'. A <Graph.Node> position property. Possible properties are 'start', 'current' or 'end'.
-  
-  */
-  getClosestNodeToOrigin: function(graph, prop, flags) {
-   return this.getClosestNodeToPos(graph, Polar.KER, prop, flags);
-  },
-  
-  /* 
-    Method: getClosestNodeToPos
-  
-    Returns the closest node to the given position.
-  
-    Also implemented by:
-    
-    <Graph>.
-    
-    Parameters:
-   
-     graph - (object) A <Graph> instance.
-     pos - (object) A <Complex> or <Polar> instance.
-     prop - (optional|string) Default's *current*. A <Graph.Node> position property. Possible properties are 'start', 'current' or 'end'.
-  
-  */
-  getClosestNodeToPos: function(graph, pos, prop, flags) {
-   var node = null;
-   prop = prop || 'current';
-   pos = pos && pos.getc(true) || Complex.KER;
-   var distance = function(a, b) {
-     var d1 = a.x - b.x, d2 = a.y - b.y;
-     return d1 * d1 + d2 * d2;
-   };
-   this.eachNode(graph, function(elem) {
-     node = (node == null || distance(elem.getPos(prop).getc(true), pos) < distance(
-         node.getPos(prop).getc(true), pos)) ? elem : node;
-   }, flags);
-   return node;
-  } 
-};
-
-//Append graph methods to <Graph>
-$.each(['get', 'getNode', 'each', 'eachNode', 'computeLevels', 'eachBFS', 'clean', 'getClosestNodeToPos', 'getClosestNodeToOrigin'], function(m) {
-  MultiGraph.prototype[m] = function() {
-    return MultiGraph.Util[m].apply(MultiGraph.Util, [this].concat(Array.prototype.slice.call(arguments)));
-  };
-});
-
-//Append node methods to <Graph.Node>
-$.each(['eachAdjacencyBatch', 'eachAdjacency', 'eachLevel', 'eachSubgraph', 'eachSubnode', 'anySubnode', 'getSubnodes', 'getParents', 'isDescendantOf'], function(m) {
-  MultiGraph.Node.prototype[m] = function() {
-    return MultiGraph.Util[m].apply(MultiGraph.Util, [this].concat(Array.prototype.slice.call(arguments)));
-  };
-});
-
-
-/*
- * File: Graph.Op.js
- *
-*/
-
-/*
-   Object: Graph.Op
-
-   Perform <Graph> operations like adding/removing <Graph.Nodes> or <Graph.Adjacences>, 
-   morphing a <Graph> into another <Graph>, contracting or expanding subtrees, etc.
-
-*/
-MultiGraph.Op = {
-
-    options: {
-      type: 'nothing',
-      duration: 2000,
-      hideLabels: true,
-      fps:30
-    },
-    
-    initialize: function(viz) {
-      this.viz = viz;
-    },
-
-    /*
-       Method: removeNode
-    
-       Removes one or more <Graph.Nodes> from the visualization. 
-       It can also perform several animations like fading sequentially, fading concurrently, iterating or replotting.
-
-       Parameters:
-    
-        node - (string|array) The node's id. Can also be an array having many ids.
-        opt - (object) Animation options. It's an object with optional properties described below
-        type - (string) Default's *nothing*. Type of the animation. Can be "nothing", "replot", "fade:seq",  "fade:con" or "iter".
-        duration - Described in <Options.Fx>.
-        fps - Described in <Options.Fx>.
-        transition - Described in <Options.Fx>.
-        hideLabels - (boolean) Default's *true*. Hide labels during the animation.
-   
-      Example:
-      (start code js)
-        var viz = new $jit.Viz(options);
-        viz.op.removeNode('nodeId', {
-          type: 'fade:seq',
-          duration: 1000,
-          hideLabels: false,
-          transition: $jit.Trans.Quart.easeOut
-        });
-        //or also
-        viz.op.removeNode(['someId', 'otherId'], {
-          type: 'fade:con',
-          duration: 1500
-        });
-      (end code)
-    */
-  
-    removeNode: function(node, opt) {
-        var viz = this.viz;
-        var options = $.merge(this.options, viz.controller, opt);
-        var n = $.splat(node);
-        var i, that, nodeObj;
-        switch(options.type) {
-            case 'nothing':
-                for(i=0; i<n.length; i++) {
-                    options.onBeforeRemoveNode(viz.graph.getNode(n[i]));
-                    viz.graph.removeNode(n[i]);
-                }
-                break;
-            
-            case 'replot':
-                this.removeNode(n, { type: 'nothing' });
-                viz.labels.clearLabels();
-                viz.refresh(true);
-                break;
-            
-            case 'fade:seq': case 'fade':
-                that = this;
-                //set alpha to 0 for nodes to remove.
-                for(i=0; i<n.length; i++) {
-                    nodeObj = viz.graph.getNode(n[i]);
-                    nodeObj.setData('alpha', 0, 'end');
-                }
-                viz.fx.animate($.merge(options, {
-                    modes: ['node-property:alpha'],
-                    onComplete: function() {
-                        that.removeNode(n, { type: 'nothing' });
-                        viz.labels.clearLabels();
-                        viz.reposition();
-                        viz.fx.animate($.merge(options, {
-                            modes: ['linear']
-                        }));
-                    }
-                }));
-                break;
-            
-            case 'fade:con':
-                that = this;
-                //set alpha to 0 for nodes to remove. Tag them for being ignored on computing positions.
-                for(i=0; i<n.length; i++) {
-                    nodeObj = viz.graph.getNode(n[i]);
-                    nodeObj.setData('alpha', 0, 'end');
-                    nodeObj.ignore = true;
-                }
-                viz.reposition();
-                viz.fx.animate($.merge(options, {
-                    modes: ['node-property:alpha', 'linear'],
-                    onComplete: function() {
-                        that.removeNode(n, { type: 'nothing' });
-                        options.onComplete && options.onComplete();
-                    }
-                }));
-                break;
-            
-            case 'iter':
-                that = this;
-                viz.fx.sequence({
-                    condition: function() { return n.length != 0; },
-                    step: function() { that.removeNode(n.shift(), { type: 'nothing' });  viz.labels.clearLabels(); },
-                    onComplete: function() { options.onComplete && options.onComplete(); },
-                    duration: Math.ceil(options.duration / n.length)
-                });
-                break;
-                
-            default: this.doError();
-        }
-    },
-    
-    /*
-       Method: removeEdge
-    
-       Removes one or more <Graph.Adjacences> from the visualization. 
-       It can also perform several animations like fading sequentially, fading concurrently, iterating or replotting.
-
-       Parameters:
-    
-       vertex - (array) An array having two strings which are the ids of the nodes connected by this edge (i.e ['id1', 'id2']). Can also be a two dimensional array holding many edges (i.e [['id1', 'id2'], ['id3', 'id4'], ...]).
-       opt - (object) Animation options. It's an object with optional properties described below
-       type - (string) Default's *nothing*. Type of the animation. Can be "nothing", "replot", "fade:seq",  "fade:con" or "iter".
-       duration - Described in <Options.Fx>.
-       fps - Described in <Options.Fx>.
-       transition - Described in <Options.Fx>.
-       hideLabels - (boolean) Default's *true*. Hide labels during the animation.
-   
-      Example:
-      (start code js)
-        var viz = new $jit.Viz(options);
-        viz.op.removeEdge(['nodeId', 'otherId'], {
-          type: 'fade:seq',
-          duration: 1000,
-          hideLabels: false,
-          transition: $jit.Trans.Quart.easeOut
-        });
-        //or also
-        viz.op.removeEdge([['someId', 'otherId'], ['id3', 'id4']], {
-          type: 'fade:con',
-          duration: 1500
-        });
-      (end code)
-    
-    */
-    removeEdge: function(vertex, opt) {
-        var viz = this.viz;
-        var options = $.merge(this.options, viz.controller, opt);
-        var v = ($.type(vertex[0]) == 'string')? [vertex] : vertex;
-        var i, that, adj;
-        switch(options.type) {
-            case 'nothing':
-                for(i=0; i<v.length; i++)   viz.graph.removeAdjacence(v[i][0], v[i][1]);
-                break;
-            
-            case 'replot':
-                this.removeEdge(v, { type: 'nothing' });
-                viz.refresh(true);
-                break;
-            
-            case 'fade:seq': case 'fade':
-                that = this;
-                //set alpha to 0 for edges to remove.
-                for(i=0; i<v.length; i++) {
-                    adj = viz.graph.getAdjacence(v[i][0], v[i][1]);
-                    if(adj) {
-                        adj.setData('alpha', 0,'end');
-                    }
-                }
-                viz.fx.animate($.merge(options, {
-                    modes: ['edge-property:alpha'],
-                    onComplete: function() {
-                        that.removeEdge(v, { type: 'nothing' });
-                        viz.reposition();
-                        viz.fx.animate($.merge(options, {
-                            modes: ['linear']
-                        }));
-                    }
-                }));
-                break;
-            
-            case 'fade:con':
-                that = this;
-                //set alpha to 0 for nodes to remove. Tag them for being ignored when computing positions.
-                for(i=0; i<v.length; i++) {
-                    adj = viz.graph.getAdjacence(v[i][0], v[i][1]);
-                    if(adj) {
-                        adj.setData('alpha',0 ,'end');
-                        adj.ignore = true;
-                    }
-                }
-                viz.reposition();
-                viz.fx.animate($.merge(options, {
-                    modes: ['edge-property:alpha', 'linear'],
-                    onComplete: function() {
-                        that.removeEdge(v, { type: 'nothing' });
-                        options.onComplete && options.onComplete();
-                    }
-                }));
-                break;
-            
-            case 'iter':
-                that = this;
-                viz.fx.sequence({
-                    condition: function() { return v.length != 0; },
-                    step: function() { that.removeEdge(v.shift(), { type: 'nothing' }); viz.labels.clearLabels(); },
-                    onComplete: function() { options.onComplete(); },
-                    duration: Math.ceil(options.duration / v.length)
-                });
-                break;
-                
-            default: this.doError();
-        }
-    },
-    
-    /*
-       Method: sum
-    
-       Adds a new graph to the visualization. 
-       The JSON graph (or tree) must at least have a common node with the current graph plotted by the visualization. 
-       The resulting graph can be defined as follows <http://mathworld.wolfram.com/GraphSum.html>
-
-       Parameters:
-    
-       json - (object) A json tree or graph structure. See also <Loader.loadJSON>.
-       opt - (object) Animation options. It's an object with optional properties described below
-       type - (string) Default's *nothing*. Type of the animation. Can be "nothing", "replot", "fade:seq",  "fade:con".
-       duration - Described in <Options.Fx>.
-       fps - Described in <Options.Fx>.
-       transition - Described in <Options.Fx>.
-       hideLabels - (boolean) Default's *true*. Hide labels during the animation.
-   
-      Example:
-      (start code js)
-        //...json contains a tree or graph structure...
-
-        var viz = new $jit.Viz(options);
-        viz.op.sum(json, {
-          type: 'fade:seq',
-          duration: 1000,
-          hideLabels: false,
-          transition: $jit.Trans.Quart.easeOut
-        });
-        //or also
-        viz.op.sum(json, {
-          type: 'fade:con',
-          duration: 1500
-        });
-      (end code)
-    
-    */
-    sum: function(json, opt) {
-        var viz = this.viz;
-        var options = $.merge(this.options, viz.controller, opt), root = viz.root;
-        var graph;
-        viz.root = opt.id || viz.root;
-        switch(options.type) {
-            case 'nothing':
-                graph = viz.construct(json);
-                graph.eachNode(function(elem) {
-                    elem.eachAdjacency(function(adj) {
-                        viz.graph.addAdjacence(adj.nodeFrom, adj.nodeTo, adj.data);
-                    });
-                });
-                break;
-            
-            case 'replot':
-                viz.refresh(true);
-                this.sum(json, { type: 'nothing' });
-                viz.refresh(true);
-                break;
-            
-            case 'fade:seq': case 'fade': case 'fade:con':
-                that = this;
-                graph = viz.construct(json);
-
-                //set alpha to 0 for nodes to add.
-                var fadeEdges = this.preprocessSum(graph);
-                var modes = !fadeEdges? ['node-property:alpha'] : ['node-property:alpha', 'edge-property:alpha'];
-                viz.reposition();
-                if(options.type != 'fade:con') {
-                    viz.fx.animate($.merge(options, {
-                        modes: ['linear'],
-                        onComplete: function() {
-                            viz.fx.animate($.merge(options, {
-                                modes: modes,
-                                onComplete: function() {
-                                    options.onComplete();
-                                }
-                            }));
-                        }
-                    }));
-                } else {
-                    viz.graph.eachNode(function(elem) {
-                        if (elem.id != root && elem.pos.isZero()) {
-                          elem.pos.set(elem.endPos); 
-                          elem.startPos.set(elem.endPos);
-                        }
-                    });
-                    viz.fx.animate($.merge(options, {
-                        modes: ['linear'].concat(modes)
-                    }));
-                }
-                break;
-
-            default: this.doError();
-        }
-    },
-    
-    /*
-       Method: morph
-    
-       This method will transform the current visualized graph into the new JSON representation passed in the method. 
-       The JSON object must at least have the root node in common with the current visualized graph.
-
-       Parameters:
-    
-       json - (object) A json tree or graph structure. See also <Loader.loadJSON>.
-       opt - (object) Animation options. It's an object with optional properties described below
-       type - (string) Default's *nothing*. Type of the animation. Can be "nothing", "replot", "fade:con".
-       duration - Described in <Options.Fx>.
-       fps - Described in <Options.Fx>.
-       transition - Described in <Options.Fx>.
-       hideLabels - (boolean) Default's *true*. Hide labels during the animation.
-       id - (string) The shared <Graph.Node> id between both graphs.
-       
-       extraModes - (optional|object) When morphing with an animation, dollar prefixed data parameters are added to 
-                    *endData* and not *data* itself. This way you can animate dollar prefixed parameters during your morphing operation. 
-                    For animating these extra-parameters you have to specify an object that has animation groups as keys and animation 
-                    properties as values, just like specified in <Graph.Plot.animate>.
-   
-      Example:
-      (start code js)
-        //...json contains a tree or graph structure...
-
-        var viz = new $jit.Viz(options);
-        viz.op.morph(json, {
-          type: 'fade',
-          duration: 1000,
-          hideLabels: false,
-          transition: $jit.Trans.Quart.easeOut
-        });
-        //or also
-        viz.op.morph(json, {
-          type: 'fade',
-          duration: 1500
-        });
-        //if the json data contains dollar prefixed params
-        //like $width or $height these too can be animated
-        viz.op.morph(json, {
-          type: 'fade',
-          duration: 1500
-        }, {
-          'node-property': ['width', 'height']
-        });
-      (end code)
-    
-    */
-    morph: function(json, opt, extraModes) {
-        extraModes = extraModes || {};
-        var viz = this.viz;
-        var options = $.merge(this.options, viz.controller, opt), root = viz.root;
-        var graph;
-        //TODO(nico) this hack makes morphing work with the Hypertree. 
-        //Need to check if it has been solved and this can be removed.
-        viz.root = opt.id || viz.root;
-        switch(options.type) {
-            case 'nothing':
-                graph = viz.construct(json);
-                graph.eachNode(function(elem) {
-                  var nodeExists = viz.graph.hasNode(elem.id);  
-                  elem.eachAdjacency(function(adj) {
-                    var adjExists = !!viz.graph.getAdjacence(adj.nodeFrom.id, adj.nodeTo.id);
-                    viz.graph.addAdjacence(adj.nodeFrom, adj.nodeTo, adj.data);
-                    //Update data properties if the node existed
-                    if(adjExists) {
-                      var addedAdj = viz.graph.getAdjacence(adj.nodeFrom.id, adj.nodeTo.id);
-                      for(var prop in (adj.data || {})) {
-                        addedAdj.data[prop] = adj.data[prop];
-                      }
-                    }
-                  });
-                  //Update data properties if the node existed
-                  if(nodeExists) {
-                    var addedNode = viz.graph.getNode(elem.id);
-                    for(var prop in (elem.data || {})) {
-                      addedNode.data[prop] = elem.data[prop];
-                    }
-                  }
-                });
-                viz.graph.eachNode(function(elem) {
-                    elem.eachAdjacency(function(adj) {
-                        if(!graph.getAdjacence(adj.nodeFrom.id, adj.nodeTo.id)) {
-                            viz.graph.removeAdjacence(adj.nodeFrom.id, adj.nodeTo.id);
-                        }
-                    });
-                    if(!graph.hasNode(elem.id)) viz.graph.removeNode(elem.id);
-                });
-                
-                break;
-            
-            case 'replot':
-                viz.labels.clearLabels(true);
-                this.morph(json, { type: 'nothing' });
-                viz.refresh(true);
-                viz.refresh(true);
-                break;
-                
-            case 'fade:seq': case 'fade': case 'fade:con':
-                that = this;
-                graph = viz.construct(json);
-                //preprocessing for nodes to delete.
-                //get node property modes to interpolate
-                var nodeModes = ('node-property' in extraModes) 
-                  && $.map($.splat(extraModes['node-property']), 
-                      function(n) { return '$' + n; });
-                viz.graph.eachNode(function(elem) {
-                  var graphNode = graph.getNode(elem.id);   
-                  if(!graphNode) {
-                      elem.setData('alpha', 1);
-                      elem.setData('alpha', 1, 'start');
-                      elem.setData('alpha', 0, 'end');
-                      elem.ignore = true;
-                    } else {
-                      //Update node data information
-                      var graphNodeData = graphNode.data;
-                      for(var prop in graphNodeData) {
-                        if(nodeModes && ($.indexOf(nodeModes, prop) > -1)) {
-                          elem.endData[prop] = graphNodeData[prop];
-                        } else {
-                          elem.data[prop] = graphNodeData[prop];
-                        }
-                      }
-                    }
-                }); 
-                viz.graph.eachNode(function(elem) {
-                    if(elem.ignore) return;
-                    elem.eachAdjacency(function(adj) {
-                        if(adj.nodeFrom.ignore || adj.nodeTo.ignore) return;
-                        var nodeFrom = graph.getNode(adj.nodeFrom.id);
-                        var nodeTo = graph.getNode(adj.nodeTo.id);
-                        if(!nodeFrom.adjacentTo(nodeTo)) {
-                            var adj = viz.graph.getAdjacence(nodeFrom.id, nodeTo.id);
-                            fadeEdges = true;
-                            adj.setData('alpha', 1);
-                            adj.setData('alpha', 1, 'start');
-                            adj.setData('alpha', 0, 'end');
-                            adj._hiding = true;
-                        } else if (adj.data.$direction && adj.data.$direction[0] === nodeFrom.id) {
-                            // only check one direction (from -> to)
-                            if (!nodeFrom.adjacentWithDirectionTo(nodeTo)) {
-                                adj._reversing = true;
-                            }
-                        }
-                    });
-                }); 
-                //preprocessing for adding nodes.
-                var fadeEdges = this.preprocessSum(graph);
-
-                var modes = !fadeEdges? ['node-property:alpha'] : 
-                                        ['node-property:alpha', 
-                                         'edge-property:alpha'];
-                //Append extra node-property animations (if any)
-                modes[0] = modes[0] + (('node-property' in extraModes)? 
-                    (':' + $.splat(extraModes['node-property']).join(':')) : '');
-                //Append extra edge-property animations (if any)
-                modes[1] = (modes[1] || 'edge-property:alpha') + (('edge-property' in extraModes)? 
-                    (':' + $.splat(extraModes['edge-property']).join(':')) : '');
-                //Add label-property animations (if any)
-                if('label-property' in extraModes) {
-                  modes.push('label-property:' + $.splat(extraModes['label-property']).join(':'))
-                }
-                //only use reposition if its implemented.
-                if (viz.reposition) {
-                  viz.reposition();
-                } else {
-                  viz.compute('end');
-                }
-                this._updateDirectedEdges();
-
-                viz.graph.eachNode(function(elem) {
-                    if (elem.id != root && elem.pos.getp().equals(Polar.KER)) {
-                      elem.pos.set(elem.endPos); elem.startPos.set(elem.endPos);
-                    }
-                });
-                viz.fx.animate($.merge(options, {
-                    modes: [extraModes.position || 'polar'].concat(modes),
-                    onComplete: function() {
-                        viz.graph.eachNode(function(elem) {
-                            if(elem.ignore) viz.graph.removeNode(elem.id);
-                        });
-                        viz.graph.eachNode(function(elem) {
-                            elem.eachAdjacency(function(adj) {
-                                if(adj.ignore) viz.graph.removeAdjacence(adj.nodeFrom.id, adj.nodeTo.id);
-                            });
-                        });
-                        options.onComplete();
-                    }
-                }));
-                break;
-
-            default:;
-        }
-    },
-
-    _updateDirectedEdges: function () {
-        var graph = this.viz.graph;
-        graph.eachNode(function(node) {
-            node.eachAdjacency(function (adj) {
-
-                var isDirectedEdge = adj.data.$direction;
-                if (isDirectedEdge && adj.nodeFrom.id !== adj.data.$direction[0]) {
-                    return;
-                }
-
-                if (adj._hiding) {
-                    graph.removeAdjacence(adj.nodeFrom.id, adj.nodeTo.id);
-                }
-
-                if (adj._reversing) {
-                    var from = adj.nodeFrom.id;
-                    var to = adj.nodeTo.id;
-//
-//                    // swap instead of adding and removing
-                    var edge1 = graph.edges[from][to];
-                    var edge2 = graph.edges[to][from];
-
-                    edge1.data.$direction = [to, from];
-                    edge2.data.$direction = [to, from];
-
-                    adj._reversing = undefined;
-                }
-            });
-        });
-    },
-    
-  /*
-    Method: contract
-    Collapses the subtree of the given node. The node will have a _collapsed=true_ property.
-    
-    Parameters:
-    node - (object) A <Graph.Node>.
-    opt - (object) An object containing options described below
-    type - (string) Whether to 'replot' or 'animate' the contraction.
-   
-    There are also a number of Animation options. For more information see <Options.Fx>.
-
-    Example:
-    (start code js)
-     var viz = new $jit.Viz(options);
-     viz.op.contract(node, {
-       type: 'animate',
-       duration: 1000,
-       hideLabels: true,
-       transition: $jit.Trans.Quart.easeOut
-     });
-   (end code)
-   */
-    contract: function(node, opt) {
-      var viz = this.viz;
-      if(node.collapsed || !node.anySubnode($.lambda(true))) return;
-      opt = $.merge(this.options, viz.config, opt || {}, {
-        'modes': ['node-property:alpha:span', 'linear']
-      });
-      node.collapsed = true;
-      (function subn(n) {
-        n.eachSubnode(function(ch) {
-          ch.ignore = true;
-          ch.setData('alpha', 0, opt.type == 'animate'? 'end' : 'current');
-          subn(ch);
-        });
-      })(node);
-      if(opt.type == 'animate') {
-        viz.compute('end');
-        if(viz.rotated) {
-          viz.rotate(viz.rotated, 'none', {
-            'property':'end'
-          });
-        }
-        (function subn(n) {
-          n.eachSubnode(function(ch) {
-            ch.setPos(node.getPos('end'), 'end');
-            subn(ch);
-          });
-        })(node);
-        viz.fx.animate(opt);
-      } else if(opt.type == 'replot'){
-        viz.refresh();
-      }
-    },
-    
-    /*
-    Method: expand
-    Expands the previously contracted subtree. The given node must have the _collapsed=true_ property.
-    
-    Parameters:
-    node - (object) A <Graph.Node>.
-    opt - (object) An object containing options described below
-    type - (string) Whether to 'replot' or 'animate'.
-     
-    There are also a number of Animation options. For more information see <Options.Fx>.
-
-    Example:
-    (start code js)
-      var viz = new $jit.Viz(options);
-      viz.op.expand(node, {
-        type: 'animate',
-        duration: 1000,
-        hideLabels: true,
-        transition: $jit.Trans.Quart.easeOut
-      });
-    (end code)
-   */
-    expand: function(node, opt) {
-      if(!('collapsed' in node)) return;
-      var viz = this.viz;
-      opt = $.merge(this.options, viz.config, opt || {}, {
-        'modes': ['node-property:alpha:span', 'linear']
-      });
-      delete node.collapsed;
-      (function subn(n) {
-        n.eachSubnode(function(ch) {
-          delete ch.ignore;
-          ch.setData('alpha', 1, opt.type == 'animate'? 'end' : 'current');
-          subn(ch);
-        });
-      })(node);
-      if(opt.type == 'animate') {
-        viz.compute('end');
-        if(viz.rotated) {
-          viz.rotate(viz.rotated, 'none', {
-            'property':'end'
-          });
-        }
-        viz.fx.animate(opt);
-      } else if(opt.type == 'replot'){
-        viz.refresh();
-      }
-    },
-
-    preprocessSum: function(graph) {
-        var viz = this.viz;
-        graph.eachNode(function(elem) {
-            if(!viz.graph.hasNode(elem.id)) {
-                viz.graph.addNode(elem);
-                var n = viz.graph.getNode(elem.id);
-                n.setData('alpha', 0);
-                n.setData('alpha', 0, 'start');
-                n.setData('alpha', 1, 'end');
-            }
-        }); 
-        var fadeEdges = false;
-        graph.eachNode(function(elem) {
-            elem.eachAdjacency(function(adj) {
-                var nodeFrom = viz.graph.getNode(adj.nodeFrom.id);
-                var nodeTo = viz.graph.getNode(adj.nodeTo.id);
-                if(!nodeFrom.adjacentTo(nodeTo)) {
-                    var adj = viz.graph.addAdjacence(nodeFrom, nodeTo, adj.data);
-                    if(nodeFrom.startAlpha == nodeFrom.endAlpha 
-                    && nodeTo.startAlpha == nodeTo.endAlpha) {
-                        fadeEdges = true;
-                        adj.setData('alpha', 0);
-                        adj.setData('alpha', 0, 'start');
-                        adj.setData('alpha', 1, 'end');
-                    } 
-                }
-            });
-        }); 
-        return fadeEdges;
-    }
-};
-
-
-
-/*
- File: Helpers.js
-
- Helpers are objects that contain rendering primitives (like rectangles, ellipses, etc), for plotting nodes and edges.
- Helpers also contain implementations of the *contains* method, a method returning a boolean indicating whether the mouse
- position is over the rendered shape.
-
- Helpers are very useful when implementing new NodeTypes, since you can access them through *this.nodeHelper* and
- *this.edgeHelper* <Graph.Plot> properties, providing you with simple primitives and mouse-position check functions.
-
- Example:
- (start code js)
- //implement a new node type
- $jit.Viz.Plot.NodeTypes.implement({
- 'customNodeType': {
- 'render': function(node, canvas) {
- this.nodeHelper.circle.render ...
- },
- 'contains': function(node, pos) {
- this.nodeHelper.circle.contains ...
- }
- }
- });
- //implement an edge type
- $jit.Viz.Plot.EdgeTypes.implement({
- 'customNodeType': {
- 'render': function(node, canvas) {
- this.edgeHelper.circle.render ...
- },
- //optional
- 'contains': function(node, pos) {
- this.edgeHelper.circle.contains ...
- }
- }
- });
- (end code)
-
- */
-
-/*
- Object: NodeHelper
-
- Contains rendering and other type of primitives for simple shapes.
- */
-var MultiNodeHelper = {
-    'none': {
-        'render': $.empty,
-        'contains': $.lambda(false)
-    },
-       'host': {
-               'render': function(pos, canvas, animating) {
-                       var ctx = canvas.getCtx();
-                       var img = new Image();
-                       img.src='../img/Device_pc_3045_default_64.png';
-                       if(animating == false) {
-                               img.onload = function() {
-                                       ctx.drawImage(img,pos.x-32,pos.y-32);
-                               };
-                       } else {
-                               ctx.drawImage(img,pos.x-32,pos.y-32);
-                               img.onload = function() {
-                                       ctx.drawImage(img,pos.x-32,pos.y-32);
-                               };
-                       }
-               },
-               'contains': function(npos, pos) {
-                       var width = 64, height = 55;
-                       return Math.abs(pos.x - npos.x) <= width / 2
-                               && Math.abs(pos.y - npos.y) <= height / 2;
-               }
-       },
-       'switch': {
-               'render': function(pos, canvas, animating) {
-                       var ctx = canvas.getCtx();
-                       var img = new Image();
-                       img.src='../img/Device_switch_3062_unknown_64.png';
-                       if(animating == false) {
-                               img.onload = function() {
-                                       ctx.drawImage(img,pos.x-32,pos.y-32);
-                               };
-                       } else {
-                               ctx.drawImage(img,pos.x-32,pos.y-32);
-                               img.onload = function() {
-                                       ctx.drawImage(img,pos.x-32,pos.y-32);
-                               };
-                       }
-               },
-               'contains': function(npos, pos) {
-                       var width = 64, height = 45;
-                       return Math.abs(pos.x - npos.x) <= width / 2
-                               && Math.abs(pos.y - npos.y) <= height / 2;
-               }
-       }
-};
-
-/*
- Object: EdgeHelper
-
- Contains rendering primitives for simple edge shapes.
- */
-var MultiEdgeHelper = {
-    /*
-     Object: EdgeHelper.line
-     */
-    'line': {
-        /*
-         Method: render
-
-         Renders a line into the canvas.
-
-         Parameters:
-
-         from - (object) An *x*, *y* object with the starting position of the line.
-         to - (object) An *x*, *y* object with the ending position of the line.
-         canvas - (object) A <Canvas> instance.
-
-         Example:
-         (start code js)
-         EdgeHelper.line.render({ x: 10, y: 30 }, { x: 10, y: 50 }, viz.canvas);
-         (end code)
-         */
-        'render': function(from, to, alpha, canvas){
-                       alpha *= 8;
-            var ctx = canvas.getCtx();
-                       ctx.beginPath();
-            
-                       // trig path
-                       dx = from.x-to.x; dy = from.y-to.y;
-                       tan = Math.atan(dx/dy);
-                       cos = (-1)*Math.cos(tan);
-                       sin = Math.sin(tan);
-
-                       // draw the line
-            ctx.moveTo(from.x+(alpha*cos), from.y+(alpha*sin));
-            ctx.lineTo(to.x+(alpha*cos), to.y+(alpha*sin));
-            ctx.stroke();
-        },
-        /*
-         Method: contains
-
-         Returns *true* if *pos* is contained in the area of the shape. Returns *false* otherwise.
-
-         Parameters:
-
-         posFrom - (object) An *x*, *y* object with a <Graph.Node> position.
-         posTo - (object) An *x*, *y* object with a <Graph.Node> position.
-         pos - (object) An *x*, *y* object with the position to check.
-         epsilon - (number) The dimension of the shape.
-
-         Example:
-         (start code js)
-         EdgeHelper.line.contains({ x: 10, y: 30 }, { x: 15, y: 35 }, { x: 15, y: 35 }, 30);
-         (end code)
-         */
-        'contains': function(posFrom, posTo, alpha, pos, epsilon, canvas) {
-                       alpha *= 8;
-                       var ctx = canvas.getCtx();
-                       ctx.save();
-                       ctx.beginPath();
-
-                       // trig path
-                       dx = posFrom.x-posTo.x; dy = posFrom.y-posTo.y;
-                       tan = Math.atan(dx/dy);
-                       cos = (-1)*Math.cos(tan);
-                       sin = Math.sin(tan);
-
-                       // draw rect
-                       var width = 2.5;
-                       ctx.moveTo(posFrom.x+((alpha-width)*cos), posFrom.y+((alpha-width)*sin));
-                       ctx.lineTo(posTo.x+((alpha-width)*cos), posTo.y+((alpha-width)*sin));
-                       ctx.lineTo(posTo.x+((alpha+width)*cos), posTo.y+((alpha+width)*sin));
-                       ctx.lineTo(posFrom.x+((alpha+width)*cos), posFrom.y+((alpha+width)*sin));
-
-                       // check if point is in path
-                       ox = ctx.canvas.offsetWidth/2;
-                       oy = ctx.canvas.offsetHeight/2;
-                       sx = canvas.scaleOffsetX;
-                       sy = canvas.scaleOffsetY;
-                       tx = canvas.translateOffsetX;
-                       ty = canvas.translateOffsetY;
-                       if (ctx.isPointInPath((tx+ox+pos.x*sx), (ty+oy+pos.y*sy))) {
-                               ctx.restore();
-                               return true;
-                       }
-
-                       ctx.restore();
-                       return false;
-        }
-    }
-};
-
-
-       /*
- * File: Graph.Plot.js
- */
-
-/*
-   Object: Graph.Plot
-
-   <Graph> rendering and animation methods.
-   
-   Properties:
-   
-   nodeHelper - <NodeHelper> object.
-   edgeHelper - <EdgeHelper> object.
-*/
-MultiGraph.Plot = {
-    //Default initializer
-    initialize: function(viz, klass){
-      this.viz = viz;
-      this.config = viz.config;
-      this.node = viz.config.Node;
-      this.edge = viz.config.Edge;
-      this.animation = new Animation;
-      this.nodeTypes = new klass.Plot.NodeTypes;
-      this.edgeTypes = new klass.Plot.EdgeTypes;
-      this.labels = viz.labels;
-   },
-
-    //Add helpers
-    nodeHelper: MultiNodeHelper,
-    edgeHelper: MultiEdgeHelper,
-    
-    Interpolator: {
-        //node/edge property parsers
-        'map': {
-          'border': 'color',
-          'color': 'color',
-          'width': 'number',
-          'height': 'number',
-          'dim': 'number',
-          'alpha': 'number',
-          'lineWidth': 'number',
-          'angularWidth':'number',
-          'span':'number',
-          'valueArray':'array-number',
-          'dimArray':'array-number',
-          'vertices':'polygon'
-          //'colorArray':'array-color'
-        },
-
-        //canvas specific parsers
-        'canvas': {
-          'globalAlpha': 'number',
-          'fillStyle': 'color',
-          'strokeStyle': 'color',
-          'lineWidth': 'number',
-          'shadowBlur': 'number',
-          'shadowColor': 'color',
-          'shadowOffsetX': 'number',
-          'shadowOffsetY': 'number',
-          'miterLimit': 'number'
-        },
-
-        //label parsers
-        'label': {
-          'size': 'number',
-          'color': 'color'
-        },
-
-        //Number interpolator
-        'compute': function(from, to, delta) {
-          return from + (to - from) * delta;
-        },
-
-        //Position interpolators
-        'moebius': function(elem, props, delta, vector) {
-          var v = vector.scale(-delta);
-          if(v.norm() < 1) {
-              var x = v.x, y = v.y;
-              var ans = elem.startPos
-                .getc().moebiusTransformation(v);
-              elem.pos.setc(ans.x, ans.y);
-              v.x = x; v.y = y;
-            }
-        },
-
-        'linear': function(elem, props, delta) {
-            var from = elem.startPos.getc(true);
-            var to = elem.endPos.getc(true);
-            elem.pos.setc(this.compute(from.x, to.x, delta),
-                          this.compute(from.y, to.y, delta));
-        },
-
-        'polar': function(elem, props, delta) {
-          var from = elem.startPos.getp(true);
-          var to = elem.endPos.getp();
-          var ans = to.interpolate(from, delta);
-          elem.pos.setp(ans.theta, ans.rho);
-        },
-
-        //Graph's Node/Edge interpolators
-        'number': function(elem, prop, delta, getter, setter) {
-                       var from, to;
-                       if(Array.isArray(elem)) { // for multi-links
-                               for(var e in elem) {
-                                       var ee = elem[e];
-                                       from = ee[getter](prop, 'start');
-                                       to = ee[getter](prop, 'end');
-                                       if (from != to) {
-                                               elem = ee;
-                                               break;
-                                       }
-                               }
-                               if(Array.isArray(elem)) return;
-                       } else { // for nodes
-                         from = elem[getter](prop, 'start');
-                         to = elem[getter](prop, 'end');
-                   }
-                       elem[setter](prop, this.compute(from, to, delta));
-        },
-
-        'color': function(elem, prop, delta, getter, setter) {
-                         var from, to;
-                         if(Array.isArray(elem)) { // for multi-links
-                               for(var e in elem) {
-                                       var ee = elem[e];
-                                       from = $.hexToRgb(ee[getter](prop, 'start'));
-                                       to = $.hexToRgb(ee[getter](prop, 'end'));
-                                       if(from[0] != to[0] || from[1] != to[1] || from[2] != to[2]) {
-                                               elem = ee;
-                                               break;
-                                       }
-                               }
-                               if(Array.isArray(elem)) return;
-                         } else { // for nodes
-                                 var from = $.hexToRgb(elem[getter](prop, 'start'));
-                                 var to = $.hexToRgb(elem[getter](prop, 'end'));
-                         }
-                         var comp = this.compute;
-                         var val = $.rgbToHex([parseInt(comp(from[0], to[0], delta)),
-                                                                       parseInt(comp(from[1], to[1], delta)),
-                                                                       parseInt(comp(from[2], to[2], delta))]);
-                         elem[setter](prop, val);
-        },
-
-        'array-number': function(elem, prop, delta, getter, setter) {
-          var from = elem[getter](prop, 'start'),
-              to = elem[getter](prop, 'end'),
-              cur = [];
-          for(var i=0, l=from.length; i<l; i++) {
-            var fromi = from[i], toi = to[i];
-            if(fromi.length) {
-              for(var j=0, len=fromi.length, curi=[]; j<len; j++) {
-                curi.push(this.compute(fromi[j], toi[j], delta));
-              }
-              cur.push(curi);
-            } else {
-              cur.push(this.compute(fromi, toi, delta));
-            }
-          }
-          elem[setter](prop, cur);
-        },
-
-        'node': function(elem, props, delta, map, getter, setter) {
-          map = this[map];
-          if(props) {
-            var len = props.length;
-            for(var i=0; i<len; i++) {
-              var pi = props[i];
-              this[map[pi]](elem, pi, delta, getter, setter);
-            }
-          } else {
-            for(var pi in map) {
-              this[map[pi]](elem, pi, delta, getter, setter);
-            }
-          }
-        },
-
-        'edge': function(elem, props, delta, mapKey, getter, setter) {
-            var adjs = elem.adjacencies;
-            for(var id in adjs) this['node'](adjs[id], props, delta, mapKey, getter, setter);
-        },
-
-        'node-property': function(elem, props, delta) {
-          this['node'](elem, props, delta, 'map', 'getData', 'setData');
-        },
-
-        'edge-property': function(elem, props, delta) {
-          this['edge'](elem, props, delta, 'map', 'getData', 'setData');
-        },
-
-        'label-property': function(elem, props, delta) {
-          this['node'](elem, props, delta, 'label', 'getLabelData', 'setLabelData');
-        },
-
-        'node-style': function(elem, props, delta) {
-          this['node'](elem, props, delta, 'canvas', 'getCanvasStyle', 'setCanvasStyle');
-        },
-
-        'edge-style': function(elem, props, delta) {
-          this['edge'](elem, props, delta, 'canvas', 'getCanvasStyle', 'setCanvasStyle');
-        },
-
-        'polygon': function(elem, prop, delta, getter, setter) {
-          var from = elem[getter](prop, 'start'),
-              to = elem[getter](prop, 'end'),
-              cur = [];
-          if (typeof from.offset == 'undefined') {
-            if (from === 0) {
-              from = $.map(to, function() {
-                return new $jit.Complex(0, 0);
-              });
-              from.offset = 0;
-            }
-            else {
-              if (from.length == 0) {
-                from.push(new $jit.Complex(0, 0));
-              }
-              while (from.length < to.length) {
-                from.push(from[0]);
-              }
-              while (from.length > to.length) {
-                to.push(to[0] || new $jit.Complex(0, 0));
-              }
-              if (from.length == 0) return;
-              var l = from.length;
-              var minDist = 1e300;
-              for (var offset = 0; offset < l; offset ++) {
-                var d = 0;
-                for (var i = 0; i < l; i++) {
-                  d +=Geometry.dist2(from[(offset + i) % l], to[i]);
-                }
-                if (d < minDist) {
-                  from.offset = offset;
-                  minDist = d;
-                }
-              }
-            }
-          }
-
-          for (var i = 0, l = from.length; i < l; i++) {
-            var fromi = from[(i + from.offset) % l], toi = to[i];
-            cur.push(new $jit.Complex(
-                this.compute(fromi.x, toi.x, delta),
-                this.compute(fromi.y, toi.y, delta)
-            ));
-          }
-          elem[setter](prop, cur);
-        }
-    },
-    
-  
-    /*
-       sequence
-    
-       Iteratively performs an action while refreshing the state of the visualization.
-
-       Parameters:
-
-       options - (object) An object containing some sequence options described below
-       condition - (function) A function returning a boolean instance in order to stop iterations.
-       step - (function) A function to execute on each step of the iteration.
-       onComplete - (function) A function to execute when the sequence finishes.
-       duration - (number) Duration (in milliseconds) of each step.
-
-      Example:
-       (start code js)
-        var rg = new $jit.RGraph(options);
-        var i = 0;
-        rg.fx.sequence({
-          condition: function() {
-           return i == 10;
-          },
-          step: function() {
-            alert(i++);
-          },
-          onComplete: function() {
-           alert('done!');
-          }
-        });
-       (end code)
-
-    */
-    sequence: function(options) {
-        var that = this;
-        options = $.merge({
-          condition: $.lambda(false),
-          step: $.empty,
-          onComplete: $.empty,
-          duration: 200
-        }, options || {});
-
-        var interval = setInterval(function() {
-          if(options.condition()) {
-            options.step();
-          } else {
-            clearInterval(interval);
-            options.onComplete();
-          }
-          that.viz.refresh(true);
-        }, options.duration);
-    },
-    
-    /*
-      prepare
-      Prepare graph position and other attribute values before performing an Animation. 
-      This method is used internally by the Toolkit.
-      
-      See also:
-       
-       <Animation>, <Graph.Plot.animate>
-
-    */
-    prepare: function(modes) {
-      var graph = this.viz.graph,
-          accessors = {
-            'node-property': {
-              'getter': 'getData',
-              'setter': 'setData'
-            },
-            'edge-property': {
-              'getter': 'getData',
-              'setter': 'setData'
-            },
-            'node-style': {
-              'getter': 'getCanvasStyle',
-              'setter': 'setCanvasStyle'
-            },
-            'edge-style': {
-              'getter': 'getCanvasStyle',
-              'setter': 'setCanvasStyle'
-            }
-          };
-
-      //parse modes
-      var m = {};
-      if($.type(modes) == 'array') {
-        for(var i=0, len=modes.length; i < len; i++) {
-          var elems = modes[i].split(':');
-          m[elems.shift()] = elems;
-        }
-      } else {
-        for(var p in modes) {
-          if(p == 'position') {
-            m[modes.position] = [];
-          } else {
-            m[p] = $.splat(modes[p]);
-          }
-        }
-      }
-      
-      graph.eachNode(function(node) { 
-        node.startPos.set(node.pos);
-        $.each(['node-property', 'node-style'], function(p) {
-          if(p in m) {
-            var prop = m[p];
-            for(var i=0, l=prop.length; i < l; i++) {
-              node[accessors[p].setter](prop[i], node[accessors[p].getter](prop[i]), 'start');
-            }
-          }
-        });
-        $.each(['edge-property', 'edge-style'], function(p) {
-          if(p in m) {
-            var prop = m[p];
-            node.eachAdjacency(function(adj) {
-              for(var i=0, l=prop.length; i < l; i++) {
-                adj[accessors[p].setter](prop[i], adj[accessors[p].getter](prop[i]), 'start');
-              }
-            });
-          }
-        });
-      });
-      return m;
-    },
-    
-    /*
-       Method: animate
-    
-       Animates a <Graph> by interpolating some <Graph.Node>, <Graph.Adjacence> or <Graph.Label> properties.
-
-       Parameters:
-
-       opt - (object) Animation options. The object properties are described below
-       duration - (optional) Described in <Options.Fx>.
-       fps - (optional) Described in <Options.Fx>.
-       hideLabels - (optional|boolean) Whether to hide labels during the animation.
-       modes - (required|object) An object with animation modes (described below).
-
-       Animation modes:
-       
-       Animation modes are strings representing different node/edge and graph properties that you'd like to animate. 
-       They are represented by an object that has as keys main categories of properties to animate and as values a list 
-       of these specific properties. The properties are described below
-       
-       position - Describes the way nodes' positions must be interpolated. Possible values are 'linear', 'polar' or 'moebius'.
-       node-property - Describes which Node properties will be interpolated. These properties can be any of the ones defined in <Options.Node>.
-       edge-property - Describes which Edge properties will be interpolated. These properties can be any the ones defined in <Options.Edge>.
-       label-property - Describes which Label properties will be interpolated. These properties can be any of the ones defined in <Options.Label> like color or size.
-       node-style - Describes which Node Canvas Styles will be interpolated. These are specific canvas properties like fillStyle, strokeStyle, lineWidth, shadowBlur, shadowColor, shadowOffsetX, shadowOffsetY, etc.
-       edge-style - Describes which Edge Canvas Styles will be interpolated. These are specific canvas properties like fillStyle, strokeStyle, lineWidth, shadowBlur, shadowColor, shadowOffsetX, shadowOffsetY, etc.
-
-       Example:
-       (start code js)
-       var viz = new $jit.Viz(options);
-       //...tweak some Data, CanvasStyles or LabelData properties...
-       viz.fx.animate({
-         modes: {
-           'position': 'linear',
-           'node-property': ['width', 'height'],
-           'node-style': 'shadowColor',
-           'label-property': 'size'
-         },
-         hideLabels: false
-       });
-       //...can also be written like this...
-       viz.fx.animate({
-         modes: ['linear',
-                 'node-property:width:height',
-                 'node-style:shadowColor',
-                 'label-property:size'],
-         hideLabels: false
-       });
-       (end code)
-    */
-    animate: function(opt, versor) {
-      opt = $.merge(this.viz.config, opt || {});
-      var that = this,
-          viz = this.viz,
-          graph  = viz.graph,
-          interp = this.Interpolator,
-          animation =  opt.type === 'nodefx'? this.nodeFxAnimation : this.animation;
-      //prepare graph values
-      var m = this.prepare(opt.modes);
-      
-      //animate
-      if(opt.hideLabels) this.labels.hideLabels(true);
-      animation.setOptions($.extend(opt, {
-        $animating: false,
-        compute: function(delta) {
-          graph.eachNode(function(node) { 
-            for(var p in m) {
-              interp[p](node, m[p], delta, versor);
-            }
-          });
-          that.plot(opt, this.$animating, delta);
-          this.$animating = true;
-        },
-        complete: function() {
-          if(opt.hideLabels) that.labels.hideLabels(false);
-          that.plot(opt);
-          opt.onComplete();
-          //TODO(nico): This shouldn't be here!
-          //opt.onAfterCompute();
-        }       
-      })).start();
-    },
-    
-    /*
-      nodeFx
-   
-      Apply animation to node properties like color, width, height, dim, etc.
-  
-      Parameters:
-  
-      options - Animation options. This object properties is described below
-      elements - The Elements to be transformed. This is an object that has a properties
-      
-      (start code js)
-      'elements': {
-        //can also be an array of ids
-        'id': 'id-of-node-to-transform',
-        //properties to be modified. All properties are optional.
-        'properties': {
-          'color': '#ccc', //some color
-          'width': 10, //some width
-          'height': 10, //some height
-          'dim': 20, //some dim
-          'lineWidth': 10 //some line width
-        } 
-      }
-      (end code)
-      
-      - _reposition_ Whether to recalculate positions and add a motion animation. 
-      This might be used when changing _width_ or _height_ properties in a <Layouts.Tree> like layout. Default's *false*.
-      
-      - _onComplete_ A method that is called when the animation completes.
-      
-      ...and all other <Graph.Plot.animate> options like _duration_, _fps_, _transition_, etc.
-  
-      Example:
-      (start code js)
-       var rg = new RGraph(canvas, config); //can be also Hypertree or ST
-       rg.fx.nodeFx({
-         'elements': {
-           'id':'mynodeid',
-           'properties': {
-             'color':'#ccf'
-           },
-           'transition': Trans.Quart.easeOut
-         }
-       });
-      (end code)    
-   */
-   nodeFx: function(opt) {
-     if (this.nodeFxAnimation == undefined) {
-       this.nodeFxAnimation = new Animation();
-     }
-
-     var viz = this.viz,
-         graph  = viz.graph,
-         animation = this.nodeFxAnimation,
-         options = $.merge(this.viz.config, {
-           'elements': {
-             'id': false,
-             'properties': {}
-           },
-           'reposition': false
-         });
-     opt = $.merge(options, opt || {}, {
-       onBeforeCompute: $.empty,
-       onAfterCompute: $.empty
-     });
-     //check if an animation is running
-     animation.stopTimer();
-     var props = opt.elements.properties;
-     //set end values for nodes
-     if(!opt.elements.id) {
-       graph.eachNode(function(n) {
-         for(var prop in props) {
-           n.setData(prop, props[prop], 'end');
-         }
-       });
-     } else {
-       var ids = $.splat(opt.elements.id);
-       $.each(ids, function(id) {
-         var n = graph.getNode(id);
-         if(n) {
-           for(var prop in props) {
-             n.setData(prop, props[prop], 'end');
-           }
-         }
-       });
-     }
-     //get keys
-     var propnames = [];
-     for(var prop in props) propnames.push(prop);
-     //add node properties modes
-     var modes = ['node-property:' + propnames.join(':')];
-     //set new node positions
-     if(opt.reposition) {
-       modes.push('linear');
-       viz.compute('end');
-     }
-     //animate
-     this.animate($.merge(opt, {
-       modes: modes,
-       type: 'nodefx'
-     }));
-   },
-
-    
-    /*
-       Method: plot
-    
-       Plots a <Graph>.
-
-       Parameters:
-
-       opt - (optional) Plotting options. Most of them are described in <Options.Fx>.
-
-       Example:
-
-       (start code js)
-       var viz = new $jit.Viz(options);
-       viz.fx.plot(); 
-       (end code)
-
-    */
-   plot: function(opt, animating) {
-     var viz = this.viz, 
-         aGraph = viz.graph, 
-         canvas = viz.canvas, 
-         id = viz.root, 
-         that = this, 
-         ctx = canvas.getCtx(), 
-         min = Math.min,
-         opt = opt || this.viz.controller;
-     
-     opt.clearCanvas && canvas.clear();
-       
-     var root = aGraph.getNode(id);
-     if(!root) return;
-     
-     var T = !!root.visited;
-
-        // helper method
-               var checkDupEdge = function(e) {                                          
-                       var skip = false;                                                       
-                       for(var d in viz.graph.dup) {                                               
-                               var ee = viz.graph.dup[d];                                              
-                               if(e.nodeTo.id == ee.nodeTo.id && e.nodeFrom.id == ee.nodeFrom.id) {
-                                       if(e.portTo == ee.portTo && e.portFrom == ee.portFrom) {        
-                                               skip = true;                                                
-                                               break; // NOTE: does this break the outer for loop?         
-                                       }                                                               
-                               }                                                                   
-                       }                                                                       
-                       return skip;                                                            
-               };                                                                        
-                                                                                                                                                          
-
-        // plot each line
-        var that = this;
-     aGraph.eachNode(function(node) {
-               node.eachAdjacencyBatch(function(adj) {
-                       // plot this line if it hasn't been plotted
-                       var total = adj.length;
-                       if (total == 1) {
-                               if(!checkDupEdge(adj[0])) // plot this edge if it isn't a dup
-                                       that.plotLine(adj[0], canvas, animating);
-                       } else {
-                               for(var pos in adj) {
-                                       var a = adj[pos];
-
-                                       // check if this edge is in duplicates
-                                       if(checkDupEdge(a)) continue; // skip plot this edge if it's a dup
-
-                                       that.plotBezierLine(a, pos, total, canvas, animating);
-                               }
-                       }
-               });
-
-          /*
-       var nodeAlpha = node.getData('alpha');
-       node.eachAdjacency(function(adj) {
-         var nodeTo = adj.nodeTo;
-         if(!!nodeTo.visited === T && node.drawn && nodeTo.drawn) {
-           !animating && opt.onBeforePlotLine(adj);
-           that.plotLine(adj, canvas, animating);
-           !animating && opt.onAfterPlotLine(adj);
-         }
-       });
-       if(node.drawn) {
-         !animating && opt.onBeforePlotNode(node);
-         that.plotNode(node, canvas, animating);
-         !animating && opt.onAfterPlotNode(node);
-       }
-       if(!that.labelsHidden && opt.withLabels) {
-         if(node.drawn && nodeAlpha >= 0.95) {
-           that.labels.plotLabel(canvas, node, opt);
-         } else {
-           that.labels.hideLabel(node, false);
-         }
-       }
-       node.visited = !T;
-          */
-     });
-
-        // plot all of the nodes
-        if (opt.modes != undefined && opt.modes.length > 0 && opt.modes[0] == "edge-property:color") {
-               animating = true; // HACK
-        }
-        aGraph.eachNode(function(node) {
-               !animating && opt.onBeforePlotNode(node);
-               that.plotNode(node, canvas, animating);
-               !animating && opt.onAfterPlotNode(node);
-                       that.labels.plotLabel(canvas, node, opt);
-        });
-    },
-
-  /*
-      Plots a Subtree.
-   */
-   plotTree: function(node, opt, animating) {
-       var that = this, 
-           viz = this.viz, 
-           canvas = viz.canvas,
-           config = this.config,
-           ctx = canvas.getCtx();
-       var nodeAlpha = node.getData('alpha');
-       node.eachSubnode(function(elem) {
-         if(opt.plotSubtree(node, elem) && elem.exist && elem.drawn) {
-             var adj = node.getAdjacency(elem.id);
-             !animating && opt.onBeforePlotLine(adj);
-             that.plotLine(adj, canvas, animating);
-             !animating && opt.onAfterPlotLine(adj);
-             that.plotTree(elem, opt, animating);
-         }
-       });
-       if(node.drawn) {
-           !animating && opt.onBeforePlotNode(node);
-           this.plotNode(node, canvas, animating);
-           !animating && opt.onAfterPlotNode(node);
-           if(!opt.hideLabels && opt.withLabels && nodeAlpha >= 0.95) 
-               this.labels.plotLabel(canvas, node, opt);
-           else 
-               this.labels.hideLabel(node, false);
-       } else {
-           this.labels.hideLabel(node, true);
-       }
-   },
-
-  /*
-       Method: plotNode
-    
-       Plots a <Graph.Node>.
-
-       Parameters:
-       
-       node - (object) A <Graph.Node>.
-       canvas - (object) A <Canvas> element.
-
-    */
-    plotNode: function(node, canvas, animating) {
-        var f = node.getData('type'), 
-            ctxObj = this.node.CanvasStyles;
-        if(f != 'none') {
-          var width = node.getData('lineWidth'),
-              color = node.getData('color'),
-              alpha = node.getData('alpha'),
-              ctx = canvas.getCtx();
-          ctx.save();
-          ctx.lineWidth = width;
-          ctx.fillStyle = ctx.strokeStyle = color;
-          ctx.globalAlpha = alpha;
-          
-          for(var s in ctxObj) {
-            ctx[s] = node.getCanvasStyle(s);
-          }
-
-          this.nodeTypes[f].render.call(this, node, canvas, animating);
-          ctx.restore();
-        }
-    },
-    
-    /*
-       Method: plotLine
-    
-       Plots a <Graph.Adjacence>.
-
-       Parameters:
-
-       adj - (object) A <Graph.Adjacence>.
-       canvas - (object) A <Canvas> instance.
-
-    */
-    plotLine: function(adj, canvas, animating) {
-      var f = adj.getData('type'),
-          ctxObj = this.edge.CanvasStyles;
-      if(f != 'none') {
-        var width = adj.getData('lineWidth'),
-            color = adj.getData('color'),
-            ctx = canvas.getCtx(),
-            nodeFrom = adj.nodeFrom,
-            nodeTo = adj.nodeTo;
-        
-        ctx.save();
-        ctx.lineWidth = width;
-        ctx.fillStyle = ctx.strokeStyle = color;
-        ctx.globalAlpha = Math.min(nodeFrom.getData('alpha'), 
-            nodeTo.getData('alpha'), 
-            adj.getData('alpha'));
-        
-        for(var s in ctxObj) {
-          ctx[s] = adj.getCanvasStyle(s);
-        }
-
-        this.edgeTypes[f].render.call(this, adj, 0, canvas, animating);
-        ctx.restore();
-      }
-    },
-
-       /*
-               Method: plotBezierLine
-
-               Plots a <MultiGraph.Adjacence>.
-
-               Parameters:
-               adj - (object) A <MultiGraph.Adjacence>.
-               pos - (int) Position of this line
-               total - (int) Total number of lines contained within this batch
-       */
-       plotBezierLine: function(adj, pos, total, canvas, animating) {
-                 var f = adj.getData('type'),
-          ctxObj = this.edge.CanvasStyles;
-                 if(f != 'none') {
-                       var width = adj.getData('lineWidth'),
-                               color = adj.getData('color'),
-                               ctx = canvas.getCtx(),
-                               nodeFrom = adj.nodeFrom,
-                               nodeTo = adj.nodeTo;
-                       
-                       ctx.save();
-                       ctx.lineWidth = width;
-                       ctx.fillStyle = ctx.strokeStyle = color;
-                       ctx.globalAlpha = Math.min(nodeFrom.getData('alpha'), 
-                               nodeTo.getData('alpha'), 
-                               adj.getData('alpha'));
-                       
-                       for(var s in ctxObj) {
-                         ctx[s] = adj.getCanvasStyle(s);
-                       }
-
-                       var alpha = parseInt(pos,10);
-                       var start = (0.5-(total/2));
-                       alpha += start;
-
-                       this.edgeTypes[f].render.call(this, adj, alpha, canvas, animating);
-                       ctx.restore();
-               }
-       }
-  
-};
-
-
-/*
- * File: Graph.Label.js
- *
-*/
-
-/*
-   Object: Graph.Label
-
-   An interface for plotting/hiding/showing labels.
-
-   Description:
-
-   This is a generic interface for plotting/hiding/showing labels.
-   The <Graph.Label> interface is implemented in multiple ways to provide
-   different label types.
-
-   For example, the Graph.Label interface is implemented as <Graph.Label.HTML> to provide
-   HTML label elements. Also we provide the <Graph.Label.SVG> interface for SVG type labels. 
-   The <Graph.Label.Native> interface implements these methods with the native Canvas text rendering functions.
-   
-   All subclasses (<Graph.Label.HTML>, <Graph.Label.SVG> and <Graph.Label.Native>) implement the method plotLabel.
-*/
-
-MultiGraph.Label = {};
-
-/*
-   Class: Graph.Label.Native
-
-   Implements labels natively, using the Canvas text API.
-*/
-MultiGraph.Label.Native = new Class({
-    initialize: function(viz) {
-      this.viz = viz;
-    },
-
-    /*
-       Method: plotLabel
-
-       Plots a label for a given node.
-
-       Parameters:
-
-       canvas - (object) A <Canvas> instance.
-       node - (object) A <Graph.Node>.
-       controller - (object) A configuration object.
-       
-       Example:
-       
-       (start code js)
-       var viz = new $jit.Viz(options);
-       var node = viz.graph.getNode('nodeId');
-       viz.labels.plotLabel(viz.canvas, node, viz.config);
-       (end code)
-    */
-    plotLabel: function(canvas, node, controller) {
-      var ctx = canvas.getCtx();
-      var pos = node.pos.getc(true);
-
-      ctx.font = node.getLabelData('style') + ' ' + node.getLabelData('size') + 'px ' + node.getLabelData('family');
-      ctx.textAlign = node.getLabelData('textAlign');
-      ctx.fillStyle = ctx.strokeStyle = node.getLabelData('color');
-      ctx.textBaseline = node.getLabelData('textBaseline');
-
-      this.renderLabel(canvas, node, controller);
-    },
-
-    /*
-       renderLabel
-
-       Does the actual rendering of the label in the canvas. The default
-       implementation renders the label close to the position of the node, this
-       method should be overriden to position the labels differently.
-
-       Parameters:
-
-       canvas - A <Canvas> instance.
-       node - A <Graph.Node>.
-       controller - A configuration object. See also <Hypertree>, <RGraph>, <ST>.
-    */
-    renderLabel: function(canvas, node, controller) {
-      var ctx = canvas.getCtx();
-      var pos = node.pos.getc(true);
-      ctx.fillText(node.name, pos.x, pos.y + node.getData("height") / 2);
-    },
-
-    /*
-       Method: hideLabel
-   
-       Hides the corresponding <Graph.Node> label.
-    
-       Parameters:
-   
-       node - (object) A <Graph.Node>. Can also be an array of <Graph.Nodes>.
-       show - (boolean) If *true*, nodes will be shown. Otherwise nodes will be hidden.
-   
-       Example:
-       (start code js)
-        var rg = new $jit.Viz(options);
-        viz.labels.hideLabel(viz.graph.getNode('someid'), false);
-       (end code)
-    */
-    hideLabel: function(node, show) {
-      node = $.splat(node);
-      var al = show ? false : true;
-      $.each(node, function(n) {
-        n._hideLabel = al;
-      });
-    },
-    hideLabels: $.empty
-});
-
-/*
-   Class: Graph.Label.DOM
-
-   Abstract Class implementing some DOM label methods.
-
-   Implemented by:
-
-   <Graph.Label.HTML> and <Graph.Label.SVG>.
-
-*/
-MultiGraph.Label.DOM = new Class({
-    //A flag value indicating if node labels are being displayed or not.
-    labelsHidden: false,
-    //Label container
-    labelContainer: false,
-    //Label elements hash.
-    labels: {},
-
-    /*
-       Method: getLabelContainer
-
-       Lazy fetcher for the label container.
-
-       Returns:
-
-       The label container DOM element.
-
-       Example:
-
-      (start code js)
-        var viz = new $jit.Viz(options);
-        var labelContainer = viz.labels.getLabelContainer();
-        alert(labelContainer.innerHTML);
-      (end code)
-    */
-    getLabelContainer: function() {
-      return this.labelContainer ?
-        this.labelContainer :
-        this.labelContainer = document.getElementById(this.viz.config.labelContainer);
-    },
-
-    /*
-       Method: getLabel
-
-       Lazy fetcher for the label element.
-
-       Parameters:
-
-       id - (string) The label id (which is also a <Graph.Node> id).
-
-       Returns:
-
-       The label element.
-
-       Example:
-
-      (start code js)
-        var viz = new $jit.Viz(options);
-        var label = viz.labels.getLabel('someid');
-        alert(label.innerHTML);
-      (end code)
-
-    */
-    getLabel: function(id) {
-      return (id in this.labels && this.labels[id] != null) ?
-        this.labels[id] :
-        this.labels[id] = document.getElementById(id);
-    },
-
-    /*
-       Method: hideLabels
-
-       Hides all labels (by hiding the label container).
-
-       Parameters:
-
-       hide - (boolean) A boolean value indicating if the label container must be hidden or not.
-
-       Example:
-       (start code js)
-        var viz = new $jit.Viz(options);
-        rg.labels.hideLabels(true);
-       (end code)
-
-    */
-    hideLabels: function (hide) {
-      var container = this.getLabelContainer();
-      if(hide)
-        container.style.display = 'none';
-      else
-        container.style.display = '';
-      this.labelsHidden = hide;
-    },
-
-    /*
-       Method: clearLabels
-
-       Clears the label container.
-
-       Useful when using a new visualization with the same canvas element/widget.
-
-       Parameters:
-
-       force - (boolean) Forces deletion of all labels.
-
-       Example:
-       (start code js)
-        var viz = new $jit.Viz(options);
-        viz.labels.clearLabels();
-        (end code)
-    */
-    clearLabels: function(force) {
-      for(var id in this.labels) {
-        if (force || !this.viz.graph.hasNode(id)) {
-          this.disposeLabel(id);
-          delete this.labels[id];
-        }
-      }
-    },
-
-    /*
-       Method: disposeLabel
-
-       Removes a label.
-
-       Parameters:
-
-       id - (string) A label id (which generally is also a <Graph.Node> id).
-
-       Example:
-       (start code js)
-        var viz = new $jit.Viz(options);
-        viz.labels.disposeLabel('labelid');
-       (end code)
-    */
-    disposeLabel: function(id) {
-      var elem = this.getLabel(id);
-      if(elem && elem.parentNode) {
-        elem.parentNode.removeChild(elem);
-      }
-    },
-
-    /*
-       Method: hideLabel
-
-       Hides the corresponding <Graph.Node> label.
-
-       Parameters:
-
-       node - (object) A <Graph.Node>. Can also be an array of <Graph.Nodes>.
-       show - (boolean) If *true*, nodes will be shown. Otherwise nodes will be hidden.
-
-       Example:
-       (start code js)
-        var rg = new $jit.Viz(options);
-        viz.labels.hideLabel(viz.graph.getNode('someid'), false);
-       (end code)
-    */
-    hideLabel: function(node, show) {
-      node = $.splat(node);
-      var st = show ? "" : "none", lab, that = this;
-      $.each(node, function(n) {
-        lab = that.getLabel(n.id);
-        if (lab) {
-          lab.style.display = st;
-        }
-      });
-    },
-
-    /*
-       fitsInCanvas
-
-       Returns _true_ or _false_ if the label for the node is contained in the canvas dom element or not.
-
-       Parameters:
-
-       pos - A <Complex> instance (I'm doing duck typing here so any object with _x_ and _y_ parameters will do).
-       canvas - A <Canvas> instance.
-
-       Returns:
-
-       A boolean value specifying if the label is contained in the <Canvas> DOM element or not.
-
-    */
-    fitsInCanvas: function(pos, canvas) {
-      var size = canvas.getSize();
-      if (pos.w && pos.h) {
-       if (pos.x >= size.width || pos.x < -pos.w
-         || pos.y >= size.height || pos.y < -pos.h) return false;              
-      }
-      else {
-       if (pos.x >= size.width || pos.x < 0
-         || pos.y >= size.height || pos.y < 0) return false;
-      }
-       return true;
-    }
-});
-
-/*
-   Class: Graph.Label.HTML
-
-   Implements HTML labels.
-
-   Extends:
-
-   All <Graph.Label.DOM> methods.
-
-*/
-MultiGraph.Label.HTML = new Class({
-    Implements: MultiGraph.Label.DOM,
-
-    /*
-       Method: plotLabel
-
-       Plots a label for a given node.
-
-       Parameters:
-
-       canvas - (object) A <Canvas> instance.
-       node - (object) A <Graph.Node>.
-       controller - (object) A configuration object.
-       
-      Example:
-       
-       (start code js)
-       var viz = new $jit.Viz(options);
-       var node = viz.graph.getNode('nodeId');
-       viz.labels.plotLabel(viz.canvas, node, viz.config);
-       (end code)
-
-
-    */
-    plotLabel: function(canvas, node, controller) {
-      var id = node.id, tag = this.getLabel(id);
-
-      if(!tag && !(tag = document.getElementById(id))) {
-        tag = document.createElement('div');
-        var container = this.getLabelContainer();
-        tag.id = id;
-        tag.className = 'node';
-        tag.style.position = 'absolute';
-        controller.onCreateLabel(tag, node);
-        container.appendChild(tag);
-        this.labels[node.id] = tag;
-      }
-
-      this.placeLabel(tag, node, controller);
-    }
-});
-
-/*
-   Class: Graph.Label.SVG
-
-   Implements SVG labels.
-
-   Extends:
-
-   All <Graph.Label.DOM> methods.
-*/
-MultiGraph.Label.SVG = new Class({
-    Implements: MultiGraph.Label.DOM,
-
-    /*
-       Method: plotLabel
-
-       Plots a label for a given node.
-
-       Parameters:
-
-       canvas - (object) A <Canvas> instance.
-       node - (object) A <Graph.Node>.
-       controller - (object) A configuration object.
-       
-       Example:
-       
-       (start code js)
-       var viz = new $jit.Viz(options);
-       var node = viz.graph.getNode('nodeId');
-       viz.labels.plotLabel(viz.canvas, node, viz.config);
-       (end code)
-
-
-    */
-    plotLabel: function(canvas, node, controller) {
-      var id = node.id, tag = this.getLabel(id);
-      if(!tag && !(tag = document.getElementById(id))) {
-        var ns = 'http://www.w3.org/2000/svg';
-          tag = document.createElementNS(ns, 'svg:text');
-        var tspan = document.createElementNS(ns, 'svg:tspan');
-        tag.appendChild(tspan);
-        var container = this.getLabelContainer();
-        tag.setAttribute('id', id);
-        tag.setAttribute('class', 'node');
-        container.appendChild(tag);
-        controller.onCreateLabel(tag, node);
-        this.labels[node.id] = tag;
-      }
-      this.placeLabel(tag, node, controller);
-    }
-});
-
-
-
-/*
- * File: MultiLoader.js
- * 
- */
-
-/*
-   Object: MultiLoader
-
-   Provides methods for loading and serving JSON data.
-*/
-var MultiLoader = {
-     construct: function(json) {
-        var ans = new MultiGraph(this.graphOptions, this.config.Node, this.config.Edge, this.config.Label);
-               //make graph
-               (function (ans, json) {
-                       var getNode = function(id) {
-                         for(var i=0, l=json.length; i<l; i++) {
-                               if(json[i].id == id) {
-                                 return json[i];
-                               }
-                         }
-                         // The node was not defined in the JSON
-                         // Let's create it
-                         var newNode = {
-                                       "id" : id,
-                                       "name" : id
-                               };
-                         return ans.addNode(newNode);
-                       };
-
-                       for(var i=0, l=json.length; i<l; i++) {
-                         ans.addNode(json[i]);
-                         var adj = json[i].adjacencies;
-                         if (adj) {
-                               for(var j=0, lj=adj.length; j<lj; j++) {
-                                 var node = adj[j], data = {};
-                                 data = $.merge(node.data, {});
-                                 node = node.nodeTo;
-                                 ans.addAdjacence(json[i], getNode(node), data);
-                               }
-                         }
-                       }
-               })(ans, json);
-
-        return ans;
-    },
-
-    /*
-     Method: loadJSON
-    
-     Loads a JSON structure to the visualization. The JSON structure can be a JSON *tree* or *graph* structure.
-     
-      A JSON tree or graph structure consists of nodes, each having as properties
-       
-       id - (string) A unique identifier for the node
-       name - (string) A node's name
-       data - (object) The data optional property contains a hash (i.e {}) 
-       where you can store all the information you want about this node.
-        
-      For JSON *Tree* structures, there's an extra optional property *children* of type Array which contains the node's children.
-      
-      Example:
-
-      (start code js)
-        var json = {  
-          "id": "aUniqueIdentifier",  
-          "name": "usually a nodes name",  
-          "data": {
-            "some key": "some value",
-            "some other key": "some other value"
-           },  
-          "children": [ *other nodes or empty* ]  
-        };  
-      (end code)
-        
-        JSON *Graph* structures consist of an array of nodes, each specifying the nodes to which the current node is connected. 
-        For JSON *Graph* structures, the *children* property is replaced by the *adjacencies* property.
-        
-        There are two types of *Graph* structures, *simple* and *extended* graph structures.
-        
-        For *simple* Graph structures, the adjacencies property contains an array of strings, each specifying the 
-        id of the node connected to the main node.
-        
-        Example:
-        
-        (start code js)
-        var json = [  
-          {  
-            "id": "aUniqueIdentifier",  
-            "name": "usually a nodes name",  
-            "data": {
-              "some key": "some value",
-              "some other key": "some other value"
-             },  
-            "adjacencies": ["anotherUniqueIdentifier", "yetAnotherUniqueIdentifier", 'etc']  
-          },
-
-          'other nodes go here...' 
-        ];          
-        (end code)
-        
-        For *extended Graph structures*, the adjacencies property contains an array of Adjacency objects that have as properties
-        
-        nodeTo - (string) The other node connected by this adjacency.
-        data - (object) A data property, where we can store custom key/value information.
-        
-        Example:
-        
-        (start code js)
-        var json = [  
-          {  
-            "id": "aUniqueIdentifier",  
-            "name": "usually a nodes name",  
-            "data": {
-              "some key": "some value",
-              "some other key": "some other value"
-             },  
-            "adjacencies": [  
-            {  
-              nodeTo:"aNodeId",  
-              data: {} //put whatever you want here  
-            },
-            'other adjacencies go here...'  
-          },
-
-          'other nodes go here...' 
-        ];          
-        (end code)
-       
-       About the data property:
-       
-       As described before, you can store custom data in the *data* property of JSON *nodes* and *adjacencies*. 
-       You can use almost any string as key for the data object. Some keys though are reserved by the toolkit, and 
-       have special meanings. This is the case for keys starting with a dollar sign, for example, *$width*.
-       
-       For JSON *node* objects, adding dollar prefixed properties that match the names of the options defined in 
-       <Options.Node> will override the general value for that option with that particular value. For this to work 
-       however, you do have to set *overridable = true* in <Options.Node>.
-       
-       The same thing is true for JSON adjacencies. Dollar prefixed data properties will alter values set in <Options.Edge> 
-       if <Options.Edge> has *overridable = true*.
-       
-       When loading JSON data into TreeMaps, the *data* property must contain a value for the *$area* key, 
-       since this is the value which will be taken into account when creating the layout. 
-       The same thing goes for the *$color* parameter.
-       
-       In JSON Nodes you can use also *$label-* prefixed properties to refer to <Options.Label> properties. For example, 
-       *$label-size* will refer to <Options.Label> size property. Also, in JSON nodes and adjacencies you can set 
-       canvas specific properties individually by using the *$canvas-* prefix. For example, *$canvas-shadowBlur* will refer 
-       to the *shadowBlur* property.
-       
-       These properties can also be accessed after loading the JSON data from <Graph.Nodes> and <Graph.Adjacences> 
-       by using <Accessors>. For more information take a look at the <Graph> and <Accessors> documentation.
-       
-       Finally, these properties can also be used to create advanced animations like with <Options.NodeStyles>. For more 
-       information about creating animations please take a look at the <Graph.Plot> and <Graph.Plot.animate> documentation.
-       
-       loadJSON Parameters:
-    
-        json - A JSON Tree or Graph structure.
-        i - For Graph structures only. Sets the indexed node as root for the visualization.
-
-    */
-    loadJSON: function(json, i) {
-      this.json = json;
-      //if they're canvas labels erase them.
-      if(this.labels && this.labels.clearLabels) {
-        this.labels.clearLabels(true);
-      }
-      this.graph = this.construct(json);
-      if($.type(json) != 'array'){
-        this.root = json.id;
-      } else {
-        this.root = json[i? i : 0].id;
-      }
-    },
-    
-    /*
-      Method: toJSON
-   
-      Returns a JSON tree/graph structure from the visualization's <Graph>. 
-      See <MultiLoader.loadJSON> for the graph formats available.
-      
-      See also:
-      
-      <MultiLoader.loadJSON>
-      
-      Parameters:
-      
-      type - (string) Default's "tree". The type of the JSON structure to be returned. 
-      Possible options are "tree" or "graph".
-    */    
-    toJSON: function(type) {
-      type = type || "tree";
-      if(type == 'tree') {
-        var ans = {};
-        var rootNode = this.graph.getNode(this.root);
-        var ans = (function recTree(node) {
-          var ans = {};
-          ans.id = node.id;
-          ans.name = node.name;
-          ans.data = node.data;
-          var ch =[];
-          node.eachSubnode(function(n) {
-            ch.push(recTree(n));
-          });
-          ans.children = ch;
-          return ans;
-        })(rootNode);
-        return ans;
-      } else {
-        var ans = [];
-        var T = !!this.graph.getNode(this.root).visited;
-        this.graph.eachNode(function(node) {
-          var ansNode = {};
-          ansNode.id = node.id;
-          ansNode.name = node.name;
-          ansNode.data = node.data;
-          var adjs = [];
-          node.eachAdjacency(function(adj) {
-            var nodeTo = adj.nodeTo;
-            if(!!nodeTo.visited === T) {
-              var ansAdj = {};
-              ansAdj.nodeTo = nodeTo.id;
-              ansAdj.data = adj.data;
-              adjs.push(ansAdj);
-            }
-          });
-          ansNode.adjacencies = adjs;
-          ans.push(ansNode);
-          node.visited = !T;
-        });
-        return ans;
-      }
-    }
-};
-
-
-
-/*
- * File: Graph.js
- *
-*/
-
-/*
- Class: Graph
-
- A Graph Class that provides useful manipulation functions. You can find more manipulation methods in the <Graph.Util> object.
-
- An instance of this class can be accessed by using the *graph* parameter of any tree or graph visualization.
- Example:
-
- (start code js)
-   //create new visualization
-   var viz = new $jit.Viz(options);
-   //load JSON data
-   viz.loadJSON(json);
-   //access model
-   viz.graph; //<Graph> instance
- (end code)
- Implements:
- The following <Graph.Util> methods are implemented in <Graph>
-  - <Graph.Util.getNode>
-  - <Graph.Util.eachNode>
-  - <Graph.Util.computeLevels>
-  - <Graph.Util.eachBFS>
-  - <Graph.Util.clean>
-  - <Graph.Util.getClosestNodeToPos>
-  - <Graph.Util.getClosestNodeToOrigin>
-*/  
-
-$jit.Graph = new Class({
-
-  initialize: function(opt, Node, Edge, Label) {
-    var innerOptions = {
-    'klass': Complex,
-    'Node': {}
-    };
-    this.Node = Node;
-    this.Edge = Edge;
-    this.Label = Label;
-    this.opt = $.merge(innerOptions, opt || {});
-    this.nodes = {};
-    this.edges = {};
-    
-    //add nodeList methods
-    var that = this;
-    this.nodeList = {};
-    for(var p in Accessors) {
-      that.nodeList[p] = (function(p) {
-        return function() {
-          var args = Array.prototype.slice.call(arguments);
-          that.eachNode(function(n) {
-            n[p].apply(n, args);
-          });
-        };
-      })(p);
-    }
-
- },
-
-/*
-     Method: getNode
-    
-     Returns a <Graph.Node> by *id*.
-
-     Parameters:
-
-     id - (string) A <Graph.Node> id.
-
-     Example:
-
-     (start code js)
-       var node = graph.getNode('nodeId');
-     (end code)
-*/  
- getNode: function(id) {
-    if(this.hasNode(id)) return this.nodes[id];
-    return false;
- },
-
- /*
-     Method: get
-    
-     An alias for <Graph.Util.getNode>. Returns a node by *id*.
-    
-     Parameters:
-    
-     id - (string) A <Graph.Node> id.
-    
-     Example:
-    
-     (start code js)
-       var node = graph.get('nodeId');
-     (end code)
-*/  
-  get: function(id) {
-    return this.getNode(id);
-  },
-
- /*
-   Method: getByName
-  
-   Returns a <Graph.Node> by *name*.
-  
-   Parameters:
-  
-   name - (string) A <Graph.Node> name.
-  
-   Example:
-  
-   (start code js)
-     var node = graph.getByName('someName');
-   (end code)
-  */  
-  getByName: function(name) {
-    for(var id in this.nodes) {
-      var n = this.nodes[id];
-      if(n.name == name) return n;
-    }
-    return false;
-  },
-
-/*
-   Method: getAdjacence
-  
-   Returns a <Graph.Adjacence> object connecting nodes with ids *id* and *id2*.
-
-   Parameters:
-
-   id - (string) A <Graph.Node> id.
-   id2 - (string) A <Graph.Node> id.
-*/  
-  getAdjacence: function (id, id2) {
-    if(id in this.edges) {
-      return this.edges[id][id2];
-    }
-    return false;
- },
-
-    /*
-     Method: addNode
-    
-     Adds a node.
-     
-     Parameters:
-    
-      obj - An object with the properties described below
-
-      id - (string) A node id
-      name - (string) A node's name
-      data - (object) A node's data hash
-
-    See also:
-    <Graph.Node>
-
-  */  
-  addNode: function(obj) { 
-   if(!this.nodes[obj.id]) {  
-     var edges = this.edges[obj.id] = {};
-     this.nodes[obj.id] = new Graph.Node($.extend({
-        'id': obj.id,
-        'name': obj.name,
-        'data': $.merge(obj.data || {}, {}),
-        'adjacencies': edges 
-      }, this.opt.Node), 
-      this.opt.klass, 
-      this.Node, 
-      this.Edge,
-      this.Label);
-    }
-    return this.nodes[obj.id];
-  },
-  
-    /*
-     Method: addAdjacence
-    
-     Connects nodes specified by *obj* and *obj2*. If not found, nodes are created.
-     
-     Parameters:
-    
-      obj - (object) A <Graph.Node> object.
-      obj2 - (object) Another <Graph.Node> object.
-      data - (object) A data object. Used to store some extra information in the <Graph.Adjacence> object created.
-
-    See also:
-
-    <Graph.Node>, <Graph.Adjacence>
-    */  
-  addAdjacence: function (obj, obj2, data) {
-    if(!this.hasNode(obj.id)) { this.addNode(obj); }
-    if(!this.hasNode(obj2.id)) { this.addNode(obj2); }
-    obj = this.nodes[obj.id]; obj2 = this.nodes[obj2.id];
-    if(!obj.adjacentTo(obj2)) {
-      var adjsObj = this.edges[obj.id] = this.edges[obj.id] || {};
-      var adjsObj2 = this.edges[obj2.id] = this.edges[obj2.id] || {};
-      adjsObj[obj2.id] = adjsObj2[obj.id] = new Graph.Adjacence(obj, obj2, data, this.Edge, this.Label);
-      return adjsObj[obj2.id];
-    }
-    return this.edges[obj.id][obj2.id];
- },
-
-    /*
-     Method: removeNode
-    
-     Removes a <Graph.Node> matching the specified *id*.
-
-     Parameters:
-
-     id - (string) A node's id.
-
-    */  
-  removeNode: function(id) {
-    if(this.hasNode(id)) {
-      delete this.nodes[id];
-      var adjs = this.edges[id];
-      for(var to in adjs) {
-        delete this.edges[to][id];
-      }
-      delete this.edges[id];
-    }
-  },
-  
-/*
-     Method: removeAdjacence
-    
-     Removes a <Graph.Adjacence> matching *id1* and *id2*.
-
-     Parameters:
-
-     id1 - (string) A <Graph.Node> id.
-     id2 - (string) A <Graph.Node> id.
-*/  
-  removeAdjacence: function(id1, id2) {
-    delete this.edges[id1][id2];
-    delete this.edges[id2][id1];
-  },
-
-   /*
-     Method: hasNode
-    
-     Returns a boolean indicating if the node belongs to the <Graph> or not.
-     
-     Parameters:
-    
-        id - (string) Node id.
-   */  
-  hasNode: function(id) {
-    return id in this.nodes;
-  },
-  
-  /*
-    Method: empty
-
-    Empties the Graph
-
-  */
-  empty: function() { this.nodes = {}; this.edges = {};}
-
-});
-
-var Graph = $jit.Graph;
-
-/*
- Object: Accessors
- Defines a set of methods for data, canvas and label styles manipulation implemented by <Graph.Node> and <Graph.Adjacence> instances.
- */
-var Accessors;
-
-(function () {
-  var getDataInternal = function(prefix, prop, type, force, prefixConfig) {
-    var data;
-    type = type || 'current';
-    prefix = "$" + (prefix ? prefix + "-" : "");
-
-    if(type == 'current') {
-      data = this.data;
-    } else if(type == 'start') {
-      data = this.startData;
-    } else if(type == 'end') {
-      data = this.endData;
-    }
-
-    var dollar = prefix + prop;
-
-    if(force) {
-      return data[dollar];
-    }
-
-    if(!this.Config.overridable)
-      return prefixConfig[prop] || 0;
-
-    return (dollar in data) ?
-      data[dollar] : ((dollar in this.data) ? this.data[dollar] : (prefixConfig[prop] || 0));
-  }
-
-  var setDataInternal = function(prefix, prop, value, type) {
-    type = type || 'current';
-    prefix = '$' + (prefix ? prefix + '-' : '');
-
-    var data;
-
-    if(type == 'current') {
-      data = this.data;
-    } else if(type == 'start') {
-      data = this.startData;
-    } else if(type == 'end') {
-      data = this.endData;
-    }
-
-    data[prefix + prop] = value;
-  }
-
-  var removeDataInternal = function(prefix, properties) {
-    prefix = '$' + (prefix ? prefix + '-' : '');
-    var that = this;
-    $.each(properties, function(prop) {
-      var pref = prefix + prop;
-      delete that.data[pref];
-      delete that.endData[pref];
-      delete that.startData[pref];
-    });
-  }
-
-  Accessors = {
-    /*
-    Method: getData
-
-    Returns the specified data value property.
-    This is useful for querying special/reserved <Graph.Node> data properties
-    (i.e dollar prefixed properties).
-
-    Parameters:
-
-      prop  - (string) The name of the property. The dollar sign is not needed. For
-              example *getData(width)* will return *data.$width*.
-      type  - (string) The type of the data property queried. Default's "current". You can access *start* and *end* 
-              data properties also. These properties are used when making animations.
-      force - (boolean) Whether to obtain the true value of the property (equivalent to
-              *data.$prop*) or to check for *node.overridable = true* first.
-
-    Returns:
-
-      The value of the dollar prefixed property or the global Node/Edge property
-      value if *overridable=false*
-
-    Example:
-    (start code js)
-     node.getData('width'); //will return node.data.$width if Node.overridable=true;
-    (end code)
-    */
-    getData: function(prop, type, force) {
-      return getDataInternal.call(this, "", prop, type, force, this.Config);
-    },
-
-
-    /*
-    Method: setData
-
-    Sets the current data property with some specific value.
-    This method is only useful for reserved (dollar prefixed) properties.
-
-    Parameters:
-
-      prop  - (string) The name of the property. The dollar sign is not necessary. For
-              example *setData(width)* will set *data.$width*.
-      value - (mixed) The value to store.
-      type  - (string) The type of the data property to store. Default's "current" but
-              can also be "start" or "end".
-
-    Example:
-    
-    (start code js)
-     node.setData('width', 30);
-    (end code)
-    
-    If we were to make an animation of a node/edge width then we could do
-    
-    (start code js)
-      var node = viz.getNode('nodeId');
-      //set start and end values
-      node.setData('width', 10, 'start');
-      node.setData('width', 30, 'end');
-      //will animate nodes width property
-      viz.fx.animate({
-        modes: ['node-property:width'],
-        duration: 1000
-      });
-    (end code)
-    */
-    setData: function(prop, value, type) {
-      setDataInternal.call(this, "", prop, value, type);
-    },
-
-    /*
-    Method: setDataset
-
-    Convenience method to set multiple data values at once.
-    
-    Parameters:
-    
-    types - (array|string) A set of 'current', 'end' or 'start' values.
-    obj - (object) A hash containing the names and values of the properties to be altered.
-
-    Example:
-    (start code js)
-      node.setDataset(['current', 'end'], {
-        'width': [100, 5],
-        'color': ['#fff', '#ccc']
-      });
-      //...or also
-      node.setDataset('end', {
-        'width': 5,
-        'color': '#ccc'
-      });
-    (end code)
-    
-    See also: 
-    
-    <Accessors.setData>
-    
-    */
-    setDataset: function(types, obj) {
-      types = $.splat(types);
-      for(var attr in obj) {
-        for(var i=0, val = $.splat(obj[attr]), l=types.length; i<l; i++) {
-          this.setData(attr, val[i], types[i]);
-        }
-      }
-    },
-    
-    /*
-    Method: removeData
-
-    Remove data properties.
-
-    Parameters:
-
-    One or more property names as arguments. The dollar sign is not needed.
-
-    Example:
-    (start code js)
-    node.removeData('width'); //now the default width value is returned
-    (end code)
-    */
-    removeData: function() {
-      removeDataInternal.call(this, "", Array.prototype.slice.call(arguments));
-    },
-
-    /*
-    Method: getCanvasStyle
-
-    Returns the specified canvas style data value property. This is useful for
-    querying special/reserved <Graph.Node> canvas style data properties (i.e.
-    dollar prefixed properties that match with $canvas-<name of canvas style>).
-
-    Parameters:
-
-      prop  - (string) The name of the property. The dollar sign is not needed. For
-              example *getCanvasStyle(shadowBlur)* will return *data[$canvas-shadowBlur]*.
-      type  - (string) The type of the data property queried. Default's *current*. You can access *start* and *end* 
-              data properties also.
-              
-    Example:
-    (start code js)
-      node.getCanvasStyle('shadowBlur');
-    (end code)
-    
-    See also:
-    
-    <Accessors.getData>
-    */
-    getCanvasStyle: function(prop, type, force) {
-      return getDataInternal.call(
-          this, 'canvas', prop, type, force, this.Config.CanvasStyles);
-    },
-
-    /*
-    Method: setCanvasStyle
-
-    Sets the canvas style data property with some specific value.
-    This method is only useful for reserved (dollar prefixed) properties.
-    
-    Parameters:
-    
-    prop - (string) Name of the property. Can be any canvas property like 'shadowBlur', 'shadowColor', 'strokeStyle', etc.
-    value - (mixed) The value to set to the property.
-    type - (string) Default's *current*. Whether to set *start*, *current* or *end* type properties.
-    
-    Example:
-    
-    (start code js)
-     node.setCanvasStyle('shadowBlur', 30);
-    (end code)
-    
-    If we were to make an animation of a node/edge shadowBlur canvas style then we could do
-    
-    (start code js)
-      var node = viz.getNode('nodeId');
-      //set start and end values
-      node.setCanvasStyle('shadowBlur', 10, 'start');
-      node.setCanvasStyle('shadowBlur', 30, 'end');
-      //will animate nodes canvas style property for nodes
-      viz.fx.animate({
-        modes: ['node-style:shadowBlur'],
-        duration: 1000
-      });
-    (end code)
-    
-    See also:
-    
-    <Accessors.setData>.
-    */
-    setCanvasStyle: function(prop, value, type) {
-      setDataInternal.call(this, 'canvas', prop, value, type);
-    },
-
-    /*
-    Method: setCanvasStyles
-
-    Convenience method to set multiple styles at once.
-
-    Parameters:
-    
-    types - (array|string) A set of 'current', 'end' or 'start' values.
-    obj - (object) A hash containing the names and values of the properties to be altered.
-
-    See also:
-    
-    <Accessors.setDataset>.
-    */
-    setCanvasStyles: function(types, obj) {
-      types = $.splat(types);
-      for(var attr in obj) {
-        for(var i=0, val = $.splat(obj[attr]), l=types.length; i<l; i++) {
-          this.setCanvasStyle(attr, val[i], types[i]);
-        }
-      }
-    },
-
-    /*
-    Method: removeCanvasStyle
-
-    Remove canvas style properties from data.
-
-    Parameters:
-    
-    A variable number of canvas style strings.
-
-    See also:
-    
-    <Accessors.removeData>.
-    */
-    removeCanvasStyle: function() {
-      removeDataInternal.call(this, 'canvas', Array.prototype.slice.call(arguments));
-    },
-
-    /*
-    Method: getLabelData
-
-    Returns the specified label data value property. This is useful for
-    querying special/reserved <Graph.Node> label options (i.e.
-    dollar prefixed properties that match with $label-<name of label style>).
-
-    Parameters:
-
-      prop  - (string) The name of the property. The dollar sign prefix is not needed. For
-              example *getLabelData(size)* will return *data[$label-size]*.
-      type  - (string) The type of the data property queried. Default's *current*. You can access *start* and *end* 
-              data properties also.
-              
-    See also:
-    
-    <Accessors.getData>.
-    */
-    getLabelData: function(prop, type, force) {
-      return getDataInternal.call(
-          this, 'label', prop, type, force, this.Label);
-    },
-
-    /*
-    Method: setLabelData
-
-    Sets the current label data with some specific value.
-    This method is only useful for reserved (dollar prefixed) properties.
-
-    Parameters:
-    
-    prop - (string) Name of the property. Can be any canvas property like 'shadowBlur', 'shadowColor', 'strokeStyle', etc.
-    value - (mixed) The value to set to the property.
-    type - (string) Default's *current*. Whether to set *start*, *current* or *end* type properties.
-    
-    Example:
-    
-    (start code js)
-     node.setLabelData('size', 30);
-    (end code)
-    
-    If we were to make an animation of a node label size then we could do
-    
-    (start code js)
-      var node = viz.getNode('nodeId');
-      //set start and end values
-      node.setLabelData('size', 10, 'start');
-      node.setLabelData('size', 30, 'end');
-      //will animate nodes label size
-      viz.fx.animate({
-        modes: ['label-property:size'],
-        duration: 1000
-      });
-    (end code)
-    
-    See also:
-    
-    <Accessors.setData>.
-    */
-    setLabelData: function(prop, value, type) {
-      setDataInternal.call(this, 'label', prop, value, type);
-    },
-
-    /*
-    Method: setLabelDataset
-
-    Convenience function to set multiple label data at once.
-
-    Parameters:
-    
-    types - (array|string) A set of 'current', 'end' or 'start' values.
-    obj - (object) A hash containing the names and values of the properties to be altered.
-
-    See also:
-    
-    <Accessors.setDataset>.
-    */
-    setLabelDataset: function(types, obj) {
-      types = $.splat(types);
-      for(var attr in obj) {
-        for(var i=0, val = $.splat(obj[attr]), l=types.length; i<l; i++) {
-          this.setLabelData(attr, val[i], types[i]);
-        }
-      }
-    },
-
-    /*
-    Method: removeLabelData
-
-    Remove label properties from data.
-    
-    Parameters:
-    
-    A variable number of label property strings.
-
-    See also:
-    
-    <Accessors.removeData>.
-    */
-    removeLabelData: function() {
-      removeDataInternal.call(this, 'label', Array.prototype.slice.call(arguments));
-    }
-  };
-})();
-
-/*
-     Class: Graph.Node
-
-     A <Graph> node.
-     
-     Implements:
-     
-     <Accessors> methods.
-     
-     The following <Graph.Util> methods are implemented by <Graph.Node>
-     
-    - <Graph.Util.eachAdjacency>
-    - <Graph.Util.eachLevel>
-    - <Graph.Util.eachSubgraph>
-    - <Graph.Util.eachSubnode>
-    - <Graph.Util.anySubnode>
-    - <Graph.Util.getSubnodes>
-    - <Graph.Util.getParents>
-    - <Graph.Util.isDescendantOf>     
-*/
-Graph.Node = new Class({
-    
-  initialize: function(opt, klass, Node, Edge, Label) {
-    var innerOptions = {
-      'id': '',
-      'name': '',
-      'data': {},
-      'startData': {},
-      'endData': {},
-      'adjacencies': {},
-
-      'selected': false,
-      'drawn': false,
-      'exist': false,
-
-      'angleSpan': {
-        'begin': 0,
-        'end' : 0
-      },
-
-      'pos': new klass,
-      'startPos': new klass,
-      'endPos': new klass
-    };
-    
-    $.extend(this, $.extend(innerOptions, opt));
-    this.Config = this.Node = Node;
-    this.Edge = Edge;
-    this.Label = Label;
-  },
-
-    /*
-       Method: adjacentTo
-    
-       Indicates if the node is adjacent to the node specified by id
-
-       Parameters:
-    
-          id - (string) A node id.
-    
-       Example:
-       (start code js)
-        node.adjacentTo('nodeId') == true;
-       (end code)
-    */
-    adjacentTo: function(node) {
-        return node.id in this.adjacencies;
-    },
-
-    /*
-     Method: adjacentWithDirectionTo
-
-     Indicates if the node has a directed edge to the node specified by id
-
-     Parameters:
-
-     id - (string) A node id.
-
-     Example:
-     (start code js)
-     node.adjacentWithDirectionTo('nodeId') == true;
-     (end code)
-     */
-    adjacentWithDirectionTo: function(node) {
-        var areNeighbors = node.id in this.adjacencies;
-        if (!areNeighbors) {
-            return false;
-        }
-
-        var direction = this.adjacencies[node.id].data.$direction;
-        return direction[0] === this.id ;
-    },
-
-    /*
-       Method: getAdjacency
-    
-       Returns a <Graph.Adjacence> object connecting the current <Graph.Node> and the node having *id* as id.
-
-       Parameters:
-    
-          id - (string) A node id.
-    */  
-    getAdjacency: function(id) {
-        return this.adjacencies[id];
-    },
-
-    /*
-      Method: getPos
-   
-      Returns the position of the node.
-  
-      Parameters:
-   
-         type - (string) Default's *current*. Possible values are "start", "end" or "current".
-   
-      Returns:
-   
-        A <Complex> or <Polar> instance.
-  
-      Example:
-      (start code js)
-       var pos = node.getPos('end');
-      (end code)
-   */
-   getPos: function(type) {
-       type = type || "current";
-       if(type == "current") {
-         return this.pos;
-       } else if(type == "end") {
-         return this.endPos;
-       } else if(type == "start") {
-         return this.startPos;
-       }
-   },
-   /*
-     Method: setPos
-  
-     Sets the node's position.
-  
-     Parameters:
-  
-        value - (object) A <Complex> or <Polar> instance.
-        type - (string) Default's *current*. Possible values are "start", "end" or "current".
-  
-     Example:
-     (start code js)
-      node.setPos(new $jit.Complex(0, 0), 'end');
-     (end code)
-  */
-  setPos: function(value, type) {
-      type = type || "current";
-      var pos;
-      if(type == "current") {
-        pos = this.pos;
-      } else if(type == "end") {
-        pos = this.endPos;
-      } else if(type == "start") {
-        pos = this.startPos;
-      }
-      pos.set(value);
-  }
-});
-
-Graph.Node.implement(Accessors);
-
-/*
-     Class: Graph.Adjacence
-
-     A <Graph> adjacence (or edge) connecting two <Graph.Nodes>.
-     
-     Implements:
-     
-     <Accessors> methods.
-
-     See also:
-
-     <Graph>, <Graph.Node>
-
-     Properties:
-     
-      nodeFrom - A <Graph.Node> connected by this edge.
-      nodeTo - Another  <Graph.Node> connected by this edge.
-      data - Node data property containing a hash (i.e {}) with custom options.
-*/
-Graph.Adjacence = new Class({
-  
-  initialize: function(nodeFrom, nodeTo, data, Edge, Label) {
-    this.nodeFrom = nodeFrom;
-    this.nodeTo = nodeTo;
-    this.data = data || {};
-    this.startData = {};
-    this.endData = {};
-    this.Config = this.Edge = Edge;
-    this.Label = Label;
-  }
-});
-
-Graph.Adjacence.implement(Accessors);
-
-/*
-   Object: Graph.Util
-
-   <Graph> traversal and processing utility object.
-   
-   Note:
-   
-   For your convenience some of these methods have also been appended to <Graph> and <Graph.Node> classes.
-*/
-Graph.Util = {
-    /*
-       filter
-    
-       For internal use only. Provides a filtering function based on flags.
-    */
-    filter: function(param) {
-        if(!param || !($.type(param) == 'string')) return function() { return true; };
-        var props = param.split(" ");
-        return function(elem) {
-            for(var i=0; i<props.length; i++) { 
-              if(elem[props[i]]) { 
-                return false; 
-              }
-            }
-            return true;
-        };
-    },
-    /*
-       Method: getNode
-    
-       Returns a <Graph.Node> by *id*.
-       
-       Also implemented by:
-       
-       <Graph>
-
-       Parameters:
-
-       graph - (object) A <Graph> instance.
-       id - (string) A <Graph.Node> id.
-
-       Example:
-
-       (start code js)
-         $jit.Graph.Util.getNode(graph, 'nodeid');
-         //or...
-         graph.getNode('nodeid');
-       (end code)
-    */
-    getNode: function(graph, id) {
-        return graph.nodes[id];
-    },
-    
-    /*
-       Method: eachNode
-    
-       Iterates over <Graph> nodes performing an *action*.
-       
-       Also implemented by:
-       
-       <Graph>.
-
-       Parameters:
-
-       graph - (object) A <Graph> instance.
-       action - (function) A callback function having a <Graph.Node> as first formal parameter.
-
-       Example:
-       (start code js)
-         $jit.Graph.Util.eachNode(graph, function(node) {
-          alert(node.name);
-         });
-         //or...
-         graph.eachNode(function(node) {
-           alert(node.name);
-         });
-       (end code)
-    */
-    eachNode: function(graph, action, flags) {
-        var filter = this.filter(flags);
-        for(var i in graph.nodes) {
-          if(filter(graph.nodes[i])) action(graph.nodes[i]);
-        } 
-    },
-    
-    /*
-      Method: each
-   
-      Iterates over <Graph> nodes performing an *action*. It's an alias for <Graph.Util.eachNode>.
-      
-      Also implemented by:
-      
-      <Graph>.
-  
-      Parameters:
-  
-      graph - (object) A <Graph> instance.
-      action - (function) A callback function having a <Graph.Node> as first formal parameter.
-  
-      Example:
-      (start code js)
-        $jit.Graph.Util.each(graph, function(node) {
-         alert(node.name);
-        });
-        //or...
-        graph.each(function(node) {
-          alert(node.name);
-        });
-      (end code)
-   */
-   each: function(graph, action, flags) {
-      this.eachNode(graph, action, flags); 
-   },
-
- /*
-       Method: eachAdjacency
-    
-       Iterates over <Graph.Node> adjacencies applying the *action* function.
-       
-       Also implemented by:
-       
-       <Graph.Node>.
-
-       Parameters:
-
-       node - (object) A <Graph.Node>.
-       action - (function) A callback function having <Graph.Adjacence> as first formal parameter.
-
-       Example:
-       (start code js)
-         $jit.Graph.Util.eachAdjacency(node, function(adj) {
-          alert(adj.nodeTo.name);
-         });
-         //or...
-         node.eachAdjacency(function(adj) {
-           alert(adj.nodeTo.name);
-         });
-       (end code)
-    */
-    eachAdjacency: function(node, action, flags) {
-        var adj = node.adjacencies, filter = this.filter(flags);
-        for(var id in adj) {
-          var a = adj[id];
-          if(filter(a)) {
-            if(a.nodeFrom != node) {
-              var tmp = a.nodeFrom;
-              a.nodeFrom = a.nodeTo;
-              a.nodeTo = tmp;
-            }
-            action(a, id);
-          }
-        }
-    },
-
-     /*
-       Method: computeLevels
-    
-       Performs a BFS traversal setting the correct depth for each node.
-        
-       Also implemented by:
-       
-       <Graph>.
-       
-       Note:
-       
-       The depth of each node can then be accessed by 
-       >node._depth
-
-       Parameters:
-
-       graph - (object) A <Graph>.
-       id - (string) A starting node id for the BFS traversal.
-       startDepth - (optional|number) A minimum depth value. Default's 0.
-
-    */
-    computeLevels: function(graph, id, startDepth, flags) {
-        startDepth = startDepth || 0;
-        var filter = this.filter(flags);
-        this.eachNode(graph, function(elem) {
-            elem._flag = false;
-            elem._depth = -1;
-        }, flags);
-        var root = graph.getNode(id);
-        root._depth = startDepth;
-        var queue = [root];
-        while(queue.length != 0) {
-            var node = queue.pop();
-            node._flag = true;
-            this.eachAdjacency(node, function(adj) {
-                var n = adj.nodeTo;
-                if(n._flag == false && filter(n) && !adj._hiding) {
-                    if(n._depth < 0) n._depth = node._depth + 1 + startDepth;
-                    queue.unshift(n);
-                }
-            }, flags);
-        }
-    },
-
-    /*
-       Method: eachBFS
-    
-       Performs a BFS traversal applying *action* to each <Graph.Node>.
-       
-       Also implemented by:
-       
-       <Graph>.
-
-       Parameters:
-
-       graph - (object) A <Graph>.
-       id - (string) A starting node id for the BFS traversal.
-       action - (function) A callback function having a <Graph.Node> as first formal parameter.
-
-       Example:
-       (start code js)
-         $jit.Graph.Util.eachBFS(graph, 'mynodeid', function(node) {
-          alert(node.name);
-         });
-         //or...
-         graph.eachBFS('mynodeid', function(node) {
-           alert(node.name);
-         });
-       (end code)
-    */
-    eachBFS: function(graph, id, action, flags) {
-        var filter = this.filter(flags);
-        this.clean(graph);
-        var queue = [graph.getNode(id)];
-        while(queue.length != 0) {
-            var node = queue.pop();
-            if (!node) return;
-            node._flag = true;
-            action(node, node._depth);
-            this.eachAdjacency(node, function(adj) {
-                var n = adj.nodeTo;
-                if(n._flag == false && filter(n) && !adj._hiding) {
-                    n._flag = true;
-                    queue.unshift(n);
-                }
-            }, flags);
-        }
-    },
-    
-    /*
-       Method: eachLevel
-    
-       Iterates over a node's subgraph applying *action* to the nodes of relative depth between *levelBegin* and *levelEnd*.
-       In case you need to break the iteration, *action* should return false.
-       
-       Also implemented by:
-       
-       <Graph.Node>.
-
-       Parameters:
-       
-       node - (object) A <Graph.Node>.
-       levelBegin - (number) A relative level value.
-       levelEnd - (number) A relative level value.
-       action - (function) A callback function having a <Graph.Node> as first formal parameter.
-
-    */
-    eachLevel: function(node, levelBegin, levelEnd, action, flags) {
-        var d = node._depth, filter = this.filter(flags), that = this, shouldContinue = true;
-        levelEnd = levelEnd === false? Number.MAX_VALUE -d : levelEnd;
-        (function loopLevel(node, levelBegin, levelEnd) {
-            if(!shouldContinue) return;
-            var d = node._depth, ret;
-            if(d >= levelBegin && d <= levelEnd && filter(node)) ret = action(node, d);
-            if(typeof ret !== "undefined") shouldContinue = ret;
-            if(shouldContinue && d < levelEnd) {
-                that.eachAdjacency(node, function(adj) {
-                    var n = adj.nodeTo;
-                    if(n._depth > d) loopLevel(n, levelBegin, levelEnd);
-                });
-            }
-        })(node, levelBegin + d, levelEnd + d);
-    },
-
-    /*
-       Method: eachSubgraph
-    
-       Iterates over a node's children recursively.
-       
-       Also implemented by:
-       
-       <Graph.Node>.
-
-       Parameters:
-       node - (object) A <Graph.Node>.
-       action - (function) A callback function having a <Graph.Node> as first formal parameter.
-
-       Example:
-       (start code js)
-         $jit.Graph.Util.eachSubgraph(node, function(node) {
-           alert(node.name);
-         });
-         //or...
-         node.eachSubgraph(function(node) {
-           alert(node.name);
-         });
-       (end code)
-    */
-    eachSubgraph: function(node, action, flags) {
-      this.eachLevel(node, 0, false, action, flags);
-    },
-
-    /*
-       Method: eachSubnode
-    
-       Iterates over a node's children (without deeper recursion).
-       
-       Also implemented by:
-       
-       <Graph.Node>.
-       
-       Parameters:
-       node - (object) A <Graph.Node>.
-       action - (function) A callback function having a <Graph.Node> as first formal parameter.
-
-       Example:
-       (start code js)
-         $jit.Graph.Util.eachSubnode(node, function(node) {
-          alert(node.name);
-         });
-         //or...
-         node.eachSubnode(function(node) {
-           alert(node.name);
-         });
-       (end code)
-    */
-    eachSubnode: function(node, action, flags) {
-        this.eachLevel(node, 1, 1, action, flags);
-    },
-
-    /*
-       Method: anySubnode
-    
-       Returns *true* if any subnode matches the given condition.
-       
-       Also implemented by:
-       
-       <Graph.Node>.
-
-       Parameters:
-       node - (object) A <Graph.Node>.
-       cond - (function) A callback function returning a Boolean instance. This function has as first formal parameter a <Graph.Node>.
-
-       Example:
-       (start code js)
-         $jit.Graph.Util.anySubnode(node, function(node) { return node.name == "mynodename"; });
-         //or...
-         node.anySubnode(function(node) { return node.name == 'mynodename'; });
-       (end code)
-    */
-    anySubnode: function(node, cond, flags) {
-      var flag = false;
-      cond = cond || $.lambda(true);
-      var c = $.type(cond) == 'string'? function(n) { return n[cond]; } : cond;
-      this.eachSubnode(node, function(elem) {
-        if(c(elem)) flag = true;
-      }, flags);
-      return flag;
-    },
-  
-    /*
-       Method: getSubnodes
-    
-       Collects all subnodes for a specified node. 
-       The *level* parameter filters nodes having relative depth of *level* from the root node. 
-       
-       Also implemented by:
-       
-       <Graph.Node>.
-
-       Parameters:
-       node - (object) A <Graph.Node>.
-       level - (optional|number) Default's *0*. A starting relative depth for collecting nodes.
-
-       Returns:
-       An array of nodes.
-
-    */
-    getSubnodes: function(node, level, flags) {
-        var ans = [], that = this;
-        level = level || 0;
-        var levelStart, levelEnd;
-        if($.type(level) == 'array') {
-            levelStart = level[0];
-            levelEnd = level[1];
-        } else {
-            levelStart = level;
-            levelEnd = Number.MAX_VALUE - node._depth;
-        }
-        this.eachLevel(node, levelStart, levelEnd, function(n) {
-            ans.push(n);
-        }, flags);
-        return ans;
-    },
-  
-  
-    /*
-       Method: getParents
-    
-       Returns an Array of <Graph.Nodes> which are parents of the given node.
-       
-       Also implemented by:
-       
-       <Graph.Node>.
-
-       Parameters:
-       node - (object) A <Graph.Node>.
-
-       Returns:
-       An Array of <Graph.Nodes>.
-
-       Example:
-       (start code js)
-         var pars = $jit.Graph.Util.getParents(node);
-         //or...
-         var pars = node.getParents();
-         
-         if(pars.length > 0) {
-           //do stuff with parents
-         }
-       (end code)
-    */
-    getParents: function(node) {
-        var ans = [];
-        this.eachAdjacency(node, function(adj) {
-            var n = adj.nodeTo;
-            if(n._depth < node._depth) ans.push(n);
-        });
-        return ans;
-    },
-    
-    /*
-    Method: isDescendantOf
-    Returns a boolean indicating if some node is descendant of the node with the given id. 
-
-    Also implemented by:
-    
-    <Graph.Node>.
-    
-    
-    Parameters:
-    node - (object) A <Graph.Node>.
-    id - (string) A <Graph.Node> id.
-
-    Example:
-    (start code js)
-      $jit.Graph.Util.isDescendantOf(node, "nodeid"); //true|false
-      //or...
-      node.isDescendantOf('nodeid');//true|false
-    (end code)
- */
- isDescendantOf: function(node, id) {
-    if(node.id == id) return true;
-    var pars = this.getParents(node), ans = false;
-    for ( var i = 0; !ans && i < pars.length; i++) {
-    ans = ans || this.isDescendantOf(pars[i], id);
-  }
-    return ans;
- },
-
- /*
-     Method: clean
-  
-     Cleans flags from nodes.
-
-     Also implemented by:
-     
-     <Graph>.
-     
-     Parameters:
-     graph - A <Graph> instance.
-  */
-  clean: function(graph) { this.eachNode(graph, function(elem) { elem._flag = false; }); },
-  
-  /* 
-    Method: getClosestNodeToOrigin 
-  
-    Returns the closest node to the center of canvas.
-  
-    Also implemented by:
-    
-    <Graph>.
-    
-    Parameters:
-   
-     graph - (object) A <Graph> instance.
-     prop - (optional|string) Default's 'current'. A <Graph.Node> position property. Possible properties are 'start', 'current' or 'end'.
-  
-  */
-  getClosestNodeToOrigin: function(graph, prop, flags) {
-   return this.getClosestNodeToPos(graph, Polar.KER, prop, flags);
-  },
-  
-  /* 
-    Method: getClosestNodeToPos
-  
-    Returns the closest node to the given position.
-  
-    Also implemented by:
-    
-    <Graph>.
-    
-    Parameters:
-   
-     graph - (object) A <Graph> instance.
-     pos - (object) A <Complex> or <Polar> instance.
-     prop - (optional|string) Default's *current*. A <Graph.Node> position property. Possible properties are 'start', 'current' or 'end'.
-  
-  */
-  getClosestNodeToPos: function(graph, pos, prop, flags) {
-   var node = null;
-   prop = prop || 'current';
-   pos = pos && pos.getc(true) || Complex.KER;
-   var distance = function(a, b) {
-     var d1 = a.x - b.x, d2 = a.y - b.y;
-     return d1 * d1 + d2 * d2;
-   };
-   this.eachNode(graph, function(elem) {
-     node = (node == null || distance(elem.getPos(prop).getc(true), pos) < distance(
-         node.getPos(prop).getc(true), pos)) ? elem : node;
-   }, flags);
-   return node;
-  } 
-};
-
-//Append graph methods to <Graph>
-$.each(['get', 'getNode', 'each', 'eachNode', 'computeLevels', 'eachBFS', 'clean', 'getClosestNodeToPos', 'getClosestNodeToOrigin'], function(m) {
-  Graph.prototype[m] = function() {
-    return Graph.Util[m].apply(Graph.Util, [this].concat(Array.prototype.slice.call(arguments)));
-  };
-});
-
-//Append node methods to <Graph.Node>
-$.each(['eachAdjacency', 'eachLevel', 'eachSubgraph', 'eachSubnode', 'anySubnode', 'getSubnodes', 'getParents', 'isDescendantOf'], function(m) {
-  Graph.Node.prototype[m] = function() {
-    return Graph.Util[m].apply(Graph.Util, [this].concat(Array.prototype.slice.call(arguments)));
-  };
-});
-
-
-/*
- * File: Layouts.js
- * 
- * Implements base Tree and Graph layouts.
- *
- * Description:
- *
- * Implements base Tree and Graph layouts like Radial, Tree, etc.
- * 
- */
-
-/*
- * Object: Layouts
- * 
- * Parent object for common layouts.
- *
- */
-var Layouts = $jit.Layouts = {};
-
-
-//Some util shared layout functions are defined here.
-var NodeDim = {
-  label: null,
-  
-  compute: function(graph, prop, opt) {
-    this.initializeLabel(opt);
-    var label = this.label, style = label.style;
-    graph.eachNode(function(n) {
-      var autoWidth  = n.getData('autoWidth'),
-          autoHeight = n.getData('autoHeight');
-      if(autoWidth || autoHeight) {
-        //delete dimensions since these are
-        //going to be overridden now.
-        delete n.data.$width;
-        delete n.data.$height;
-        delete n.data.$dim;
-        
-        var width  = n.getData('width'),
-            height = n.getData('height');
-        //reset label dimensions
-        style.width  = autoWidth? 'auto' : width + 'px';
-        style.height = autoHeight? 'auto' : height + 'px';
-        
-        //TODO(nico) should let the user choose what to insert here.
-        label.innerHTML = n.name;
-        
-        var offsetWidth  = label.offsetWidth,
-            offsetHeight = label.offsetHeight;
-        var type = n.getData('type');
-        if($.indexOf(['circle', 'square', 'triangle', 'star'], type) === -1) {
-          n.setData('width', offsetWidth);
-          n.setData('height', offsetHeight);
-        } else {
-          var dim = offsetWidth > offsetHeight? offsetWidth : offsetHeight;
-          n.setData('width', dim);
-          n.setData('height', dim);
-          n.setData('dim', dim); 
-        }
-      }
-    });
-  },
-  
-  initializeLabel: function(opt) {
-    if(!this.label) {
-      this.label = document.createElement('div');
-      document.body.appendChild(this.label);
-    }
-    this.setLabelStyles(opt);
-  },
-  
-  setLabelStyles: function(opt) {
-    $.extend(this.label.style, {
-      'visibility': 'hidden',
-      'position': 'absolute',
-      'width': 'auto',
-      'height': 'auto'
-    });
-    this.label.className = 'jit-autoadjust-label';
-  }
-};
-
-
-/*
- * File: Layouts.MultiTopology.js
- *
-*/
-
-/*
- * Class: Layouts.MultiTopology
- * 
- * Implements a Multi Topology Layout.
- * Adapted from Layouts.ForceDirected
- * 
- * Implemented By:
- * 
- * <MultiTopology>
- * 
- * Credits:
- * 
- * Marcus Cobden <http://marcuscobden.co.uk>
- * 
- */
-Layouts.MultiTopology = new Class({
-
-  getOptions: function(random) {
-    var s = this.canvas.getSize();
-    var w = s.width, h = s.height;
-    //count nodes
-    var count = 0;
-    this.graph.eachNode(function(n) { 
-      count++;
-    });
-    var k2 = w * h / count, k = Math.sqrt(k2);
-    var l = this.config.levelDistance;
-    
-    return {
-      width: w - l,
-      height: h - l,
-      tstart: w * 0.1,
-      nodef: function(x) { return k2 / (x || 1); },
-      edgef: function(x) { return /* x * x / k; */ k * (x - l); }
-    };
-  },
-  
-  compute: function(property, incremental) {
-    var prop = $.splat(property || ['current', 'start', 'end']);
-    var opt = this.getOptions();
-    NodeDim.compute(this.graph, prop, this.config);
-    this.graph.computeLevels(this.root, 0, "ignore");
-    this.graph.eachNode(function(n) {
-      $.each(prop, function(p) {
-        var pos = n.getPos(p);
-        if(pos.equals(Complex.KER)) {
-          pos.x = opt.width/5 * (Math.random() - 0.5);
-          pos.y = opt.height/5 * (Math.random() - 0.5);
-        }
-        //initialize disp vector
-        n.disp = {};
-        $.each(prop, function(p) {
-          n.disp[p] = $C(0, 0);
-        });
-      });
-    });
-    this.computePositions(prop, opt, incremental);
-  },
-  
-  computePositions: function(property, opt, incremental) {
-    var times = this.config.iterations, i = 0, that = this;
-    if(incremental) {
-      (function iter() {
-        for(var total=incremental.iter, j=0; j<total; j++) {
-          opt.t = opt.tstart;
-          if(times) opt.t *= (1 - i++/(times -1));
-          that.computePositionStep(property, opt);
-          if(times && i >= times) {
-            incremental.onComplete();
-            return;
-          }
-        }
-        incremental.onStep(Math.round(i / (times -1) * 100));
-        setTimeout(iter, 1);
-      })();
-    } else {
-      for(; i < times; i++) {
-        opt.t = opt.tstart * (1 - i/(times -1));
-        this.computePositionStep(property, opt);
-      }
-    }
-  },
-  
-  computePositionStep: function(property, opt) {
-    var graph = this.graph;
-    var min = Math.min, max = Math.max;
-    var dpos = $C(0, 0);
-    //calculate repulsive forces
-    graph.eachNode(function(v) {
-      //initialize disp
-      $.each(property, function(p) {
-        v.disp[p].x = 0; v.disp[p].y = 0;
-      });
-      graph.eachNode(function(u) {
-        if(u.id != v.id) {
-          $.each(property, function(p) {
-            var vp = v.getPos(p), up = u.getPos(p);
-            dpos.x = vp.x - up.x;
-            dpos.y = vp.y - up.y;
-            var norm = dpos.norm() || 1;
-            v.disp[p].$add(dpos
-                .$scale(opt.nodef(norm) / norm));
-          });
-        }
-      });
-    });
-    //calculate attractive forces
-    var T = !!graph.getNode(this.root).visited;
-    graph.eachNode(function(node) {
-      node.eachAdjacency(function(adj) {
-        var nodeTo = adj.nodeTo;
-        if(!!nodeTo.visited === T) {
-          $.each(property, function(p) {
-            var vp = node.getPos(p), up = nodeTo.getPos(p);
-            dpos.x = vp.x - up.x;
-            dpos.y = vp.y - up.y;
-            var norm = dpos.norm() || 1;
-            node.disp[p].$add(dpos.$scale(-opt.edgef(norm) / norm));
-            nodeTo.disp[p].$add(dpos.$scale(-1));
-          });
-        }
-      });
-      node.visited = !T;
-    });
-    //arrange positions to fit the canvas
-    var t = opt.t, w2 = opt.width / 2, h2 = opt.height / 2;
-    graph.eachNode(function(u) {
-      $.each(property, function(p) {
-        var disp = u.disp[p];
-        var norm = disp.norm() || 1;
-        var p = u.getPos(p);
-        p.$add($C(disp.x * min(Math.abs(disp.x), t) / norm, 
-            disp.y * min(Math.abs(disp.y), t) / norm));
-        p.x = min(w2, max(-w2, p.x));
-        p.y = min(h2, max(-h2, p.y));
-      });
-    });
-  }
-});
-
-
-/*
- * File: MultiTopology.js
- */
-
-/*
-   Class: MultiTopology
-      
-   A network graph visualization adapted from the Force-Directed graph
-   
-  Implements:
-  
-  All <MultiLoader> methods
-  
-   Constructor Options:
-   
-   Inherits options from
-   
-   - <Options.Canvas>
-   - <Options.Controller>
-   - <Options.Node>
-   - <Options.Edge>
-   - <Options.Label>
-   - <Options.Events>
-   - <Options.Tips>
-   - <Options.NodeStyles>
-   - <Options.Navigation>
-   
-   Additionally, there are two parameters
-   
-   levelDistance - (number) Default's *50*. The natural length desired for the edges.
-   iterations - (number) Default's *50*. The number of iterations for the spring layout simulation. Depending on the browser's speed you could set this to a more 'interesting' number, like *200*. 
-     
-   Instance Properties:
-
-   canvas - Access a <Canvas> instance.
-   graph - Access a <Graph> instance.
-   op - Access a <ForceDirected.Op> instance.
-   fx - Access a <ForceDirected.Plot> instance.
-   labels - Access a <ForceDirected.Label> interface implementation.
-
-*/
-
-$jit.MultiTopology = new Class( {
-
-  Implements: [ MultiLoader, MultiExtras, Layouts.MultiTopology ],
-
-  initialize: function(controller) {
-    var $MultiTopology = $jit.MultiTopology;
-
-    var config = {
-      iterations: 50,
-      levelDistance: 50
-    };
-
-    this.controller = this.config = $.merge(Options("Canvas", "Node", "Edge",
-        "Fx", "Tips", "NodeStyles", "Events", "Navigation", "Controller", "Label"), config, controller);
-
-    var canvasConfig = this.config;
-    if(canvasConfig.useCanvas) {
-      this.canvas = canvasConfig.useCanvas;
-      this.config.labelContainer = this.canvas.id + '-label';
-    } else {
-      if(canvasConfig.background) {
-        canvasConfig.background = $.merge({
-          type: 'Circles'
-        }, canvasConfig.background);
-      }
-      this.canvas = new Canvas(this, canvasConfig);
-      this.config.labelContainer = (typeof canvasConfig.injectInto == 'string'? canvasConfig.injectInto : canvasConfig.injectInto.id) + '-label';
-    }
-
-    this.graphOptions = {
-      'klass': Complex,
-      'Node': {
-        'selected': false,
-        'exist': true,
-        'drawn': true
-      }
-    };
-    this.graph = new MultiGraph(this.graphOptions, this.config.Node,
-        this.config.Edge);
-    this.labels = new $MultiTopology.Label[canvasConfig.Label.type](this);
-    this.fx = new $MultiTopology.Plot(this, $MultiTopology);
-    this.op = new $MultiTopology.Op(this);
-    this.json = null;
-    this.busy = false;
-    // initialize extras
-    this.initializeExtras();
-  },
-
-  /* 
-    Method: refresh 
-    
-    Computes positions and plots the tree.
-  */
-  refresh: function() {
-    this.compute();
-    this.plot();
-  },
-
-  reposition: function() {
-    this.compute('end');
-  },
-
-/*
-  Method: computeIncremental
-  
-  Performs the Force Directed algorithm incrementally.
-  
-  Description:
-  
-  ForceDirected algorithms can perform many computations and lead to JavaScript taking too much time to complete. 
-  This method splits the algorithm into smaller parts allowing the user to track the evolution of the algorithm and 
-  avoiding browser messages such as "This script is taking too long to complete".
-  
-  Parameters:
-  
-  opt - (object) The object properties are described below
-  
-  iter - (number) Default's *20*. Split the algorithm into pieces of _iter_ iterations. For example, if the _iterations_ configuration property 
-  of your <ForceDirected> class is 100, then you could set _iter_ to 20 to split the main algorithm into 5 smaller pieces.
-  
-  property - (string) Default's *end*. Whether to update starting, current or ending node positions. Possible values are 'end', 'start', 'current'. 
-  You can also set an array of these properties. If you'd like to keep the current node positions but to perform these 
-  computations for final animation positions then you can just choose 'end'.
-  
-  onStep - (function) A callback function called when each "small part" of the algorithm completed. This function gets as first formal 
-  parameter a percentage value.
-  
-  onComplete - A callback function called when the algorithm completed.
-  
-  Example:
-  
-  In this example I calculate the end positions and then animate the graph to those positions
-  
-  (start code js)
-  var fd = new $jit.ForceDirected(...);
-  fd.computeIncremental({
-    iter: 20,
-    property: 'end',
-    onStep: function(perc) {
-      Log.write("loading " + perc + "%");
-    },
-    onComplete: function() {
-      Log.write("done");
-      fd.animate();
-    }
-  });
-  (end code)
-  
-  In this example I calculate all positions and (re)plot the graph
-  
-  (start code js)
-  var fd = new ForceDirected(...);
-  fd.computeIncremental({
-    iter: 20,
-    property: ['end', 'start', 'current'],
-    onStep: function(perc) {
-      Log.write("loading " + perc + "%");
-    },
-    onComplete: function() {
-      Log.write("done");
-      fd.plot();
-    }
-  });
-  (end code)
-  
-  */
-  computeIncremental: function(opt) {
-    opt = $.merge( {
-      iter: 20,
-      property: 'end',
-      onStep: $.empty,
-      onComplete: $.empty
-    }, opt || {});
-
-    this.config.onBeforeCompute(this.graph.getNode(this.root));
-    this.compute(opt.property, opt);
-  },
-
-  /*
-    Method: plot
-   
-    Plots the ForceDirected graph. This is a shortcut to *fx.plot*.
-   */
-  plot: function() {
-    this.fx.plot();
-  },
-
-  /*
-     Method: animate
-    
-     Animates the graph from the current positions to the 'end' node positions.
-  */
-  animate: function(opt) {
-    this.fx.animate($.merge( {
-      modes: [ 'linear' ]
-    }, opt || {}));
-  }
-});
-
-$jit.MultiTopology.$extend = true;
-
-(function(MultiTopology) {
-
-  /*
-     Class: ForceDirected.Op
-     
-     Custom extension of <Graph.Op>.
-
-     Extends:
-
-     All <Graph.Op> methods
-     
-     See also:
-     
-     <Graph.Op>
-
-  */
-  MultiTopology.Op = new Class( {
-
-    Implements: MultiGraph.Op
-
-  });
-
-  /*
-    Class: ForceDirected.Plot
-    
-    Custom extension of <Graph.Plot>.
-  
-    Extends:
-  
-    All <Graph.Plot> methods
-    
-    See also:
-    
-    <Graph.Plot>
-  
-  */
-  MultiTopology.Plot = new Class( {
-
-    Implements: MultiGraph.Plot
-
-  });
-
-  /*
-    Class: ForceDirected.Label
-    
-    Custom extension of <Graph.Label>. 
-    Contains custom <Graph.Label.SVG>, <Graph.Label.HTML> and <Graph.Label.Native> extensions.
-  
-    Extends:
-  
-    All <Graph.Label> methods and subclasses.
-  
-    See also:
-  
-    <Graph.Label>, <Graph.Label.Native>, <Graph.Label.HTML>, <Graph.Label.SVG>.
-  
-  */
-  MultiTopology.Label = {};
-
-  /*
-     ForceDirected.Label.Native
-     
-     Custom extension of <Graph.Label.Native>.
-
-     Extends:
-
-     All <Graph.Label.Native> methods
-
-     See also:
-
-     <Graph.Label.Native>
-
-  */
-  MultiTopology.Label.Native = new Class( {
-    Implements: MultiGraph.Label.Native
-  });
-
-  /*
-    ForceDirected.Label.SVG
-    
-    Custom extension of <Graph.Label.SVG>.
-  
-    Extends:
-  
-    All <Graph.Label.SVG> methods
-  
-    See also:
-  
-    <Graph.Label.SVG>
-  
-  */
-  MultiTopology.Label.SVG = new Class( {
-    Implements: MultiGraph.Label.SVG,
-
-    initialize: function(viz) {
-      this.viz = viz;
-    },
-
-    /* 
-       placeLabel
-
-       Overrides abstract method placeLabel in <Graph.Label>.
-
-       Parameters:
-
-       tag - A DOM label element.
-       node - A <Graph.Node>.
-       controller - A configuration/controller object passed to the visualization.
-      
-     */
-    placeLabel: function(tag, node, controller) {
-      var pos = node.pos.getc(true), 
-          canvas = this.viz.canvas,
-          ox = canvas.translateOffsetX,
-          oy = canvas.translateOffsetY,
-          sx = canvas.scaleOffsetX,
-          sy = canvas.scaleOffsetY,
-          radius = canvas.getSize();
-      var labelPos = {
-        x: Math.round(pos.x * sx + ox + radius.width / 2),
-        y: Math.round(pos.y * sy + oy + radius.height / 2)
-      };
-      tag.setAttribute('x', labelPos.x);
-      tag.setAttribute('y', labelPos.y);
-
-      controller.onPlaceLabel(tag, node);
-    }
-  });
-
-  /*
-     ForceDirected.Label.HTML
-     
-     Custom extension of <Graph.Label.HTML>.
-
-     Extends:
-
-     All <Graph.Label.HTML> methods.
-
-     See also:
-
-     <Graph.Label.HTML>
-
-  */
-  MultiTopology.Label.HTML = new Class( {
-    Implements: MultiGraph.Label.HTML,
-
-    initialize: function(viz) {
-      this.viz = viz;
-    },
-    /* 
-       placeLabel
-
-       Overrides abstract method placeLabel in <Graph.Plot>.
-
-       Parameters:
-
-       tag - A DOM label element.
-       node - A <Graph.Node>.
-       controller - A configuration/controller object passed to the visualization.
-      
-     */
-    placeLabel: function(tag, node, controller) {
-      var pos = node.pos.getc(true), 
-          canvas = this.viz.canvas,
-          ox = canvas.translateOffsetX,
-          oy = canvas.translateOffsetY,
-          sx = canvas.scaleOffsetX,
-          sy = canvas.scaleOffsetY,
-          radius = canvas.getSize();
-      var labelPos = {
-        x: Math.round(pos.x * sx + ox + radius.width / 2),
-        y: Math.round(pos.y * sy + oy + radius.height / 2)
-      };
-      var style = tag.style;
-      style.left = labelPos.x + 'px';
-      style.top = labelPos.y + 'px';
-      style.display = this.fitsInCanvas(labelPos, canvas) ? '' : 'none';
-
-      controller.onPlaceLabel(tag, node);
-    }
-  });
-
-  /*
-    Class: ForceDirected.Plot.NodeTypes
-
-    This class contains a list of <Graph.Node> built-in types. 
-    Node types implemented are 'none', 'circle', 'triangle', 'rectangle', 'star', 'ellipse' and 'square'.
-
-    You can add your custom node types, customizing your visualization to the extreme.
-
-    Example:
-
-    (start code js)
-      ForceDirected.Plot.NodeTypes.implement({
-        'mySpecialType': {
-          'render': function(node, canvas) {
-            //print your custom node to canvas
-          },
-          //optional
-          'contains': function(node, pos) {
-            //return true if pos is inside the node or false otherwise
-          }
-        }
-      });
-    (end code)
-
-  */
-  MultiTopology.Plot.NodeTypes = new Class({
-    'none': {
-      'render': $.empty,
-      'contains': $.lambda(false)
-    },
-       'host': {
-               'render': function(node, canvas, animating) {
-                       var pos = node.pos.getc(true);
-                       this.nodeHelper.host.render(pos, canvas, animating);
-               },
-               'contains': function(node, pos) {
-                       var npos = node.pos.getc(true);
-                       return this.nodeHelper.host.contains(npos, pos);
-               }
-       },
-       'switch': {
-               'render': function(node, canvas, animating) {
-                       var pos = node.pos.getc(true);
-                       this.nodeHelper.switch.render(pos, canvas, animating);
-               },
-               'contains': function(node, pos) {
-                       var npos = node.pos.getc(true);
-                       return this.nodeHelper.switch.contains(npos, pos);
-               }
-       }
-  });
-
-  /*
-    Class: ForceDirected.Plot.EdgeTypes
-  
-    This class contains a list of <Graph.Adjacence> built-in types. 
-    Edge types implemented are 'none', 'line' and 'arrow'.
-  
-    You can add your custom edge types, customizing your visualization to the extreme.
-  
-    Example:
-  
-    (start code js)
-      ForceDirected.Plot.EdgeTypes.implement({
-        'mySpecialType': {
-          'render': function(adj, canvas) {
-            //print your custom edge to canvas
-          },
-          //optional
-          'contains': function(adj, pos) {
-            //return true if pos is inside the arc or false otherwise
-          }
-        }
-      });
-    (end code)
-  
-  */
-  MultiTopology.Plot.EdgeTypes = new Class({
-    'none': $.empty,
-    'line': {
-      'render': function(adj, alpha, canvas) {
-        var from = adj.nodeFrom.pos.getc(true),
-            to = adj.nodeTo.pos.getc(true);
-        this.edgeHelper.line.render(from, to, alpha, canvas);
-      },
-      'contains': function(adj, alpha, pos, canvas) {
-        var from = adj.nodeFrom.pos.getc(true),
-            to = adj.nodeTo.pos.getc(true);
-        return this.edgeHelper.line.contains(from, to, alpha, pos, this.edge.epsilon, canvas);
-      }
-    }
-  });
-
-})($jit.MultiTopology);
-
-
-
-
- })();
diff --git a/opendaylight/adsal/web/root/src/main/resources/js/jquery-1.9.1.min.js b/opendaylight/adsal/web/root/src/main/resources/js/jquery-1.9.1.min.js
deleted file mode 100644 (file)
index 006e953..0000000
+++ /dev/null
@@ -1,5 +0,0 @@
-/*! jQuery v1.9.1 | (c) 2005, 2012 jQuery Foundation, Inc. | jquery.org/license
-//@ sourceMappingURL=jquery.min.map
-*/(function(e,t){var n,r,i=typeof t,o=e.document,a=e.location,s=e.jQuery,u=e.$,l={},c=[],p="1.9.1",f=c.concat,d=c.push,h=c.slice,g=c.indexOf,m=l.toString,y=l.hasOwnProperty,v=p.trim,b=function(e,t){return new b.fn.init(e,t,r)},x=/[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/.source,w=/\S+/g,T=/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g,N=/^(?:(<[\w\W]+>)[^>]*|#([\w-]*))$/,C=/^<(\w+)\s*\/?>(?:<\/\1>|)$/,k=/^[\],:{}\s]*$/,E=/(?:^|:|,)(?:\s*\[)+/g,S=/\\(?:["\\\/bfnrt]|u[\da-fA-F]{4})/g,A=/"[^"\\\r\n]*"|true|false|null|-?(?:\d+\.|)\d+(?:[eE][+-]?\d+|)/g,j=/^-ms-/,D=/-([\da-z])/gi,L=function(e,t){return t.toUpperCase()},H=function(e){(o.addEventListener||"load"===e.type||"complete"===o.readyState)&&(q(),b.ready())},q=function(){o.addEventListener?(o.removeEventListener("DOMContentLoaded",H,!1),e.removeEventListener("load",H,!1)):(o.detachEvent("onreadystatechange",H),e.detachEvent("onload",H))};b.fn=b.prototype={jquery:p,constructor:b,init:function(e,n,r){var i,a;if(!e)return this;if("string"==typeof e){if(i="<"===e.charAt(0)&&">"===e.charAt(e.length-1)&&e.length>=3?[null,e,null]:N.exec(e),!i||!i[1]&&n)return!n||n.jquery?(n||r).find(e):this.constructor(n).find(e);if(i[1]){if(n=n instanceof b?n[0]:n,b.merge(this,b.parseHTML(i[1],n&&n.nodeType?n.ownerDocument||n:o,!0)),C.test(i[1])&&b.isPlainObject(n))for(i in n)b.isFunction(this[i])?this[i](n[i]):this.attr(i,n[i]);return this}if(a=o.getElementById(i[2]),a&&a.parentNode){if(a.id!==i[2])return r.find(e);this.length=1,this[0]=a}return this.context=o,this.selector=e,this}return e.nodeType?(this.context=this[0]=e,this.length=1,this):b.isFunction(e)?r.ready(e):(e.selector!==t&&(this.selector=e.selector,this.context=e.context),b.makeArray(e,this))},selector:"",length:0,size:function(){return this.length},toArray:function(){return h.call(this)},get:function(e){return null==e?this.toArray():0>e?this[this.length+e]:this[e]},pushStack:function(e){var t=b.merge(this.constructor(),e);return t.prevObject=this,t.context=this.context,t},each:function(e,t){return b.each(this,e,t)},ready:function(e){return b.ready.promise().done(e),this},slice:function(){return this.pushStack(h.apply(this,arguments))},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},eq:function(e){var t=this.length,n=+e+(0>e?t:0);return this.pushStack(n>=0&&t>n?[this[n]]:[])},map:function(e){return this.pushStack(b.map(this,function(t,n){return e.call(t,n,t)}))},end:function(){return this.prevObject||this.constructor(null)},push:d,sort:[].sort,splice:[].splice},b.fn.init.prototype=b.fn,b.extend=b.fn.extend=function(){var e,n,r,i,o,a,s=arguments[0]||{},u=1,l=arguments.length,c=!1;for("boolean"==typeof s&&(c=s,s=arguments[1]||{},u=2),"object"==typeof s||b.isFunction(s)||(s={}),l===u&&(s=this,--u);l>u;u++)if(null!=(o=arguments[u]))for(i in o)e=s[i],r=o[i],s!==r&&(c&&r&&(b.isPlainObject(r)||(n=b.isArray(r)))?(n?(n=!1,a=e&&b.isArray(e)?e:[]):a=e&&b.isPlainObject(e)?e:{},s[i]=b.extend(c,a,r)):r!==t&&(s[i]=r));return s},b.extend({noConflict:function(t){return e.$===b&&(e.$=u),t&&e.jQuery===b&&(e.jQuery=s),b},isReady:!1,readyWait:1,holdReady:function(e){e?b.readyWait++:b.ready(!0)},ready:function(e){if(e===!0?!--b.readyWait:!b.isReady){if(!o.body)return setTimeout(b.ready);b.isReady=!0,e!==!0&&--b.readyWait>0||(n.resolveWith(o,[b]),b.fn.trigger&&b(o).trigger("ready").off("ready"))}},isFunction:function(e){return"function"===b.type(e)},isArray:Array.isArray||function(e){return"array"===b.type(e)},isWindow:function(e){return null!=e&&e==e.window},isNumeric:function(e){return!isNaN(parseFloat(e))&&isFinite(e)},type:function(e){return null==e?e+"":"object"==typeof e||"function"==typeof e?l[m.call(e)]||"object":typeof e},isPlainObject:function(e){if(!e||"object"!==b.type(e)||e.nodeType||b.isWindow(e))return!1;try{if(e.constructor&&!y.call(e,"constructor")&&!y.call(e.constructor.prototype,"isPrototypeOf"))return!1}catch(n){return!1}var r;for(r in e);return r===t||y.call(e,r)},isEmptyObject:function(e){var t;for(t in e)return!1;return!0},error:function(e){throw Error(e)},parseHTML:function(e,t,n){if(!e||"string"!=typeof e)return null;"boolean"==typeof t&&(n=t,t=!1),t=t||o;var r=C.exec(e),i=!n&&[];return r?[t.createElement(r[1])]:(r=b.buildFragment([e],t,i),i&&b(i).remove(),b.merge([],r.childNodes))},parseJSON:function(n){return e.JSON&&e.JSON.parse?e.JSON.parse(n):null===n?n:"string"==typeof n&&(n=b.trim(n),n&&k.test(n.replace(S,"@").replace(A,"]").replace(E,"")))?Function("return "+n)():(b.error("Invalid JSON: "+n),t)},parseXML:function(n){var r,i;if(!n||"string"!=typeof n)return null;try{e.DOMParser?(i=new DOMParser,r=i.parseFromString(n,"text/xml")):(r=new ActiveXObject("Microsoft.XMLDOM"),r.async="false",r.loadXML(n))}catch(o){r=t}return r&&r.documentElement&&!r.getElementsByTagName("parsererror").length||b.error("Invalid XML: "+n),r},noop:function(){},globalEval:function(t){t&&b.trim(t)&&(e.execScript||function(t){e.eval.call(e,t)})(t)},camelCase:function(e){return e.replace(j,"ms-").replace(D,L)},nodeName:function(e,t){return e.nodeName&&e.nodeName.toLowerCase()===t.toLowerCase()},each:function(e,t,n){var r,i=0,o=e.length,a=M(e);if(n){if(a){for(;o>i;i++)if(r=t.apply(e[i],n),r===!1)break}else for(i in e)if(r=t.apply(e[i],n),r===!1)break}else if(a){for(;o>i;i++)if(r=t.call(e[i],i,e[i]),r===!1)break}else for(i in e)if(r=t.call(e[i],i,e[i]),r===!1)break;return e},trim:v&&!v.call("\ufeff\u00a0")?function(e){return null==e?"":v.call(e)}:function(e){return null==e?"":(e+"").replace(T,"")},makeArray:function(e,t){var n=t||[];return null!=e&&(M(Object(e))?b.merge(n,"string"==typeof e?[e]:e):d.call(n,e)),n},inArray:function(e,t,n){var r;if(t){if(g)return g.call(t,e,n);for(r=t.length,n=n?0>n?Math.max(0,r+n):n:0;r>n;n++)if(n in t&&t[n]===e)return n}return-1},merge:function(e,n){var r=n.length,i=e.length,o=0;if("number"==typeof r)for(;r>o;o++)e[i++]=n[o];else while(n[o]!==t)e[i++]=n[o++];return e.length=i,e},grep:function(e,t,n){var r,i=[],o=0,a=e.length;for(n=!!n;a>o;o++)r=!!t(e[o],o),n!==r&&i.push(e[o]);return i},map:function(e,t,n){var r,i=0,o=e.length,a=M(e),s=[];if(a)for(;o>i;i++)r=t(e[i],i,n),null!=r&&(s[s.length]=r);else for(i in e)r=t(e[i],i,n),null!=r&&(s[s.length]=r);return f.apply([],s)},guid:1,proxy:function(e,n){var r,i,o;return"string"==typeof n&&(o=e[n],n=e,e=o),b.isFunction(e)?(r=h.call(arguments,2),i=function(){return e.apply(n||this,r.concat(h.call(arguments)))},i.guid=e.guid=e.guid||b.guid++,i):t},access:function(e,n,r,i,o,a,s){var u=0,l=e.length,c=null==r;if("object"===b.type(r)){o=!0;for(u in r)b.access(e,n,u,r[u],!0,a,s)}else if(i!==t&&(o=!0,b.isFunction(i)||(s=!0),c&&(s?(n.call(e,i),n=null):(c=n,n=function(e,t,n){return c.call(b(e),n)})),n))for(;l>u;u++)n(e[u],r,s?i:i.call(e[u],u,n(e[u],r)));return o?e:c?n.call(e):l?n(e[0],r):a},now:function(){return(new Date).getTime()}}),b.ready.promise=function(t){if(!n)if(n=b.Deferred(),"complete"===o.readyState)setTimeout(b.ready);else if(o.addEventListener)o.addEventListener("DOMContentLoaded",H,!1),e.addEventListener("load",H,!1);else{o.attachEvent("onreadystatechange",H),e.attachEvent("onload",H);var r=!1;try{r=null==e.frameElement&&o.documentElement}catch(i){}r&&r.doScroll&&function a(){if(!b.isReady){try{r.doScroll("left")}catch(e){return setTimeout(a,50)}q(),b.ready()}}()}return n.promise(t)},b.each("Boolean Number String Function Array Date RegExp Object Error".split(" "),function(e,t){l["[object "+t+"]"]=t.toLowerCase()});function M(e){var t=e.length,n=b.type(e);return b.isWindow(e)?!1:1===e.nodeType&&t?!0:"array"===n||"function"!==n&&(0===t||"number"==typeof t&&t>0&&t-1 in e)}r=b(o);var _={};function F(e){var t=_[e]={};return b.each(e.match(w)||[],function(e,n){t[n]=!0}),t}b.Callbacks=function(e){e="string"==typeof e?_[e]||F(e):b.extend({},e);var n,r,i,o,a,s,u=[],l=!e.once&&[],c=function(t){for(r=e.memory&&t,i=!0,a=s||0,s=0,o=u.length,n=!0;u&&o>a;a++)if(u[a].apply(t[0],t[1])===!1&&e.stopOnFalse){r=!1;break}n=!1,u&&(l?l.length&&c(l.shift()):r?u=[]:p.disable())},p={add:function(){if(u){var t=u.length;(function i(t){b.each(t,function(t,n){var r=b.type(n);"function"===r?e.unique&&p.has(n)||u.push(n):n&&n.length&&"string"!==r&&i(n)})})(arguments),n?o=u.length:r&&(s=t,c(r))}return this},remove:function(){return u&&b.each(arguments,function(e,t){var r;while((r=b.inArray(t,u,r))>-1)u.splice(r,1),n&&(o>=r&&o--,a>=r&&a--)}),this},has:function(e){return e?b.inArray(e,u)>-1:!(!u||!u.length)},empty:function(){return u=[],this},disable:function(){return u=l=r=t,this},disabled:function(){return!u},lock:function(){return l=t,r||p.disable(),this},locked:function(){return!l},fireWith:function(e,t){return t=t||[],t=[e,t.slice?t.slice():t],!u||i&&!l||(n?l.push(t):c(t)),this},fire:function(){return p.fireWith(this,arguments),this},fired:function(){return!!i}};return p},b.extend({Deferred:function(e){var t=[["resolve","done",b.Callbacks("once memory"),"resolved"],["reject","fail",b.Callbacks("once memory"),"rejected"],["notify","progress",b.Callbacks("memory")]],n="pending",r={state:function(){return n},always:function(){return i.done(arguments).fail(arguments),this},then:function(){var e=arguments;return b.Deferred(function(n){b.each(t,function(t,o){var a=o[0],s=b.isFunction(e[t])&&e[t];i[o[1]](function(){var e=s&&s.apply(this,arguments);e&&b.isFunction(e.promise)?e.promise().done(n.resolve).fail(n.reject).progress(n.notify):n[a+"With"](this===r?n.promise():this,s?[e]:arguments)})}),e=null}).promise()},promise:function(e){return null!=e?b.extend(e,r):r}},i={};return r.pipe=r.then,b.each(t,function(e,o){var a=o[2],s=o[3];r[o[1]]=a.add,s&&a.add(function(){n=s},t[1^e][2].disable,t[2][2].lock),i[o[0]]=function(){return i[o[0]+"With"](this===i?r:this,arguments),this},i[o[0]+"With"]=a.fireWith}),r.promise(i),e&&e.call(i,i),i},when:function(e){var t=0,n=h.call(arguments),r=n.length,i=1!==r||e&&b.isFunction(e.promise)?r:0,o=1===i?e:b.Deferred(),a=function(e,t,n){return function(r){t[e]=this,n[e]=arguments.length>1?h.call(arguments):r,n===s?o.notifyWith(t,n):--i||o.resolveWith(t,n)}},s,u,l;if(r>1)for(s=Array(r),u=Array(r),l=Array(r);r>t;t++)n[t]&&b.isFunction(n[t].promise)?n[t].promise().done(a(t,l,n)).fail(o.reject).progress(a(t,u,s)):--i;return i||o.resolveWith(l,n),o.promise()}}),b.support=function(){var t,n,r,a,s,u,l,c,p,f,d=o.createElement("div");if(d.setAttribute("className","t"),d.innerHTML="  <link/><table></table><a href='/a'>a</a><input type='checkbox'/>",n=d.getElementsByTagName("*"),r=d.getElementsByTagName("a")[0],!n||!r||!n.length)return{};s=o.createElement("select"),l=s.appendChild(o.createElement("option")),a=d.getElementsByTagName("input")[0],r.style.cssText="top:1px;float:left;opacity:.5",t={getSetAttribute:"t"!==d.className,leadingWhitespace:3===d.firstChild.nodeType,tbody:!d.getElementsByTagName("tbody").length,htmlSerialize:!!d.getElementsByTagName("link").length,style:/top/.test(r.getAttribute("style")),hrefNormalized:"/a"===r.getAttribute("href"),opacity:/^0.5/.test(r.style.opacity),cssFloat:!!r.style.cssFloat,checkOn:!!a.value,optSelected:l.selected,enctype:!!o.createElement("form").enctype,html5Clone:"<:nav></:nav>"!==o.createElement("nav").cloneNode(!0).outerHTML,boxModel:"CSS1Compat"===o.compatMode,deleteExpando:!0,noCloneEvent:!0,inlineBlockNeedsLayout:!1,shrinkWrapBlocks:!1,reliableMarginRight:!0,boxSizingReliable:!0,pixelPosition:!1},a.checked=!0,t.noCloneChecked=a.cloneNode(!0).checked,s.disabled=!0,t.optDisabled=!l.disabled;try{delete d.test}catch(h){t.deleteExpando=!1}a=o.createElement("input"),a.setAttribute("value",""),t.input=""===a.getAttribute("value"),a.value="t",a.setAttribute("type","radio"),t.radioValue="t"===a.value,a.setAttribute("checked","t"),a.setAttribute("name","t"),u=o.createDocumentFragment(),u.appendChild(a),t.appendChecked=a.checked,t.checkClone=u.cloneNode(!0).cloneNode(!0).lastChild.checked,d.attachEvent&&(d.attachEvent("onclick",function(){t.noCloneEvent=!1}),d.cloneNode(!0).click());for(f in{submit:!0,change:!0,focusin:!0})d.setAttribute(c="on"+f,"t"),t[f+"Bubbles"]=c in e||d.attributes[c].expando===!1;return d.style.backgroundClip="content-box",d.cloneNode(!0).style.backgroundClip="",t.clearCloneStyle="content-box"===d.style.backgroundClip,b(function(){var n,r,a,s="padding:0;margin:0;border:0;display:block;box-sizing:content-box;-moz-box-sizing:content-box;-webkit-box-sizing:content-box;",u=o.getElementsByTagName("body")[0];u&&(n=o.createElement("div"),n.style.cssText="border:0;width:0;height:0;position:absolute;top:0;left:-9999px;margin-top:1px",u.appendChild(n).appendChild(d),d.innerHTML="<table><tr><td></td><td>t</td></tr></table>",a=d.getElementsByTagName("td"),a[0].style.cssText="padding:0;margin:0;border:0;display:none",p=0===a[0].offsetHeight,a[0].style.display="",a[1].style.display="none",t.reliableHiddenOffsets=p&&0===a[0].offsetHeight,d.innerHTML="",d.style.cssText="box-sizing:border-box;-moz-box-sizing:border-box;-webkit-box-sizing:border-box;padding:1px;border:1px;display:block;width:4px;margin-top:1%;position:absolute;top:1%;",t.boxSizing=4===d.offsetWidth,t.doesNotIncludeMarginInBodyOffset=1!==u.offsetTop,e.getComputedStyle&&(t.pixelPosition="1%"!==(e.getComputedStyle(d,null)||{}).top,t.boxSizingReliable="4px"===(e.getComputedStyle(d,null)||{width:"4px"}).width,r=d.appendChild(o.createElement("div")),r.style.cssText=d.style.cssText=s,r.style.marginRight=r.style.width="0",d.style.width="1px",t.reliableMarginRight=!parseFloat((e.getComputedStyle(r,null)||{}).marginRight)),typeof d.style.zoom!==i&&(d.innerHTML="",d.style.cssText=s+"width:1px;padding:1px;display:inline;zoom:1",t.inlineBlockNeedsLayout=3===d.offsetWidth,d.style.display="block",d.innerHTML="<div></div>",d.firstChild.style.width="5px",t.shrinkWrapBlocks=3!==d.offsetWidth,t.inlineBlockNeedsLayout&&(u.style.zoom=1)),u.removeChild(n),n=d=a=r=null)}),n=s=u=l=r=a=null,t}();var O=/(?:\{[\s\S]*\}|\[[\s\S]*\])$/,B=/([A-Z])/g;function P(e,n,r,i){if(b.acceptData(e)){var o,a,s=b.expando,u="string"==typeof n,l=e.nodeType,p=l?b.cache:e,f=l?e[s]:e[s]&&s;if(f&&p[f]&&(i||p[f].data)||!u||r!==t)return f||(l?e[s]=f=c.pop()||b.guid++:f=s),p[f]||(p[f]={},l||(p[f].toJSON=b.noop)),("object"==typeof n||"function"==typeof n)&&(i?p[f]=b.extend(p[f],n):p[f].data=b.extend(p[f].data,n)),o=p[f],i||(o.data||(o.data={}),o=o.data),r!==t&&(o[b.camelCase(n)]=r),u?(a=o[n],null==a&&(a=o[b.camelCase(n)])):a=o,a}}function R(e,t,n){if(b.acceptData(e)){var r,i,o,a=e.nodeType,s=a?b.cache:e,u=a?e[b.expando]:b.expando;if(s[u]){if(t&&(o=n?s[u]:s[u].data)){b.isArray(t)?t=t.concat(b.map(t,b.camelCase)):t in o?t=[t]:(t=b.camelCase(t),t=t in o?[t]:t.split(" "));for(r=0,i=t.length;i>r;r++)delete o[t[r]];if(!(n?$:b.isEmptyObject)(o))return}(n||(delete s[u].data,$(s[u])))&&(a?b.cleanData([e],!0):b.support.deleteExpando||s!=s.window?delete s[u]:s[u]=null)}}}b.extend({cache:{},expando:"jQuery"+(p+Math.random()).replace(/\D/g,""),noData:{embed:!0,object:"clsid:D27CDB6E-AE6D-11cf-96B8-444553540000",applet:!0},hasData:function(e){return e=e.nodeType?b.cache[e[b.expando]]:e[b.expando],!!e&&!$(e)},data:function(e,t,n){return P(e,t,n)},removeData:function(e,t){return R(e,t)},_data:function(e,t,n){return P(e,t,n,!0)},_removeData:function(e,t){return R(e,t,!0)},acceptData:function(e){if(e.nodeType&&1!==e.nodeType&&9!==e.nodeType)return!1;var t=e.nodeName&&b.noData[e.nodeName.toLowerCase()];return!t||t!==!0&&e.getAttribute("classid")===t}}),b.fn.extend({data:function(e,n){var r,i,o=this[0],a=0,s=null;if(e===t){if(this.length&&(s=b.data(o),1===o.nodeType&&!b._data(o,"parsedAttrs"))){for(r=o.attributes;r.length>a;a++)i=r[a].name,i.indexOf("data-")||(i=b.camelCase(i.slice(5)),W(o,i,s[i]));b._data(o,"parsedAttrs",!0)}return s}return"object"==typeof e?this.each(function(){b.data(this,e)}):b.access(this,function(n){return n===t?o?W(o,e,b.data(o,e)):null:(this.each(function(){b.data(this,e,n)}),t)},null,n,arguments.length>1,null,!0)},removeData:function(e){return this.each(function(){b.removeData(this,e)})}});function W(e,n,r){if(r===t&&1===e.nodeType){var i="data-"+n.replace(B,"-$1").toLowerCase();if(r=e.getAttribute(i),"string"==typeof r){try{r="true"===r?!0:"false"===r?!1:"null"===r?null:+r+""===r?+r:O.test(r)?b.parseJSON(r):r}catch(o){}b.data(e,n,r)}else r=t}return r}function $(e){var t;for(t in e)if(("data"!==t||!b.isEmptyObject(e[t]))&&"toJSON"!==t)return!1;return!0}b.extend({queue:function(e,n,r){var i;return e?(n=(n||"fx")+"queue",i=b._data(e,n),r&&(!i||b.isArray(r)?i=b._data(e,n,b.makeArray(r)):i.push(r)),i||[]):t},dequeue:function(e,t){t=t||"fx";var n=b.queue(e,t),r=n.length,i=n.shift(),o=b._queueHooks(e,t),a=function(){b.dequeue(e,t)};"inprogress"===i&&(i=n.shift(),r--),o.cur=i,i&&("fx"===t&&n.unshift("inprogress"),delete o.stop,i.call(e,a,o)),!r&&o&&o.empty.fire()},_queueHooks:function(e,t){var n=t+"queueHooks";return b._data(e,n)||b._data(e,n,{empty:b.Callbacks("once memory").add(function(){b._removeData(e,t+"queue"),b._removeData(e,n)})})}}),b.fn.extend({queue:function(e,n){var r=2;return"string"!=typeof e&&(n=e,e="fx",r--),r>arguments.length?b.queue(this[0],e):n===t?this:this.each(function(){var t=b.queue(this,e,n);b._queueHooks(this,e),"fx"===e&&"inprogress"!==t[0]&&b.dequeue(this,e)})},dequeue:function(e){return this.each(function(){b.dequeue(this,e)})},delay:function(e,t){return e=b.fx?b.fx.speeds[e]||e:e,t=t||"fx",this.queue(t,function(t,n){var r=setTimeout(t,e);n.stop=function(){clearTimeout(r)}})},clearQueue:function(e){return this.queue(e||"fx",[])},promise:function(e,n){var r,i=1,o=b.Deferred(),a=this,s=this.length,u=function(){--i||o.resolveWith(a,[a])};"string"!=typeof e&&(n=e,e=t),e=e||"fx";while(s--)r=b._data(a[s],e+"queueHooks"),r&&r.empty&&(i++,r.empty.add(u));return u(),o.promise(n)}});var I,z,X=/[\t\r\n]/g,U=/\r/g,V=/^(?:input|select|textarea|button|object)$/i,Y=/^(?:a|area)$/i,J=/^(?:checked|selected|autofocus|autoplay|async|controls|defer|disabled|hidden|loop|multiple|open|readonly|required|scoped)$/i,G=/^(?:checked|selected)$/i,Q=b.support.getSetAttribute,K=b.support.input;b.fn.extend({attr:function(e,t){return b.access(this,b.attr,e,t,arguments.length>1)},removeAttr:function(e){return this.each(function(){b.removeAttr(this,e)})},prop:function(e,t){return b.access(this,b.prop,e,t,arguments.length>1)},removeProp:function(e){return e=b.propFix[e]||e,this.each(function(){try{this[e]=t,delete this[e]}catch(n){}})},addClass:function(e){var t,n,r,i,o,a=0,s=this.length,u="string"==typeof e&&e;if(b.isFunction(e))return this.each(function(t){b(this).addClass(e.call(this,t,this.className))});if(u)for(t=(e||"").match(w)||[];s>a;a++)if(n=this[a],r=1===n.nodeType&&(n.className?(" "+n.className+" ").replace(X," "):" ")){o=0;while(i=t[o++])0>r.indexOf(" "+i+" ")&&(r+=i+" ");n.className=b.trim(r)}return this},removeClass:function(e){var t,n,r,i,o,a=0,s=this.length,u=0===arguments.length||"string"==typeof e&&e;if(b.isFunction(e))return this.each(function(t){b(this).removeClass(e.call(this,t,this.className))});if(u)for(t=(e||"").match(w)||[];s>a;a++)if(n=this[a],r=1===n.nodeType&&(n.className?(" "+n.className+" ").replace(X," "):"")){o=0;while(i=t[o++])while(r.indexOf(" "+i+" ")>=0)r=r.replace(" "+i+" "," ");n.className=e?b.trim(r):""}return this},toggleClass:function(e,t){var n=typeof e,r="boolean"==typeof t;return b.isFunction(e)?this.each(function(n){b(this).toggleClass(e.call(this,n,this.className,t),t)}):this.each(function(){if("string"===n){var o,a=0,s=b(this),u=t,l=e.match(w)||[];while(o=l[a++])u=r?u:!s.hasClass(o),s[u?"addClass":"removeClass"](o)}else(n===i||"boolean"===n)&&(this.className&&b._data(this,"__className__",this.className),this.className=this.className||e===!1?"":b._data(this,"__className__")||"")})},hasClass:function(e){var t=" "+e+" ",n=0,r=this.length;for(;r>n;n++)if(1===this[n].nodeType&&(" "+this[n].className+" ").replace(X," ").indexOf(t)>=0)return!0;return!1},val:function(e){var n,r,i,o=this[0];{if(arguments.length)return i=b.isFunction(e),this.each(function(n){var o,a=b(this);1===this.nodeType&&(o=i?e.call(this,n,a.val()):e,null==o?o="":"number"==typeof o?o+="":b.isArray(o)&&(o=b.map(o,function(e){return null==e?"":e+""})),r=b.valHooks[this.type]||b.valHooks[this.nodeName.toLowerCase()],r&&"set"in r&&r.set(this,o,"value")!==t||(this.value=o))});if(o)return r=b.valHooks[o.type]||b.valHooks[o.nodeName.toLowerCase()],r&&"get"in r&&(n=r.get(o,"value"))!==t?n:(n=o.value,"string"==typeof n?n.replace(U,""):null==n?"":n)}}}),b.extend({valHooks:{option:{get:function(e){var t=e.attributes.value;return!t||t.specified?e.value:e.text}},select:{get:function(e){var t,n,r=e.options,i=e.selectedIndex,o="select-one"===e.type||0>i,a=o?null:[],s=o?i+1:r.length,u=0>i?s:o?i:0;for(;s>u;u++)if(n=r[u],!(!n.selected&&u!==i||(b.support.optDisabled?n.disabled:null!==n.getAttribute("disabled"))||n.parentNode.disabled&&b.nodeName(n.parentNode,"optgroup"))){if(t=b(n).val(),o)return t;a.push(t)}return a},set:function(e,t){var n=b.makeArray(t);return b(e).find("option").each(function(){this.selected=b.inArray(b(this).val(),n)>=0}),n.length||(e.selectedIndex=-1),n}}},attr:function(e,n,r){var o,a,s,u=e.nodeType;if(e&&3!==u&&8!==u&&2!==u)return typeof e.getAttribute===i?b.prop(e,n,r):(a=1!==u||!b.isXMLDoc(e),a&&(n=n.toLowerCase(),o=b.attrHooks[n]||(J.test(n)?z:I)),r===t?o&&a&&"get"in o&&null!==(s=o.get(e,n))?s:(typeof e.getAttribute!==i&&(s=e.getAttribute(n)),null==s?t:s):null!==r?o&&a&&"set"in o&&(s=o.set(e,r,n))!==t?s:(e.setAttribute(n,r+""),r):(b.removeAttr(e,n),t))},removeAttr:function(e,t){var n,r,i=0,o=t&&t.match(w);if(o&&1===e.nodeType)while(n=o[i++])r=b.propFix[n]||n,J.test(n)?!Q&&G.test(n)?e[b.camelCase("default-"+n)]=e[r]=!1:e[r]=!1:b.attr(e,n,""),e.removeAttribute(Q?n:r)},attrHooks:{type:{set:function(e,t){if(!b.support.radioValue&&"radio"===t&&b.nodeName(e,"input")){var n=e.value;return e.setAttribute("type",t),n&&(e.value=n),t}}}},propFix:{tabindex:"tabIndex",readonly:"readOnly","for":"htmlFor","class":"className",maxlength:"maxLength",cellspacing:"cellSpacing",cellpadding:"cellPadding",rowspan:"rowSpan",colspan:"colSpan",usemap:"useMap",frameborder:"frameBorder",contenteditable:"contentEditable"},prop:function(e,n,r){var i,o,a,s=e.nodeType;if(e&&3!==s&&8!==s&&2!==s)return a=1!==s||!b.isXMLDoc(e),a&&(n=b.propFix[n]||n,o=b.propHooks[n]),r!==t?o&&"set"in o&&(i=o.set(e,r,n))!==t?i:e[n]=r:o&&"get"in o&&null!==(i=o.get(e,n))?i:e[n]},propHooks:{tabIndex:{get:function(e){var n=e.getAttributeNode("tabindex");return n&&n.specified?parseInt(n.value,10):V.test(e.nodeName)||Y.test(e.nodeName)&&e.href?0:t}}}}),z={get:function(e,n){var r=b.prop(e,n),i="boolean"==typeof r&&e.getAttribute(n),o="boolean"==typeof r?K&&Q?null!=i:G.test(n)?e[b.camelCase("default-"+n)]:!!i:e.getAttributeNode(n);return o&&o.value!==!1?n.toLowerCase():t},set:function(e,t,n){return t===!1?b.removeAttr(e,n):K&&Q||!G.test(n)?e.setAttribute(!Q&&b.propFix[n]||n,n):e[b.camelCase("default-"+n)]=e[n]=!0,n}},K&&Q||(b.attrHooks.value={get:function(e,n){var r=e.getAttributeNode(n);return b.nodeName(e,"input")?e.defaultValue:r&&r.specified?r.value:t},set:function(e,n,r){return b.nodeName(e,"input")?(e.defaultValue=n,t):I&&I.set(e,n,r)}}),Q||(I=b.valHooks.button={get:function(e,n){var r=e.getAttributeNode(n);return r&&("id"===n||"name"===n||"coords"===n?""!==r.value:r.specified)?r.value:t},set:function(e,n,r){var i=e.getAttributeNode(r);return i||e.setAttributeNode(i=e.ownerDocument.createAttribute(r)),i.value=n+="","value"===r||n===e.getAttribute(r)?n:t}},b.attrHooks.contenteditable={get:I.get,set:function(e,t,n){I.set(e,""===t?!1:t,n)}},b.each(["width","height"],function(e,n){b.attrHooks[n]=b.extend(b.attrHooks[n],{set:function(e,r){return""===r?(e.setAttribute(n,"auto"),r):t}})})),b.support.hrefNormalized||(b.each(["href","src","width","height"],function(e,n){b.attrHooks[n]=b.extend(b.attrHooks[n],{get:function(e){var r=e.getAttribute(n,2);return null==r?t:r}})}),b.each(["href","src"],function(e,t){b.propHooks[t]={get:function(e){return e.getAttribute(t,4)}}})),b.support.style||(b.attrHooks.style={get:function(e){return e.style.cssText||t},set:function(e,t){return e.style.cssText=t+""}}),b.support.optSelected||(b.propHooks.selected=b.extend(b.propHooks.selected,{get:function(e){var t=e.parentNode;return t&&(t.selectedIndex,t.parentNode&&t.parentNode.selectedIndex),null}})),b.support.enctype||(b.propFix.enctype="encoding"),b.support.checkOn||b.each(["radio","checkbox"],function(){b.valHooks[this]={get:function(e){return null===e.getAttribute("value")?"on":e.value}}}),b.each(["radio","checkbox"],function(){b.valHooks[this]=b.extend(b.valHooks[this],{set:function(e,n){return b.isArray(n)?e.checked=b.inArray(b(e).val(),n)>=0:t}})});var Z=/^(?:input|select|textarea)$/i,et=/^key/,tt=/^(?:mouse|contextmenu)|click/,nt=/^(?:focusinfocus|focusoutblur)$/,rt=/^([^.]*)(?:\.(.+)|)$/;function it(){return!0}function ot(){return!1}b.event={global:{},add:function(e,n,r,o,a){var s,u,l,c,p,f,d,h,g,m,y,v=b._data(e);if(v){r.handler&&(c=r,r=c.handler,a=c.selector),r.guid||(r.guid=b.guid++),(u=v.events)||(u=v.events={}),(f=v.handle)||(f=v.handle=function(e){return typeof b===i||e&&b.event.triggered===e.type?t:b.event.dispatch.apply(f.elem,arguments)},f.elem=e),n=(n||"").match(w)||[""],l=n.length;while(l--)s=rt.exec(n[l])||[],g=y=s[1],m=(s[2]||"").split(".").sort(),p=b.event.special[g]||{},g=(a?p.delegateType:p.bindType)||g,p=b.event.special[g]||{},d=b.extend({type:g,origType:y,data:o,handler:r,guid:r.guid,selector:a,needsContext:a&&b.expr.match.needsContext.test(a),namespace:m.join(".")},c),(h=u[g])||(h=u[g]=[],h.delegateCount=0,p.setup&&p.setup.call(e,o,m,f)!==!1||(e.addEventListener?e.addEventListener(g,f,!1):e.attachEvent&&e.attachEvent("on"+g,f))),p.add&&(p.add.call(e,d),d.handler.guid||(d.handler.guid=r.guid)),a?h.splice(h.delegateCount++,0,d):h.push(d),b.event.global[g]=!0;e=null}},remove:function(e,t,n,r,i){var o,a,s,u,l,c,p,f,d,h,g,m=b.hasData(e)&&b._data(e);if(m&&(c=m.events)){t=(t||"").match(w)||[""],l=t.length;while(l--)if(s=rt.exec(t[l])||[],d=g=s[1],h=(s[2]||"").split(".").sort(),d){p=b.event.special[d]||{},d=(r?p.delegateType:p.bindType)||d,f=c[d]||[],s=s[2]&&RegExp("(^|\\.)"+h.join("\\.(?:.*\\.|)")+"(\\.|$)"),u=o=f.length;while(o--)a=f[o],!i&&g!==a.origType||n&&n.guid!==a.guid||s&&!s.test(a.namespace)||r&&r!==a.selector&&("**"!==r||!a.selector)||(f.splice(o,1),a.selector&&f.delegateCount--,p.remove&&p.remove.call(e,a));u&&!f.length&&(p.teardown&&p.teardown.call(e,h,m.handle)!==!1||b.removeEvent(e,d,m.handle),delete c[d])}else for(d in c)b.event.remove(e,d+t[l],n,r,!0);b.isEmptyObject(c)&&(delete m.handle,b._removeData(e,"events"))}},trigger:function(n,r,i,a){var s,u,l,c,p,f,d,h=[i||o],g=y.call(n,"type")?n.type:n,m=y.call(n,"namespace")?n.namespace.split("."):[];if(l=f=i=i||o,3!==i.nodeType&&8!==i.nodeType&&!nt.test(g+b.event.triggered)&&(g.indexOf(".")>=0&&(m=g.split("."),g=m.shift(),m.sort()),u=0>g.indexOf(":")&&"on"+g,n=n[b.expando]?n:new b.Event(g,"object"==typeof n&&n),n.isTrigger=!0,n.namespace=m.join("."),n.namespace_re=n.namespace?RegExp("(^|\\.)"+m.join("\\.(?:.*\\.|)")+"(\\.|$)"):null,n.result=t,n.target||(n.target=i),r=null==r?[n]:b.makeArray(r,[n]),p=b.event.special[g]||{},a||!p.trigger||p.trigger.apply(i,r)!==!1)){if(!a&&!p.noBubble&&!b.isWindow(i)){for(c=p.delegateType||g,nt.test(c+g)||(l=l.parentNode);l;l=l.parentNode)h.push(l),f=l;f===(i.ownerDocument||o)&&h.push(f.defaultView||f.parentWindow||e)}d=0;while((l=h[d++])&&!n.isPropagationStopped())n.type=d>1?c:p.bindType||g,s=(b._data(l,"events")||{})[n.type]&&b._data(l,"handle"),s&&s.apply(l,r),s=u&&l[u],s&&b.acceptData(l)&&s.apply&&s.apply(l,r)===!1&&n.preventDefault();if(n.type=g,!(a||n.isDefaultPrevented()||p._default&&p._default.apply(i.ownerDocument,r)!==!1||"click"===g&&b.nodeName(i,"a")||!b.acceptData(i)||!u||!i[g]||b.isWindow(i))){f=i[u],f&&(i[u]=null),b.event.triggered=g;try{i[g]()}catch(v){}b.event.triggered=t,f&&(i[u]=f)}return n.result}},dispatch:function(e){e=b.event.fix(e);var n,r,i,o,a,s=[],u=h.call(arguments),l=(b._data(this,"events")||{})[e.type]||[],c=b.event.special[e.type]||{};if(u[0]=e,e.delegateTarget=this,!c.preDispatch||c.preDispatch.call(this,e)!==!1){s=b.event.handlers.call(this,e,l),n=0;while((o=s[n++])&&!e.isPropagationStopped()){e.currentTarget=o.elem,a=0;while((i=o.handlers[a++])&&!e.isImmediatePropagationStopped())(!e.namespace_re||e.namespace_re.test(i.namespace))&&(e.handleObj=i,e.data=i.data,r=((b.event.special[i.origType]||{}).handle||i.handler).apply(o.elem,u),r!==t&&(e.result=r)===!1&&(e.preventDefault(),e.stopPropagation()))}return c.postDispatch&&c.postDispatch.call(this,e),e.result}},handlers:function(e,n){var r,i,o,a,s=[],u=n.delegateCount,l=e.target;if(u&&l.nodeType&&(!e.button||"click"!==e.type))for(;l!=this;l=l.parentNode||this)if(1===l.nodeType&&(l.disabled!==!0||"click"!==e.type)){for(o=[],a=0;u>a;a++)i=n[a],r=i.selector+" ",o[r]===t&&(o[r]=i.needsContext?b(r,this).index(l)>=0:b.find(r,this,null,[l]).length),o[r]&&o.push(i);o.length&&s.push({elem:l,handlers:o})}return n.length>u&&s.push({elem:this,handlers:n.slice(u)}),s},fix:function(e){if(e[b.expando])return e;var t,n,r,i=e.type,a=e,s=this.fixHooks[i];s||(this.fixHooks[i]=s=tt.test(i)?this.mouseHooks:et.test(i)?this.keyHooks:{}),r=s.props?this.props.concat(s.props):this.props,e=new b.Event(a),t=r.length;while(t--)n=r[t],e[n]=a[n];return e.target||(e.target=a.srcElement||o),3===e.target.nodeType&&(e.target=e.target.parentNode),e.metaKey=!!e.metaKey,s.filter?s.filter(e,a):e},props:"altKey bubbles cancelable ctrlKey currentTarget eventPhase metaKey relatedTarget shiftKey target timeStamp view which".split(" "),fixHooks:{},keyHooks:{props:"char charCode key keyCode".split(" "),filter:function(e,t){return null==e.which&&(e.which=null!=t.charCode?t.charCode:t.keyCode),e}},mouseHooks:{props:"button buttons clientX clientY fromElement offsetX offsetY pageX pageY screenX screenY toElement".split(" "),filter:function(e,n){var r,i,a,s=n.button,u=n.fromElement;return null==e.pageX&&null!=n.clientX&&(i=e.target.ownerDocument||o,a=i.documentElement,r=i.body,e.pageX=n.clientX+(a&&a.scrollLeft||r&&r.scrollLeft||0)-(a&&a.clientLeft||r&&r.clientLeft||0),e.pageY=n.clientY+(a&&a.scrollTop||r&&r.scrollTop||0)-(a&&a.clientTop||r&&r.clientTop||0)),!e.relatedTarget&&u&&(e.relatedTarget=u===e.target?n.toElement:u),e.which||s===t||(e.which=1&s?1:2&s?3:4&s?2:0),e}},special:{load:{noBubble:!0},click:{trigger:function(){return b.nodeName(this,"input")&&"checkbox"===this.type&&this.click?(this.click(),!1):t}},focus:{trigger:function(){if(this!==o.activeElement&&this.focus)try{return this.focus(),!1}catch(e){}},delegateType:"focusin"},blur:{trigger:function(){return this===o.activeElement&&this.blur?(this.blur(),!1):t},delegateType:"focusout"},beforeunload:{postDispatch:function(e){e.result!==t&&(e.originalEvent.returnValue=e.result)}}},simulate:function(e,t,n,r){var i=b.extend(new b.Event,n,{type:e,isSimulated:!0,originalEvent:{}});r?b.event.trigger(i,null,t):b.event.dispatch.call(t,i),i.isDefaultPrevented()&&n.preventDefault()}},b.removeEvent=o.removeEventListener?function(e,t,n){e.removeEventListener&&e.removeEventListener(t,n,!1)}:function(e,t,n){var r="on"+t;e.detachEvent&&(typeof e[r]===i&&(e[r]=null),e.detachEvent(r,n))},b.Event=function(e,n){return this instanceof b.Event?(e&&e.type?(this.originalEvent=e,this.type=e.type,this.isDefaultPrevented=e.defaultPrevented||e.returnValue===!1||e.getPreventDefault&&e.getPreventDefault()?it:ot):this.type=e,n&&b.extend(this,n),this.timeStamp=e&&e.timeStamp||b.now(),this[b.expando]=!0,t):new b.Event(e,n)},b.Event.prototype={isDefaultPrevented:ot,isPropagationStopped:ot,isImmediatePropagationStopped:ot,preventDefault:function(){var e=this.originalEvent;this.isDefaultPrevented=it,e&&(e.preventDefault?e.preventDefault():e.returnValue=!1)},stopPropagation:function(){var e=this.originalEvent;this.isPropagationStopped=it,e&&(e.stopPropagation&&e.stopPropagation(),e.cancelBubble=!0)},stopImmediatePropagation:function(){this.isImmediatePropagationStopped=it,this.stopPropagation()}},b.each({mouseenter:"mouseover",mouseleave:"mouseout"},function(e,t){b.event.special[e]={delegateType:t,bindType:t,handle:function(e){var n,r=this,i=e.relatedTarget,o=e.handleObj;
-return(!i||i!==r&&!b.contains(r,i))&&(e.type=o.origType,n=o.handler.apply(this,arguments),e.type=t),n}}}),b.support.submitBubbles||(b.event.special.submit={setup:function(){return b.nodeName(this,"form")?!1:(b.event.add(this,"click._submit keypress._submit",function(e){var n=e.target,r=b.nodeName(n,"input")||b.nodeName(n,"button")?n.form:t;r&&!b._data(r,"submitBubbles")&&(b.event.add(r,"submit._submit",function(e){e._submit_bubble=!0}),b._data(r,"submitBubbles",!0))}),t)},postDispatch:function(e){e._submit_bubble&&(delete e._submit_bubble,this.parentNode&&!e.isTrigger&&b.event.simulate("submit",this.parentNode,e,!0))},teardown:function(){return b.nodeName(this,"form")?!1:(b.event.remove(this,"._submit"),t)}}),b.support.changeBubbles||(b.event.special.change={setup:function(){return Z.test(this.nodeName)?(("checkbox"===this.type||"radio"===this.type)&&(b.event.add(this,"propertychange._change",function(e){"checked"===e.originalEvent.propertyName&&(this._just_changed=!0)}),b.event.add(this,"click._change",function(e){this._just_changed&&!e.isTrigger&&(this._just_changed=!1),b.event.simulate("change",this,e,!0)})),!1):(b.event.add(this,"beforeactivate._change",function(e){var t=e.target;Z.test(t.nodeName)&&!b._data(t,"changeBubbles")&&(b.event.add(t,"change._change",function(e){!this.parentNode||e.isSimulated||e.isTrigger||b.event.simulate("change",this.parentNode,e,!0)}),b._data(t,"changeBubbles",!0))}),t)},handle:function(e){var n=e.target;return this!==n||e.isSimulated||e.isTrigger||"radio"!==n.type&&"checkbox"!==n.type?e.handleObj.handler.apply(this,arguments):t},teardown:function(){return b.event.remove(this,"._change"),!Z.test(this.nodeName)}}),b.support.focusinBubbles||b.each({focus:"focusin",blur:"focusout"},function(e,t){var n=0,r=function(e){b.event.simulate(t,e.target,b.event.fix(e),!0)};b.event.special[t]={setup:function(){0===n++&&o.addEventListener(e,r,!0)},teardown:function(){0===--n&&o.removeEventListener(e,r,!0)}}}),b.fn.extend({on:function(e,n,r,i,o){var a,s;if("object"==typeof e){"string"!=typeof n&&(r=r||n,n=t);for(a in e)this.on(a,n,r,e[a],o);return this}if(null==r&&null==i?(i=n,r=n=t):null==i&&("string"==typeof n?(i=r,r=t):(i=r,r=n,n=t)),i===!1)i=ot;else if(!i)return this;return 1===o&&(s=i,i=function(e){return b().off(e),s.apply(this,arguments)},i.guid=s.guid||(s.guid=b.guid++)),this.each(function(){b.event.add(this,e,i,r,n)})},one:function(e,t,n,r){return this.on(e,t,n,r,1)},off:function(e,n,r){var i,o;if(e&&e.preventDefault&&e.handleObj)return i=e.handleObj,b(e.delegateTarget).off(i.namespace?i.origType+"."+i.namespace:i.origType,i.selector,i.handler),this;if("object"==typeof e){for(o in e)this.off(o,n,e[o]);return this}return(n===!1||"function"==typeof n)&&(r=n,n=t),r===!1&&(r=ot),this.each(function(){b.event.remove(this,e,r,n)})},bind:function(e,t,n){return this.on(e,null,t,n)},unbind:function(e,t){return this.off(e,null,t)},delegate:function(e,t,n,r){return this.on(t,e,n,r)},undelegate:function(e,t,n){return 1===arguments.length?this.off(e,"**"):this.off(t,e||"**",n)},trigger:function(e,t){return this.each(function(){b.event.trigger(e,t,this)})},triggerHandler:function(e,n){var r=this[0];return r?b.event.trigger(e,n,r,!0):t}}),function(e,t){var n,r,i,o,a,s,u,l,c,p,f,d,h,g,m,y,v,x="sizzle"+-new Date,w=e.document,T={},N=0,C=0,k=it(),E=it(),S=it(),A=typeof t,j=1<<31,D=[],L=D.pop,H=D.push,q=D.slice,M=D.indexOf||function(e){var t=0,n=this.length;for(;n>t;t++)if(this[t]===e)return t;return-1},_="[\\x20\\t\\r\\n\\f]",F="(?:\\\\.|[\\w-]|[^\\x00-\\xa0])+",O=F.replace("w","w#"),B="([*^$|!~]?=)",P="\\["+_+"*("+F+")"+_+"*(?:"+B+_+"*(?:(['\"])((?:\\\\.|[^\\\\])*?)\\3|("+O+")|)|)"+_+"*\\]",R=":("+F+")(?:\\(((['\"])((?:\\\\.|[^\\\\])*?)\\3|((?:\\\\.|[^\\\\()[\\]]|"+P.replace(3,8)+")*)|.*)\\)|)",W=RegExp("^"+_+"+|((?:^|[^\\\\])(?:\\\\.)*)"+_+"+$","g"),$=RegExp("^"+_+"*,"+_+"*"),I=RegExp("^"+_+"*([\\x20\\t\\r\\n\\f>+~])"+_+"*"),z=RegExp(R),X=RegExp("^"+O+"$"),U={ID:RegExp("^#("+F+")"),CLASS:RegExp("^\\.("+F+")"),NAME:RegExp("^\\[name=['\"]?("+F+")['\"]?\\]"),TAG:RegExp("^("+F.replace("w","w*")+")"),ATTR:RegExp("^"+P),PSEUDO:RegExp("^"+R),CHILD:RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\("+_+"*(even|odd|(([+-]|)(\\d*)n|)"+_+"*(?:([+-]|)"+_+"*(\\d+)|))"+_+"*\\)|)","i"),needsContext:RegExp("^"+_+"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\("+_+"*((?:-\\d)?\\d*)"+_+"*\\)|)(?=[^-]|$)","i")},V=/[\x20\t\r\n\f]*[+~]/,Y=/^[^{]+\{\s*\[native code/,J=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,G=/^(?:input|select|textarea|button)$/i,Q=/^h\d$/i,K=/'|\\/g,Z=/\=[\x20\t\r\n\f]*([^'"\]]*)[\x20\t\r\n\f]*\]/g,et=/\\([\da-fA-F]{1,6}[\x20\t\r\n\f]?|.)/g,tt=function(e,t){var n="0x"+t-65536;return n!==n?t:0>n?String.fromCharCode(n+65536):String.fromCharCode(55296|n>>10,56320|1023&n)};try{q.call(w.documentElement.childNodes,0)[0].nodeType}catch(nt){q=function(e){var t,n=[];while(t=this[e++])n.push(t);return n}}function rt(e){return Y.test(e+"")}function it(){var e,t=[];return e=function(n,r){return t.push(n+=" ")>i.cacheLength&&delete e[t.shift()],e[n]=r}}function ot(e){return e[x]=!0,e}function at(e){var t=p.createElement("div");try{return e(t)}catch(n){return!1}finally{t=null}}function st(e,t,n,r){var i,o,a,s,u,l,f,g,m,v;if((t?t.ownerDocument||t:w)!==p&&c(t),t=t||p,n=n||[],!e||"string"!=typeof e)return n;if(1!==(s=t.nodeType)&&9!==s)return[];if(!d&&!r){if(i=J.exec(e))if(a=i[1]){if(9===s){if(o=t.getElementById(a),!o||!o.parentNode)return n;if(o.id===a)return n.push(o),n}else if(t.ownerDocument&&(o=t.ownerDocument.getElementById(a))&&y(t,o)&&o.id===a)return n.push(o),n}else{if(i[2])return H.apply(n,q.call(t.getElementsByTagName(e),0)),n;if((a=i[3])&&T.getByClassName&&t.getElementsByClassName)return H.apply(n,q.call(t.getElementsByClassName(a),0)),n}if(T.qsa&&!h.test(e)){if(f=!0,g=x,m=t,v=9===s&&e,1===s&&"object"!==t.nodeName.toLowerCase()){l=ft(e),(f=t.getAttribute("id"))?g=f.replace(K,"\\$&"):t.setAttribute("id",g),g="[id='"+g+"'] ",u=l.length;while(u--)l[u]=g+dt(l[u]);m=V.test(e)&&t.parentNode||t,v=l.join(",")}if(v)try{return H.apply(n,q.call(m.querySelectorAll(v),0)),n}catch(b){}finally{f||t.removeAttribute("id")}}}return wt(e.replace(W,"$1"),t,n,r)}a=st.isXML=function(e){var t=e&&(e.ownerDocument||e).documentElement;return t?"HTML"!==t.nodeName:!1},c=st.setDocument=function(e){var n=e?e.ownerDocument||e:w;return n!==p&&9===n.nodeType&&n.documentElement?(p=n,f=n.documentElement,d=a(n),T.tagNameNoComments=at(function(e){return e.appendChild(n.createComment("")),!e.getElementsByTagName("*").length}),T.attributes=at(function(e){e.innerHTML="<select></select>";var t=typeof e.lastChild.getAttribute("multiple");return"boolean"!==t&&"string"!==t}),T.getByClassName=at(function(e){return e.innerHTML="<div class='hidden e'></div><div class='hidden'></div>",e.getElementsByClassName&&e.getElementsByClassName("e").length?(e.lastChild.className="e",2===e.getElementsByClassName("e").length):!1}),T.getByName=at(function(e){e.id=x+0,e.innerHTML="<a name='"+x+"'></a><div name='"+x+"'></div>",f.insertBefore(e,f.firstChild);var t=n.getElementsByName&&n.getElementsByName(x).length===2+n.getElementsByName(x+0).length;return T.getIdNotName=!n.getElementById(x),f.removeChild(e),t}),i.attrHandle=at(function(e){return e.innerHTML="<a href='#'></a>",e.firstChild&&typeof e.firstChild.getAttribute!==A&&"#"===e.firstChild.getAttribute("href")})?{}:{href:function(e){return e.getAttribute("href",2)},type:function(e){return e.getAttribute("type")}},T.getIdNotName?(i.find.ID=function(e,t){if(typeof t.getElementById!==A&&!d){var n=t.getElementById(e);return n&&n.parentNode?[n]:[]}},i.filter.ID=function(e){var t=e.replace(et,tt);return function(e){return e.getAttribute("id")===t}}):(i.find.ID=function(e,n){if(typeof n.getElementById!==A&&!d){var r=n.getElementById(e);return r?r.id===e||typeof r.getAttributeNode!==A&&r.getAttributeNode("id").value===e?[r]:t:[]}},i.filter.ID=function(e){var t=e.replace(et,tt);return function(e){var n=typeof e.getAttributeNode!==A&&e.getAttributeNode("id");return n&&n.value===t}}),i.find.TAG=T.tagNameNoComments?function(e,n){return typeof n.getElementsByTagName!==A?n.getElementsByTagName(e):t}:function(e,t){var n,r=[],i=0,o=t.getElementsByTagName(e);if("*"===e){while(n=o[i++])1===n.nodeType&&r.push(n);return r}return o},i.find.NAME=T.getByName&&function(e,n){return typeof n.getElementsByName!==A?n.getElementsByName(name):t},i.find.CLASS=T.getByClassName&&function(e,n){return typeof n.getElementsByClassName===A||d?t:n.getElementsByClassName(e)},g=[],h=[":focus"],(T.qsa=rt(n.querySelectorAll))&&(at(function(e){e.innerHTML="<select><option selected=''></option></select>",e.querySelectorAll("[selected]").length||h.push("\\["+_+"*(?:checked|disabled|ismap|multiple|readonly|selected|value)"),e.querySelectorAll(":checked").length||h.push(":checked")}),at(function(e){e.innerHTML="<input type='hidden' i=''/>",e.querySelectorAll("[i^='']").length&&h.push("[*^$]="+_+"*(?:\"\"|'')"),e.querySelectorAll(":enabled").length||h.push(":enabled",":disabled"),e.querySelectorAll("*,:x"),h.push(",.*:")})),(T.matchesSelector=rt(m=f.matchesSelector||f.mozMatchesSelector||f.webkitMatchesSelector||f.oMatchesSelector||f.msMatchesSelector))&&at(function(e){T.disconnectedMatch=m.call(e,"div"),m.call(e,"[s!='']:x"),g.push("!=",R)}),h=RegExp(h.join("|")),g=RegExp(g.join("|")),y=rt(f.contains)||f.compareDocumentPosition?function(e,t){var n=9===e.nodeType?e.documentElement:e,r=t&&t.parentNode;return e===r||!(!r||1!==r.nodeType||!(n.contains?n.contains(r):e.compareDocumentPosition&&16&e.compareDocumentPosition(r)))}:function(e,t){if(t)while(t=t.parentNode)if(t===e)return!0;return!1},v=f.compareDocumentPosition?function(e,t){var r;return e===t?(u=!0,0):(r=t.compareDocumentPosition&&e.compareDocumentPosition&&e.compareDocumentPosition(t))?1&r||e.parentNode&&11===e.parentNode.nodeType?e===n||y(w,e)?-1:t===n||y(w,t)?1:0:4&r?-1:1:e.compareDocumentPosition?-1:1}:function(e,t){var r,i=0,o=e.parentNode,a=t.parentNode,s=[e],l=[t];if(e===t)return u=!0,0;if(!o||!a)return e===n?-1:t===n?1:o?-1:a?1:0;if(o===a)return ut(e,t);r=e;while(r=r.parentNode)s.unshift(r);r=t;while(r=r.parentNode)l.unshift(r);while(s[i]===l[i])i++;return i?ut(s[i],l[i]):s[i]===w?-1:l[i]===w?1:0},u=!1,[0,0].sort(v),T.detectDuplicates=u,p):p},st.matches=function(e,t){return st(e,null,null,t)},st.matchesSelector=function(e,t){if((e.ownerDocument||e)!==p&&c(e),t=t.replace(Z,"='$1']"),!(!T.matchesSelector||d||g&&g.test(t)||h.test(t)))try{var n=m.call(e,t);if(n||T.disconnectedMatch||e.document&&11!==e.document.nodeType)return n}catch(r){}return st(t,p,null,[e]).length>0},st.contains=function(e,t){return(e.ownerDocument||e)!==p&&c(e),y(e,t)},st.attr=function(e,t){var n;return(e.ownerDocument||e)!==p&&c(e),d||(t=t.toLowerCase()),(n=i.attrHandle[t])?n(e):d||T.attributes?e.getAttribute(t):((n=e.getAttributeNode(t))||e.getAttribute(t))&&e[t]===!0?t:n&&n.specified?n.value:null},st.error=function(e){throw Error("Syntax error, unrecognized expression: "+e)},st.uniqueSort=function(e){var t,n=[],r=1,i=0;if(u=!T.detectDuplicates,e.sort(v),u){for(;t=e[r];r++)t===e[r-1]&&(i=n.push(r));while(i--)e.splice(n[i],1)}return e};function ut(e,t){var n=t&&e,r=n&&(~t.sourceIndex||j)-(~e.sourceIndex||j);if(r)return r;if(n)while(n=n.nextSibling)if(n===t)return-1;return e?1:-1}function lt(e){return function(t){var n=t.nodeName.toLowerCase();return"input"===n&&t.type===e}}function ct(e){return function(t){var n=t.nodeName.toLowerCase();return("input"===n||"button"===n)&&t.type===e}}function pt(e){return ot(function(t){return t=+t,ot(function(n,r){var i,o=e([],n.length,t),a=o.length;while(a--)n[i=o[a]]&&(n[i]=!(r[i]=n[i]))})})}o=st.getText=function(e){var t,n="",r=0,i=e.nodeType;if(i){if(1===i||9===i||11===i){if("string"==typeof e.textContent)return e.textContent;for(e=e.firstChild;e;e=e.nextSibling)n+=o(e)}else if(3===i||4===i)return e.nodeValue}else for(;t=e[r];r++)n+=o(t);return n},i=st.selectors={cacheLength:50,createPseudo:ot,match:U,find:{},relative:{">":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(e){return e[1]=e[1].replace(et,tt),e[3]=(e[4]||e[5]||"").replace(et,tt),"~="===e[2]&&(e[3]=" "+e[3]+" "),e.slice(0,4)},CHILD:function(e){return e[1]=e[1].toLowerCase(),"nth"===e[1].slice(0,3)?(e[3]||st.error(e[0]),e[4]=+(e[4]?e[5]+(e[6]||1):2*("even"===e[3]||"odd"===e[3])),e[5]=+(e[7]+e[8]||"odd"===e[3])):e[3]&&st.error(e[0]),e},PSEUDO:function(e){var t,n=!e[5]&&e[2];return U.CHILD.test(e[0])?null:(e[4]?e[2]=e[4]:n&&z.test(n)&&(t=ft(n,!0))&&(t=n.indexOf(")",n.length-t)-n.length)&&(e[0]=e[0].slice(0,t),e[2]=n.slice(0,t)),e.slice(0,3))}},filter:{TAG:function(e){return"*"===e?function(){return!0}:(e=e.replace(et,tt).toLowerCase(),function(t){return t.nodeName&&t.nodeName.toLowerCase()===e})},CLASS:function(e){var t=k[e+" "];return t||(t=RegExp("(^|"+_+")"+e+"("+_+"|$)"))&&k(e,function(e){return t.test(e.className||typeof e.getAttribute!==A&&e.getAttribute("class")||"")})},ATTR:function(e,t,n){return function(r){var i=st.attr(r,e);return null==i?"!="===t:t?(i+="","="===t?i===n:"!="===t?i!==n:"^="===t?n&&0===i.indexOf(n):"*="===t?n&&i.indexOf(n)>-1:"$="===t?n&&i.slice(-n.length)===n:"~="===t?(" "+i+" ").indexOf(n)>-1:"|="===t?i===n||i.slice(0,n.length+1)===n+"-":!1):!0}},CHILD:function(e,t,n,r,i){var o="nth"!==e.slice(0,3),a="last"!==e.slice(-4),s="of-type"===t;return 1===r&&0===i?function(e){return!!e.parentNode}:function(t,n,u){var l,c,p,f,d,h,g=o!==a?"nextSibling":"previousSibling",m=t.parentNode,y=s&&t.nodeName.toLowerCase(),v=!u&&!s;if(m){if(o){while(g){p=t;while(p=p[g])if(s?p.nodeName.toLowerCase()===y:1===p.nodeType)return!1;h=g="only"===e&&!h&&"nextSibling"}return!0}if(h=[a?m.firstChild:m.lastChild],a&&v){c=m[x]||(m[x]={}),l=c[e]||[],d=l[0]===N&&l[1],f=l[0]===N&&l[2],p=d&&m.childNodes[d];while(p=++d&&p&&p[g]||(f=d=0)||h.pop())if(1===p.nodeType&&++f&&p===t){c[e]=[N,d,f];break}}else if(v&&(l=(t[x]||(t[x]={}))[e])&&l[0]===N)f=l[1];else while(p=++d&&p&&p[g]||(f=d=0)||h.pop())if((s?p.nodeName.toLowerCase()===y:1===p.nodeType)&&++f&&(v&&((p[x]||(p[x]={}))[e]=[N,f]),p===t))break;return f-=i,f===r||0===f%r&&f/r>=0}}},PSEUDO:function(e,t){var n,r=i.pseudos[e]||i.setFilters[e.toLowerCase()]||st.error("unsupported pseudo: "+e);return r[x]?r(t):r.length>1?(n=[e,e,"",t],i.setFilters.hasOwnProperty(e.toLowerCase())?ot(function(e,n){var i,o=r(e,t),a=o.length;while(a--)i=M.call(e,o[a]),e[i]=!(n[i]=o[a])}):function(e){return r(e,0,n)}):r}},pseudos:{not:ot(function(e){var t=[],n=[],r=s(e.replace(W,"$1"));return r[x]?ot(function(e,t,n,i){var o,a=r(e,null,i,[]),s=e.length;while(s--)(o=a[s])&&(e[s]=!(t[s]=o))}):function(e,i,o){return t[0]=e,r(t,null,o,n),!n.pop()}}),has:ot(function(e){return function(t){return st(e,t).length>0}}),contains:ot(function(e){return function(t){return(t.textContent||t.innerText||o(t)).indexOf(e)>-1}}),lang:ot(function(e){return X.test(e||"")||st.error("unsupported lang: "+e),e=e.replace(et,tt).toLowerCase(),function(t){var n;do if(n=d?t.getAttribute("xml:lang")||t.getAttribute("lang"):t.lang)return n=n.toLowerCase(),n===e||0===n.indexOf(e+"-");while((t=t.parentNode)&&1===t.nodeType);return!1}}),target:function(t){var n=e.location&&e.location.hash;return n&&n.slice(1)===t.id},root:function(e){return e===f},focus:function(e){return e===p.activeElement&&(!p.hasFocus||p.hasFocus())&&!!(e.type||e.href||~e.tabIndex)},enabled:function(e){return e.disabled===!1},disabled:function(e){return e.disabled===!0},checked:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&!!e.checked||"option"===t&&!!e.selected},selected:function(e){return e.parentNode&&e.parentNode.selectedIndex,e.selected===!0},empty:function(e){for(e=e.firstChild;e;e=e.nextSibling)if(e.nodeName>"@"||3===e.nodeType||4===e.nodeType)return!1;return!0},parent:function(e){return!i.pseudos.empty(e)},header:function(e){return Q.test(e.nodeName)},input:function(e){return G.test(e.nodeName)},button:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&"button"===e.type||"button"===t},text:function(e){var t;return"input"===e.nodeName.toLowerCase()&&"text"===e.type&&(null==(t=e.getAttribute("type"))||t.toLowerCase()===e.type)},first:pt(function(){return[0]}),last:pt(function(e,t){return[t-1]}),eq:pt(function(e,t,n){return[0>n?n+t:n]}),even:pt(function(e,t){var n=0;for(;t>n;n+=2)e.push(n);return e}),odd:pt(function(e,t){var n=1;for(;t>n;n+=2)e.push(n);return e}),lt:pt(function(e,t,n){var r=0>n?n+t:n;for(;--r>=0;)e.push(r);return e}),gt:pt(function(e,t,n){var r=0>n?n+t:n;for(;t>++r;)e.push(r);return e})}};for(n in{radio:!0,checkbox:!0,file:!0,password:!0,image:!0})i.pseudos[n]=lt(n);for(n in{submit:!0,reset:!0})i.pseudos[n]=ct(n);function ft(e,t){var n,r,o,a,s,u,l,c=E[e+" "];if(c)return t?0:c.slice(0);s=e,u=[],l=i.preFilter;while(s){(!n||(r=$.exec(s)))&&(r&&(s=s.slice(r[0].length)||s),u.push(o=[])),n=!1,(r=I.exec(s))&&(n=r.shift(),o.push({value:n,type:r[0].replace(W," ")}),s=s.slice(n.length));for(a in i.filter)!(r=U[a].exec(s))||l[a]&&!(r=l[a](r))||(n=r.shift(),o.push({value:n,type:a,matches:r}),s=s.slice(n.length));if(!n)break}return t?s.length:s?st.error(e):E(e,u).slice(0)}function dt(e){var t=0,n=e.length,r="";for(;n>t;t++)r+=e[t].value;return r}function ht(e,t,n){var i=t.dir,o=n&&"parentNode"===i,a=C++;return t.first?function(t,n,r){while(t=t[i])if(1===t.nodeType||o)return e(t,n,r)}:function(t,n,s){var u,l,c,p=N+" "+a;if(s){while(t=t[i])if((1===t.nodeType||o)&&e(t,n,s))return!0}else while(t=t[i])if(1===t.nodeType||o)if(c=t[x]||(t[x]={}),(l=c[i])&&l[0]===p){if((u=l[1])===!0||u===r)return u===!0}else if(l=c[i]=[p],l[1]=e(t,n,s)||r,l[1]===!0)return!0}}function gt(e){return e.length>1?function(t,n,r){var i=e.length;while(i--)if(!e[i](t,n,r))return!1;return!0}:e[0]}function mt(e,t,n,r,i){var o,a=[],s=0,u=e.length,l=null!=t;for(;u>s;s++)(o=e[s])&&(!n||n(o,r,i))&&(a.push(o),l&&t.push(s));return a}function yt(e,t,n,r,i,o){return r&&!r[x]&&(r=yt(r)),i&&!i[x]&&(i=yt(i,o)),ot(function(o,a,s,u){var l,c,p,f=[],d=[],h=a.length,g=o||xt(t||"*",s.nodeType?[s]:s,[]),m=!e||!o&&t?g:mt(g,f,e,s,u),y=n?i||(o?e:h||r)?[]:a:m;if(n&&n(m,y,s,u),r){l=mt(y,d),r(l,[],s,u),c=l.length;while(c--)(p=l[c])&&(y[d[c]]=!(m[d[c]]=p))}if(o){if(i||e){if(i){l=[],c=y.length;while(c--)(p=y[c])&&l.push(m[c]=p);i(null,y=[],l,u)}c=y.length;while(c--)(p=y[c])&&(l=i?M.call(o,p):f[c])>-1&&(o[l]=!(a[l]=p))}}else y=mt(y===a?y.splice(h,y.length):y),i?i(null,a,y,u):H.apply(a,y)})}function vt(e){var t,n,r,o=e.length,a=i.relative[e[0].type],s=a||i.relative[" "],u=a?1:0,c=ht(function(e){return e===t},s,!0),p=ht(function(e){return M.call(t,e)>-1},s,!0),f=[function(e,n,r){return!a&&(r||n!==l)||((t=n).nodeType?c(e,n,r):p(e,n,r))}];for(;o>u;u++)if(n=i.relative[e[u].type])f=[ht(gt(f),n)];else{if(n=i.filter[e[u].type].apply(null,e[u].matches),n[x]){for(r=++u;o>r;r++)if(i.relative[e[r].type])break;return yt(u>1&&gt(f),u>1&&dt(e.slice(0,u-1)).replace(W,"$1"),n,r>u&&vt(e.slice(u,r)),o>r&&vt(e=e.slice(r)),o>r&&dt(e))}f.push(n)}return gt(f)}function bt(e,t){var n=0,o=t.length>0,a=e.length>0,s=function(s,u,c,f,d){var h,g,m,y=[],v=0,b="0",x=s&&[],w=null!=d,T=l,C=s||a&&i.find.TAG("*",d&&u.parentNode||u),k=N+=null==T?1:Math.random()||.1;for(w&&(l=u!==p&&u,r=n);null!=(h=C[b]);b++){if(a&&h){g=0;while(m=e[g++])if(m(h,u,c)){f.push(h);break}w&&(N=k,r=++n)}o&&((h=!m&&h)&&v--,s&&x.push(h))}if(v+=b,o&&b!==v){g=0;while(m=t[g++])m(x,y,u,c);if(s){if(v>0)while(b--)x[b]||y[b]||(y[b]=L.call(f));y=mt(y)}H.apply(f,y),w&&!s&&y.length>0&&v+t.length>1&&st.uniqueSort(f)}return w&&(N=k,l=T),x};return o?ot(s):s}s=st.compile=function(e,t){var n,r=[],i=[],o=S[e+" "];if(!o){t||(t=ft(e)),n=t.length;while(n--)o=vt(t[n]),o[x]?r.push(o):i.push(o);o=S(e,bt(i,r))}return o};function xt(e,t,n){var r=0,i=t.length;for(;i>r;r++)st(e,t[r],n);return n}function wt(e,t,n,r){var o,a,u,l,c,p=ft(e);if(!r&&1===p.length){if(a=p[0]=p[0].slice(0),a.length>2&&"ID"===(u=a[0]).type&&9===t.nodeType&&!d&&i.relative[a[1].type]){if(t=i.find.ID(u.matches[0].replace(et,tt),t)[0],!t)return n;e=e.slice(a.shift().value.length)}o=U.needsContext.test(e)?0:a.length;while(o--){if(u=a[o],i.relative[l=u.type])break;if((c=i.find[l])&&(r=c(u.matches[0].replace(et,tt),V.test(a[0].type)&&t.parentNode||t))){if(a.splice(o,1),e=r.length&&dt(a),!e)return H.apply(n,q.call(r,0)),n;break}}}return s(e,p)(r,t,d,n,V.test(e)),n}i.pseudos.nth=i.pseudos.eq;function Tt(){}i.filters=Tt.prototype=i.pseudos,i.setFilters=new Tt,c(),st.attr=b.attr,b.find=st,b.expr=st.selectors,b.expr[":"]=b.expr.pseudos,b.unique=st.uniqueSort,b.text=st.getText,b.isXMLDoc=st.isXML,b.contains=st.contains}(e);var at=/Until$/,st=/^(?:parents|prev(?:Until|All))/,ut=/^.[^:#\[\.,]*$/,lt=b.expr.match.needsContext,ct={children:!0,contents:!0,next:!0,prev:!0};b.fn.extend({find:function(e){var t,n,r,i=this.length;if("string"!=typeof e)return r=this,this.pushStack(b(e).filter(function(){for(t=0;i>t;t++)if(b.contains(r[t],this))return!0}));for(n=[],t=0;i>t;t++)b.find(e,this[t],n);return n=this.pushStack(i>1?b.unique(n):n),n.selector=(this.selector?this.selector+" ":"")+e,n},has:function(e){var t,n=b(e,this),r=n.length;return this.filter(function(){for(t=0;r>t;t++)if(b.contains(this,n[t]))return!0})},not:function(e){return this.pushStack(ft(this,e,!1))},filter:function(e){return this.pushStack(ft(this,e,!0))},is:function(e){return!!e&&("string"==typeof e?lt.test(e)?b(e,this.context).index(this[0])>=0:b.filter(e,this).length>0:this.filter(e).length>0)},closest:function(e,t){var n,r=0,i=this.length,o=[],a=lt.test(e)||"string"!=typeof e?b(e,t||this.context):0;for(;i>r;r++){n=this[r];while(n&&n.ownerDocument&&n!==t&&11!==n.nodeType){if(a?a.index(n)>-1:b.find.matchesSelector(n,e)){o.push(n);break}n=n.parentNode}}return this.pushStack(o.length>1?b.unique(o):o)},index:function(e){return e?"string"==typeof e?b.inArray(this[0],b(e)):b.inArray(e.jquery?e[0]:e,this):this[0]&&this[0].parentNode?this.first().prevAll().length:-1},add:function(e,t){var n="string"==typeof e?b(e,t):b.makeArray(e&&e.nodeType?[e]:e),r=b.merge(this.get(),n);return this.pushStack(b.unique(r))},addBack:function(e){return this.add(null==e?this.prevObject:this.prevObject.filter(e))}}),b.fn.andSelf=b.fn.addBack;function pt(e,t){do e=e[t];while(e&&1!==e.nodeType);return e}b.each({parent:function(e){var t=e.parentNode;return t&&11!==t.nodeType?t:null},parents:function(e){return b.dir(e,"parentNode")},parentsUntil:function(e,t,n){return b.dir(e,"parentNode",n)},next:function(e){return pt(e,"nextSibling")},prev:function(e){return pt(e,"previousSibling")},nextAll:function(e){return b.dir(e,"nextSibling")},prevAll:function(e){return b.dir(e,"previousSibling")},nextUntil:function(e,t,n){return b.dir(e,"nextSibling",n)},prevUntil:function(e,t,n){return b.dir(e,"previousSibling",n)},siblings:function(e){return b.sibling((e.parentNode||{}).firstChild,e)},children:function(e){return b.sibling(e.firstChild)},contents:function(e){return b.nodeName(e,"iframe")?e.contentDocument||e.contentWindow.document:b.merge([],e.childNodes)}},function(e,t){b.fn[e]=function(n,r){var i=b.map(this,t,n);return at.test(e)||(r=n),r&&"string"==typeof r&&(i=b.filter(r,i)),i=this.length>1&&!ct[e]?b.unique(i):i,this.length>1&&st.test(e)&&(i=i.reverse()),this.pushStack(i)}}),b.extend({filter:function(e,t,n){return n&&(e=":not("+e+")"),1===t.length?b.find.matchesSelector(t[0],e)?[t[0]]:[]:b.find.matches(e,t)},dir:function(e,n,r){var i=[],o=e[n];while(o&&9!==o.nodeType&&(r===t||1!==o.nodeType||!b(o).is(r)))1===o.nodeType&&i.push(o),o=o[n];return i},sibling:function(e,t){var n=[];for(;e;e=e.nextSibling)1===e.nodeType&&e!==t&&n.push(e);return n}});function ft(e,t,n){if(t=t||0,b.isFunction(t))return b.grep(e,function(e,r){var i=!!t.call(e,r,e);return i===n});if(t.nodeType)return b.grep(e,function(e){return e===t===n});if("string"==typeof t){var r=b.grep(e,function(e){return 1===e.nodeType});if(ut.test(t))return b.filter(t,r,!n);t=b.filter(t,r)}return b.grep(e,function(e){return b.inArray(e,t)>=0===n})}function dt(e){var t=ht.split("|"),n=e.createDocumentFragment();if(n.createElement)while(t.length)n.createElement(t.pop());return n}var ht="abbr|article|aside|audio|bdi|canvas|data|datalist|details|figcaption|figure|footer|header|hgroup|mark|meter|nav|output|progress|section|summary|time|video",gt=/ jQuery\d+="(?:null|\d+)"/g,mt=RegExp("<(?:"+ht+")[\\s/>]","i"),yt=/^\s+/,vt=/<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\w:]+)[^>]*)\/>/gi,bt=/<([\w:]+)/,xt=/<tbody/i,wt=/<|&#?\w+;/,Tt=/<(?:script|style|link)/i,Nt=/^(?:checkbox|radio)$/i,Ct=/checked\s*(?:[^=]|=\s*.checked.)/i,kt=/^$|\/(?:java|ecma)script/i,Et=/^true\/(.*)/,St=/^\s*<!(?:\[CDATA\[|--)|(?:\]\]|--)>\s*$/g,At={option:[1,"<select multiple='multiple'>","</select>"],legend:[1,"<fieldset>","</fieldset>"],area:[1,"<map>","</map>"],param:[1,"<object>","</object>"],thead:[1,"<table>","</table>"],tr:[2,"<table><tbody>","</tbody></table>"],col:[2,"<table><tbody></tbody><colgroup>","</colgroup></table>"],td:[3,"<table><tbody><tr>","</tr></tbody></table>"],_default:b.support.htmlSerialize?[0,"",""]:[1,"X<div>","</div>"]},jt=dt(o),Dt=jt.appendChild(o.createElement("div"));At.optgroup=At.option,At.tbody=At.tfoot=At.colgroup=At.caption=At.thead,At.th=At.td,b.fn.extend({text:function(e){return b.access(this,function(e){return e===t?b.text(this):this.empty().append((this[0]&&this[0].ownerDocument||o).createTextNode(e))},null,e,arguments.length)},wrapAll:function(e){if(b.isFunction(e))return this.each(function(t){b(this).wrapAll(e.call(this,t))});if(this[0]){var t=b(e,this[0].ownerDocument).eq(0).clone(!0);this[0].parentNode&&t.insertBefore(this[0]),t.map(function(){var e=this;while(e.firstChild&&1===e.firstChild.nodeType)e=e.firstChild;return e}).append(this)}return this},wrapInner:function(e){return b.isFunction(e)?this.each(function(t){b(this).wrapInner(e.call(this,t))}):this.each(function(){var t=b(this),n=t.contents();n.length?n.wrapAll(e):t.append(e)})},wrap:function(e){var t=b.isFunction(e);return this.each(function(n){b(this).wrapAll(t?e.call(this,n):e)})},unwrap:function(){return this.parent().each(function(){b.nodeName(this,"body")||b(this).replaceWith(this.childNodes)}).end()},append:function(){return this.domManip(arguments,!0,function(e){(1===this.nodeType||11===this.nodeType||9===this.nodeType)&&this.appendChild(e)})},prepend:function(){return this.domManip(arguments,!0,function(e){(1===this.nodeType||11===this.nodeType||9===this.nodeType)&&this.insertBefore(e,this.firstChild)})},before:function(){return this.domManip(arguments,!1,function(e){this.parentNode&&this.parentNode.insertBefore(e,this)})},after:function(){return this.domManip(arguments,!1,function(e){this.parentNode&&this.parentNode.insertBefore(e,this.nextSibling)})},remove:function(e,t){var n,r=0;for(;null!=(n=this[r]);r++)(!e||b.filter(e,[n]).length>0)&&(t||1!==n.nodeType||b.cleanData(Ot(n)),n.parentNode&&(t&&b.contains(n.ownerDocument,n)&&Mt(Ot(n,"script")),n.parentNode.removeChild(n)));return this},empty:function(){var e,t=0;for(;null!=(e=this[t]);t++){1===e.nodeType&&b.cleanData(Ot(e,!1));while(e.firstChild)e.removeChild(e.firstChild);e.options&&b.nodeName(e,"select")&&(e.options.length=0)}return this},clone:function(e,t){return e=null==e?!1:e,t=null==t?e:t,this.map(function(){return b.clone(this,e,t)})},html:function(e){return b.access(this,function(e){var n=this[0]||{},r=0,i=this.length;if(e===t)return 1===n.nodeType?n.innerHTML.replace(gt,""):t;if(!("string"!=typeof e||Tt.test(e)||!b.support.htmlSerialize&&mt.test(e)||!b.support.leadingWhitespace&&yt.test(e)||At[(bt.exec(e)||["",""])[1].toLowerCase()])){e=e.replace(vt,"<$1></$2>");try{for(;i>r;r++)n=this[r]||{},1===n.nodeType&&(b.cleanData(Ot(n,!1)),n.innerHTML=e);n=0}catch(o){}}n&&this.empty().append(e)},null,e,arguments.length)},replaceWith:function(e){var t=b.isFunction(e);return t||"string"==typeof e||(e=b(e).not(this).detach()),this.domManip([e],!0,function(e){var t=this.nextSibling,n=this.parentNode;n&&(b(this).remove(),n.insertBefore(e,t))})},detach:function(e){return this.remove(e,!0)},domManip:function(e,n,r){e=f.apply([],e);var i,o,a,s,u,l,c=0,p=this.length,d=this,h=p-1,g=e[0],m=b.isFunction(g);if(m||!(1>=p||"string"!=typeof g||b.support.checkClone)&&Ct.test(g))return this.each(function(i){var o=d.eq(i);m&&(e[0]=g.call(this,i,n?o.html():t)),o.domManip(e,n,r)});if(p&&(l=b.buildFragment(e,this[0].ownerDocument,!1,this),i=l.firstChild,1===l.childNodes.length&&(l=i),i)){for(n=n&&b.nodeName(i,"tr"),s=b.map(Ot(l,"script"),Ht),a=s.length;p>c;c++)o=l,c!==h&&(o=b.clone(o,!0,!0),a&&b.merge(s,Ot(o,"script"))),r.call(n&&b.nodeName(this[c],"table")?Lt(this[c],"tbody"):this[c],o,c);if(a)for(u=s[s.length-1].ownerDocument,b.map(s,qt),c=0;a>c;c++)o=s[c],kt.test(o.type||"")&&!b._data(o,"globalEval")&&b.contains(u,o)&&(o.src?b.ajax({url:o.src,type:"GET",dataType:"script",async:!1,global:!1,"throws":!0}):b.globalEval((o.text||o.textContent||o.innerHTML||"").replace(St,"")));l=i=null}return this}});function Lt(e,t){return e.getElementsByTagName(t)[0]||e.appendChild(e.ownerDocument.createElement(t))}function Ht(e){var t=e.getAttributeNode("type");return e.type=(t&&t.specified)+"/"+e.type,e}function qt(e){var t=Et.exec(e.type);return t?e.type=t[1]:e.removeAttribute("type"),e}function Mt(e,t){var n,r=0;for(;null!=(n=e[r]);r++)b._data(n,"globalEval",!t||b._data(t[r],"globalEval"))}function _t(e,t){if(1===t.nodeType&&b.hasData(e)){var n,r,i,o=b._data(e),a=b._data(t,o),s=o.events;if(s){delete a.handle,a.events={};for(n in s)for(r=0,i=s[n].length;i>r;r++)b.event.add(t,n,s[n][r])}a.data&&(a.data=b.extend({},a.data))}}function Ft(e,t){var n,r,i;if(1===t.nodeType){if(n=t.nodeName.toLowerCase(),!b.support.noCloneEvent&&t[b.expando]){i=b._data(t);for(r in i.events)b.removeEvent(t,r,i.handle);t.removeAttribute(b.expando)}"script"===n&&t.text!==e.text?(Ht(t).text=e.text,qt(t)):"object"===n?(t.parentNode&&(t.outerHTML=e.outerHTML),b.support.html5Clone&&e.innerHTML&&!b.trim(t.innerHTML)&&(t.innerHTML=e.innerHTML)):"input"===n&&Nt.test(e.type)?(t.defaultChecked=t.checked=e.checked,t.value!==e.value&&(t.value=e.value)):"option"===n?t.defaultSelected=t.selected=e.defaultSelected:("input"===n||"textarea"===n)&&(t.defaultValue=e.defaultValue)}}b.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},function(e,t){b.fn[e]=function(e){var n,r=0,i=[],o=b(e),a=o.length-1;for(;a>=r;r++)n=r===a?this:this.clone(!0),b(o[r])[t](n),d.apply(i,n.get());return this.pushStack(i)}});function Ot(e,n){var r,o,a=0,s=typeof e.getElementsByTagName!==i?e.getElementsByTagName(n||"*"):typeof e.querySelectorAll!==i?e.querySelectorAll(n||"*"):t;if(!s)for(s=[],r=e.childNodes||e;null!=(o=r[a]);a++)!n||b.nodeName(o,n)?s.push(o):b.merge(s,Ot(o,n));return n===t||n&&b.nodeName(e,n)?b.merge([e],s):s}function Bt(e){Nt.test(e.type)&&(e.defaultChecked=e.checked)}b.extend({clone:function(e,t,n){var r,i,o,a,s,u=b.contains(e.ownerDocument,e);if(b.support.html5Clone||b.isXMLDoc(e)||!mt.test("<"+e.nodeName+">")?o=e.cloneNode(!0):(Dt.innerHTML=e.outerHTML,Dt.removeChild(o=Dt.firstChild)),!(b.support.noCloneEvent&&b.support.noCloneChecked||1!==e.nodeType&&11!==e.nodeType||b.isXMLDoc(e)))for(r=Ot(o),s=Ot(e),a=0;null!=(i=s[a]);++a)r[a]&&Ft(i,r[a]);if(t)if(n)for(s=s||Ot(e),r=r||Ot(o),a=0;null!=(i=s[a]);a++)_t(i,r[a]);else _t(e,o);return r=Ot(o,"script"),r.length>0&&Mt(r,!u&&Ot(e,"script")),r=s=i=null,o},buildFragment:function(e,t,n,r){var i,o,a,s,u,l,c,p=e.length,f=dt(t),d=[],h=0;for(;p>h;h++)if(o=e[h],o||0===o)if("object"===b.type(o))b.merge(d,o.nodeType?[o]:o);else if(wt.test(o)){s=s||f.appendChild(t.createElement("div")),u=(bt.exec(o)||["",""])[1].toLowerCase(),c=At[u]||At._default,s.innerHTML=c[1]+o.replace(vt,"<$1></$2>")+c[2],i=c[0];while(i--)s=s.lastChild;if(!b.support.leadingWhitespace&&yt.test(o)&&d.push(t.createTextNode(yt.exec(o)[0])),!b.support.tbody){o="table"!==u||xt.test(o)?"<table>"!==c[1]||xt.test(o)?0:s:s.firstChild,i=o&&o.childNodes.length;while(i--)b.nodeName(l=o.childNodes[i],"tbody")&&!l.childNodes.length&&o.removeChild(l)
-}b.merge(d,s.childNodes),s.textContent="";while(s.firstChild)s.removeChild(s.firstChild);s=f.lastChild}else d.push(t.createTextNode(o));s&&f.removeChild(s),b.support.appendChecked||b.grep(Ot(d,"input"),Bt),h=0;while(o=d[h++])if((!r||-1===b.inArray(o,r))&&(a=b.contains(o.ownerDocument,o),s=Ot(f.appendChild(o),"script"),a&&Mt(s),n)){i=0;while(o=s[i++])kt.test(o.type||"")&&n.push(o)}return s=null,f},cleanData:function(e,t){var n,r,o,a,s=0,u=b.expando,l=b.cache,p=b.support.deleteExpando,f=b.event.special;for(;null!=(n=e[s]);s++)if((t||b.acceptData(n))&&(o=n[u],a=o&&l[o])){if(a.events)for(r in a.events)f[r]?b.event.remove(n,r):b.removeEvent(n,r,a.handle);l[o]&&(delete l[o],p?delete n[u]:typeof n.removeAttribute!==i?n.removeAttribute(u):n[u]=null,c.push(o))}}});var Pt,Rt,Wt,$t=/alpha\([^)]*\)/i,It=/opacity\s*=\s*([^)]*)/,zt=/^(top|right|bottom|left)$/,Xt=/^(none|table(?!-c[ea]).+)/,Ut=/^margin/,Vt=RegExp("^("+x+")(.*)$","i"),Yt=RegExp("^("+x+")(?!px)[a-z%]+$","i"),Jt=RegExp("^([+-])=("+x+")","i"),Gt={BODY:"block"},Qt={position:"absolute",visibility:"hidden",display:"block"},Kt={letterSpacing:0,fontWeight:400},Zt=["Top","Right","Bottom","Left"],en=["Webkit","O","Moz","ms"];function tn(e,t){if(t in e)return t;var n=t.charAt(0).toUpperCase()+t.slice(1),r=t,i=en.length;while(i--)if(t=en[i]+n,t in e)return t;return r}function nn(e,t){return e=t||e,"none"===b.css(e,"display")||!b.contains(e.ownerDocument,e)}function rn(e,t){var n,r,i,o=[],a=0,s=e.length;for(;s>a;a++)r=e[a],r.style&&(o[a]=b._data(r,"olddisplay"),n=r.style.display,t?(o[a]||"none"!==n||(r.style.display=""),""===r.style.display&&nn(r)&&(o[a]=b._data(r,"olddisplay",un(r.nodeName)))):o[a]||(i=nn(r),(n&&"none"!==n||!i)&&b._data(r,"olddisplay",i?n:b.css(r,"display"))));for(a=0;s>a;a++)r=e[a],r.style&&(t&&"none"!==r.style.display&&""!==r.style.display||(r.style.display=t?o[a]||"":"none"));return e}b.fn.extend({css:function(e,n){return b.access(this,function(e,n,r){var i,o,a={},s=0;if(b.isArray(n)){for(o=Rt(e),i=n.length;i>s;s++)a[n[s]]=b.css(e,n[s],!1,o);return a}return r!==t?b.style(e,n,r):b.css(e,n)},e,n,arguments.length>1)},show:function(){return rn(this,!0)},hide:function(){return rn(this)},toggle:function(e){var t="boolean"==typeof e;return this.each(function(){(t?e:nn(this))?b(this).show():b(this).hide()})}}),b.extend({cssHooks:{opacity:{get:function(e,t){if(t){var n=Wt(e,"opacity");return""===n?"1":n}}}},cssNumber:{columnCount:!0,fillOpacity:!0,fontWeight:!0,lineHeight:!0,opacity:!0,orphans:!0,widows:!0,zIndex:!0,zoom:!0},cssProps:{"float":b.support.cssFloat?"cssFloat":"styleFloat"},style:function(e,n,r,i){if(e&&3!==e.nodeType&&8!==e.nodeType&&e.style){var o,a,s,u=b.camelCase(n),l=e.style;if(n=b.cssProps[u]||(b.cssProps[u]=tn(l,u)),s=b.cssHooks[n]||b.cssHooks[u],r===t)return s&&"get"in s&&(o=s.get(e,!1,i))!==t?o:l[n];if(a=typeof r,"string"===a&&(o=Jt.exec(r))&&(r=(o[1]+1)*o[2]+parseFloat(b.css(e,n)),a="number"),!(null==r||"number"===a&&isNaN(r)||("number"!==a||b.cssNumber[u]||(r+="px"),b.support.clearCloneStyle||""!==r||0!==n.indexOf("background")||(l[n]="inherit"),s&&"set"in s&&(r=s.set(e,r,i))===t)))try{l[n]=r}catch(c){}}},css:function(e,n,r,i){var o,a,s,u=b.camelCase(n);return n=b.cssProps[u]||(b.cssProps[u]=tn(e.style,u)),s=b.cssHooks[n]||b.cssHooks[u],s&&"get"in s&&(a=s.get(e,!0,r)),a===t&&(a=Wt(e,n,i)),"normal"===a&&n in Kt&&(a=Kt[n]),""===r||r?(o=parseFloat(a),r===!0||b.isNumeric(o)?o||0:a):a},swap:function(e,t,n,r){var i,o,a={};for(o in t)a[o]=e.style[o],e.style[o]=t[o];i=n.apply(e,r||[]);for(o in t)e.style[o]=a[o];return i}}),e.getComputedStyle?(Rt=function(t){return e.getComputedStyle(t,null)},Wt=function(e,n,r){var i,o,a,s=r||Rt(e),u=s?s.getPropertyValue(n)||s[n]:t,l=e.style;return s&&(""!==u||b.contains(e.ownerDocument,e)||(u=b.style(e,n)),Yt.test(u)&&Ut.test(n)&&(i=l.width,o=l.minWidth,a=l.maxWidth,l.minWidth=l.maxWidth=l.width=u,u=s.width,l.width=i,l.minWidth=o,l.maxWidth=a)),u}):o.documentElement.currentStyle&&(Rt=function(e){return e.currentStyle},Wt=function(e,n,r){var i,o,a,s=r||Rt(e),u=s?s[n]:t,l=e.style;return null==u&&l&&l[n]&&(u=l[n]),Yt.test(u)&&!zt.test(n)&&(i=l.left,o=e.runtimeStyle,a=o&&o.left,a&&(o.left=e.currentStyle.left),l.left="fontSize"===n?"1em":u,u=l.pixelLeft+"px",l.left=i,a&&(o.left=a)),""===u?"auto":u});function on(e,t,n){var r=Vt.exec(t);return r?Math.max(0,r[1]-(n||0))+(r[2]||"px"):t}function an(e,t,n,r,i){var o=n===(r?"border":"content")?4:"width"===t?1:0,a=0;for(;4>o;o+=2)"margin"===n&&(a+=b.css(e,n+Zt[o],!0,i)),r?("content"===n&&(a-=b.css(e,"padding"+Zt[o],!0,i)),"margin"!==n&&(a-=b.css(e,"border"+Zt[o]+"Width",!0,i))):(a+=b.css(e,"padding"+Zt[o],!0,i),"padding"!==n&&(a+=b.css(e,"border"+Zt[o]+"Width",!0,i)));return a}function sn(e,t,n){var r=!0,i="width"===t?e.offsetWidth:e.offsetHeight,o=Rt(e),a=b.support.boxSizing&&"border-box"===b.css(e,"boxSizing",!1,o);if(0>=i||null==i){if(i=Wt(e,t,o),(0>i||null==i)&&(i=e.style[t]),Yt.test(i))return i;r=a&&(b.support.boxSizingReliable||i===e.style[t]),i=parseFloat(i)||0}return i+an(e,t,n||(a?"border":"content"),r,o)+"px"}function un(e){var t=o,n=Gt[e];return n||(n=ln(e,t),"none"!==n&&n||(Pt=(Pt||b("<iframe frameborder='0' width='0' height='0'/>").css("cssText","display:block !important")).appendTo(t.documentElement),t=(Pt[0].contentWindow||Pt[0].contentDocument).document,t.write("<!doctype html><html><body>"),t.close(),n=ln(e,t),Pt.detach()),Gt[e]=n),n}function ln(e,t){var n=b(t.createElement(e)).appendTo(t.body),r=b.css(n[0],"display");return n.remove(),r}b.each(["height","width"],function(e,n){b.cssHooks[n]={get:function(e,r,i){return r?0===e.offsetWidth&&Xt.test(b.css(e,"display"))?b.swap(e,Qt,function(){return sn(e,n,i)}):sn(e,n,i):t},set:function(e,t,r){var i=r&&Rt(e);return on(e,t,r?an(e,n,r,b.support.boxSizing&&"border-box"===b.css(e,"boxSizing",!1,i),i):0)}}}),b.support.opacity||(b.cssHooks.opacity={get:function(e,t){return It.test((t&&e.currentStyle?e.currentStyle.filter:e.style.filter)||"")?.01*parseFloat(RegExp.$1)+"":t?"1":""},set:function(e,t){var n=e.style,r=e.currentStyle,i=b.isNumeric(t)?"alpha(opacity="+100*t+")":"",o=r&&r.filter||n.filter||"";n.zoom=1,(t>=1||""===t)&&""===b.trim(o.replace($t,""))&&n.removeAttribute&&(n.removeAttribute("filter"),""===t||r&&!r.filter)||(n.filter=$t.test(o)?o.replace($t,i):o+" "+i)}}),b(function(){b.support.reliableMarginRight||(b.cssHooks.marginRight={get:function(e,n){return n?b.swap(e,{display:"inline-block"},Wt,[e,"marginRight"]):t}}),!b.support.pixelPosition&&b.fn.position&&b.each(["top","left"],function(e,n){b.cssHooks[n]={get:function(e,r){return r?(r=Wt(e,n),Yt.test(r)?b(e).position()[n]+"px":r):t}}})}),b.expr&&b.expr.filters&&(b.expr.filters.hidden=function(e){return 0>=e.offsetWidth&&0>=e.offsetHeight||!b.support.reliableHiddenOffsets&&"none"===(e.style&&e.style.display||b.css(e,"display"))},b.expr.filters.visible=function(e){return!b.expr.filters.hidden(e)}),b.each({margin:"",padding:"",border:"Width"},function(e,t){b.cssHooks[e+t]={expand:function(n){var r=0,i={},o="string"==typeof n?n.split(" "):[n];for(;4>r;r++)i[e+Zt[r]+t]=o[r]||o[r-2]||o[0];return i}},Ut.test(e)||(b.cssHooks[e+t].set=on)});var cn=/%20/g,pn=/\[\]$/,fn=/\r?\n/g,dn=/^(?:submit|button|image|reset|file)$/i,hn=/^(?:input|select|textarea|keygen)/i;b.fn.extend({serialize:function(){return b.param(this.serializeArray())},serializeArray:function(){return this.map(function(){var e=b.prop(this,"elements");return e?b.makeArray(e):this}).filter(function(){var e=this.type;return this.name&&!b(this).is(":disabled")&&hn.test(this.nodeName)&&!dn.test(e)&&(this.checked||!Nt.test(e))}).map(function(e,t){var n=b(this).val();return null==n?null:b.isArray(n)?b.map(n,function(e){return{name:t.name,value:e.replace(fn,"\r\n")}}):{name:t.name,value:n.replace(fn,"\r\n")}}).get()}}),b.param=function(e,n){var r,i=[],o=function(e,t){t=b.isFunction(t)?t():null==t?"":t,i[i.length]=encodeURIComponent(e)+"="+encodeURIComponent(t)};if(n===t&&(n=b.ajaxSettings&&b.ajaxSettings.traditional),b.isArray(e)||e.jquery&&!b.isPlainObject(e))b.each(e,function(){o(this.name,this.value)});else for(r in e)gn(r,e[r],n,o);return i.join("&").replace(cn,"+")};function gn(e,t,n,r){var i;if(b.isArray(t))b.each(t,function(t,i){n||pn.test(e)?r(e,i):gn(e+"["+("object"==typeof i?t:"")+"]",i,n,r)});else if(n||"object"!==b.type(t))r(e,t);else for(i in t)gn(e+"["+i+"]",t[i],n,r)}b.each("blur focus focusin focusout load resize scroll unload click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup error contextmenu".split(" "),function(e,t){b.fn[t]=function(e,n){return arguments.length>0?this.on(t,null,e,n):this.trigger(t)}}),b.fn.hover=function(e,t){return this.mouseenter(e).mouseleave(t||e)};var mn,yn,vn=b.now(),bn=/\?/,xn=/#.*$/,wn=/([?&])_=[^&]*/,Tn=/^(.*?):[ \t]*([^\r\n]*)\r?$/gm,Nn=/^(?:about|app|app-storage|.+-extension|file|res|widget):$/,Cn=/^(?:GET|HEAD)$/,kn=/^\/\//,En=/^([\w.+-]+:)(?:\/\/([^\/?#:]*)(?::(\d+)|)|)/,Sn=b.fn.load,An={},jn={},Dn="*/".concat("*");try{yn=a.href}catch(Ln){yn=o.createElement("a"),yn.href="",yn=yn.href}mn=En.exec(yn.toLowerCase())||[];function Hn(e){return function(t,n){"string"!=typeof t&&(n=t,t="*");var r,i=0,o=t.toLowerCase().match(w)||[];if(b.isFunction(n))while(r=o[i++])"+"===r[0]?(r=r.slice(1)||"*",(e[r]=e[r]||[]).unshift(n)):(e[r]=e[r]||[]).push(n)}}function qn(e,n,r,i){var o={},a=e===jn;function s(u){var l;return o[u]=!0,b.each(e[u]||[],function(e,u){var c=u(n,r,i);return"string"!=typeof c||a||o[c]?a?!(l=c):t:(n.dataTypes.unshift(c),s(c),!1)}),l}return s(n.dataTypes[0])||!o["*"]&&s("*")}function Mn(e,n){var r,i,o=b.ajaxSettings.flatOptions||{};for(i in n)n[i]!==t&&((o[i]?e:r||(r={}))[i]=n[i]);return r&&b.extend(!0,e,r),e}b.fn.load=function(e,n,r){if("string"!=typeof e&&Sn)return Sn.apply(this,arguments);var i,o,a,s=this,u=e.indexOf(" ");return u>=0&&(i=e.slice(u,e.length),e=e.slice(0,u)),b.isFunction(n)?(r=n,n=t):n&&"object"==typeof n&&(a="POST"),s.length>0&&b.ajax({url:e,type:a,dataType:"html",data:n}).done(function(e){o=arguments,s.html(i?b("<div>").append(b.parseHTML(e)).find(i):e)}).complete(r&&function(e,t){s.each(r,o||[e.responseText,t,e])}),this},b.each(["ajaxStart","ajaxStop","ajaxComplete","ajaxError","ajaxSuccess","ajaxSend"],function(e,t){b.fn[t]=function(e){return this.on(t,e)}}),b.each(["get","post"],function(e,n){b[n]=function(e,r,i,o){return b.isFunction(r)&&(o=o||i,i=r,r=t),b.ajax({url:e,type:n,dataType:o,data:r,success:i})}}),b.extend({active:0,lastModified:{},etag:{},ajaxSettings:{url:yn,type:"GET",isLocal:Nn.test(mn[1]),global:!0,processData:!0,async:!0,contentType:"application/x-www-form-urlencoded; charset=UTF-8",accepts:{"*":Dn,text:"text/plain",html:"text/html",xml:"application/xml, text/xml",json:"application/json, text/javascript"},contents:{xml:/xml/,html:/html/,json:/json/},responseFields:{xml:"responseXML",text:"responseText"},converters:{"* text":e.String,"text html":!0,"text json":b.parseJSON,"text xml":b.parseXML},flatOptions:{url:!0,context:!0}},ajaxSetup:function(e,t){return t?Mn(Mn(e,b.ajaxSettings),t):Mn(b.ajaxSettings,e)},ajaxPrefilter:Hn(An),ajaxTransport:Hn(jn),ajax:function(e,n){"object"==typeof e&&(n=e,e=t),n=n||{};var r,i,o,a,s,u,l,c,p=b.ajaxSetup({},n),f=p.context||p,d=p.context&&(f.nodeType||f.jquery)?b(f):b.event,h=b.Deferred(),g=b.Callbacks("once memory"),m=p.statusCode||{},y={},v={},x=0,T="canceled",N={readyState:0,getResponseHeader:function(e){var t;if(2===x){if(!c){c={};while(t=Tn.exec(a))c[t[1].toLowerCase()]=t[2]}t=c[e.toLowerCase()]}return null==t?null:t},getAllResponseHeaders:function(){return 2===x?a:null},setRequestHeader:function(e,t){var n=e.toLowerCase();return x||(e=v[n]=v[n]||e,y[e]=t),this},overrideMimeType:function(e){return x||(p.mimeType=e),this},statusCode:function(e){var t;if(e)if(2>x)for(t in e)m[t]=[m[t],e[t]];else N.always(e[N.status]);return this},abort:function(e){var t=e||T;return l&&l.abort(t),k(0,t),this}};if(h.promise(N).complete=g.add,N.success=N.done,N.error=N.fail,p.url=((e||p.url||yn)+"").replace(xn,"").replace(kn,mn[1]+"//"),p.type=n.method||n.type||p.method||p.type,p.dataTypes=b.trim(p.dataType||"*").toLowerCase().match(w)||[""],null==p.crossDomain&&(r=En.exec(p.url.toLowerCase()),p.crossDomain=!(!r||r[1]===mn[1]&&r[2]===mn[2]&&(r[3]||("http:"===r[1]?80:443))==(mn[3]||("http:"===mn[1]?80:443)))),p.data&&p.processData&&"string"!=typeof p.data&&(p.data=b.param(p.data,p.traditional)),qn(An,p,n,N),2===x)return N;u=p.global,u&&0===b.active++&&b.event.trigger("ajaxStart"),p.type=p.type.toUpperCase(),p.hasContent=!Cn.test(p.type),o=p.url,p.hasContent||(p.data&&(o=p.url+=(bn.test(o)?"&":"?")+p.data,delete p.data),p.cache===!1&&(p.url=wn.test(o)?o.replace(wn,"$1_="+vn++):o+(bn.test(o)?"&":"?")+"_="+vn++)),p.ifModified&&(b.lastModified[o]&&N.setRequestHeader("If-Modified-Since",b.lastModified[o]),b.etag[o]&&N.setRequestHeader("If-None-Match",b.etag[o])),(p.data&&p.hasContent&&p.contentType!==!1||n.contentType)&&N.setRequestHeader("Content-Type",p.contentType),N.setRequestHeader("Accept",p.dataTypes[0]&&p.accepts[p.dataTypes[0]]?p.accepts[p.dataTypes[0]]+("*"!==p.dataTypes[0]?", "+Dn+"; q=0.01":""):p.accepts["*"]);for(i in p.headers)N.setRequestHeader(i,p.headers[i]);if(p.beforeSend&&(p.beforeSend.call(f,N,p)===!1||2===x))return N.abort();T="abort";for(i in{success:1,error:1,complete:1})N[i](p[i]);if(l=qn(jn,p,n,N)){N.readyState=1,u&&d.trigger("ajaxSend",[N,p]),p.async&&p.timeout>0&&(s=setTimeout(function(){N.abort("timeout")},p.timeout));try{x=1,l.send(y,k)}catch(C){if(!(2>x))throw C;k(-1,C)}}else k(-1,"No Transport");function k(e,n,r,i){var c,y,v,w,T,C=n;2!==x&&(x=2,s&&clearTimeout(s),l=t,a=i||"",N.readyState=e>0?4:0,r&&(w=_n(p,N,r)),e>=200&&300>e||304===e?(p.ifModified&&(T=N.getResponseHeader("Last-Modified"),T&&(b.lastModified[o]=T),T=N.getResponseHeader("etag"),T&&(b.etag[o]=T)),204===e?(c=!0,C="nocontent"):304===e?(c=!0,C="notmodified"):(c=Fn(p,w),C=c.state,y=c.data,v=c.error,c=!v)):(v=C,(e||!C)&&(C="error",0>e&&(e=0))),N.status=e,N.statusText=(n||C)+"",c?h.resolveWith(f,[y,C,N]):h.rejectWith(f,[N,C,v]),N.statusCode(m),m=t,u&&d.trigger(c?"ajaxSuccess":"ajaxError",[N,p,c?y:v]),g.fireWith(f,[N,C]),u&&(d.trigger("ajaxComplete",[N,p]),--b.active||b.event.trigger("ajaxStop")))}return N},getScript:function(e,n){return b.get(e,t,n,"script")},getJSON:function(e,t,n){return b.get(e,t,n,"json")}});function _n(e,n,r){var i,o,a,s,u=e.contents,l=e.dataTypes,c=e.responseFields;for(s in c)s in r&&(n[c[s]]=r[s]);while("*"===l[0])l.shift(),o===t&&(o=e.mimeType||n.getResponseHeader("Content-Type"));if(o)for(s in u)if(u[s]&&u[s].test(o)){l.unshift(s);break}if(l[0]in r)a=l[0];else{for(s in r){if(!l[0]||e.converters[s+" "+l[0]]){a=s;break}i||(i=s)}a=a||i}return a?(a!==l[0]&&l.unshift(a),r[a]):t}function Fn(e,t){var n,r,i,o,a={},s=0,u=e.dataTypes.slice(),l=u[0];if(e.dataFilter&&(t=e.dataFilter(t,e.dataType)),u[1])for(i in e.converters)a[i.toLowerCase()]=e.converters[i];for(;r=u[++s];)if("*"!==r){if("*"!==l&&l!==r){if(i=a[l+" "+r]||a["* "+r],!i)for(n in a)if(o=n.split(" "),o[1]===r&&(i=a[l+" "+o[0]]||a["* "+o[0]])){i===!0?i=a[n]:a[n]!==!0&&(r=o[0],u.splice(s--,0,r));break}if(i!==!0)if(i&&e["throws"])t=i(t);else try{t=i(t)}catch(c){return{state:"parsererror",error:i?c:"No conversion from "+l+" to "+r}}}l=r}return{state:"success",data:t}}b.ajaxSetup({accepts:{script:"text/javascript, application/javascript, application/ecmascript, application/x-ecmascript"},contents:{script:/(?:java|ecma)script/},converters:{"text script":function(e){return b.globalEval(e),e}}}),b.ajaxPrefilter("script",function(e){e.cache===t&&(e.cache=!1),e.crossDomain&&(e.type="GET",e.global=!1)}),b.ajaxTransport("script",function(e){if(e.crossDomain){var n,r=o.head||b("head")[0]||o.documentElement;return{send:function(t,i){n=o.createElement("script"),n.async=!0,e.scriptCharset&&(n.charset=e.scriptCharset),n.src=e.url,n.onload=n.onreadystatechange=function(e,t){(t||!n.readyState||/loaded|complete/.test(n.readyState))&&(n.onload=n.onreadystatechange=null,n.parentNode&&n.parentNode.removeChild(n),n=null,t||i(200,"success"))},r.insertBefore(n,r.firstChild)},abort:function(){n&&n.onload(t,!0)}}}});var On=[],Bn=/(=)\?(?=&|$)|\?\?/;b.ajaxSetup({jsonp:"callback",jsonpCallback:function(){var e=On.pop()||b.expando+"_"+vn++;return this[e]=!0,e}}),b.ajaxPrefilter("json jsonp",function(n,r,i){var o,a,s,u=n.jsonp!==!1&&(Bn.test(n.url)?"url":"string"==typeof n.data&&!(n.contentType||"").indexOf("application/x-www-form-urlencoded")&&Bn.test(n.data)&&"data");return u||"jsonp"===n.dataTypes[0]?(o=n.jsonpCallback=b.isFunction(n.jsonpCallback)?n.jsonpCallback():n.jsonpCallback,u?n[u]=n[u].replace(Bn,"$1"+o):n.jsonp!==!1&&(n.url+=(bn.test(n.url)?"&":"?")+n.jsonp+"="+o),n.converters["script json"]=function(){return s||b.error(o+" was not called"),s[0]},n.dataTypes[0]="json",a=e[o],e[o]=function(){s=arguments},i.always(function(){e[o]=a,n[o]&&(n.jsonpCallback=r.jsonpCallback,On.push(o)),s&&b.isFunction(a)&&a(s[0]),s=a=t}),"script"):t});var Pn,Rn,Wn=0,$n=e.ActiveXObject&&function(){var e;for(e in Pn)Pn[e](t,!0)};function In(){try{return new e.XMLHttpRequest}catch(t){}}function zn(){try{return new e.ActiveXObject("Microsoft.XMLHTTP")}catch(t){}}b.ajaxSettings.xhr=e.ActiveXObject?function(){return!this.isLocal&&In()||zn()}:In,Rn=b.ajaxSettings.xhr(),b.support.cors=!!Rn&&"withCredentials"in Rn,Rn=b.support.ajax=!!Rn,Rn&&b.ajaxTransport(function(n){if(!n.crossDomain||b.support.cors){var r;return{send:function(i,o){var a,s,u=n.xhr();if(n.username?u.open(n.type,n.url,n.async,n.username,n.password):u.open(n.type,n.url,n.async),n.xhrFields)for(s in n.xhrFields)u[s]=n.xhrFields[s];n.mimeType&&u.overrideMimeType&&u.overrideMimeType(n.mimeType),n.crossDomain||i["X-Requested-With"]||(i["X-Requested-With"]="XMLHttpRequest");try{for(s in i)u.setRequestHeader(s,i[s])}catch(l){}u.send(n.hasContent&&n.data||null),r=function(e,i){var s,l,c,p;try{if(r&&(i||4===u.readyState))if(r=t,a&&(u.onreadystatechange=b.noop,$n&&delete Pn[a]),i)4!==u.readyState&&u.abort();else{p={},s=u.status,l=u.getAllResponseHeaders(),"string"==typeof u.responseText&&(p.text=u.responseText);try{c=u.statusText}catch(f){c=""}s||!n.isLocal||n.crossDomain?1223===s&&(s=204):s=p.text?200:404}}catch(d){i||o(-1,d)}p&&o(s,c,p,l)},n.async?4===u.readyState?setTimeout(r):(a=++Wn,$n&&(Pn||(Pn={},b(e).unload($n)),Pn[a]=r),u.onreadystatechange=r):r()},abort:function(){r&&r(t,!0)}}}});var Xn,Un,Vn=/^(?:toggle|show|hide)$/,Yn=RegExp("^(?:([+-])=|)("+x+")([a-z%]*)$","i"),Jn=/queueHooks$/,Gn=[nr],Qn={"*":[function(e,t){var n,r,i=this.createTween(e,t),o=Yn.exec(t),a=i.cur(),s=+a||0,u=1,l=20;if(o){if(n=+o[2],r=o[3]||(b.cssNumber[e]?"":"px"),"px"!==r&&s){s=b.css(i.elem,e,!0)||n||1;do u=u||".5",s/=u,b.style(i.elem,e,s+r);while(u!==(u=i.cur()/a)&&1!==u&&--l)}i.unit=r,i.start=s,i.end=o[1]?s+(o[1]+1)*n:n}return i}]};function Kn(){return setTimeout(function(){Xn=t}),Xn=b.now()}function Zn(e,t){b.each(t,function(t,n){var r=(Qn[t]||[]).concat(Qn["*"]),i=0,o=r.length;for(;o>i;i++)if(r[i].call(e,t,n))return})}function er(e,t,n){var r,i,o=0,a=Gn.length,s=b.Deferred().always(function(){delete u.elem}),u=function(){if(i)return!1;var t=Xn||Kn(),n=Math.max(0,l.startTime+l.duration-t),r=n/l.duration||0,o=1-r,a=0,u=l.tweens.length;for(;u>a;a++)l.tweens[a].run(o);return s.notifyWith(e,[l,o,n]),1>o&&u?n:(s.resolveWith(e,[l]),!1)},l=s.promise({elem:e,props:b.extend({},t),opts:b.extend(!0,{specialEasing:{}},n),originalProperties:t,originalOptions:n,startTime:Xn||Kn(),duration:n.duration,tweens:[],createTween:function(t,n){var r=b.Tween(e,l.opts,t,n,l.opts.specialEasing[t]||l.opts.easing);return l.tweens.push(r),r},stop:function(t){var n=0,r=t?l.tweens.length:0;if(i)return this;for(i=!0;r>n;n++)l.tweens[n].run(1);return t?s.resolveWith(e,[l,t]):s.rejectWith(e,[l,t]),this}}),c=l.props;for(tr(c,l.opts.specialEasing);a>o;o++)if(r=Gn[o].call(l,e,c,l.opts))return r;return Zn(l,c),b.isFunction(l.opts.start)&&l.opts.start.call(e,l),b.fx.timer(b.extend(u,{elem:e,anim:l,queue:l.opts.queue})),l.progress(l.opts.progress).done(l.opts.done,l.opts.complete).fail(l.opts.fail).always(l.opts.always)}function tr(e,t){var n,r,i,o,a;for(i in e)if(r=b.camelCase(i),o=t[r],n=e[i],b.isArray(n)&&(o=n[1],n=e[i]=n[0]),i!==r&&(e[r]=n,delete e[i]),a=b.cssHooks[r],a&&"expand"in a){n=a.expand(n),delete e[r];for(i in n)i in e||(e[i]=n[i],t[i]=o)}else t[r]=o}b.Animation=b.extend(er,{tweener:function(e,t){b.isFunction(e)?(t=e,e=["*"]):e=e.split(" ");var n,r=0,i=e.length;for(;i>r;r++)n=e[r],Qn[n]=Qn[n]||[],Qn[n].unshift(t)},prefilter:function(e,t){t?Gn.unshift(e):Gn.push(e)}});function nr(e,t,n){var r,i,o,a,s,u,l,c,p,f=this,d=e.style,h={},g=[],m=e.nodeType&&nn(e);n.queue||(c=b._queueHooks(e,"fx"),null==c.unqueued&&(c.unqueued=0,p=c.empty.fire,c.empty.fire=function(){c.unqueued||p()}),c.unqueued++,f.always(function(){f.always(function(){c.unqueued--,b.queue(e,"fx").length||c.empty.fire()})})),1===e.nodeType&&("height"in t||"width"in t)&&(n.overflow=[d.overflow,d.overflowX,d.overflowY],"inline"===b.css(e,"display")&&"none"===b.css(e,"float")&&(b.support.inlineBlockNeedsLayout&&"inline"!==un(e.nodeName)?d.zoom=1:d.display="inline-block")),n.overflow&&(d.overflow="hidden",b.support.shrinkWrapBlocks||f.always(function(){d.overflow=n.overflow[0],d.overflowX=n.overflow[1],d.overflowY=n.overflow[2]}));for(i in t)if(a=t[i],Vn.exec(a)){if(delete t[i],u=u||"toggle"===a,a===(m?"hide":"show"))continue;g.push(i)}if(o=g.length){s=b._data(e,"fxshow")||b._data(e,"fxshow",{}),"hidden"in s&&(m=s.hidden),u&&(s.hidden=!m),m?b(e).show():f.done(function(){b(e).hide()}),f.done(function(){var t;b._removeData(e,"fxshow");for(t in h)b.style(e,t,h[t])});for(i=0;o>i;i++)r=g[i],l=f.createTween(r,m?s[r]:0),h[r]=s[r]||b.style(e,r),r in s||(s[r]=l.start,m&&(l.end=l.start,l.start="width"===r||"height"===r?1:0))}}function rr(e,t,n,r,i){return new rr.prototype.init(e,t,n,r,i)}b.Tween=rr,rr.prototype={constructor:rr,init:function(e,t,n,r,i,o){this.elem=e,this.prop=n,this.easing=i||"swing",this.options=t,this.start=this.now=this.cur(),this.end=r,this.unit=o||(b.cssNumber[n]?"":"px")},cur:function(){var e=rr.propHooks[this.prop];return e&&e.get?e.get(this):rr.propHooks._default.get(this)},run:function(e){var t,n=rr.propHooks[this.prop];return this.pos=t=this.options.duration?b.easing[this.easing](e,this.options.duration*e,0,1,this.options.duration):e,this.now=(this.end-this.start)*t+this.start,this.options.step&&this.options.step.call(this.elem,this.now,this),n&&n.set?n.set(this):rr.propHooks._default.set(this),this}},rr.prototype.init.prototype=rr.prototype,rr.propHooks={_default:{get:function(e){var t;return null==e.elem[e.prop]||e.elem.style&&null!=e.elem.style[e.prop]?(t=b.css(e.elem,e.prop,""),t&&"auto"!==t?t:0):e.elem[e.prop]},set:function(e){b.fx.step[e.prop]?b.fx.step[e.prop](e):e.elem.style&&(null!=e.elem.style[b.cssProps[e.prop]]||b.cssHooks[e.prop])?b.style(e.elem,e.prop,e.now+e.unit):e.elem[e.prop]=e.now}}},rr.propHooks.scrollTop=rr.propHooks.scrollLeft={set:function(e){e.elem.nodeType&&e.elem.parentNode&&(e.elem[e.prop]=e.now)}},b.each(["toggle","show","hide"],function(e,t){var n=b.fn[t];b.fn[t]=function(e,r,i){return null==e||"boolean"==typeof e?n.apply(this,arguments):this.animate(ir(t,!0),e,r,i)}}),b.fn.extend({fadeTo:function(e,t,n,r){return this.filter(nn).css("opacity",0).show().end().animate({opacity:t},e,n,r)},animate:function(e,t,n,r){var i=b.isEmptyObject(e),o=b.speed(t,n,r),a=function(){var t=er(this,b.extend({},e),o);a.finish=function(){t.stop(!0)},(i||b._data(this,"finish"))&&t.stop(!0)};return a.finish=a,i||o.queue===!1?this.each(a):this.queue(o.queue,a)},stop:function(e,n,r){var i=function(e){var t=e.stop;delete e.stop,t(r)};return"string"!=typeof e&&(r=n,n=e,e=t),n&&e!==!1&&this.queue(e||"fx",[]),this.each(function(){var t=!0,n=null!=e&&e+"queueHooks",o=b.timers,a=b._data(this);if(n)a[n]&&a[n].stop&&i(a[n]);else for(n in a)a[n]&&a[n].stop&&Jn.test(n)&&i(a[n]);for(n=o.length;n--;)o[n].elem!==this||null!=e&&o[n].queue!==e||(o[n].anim.stop(r),t=!1,o.splice(n,1));(t||!r)&&b.dequeue(this,e)})},finish:function(e){return e!==!1&&(e=e||"fx"),this.each(function(){var t,n=b._data(this),r=n[e+"queue"],i=n[e+"queueHooks"],o=b.timers,a=r?r.length:0;for(n.finish=!0,b.queue(this,e,[]),i&&i.cur&&i.cur.finish&&i.cur.finish.call(this),t=o.length;t--;)o[t].elem===this&&o[t].queue===e&&(o[t].anim.stop(!0),o.splice(t,1));for(t=0;a>t;t++)r[t]&&r[t].finish&&r[t].finish.call(this);delete n.finish})}});function ir(e,t){var n,r={height:e},i=0;for(t=t?1:0;4>i;i+=2-t)n=Zt[i],r["margin"+n]=r["padding"+n]=e;return t&&(r.opacity=r.width=e),r}b.each({slideDown:ir("show"),slideUp:ir("hide"),slideToggle:ir("toggle"),fadeIn:{opacity:"show"},fadeOut:{opacity:"hide"},fadeToggle:{opacity:"toggle"}},function(e,t){b.fn[e]=function(e,n,r){return this.animate(t,e,n,r)}}),b.speed=function(e,t,n){var r=e&&"object"==typeof e?b.extend({},e):{complete:n||!n&&t||b.isFunction(e)&&e,duration:e,easing:n&&t||t&&!b.isFunction(t)&&t};return r.duration=b.fx.off?0:"number"==typeof r.duration?r.duration:r.duration in b.fx.speeds?b.fx.speeds[r.duration]:b.fx.speeds._default,(null==r.queue||r.queue===!0)&&(r.queue="fx"),r.old=r.complete,r.complete=function(){b.isFunction(r.old)&&r.old.call(this),r.queue&&b.dequeue(this,r.queue)},r},b.easing={linear:function(e){return e},swing:function(e){return.5-Math.cos(e*Math.PI)/2}},b.timers=[],b.fx=rr.prototype.init,b.fx.tick=function(){var e,n=b.timers,r=0;for(Xn=b.now();n.length>r;r++)e=n[r],e()||n[r]!==e||n.splice(r--,1);n.length||b.fx.stop(),Xn=t},b.fx.timer=function(e){e()&&b.timers.push(e)&&b.fx.start()},b.fx.interval=13,b.fx.start=function(){Un||(Un=setInterval(b.fx.tick,b.fx.interval))},b.fx.stop=function(){clearInterval(Un),Un=null},b.fx.speeds={slow:600,fast:200,_default:400},b.fx.step={},b.expr&&b.expr.filters&&(b.expr.filters.animated=function(e){return b.grep(b.timers,function(t){return e===t.elem}).length}),b.fn.offset=function(e){if(arguments.length)return e===t?this:this.each(function(t){b.offset.setOffset(this,e,t)});var n,r,o={top:0,left:0},a=this[0],s=a&&a.ownerDocument;if(s)return n=s.documentElement,b.contains(n,a)?(typeof a.getBoundingClientRect!==i&&(o=a.getBoundingClientRect()),r=or(s),{top:o.top+(r.pageYOffset||n.scrollTop)-(n.clientTop||0),left:o.left+(r.pageXOffset||n.scrollLeft)-(n.clientLeft||0)}):o},b.offset={setOffset:function(e,t,n){var r=b.css(e,"position");"static"===r&&(e.style.position="relative");var i=b(e),o=i.offset(),a=b.css(e,"top"),s=b.css(e,"left"),u=("absolute"===r||"fixed"===r)&&b.inArray("auto",[a,s])>-1,l={},c={},p,f;u?(c=i.position(),p=c.top,f=c.left):(p=parseFloat(a)||0,f=parseFloat(s)||0),b.isFunction(t)&&(t=t.call(e,n,o)),null!=t.top&&(l.top=t.top-o.top+p),null!=t.left&&(l.left=t.left-o.left+f),"using"in t?t.using.call(e,l):i.css(l)}},b.fn.extend({position:function(){if(this[0]){var e,t,n={top:0,left:0},r=this[0];return"fixed"===b.css(r,"position")?t=r.getBoundingClientRect():(e=this.offsetParent(),t=this.offset(),b.nodeName(e[0],"html")||(n=e.offset()),n.top+=b.css(e[0],"borderTopWidth",!0),n.left+=b.css(e[0],"borderLeftWidth",!0)),{top:t.top-n.top-b.css(r,"marginTop",!0),left:t.left-n.left-b.css(r,"marginLeft",!0)}}},offsetParent:function(){return this.map(function(){var e=this.offsetParent||o.documentElement;while(e&&!b.nodeName(e,"html")&&"static"===b.css(e,"position"))e=e.offsetParent;return e||o.documentElement})}}),b.each({scrollLeft:"pageXOffset",scrollTop:"pageYOffset"},function(e,n){var r=/Y/.test(n);b.fn[e]=function(i){return b.access(this,function(e,i,o){var a=or(e);return o===t?a?n in a?a[n]:a.document.documentElement[i]:e[i]:(a?a.scrollTo(r?b(a).scrollLeft():o,r?o:b(a).scrollTop()):e[i]=o,t)},e,i,arguments.length,null)}});function or(e){return b.isWindow(e)?e:9===e.nodeType?e.defaultView||e.parentWindow:!1}b.each({Height:"height",Width:"width"},function(e,n){b.each({padding:"inner"+e,content:n,"":"outer"+e},function(r,i){b.fn[i]=function(i,o){var a=arguments.length&&(r||"boolean"!=typeof i),s=r||(i===!0||o===!0?"margin":"border");return b.access(this,function(n,r,i){var o;return b.isWindow(n)?n.document.documentElement["client"+e]:9===n.nodeType?(o=n.documentElement,Math.max(n.body["scroll"+e],o["scroll"+e],n.body["offset"+e],o["offset"+e],o["client"+e])):i===t?b.css(n,r,s):b.style(n,r,i,s)},n,a?i:t,a,null)}})}),e.jQuery=e.$=b,"function"==typeof define&&define.amd&&define.amd.jQuery&&define("jquery",[],function(){return b})})(window);
\ No newline at end of file
diff --git a/opendaylight/adsal/web/root/src/main/resources/js/less-1.3.3.min.js b/opendaylight/adsal/web/root/src/main/resources/js/less-1.3.3.min.js
deleted file mode 100644 (file)
index 9b0fa6b..0000000
+++ /dev/null
@@ -1,9 +0,0 @@
-//
-// LESS - Leaner CSS v1.3.3
-// http://lesscss.org
-// 
-// Copyright (c) 2009-2013, Alexis Sellier
-// Licensed under the Apache 2.0 License.
-//
-(function(e,t){function n(t){return e.less[t.split("/")[1]]}function f(){r.env==="development"?(r.optimization=0,r.watchTimer=setInterval(function(){r.watchMode&&g(function(e,t,n,r,i){t&&S(t.toCSS(),r,i.lastModified)})},r.poll)):r.optimization=3}function m(){var e=document.getElementsByTagName("style");for(var t=0;t<e.length;t++)e[t].type.match(p)&&(new r.Parser({filename:document.location.href.replace(/#.*$/,""),dumpLineNumbers:r.dumpLineNumbers})).parse(e[t].innerHTML||"",function(n,r){var i=r.toCSS(),s=e[t];s.type="text/css",s.styleSheet?s.styleSheet.cssText=i:s.innerHTML=i})}function g(e,t){for(var n=0;n<r.sheets.length;n++)w(r.sheets[n],e,t,r.sheets.length-(n+1))}function y(e,t){var n=b(e),r=b(t),i,s,o,u,a="";if(n.hostPart!==r.hostPart)return"";s=Math.max(r.directories.length,n.directories.length);for(i=0;i<s;i++)if(r.directories[i]!==n.directories[i])break;u=r.directories.slice(i),o=n.directories.slice(i);for(i=0;i<u.length-1;i++)a+="../";for(i=0;i<o.length-1;i++)a+=o[i]+"/";return a}function b(e,t){var n=/^((?:[a-z-]+:)?\/\/(?:[^\/\?#]*\/)|([\/\\]))?((?:[^\/\\\?#]*[\/\\])*)([^\/\\\?#]*)([#\?].*)?$/,r=e.match(n),i={},s=[],o,u;if(!r)throw new Error("Could not parse sheet href - '"+e+"'");if(!r[1]||r[2]){u=t.match(n);if(!u)throw new Error("Could not parse page url - '"+t+"'");r[1]=u[1],r[2]||(r[3]=u[3]+r[3])}if(r[3]){s=r[3].replace("\\","/").split("/");for(o=0;o<s.length;o++)s[o]===".."&&o>0&&(s.splice(o-1,2),o-=2)}return i.hostPart=r[1],i.directories=s,i.path=r[1]+s.join("/"),i.fileUrl=i.path+(r[4]||""),i.url=i.fileUrl+(r[5]||""),i}function w(t,n,i,s){var o=t.contents||{},u=t.files||{},a=b(t.href,e.location.href),f=a.url,c=l&&l.getItem(f),h=l&&l.getItem(f+":timestamp"),p={css:c,timestamp:h},d;r.relativeUrls?r.rootpath?t.entryPath?d=b(r.rootpath+y(a.path,t.entryPath)).path:d=r.rootpath:d=a.path:r.rootpath?d=r.rootpath:t.entryPath?d=t.entryPath:d=a.path,x(f,t.type,function(e,l){v+=e.replace(/@import .+?;/ig,"");if(!i&&p&&l&&(new Date(l)).valueOf()===(new Date(p.timestamp)).valueOf())S(p.css,t),n(null,null,e,t,{local:!0,remaining:s},f);else try{o[f]=e,(new r.Parser({optimization:r.optimization,paths:[a.path],entryPath:t.entryPath||a.path,mime:t.type,filename:f,rootpath:d,relativeUrls:t.relativeUrls,contents:o,files:u,dumpLineNumbers:r.dumpLineNumbers})).parse(e,function(r,i){if(r)return k(r,f);try{n(r,i,e,t,{local:!1,lastModified:l,remaining:s},f),N(document.getElementById("less-error-message:"+E(f)))}catch(r){k(r,f)}})}catch(c){k(c,f)}},function(e,t){throw new Error("Couldn't load "+t+" ("+e+")")})}function E(e){return e.replace(/^[a-z]+:\/\/?[^\/]+/,"").replace(/^\//,"").replace(/\.[a-zA-Z]+$/,"").replace(/[^\.\w-]+/g,"-").replace(/\./g,":")}function S(e,t,n){var r,i=t.href||"",s="less:"+(t.title||E(i));if((r=document.getElementById(s))===null){r=document.createElement("style"),r.type="text/css",t.media&&(r.media=t.media),r.id=s;var o=t&&t.nextSibling||null;(o||document.getElementsByTagName("head")[0]).parentNode.insertBefore(r,o)}if(r.styleSheet)try{r.styleSheet.cssText=e}catch(u){throw new Error("Couldn't reassign styleSheet.cssText.")}else(function(e){r.childNodes.length>0?r.firstChild.nodeValue!==e.nodeValue&&r.replaceChild(e,r.firstChild):r.appendChild(e)})(document.createTextNode(e));if(n&&l){C("saving "+i+" to cache.");try{l.setItem(i,e),l.setItem(i+":timestamp",n)}catch(u){C("failed to save")}}}function x(e,t,n,i){function a(t,n,r){t.status>=200&&t.status<300?n(t.responseText,t.getResponseHeader("Last-Modified")):typeof r=="function"&&r(t.status,e)}var s=T(),u=o?r.fileAsync:r.async;typeof s.overrideMimeType=="function"&&s.overrideMimeType("text/css"),s.open("GET",e,u),s.setRequestHeader("Accept",t||"text/x-less, text/css; q=0.9, */*; q=0.5"),s.send(null),o&&!r.fileAsync?s.status===0||s.status>=200&&s.status<300?n(s.responseText):i(s.status,e):u?s.onreadystatechange=function(){s.readyState==4&&a(s,n,i)}:a(s,n,i)}function T(){if(e.XMLHttpRequest)return new XMLHttpRequest;try{return new ActiveXObject("MSXML2.XMLHTTP.3.0")}catch(t){return C("browser doesn't support AJAX."),null}}function N(e){return e&&e.parentNode.removeChild(e)}function C(e){r.env=="development"&&typeof console!="undefined"&&console.log("less: "+e)}function k(e,t){var n="less-error-message:"+E(t),i='<li><label>{line}</label><pre class="{class}">{content}</pre></li>',s=document.createElement("div"),o,u,a=[],f=e.filename||t,l=f.match(/([^\/]+(\?.*)?)$/)[1];s.id=n,s.className="less-error-message",u="<h3>"+(e.message||"There is an error in your .less file")+"</h3>"+'<p>in <a href="'+f+'">'+l+"</a> ";var c=function(e,t,n){e.extract[t]&&a.push(i.replace(/\{line\}/,parseInt(e.line)+(t-1)).replace(/\{class\}/,n).replace(/\{content\}/,e.extract[t]))};e.stack?u+="<br/>"+e.stack.split("\n").slice(1).join("<br/>"):e.extract&&(c(e,0,""),c(e,1,"line"),c(e,2,""),u+="on line "+e.line+", column "+(e.column+1)+":</p>"+"<ul>"+a.join("")+"</ul>"),s.innerHTML=u,S([".less-error-message ul, .less-error-message li {","list-style-type: none;","margin-right: 15px;","padding: 4px 0;","margin: 0;","}",".less-error-message label {","font-size: 12px;","margin-right: 15px;","padding: 4px 0;","color: #cc7777;","}",".less-error-message pre {","color: #dd6666;","padding: 4px 0;","margin: 0;","display: inline-block;","}",".less-error-message pre.line {","color: #ff0000;","}",".less-error-message h3 {","font-size: 20px;","font-weight: bold;","padding: 15px 0 5px 0;","margin: 0;","}",".less-error-message a {","color: #10a","}",".less-error-message .error {","color: red;","font-weight: bold;","padding-bottom: 2px;","border-bottom: 1px dashed red;","}"].join("\n"),{title:"error-message"}),s.style.cssText=["font-family: Arial, sans-serif","border: 1px solid #e00","background-color: #eee","border-radius: 5px","-webkit-border-radius: 5px","-moz-border-radius: 5px","color: #e00","padding: 15px","margin-bottom: 15px"].join(";"),r.env=="development"&&(o=setInterval(function(){document.body&&(document.getElementById(n)?document.body.replaceChild(s,document.getElementById(n)):document.body.insertBefore(s,document.body.firstChild),clearInterval(o))},10))}Array.isArray||(Array.isArray=function(e){return Object.prototype.toString.call(e)==="[object Array]"||e instanceof Array}),Array.prototype.forEach||(Array.prototype.forEach=function(e,t){var n=this.length>>>0;for(var r=0;r<n;r++)r in this&&e.call(t,this[r],r,this)}),Array.prototype.map||(Array.prototype.map=function(e){var t=this.length>>>0,n=new Array(t),r=arguments[1];for(var i=0;i<t;i++)i in this&&(n[i]=e.call(r,this[i],i,this));return n}),Array.prototype.filter||(Array.prototype.filter=function(e){var t=[],n=arguments[1];for(var r=0;r<this.length;r++)e.call(n,this[r])&&t.push(this[r]);return t}),Array.prototype.reduce||(Array.prototype.reduce=function(e){var t=this.length>>>0,n=0;if(t===0&&arguments.length===1)throw new TypeError;if(arguments.length>=2)var r=arguments[1];else do{if(n in this){r=this[n++];break}if(++n>=t)throw new TypeError}while(!0);for(;n<t;n++)n in this&&(r=e.call(null,r,this[n],n,this));return r}),Array.prototype.indexOf||(Array.prototype.indexOf=function(e){var t=this.length,n=arguments[1]||0;if(!t)return-1;if(n>=t)return-1;n<0&&(n+=t);for(;n<t;n++){if(!Object.prototype.hasOwnProperty.call(this,n))continue;if(e===this[n])return n}return-1}),Object.keys||(Object.keys=function(e){var t=[];for(var n in e)Object.prototype.hasOwnProperty.call(e,n)&&t.push(n);return t}),String.prototype.trim||(String.prototype.trim=function(){return String(this).replace(/^\s\s*/,"").replace(/\s\s*$/,"")});var r,i,s;typeof environment=="object"&&{}.toString.call(environment)==="[object Environment]"?(typeof e=="undefined"?r={}:r=e.less={},i=r.tree={},r.mode="rhino"):typeof e=="undefined"?(r=exports,i=n("./tree"),r.mode="node"):(typeof e.less=="undefined"&&(e.less={}),r=e.less,i=e.less.tree={},r.mode="browser"),r.Parser=function(t){function g(){a=c[u],f=o,h=o}function y(){c[u]=a,o=f,h=o}function b(){o>h&&(c[u]=c[u].slice(o-h),h=o)}function w(e){var t=e.charCodeAt(0);return t===32||t===10||t===9}function E(e){var t,n,r,i,a;if(e instanceof Function)return e.call(p.parsers);if(typeof e=="string")t=s.charAt(o)===e?e:null,r=1,b();else{b();if(!(t=e.exec(c[u])))return null;r=t[0].length}if(t)return S(r),typeof t=="string"?t:t.length===1?t[0]:t}function S(e){var t=o,n=u,r=o+c[u].length,i=o+=e;while(o<r){if(!w(s.charAt(o)))break;o++}return c[u]=c[u].slice(e+(o-i)),h=o,c[u].length===0&&u<c.length-1&&u++,t!==o||n!==u}function x(e,t){var n=E(e);if(!!n)return n;T(t||(typeof e=="string"?"expected '"+e+"' got '"+s.charAt(o)+"'":"unexpected token"))}function T(e,t){var n=new Error(e);throw n.index=o,n.type=t||"Syntax",n}function N(e){return typeof e=="string"?s.charAt(o)===e:e.test(c[u])?!0:!1}function C(e,t){return e.filename&&t.filename&&e.filename!==t.filename?p.imports.contents[e.filename]:s}function k(e,t){for(var n=e,r=-1;n>=0&&t.charAt(n)!=="\n";n--)r++;return{line:typeof e=="number"?(t.slice(0,e).match(/\n/g)||"").length:null,column:r}}function L(e){return r.mode==="browser"||r.mode==="rhino"?e.filename:n("path").resolve(e.filename)}function A(e,t,n){return{lineNumber:k(e,t).line+1,fileName:L(n)}}function O(e,t){var n=C(e,t),r=k(e.index,n),i=r.line,s=r.column,o=n.split("\n");this.type=e.type||"Syntax",this.message=e.message,this.filename=e.filename||t.filename,this.index=e.index,this.line=typeof i=="number"?i+1:null,this.callLine=e.call&&k(e.call,n).line+1,this.callExtract=o[k(e.call,n).line],this.stack=e.stack,this.column=s,this.extract=[o[i-1],o[i],o[i+1]]}var s,o,u,a,f,l,c,h,p,d=this,t=t||{};t.contents||(t.contents={}),t.rootpath=t.rootpath||"",t.files||(t.files={});var v=function(){},m=this.imports={paths:t.paths||[],queue:[],files:t.files,contents:t.contents,mime:t.mime,error:null,push:function(e,n){var i=this;this.queue.push(e),r.Parser.importer(e,this.paths,function(t,r,s){i.queue.splice(i.queue.indexOf(e),1);var o=s in i.files;i.files[s]=r,t&&!i.error&&(i.error=t),n(t,r,o),i.queue.length===0&&v(i.error)},t)}};return this.env=t=t||{},this.optimization="optimization"in this.env?this.env.optimization:1,this.env.filename=this.env.filename||null,p={imports:m,parse:function(e,a){var f,d,m,g,y,b,w=[],S,x=null;o=u=h=l=0,s=e.replace(/\r\n/g,"\n"),s=s.replace(/^\uFEFF/,""),c=function(e){var n=0,r=/(?:@\{[\w-]+\}|[^"'`\{\}\/\(\)\\])+/g,i=/\/\*(?:[^*]|\*+[^\/*])*\*+\/|\/\/.*/g,o=/"((?:[^"\\\r\n]|\\.)*)"|'((?:[^'\\\r\n]|\\.)*)'|`((?:[^`]|\\.)*)`/g,u=0,a,f=e[0],l;for(var c=0,h,p;c<s.length;){r.lastIndex=c,(a=r.exec(s))&&a.index===c&&(c+=a[0].length,f.push(a[0])),h=s.charAt(c),i.lastIndex=o.lastIndex=c;if(a=o.exec(s))if(a.index===c){c+=a[0].length,f.push(a[0]);continue}if(!l&&h==="/"){p=s.charAt(c+1);if(p==="/"||p==="*")if(a=i.exec(s))if(a.index===c){c+=a[0].length,f.push(a[0]);continue}}switch(h){case"{":if(!l){u++,f.push(h);break};case"}":if(!l){u--,f.push(h),e[++n]=f=[];break};case"(":if(!l){l=!0,f.push(h);break};case")":if(l){l=!1,f.push(h);break};default:f.push(h)}c++}return u!=0&&(x=new O({index:c-1,type:"Parse",message:u>0?"missing closing `}`":"missing opening `{`",filename:t.filename},t)),e.map(function(e){return e.join("")})}([[]]);if(x)return a(x,t);try{f=new i.Ruleset([],E(this.parsers.primary)),f.root=!0}catch(T){return a(new O(T,t))}f.toCSS=function(e){var s,o,u;return function(s,o){var u=[],a;s=s||{},typeof o=="object"&&!Array.isArray(o)&&(o=Object.keys(o).map(function(e){var t=o[e];return t instanceof i.Value||(t instanceof i.Expression||(t=new i.Expression([t])),t=new i.Value([t])),new i.Rule("@"+e,t,!1,0)}),u=[new i.Ruleset(null,o)]);try{var f=e.call(this,{frames:u}).toCSS([],{compress:s.compress||!1,dumpLineNumbers:t.dumpLineNumbers})}catch(l){throw new O(l,t)}if(a=p.imports.error)throw a instanceof O?a:new O(a,t);return s.yuicompress&&r.mode==="node"?n("ycssmin").cssmin(f):s.compress?f.replace(/(\s)+/g,"$1"):f}}(f.eval);if(o<s.length-1){o=l,b=s.split("\n"),y=(s.slice(0,o).match(/\n/g)||"").length+1;for(var N=o,C=-1;N>=0&&s.charAt(N)!=="\n";N--)C++;x={type:"Parse",message:"Syntax Error on line "+y,index:o,filename:t.filename,line:y,column:C,extract:[b[y-2],b[y-1],b[y]]}}this.imports.queue.length>0?v=function(e){e=x||e,e?a(e):a(null,f)}:a(x,f)},parsers:{primary:function(){var e,t=[];while((e=E(this.mixin.definition)||E(this.rule)||E(this.ruleset)||E(this.mixin.call)||E(this.comment)||E(this.directive))||E(/^[\s\n]+/)||E(/^;+/))e&&t.push(e);return t},comment:function(){var e;if(s.charAt(o)!=="/")return;if(s.charAt(o+1)==="/")return new i.Comment(E(/^\/\/.*/),!0);if(e=E(/^\/\*(?:[^*]|\*+[^\/*])*\*+\/\n?/))return new i.Comment(e)},entities:{quoted:function(){var e,t=o,n;s.charAt(t)==="~"&&(t++,n=!0);if(s.charAt(t)!=='"'&&s.charAt(t)!=="'")return;n&&E("~");if(e=E(/^"((?:[^"\\\r\n]|\\.)*)"|'((?:[^'\\\r\n]|\\.)*)'/))return new i.Quoted(e[0],e[1]||e[2],n)},keyword:function(){var e;if(e=E(/^[_A-Za-z-][_A-Za-z0-9-]*/))return i.colors.hasOwnProperty(e)?new i.Color(i.colors[e].slice(1)):new i.Keyword(e)},call:function(){var e,n,r,s,a=o;if(!(e=/^([\w-]+|%|progid:[\w\.]+)\(/.exec(c[u])))return;e=e[1],n=e.toLowerCase();if(n==="url")return null;o+=e.length;if(n==="alpha"){s=E(this.alpha);if(typeof s!="undefined")return s}E("("),r=E(this.entities.arguments);if(!E(")"))return;if(e)return new i.Call(e,r,a,t.filename)},arguments:function(){var e=[],t;while(t=E(this.entities.assignment)||E(this.expression)){e.push(t);if(!E(","))break}return e},literal:function(){return E(this.entities.ratio)||E(this.entities.dimension)||E(this.entities.color)||E(this.entities.quoted)||E(this.entities.unicodeDescriptor)},assignment:function(){var e,t;if((e=E(/^\w+(?=\s?=)/i))&&E("=")&&(t=E(this.entity)))return new i.Assignment(e,t)},url:function(){var e;if(s.charAt(o)!=="u"||!E(/^url\(/))return;return e=E(this.entities.quoted)||E(this.entities.variable)||E(/^(?:(?:\\[\(\)'"])|[^\(\)'"])+/)||"",x(")"),new i.URL(e.value!=null||e instanceof i.Variable?e:new i.Anonymous(e),t.rootpath)},variable:function(){var e,n=o;if(s.charAt(o)==="@"&&(e=E(/^@@?[\w-]+/)))return new i.Variable(e,n,t.filename)},variableCurly:function(){var e,n,r=o;if(s.charAt(o)==="@"&&(n=E(/^@\{([\w-]+)\}/)))return new i.Variable("@"+n[1],r,t.filename)},color:function(){var e;if(s.charAt(o)==="#"&&(e=E(/^#([A-Fa-f0-9]{6}|[A-Fa-f0-9]{3})/)))return new i.Color(e[1])},dimension:function(){var e,t=s.charCodeAt(o);if(t>57||t<43||t===47||t==44)return;if(e=E(/^([+-]?\d*\.?\d+)(px|%|em|pc|ex|in|deg|s|ms|pt|cm|mm|rad|grad|turn|dpi|dpcm|dppx|rem|vw|vh|vmin|vm|ch)?/))return new i.Dimension(e[1],e[2])},ratio:function(){var e,t=s.charCodeAt(o);if(t>57||t<48)return;if(e=E(/^(\d+\/\d+)/))return new i.Ratio(e[1])},unicodeDescriptor:function(){var e;if(e=E(/^U\+[0-9a-fA-F?]+(\-[0-9a-fA-F?]+)?/))return new i.UnicodeDescriptor(e[0])},javascript:function(){var e,t=o,n;s.charAt(t)==="~"&&(t++,n=!0);if(s.charAt(t)!=="`")return;n&&E("~");if(e=E(/^`([^`]*)`/))return new i.JavaScript(e[1],o,n)}},variable:function(){var e;if(s.charAt(o)==="@"&&(e=E(/^(@[\w-]+)\s*:/)))return e[1]},shorthand:function(){var e,t;if(!N(/^[@\w.%-]+\/[@\w.-]+/))return;g();if((e=E(this.entity))&&E("/")&&(t=E(this.entity)))return new i.Shorthand(e,t);y()},mixin:{call:function(){var e=[],n,r,u=[],a=[],f,l,c,h,p,d,v,m=o,b=s.charAt(o),w,S,C=!1;if(b!=="."&&b!=="#")return;g();while(n=E(/^[#.](?:[\w-]|\\(?:[A-Fa-f0-9]{1,6} ?|[^A-Fa-f0-9]))+/))e.push(new i.Element(r,n,o)),r=E(">");if(E("(")){p=[];while(c=E(this.expression)){h=null,S=c;if(c.value.length==1){var k=c.value[0];k instanceof i.Variable&&E(":")&&(p.length>0&&(d&&T("Cannot mix ; and , as delimiter types"),v=!0),S=x(this.expression),h=w=k.name)}p.push(S),a.push({name:h,value:S});if(E(","))continue;if(E(";")||d)v&&T("Cannot mix ; and , as delimiter types"),d=!0,p.length>1&&(S=new i.Value(p)),u.push({name:w,value:S}),w=null,p=[],v=!1}x(")")}f=d?u:a,E(this.important)&&(C=!0);if(e.length>0&&(E(";")||N("}")))return new i.mixin.Call(e,f,m,t.filename,C);y()},definition:function(){var e,t=[],n,r,u,a,f,c=!1;if(s.charAt(o)!=="."&&s.charAt(o)!=="#"||N(/^[^{]*\}/))return;g();if(n=E(/^([#.](?:[\w-]|\\(?:[A-Fa-f0-9]{1,6} ?|[^A-Fa-f0-9]))+)\s*\(/)){e=n[1];do{E(this.comment);if(s.charAt(o)==="."&&E(/^\.{3}/)){c=!0,t.push({variadic:!0});break}if(!(u=E(this.entities.variable)||E(this.entities.literal)||E(this.entities.keyword)))break;if(u instanceof i.Variable)if(E(":"))a=x(this.expression,"expected expression"),t.push({name:u.name,value:a});else{if(E(/^\.{3}/)){t.push({name:u.name,variadic:!0}),c=!0;break}t.push({name:u.name})}else t.push({value:u})}while(E(",")||E(";"));E(")")||(l=o,y()),E(this.comment),E(/^when/)&&(f=x(this.conditions,"expected condition")),r=E(this.block);if(r)return new i.mixin.Definition(e,t,r,f,c);y()}}},entity:function(){return E(this.entities.literal)||E(this.entities.variable)||E(this.entities.url)||E(this.entities.call)||E(this.entities.keyword)||E(this.entities.javascript)||E(this.comment)},end:function(){return E(";")||N("}")},alpha:function(){var e;if(!E(/^\(opacity=/i))return;if(e=E(/^\d+/)||E(this.entities.variable))return x(")"),new i.Alpha(e)},element:function(){var e,t,n,r;n=E(this.combinator),e=E(/^(?:\d+\.\d+|\d+)%/)||E(/^(?:[.#]?|:*)(?:[\w-]|[^\x00-\x9f]|\\(?:[A-Fa-f0-9]{1,6} ?|[^A-Fa-f0-9]))+/)||E("*")||E("&")||E(this.attribute)||E(/^\([^()@]+\)/)||E(/^[\.#](?=@)/)||E(this.entities.variableCurly),e||E("(")&&(r=E(this.entities.variableCurly)||E(this.entities.variable)||E(this.selector))&&E(")")&&(e=new i.Paren(r));if(e)return new i.Element(n,e,o)},combinator:function(){var e,t=s.charAt(o);if(t===">"||t==="+"||t==="~"||t==="|"){o++;while(s.charAt(o).match(/\s/))o++;return new i.Combinator(t)}return s.charAt(o-1).match(/\s/)?new i.Combinator(" "):new i.Combinator(null)},selector:function(){var e,t,n=[],r,u;if(E("("))return e=E(this.entity),E(")")?new i.Selector([new i.Element("",e,o)]):null;while(t=E(this.element)){r=s.charAt(o),n.push(t);if(r==="{"||r==="}"||r===";"||r===","||r===")")break}if(n.length>0)return new i.Selector(n)},attribute:function(){var e="",t,n,r;if(!E("["))return;if(t=E(/^(?:[_A-Za-z0-9-]|\\.)+/)||E(this.entities.quoted))(r=E(/^[|~*$^]?=/))&&(n=E(this.entities.quoted)||E(/^[\w-]+/))?e=[t,r,n.toCSS?n.toCSS():n].join(""):e=t;if(!E("]"))return;if(e)return"["+e+"]"},block:function(){var e;if(E("{")&&(e=E(this.primary))&&E("}"))return e},ruleset:function(){var e=[],n,r,u,a;g(),t.dumpLineNumbers&&(a=A(o,s,t));while(n=E(this.selector)){e.push(n),E(this.comment);if(!E(","))break;E(this.comment)}if(e.length>0&&(r=E(this.block))){var f=new i.Ruleset(e,r,t.strictImports);return t.dumpLineNumbers&&(f.debugInfo=a),f}l=o,y()},rule:function(){var e,t,n=s.charAt(o),r,a;g();if(n==="."||n==="#"||n==="&")return;if(e=E(this.variable)||E(this.property)){e.charAt(0)!="@"&&(a=/^([^@+\/'"*`(;{}-]*);/.exec(c[u]))?(o+=a[0].length-1,t=new i.Anonymous(a[1])):e==="font"?t=E(this.font):t=E(this.value),r=E(this.important);if(t&&E(this.end))return new i.Rule(e,t,r,f);l=o,y()}},"import":function(){var e,n,r=o;g();var s=E(/^@import(?:-(once))?\s+/);if(s&&(e=E(this.entities.quoted)||E(this.entities.url))){n=E(this.mediaFeatures);if(E(";"))return new i.Import(e,m,n,s[1]==="once",r,t.rootpath)}y()},mediaFeature:function(){var e,t,n=[];do if(e=E(this.entities.keyword))n.push(e);else if(E("(")){t=E(this.property),e=E(this.entity);if(!E(")"))return null;if(t&&e)n.push(new i.Paren(new i.Rule(t,e,null,o,!0)));else{if(!e)return null;n.push(new i.Paren(e))}}while(e);if(n.length>0)return new i.Expression(n)},mediaFeatures:function(){var e,t=[];do if(e=E(this.mediaFeature)){t.push(e);if(!E(","))break}else if(e=E(this.entities.variable)){t.push(e);if(!E(","))break}while(e);return t.length>0?t:null},media:function(){var e,n,r,u;t.dumpLineNumbers&&(u=A(o,s,t));if(E(/^@media/)){e=E(this.mediaFeatures);if(n=E(this.block))return r=new i.Media(n,e),t.dumpLineNumbers&&(r.debugInfo=u),r}},directive:function(){var e,n,r,u,a,f,l,c,h,p;if(s.charAt(o)!=="@")return;if(n=E(this["import"])||E(this.media))return n;g(),e=E(/^@[a-z-]+/);if(!e)return;l=e,e.charAt(1)=="-"&&e.indexOf("-",2)>0&&(l="@"+e.slice(e.indexOf("-",2)+1));switch(l){case"@font-face":c=!0;break;case"@viewport":case"@top-left":case"@top-left-corner":case"@top-center":case"@top-right":case"@top-right-corner":case"@bottom-left":case"@bottom-left-corner":case"@bottom-center":case"@bottom-right":case"@bottom-right-corner":case"@left-top":case"@left-middle":case"@left-bottom":case"@right-top":case"@right-middle":case"@right-bottom":c=!0;break;case"@page":case"@document":case"@supports":case"@keyframes":c=!0,h=!0;break;case"@namespace":p=!0}h&&(e+=" "+(E(/^[^{]+/)||"").trim());if(c){if(r=E(this.block))return new i.Directive(e,r)}else if((n=p?E(this.expression):E(this.entity))&&E(";")){var d=new i.Directive(e,n);return t.dumpLineNumbers&&(d.debugInfo=A(o,s,t)),d}y()},font:function(){var e=[],t=[],n,r,s,o;while(o=E(this.shorthand)||E(this.entity))t.push(o);e.push(new i.Expression(t));if(E(","))while(o=E(this.expression)){e.push(o);if(!E(","))break}return new i.Value(e)},value:function(){var e,t=[],n;while(e=E(this.expression)){t.push(e);if(!E(","))break}if(t.length>0)return new i.Value(t)},important:function(){if(s.charAt(o)==="!")return E(/^! *important/)},sub:function(){var e;if(E("(")&&(e=E(this.expression))&&E(")"))return e},multiplication:function(){var e,t,n,r;if(e=E(this.operand)){while(!N(/^\/[*\/]/)&&(n=E("/")||E("*"))&&(t=E(this.operand)))r=new i.Operation(n,[r||e,t]);return r||e}},addition:function(){var e,t,n,r;if(e=E(this.multiplication)){while((n=E(/^[-+]\s+/)||!w(s.charAt(o-1))&&(E("+")||E("-")))&&(t=E(this.multiplication)))r=new i.Operation(n,[r||e,t]);return r||e}},conditions:function(){var e,t,n=o,r;if(e=E(this.condition)){while(E(",")&&(t=E(this.condition)))r=new i.Condition("or",r||e,t,n);return r||e}},condition:function(){var e,t,n,r,s=o,u=!1;E(/^not/)&&(u=!0),x("(");if(e=E(this.addition)||E(this.entities.keyword)||E(this.entities.quoted))return(r=E(/^(?:>=|=<|[<=>])/))?(t=E(this.addition)||E(this.entities.keyword)||E(this.entities.quoted))?n=new i.Condition(r,e,t,s,u):T("expected expression"):n=new i.Condition("=",e,new i.Keyword("true"),s,u),x(")"),E(/^and/)?new i.Condition("and",n,E(this.condition)):n},operand:function(){var e,t=s.charAt(o+1);s.charAt(o)==="-"&&(t==="@"||t==="(")&&(e=E("-"));var n=E(this.sub)||E(this.entities.dimension)||E(this.entities.color)||E(this.entities.variable)||E(this.entities.call);return e?new i.Operation("*",[new i.Dimension(-1),n]):n},expression:function(){var e,t,n=[],r;while(e=E(this.addition)||E(this.entity))n.push(e);if(n.length>0)return new i.Expression(n)},property:function(){var e;if(e=E(/^(\*?-?[_a-z0-9-]+)\s*:/))return e[1]}}}};if(r.mode==="browser"||r.mode==="rhino")r.Parser.importer=function(e,t,n,r){!/^([a-z-]+:)?\//.test(e)&&t.length>0&&(e=t[0]+e),w({href:e,title:e,type:r.mime,contents:r.contents,files:r.files,rootpath:r.rootpath,entryPath:r.entryPath,relativeUrls:r.relativeUrls},function(e,i,s,o,u,a){e&&typeof r.errback=="function"?r.errback.call(null,a,t,n,r):n.call(null,e,i,a)},!0)};(function(e){function t(t){return e.functions.hsla(t.h,t.s,t.l,t.a)}function n(t,n){return t instanceof e.Dimension&&t.unit=="%"?parseFloat(t.value*n/100):r(t)}function r(t){if(t instanceof e.Dimension)return parseFloat(t.unit=="%"?t.value/100:t.value);if(typeof t=="number")return t;throw{error:"RuntimeError",message:"color functions take numbers as parameters"}}function i(e){return Math.min(1,Math.max(0,e))}e.functions={rgb:function(e,t,n){return this.rgba(e,t,n,1)},rgba:function(t,i,s,o){var u=[t,i,s].map(function(e){return n(e,256)});return o=r(o),new e.Color(u,o)},hsl:function(e,t,n){return this.hsla(e,t,n,1)},hsla:function(e,t,n,i){function u(e){return e=e<0?e+1:e>1?e-1:e,e*6<1?o+(s-o)*e*6:e*2<1?s:e*3<2?o+(s-o)*(2/3-e)*6:o}e=r(e)%360/360,t=r(t),n=r(n),i=r(i);var s=n<=.5?n*(t+1):n+t-n*t,o=n*2-s;return this.rgba(u(e+1/3)*255,u(e)*255,u(e-1/3)*255,i)},hsv:function(e,t,n){return this.hsva(e,t,n,1)},hsva:function(e,t,n,i){e=r(e)%360/360*360,t=r(t),n=r(n),i=r(i);var s,o;s=Math.floor(e/60%6),o=e/60-s;var u=[n,n*(1-t),n*(1-o*t),n*(1-(1-o)*t)],a=[[0,3,1],[2,0,1],[1,0,3],[1,2,0],[3,1,0],[0,1,2]];return this.rgba(u[a[s][0]]*255,u[a[s][1]]*255,u[a[s][2]]*255,i)},hue:function(t){return new e.Dimension(Math.round(t.toHSL().h))},saturation:function(t){return new e.Dimension(Math.round(t.toHSL().s*100),"%")},lightness:function(t){return new e.Dimension(Math.round(t.toHSL().l*100),"%")},red:function(t){return new e.Dimension(t.rgb[0])},green:function(t){return new e.Dimension(t.rgb[1])},blue:function(t){return new e.Dimension(t.rgb[2])},alpha:function(t){return new e.Dimension(t.toHSL().a)},luma:function(t){return new e.Dimension(Math.round((.2126*(t.rgb[0]/255)+.7152*(t.rgb[1]/255)+.0722*(t.rgb[2]/255))*t.alpha*100),"%")},saturate:function(e,n){var r=e.toHSL();return r.s+=n.value/100,r.s=i(r.s),t(r)},desaturate:function(e,n){var r=e.toHSL();return r.s-=n.value/100,r.s=i(r.s),t(r)},lighten:function(e,n){var r=e.toHSL();return r.l+=n.value/100,r.l=i(r.l),t(r)},darken:function(e,n){var r=e.toHSL();return r.l-=n.value/100,r.l=i(r.l),t(r)},fadein:function(e,n){var r=e.toHSL();return r.a+=n.value/100,r.a=i(r.a),t(r)},fadeout:function(e,n){var r=e.toHSL();return r.a-=n.value/100,r.a=i(r.a),t(r)},fade:function(e,n){var r=e.toHSL();return r.a=n.value/100,r.a=i(r.a),t(r)},spin:function(e,n){var r=e.toHSL(),i=(r.h+n.value)%360;return r.h=i<0?360+i:i,t(r)},mix:function(t,n,r){r||(r=new e.Dimension(50));var i=r.value/100,s=i*2-1,o=t.toHSL().a-n.toHSL().a,u=((s*o==-1?s:(s+o)/(1+s*o))+1)/2,a=1-u,f=[t.rgb[0]*u+n.rgb[0]*a,t.rgb[1]*u+n.rgb[1]*a,t.rgb[2]*u+n.rgb[2]*a],l=t.alpha*i+n.alpha*(1-i);return new e.Color(f,l)},greyscale:function(t){return this.desaturate(t,new e.Dimension(100))},contrast:function(e,t,n,r){return e.rgb?(typeof n=="undefined"&&(n=this.rgba(255,255,255,1)),typeof t=="undefined"&&(t=this.rgba(0,0,0,1)),typeof r=="undefined"?r=.43:r=r.value,(.2126*(e.rgb[0]/255)+.7152*(e.rgb[1]/255)+.0722*(e.rgb[2]/255))*e.alpha<r?n:t):null},e:function(t){return new e.Anonymous(t instanceof e.JavaScript?t.evaluated:t)},escape:function(t){return new e.Anonymous(encodeURI(t.value).replace(/=/g,"%3D").replace(/:/g,"%3A").replace(/#/g,"%23").replace(/;/g,"%3B").replace(/\(/g,"%28").replace(/\)/g,"%29"))},"%":function(t){var n=Array.prototype.slice.call(arguments,1),r=t.value;for(var i=0;i<n.length;i++)r=r.replace(/%[sda]/i,function(e){var t=e.match(/s/i)?n[i].value:n[i].toCSS();return e.match(/[A-Z]$/)?encodeURIComponent(t):t});return r=r.replace(/%%/g,"%"),new e.Quoted('"'+r+'"',r)},unit:function(t,n){return new e.Dimension(t.value,n?n.toCSS():"")},round:function(e,t){var n=typeof t=="undefined"?0:t.value;return this._math(function(e){return e.toFixed(n)},e)},ceil:function(e){return this._math(Math.ceil,e)},floor:function(e){return this._math(Math.floor,e)},_math:function(t,n){if(n instanceof e.Dimension)return new e.Dimension(t(parseFloat(n.value)),n.unit);if(typeof n=="number")return t(n);throw{type:"Argument",message:"argument must be a number"}},argb:function(t){return new e.Anonymous(t.toARGB())},percentage:function(t){return new e.Dimension(t.value*100,"%")},color:function(t){if(t instanceof e.Quoted)return new e.Color(t.value.slice(1));throw{type:"Argument",message:"argument must be a string"}},iscolor:function(t){return this._isa(t,e.Color)},isnumber:function(t){return this._isa(t,e.Dimension)},isstring:function(t){return this._isa(t,e.Quoted)},iskeyword:function(t){return this._isa(t,e.Keyword)},isurl:function(t){return this._isa(t,e.URL)},ispixel:function(t){return t instanceof e.Dimension&&t.unit==="px"?e.True:e.False},ispercentage:function(t){return t instanceof e.Dimension&&t.unit==="%"?e.True:e.False},isem:function(t){return t instanceof e.Dimension&&t.unit==="em"?e.True:e.False},_isa:function(t,n){return t instanceof n?e.True:e.False},multiply:function(e,t){var n=e.rgb[0]*t.rgb[0]/255,r=e.rgb[1]*t.rgb[1]/255,i=e.rgb[2]*t.rgb[2]/255;return this.rgb(n,r,i)},screen:function(e,t){var n=255-(255-e.rgb[0])*(255-t.rgb[0])/255,r=255-(255-e.rgb[1])*(255-t.rgb[1])/255,i=255-(255-e.rgb[2])*(255-t.rgb[2])/255;return this.rgb(n,r,i)},overlay:function(e,t){var n=e.rgb[0]<128?2*e.rgb[0]*t.rgb[0]/255:255-2*(255-e.rgb[0])*(255-t.rgb[0])/255,r=e.rgb[1]<128?2*e.rgb[1]*t.rgb[1]/255:255-2*(255-e.rgb[1])*(255-t.rgb[1])/255,i=e.rgb[2]<128?2*e.rgb[2]*t.rgb[2]/255:255-2*(255-e.rgb[2])*(255-t.rgb[2])/255;return this.rgb(n,r,i)},softlight:function(e,t){var n=t.rgb[0]*e.rgb[0]/255,r=n+e.rgb[0]*(255-(255-e.rgb[0])*(255-t.rgb[0])/255-n)/255;n=t.rgb[1]*e.rgb[1]/255;var i=n+e.rgb[1]*(255-(255-e.rgb[1])*(255-t.rgb[1])/255-n)/255;n=t.rgb[2]*e.rgb[2]/255;var s=n+e.rgb[2]*(255-(255-e.rgb[2])*(255-t.rgb[2])/255-n)/255;return this.rgb(r,i,s)},hardlight:function(e,t){var n=t.rgb[0]<128?2*t.rgb[0]*e.rgb[0]/255:255-2*(255-t.rgb[0])*(255-e.rgb[0])/255,r=t.rgb[1]<128?2*t.rgb[1]*e.rgb[1]/255:255-2*(255-t.rgb[1])*(255-e.rgb[1])/255,i=t.rgb[2]<128?2*t.rgb[2]*e.rgb[2]/255:255-2*(255-t.rgb[2])*(255-e.rgb[2])/255;return this.rgb(n,r,i)},difference:function(e,t){var n=Math.abs(e.rgb[0]-t.rgb[0]),r=Math.abs(e.rgb[1]-t.rgb[1]),i=Math.abs(e.rgb[2]-t.rgb[2]);return this.rgb(n,r,i)},exclusion:function(e,t){var n=e.rgb[0]+t.rgb[0]*(255-e.rgb[0]-e.rgb[0])/255,r=e.rgb[1]+t.rgb[1]*(255-e.rgb[1]-e.rgb[1])/255,i=e.rgb[2]+t.rgb[2]*(255-e.rgb[2]-e.rgb[2])/255;return this.rgb(n,r,i)},average:function(e,t){var n=(e.rgb[0]+t.rgb[0])/2,r=(e.rgb[1]+t.rgb[1])/2,i=(e.rgb[2]+t.rgb[2])/2;return this.rgb(n,r,i)},negation:function(e,t){var n=255-Math.abs(255-t.rgb[0]-e.rgb[0]),r=255-Math.abs(255-t.rgb[1]-e.rgb[1]),i=255-Math.abs(255-t.rgb[2]-e.rgb[2]);return this.rgb(n,r,i)},tint:function(e,t){return this.mix(this.rgb(255,255,255),e,t)},shade:function(e,t){return this.mix(this.rgb(0,0,0),e,t)}}})(n("./tree")),function(e){e.colors={aliceblue:"#f0f8ff",antiquewhite:"#faebd7",aqua:"#00ffff",aquamarine:"#7fffd4",azure:"#f0ffff",beige:"#f5f5dc",bisque:"#ffe4c4",black:"#000000",blanchedalmond:"#ffebcd",blue:"#0000ff",blueviolet:"#8a2be2",brown:"#a52a2a",burlywood:"#deb887",cadetblue:"#5f9ea0",chartreuse:"#7fff00",chocolate:"#d2691e",coral:"#ff7f50",cornflowerblue:"#6495ed",cornsilk:"#fff8dc",crimson:"#dc143c",cyan:"#00ffff",darkblue:"#00008b",darkcyan:"#008b8b",darkgoldenrod:"#b8860b",darkgray:"#a9a9a9",darkgrey:"#a9a9a9",darkgreen:"#006400",darkkhaki:"#bdb76b",darkmagenta:"#8b008b",darkolivegreen:"#556b2f",darkorange:"#ff8c00",darkorchid:"#9932cc",darkred:"#8b0000",darksalmon:"#e9967a",darkseagreen:"#8fbc8f",darkslateblue:"#483d8b",darkslategray:"#2f4f4f",darkslategrey:"#2f4f4f",darkturquoise:"#00ced1",darkviolet:"#9400d3",deeppink:"#ff1493",deepskyblue:"#00bfff",dimgray:"#696969",dimgrey:"#696969",dodgerblue:"#1e90ff",firebrick:"#b22222",floralwhite:"#fffaf0",forestgreen:"#228b22",fuchsia:"#ff00ff",gainsboro:"#dcdcdc",ghostwhite:"#f8f8ff",gold:"#ffd700",goldenrod:"#daa520",gray:"#808080",grey:"#808080",green:"#008000",greenyellow:"#adff2f",honeydew:"#f0fff0",hotpink:"#ff69b4",indianred:"#cd5c5c",indigo:"#4b0082",ivory:"#fffff0",khaki:"#f0e68c",lavender:"#e6e6fa",lavenderblush:"#fff0f5",lawngreen:"#7cfc00",lemonchiffon:"#fffacd",lightblue:"#add8e6",lightcoral:"#f08080",lightcyan:"#e0ffff",lightgoldenrodyellow:"#fafad2",lightgray:"#d3d3d3",lightgrey:"#d3d3d3",lightgreen:"#90ee90",lightpink:"#ffb6c1",lightsalmon:"#ffa07a",lightseagreen:"#20b2aa",lightskyblue:"#87cefa",lightslategray:"#778899",lightslategrey:"#778899",lightsteelblue:"#b0c4de",lightyellow:"#ffffe0",lime:"#00ff00",limegreen:"#32cd32",linen:"#faf0e6",magenta:"#ff00ff",maroon:"#800000",mediumaquamarine:"#66cdaa",mediumblue:"#0000cd",mediumorchid:"#ba55d3",mediumpurple:"#9370d8",mediumseagreen:"#3cb371",mediumslateblue:"#7b68ee",mediumspringgreen:"#00fa9a",mediumturquoise:"#48d1cc",mediumvioletred:"#c71585",midnightblue:"#191970",mintcream:"#f5fffa",mistyrose:"#ffe4e1",moccasin:"#ffe4b5",navajowhite:"#ffdead",navy:"#000080",oldlace:"#fdf5e6",olive:"#808000",olivedrab:"#6b8e23",orange:"#ffa500",orangered:"#ff4500",orchid:"#da70d6",palegoldenrod:"#eee8aa",palegreen:"#98fb98",paleturquoise:"#afeeee",palevioletred:"#d87093",papayawhip:"#ffefd5",peachpuff:"#ffdab9",peru:"#cd853f",pink:"#ffc0cb",plum:"#dda0dd",powderblue:"#b0e0e6",purple:"#800080",red:"#ff0000",rosybrown:"#bc8f8f",royalblue:"#4169e1",saddlebrown:"#8b4513",salmon:"#fa8072",sandybrown:"#f4a460",seagreen:"#2e8b57",seashell:"#fff5ee",sienna:"#a0522d",silver:"#c0c0c0",skyblue:"#87ceeb",slateblue:"#6a5acd",slategray:"#708090",slategrey:"#708090",snow:"#fffafa",springgreen:"#00ff7f",steelblue:"#4682b4",tan:"#d2b48c",teal:"#008080",thistle:"#d8bfd8",tomato:"#ff6347",turquoise:"#40e0d0",violet:"#ee82ee",wheat:"#f5deb3",white:"#ffffff",whitesmoke:"#f5f5f5",yellow:"#ffff00",yellowgreen
-:"#9acd32"}}(n("./tree")),function(e){e.Alpha=function(e){this.value=e},e.Alpha.prototype={toCSS:function(){return"alpha(opacity="+(this.value.toCSS?this.value.toCSS():this.value)+")"},eval:function(e){return this.value.eval&&(this.value=this.value.eval(e)),this}}}(n("../tree")),function(e){e.Anonymous=function(e){this.value=e.value||e},e.Anonymous.prototype={toCSS:function(){return this.value},eval:function(){return this},compare:function(e){if(!e.toCSS)return-1;var t=this.toCSS(),n=e.toCSS();return t===n?0:t<n?-1:1}}}(n("../tree")),function(e){e.Assignment=function(e,t){this.key=e,this.value=t},e.Assignment.prototype={toCSS:function(){return this.key+"="+(this.value.toCSS?this.value.toCSS():this.value)},eval:function(t){return this.value.eval?new e.Assignment(this.key,this.value.eval(t)):this}}}(n("../tree")),function(e){e.Call=function(e,t,n,r){this.name=e,this.args=t,this.index=n,this.filename=r},e.Call.prototype={eval:function(t){var n=this.args.map(function(e){return e.eval(t)}),r;if(this.name in e.functions)try{r=e.functions[this.name].apply(e.functions,n);if(r!=null)return r}catch(i){throw{type:i.type||"Runtime",message:"error evaluating function `"+this.name+"`"+(i.message?": "+i.message:""),index:this.index,filename:this.filename}}return new e.Anonymous(this.name+"("+n.map(function(e){return e.toCSS(t)}).join(", ")+")")},toCSS:function(e){return this.eval(e).toCSS()}}}(n("../tree")),function(e){e.Color=function(e,t){Array.isArray(e)?this.rgb=e:e.length==6?this.rgb=e.match(/.{2}/g).map(function(e){return parseInt(e,16)}):this.rgb=e.split("").map(function(e){return parseInt(e+e,16)}),this.alpha=typeof t=="number"?t:1},e.Color.prototype={eval:function(){return this},toCSS:function(){return this.alpha<1?"rgba("+this.rgb.map(function(e){return Math.round(e)}).concat(this.alpha).join(", ")+")":"#"+this.rgb.map(function(e){return e=Math.round(e),e=(e>255?255:e<0?0:e).toString(16),e.length===1?"0"+e:e}).join("")},operate:function(t,n){var r=[];n instanceof e.Color||(n=n.toColor());for(var i=0;i<3;i++)r[i]=e.operate(t,this.rgb[i],n.rgb[i]);return new e.Color(r,this.alpha+n.alpha)},toHSL:function(){var e=this.rgb[0]/255,t=this.rgb[1]/255,n=this.rgb[2]/255,r=this.alpha,i=Math.max(e,t,n),s=Math.min(e,t,n),o,u,a=(i+s)/2,f=i-s;if(i===s)o=u=0;else{u=a>.5?f/(2-i-s):f/(i+s);switch(i){case e:o=(t-n)/f+(t<n?6:0);break;case t:o=(n-e)/f+2;break;case n:o=(e-t)/f+4}o/=6}return{h:o*360,s:u,l:a,a:r}},toARGB:function(){var e=[Math.round(this.alpha*255)].concat(this.rgb);return"#"+e.map(function(e){return e=Math.round(e),e=(e>255?255:e<0?0:e).toString(16),e.length===1?"0"+e:e}).join("")},compare:function(e){return e.rgb?e.rgb[0]===this.rgb[0]&&e.rgb[1]===this.rgb[1]&&e.rgb[2]===this.rgb[2]&&e.alpha===this.alpha?0:-1:-1}}}(n("../tree")),function(e){e.Comment=function(e,t){this.value=e,this.silent=!!t},e.Comment.prototype={toCSS:function(e){return e.compress?"":this.value},eval:function(){return this}}}(n("../tree")),function(e){e.Condition=function(e,t,n,r,i){this.op=e.trim(),this.lvalue=t,this.rvalue=n,this.index=r,this.negate=i},e.Condition.prototype.eval=function(e){var t=this.lvalue.eval(e),n=this.rvalue.eval(e),r=this.index,i,i=function(e){switch(e){case"and":return t&&n;case"or":return t||n;default:if(t.compare)i=t.compare(n);else{if(!n.compare)throw{type:"Type",message:"Unable to perform comparison",index:r};i=n.compare(t)}switch(i){case-1:return e==="<"||e==="=<";case 0:return e==="="||e===">="||e==="=<";case 1:return e===">"||e===">="}}}(this.op);return this.negate?!i:i}}(n("../tree")),function(e){e.Dimension=function(e,t){this.value=parseFloat(e),this.unit=t||null},e.Dimension.prototype={eval:function(){return this},toColor:function(){return new e.Color([this.value,this.value,this.value])},toCSS:function(){var e=this.value+this.unit;return e},operate:function(t,n){return new e.Dimension(e.operate(t,this.value,n.value),this.unit||n.unit)},compare:function(t){return t instanceof e.Dimension?t.value>this.value?-1:t.value<this.value?1:t.unit&&this.unit!==t.unit?-1:0:-1}}}(n("../tree")),function(e){e.Directive=function(t,n){this.name=t,Array.isArray(n)?(this.ruleset=new e.Ruleset([],n),this.ruleset.allowImports=!0):this.value=n},e.Directive.prototype={toCSS:function(e,t){return this.ruleset?(this.ruleset.root=!0,this.name+(t.compress?"{":" {\n  ")+this.ruleset.toCSS(e,t).trim().replace(/\n/g,"\n  ")+(t.compress?"}":"\n}\n")):this.name+" "+this.value.toCSS()+";\n"},eval:function(t){var n=this;return this.ruleset&&(t.frames.unshift(this),n=new e.Directive(this.name),n.ruleset=this.ruleset.eval(t),t.frames.shift()),n},variable:function(t){return e.Ruleset.prototype.variable.call(this.ruleset,t)},find:function(){return e.Ruleset.prototype.find.apply(this.ruleset,arguments)},rulesets:function(){return e.Ruleset.prototype.rulesets.apply(this.ruleset)}}}(n("../tree")),function(e){e.Element=function(t,n,r){this.combinator=t instanceof e.Combinator?t:new e.Combinator(t),typeof n=="string"?this.value=n.trim():n?this.value=n:this.value="",this.index=r},e.Element.prototype.eval=function(t){return new e.Element(this.combinator,this.value.eval?this.value.eval(t):this.value,this.index)},e.Element.prototype.toCSS=function(e){var t=this.value.toCSS?this.value.toCSS(e):this.value;return t==""&&this.combinator.value.charAt(0)=="&"?"":this.combinator.toCSS(e||{})+t},e.Combinator=function(e){e===" "?this.value=" ":this.value=e?e.trim():""},e.Combinator.prototype.toCSS=function(e){return{"":""," ":" ",":":" :","+":e.compress?"+":" + ","~":e.compress?"~":" ~ ",">":e.compress?">":" > ","|":e.compress?"|":" | "}[this.value]}}(n("../tree")),function(e){e.Expression=function(e){this.value=e},e.Expression.prototype={eval:function(t){return this.value.length>1?new e.Expression(this.value.map(function(e){return e.eval(t)})):this.value.length===1?this.value[0].eval(t):this},toCSS:function(e){return this.value.map(function(t){return t.toCSS?t.toCSS(e):""}).join(" ")}}}(n("../tree")),function(e){e.Import=function(t,n,r,i,s,o){var u=this;this.once=i,this.index=s,this._path=t,this.features=r&&new e.Value(r),this.rootpath=o,t instanceof e.Quoted?this.path=/(\.[a-z]*$)|([\?;].*)$/.test(t.value)?t.value:t.value+".less":this.path=t.value.value||t.value,this.css=/css([\?;].*)?$/.test(this.path),this.css||n.push(this.path,function(t,n,r){t&&(t.index=s),r&&u.once&&(u.skip=r),u.root=n||new e.Ruleset([],[])})},e.Import.prototype={toCSS:function(e){var t=this.features?" "+this.features.toCSS(e):"";return this.css?(typeof this._path.value=="string"&&!/^(?:[a-z-]+:|\/)/.test(this._path.value)&&(this._path.value=this.rootpath+this._path.value),"@import "+this._path.toCSS()+t+";\n"):""},eval:function(t){var n,r=this.features&&this.features.eval(t);return this.skip?[]:this.css?this:(n=new e.Ruleset([],this.root.rules.slice(0)),n.evalImports(t),this.features?new e.Media(n.rules,this.features.value):n.rules)}}}(n("../tree")),function(e){e.JavaScript=function(e,t,n){this.escaped=n,this.expression=e,this.index=t},e.JavaScript.prototype={eval:function(t){var n,r=this,i={},s=this.expression.replace(/@\{([\w-]+)\}/g,function(n,i){return e.jsify((new e.Variable("@"+i,r.index)).eval(t))});try{s=new Function("return ("+s+")")}catch(o){throw{message:"JavaScript evaluation error: `"+s+"`",index:this.index}}for(var u in t.frames[0].variables())i[u.slice(1)]={value:t.frames[0].variables()[u].value,toJS:function(){return this.value.eval(t).toCSS()}};try{n=s.call(i)}catch(o){throw{message:"JavaScript evaluation error: '"+o.name+": "+o.message+"'",index:this.index}}return typeof n=="string"?new e.Quoted('"'+n+'"',n,this.escaped,this.index):Array.isArray(n)?new e.Anonymous(n.join(", ")):new e.Anonymous(n)}}}(n("../tree")),function(e){e.Keyword=function(e){this.value=e},e.Keyword.prototype={eval:function(){return this},toCSS:function(){return this.value},compare:function(t){return t instanceof e.Keyword?t.value===this.value?0:1:-1}},e.True=new e.Keyword("true"),e.False=new e.Keyword("false")}(n("../tree")),function(e){e.Media=function(t,n){var r=this.emptySelectors();this.features=new e.Value(n),this.ruleset=new e.Ruleset(r,t),this.ruleset.allowImports=!0},e.Media.prototype={toCSS:function(e,t){var n=this.features.toCSS(t);return this.ruleset.root=e.length===0||e[0].multiMedia,"@media "+n+(t.compress?"{":" {\n  ")+this.ruleset.toCSS(e,t).trim().replace(/\n/g,"\n  ")+(t.compress?"}":"\n}\n")},eval:function(t){t.mediaBlocks||(t.mediaBlocks=[],t.mediaPath=[]);var n=new e.Media([],[]);return this.debugInfo&&(this.ruleset.debugInfo=this.debugInfo,n.debugInfo=this.debugInfo),n.features=this.features.eval(t),t.mediaPath.push(n),t.mediaBlocks.push(n),t.frames.unshift(this.ruleset),n.ruleset=this.ruleset.eval(t),t.frames.shift(),t.mediaPath.pop(),t.mediaPath.length===0?n.evalTop(t):n.evalNested(t)},variable:function(t){return e.Ruleset.prototype.variable.call(this.ruleset,t)},find:function(){return e.Ruleset.prototype.find.apply(this.ruleset,arguments)},rulesets:function(){return e.Ruleset.prototype.rulesets.apply(this.ruleset)},emptySelectors:function(){var t=new e.Element("","&",0);return[new e.Selector([t])]},evalTop:function(t){var n=this;if(t.mediaBlocks.length>1){var r=this.emptySelectors();n=new e.Ruleset(r,t.mediaBlocks),n.multiMedia=!0}return delete t.mediaBlocks,delete t.mediaPath,n},evalNested:function(t){var n,r,i=t.mediaPath.concat([this]);for(n=0;n<i.length;n++)r=i[n].features instanceof e.Value?i[n].features.value:i[n].features,i[n]=Array.isArray(r)?r:[r];return this.features=new e.Value(this.permute(i).map(function(t){t=t.map(function(t){return t.toCSS?t:new e.Anonymous(t)});for(n=t.length-1;n>0;n--)t.splice(n,0,new e.Anonymous("and"));return new e.Expression(t)})),new e.Ruleset([],[])},permute:function(e){if(e.length===0)return[];if(e.length===1)return e[0];var t=[],n=this.permute(e.slice(1));for(var r=0;r<n.length;r++)for(var i=0;i<e[0].length;i++)t.push([e[0][i]].concat(n[r]));return t},bubbleSelectors:function(t){this.ruleset=new e.Ruleset(t.slice(0),[this.ruleset])}}}(n("../tree")),function(e){e.mixin={},e.mixin.Call=function(t,n,r,i,s){this.selector=new e.Selector(t),this.arguments=n,this.index=r,this.filename=i,this.important=s},e.mixin.Call.prototype={eval:function(t){var n,r,i,s=[],o=!1,u,a,f,l,c;i=this.arguments&&this.arguments.map(function(e){return{name:e.name,value:e.value.eval(t)}});for(u=0;u<t.frames.length;u++)if((n=t.frames[u].find(this.selector)).length>0){c=!0;for(a=0;a<n.length;a++){r=n[a],l=!1;for(f=0;f<t.frames.length;f++)if(!(r instanceof e.mixin.Definition)&&r===(t.frames[f].originalRuleset||t.frames[f])){l=!0;break}if(l)continue;if(r.matchArgs(i,t)){if(!r.matchCondition||r.matchCondition(i,t))try{Array.prototype.push.apply(s,r.eval(t,i,this.important).rules)}catch(h){throw{message:h.message,index:this.index,filename:this.filename,stack:h.stack}}o=!0}}if(o)return s}throw c?{type:"Runtime",message:"No matching definition was found for `"+this.selector.toCSS().trim()+"("+(i?i.map(function(e){var t="";return e.name&&(t+=e.name+":"),e.value.toCSS?t+=e.value.toCSS():t+="???",t}).join(", "):"")+")`",index:this.index,filename:this.filename}:{type:"Name",message:this.selector.toCSS().trim()+" is undefined",index:this.index,filename:this.filename}}},e.mixin.Definition=function(t,n,r,i,s){this.name=t,this.selectors=[new e.Selector([new e.Element(null,t)])],this.params=n,this.condition=i,this.variadic=s,this.arity=n.length,this.rules=r,this._lookups={},this.required=n.reduce(function(e,t){return!t.name||t.name&&!t.value?e+1:e},0),this.parent=e.Ruleset.prototype,this.frames=[]},e.mixin.Definition.prototype={toCSS:function(){return""},variable:function(e){return this.parent.variable.call(this,e)},variables:function(){return this.parent.variables.call(this)},find:function(){return this.parent.find.apply(this,arguments)},rulesets:function(){return this.parent.rulesets.apply(this)},evalParams:function(t,n,r,i){var s=new e.Ruleset(null,[]),o,u,a=this.params.slice(0),f,l,c,h,p,d;if(r){r=r.slice(0);for(f=0;f<r.length;f++){u=r[f];if(h=u&&u.name){p=!1;for(l=0;l<a.length;l++)if(!i[l]&&h===a[l].name){i[l]=u.value.eval(t),s.rules.unshift(new e.Rule(h,u.value.eval(t))),p=!0;break}if(p){r.splice(f,1),f--;continue}throw{type:"Runtime",message:"Named argument for "+this.name+" "+r[f].name+" not found"}}}}d=0;for(f=0;f<a.length;f++){if(i[f])continue;u=r&&r[d];if(h=a[f].name)if(a[f].variadic&&r){o=[];for(l=d;l<r.length;l++)o.push(r[l].value.eval(t));s.rules.unshift(new e.Rule(h,(new e.Expression(o)).eval(t)))}else{c=u&&u.value;if(c)c=c.eval(t);else{if(!a[f].value)throw{type:"Runtime",message:"wrong number of arguments for "+this.name+" ("+r.length+" for "+this.arity+")"};c=a[f].value.eval(n)}s.rules.unshift(new e.Rule(h,c)),i[f]=c}if(a[f].variadic&&r)for(l=d;l<r.length;l++)i[l]=r[l].value.eval(t);d++}return s},eval:function(t,n,r){var i=[],s=this.frames.concat(t.frames),o=this.evalParams(t,{frames:s},n,i),u,a,f,l;return o.rules.unshift(new e.Rule("@arguments",(new e.Expression(i)).eval(t))),a=r?this.parent.makeImportant.apply(this).rules:this.rules.slice(0),l=(new e.Ruleset(null,a)).eval({frames:[this,o].concat(s)}),l.originalRuleset=this,l},matchCondition:function(e,t){return this.condition&&!this.condition.eval({frames:[this.evalParams(t,{frames:this.frames.concat(t.frames)},e,[])].concat(t.frames)})?!1:!0},matchArgs:function(e,t){var n=e&&e.length||0,r,i;if(!this.variadic){if(n<this.required)return!1;if(n>this.params.length)return!1;if(this.required>0&&n>this.params.length)return!1}r=Math.min(n,this.arity);for(var s=0;s<r;s++)if(!this.params[s].name&&!this.params[s].variadic&&e[s].value.eval(t).toCSS()!=this.params[s].value.eval(t).toCSS())return!1;return!0}}}(n("../tree")),function(e){e.Operation=function(e,t){this.op=e.trim(),this.operands=t},e.Operation.prototype.eval=function(t){var n=this.operands[0].eval(t),r=this.operands[1].eval(t),i;if(n instanceof e.Dimension&&r instanceof e.Color){if(this.op!=="*"&&this.op!=="+")throw{name:"OperationError",message:"Can't substract or divide a color from a number"};i=r,r=n,n=i}if(!n.operate)throw{name:"OperationError",message:"Operation on an invalid type"};return n.operate(this.op,r)},e.operate=function(e,t,n){switch(e){case"+":return t+n;case"-":return t-n;case"*":return t*n;case"/":return t/n}}}(n("../tree")),function(e){e.Paren=function(e){this.value=e},e.Paren.prototype={toCSS:function(e){return"("+this.value.toCSS(e)+")"},eval:function(t){return new e.Paren(this.value.eval(t))}}}(n("../tree")),function(e){e.Quoted=function(e,t,n,r){this.escaped=n,this.value=t||"",this.quote=e.charAt(0),this.index=r},e.Quoted.prototype={toCSS:function(){return this.escaped?this.value:this.quote+this.value+this.quote},eval:function(t){var n=this,r=this.value.replace(/`([^`]+)`/g,function(r,i){return(new e.JavaScript(i,n.index,!0)).eval(t).value}).replace(/@\{([\w-]+)\}/g,function(r,i){var s=(new e.Variable("@"+i,n.index)).eval(t);return s instanceof e.Quoted?s.value:s.toCSS()});return new e.Quoted(this.quote+r+this.quote,r,this.escaped,this.index)},compare:function(e){if(!e.toCSS)return-1;var t=this.toCSS(),n=e.toCSS();return t===n?0:t<n?-1:1}}}(n("../tree")),function(e){e.Ratio=function(e){this.value=e},e.Ratio.prototype={toCSS:function(e){return this.value},eval:function(){return this}}}(n("../tree")),function(e){e.Rule=function(t,n,r,i,s){this.name=t,this.value=n instanceof e.Value?n:new e.Value([n]),this.important=r?" "+r.trim():"",this.index=i,this.inline=s||!1,t.charAt(0)==="@"?this.variable=!0:this.variable=!1},e.Rule.prototype.toCSS=function(e){return this.variable?"":this.name+(e.compress?":":": ")+this.value.toCSS(e)+this.important+(this.inline?"":";")},e.Rule.prototype.eval=function(t){return new e.Rule(this.name,this.value.eval(t),this.important,this.index,this.inline)},e.Rule.prototype.makeImportant=function(){return new e.Rule(this.name,this.value,"!important",this.index,this.inline)},e.Shorthand=function(e,t){this.a=e,this.b=t},e.Shorthand.prototype={toCSS:function(e){return this.a.toCSS(e)+"/"+this.b.toCSS(e)},eval:function(){return this}}}(n("../tree")),function(e){e.Ruleset=function(e,t,n){this.selectors=e,this.rules=t,this._lookups={},this.strictImports=n},e.Ruleset.prototype={eval:function(t){var n=this.selectors&&this.selectors.map(function(e){return e.eval(t)}),r=new e.Ruleset(n,this.rules.slice(0),this.strictImports),i;r.originalRuleset=this,r.root=this.root,r.allowImports=this.allowImports,this.debugInfo&&(r.debugInfo=this.debugInfo),t.frames.unshift(r),(r.root||r.allowImports||!r.strictImports)&&r.evalImports(t);for(var s=0;s<r.rules.length;s++)r.rules[s]instanceof e.mixin.Definition&&(r.rules[s].frames=t.frames.slice(0));var o=t.mediaBlocks&&t.mediaBlocks.length||0;for(var s=0;s<r.rules.length;s++)r.rules[s]instanceof e.mixin.Call&&(i=r.rules[s].eval(t),r.rules.splice.apply(r.rules,[s,1].concat(i)),s+=i.length-1,r.resetCache());for(var s=0,u;s<r.rules.length;s++)u=r.rules[s],u instanceof e.mixin.Definition||(r.rules[s]=u.eval?u.eval(t):u);t.frames.shift();if(t.mediaBlocks)for(var s=o;s<t.mediaBlocks.length;s++)t.mediaBlocks[s].bubbleSelectors(n);return r},evalImports:function(t){var n,r;for(n=0;n<this.rules.length;n++)this.rules[n]instanceof e.Import&&(r=this.rules[n].eval(t),typeof r.length=="number"?(this.rules.splice.apply(this.rules,[n,1].concat(r)),n+=r.length-1):this.rules.splice(n,1,r),this.resetCache())},makeImportant:function(){return new e.Ruleset(this.selectors,this.rules.map(function(e){return e.makeImportant?e.makeImportant():e}),this.strictImports)},matchArgs:function(e){return!e||e.length===0},resetCache:function(){this._rulesets=null,this._variables=null,this._lookups={}},variables:function(){return this._variables?this._variables:this._variables=this.rules.reduce(function(t,n){return n instanceof e.Rule&&n.variable===!0&&(t[n.name]=n),t},{})},variable:function(e){return this.variables()[e]},rulesets:function(){return this._rulesets?this._rulesets:this._rulesets=this.rules.filter(function(t){return t instanceof e.Ruleset||t instanceof e.mixin.Definition})},find:function(t,n){n=n||this;var r=[],i,s,o=t.toCSS();return o in this._lookups?this._lookups[o]:(this.rulesets().forEach(function(i){if(i!==n)for(var o=0;o<i.selectors.length;o++)if(s=t.match(i.selectors[o])){t.elements.length>i.selectors[o].elements.length?Array.prototype.push.apply(r,i.find(new e.Selector(t.elements.slice(1)),n)):r.push(i);break}}),this._lookups[o]=r)},toCSS:function(t,n){var r=[],i=[],s=[],o=[],u=[],a,f,l;this.root||this.joinSelectors(u,t,this.selectors);for(var c=0;c<this.rules.length;c++){l=this.rules[c];if(l.rules||l instanceof e.Media)o.push(l.toCSS(u,n));else if(l instanceof e.Directive){var h=l.toCSS(u,n);if(l.name==="@charset"){if(n.charset){l.debugInfo&&(o.push(e.debugInfo(n,l)),o.push((new e.Comment("/* "+h.replace(/\n/g,"")+" */\n")).toCSS(n)));continue}n.charset=!0}o.push(h)}else l instanceof e.Comment?l.silent||(this.root?o.push(l.toCSS(n)):i.push(l.toCSS(n))):l.toCSS&&!l.variable?i.push(l.toCSS(n)):l.value&&!l.variable&&i.push(l.value.toString())}o=o.join("");if(this.root)r.push(i.join(n.compress?"":"\n"));else if(i.length>0){f=e.debugInfo(n,this),a=u.map(function(e){return e.map(function(e){return e.toCSS(n)}).join("").trim()}).join(n.compress?",":",\n");for(var c=i.length-1;c>=0;c--)s.indexOf(i[c])===-1&&s.unshift(i[c]);i=s,r.push(f+a+(n.compress?"{":" {\n  ")+i.join(n.compress?"":"\n  ")+(n.compress?"}":"\n}\n"))}return r.push(o),r.join("")+(n.compress?"\n":"")},joinSelectors:function(e,t,n){for(var r=0;r<n.length;r++)this.joinSelector(e,t,n[r])},joinSelector:function(t,n,r){var i,s,o,u,a,f,l,c,h,p,d,v,m,g,y;for(i=0;i<r.elements.length;i++)f=r.elements[i],f.value==="&"&&(u=!0);if(!u){if(n.length>0)for(i=0;i<n.length;i++)t.push(n[i].concat(r));else t.push([r]);return}g=[],a=[[]];for(i=0;i<r.elements.length;i++){f=r.elements[i];if(f.value!=="&")g.push(f);else{y=[],g.length>0&&this.mergeElementsOnToSelectors(g,a);for(s=0;s<a.length;s++){l=a[s];if(n.length==0)l.length>0&&(l[0].elements=l[0].elements.slice(0),l[0].elements.push(new e.Element(f.combinator,"",0))),y.push(l);else for(o=0;o<n.length;o++)c=n[o],h=[],p=[],v=!0,l.length>0?(h=l.slice(0),m=h.pop(),d=new e.Selector(m.elements.slice(0)),v=!1):d=new e.Selector([]),c.length>1&&(p=p.concat(c.slice(1))),c.length>0&&(v=!1,d.elements.push(new e.Element(f.combinator,c[0].elements[0].value,0)),d.elements=d.elements.concat(c[0].elements.slice(1))),v||h.push(d),h=h.concat(p),y.push(h)}a=y,g=[]}}g.length>0&&this.mergeElementsOnToSelectors(g,a);for(i=0;i<a.length;i++)t.push(a[i])},mergeElementsOnToSelectors:function(t,n){var r,i;if(n.length==0){n.push([new e.Selector(t)]);return}for(r=0;r<n.length;r++)i=n[r],i.length>0?i[i.length-1]=new e.Selector(i[i.length-1].elements.concat(t)):i.push(new e.Selector(t))}}}(n("../tree")),function(e){e.Selector=function(e){this.elements=e},e.Selector.prototype.match=function(e){var t=this.elements,n=t.length,r,i,s,o;r=e.elements.slice(e.elements.length&&e.elements[0].value==="&"?1:0),i=r.length,s=Math.min(n,i);if(i===0||n<i)return!1;for(o=0;o<s;o++)if(t[o].value!==r[o].value)return!1;return!0},e.Selector.prototype.eval=function(t){return new e.Selector(this.elements.map(function(e){return e.eval(t)}))},e.Selector.prototype.toCSS=function(e){return this._css?this._css:(this.elements[0].combinator.value===""?this._css=" ":this._css="",this._css+=this.elements.map(function(t){return typeof t=="string"?" "+t.trim():t.toCSS(e)}).join(""),this._css)}}(n("../tree")),function(e){e.UnicodeDescriptor=function(e){this.value=e},e.UnicodeDescriptor.prototype={toCSS:function(e){return this.value},eval:function(){return this}}}(n("../tree")),function(e){e.URL=function(e,t){this.value=e,this.rootpath=t},e.URL.prototype={toCSS:function(){return"url("+this.value.toCSS()+")"},eval:function(t){var n=this.value.eval(t),r;return typeof n.value=="string"&&!/^(?:[a-z-]+:|\/)/.test(n.value)&&(r=this.rootpath,n.quote||(r=r.replace(/[\(\)'"\s]/g,function(e){return"\\"+e})),n.value=r+n.value),new e.URL(n,this.rootpath)}}}(n("../tree")),function(e){e.Value=function(e){this.value=e,this.is="value"},e.Value.prototype={eval:function(t){return this.value.length===1?this.value[0].eval(t):new e.Value(this.value.map(function(e){return e.eval(t)}))},toCSS:function(e){return this.value.map(function(t){return t.toCSS(e)}).join(e.compress?",":", ")}}}(n("../tree")),function(e){e.Variable=function(e,t,n){this.name=e,this.index=t,this.file=n},e.Variable.prototype={eval:function(t){var n,r,i=this.name;i.indexOf("@@")==0&&(i="@"+(new e.Variable(i.slice(1))).eval(t).value);if(this.evaluating)throw{type:"Name",message:"Recursive variable definition for "+i,filename:this.file,index:this.index};this.evaluating=!0;if(n=e.find(t.frames,function(e){if(r=e.variable(i))return r.value.eval(t)}))return this.evaluating=!1,n;throw{type:"Name",message:"variable "+i+" is undefined",filename:this.file,index:this.index}}}}(n("../tree")),function(e){e.debugInfo=function(t,n){var r="";if(t.dumpLineNumbers&&!t.compress)switch(t.dumpLineNumbers){case"comments":r=e.debugInfo.asComment(n);break;case"mediaquery":r=e.debugInfo.asMediaQuery(n);break;case"all":r=e.debugInfo.asComment(n)+e.debugInfo.asMediaQuery(n)}return r},e.debugInfo.asComment=function(e){return"/* line "+e.debugInfo.lineNumber+", "+e.debugInfo.fileName+" */\n"},e.debugInfo.asMediaQuery=function(e){return"@media -sass-debug-info{filename{font-family:"+("file://"+e.debugInfo.fileName).replace(/[\/:.]/g,"\\$&")+"}line{font-family:\\00003"+e.debugInfo.lineNumber+"}}\n"},e.find=function(e,t){for(var n=0,r;n<e.length;n++)if(r=t.call(e,e[n]))return r;return null},e.jsify=function(e){return Array.isArray(e.value)&&e.value.length>1?"["+e.value.map(function(e){return e.toCSS(!1)}).join(", ")+"]":e.toCSS(!1)}}(n("./tree"));var o=/^(file|chrome(-extension)?|resource|qrc|app):/.test(location.protocol);r.env=r.env||(location.hostname=="127.0.0.1"||location.hostname=="0.0.0.0"||location.hostname=="localhost"||location.port.length>0||o?"development":"production"),r.async=r.async||!1,r.fileAsync=r.fileAsync||!1,r.poll=r.poll||(o?1e3:1500);if(r.functions)for(var u in r.functions)r.tree.functions[u]=r.functions[u];var a=/!dumpLineNumbers:(comments|mediaquery|all)/.exec(location.hash);a&&(r.dumpLineNumbers=a[1]),r.watch=function(){return r.watchMode||(r.env="development",f()),this.watchMode=!0},r.unwatch=function(){return clearInterval(r.watchTimer),this.watchMode=!1},/!watch/.test(location.hash)&&r.watch();var l=null;if(r.env!="development")try{l=typeof e.localStorage=="undefined"?null:e.localStorage}catch(c){}var h=document.getElementsByTagName("link"),p=/^text\/(x-)?less$/;r.sheets=[];for(var d=0;d<h.length;d++)(h[d].rel==="stylesheet/less"||h[d].rel.match(/stylesheet/)&&h[d].type.match(p))&&r.sheets.push(h[d]);var v="";r.modifyVars=function(e){var t=v;for(name in e)t+=(name.slice(0,1)==="@"?"":"@")+name+": "+(e[name].slice(-1)===";"?e[name]:e[name]+";");(new r.Parser).parse(t,function(e,t){S(t.toCSS(),r.sheets[r.sheets.length-1])})},r.refresh=function(e){var t,n;t=n=new Date,g(function(e,r,i,s,o){o.local?C("loading "+s.href+" from cache."):(C("parsed "+s.href+" successfully."),S(r.toCSS(),s,o.lastModified)),C("css for "+s.href+" generated in "+(new Date-n)+"ms"),o.remaining===0&&C("css generated in "+(new Date-t)+"ms"),n=new Date},e),m()},r.refreshStyles=m,r.refresh(r.env==="development"),typeof define=="function"&&define.amd&&define("less",[],function(){return r})})(window);
\ No newline at end of file
diff --git a/opendaylight/adsal/web/root/src/main/resources/js/lib.js b/opendaylight/adsal/web/root/src/main/resources/js/lib.js
deleted file mode 100644 (file)
index c265760..0000000
+++ /dev/null
@@ -1,395 +0,0 @@
-// global
-var one = {
-    // global variables
-    global : {
-        remoteAddress : "/"
-    },
-    role : null
-}
-
-// one ui library
-one.lib = {};
-
-// registry
-one.lib.registry = {};
-
-/** DASHLET */
-one.lib.dashlet = {
-    empty : function($dashlet) {
-        $dashlet.empty();
-    },
-    append : function($dashlet, $content) {
-        $dashlet.append($content);
-    },
-    header : function(header) {
-        var $h4 = $(document.createElement('h4'));
-        $h4.text(header);
-        return $h4;
-    },
-    label : function(name, type) {
-        var $span = $(document.createElement('span'));
-        $span.addClass('label');
-        if (type !== undefined) {
-            $span.addClass(type);
-        } else if (type !== null) {
-            $span.addClass('label-info');
-        }
-        $span.append(name);
-        return $span;
-    },
-    list : function(list) {
-        var $ul = $(document.createElement('ul'));
-        $(list).each(function(index, value) {
-            var $li = $(document.createElement('li'));
-            $li.append(value);
-            $ul.append($li);
-        });
-        return $ul;
-    },
-    button : {
-        config : function(name, id, type, size) {
-            var button = {};
-            button['name'] = name;
-            button['id'] = id;
-            button['type'] = type;
-            button['size'] = size;
-            return button;
-        },
-        single : function(name, id, type, size) {
-            var buttonList = [];
-            var button = one.lib.dashlet.button.config(name, id, type, size);
-            buttonList.push(button);
-            return buttonList;
-        },
-        button : function(buttonList) {
-            var $buttonGroup = $(document.createElement('div'));
-            $buttonGroup.addClass("btn-group");
-            $(buttonList).each(function(index, value) {
-                var $button = $(document.createElement('button'));
-                $button.text(value.name);
-                $button.addClass('btn');
-                $button.addClass(value['type']);
-                $button.addClass(value['size']);
-                if (!(typeof value.id === 'undefined')) {
-                    $button.attr('id', value.id);
-                }
-                $buttonGroup.append($button);
-            });
-            return $buttonGroup;
-        }
-    },
-    datagrid: {
-        /*
-         * The init function returns HTML markup for the datagrid per the options provided. Each consumer 
-         * of the datagrid must first call init and then provide the datasource for the grid.   
-         * id: this is the id of the table
-         * options: {
-         * searchable: true/false,
-         * pagination: turned off for now,
-         * flexibleRowsPerPage: turned off
-         * }
-         * classes : String containing bootstrap related classes. For ex: "table-striped table-condensed"
-         * The classes "table", "table-bordered" and "datagrid" will be added by default
-         */
-        init: function(id, options, classes) {
-            var $fuelGridContainerDiv = $(document.createElement("div"));
-            $fuelGridContainerDiv.addClass("fuelux");
-            $table = $(document.createElement("table"));
-            $table.attr("id", id);
-            $table.addClass("table table-bordered datagrid");
-            $table.addClass(classes);
-            // create datagrid header
-            $thead = $(document.createElement("thead"));
-            $headertr = $(document.createElement("tr"));
-            $headerth = $(document.createElement("th"));
-            // create datagrid footer
-            $tfoot = $(document.createElement("tfoot"));
-            $footertr = $(document.createElement("tr"));
-            $footerth = $(document.createElement("th"));
-            if(options.searchable == true) {
-                $headerth.append(one.lib.dashlet.datagrid._searchable());
-            }
-            if(options.flexibleRowsPerPage == true) {
-                $footerth.append(one.lib.dashlet.datagrid._rowsPerPage(options.popout));
-            }
-            if(options.pagination == true) {
-                $footerth.append(one.lib.dashlet.datagrid._pagination());
-            }
-            $headertr.append($headerth);
-            $thead.append($headertr);
-            $footertr.append($footerth);
-            $tfoot.append($footertr);
-            $table.append($thead).append($tfoot);
-            $fuelGridContainerDiv.append($table);
-            return $fuelGridContainerDiv;
-        },
-        _searchable: function() {
-            var searchHTML = "<div class='datagrid-header-left'><div class='input-append search datagrid-search'> <input type='text' class='input-medium' placeholder='Search'><button type='button' class='btn'><i class='icon-search'></i></button></div></div>";
-            return searchHTML;
-        },
-        _pagination: function() {
-            var html = '<div class="datagrid-footer-right" style="display:none;"><div class="grid-pager"><button type="button" class="btn grid-prevpage"><i class="icon-chevron-left"></i></button><span>Page</span> <div style="display:inline-block;"><input type="text" name="pagenumber" style="width:25px;margin-bottom:-10px;vertical-align:middle;margin-right:5px;"></div><span>of <span class="grid-pages"></span></span><button type="button" class="btn grid-nextpage"><i class="icon-chevron-right"></i></button></div></div>';
-            return html;
-        },
-        _rowsPerPage: function(popout) {
-            if(popout) {
-                var html = '<div class="datagrid-footer-left" style="display:none;"><div class="grid-controls"><span><span class="grid-start"></span>-<span class="grid-end"></span> of <span class="grid-count"></span></span><div class="select grid-pagesize" data-resize="auto" style="visibility:hidden;"><button type="button" data-toggle="dropdown" class="btn dropdown-toggle"><span class="dropdown-label"></span><span class="caret"></span></button><ul class="dropdown-menu"><li data-value="10" data-selected="true"><a href="#">5</a></li><li data-value="10"><a href="#">10</a></li><li data-value="20"><a href="#">20</a></li><li data-value="50"><a href="#">50</a></li><li data-value="100"><a href="#">100</a></li></ul></div><span style="display:none;">Per Page</span></div></div>';
-            } else {
-                var html = '<div class="datagrid-footer-left" style="display:none;"><div class="grid-controls"><span><span class="grid-start"></span>-<span class="grid-end"></span> of <span class="grid-count"></span></span><div class="select grid-pagesize" data-resize="auto" style="visibility:hidden;"><button type="button" data-toggle="dropdown" class="btn dropdown-toggle"><span class="dropdown-label"></span><span class="caret"></span></button><ul class="dropdown-menu"><li data-value="5" data-selected="true"><a href="#">5</a></li><li data-value="10"><a href="#">10</a></li><li data-value="20"><a href="#">20</a></li><li data-value="50"><a href="#">50</a></li><li data-value="100"><a href="#">100</a></li></ul></div><span style="display:none;">Per Page</span></div></div>';
-            }
-            return html;
-        }
-    },
-    table : {
-        table : function(classes, id) {
-            var $table = $(document.createElement('table'));
-            $table.addClass("table");
-            $(classes).each(function(index, value) {
-                $table.addClass(value);
-            });
-            if (!(typeof id === 'undefined'))
-                $table.attr("id", id);
-            return $table;
-        },
-        header : function(headers) {
-            var $thead = $(document.createElement('thead'));
-            var $tr = $(document.createElement('tr'));
-            $(headers).each(function(index, value) {
-                $th = $(document.createElement('th'));
-                $th.append(value);
-                $tr.append($th);
-            });
-            $thead.append($tr);
-            return $thead;
-        },
-        body : function(body, thead) {
-            var $tbody = $(document.createElement('tbody'));
-            // if empty
-            if (body.length == 0 && !(typeof thead === 'undefined')) {
-                var $tr = $(document.createElement('tr'));
-                var $td = $(document.createElement('td'));
-                $td.attr('colspan', thead.length);
-                $td.text('No data available');
-                $td.addClass('empty');
-                $tr.append($td);
-                $tbody.append($tr);
-                return $tbody;
-            }
-            // else, populate as usual
-            $(body).each(function(index, value) {
-                var $tr = $(document.createElement('tr'));
-                $.each(value, function(key, value) {
-                    if (key == 'type') {
-                        // add classes
-                        $(value).each(function(index, value) {
-                            $tr.addClass(value);
-                        });
-                    } else if (key == 'entry') {
-                        // add entries
-                        $(value).each(function(index, value) {
-                            var $td = $(document.createElement('td'));
-                            $td.append(value);
-                            $tr.append($td);
-                        });
-                    } else {
-                        // data field
-                        $tr.attr('data-' + key, value);
-                    }
-                    $tbody.append($tr);
-                });
-            });
-            return $tbody;
-        }
-    },
-    description : function(description, horizontal) {
-        var $dl = $(document.createElement('dl'));
-        if (horizontal == true) {
-            $dl.addClass("dl-horizontal");
-        }
-        $(description).each(function(index, value) {
-            var $dt = $(document.createElement('dt'));
-            $dt.text(value.dt);
-            var $dd = $(document.createElement('dd'));
-            $dd.text(value.dd);
-            $dl.append($dt).append($dd);
-        });
-        return $dl;
-    }
-}
-
-/** MODAL */
-one.lib.modal = {
-    // clone default modal
-    clone : function(id) {
-        var $clone = $("#modal").clone(true);
-        $clone.attr("id", id);
-        return $clone;
-    },
-    // populate modal
-    populate : function($modal, header, $body, footer, ajax) {
-      if (ajax === undefined && ajax !== false) {
-        $.getJSON('/web.json'); // session check per modal
-      }
-        var $h3 = $modal.find("h3");
-        $h3.text(header);
-
-        var $modalBody = $modal.find(".modal-body");
-        $modalBody.append($body);
-
-        $(footer).each(function(index, value) {
-            $modal.find(".modal-footer").append(value);
-        });
-    },
-    // clone and populate modal
-    spawn : function(id, header, $body, footer) {
-        var $modal = one.lib.modal.clone(id);
-        one.lib.modal.populate($modal, header, $body, footer);
-        $modal.on('hide', function () {
-            $('.modal-body').scrollTop(0);
-        });
-        return $modal;
-    },
-    // empty modal
-    empty : function($modal) {
-        $modal.find("h3").empty();
-        $modal.find(".modal-body").empty();
-        $modal.find(".modal-footer").empty();
-    },
-    // injection
-    inject : {
-        body : function($modal, $body) {
-            $modal.find(".modal-body").empty();
-            $modal.find(".modal-body").append($body);
-        }
-    }
-}
-
-/** FORM */
-one.lib.form = {
-    // create select-option form element
-    select : {
-        create : function(options, multiple, sort) {
-            // assert - auto assign
-            if (options == undefined)
-                options = {};
-
-            var $select = $(document.createElement('select'));
-            if (multiple == true) {
-                $select.attr("multiple", "multiple");
-            }
-            var optionArray = one.lib.form.select.options(options);
-
-            // If specified, sort the option elements based on their text field
-            if (sort == true && optionArray.length > 1) {
-                var shifted = true;
-                var limit = optionArray.length;
-                while (shifted) {
-                    shifted = false;
-                    for ( var i = 1; i < limit; i++) {
-                        if (optionArray[i - 1].text() > optionArray[i].text()) {
-                            var swap = optionArray[i - 1];
-                            optionArray[i - 1] = optionArray[i];
-                            optionArray[i] = swap;
-                            shifted = true;
-                        }
-                    }
-                }
-            }
-
-            $(optionArray).each(function(index, value) {
-                $select.append(value);
-            });
-            return $select;
-        },
-        options : function(options) {
-            var result = [];
-            $.each(options, function(key, value) {
-                var $option = $(document.createElement('option'));
-                $option.attr("value", key);
-                $option.text(value);
-                result.push($option);
-            });
-            return result;
-        },
-        empty : function($select) {
-            $select.empty();
-        },
-        inject : function($select, options) {
-            $select.empty();
-            var options = one.lib.form.select.options(options);
-            $select.append(options);
-        },
-        prepend : function($select, options) {
-            var options = one.lib.form.select.options(options);
-            $select.prepend(options);
-        },
-        bubble : function($select, bubble) {
-            $($select.find("option")).each(function(index, value) {
-                if ($(value).attr("value") == bubble) {
-                    var option = $(value);
-                    $(value).remove();
-                    $select.prepend(option);
-                    return;
-                }
-            });
-        }
-    },
-    // create legend form element
-    legend : function(name) {
-        var $legend = $(document.createElement('legend'));
-        $legend.text(name);
-        return $legend;
-    },
-    // create label form element
-    label : function(name) {
-        var $label = $(document.createElement('label'));
-        $label.text(name);
-        return $label;
-    },
-    // create help block form element
-    help : function(help) {
-        var $help = $(document.createElement('span'));
-        $help.text(help);
-        $help.addClass("help-block");
-        return $help;
-    },
-    // create generic text input
-    input : function(placeholder) {
-        var $input = $(document.createElement('input'));
-        $input.attr('type', 'text');
-        $input.attr('placeholder', placeholder);
-        return $input;
-    }
-}
-
-/** NAV */
-one.lib.nav = {
-    unfocus : function($nav) {
-        $($nav.find("li")).each(function(index, value) {
-            $(value).removeClass("active");
-        });
-    }
-}
-
-one.lib.helper = {
-    parseInt : function(value) {
-        return (value != null && value.trim() !== '') ?
-            parseInt(value) : ''
-    },
-    parseFloat : function(value) {
-        return (value != null && value.trim() !== '') ?
-            parseFloat(value) : ''
-    }
-}
-
-
-/** ALERT */
-one.lib.alert = function(alert) {
-    $("#alert p").text(alert);
-    $("#alert").hide();
-    $("#alert").slideToggle();
-    clearTimeout(one.lib.registry.alert);
-    one.lib.registry.alert = setTimeout(function() {
-        $("#alert").slideUp();
-    }, 8000);
-}
diff --git a/opendaylight/adsal/web/root/src/main/resources/js/open-topology.js b/opendaylight/adsal/web/root/src/main/resources/js/open-topology.js
deleted file mode 100644 (file)
index ec5d87b..0000000
+++ /dev/null
@@ -1,237 +0,0 @@
-/** COMMON * */
-var labelType, useGradients, nativeTextSupport, animate;
-
-(function() {
-    var ua = navigator.userAgent, iStuff = ua.match(/iPhone/i)
-            || ua.match(/iPad/i), typeOfCanvas = typeof HTMLCanvasElement, nativeCanvasSupport = (typeOfCanvas == 'object' || typeOfCanvas == 'function'), textSupport = nativeCanvasSupport
-            && (typeof document.createElement('canvas').getContext('2d').fillText == 'function');
-    // I'm setting this based on the fact that ExCanvas provides text support
-    // for IE
-    // and that as of today iPhone/iPad current text support is lame
-    labelType = (!nativeCanvasSupport || (textSupport && !iStuff)) ? 'Native'
-            : 'HTML';
-    nativeTextSupport = labelType == 'Native';
-    useGradients = nativeCanvasSupport;
-    animate = !(iStuff || !nativeCanvasSupport);
-})();
-
-/** TOPOLOGY * */
-one.topology = {};
-
-one.topology.option = {
-    navigation : function(enable, panning, zooming) {
-        var option = {};
-        option["enable"] = enable;
-        option["panning"] = panning;
-        option["zooming"] = zooming;
-        return option;
-    },
-    node : function(overridable, color, height, dim) {
-        var option = {};
-        option["overridable"] = overridable;
-        option["color"] = color;
-        option["height"] = height;
-        option["dim"] = dim;
-        return option;
-    },
-    edge : function(overridable, color, lineWidth, epsilon) {
-        var option = {};
-        option["overridable"] = overridable;
-        option["color"] = color;
-        option["lineWidth"] = lineWidth;
-        if (epsilon != undefined)
-            option["epsilon"] = epsilon;
-        return option;
-    },
-    label : function(style, node) {
-        var marginTop, minWidth;
-        if (node.data["$type"] == "switch") {
-            marginTop = "42px";
-            minWidth = "65px";
-        } else if (node.data["$type"] == "host") {
-            marginTop = "48px";
-            minWidth = "";
-        } else if (node.data["$type"].indexOf("monitor") == 0) {
-            marginTop = "52px";
-            minWidth = "";
-        }
-        style.marginTop = marginTop;
-        style.minWidth = minWidth;
-        style.background = "rgba(68,68,68,0.7)";
-        style.borderRadius = "4px";
-        style.color = "#fff";
-        style.cursor = "default";
-    }
-};
-
-one.topology.init = function(json) {
-    if (json.length == 0) {
-        $div = $(document.createElement('div'));
-        $img = $(document.createElement('div'));
-        $img.css('height', '128px');
-        $img.css('width', '128px');
-        $img.css('background-image', 'url(/img/topology_view_1033_128.png)');
-        $img.css('clear', 'both');
-        $img.css('margin', '0 auto');
-        $p = $(document.createElement('p'));
-        $p.addClass('text-center');
-        $p.addClass('text-info');
-        $p.css('width', '100%');
-        $p.css('padding', '10px 0');
-        $p.css('cursor', 'default');
-        $p.append('No Network Elements Connected');
-        $div.css('position', 'absolute');
-        $div.css('top', '25%');
-        $div.css('margin', '0 auto');
-        $div.css('width', '100%');
-        $div.css('text-align', 'center');
-        $div.append($img).append($p);
-        $("#topology").append($div);
-        return false;
-    }
-    one.topology.graph = new $jit.MultiTopology(
-            {
-                injectInto : 'topology',
-                Navigation : one.topology.option.navigation(true,
-                        'avoid nodes', 10),
-                Node : one.topology.option.node(true, '#444', 25, 27),
-                Edge : one.topology.option.edge(true, '23A4FF', 1.5),
-                Tips : {
-                    enable : true,
-                    type : 'auto',
-                    offsetX: 15,
-                    offsetY: 15,
-                    onShow : function(tip, node) {
-                        if (node.name != undefined)
-                            tip.innerHTML = "Name : " + node.name + "<br>";
-                        if(node.data["$type"]!=undefined)
-                            tip.innerHTML = tip.innerHTML + "Type : " + node.data["$type"] + "<br>";
-                        if(node.data["$desc"]!=undefined)
-                            tip.innerHTML = tip.innerHTML + "Description : " + node.data["$desc"];
-                    }
-                },
-                Events : {
-                    enable : true,
-                    type : 'Native',
-                    onMouseEnter : function(node, eventInfo, e) {
-                        // if node
-                        if (node.id != undefined) {
-                            one.topology.graph.canvas.getElement().style.cursor = 'move';
-                        } else if (eventInfo.edge != undefined
-                                && eventInfo.edge.nodeTo.data["$type"] == "switch"
-                                && eventInfo.edge.nodeFrom.data["$type"] == "switch") {
-                            one.topology.graph.canvas.getElement().style.cursor = 'pointer';
-                        }
-                    },
-                    onMouseLeave : function(node, eventInfo, e) {
-                        one.topology.graph.canvas.getElement().style.cursor = '';
-                    },
-                    // Update node positions when dragged
-                    onDragMove : function(node, eventInfo, e) {
-                        var pos = eventInfo.getPos();
-                        node.pos.setc(pos.x, pos.y);
-                        one.topology.graph.plot();
-                        one.topology.graph.canvas.getElement().style.cursor = 'crosshair';
-                    },
-                    // Implement the same handler for touchscreens
-                    onTouchMove : function(node, eventInfo, e) {
-                        $jit.util.event.stop(e); // stop default touchmove
-                        // event
-                        this.onDragMove(node, eventInfo, e);
-                    },
-                    onDragEnd : function(node, eventInfo, e) {
-                        var ps = eventInfo.getPos();
-                        var did = node.id;
-                        var data = {};
-                        data['x'] = ps.x;
-                        data['y'] = ps.y;
-                        $.post('/controller/web/topology/node/' + did, data);
-                    },
-                    onClick : function(node, eventInfo, e) {
-                        if (one.f.topology === undefined) {
-                            return false;
-                        } else {
-                            one.f.topology.Events.onClick(node, eventInfo);
-                        }
-                    }
-                },
-                iterations : 200,
-                levelDistance : 130,
-                onCreateLabel : function(domElement, node) {
-                    var nameContainer = document.createElement('span'), closeButton = document
-                            .createElement('span'), style = nameContainer.style;
-                    nameContainer.className = 'name';
-                    var nodeDesc = node.data["$desc"];
-                    if (nodeDesc == "None" || nodeDesc == ""
-                            || nodeDesc == "undefined" || nodeDesc == undefined) {
-                        nameContainer.innerHTML = "<small>" + node.name
-                                + "</small>";
-                    } else {
-                        nameContainer.innerHTML = nodeDesc;
-                    }
-                    domElement.appendChild(nameContainer);
-                    style.fontSize = "1.0em";
-                    style.color = "#000";
-                    style.fontWeight = "bold";
-                    style.width = "100%";
-                    style.padding = "1.5px 4px";
-                    style.display = "block";
-
-                    one.topology.option.label(style, node);
-                },
-                onPlaceLabel : function(domElement, node) {
-                    var style = domElement.style;
-                    var left = parseInt(style.left);
-                    var top = parseInt(style.top);
-                    var w = domElement.offsetWidth;
-                    style.left = (left - w / 2) + 'px';
-                    style.top = (top - 15) + 'px';
-                    style.display = '';
-                    style.minWidth = "28px";
-                    style.width = "auto";
-                    style.height = "28px";
-                    style.textAlign = "center";
-                }
-            });
-
-    one.topology.graph.loadJSON(json);
-    // compute positions incrementally and animate.
-    one.topology.graph.computeIncremental({
-        iter : 40,
-        property : 'end',
-        onStep : function(perc) {
-            console.log(perc + '% loaded');
-        },
-        onComplete : function() {
-            for ( var idx in one.topology.graph.graph.nodes) {
-                var node = one.topology.graph.graph.nodes[idx];
-                if (node.getData("x") && node.getData("y")) {
-                    var x = node.getData("x");
-                    var y = node.getData("y");
-                    node.setPos(new $jit.Complex(x, y), "end");
-                }
-            }
-            console.log('done');
-            one.topology.graph.animate({
-                modes : [ 'linear' ],
-                transition : $jit.Trans.Elastic.easeOut,
-                duration : 0
-            });
-        }
-    });
-    one.topology.graph.canvas.setZoom(0.8, 0.8);
-}
-
-one.topology.update = function() {
-    $('#topology').empty();
-    $.getJSON(one.global.remoteAddress + "controller/web/topology/visual.json",
-            function(data) {
-                one.topology.init(data);
-            });
-}
-
-/** INIT */
-$.getJSON(one.global.remoteAddress + "controller/web/topology/visual.json",
-        function(data) {
-            one.topology.init(data);
-        });
diff --git a/opendaylight/adsal/web/root/src/main/resources/js/open.js b/opendaylight/adsal/web/root/src/main/resources/js/open.js
deleted file mode 100644 (file)
index 511e588..0000000
+++ /dev/null
@@ -1,797 +0,0 @@
-one.main = {};
-
-one.main.constants = {
-  address : {
-    menu : "/web.json",
-    prefix : "/controller/web",
-    save : "/save"
-  }
-}
-
-one.main.menu = {
-  registry : {
-    load : false
-  },
-  load : function() {
-    one.main.menu.ajax(function(data) {
-      // reparse the ajax data
-      var result = one.main.menu.data.menu(data);
-      // transform into list to append to menu
-      var $div = one.main.menu.menu(result);
-      // append to menu
-      $("#menu .nav").append($div.children());
-      // binding all menu items
-      var $menu = $("#menu .nav a");
-      $menu.click(function() {
-        if (one.main.menu.registry.load === true) {
-          return false;
-        }
-        one.main.menu.registry.load = true;
-        var href = $(this).attr('href').substring(1);
-        one.main.page.load(href);
-        var $li = $(this).parent();
-        // reset all other active
-        $menu.each(function(index, value) {
-          $(value).parent().removeClass('active');
-        });
-        $li.addClass('active');
-      });
-      // reset or go to first menu item by default
-      var currentLocation = location.hash;
-      if (data[currentLocation.substring(1)] == undefined) {
-        $($menu[0]).click();
-      } else {
-        $menu.each(function(index, value) {
-          var menuLocation = $(value).attr('href');
-          if (currentLocation == menuLocation) {
-            $($menu[index]).click();
-            return;
-          }
-        });
-      }
-    });
-  },
-  menu : function(result) {
-    var $div = $(document.createElement('div'));
-    $(result).each(function(index, value) {
-      if (value != undefined) {
-        var $li = $(document.createElement('li'));
-        var $a = $(document.createElement('a'));
-        $a.text(value['name']);
-        $a.attr('href', '#' + value['id']);
-        $li.append($a);
-        $div.append($li);
-      }
-    });
-    return $div;
-  },
-  ajax : function(successCallback) {
-    $.getJSON(one.main.constants.address.menu, function(data) {
-      successCallback(data);
-    });
-  },
-  data : {
-    menu : function(data) {
-      var result = [];
-      $.each(data, function(key, value) {
-        var order = value['order'];
-        if (order >= 0) {
-          var name = value['name'];
-          var entry = {
-            'name' : name,
-        'id' : key
-          };
-          result[order] = entry;
-        }
-      });
-      return result;
-    }
-  }
-}
-
-one.main.page = {
-  load : function(page) {
-    if (one.f !== undefined && one.f.cleanUp !== undefined) {
-      one.f.cleanUp();
-    }
-    // clear page related
-    delete one.f;
-    $('.dashlet', '#main').empty();
-    $('.nav', '#main').empty();
-    // fetch page's js
-    $.getScript(one.main.constants.address.prefix+"/"+page+"/js/page.js")
-      .success(function() {
-        one.main.menu.registry.load = false;
-      });
-
-    $.ajaxSetup({
-      data : {
-        'x-page-url' : page
-      }
-    });
-  },
-  dashlet : function($nav, dashlet) {
-    var $li = $(document.createElement('li'));
-    var $a = $(document.createElement('a'));
-    $a.text(dashlet.name);
-    $a.attr('id', dashlet.id);
-    $a.attr('href', '#');
-    $li.append($a);
-    $nav.append($li);
-  }
-}
-
-one.main.admin = {
-  id : {
-    modal : {
-      main : "one_main_admin_id_modal_main",
-      close : "one_main_admin_id_modal_close",
-      user : "one_main_admin_id_modal_user",
-      add : {
-        user : "one_main_admin_id_modal_add_user",
-        close : "one_main_admin_id_modal_add_close",
-        form : {
-          name : "one_main_admin_id_modal_add_form_name",
-          role : "one_main_admin_id_modal_add_form_role",
-          password : "one_main_admin_id_modal_add_form_password",
-          verify : "one_main_admin_id_modal_add_form_verify"
-        }
-      },
-      remove : {
-        user : "one_main_admin_id_modal_remove_user",
-        close : "one_main_admin_id_modal_remove_close",
-        password : 'one_main_admin_id_modal_remove_password'
-      },
-      modify : {
-          user : "one_main_admin_id_modal_modify_user",
-      },
-      password : {
-        modal : 'one_main_admin_id_modal_password_modal',
-        submit : 'one_main_admin_id_modal_password_submit',
-        cancel : 'one_main_admin_id_modal_password_cancel',
-        form : {
-          old : 'one_main_admin_id_modal_password_form_old',
-          set : 'one_main_admin_id_modal_password_form_new',
-          verify : 'one_main_admin_id_modal_password_form_verify'
-        }
-      }
-    },
-    add : {
-      user : "one_main_admin_id_add_user"
-    }
-  },
-  registry :{
-
-  },
-  address : {
-    root : "/admin",
-    users : "/users",
-    modifyUser : "/user/modify",
-    password : '/admin/users/password/'
-  },
-  modal : {
-    initialize : function(callback) {
-      var h3 = "Welcome " + $('#admin').text();
-      var footer = one.main.admin.modal.footer();
-      var $modal = one.lib.modal.spawn(one.main.admin.id.modal.main, h3,
-          '', footer);
-
-      // close binding
-      $('#' + one.main.admin.id.modal.close, $modal).click(function() {
-        $modal.modal('hide');
-      });
-
-      // body inject
-      one.main.admin.ajax.users(function($body) {
-        one.lib.modal.inject.body($modal, $body);
-      });
-
-      // modal show callback
-      callback($modal);
-    },
-    footer : function() {
-      var footer = [];
-      var closeButton = one.lib.dashlet.button.single('Close', one.main.admin.id.modal.close, '', '');
-      var $closeButton = one.lib.dashlet.button.button(closeButton);
-      footer.push($closeButton);
-      return footer;
-    }
-  },
-  ajax : {
-    users : function(callback) {
-      $.getJSON(one.main.admin.address.root
-          + one.main.admin.address.users, function(data) {
-            var body = one.main.admin.data.users(data);
-            one.main.admin.registry["users"] = data;
-            var $body = one.main.admin.body.users(body);
-            callback($body);
-          });
-    }
-  },
-  data : {
-    users : function(data) {
-      var body = [];
-      $(data).each(function(index, value) {
-        var tr = {};
-        var entry = [];
-        entry.push(value['user']);
-        entry.push(value['roles']);
-        tr['entry'] = entry;
-        tr['id'] = value['user'];
-        body.push(tr);
-      });
-      return body;
-    }
-  },
-  body : {
-    users : function(body) {
-      var $div = $(document.createElement('div'));
-      var $h5 = $(document.createElement('h5'));
-      $h5.append("Manage Users");
-      var attributes = [ "table-striped", "table-bordered",
-          "table-hover", "table-cursor" ];
-      var $table = one.lib.dashlet.table.table(attributes);
-      var headers = [ "User", "Role" ];
-      var $thead = one.lib.dashlet.table.header(headers);
-      var $tbody = one.lib.dashlet.table.body(body);
-      $table.append($thead).append($tbody);
-
-      // bind table
-      if (one.role < 2) {
-        $table.find('tr').click(function() {
-          var id = $(this).data('id');
-          one.main.admin.remove.modal.initialize(id);
-        });
-      }
-
-      // append to div
-      $div.append($h5).append($table);
-
-      if (one.role < 2) {
-        var addUserButton = one.lib.dashlet.button.single("Add User",
-            one.main.admin.id.add.user, "btn-primary", "btn-mini");
-        var $addUserButton = one.lib.dashlet.button
-          .button(addUserButton);
-        $div.append($addUserButton);
-
-        // add user binding
-        $addUserButton.click(function() {
-          one.main.admin.add.modal.initialize();
-        });
-      }
-
-      return $div;
-    }
-  },
-  remove : {
-    modal : {
-      initialize : function(id) {
-        var h3 = "Manage user - " + id;
-        var footer = one.main.admin.remove.footer();
-        var $body = one.main.admin.remove.body();
-        var $modal = one.lib.modal.spawn(one.main.admin.id.modal.user,
-            h3, $body, footer);
-        // close binding
-        $('#'+one.main.admin.id.modal.remove.close, $modal).click(function() {
-          $modal.modal('hide');
-        });
-        // close binding
-        $('#'+one.main.admin.id.modal.modify.user, $modal).click(function() {
-          one.main.admin.add.modal.initialize(id, true);
-        });
-        // remove binding
-        $('#' + one.main.admin.id.modal.remove.user, $modal).click(function() {
-          one.main.admin.remove.modal.ajax(id, function(result) {
-            if (result.description == 'Success') {
-              $modal.modal('hide');
-              // body inject
-              var $admin = $('#'+one.main.admin.id.modal.main);
-              one.main.admin.ajax.users(function($body) {
-                one.lib.modal.inject.body($admin, $body);
-              });
-            } else {
-              alert("Failed to remove user: " + result.description);
-            }
-          });
-        });
-        // change password binding
-        $('#' + one.main.admin.id.modal.remove.password, $modal).click(function() {
-          one.main.admin.password.initialize(id, function() {
-            $modal.modal('hide');
-          });
-        });
-        $modal.modal();
-      },
-      ajax : function(id, callback) {
-        $.post(one.main.admin.address.root + one.main.admin.address.users + '/' + id, function(data) {
-          callback(data);
-        });
-      },
-    },
-    footer : function() {
-      var footer = [];
-      var removeButton = one.lib.dashlet.button.single("Remove User",
-          one.main.admin.id.modal.remove.user, "btn-danger", "");
-      var $removeButton = one.lib.dashlet.button.button(removeButton);
-      footer.push($removeButton);
-      var modifyButton = one.lib.dashlet.button.single("Change Role",
-              one.main.admin.id.modal.modify.user, "btn-success", "");
-      var $modifyButton = one.lib.dashlet.button.button(modifyButton);
-      footer.push($modifyButton);
-      var change = one.lib.dashlet.button.single('Change Password',
-          one.main.admin.id.modal.remove.password, 'btn-success', '');
-      var $change = one.lib.dashlet.button.button(change);
-      footer.push($change);
-      var closeButton = one.lib.dashlet.button.single("Close",
-          one.main.admin.id.modal.remove.close, "", "");
-      var $closeButton = one.lib.dashlet.button.button(closeButton);
-      footer.push($closeButton);
-      return footer;
-    },
-    body : function() {
-      var $p = $(document.createElement('p'));
-      $p.append('Select an action');
-      return $p;
-    },
-  },
-  add : {
-    modal : {
-      initialize : function(id, edit) {
-        var h3 = edit? "Change Role of user " + id:"Add User";
-        var footer = one.main.admin.add.footer(edit);
-        var $body = one.main.admin.add.body(id, edit);
-        var $modal = one.lib.modal.spawn(one.main.admin.id.modal.user,
-            h3, $body, footer);
-        // close binding
-        $('#' + one.main.admin.id.modal.add.close, $modal).click(function() {
-          $modal.modal('hide');
-        });
-        // add binding
-        $('#' + one.main.admin.id.modal.add.user, $modal).click(function() {
-          one.main.admin.add.modal.add($modal, edit, function(result) {
-            if (result.description == 'Success') {
-              $modal.modal('hide');
-              // body inject
-              var $admin = $('#'+one.main.admin.id.modal.main);
-              one.main.admin.ajax.users(function($body) {
-               one.lib.modal.inject.body($admin, $body);
-              });
-            } else {
-              var action = edit? "edit" :"add";
-              alert("Failed to "+ action +" user: "+result.description);
-            }
-          });
-        });
-        $modal.modal();
-      },
-      add : function($modal, edit, callback) {
-        var user = {};
-        user['user'] = $modal.find(
-            '#' + one.main.admin.id.modal.add.form.name).val();
-        if (!edit) {
-            user['password'] = $modal.find(
-                '#' + one.main.admin.id.modal.add.form.password).val();
-        }
-        roles = new Array();
-        roles[0] = $modal.find(
-            '#' + one.main.admin.id.modal.add.form.role).find(
-              'option:selected').attr('value');
-        user['roles'] = roles;
-
-        if (!edit) {
-            // password check
-            var verify = $('#'+one.main.admin.id.modal.add.form.verify).val();
-            if (user.password != verify) {
-              alert('Passwords do not match');
-              return false;
-            }
-        }
-        var resource = {};
-        resource['json'] = JSON.stringify(user);
-        resource['action'] = 'add'
-
-        one.main.admin.add.modal.ajax(resource, edit, callback);
-      },
-      ajax : function(data, edit, callback) {
-          if(edit) {
-            $.post(one.main.admin.address.root
-              + one.main.admin.address.modifyUser, data, function(data) {
-                callback(data);
-              });
-          } else {  
-            $.post(one.main.admin.address.root
-              + one.main.admin.address.users, data, function(data) {
-                callback(data);
-              });
-          }
-      }
-    },
-    body : function(id, edit) {
-      var $form = $(document.createElement('form'));
-      var $fieldset = $(document.createElement('fieldset'));
-      var users = one.main.admin.registry["users"];
-      var currentUser;
-      if(edit) {
-        $(users).each(function(index, val) {
-             if(val.user == id){
-            currentUser = val;
-          }
-        });
-      }
-
-      // user
-      var $label = one.lib.form.label('Username');
-      var $input = one.lib.form.input('Username');
-      $input.attr('id', one.main.admin.id.modal.add.form.name);
-      if(edit) {
-         $input.attr("disabled",true);
-         $input.val(id);
-      }
-      $fieldset.append($label).append($input);
-      if(!edit) {
-          // password
-          var $label = one.lib.form.label('Password');
-          var $input = one.lib.form.input('Password');
-          $input.attr('id', one.main.admin.id.modal.add.form.password);
-          $input.attr('type', 'password');
-          $fieldset.append($label).append($input);
-          // password verify
-          var $label = one.lib.form.label('Verify Password');
-          var $input = one.lib.form.input('Verify Password');
-          $input.attr('id', one.main.admin.id.modal.add.form.verify);
-          $input.attr('type', 'password');
-          $fieldset.append($label).append($input);
-      }
-      // roles
-      var $label = one.lib.form.label('Roles');
-      var options = {
-        "Network-Admin" : "Network Administrator",
-        "Network-Operator" : "Network Operator"
-      };
-      var $select = one.lib.form.select.create(options);
-      $select.attr('id', one.main.admin.id.modal.add.form.role);
-      if(edit) {
-          $select.children().each(function() {
-                 this.selected = (this.text == options[currentUser.roles[0]]);
-          });
-      }
-
-      $fieldset.append($label).append($select);
-      $form.append($fieldset);
-      return $form;
-    },
-    footer : function(edit) {
-      var footer = [];
-
-      var buttonText = edit ? "Update User" : "Add User";
-
-      var addButton = one.lib.dashlet.button.single(buttonText,
-          one.main.admin.id.modal.add.user, "btn-primary", "");
-      var $addButton = one.lib.dashlet.button.button(addButton);
-      footer.push($addButton);
-
-      var closeButton = one.lib.dashlet.button.single("Close",
-          one.main.admin.id.modal.add.close, "", "");
-      var $closeButton = one.lib.dashlet.button.button(closeButton);
-      footer.push($closeButton);
-
-      return footer;
-    }
-  },
-  password : {
-    initialize : function(id, successCallback) {
-      var h3 = 'Change Password';
-      var footer = one.main.admin.password.footer();
-      var $body = one.main.admin.password.body(id);;
-      var $modal = one.lib.modal.spawn(one.main.admin.id.modal.password.modal,
-          h3, $body, footer);
-
-      // cancel binding
-      $('#'+one.main.admin.id.modal.password.cancel, $modal).click(function() {
-        $modal.modal('hide');
-      });
-
-      // change password binding
-      $('#'+one.main.admin.id.modal.password.submit, $modal).click(function() {
-        one.main.admin.password.submit(id, $modal, function(result) {
-          if (result.success) {
-            //if changed own password, enforce relogin
-            if (id.trim() == $('#currentuser').val().trim()) {
-                alert("Password changed successfully. Please re-login with your new password.");
-                window.location = '/';
-            }
-          } else {
-            alert(result.code+': '+result.description);
-          }
-        });
-      });
-
-      $modal.modal();
-    },
-    submit : function(id, $modal, callback) {
-      var resource = {};
-      resource.newPassword = $('#'+one.main.admin.id.modal.password.form.set, $modal).val();
-
-      // verify password
-      var verify = $('#'+one.main.admin.id.modal.password.form.verify, $modal).val();
-      if (verify != resource.newPassword) {
-        alert('Passwords do not match');
-        return false;
-      }
-
-      resource.currentPassword = $('#'+one.main.admin.id.modal.password.form.old, $modal).val();
-
-      $.post(one.main.admin.address.password+id, resource, function(data) {
-        callback(data);
-      });
-    },
-    body : function(id) {
-      var $form = $(document.createElement('form'));
-      var $fieldset = $(document.createElement('fieldset'));
-      // user
-      var $label = one.lib.form.label('Username');
-      var $input = one.lib.form.input('');
-      $input.attr('disabled', 'disabled');
-      $input.val(id);
-      $fieldset.append($label)
-        .append($input);
-      // old password
-      var $label = one.lib.form.label('Old Password');
-      var $input = one.lib.form.input('Old Password');
-      $input.attr('id', one.main.admin.id.modal.password.form.old);
-      $input.attr('type', 'password');
-      $fieldset.append($label).append($input);
-      // new password
-      var $label = one.lib.form.label('New Password');
-      var $input = one.lib.form.input('New Password');
-      $input.attr('id', one.main.admin.id.modal.password.form.set);
-      $input.attr('type', 'password');
-      $fieldset.append($label).append($input);
-      // verify new password
-      var $label = one.lib.form.label('Verify Password');
-      var $input = one.lib.form.input('Verify Password');
-      $input.attr('id', one.main.admin.id.modal.password.form.verify);
-      $input.attr('type', 'password');
-      $fieldset.append($label).append($input);
-      // return
-      $form.append($fieldset);
-      return $form;
-    },
-    footer : function() {
-      var footer = [];
-      var submit = one.lib.dashlet.button.single('Submit',
-          one.main.admin.id.modal.password.submit, 'btn-primary', '');
-      var $submit = one.lib.dashlet.button.button(submit);
-      footer.push($submit);
-      var cancel = one.lib.dashlet.button.single('Cancel',
-          one.main.admin.id.modal.password.cancel, '', '');
-      var $cancel = one.lib.dashlet.button.button(cancel);
-      footer.push($cancel);
-      return footer;
-    }
-  }
-}
-
-one.main.cluster = {
-  id : { // one.main.cluster.id
-    modal : 'one-main-cluster-id-modal',
-    close : 'one-main-cluster-id-close',
-    datagrid : 'one-main-cluster-id-datagrid'
-  },
-  initialize : function() {
-    var h3 = 'Cluster Management';
-    var footer = one.main.cluster.footer();
-    var $body = '';
-    var $modal = one.lib.modal.spawn(one.main.cluster.id.modal, h3, $body, footer); 
-
-    // close
-    $('#'+one.main.cluster.id.close, $modal).click(function() {
-      $modal.modal('hide');
-    });
-
-    // body
-    $.getJSON('/admin/cluster', function(data) {
-      var $gridHTML = one.lib.dashlet.datagrid.init(one.main.cluster.id.datagrid, {
-        searchable: true,
-          filterable: false,
-          pagination: true,
-          flexibleRowsPerPage: true
-      }, 'table-striped table-condensed table-cursor');
-      var source = one.main.cluster.data(data);
-      $gridHTML.datagrid({dataSource : source}).on('loaded', function() {
-        $(this).find('tbody tr').click(function() {
-          var $tr = $(this);
-          if ($tr.find('td:nth-child(1)').attr('colspan') === '1') {
-            return false;
-          }
-          var address = $tr.find('.ux-id').text();
-          one.main.cluster.nodes.initialize(address);
-        });
-      });
-      one.lib.modal.inject.body($modal, $gridHTML);
-    });
-
-    $modal.modal();
-  },
-  data : function(data) {
-    var tdata = [];
-    var registry = [];
-    $(data).each(function(idx, controller) {
-      var name = controller.name;
-      var address = controller.address;
-      var $registry = $(document.createElement('span'));
-      $registry
-      .append(JSON.stringify(address))
-      .css('display', 'none')
-      .addClass('ux-id');
-    name = one.lib.dashlet.label(name, null)[0].outerHTML;
-    name += $registry[0].outerHTML;
-    if (controller.me === true) {
-      var me = one.lib.dashlet.label('*', 'label-inverse')[0].outerHTML;
-      name += '&nbsp;'+me;
-    }
-    if (controller.coordinator === true) {
-      var coord = one.lib.dashlet.label('C')[0].outerHTML;
-      name += '&nbsp;'+coord;
-    }
-    tdata.push({
-      'controller' : name,
-      'numNodes'   : controller.numConnectedNodes
-    });
-    });
-    var source = new StaticDataSource({
-        columns : [
-            {
-              property : 'controller',
-                label : 'Controller',
-                sortable : true
-            },
-            {
-                property : 'numNodes',
-                label    : 'Nodes',
-                sortable : true
-            }
-        ],
-        data : tdata,
-        delay : 0
-    });
-    return source;
-  },
-  footer : function() {
-    var footer = [];
-    var close = one.lib.dashlet.button.single('Close', one.main.cluster.id.close, '', '');
-    var $close = one.lib.dashlet.button.button(close);
-    footer.push($close);
-    return footer;
-  }
-}
-
-one.main.cluster.nodes = {
-  id : { // one.main.cluster.nodes.id
-    modal : 'one-main-cluster-nodes-id-modal',
-    close : 'one-main-cluster-nodes-id-close',
-    datagrid : 'one-main-cluser-nodes-id-datagrid'
-  },
-  initialize : function(address) { // one.main.cluster.nodes.initialize
-    var h3 = 'Connected Nodes';
-    var footer = one.main.cluster.nodes.footer();
-    var $body = '';
-    var $modal = one.lib.modal.spawn(one.main.cluster.nodes.id.modal, h3, $body, footer);
-
-    // close
-    $('#'+one.main.cluster.nodes.id.close, $modal).click(function() {
-      $modal.modal('hide');
-    });
-
-    // body
-    $.getJSON('/admin/cluster/controller/'+address, function(data) {
-      var $gridHTML = one.lib.dashlet.datagrid.init(one.main.cluster.nodes.id.datagrid, {
-        searchable: true,
-          filterable: false,
-          pagination: true,
-          flexibleRowsPerPage: true
-      }, 'table-striped table-condensed');
-      var source = one.main.cluster.nodes.data(data);
-      $gridHTML.datagrid({dataSource : source});
-      one.lib.modal.inject.body($modal, $gridHTML);
-    });
-
-    $modal.modal();
-  },
-  data : function(data) {
-    var tdata = [];
-    $(data).each(function(idx, val) {
-      tdata.push({
-        'node' : val.description
-      });
-    });
-    var source = new StaticDataSource({
-      columns : [
-    {
-      property : 'node',
-        label : 'Node',
-        sortable : true
-    }
-    ],
-        data : tdata,
-        delay : 0
-    });
-    return source;
-  },
-  footer : function() { // one.main.cluster.nodes.footer
-    var footer = [];
-    var close = one.lib.dashlet.button.single('Close', one.main.cluster.nodes.id.close, '', '');
-    var $close = one.lib.dashlet.button.button(close);
-    footer.push($close);
-    return footer;
-  }
-}
-
-one.main.dashlet = {
-  left : {
-    top : $("#left-top .dashlet"),
-    bottom : $("#left-bottom .dashlet")
-  },
-  right : {
-    bottom : $("#right-bottom .dashlet")
-  }
-}
-
-/** BOOTSTRAP */
-$(".modal").on('hidden', function() {
-  $(this).remove();
-});
-
-$("#alert .close").click(function() {
-  $("#alert").hide();
-});
-
-/** INIT */
-
-// parse role
-one.role = $('#admin').data('role');
-
-// user admin
-$("#admin").click(function() {
-  one.main.admin.modal.initialize(function($modal) {
-    $modal.modal();
-  });
-});
-
-// cluster
-$('#cluster').click(function() {
-  one.main.cluster.initialize();
-});
-
-// save
-$("#save").click(function() {
-  $.post(one.main.constants.address.save, function(data) {
-    if (data == "Success") {
-      one.lib.alert("Configuration Saved");
-    } else {
-      one.lib.alert("Unable to save configuration: " + data);
-    }
-  });
-});
-
-// logout
-$("#logout").click(function() {
-  location.href = "/logout";
-});
-
-// felix osgi runtime
-$("#osgi").click(function() {
-  window.open("/controller/osgi/system/console", '_newtab');
-});
-
-$.ajaxSetup({
-  complete : function(xhr, textStatus) {
-    var mime = xhr.getResponseHeader('Content-Type');
-    if (mime.substring(0, 9) == 'text/html') {
-      location.href = '/';
-    }
-  }
-});
-
-/** MAIN PAGE LOAD */
-one.main.menu.load();
\ No newline at end of file
diff --git a/opendaylight/adsal/web/root/src/main/resources/js/underscore-min.js b/opendaylight/adsal/web/root/src/main/resources/js/underscore-min.js
deleted file mode 100644 (file)
index 459f691..0000000
+++ /dev/null
@@ -1,32 +0,0 @@
-// Underscore.js 1.3.3
-// (c) 2009-2012 Jeremy Ashkenas, DocumentCloud Inc.
-// Underscore is freely distributable under the MIT license.
-// Portions of Underscore are inspired or borrowed from Prototype,
-// Oliver Steele's Functional, and John Resig's Micro-Templating.
-// For all details and documentation:
-// http://documentcloud.github.com/underscore
-(function(){function r(a,c,d){if(a===c)return 0!==a||1/a==1/c;if(null==a||null==c)return a===c;a._chain&&(a=a._wrapped);c._chain&&(c=c._wrapped);if(a.isEqual&&b.isFunction(a.isEqual))return a.isEqual(c);if(c.isEqual&&b.isFunction(c.isEqual))return c.isEqual(a);var e=l.call(a);if(e!=l.call(c))return!1;switch(e){case "[object String]":return a==""+c;case "[object Number]":return a!=+a?c!=+c:0==a?1/a==1/c:a==+c;case "[object Date]":case "[object Boolean]":return+a==+c;case "[object RegExp]":return a.source==
-c.source&&a.global==c.global&&a.multiline==c.multiline&&a.ignoreCase==c.ignoreCase}if("object"!=typeof a||"object"!=typeof c)return!1;for(var f=d.length;f--;)if(d[f]==a)return!0;d.push(a);var f=0,g=!0;if("[object Array]"==e){if(f=a.length,g=f==c.length)for(;f--&&(g=f in a==f in c&&r(a[f],c[f],d)););}else{if("constructor"in a!="constructor"in c||a.constructor!=c.constructor)return!1;for(var h in a)if(b.has(a,h)&&(f++,!(g=b.has(c,h)&&r(a[h],c[h],d))))break;if(g){for(h in c)if(b.has(c,h)&&!f--)break;
-g=!f}}d.pop();return g}var s=this,I=s._,o={},k=Array.prototype,p=Object.prototype,i=k.slice,J=k.unshift,l=p.toString,K=p.hasOwnProperty,y=k.forEach,z=k.map,A=k.reduce,B=k.reduceRight,C=k.filter,D=k.every,E=k.some,q=k.indexOf,F=k.lastIndexOf,p=Array.isArray,L=Object.keys,t=Function.prototype.bind,b=function(a){return new m(a)};"undefined"!==typeof exports?("undefined"!==typeof module&&module.exports&&(exports=module.exports=b),exports._=b):s._=b;b.VERSION="1.3.3";var j=b.each=b.forEach=function(a,
-c,d){if(a!=null)if(y&&a.forEach===y)a.forEach(c,d);else if(a.length===+a.length)for(var e=0,f=a.length;e<f;e++){if(e in a&&c.call(d,a[e],e,a)===o)break}else for(e in a)if(b.has(a,e)&&c.call(d,a[e],e,a)===o)break};b.map=b.collect=function(a,c,b){var e=[];if(a==null)return e;if(z&&a.map===z)return a.map(c,b);j(a,function(a,g,h){e[e.length]=c.call(b,a,g,h)});if(a.length===+a.length)e.length=a.length;return e};b.reduce=b.foldl=b.inject=function(a,c,d,e){var f=arguments.length>2;a==null&&(a=[]);if(A&&
-a.reduce===A){e&&(c=b.bind(c,e));return f?a.reduce(c,d):a.reduce(c)}j(a,function(a,b,i){if(f)d=c.call(e,d,a,b,i);else{d=a;f=true}});if(!f)throw new TypeError("Reduce of empty array with no initial value");return d};b.reduceRight=b.foldr=function(a,c,d,e){var f=arguments.length>2;a==null&&(a=[]);if(B&&a.reduceRight===B){e&&(c=b.bind(c,e));return f?a.reduceRight(c,d):a.reduceRight(c)}var g=b.toArray(a).reverse();e&&!f&&(c=b.bind(c,e));return f?b.reduce(g,c,d,e):b.reduce(g,c)};b.find=b.detect=function(a,
-c,b){var e;G(a,function(a,g,h){if(c.call(b,a,g,h)){e=a;return true}});return e};b.filter=b.select=function(a,c,b){var e=[];if(a==null)return e;if(C&&a.filter===C)return a.filter(c,b);j(a,function(a,g,h){c.call(b,a,g,h)&&(e[e.length]=a)});return e};b.reject=function(a,c,b){var e=[];if(a==null)return e;j(a,function(a,g,h){c.call(b,a,g,h)||(e[e.length]=a)});return e};b.every=b.all=function(a,c,b){var e=true;if(a==null)return e;if(D&&a.every===D)return a.every(c,b);j(a,function(a,g,h){if(!(e=e&&c.call(b,
-a,g,h)))return o});return!!e};var G=b.some=b.any=function(a,c,d){c||(c=b.identity);var e=false;if(a==null)return e;if(E&&a.some===E)return a.some(c,d);j(a,function(a,b,h){if(e||(e=c.call(d,a,b,h)))return o});return!!e};b.include=b.contains=function(a,c){var b=false;if(a==null)return b;if(q&&a.indexOf===q)return a.indexOf(c)!=-1;return b=G(a,function(a){return a===c})};b.invoke=function(a,c){var d=i.call(arguments,2);return b.map(a,function(a){return(b.isFunction(c)?c||a:a[c]).apply(a,d)})};b.pluck=
-function(a,c){return b.map(a,function(a){return a[c]})};b.max=function(a,c,d){if(!c&&b.isArray(a)&&a[0]===+a[0])return Math.max.apply(Math,a);if(!c&&b.isEmpty(a))return-Infinity;var e={computed:-Infinity};j(a,function(a,b,h){b=c?c.call(d,a,b,h):a;b>=e.computed&&(e={value:a,computed:b})});return e.value};b.min=function(a,c,d){if(!c&&b.isArray(a)&&a[0]===+a[0])return Math.min.apply(Math,a);if(!c&&b.isEmpty(a))return Infinity;var e={computed:Infinity};j(a,function(a,b,h){b=c?c.call(d,a,b,h):a;b<e.computed&&
-(e={value:a,computed:b})});return e.value};b.shuffle=function(a){var b=[],d;j(a,function(a,f){d=Math.floor(Math.random()*(f+1));b[f]=b[d];b[d]=a});return b};b.sortBy=function(a,c,d){var e=b.isFunction(c)?c:function(a){return a[c]};return b.pluck(b.map(a,function(a,b,c){return{value:a,criteria:e.call(d,a,b,c)}}).sort(function(a,b){var c=a.criteria,d=b.criteria;return c===void 0?1:d===void 0?-1:c<d?-1:c>d?1:0}),"value")};b.groupBy=function(a,c){var d={},e=b.isFunction(c)?c:function(a){return a[c]};
-j(a,function(a,b){var c=e(a,b);(d[c]||(d[c]=[])).push(a)});return d};b.sortedIndex=function(a,c,d){d||(d=b.identity);for(var e=0,f=a.length;e<f;){var g=e+f>>1;d(a[g])<d(c)?e=g+1:f=g}return e};b.toArray=function(a){return!a?[]:b.isArray(a)||b.isArguments(a)?i.call(a):a.toArray&&b.isFunction(a.toArray)?a.toArray():b.values(a)};b.size=function(a){return b.isArray(a)?a.length:b.keys(a).length};b.first=b.head=b.take=function(a,b,d){return b!=null&&!d?i.call(a,0,b):a[0]};b.initial=function(a,b,d){return i.call(a,
-0,a.length-(b==null||d?1:b))};b.last=function(a,b,d){return b!=null&&!d?i.call(a,Math.max(a.length-b,0)):a[a.length-1]};b.rest=b.tail=function(a,b,d){return i.call(a,b==null||d?1:b)};b.compact=function(a){return b.filter(a,function(a){return!!a})};b.flatten=function(a,c){return b.reduce(a,function(a,e){if(b.isArray(e))return a.concat(c?e:b.flatten(e));a[a.length]=e;return a},[])};b.without=function(a){return b.difference(a,i.call(arguments,1))};b.uniq=b.unique=function(a,c,d){var d=d?b.map(a,d):a,
-e=[];a.length<3&&(c=true);b.reduce(d,function(d,g,h){if(c?b.last(d)!==g||!d.length:!b.include(d,g)){d.push(g);e.push(a[h])}return d},[]);return e};b.union=function(){return b.uniq(b.flatten(arguments,true))};b.intersection=b.intersect=function(a){var c=i.call(arguments,1);return b.filter(b.uniq(a),function(a){return b.every(c,function(c){return b.indexOf(c,a)>=0})})};b.difference=function(a){var c=b.flatten(i.call(arguments,1),true);return b.filter(a,function(a){return!b.include(c,a)})};b.zip=function(){for(var a=
-i.call(arguments),c=b.max(b.pluck(a,"length")),d=Array(c),e=0;e<c;e++)d[e]=b.pluck(a,""+e);return d};b.indexOf=function(a,c,d){if(a==null)return-1;var e;if(d){d=b.sortedIndex(a,c);return a[d]===c?d:-1}if(q&&a.indexOf===q)return a.indexOf(c);d=0;for(e=a.length;d<e;d++)if(d in a&&a[d]===c)return d;return-1};b.lastIndexOf=function(a,b){if(a==null)return-1;if(F&&a.lastIndexOf===F)return a.lastIndexOf(b);for(var d=a.length;d--;)if(d in a&&a[d]===b)return d;return-1};b.range=function(a,b,d){if(arguments.length<=
-1){b=a||0;a=0}for(var d=arguments[2]||1,e=Math.max(Math.ceil((b-a)/d),0),f=0,g=Array(e);f<e;){g[f++]=a;a=a+d}return g};var H=function(){};b.bind=function(a,c){var d,e;if(a.bind===t&&t)return t.apply(a,i.call(arguments,1));if(!b.isFunction(a))throw new TypeError;e=i.call(arguments,2);return d=function(){if(!(this instanceof d))return a.apply(c,e.concat(i.call(arguments)));H.prototype=a.prototype;var b=new H,g=a.apply(b,e.concat(i.call(arguments)));return Object(g)===g?g:b}};b.bindAll=function(a){var c=
-i.call(arguments,1);c.length==0&&(c=b.functions(a));j(c,function(c){a[c]=b.bind(a[c],a)});return a};b.memoize=function(a,c){var d={};c||(c=b.identity);return function(){var e=c.apply(this,arguments);return b.has(d,e)?d[e]:d[e]=a.apply(this,arguments)}};b.delay=function(a,b){var d=i.call(arguments,2);return setTimeout(function(){return a.apply(null,d)},b)};b.defer=function(a){return b.delay.apply(b,[a,1].concat(i.call(arguments,1)))};b.throttle=function(a,c){var d,e,f,g,h,i,j=b.debounce(function(){h=
-g=false},c);return function(){d=this;e=arguments;f||(f=setTimeout(function(){f=null;h&&a.apply(d,e);j()},c));g?h=true:i=a.apply(d,e);j();g=true;return i}};b.debounce=function(a,b,d){var e;return function(){var f=this,g=arguments;d&&!e&&a.apply(f,g);clearTimeout(e);e=setTimeout(function(){e=null;d||a.apply(f,g)},b)}};b.once=function(a){var b=false,d;return function(){if(b)return d;b=true;return d=a.apply(this,arguments)}};b.wrap=function(a,b){return function(){var d=[a].concat(i.call(arguments,0));
-return b.apply(this,d)}};b.compose=function(){var a=arguments;return function(){for(var b=arguments,d=a.length-1;d>=0;d--)b=[a[d].apply(this,b)];return b[0]}};b.after=function(a,b){return a<=0?b():function(){if(--a<1)return b.apply(this,arguments)}};b.keys=L||function(a){if(a!==Object(a))throw new TypeError("Invalid object");var c=[],d;for(d in a)b.has(a,d)&&(c[c.length]=d);return c};b.values=function(a){return b.map(a,b.identity)};b.functions=b.methods=function(a){var c=[],d;for(d in a)b.isFunction(a[d])&&
-c.push(d);return c.sort()};b.extend=function(a){j(i.call(arguments,1),function(b){for(var d in b)a[d]=b[d]});return a};b.pick=function(a){var c={};j(b.flatten(i.call(arguments,1)),function(b){b in a&&(c[b]=a[b])});return c};b.defaults=function(a){j(i.call(arguments,1),function(b){for(var d in b)a[d]==null&&(a[d]=b[d])});return a};b.clone=function(a){return!b.isObject(a)?a:b.isArray(a)?a.slice():b.extend({},a)};b.tap=function(a,b){b(a);return a};b.isEqual=function(a,b){return r(a,b,[])};b.isEmpty=
-function(a){if(a==null)return true;if(b.isArray(a)||b.isString(a))return a.length===0;for(var c in a)if(b.has(a,c))return false;return true};b.isElement=function(a){return!!(a&&a.nodeType==1)};b.isArray=p||function(a){return l.call(a)=="[object Array]"};b.isObject=function(a){return a===Object(a)};b.isArguments=function(a){return l.call(a)=="[object Arguments]"};b.isArguments(arguments)||(b.isArguments=function(a){return!(!a||!b.has(a,"callee"))});b.isFunction=function(a){return l.call(a)=="[object Function]"};
-b.isString=function(a){return l.call(a)=="[object String]"};b.isNumber=function(a){return l.call(a)=="[object Number]"};b.isFinite=function(a){return b.isNumber(a)&&isFinite(a)};b.isNaN=function(a){return a!==a};b.isBoolean=function(a){return a===true||a===false||l.call(a)=="[object Boolean]"};b.isDate=function(a){return l.call(a)=="[object Date]"};b.isRegExp=function(a){return l.call(a)=="[object RegExp]"};b.isNull=function(a){return a===null};b.isUndefined=function(a){return a===void 0};b.has=function(a,
-b){return K.call(a,b)};b.noConflict=function(){s._=I;return this};b.identity=function(a){return a};b.times=function(a,b,d){for(var e=0;e<a;e++)b.call(d,e)};b.escape=function(a){return(""+a).replace(/&/g,"&amp;").replace(/</g,"&lt;").replace(/>/g,"&gt;").replace(/"/g,"&quot;").replace(/'/g,"&#x27;").replace(/\//g,"&#x2F;")};b.result=function(a,c){if(a==null)return null;var d=a[c];return b.isFunction(d)?d.call(a):d};b.mixin=function(a){j(b.functions(a),function(c){M(c,b[c]=a[c])})};var N=0;b.uniqueId=
-function(a){var b=N++;return a?a+b:b};b.templateSettings={evaluate:/<%([\s\S]+?)%>/g,interpolate:/<%=([\s\S]+?)%>/g,escape:/<%-([\s\S]+?)%>/g};var u=/.^/,n={"\\":"\\","'":"'",r:"\r",n:"\n",t:"\t",u2028:"\u2028",u2029:"\u2029"},v;for(v in n)n[n[v]]=v;var O=/\\|'|\r|\n|\t|\u2028|\u2029/g,P=/\\(\\|'|r|n|t|u2028|u2029)/g,w=function(a){return a.replace(P,function(a,b){return n[b]})};b.template=function(a,c,d){d=b.defaults(d||{},b.templateSettings);a="__p+='"+a.replace(O,function(a){return"\\"+n[a]}).replace(d.escape||
-u,function(a,b){return"'+\n_.escape("+w(b)+")+\n'"}).replace(d.interpolate||u,function(a,b){return"'+\n("+w(b)+")+\n'"}).replace(d.evaluate||u,function(a,b){return"';\n"+w(b)+"\n;__p+='"})+"';\n";d.variable||(a="with(obj||{}){\n"+a+"}\n");var a="var __p='';var print=function(){__p+=Array.prototype.join.call(arguments, '')};\n"+a+"return __p;\n",e=new Function(d.variable||"obj","_",a);if(c)return e(c,b);c=function(a){return e.call(this,a,b)};c.source="function("+(d.variable||"obj")+"){\n"+a+"}";return c};
-b.chain=function(a){return b(a).chain()};var m=function(a){this._wrapped=a};b.prototype=m.prototype;var x=function(a,c){return c?b(a).chain():a},M=function(a,c){m.prototype[a]=function(){var a=i.call(arguments);J.call(a,this._wrapped);return x(c.apply(b,a),this._chain)}};b.mixin(b);j("pop,push,reverse,shift,sort,splice,unshift".split(","),function(a){var b=k[a];m.prototype[a]=function(){var d=this._wrapped;b.apply(d,arguments);var e=d.length;(a=="shift"||a=="splice")&&e===0&&delete d[0];return x(d,
-this._chain)}});j(["concat","join","slice"],function(a){var b=k[a];m.prototype[a]=function(){return x(b.apply(this._wrapped,arguments),this._chain)}});m.prototype.chain=function(){this._chain=true;return this};m.prototype.value=function(){return this._wrapped}}).call(this);
\ No newline at end of file
diff --git a/opendaylight/adsal/web/topology/pom.xml b/opendaylight/adsal/web/topology/pom.xml
deleted file mode 100644 (file)
index 70fa599..0000000
+++ /dev/null
@@ -1,125 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>topology.web</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>configuration</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>containermanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>switchmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>topologymanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>web</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller.thirdparty</groupId>
-      <artifactId>net.sf.jung2</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-      <scope>test</scope>
-    </dependency>
-  </dependencies>
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Export-Package></Export-Package>
-            <Import-Package>org.opendaylight.controller.containermanager,
-              org.opendaylight.controller.configuration,
-              org.opendaylight.controller.sal.authorization,
-              org.opendaylight.controller.sal.packet.address,
-              org.opendaylight.controller.sal.action,
-              org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.sal.utils,
-              org.opendaylight.controller.switchmanager,
-              org.opendaylight.controller.topologymanager,
-              org.opendaylight.controller.usermanager,
-              org.opendaylight.controller.web,
-              com.google.gson,
-              edu.uci.ics.jung.algorithms.layout,
-              edu.uci.ics.jung.graph,
-              javax.annotation,
-              javax.naming,
-              javax.servlet,
-              javax.servlet.annotation,
-              javax.servlet.http,
-              javax.servlet.jsp,
-              javax.servlet.jsp.el,
-              javax.servlet.jsp.jstl.core,
-              javax.servlet.jsp.jstl.fmt,
-              javax.servlet.jsp.jstl.tlv,
-              javax.servlet.jsp.tagext,
-              javax.servlet.resources,
-              javax.xml.parsers,
-              javax.xml.transform,
-              org.apache.commons.logging,
-              org.apache.taglibs.standard.functions,
-              org.apache.taglibs.standard.resources,
-              org.apache.taglibs.standard.tag.common.core,
-              org.apache.taglibs.standard.tag.common.fmt,
-              org.apache.taglibs.standard.tag.rt.core,
-              org.apache.taglibs.standard.tag.rt.fmt,
-              org.apache.taglibs.standard.tei,
-              org.apache.taglibs.standard.tlv,
-              com.fasterxml.jackson.core,
-              com.fasterxml.jackson.databind,
-              com.fasterxml.jackson.annotation,
-              org.osgi.framework,
-              org.slf4j,
-              org.springframework.beans,
-              org.springframework.beans.factory.xml,
-              org.springframework.context.config,
-              org.springframework.stereotype,
-              org.springframework.util,
-              org.springframework.web,
-              org.springframework.web.bind.annotation,
-              org.springframework.web.servlet,
-              org.springframework.web.servlet.config,
-              org.springframework.web.servlet.view,
-              org.springframework.web.filter,
-              org.springframework.web.context,</Import-Package>
-            <Web-ContextPath>/controller/web/topology</Web-ContextPath>
-          </instructions>
-          <manifestLocation>${project.basedir}/src/main/resources/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/web/topology/src/main/java/org/opendaylight/controller/topology/web/Topology.java b/opendaylight/adsal/web/topology/src/main/java/org/opendaylight/controller/topology/web/Topology.java
deleted file mode 100644 (file)
index 3ba21f1..0000000
+++ /dev/null
@@ -1,649 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.topology.web;
-
-import java.awt.Dimension;
-import java.io.FileNotFoundException;
-import java.io.IOException;
-import java.io.ObjectInputStream;
-import java.nio.ByteBuffer;
-import java.util.ArrayList;
-import java.util.Collection;
-import java.util.HashMap;
-import java.util.LinkedList;
-import java.util.List;
-import java.util.Map;
-import java.util.Set;
-
-import javax.servlet.http.HttpServletRequest;
-
-import org.opendaylight.controller.configuration.IConfigurationAware;
-import org.opendaylight.controller.sal.authorization.Privilege;
-import org.opendaylight.controller.sal.core.Bandwidth;
-import org.opendaylight.controller.sal.core.Description;
-import org.opendaylight.controller.sal.core.Edge;
-import org.opendaylight.controller.sal.core.Host;
-import org.opendaylight.controller.sal.core.Name;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.Node.NodeIDType;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.Property;
-import org.opendaylight.controller.sal.packet.address.EthernetAddress;
-import org.opendaylight.controller.sal.utils.GlobalConstants;
-import org.opendaylight.controller.sal.utils.IObjectReader;
-import org.opendaylight.controller.sal.utils.ObjectReader;
-import org.opendaylight.controller.sal.utils.ObjectWriter;
-import org.opendaylight.controller.sal.utils.ServiceHelper;
-import org.opendaylight.controller.sal.utils.Status;
-import org.opendaylight.controller.sal.utils.StatusCode;
-import org.opendaylight.controller.switchmanager.ISwitchManager;
-import org.opendaylight.controller.switchmanager.Switch;
-import org.opendaylight.controller.switchmanager.SwitchConfig;
-import org.opendaylight.controller.topologymanager.ITopologyManager;
-import org.opendaylight.controller.web.DaylightWebUtil;
-import org.springframework.stereotype.Controller;
-import org.springframework.web.bind.annotation.PathVariable;
-import org.springframework.web.bind.annotation.RequestMapping;
-import org.springframework.web.bind.annotation.RequestMethod;
-import org.springframework.web.bind.annotation.RequestParam;
-import org.springframework.web.bind.annotation.ResponseBody;
-
-import edu.uci.ics.jung.algorithms.layout.CircleLayout;
-import edu.uci.ics.jung.graph.Graph;
-import edu.uci.ics.jung.graph.SparseMultigraph;
-
-@Controller
-@RequestMapping("/")
-public class Topology implements IObjectReader, IConfigurationAware {
-    private static String ROOT = GlobalConstants.STARTUPHOME.toString();
-    private String topologyWebFileName = null;
-
-    protected Map<String, Map<String, Map<String, Object>>> metaCache = new HashMap<String, Map<String, Map<String, Object>>>();
-    protected Map<String, Map<String, Object>> stagedNodes;
-    protected Map<String, Map<String, Object>> newNodes;
-
-    protected Map<String, Integer> metaNodeHash = new HashMap<String, Integer>();
-    protected Map<String, Integer> metaHostHash = new HashMap<String, Integer>();
-    protected Map<String, Integer> metaNodeSingleHash = new HashMap<String, Integer>();
-    protected Map<String, Integer> metaNodeConfigurationHash = new HashMap<String, Integer>();
-
-    public Topology() {
-        ServiceHelper.registerGlobalService(IConfigurationAware.class, this, null);
-        topologyWebFileName = ROOT + "topologyCache.sav";
-        loadConfiguration();
-    }
-
-    /**
-     * Topology of nodes and hosts in the network in JSON format.
-     *
-     * Mainly intended for consumption by the visual topology.
-     *
-     * @return - JSON output for visual topology
-     */
-    @RequestMapping(value = "/visual.json", method = RequestMethod.GET)
-    @ResponseBody
-    public Collection<Map<String, Object>> getLinkData(@RequestParam(required = false) String container, HttpServletRequest request) {
-        String containerName = (container == null) ? GlobalConstants.DEFAULT.toString() : container;
-
-        // Derive the privilege this user has on the current container
-        String userName = request.getUserPrincipal().getName();
-        Privilege privilege = DaylightWebUtil.getContainerPrivilege(userName, containerName, this);
-
-        if (privilege == Privilege.NONE) {
-            return null;
-        }
-
-        ITopologyManager topologyManager = (ITopologyManager) ServiceHelper
-                .getInstance(ITopologyManager.class, containerName, this);
-        if (topologyManager == null) {
-                return null;
-        }
-        ISwitchManager switchManager = (ISwitchManager) ServiceHelper
-                .getInstance(ISwitchManager.class, containerName, this);
-        if (switchManager == null) {
-                return null;
-        }
-
-        Map<Node, Set<Edge>> nodeEdges = topologyManager.getNodeEdges();
-        Map<Node, Set<NodeConnector>> hostEdges = topologyManager
-                .getNodesWithNodeConnectorHost();
-        int hostEdgesHashCode = getHostHashCode(hostEdges, topologyManager);
-        List<Switch> nodes = switchManager.getNetworkDevices();
-
-        List<SwitchConfig> switchConfigurations = new ArrayList<SwitchConfig>();
-        for(Switch sw : nodes) {
-                Node n = sw.getNode();
-                SwitchConfig config = switchManager.getSwitchConfig(n.toString());
-                switchConfigurations.add(config);
-        }
-
-        // initialize cache if needed
-        if (!metaCache.containsKey(containerName)) {
-                metaCache.put(containerName, new HashMap<String, Map<String, Object>>());
-                // initialize hashes
-                metaNodeHash.put(containerName, null);
-                metaHostHash.put(containerName, null);
-                metaNodeSingleHash.put(containerName, null);
-                metaNodeConfigurationHash.put(containerName, null);
-        }
-
-        // return cache if topology hasn't changed
-        if (
-                (metaNodeHash.get(containerName) != null && metaHostHash.get(containerName) != null && metaNodeSingleHash.get(containerName) != null && metaNodeConfigurationHash.get(containerName) != null) &&
-                metaNodeHash.get(containerName).equals(nodeEdges.hashCode()) && metaHostHash.get(containerName).equals(hostEdgesHashCode) && metaNodeSingleHash.get(containerName).equals(nodes.hashCode()) && metaNodeConfigurationHash.get(containerName).equals(switchConfigurations.hashCode())
-        ) {
-                return metaCache.get(containerName).values();
-        }
-
-        // cache has changed, we must assign the new values
-        metaNodeHash.put(containerName, nodeEdges.hashCode());
-        metaHostHash.put(containerName, hostEdgesHashCode);
-        metaNodeSingleHash.put(containerName, nodes.hashCode());
-        metaNodeConfigurationHash.put(containerName, switchConfigurations.hashCode());
-
-        stagedNodes = new HashMap<String, Map<String, Object>>();
-        newNodes = new HashMap<String, Map<String, Object>>();
-
-        // nodeEdges addition
-        addNodes(nodeEdges, topologyManager, switchManager, containerName);
-
-        // single nodes addition
-        addSingleNodes(nodes, switchManager, containerName);
-
-        // hostNodes addition
-        addHostNodes(hostEdges, topologyManager, containerName);
-
-        repositionTopology(containerName);
-
-        return metaCache.get(containerName).values();
-    }
-
-    /**
-     * Add regular nodes to main topology
-     *
-     * @param nodeEdges - node-edges mapping derived from topology
-     * @param topology - the topology instance
-     */
-    private void addNodes(Map<Node, Set<Edge>> nodeEdges,
-            ITopologyManager topology, ISwitchManager switchManager, String containerName) {
-        Bandwidth bandwidth = new Bandwidth(0);
-        Map<Edge, Set<Property>> properties = topology.getEdges();
-
-        for (Map.Entry<Node, Set<Edge>> e : nodeEdges.entrySet()) {
-            Node n = e.getKey();
-            String description = getNodeDesc(n, switchManager);
-
-            NodeBean node = createNodeBean(description, n);
-
-            // skip production node
-            if (nodeIgnore(n)) {
-                continue;
-            }
-
-            List<Map<String, Object>> adjacencies = new LinkedList<Map<String, Object>>();
-            Set<Edge> links = e.getValue();
-            for (Edge link : links) {
-                if (edgeIgnore(link)) {
-                    continue;
-                }
-                Set<Property> props = properties.get(link);
-                if (props == null) {
-                    continue;
-                }
-                for (Property p : props) {
-                    if (p instanceof Bandwidth) {
-                        bandwidth = (Bandwidth) p;
-                        break;
-                    }
-                }
-                NodeConnector headNodeConnector = link.getHeadNodeConnector();
-                NodeConnector tailNodeConnector = link.getTailNodeConnector();
-
-                String headDescription = this.getNodeConnectorDescription(headNodeConnector, switchManager);
-                String tailDescription = this.getNodeConnectorDescription(tailNodeConnector, switchManager);
-                String headPortDescription = this.getNodeConnectorPortDescription(headNodeConnector, switchManager);
-                String tailPortDescription = this.getNodeConnectorPortDescription(tailNodeConnector, switchManager);
-                EdgeBean edge = new EdgeBean(link, bandwidth, headDescription, tailDescription, headPortDescription, tailPortDescription);
-                adjacencies.add(edge.out());
-            }
-
-            node.setLinks(adjacencies);
-            if (metaCache.get(containerName).containsKey(node.id())) {
-                // retrieve node from cache
-                Map<String, Object> nodeEntry = metaCache.get(containerName).get(node.id());
-
-                        Map<String, String> data = (Map<String, String>) nodeEntry.get("data");
-                        data.put("$desc", description);
-                        nodeEntry.put("data", data);
-
-                // always update adjacencies
-                nodeEntry.put("adjacencies", adjacencies);
-                // stage this cached node (with position)
-                stagedNodes.put(node.id(), nodeEntry);
-            } else {
-                newNodes.put(node.id(), node.out());
-            }
-        }
-    }
-
-    /**
-     * Check if this node shouldn't appear in the visual topology
-     *
-     * @param node
-     * @return
-     */
-    private boolean nodeIgnore(Node node) {
-        String nodeType = node.getType();
-
-        // add other node types to ignore later
-        if (nodeType.equals(NodeIDType.PRODUCTION)) {
-            return true;
-        }
-
-        return false;
-    }
-
-    /**
-     * Check if this edge shouldn't appear in the visual topology
-     *
-     * @param edge
-     * @return
-     */
-    private boolean edgeIgnore(Edge edge) {
-        NodeConnector headNodeConnector = edge.getHeadNodeConnector();
-        Node headNode = headNodeConnector.getNode();
-        if (nodeIgnore(headNode)) {
-            return true;
-        }
-
-        NodeConnector tailNodeConnector = edge.getTailNodeConnector();
-        Node tailNode = tailNodeConnector.getNode();
-        if (nodeIgnore(tailNode)) {
-            return true;
-        }
-
-        return false;
-    }
-
-    protected NodeBean createNodeBean(String description, Node node) {
-        String name = this.getDescription(description, node);
-        return  new NodeBean(node.toString(), name, NodeType.NODE);
-    }
-
-    private String getDescription(String description, Node node) {
-        String name = (description == null ||
-                description.trim().isEmpty() ||
-                description.equalsIgnoreCase("none"))?
-                                node.toString() : description;
-        return name;
-    }
-
-    private String getNodeConnectorDescription(NodeConnector nodeConnector, ISwitchManager switchManager) {
-        Node node = nodeConnector.getNode();
-        String name = this.getDescription(getNodeDesc(node, switchManager), node);
-        return name;
-    }
-
-    private String getNodeConnectorPortDescription(NodeConnector nodeConnector, ISwitchManager switchManager) {
-        Name ncName = (Name) switchManager.getNodeConnectorProp(nodeConnector, Name.NamePropName);
-        String nodeConnectorName = nodeConnector.getNodeConnectorIDString();
-        if (ncName != null) {
-            nodeConnectorName = ncName.getValue();
-        }
-        return nodeConnectorName;
-    }
-
-    @SuppressWarnings("unchecked")
-        private void addSingleNodes(List<Switch> nodes, ISwitchManager switchManager, String containerName) {
-        if (nodes == null) {
-                return;
-        }
-        for (Switch sw : nodes) {
-                Node n = sw.getNode();
-
-                // skip production node
-                if (nodeIgnore(n)) {
-                    continue;
-                }
-
-                String description = getNodeDesc(n, switchManager);
-
-                if ((stagedNodes.containsKey(n.toString()) && metaCache.get(containerName).containsKey(n.toString())) || newNodes.containsKey(n.toString())) {
-                        continue;
-                }
-                NodeBean node = createNodeBean(description, n);
-
-                // FIXME still doesn't display standalone node when last remaining link is removed
-                if (metaCache.get(containerName).containsKey(node.id()) && !stagedNodes.containsKey(node.id())) {
-                        Map<String, Object> nodeEntry = metaCache.get(containerName).get(node.id());
-                                Map<String, String> data = (Map<String, String>) nodeEntry.get("data");
-                        data.put("$desc", description);
-                        nodeEntry.put("data", data);
-                        // clear adjacencies since this is now a single node
-                        nodeEntry.put("adjacencies", new LinkedList<Map<String, Object>>());
-                stagedNodes.put(node.id(), nodeEntry);
-            } else {
-                newNodes.put(node.id(), node.out());
-            }
-        }
-    }
-
-    /**
-     * Calculate the total host hashcode
-     *
-     * This is to handle cases where there are multiple hosts per NodeConnector
-     *
-     * @param hostEdges
-     *            - hostEdges data structure
-     * @param topology
-     *            - topology bundle
-     * @return this topology's host hashcode
-     */
-    private int getHostHashCode(Map<Node, Set<NodeConnector>> hostEdges, ITopologyManager topology) {
-        List<Host> hosts = new ArrayList<Host>();
-        for (Set<NodeConnector> nodeConnectors : hostEdges.values()) {
-            for (NodeConnector nodeConnector : nodeConnectors) {
-                List<Host> theseHosts = topology.getHostsAttachedToNodeConnector(nodeConnector);
-                hosts.addAll(theseHosts);
-            }
-        }
-
-        return hosts.hashCode();
-    }
-
-    /**
-     * Add regular hosts to main topology
-     *
-     * @param hostEdges - node-nodeconnectors host-specific mapping from topology
-     * @param topology - topology instance
-     */
-    private void addHostNodes(Map<Node, Set<NodeConnector>> hostEdges,
-            ITopologyManager topology, String containerName) {
-        for (Map.Entry<Node, Set<NodeConnector>> e : hostEdges.entrySet()) {
-            for (NodeConnector connector : e.getValue()) {
-                List<Host> hosts = topology.getHostsAttachedToNodeConnector(connector);
-                for (Host host : hosts) {
-                    EthernetAddress dmac = (EthernetAddress) host.getDataLayerAddress();
-
-                    ByteBuffer addressByteBuffer = ByteBuffer.allocate(8);
-                    addressByteBuffer.putShort((short) 0);
-                    addressByteBuffer.put(dmac.getValue());
-                    addressByteBuffer.rewind();
-
-                    long hid = addressByteBuffer.getLong();
-                    String hostId = String.valueOf(hid);
-
-                    NodeBean hostBean = new NodeBean(hostId, host.getNetworkAddressAsString(), NodeType.HOST);
-                    List<Map<String, Object>> adjacencies = new LinkedList<Map<String, Object>>();
-                    EdgeBean edge = new EdgeBean(connector, hid);
-                    adjacencies.add(edge.out());
-                    hostBean.setLinks(adjacencies);
-
-                    if (metaCache.get(containerName).containsKey(hostId)) {
-                        Map<String, Object> hostEntry = metaCache.get(containerName).get(hostId);
-                        hostEntry.put("adjacencies", adjacencies);
-                        stagedNodes.put(hostId, hostEntry);
-                    } else {
-                        newNodes.put(String.valueOf(hid), hostBean.out());
-                    }
-                }
-            }
-        }
-    }
-
-    /**
-     * Re-position nodes in circular layout
-     */
-    private void repositionTopology(String containerName) {
-        Graph<String, String> graph = new SparseMultigraph<String, String>();
-
-        metaCache.get(containerName).clear();
-        metaCache.get(containerName).putAll(stagedNodes);
-        metaCache.get(containerName).putAll(newNodes);
-
-        for (Map<String, Object> on : metaCache.get(containerName).values()) {
-            graph.addVertex(on.toString());
-
-            List<Map<String, Object>> adjacencies = (List<Map<String, Object>>) on.get("adjacencies");
-
-            for (Map<String, Object> adj : adjacencies) {
-                graph.addEdge(
-                        adj.toString(), adj.get("nodeFrom").toString(),
-                        adj.get("nodeTo").toString()
-                );
-            }
-        }
-
-        CircleLayout<String, String> layout = new CircleLayout<String, String>(graph);
-        layout.setSize(new Dimension(1200, 365));
-        for (Map.Entry<String, Map<String, Object>> v : newNodes.entrySet()) {
-            Double x = layout.transform(v.getKey()).getX();
-            Double y = layout.transform(v.getKey()).getY();
-
-            Map<String, String> nodeData = (HashMap<String, String>) v.getValue().get("data");
-            nodeData.put("$x", (x - 600) + "");
-            nodeData.put("$y", (y - 225) + "");
-
-            newNodes.get(v.getKey()).put("data", nodeData);
-        }
-    }
-
-    /**
-     * Update node position
-     *
-     * This method is mainly used by the visual topology
-     *
-     * @param nodeId - The node to update
-     * @return The node object
-     */
-    @RequestMapping(value = "/node/{nodeId}", method = RequestMethod.POST)
-    @ResponseBody
-    public Map<String, Object> post(@PathVariable String nodeId, @RequestParam(required = true) String x,
-                @RequestParam(required = true) String y, @RequestParam(required = false) String container,
-                HttpServletRequest request) {
-        String containerName = (container == null) ? GlobalConstants.DEFAULT.toString() : container;
-
-        // Derive the privilege this user has on the current container
-        String userName = request.getUserPrincipal().getName();
-        Privilege privilege = DaylightWebUtil.getContainerPrivilege(userName, containerName, this);
-
-        if (privilege != Privilege.WRITE) {
-            return new HashMap<String, Object>(); // silently disregard new node position
-        }
-
-        String id = new String(nodeId);
-
-        if (!metaCache.get(containerName).containsKey(id)) {
-            return null;
-        }
-
-        Map<String, Object> node = metaCache.get(containerName).get(id);
-        Map<String, String> data = (Map<String, String>) node.get("data");
-
-        data.put("$x", x);
-        data.put("$y", y);
-
-        node.put("data", data);
-
-        return node;
-    }
-
-    /**
-     * Node object for visual topology
-     */
-    protected class NodeBean {
-        protected String id;
-        protected String name;
-        protected Map<String, String> data;
-        protected List<Map<String, Object>> links;
-
-        public NodeBean() {
-                data = new HashMap<String, String>();
-                links = new ArrayList<Map<String, Object>>();
-        }
-
-        public NodeBean(String id, String name, String type) {
-                this();
-                this.id = id;
-                this.name = name;
-                data.put("$desc", name);
-                data.put("$type", type);
-        }
-
-        public void setLinks(List<Map<String, Object>> links) {
-                this.links = links;
-        }
-
-        public Map<String, Object> out() {
-                Map<String, Object> node = new HashMap<String, Object>();
-                node.put("id", this.id);
-                node.put("name", this.name);
-                node.put("data", this.data);
-                node.put("adjacencies", this.links);
-
-                return node;
-        }
-
-        public String name() {
-                return this.name;
-        }
-
-        public String id() {
-                return this.id;
-        }
-    }
-
-    /**
-     * Edge object for visual topology
-     */
-    protected class EdgeBean {
-        protected NodeConnector source;
-        protected NodeConnector destination;
-        protected Map<String, String> data;
-        protected Long hostId;
-
-        public EdgeBean() {
-                data = new HashMap<String, String>();
-        }
-
-        /**
-         * EdgeBean object that includes complete node description
-         *
-         * @param link
-         * @param bandwidth
-         * @param headDescription
-         * @param tailDescription
-         */
-        public EdgeBean(Edge link, Bandwidth bandwidth, String headDescription,
-                String tailDescription, String headPortDescription, String tailPortDescription) {
-            this();
-            this.source = link.getHeadNodeConnector();
-            this.destination = link.getTailNodeConnector();
-
-            // data
-            data.put("$bandwidth", bandwidth.toString());
-            data.put("$color", bandwidthColor(bandwidth));
-            data.put("$nodeToPort", destination.getID().toString());
-            data.put("$nodeFromPort", source.getID().toString());
-            data.put("$descFrom", headDescription);
-            data.put("$descTo", tailDescription);
-            data.put("$nodeFromPortName", source.toString());
-            data.put("$nodeToPortName", destination.toString());
-            data.put("$nodeFromPortDescription", headPortDescription);
-            data.put("$nodeToPortDescription", tailPortDescription);
-        }
-
-        public EdgeBean(NodeConnector connector, Long hostId) {
-            this();
-            this.source = null;
-            this.destination = connector;
-            this.hostId = hostId;
-
-            data.put("$bandwidth", "N/A");
-            data.put("$color", bandwidthColor(new Bandwidth(0)));
-            data.put("$nodeToPort", connector.getNodeConnectorIDString());
-            data.put("$nodeFromPort", connector.getNodeConnectorIDString());
-            data.put("$descTo", "");
-            data.put("$descFrom", "");
-            data.put("$nodeToPortName", "");
-            data.put("$nodeFromPortName", "");
-        }
-
-        public Map<String, Object> out() {
-                Map<String, Object> edge = new HashMap<String, Object>();
-
-                edge.put("data", data);
-                if (source == null) {
-                        edge.put("nodeFrom", String.valueOf(this.hostId));
-                } else {
-                        edge.put("nodeFrom", source.getNode().toString());
-                }
-                edge.put("nodeTo", destination.getNode().toString());
-
-
-                return edge;
-        }
-
-        private String bandwidthColor(Bandwidth bandwidth) {
-                String color = null;
-                long bandwidthValue = bandwidth.getValue();
-
-                if (bandwidthValue == 0) {
-                color = "#000";
-            } else if (bandwidthValue < Bandwidth.BW1Kbps) {
-                color = "#148AC6";
-            } else if (bandwidthValue < Bandwidth.BW1Mbps) {
-                color = "#2858A0";
-            } else if (bandwidthValue < Bandwidth.BW1Gbps) {
-                color = "#009393";
-            } else if (bandwidthValue < Bandwidth.BW1Tbps) {
-                color = "#C6C014";
-            } else if (bandwidthValue < Bandwidth.BW1Pbps) {
-                color = "#F9F464";
-            }
-
-                return color;
-        }
-    }
-
-    protected class NodeType {
-        public static final String NODE = "switch";
-        public static final String HOST = "host";
-    }
-
-    @SuppressWarnings("unchecked")
-        private void loadConfiguration() {
-        ObjectReader objReader = new ObjectReader();
-        metaCache = (Map<String, Map<String, Map<String, Object>>>) objReader.read(this, topologyWebFileName);
-        if (metaCache == null) {
-            metaCache = new HashMap<String, Map<String, Map<String, Object>>>();
-        }
-    }
-
-    @Override
-    public Status saveConfiguration() {
-        ObjectWriter objWriter = new ObjectWriter();
-        objWriter.write(metaCache, topologyWebFileName);
-        return new Status(StatusCode.SUCCESS, null);
-    }
-
-    @Override
-    public Object readObject(ObjectInputStream ois)
-            throws FileNotFoundException, IOException, ClassNotFoundException {
-        // Perform the class deserialization locally, from inside the package where the class is defined
-        return ois.readObject();
-    }
-
-    private String getNodeDesc(Node node, ISwitchManager switchManager) {
-        Description desc = (Description) switchManager.getNodeProp(node, Description.propertyName);
-        return (desc == null) ? "" : desc.getValue();
-    }
-
-}
\ No newline at end of file
diff --git a/opendaylight/adsal/web/topology/src/main/resources/META-INF/spring.factories b/opendaylight/adsal/web/topology/src/main/resources/META-INF/spring.factories
deleted file mode 100644 (file)
index 93db02e..0000000
+++ /dev/null
@@ -1 +0,0 @@
-org.springframework.beans.BeanInfoFactory=org.springframework.beans.ExtendedBeanInfoFactory
diff --git a/opendaylight/adsal/web/topology/src/main/resources/META-INF/spring.handlers b/opendaylight/adsal/web/topology/src/main/resources/META-INF/spring.handlers
deleted file mode 100644 (file)
index 957af91..0000000
+++ /dev/null
@@ -1,10 +0,0 @@
-http\://www.springframework.org/schema/context=org.springframework.context.config.ContextNamespaceHandler
-http\://www.springframework.org/schema/jee=org.springframework.ejb.config.JeeNamespaceHandler
-http\://www.springframework.org/schema/lang=org.springframework.scripting.config.LangNamespaceHandler
-http\://www.springframework.org/schema/task=org.springframework.scheduling.config.TaskNamespaceHandler
-http\://www.springframework.org/schema/cache=org.springframework.cache.config.CacheNamespaceHandler
-http\://www.springframework.org/schema/c=org.springframework.beans.factory.xml.SimpleConstructorNamespaceHandler
-http\://www.springframework.org/schema/p=org.springframework.beans.factory.xml.SimplePropertyNamespaceHandler
-http\://www.springframework.org/schema/util=org.springframework.beans.factory.xml.UtilNamespaceHandler
-http\://www.springframework.org/schema/mvc=org.springframework.web.servlet.config.MvcNamespaceHandler
-http\://www.springframework.org/schema/security=org.springframework.security.config.SecurityNamespaceHandler
diff --git a/opendaylight/adsal/web/topology/src/main/resources/META-INF/spring.schemas b/opendaylight/adsal/web/topology/src/main/resources/META-INF/spring.schemas
deleted file mode 100644 (file)
index d865edc..0000000
+++ /dev/null
@@ -1,49 +0,0 @@
-http\://www.springframework.org/schema/beans/spring-beans-2.0.xsd=org/springframework/beans/factory/xml/spring-beans-2.0.xsd
-http\://www.springframework.org/schema/beans/spring-beans-2.5.xsd=org/springframework/beans/factory/xml/spring-beans-2.5.xsd
-http\://www.springframework.org/schema/beans/spring-beans-3.0.xsd=org/springframework/beans/factory/xml/spring-beans-3.0.xsd
-http\://www.springframework.org/schema/beans/spring-beans-3.1.xsd=org/springframework/beans/factory/xml/spring-beans-3.1.xsd
-http\://www.springframework.org/schema/beans/spring-beans-3.2.xsd=org/springframework/beans/factory/xml/spring-beans-3.2.xsd
-http\://www.springframework.org/schema/beans/spring-beans.xsd=org/springframework/beans/factory/xml/spring-beans-3.2.xsd
-http\://www.springframework.org/schema/tool/spring-tool-2.0.xsd=org/springframework/beans/factory/xml/spring-tool-2.0.xsd
-http\://www.springframework.org/schema/tool/spring-tool-2.5.xsd=org/springframework/beans/factory/xml/spring-tool-2.5.xsd
-http\://www.springframework.org/schema/tool/spring-tool-3.0.xsd=org/springframework/beans/factory/xml/spring-tool-3.0.xsd
-http\://www.springframework.org/schema/tool/spring-tool-3.1.xsd=org/springframework/beans/factory/xml/spring-tool-3.1.xsd
-http\://www.springframework.org/schema/tool/spring-tool-3.2.xsd=org/springframework/beans/factory/xml/spring-tool-3.2.xsd
-http\://www.springframework.org/schema/tool/spring-tool.xsd=org/springframework/beans/factory/xml/spring-tool-3.2.xsd
-http\://www.springframework.org/schema/util/spring-util-2.0.xsd=org/springframework/beans/factory/xml/spring-util-2.0.xsd
-http\://www.springframework.org/schema/util/spring-util-2.5.xsd=org/springframework/beans/factory/xml/spring-util-2.5.xsd
-http\://www.springframework.org/schema/util/spring-util-3.0.xsd=org/springframework/beans/factory/xml/spring-util-3.0.xsd
-http\://www.springframework.org/schema/util/spring-util-3.1.xsd=org/springframework/beans/factory/xml/spring-util-3.1.xsd
-http\://www.springframework.org/schema/util/spring-util-3.2.xsd=org/springframework/beans/factory/xml/spring-util-3.2.xsd
-http\://www.springframework.org/schema/util/spring-util.xsd=org/springframework/beans/factory/xml/spring-util-3.2.xsd
-http\://www.springframework.org/schema/context/spring-context-2.5.xsd=org/springframework/context/config/spring-context-2.5.xsd
-http\://www.springframework.org/schema/context/spring-context-3.0.xsd=org/springframework/context/config/spring-context-3.0.xsd
-http\://www.springframework.org/schema/context/spring-context-3.1.xsd=org/springframework/context/config/spring-context-3.1.xsd
-http\://www.springframework.org/schema/context/spring-context-3.2.xsd=org/springframework/context/config/spring-context-3.2.xsd
-http\://www.springframework.org/schema/context/spring-context.xsd=org/springframework/context/config/spring-context-3.2.xsd
-http\://www.springframework.org/schema/jee/spring-jee-2.0.xsd=org/springframework/ejb/config/spring-jee-2.0.xsd
-http\://www.springframework.org/schema/jee/spring-jee-2.5.xsd=org/springframework/ejb/config/spring-jee-2.5.xsd
-http\://www.springframework.org/schema/jee/spring-jee-3.0.xsd=org/springframework/ejb/config/spring-jee-3.0.xsd
-http\://www.springframework.org/schema/jee/spring-jee-3.1.xsd=org/springframework/ejb/config/spring-jee-3.1.xsd
-http\://www.springframework.org/schema/jee/spring-jee-3.2.xsd=org/springframework/ejb/config/spring-jee-3.2.xsd
-http\://www.springframework.org/schema/jee/spring-jee.xsd=org/springframework/ejb/config/spring-jee-3.2.xsd
-http\://www.springframework.org/schema/lang/spring-lang-2.0.xsd=org/springframework/scripting/config/spring-lang-2.0.xsd
-http\://www.springframework.org/schema/lang/spring-lang-2.5.xsd=org/springframework/scripting/config/spring-lang-2.5.xsd
-http\://www.springframework.org/schema/lang/spring-lang-3.0.xsd=org/springframework/scripting/config/spring-lang-3.0.xsd
-http\://www.springframework.org/schema/lang/spring-lang-3.1.xsd=org/springframework/scripting/config/spring-lang-3.1.xsd
-http\://www.springframework.org/schema/lang/spring-lang-3.2.xsd=org/springframework/scripting/config/spring-lang-3.2.xsd
-http\://www.springframework.org/schema/lang/spring-lang.xsd=org/springframework/scripting/config/spring-lang-3.2.xsd
-http\://www.springframework.org/schema/task/spring-task-3.0.xsd=org/springframework/scheduling/config/spring-task-3.0.xsd
-http\://www.springframework.org/schema/task/spring-task-3.1.xsd=org/springframework/scheduling/config/spring-task-3.1.xsd
-http\://www.springframework.org/schema/task/spring-task-3.2.xsd=org/springframework/scheduling/config/spring-task-3.2.xsd
-http\://www.springframework.org/schema/task/spring-task.xsd=org/springframework/scheduling/config/spring-task-3.2.xsd
-http\://www.springframework.org/schema/cache/spring-cache-3.1.xsd=org/springframework/cache/config/spring-cache-3.1.xsd
-http\://www.springframework.org/schema/cache/spring-cache-3.2.xsd=org/springframework/cache/config/spring-cache-3.2.xsd
-http\://www.springframework.org/schema/cache/spring-cache.xsd=org/springframework/cache/config/spring-cache-3.2.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd=org/springframework/web/servlet/config/spring-mvc-3.0.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc-3.1.xsd=org/springframework/web/servlet/config/spring-mvc-3.1.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc-3.2.xsd=org/springframework/web/servlet/config/spring-mvc-3.2.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc.xsd=org/springframework/web/servlet/config/spring-mvc-3.2.xsd
-http\://www.springframework.org/schema/security/spring-security-3.1.xsd=org/springframework/security/config/spring-security-3.1.xsd
-http\://www.springframework.org/schema/security/spring-security-3.2.xsd=org/springframework/security/config/spring-security-3.2.xsd
-
diff --git a/opendaylight/adsal/web/topology/src/main/resources/META-INF/spring.tooling b/opendaylight/adsal/web/topology/src/main/resources/META-INF/spring.tooling
deleted file mode 100644 (file)
index 057d834..0000000
+++ /dev/null
@@ -1,39 +0,0 @@
-# Tooling related information for the beans namespace
-http\://www.springframework.org/schema/beans@name=beans Namespace
-http\://www.springframework.org/schema/beans@prefix=beans
-http\://www.springframework.org/schema/beans@icon=org/springframework/beans/factory/xml/spring-beans.gif
-
-# Tooling related information for the util namespace
-http\://www.springframework.org/schema/util@name=util Namespace
-http\://www.springframework.org/schema/util@prefix=util
-http\://www.springframework.org/schema/util@icon=org/springframework/beans/factory/xml/spring-util.gif
-
-# Tooling related information for the context namespace
-http\://www.springframework.org/schema/context@name=context Namespace
-http\://www.springframework.org/schema/context@prefix=context
-http\://www.springframework.org/schema/context@icon=org/springframework/context/config/spring-context.gif
-
-# Tooling related information for the jee namespace
-http\://www.springframework.org/schema/jee@name=jee Namespace
-http\://www.springframework.org/schema/jee@prefix=jee
-http\://www.springframework.org/schema/jee@icon=org/springframework/ejb/config/spring-jee.gif
-
-# Tooling related information for the scheduling namespace
-http\://www.springframework.org/schema/task@name=task Namespace
-http\://www.springframework.org/schema/task@prefix=task
-http\://www.springframework.org/schema/task@icon=org/springframework/scheduling/config/spring-task.gif
-
-# Tooling related information for the lang namespace
-http\://www.springframework.org/schema/lang@name=lang Namespace
-http\://www.springframework.org/schema/lang@prefix=lang
-http\://www.springframework.org/schema/lang@icon=org/springframework/scripting/config/spring-lang.gif
-
-# Tooling related information for the cache namespace
-http\://www.springframework.org/schema/cache@name=cache Namespace
-http\://www.springframework.org/schema/cache@prefix=cache
-http\://www.springframework.org/schema/cache@icon=org/springframework/cache/config/spring-cache.gif
-
-# Tooling related information for the mvc namespace
-http\://www.springframework.org/schema/mvc@name=mvc Namespace
-http\://www.springframework.org/schema/mvc@prefix=mvc
-http\://www.springframework.org/schema/mvc@icon=org/springframework/web/servlet/config/spring-mvc.gif
diff --git a/opendaylight/adsal/web/topology/src/main/resources/WEB-INF/Topology-servlet.xml b/opendaylight/adsal/web/topology/src/main/resources/WEB-INF/Topology-servlet.xml
deleted file mode 100644 (file)
index cb6f2b6..0000000
+++ /dev/null
@@ -1,21 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>\r
-<beans xmlns="http://www.springframework.org/schema/beans"\r
-  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"\r
-  xmlns:context="http://www.springframework.org/schema/context"\r
-  xmlns:mvc="http://www.springframework.org/schema/mvc"\r
-  xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd\r
-                      http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd\r
-                      http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd">\r
-\r
-  <context:component-scan base-package="org.opendaylight.controller.topology.web"/>\r
-\r
-  <mvc:resources mapping="/js/**" location="/js/" />\r
-  <mvc:resources mapping="/css/**" location="/css/" />\r
-  <mvc:resources mapping="/img/**" location="/img/" />\r
-  <mvc:annotation-driven/>\r
-\r
-  <bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">\r
-        <property name="prefix" value="/WEB-INF/jsp/"/>\r
-        <property name="suffix" value=".jsp"/>\r
-  </bean>\r
-</beans>\r
diff --git a/opendaylight/adsal/web/topology/src/main/resources/WEB-INF/jsp/autherror.jsp b/opendaylight/adsal/web/topology/src/main/resources/WEB-INF/jsp/autherror.jsp
deleted file mode 100644 (file)
index 127a5a0..0000000
+++ /dev/null
@@ -1,55 +0,0 @@
-<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
-<%@ page import="java.net.URL" %>
-<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
-
-<!DOCTYPE html>
-<html>
-  <head>
-    <meta charset="utf-8">
-
-    <!-- Bootstrap CSS - 1 -->
-    <link href="/css/bootstrap.min.css" rel="stylesheet" media="screen">
-    
-    <!-- Login CSS - 2 -->
-    <link rel="stylesheet/less" type="text/css" href="/css/login.less">
-
-<c:set var="title" value="OpenDaylight login error" scope="application"/>
-<%
-    String filePath = "/WEB-INF/jsp/customerror.jsp"; 
-       URL fileURL = pageContext.getServletContext().getResource(filePath);
-       if(fileURL!=null) {
-%>
-         <jsp:include page="<%=filePath%>" flush="true"/>
-<% } %>
-       <title>${title}</title>
-    <!-- Bootstrap JS - 1 -->
-    <script src="/js/bootstrap.min.js"></script>
-    
-    <!-- LESS - 2 -->
-    <script type="text/javascript">
-        less = {
-            env: "production"
-        };
-    </script>
-    <script src="/js/less-1.3.3.min.js"></script>
-</head>
-<body>
-        <form action="<c:url value='/' />" id="form" method="post">
-
-  <div class="container">
-    <div class="content">
-       <div class="login-form">
-         <div id="logo"></div>
-           <fieldset>
-            <p>You are not authorized to access this resource.<p>
-            <p>Please contact your administrator to resolve your Role privileges.</p>
-            <br/>
-             <button class="btn btn-primary" type="submit" value="Log In" >Go To Login Page</button>
-           </fieldset>
-       </div>
-    </div>
-  </div> 
-  </form>
-  <% if (session != null) session.invalidate(); %>  
-</body>
-</html>
diff --git a/opendaylight/adsal/web/topology/src/main/resources/WEB-INF/jsp/error.jsp b/opendaylight/adsal/web/topology/src/main/resources/WEB-INF/jsp/error.jsp
deleted file mode 100644 (file)
index 270d793..0000000
+++ /dev/null
@@ -1,8 +0,0 @@
-<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
-<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
-<%@taglib prefix="fn" uri="http://java.sun.com/jsp/jstl/functions" %>
-<c:set var="req" value="${pageContext.request}" />
-<c:set var="uri" value="${req.requestURI}" />
-<c:set var="replaceWith" value="/" />
-<c:set var="redirectUrl" value="${fn:replace(req.requestURL, req.contextPath , replaceWith)}" />
-<c:import url="${redirectUrl}" />
\ No newline at end of file
diff --git a/opendaylight/adsal/web/topology/src/main/resources/WEB-INF/jsp/login.jsp b/opendaylight/adsal/web/topology/src/main/resources/WEB-INF/jsp/login.jsp
deleted file mode 100644 (file)
index 270d793..0000000
+++ /dev/null
@@ -1,8 +0,0 @@
-<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
-<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
-<%@taglib prefix="fn" uri="http://java.sun.com/jsp/jstl/functions" %>
-<c:set var="req" value="${pageContext.request}" />
-<c:set var="uri" value="${req.requestURI}" />
-<c:set var="replaceWith" value="/" />
-<c:set var="redirectUrl" value="${fn:replace(req.requestURL, req.contextPath , replaceWith)}" />
-<c:import url="${redirectUrl}" />
\ No newline at end of file
diff --git a/opendaylight/adsal/web/topology/src/main/resources/WEB-INF/web.xml b/opendaylight/adsal/web/topology/src/main/resources/WEB-INF/web.xml
deleted file mode 100644 (file)
index c37fffe..0000000
+++ /dev/null
@@ -1,78 +0,0 @@
-<?xml version="1.0" encoding="ISO-8859-1"?>
-<web-app xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
-        xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
-        version="3.0">
-        <security-constraint>
-                <web-resource-collection>
-                        <web-resource-name>free access</web-resource-name>
-                        <url-pattern>/js/*</url-pattern>
-                        <url-pattern>/images/*</url-pattern>
-                        <url-pattern>/css/*</url-pattern>
-                        <url-pattern>/favicon.ico</url-pattern>
-                </web-resource-collection>
-        </security-constraint>
-
-        <security-constraint>
-                <display-name>TopologyApp</display-name>
-                <web-resource-collection>
-                        <web-resource-name>TopoGUI</web-resource-name>
-                        <url-pattern>/*</url-pattern>
-                </web-resource-collection>
-                <auth-constraint>
-                        <role-name>System-Admin</role-name>
-                        <role-name>Network-Admin</role-name>
-                        <role-name>Network-Operator</role-name>
-                        <role-name>Container-User</role-name>
-                </auth-constraint>
-        </security-constraint>
-        <security-role>
-                <role-name>System-Admin</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Network-Admin</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Network-Operator</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Container-User</role-name>
-        </security-role>
-
-        <login-config>
-                <auth-method>FORM</auth-method>
-                <form-login-config>
-                        <form-login-page>/WEB-INF/jsp/login.jsp</form-login-page>
-                        <form-error-page>/WEB-INF/jsp/error.jsp</form-error-page>
-                </form-login-config>
-        </login-config>
-
-    <error-page>
-            <error-code>403</error-code>
-            <location>/WEB-INF/jsp/autherror.jsp</location>
-    </error-page>
-
-        <servlet>
-                <servlet-name>Topology</servlet-name>
-                <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
-                <load-on-startup>1</load-on-startup>
-        </servlet>
-
-
-
-        <servlet-mapping>
-                <servlet-name>Topology</servlet-name>
-                <url-pattern>/</url-pattern>
-        </servlet-mapping>
-
-        <listener>
-                <listener-class>org.opendaylight.controller.web.ControllerUISessionManager</listener-class>
-        </listener>
-
-        <session-config>
-                <cookie-config>
-                        <path>/</path>
-                </cookie-config>
-        </session-config>
-
-
-</web-app>
diff --git a/opendaylight/adsal/web/topology/src/main/resources/js/page.js b/opendaylight/adsal/web/topology/src/main/resources/js/page.js
deleted file mode 100644 (file)
index 5b4e79f..0000000
+++ /dev/null
@@ -1,113 +0,0 @@
-
-/* 
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved. 
- * 
- * This program and the accompanying materials are made available under the 
- * terms of the Eclipse Public License v1.0 which accompanies this distribution, 
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-//PAGE topology
-one.f = {};
-
-// specify dashlets and layouts
-one.f.dashlet = {
-    flows : {
-        id : 'dashletFlows',
-        name : 'Flows'
-    },
-    widget : {
-        id : 'dashletWidget',
-        name : 'Acme Widgets'
-    },
-    status : {
-        id : 'dashletStatus',
-        name : 'Network Status'
-    },
-    foo : {
-        id : 'dashletFoo',
-        name : 'Foo'
-    },
-    bar : {
-        id : 'dashletBar',
-        name : 'Bar'
-    }
-};
-
-one.f.menu = {
-    left : {
-        top : [
-            one.f.dashlet.flows,
-            one.f.dashlet.bar
-        ],
-        bottom : [
-            one.f.dashlet.foo
-        ]
-    },
-    right : {
-        top : [],
-        bottom : [
-            one.f.dashlet.widget,
-            one.f.dashlet.status
-        ]
-    }
-};
-
-/** INIT **/
-// populate nav tabs
-$(one.f.menu.left.top).each(function(index, value) {
-    var $nav = $(".nav", "#left-top");
-    one.main.page.dashlet($nav, value);
-});
-
-$(one.f.menu.left.bottom).each(function(index, value) {
-    var $nav = $(".nav", "#left-bottom");
-    one.main.page.dashlet($nav, value);
-});
-
-$(one.f.menu.right.bottom).each(function(index, value) {
-    var $nav = $(".nav", "#right-bottom");
-    one.main.page.dashlet($nav, value);
-});
-
-one.f.populate = function($dashlet, header) {
-    var $h4 = one.lib.dashlet.header(header);
-    $dashlet.append($h4);
-};
-
-// bind dashlet nav
-$('.dash .nav a', '#main').click(function() {
-    // de/activation
-    var $li = $(this).parent();
-    var $ul = $li.parent();
-    one.lib.nav.unfocus($ul);
-    $li.addClass('active');
-    // clear respective dashlet
-    var $dashlet = $ul.parent().find('.dashlet');
-    one.lib.dashlet.empty($dashlet);
-    // callback based on menu
-    var id = $(this).attr('id');
-    var menu = one.f.dashlet;
-    switch (id) {
-        case menu.foo.id:
-            one.f.populate($dashlet, "Foo");
-            break;
-        case menu.flows.id:
-            one.f.populate($dashlet, "Flows");
-            break;
-        case menu.bar.id:
-            one.f.populate($dashlet, "Bar");
-            break;
-        case menu.widget.id:
-            one.f.populate($dashlet, "Widget");
-            break;
-        case menu.status.id:
-            one.f.populate($dashlet, "Status");
-            break;
-    };
-});
-
-// activate first tab on each dashlet
-$('.dash .nav').each(function(index, value) {
-    $($(value).find('li')[0]).find('a').click();
-});
diff --git a/opendaylight/adsal/web/topology/src/test/java/org/opendaylight/controller/topology/web/TopologyTest.java b/opendaylight/adsal/web/topology/src/test/java/org/opendaylight/controller/topology/web/TopologyTest.java
deleted file mode 100644 (file)
index b956a4e..0000000
+++ /dev/null
@@ -1,46 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.topology.web;
-
-import static org.junit.Assert.assertEquals;
-import static org.junit.Assert.assertNotNull;
-
-import org.junit.Test;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.utils.NodeCreator;
-import org.opendaylight.controller.topology.web.Topology.NodeBean;
-
-public class TopologyTest {
-
-        @Test
-        public void testCreateNodeBean() {
-                Topology topology = new Topology();
-                Node node = NodeCreator.createOFNode(new Long(3));
-                String description = "foo";
-
-                NodeBean bean = topology.createNodeBean(description, node);
-
-                assertNotNull(bean);
-                assertEquals(bean.id, node.toString());
-                assertEquals(bean.name, "foo");
-
-                bean = topology.createNodeBean(null, node);
-
-                assertNotNull(bean);
-                assertEquals(bean.id, node.toString());
-                assertEquals(bean.name, bean.id);
-
-                bean = topology.createNodeBean("   ", node);
-
-                assertNotNull(bean);
-                assertEquals(bean.id, node.toString());
-                assertEquals(bean.name, bean.id);
-        }
-
-}
diff --git a/opendaylight/adsal/web/troubleshoot/pom.xml b/opendaylight/adsal/web/troubleshoot/pom.xml
deleted file mode 100644 (file)
index 2ee231d..0000000
+++ /dev/null
@@ -1,118 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <parent>
-    <groupId>org.opendaylight.controller</groupId>
-    <artifactId>commons.opendaylight</artifactId>
-    <version>1.6.0-SNAPSHOT</version>
-    <relativePath>../../../commons/opendaylight</relativePath>
-  </parent>
-
-  <artifactId>troubleshoot.web</artifactId>
-  <version>0.6.0-SNAPSHOT</version>
-  <packaging>bundle</packaging>
-  <dependencies>
-    <dependency>
-      <groupId>com.fasterxml.jackson.core</groupId>
-      <artifactId>jackson-databind</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>containermanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>forwardingrulesmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>sal</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>statisticsmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>switchmanager</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>org.opendaylight.controller</groupId>
-      <artifactId>web</artifactId>
-    </dependency>
-  </dependencies>
-  <build>
-    <plugins>
-      <plugin>
-        <groupId>org.apache.felix</groupId>
-        <artifactId>maven-bundle-plugin</artifactId>
-        <extensions>true</extensions>
-        <configuration>
-          <instructions>
-            <Export-Package></Export-Package>
-            <Import-Package>org.opendaylight.controller.forwardingrulesmanager,
-              org.opendaylight.controller.sal.authorization,
-              org.opendaylight.controller.sal.action,
-              org.opendaylight.controller.sal.core,
-              org.opendaylight.controller.sal.utils,
-              org.opendaylight.controller.containermanager,
-              org.opendaylight.controller.switchmanager,
-              org.opendaylight.controller.statisticsmanager,
-              org.opendaylight.controller.sal.flowprogrammer,
-              org.opendaylight.controller.sal.match,
-              org.opendaylight.controller.sal.reader,
-              org.opendaylight.controller.web,
-              com.google.gson,
-              javax.annotation,
-              javax.naming,
-              javax.servlet,
-              javax.servlet.annotation,
-              javax.servlet.http,
-              javax.servlet.jsp,
-              javax.servlet.jsp.el,
-              javax.servlet.jsp.jstl.core,
-              javax.servlet.jsp.jstl.fmt,
-              javax.servlet.jsp.jstl.tlv,
-              javax.servlet.jsp.tagext,
-              javax.servlet.resources,
-              javax.xml.parsers,
-              javax.xml.transform,
-              org.apache.commons.logging,
-              org.apache.taglibs.standard.functions,
-              org.apache.taglibs.standard.resources,
-              org.apache.taglibs.standard.tag.common.core,
-              org.apache.taglibs.standard.tag.common.fmt,
-              org.apache.taglibs.standard.tag.rt.core,
-              org.apache.taglibs.standard.tag.rt.fmt,
-              org.apache.taglibs.standard.tei,
-              org.apache.taglibs.standard.tlv,
-              com.fasterxml.jackson.core,
-              com.fasterxml.jackson.databind,
-              com.fasterxml.jackson.annotation,
-              org.osgi.framework,
-              org.slf4j,
-              org.springframework.beans,
-              org.springframework.beans.factory.xml,
-              org.springframework.context.config,
-              org.springframework.stereotype,
-              org.springframework.web,
-              org.springframework.web.bind.annotation,
-              org.springframework.web.servlet,
-              org.springframework.web.servlet.config,
-              org.springframework.web.servlet.view,
-              org.springframework.web.filter,
-              org.springframework.web.context</Import-Package>
-            <Web-ContextPath>/controller/web/troubleshoot</Web-ContextPath>
-          </instructions>
-          <manifestLocation>${project.basedir}/src/main/resources/META-INF</manifestLocation>
-        </configuration>
-      </plugin>
-    </plugins>
-  </build>
-  <scm>
-    <connection>scm:git:ssh://git.opendaylight.org:29418/controller.git</connection>
-    <developerConnection>scm:git:ssh://git.opendaylight.org:29418/controller.git</developerConnection>
-    <tag>HEAD</tag>
-    <url>https://wiki.opendaylight.org/view/OpenDaylight_Controller:Main</url>
-  </scm>
-</project>
diff --git a/opendaylight/adsal/web/troubleshoot/src/main/java/org/opendaylight/controller/troubleshoot/web/Troubleshoot.java b/opendaylight/adsal/web/troubleshoot/src/main/java/org/opendaylight/controller/troubleshoot/web/Troubleshoot.java
deleted file mode 100644 (file)
index 04fbf84..0000000
+++ /dev/null
@@ -1,459 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.troubleshoot.web;
-
-import java.net.InetAddress;
-import java.util.ArrayList;
-import java.util.Arrays;
-import java.util.Date;
-import java.util.HashMap;
-import java.util.List;
-import java.util.Map;
-import java.util.Set;
-
-import javax.servlet.http.HttpServletRequest;
-
-import org.opendaylight.controller.sal.action.Action;
-import org.opendaylight.controller.sal.action.Output;
-import org.opendaylight.controller.sal.action.SetDlDst;
-import org.opendaylight.controller.sal.action.SetDlSrc;
-import org.opendaylight.controller.sal.action.SetNwDst;
-import org.opendaylight.controller.sal.action.SetNwSrc;
-import org.opendaylight.controller.sal.action.SetNwTos;
-import org.opendaylight.controller.sal.action.SetTpDst;
-import org.opendaylight.controller.sal.action.SetTpSrc;
-import org.opendaylight.controller.sal.action.SetVlanId;
-import org.opendaylight.controller.sal.action.SetVlanPcp;
-import org.opendaylight.controller.sal.authorization.Privilege;
-import org.opendaylight.controller.sal.authorization.UserLevel;
-import org.opendaylight.controller.sal.core.Description;
-import org.opendaylight.controller.sal.core.Node;
-import org.opendaylight.controller.sal.core.NodeConnector;
-import org.opendaylight.controller.sal.core.TimeStamp;
-import org.opendaylight.controller.sal.flowprogrammer.Flow;
-import org.opendaylight.controller.sal.match.Match;
-import org.opendaylight.controller.sal.match.MatchType;
-import org.opendaylight.controller.sal.reader.FlowOnNode;
-import org.opendaylight.controller.sal.reader.NodeConnectorStatistics;
-import org.opendaylight.controller.sal.reader.NodeDescription;
-import org.opendaylight.controller.sal.utils.EtherTypes;
-import org.opendaylight.controller.sal.utils.GlobalConstants;
-import org.opendaylight.controller.sal.utils.HexEncode;
-import org.opendaylight.controller.sal.utils.IPProtocols;
-import org.opendaylight.controller.sal.utils.NetUtils;
-import org.opendaylight.controller.sal.utils.ServiceHelper;
-import org.opendaylight.controller.statisticsmanager.IStatisticsManager;
-import org.opendaylight.controller.switchmanager.ISwitchManager;
-import org.opendaylight.controller.web.DaylightWebUtil;
-import org.opendaylight.controller.web.IDaylightWeb;
-import org.springframework.stereotype.Controller;
-import org.springframework.web.bind.annotation.RequestMapping;
-import org.springframework.web.bind.annotation.RequestMethod;
-import org.springframework.web.bind.annotation.RequestParam;
-import org.springframework.web.bind.annotation.ResponseBody;
-
-@Controller
-@RequestMapping("/")
-public class Troubleshoot implements IDaylightWeb {
-    private static final UserLevel AUTH_LEVEL = UserLevel.CONTAINERUSER;
-    private static final List<String> flowStatsColumnNames = Arrays.asList("Node", "In Port",
-            "DL Src", "DL Dst", "DL Type", "DL Vlan","Vlan Priority", "NW Src", "NW Dst","ToS Bits",
-            "NW Proto", "TP Src", "TP Dst", "Actions", "Bytes", "Packets",
-            "Time (s)", "Timeout (s)",
-            "Priority");
-    private static final List<String> portStatsColumnNames = Arrays.asList("Node Connector",
-            "Rx Pkts", "Tx Pkts", "Rx Bytes", "Tx Bytes", "Rx Drops",
-            "Tx Drops", "Rx Errs", "Tx Errs", "Rx Frame Errs",
-            "Rx OverRun Errs", "Rx CRC Errs", "Collisions");
-    private static final List<String> nodesColumnNames = Arrays.asList("Node", "Node ID", "Statistics");
-    private static final List<String> nodeStatsColumnNames = Arrays.asList("Node", "Node ID", "Statistics");
-    private final String WEB_NAME = "Troubleshoot";
-    private final String WEB_ID = "troubleshoot";
-    private final short WEB_ORDER = 4;
-
-
-    public Troubleshoot() {
-        ServiceHelper.registerGlobalService(IDaylightWeb.class, this, null);
-    }
-
-    @Override
-    public String getWebName() {
-        return WEB_NAME;
-    }
-
-    @Override
-    public String getWebId() {
-        return WEB_ID;
-    }
-
-    @Override
-    public short getWebOrder() {
-        return WEB_ORDER;
-    }
-
-    @Override
-    public boolean isAuthorized(UserLevel userLevel) {
-        return userLevel.ordinal() <= AUTH_LEVEL.ordinal();
-    }
-
-    @RequestMapping(value = "/nodeInfo", method = RequestMethod.GET)
-    @ResponseBody
-    public NodeDescription getNodeInfo(HttpServletRequest request, @RequestParam(required = false) String container,
-            @RequestParam(required = true) String nodeId) {
-        List<Map<String, String>> lines = new ArrayList<Map<String, String>>();
-        String containerName = (container == null) ? GlobalConstants.DEFAULT.toString() : container;
-
-        // Derive the privilege this user has on the current container
-        String userName = request.getUserPrincipal().getName();
-        Privilege privilege = DaylightWebUtil.getContainerPrivilege(userName, containerName, this);
-
-        if (privilege != Privilege.NONE) {
-            IStatisticsManager statisticsManager = (IStatisticsManager) ServiceHelper
-                    .getInstance(IStatisticsManager.class, containerName, this);
-            if(statisticsManager != null){
-                Node node = Node.fromString(nodeId);
-                NodeDescription nodeDesc = statisticsManager.getNodeDescription(node);
-                return nodeDesc;
-            }
-        }
-
-        return new NodeDescription();
-    }
-
-    @RequestMapping(value = "/existingNodes", method = RequestMethod.GET)
-    @ResponseBody
-    public TroubleshootingJsonBean getExistingNodes(HttpServletRequest request, @RequestParam(required = false) String container) {
-        List<Map<String, String>> lines = new ArrayList<Map<String, String>>();
-        String containerName = (container == null) ? GlobalConstants.DEFAULT.toString() : container;
-
-        // Derive the privilege this user has on the current container
-        String userName = request.getUserPrincipal().getName();
-        Privilege privilege = DaylightWebUtil.getContainerPrivilege(userName, containerName, this);
-
-        if (privilege != Privilege.NONE) {
-            ISwitchManager switchManager = (ISwitchManager) ServiceHelper
-                    .getInstance(ISwitchManager.class, containerName, this);
-            Set<Node> nodeSet = (switchManager != null) ? switchManager.getNodes() : null;
-            if (nodeSet != null) {
-                for (Node node : nodeSet) {
-                    Map<String, String> device = new HashMap<String, String>();
-                    device.put("nodeName", getNodeDesc(node, switchManager));
-                    device.put("nodeId", node.toString());
-                    lines.add(device);
-                }
-            }
-        }
-
-        TroubleshootingJsonBean result = new TroubleshootingJsonBean();
-        result.setColumnNames(nodesColumnNames);
-        result.setNodeData(lines);
-        return result;
-    }
-
-    @RequestMapping(value = "/uptime", method = RequestMethod.GET)
-    @ResponseBody
-    public TroubleshootingJsonBean getUptime(HttpServletRequest request, @RequestParam(required = false) String container) {
-        List<Map<String, String>> lines = new ArrayList<Map<String, String>>();
-        String containerName = (container == null) ? GlobalConstants.DEFAULT.toString() : container;
-
-        // Derive the privilege this user has on the current container
-        String userName = request.getUserPrincipal().getName();
-        Privilege privilege = DaylightWebUtil.getContainerPrivilege(userName, containerName, this);
-
-        if (privilege != Privilege.NONE) {
-            ISwitchManager switchManager = (ISwitchManager) ServiceHelper
-                    .getInstance(ISwitchManager.class, containerName, this);
-            Set<Node> nodeSet = (switchManager != null) ? switchManager.getNodes() : null;
-            if (nodeSet != null) {
-                for (Node node : nodeSet) {
-                    Map<String, String> device = new HashMap<String, String>();
-                    device.put("nodeName", getNodeDesc(node, switchManager));
-                    device.put("nodeId", node.toString());
-                    TimeStamp timeStamp = (TimeStamp) switchManager.getNodeProp(
-                            node, TimeStamp.TimeStampPropName);
-                    Long time = (timeStamp == null) ? 0 : timeStamp.getValue();
-                    String date = (time == 0) ? "" : (new Date(time)).toString();
-                    device.put("connectedSince", date);
-                    lines.add(device);
-                }
-            }
-        }
-
-        TroubleshootingJsonBean result = new TroubleshootingJsonBean();
-        result.setColumnNames(nodeStatsColumnNames);
-        result.setNodeData(lines);
-        return result;
-    }
-
-    @RequestMapping(value = "/flowStats", method = RequestMethod.GET)
-    @ResponseBody
-    public TroubleshootingJsonBean getFlowStats(
-            @RequestParam("nodeId") String nodeId,
-            HttpServletRequest request, @RequestParam(required = false) String container) {
-        List<Map<String, String>> cells = new ArrayList<Map<String, String>>();
-        String containerName = (container == null) ? GlobalConstants.DEFAULT.toString() : container;
-
-        // Derive the privilege this user has on the current container
-        String userName = request.getUserPrincipal().getName();
-        Privilege privilege = DaylightWebUtil.getContainerPrivilege(userName, containerName, this);
-
-        if (privilege != Privilege.NONE) {
-            IStatisticsManager statisticsManager = (IStatisticsManager) ServiceHelper
-                    .getInstance(IStatisticsManager.class, containerName, this);
-            if (statisticsManager != null) {
-                Node node = Node.fromString(nodeId);
-                List<FlowOnNode> statistics = statisticsManager.getFlows(node);
-                for (FlowOnNode stats : statistics) {
-                    cells.add(this.convertFlowStatistics(node, stats, containerName));
-                }
-            }
-        }
-
-        TroubleshootingJsonBean result = new TroubleshootingJsonBean();
-        result.setColumnNames(flowStatsColumnNames);
-        result.setNodeData(cells);
-        return result;
-    }
-
-    @RequestMapping(value = "/portStats", method = RequestMethod.GET)
-    @ResponseBody
-    public TroubleshootingJsonBean getPortStats(
-            @RequestParam("nodeId") String nodeId,
-            HttpServletRequest request, @RequestParam(required = false) String container) {
-        List<Map<String, String>> cells = new ArrayList<Map<String, String>>();
-        String containerName = (container == null) ? GlobalConstants.DEFAULT.toString() : container;
-
-        // Derive the privilege this user has on the current container
-        String userName = request.getUserPrincipal().getName();
-        Privilege privilege = DaylightWebUtil.getContainerPrivilege(userName, containerName, this);
-
-        if (privilege != Privilege.NONE) {
-            IStatisticsManager statisticsManager = (IStatisticsManager) ServiceHelper
-                    .getInstance(IStatisticsManager.class, containerName, this);
-            if (statisticsManager != null) {
-                Node node = Node.fromString(nodeId);
-                List<NodeConnectorStatistics> statistics = statisticsManager
-                        .getNodeConnectorStatistics(node);
-                for (NodeConnectorStatistics stats : statistics) {
-                    cells.add(this.convertPortsStatistics(stats, containerName));
-                }
-            }
-        }
-
-        TroubleshootingJsonBean result = new TroubleshootingJsonBean();
-        result.setColumnNames(portStatsColumnNames);
-        result.setNodeData(cells);
-        return result;
-    }
-
-    private Map<String, String> convertPortsStatistics(
-            NodeConnectorStatistics ncStats, String containerName) {
-
-        Map<String, String> row = new HashMap<String, String>();
-
-        ISwitchManager switchManager = (ISwitchManager) ServiceHelper
-                .getInstance(ISwitchManager.class, containerName, this);
-        NodeConnector nodeConnector = ncStats.getNodeConnector();
-        Description description = (Description) switchManager.getNodeProp(nodeConnector.getNode(), Description.propertyName);
-        String desc = (description == null) ? "" : description.getValue();
-        String nodeName = desc.equalsIgnoreCase("none") ? nodeConnector.getNode().getNodeIDString() : desc;
-        String nodeConnectorDisplayName = nodeConnector.getType() + "|" + nodeConnector.getID() + "@" + nodeName;
-        row.put("nodeConnector",
-                String.valueOf(nodeConnectorDisplayName));
-
-        row.put("rxPkts", String.valueOf(ncStats.getReceivePacketCount()));
-        row.put("txPkts", String.valueOf(ncStats.getTransmitPacketCount()));
-        row.put("rxBytes", String.valueOf(ncStats.getReceiveByteCount()));
-        row.put("txBytes", String.valueOf(ncStats.getTransmitByteCount()));
-        row.put("rxDrops", String.valueOf(ncStats.getReceiveDropCount()));
-        row.put("txDrops", String.valueOf(ncStats.getTransmitDropCount()));
-        row.put("rxErrors", String.valueOf(ncStats.getReceiveErrorCount()));
-        row.put("txErrors", String.valueOf(ncStats.getTransmitErrorCount()));
-        row.put("rxFrameErrors",
-                String.valueOf(ncStats.getReceiveFrameErrorCount()));
-        row.put("rxOverRunErrors",
-                String.valueOf(ncStats.getReceiveOverRunErrorCount()));
-        row.put("rxCRCErrors",
-                String.valueOf(ncStats.getReceiveCRCErrorCount()));
-        row.put("collisions", String.valueOf(ncStats.getCollisionCount()));
-
-        return row;
-    }
-
-    private Map<String, String> convertFlowStatistics(Node node,
-            FlowOnNode flowOnNode,
-            String containerName) {
-        Map<String, String> row = new HashMap<String, String>();
-        Flow flow = flowOnNode.getFlow();
-        Match match = flow.getMatch();
-        ISwitchManager switchManager = (ISwitchManager) ServiceHelper
-                .getInstance(ISwitchManager.class, containerName, this);
-        String desc = getNodeDesc(node, switchManager);
-        desc = (desc == null || desc.isEmpty() || desc.equalsIgnoreCase("none"))?
-                        node.toString() : desc;
-        row.put("nodeName", desc);
-        if (match.isPresent(MatchType.IN_PORT)) {
-            row.put(MatchType.IN_PORT.id(), ((NodeConnector) flow.getMatch()
-                    .getField(MatchType.IN_PORT).getValue())
-                    .getNodeConnectorIdAsString());
-        } else {
-            row.put(MatchType.IN_PORT.id(), "*");
-        }
-        if (match.isPresent(MatchType.DL_SRC)) {
-            row.put(MatchType.DL_SRC.id(),
-                    (HexEncode.bytesToHexString(((byte[]) flow.getMatch()
-                            .getField(MatchType.DL_SRC).getValue()))));
-        } else {
-            row.put(MatchType.DL_SRC.id(), "*");
-        }
-        if (match.isPresent(MatchType.DL_DST)) {
-            row.put(MatchType.DL_DST.id(),
-                    (HexEncode.bytesToHexString(((byte[]) flow.getMatch()
-                            .getField(MatchType.DL_DST).getValue()))));
-        } else {
-            row.put(MatchType.DL_DST.id(), "*");
-        }
-        if (match.isPresent(MatchType.DL_TYPE)) {
-            row.put(MatchType.DL_TYPE.id(),
-                    EtherTypes.getEtherTypeName(((Short) flow.getMatch()
-                            .getField(MatchType.DL_TYPE).getValue())));
-        } else {
-            row.put(MatchType.DL_TYPE.id(), "*");
-        }
-
-        // Some physical switch has vlan as ffff to show "any" vlan
-        if (match.isPresent(MatchType.DL_VLAN)) {
-            if (((Short) flow.getMatch().getField(MatchType.DL_VLAN).getValue())
-                    .shortValue() < 0) {
-                row.put(MatchType.DL_VLAN.id(), "0");
-            } else {
-                row.put(MatchType.DL_VLAN.id(), ((Short) flow.getMatch()
-                        .getField(MatchType.DL_VLAN).getValue()).toString());
-            }
-        } else {
-            row.put(MatchType.DL_VLAN.id(), "*");
-        }
-        //Vlan Priority
-        if (match.isPresent(MatchType.DL_VLAN_PR)) {
-            if (((Byte) flow.getMatch().getField(MatchType.DL_VLAN_PR).getValue())
-                    .shortValue() < 0) {
-                row.put(MatchType.DL_VLAN_PR.id(), "0");
-            } else {
-                row.put(MatchType.DL_VLAN_PR.id(), ((Byte) flow.getMatch()
-                        .getField(MatchType.DL_VLAN_PR).getValue()).toString());
-            }
-        } else {
-            row.put(MatchType.DL_VLAN_PR.id(), "*");
-        }
-
-        if (match.isPresent(MatchType.NW_SRC)) {
-            row.put(MatchType.NW_SRC.id(), ((InetAddress) flow.getMatch()
-                    .getField(MatchType.NW_SRC).getValue()).getHostAddress());
-        } else {
-            row.put(MatchType.NW_SRC.id(), "*");
-        }
-        if (match.isPresent(MatchType.NW_DST)) {
-            row.put(MatchType.NW_DST.id(), ((InetAddress) flow.getMatch()
-                    .getField(MatchType.NW_DST).getValue()).getHostAddress());
-        } else {
-            row.put(MatchType.NW_DST.id(), "*");
-        }
-        if (match.isPresent(MatchType.NW_TOS)) {
-            row.put(MatchType.NW_TOS.id(), ((Byte) flow.getMatch()
-                        .getField(MatchType.NW_TOS).getValue()).toString());
-        } else {
-            row.put(MatchType.NW_TOS.id(), "*");
-        }
-        if (match.isPresent(MatchType.NW_PROTO)) {
-            row.put(MatchType.NW_PROTO.id(),
-                    IPProtocols.getProtocolName(((Byte) flow.getMatch()
-                            .getField(MatchType.NW_PROTO).getValue())));
-        } else {
-            row.put(MatchType.NW_PROTO.id(), "*");
-        }
-        if (match.isPresent(MatchType.TP_SRC)) {
-            Short tpSrc = (Short) (flow.getMatch().getField(MatchType.TP_SRC)
-                    .getValue());
-            row.put(MatchType.TP_SRC.id(),
-                        String.valueOf(NetUtils.getUnsignedShort(tpSrc)));
-        } else {
-            row.put(MatchType.TP_SRC.id(), "*");
-        }
-        if (match.isPresent(MatchType.TP_DST)) {
-            Short tpDst = (Short) (flow.getMatch().getField(MatchType.TP_DST)
-                    .getValue());
-            row.put(MatchType.TP_DST.id(),
-                        String.valueOf(NetUtils.getUnsignedShort(tpDst)));
-        } else {
-            row.put(MatchType.TP_DST.id(), "*");
-        }
-
-        row.put("byteCount", ((Long) flowOnNode.getByteCount()).toString());
-        row.put("packetCount", ((Long) flowOnNode.getPacketCount()).toString());
-
-        StringBuffer actions = new StringBuffer();
-        StringBuffer outPorts = new StringBuffer();
-        for (Action action : flow.getActions()) {
-
-            if (action instanceof Output) {
-                Output ao = (Output) action;
-                if (outPorts.length() > 0) {
-                    outPorts.append(" ");
-                }
-                actions.append(action.getType().toString()).append(" = ").append(ao.getPort().getNodeConnectorIdAsString()).append("<br>");
-            } else if (action instanceof SetVlanId) {
-                SetVlanId av = (SetVlanId) action;
-                String outVlanId = String.valueOf(av.getVlanId());
-                actions.append(action.getType().toString()).append(" = ").append(outVlanId).append("<br>");
-            } else if (action instanceof SetDlSrc) {
-                SetDlSrc ads = (SetDlSrc) action;
-                actions.append(action.getType().toString()).append(" = ").append(HexEncode.bytesToHexStringFormat(ads.getDlAddress())).append("<br>");
-            } else if (action instanceof SetDlDst) {
-                SetDlDst add = (SetDlDst) action;
-                actions.append(action.getType().toString()).append(" = ").append(HexEncode.bytesToHexStringFormat(add.getDlAddress())).append("<br>");
-            } else if (action instanceof SetNwSrc) {
-                SetNwSrc ans = (SetNwSrc) action;
-                actions.append(action.getType().toString()).append(" = ").append(ans.getAddressAsString()).append("<br>");
-            } else if (action instanceof SetNwDst) {
-                SetNwDst and = (SetNwDst) action;
-                actions.append(action.getType().toString()).append(" = ").append(and.getAddressAsString()).append("<br>");
-            } else if (action instanceof SetNwTos) {
-                SetNwTos ant = (SetNwTos) action;
-                actions.append(action.getType().toString()).append(" = ").append(ant.getNwTos()).append("<br>");
-            } else if (action instanceof SetTpSrc) {
-                SetTpSrc ads = (SetTpSrc) action;
-                actions.append(action.getType().toString()).append(" = ").append(ads.getPort()).append("<br>");
-            } else if (action instanceof SetTpDst) {
-                SetTpDst atd = (SetTpDst) action;
-                actions.append(action.getType().toString()).append(" = ").append(atd.getPort()).append("<br>");
-            } else if (action instanceof SetVlanPcp) {
-                SetVlanPcp avp = (SetVlanPcp) action;
-                actions.append(action.getType().toString()).append(" = ").append(avp.getPcp()).append("<br>");
-                // } else if (action instanceof SetDlSrc) {
-                // SetDlSrc ads = (SetDlSrc) action;
-            } else {
-                actions.append(action.getType().toString()).append("<br>");
-            }
-        }
-        row.put("actions", actions.toString());
-        row.put("durationSeconds",
-                ((Integer) flowOnNode.getDurationSeconds()).toString());
-        row.put("idleTimeout", ((Short) flow.getIdleTimeout()).toString());
-        row.put("priority", String.valueOf(NetUtils.getUnsignedShort(flow.getPriority())));
-        return row;
-    }
-
-    private String getNodeDesc(Node node, ISwitchManager switchManager) {
-        if (switchManager == null) {
-            return null;
-        }
-        Description desc = (Description) switchManager.getNodeProp(node, Description.propertyName);
-        return (desc == null) ? "" : desc.getValue();
-    }
-}
diff --git a/opendaylight/adsal/web/troubleshoot/src/main/java/org/opendaylight/controller/troubleshoot/web/TroubleshootingJsonBean.java b/opendaylight/adsal/web/troubleshoot/src/main/java/org/opendaylight/controller/troubleshoot/web/TroubleshootingJsonBean.java
deleted file mode 100644 (file)
index 3c9a8b0..0000000
+++ /dev/null
@@ -1,34 +0,0 @@
-
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.troubleshoot.web;
-
-import java.util.List;
-import java.util.Map;
-
-public class TroubleshootingJsonBean {
-    private List<String> columnNames;
-    private List<Map<String, String>> nodeData;
-
-    public List<String> getColumnNames() {
-        return columnNames;
-    }
-
-    public void setColumnNames(List<String> columnNames) {
-        this.columnNames = columnNames;
-    }
-
-    public List<Map<String, String>> getNodeData() {
-        return nodeData;
-    }
-
-    public void setNodeData(List<Map<String, String>> nodeData) {
-        this.nodeData = nodeData;
-    }
-}
diff --git a/opendaylight/adsal/web/troubleshoot/src/main/resources/META-INF/spring.factories b/opendaylight/adsal/web/troubleshoot/src/main/resources/META-INF/spring.factories
deleted file mode 100644 (file)
index 93db02e..0000000
+++ /dev/null
@@ -1 +0,0 @@
-org.springframework.beans.BeanInfoFactory=org.springframework.beans.ExtendedBeanInfoFactory
diff --git a/opendaylight/adsal/web/troubleshoot/src/main/resources/META-INF/spring.handlers b/opendaylight/adsal/web/troubleshoot/src/main/resources/META-INF/spring.handlers
deleted file mode 100644 (file)
index 957af91..0000000
+++ /dev/null
@@ -1,10 +0,0 @@
-http\://www.springframework.org/schema/context=org.springframework.context.config.ContextNamespaceHandler
-http\://www.springframework.org/schema/jee=org.springframework.ejb.config.JeeNamespaceHandler
-http\://www.springframework.org/schema/lang=org.springframework.scripting.config.LangNamespaceHandler
-http\://www.springframework.org/schema/task=org.springframework.scheduling.config.TaskNamespaceHandler
-http\://www.springframework.org/schema/cache=org.springframework.cache.config.CacheNamespaceHandler
-http\://www.springframework.org/schema/c=org.springframework.beans.factory.xml.SimpleConstructorNamespaceHandler
-http\://www.springframework.org/schema/p=org.springframework.beans.factory.xml.SimplePropertyNamespaceHandler
-http\://www.springframework.org/schema/util=org.springframework.beans.factory.xml.UtilNamespaceHandler
-http\://www.springframework.org/schema/mvc=org.springframework.web.servlet.config.MvcNamespaceHandler
-http\://www.springframework.org/schema/security=org.springframework.security.config.SecurityNamespaceHandler
diff --git a/opendaylight/adsal/web/troubleshoot/src/main/resources/META-INF/spring.schemas b/opendaylight/adsal/web/troubleshoot/src/main/resources/META-INF/spring.schemas
deleted file mode 100644 (file)
index d865edc..0000000
+++ /dev/null
@@ -1,49 +0,0 @@
-http\://www.springframework.org/schema/beans/spring-beans-2.0.xsd=org/springframework/beans/factory/xml/spring-beans-2.0.xsd
-http\://www.springframework.org/schema/beans/spring-beans-2.5.xsd=org/springframework/beans/factory/xml/spring-beans-2.5.xsd
-http\://www.springframework.org/schema/beans/spring-beans-3.0.xsd=org/springframework/beans/factory/xml/spring-beans-3.0.xsd
-http\://www.springframework.org/schema/beans/spring-beans-3.1.xsd=org/springframework/beans/factory/xml/spring-beans-3.1.xsd
-http\://www.springframework.org/schema/beans/spring-beans-3.2.xsd=org/springframework/beans/factory/xml/spring-beans-3.2.xsd
-http\://www.springframework.org/schema/beans/spring-beans.xsd=org/springframework/beans/factory/xml/spring-beans-3.2.xsd
-http\://www.springframework.org/schema/tool/spring-tool-2.0.xsd=org/springframework/beans/factory/xml/spring-tool-2.0.xsd
-http\://www.springframework.org/schema/tool/spring-tool-2.5.xsd=org/springframework/beans/factory/xml/spring-tool-2.5.xsd
-http\://www.springframework.org/schema/tool/spring-tool-3.0.xsd=org/springframework/beans/factory/xml/spring-tool-3.0.xsd
-http\://www.springframework.org/schema/tool/spring-tool-3.1.xsd=org/springframework/beans/factory/xml/spring-tool-3.1.xsd
-http\://www.springframework.org/schema/tool/spring-tool-3.2.xsd=org/springframework/beans/factory/xml/spring-tool-3.2.xsd
-http\://www.springframework.org/schema/tool/spring-tool.xsd=org/springframework/beans/factory/xml/spring-tool-3.2.xsd
-http\://www.springframework.org/schema/util/spring-util-2.0.xsd=org/springframework/beans/factory/xml/spring-util-2.0.xsd
-http\://www.springframework.org/schema/util/spring-util-2.5.xsd=org/springframework/beans/factory/xml/spring-util-2.5.xsd
-http\://www.springframework.org/schema/util/spring-util-3.0.xsd=org/springframework/beans/factory/xml/spring-util-3.0.xsd
-http\://www.springframework.org/schema/util/spring-util-3.1.xsd=org/springframework/beans/factory/xml/spring-util-3.1.xsd
-http\://www.springframework.org/schema/util/spring-util-3.2.xsd=org/springframework/beans/factory/xml/spring-util-3.2.xsd
-http\://www.springframework.org/schema/util/spring-util.xsd=org/springframework/beans/factory/xml/spring-util-3.2.xsd
-http\://www.springframework.org/schema/context/spring-context-2.5.xsd=org/springframework/context/config/spring-context-2.5.xsd
-http\://www.springframework.org/schema/context/spring-context-3.0.xsd=org/springframework/context/config/spring-context-3.0.xsd
-http\://www.springframework.org/schema/context/spring-context-3.1.xsd=org/springframework/context/config/spring-context-3.1.xsd
-http\://www.springframework.org/schema/context/spring-context-3.2.xsd=org/springframework/context/config/spring-context-3.2.xsd
-http\://www.springframework.org/schema/context/spring-context.xsd=org/springframework/context/config/spring-context-3.2.xsd
-http\://www.springframework.org/schema/jee/spring-jee-2.0.xsd=org/springframework/ejb/config/spring-jee-2.0.xsd
-http\://www.springframework.org/schema/jee/spring-jee-2.5.xsd=org/springframework/ejb/config/spring-jee-2.5.xsd
-http\://www.springframework.org/schema/jee/spring-jee-3.0.xsd=org/springframework/ejb/config/spring-jee-3.0.xsd
-http\://www.springframework.org/schema/jee/spring-jee-3.1.xsd=org/springframework/ejb/config/spring-jee-3.1.xsd
-http\://www.springframework.org/schema/jee/spring-jee-3.2.xsd=org/springframework/ejb/config/spring-jee-3.2.xsd
-http\://www.springframework.org/schema/jee/spring-jee.xsd=org/springframework/ejb/config/spring-jee-3.2.xsd
-http\://www.springframework.org/schema/lang/spring-lang-2.0.xsd=org/springframework/scripting/config/spring-lang-2.0.xsd
-http\://www.springframework.org/schema/lang/spring-lang-2.5.xsd=org/springframework/scripting/config/spring-lang-2.5.xsd
-http\://www.springframework.org/schema/lang/spring-lang-3.0.xsd=org/springframework/scripting/config/spring-lang-3.0.xsd
-http\://www.springframework.org/schema/lang/spring-lang-3.1.xsd=org/springframework/scripting/config/spring-lang-3.1.xsd
-http\://www.springframework.org/schema/lang/spring-lang-3.2.xsd=org/springframework/scripting/config/spring-lang-3.2.xsd
-http\://www.springframework.org/schema/lang/spring-lang.xsd=org/springframework/scripting/config/spring-lang-3.2.xsd
-http\://www.springframework.org/schema/task/spring-task-3.0.xsd=org/springframework/scheduling/config/spring-task-3.0.xsd
-http\://www.springframework.org/schema/task/spring-task-3.1.xsd=org/springframework/scheduling/config/spring-task-3.1.xsd
-http\://www.springframework.org/schema/task/spring-task-3.2.xsd=org/springframework/scheduling/config/spring-task-3.2.xsd
-http\://www.springframework.org/schema/task/spring-task.xsd=org/springframework/scheduling/config/spring-task-3.2.xsd
-http\://www.springframework.org/schema/cache/spring-cache-3.1.xsd=org/springframework/cache/config/spring-cache-3.1.xsd
-http\://www.springframework.org/schema/cache/spring-cache-3.2.xsd=org/springframework/cache/config/spring-cache-3.2.xsd
-http\://www.springframework.org/schema/cache/spring-cache.xsd=org/springframework/cache/config/spring-cache-3.2.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd=org/springframework/web/servlet/config/spring-mvc-3.0.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc-3.1.xsd=org/springframework/web/servlet/config/spring-mvc-3.1.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc-3.2.xsd=org/springframework/web/servlet/config/spring-mvc-3.2.xsd
-http\://www.springframework.org/schema/mvc/spring-mvc.xsd=org/springframework/web/servlet/config/spring-mvc-3.2.xsd
-http\://www.springframework.org/schema/security/spring-security-3.1.xsd=org/springframework/security/config/spring-security-3.1.xsd
-http\://www.springframework.org/schema/security/spring-security-3.2.xsd=org/springframework/security/config/spring-security-3.2.xsd
-
diff --git a/opendaylight/adsal/web/troubleshoot/src/main/resources/META-INF/spring.tooling b/opendaylight/adsal/web/troubleshoot/src/main/resources/META-INF/spring.tooling
deleted file mode 100644 (file)
index 057d834..0000000
+++ /dev/null
@@ -1,39 +0,0 @@
-# Tooling related information for the beans namespace
-http\://www.springframework.org/schema/beans@name=beans Namespace
-http\://www.springframework.org/schema/beans@prefix=beans
-http\://www.springframework.org/schema/beans@icon=org/springframework/beans/factory/xml/spring-beans.gif
-
-# Tooling related information for the util namespace
-http\://www.springframework.org/schema/util@name=util Namespace
-http\://www.springframework.org/schema/util@prefix=util
-http\://www.springframework.org/schema/util@icon=org/springframework/beans/factory/xml/spring-util.gif
-
-# Tooling related information for the context namespace
-http\://www.springframework.org/schema/context@name=context Namespace
-http\://www.springframework.org/schema/context@prefix=context
-http\://www.springframework.org/schema/context@icon=org/springframework/context/config/spring-context.gif
-
-# Tooling related information for the jee namespace
-http\://www.springframework.org/schema/jee@name=jee Namespace
-http\://www.springframework.org/schema/jee@prefix=jee
-http\://www.springframework.org/schema/jee@icon=org/springframework/ejb/config/spring-jee.gif
-
-# Tooling related information for the scheduling namespace
-http\://www.springframework.org/schema/task@name=task Namespace
-http\://www.springframework.org/schema/task@prefix=task
-http\://www.springframework.org/schema/task@icon=org/springframework/scheduling/config/spring-task.gif
-
-# Tooling related information for the lang namespace
-http\://www.springframework.org/schema/lang@name=lang Namespace
-http\://www.springframework.org/schema/lang@prefix=lang
-http\://www.springframework.org/schema/lang@icon=org/springframework/scripting/config/spring-lang.gif
-
-# Tooling related information for the cache namespace
-http\://www.springframework.org/schema/cache@name=cache Namespace
-http\://www.springframework.org/schema/cache@prefix=cache
-http\://www.springframework.org/schema/cache@icon=org/springframework/cache/config/spring-cache.gif
-
-# Tooling related information for the mvc namespace
-http\://www.springframework.org/schema/mvc@name=mvc Namespace
-http\://www.springframework.org/schema/mvc@prefix=mvc
-http\://www.springframework.org/schema/mvc@icon=org/springframework/web/servlet/config/spring-mvc.gif
diff --git a/opendaylight/adsal/web/troubleshoot/src/main/resources/WEB-INF/Troubleshoot-servlet.xml b/opendaylight/adsal/web/troubleshoot/src/main/resources/WEB-INF/Troubleshoot-servlet.xml
deleted file mode 100644 (file)
index 91e22f6..0000000
+++ /dev/null
@@ -1,21 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>\r
-<beans xmlns="http://www.springframework.org/schema/beans"\r
-  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"\r
-  xmlns:context="http://www.springframework.org/schema/context"\r
-  xmlns:mvc="http://www.springframework.org/schema/mvc"\r
-  xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd\r
-                      http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd\r
-                      http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd">\r
-\r
-  <context:component-scan base-package="org.opendaylight.controller.troubleshoot.web"/>\r
-\r
-  <mvc:resources mapping="/js/**" location="/js/" />\r
-  <mvc:resources mapping="/css/**" location="/css/" />\r
-  <mvc:resources mapping="/img/**" location="/img/" />\r
-  <mvc:annotation-driven/>\r
-\r
-  <bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">\r
-        <property name="prefix" value="/WEB-INF/jsp/"/>\r
-        <property name="suffix" value=".jsp"/>\r
-  </bean>\r
-</beans>\r
diff --git a/opendaylight/adsal/web/troubleshoot/src/main/resources/WEB-INF/jsp/autherror.jsp b/opendaylight/adsal/web/troubleshoot/src/main/resources/WEB-INF/jsp/autherror.jsp
deleted file mode 100644 (file)
index a2fa428..0000000
+++ /dev/null
@@ -1,55 +0,0 @@
-<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
-<%@ page import="java.net.URL" %>
-<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
-
-<!DOCTYPE html>
-<html>
-  <head>
-    <meta charset="utf-8">
-
-    <!-- Bootstrap CSS - 1 -->
-    <link href="/css/bootstrap.min.css" rel="stylesheet" media="screen">
-    
-    <!-- Login CSS - 2 -->
-    <link rel="stylesheet/less" type="text/css" href="/css/login.less">
-
-<c:set var="title" value="OpenDaylight login error" scope="application"/>
-<%
-    String filePath = "/WEB-INF/jsp/customerror.jsp"; 
-       URL fileURL = pageContext.getServletContext().getResource(filePath);
-       if(fileURL!=null) {
-%>
-         <jsp:include page="<%=filePath%>" flush="true"/>
-<% } %>
-       <title>${title}</title>
-    <!-- Bootstrap JS - 1 -->
-    <script src="/js/bootstrap.min.js"></script>
-    
-    <!-- LESS - 2 -->
-    <script type="text/javascript">
-        less = {
-            env: "production"
-        };
-    </script>
-    <script src="/js/less-1.3.3.min.js"></script>
-</head>
-<body>
-        <form action="<c:url value='/' />" id="form" method="post">
-
-  <div class="container">
-    <div class="content">
-       <div class="login-form">
-         <div id="logo"></div>
-           <fieldset>
-            <p>You are not authorized to access this resource.<p>
-            <p>Please contact your administrator to resolve your Role privileges.</p>
-            <br/>
-             <button class="btn btn-primary" type="submit" value="Log In" >Go To Login Page</button>
-           </fieldset>
-       </div>
-    </div>
-  </div> 
-  </form>
-  <% if (session != null) session.invalidate(); %>
-</body>
-</html>
diff --git a/opendaylight/adsal/web/troubleshoot/src/main/resources/WEB-INF/jsp/error.jsp b/opendaylight/adsal/web/troubleshoot/src/main/resources/WEB-INF/jsp/error.jsp
deleted file mode 100644 (file)
index 270d793..0000000
+++ /dev/null
@@ -1,8 +0,0 @@
-<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
-<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
-<%@taglib prefix="fn" uri="http://java.sun.com/jsp/jstl/functions" %>
-<c:set var="req" value="${pageContext.request}" />
-<c:set var="uri" value="${req.requestURI}" />
-<c:set var="replaceWith" value="/" />
-<c:set var="redirectUrl" value="${fn:replace(req.requestURL, req.contextPath , replaceWith)}" />
-<c:import url="${redirectUrl}" />
\ No newline at end of file
diff --git a/opendaylight/adsal/web/troubleshoot/src/main/resources/WEB-INF/jsp/login.jsp b/opendaylight/adsal/web/troubleshoot/src/main/resources/WEB-INF/jsp/login.jsp
deleted file mode 100644 (file)
index 270d793..0000000
+++ /dev/null
@@ -1,8 +0,0 @@
-<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
-<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
-<%@taglib prefix="fn" uri="http://java.sun.com/jsp/jstl/functions" %>
-<c:set var="req" value="${pageContext.request}" />
-<c:set var="uri" value="${req.requestURI}" />
-<c:set var="replaceWith" value="/" />
-<c:set var="redirectUrl" value="${fn:replace(req.requestURL, req.contextPath , replaceWith)}" />
-<c:import url="${redirectUrl}" />
\ No newline at end of file
diff --git a/opendaylight/adsal/web/troubleshoot/src/main/resources/WEB-INF/web.xml b/opendaylight/adsal/web/troubleshoot/src/main/resources/WEB-INF/web.xml
deleted file mode 100644 (file)
index 2d89e9d..0000000
+++ /dev/null
@@ -1,82 +0,0 @@
-<?xml version="1.0" encoding="ISO-8859-1"?>
-<web-app xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
-        xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
-        version="3.0">
-
-        <servlet>
-                <servlet-name>Troubleshoot</servlet-name>
-                <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
-                <load-on-startup>1</load-on-startup>
-        </servlet>
-
-        <servlet-mapping>
-                <servlet-name>Troubleshoot</servlet-name>
-                <url-pattern>/</url-pattern>
-        </servlet-mapping>
-
-
-
-        <security-constraint>
-                <web-resource-collection>
-                        <web-resource-name>free access</web-resource-name>
-                        <url-pattern>/js/*</url-pattern>
-                        <url-pattern>/images/*</url-pattern>
-                        <url-pattern>/css/*</url-pattern>
-                        <url-pattern>/favicon.ico</url-pattern>
-                </web-resource-collection>
-        </security-constraint>
-
-        <security-constraint>
-                <display-name>TroubleShootApp</display-name>
-                <web-resource-collection>
-                        <web-resource-name>TroubleShootGUI</web-resource-name>
-                        <url-pattern>/*</url-pattern>
-                </web-resource-collection>
-                <auth-constraint>
-                        <role-name>System-Admin</role-name>
-                        <role-name>Network-Admin</role-name>
-                        <role-name>Network-Operator</role-name>
-                        <role-name>Container-User</role-name>
-                </auth-constraint>
-        </security-constraint>
-
-        <security-role>
-                <role-name>System-Admin</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Network-Admin</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Network-Operator</role-name>
-        </security-role>
-        <security-role>
-                <role-name>Container-User</role-name>
-        </security-role>
-
-
-        <login-config>
-                <auth-method>FORM</auth-method>
-                <form-login-config>
-                        <form-login-page>/WEB-INF/jsp/login.jsp</form-login-page>
-                        <form-error-page>/WEB-INF/jsp/error.jsp</form-error-page>
-                </form-login-config>
-        </login-config>
-
-    <error-page>
-            <error-code>403</error-code>
-            <location>/WEB-INF/jsp/autherror.jsp</location>
-    </error-page>
-
-        <listener>
-                <listener-class>org.opendaylight.controller.web.ControllerUISessionManager</listener-class>
-        </listener>
-
-        <session-config>
-                <cookie-config>
-                        <path>/</path>
-                </cookie-config>
-        </session-config>
-
-
-
-</web-app>
diff --git a/opendaylight/adsal/web/troubleshoot/src/main/resources/js/page.js b/opendaylight/adsal/web/troubleshoot/src/main/resources/js/page.js
deleted file mode 100644 (file)
index 09c4666..0000000
+++ /dev/null
@@ -1,631 +0,0 @@
-/*
- * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- *
- */
-
-//PAGE troubleshoot
-one.f = {};
-
-// specify dashlets and layouts
-one.f.dashlet = {
-    existingNodes : {
-        id : 'existingNodes',
-        name : 'Existing Nodes'
-    },
-    uptime: {
-        id: 'uptime',
-        name: 'Uptime'
-    },
-    flowsOrPorts: {
-        id: "flowsOrPorts",
-        name: "Statistics"
-    }
-};
-
-one.f.menu = {
-    left : {
-        top : [
-            one.f.dashlet.existingNodes
-        ],
-        bottom : [
-            one.f.dashlet.uptime
-        ]
-    },
-    right : {
-        top : [],
-        bottom : [
-            one.f.dashlet.flowsOrPorts
-        ]
-    }
-};
-
-/** INIT **/
-// populate nav tabs
-$(one.f.menu.left.top).each(function(index, value) {
-    var $nav = $(".nav", "#left-top");
-    one.main.page.dashlet($nav, value);
-});
-
-$(one.f.menu.left.bottom).each(function(index, value) {
-    var $nav = $(".nav", "#left-bottom");
-    one.main.page.dashlet($nav, value);
-});
-
-$(one.f.menu.right.bottom).each(function(index, value) {
-    var $nav = $(".nav", "#right-bottom");
-    one.main.page.dashlet($nav, value);
-});
-
-/**Troubleshoot modules*/
-one.f.troubleshooting = {
-    rootUrl: "/controller/web/troubleshoot",
-    rightBottomDashlet: {
-        get: function() {
-            var $rightBottomDashlet = $("#right-bottom").find(".dashlet");
-            return $rightBottomDashlet;
-        },
-        setDashletHeader: function(label) {
-            $("#right-bottom li a")[0].innerHTML = label;
-        }
-    },
-    createTable: function(columnNames, body) {
-        var tableAttributes = ["table-striped", "table-bordered", "table-condensed"];
-        var $table = one.lib.dashlet.table.table(tableAttributes);
-        var tableHeaders = columnNames;
-        var $thead = one.lib.dashlet.table.header(tableHeaders);
-        var $tbody = one.lib.dashlet.table.body(body, tableHeaders);
-        $table.append($thead)
-            .append($tbody);
-        return $table;
-    }
-};
-
-one.f.troubleshooting.existingNodes = {
-        id: {
-            popout: "one_f_troubleshooting_existingNodes_id_popout",
-            modal: "one_f_troubleshooting_existingNodes_id_modal",
-            existingNodesDataGrid: "one_f_troubleshooting_existingNodes_id_datagrid",
-            portsDataGrid: "one_f_troubleshooting_existingNodes_id_portsDataGrid",
-            flowsDataGrid: "one_f_troubleshooting_existingNodes_id_flowsDataGrid",
-            refreshFlowsButton:"one_f_troubleshooting_existingNodes_id_refreshFlowsButton",
-            refreshPortsButton:"one_f_troubleshooting_existingNodes_id_refreshPortsButton",
-            modal : {
-                nodeInfo : "one_f_troubleshooting_existingNodes_id_modal_nodeInfo",
-                cancelButton : "one_f_troubleshooting_existingNodes_id_modal_cancelButton",
-            }
-        },
-        load: {
-            main: function($dashlet) {
-                one.lib.dashlet.empty($dashlet);
-                $dashlet.append(one.lib.dashlet.header(one.f.dashlet.existingNodes.name));
-                // TODO(l): Add a generic auto expand function to one.lib and replace custom height setting.
-                //$('#left-top').height('100%');
-                one.f.troubleshooting.existingNodes.ajax(one.f.troubleshooting.rootUrl + "/existingNodes" , function(content) {
-                    var $gridHTML = one.lib.dashlet.datagrid.init(one.f.troubleshooting.existingNodes.id.existingNodesDataGrid, {
-                        searchable: true,
-                        filterable: false,
-                        pagination: true,
-                        flexibleRowsPerPage: true
-                        }, "table-striped table-condensed");
-                    $dashlet.append($gridHTML);
-                    var dataSource = one.f.troubleshooting.existingNodes.data.existingNodesGrid(content);
-                    $("#" + one.f.troubleshooting.existingNodes.id.existingNodesDataGrid).datagrid({dataSource: dataSource});
-
-                });
-            },
-            flows: function(nodeId) {
-                try {
-                    if(one.f.troubleshooting === undefined){
-                        return;
-                    }
-                    $.getJSON(one.main.constants.address.prefix + "/troubleshoot/flowStats?nodeId=" + nodeId, function(content) {
-                        $rightBottomDashlet = one.f.troubleshooting.rightBottomDashlet.get();
-                        one.f.troubleshooting.rightBottomDashlet.setDashletHeader("Flows");
-                        one.lib.dashlet.empty($rightBottomDashlet);
-                        $rightBottomDashlet.append(one.lib.dashlet.header("Flow Details"));
-                        var button = one.lib.dashlet.button.single("Refresh",
-                                one.f.troubleshooting.existingNodes.id.refreshFlowsButton, "btn-primary", "btn-mini");
-                        var $button = one.lib.dashlet.button.button(button);
-                        $button.click(function() {
-                            one.f.troubleshooting.existingNodes.load.flows(nodeId);
-                        });
-                        $rightBottomDashlet.append($button);
-                        var $gridHTML = one.lib.dashlet.datagrid.init(one.f.troubleshooting.existingNodes.id.flowsDataGrid, {
-                            searchable: true,
-                            filterable: false,
-                            pagination: true,
-                            flexibleRowsPerPage: true
-                            }, "table-striped table-condensed");
-                        $rightBottomDashlet.append($gridHTML);
-                        var dataSource = one.f.troubleshooting.existingNodes.data.flowsGrid(content);
-                        $("#" + one.f.troubleshooting.existingNodes.id.flowsDataGrid).datagrid({dataSource: dataSource});
-                    });
-                } catch(e) {}
-            },
-            ports: function(nodeId) {
-                try {
-                    if(one.f.troubleshooting === undefined){
-                        return;
-                    }
-                    $.getJSON(one.main.constants.address.prefix + "/troubleshoot/portStats?nodeId=" + nodeId, function(content) {
-                        $rightBottomDashlet = one.f.troubleshooting.rightBottomDashlet.get();
-                        one.f.troubleshooting.rightBottomDashlet.setDashletHeader("Ports");
-                        one.lib.dashlet.empty($rightBottomDashlet);
-                        $rightBottomDashlet.append(one.lib.dashlet.header("Port Details"));
-                        var button = one.lib.dashlet.button.single("Refresh",
-                                one.f.troubleshooting.existingNodes.id.refreshPortsButton, "btn-primary", "btn-mini");
-                        var $button = one.lib.dashlet.button.button(button);
-                        $button.click(function() {
-                            one.f.troubleshooting.existingNodes.load.ports(nodeId);
-                        });
-                        $rightBottomDashlet.append($button);
-                        var $gridHTML = one.lib.dashlet.datagrid.init(one.f.troubleshooting.existingNodes.id.portsDataGrid, {
-                            searchable: true,
-                            filterable: false,
-                            pagination: true,
-                            flexibleRowsPerPage: true
-                            }, "table-striped table-condensed");
-                        $rightBottomDashlet.append($gridHTML);
-                        var dataSource = one.f.troubleshooting.existingNodes.data.portsGrid(content);
-                        $("#" + one.f.troubleshooting.existingNodes.id.portsDataGrid).datagrid({dataSource: dataSource});
-                    });
-                } catch(e) {}
-            }
-        },
-        ajax : function(url, callback) {
-            $.getJSON(url, function(data) {
-                callback(data);
-            });
-        },
-        registry: {},
-        modal : {
-        },
-        data : {
-            existingNodesGrid: function(data) {
-                var source = new StaticDataSource({
-                    columns: [
-                        {
-                            property: 'nodeName',
-                            label: 'Name',
-                            sortable: true
-                        },
-                        {
-                            property: 'nodeId',
-                            label: 'Node ID',
-                            sortable: true
-                        },
-                        {
-                            property: 'statistics',
-                            label: 'Statistics',
-                            sortable: true
-                        }
-                    ],
-                    data: data.nodeData,
-                    formatter: function(items) {
-                        $.each(items, function(index, item) {
-                            item.nodeName = "<a href=\"javascript:one.f.troubleshooting.existingNodes.data.nodeInfo('"
-                                + item.nodeId + "');\">" + item.nodeName + "</a>"
-                            item["statistics"] = "<a href=\"javascript:one.f.troubleshooting.existingNodes.load.flows('" + item["nodeId"] + "');\">Flows</a>" +
-                            " <a href=\"javascript:one.f.troubleshooting.existingNodes.load.ports('" + item["nodeId"] + "');\">Ports</a>";
-                        });
-                    },
-                    delay: 0
-                });
-                return source;
-            },
-            portsGrid: function(data) {
-                $.each(data.nodeData, function(index, item) {
-                    item.rxPkts = one.lib.helper.parseInt(item.rxPkts);
-                    item.txPkts = one.lib.helper.parseInt(item.txPkts);
-                    item.rxBytes = one.lib.helper.parseInt(item.rxBytes);
-                    item.txBytes = one.lib.helper.parseInt(item.txBytes);
-                    item.rxDrops = one.lib.helper.parseInt(item.rxDrops);
-                    item.txDrops = one.lib.helper.parseInt(item.txDrops);
-                    item.rxErrors = one.lib.helper.parseInt(item.rxErrors);
-                    item.txErrors = one.lib.helper.parseInt(item.txErrors);
-                    item.rxFrameErrors = one.lib.helper.parseInt(item.rxFrameErrors);
-                    item.rxOverRunErrors = one.lib.helper.parseInt(item.rxOverRunErrors);
-                    item.rxCRCErrors = one.lib.helper.parseInt(item.rxCRCErrors);
-                    item.collisions = one.lib.helper.parseInt(item.collisions);
-                });
-                var source = new StaticDataSource({
-                    columns: [
-                        {
-                            property: 'nodeConnector',
-                            label: 'Node Connector',
-                            sortable: true
-                        },
-                        {
-                            property: 'rxPkts',
-                            label: 'Rx Pkts',
-                            sortable: true
-                        },
-                        {
-                            property: 'txPkts',
-                            label: 'Tx Pkts',
-                            sortable: true
-                        },
-                        {
-                            property: 'rxBytes',
-                            label: 'Rx Bytes',
-                            sortable: true
-                        },
-                        {
-                            property: 'txBytes',
-                            label: 'Tx Bytes',
-                            sortable: true
-                        },
-                        {
-                            property: 'rxDrops',
-                            label: 'Rx Drops',
-                            sortable: true
-                        },
-                        {
-                            property: 'txDrops',
-                            label: 'Tx Drops',
-                            sortable: true
-                        },
-                        {
-                            property: 'rxErrors',
-                            label: 'Rx Errs',
-                            sortable: true
-                        },
-                        {
-                            property: 'txErrors',
-                            label: 'Tx Errs',
-                            sortable: true
-                        },
-                        {
-                            property: 'rxFrameErrors',
-                            label: 'Rx Frame Errs',
-                            sortable: true
-                        },
-                        {
-                            property: 'rxOverRunErrors',
-                            label: 'Rx OverRun Errs',
-                            sortable: true
-                        },
-                        {
-                            property: 'rxCRCErrors',
-                            label: 'Rx CRC Errs',
-                            sortable: true
-                        },
-                        {
-                            property: 'collisions',
-                            label: 'Collisions',
-                            sortable: true
-                        }
-                    ],
-                    data: data.nodeData,
-                    delay: 0
-                });
-                return source;
-            },
-            ports: function(data) {
-                var result = [];
-                $.each(data.nodeData, function(key, value) {
-                    var tr = {};
-                    var entry = [];
-                    entry.push(value["nodeConnector"]);
-                    entry.push(value["rxPkts"]);
-                    entry.push(value["txPkts"]);
-                    entry.push(value["rxBytes"]);
-                    entry.push(value["txBytes"]);
-                    entry.push(value["rxDrops"]);
-                    entry.push(value["txDrops"]);
-                    entry.push(value["rxErrors"]);
-                    entry.push(value["txErrors"]);
-                    entry.push(value["rxFrameErrors"]);
-                    entry.push(value["rxOverRunErrors"]);
-                    entry.push(value["rxCRCErrors"]);
-                    entry.push(value["collisions"]);
-                    tr.entry = entry;
-                    result.push(tr);
-                });
-                return result;
-            },
-            flowsGrid: function(data) {
-                $.each(data.nodeData, function(index, item) {
-                    item.byteCount = one.lib.helper.parseInt(item.byteCount);
-                    item.packetCount = one.lib.helper.parseInt(item.packetCount);
-                    item.durationSeconds = one.lib.helper.parseInt(item.durationSeconds);
-                    item.idleTimeout = one.lib.helper.parseInt(item.idleTimeout);
-                    item.priority = one.lib.helper.parseInt(item.priority);
-                });
-                var source = new StaticDataSource({
-                    columns: [
-                        {
-                            property: 'nodeName',
-                            label: 'Node',
-                            sortable: true
-                        },
-                        {
-                            property: 'inPort',
-                            label: 'In Port',
-                            sortable: true
-                        },
-                        {
-                            property: 'dlSrc',
-                            label: 'DL Src',
-                            sortable: true
-                        },
-                        {
-                            property: 'dlDst',
-                            label: 'DL Dst',
-                            sortable: true
-                        },
-                        {
-                            property: 'dlType',
-                            label: 'DL Type',
-                            sortable: true
-                        },
-                        {
-                            property: 'dlVlan',
-                            label: 'DL Vlan',
-                            sortable: true
-                        },
-                        {
-                            property: 'dlVlanPriority',
-                            label: 'Vlan PCP',
-                            sortable: true
-                        },
-                        {
-                            property: 'nwSrc',
-                            label: 'NW Src',
-                            sortable: true
-                        },
-                        {
-                            property: 'nwDst',
-                            label: 'NW Dst',
-                            sortable: true
-                        },
-                        {
-                            property: 'nwTOS',
-                            label: 'ToS Bits',
-                            sortable: true
-                        },
-                        {
-                            property: 'nwProto',
-                            label: 'NW Proto',
-                            sortable: true
-                        },
-                        {
-                            property: 'tpSrc',
-                            label: 'TP Src',
-                            sortable: true
-                        },
-                        {
-                            property: 'tpDst',
-                            label: 'TP Dst',
-                            sortable: true
-                        },
-                        {
-                            property: 'actions',
-                            label: 'Actions',
-                            sortable: true
-                        },
-                        {
-                            property: 'byteCount',
-                            label: 'Byte Count',
-                            sortable: true
-                        },
-                        {
-                            property: 'packetCount',
-                            label: 'Packet Count',
-                            sortable: true
-                        },
-                        {
-                            property: 'durationSeconds',
-                            label: 'Duration Seconds',
-                            sortable: true
-                        },
-                        {
-                            property: 'idleTimeout',
-                            label: 'Idle Timeout',
-                            sortable: true
-                        },
-                        {
-                            property: 'priority',
-                            label: 'Priority',
-                            sortable: true
-                        }
-                    ],
-                    data: data.nodeData,
-                    delay: 0
-                });
-                return source;
-            },
-            flows: function(data) {
-                var result = [];
-                $.each(data.nodeData, function(key, value) {
-                    var tr = {};
-                    var entry = [];
-                    entry.push(value["nodeName"]);
-                    entry.push(value["inPort"]);
-                    entry.push(value["dlSrc"]);
-                    entry.push(value["dlDst"]);
-                    entry.push(value["dlType"]);
-                    entry.push(value["dlVlan"]);
-                    entry.push(value["nwSrc"]);
-                    entry.push(value["nwDst"]);
-                    entry.push(value["nwTOS"]);
-                    entry.push(value["nwProto"]);
-                    entry.push(value["tpSrc"]);
-                    entry.push(value["tpDst"]);
-                    entry.push(value["actions"]);
-                    entry.push(value["byteCount"]);
-                    entry.push(value["packetCount"]);
-                    entry.push(value["durationSeconds"]);
-                    entry.push(value["idleTimeout"]);
-                    entry.push(value["priority"]);
-                    tr.entry = entry;
-                    result.push(tr);
-                });
-                return result;
-            },
-            nodeInfo : function(nodeId){
-                $.getJSON(one.main.constants.address.prefix + "/troubleshoot/nodeInfo?nodeId=" + nodeId, function(content) {
-                    var h3 = 'Node Information'
-
-                    var headers = [ 'Description','Specification'];
-
-                    var attributes = ['table-striped', 'table-bordered', 'table-condensed'];
-                    var $table = one.lib.dashlet.table.table(attributes);
-                    var $thead = one.lib.dashlet.table.header(headers);
-                    $table.append($thead);
-
-                    var footer = [];
-
-                    var cancelButton = one.lib.dashlet.button.single("Cancel",
-                            one.f.troubleshooting.existingNodes.id.modal.nodeInfo, "", "");
-                    var $cancelButton = one.lib.dashlet.button.button(cancelButton);
-                    footer.push($cancelButton);
-
-                    var body = []
-                    $.each(content, function(key, value) {
-                        var tr = {};
-                        var entry = [];
-
-                        entry.push(key);
-                        entry.push(value);
-
-                        tr.entry = entry;
-                        body.push(tr);
-                    });
-                    var $tbody = one.lib.dashlet.table.body(body);
-                    $table.append($tbody);
-
-                    var $modal = one.lib.modal.spawn(one.f.troubleshooting.existingNodes.id.modal.nodeInfo, h3, $table , footer);
-                    $modal.modal();
-
-                    $('#'+one.f.troubleshooting.existingNodes.id.modal.nodeInfo, $modal).click(function() {
-                        $modal.modal('hide');
-                    });
-                });
-            }
-        }
-};
-
-one.f.troubleshooting.uptime = {
-    id: {
-        popout: "one_f_troubleshooting_uptime_id_popout",
-        modal: "one_f_troubleshooting_uptime_id_modal",
-        datagrid: "one_f_troubleshooting_uptime_id_datagrid"
-    },
-
-    dashlet: function($dashlet) {
-            one.lib.dashlet.empty($dashlet);
-            $dashlet.append(one.lib.dashlet.header(one.f.dashlet.uptime.name));
-            var url = one.f.troubleshooting.rootUrl + "/uptime";
-            one.f.troubleshooting.uptime.ajax.main(url , {} ,function(content) {
-                var $gridHTML = one.lib.dashlet.datagrid.init(one.f.troubleshooting.uptime.id.datagrid, {
-                    searchable: true,
-                    filterable: false,
-                    pagination: true,
-                    flexibleRowsPerPage: true
-                    }, "table-striped table-condensed");
-                $dashlet.append($gridHTML);
-                var dataSource = one.f.troubleshooting.uptime.data.uptimeDataGrid(content);
-                $("#" + one.f.troubleshooting.uptime.id.datagrid).datagrid({dataSource: dataSource});
-            });
-    },
-
-    ajax : {
-        main : function(url, requestData, callback) {
-            $.getJSON(url, requestData, function(data) {
-                callback(data);
-            });
-        }
-    },
-
-    data: {
-        uptimeDataGrid: function(data) {
-            var source = new StaticDataSource({
-                columns: [
-                    {
-                        property: 'nodeName',
-                        label: 'Node',
-                        sortable: true
-                    },
-                    {
-                        property: 'nodeId',
-                        label: 'Node ID',
-                        sortable: true
-                    },
-                    {
-                        property: 'connectedSince',
-                        label: 'Statistics',
-                        sortable: true
-                    }
-                ],
-                data: data.nodeData,
-                delay: 0
-            });
-            return source;
-        },
-        uptime: function(data) {
-            var result = [];
-            $.each(data.nodeData, function(key, value) {
-                var tr = {};
-                var entry = [];
-                entry.push(value["nodeName"]);
-                entry.push(value["nodeId"]);
-                entry.push(value["connectedSince"]);
-                tr.entry = entry;
-                result.push(tr);
-            });
-            return result;
-        }
-    },
-};
-
-one.f.troubleshooting.statistics = {
-    dashlet : function($dashlet) {
-        var $h4 = one.lib.dashlet.header("Statistics");
-        $dashlet.append($h4);
-        // empty
-        var $none = $(document.createElement('div'));
-        $none.addClass('none');
-        var $p = $(document.createElement('p'));
-        $p.text('Please select a Flow or Ports statistics');
-        $p.addClass('text-center').addClass('text-info');
-
-        $dashlet.append($none)
-            .append($p);
-    }
-};
-
-// bind dashlet nav
-$('.dash .nav a', '#main').click(function() {
-    // de/activation
-    var $li = $(this).parent();
-    var $ul = $li.parent();
-    one.lib.nav.unfocus($ul);
-    $li.addClass('active');
-    // clear respective dashlet
-    var $dashlet = $ul.parent().find('.dashlet');
-    one.lib.dashlet.empty($dashlet);
-    // callback based on menu
-    var id = $(this).attr('id');
-    var menu = one.f.dashlet;
-    switch (id) {
-        case menu.existingNodes.id:
-            one.f.troubleshooting.existingNodes.load.main($dashlet);
-            break;
-        case menu.uptime.id:
-            one.f.troubleshooting.uptime.dashlet($dashlet);
-            break;
-        case menu.flowsOrPorts.id:
-            one.f.troubleshooting.statistics.dashlet($dashlet);
-            break;
-    };
-});
-
-// activate first tab on each dashlet
-$('.dash .nav').each(function(index, value) {
-    $($(value).find('li')[0]).find('a').click();
-});
diff --git a/pom.xml b/pom.xml
index bde0e73a20eb6b07627ffebc9f46d10b4e070a02..4798184bcfbb3277845e310c8ddf6b51995fe481 100644 (file)
--- a/pom.xml
+++ b/pom.xml
@@ -23,9 +23,6 @@
     <!-- netconf -->
     <module>opendaylight/netconf</module>
 
     <!-- netconf -->
     <module>opendaylight/netconf</module>
 
-    <!-- adsal -->
-    <module>opendaylight/adsal</module>
-
     <!-- Parents -->
     <module>opendaylight/commons/concepts</module>
     <module>opendaylight/commons/protocol-framework</module>
     <!-- Parents -->
     <module>opendaylight/commons/concepts</module>
     <module>opendaylight/commons/protocol-framework</module>