/* * Copyright (c) 2016 Cisco Systems, Inc. and others. All rights reserved. * * This program and the accompanying materials are made available under the * terms of the Eclipse Public License v1.0 which accompanies this distribution, * and is available at http://www.eclipse.org/legal/epl-v10.html */ package org.opendaylight.openflowplugin.openflow.md.core.sal.convertor.match.cases; import java.util.Optional; import javax.annotation.Nonnull; import org.opendaylight.openflowplugin.api.OFConstants; import org.opendaylight.openflowplugin.openflow.md.core.sal.convertor.ConvertorExecutor; import org.opendaylight.openflowplugin.openflow.md.core.sal.convertor.common.ConvertorCase; import org.opendaylight.openflowplugin.openflow.md.core.sal.convertor.common.IpConversionUtil; import org.opendaylight.openflowplugin.openflow.md.core.sal.convertor.match.data.MatchResponseConvertorData; import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.inet.types.rev130715.Ipv6Address; import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.inet.types.rev130715.Ipv6Prefix; import org.opendaylight.yang.gen.v1.urn.opendaylight.flow.types.rev131026.flow.MatchBuilder; import org.opendaylight.yang.gen.v1.urn.opendaylight.model.match.types.rev131026.match.layer._3.match.Ipv6MatchArbitraryBitMaskBuilder; import org.opendaylight.yang.gen.v1.urn.opendaylight.model.match.types.rev131026.match.layer._3.match.Ipv6MatchBuilder; import org.opendaylight.yang.gen.v1.urn.opendaylight.opendaylight.ipv6.arbitrary.bitmask.fields.rev160224.Ipv6ArbitraryMask; import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev150225.match.entry.value.grouping.match.entry.value.Ipv6DstCase; import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev150225.match.entry.value.grouping.match.entry.value.ipv6.dst._case.Ipv6Dst; public class OfToSalIpv6DstCase extends ConvertorCase { public OfToSalIpv6DstCase() { super(Ipv6DstCase.class, true, OFConstants.OFP_VERSION_1_0, OFConstants.OFP_VERSION_1_3); } @Override public Optional process(@Nonnull Ipv6DstCase source, MatchResponseConvertorData data, ConvertorExecutor convertorExecutor) { final MatchBuilder matchBuilder = data.getMatchBuilder(); final Ipv6MatchBuilder ipv6MatchBuilder = data.getIpv6MatchBuilder(); final Ipv6MatchArbitraryBitMaskBuilder ipv6MatchArbitraryBitMaskBuilder = data.getIpv6MatchArbitraryBitMaskBuilder(); Ipv6Dst ipv6Dst = source.getIpv6Dst(); if (ipv6Dst != null) { byte[] mask = ipv6Dst.getMask(); if (mask != null && IpConversionUtil.isIpv6ArbitraryBitMask(mask)) { // case where ipv6src is of type ipv6MatchBuilder and ipv6dst is of type ipv6MatchArbitrary. // Need to convert ipv6src to ipv6MatchArbitrary. if (ipv6MatchBuilder.getIpv6Source() != null) { Ipv6Prefix ipv6PrefixSourceAddress = ipv6MatchBuilder.getIpv6Source(); Ipv6Address ipv6SrcAddress = IpConversionUtil.extractIpv6Address(ipv6PrefixSourceAddress); Ipv6ArbitraryMask srcIpv6Arbitrary = IpConversionUtil.compressedIpv6MaskFormat( IpConversionUtil.extractIpv6AddressMask(ipv6PrefixSourceAddress)); setSrcIpv6MatchArbitraryBitMaskBuilderFields(ipv6MatchArbitraryBitMaskBuilder, srcIpv6Arbitrary, IpConversionUtil.compressedIpv6Format(ipv6SrcAddress.getValue())); } Ipv6ArbitraryMask dstIpv6ArbitraryMask = IpConversionUtil.compressedIpv6MaskFormat( IpConversionUtil.createIpv6ArbitraryBitMask(mask)); String stringIpv6DstAddress = IpConversionUtil.compressedIpv6Format(ipv6Dst.getIpv6Address().getValue()); setDstIpv6MatchArbitraryBitMaskBuilderFields(ipv6MatchArbitraryBitMaskBuilder, dstIpv6ArbitraryMask, stringIpv6DstAddress); matchBuilder.setLayer3Match(ipv6MatchArbitraryBitMaskBuilder.build()); } else if (ipv6MatchArbitraryBitMaskBuilder.getIpv6SourceAddressNoMask() != null) { /* TODO Change comments Case where source is of type ipv4MatchArbitraryBitMask already exists in Layer3Match, source which of type ipv6Match needs to be converted to ipv6MatchArbitraryBitMask. We convert 1::/32 to 1::/FFFF:FFFF:: example:- 1::/32 1::1 FFFF::0001 after conversion output example:- 1:: FFFF:FFFF:: 1::1 FFFF::0001 */ Ipv6ArbitraryMask dstIpv6ArbitraryMask = IpConversionUtil.compressedIpv6MaskFormat( IpConversionUtil.createIpv6ArbitraryBitMask(mask)); String stringIpv6DstAddress = IpConversionUtil.compressedIpv6Format(ipv6Dst.getIpv6Address().getValue()); setDstIpv6MatchArbitraryBitMaskBuilderFields(ipv6MatchArbitraryBitMaskBuilder, dstIpv6ArbitraryMask, stringIpv6DstAddress); matchBuilder.setLayer3Match(ipv6MatchArbitraryBitMaskBuilder.build()); } else { String stringIpv6DstAddress = IpConversionUtil.compressedIpv6Format(ipv6Dst.getIpv6Address().getValue()); setIpv6MatchBuilderFields(ipv6MatchBuilder, mask, stringIpv6DstAddress); matchBuilder.setLayer3Match(ipv6MatchBuilder.build()); } } return Optional.of(matchBuilder); } private static void setIpv6MatchBuilderFields(final Ipv6MatchBuilder ipv6MatchBuilder, final byte[] mask, final String ipv6PrefixStr) { Ipv6Prefix ipv6Prefix; if (mask != null) { ipv6Prefix = IpConversionUtil.createPrefix(new Ipv6Address(ipv6PrefixStr), mask); } else { ipv6Prefix = IpConversionUtil.createPrefix(new Ipv6Address(ipv6PrefixStr)); } ipv6MatchBuilder.setIpv6Destination(ipv6Prefix); } private static void setSrcIpv6MatchArbitraryBitMaskBuilderFields( final Ipv6MatchArbitraryBitMaskBuilder ipv6MatchArbitraryBitMaskBuilder, final Ipv6ArbitraryMask mask, final String ipv6AddressStr) { Ipv6Address ipv6Address; if (mask != null) { ipv6MatchArbitraryBitMaskBuilder.setIpv6SourceArbitraryBitmask(mask); } ipv6Address = new Ipv6Address(ipv6AddressStr); ipv6MatchArbitraryBitMaskBuilder.setIpv6SourceAddressNoMask(ipv6Address); } private static void setDstIpv6MatchArbitraryBitMaskBuilderFields( final Ipv6MatchArbitraryBitMaskBuilder ipv6MatchArbitraryBitMaskBuilder, final Ipv6ArbitraryMask mask, final String ipv6AddressStr) { Ipv6Address ipv6Address; if (mask != null) { ipv6MatchArbitraryBitMaskBuilder.setIpv6DestinationArbitraryBitmask(mask); } ipv6Address = new Ipv6Address(ipv6AddressStr); ipv6MatchArbitraryBitMaskBuilder.setIpv6DestinationAddressNoMask(ipv6Address); } }