All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.xsocket.connection.IConnection Maven / Gradle / Ivy

/*
 * Copyright (c) xlightweb.org, 2006 - 2010. All rights reserved.
 *
 *  This library is free software; you can redistribute it and/or
 *  modify it under the terms of the GNU Lesser General Public
 *  License as published by the Free Software Foundation; either
 *  version 2.1 of the License, or (at your option) any later version.
 *
 *  This library is distributed in the hope that it will be useful,
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 *  Lesser General Public License for more details.
 *
 *  You should have received a copy of the GNU Lesser General Public
 *  License along with this library; if not, write to the Free Software
 *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 *
 * Please refer to the LGPL license at: http://www.gnu.org/copyleft/lesser.txt
 * The latest copy of this software may be found on http://www.xsocket.org/
 */
package org.xsocket.connection;

import java.io.Closeable;
import java.io.IOException;
import java.net.InetAddress;



/**
 * A connection (session) between two endpoints. It encapsulates the underlying socket channel. 

* * * @author [email protected] */ public interface IConnection extends Closeable { public static final String INITIAL_DEFAULT_ENCODING = "UTF-8"; public static final String SO_SNDBUF = "SOL_SOCKET.SO_SNDBUF"; public static final String SO_RCVBUF = "SOL_SOCKET.SO_RCVBUF"; public static final String SO_REUSEADDR = "SOL_SOCKET.SO_REUSEADDR"; public static final String SO_KEEPALIVE = "SOL_SOCKET.SO_KEEPALIVE"; public static final String SO_LINGER = "SOL_SOCKET.SO_LINGER"; public static final String TCP_NODELAY = "IPPROTO_TCP.TCP_NODELAY"; static final String SO_TIMEOUT = "SOL_SOCKET.SO_TIMEOUT"; public static final long MAX_TIMEOUT_MILLIS = Long.MAX_VALUE; public static final long DEFAULT_CONNECTION_TIMEOUT_MILLIS = MAX_TIMEOUT_MILLIS; public static final long DEFAULT_IDLE_TIMEOUT_MILLIS = MAX_TIMEOUT_MILLIS; public enum FlushMode { SYNC, ASYNC }; public static final FlushMode DEFAULT_FLUSH_MODE = FlushMode.SYNC; public static final boolean DEFAULT_AUTOFLUSH = true; /** * returns the id * * @return id */ String getId(); /** * returns true id connection is server side * * @return true, if is server side */ boolean isServerSide(); /** * returns, if the connection is open.

* * Please note, that a connection could be closed, but reading of already * received (and internally buffered) data would not fail. See also * {@link IDataHandler#onData(INonBlockingConnection)} * * * @return true if the connection is open */ boolean isOpen(); /** * returns the local port * * @return the local port */ int getLocalPort(); /** * returns the local address * * @return the local IP address or InetAddress.anyLocalAddress() if the socket is not bound yet. */ InetAddress getLocalAddress(); /** * returns the remote address * * @return the remote address */ InetAddress getRemoteAddress(); /** * returns the port of the remote end point * * @return the remote port */ int getRemotePort(); /** * returns the idle timeout in millis. * * @return idle timeout in millis */ long getIdleTimeoutMillis(); /** * sets the idle timeout in millis * * @param timeoutInSec idle timeout in millis */ void setIdleTimeoutMillis(long timeoutInMillis); /** * gets the connection timeout * * @return connection timeout */ long getConnectionTimeoutMillis(); /** * sets the max time for a connections. By * exceeding this time the connection will be * terminated * * @param timeoutSec the connection timeout in millis */ void setConnectionTimeoutMillis(long timeoutMillis); /** * returns the remaining time before a idle timeout occurs * * @return the remaining time */ long getRemainingMillisToIdleTimeout(); /** * returns the remaining time before a connection timeout occurs * * @return the remaining time */ long getRemainingMillisToConnectionTimeout(); /** * sets the value of a option.

* * A good article for tuning can be found here {@link http://www.onlamp.com/lpt/a/6324} * * @param name the name of the option * @param value the value of the option * @throws IOException In an I/O error occurs */ void setOption(String name, Object value) throws IOException; /** * returns the value of a option * * @param name the name of the option * @return the value of the option * @throws IOException In an I/O error occurs */ Object getOption(String name) throws IOException; /** * Returns an unmodifiable map of the options supported by this end point. * * The key in the returned map is the name of a option, and its value * is the type of the option value. The returned map will never contain null keys or values. * * @return An unmodifiable map of the options supported by this channel */ @SuppressWarnings("unchecked") java.util.Map getOptions(); /** * Attaches the given object to this connection * * @param obj The object to be attached; may be null * @return The previously-attached object, if any, otherwise null */ void setAttachment(Object obj); /** * Retrieves the current attachment. * * @return The object currently attached to this key, or null if there is no attachment */ Object getAttachment(); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy