blob: 1a28c2691030f34dc699e3bbbd4582b2929353f9 [file] [log] [blame]
/*
*
* 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;
/**
* Session
*
* Note that session level flow control is handled internally by Proton.
*/
public interface Session extends Endpoint
{
/**
* Returns a newly created sender endpoint
*/
public Sender sender(String name);
/**
* Returns a newly created receiver endpoint
*/
public Receiver receiver(String name);
public Session next(EnumSet<EndpointState> local, EnumSet<EndpointState> remote);
public Connection getConnection();
public int getIncomingCapacity();
public void setIncomingCapacity(int bytes);
public int getIncomingBytes();
public int getOutgoingBytes();
public long getOutgoingWindow();
/**
* Sets the outgoing window size.
*
* @param outgoingWindowSize the outgoing window size
*/
public void setOutgoingWindow(long outgoingWindowSize);
/**
* Sets the local session properties, to be conveyed to the peer via the Begin frame when
* attaching the session to the session.
*
* Must be called during session setup, i.e. before calling the {@link #open()} method.
*
* @param properties
* the properties map to send, or null for none.
*/
void setProperties(Map<Symbol, Object> properties);
/**
* Gets the local session properties.
*
* @return the properties map, or null if none was set.
*
* @see #setProperties(Map)
*/
Map<Symbol, Object> getProperties();
/**
* Gets the remote session properties, as conveyed from the peer via the Begin frame
* when opening the session.
*
* @return the properties Map conveyed by the peer, or null if there was none.
*/
Map<Symbol, Object> getRemoteProperties();
/**
* Sets the local session offered capabilities, to be conveyed to the peer via the Begin frame
* when opening the session.
*
* Must be called during session setup, i.e. before calling the {@link #open()} method.
*
* @param offeredCapabilities
* the offered capabilities array to send, or null for none.
*/
public void setOfferedCapabilities(Symbol[] offeredCapabilities);
/**
* Gets the local session offered capabilities.
*
* @return the offered capabilities array, or null if none was set.
*
* @see #setOfferedCapabilities(Symbol[])
*/
Symbol[] getOfferedCapabilities();
/**
* Gets the remote session offered capabilities, as conveyed from the peer via the Begin frame
* when opening the session.
*
* @return the offered capabilities array conveyed by the peer, or null if there was none.
*/
Symbol[] getRemoteOfferedCapabilities();
/**
* Sets the local session desired capabilities, to be conveyed to the peer via the Begin frame
* when opening the session.
*
* Must be called during session setup, i.e. before calling the {@link #open()} method.
*
* @param desiredCapabilities
* the desired capabilities array to send, or null for none.
*/
public void setDesiredCapabilities(Symbol[] desiredCapabilities);
/**
* Gets the local session desired capabilities.
*
* @return the desired capabilities array, or null if none was set.
*
* @see #setDesiredCapabilities(Symbol[])
*/
Symbol[] getDesiredCapabilities();
/**
* Gets the remote session desired capabilities, as conveyed from the peer via the Begin frame
* when opening the session.
*
* @return the desired capabilities array conveyed by the peer, or null if there was none.
*/
Symbol[] getRemoteDesiredCapabilities();
}