/*
* Copyright 2000-2001,2004 The Apache Software Foundation.
*
* Licensed 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.jetspeed.services.daemonfactory;
import org.apache.jetspeed.daemon.Daemon;
import org.apache.jetspeed.daemon.DaemonEntry;
import org.apache.jetspeed.daemon.DaemonContext;
import org.apache.jetspeed.daemon.DaemonException;
import org.apache.jetspeed.daemon.DaemonNotFoundException;
import org.apache.turbine.services.TurbineServices;
/**
@author <a href="mailto:burton@apache.org">Kevin A. Burton</a>
@version $Id: DaemonFactory.java,v 1.4 2004/02/23 03:29:24 jford Exp $
*/
public class DaemonFactory {
protected static final DaemonFactoryService getService() {
return (DaemonFactoryService)TurbineServices
.getInstance()
.getService(DaemonFactoryService.SERVICE_NAME);
}
/**
<p>
Starts any daemons that need processing.
</p>
<p>
This should be called right after init() so that any daemons that need to be
started will be. If you need to do any per-daemon initialization then do so
before calling start()
</p>
*/
public static void start() {
getService().start();
}
/**
Allows a Daemon to define its Thread priority through a factory. The Thread
that this object should return should be an implementation of itself.
*/
public static Daemon getDaemon( DaemonEntry entry ) throws DaemonException {
return getService().getDaemon( entry );
}
/**
Get a daemon with the given classname.
@see #getDaemon( DaemonEntry entry )
*/
public static Daemon getDaemon( String classname ) throws DaemonException {
return getService().getDaemon( classname );
}
/**
*/
public static DaemonContext getDaemonContext() {
return getService().getDaemonContext();
}
/**
Kicks of processing of a Daemon. Does the same thing as getDaemon() but
also creates a thread and runs the daemon.
*/
public static void process( DaemonEntry entry ) throws DaemonException {
getService().process( entry );
}
/**
*/
public static int getStatus(DaemonEntry entry) {
return getService().getStatus( entry );
}
/**
Get the last known result of the given DaemonEntry's processing
*/
public static int getResult(DaemonEntry entry) {
return getService().getResult( entry );
}
/**
Get the last known message of the given DaemonEntry's processing
*/
public static String getMessage( DaemonEntry entry ) {
return getService().getMessage( entry );
}
/**
Get the current known DaemonEntries within the DaemonFactory
*/
public static DaemonEntry[] getDaemonEntries() {
return getService().getDaemonEntries();
}
/**
Given the name of a DaemonEntry... get it from the DaemonFactory
*/
public static DaemonEntry getDaemonEntry(String name)
throws DaemonNotFoundException {
return getService().getDaemonEntry( name );
}
}