package org.jboss.management.j2ee;
import org.jboss.deployment.DeploymentInfo;
import org.jboss.deployment.MainDeployerConstants;
import org.jboss.deployment.SubDeployer;
import org.jboss.logging.Logger;
import org.jboss.management.j2ee.factory.DefaultManagedObjectFactoryMap;
import org.jboss.management.j2ee.factory.ManagedObjectFactory;
import org.jboss.management.j2ee.factory.ManagedObjectFactoryMap;
import org.jboss.system.ServiceControllerMBean;
import org.jboss.system.ServiceMBean;
import javax.management.JMException;
import javax.management.MBeanException;
import javax.management.MBeanServer;
import javax.management.MalformedObjectNameException;
import javax.management.Notification;
import javax.management.NotificationListener;
import javax.management.ObjectName;
import java.net.InetAddress;
import java.util.Collection;
import java.util.Iterator;
import java.util.Set;
public class LocalJBossServerDomain
extends J2EEDomain
implements NotificationListener, LocalJBossServerDomainMBean
{
private static final Logger log =
Logger.getLogger(LocalJBossServerDomain.class);
private ObjectName mainDeployer;
private ObjectName sarDeployer;
private ObjectName earDeployer;
private ObjectName ejbDeployer;
private ObjectName rarDeployer;
private ObjectName jcaCMDeployer;
private ObjectName warDeployer;
private ObjectName jmsService;
private ObjectName jndiService;
private ObjectName jtaService;
private ObjectName userTxService;
private ObjectName mailService;
private ObjectName rmiiiopService;
private ObjectName jndiBindingService;
private ManagedObjectFactoryMap managedObjFactoryMap;
private Class managedObjFactoryMapClass = DefaultManagedObjectFactoryMap.class;
public LocalJBossServerDomain()
throws MalformedObjectNameException, InvalidParentException
{
super("jboss.management.local");
}
public ObjectName getMainDeployer()
{
return mainDeployer;
}
public void setMainDeployer(ObjectName name)
{
this.mainDeployer = name;
}
public ObjectName getSARDeployer()
{
return sarDeployer;
}
public void setSARDeployer(ObjectName name)
{
this.sarDeployer = name;
}
public ObjectName getEARDeployer()
{
return earDeployer;
}
public void setEARDeployer(ObjectName name)
{
this.earDeployer = name;
}
public ObjectName getEJBDeployer()
{
return ejbDeployer;
}
public void setEJBDeployer(ObjectName name)
{
this.ejbDeployer = name;
}
public ObjectName getRARDeployer()
{
return rarDeployer;
}
public void setRARDeployer(ObjectName name)
{
this.rarDeployer = name;
}
public ObjectName getCMDeployer()
{
return jcaCMDeployer;
}
public void setCMDeployer(ObjectName name)
{
this.jcaCMDeployer = name;
}
public ObjectName getWARDeployer()
{
return warDeployer;
}
public void setWARDeployer(ObjectName name)
{
this.warDeployer = name;
}
public ObjectName getJMSService()
{
return jmsService;
}
public void setJMSService(ObjectName name)
{
this.jmsService = name;
}
public ObjectName getJNDIService()
{
return jndiService;
}
public void setJNDIService(ObjectName name)
{
this.jndiService = name;
}
public ObjectName getJTAService()
{
return jtaService;
}
public void setJTAService(ObjectName name)
{
this.jtaService = name;
}
public ObjectName getMailService()
{
return mailService;
}
public void setMailService(ObjectName name)
{
this.mailService = name;
}
public ObjectName getUserTransactionService()
{
return userTxService;
}
public void setUserTransactionService(ObjectName name)
{
this.userTxService = name;
}
public ObjectName getRMI_IIOPService()
{
return rmiiiopService;
}
public void setRMI_IIOPService(ObjectName name)
{
this.rmiiiopService = name;
}
public ObjectName getJndiBindingService()
{
return jndiBindingService;
}
public void setJndiBindingService(ObjectName name)
{
this.jndiBindingService = name;
}
public Class getManagementObjFactoryMapClass()
{
return managedObjFactoryMapClass;
}
public void setManagementObjFactoryMapClass(Class cls)
{
this.managedObjFactoryMapClass = cls;
}
public void handleNotification(Notification msg, Object handback)
{
MBeanServer mbeanServer = getServer();
if (managedObjFactoryMap == null || mbeanServer == null)
{
return;
}
log.debug("handleNotification: " + msg);
String type = msg.getType();
Object userData = msg.getUserData();
try
{
if (type.equals(ServiceMBean.CREATE_EVENT))
{
ManagedObjectFactory factory = managedObjFactoryMap.getFactory(msg);
if (factory != null)
{
factory.create(mbeanServer, userData);
}
}
else if (type.equals(ServiceMBean.DESTROY_EVENT))
{
ManagedObjectFactory factory = managedObjFactoryMap.getFactory(msg);
if (factory != null)
{
factory.destroy(mbeanServer, userData);
}
}
else if (type.equals(SubDeployer.START_NOTIFICATION))
{
ManagedObjectFactory factory = managedObjFactoryMap.getFactory(msg);
if (factory != null)
{
factory.create(mbeanServer, userData);
}
}
else if (type.equals(SubDeployer.DESTROY_NOTIFICATION))
{
ManagedObjectFactory factory = managedObjFactoryMap.getFactory(msg);
if (factory != null)
{
DeploymentInfo di = (DeploymentInfo) msg.getUserData();
factory.destroy(mbeanServer, di);
}
}
else if (type.equals(MainDeployerConstants.ADD_DEPLOYER))
{
ObjectName deployerName = (ObjectName) msg.getUserData();
registerWithDeployer(deployerName);
}
else if (type.equals(MainDeployerConstants.REMOVE_DEPLOYER))
{
ObjectName deployerName = (ObjectName) msg.getUserData();
unregisterWithDeployer(deployerName);
}
}
catch (Throwable t)
{
log.debug("Failed to handle event", t);
}
}
public void postCreation()
{
MBeanServer server = getServer();
setupJ2EEMBeans(server);
registerWithController(server);
}
public String toString()
{
return "LocalJBossServerDomain { " + super.toString() + " } []";
}
protected void createService() throws Exception
{
populateFactoryMap();
MBeanServer server = getServer();
registerWithCurrentDeployers(server);
}
protected void destroyService() throws Exception
{
MBeanServer server = getServer();
unregisterWithCurrentDeployers(server);
cleanupLeftoverMBeans(server);
}
protected void preDestruction()
{
MBeanServer server = getServer();
unregisterWithController(server);
}
protected void registerWithDeployer(ObjectName deployerName)
{
log.debug("Registering as listener of deployer: " + deployerName);
try
{
getServer().addNotificationListener(deployerName, this, null, null);
}
catch (Exception e)
{
log.debug("Failed to register with deployer: " + deployerName, e);
}
}
protected void unregisterWithDeployer(ObjectName deployerName)
{
log.debug("Unregistering as listener of deployer: " + deployerName);
try
{
getServer().removeNotificationListener(deployerName, this);
}
catch (Exception e)
{
log.debug("Failed to unregister with deployer: " + deployerName, e);
}
}
private void populateFactoryMap() throws Exception
{
managedObjFactoryMap = (ManagedObjectFactoryMap) managedObjFactoryMapClass.newInstance();
managedObjFactoryMap.setSARDeployer(sarDeployer);
managedObjFactoryMap.setEARDeployer(earDeployer);
managedObjFactoryMap.setEJBDeployer(ejbDeployer);
managedObjFactoryMap.setRARDeployer(rarDeployer);
managedObjFactoryMap.setCMDeployer(jcaCMDeployer);
managedObjFactoryMap.setWARDeployer(warDeployer);
managedObjFactoryMap.setJMSResource(jmsService);
managedObjFactoryMap.setJNDIResource(jndiService);
managedObjFactoryMap.setJTAResource(jtaService);
managedObjFactoryMap.setJTAResource(userTxService);
managedObjFactoryMap.setJavaMailResource(mailService);
managedObjFactoryMap.setRMI_IIOPResource(rmiiiopService);
}
private void setupJ2EEMBeans(MBeanServer mbeanServer)
{
try
{
log.debug("setupJ2EEMBeans(), create J2EEServer instance");
Package pkg = Package.getPackage("org.jboss");
String vendor = pkg.getSpecificationVendor();
String version = pkg.getImplementationVersion();
J2EEServer j2eeServer = new J2EEServer("Local", getObjectName(),
vendor, version);
ObjectName lServer = j2eeServer.getObjectName();
mbeanServer.registerMBean(j2eeServer, lServer);
String hostName = "localhost";
try
{
InetAddress lLocalHost = InetAddress.getLocalHost();
hostName = lLocalHost.getHostName();
}
catch (Exception e)
{
}
JVM jvm = new JVM("localhost", lServer,
System.getProperty("java.version"),
System.getProperty("java.vendor"),
hostName);
ObjectName jvmName = jvm.getObjectName();
mbeanServer.registerMBean(jvm, jvmName);
}
catch (JMException jme)
{
log.debug("setupJ2EEMBeans - unexpected JMException", jme);
}
catch (Exception e)
{
log.debug("setupJ2EEMBeans - unexpected exception", e);
}
}
private void registerWithController(MBeanServer mbeanServer)
{
try
{
mbeanServer.addNotificationListener(ServiceControllerMBean.OBJECT_NAME,
this, null, null);
log.debug("Registered as listener of: " + ServiceControllerMBean.OBJECT_NAME);
}
catch (JMException jme)
{
log.debug("unexpected exception", jme);
}
catch (Exception e)
{
log.debug("unexpected exception", e);
}
}
private void unregisterWithController(MBeanServer mbeanServer)
{
try
{
mbeanServer.removeNotificationListener(ServiceControllerMBean.OBJECT_NAME, this);
log.debug("UNRegistered as listener of: " + ServiceControllerMBean.OBJECT_NAME);
}
catch (JMException jme)
{
log.debug("unexpected exception", jme);
}
catch (Exception e)
{
log.debug("unexpected exception", e);
}
}
private void registerWithCurrentDeployers(MBeanServer mbeanServer)
throws Exception
{
log.debug("Registering with all deployers, mainDeployer=" + mainDeployer);
mbeanServer.addNotificationListener(mainDeployer, this, null, null);
log.debug("Getting current deployers");
Object[] args = {};
String[] sig = {};
Collection deployers = (Collection) mbeanServer.invoke(mainDeployer,
"listDeployers", args, sig);
Iterator iter = deployers.iterator();
while (iter.hasNext())
{
ObjectName name = (ObjectName) iter.next();
registerWithDeployer(name);
}
}
private void unregisterWithCurrentDeployers(MBeanServer mbeanServer)
throws Exception
{
log.debug("Unregistering with all deployers, mainDeployer=" + mainDeployer);
mbeanServer.removeNotificationListener(mainDeployer, this);
log.debug("Getting current deployers");
Object[] args = {};
String[] sig = {};
Collection deployers = (Collection) mbeanServer.invoke(mainDeployer,
"listDeployers", args, sig);
Iterator iter = deployers.iterator();
while (iter.hasNext())
{
ObjectName name = (ObjectName) iter.next();
unregisterWithDeployer(name);
}
}
private void cleanupLeftoverMBeans(MBeanServer mbeanServer) throws Exception
{
ObjectName myName = getServiceName();
String domain = myName.getDomain();
ObjectName domainName = new ObjectName(domain + ":*");
Set domainNames = mbeanServer.queryNames(domainName, null);
log.debug("Found " + domainNames.size() + " domain mbeans");
Iterator domainIter = domainNames.iterator();
while (domainIter.hasNext())
{
try
{
ObjectName name = (ObjectName) domainIter.next();
if (name.equals(myName))
continue;
server.unregisterMBean(name);
}
catch (MBeanException ignore)
{
}
}
}
}