Package org.onosproject.net.flow
Interface FlowRule
- 
- All Superinterfaces:
- PiTranslatable
 - All Known Subinterfaces:
- FlowEntry,- StoredFlowEntry,- TypedStoredFlowEntry
 - All Known Implementing Classes:
- DefaultFlowEntry,- DefaultFlowRule,- DefaultTypedFlowEntry
 
 public interface FlowRule extends PiTranslatable Represents a generalized match & action pair to be applied to an infrastructure device.
- 
- 
Nested Class SummaryNested Classes Modifier and Type Interface Description static interfaceFlowRule.BuilderA flowrule builder.static classFlowRule.FlowRemoveReasonReason for flow parameter received from switches.
 - 
Field SummaryFields Modifier and Type Field Description static IndexTableIdDEFAULT_TABLEstatic intMAX_PRIORITYstatic intMAX_TIMEOUTstatic intMIN_PRIORITY
 - 
Method SummaryAll Methods Instance Methods Abstract Methods Deprecated Methods Modifier and Type Method Description shortappId()Returns the application id of this flow.DeviceIddeviceId()Returns the identity of the device where this rule applies.booleanequals(Object obj)Equality for flow rules only considers 'match equality'.booleanexactMatch(FlowRule rule)Returns whether this flow rule is an exact match to the flow rule given in the argument.GroupIdgroupId()Returns the group id of this flow.inthardTimeout()Returns the hard timeout for this flow requested by an application.FlowIdid()Returns the ID of this flow.booleanisPermanent()Returns whether the flow is permanent i.e.intpriority()Returns the flow rule priority given in natural order; higher numbers mean higher priorities.FlowRule.FlowRemoveReasonreason()Returns the reason for the flow received from switches.TrafficSelectorselector()Returns the traffic selector that identifies what traffic this rule should apply to.TableIdtable()Returns the table identifier for this rule.inttableId()Deprecated.in Loon release (version 1.11.0).inttimeout()Returns the timeout for this flow requested by an application.TrafficTreatmenttreatment()Returns the traffic treatment that applies to selected traffic.
 
- 
- 
- 
Field Detail- 
DEFAULT_TABLEstatic final IndexTableId DEFAULT_TABLE 
 - 
MAX_TIMEOUTstatic final int MAX_TIMEOUT - See Also:
- Constant Field Values
 
 - 
MIN_PRIORITYstatic final int MIN_PRIORITY - See Also:
- Constant Field Values
 
 - 
MAX_PRIORITYstatic final int MAX_PRIORITY - See Also:
- Constant Field Values
 
 
- 
 - 
Method Detail- 
idFlowId id() Returns the ID of this flow.- Returns:
- the flow ID
 
 - 
appIdshort appId() Returns the application id of this flow.- Returns:
- an applicationId
 
 - 
groupIdGroupId groupId() Returns the group id of this flow.- Returns:
- an groupId
 
 - 
priorityint priority() Returns the flow rule priority given in natural order; higher numbers mean higher priorities.- Returns:
- flow rule priority
 
 - 
deviceIdDeviceId deviceId() Returns the identity of the device where this rule applies.- Returns:
- device identifier
 
 - 
selectorTrafficSelector selector() Returns the traffic selector that identifies what traffic this rule should apply to.- Returns:
- traffic selector
 
 - 
treatmentTrafficTreatment treatment() Returns the traffic treatment that applies to selected traffic.- Returns:
- traffic treatment
 
 - 
timeoutint timeout() Returns the timeout for this flow requested by an application.- Returns:
- integer value of the timeout
 
 - 
hardTimeoutint hardTimeout() Returns the hard timeout for this flow requested by an application. This parameter configure switch's flow hard timeout. In case of controller-switch connection lost, this variable can be useful.- Returns:
- integer value of the hard Timeout
 
 - 
reasonFlowRule.FlowRemoveReason reason() Returns the reason for the flow received from switches.- Returns:
- FlowRemoveReason value of reason
 
 - 
isPermanentboolean isPermanent() Returns whether the flow is permanent i.e. does not time out.- Returns:
- true if the flow is permanent, otherwise false
 
 - 
tableId@Deprecated int tableId() Deprecated.in Loon release (version 1.11.0). Usetable()instead.Returns the table id for this rule.- Returns:
- an integer.
 
 - 
tableTableId table() Returns the table identifier for this rule.- Returns:
- a table identifier.
 
 - 
equalsboolean equals(Object obj) Equality for flow rules only considers 'match equality'. This means that two flow rules with the same match conditions will be equal, regardless of the treatment or other characteristics of the flow.
 - 
exactMatchboolean exactMatch(FlowRule rule) Returns whether this flow rule is an exact match to the flow rule given in the argument.Exact match means that deviceId, priority, selector, tableId, flowId and treatment are equal. Note that this differs from the notion of object equality for flow rules, which does not consider the flowId or treatment when testing equality. - Parameters:
- rule- other rule to match against
- Returns:
- true if the rules are an exact match, otherwise false
 
 
- 
 
-