use of org.opendaylight.yang.gen.v1.urn.opendaylight.netvirt.natservice.rev160111.snatint.ip.port.map.intip.port.map.IpPort in project netvirt by opendaylight.
the class NaptSwitchHA method handleNatFlowsInNewNaptSwitch.
// TODO Clean up the exception handling
@SuppressWarnings("checkstyle:IllegalCatch")
private boolean handleNatFlowsInNewNaptSwitch(String routerName, Long routerId, BigInteger oldNaptSwitch, BigInteger newNaptSwitch, Long routerVpnId, Uuid networkId) {
LOG.debug("handleNatFlowsInNewNaptSwitch : Proceeding to install flows in newNaptSwitch {} for routerId {}", newNaptSwitch, routerId);
IpPortMapping ipPortMapping = NatUtil.getIportMapping(dataBroker, routerId);
if (ipPortMapping == null || ipPortMapping.getIntextIpProtocolType() == null || ipPortMapping.getIntextIpProtocolType().isEmpty()) {
LOG.debug("handleNatFlowsInNewNaptSwitch : No Internal Ip Port mapping associated to router {}," + "no flows need to be installed in newNaptSwitch {}", routerId, newNaptSwitch);
return true;
}
// getvpnId
Long vpnId = getVpnIdForRouter(routerId, networkId);
if (vpnId == NatConstants.INVALID_ID) {
LOG.error("handleNatFlowsInNewNaptSwitch : Invalid vpnId for routerId {}", routerId);
return false;
}
Long bgpVpnId;
if (routerId.equals(routerVpnId)) {
bgpVpnId = NatConstants.INVALID_ID;
} else {
bgpVpnId = routerVpnId;
}
LOG.debug("handleNatFlowsInNewNaptSwitch : retrieved bgpVpnId {} for router {}", bgpVpnId, routerId);
// Get the External Gateway MAC Address
String extGwMacAddress = NatUtil.getExtGwMacAddFromRouterName(dataBroker, routerName);
if (extGwMacAddress != null) {
LOG.debug("handleNatFlowsInNewNaptSwitch :External Gateway MAC address {} found for External Router ID {}", extGwMacAddress, routerId);
} else {
LOG.error("handleNatFlowsInNewNaptSwitch : No External Gateway MAC address found for External Router ID {}", routerId);
return false;
}
for (IntextIpProtocolType protocolType : ipPortMapping.getIntextIpProtocolType()) {
if (protocolType.getIpPortMap() == null || protocolType.getIpPortMap().isEmpty()) {
LOG.debug("handleNatFlowsInNewNaptSwitch : No {} session associated to router {}", protocolType.getProtocol(), routerId);
return true;
}
for (IpPortMap intIpPortMap : protocolType.getIpPortMap()) {
String internalIpAddress = intIpPortMap.getIpPortInternal().split(":")[0];
String intportnum = intIpPortMap.getIpPortInternal().split(":")[1];
LOG.debug("handleNatFlowsInNewNaptSwitch : Found Internal IP Address {} and Port Number {}", internalIpAddress, intportnum);
// Get the external IP address and the port from the model
NAPTEntryEvent.Protocol proto = protocolType.getProtocol().toString().equals(ProtocolTypes.TCP.toString()) ? NAPTEntryEvent.Protocol.TCP : NAPTEntryEvent.Protocol.UDP;
IpPortExternal ipPortExternal = NatUtil.getExternalIpPortMap(dataBroker, routerId, internalIpAddress, intportnum, proto);
if (ipPortExternal == null) {
LOG.debug("handleNatFlowsInNewNaptSwitch : External Ipport mapping is not found for internalIp {} " + "with port {}", internalIpAddress, intportnum);
continue;
}
String externalIpAddress = ipPortExternal.getIpAddress();
Integer extportNumber = ipPortExternal.getPortNum();
LOG.debug("handleNatFlowsInNewNaptSwitch : ExternalIPport {}:{} mapping for internal ipport {}:{}", externalIpAddress, extportNumber, internalIpAddress, intportnum);
SessionAddress sourceAddress = new SessionAddress(internalIpAddress, Integer.parseInt(intportnum));
SessionAddress externalAddress = new SessionAddress(externalIpAddress, extportNumber);
// checking naptSwitch status before installing flows
if (getSwitchStatus(newNaptSwitch)) {
// Install the flow in newNaptSwitch Inbound NAPT table.
try {
naptEventHandler.buildAndInstallNatFlows(newNaptSwitch, NwConstants.INBOUND_NAPT_TABLE, vpnId, routerId, bgpVpnId, externalAddress, sourceAddress, proto, extGwMacAddress);
} catch (RuntimeException ex) {
LOG.error("handleNatFlowsInNewNaptSwitch : Failed to add flow in INBOUND_NAPT_TABLE for " + "routerid {} dpnId {} extIpport{}:{} proto {} ipport {}:{} BgpVpnId {}", routerId, newNaptSwitch, externalAddress, extportNumber, proto, internalIpAddress, intportnum, bgpVpnId);
return false;
}
LOG.debug("handleNatFlowsInNewNaptSwitch : Successfully installed a flow in Primary switch {} " + "Inbound NAPT table for router {} ipport {}:{} proto {} extIpport {}:{} BgpVpnId {}", newNaptSwitch, routerId, internalIpAddress, intportnum, proto, externalAddress, extportNumber, bgpVpnId);
// Install the flow in newNaptSwitch Outbound NAPT table.
try {
naptEventHandler.buildAndInstallNatFlows(newNaptSwitch, NwConstants.OUTBOUND_NAPT_TABLE, vpnId, routerId, bgpVpnId, sourceAddress, externalAddress, proto, extGwMacAddress);
} catch (RuntimeException ex) {
LOG.error("handleNatFlowsInNewNaptSwitch : Failed to add flow in OUTBOUND_NAPT_TABLE for " + "routerid {} dpnId {} ipport {}:{} proto {} extIpport {}:{} BgpVpnId {}", routerId, newNaptSwitch, internalIpAddress, intportnum, proto, externalAddress, extportNumber, bgpVpnId, ex);
return false;
}
LOG.debug("handleNatFlowsInNewNaptSwitch : Successfully installed a flow in Primary switch {} " + "Outbound NAPT table for router {} ipport {}:{} proto {} extIpport {}:{} BgpVpnId {}", newNaptSwitch, routerId, internalIpAddress, intportnum, proto, externalAddress, extportNumber, bgpVpnId);
} else {
LOG.error("handleNatFlowsInNewNaptSwitch : NewNaptSwitch {} gone down while installing flows " + "from oldNaptswitch {}", newNaptSwitch, oldNaptSwitch);
return false;
}
}
}
return true;
}
use of org.opendaylight.yang.gen.v1.urn.opendaylight.netvirt.natservice.rev160111.snatint.ip.port.map.intip.port.map.IpPort in project openflowplugin by opendaylight.
the class MatchV10Convertor method convert.
@Override
public MatchV10 convert(final Match source, final VersionConvertorData data) {
MatchV10Builder matchBuilder = new MatchV10Builder();
boolean dlDst = true;
boolean dlSsc = true;
boolean dlType = true;
boolean dlVlan = true;
boolean dlVlanPcp = true;
boolean ipPort = true;
boolean nwProto = true;
boolean nwTos = true;
boolean tpDst = true;
boolean tpSrc = true;
matchBuilder.setInPort(0);
matchBuilder.setDlDst(ZERO_MAC);
matchBuilder.setDlSrc(ZERO_MAC);
matchBuilder.setDlType(0);
matchBuilder.setDlVlan(OFP_VLAN_NONE);
matchBuilder.setDlVlanPcp((short) 0);
matchBuilder.setNwDst(ZERO_IPV4);
matchBuilder.setNwDstMask((short) 0);
matchBuilder.setNwSrc(ZERO_IPV4);
matchBuilder.setNwSrcMask((short) 0);
matchBuilder.setNwProto((short) 0);
matchBuilder.setNwTos((short) 0);
matchBuilder.setTpSrc(0);
matchBuilder.setTpDst(0);
if (source != null) {
EthernetMatch ethernetMatch = source.getEthernetMatch();
if (ethernetMatch != null) {
dlDst = convertEthernetDlDst(matchBuilder, ethernetMatch);
dlSsc = convertEthernetDlSrc(matchBuilder, ethernetMatch);
dlType = convertEthernetDlType(matchBuilder, ethernetMatch);
}
VlanMatch vlanMatch = source.getVlanMatch();
if (vlanMatch != null) {
dlVlan = convertDlVlan(matchBuilder, vlanMatch);
dlVlanPcp = convertDlVlanPcp(matchBuilder, vlanMatch);
}
NodeConnectorId inPort = source.getInPort();
if (inPort != null) {
ipPort = convertInPortMatch(matchBuilder, inPort);
}
Layer3Match l3Match = source.getLayer3Match();
if (l3Match != null) {
if (l3Match instanceof Ipv4Match) {
Ipv4Match ipv4 = (Ipv4Match) l3Match;
convertL3Ipv4SrcMatch(matchBuilder, ipv4);
convertL3Ipv4DstMatch(matchBuilder, ipv4);
}
}
IpMatch ipMatch = source.getIpMatch();
if (ipMatch != null) {
nwProto = convertNwProto(matchBuilder, ipMatch);
nwTos = convertNwTos(matchBuilder, ipMatch);
}
Layer4Match layer4Match = source.getLayer4Match();
if (layer4Match != null) {
if (layer4Match instanceof TcpMatch) {
TcpMatch tcpMatch = (TcpMatch) layer4Match;
tpSrc = convertL4TpSrcMatch(matchBuilder, tcpMatch);
tpDst = convertL4TpDstMatch(matchBuilder, tcpMatch);
} else if (layer4Match instanceof UdpMatch) {
UdpMatch udpMatch = (UdpMatch) layer4Match;
tpSrc = convertL4UdpSrcMatch(matchBuilder, udpMatch);
tpDst = convertL4UdpDstMatch(matchBuilder, udpMatch);
}
} else {
Icmpv4Match icmpv4Match = source.getIcmpv4Match();
if (icmpv4Match != null) {
Short type = icmpv4Match.getIcmpv4Type();
if (type != null) {
matchBuilder.setTpSrc(type.intValue());
tpSrc = false;
}
Short code = icmpv4Match.getIcmpv4Code();
if (code != null) {
matchBuilder.setTpDst(code.intValue());
tpDst = false;
}
}
}
}
FlowWildcardsV10 wildCards = new FlowWildcardsV10(dlDst, dlSsc, dlType, dlVlan, dlVlanPcp, ipPort, nwProto, nwTos, tpDst, tpSrc);
matchBuilder.setWildcards(wildCards);
return matchBuilder.build();
}
Aggregations