001/* 002 * Licensed to the Apache Software Foundation (ASF) under one or more 003 * contributor license agreements. See the NOTICE file distributed with 004 * this work for additional information regarding copyright ownership. 005 * The ASF licenses this file to You under the Apache License, Version 2.0 006 * (the "License"); you may not use this file except in compliance with 007 * the License. You may obtain a copy of the License at 008 * 009 * http://www.apache.org/licenses/LICENSE-2.0 010 * 011 * Unless required by applicable law or agreed to in writing, software 012 * distributed under the License is distributed on an "AS IS" BASIS, 013 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 014 * See the License for the specific language governing permissions and 015 * limitations under the License. 016 */ 017 018package org.apache.commons.daemon; 019 020/** 021 * Provides support for native daemon invocation. Using 022 * a platform dependant helper program, classes that implement the 023 * {@code Daemon} interface can be initialized, started and 024 * stopped according to the conventions of the underlying operating 025 * system. 026 * <p> 027 * Implementors of this interface must also provide a public constructor 028 * with no arguments so that instances can be created in an automated 029 * fashion. 030 * </p> 031 */ 032public interface Daemon 033{ 034 035 /** 036 * Initializes this {@code Daemon} instance. 037 * <p> 038 * This method gets called once the JVM process is created and the 039 * {@code Daemon} instance is created thru its empty public 040 * constructor. 041 * </p> 042 * <p> 043 * Under certain operating systems (typically Unix based operating 044 * systems) and if the native invocation framework is configured to do 045 * so, this method might be called with <em>super-user</em> privileges. 046 * </p> 047 * <p> 048 * For example, it might be wise to create {@code ServerSocket} 049 * instances within the scope of this method, and perform all operations 050 * requiring <em>super-user</em> privileges in the underlying operating 051 * system. 052 * </p> 053 * <p> 054 * Apart from set up and allocation of native resources, this method 055 * must not start the actual operation of the {@code Daemon} (such 056 * as starting threads calling the {@code ServerSocket.accept()} 057 * method) as this would impose some serious security hazards. The 058 * start of operation must be performed in the {@code start()} 059 * method. 060 * </p> 061 * 062 * @param context A {@code DaemonContext} object used to 063 * communicate with the container. 064 * @throws DaemonInitException An exception that prevented 065 * initialization where you want to display a nice message to the user, 066 * rather than a stack trace. 067 * @throws Exception Any exception preventing a successful 068 * initialization. 069 */ 070 void init(DaemonContext context) 071 throws DaemonInitException, Exception; 072 073 /** 074 * Starts the operation of this {@code Daemon} instance. This 075 * method is to be invoked by the environment after the init() 076 * method has been successfully invoked and possibly the security 077 * level of the JVM has been dropped. Implementors of this 078 * method are free to start any number of threads, but need to 079 * return control after having done that to enable invocation of 080 * the stop()-method. 081 * 082 * @throws Exception If the start was not successful 083 */ 084 void start() 085 throws Exception; 086 087 /** 088 * Stops the operation of this {@code Daemon} instance. Note 089 * that the proper place to free any allocated resources such as 090 * sockets or file descriptors is in the destroy method, as the 091 * container may restart the Daemon by calling start() after 092 * stop(). 093 * 094 * @throws Exception If the stop was not successful 095 */ 096 void stop() 097 throws Exception; 098 099 /** 100 * Frees any resources allocated by this daemon such as file 101 * descriptors or sockets. This method gets called by the container 102 * after stop() has been called, before the JVM exits. The Daemon 103 * cannot be restarted after this method has been called without a 104 * new call to the init() method. 105 */ 106 void destroy(); 107} 108