Merge "Remove ovsdb related in resources"
[netvirt.git] / openstack / net-virt / src / main / java / org / opendaylight / netvirt / openstack / netvirt / ConfigActivator.java
1 /*
2  * Copyright (c) 2015, 2016 Red Hat, Inc. and others. All rights reserved.
3  *
4  * This program and the accompanying materials are made available under the
5  * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6  * and is available at http://www.eclipse.org/legal/epl-v10.html
7  */
8
9 package org.opendaylight.netvirt.openstack.netvirt;
10
11 import java.util.ArrayList;
12 import java.util.Dictionary;
13 import java.util.Hashtable;
14 import java.util.List;
15
16 import org.apache.commons.lang3.tuple.Pair;
17 import org.opendaylight.controller.md.sal.binding.api.DataBroker;
18 import org.opendaylight.controller.sal.binding.api.BindingAwareBroker.ProviderContext;
19 import org.opendaylight.netvirt.openstack.netvirt.api.ArpProvider;
20 import org.opendaylight.netvirt.openstack.netvirt.api.BridgeConfigurationManager;
21 import org.opendaylight.netvirt.openstack.netvirt.api.ConfigurationService;
22 import org.opendaylight.netvirt.openstack.netvirt.api.EgressAclProvider;
23 import org.opendaylight.netvirt.openstack.netvirt.api.EventDispatcher;
24 import org.opendaylight.netvirt.openstack.netvirt.api.GatewayMacResolver;
25 import org.opendaylight.netvirt.openstack.netvirt.api.GatewayMacResolverListener;
26 import org.opendaylight.netvirt.openstack.netvirt.api.IcmpEchoProvider;
27 import org.opendaylight.netvirt.openstack.netvirt.api.IngressAclProvider;
28 import org.opendaylight.netvirt.openstack.netvirt.api.L3ForwardingProvider;
29 import org.opendaylight.netvirt.openstack.netvirt.api.LoadBalancerProvider;
30 import org.opendaylight.netvirt.openstack.netvirt.api.MultiTenantAwareRouter;
31 import org.opendaylight.netvirt.openstack.netvirt.api.NetworkingProviderManager;
32 import org.opendaylight.netvirt.openstack.netvirt.api.NodeCacheListener;
33 import org.opendaylight.netvirt.openstack.netvirt.api.NodeCacheManager;
34 import org.opendaylight.netvirt.openstack.netvirt.api.OutboundNatProvider;
35 import org.opendaylight.netvirt.openstack.netvirt.api.OvsdbInventoryListener;
36 import org.opendaylight.netvirt.openstack.netvirt.api.OvsdbInventoryService;
37 import org.opendaylight.netvirt.openstack.netvirt.api.RoutingProvider;
38 import org.opendaylight.netvirt.openstack.netvirt.api.SecurityServicesManager;
39 import org.opendaylight.netvirt.openstack.netvirt.api.TenantNetworkManager;
40 import org.opendaylight.netvirt.openstack.netvirt.api.VlanConfigurationCache;
41 import org.opendaylight.netvirt.openstack.netvirt.impl.BridgeConfigurationManagerImpl;
42 import org.opendaylight.netvirt.openstack.netvirt.impl.ConfigurationServiceImpl;
43 import org.opendaylight.netvirt.openstack.netvirt.impl.DistributedArpService;
44 import org.opendaylight.netvirt.openstack.netvirt.impl.EventDispatcherImpl;
45 import org.opendaylight.netvirt.openstack.netvirt.impl.NodeCacheManagerImpl;
46 import org.opendaylight.netvirt.openstack.netvirt.impl.OpenstackRouter;
47 import org.opendaylight.netvirt.openstack.netvirt.impl.OvsdbInventoryServiceImpl;
48 import org.opendaylight.netvirt.openstack.netvirt.impl.ProviderNetworkManagerImpl;
49 import org.opendaylight.netvirt.openstack.netvirt.impl.SecurityGroupCacheManagerImpl;
50 import org.opendaylight.netvirt.openstack.netvirt.impl.SecurityServicesImpl;
51 import org.opendaylight.netvirt.openstack.netvirt.impl.SouthboundImpl;
52 import org.opendaylight.netvirt.openstack.netvirt.impl.HostConfigService;
53 import org.opendaylight.netvirt.openstack.netvirt.impl.VlanConfigurationCacheImpl;
54 import org.opendaylight.netvirt.openstack.netvirt.translator.crud.INeutronLoadBalancerCRUD;
55 import org.opendaylight.netvirt.openstack.netvirt.translator.crud.INeutronLoadBalancerPoolCRUD;
56 import org.opendaylight.netvirt.openstack.netvirt.translator.crud.INeutronNetworkCRUD;
57 import org.opendaylight.netvirt.openstack.netvirt.translator.crud.INeutronPortCRUD;
58 import org.opendaylight.netvirt.openstack.netvirt.translator.crud.impl.NeutronFirewallInterface;
59 import org.opendaylight.netvirt.openstack.netvirt.translator.crud.impl.NeutronFirewallPolicyInterface;
60 import org.opendaylight.netvirt.openstack.netvirt.translator.crud.impl.NeutronFirewallRuleInterface;
61 import org.opendaylight.netvirt.openstack.netvirt.translator.crud.impl.NeutronFloatingIPInterface;
62 import org.opendaylight.netvirt.openstack.netvirt.translator.crud.impl.NeutronLoadBalancerInterface;
63 import org.opendaylight.netvirt.openstack.netvirt.translator.crud.impl.NeutronLoadBalancerListenerInterface;
64 import org.opendaylight.netvirt.openstack.netvirt.translator.crud.impl.NeutronLoadBalancerPoolInterface;
65 import org.opendaylight.netvirt.openstack.netvirt.translator.crud.impl.NeutronLoadBalancerPoolMemberInterface;
66 import org.opendaylight.netvirt.openstack.netvirt.translator.crud.impl.NeutronNetworkInterface;
67 import org.opendaylight.netvirt.openstack.netvirt.translator.crud.impl.NeutronPortInterface;
68 import org.opendaylight.netvirt.openstack.netvirt.translator.crud.impl.NeutronRouterInterface;
69 import org.opendaylight.netvirt.openstack.netvirt.translator.crud.impl.NeutronSecurityGroupInterface;
70 import org.opendaylight.netvirt.openstack.netvirt.translator.crud.impl.NeutronSecurityRuleInterface;
71 import org.opendaylight.netvirt.openstack.netvirt.translator.crud.impl.NeutronSubnetInterface;
72 import org.opendaylight.netvirt.openstack.netvirt.translator.iaware.INeutronFirewallAware;
73 import org.opendaylight.netvirt.openstack.netvirt.translator.iaware.INeutronFirewallPolicyAware;
74 import org.opendaylight.netvirt.openstack.netvirt.translator.iaware.INeutronLoadBalancerAware;
75 import org.opendaylight.netvirt.openstack.netvirt.translator.iaware.INeutronLoadBalancerPoolAware;
76 import org.opendaylight.netvirt.openstack.netvirt.translator.iaware.INeutronLoadBalancerPoolMemberAware;
77 import org.opendaylight.netvirt.openstack.netvirt.translator.iaware.INeutronNetworkAware;
78 import org.opendaylight.netvirt.openstack.netvirt.translator.iaware.INeutronRouterAware;
79 import org.opendaylight.netvirt.openstack.netvirt.translator.iaware.INeutronSecurityGroupAware;
80 import org.opendaylight.netvirt.openstack.netvirt.translator.iaware.INeutronSecurityRuleAware;
81 import org.opendaylight.netvirt.openstack.netvirt.translator.iaware.INeutronSubnetAware;
82 import org.opendaylight.netvirt.openstack.netvirt.api.Constants;
83 import org.opendaylight.netvirt.openstack.netvirt.api.InboundNatProvider;
84 import org.opendaylight.netvirt.openstack.netvirt.api.SecurityGroupCacheManger;
85 import org.opendaylight.netvirt.openstack.netvirt.api.Southbound;
86 import org.opendaylight.netvirt.openstack.netvirt.impl.NeutronL3Adapter;
87 import org.opendaylight.netvirt.openstack.netvirt.impl.TenantNetworkManagerImpl;
88 import org.opendaylight.netvirt.openstack.netvirt.translator.crud.INeutronFloatingIPCRUD;
89 import org.opendaylight.netvirt.openstack.netvirt.translator.crud.INeutronSubnetCRUD;
90 import org.opendaylight.netvirt.openstack.netvirt.translator.crud.impl.NeutronLoadBalancerHealthMonitorInterface;
91 import org.opendaylight.netvirt.openstack.netvirt.translator.iaware.INeutronFirewallRuleAware;
92 import org.opendaylight.netvirt.openstack.netvirt.translator.iaware.INeutronFloatingIPAware;
93 import org.opendaylight.netvirt.openstack.netvirt.translator.iaware.INeutronPortAware;
94 import org.opendaylight.netvirt.utils.neutron.utils.NeutronModelsDataStoreHelper;
95 import org.osgi.framework.BundleActivator;
96 import org.osgi.framework.BundleContext;
97 import org.osgi.framework.ServiceReference;
98 import org.osgi.framework.ServiceRegistration;
99 import org.osgi.util.tracker.ServiceTracker;
100 import org.slf4j.Logger;
101 import org.slf4j.LoggerFactory;
102
103 public class ConfigActivator implements BundleActivator {
104     private static final Logger LOG = LoggerFactory.getLogger(ConfigActivator.class);
105     private List<ServiceRegistration<?>> translatorCRUDRegistrations = new ArrayList<>();
106     private List<Pair<Object, ServiceRegistration>> servicesAndRegistrations = new ArrayList<>();
107     private ProviderContext providerContext;
108     private boolean conntrackEnabled = false;
109
110     public ConfigActivator(ProviderContext providerContext) {
111         this.providerContext = providerContext;
112     }
113
114     @Override
115     public void start(BundleContext context) throws Exception {
116         LOG.info("ConfigActivator start:");
117         registerCRUDServiceProviders(context, this.providerContext);
118
119         ConfigurationServiceImpl configurationService = new ConfigurationServiceImpl();
120         registerService(context, new String[] {ConfigurationService.class.getName()},
121                 null, configurationService);
122
123         BridgeConfigurationManagerImpl bridgeConfigurationManager = new BridgeConfigurationManagerImpl();
124         registerService(context, new String[] {BridgeConfigurationManager.class.getName()},
125                 null, bridgeConfigurationManager);
126
127         final TenantNetworkManagerImpl tenantNetworkManager = new TenantNetworkManagerImpl();
128         registerService(context, new String[] {TenantNetworkManager.class.getName()},
129                 null, tenantNetworkManager);
130
131         VlanConfigurationCacheImpl vlanConfigurationCache = new VlanConfigurationCacheImpl();
132         registerService(context, new String[] {VlanConfigurationCache.class.getName()},
133                 null, vlanConfigurationCache);
134
135         FloatingIPHandler floatingIPHandler = new FloatingIPHandler();
136         registerAbstractHandlerService(context, new Class[] {INeutronFloatingIPAware.class},
137                 AbstractEvent.HandlerType.NEUTRON_FLOATING_IP, floatingIPHandler);
138
139         final NetworkHandler networkHandler = new NetworkHandler();
140         registerAbstractHandlerService(context, new Class[] {INeutronNetworkAware.class},
141                 AbstractEvent.HandlerType.NEUTRON_NETWORK, networkHandler);
142
143         SubnetHandler subnetHandler = new SubnetHandler();
144         registerAbstractHandlerService(context, new Class[] {INeutronSubnetAware.class},
145                 AbstractEvent.HandlerType.NEUTRON_SUBNET, subnetHandler);
146
147         PortHandler portHandler = new PortHandler();
148         registerAbstractHandlerService(context, new Class[] {INeutronPortAware.class},
149                 AbstractEvent.HandlerType.NEUTRON_PORT, portHandler);
150
151         RouterHandler routerHandler = new RouterHandler();
152         registerAbstractHandlerService(context, new Class[] {INeutronRouterAware.class},
153                 AbstractEvent.HandlerType.NEUTRON_ROUTER, routerHandler);
154
155         SouthboundHandler southboundHandler = new SouthboundHandler();
156         registerAbstractHandlerService(context, new Class[] {OvsdbInventoryListener.class, NodeCacheListener.class},
157                 AbstractEvent.HandlerType.SOUTHBOUND, southboundHandler);
158
159         final LBaaSHandler lBaaSHandler = new LBaaSHandler();
160         registerAbstractHandlerService(context, new Class[] {INeutronLoadBalancerAware.class, NodeCacheListener.class},
161                 AbstractEvent.HandlerType.NEUTRON_LOAD_BALANCER, lBaaSHandler);
162
163         final LBaaSPoolHandler lBaaSPoolHandler = new LBaaSPoolHandler();
164         registerAbstractHandlerService(context, new Class[] {INeutronLoadBalancerPoolAware.class},
165                 AbstractEvent.HandlerType.NEUTRON_LOAD_BALANCER_POOL, lBaaSPoolHandler);
166
167         final LBaaSPoolMemberHandler lBaaSPoolMemberHandler = new LBaaSPoolMemberHandler();
168         registerAbstractHandlerService(context, new Class[] {INeutronLoadBalancerPoolMemberAware.class},
169                 AbstractEvent.HandlerType.NEUTRON_LOAD_BALANCER_POOL_MEMBER, lBaaSPoolMemberHandler);
170
171         PortSecurityHandler portSecurityHandler = new PortSecurityHandler();
172         registerAbstractHandlerService(context,
173                 new Class[] {INeutronSecurityRuleAware.class, INeutronSecurityGroupAware.class},
174                 AbstractEvent.HandlerType.NEUTRON_PORT_SECURITY, portSecurityHandler);
175
176         final SecurityServicesImpl securityServices = new SecurityServicesImpl(conntrackEnabled);
177         registerService(context,
178                 new String[]{SecurityServicesManager.class.getName()}, null, securityServices);
179
180         final SecurityGroupCacheManger securityGroupCacheManger = new SecurityGroupCacheManagerImpl();
181         registerService(context,
182                         new String[]{SecurityGroupCacheManger.class.getName()}, null, securityGroupCacheManger);
183
184         registerService(context,
185                 new String[]{SecurityServicesManager.class.getName()}, null, securityServices);
186
187         FWaasHandler fWaasHandler = new FWaasHandler();
188         registerAbstractHandlerService(context,
189                 new Class[] {INeutronFirewallAware.class, INeutronFirewallRuleAware.class, INeutronFirewallPolicyAware.class},
190                 AbstractEvent.HandlerType.NEUTRON_FWAAS, fWaasHandler);
191
192         ProviderNetworkManagerImpl providerNetworkManager = new ProviderNetworkManagerImpl();
193         registerService(context,
194                 new String[]{NetworkingProviderManager.class.getName()}, null, providerNetworkManager);
195
196         EventDispatcherImpl eventDispatcher = new EventDispatcherImpl();
197         registerService(context,
198                 new String[]{EventDispatcher.class.getName()}, null, eventDispatcher);
199
200         final NeutronL3Adapter neutronL3Adapter = new NeutronL3Adapter(
201                 new NeutronModelsDataStoreHelper(this.providerContext.getSALService(DataBroker.class)));
202         registerAbstractHandlerService(context, new Class[] {NeutronL3Adapter.class, GatewayMacResolverListener.class},
203                 AbstractEvent.HandlerType.NEUTRON_L3_ADAPTER, neutronL3Adapter);
204
205         // TODO Why is DistributedArpService registered as an event handler without being an AbstractHandlerService?
206         Dictionary<String, Object> distributedArpServiceProperties = new Hashtable<>();
207         distributedArpServiceProperties.put(Constants.EVENT_HANDLER_TYPE_PROPERTY,
208                 AbstractEvent.HandlerType.DISTRIBUTED_ARP_SERVICE);
209         final DistributedArpService distributedArpService = new DistributedArpService();
210         registerService(context,
211                 new String[] {DistributedArpService.class.getName()},
212                 distributedArpServiceProperties, distributedArpService);
213
214         OpenstackRouter openstackRouter = new OpenstackRouter();
215         registerService(context,
216                 new String[]{MultiTenantAwareRouter.class.getName()}, null, openstackRouter);
217
218         Southbound southbound = new SouthboundImpl(providerContext.getSALService(DataBroker.class));
219         registerService(context,
220                 new String[]{Southbound.class.getName()}, null, southbound);
221
222         HostConfigService hostConfigService = new HostConfigService(providerContext.getSALService(DataBroker.class));
223         registerService(context,
224                 new String[]{HostConfigService.class.getName()}, null, hostConfigService);
225
226         NodeCacheManagerImpl nodeCacheManager = new NodeCacheManagerImpl();
227         registerAbstractHandlerService(context, new Class[] {NodeCacheManager.class},
228                 AbstractEvent.HandlerType.NODE, nodeCacheManager);
229
230         OvsdbInventoryServiceImpl ovsdbInventoryService = new OvsdbInventoryServiceImpl(providerContext);
231         registerService(context,
232                 new String[] {OvsdbInventoryService.class.getName()}, null, ovsdbInventoryService);
233
234         // Call .setDependencies() starting with the last service registered
235         for (int i = servicesAndRegistrations.size() - 1; i >= 0; i--) {
236             Pair<Object, ServiceRegistration> serviceAndRegistration = servicesAndRegistrations.get(i);
237             Object service = serviceAndRegistration.getLeft();
238             ServiceRegistration<?> serviceRegistration = serviceAndRegistration.getRight();
239             LOG.info("Setting dependencies on service {}/{}, {}", i, servicesAndRegistrations.size(),
240                     service.getClass());
241             if (service instanceof ConfigInterface) {
242                 ((ConfigInterface) service).setDependencies(
243                         serviceRegistration != null ? serviceRegistration.getReference() : null);
244                 LOG.info("Dependencies set");
245             } else {
246                 LOG.warn("Service isn't a ConfigInterface");
247             }
248         }
249
250         // TODO check if services are already available and setDependencies
251         // addingService may not be called if the service is already available when the ServiceTracker
252         // is started
253         trackService(context, INeutronNetworkCRUD.class, tenantNetworkManager, networkHandler, lBaaSHandler,
254                 lBaaSPoolHandler, lBaaSPoolMemberHandler, neutronL3Adapter, distributedArpService);
255         trackService(context, INeutronSubnetCRUD.class, lBaaSHandler, lBaaSPoolHandler, lBaaSPoolMemberHandler,
256                 securityServices, neutronL3Adapter);
257         trackService(context, INeutronPortCRUD.class, tenantNetworkManager, lBaaSHandler, lBaaSPoolHandler,
258                 lBaaSPoolMemberHandler, securityServices, neutronL3Adapter, distributedArpService);
259         trackService(context, INeutronFloatingIPCRUD.class, neutronL3Adapter);
260         trackService(context, INeutronLoadBalancerCRUD.class, lBaaSHandler, lBaaSPoolHandler, lBaaSPoolMemberHandler);
261         trackService(context, INeutronLoadBalancerPoolCRUD.class, lBaaSHandler, lBaaSPoolMemberHandler);
262         trackService(context, LoadBalancerProvider.class, lBaaSHandler, lBaaSPoolHandler, lBaaSPoolMemberHandler);
263         trackService(context, ArpProvider.class, neutronL3Adapter, distributedArpService);
264         trackService(context, InboundNatProvider.class, neutronL3Adapter);
265         trackService(context, OutboundNatProvider.class, neutronL3Adapter);
266         trackService(context, RoutingProvider.class, neutronL3Adapter);
267         trackService(context, L3ForwardingProvider.class, neutronL3Adapter);
268         trackService(context, GatewayMacResolver.class, neutronL3Adapter);
269         trackService(context, IngressAclProvider.class, securityServices);
270         trackService(context, EgressAclProvider.class, securityServices);
271         trackService(context, IcmpEchoProvider.class, neutronL3Adapter);
272
273         // We no longer need to track the services, avoid keeping references around
274         servicesAndRegistrations.clear();
275     }
276
277     private void registerCRUDServiceProviders(BundleContext context,
278             ProviderContext providerContext) {
279         LOG.debug("Registering CRUD service providers");
280         NeutronRouterInterface.registerNewInterface(context, providerContext, translatorCRUDRegistrations);
281         NeutronPortInterface.registerNewInterface(context, providerContext, translatorCRUDRegistrations);
282         NeutronSubnetInterface.registerNewInterface(context, providerContext, translatorCRUDRegistrations);
283         NeutronNetworkInterface.registerNewInterface(context, providerContext, translatorCRUDRegistrations);
284         NeutronSecurityGroupInterface.registerNewInterface(context, providerContext, translatorCRUDRegistrations);
285         NeutronSecurityRuleInterface.registerNewInterface(context, providerContext, translatorCRUDRegistrations);
286         NeutronFirewallInterface.registerNewInterface(context, providerContext, translatorCRUDRegistrations);
287         NeutronFirewallPolicyInterface.registerNewInterface(context, providerContext, translatorCRUDRegistrations);
288         NeutronFirewallRuleInterface.registerNewInterface(context, providerContext, translatorCRUDRegistrations);
289         NeutronLoadBalancerInterface.registerNewInterface(context, providerContext, translatorCRUDRegistrations);
290         NeutronLoadBalancerPoolInterface.registerNewInterface(context, providerContext, translatorCRUDRegistrations);
291         NeutronLoadBalancerListenerInterface.registerNewInterface(context, providerContext, translatorCRUDRegistrations);
292         NeutronLoadBalancerHealthMonitorInterface.registerNewInterface(context, providerContext, translatorCRUDRegistrations);
293         NeutronLoadBalancerPoolMemberInterface.registerNewInterface(context, providerContext, translatorCRUDRegistrations);
294         NeutronFloatingIPInterface.registerNewInterface(context, providerContext, translatorCRUDRegistrations);
295     }
296
297     private void trackService(BundleContext context, final Class<?> clazz, final ConfigInterface... dependents) {
298         @SuppressWarnings("unchecked")
299         ServiceTracker tracker = new ServiceTracker(context, clazz, null) {
300             @Override
301             public Object addingService(ServiceReference reference) {
302                 LOG.info("addingService " + clazz.getName());
303                 Object service = context.getService(reference);
304                 if (service != null) {
305                     for (ConfigInterface dependent : dependents) {
306                         dependent.setDependencies(service);
307                     }
308                 }
309                 return service;
310             }
311         };
312         tracker.open();
313     }
314
315     private void registerAbstractHandlerService(BundleContext context, Class[] interfaces,
316                                                 AbstractEvent.HandlerType handlerType, AbstractHandler handler) {
317         Dictionary<String, Object> properties = new Hashtable<>();
318         properties.put(Constants.EVENT_HANDLER_TYPE_PROPERTY, handlerType);
319         String[] interfaceNames = new String[interfaces.length + 1];
320         for (int i = 0; i < interfaces.length; i++) {
321             interfaceNames[i] = interfaces[i].getName();
322         }
323         interfaceNames[interfaces.length] = AbstractHandler.class.getName();
324         registerService(context, interfaceNames, properties, handler);
325     }
326
327
328     @Override
329     public void stop(BundleContext context) throws Exception {
330         LOG.info("ConfigActivator stop");
331         // ServiceTrackers and services are already released when bundle stops,
332         // so we don't need to close the trackers or unregister the services
333     }
334
335     private ServiceRegistration<?> registerService(BundleContext bundleContext, String[] interfaces,
336                                                    Dictionary<String, Object> properties, Object impl) {
337         ServiceRegistration serviceRegistration = bundleContext.registerService(interfaces, impl, properties);
338         if (serviceRegistration == null) {
339             LOG.warn("Service registration for {} failed to return a ServiceRegistration instance", impl.getClass());
340         }
341         servicesAndRegistrations.add(Pair.of(impl, serviceRegistration));
342         return serviceRegistration;
343     }
344
345     public void setConntrackEnabled(boolean conntrackEnabled) {
346         this.conntrackEnabled = conntrackEnabled;
347     }
348 }