/*
* 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 samples.util;
import org.apache.axis2.clustering.ClusteringAgent;
import org.apache.axis2.context.ConfigurationContext;
import org.apache.axis2.context.ConfigurationContextFactory;
import org.apache.axis2.description.TransportInDescription;
import org.apache.axis2.engine.ListenerManager;
import org.apache.axis2.util.CommandLineOption;
import org.apache.axis2.util.CommandLineOptionParser;
import org.apache.axis2.util.OptionsValidator;
//import org.apache.axis2.clustering.ClusteringAgent;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import java.io.File;
import java.util.List;
import java.util.Map;
public class SampleAxis2ServerManager {
private static final Log log = LogFactory.getLog(SampleAxis2ServerManager.class);
private static SampleAxis2ServerManager ourInstance = new SampleAxis2ServerManager();
public static final int DEFAULT_PORT = 9000;
private ConfigurationContext configctx;
private ListenerManager listenerManager;
public static SampleAxis2ServerManager getInstance() {
return ourInstance;
}
private SampleAxis2ServerManager() {
}
public void start(String[] args) throws Exception {
String repoLocation = null;
String confLocation = null;
CommandLineOptionParser optionsParser = new CommandLineOptionParser(args);
List invalidOptionsList = optionsParser.getInvalidOptions(new OptionsValidator() {
public boolean isInvalid(CommandLineOption option) {
String optionType = option.getOptionType();
return !("repo".equalsIgnoreCase(optionType) || "conf"
.equalsIgnoreCase(optionType));
}
});
if ((invalidOptionsList.size() > 0) || (args.length > 4)) {
printUsage();
}
Map optionsMap = optionsParser.getAllOptions();
CommandLineOption repoOption = (CommandLineOption) optionsMap
.get("repo");
CommandLineOption confOption = (CommandLineOption) optionsMap
.get("conf");
log.info("[SimpleAxisServer] Starting");
if (repoOption != null) {
repoLocation = repoOption.getOptionValue();
System.out.println("[SimpleAxisServer] Using the Axis2 Repository : "
+ new File(repoLocation).getAbsolutePath());
}
if (confOption != null) {
confLocation = confOption.getOptionValue();
System.out
.println("[SimpleAxisServer] Using the Axis2 Configuration File : "
+ new File(confLocation).getAbsolutePath());
}
try {
configctx = ConfigurationContextFactory
.createConfigurationContextFromFileSystem(repoLocation,
confLocation);
configurePort(configctx);
// Need to initialize the cluster manager at last since we are changing the servers
// HTTP/S ports above. In the axis2.xml file, we need to set the "AvoidInitiation" param
// to "true"
ClusteringAgent clusteringAgent =
configctx.getAxisConfiguration().getClusteringAgent();
if(clusteringAgent != null) {
clusteringAgent.setConfigurationContext(configctx);
clusteringAgent.init();
}
// Finally start the transport listeners
listenerManager = new ListenerManager();
listenerManager.init(configctx);
listenerManager.start();
log.info("[SimpleAxisServer] Started");
} catch (Throwable t) {
log.fatal("[SimpleAxisServer] Shutting down. Error starting SimpleAxisServer", t);
System.exit(1); // must stop application
}
}
public void stop() throws Exception {
if (listenerManager != null) {
listenerManager.stop();
listenerManager.destroy();
}
//we need to call this method to clean the team fils we created.
if (configctx != null) {
configctx.terminate();
}
}
private void configurePort(ConfigurationContext configCtx) {
TransportInDescription trsIn = configCtx.getAxisConfiguration().getTransportsIn().get("http");
if (trsIn != null) {
String port = System.getProperty("http_port");
if (port != null) {
try {
new Integer(port);
trsIn.getParameter("port").setValue(port);
} catch (NumberFormatException e) {
log.error("Given port is not a valid integer. Using 9000 for port.");
trsIn.getParameter("port").setValue("9000");
}
} else {
trsIn.getParameter("port").setValue("9000");
}
}
TransportInDescription httpsTrsIn = configCtx.getAxisConfiguration().
getTransportsIn().get("https");
if (httpsTrsIn != null) {
String port = System.getProperty("https_port");
if (port != null) {
try {
new Integer(port);
httpsTrsIn.getParameter("port").setValue(port);
} catch (NumberFormatException e) {
log.error("Given port is not a valid integer. Using 9000 for port.");
httpsTrsIn.getParameter("port").setValue("9002");
}
} else {
httpsTrsIn.getParameter("port").setValue("9002");
}
}
}
public static void printUsage() {
System.out.println("Usage: SampleAxisServer -repo <repository> -conf <axis2 configuration file>");
System.out.println();
System.exit(1);
}
}