2 * Copyright (C) 2013 Red Hat, Inc.
4 * This program and the accompanying materials are made available under the
5 * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6 * and is available at http://www.eclipse.org/legal/epl-v10.html
8 * Authors : Madhu Venugopal, Brent Salisbury, Sam Hague, Dave Tucker
10 package org.opendaylight.ovsdb.openstack.netvirt.impl;
12 import java.net.InetAddress;
15 import org.apache.commons.lang3.tuple.ImmutablePair;
16 import org.apache.commons.lang3.tuple.Pair;
17 import org.opendaylight.ovsdb.lib.notation.Row;
18 import org.opendaylight.ovsdb.openstack.netvirt.api.ConfigurationService;
19 import org.opendaylight.ovsdb.openstack.netvirt.api.Constants;
20 import org.opendaylight.ovsdb.openstack.netvirt.api.MdsalConsumer;
21 import org.opendaylight.ovsdb.schema.openvswitch.OpenVSwitch;
22 import org.opendaylight.ovsdb.utils.config.ConfigProperties;
23 import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.nodes.Node;
25 import org.slf4j.Logger;
26 import org.slf4j.LoggerFactory;
28 import com.google.common.collect.Maps;
30 public class ConfigurationServiceImpl implements ConfigurationService {
31 static final Logger logger = LoggerFactory.getLogger(ConfigurationServiceImpl.class);
33 // Values set with dependency injection from OSGi
34 //private volatile OvsdbConfigurationService ovsdbConfigurationService;
35 private volatile MdsalConsumer mdsalConsumer;
37 private String integrationBridgeName;
38 private String networkBridgeName;
39 private String externalBridgeName;
40 private String tunnelEndpointKey;
42 private Map<Pair<String, String>, String> patchPortNames = Maps.newHashMap();
43 private String providerMappingsKey;
44 private String providerMapping;
46 public ConfigurationServiceImpl() {
47 tunnelEndpointKey = Constants.TUNNEL_ENDPOINT_KEY;
48 integrationBridgeName = Constants.INTEGRATION_BRIDGE;
49 networkBridgeName = Constants.NETWORK_BRIDGE;
50 externalBridgeName = Constants.EXTERNAL_BRIDGE;
51 patchPortNames.put(new ImmutablePair<>(integrationBridgeName, networkBridgeName),
52 Constants.PATCH_PORT_TO_NETWORK_BRIDGE_NAME);
53 patchPortNames.put(new ImmutablePair<>(networkBridgeName, integrationBridgeName),
54 Constants.PATCH_PORT_TO_INTEGRATION_BRIDGE_NAME);
55 providerMappingsKey = Constants.PROVIDER_MAPPINGS_KEY;
56 providerMapping = Constants.PROVIDER_MAPPING;
60 public String getIntegrationBridgeName() {
61 return integrationBridgeName;
65 public void setIntegrationBridgeName(String integrationBridgeName) {
66 this.integrationBridgeName = integrationBridgeName;
70 public String getNetworkBridgeName() {
71 return networkBridgeName;
75 public void setNetworkBridgeName(String networkBridgeName) {
76 this.networkBridgeName = networkBridgeName;
80 public String getExternalBridgeName() {
81 return externalBridgeName;
85 public void setExternalBridgeName(String externalBridgeName) {
86 this.externalBridgeName = externalBridgeName;
90 public String getTunnelEndpointKey() {
91 return tunnelEndpointKey;
95 public void setTunnelEndpointKey(String tunnelEndpointKey) {
96 this.tunnelEndpointKey = tunnelEndpointKey;
100 public String getProviderMappingsKey() {
101 return providerMappingsKey;
105 public void setProviderMappingsKey(String providerMappingsKey) {
106 this.providerMappingsKey = providerMappingsKey;
110 public Map<Pair<String, String>, String> getPatchPortNames() {
111 return patchPortNames;
115 public void setPatchPortNames(Map<Pair<String, String>, String> patchPortNames) {
116 this.patchPortNames = patchPortNames;
120 public String getPatchPortName(Pair portTuple){
121 return this.patchPortNames.get(portTuple);
125 public String getDefaultProviderMapping() {
126 return providerMapping;
130 public void setDefaultProviderMapping(String providerMapping) {
131 this.providerMapping = providerMapping;
135 public InetAddress getTunnelEndPoint(Node node) {
136 InetAddress address = mdsalConsumer.getTunnelEndPoint(node);
138 InetAddress address = null;
140 Map<String, Row> ovsTable = ovsdbConfigurationService.getRows(node,
141 ovsdbConfigurationService.getTableName(node, OpenVSwitch.class));
143 if (ovsTable == null) {
144 logger.error("OpenVSwitch table is null for Node {} ", node);
148 // While there is only one entry in the HashMap, we can't access it by index...
149 for (Row row : ovsTable.values()) {
150 OpenVSwitch ovsRow = ovsdbConfigurationService.getTypedRow(node, OpenVSwitch.class, row);
151 Map<String, String> configs = ovsRow.getOtherConfigColumn().getData();
153 if (configs == null) {
154 logger.debug("OpenVSwitch table is null for Node {} ", node);
158 String tunnelEndpoint = configs.get(tunnelEndpointKey);
160 if (tunnelEndpoint == null) {
164 address = InetAddress.getByName(tunnelEndpoint);
165 logger.debug("Tunnel Endpoint for Node {} {}", node, address.getHostAddress());
169 catch (Exception e) {
170 logger.error("Error populating Tunnel Endpoint for Node {} ", node, e);
177 public String getOpenflowVersion(Node node) {
178 return Constants.OPENFLOW13;
182 public String getDefaultGatewayMacAddress(Node node) {
183 final String l3gatewayForNode =
185 ConfigProperties.getProperty(this.getClass(), "ovsdb.l3gateway.mac." + node.getId().getValue()) : null;
186 return l3gatewayForNode != null ?
187 l3gatewayForNode : ConfigProperties.getProperty(this.getClass(), "ovsdb.l3gateway.mac");