2010-10-12 09:16:40 +02:00
|
|
|
/*
|
|
|
|
|
* To change this template, choose Tools | Templates
|
|
|
|
|
* and open the template in the editor.
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2010-10-31 13:07:43 +01:00
|
|
|
package sonia.scm.web.plugin;
|
2010-10-12 09:16:40 +02:00
|
|
|
|
|
|
|
|
//~--- non-JDK imports --------------------------------------------------------
|
|
|
|
|
|
2010-10-16 11:03:54 +02:00
|
|
|
import org.slf4j.Logger;
|
|
|
|
|
import org.slf4j.LoggerFactory;
|
|
|
|
|
|
2010-10-12 09:16:40 +02:00
|
|
|
//~--- JDK imports ------------------------------------------------------------
|
|
|
|
|
|
|
|
|
|
import java.io.IOException;
|
|
|
|
|
|
|
|
|
|
import java.net.URL;
|
|
|
|
|
|
|
|
|
|
import java.util.Enumeration;
|
2010-10-31 13:07:43 +01:00
|
|
|
import java.util.LinkedHashSet;
|
2010-10-12 09:16:40 +02:00
|
|
|
import java.util.Set;
|
|
|
|
|
|
|
|
|
|
import javax.xml.bind.JAXB;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
*
|
|
|
|
|
* @author Sebastian Sdorra
|
|
|
|
|
*/
|
|
|
|
|
public class SCMPluginManager
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
/** Field description */
|
|
|
|
|
public static final String PATH_PLUGINCONFIG = "META-INF/scm/plugin.xml";
|
|
|
|
|
|
|
|
|
|
/** Field description */
|
|
|
|
|
private static final Logger logger =
|
2010-10-16 11:03:54 +02:00
|
|
|
LoggerFactory.getLogger(SCMPluginManager.class);
|
2010-10-12 09:16:40 +02:00
|
|
|
|
|
|
|
|
//~--- methods --------------------------------------------------------------
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Method description
|
|
|
|
|
*
|
|
|
|
|
*
|
|
|
|
|
* @throws IOException
|
|
|
|
|
*/
|
|
|
|
|
public void load() throws IOException
|
|
|
|
|
{
|
|
|
|
|
ClassLoader classLoader = Thread.currentThread().getContextClassLoader();
|
|
|
|
|
|
|
|
|
|
if (classLoader == null)
|
|
|
|
|
{
|
|
|
|
|
classLoader = SCMPluginManager.class.getClassLoader();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
load(classLoader);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Method description
|
|
|
|
|
*
|
|
|
|
|
*
|
|
|
|
|
* @param classLoader
|
|
|
|
|
*
|
|
|
|
|
* @throws IOException
|
|
|
|
|
*/
|
|
|
|
|
public void load(ClassLoader classLoader) throws IOException
|
|
|
|
|
{
|
|
|
|
|
Enumeration<URL> urlEnum = classLoader.getResources(PATH_PLUGINCONFIG);
|
|
|
|
|
|
|
|
|
|
if (urlEnum != null)
|
|
|
|
|
{
|
|
|
|
|
while (urlEnum.hasMoreElements())
|
|
|
|
|
{
|
|
|
|
|
URL url = urlEnum.nextElement();
|
|
|
|
|
|
|
|
|
|
loadPlugin(url);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//~--- get methods ----------------------------------------------------------
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Method description
|
|
|
|
|
*
|
|
|
|
|
*
|
|
|
|
|
* @return
|
|
|
|
|
*/
|
2010-10-31 13:07:43 +01:00
|
|
|
public Set<SCMPlugin> getPlugins()
|
2010-10-12 09:16:40 +02:00
|
|
|
{
|
2010-10-31 13:07:43 +01:00
|
|
|
return plugins;
|
2010-10-12 09:16:40 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//~--- methods --------------------------------------------------------------
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Method description
|
|
|
|
|
*
|
|
|
|
|
*
|
|
|
|
|
* @param url
|
|
|
|
|
*/
|
|
|
|
|
private void loadPlugin(URL url)
|
|
|
|
|
{
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
SCMPlugin plugin = JAXB.unmarshal(url, SCMPlugin.class);
|
|
|
|
|
|
2010-10-31 13:07:43 +01:00
|
|
|
if (logger.isInfoEnabled())
|
2010-10-12 09:16:40 +02:00
|
|
|
{
|
2010-10-31 13:07:43 +01:00
|
|
|
logger.info("load plugin {}", url.toExternalForm());
|
2010-10-12 09:16:40 +02:00
|
|
|
}
|
2010-10-31 13:07:43 +01:00
|
|
|
|
|
|
|
|
plugins.add(plugin);
|
2010-10-12 09:16:40 +02:00
|
|
|
}
|
|
|
|
|
catch (Exception ex)
|
|
|
|
|
{
|
2010-10-16 11:03:54 +02:00
|
|
|
logger.error(ex.getMessage(), ex);
|
2010-10-12 09:16:40 +02:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//~--- fields ---------------------------------------------------------------
|
|
|
|
|
|
|
|
|
|
/** Field description */
|
2010-10-31 13:07:43 +01:00
|
|
|
private Set<SCMPlugin> plugins = new LinkedHashSet<SCMPlugin>();
|
2010-10-12 09:16:40 +02:00
|
|
|
}
|