Introducing new API in neutron-mapper
[groupbasedpolicy.git] / neutron-mapper / src / main / java / org / opendaylight / groupbasedpolicy / neutron / mapper / util / MappingUtils.java
index 6772d0d5467267e70ab1a62abb66f36d2ed59cc1..8b901cf8ddf7f6cd31c41aba4a49f928e3251aab 100644 (file)
@@ -9,11 +9,23 @@
 package org.opendaylight.groupbasedpolicy.neutron.mapper.util;
 
 import org.opendaylight.groupbasedpolicy.api.sf.AllowActionDefinition;
+import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.inet.types.rev100924.IpAddress;
 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.inet.types.rev100924.IpPrefix;
 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.inet.types.rev100924.Ipv4Prefix;
+import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.inet.types.rev100924.Ipv6Prefix;
 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.yang.types.rev130715.Uuid;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.groupbasedpolicy.common.rev140421.ActionName;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.groupbasedpolicy.common.rev140421.ContextId;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.groupbasedpolicy.common.rev140421.EndpointGroupId;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.groupbasedpolicy.common.rev140421.Name;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.groupbasedpolicy.common.rev140421.NetworkDomainId;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.groupbasedpolicy.forwarding.l2_l3.rev160427.L3Context;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.groupbasedpolicy.forwarding.l2_l3.rev160427.L2BridgeDomain;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.groupbasedpolicy.forwarding.l2_l3.rev160427.L2FloodDomain;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.groupbasedpolicy.forwarding.l2_l3.rev160427.Subnet;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.groupbasedpolicy.forwarding.rev160427.ContextType;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.groupbasedpolicy.forwarding.rev160427.forwarding.fields.Parent;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.groupbasedpolicy.forwarding.rev160427.forwarding.fields.ParentBuilder;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.groupbasedpolicy.neutron.gbp.mapper.rev150513.change.action.of.security.group.rules.input.action.ActionChoice;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.groupbasedpolicy.neutron.gbp.mapper.rev150513.change.action.of.security.group.rules.input.action.action.choice.AllowActionCaseBuilder;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.groupbasedpolicy.neutron.gbp.mapper.rev150513.change.action.of.security.group.rules.input.action.action.choice.SfcActionCaseBuilder;
@@ -44,6 +56,12 @@ public final class MappingUtils {
     public static final String NAME_DELIMETER = "_";
     public static final String NAME_DOUBLE_DELIMETER = "__";
 
+    // Network domains defined here to overcome package conflict resolution
+    public static final Class<L3Context> L3_CONTEXT = L3Context.class;
+    public static final Class<L2BridgeDomain> L2_BRDIGE_DOMAIN = L2BridgeDomain.class;
+    public static final Class<L2FloodDomain> L2_FLOOD_DOMAIN = L2FloodDomain.class;
+    public static final Class<Subnet> SUBNET = Subnet.class;
+
     private MappingUtils() {
         throw new UnsupportedOperationException("Cannot create an instance.");
     }
@@ -56,4 +74,69 @@ public final class MappingUtils {
         return new SfcActionCaseBuilder().setSfcChainName(chainName).build();
     }
 
+    public static <T extends ContextType> Parent createParent(ContextId id, Class<T> domainType) {
+        return new ParentBuilder().setContextId(id).setContextType(domainType).build();
+    }
+
+    public static <T extends ContextType> Parent createParent(NetworkDomainId id, Class<T> domainType) {
+        return new ParentBuilder().setContextId(new ContextId(id.getValue())).setContextType(domainType).build();
+    }
+
+    public static IpPrefix ipAddressToIpPrefix(char[] address) {
+        return ipAddressToIpPrefix(new IpAddress(address));
+    }
+
+    public static IpPrefix ipAddressToIpPrefix(IpAddress address) {
+        if (address.getIpv4Address() != null) {
+            return new IpPrefix(new Ipv4Prefix(ipv4PrefixOf(address)));
+        } else if (address.getIpv6Address() != null) {
+            return new IpPrefix(new Ipv6Prefix(ipv6PrefixOf(address)));
+        }
+        throw new IllegalArgumentException("Ip address [{}] is not a valid Ipv4 or Ipv6 address." + address);
+    }
+
+    public static String ipAddressToStringIpPrefix(String address) {
+        return ipAddressToStringIpPrefix(new IpAddress(address.toCharArray()));
+    }
+
+    public static String ipAddressToStringIpPrefix(char[] address) {
+        return ipAddressToStringIpPrefix(new IpAddress(address));
+    }
+
+    public static String ipAddressToStringIpPrefix(IpAddress address) {
+        if (address.getIpv4Address() != null) {
+            return ipv4PrefixOf(address);
+        } else if (address.getIpv6Address() != null) {
+            return ipv6PrefixOf(address);
+        }
+        throw new IllegalArgumentException("Ip address [{}] is not a valid Ipv4 or Ipv6 address." + address);
+    }
+
+    private static String ipv4PrefixOf(IpAddress ipAddress) {
+        return new String(ipAddress.getValue()) + "/32";
+    }
+
+    private static String ipv6PrefixOf(IpAddress ipAddress) {
+        return new String(ipAddress.getValue()) + "/128";
+    }
+
+    public static IpAddress ipPrefixToIpAddress(char[] ipPrefix) {
+        return ipPrefixToIpAddress(new IpPrefix(ipPrefix));
+    }
+
+    public static IpAddress ipPrefixToIpAddress(IpPrefix prefix) {
+        return new IpAddress(ipPrefixToStringIpAddress(prefix).toCharArray());
+    }
+
+    public static String ipPrefixToStringIpAddress(IpPrefix prefix) {
+        if (prefix.getIpv4Prefix() != null) {
+            String[] split = prefix.getIpv4Prefix().getValue().split("/");
+            return split[0];
+
+        } else if (prefix.getIpv6Prefix() != null) {
+            String[] split = prefix.getIpv6Prefix().getValue().split("/");
+            return split[0];
+        }
+        throw new IllegalArgumentException("Cannot extract IP prefix from IP address {}" + prefix);
+    }
 }