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

org.xsocket.connection.IServer 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;
import java.util.Map;
import java.util.concurrent.Executor;

import org.xsocket.connection.IConnection.FlushMode;






/**
 * A server accepts new incoming connections, and delegates the handling of the
 * {@link INonBlockingConnection} to the assigned handler.
 *
 * The server includes dispatchers, which are responsible to perform the
 * socket I/O operations. A connection is assigned to one dispatcher. 
* To handle application-relevant events like onData, * onClose or onConnect the appropriated callback method * of the assigned {@link IHandler} will be called. The supported callback * methods of the handler will be analyzed by using reflection during the server start-up * phase. The callback method will be marked by implementing the specific interface * like {@link IDataHandler} or {@link IConnectHandler}. Often a * handler will implement several handler interfaces.
*
* E.g. *
 *   ...
 *   IServer smtpServer = new Server(25, new SmtpProtcolHandler());
 *   
 *   smtpServer.start();
 *   ...
 *
 *
 *   // Handler definition
 *   class SmtpProtcolHandler implements IDataHandler, IConnectHandler {
 *
 *      SessionData sessionData = (SessionData) connection.getAttachment();
 *      
 *      String cmd = connection.readStringByDelimiter("\r\n").toUpperCase();
 *      
 *      if (cmd.startsWith("HELO")) {
 *         connection.write("250 SMTP Service\r\n");
 *         
 *      } else if(cmd.equals("DATA")) {
 *         String msgId = connection.getId() + "." + sessionData.nextId();
 *         File msgFile = new File(msgFileDir + File.separator + msgId + ".msg");
 *         
 *         connection.setHandler(new DataHandler(msgFile, this));
 *         connection.write("354 Enter message, ending with \".\"\r\n");
 *         
 *      } else {
 *       
 *         ...         
 *      }
 *      
 *      ...
 *   }
 * 
* * * @author [email protected] */ public interface IServer extends Runnable, Closeable { /** * the default idle timeout */ public static final int DEFAULT_IDLE_TIMEOUT_SEC = 1 * 60 * 60; // one hour /** * the default connection timeout */ public static final int DEFAULT_CONNECTION_TIMEOUT_SEC = Integer.MAX_VALUE; // no timeout public static final String SO_RCVBUF = IConnection.SO_RCVBUF; public static final String SO_REUSEADDR = IConnection.SO_REUSEADDR; public static final int DEFAULT_READ_TRANSFER_PREALLOCATION_SIZE = 65536; public static final int DEFAULT_READ_TRANSFER_PREALLOCATION_MIN_SIZE = 64; public static final boolean DEFAULT_READ_TRANSFER_USE_DIRECT = true; /** * signals, if service is running * * @return true, if the server is running */ boolean isOpen(); /** * starts the given server within a dedicated thread. This method blocks * until the server is open. * * @throws SocketTimeoutException is the timeout has been reached */ void start() throws IOException; /** * 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); /** * set the send delay time for a connection. Data to write will be buffered * internally and be written to the underlying subsystem * based on the given write rate. * The write methods will not block for this time.
* * By default the write transfer rate is set with UNLIMITED

* * Reduced write transfer is only supported for FlushMode.ASYNC. see * {@link INonBlockingConnection#setFlushmode(org.xsocket.connection.IConnection.FlushMode))} * * @param bytesPerSecond the transfer rate of the outgoing data * @throws IOException If some other I/O error occurs */ void setWriteTransferRate(int bytesPerSecond) throws IOException; /** * set the read rate. By default the read transfer rate is set with UNLIMITED

* * @param bytesPerSecond the transfer rate of the outgoing data * @throws IOException If some other I/O error occurs */ // public void setReadTransferRate(int bytesPerSecond) throws IOException; /** * get the server port * * @return the server port */ int getLocalPort(); /** * return the worker pool * * @return the worker pool */ Executor getWorkerpool(); /** * sets the worker pool * @param workerpool the workerpool */ void setWorkerpool(Executor workerpool); /** * gets the handler * @return the handler */ IHandler getHandler(); /** * * sets the flush mode for new connections. See {@link INonBlockingConnection#setFlushmode(FlushMode)} * for more information * * @param flusmode the flush mode */ void setFlushmode(FlushMode flusmode); /** * return the flush mode for new connections * * @return the flush mode */ FlushMode getFlushmode(); /** * set autoflush for new connections. See {@link IReadWriteableConnection#setAutoflush(boolean)} * for more information * * @param autoflush true if autoflush should be activated */ void setAutoflush(boolean autoflush); /** * get autoflush. See {@link IReadWriteableConnection#setAutoflush(boolean)} * for more information * * @return true, if autoflush is activated */ boolean getAutoflush(); /** * adds a listener * @param listener gthe listener to add */ void addListener(IServerListener listener); /** * removes a listener * @param listener the listener to remove * @return true, is the listener has been removed */ boolean removeListener(IServerListener listener); /** * get the local address * @return the local address */ InetAddress getLocalAddress(); /** * returns the vlaue 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; /** * set the log message, which will be printed out during the start up * * @param message the startUp log message */ void setStartUpLogMessage(String message); /** * returns the startUp log message * * @return the startUp log message */ String getStartUpLogMessage(); /** * Returns an unmodifiable map of the options supported by this endpont. * * 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") Map getOptions(); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy