package org.jboss.axis.utils;
import org.jboss.axis.AxisEngine;
import org.jboss.axis.AxisFault;
import org.jboss.axis.Constants;
import org.jboss.axis.EngineConfiguration;
import org.jboss.axis.Handler;
import org.jboss.axis.MessageContext;
import org.jboss.axis.WSDDEngineConfiguration;
import org.jboss.axis.client.AxisClient;
import org.jboss.axis.deployment.wsdd.WSDDConstants;
import org.jboss.axis.deployment.wsdd.WSDDDeployment;
import org.jboss.axis.deployment.wsdd.WSDDDocument;
import org.jboss.axis.encoding.SerializationContext;
import org.jboss.axis.encoding.SerializationContextImpl;
import org.jboss.axis.server.AxisServer;
import org.jboss.logging.Logger;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.xml.sax.InputSource;
import java.io.FileInputStream;
import java.io.StringReader;
import java.io.StringWriter;
import java.net.InetAddress;
import java.net.UnknownHostException;
public class Admin
{
private static Logger log = Logger.getLogger(Admin.class.getName());
public Element[] AdminService(Element[] xml)
throws Exception
{
log.debug("Enter: Admin::AdminService");
MessageContext msgContext = MessageContext.getCurrentContext();
Document doc = process(msgContext, xml[0]);
Element[] result = new Element[1];
result[0] = doc.getDocumentElement();
log.debug("Exit: Admin::AdminService");
return result;
}
protected static Document processWSDD(MessageContext msgContext,
AxisEngine engine,
Element root)
throws Exception
{
Document doc = null;
String action = root.getLocalName();
if (action.equals("passwd"))
{
String newPassword = root.getFirstChild().getNodeValue();
engine.setAdminPassword(newPassword);
doc = XMLUtils.newDocument();
doc.appendChild(root = doc.createElementNS("", "Admin"));
root.appendChild(doc.createTextNode(Messages.getMessage("done00")));
return doc;
}
if (action.equals("quit"))
{
log.error(Messages.getMessage("quitRequest00"));
if (msgContext != null)
{
msgContext.setProperty(MessageContext.QUIT_REQUESTED, "true");
}
doc = XMLUtils.newDocument();
doc.appendChild(root = doc.createElementNS("", "Admin"));
root.appendChild(doc.createTextNode(Messages.getMessage("quit00", "")));
return doc;
}
if (action.equals("list"))
{
return listConfig(engine);
}
if (action.equals("clientdeploy"))
{
engine = engine.getClientEngine();
}
WSDDDocument wsddDoc = new WSDDDocument(root);
EngineConfiguration config = engine.getConfig();
if (config instanceof WSDDEngineConfiguration)
{
WSDDDeployment deployment =
((WSDDEngineConfiguration)config).getDeployment();
wsddDoc.deploy(deployment);
}
engine.refreshGlobalOptions();
engine.saveConfiguration();
doc = XMLUtils.newDocument();
doc.appendChild(root = doc.createElementNS("", "Admin"));
root.appendChild(doc.createTextNode(Messages.getMessage("done00")));
return doc;
}
protected void preProcessWSDD(MessageContext msgContext, AxisEngine engine, Element root)
{
}
public Document process(MessageContext msgContext, Element root)
throws Exception
{
Handler serviceHandler = msgContext.getService();
if (serviceHandler != null &&
!JavaUtils.isTrueExplicitly(serviceHandler.getOption("enableRemoteAdmin")))
{
String remoteIP = msgContext.getStrProp(Constants.MC_REMOTE_ADDR);
if (remoteIP != null &&
!remoteIP.equals("127.0.0.1"))
{
try
{
InetAddress myAddr = InetAddress.getLocalHost();
InetAddress remoteAddr =
InetAddress.getByName(remoteIP);
if (log.isDebugEnabled())
{
log.debug("Comparing remote caller " + remoteAddr + " to " + myAddr);
}
if (!myAddr.equals(remoteAddr))
{
log.error(Messages.getMessage("noAdminAccess01",
remoteAddr.toString()));
throw new AxisFault("Server.Unauthorized",
Messages.getMessage("noAdminAccess00"),
null, null);
}
}
catch (UnknownHostException e)
{
throw new AxisFault("Server.UnknownHost",
Messages.getMessage("unknownHost00"),
null, null);
}
}
}
String rootNS = root.getNamespaceURI();
AxisEngine engine = msgContext.getAxisEngine();
if (rootNS != null && rootNS.equals(WSDDConstants.URI_WSDD))
{
preProcessWSDD(msgContext, engine, root);
return processWSDD(msgContext, engine, root);
}
throw new Exception("FIXME");
}
public static Document listConfig(AxisEngine engine)
throws AxisFault
{
StringWriter writer = new StringWriter();
SerializationContext context = new SerializationContextImpl(writer, null);
context.setPretty(true);
try
{
EngineConfiguration config = engine.getConfig();
if (config instanceof WSDDEngineConfiguration)
{
WSDDDeployment deployment =
((WSDDEngineConfiguration)config).getDeployment();
deployment.writeToContext(context);
}
}
catch (Exception e)
{
throw new AxisFault(Messages.getMessage("noEngineWSDD"));
}
try
{
writer.close();
return XMLUtils.newDocument(new InputSource(new StringReader(writer.getBuffer().toString())));
}
catch (Exception e)
{
log.error("exception00", e);
return null;
}
}
public static void main(String args[]) throws Exception
{
int i = 0;
if (args.length < 2 || !(args[0].equals("client") ||
args[0].equals("server")))
{
log.error(Messages.getMessage("usage00", "Admin client|server <xml-file>"));
log.error(Messages.getMessage("where00", "<xml-file>"));
log.error("<deploy>");
log.error(" <handler name=a class=className/>");
log.error(" <chain name=a flow=\"a,b,c\" />");
log.error(" <chain name=a request=\"a,b,c\" pivot=\"d\"");
log.error(" response=\"e,f,g\" />");
log.error(" <service name=a handler=b />");
log.error("</deploy>");
log.error("<undeploy>");
log.error(" <handler name=a/>");
log.error(" <chain name=a/>");
log.error(" <service name=a/>");
log.error("</undeploy>");
log.error("<list/>");
throw new IllegalArgumentException(Messages.getMessage("usage00",
"Admin client|server <xml-file>"));
}
Admin admin = new Admin();
AxisEngine engine;
if (args[0].equals("client"))
engine = new AxisClient();
else
engine = new AxisServer();
engine.setShouldSaveConfig(true);
engine.init();
MessageContext msgContext = new MessageContext(engine);
try
{
for (i = 1; i < args.length; i++)
{
if (log.isDebugEnabled())
log.debug(Messages.getMessage("process00", args[i]));
Document doc = XMLUtils.newDocument(new FileInputStream(args[i]));
admin.process(msgContext, doc.getDocumentElement());
}
}
catch (Exception e)
{
log.error(Messages.getMessage("errorProcess00", args[i]), e);
throw e;
}
}
}