mirror of
				https://github.com/opennetworkinglab/onos.git
				synced 2025-10-25 06:11:05 +02:00 
			
		
		
		
	reinstating the key field in FilterObjectives
Change-Id: I25f7d105edd562785cb213f747e7d9e0650f2635
This commit is contained in:
		
							parent
							
								
									1097c978fb
								
							
						
					
					
						commit
						a3a476d1c4
					
				| @ -375,6 +375,10 @@ public final class Criteria { | |||||||
|         return new OpticalSignalTypeCriterion(sigType, Type.OCH_SIGTYPE); |         return new OpticalSignalTypeCriterion(sigType, Type.OCH_SIGTYPE); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     public static Criterion dummy() { | ||||||
|  |         return new DummyCriterion(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     /** |     /** | ||||||
|      * Implementation of input port criterion. |      * Implementation of input port criterion. | ||||||
|      */ |      */ | ||||||
| @ -1729,4 +1733,15 @@ public final class Criteria { | |||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  | 
 | ||||||
|  |     /** | ||||||
|  |      * Dummy Criterion used with @see{FilteringObjective}. | ||||||
|  |      */ | ||||||
|  |     private static class DummyCriterion implements Criterion { | ||||||
|  | 
 | ||||||
|  |         @Override | ||||||
|  |         public Type type() { | ||||||
|  |             return Type.DUMMY; | ||||||
|  |         } | ||||||
|  |     } | ||||||
| } | } | ||||||
|  | |||||||
| @ -124,7 +124,12 @@ public interface Criterion { | |||||||
|         /** Optical channel signal ID (lambda). */ |         /** Optical channel signal ID (lambda). */ | ||||||
|         OCH_SIGID, |         OCH_SIGID, | ||||||
|         /** Optical channel signal type (fixed or flexible). */ |         /** Optical channel signal type (fixed or flexible). */ | ||||||
|         OCH_SIGTYPE |         OCH_SIGTYPE, | ||||||
|  | 
 | ||||||
|  |         /** | ||||||
|  |          * An empty criterion. | ||||||
|  |          */ | ||||||
|  |         DUMMY | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|  | |||||||
| @ -17,6 +17,7 @@ package org.onosproject.net.flowobjective; | |||||||
| 
 | 
 | ||||||
| import com.google.common.collect.ImmutableList; | import com.google.common.collect.ImmutableList; | ||||||
| import org.onosproject.core.ApplicationId; | import org.onosproject.core.ApplicationId; | ||||||
|  | import org.onosproject.net.flow.criteria.Criteria; | ||||||
| import org.onosproject.net.flow.criteria.Criterion; | import org.onosproject.net.flow.criteria.Criterion; | ||||||
| 
 | 
 | ||||||
| import java.util.Collection; | import java.util.Collection; | ||||||
| @ -37,13 +38,15 @@ public final class DefaultFilteringObjective implements FilteringObjective { | |||||||
|     private final int timeout; |     private final int timeout; | ||||||
|     private final ApplicationId appId; |     private final ApplicationId appId; | ||||||
|     private final int priority; |     private final int priority; | ||||||
|  |     private final Criterion key; | ||||||
|     private final List<Criterion> conditions; |     private final List<Criterion> conditions; | ||||||
|     private final int id; |     private final int id; | ||||||
|     private final Operation op; |     private final Operation op; | ||||||
| 
 | 
 | ||||||
|     private DefaultFilteringObjective(Type type, boolean permanent, int timeout, |     private DefaultFilteringObjective(Type type, boolean permanent, int timeout, | ||||||
|                                       ApplicationId appId, int priority, |                                       ApplicationId appId, int priority, Criterion key, | ||||||
|                                       List<Criterion> conditions, Operation op) { |                                       List<Criterion> conditions, Operation op) { | ||||||
|  |         this.key = key; | ||||||
|         this.type = type; |         this.type = type; | ||||||
|         this.permanent = permanent; |         this.permanent = permanent; | ||||||
|         this.timeout = timeout; |         this.timeout = timeout; | ||||||
| @ -52,10 +55,15 @@ public final class DefaultFilteringObjective implements FilteringObjective { | |||||||
|         this.conditions = conditions; |         this.conditions = conditions; | ||||||
|         this.op = op; |         this.op = op; | ||||||
| 
 | 
 | ||||||
|         this.id = Objects.hash(type, conditions, permanent, |         this.id = Objects.hash(type, key, conditions, permanent, | ||||||
|                                timeout, appId, priority); |                                timeout, appId, priority); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     @Override | ||||||
|  |     public Criterion key() { | ||||||
|  |         return key; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     @Override |     @Override | ||||||
|     public Type type() { |     public Type type() { | ||||||
|         return this.type; |         return this.type; | ||||||
| @ -115,6 +123,13 @@ public final class DefaultFilteringObjective implements FilteringObjective { | |||||||
|         private int timeout = DEFAULT_TIMEOUT; |         private int timeout = DEFAULT_TIMEOUT; | ||||||
|         private ApplicationId appId; |         private ApplicationId appId; | ||||||
|         private int priority = DEFAULT_PRIORITY; |         private int priority = DEFAULT_PRIORITY; | ||||||
|  |         private Criterion key = Criteria.dummy(); | ||||||
|  | 
 | ||||||
|  |         @Override | ||||||
|  |         public Builder withKey(Criterion key) { | ||||||
|  |             this.key = key; | ||||||
|  |             return this; | ||||||
|  |         } | ||||||
| 
 | 
 | ||||||
|         @Override |         @Override | ||||||
|         public Builder addCondition(Criterion criterion) { |         public Builder addCondition(Criterion criterion) { | ||||||
| @ -167,7 +182,7 @@ public final class DefaultFilteringObjective implements FilteringObjective { | |||||||
|             checkNotNull(appId, "Must supply an application id"); |             checkNotNull(appId, "Must supply an application id"); | ||||||
| 
 | 
 | ||||||
|             return new DefaultFilteringObjective(type, permanent, timeout, |             return new DefaultFilteringObjective(type, permanent, timeout, | ||||||
|                                                 appId, priority, conditions, |                                                 appId, priority, key, conditions, | ||||||
|                                                 Operation.ADD); |                                                 Operation.ADD); | ||||||
| 
 | 
 | ||||||
|         } |         } | ||||||
| @ -179,8 +194,9 @@ public final class DefaultFilteringObjective implements FilteringObjective { | |||||||
|             checkArgument(!conditions.isEmpty(), "Must have at least one condition."); |             checkArgument(!conditions.isEmpty(), "Must have at least one condition."); | ||||||
|             checkNotNull(appId, "Must supply an application id"); |             checkNotNull(appId, "Must supply an application id"); | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
|             return new DefaultFilteringObjective(type, permanent, timeout, |             return new DefaultFilteringObjective(type, permanent, timeout, | ||||||
|                                                  appId, priority, conditions, |                                                  appId, priority, key, conditions, | ||||||
|                                                  Operation.REMOVE); |                                                  Operation.REMOVE); | ||||||
| 
 | 
 | ||||||
|         } |         } | ||||||
|  | |||||||
| @ -40,6 +40,13 @@ public interface FilteringObjective extends Objective { | |||||||
|         DENY |         DENY | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     /** | ||||||
|  |      * Obtain the key for this filter. | ||||||
|  |      * | ||||||
|  |      * @return a criterion | ||||||
|  |      */ | ||||||
|  |     public Criterion key(); | ||||||
|  | 
 | ||||||
|     /** |     /** | ||||||
|      * Obtain this filtering type. |      * Obtain this filtering type. | ||||||
|      * @return the type |      * @return the type | ||||||
| @ -58,6 +65,14 @@ public interface FilteringObjective extends Objective { | |||||||
|      */ |      */ | ||||||
|     public interface Builder extends Objective.Builder { |     public interface Builder extends Objective.Builder { | ||||||
| 
 | 
 | ||||||
|  |         /** | ||||||
|  |          * Specify the key for the filter. | ||||||
|  |          * | ||||||
|  |          * @param key a criterion | ||||||
|  |          * @return a filter objective builder | ||||||
|  |          */ | ||||||
|  |         public Builder withKey(Criterion key); | ||||||
|  | 
 | ||||||
|         /** |         /** | ||||||
|          * Add a filtering condition. |          * Add a filtering condition. | ||||||
|          * |          * | ||||||
|  | |||||||
| @ -74,6 +74,7 @@ public final class CriterionCodec extends JsonCodec<Criterion> { | |||||||
|         formatMap.put(Criterion.Type.IPV6_EXTHDR, new FormatIpV6Exthdr()); |         formatMap.put(Criterion.Type.IPV6_EXTHDR, new FormatIpV6Exthdr()); | ||||||
|         formatMap.put(Criterion.Type.OCH_SIGID, new FormatOchSigId()); |         formatMap.put(Criterion.Type.OCH_SIGID, new FormatOchSigId()); | ||||||
|         formatMap.put(Criterion.Type.OCH_SIGTYPE, new FormatOchSigType()); |         formatMap.put(Criterion.Type.OCH_SIGTYPE, new FormatOchSigType()); | ||||||
|  |         formatMap.put(Criterion.Type.DUMMY, new FormatDummyType()); | ||||||
| 
 | 
 | ||||||
|         // Currently unimplemented |         // Currently unimplemented | ||||||
|         formatMap.put(Criterion.Type.ARP_OP, new FormatUnknown()); |         formatMap.put(Criterion.Type.ARP_OP, new FormatUnknown()); | ||||||
| @ -316,6 +317,17 @@ public final class CriterionCodec extends JsonCodec<Criterion> { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     private class FormatDummyType implements CriterionTypeFormatter { | ||||||
|  | 
 | ||||||
|  |         @Override | ||||||
|  |         public ObjectNode formatCriterion(ObjectNode root, Criterion criterion) { | ||||||
|  |             checkNotNull(criterion, "Criterion cannot be null"); | ||||||
|  | 
 | ||||||
|  |             return root.put("type", criterion.type().toString()); | ||||||
|  | 
 | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     @Override |     @Override | ||||||
|     public ObjectNode encode(Criterion criterion, CodecContext context) { |     public ObjectNode encode(Criterion criterion, CodecContext context) { | ||||||
|         checkNotNull(criterion, "Criterion cannot be null"); |         checkNotNull(criterion, "Criterion cannot be null"); | ||||||
| @ -331,4 +343,6 @@ public final class CriterionCodec extends JsonCodec<Criterion> { | |||||||
| 
 | 
 | ||||||
|         return formatter.formatCriterion(result, criterion); |         return formatter.formatCriterion(result, criterion); | ||||||
|     } |     } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| } | } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user