fr.dyade.aaa.agent.SCAdminHelper Maven / Gradle / Ivy
/*
* Copyright (C) 2001 - 2012 ScalAgent Distributed Technologies
*
* 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 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.
*
* Initial developer(s): ScalAgent Distributed Technologies
* Contributor(s):
*/
package fr.dyade.aaa.agent;
import java.io.*;
import java.net.*;
import java.util.*;
import org.objectweb.util.monolog.api.BasicLevel;
import org.objectweb.util.monolog.api.Logger;
public class SCAdminHelper {
/** Hashtable that contain all Process
of running AgentServer */
protected Hashtable ASP = null;
protected Logger logmon = null;
public SCAdminHelper() {
// Get the logging monitor from current server MonologMonitorFactory
logmon = Debug.getLogger("fr.dyade.aaa.agent.SCAdmin");
ASP = new Hashtable();
}
/**
* Starts an agent server from its id.
*
* @param sid id of agent server to start
*/
public String startAgentServer(short sid) throws Exception {
return startAgentServer(sid, null, null, null, null);
}
/**
* Starts an agent server from its id using specific jvmargs.
*
* @param sid id of agent server to start
* @param jvmargs arguments to pass to the created java program
*/
public String startAgentServer(short sid,
String[] jvmargs) throws Exception {
return startAgentServer(sid, null, jvmargs, null, null);
}
/**
* Starts an agent server from its id using specific jvmargs and storage
* directory.
*
* @param sid id of agent server to start
* @param dir new working directory for the created agent server,
* current working directory if null
* @param jvmargs arguments to pass to the created java program
*/
public String startAgentServer(short sid,
File dir,
String[] jvmargs) throws Exception {
return startAgentServer(sid, dir, jvmargs, null, null);
}
/**
* Starts an agent server from its id using specific jvmargs and storage
* directory.
*
* @param sid id of agent server to start
* @param dir new working directory for the created agent server,
* current working directory if null
* @param jvmargs arguments to pass to the created java program
* @param args additional arguments to pass to the created java
* program
*/
public String startAgentServer(short sid,
File dir,
String[] jvmargs,
String[] args) throws Exception {
return startAgentServer(sid, dir, jvmargs, null, args);
}
/**
* Starts an agent server from its id.
*
* @param sid id of agent server to start
* @param dir new working directory for the created agent server,
* current working directory if null
* @param jvmargs arguments to pass to the created java program
* @param className the name of the main class
* @param args additional arguments to pass to the created java
* program
*/
public String startAgentServer(short sid,
File dir,
String[] jvmargs,
String className,
String[] args) throws Exception {
logmon.log(BasicLevel.DEBUG,
"SCAdmin: start AgentServer#" + sid);
Process p = (Process) ASP.get(new Short(sid));
if (p != null) {
try {
logmon.log(BasicLevel.DEBUG,
"SCAdmin: AgentServer#" + sid + " -> " + p.exitValue());
} catch (IllegalThreadStateException exc) {
// there is already another AS#sid running
logmon.log(BasicLevel.WARN,
"SCAdmin: AgentServer#" + sid + " already running.");
throw new IllegalStateException("AgentServer#" + sid +
" already running.");
}
}
p = execAgentServer(sid, dir, jvmargs, className, args);
ASP.put(new Short(sid), p);
String ret = waitServerStarting(p);
closeServerStream(p);
return ret;
}
/**
* Runs an agent server from its id and specific parameters.
*
* @param sid id of agent server to start
* @param dir new working directory for the created agent server,
* current working directory if null
* @param jvmargs arguments to pass to the created java program
* @param className the name of the main class
* @param args additional arguments to pass to the created java
* program
*/
public Process execAgentServer(short sid,
File dir,
String[] jvmargs,
String className,
String[] args) throws Exception {
logmon.log(BasicLevel.DEBUG,
"SCAdmin: run AgentServer#" + sid);
String javapath =
new File(new File(System.getProperty("java.home"), "bin"),
"java").getPath();
String classpath = System.getProperty("java.class.path");
Vector argv = new Vector();
argv.addElement(javapath);
argv.addElement("-classpath");
argv.addElement(classpath);
if (jvmargs != null) {
for (int i=0; i
© 2015 - 2025 Weber Informatics LLC | Privacy Policy