2 * Copyright (c) 2017 Red Hat, Inc. and others. All rights reserved.
4 * This program and the accompanying materials are made available under the
5 * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6 * and is available at http://www.eclipse.org/legal/epl-v10.html
9 package org.opendaylight.netvirt.natservice.cli;
11 import com.google.common.base.Optional;
12 import java.io.PrintStream;
13 import java.math.BigInteger;
14 import javax.annotation.Nonnull;
15 import org.apache.karaf.shell.commands.Command;
16 import org.apache.karaf.shell.console.OsgiCommandSupport;
17 import org.opendaylight.controller.md.sal.binding.api.DataBroker;
18 import org.opendaylight.controller.md.sal.common.api.data.LogicalDatastoreType;
19 import org.opendaylight.genius.datastoreutils.SingleTransactionDataBroker;
20 import org.opendaylight.netvirt.natservice.internal.NatUtil;
21 import org.opendaylight.yang.gen.v1.urn.opendaylight.genius.interfacemanager.meta.rev160406.BridgeRefInfo;
22 import org.opendaylight.yang.gen.v1.urn.opendaylight.genius.interfacemanager.meta.rev160406.bridge.ref.info.BridgeRefEntry;
23 import org.opendaylight.yang.gen.v1.urn.opendaylight.genius.interfacemanager.meta.rev160406.bridge.ref.info.BridgeRefEntryKey;
24 import org.opendaylight.yang.gen.v1.urn.opendaylight.netvirt.natservice.rev160111.NaptSwitches;
25 import org.opendaylight.yang.gen.v1.urn.opendaylight.netvirt.natservice.rev160111.napt.switches.RouterToNaptSwitch;
26 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.ovsdb.rev150105.OvsdbBridgeAugmentation;
27 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.ovsdb.rev150105.OvsdbNodeAugmentation;
28 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.ovsdb.rev150105.ovsdb.node.attributes.OpenvswitchOtherConfigs;
29 import org.opendaylight.yang.gen.v1.urn.tbd.params.xml.ns.yang.network.topology.rev131021.network.topology.topology.Node;
30 import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
32 @Command(scope = "odl", name = "display-napt-switches", description = "Display the napt switch for the routers.")
33 public class DisplayNaptSwithcesCli extends OsgiCommandSupport {
35 private DataBroker dataBroker;
36 private static final String LOCAL_IP = "local_ip";
38 public void setDataBroker(DataBroker dataBroker) {
39 this.dataBroker = dataBroker;
43 protected Object doExecute() throws Exception {
44 PrintStream ps = session.getConsole();
45 Optional<NaptSwitches> npatSwitches = NatUtil.getAllPrimaryNaptSwitches(dataBroker);
46 ps.printf(String.format(" %-36s %-20s %-20s %n", "Router Id ", "Datapath Node Id", "Managment Ip Address"));
47 ps.printf("-------------------------------------------------------------------------------------------%n");
48 if (npatSwitches.isPresent()) {
49 for (RouterToNaptSwitch routerToNaptSwitch : npatSwitches.get().getRouterToNaptSwitch()) {
50 ps.printf(String.format(" %-36s %-20s %-20s %n", routerToNaptSwitch.getRouterName(),
51 routerToNaptSwitch.getPrimarySwitchId(), getDpnLocalIp(routerToNaptSwitch.getPrimarySwitchId())));
57 @SuppressWarnings("unchecked")
58 private Optional<Node> getPortsNode(BigInteger dpnId) {
59 InstanceIdentifier<BridgeRefEntry> bridgeRefInfoPath = InstanceIdentifier.create(BridgeRefInfo.class)
60 .child(BridgeRefEntry.class, new BridgeRefEntryKey(dpnId));
62 Optional<BridgeRefEntry> bridgeRefEntry =
63 SingleTransactionDataBroker.syncReadOptionalAndTreatReadFailedExceptionAsAbsentOptional(dataBroker,
64 LogicalDatastoreType.OPERATIONAL, bridgeRefInfoPath);
65 if (!bridgeRefEntry.isPresent()) {
66 return Optional.absent();
69 InstanceIdentifier<Node> nodeId =
70 bridgeRefEntry.get().getBridgeReference().getValue().firstIdentifierOf(Node.class);
72 return SingleTransactionDataBroker.syncReadOptionalAndTreatReadFailedExceptionAsAbsentOptional(dataBroker,
73 LogicalDatastoreType.OPERATIONAL, nodeId);
76 private String getDpnLocalIp(BigInteger dpId) {
77 return getPortsNode(dpId).toJavaUtil().map(node -> getOpenvswitchOtherConfig(node, LOCAL_IP)).orElse(null);
80 private String getOpenvswitchOtherConfig(Node node, String key) {
81 OvsdbNodeAugmentation ovsdbNode = node.augmentation(OvsdbNodeAugmentation.class);
82 if (ovsdbNode == null) {
83 Optional<Node> nodeFromReadOvsdbNode = readOvsdbNode(node);
84 if (nodeFromReadOvsdbNode.isPresent()) {
85 ovsdbNode = nodeFromReadOvsdbNode.get().augmentation(OvsdbNodeAugmentation.class);
89 if (ovsdbNode != null && ovsdbNode.getOpenvswitchOtherConfigs() != null) {
90 for (OpenvswitchOtherConfigs openvswitchOtherConfigs : ovsdbNode.getOpenvswitchOtherConfigs()) {
91 if (openvswitchOtherConfigs.getOtherConfigKey().equals(key)) {
92 return openvswitchOtherConfigs.getOtherConfigValue();
101 private Optional<Node> readOvsdbNode(Node bridgeNode) {
102 OvsdbBridgeAugmentation bridgeAugmentation = extractBridgeAugmentation(bridgeNode);
103 if (bridgeAugmentation != null) {
104 InstanceIdentifier<Node> ovsdbNodeIid =
105 (InstanceIdentifier<Node>) bridgeAugmentation.getManagedBy().getValue();
106 return SingleTransactionDataBroker.syncReadOptionalAndTreatReadFailedExceptionAsAbsentOptional(dataBroker,
107 LogicalDatastoreType.OPERATIONAL, ovsdbNodeIid);
109 return Optional.absent();
113 private OvsdbBridgeAugmentation extractBridgeAugmentation(Node node) {
117 return node.augmentation(OvsdbBridgeAugmentation.class);