init
This commit is contained in:
222
java/org/apache/catalina/Server.java
Normal file
222
java/org/apache/catalina/Server.java
Normal file
@@ -0,0 +1,222 @@
|
||||
/*
|
||||
* 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.catalina;
|
||||
|
||||
import java.io.File;
|
||||
|
||||
import org.apache.catalina.deploy.NamingResourcesImpl;
|
||||
import org.apache.catalina.startup.Catalina;
|
||||
|
||||
/**
|
||||
* A <code>Server</code> element represents the entire Catalina
|
||||
* servlet container. Its attributes represent the characteristics of
|
||||
* the servlet container as a whole. A <code>Server</code> may contain
|
||||
* one or more <code>Services</code>, and the top level set of naming
|
||||
* resources.
|
||||
* <p>
|
||||
* Normally, an implementation of this interface will also implement
|
||||
* <code>Lifecycle</code>, such that when the <code>start()</code> and
|
||||
* <code>stop()</code> methods are called, all of the defined
|
||||
* <code>Services</code> are also started or stopped.
|
||||
* <p>
|
||||
* In between, the implementation must open a server socket on the port number
|
||||
* specified by the <code>port</code> property. When a connection is accepted,
|
||||
* the first line is read and compared with the specified shutdown command.
|
||||
* If the command matches, shutdown of the server is initiated.
|
||||
* <p>
|
||||
* <strong>NOTE</strong> - The concrete implementation of this class should
|
||||
* register the (singleton) instance with the <code>ServerFactory</code>
|
||||
* class in its constructor(s).
|
||||
*
|
||||
* @author Craig R. McClanahan
|
||||
*/
|
||||
public interface Server extends Lifecycle {
|
||||
|
||||
// ------------------------------------------------------------- Properties
|
||||
|
||||
/**
|
||||
* @return the global naming resources.
|
||||
*/
|
||||
public NamingResourcesImpl getGlobalNamingResources();
|
||||
|
||||
|
||||
/**
|
||||
* Set the global naming resources.
|
||||
*
|
||||
* @param globalNamingResources The new global naming resources
|
||||
*/
|
||||
public void setGlobalNamingResources
|
||||
(NamingResourcesImpl globalNamingResources);
|
||||
|
||||
|
||||
/**
|
||||
* @return the global naming resources context.
|
||||
*/
|
||||
public javax.naming.Context getGlobalNamingContext();
|
||||
|
||||
|
||||
/**
|
||||
* @return the port number we listen to for shutdown commands.
|
||||
*/
|
||||
public int getPort();
|
||||
|
||||
|
||||
/**
|
||||
* Set the port number we listen to for shutdown commands.
|
||||
*
|
||||
* @param port The new port number
|
||||
*/
|
||||
public void setPort(int port);
|
||||
|
||||
|
||||
/**
|
||||
* @return the address on which we listen to for shutdown commands.
|
||||
*/
|
||||
public String getAddress();
|
||||
|
||||
|
||||
/**
|
||||
* Set the address on which we listen to for shutdown commands.
|
||||
*
|
||||
* @param address The new address
|
||||
*/
|
||||
public void setAddress(String address);
|
||||
|
||||
|
||||
/**
|
||||
* @return the shutdown command string we are waiting for.
|
||||
*/
|
||||
public String getShutdown();
|
||||
|
||||
|
||||
/**
|
||||
* Set the shutdown command we are waiting for.
|
||||
*
|
||||
* @param shutdown The new shutdown command
|
||||
*/
|
||||
public void setShutdown(String shutdown);
|
||||
|
||||
|
||||
/**
|
||||
* @return the parent class loader for this component. If not set, return
|
||||
* {@link #getCatalina()} {@link Catalina#getParentClassLoader()}. If
|
||||
* catalina has not been set, return the system class loader.
|
||||
*/
|
||||
public ClassLoader getParentClassLoader();
|
||||
|
||||
|
||||
/**
|
||||
* Set the parent class loader for this server.
|
||||
*
|
||||
* @param parent The new parent class loader
|
||||
*/
|
||||
public void setParentClassLoader(ClassLoader parent);
|
||||
|
||||
|
||||
/**
|
||||
* @return the outer Catalina startup/shutdown component if present.
|
||||
*/
|
||||
public Catalina getCatalina();
|
||||
|
||||
/**
|
||||
* Set the outer Catalina startup/shutdown component if present.
|
||||
*
|
||||
* @param catalina the outer Catalina component
|
||||
*/
|
||||
public void setCatalina(Catalina catalina);
|
||||
|
||||
|
||||
/**
|
||||
* @return the configured base (instance) directory. Note that home and base
|
||||
* may be the same (and are by default). If this is not set the value
|
||||
* returned by {@link #getCatalinaHome()} will be used.
|
||||
*/
|
||||
public File getCatalinaBase();
|
||||
|
||||
/**
|
||||
* Set the configured base (instance) directory. Note that home and base
|
||||
* may be the same (and are by default).
|
||||
*
|
||||
* @param catalinaBase the configured base directory
|
||||
*/
|
||||
public void setCatalinaBase(File catalinaBase);
|
||||
|
||||
|
||||
/**
|
||||
* @return the configured home (binary) directory. Note that home and base
|
||||
* may be the same (and are by default).
|
||||
*/
|
||||
public File getCatalinaHome();
|
||||
|
||||
/**
|
||||
* Set the configured home (binary) directory. Note that home and base
|
||||
* may be the same (and are by default).
|
||||
*
|
||||
* @param catalinaHome the configured home directory
|
||||
*/
|
||||
public void setCatalinaHome(File catalinaHome);
|
||||
|
||||
|
||||
// --------------------------------------------------------- Public Methods
|
||||
|
||||
|
||||
/**
|
||||
* Add a new Service to the set of defined Services.
|
||||
*
|
||||
* @param service The Service to be added
|
||||
*/
|
||||
public void addService(Service service);
|
||||
|
||||
|
||||
/**
|
||||
* Wait until a proper shutdown command is received, then return.
|
||||
*/
|
||||
public void await();
|
||||
|
||||
|
||||
/**
|
||||
* Find the specified Service
|
||||
*
|
||||
* @param name Name of the Service to be returned
|
||||
* @return the specified Service, or <code>null</code> if none exists.
|
||||
*/
|
||||
public Service findService(String name);
|
||||
|
||||
|
||||
/**
|
||||
* @return the set of Services defined within this Server.
|
||||
*/
|
||||
public Service[] findServices();
|
||||
|
||||
|
||||
/**
|
||||
* Remove the specified Service from the set associated from this
|
||||
* Server.
|
||||
*
|
||||
* @param service The Service to be removed
|
||||
*/
|
||||
public void removeService(Service service);
|
||||
|
||||
|
||||
/**
|
||||
* @return the token necessary for operations on the associated JNDI naming
|
||||
* context.
|
||||
*/
|
||||
public Object getNamingToken();
|
||||
}
|
||||
Reference in New Issue
Block a user