package org.jacorb.orb.factory; /* * Written for JacORB - a free Java ORB * * Copyright (C) 1999-2014 Gerald Brose / The JacORB Team. * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Library General Public * License as published by the Free Software Foundation; either * version 2 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 * Library General Public License for more details. * * You should have received a copy of the GNU Library General Public * License along with this library; if not, write to the Free * Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ /** * We follow the design of socket factories in package javax.net and * javax.net.ssl. Because this package isn't in the JDK yet we don't * extend its classes, but we are fully compatible. * * The basic idea is to setup policies related to the sockets being * constructed, in the factory: no special configuration is done in * the code which asks for the sockets. * * @author Andre Benvenuti */ import java.io.IOException; import java.net.InetAddress; import java.net.ServerSocket; /** * @author Gerald Brose */ public interface ServerSocketFactory { ServerSocket createServerSocket (int port) throws IOException; /** * Returns a server socket which uses all network interfaces on * the host, and is bound to the specified port. * * @param port - the port to listen to * @param backlog - how many connections are queued * @exception IOException - for networking errors */ ServerSocket createServerSocket(int port, int backlog ) throws IOException; /** * Returns a server socket which uses all network interfaces on * the host, is bound to a the specified port, and uses the * specified connection backlog. The socket is configured with the * socket options (such as accept timeout) given to this factory. * * @param port - the port to listen to * @param backlog - how many connections are queued * * @exception IOException - for networking errors */ ServerSocket createServerSocket(int port, int backlog, InetAddress ifAddress) throws IOException; }