/*
* Copyright (C) 2009 eXo Platform SAS.
*
* This 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 (at your option) any later version.
*
* This software 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 software; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
* 02110-1301 USA, or see the FSF site: http://www.fsf.org.
*/
package org.exoplatform.management.jmx.impl;
import org.exoplatform.management.jmx.annotations.NameTemplate;
import org.exoplatform.management.spi.ManagedResource;
import org.exoplatform.management.spi.ManagementProvider;
import org.exoplatform.services.log.ExoLogger;
import org.exoplatform.services.log.Log;
import java.util.Hashtable;
import java.util.List;
import java.util.Map;
import javax.management.InstanceNotFoundException;
import javax.management.MBeanRegistrationException;
import javax.management.MBeanServer;
import javax.management.MBeanServerFactory;
import javax.management.MalformedObjectNameException;
import javax.management.ObjectName;
import javax.management.modelmbean.ModelMBeanInfo;
/**
* @author <a href="mailto:julien.viet@exoplatform.com">Julien Viet</a>
* @version $Revision$
*/
public class JMXManagementProvider implements ManagementProvider
{
/**
* The logger
*/
private static final Log LOG = ExoLogger.getLogger("exo.kernel.container.JMXManagementProvider");
/** . */
private final MBeanServer server;
public JMXManagementProvider()
{
this(MBeanServerFactory.createMBeanServer());
}
public JMXManagementProvider(MBeanServer server)
{
this.server = server;
}
public Object manage(ManagedResource context)
{
ExoModelMBean mbean = null;
try
{
ExoMBeanInfoBuilder infoBuilder = new ExoMBeanInfoBuilder(context.getMetaData());
ModelMBeanInfo info = infoBuilder.build();
mbean = new ExoModelMBean(context, context.getResource(), info);
}
catch (Exception e)
{
e.printStackTrace();
}
//
if (mbean != null)
{
ObjectName on = null;
PropertiesInfo oni = PropertiesInfo.resolve(context.getResource().getClass(), NameTemplate.class);
if (oni != null)
{
try
{
Map<String, String> foo = oni.resolve(context.getResource());
on = JMX.createObjectName("exo", foo);
}
catch (MalformedObjectNameException e)
{
e.printStackTrace();
}
}
if (on != null)
{
// Merge with the container hierarchy context
try
{
Map<String, String> props = new Hashtable<String, String>();
// Merge scoping properties
List<MBeanScopingData> list = context.getScopingData(MBeanScopingData.class);
for (MBeanScopingData scopingData : list)
{
props.putAll(scopingData);
}
// Julien : I know it's does not look great but it's necessary
// for compiling under Java 5 and Java 6 properly. The methods
// ObjectName#getKeyPropertyList() returns an Hashtable with Java 5
// and a Hashtable<String, String> with Java 6.
for (Object o : on.getKeyPropertyList().entrySet())
{
Map.Entry entry = (Map.Entry)o;
String key = (String)entry.getKey();
String value = (String)entry.getValue();
props.put(key, value);
}
//
on = JMX.createObjectName(on.getDomain(), props);
//
attemptToRegister(on, mbean);
//
return on;
}
catch (MalformedObjectNameException e)
{
e.printStackTrace();
}
}
}
//
return null;
}
private void attemptToRegister(ObjectName name, Object mbean)
{
synchronized (server)
{
if (server.isRegistered(name))
{
if (LOG.isTraceEnabled())
{
LOG.trace("The MBean '" + name + " has already been registered, it will be unregistered and then re-registered");
}
try
{
server.unregisterMBean(name);
}
catch (Exception e)
{
throw new RuntimeException("Failed to unregister MBean '" + name + " due to " + e.getMessage(), e);
}
}
try
{
server.registerMBean(mbean, name);
}
catch (Exception e)
{
throw new RuntimeException("Failed to register MBean '" + name + " due to " + e.getMessage(), e);
}
}
}
public void unmanage(Object key)
{
ObjectName name = (ObjectName)key;
try
{
server.unregisterMBean(name);
}
catch (InstanceNotFoundException e)
{
e.printStackTrace();
}
catch (MBeanRegistrationException e)
{
e.printStackTrace();
}
}
}