2 * Copyright © 2016, 2017 Red Hat, Inc. and others.
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 package org.opendaylight.genius.mdsalutil.actions;
10 import java.util.ArrayList;
11 import java.util.Collections;
12 import java.util.List;
13 import java.util.stream.Collectors;
15 import org.opendaylight.genius.mdsalutil.ActionInfo;
16 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.inet.types.rev130715.IpAddress;
17 import org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.list.Action;
18 import org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.list.ActionBuilder;
19 import org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.list.ActionKey;
20 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflowplugin.extension.nicira.action.rev140714.nodes.node.table.flow.instructions.instruction.instruction.apply.actions._case.apply.actions.action.action.NxActionConntrackNodesNodeTableFlowApplyActionsCaseBuilder;
21 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflowplugin.extension.nicira.action.rev140714.nx.action.conntrack.grouping.NxConntrackBuilder;
22 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflowplugin.extension.nicira.action.rev140714.nx.action.conntrack.grouping.nx.conntrack.CtActions;
23 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflowplugin.extension.nicira.action.rev140714.nx.action.conntrack.grouping.nx.conntrack.CtActionsBuilder;
24 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflowplugin.extension.nicira.action.rev140714.ofpact.actions.ofpact.actions.NxActionCtMarkCaseBuilder;
25 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflowplugin.extension.nicira.action.rev140714.ofpact.actions.ofpact.actions.NxActionNatCaseBuilder;
26 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflowplugin.extension.nicira.action.rev140714.ofpact.actions.ofpact.actions.nx.action.ct.mark._case.NxActionCtMarkBuilder;
27 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflowplugin.extension.nicira.action.rev140714.ofpact.actions.ofpact.actions.nx.action.nat._case.NxActionNatBuilder;
30 * NX conntrack action.
32 public class ActionNxConntrack extends ActionInfo {
34 private final int flags;
35 private final long zoneSrc;
36 private final int conntrackZone;
37 private final short recircTable;
38 private final List<NxCtAction> ctActions = new ArrayList<>();
40 public ActionNxConntrack(int flags, long zoneSrc, int conntrackZone, short recircTable) {
41 this(0, flags, zoneSrc, conntrackZone, recircTable, Collections.emptyList());
44 public ActionNxConntrack(int flags, long zoneSrc, int conntrackZone, short recircTable,
45 List<NxCtAction> ctActions) {
46 this(0, flags, zoneSrc, conntrackZone, recircTable, ctActions);
49 public ActionNxConntrack(int actionKey, int flags, long zoneSrc, int conntrackZone, short recircTable) {
50 this(actionKey, flags, zoneSrc, conntrackZone, recircTable, Collections.emptyList());
53 public ActionNxConntrack(int actionKey, int flags, long zoneSrc, int conntrackZone, short recircTable,
54 List<NxCtAction> ctActions) {
57 this.zoneSrc = zoneSrc;
58 this.conntrackZone = conntrackZone;
59 this.recircTable = recircTable;
60 this.ctActions.addAll(ctActions);
64 public Action buildAction() {
65 return buildAction(getActionKey());
69 public Action buildAction(int newActionKey) {
70 NxConntrackBuilder ctb = new NxConntrackBuilder()
73 .setConntrackZone(conntrackZone)
74 .setRecircTable(recircTable);
75 ctb.setCtActions(this.ctActions.stream().map(NxCtAction::buildCtActions).collect(Collectors.toList()));
76 ActionBuilder ab = new ActionBuilder();
77 ab.setAction(new NxActionConntrackNodesNodeTableFlowApplyActionsCaseBuilder()
78 .setNxConntrack(ctb.build()).build());
79 ab.setKey(new ActionKey(newActionKey));
83 public int getFlags() {
87 public long getZoneSrc() {
91 public int getConntrackZone() {
95 public short getRecircTable() {
99 public List<NxCtAction> getCtActions() {
104 public boolean equals(Object other) {
108 if (other == null || getClass() != other.getClass()) {
111 if (!super.equals(other)) {
115 ActionNxConntrack that = (ActionNxConntrack) other;
117 if (flags != that.flags) {
120 if (zoneSrc != that.zoneSrc) {
123 if (conntrackZone != that.conntrackZone) {
126 if (recircTable != that.recircTable) {
129 return ctActions.equals(that.ctActions);
133 public int hashCode() {
134 int result = super.hashCode();
135 result = 31 * result + flags;
136 result = 31 * result + (int) (zoneSrc ^ zoneSrc >>> 32);
137 result = 31 * result + conntrackZone;
138 result = 31 * result + recircTable;
139 result = 31 * result + ctActions.hashCode();
144 public String toString() {
145 return "ActionNxConntrack [flags=" + flags + ", zoneSrc=" + zoneSrc + ", conntrackZone=" + conntrackZone
146 + ", recircTable=" + recircTable + ", ctActions=" + ctActions + ", getActionKey()=" + getActionKey()
150 public interface NxCtAction {
151 CtActions buildCtActions();
154 public static class NxNat implements NxCtAction {
155 private final int flags;
156 private final int rangePresent;
157 private final IpAddress ipAddressMin;
158 private final IpAddress ipAddressMax;
159 private final int portMin;
160 private final int portMax;
162 public NxNat(int actionKey, int flags, int natType, IpAddress ipAddressMin,
163 IpAddress ipAddressMax,int portMin, int portMax) {
165 this.rangePresent = natType;
166 this.ipAddressMin = ipAddressMin;
167 this.ipAddressMax = ipAddressMax;
168 this.portMin = portMin;
169 this.portMax = portMax;
172 public int getFlags() {
176 public int getRangePresent() {
180 public IpAddress getIpAddressMin() {
184 public IpAddress getIpAddressMax() {
188 public int getPortMin() {
192 public int getPortMax() {
197 public CtActions buildCtActions() {
198 NxActionNatBuilder nxActionNatBuilder = new NxActionNatBuilder()
200 .setRangePresent(rangePresent)
201 .setIpAddressMin(ipAddressMin)
202 .setIpAddressMax(ipAddressMax)
204 .setPortMax(portMax);
206 CtActionsBuilder ctActionsBuilder = new CtActionsBuilder();
207 NxActionNatCaseBuilder caseBuilder = new NxActionNatCaseBuilder();
208 caseBuilder.setNxActionNat(nxActionNatBuilder.build());
209 ctActionsBuilder.setOfpactActions(caseBuilder.build());
210 return ctActionsBuilder.build();
214 public boolean equals(Object other) {
218 if (other == null || getClass() != other.getClass()) {
222 NxNat that = (NxNat) other;
224 if (flags != that.flags) {
227 if (rangePresent != that.rangePresent) {
230 if (ipAddressMin != null ? !ipAddressMin.equals(that.ipAddressMin) : that.ipAddressMin != null) {
233 if (ipAddressMax != null ? !ipAddressMax.equals(that.ipAddressMax) : that.ipAddressMax != null) {
236 if (portMin != that.portMin) {
239 return portMax == that.portMax;
243 public int hashCode() {
245 result = 31 * result + rangePresent;
246 result = 31 * result + ipAddressMin.hashCode();
247 result = 31 * result + ipAddressMax.hashCode();
248 result = 31 * result + portMin;
249 result = 31 * result + portMax;
254 public String toString() {
255 return "NxNat [flags=" + flags + ", rangePresent=" + rangePresent + ", ipAddressMin=" + ipAddressMin
256 + ", ipAddressMax=" + ipAddressMax + ", portMin=" + portMin + ", portMax=" + portMax + "]";
260 public static class NxCtMark implements NxCtAction {
261 private final long ctMark;
263 public NxCtMark(long ctMark) {
264 this.ctMark = ctMark;
268 public CtActions buildCtActions() {
269 NxActionCtMarkBuilder nxActionCtMarkBuilder = new NxActionCtMarkBuilder()
272 CtActionsBuilder ctActionsBuilder = new CtActionsBuilder();
273 NxActionCtMarkCaseBuilder caseBuilder = new NxActionCtMarkCaseBuilder();
274 caseBuilder.setNxActionCtMark(nxActionCtMarkBuilder.build());
275 ctActionsBuilder.setOfpactActions(caseBuilder.build());
276 return ctActionsBuilder.build();
280 public boolean equals(Object other) {
284 if (other == null || getClass() != other.getClass()) {
288 NxCtMark that = (NxCtMark) other;
290 return ctMark == that.ctMark;
294 public int hashCode() {
295 return 31 * (int) (ctMark ^ ctMark >>> 32);