Class ClientStreamTracker
- java.lang.Object
- 
- org.apache.qpid.protonj2.client.impl.ClientStreamTracker
 
- 
- All Implemented Interfaces:
- StreamTracker,- Tracker
 
 public final class ClientStreamTracker extends java.lang.Object implements StreamTracker StreamTrackerimplementation that relies on the ClientTracker to handle the basicOutgoingDeliverymanagement.
- 
- 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description TrackerawaitAccepted()Waits if necessary for the remote to settle the sent delivery with anAccepteddisposition unless it has either already been settled and accepted or the original delivery was sent settled in which case the remote will not send aDispositionback.TrackerawaitAccepted(long timeout, java.util.concurrent.TimeUnit unit)Waits if necessary for the remote to settle the sent delivery with anAccepteddisposition unless it has either already been settled and accepted or the original delivery was sent settled in which case the remote will not send aDispositionback.StreamTrackerawaitSettlement()Waits if necessary for the remote to settle the sent delivery unless it has either already been settled or the original delivery was sent settled in which case the remote will not send aDispositionback.StreamTrackerawaitSettlement(long timeout, java.util.concurrent.TimeUnit unit)Waits if necessary for the remote to settle the sent delivery unless it has either already been settled or the original delivery was sent settled in which case the remote will not send aDispositionback.StreamTrackerdisposition(DeliveryState state, boolean settle)Updates the DeliveryState, and optionally settle the delivery as well.booleanremoteSettled()Gets whether the delivery was settled by the remote peer yet.DeliveryStateremoteState()Gets the current remote state for the tracked delivery.StreamSendersender()StreamTrackersettle()Settles the delivery locally, if notauto-settling.booleansettled()ClientFuture<Tracker>settlementFuture()Returns a future that can be used to wait for the remote to acknowledge receipt of a sent message by settling it.DeliveryStatestate()Gets the current local state for the tracked delivery.- 
Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 - 
Methods inherited from interface org.apache.qpid.protonj2.client.StreamTrackersettlementFuture
 - 
Methods inherited from interface org.apache.qpid.protonj2.client.TrackerawaitAccepted, awaitAccepted, remoteSettled, remoteState, settled, state
 
- 
 
- 
- 
- 
Method Detail- 
senderpublic StreamSender sender() Description copied from interface:StreamTracker- Specified by:
- senderin interface- StreamTracker
- Specified by:
- senderin interface- Tracker
- Returns:
- the Senderthat was used to send the delivery that is being tracked.
 
 - 
dispositionpublic StreamTracker disposition(DeliveryState state, boolean settle) throws ClientException Description copied from interface:TrackerUpdates the DeliveryState, and optionally settle the delivery as well.- Specified by:
- dispositionin interface- StreamTracker
- Specified by:
- dispositionin interface- Tracker
- Parameters:
- state- the delivery state to apply
- settle- whether to- Tracker.settle()the delivery at the same time
- Returns:
- this Trackerinstance.
- Throws:
- ClientException- if an error occurs while applying the given disposition
 
 - 
settlepublic StreamTracker settle() throws ClientException Description copied from interface:TrackerSettles the delivery locally, if notauto-settling.- Specified by:
- settlein interface- StreamTracker
- Specified by:
- settlein interface- Tracker
- Returns:
- this Trackerinstance.
- Throws:
- ClientException- if an error occurs while performing the settlement.
 
 - 
awaitSettlementpublic StreamTracker awaitSettlement() throws ClientException Description copied from interface:TrackerWaits if necessary for the remote to settle the sent delivery unless it has either already been settled or the original delivery was sent settled in which case the remote will not send aDispositionback.- Specified by:
- awaitSettlementin interface- StreamTracker
- Specified by:
- awaitSettlementin interface- Tracker
- Returns:
- this Trackerinstance.
- Throws:
- ClientException- if an error occurs while awaiting the remote settlement.
 
 - 
awaitSettlementpublic StreamTracker awaitSettlement(long timeout, java.util.concurrent.TimeUnit unit) throws ClientException Description copied from interface:TrackerWaits if necessary for the remote to settle the sent delivery unless it has either already been settled or the original delivery was sent settled in which case the remote will not send aDispositionback.- Specified by:
- awaitSettlementin interface- StreamTracker
- Specified by:
- awaitSettlementin interface- Tracker
- Parameters:
- timeout- the maximum time to wait for the remote to settle.
- unit- the time unit of the timeout argument.
- Returns:
- this Trackerinstance.
- Throws:
- ClientException- if an error occurs while awaiting the remote settlement.
 
 - 
statepublic DeliveryState state() Description copied from interface:TrackerGets the current local state for the tracked delivery.
 - 
remoteStatepublic DeliveryState remoteState() Description copied from interface:TrackerGets the current remote state for the tracked delivery.- Specified by:
- remoteStatein interface- Tracker
- Returns:
- the remote DeliveryStateonce a value is received from the remote.
 
 - 
remoteSettledpublic boolean remoteSettled() Description copied from interface:TrackerGets whether the delivery was settled by the remote peer yet.- Specified by:
- remoteSettledin interface- Tracker
- Returns:
- whether the delivery is remotely settled
 
 - 
settledpublic boolean settled() 
 - 
settlementFuturepublic ClientFuture<Tracker> settlementFuture() Description copied from interface:TrackerReturns a future that can be used to wait for the remote to acknowledge receipt of a sent message by settling it.- Specified by:
- settlementFuturein interface- Tracker
- Returns:
- a Futurethat can be used to wait on remote settlement.
 
 - 
awaitAcceptedpublic Tracker awaitAccepted() throws ClientException Description copied from interface:TrackerWaits if necessary for the remote to settle the sent delivery with anAccepteddisposition unless it has either already been settled and accepted or the original delivery was sent settled in which case the remote will not send aDispositionback.- Specified by:
- awaitAcceptedin interface- Tracker
- Returns:
- this Trackerinstance.
- Throws:
- ClientDeliveryStateException- if the remote sends a disposition other than Accepted.
- ClientException- if an error occurs while awaiting the remote settlement.
 
 - 
awaitAcceptedpublic Tracker awaitAccepted(long timeout, java.util.concurrent.TimeUnit unit) throws ClientException Description copied from interface:TrackerWaits if necessary for the remote to settle the sent delivery with anAccepteddisposition unless it has either already been settled and accepted or the original delivery was sent settled in which case the remote will not send aDispositionback.- Specified by:
- awaitAcceptedin interface- Tracker
- Parameters:
- timeout- the maximum time to wait for the remote to settle.
- unit- the time unit of the timeout argument.
- Returns:
- this Trackerinstance.
- Throws:
- ClientDeliveryStateException- if the remote sends a disposition other than Accepted.
- ClientException- if an error occurs while awaiting the remote settlement.
 
 
- 
 
-