org.apache.qpid.proton.engine.Link Maven / Gradle / Ivy
/*
*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*
*/
package org.apache.qpid.proton.engine;
import java.util.EnumSet;
import java.util.Map;
import org.apache.qpid.proton.amqp.Symbol;
import org.apache.qpid.proton.amqp.transport.ReceiverSettleMode;
import org.apache.qpid.proton.amqp.transport.SenderSettleMode;
import org.apache.qpid.proton.amqp.transport.Source;
import org.apache.qpid.proton.amqp.transport.Target;
/**
* Link
*
* The settlement mode defaults are:
*
* Sender settle mode - {@link SenderSettleMode#MIXED}.
* Receiver settle mode - {@link ReceiverSettleMode#FIRST}
*
* TODO describe the application's responsibility to honour settlement.
*/
public interface Link extends Endpoint
{
/**
* Returns the name of the link
*
* @return the link name
*/
String getName();
/**
* Create a delivery object based on the specified tag and adds it to the
* this link's delivery list and its connection work list.
*
* TODO to clarify - this adds the delivery to the connection list. It is not yet
* clear why this is done or if it is useful for the application to be able to discover
* newly created deliveries from the {@link Connection#getWorkHead()}.
*
* @param tag a tag for the delivery
* @return a new Delivery object
*/
public Delivery delivery(byte[] tag);
/**
* Create a delivery object based on the specified tag. This form
* of the method is intended to allow the tag to be formed from a
* subsequence of the byte array passed in. This might allow more
* optimisation options in future but at present is not
* implemented.
*
* @param tag a tag for the delivery
* @param offset (currently ignored and must be 0)
* @param length (currently ignored and must be the length of the tag
array
* @return a Delivery object
*/
public Delivery delivery(byte[] tag, int offset, int length);
/**
* Returns the head delivery on the link.
*/
Delivery head();
/**
* Returns the current delivery
*/
Delivery current();
/**
* Attempts to advance the current delivery. Advances it to the next delivery if one exists, else null.
*
* The behaviour of this method is different for senders and receivers.
*
* @return true if it can advance, false if it cannot
*
* TODO document the meaning of the return value more fully. Currently Senderimpl only returns false if there is no current delivery
*/
boolean advance();
Source getSource();
Target getTarget();
/**
* Sets the source for this link.
*
* The initiator of the link must always provide a Source.
*
* An application responding to the creation of the link should perform an application
* specific lookup on the {@link #getRemoteSource()} to determine an actual Source. If it
* failed to determine an actual source, it should set null, and then go on to {@link #close()}
* the link.
*
* @see "AMQP Spec 1.0 section 2.6.3"
*/
void setSource(Source address);
/**
* Expected to be used in a similar manner to {@link #setSource(Source)}
*/
void setTarget(Target address);
/**
* @see #setSource(Source)
*/
Source getRemoteSource();
/**
* @see #setTarget(Target)
*/
Target getRemoteTarget();
public Link next(EnumSet local, EnumSet remote);
public int getCredit();
public int getQueued();
public int getUnsettled();
public Session getSession();
SenderSettleMode getSenderSettleMode();
/**
* Sets the sender settle mode.
*
* Should only be called during link set-up, i.e. before calling {@link #open()}.
*
* If this endpoint is the initiator of the link, this method can be used to set a value other than
* the default.
*
* If this endpoint is not the initiator, this method should be used to set a local value. According
* to the AMQP spec, the application may choose to accept the sender's suggestion
* (accessed by calling {@link #getRemoteSenderSettleMode()}) or choose another value. The value
* has no effect on Proton, but may be useful to the application at a later point.
*
* In order to be AMQP compliant the application is responsible for honouring the settlement mode. See {@link Link}.
*/
void setSenderSettleMode(SenderSettleMode senderSettleMode);
/**
* @see #setSenderSettleMode(SenderSettleMode)
*/
SenderSettleMode getRemoteSenderSettleMode();
ReceiverSettleMode getReceiverSettleMode();
/**
* Sets the receiver settle mode.
*
* Used in analogous way to {@link #setSenderSettleMode(SenderSettleMode)}
*/
void setReceiverSettleMode(ReceiverSettleMode receiverSettleMode);
/**
* @see #setReceiverSettleMode(ReceiverSettleMode)
*/
ReceiverSettleMode getRemoteReceiverSettleMode();
/**
* TODO should this be part of the interface?
*/
@Deprecated
void setRemoteSenderSettleMode(SenderSettleMode remoteSenderSettleMode);
/**
* Gets the local link properties.
*
* @see #setProperties(Map)
*/
Map getProperties();
/**
* Sets the local link properties, to be conveyed to the peer via the Attach frame when
* attaching the link to the session.
*
* Must be called during link setup, i.e. before calling the {@link #open()} method.
*/
void setProperties(Map properties);
/**
* Gets the remote link properties, as conveyed from the peer via the Attach frame
* when attaching the link to the session.
*
* @return the properties Map conveyed by the peer, or null if there was none.
*/
Map getRemoteProperties();
public int drained();
public int getRemoteCredit();
public boolean getDrain();
public void detach();
public boolean detached();
}