bug 316909 cleanup and web-bundles don't need to be unzipped anymore. Jetty's standard WebInfConfiguration object takes care of unzipping wars on the fly as necessary to make the webapp consumable for JSPs.
git-svn-id: svn+ssh://dev.eclipse.org/svnroot/rt/org.eclipse.jetty/jetty/trunk@2048 7e9141cc-0065-0410-87d8-b60c137991c4
This commit is contained in:
parent
76d1e6bb30
commit
863cc0a757
|
@ -20,6 +20,7 @@ import java.util.Properties;
|
||||||
|
|
||||||
import org.eclipse.jetty.osgi.boot.internal.serverfactory.DefaultJettyAtJettyHomeHelper;
|
import org.eclipse.jetty.osgi.boot.internal.serverfactory.DefaultJettyAtJettyHomeHelper;
|
||||||
import org.eclipse.jetty.osgi.boot.internal.serverfactory.JettyServerServiceTracker;
|
import org.eclipse.jetty.osgi.boot.internal.serverfactory.JettyServerServiceTracker;
|
||||||
|
import org.eclipse.jetty.osgi.boot.internal.webapp.IWebBundleDeployerHelper;
|
||||||
import org.eclipse.jetty.osgi.boot.internal.webapp.JettyContextHandlerServiceTracker;
|
import org.eclipse.jetty.osgi.boot.internal.webapp.JettyContextHandlerServiceTracker;
|
||||||
import org.eclipse.jetty.osgi.boot.internal.webapp.WebBundleTrackerCustomizer;
|
import org.eclipse.jetty.osgi.boot.internal.webapp.WebBundleTrackerCustomizer;
|
||||||
import org.eclipse.jetty.osgi.boot.utils.internal.PackageAdminServiceTracker;
|
import org.eclipse.jetty.osgi.boot.utils.internal.PackageAdminServiceTracker;
|
||||||
|
@ -56,9 +57,6 @@ import org.osgi.util.tracker.BundleTracker;
|
||||||
public class JettyBootstrapActivator implements BundleActivator
|
public class JettyBootstrapActivator implements BundleActivator
|
||||||
{
|
{
|
||||||
|
|
||||||
/** development only: when set to true enable the jetty server service tracker */
|
|
||||||
private static boolean _enableMultipleJettyServers = true;
|
|
||||||
|
|
||||||
private static JettyBootstrapActivator INSTANCE = null;
|
private static JettyBootstrapActivator INSTANCE = null;
|
||||||
|
|
||||||
public static JettyBootstrapActivator getInstance()
|
public static JettyBootstrapActivator getInstance()
|
||||||
|
@ -92,36 +90,24 @@ public class JettyBootstrapActivator implements BundleActivator
|
||||||
// should activate.
|
// should activate.
|
||||||
_packageAdminServiceTracker = new PackageAdminServiceTracker(context);
|
_packageAdminServiceTracker = new PackageAdminServiceTracker(context);
|
||||||
|
|
||||||
|
_jettyServerServiceTracker = new JettyServerServiceTracker();
|
||||||
if (_enableMultipleJettyServers)
|
context.addServiceListener(_jettyServerServiceTracker,"(objectclass=" + Server.class.getName() + ")");
|
||||||
{//new style...
|
|
||||||
_jettyServerServiceTracker = new JettyServerServiceTracker();
|
|
||||||
context.addServiceListener(_jettyServerServiceTracker,"(objectclass=" + Server.class.getName() + ")");
|
|
||||||
|
|
||||||
//Register the Jetty Server Factory as a ManagedServiceFactory:
|
//Register the Jetty Server Factory as a ManagedServiceFactory:
|
||||||
// Properties jettyServerMgdFactoryServiceProps = new Properties();
|
// Properties jettyServerMgdFactoryServiceProps = new Properties();
|
||||||
// jettyServerMgdFactoryServiceProps.put("pid", OSGiWebappConstants.MANAGED_JETTY_SERVER_FACTORY_PID);
|
// jettyServerMgdFactoryServiceProps.put("pid", OSGiWebappConstants.MANAGED_JETTY_SERVER_FACTORY_PID);
|
||||||
// _jettyServerFactoryService = context.registerService(
|
// _jettyServerFactoryService = context.registerService(
|
||||||
// ManagedServiceFactory.class.getName(), new JettyServersManagedFactory(),
|
// ManagedServiceFactory.class.getName(), new JettyServersManagedFactory(),
|
||||||
// jettyServerMgdFactoryServiceProps);
|
// jettyServerMgdFactoryServiceProps);
|
||||||
|
|
||||||
_jettyContextHandlerTracker = new JettyContextHandlerServiceTracker(_jettyServerServiceTracker);
|
_jettyContextHandlerTracker = new JettyContextHandlerServiceTracker(_jettyServerServiceTracker);
|
||||||
}
|
|
||||||
else
|
|
||||||
{//old style...
|
|
||||||
_server = new Server();
|
|
||||||
// expose the server as a service.
|
|
||||||
_registeredServer = context.registerService(_server.getClass().getName(),_server,new Properties());
|
|
||||||
_jettyContextHandlerTracker = new JettyContextHandlerServiceTracker(context,_server);
|
|
||||||
}
|
|
||||||
// the tracker in charge of the actual deployment
|
// the tracker in charge of the actual deployment
|
||||||
// and that will configure and start the jetty server.
|
// and that will configure and start the jetty server.
|
||||||
context.addServiceListener(_jettyContextHandlerTracker,"(objectclass=" + ContextHandler.class.getName() + ")");
|
context.addServiceListener(_jettyContextHandlerTracker,"(objectclass=" + ContextHandler.class.getName() + ")");
|
||||||
|
|
||||||
if (_enableMultipleJettyServers)
|
//see if we shoult start a default jetty instance right now.
|
||||||
{
|
DefaultJettyAtJettyHomeHelper.startJettyAtJettyHome(context);
|
||||||
DefaultJettyAtJettyHomeHelper.startJettyAtJettyHome(context);
|
|
||||||
}
|
|
||||||
|
|
||||||
// now ready to support the Extender pattern:
|
// now ready to support the Extender pattern:
|
||||||
_webBundleTracker = new BundleTracker(context,
|
_webBundleTracker = new BundleTracker(context,
|
||||||
|
@ -288,6 +274,7 @@ public class JettyBootstrapActivator implements BundleActivator
|
||||||
{
|
{
|
||||||
ContextHandler contextHandler = new ContextHandler();
|
ContextHandler contextHandler = new ContextHandler();
|
||||||
dic.put(OSGiWebappConstants.SERVICE_PROP_CONTEXT_FILE_PATH,contextFilePath);
|
dic.put(OSGiWebappConstants.SERVICE_PROP_CONTEXT_FILE_PATH,contextFilePath);
|
||||||
|
dic.put(IWebBundleDeployerHelper.INTERNAL_SERVICE_PROP_UNKNOWN_CONTEXT_HANDLER_TYPE,Boolean.TRUE.toString());
|
||||||
contributor.getBundleContext().registerService(ContextHandler.class.getName(),contextHandler,dic);
|
contributor.getBundleContext().registerService(ContextHandler.class.getName(),contextHandler,dic);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -289,6 +289,17 @@ public class OSGiAppProvider extends ScanningAppProvider implements AppProvider
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public boolean isExtract()
|
||||||
|
{
|
||||||
|
return _extractWars;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setExtract(boolean extract)
|
||||||
|
{
|
||||||
|
_extractWars=extract;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/* ------------------------------------------------------------ */
|
/* ------------------------------------------------------------ */
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -18,11 +18,13 @@ import java.io.File;
|
||||||
import java.net.MalformedURLException;
|
import java.net.MalformedURLException;
|
||||||
import java.net.URL;
|
import java.net.URL;
|
||||||
import java.util.Enumeration;
|
import java.util.Enumeration;
|
||||||
|
import java.util.Map.Entry;
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
import java.util.StringTokenizer;
|
import java.util.StringTokenizer;
|
||||||
|
|
||||||
import org.eclipse.jetty.osgi.boot.JettyBootstrapActivator;
|
import org.eclipse.jetty.osgi.boot.JettyBootstrapActivator;
|
||||||
import org.eclipse.jetty.osgi.boot.OSGiServerConstants;
|
import org.eclipse.jetty.osgi.boot.OSGiServerConstants;
|
||||||
|
import org.eclipse.jetty.osgi.boot.utils.BundleFileLocatorHelper;
|
||||||
import org.eclipse.jetty.server.Server;
|
import org.eclipse.jetty.server.Server;
|
||||||
import org.osgi.framework.Bundle;
|
import org.osgi.framework.Bundle;
|
||||||
import org.osgi.framework.BundleContext;
|
import org.osgi.framework.BundleContext;
|
||||||
|
@ -135,11 +137,10 @@ public class DefaultJettyAtJettyHomeHelper {
|
||||||
properties.put(OSGiServerConstants.MANAGED_JETTY_XML_CONFIG_URLS, configURLs);
|
properties.put(OSGiServerConstants.MANAGED_JETTY_XML_CONFIG_URLS, configURLs);
|
||||||
|
|
||||||
//these properties usually are the ones passed to this type of configuration.
|
//these properties usually are the ones passed to this type of configuration.
|
||||||
//TODO remove the hardcoded defaults once we use 7.1.5
|
|
||||||
setProperty(properties,SYS_PROP_JETTY_HOME,System.getProperty(SYS_PROP_JETTY_HOME));
|
setProperty(properties,SYS_PROP_JETTY_HOME,System.getProperty(SYS_PROP_JETTY_HOME));
|
||||||
setProperty(properties,SYS_PROP_JETTY_HOST,System.getProperty(SYS_PROP_JETTY_HOST));
|
setProperty(properties,SYS_PROP_JETTY_HOST,System.getProperty(SYS_PROP_JETTY_HOST));
|
||||||
setProperty(properties,SYS_PROP_JETTY_PORT,System.getProperty(SYS_PROP_JETTY_PORT, "8080"));
|
setProperty(properties,SYS_PROP_JETTY_PORT,System.getProperty(SYS_PROP_JETTY_PORT));
|
||||||
setProperty(properties,SYS_PROP_JETTY_PORT_SSL,System.getProperty(SYS_PROP_JETTY_PORT_SSL, "8443"));
|
setProperty(properties,SYS_PROP_JETTY_PORT_SSL,System.getProperty(SYS_PROP_JETTY_PORT_SSL));
|
||||||
|
|
||||||
bundleContext.registerService(Server.class.getName(), server, properties);
|
bundleContext.registerService(Server.class.getName(), server, properties);
|
||||||
}
|
}
|
||||||
|
@ -201,26 +202,18 @@ public class DefaultJettyAtJettyHomeHelper {
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
int last = etcFile.lastIndexOf('/');
|
Enumeration<URL> enUrls = BundleFileLocatorHelper.DEFAULT
|
||||||
String path = last != -1 && last < etcFile.length() -2
|
.findEntries(configurationBundle, etcFile);
|
||||||
? etcFile.substring(0, last) : "/";
|
|
||||||
if (!path.startsWith("/"))
|
|
||||||
{
|
|
||||||
path = "/" + path;
|
|
||||||
}
|
|
||||||
String pattern = last != -1 && last < etcFile.length() -2
|
|
||||||
? etcFile.substring(last+1) : etcFile;
|
|
||||||
Enumeration<URL> enUrls = configurationBundle.findEntries(path, pattern, false);
|
|
||||||
|
|
||||||
//default for org.eclipse.osgi.boot where we look inside jettyhome for the default embedded configuration.
|
//default for org.eclipse.osgi.boot where we look inside jettyhome for the default embedded configuration.
|
||||||
//default inside jettyhome. this way fragments to the bundle can define their own configuration.
|
//default inside jettyhome. this way fragments to the bundle can define their own configuration.
|
||||||
if ((enUrls == null || !enUrls.hasMoreElements()) && pattern.equals("jetty.xml"))
|
if ((enUrls == null || !enUrls.hasMoreElements()) && etcFile.endsWith("etc/jetty.xml"))
|
||||||
{
|
{
|
||||||
path = "/jettyhome" + path;
|
enUrls = BundleFileLocatorHelper.DEFAULT
|
||||||
pattern = "jetty-osgi-default.xml";
|
.findEntries(configurationBundle, "/jettyhome/etc/jetty-osgi-default.xml");
|
||||||
enUrls = configurationBundle.findEntries(path, pattern, false);
|
|
||||||
System.err.println("Configuring jetty with the default embedded configuration:" +
|
System.err.println("Configuring jetty with the default embedded configuration:" +
|
||||||
"bundle: " + configurationBundle.getSymbolicName() + " config: /jettyhome/etc/jetty-osgi-default.xml");
|
"bundle: " + configurationBundle.getSymbolicName() +
|
||||||
|
" config: /jettyhome/etc/jetty-osgi-default.xml");
|
||||||
}
|
}
|
||||||
if (enUrls != null)
|
if (enUrls != null)
|
||||||
{
|
{
|
||||||
|
@ -250,4 +243,5 @@ public class DefaultJettyAtJettyHomeHelper {
|
||||||
properties.put(key, value);
|
properties.put(key, value);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -33,7 +33,6 @@ import org.eclipse.jetty.osgi.boot.OSGiServerConstants;
|
||||||
import org.eclipse.jetty.osgi.boot.internal.jsp.TldLocatableURLClassloader;
|
import org.eclipse.jetty.osgi.boot.internal.jsp.TldLocatableURLClassloader;
|
||||||
import org.eclipse.jetty.osgi.boot.internal.webapp.LibExtClassLoaderHelper;
|
import org.eclipse.jetty.osgi.boot.internal.webapp.LibExtClassLoaderHelper;
|
||||||
import org.eclipse.jetty.osgi.boot.internal.webapp.WebBundleDeployerHelper;
|
import org.eclipse.jetty.osgi.boot.internal.webapp.WebBundleDeployerHelper;
|
||||||
import org.eclipse.jetty.osgi.boot.internal.webapp.WebappRegistrationHelper;
|
|
||||||
import org.eclipse.jetty.osgi.boot.utils.WebappRegistrationCustomizer;
|
import org.eclipse.jetty.osgi.boot.utils.WebappRegistrationCustomizer;
|
||||||
import org.eclipse.jetty.osgi.boot.utils.internal.DefaultFileLocatorHelper;
|
import org.eclipse.jetty.osgi.boot.utils.internal.DefaultFileLocatorHelper;
|
||||||
import org.eclipse.jetty.server.Server;
|
import org.eclipse.jetty.server.Server;
|
||||||
|
@ -224,9 +223,10 @@ public class ServerInstanceWrapper {
|
||||||
private URL[] getJarsWithTlds() throws Exception
|
private URL[] getJarsWithTlds() throws Exception
|
||||||
{
|
{
|
||||||
ArrayList<URL> res = new ArrayList<URL>();
|
ArrayList<URL> res = new ArrayList<URL>();
|
||||||
|
WebBundleDeployerHelper.staticInit();//that is not looking great.
|
||||||
for (WebappRegistrationCustomizer regCustomizer : WebBundleDeployerHelper.JSP_REGISTRATION_HELPERS)
|
for (WebappRegistrationCustomizer regCustomizer : WebBundleDeployerHelper.JSP_REGISTRATION_HELPERS)
|
||||||
{
|
{
|
||||||
URL[] urls = regCustomizer.getJarsWithTlds(_provider, WebBundleDeployerHelper.BUNDLE_FILE_LOCATOR_HELPER);
|
URL[] urls = regCustomizer.getJarsWithTlds(_provider, WebBundleDeployerHelper.BUNDLE_FILE_LOCATOR_HELPER);
|
||||||
for (URL url : urls)
|
for (URL url : urls)
|
||||||
{
|
{
|
||||||
if (!res.contains(url))
|
if (!res.contains(url))
|
||||||
|
@ -274,8 +274,7 @@ public class ServerInstanceWrapper {
|
||||||
}
|
}
|
||||||
catch (SAXParseException saxparse)
|
catch (SAXParseException saxparse)
|
||||||
{
|
{
|
||||||
Log.getLogger(WebappRegistrationHelper.class.getName())
|
__logger.warn("Unable to configure the jetty/etc file " + jettyConfiguration,saxparse);
|
||||||
.warn("Unable to configure the jetty/etc file " + jettyConfiguration,saxparse);
|
|
||||||
throw saxparse;
|
throw saxparse;
|
||||||
}
|
}
|
||||||
finally
|
finally
|
||||||
|
|
|
@ -14,11 +14,9 @@
|
||||||
// ========================================================================
|
// ========================================================================
|
||||||
package org.eclipse.jetty.osgi.boot.internal.webapp;
|
package org.eclipse.jetty.osgi.boot.internal.webapp;
|
||||||
|
|
||||||
import java.io.File;
|
|
||||||
|
|
||||||
import org.eclipse.jetty.deploy.ContextDeployer;
|
import org.eclipse.jetty.deploy.ContextDeployer;
|
||||||
import org.eclipse.jetty.deploy.WebAppDeployer;
|
|
||||||
import org.eclipse.jetty.server.handler.ContextHandler;
|
import org.eclipse.jetty.server.handler.ContextHandler;
|
||||||
|
import org.eclipse.jetty.webapp.WebAppContext;
|
||||||
import org.osgi.framework.Bundle;
|
import org.osgi.framework.Bundle;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -27,6 +25,11 @@ import org.osgi.framework.Bundle;
|
||||||
*/
|
*/
|
||||||
public interface IWebBundleDeployerHelper {
|
public interface IWebBundleDeployerHelper {
|
||||||
|
|
||||||
|
/** when this property is present, the type of context handler registered is not
|
||||||
|
* known in advance. */
|
||||||
|
public static final String INTERNAL_SERVICE_PROP_UNKNOWN_CONTEXT_HANDLER_TYPE = "unknownContextHandlerType";
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Deploy a new web application on the jetty server.
|
* Deploy a new web application on the jetty server.
|
||||||
*
|
*
|
||||||
|
@ -45,29 +48,10 @@ public interface IWebBundleDeployerHelper {
|
||||||
* @return The contexthandler created and started
|
* @return The contexthandler created and started
|
||||||
* @throws Exception
|
* @throws Exception
|
||||||
*/
|
*/
|
||||||
public abstract ContextHandler registerWebapplication(Bundle bundle,
|
public abstract WebAppContext registerWebapplication(Bundle bundle,
|
||||||
String webappFolderPath, String contextPath, String extraClasspath,
|
String webappFolderPath, String contextPath, String extraClasspath,
|
||||||
String overrideBundleInstallLocation, String webXmlPath,
|
String overrideBundleInstallLocation, String webXmlPath,
|
||||||
String defaultWebXmlPath) throws Exception;
|
String defaultWebXmlPath, WebAppContext webAppContext) throws Exception;
|
||||||
|
|
||||||
/**
|
|
||||||
* TODO: refactor this into the createContext method of OSGiAppProvider.
|
|
||||||
* @see WebAppDeployer#scan()
|
|
||||||
|
|
||||||
* @param contributor
|
|
||||||
* @param webapp
|
|
||||||
* @param contextPath
|
|
||||||
* @param extraClasspath
|
|
||||||
* @param bundleInstall
|
|
||||||
* @param webXmlPath
|
|
||||||
* @param defaultWebXmlPath
|
|
||||||
* @return The contexthandler created and started
|
|
||||||
* @throws Exception
|
|
||||||
*/
|
|
||||||
public abstract ContextHandler registerWebapplication(Bundle contributor,
|
|
||||||
String pathInBundleToWebApp, File webapp, String contextPath,
|
|
||||||
String extraClasspath, File bundleInstall, String webXmlPath,
|
|
||||||
String defaultWebXmlPath) throws Exception;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Stop a ContextHandler and remove it from the collection.
|
* Stop a ContextHandler and remove it from the collection.
|
||||||
|
@ -88,11 +72,13 @@ public interface IWebBundleDeployerHelper {
|
||||||
* @param contextFileRelativePath
|
* @param contextFileRelativePath
|
||||||
* @param extraClasspath
|
* @param extraClasspath
|
||||||
* @param overrideBundleInstallLocation
|
* @param overrideBundleInstallLocation
|
||||||
|
* @param handler the context handler passed in the server
|
||||||
|
* reference that will be configured, deployed and started.
|
||||||
* @return The contexthandler created and started
|
* @return The contexthandler created and started
|
||||||
* @throws Exception
|
* @throws Exception
|
||||||
*/
|
*/
|
||||||
public abstract ContextHandler registerContext(Bundle contributor,
|
public abstract ContextHandler registerContext(Bundle contributor,
|
||||||
String contextFileRelativePath, String extraClasspath,
|
String contextFileRelativePath, String extraClasspath,
|
||||||
String overrideBundleInstallLocation) throws Exception;
|
String overrideBundleInstallLocation, ContextHandler handler) throws Exception;
|
||||||
|
|
||||||
}
|
}
|
|
@ -22,7 +22,6 @@ import org.eclipse.jetty.osgi.boot.OSGiServerConstants;
|
||||||
import org.eclipse.jetty.osgi.boot.OSGiWebappConstants;
|
import org.eclipse.jetty.osgi.boot.OSGiWebappConstants;
|
||||||
import org.eclipse.jetty.osgi.boot.internal.serverfactory.IManagedJettyServerRegistry;
|
import org.eclipse.jetty.osgi.boot.internal.serverfactory.IManagedJettyServerRegistry;
|
||||||
import org.eclipse.jetty.osgi.boot.internal.serverfactory.ServerInstanceWrapper;
|
import org.eclipse.jetty.osgi.boot.internal.serverfactory.ServerInstanceWrapper;
|
||||||
import org.eclipse.jetty.server.Server;
|
|
||||||
import org.eclipse.jetty.server.handler.ContextHandler;
|
import org.eclipse.jetty.server.handler.ContextHandler;
|
||||||
import org.eclipse.jetty.util.Scanner;
|
import org.eclipse.jetty.util.Scanner;
|
||||||
import org.eclipse.jetty.webapp.WebAppContext;
|
import org.eclipse.jetty.webapp.WebAppContext;
|
||||||
|
@ -55,15 +54,12 @@ public class JettyContextHandlerServiceTracker implements ServiceListener
|
||||||
|
|
||||||
/** New style: ability to manage multiple jetty instances */
|
/** New style: ability to manage multiple jetty instances */
|
||||||
private final IManagedJettyServerRegistry _registry;
|
private final IManagedJettyServerRegistry _registry;
|
||||||
/** Old style: ability to manage multiple jetty instances */
|
|
||||||
private final WebappRegistrationHelper _helper;
|
|
||||||
|
|
||||||
/** The context-handler to deactivate indexed by context handler */
|
/** The context-handler to deactivate indexed by context handler */
|
||||||
private Map<ServiceReference, ContextHandler> _indexByServiceReference = new HashMap<ServiceReference, ContextHandler>();
|
private Map<ServiceReference, ContextHandler> _indexByServiceReference = new HashMap<ServiceReference, ContextHandler>();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The index is the bundle-symbolic-name/paht/to/context/file when there is
|
* The index is the bundle-symbolic-name/path/to/context/file when there is such thing
|
||||||
* such thing
|
|
||||||
*/
|
*/
|
||||||
private Map<String, ServiceReference> _indexByContextFile = new HashMap<String, ServiceReference>();
|
private Map<String, ServiceReference> _indexByContextFile = new HashMap<String, ServiceReference>();
|
||||||
|
|
||||||
|
@ -71,24 +67,11 @@ public class JettyContextHandlerServiceTracker implements ServiceListener
|
||||||
private Scanner _scanner;
|
private Scanner _scanner;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param context
|
* @param registry
|
||||||
* @param server
|
|
||||||
*/
|
|
||||||
public JettyContextHandlerServiceTracker(BundleContext context, Server server) throws Exception
|
|
||||||
{
|
|
||||||
_registry = null;
|
|
||||||
_helper = new WebappRegistrationHelper(server);
|
|
||||||
_helper.setup(context,new HashMap<String, String>());
|
|
||||||
setupContextHomeScanner(_helper.getOSGiContextsHome());
|
|
||||||
}
|
|
||||||
/**
|
|
||||||
* @param context
|
|
||||||
* @param server
|
|
||||||
*/
|
*/
|
||||||
public JettyContextHandlerServiceTracker(IManagedJettyServerRegistry registry) throws Exception
|
public JettyContextHandlerServiceTracker(IManagedJettyServerRegistry registry) throws Exception
|
||||||
{
|
{
|
||||||
_registry = registry;
|
_registry = registry;
|
||||||
_helper = null;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void stop()
|
public void stop()
|
||||||
|
@ -192,7 +175,11 @@ public class JettyContextHandlerServiceTracker implements ServiceListener
|
||||||
// is configured elsewhere.
|
// is configured elsewhere.
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (contextHandler instanceof WebAppContext)
|
String contextFilePath = (String)sr.getProperty(OSGiWebappConstants.SERVICE_PROP_CONTEXT_FILE_PATH);
|
||||||
|
if (contextHandler instanceof WebAppContext && contextFilePath == null)
|
||||||
|
//it could be a web-application that will in fact be configured via a context file.
|
||||||
|
//that case is identified by the fact that the contextFilePath is not null
|
||||||
|
//in that case we must use the register context methods.
|
||||||
{
|
{
|
||||||
WebAppContext webapp = (WebAppContext)contextHandler;
|
WebAppContext webapp = (WebAppContext)contextHandler;
|
||||||
String contextPath = (String)sr.getProperty(OSGiWebappConstants.SERVICE_PROP_CONTEXT_PATH);
|
String contextPath = (String)sr.getProperty(OSGiWebappConstants.SERVICE_PROP_CONTEXT_PATH);
|
||||||
|
@ -213,14 +200,23 @@ public class JettyContextHandlerServiceTracker implements ServiceListener
|
||||||
String war = (String)sr.getProperty("war");
|
String war = (String)sr.getProperty("war");
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
ContextHandler handler = getWebBundleDeployerHelp(sr)
|
IWebBundleDeployerHelper deployerHelper = getWebBundleDeployerHelp(sr);
|
||||||
|
if (deployerHelper == null)
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
WebAppContext handler = deployerHelper
|
||||||
.registerWebapplication(contributor,war,contextPath,(String)sr
|
.registerWebapplication(contributor,war,contextPath,(String)sr
|
||||||
.getProperty(OSGiWebappConstants.SERVICE_PROP_EXTRA_CLASSPATH),(String)sr
|
.getProperty(OSGiWebappConstants.SERVICE_PROP_EXTRA_CLASSPATH),(String)sr
|
||||||
.getProperty(OSGiWebappConstants.SERVICE_PROP_BUNDLE_INSTALL_LOCATION_OVERRIDE),webXmlPath,defaultWebXmlPath);
|
.getProperty(OSGiWebappConstants.SERVICE_PROP_BUNDLE_INSTALL_LOCATION_OVERRIDE),
|
||||||
if (handler != null)
|
webXmlPath,defaultWebXmlPath,webapp);
|
||||||
{
|
if (handler != null)
|
||||||
registerInIndex(handler,sr);
|
{
|
||||||
}
|
registerInIndex(handler,sr);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
catch (Throwable e)
|
catch (Throwable e)
|
||||||
{
|
{
|
||||||
|
@ -230,20 +226,33 @@ public class JettyContextHandlerServiceTracker implements ServiceListener
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
// consider this just an empty skeleton:
|
// consider this just an empty skeleton:
|
||||||
String contextFilePath = (String)sr.getProperty(OSGiWebappConstants.SERVICE_PROP_CONTEXT_FILE_PATH);
|
|
||||||
if (contextFilePath == null)
|
if (contextFilePath == null)
|
||||||
{
|
{
|
||||||
throw new IllegalArgumentException("the property contextFilePath is required");
|
throw new IllegalArgumentException("the property contextFilePath is required");
|
||||||
}
|
}
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
ContextHandler handler = getWebBundleDeployerHelp(sr).registerContext(contributor,contextFilePath,(String)sr
|
IWebBundleDeployerHelper deployerHelper = getWebBundleDeployerHelp(sr);
|
||||||
.getProperty(OSGiWebappConstants.SERVICE_PROP_EXTRA_CLASSPATH),(String)sr
|
if (deployerHelper == null)
|
||||||
.getProperty(OSGiWebappConstants.SERVICE_PROP_BUNDLE_INSTALL_LOCATION_OVERRIDE));
|
{
|
||||||
if (handler != null)
|
//more warnings?
|
||||||
{
|
}
|
||||||
registerInIndex(handler,sr);
|
else
|
||||||
}
|
{
|
||||||
|
if (Boolean.TRUE.toString().equals(sr.getProperty(
|
||||||
|
IWebBundleDeployerHelper.INTERNAL_SERVICE_PROP_UNKNOWN_CONTEXT_HANDLER_TYPE)))
|
||||||
|
{
|
||||||
|
contextHandler = null;
|
||||||
|
}
|
||||||
|
ContextHandler handler = deployerHelper.registerContext(contributor,contextFilePath,
|
||||||
|
(String)sr.getProperty(OSGiWebappConstants.SERVICE_PROP_EXTRA_CLASSPATH),
|
||||||
|
(String)sr.getProperty(OSGiWebappConstants.SERVICE_PROP_BUNDLE_INSTALL_LOCATION_OVERRIDE),
|
||||||
|
contextHandler);
|
||||||
|
if (handler != null)
|
||||||
|
{
|
||||||
|
registerInIndex(handler,sr);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
catch (Throwable e)
|
catch (Throwable e)
|
||||||
{
|
{
|
||||||
|
@ -353,6 +362,7 @@ public class JettyContextHandlerServiceTracker implements ServiceListener
|
||||||
managedServerName = OSGiServerConstants.MANAGED_JETTY_SERVER_DEFAULT_NAME;
|
managedServerName = OSGiServerConstants.MANAGED_JETTY_SERVER_DEFAULT_NAME;
|
||||||
}
|
}
|
||||||
ServerInstanceWrapper wrapper = _registry.getServerInstanceWrapper(managedServerName);
|
ServerInstanceWrapper wrapper = _registry.getServerInstanceWrapper(managedServerName);
|
||||||
|
System.err.println("Returning " + managedServerName + " = " + wrapper);
|
||||||
return wrapper;
|
return wrapper;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -360,12 +370,11 @@ public class JettyContextHandlerServiceTracker implements ServiceListener
|
||||||
{
|
{
|
||||||
if (_registry == null)
|
if (_registry == null)
|
||||||
{
|
{
|
||||||
return _helper;
|
return null;
|
||||||
}
|
}
|
||||||
String managedServerName = (String)sr.getProperty(OSGiServerConstants.MANAGED_JETTY_SERVER_NAME);
|
String managedServerName = (String)sr.getProperty(OSGiServerConstants.MANAGED_JETTY_SERVER_NAME);
|
||||||
ServerInstanceWrapper wrapper = getServerInstanceWrapper(managedServerName);
|
ServerInstanceWrapper wrapper = getServerInstanceWrapper(managedServerName);
|
||||||
return wrapper != null ? wrapper.getWebBundleDeployerHelp() : _helper;
|
return wrapper != null ? wrapper.getWebBundleDeployerHelp() : null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,9 +23,8 @@ import java.io.InputStream;
|
||||||
import java.net.URL;
|
import java.net.URL;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
|
import java.util.Enumeration;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.jar.JarFile;
|
|
||||||
import java.util.zip.ZipEntry;
|
|
||||||
|
|
||||||
import org.eclipse.jetty.deploy.ContextDeployer;
|
import org.eclipse.jetty.deploy.ContextDeployer;
|
||||||
import org.eclipse.jetty.osgi.boot.OSGiWebappConstants;
|
import org.eclipse.jetty.osgi.boot.OSGiWebappConstants;
|
||||||
|
@ -36,6 +35,7 @@ import org.eclipse.jetty.osgi.boot.utils.WebappRegistrationCustomizer;
|
||||||
import org.eclipse.jetty.osgi.boot.utils.internal.DefaultBundleClassLoaderHelper;
|
import org.eclipse.jetty.osgi.boot.utils.internal.DefaultBundleClassLoaderHelper;
|
||||||
import org.eclipse.jetty.osgi.boot.utils.internal.DefaultFileLocatorHelper;
|
import org.eclipse.jetty.osgi.boot.utils.internal.DefaultFileLocatorHelper;
|
||||||
import org.eclipse.jetty.server.handler.ContextHandler;
|
import org.eclipse.jetty.server.handler.ContextHandler;
|
||||||
|
import org.eclipse.jetty.util.IO;
|
||||||
import org.eclipse.jetty.util.log.Log;
|
import org.eclipse.jetty.util.log.Log;
|
||||||
import org.eclipse.jetty.util.log.Logger;
|
import org.eclipse.jetty.util.log.Logger;
|
||||||
import org.eclipse.jetty.util.resource.Resource;
|
import org.eclipse.jetty.util.resource.Resource;
|
||||||
|
@ -67,7 +67,7 @@ public class WebBundleDeployerHelper implements IWebBundleDeployerHelper
|
||||||
private static Logger __logger = Log.getLogger(WebBundleDeployerHelper.class.getName());
|
private static Logger __logger = Log.getLogger(WebBundleDeployerHelper.class.getName());
|
||||||
|
|
||||||
private static boolean INITIALIZED = false;
|
private static boolean INITIALIZED = false;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* By default set to: {@link DefaultBundleClassLoaderHelper}. It supports
|
* By default set to: {@link DefaultBundleClassLoaderHelper}. It supports
|
||||||
* equinox and apache-felix fragment bundles that are specific to an OSGi
|
* equinox and apache-felix fragment bundles that are specific to an OSGi
|
||||||
|
@ -103,12 +103,12 @@ public class WebBundleDeployerHelper implements IWebBundleDeployerHelper
|
||||||
|
|
||||||
public WebBundleDeployerHelper(ServerInstanceWrapper wrapper)
|
public WebBundleDeployerHelper(ServerInstanceWrapper wrapper)
|
||||||
{
|
{
|
||||||
|
staticInit();
|
||||||
_wrapper = wrapper;
|
_wrapper = wrapper;
|
||||||
staticInit();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Inject the customizing classes that might be defined in fragment bundles.
|
// Inject the customizing classes that might be defined in fragment bundles.
|
||||||
private static synchronized void staticInit()
|
public static synchronized void staticInit()
|
||||||
{
|
{
|
||||||
if (!INITIALIZED)
|
if (!INITIALIZED)
|
||||||
{
|
{
|
||||||
|
@ -139,45 +139,60 @@ public class WebBundleDeployerHelper implements IWebBundleDeployerHelper
|
||||||
/* (non-Javadoc)
|
/* (non-Javadoc)
|
||||||
* @see org.eclipse.jetty.osgi.boot.internal.webapp.IWebBundleDeployerHelper#registerWebapplication(org.osgi.framework.Bundle, java.lang.String, java.lang.String, java.lang.String, java.lang.String, java.lang.String, java.lang.String)
|
* @see org.eclipse.jetty.osgi.boot.internal.webapp.IWebBundleDeployerHelper#registerWebapplication(org.osgi.framework.Bundle, java.lang.String, java.lang.String, java.lang.String, java.lang.String, java.lang.String, java.lang.String)
|
||||||
*/
|
*/
|
||||||
public ContextHandler registerWebapplication(Bundle bundle, String webappFolderPath, String contextPath, String extraClasspath,
|
public WebAppContext registerWebapplication(Bundle bundle, String webappFolderPath, String contextPath, String extraClasspath,
|
||||||
String overrideBundleInstallLocation, String webXmlPath, String defaultWebXmlPath) throws Exception
|
String overrideBundleInstallLocation, String webXmlPath, String defaultWebXmlPath, WebAppContext webAppContext) throws Exception
|
||||||
{
|
{
|
||||||
File bundleInstall = overrideBundleInstallLocation == null?BUNDLE_FILE_LOCATOR_HELPER.getBundleInstallLocation(bundle):new File(
|
File bundleInstall = overrideBundleInstallLocation == null?BUNDLE_FILE_LOCATOR_HELPER.getBundleInstallLocation(bundle):new File(
|
||||||
overrideBundleInstallLocation);
|
overrideBundleInstallLocation);
|
||||||
File webapp = null;
|
File webapp = null;
|
||||||
|
URL baseWebappInstallURL = null;
|
||||||
if (webappFolderPath != null && webappFolderPath.length() != 0 && !webappFolderPath.equals("."))
|
if (webappFolderPath != null && webappFolderPath.length() != 0 && !webappFolderPath.equals("."))
|
||||||
{
|
{
|
||||||
if (webappFolderPath.startsWith("/") || webappFolderPath.startsWith("file:/"))
|
if (webappFolderPath.startsWith("/") || webappFolderPath.startsWith("file:"))
|
||||||
{
|
{
|
||||||
webapp = new File(webappFolderPath);
|
webapp = new File(webappFolderPath);
|
||||||
}
|
}
|
||||||
else
|
else if (bundleInstall != null && bundleInstall.isDirectory())
|
||||||
{
|
{
|
||||||
webapp = new File(bundleInstall,webappFolderPath);
|
webapp = new File(bundleInstall,webappFolderPath);
|
||||||
}
|
}
|
||||||
|
else if (bundleInstall != null)
|
||||||
|
{
|
||||||
|
Enumeration<URL> urls = BUNDLE_FILE_LOCATOR_HELPER.findEntries(bundle, webappFolderPath);
|
||||||
|
if (urls != null && urls.hasMoreElements())
|
||||||
|
{
|
||||||
|
baseWebappInstallURL = urls.nextElement();
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
webapp = bundleInstall;
|
webapp = bundleInstall;
|
||||||
}
|
}
|
||||||
if (!webapp.exists())
|
if (baseWebappInstallURL == null && (webapp == null || !webapp.exists()))
|
||||||
{
|
{
|
||||||
throw new IllegalArgumentException("Unable to locate " + webappFolderPath + " inside "
|
throw new IllegalArgumentException("Unable to locate " + webappFolderPath + " inside "
|
||||||
+ (bundleInstall != null?bundleInstall.getAbsolutePath():"unlocated bundle '" + bundle.getSymbolicName() + "'"));
|
+ (bundleInstall != null?bundleInstall.getAbsolutePath():"unlocated bundle '" + bundle.getSymbolicName() + "'"));
|
||||||
}
|
}
|
||||||
return registerWebapplication(bundle,webappFolderPath,webapp,contextPath,extraClasspath,bundleInstall,webXmlPath,defaultWebXmlPath);
|
if (baseWebappInstallURL == null && webapp != null)
|
||||||
|
{
|
||||||
|
baseWebappInstallURL = webapp.toURI().toURL();
|
||||||
|
}
|
||||||
|
return registerWebapplication(bundle,webappFolderPath,baseWebappInstallURL,contextPath,
|
||||||
|
extraClasspath,bundleInstall,webXmlPath,defaultWebXmlPath,webAppContext);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* (non-Javadoc)
|
/* (non-Javadoc)
|
||||||
* @see org.eclipse.jetty.osgi.boot.internal.webapp.IWebBundleDeployerHelper#registerWebapplication(org.osgi.framework.Bundle, java.lang.String, java.io.File, java.lang.String, java.lang.String, java.io.File, java.lang.String, java.lang.String)
|
* @see org.eclipse.jetty.osgi.boot.internal.webapp.IWebBundleDeployerHelper#registerWebapplication(org.osgi.framework.Bundle, java.lang.String, java.io.File, java.lang.String, java.lang.String, java.io.File, java.lang.String, java.lang.String)
|
||||||
*/
|
*/
|
||||||
public ContextHandler registerWebapplication(Bundle contributor, String pathInBundleToWebApp, File webapp, String contextPath, String extraClasspath, File bundleInstall,
|
private WebAppContext registerWebapplication(Bundle contributor, String pathInBundleToWebApp,
|
||||||
String webXmlPath, String defaultWebXmlPath) throws Exception
|
URL baseWebappInstallURL, String contextPath, String extraClasspath, File bundleInstall,
|
||||||
|
String webXmlPath, String defaultWebXmlPath, WebAppContext context) throws Exception
|
||||||
{
|
{
|
||||||
|
|
||||||
ClassLoader contextCl = Thread.currentThread().getContextClassLoader();
|
ClassLoader contextCl = Thread.currentThread().getContextClassLoader();
|
||||||
String[] oldServerClasses = null;
|
String[] oldServerClasses = null;
|
||||||
WebAppContext context = null;
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
// make sure we provide access to all the jetty bundles by going
|
// make sure we provide access to all the jetty bundles by going
|
||||||
|
@ -187,7 +202,8 @@ public class WebBundleDeployerHelper implements IWebBundleDeployerHelper
|
||||||
// that the contributor gives access to.
|
// that the contributor gives access to.
|
||||||
Thread.currentThread().setContextClassLoader(composite);
|
Thread.currentThread().setContextClassLoader(composite);
|
||||||
|
|
||||||
context = new WebAppContext(webapp.getAbsolutePath(),contextPath);
|
context.setWar(baseWebappInstallURL.toString());
|
||||||
|
context.setContextPath(contextPath);
|
||||||
context.setExtraClasspath(extraClasspath);
|
context.setExtraClasspath(extraClasspath);
|
||||||
|
|
||||||
if (webXmlPath != null && webXmlPath.length() != 0)
|
if (webXmlPath != null && webXmlPath.length() != 0)
|
||||||
|
@ -242,7 +258,9 @@ public class WebBundleDeployerHelper implements IWebBundleDeployerHelper
|
||||||
// through the webapp classloader.
|
// through the webapp classloader.
|
||||||
oldServerClasses = context.getServerClasses();
|
oldServerClasses = context.getServerClasses();
|
||||||
context.setServerClasses(null);
|
context.setServerClasses(null);
|
||||||
|
|
||||||
_wrapper.getOSGiAppProvider().addContext(contributor,pathInBundleToWebApp,context);
|
_wrapper.getOSGiAppProvider().addContext(contributor,pathInBundleToWebApp,context);
|
||||||
|
|
||||||
return context;
|
return context;
|
||||||
}
|
}
|
||||||
finally
|
finally
|
||||||
|
@ -267,7 +285,8 @@ public class WebBundleDeployerHelper implements IWebBundleDeployerHelper
|
||||||
/* (non-Javadoc)
|
/* (non-Javadoc)
|
||||||
* @see org.eclipse.jetty.osgi.boot.internal.webapp.IWebBundleDeployerHelper#registerContext(org.osgi.framework.Bundle, java.lang.String, java.lang.String, java.lang.String)
|
* @see org.eclipse.jetty.osgi.boot.internal.webapp.IWebBundleDeployerHelper#registerContext(org.osgi.framework.Bundle, java.lang.String, java.lang.String, java.lang.String)
|
||||||
*/
|
*/
|
||||||
public ContextHandler registerContext(Bundle contributor, String contextFileRelativePath, String extraClasspath, String overrideBundleInstallLocation)
|
public ContextHandler registerContext(Bundle contributor, String contextFileRelativePath, String extraClasspath,
|
||||||
|
String overrideBundleInstallLocation, ContextHandler handler)
|
||||||
throws Exception
|
throws Exception
|
||||||
{
|
{
|
||||||
File contextsHome = _wrapper.getOSGiAppProvider().getContextXmlDirAsFile();
|
File contextsHome = _wrapper.getOSGiAppProvider().getContextXmlDirAsFile();
|
||||||
|
@ -276,15 +295,17 @@ public class WebBundleDeployerHelper implements IWebBundleDeployerHelper
|
||||||
File prodContextFile = new File(contextsHome,contributor.getSymbolicName() + "/" + contextFileRelativePath);
|
File prodContextFile = new File(contextsHome,contributor.getSymbolicName() + "/" + contextFileRelativePath);
|
||||||
if (prodContextFile.exists())
|
if (prodContextFile.exists())
|
||||||
{
|
{
|
||||||
return registerContext(contributor,contextFileRelativePath,prodContextFile,extraClasspath,overrideBundleInstallLocation);
|
return registerContext(contributor,contextFileRelativePath,prodContextFile,extraClasspath,
|
||||||
|
overrideBundleInstallLocation,handler);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
File rootFolder = overrideBundleInstallLocation != null
|
||||||
File contextFile = overrideBundleInstallLocation != null?new File(overrideBundleInstallLocation,contextFileRelativePath):new File(
|
? Resource.newResource(overrideBundleInstallLocation).getFile()
|
||||||
BUNDLE_FILE_LOCATOR_HELPER.getBundleInstallLocation(contributor),contextFileRelativePath);
|
: BUNDLE_FILE_LOCATOR_HELPER.getBundleInstallLocation(contributor);
|
||||||
if (contextFile.exists())
|
File contextFile = rootFolder != null?new File(rootFolder,contextFileRelativePath):null;
|
||||||
|
if (contextFile != null && contextFile.exists())
|
||||||
{
|
{
|
||||||
return registerContext(contributor,contextFileRelativePath,contextFile,extraClasspath,overrideBundleInstallLocation);
|
return registerContext(contributor,contextFileRelativePath,contextFile,extraClasspath,overrideBundleInstallLocation,handler);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -297,39 +318,10 @@ public class WebBundleDeployerHelper implements IWebBundleDeployerHelper
|
||||||
contextFileRelativePath = "/" + contextFileRelativePath;
|
contextFileRelativePath = "/" + contextFileRelativePath;
|
||||||
}
|
}
|
||||||
|
|
||||||
File overrideBundleInstallLocationF = overrideBundleInstallLocation != null ? Resource.newResource(overrideBundleInstallLocation).getFile() : null;
|
URL contextURL = contributor.getEntry(contextFileRelativePath);
|
||||||
if (overrideBundleInstallLocationF == null)
|
if (contextURL != null)
|
||||||
{
|
{
|
||||||
URL contextURL = contributor.getEntry(contextFileRelativePath);
|
return registerContext(contributor,contextFileRelativePath,contextURL.openStream(),extraClasspath,overrideBundleInstallLocation,handler);
|
||||||
if (contextURL != null)
|
|
||||||
{
|
|
||||||
return registerContext(contributor,contextFileRelativePath,contextURL.openStream(),extraClasspath,overrideBundleInstallLocation);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
JarFile zipFile = null;
|
|
||||||
try
|
|
||||||
{
|
|
||||||
zipFile = new JarFile(overrideBundleInstallLocation);
|
|
||||||
ZipEntry entry = zipFile.getEntry(contextFileRelativePath.substring(1));
|
|
||||||
return registerContext(contributor,contextFileRelativePath,zipFile.getInputStream(entry),extraClasspath,overrideBundleInstallLocation);
|
|
||||||
}
|
|
||||||
catch (Throwable t)
|
|
||||||
{
|
|
||||||
|
|
||||||
}
|
|
||||||
finally
|
|
||||||
{
|
|
||||||
if (zipFile != null)
|
|
||||||
try
|
|
||||||
{
|
|
||||||
zipFile.close();
|
|
||||||
}
|
|
||||||
catch (IOException ioe)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
throw new IllegalArgumentException("Could not find the context " + "file " + contextFileRelativePath + " for the bundle "
|
throw new IllegalArgumentException("Could not find the context " + "file " + contextFileRelativePath + " for the bundle "
|
||||||
+ contributor.getSymbolicName() + (overrideBundleInstallLocation != null?" using the install location " + overrideBundleInstallLocation:""));
|
+ contributor.getSymbolicName() + (overrideBundleInstallLocation != null?" using the install location " + overrideBundleInstallLocation:""));
|
||||||
|
@ -346,24 +338,18 @@ public class WebBundleDeployerHelper implements IWebBundleDeployerHelper
|
||||||
* @param classInBundle
|
* @param classInBundle
|
||||||
* @throws Exception
|
* @throws Exception
|
||||||
*/
|
*/
|
||||||
private ContextHandler registerContext(Bundle contributor, String pathInBundle, File contextFile, String extraClasspath, String overrideBundleInstallLocation) throws Exception
|
private ContextHandler registerContext(Bundle contributor, String pathInBundle, File contextFile,
|
||||||
|
String extraClasspath, String overrideBundleInstallLocation, ContextHandler handler) throws Exception
|
||||||
{
|
{
|
||||||
InputStream contextFileInputStream = null;
|
InputStream contextFileInputStream = null;
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
contextFileInputStream = new BufferedInputStream(new FileInputStream(contextFile));
|
contextFileInputStream = new BufferedInputStream(new FileInputStream(contextFile));
|
||||||
return registerContext(contributor, pathInBundle, contextFileInputStream,extraClasspath,overrideBundleInstallLocation);
|
return registerContext(contributor, pathInBundle, contextFileInputStream,extraClasspath,overrideBundleInstallLocation, handler);
|
||||||
}
|
}
|
||||||
finally
|
finally
|
||||||
{
|
{
|
||||||
if (contextFileInputStream != null)
|
IO.close(contextFileInputStream);
|
||||||
try
|
|
||||||
{
|
|
||||||
contextFileInputStream.close();
|
|
||||||
}
|
|
||||||
catch (IOException ioe)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -374,7 +360,8 @@ public class WebBundleDeployerHelper implements IWebBundleDeployerHelper
|
||||||
* happen.
|
* happen.
|
||||||
* @throws Exception
|
* @throws Exception
|
||||||
*/
|
*/
|
||||||
private ContextHandler registerContext(Bundle contributor, String pathInsideBundle, InputStream contextFileInputStream, String extraClasspath, String overrideBundleInstallLocation)
|
private ContextHandler registerContext(Bundle contributor, String pathInsideBundle, InputStream contextFileInputStream,
|
||||||
|
String extraClasspath, String overrideBundleInstallLocation, ContextHandler handler)
|
||||||
throws Exception
|
throws Exception
|
||||||
{
|
{
|
||||||
ClassLoader contextCl = Thread.currentThread().getContextClassLoader();
|
ClassLoader contextCl = Thread.currentThread().getContextClassLoader();
|
||||||
|
@ -389,7 +376,7 @@ public class WebBundleDeployerHelper implements IWebBundleDeployerHelper
|
||||||
// classes
|
// classes
|
||||||
// that the contributor gives access to.
|
// that the contributor gives access to.
|
||||||
Thread.currentThread().setContextClassLoader(composite);
|
Thread.currentThread().setContextClassLoader(composite);
|
||||||
ContextHandler context = createContextHandler(contributor,contextFileInputStream,extraClasspath,overrideBundleInstallLocation);
|
ContextHandler context = createContextHandler(handler, contributor,contextFileInputStream,extraClasspath,overrideBundleInstallLocation);
|
||||||
if (context == null)
|
if (context == null)
|
||||||
{
|
{
|
||||||
return null;// did not happen
|
return null;// did not happen
|
||||||
|
@ -449,11 +436,12 @@ public class WebBundleDeployerHelper implements IWebBundleDeployerHelper
|
||||||
* @param contextFile
|
* @param contextFile
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
protected ContextHandler createContextHandler(Bundle bundle, File contextFile, String extraClasspath, String overrideBundleInstallLocation)
|
protected ContextHandler createContextHandler(ContextHandler handlerToConfigure,
|
||||||
|
Bundle bundle, File contextFile, String extraClasspath, String overrideBundleInstallLocation)
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
return createContextHandler(bundle,new BufferedInputStream(new FileInputStream(contextFile)),extraClasspath,overrideBundleInstallLocation);
|
return createContextHandler(handlerToConfigure,bundle,new BufferedInputStream(new FileInputStream(contextFile)),extraClasspath,overrideBundleInstallLocation);
|
||||||
}
|
}
|
||||||
catch (FileNotFoundException e)
|
catch (FileNotFoundException e)
|
||||||
{
|
{
|
||||||
|
@ -468,7 +456,8 @@ public class WebBundleDeployerHelper implements IWebBundleDeployerHelper
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked")
|
||||||
protected ContextHandler createContextHandler(Bundle bundle, InputStream contextInputStream, String extraClasspath, String overrideBundleInstallLocation)
|
protected ContextHandler createContextHandler(ContextHandler handlerToConfigure,
|
||||||
|
Bundle bundle, InputStream contextInputStream, String extraClasspath, String overrideBundleInstallLocation)
|
||||||
{
|
{
|
||||||
/*
|
/*
|
||||||
* Do something identical to what the ContextProvider would have done:
|
* Do something identical to what the ContextProvider would have done:
|
||||||
|
@ -491,7 +480,17 @@ public class WebBundleDeployerHelper implements IWebBundleDeployerHelper
|
||||||
setThisBundleHomeProperty(bundle,properties,overrideBundleInstallLocation);
|
setThisBundleHomeProperty(bundle,properties,overrideBundleInstallLocation);
|
||||||
xmlConfiguration.setProperties(properties);
|
xmlConfiguration.setProperties(properties);
|
||||||
|
|
||||||
ContextHandler context = (ContextHandler)xmlConfiguration.configure();
|
ContextHandler context = null;
|
||||||
|
if (handlerToConfigure == null)
|
||||||
|
{
|
||||||
|
context = (ContextHandler)xmlConfiguration.configure();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
xmlConfiguration.configure(handlerToConfigure);
|
||||||
|
context = handlerToConfigure;
|
||||||
|
}
|
||||||
|
|
||||||
if (context instanceof WebAppContext)
|
if (context instanceof WebAppContext)
|
||||||
{
|
{
|
||||||
((WebAppContext)context).setExtraClasspath(extraClasspath);
|
((WebAppContext)context).setExtraClasspath(extraClasspath);
|
||||||
|
@ -534,14 +533,7 @@ public class WebBundleDeployerHelper implements IWebBundleDeployerHelper
|
||||||
}
|
}
|
||||||
finally
|
finally
|
||||||
{
|
{
|
||||||
if (contextInputStream != null)
|
IO.close(contextInputStream);
|
||||||
try
|
|
||||||
{
|
|
||||||
contextInputStream.close();
|
|
||||||
}
|
|
||||||
catch (IOException ioe)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -13,6 +13,8 @@
|
||||||
package org.eclipse.jetty.osgi.boot.utils;
|
package org.eclipse.jetty.osgi.boot.utils;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.util.Enumeration;
|
||||||
|
|
||||||
import org.eclipse.jetty.osgi.boot.utils.internal.DefaultFileLocatorHelper;
|
import org.eclipse.jetty.osgi.boot.utils.internal.DefaultFileLocatorHelper;
|
||||||
import org.osgi.framework.Bundle;
|
import org.osgi.framework.Bundle;
|
||||||
|
@ -73,5 +75,16 @@ public interface BundleFileLocatorHelper
|
||||||
* embedded inside it.
|
* embedded inside it.
|
||||||
*/
|
*/
|
||||||
public File[] locateJarsInsideBundle(Bundle bundle) throws Exception;
|
public File[] locateJarsInsideBundle(Bundle bundle) throws Exception;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Helper method equivalent to Bundle#getEntry(String entryPath) except that
|
||||||
|
* it searches for entries in the fragments by using the findEntries method.
|
||||||
|
*
|
||||||
|
* @param bundle
|
||||||
|
* @param entryPath
|
||||||
|
* @return null or all the entries found for that path.
|
||||||
|
*/
|
||||||
|
public Enumeration<URL> findEntries(Bundle bundle, String entryPath);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,6 +20,7 @@ import java.net.URL;
|
||||||
import java.net.URLConnection;
|
import java.net.URLConnection;
|
||||||
import java.net.URLDecoder;
|
import java.net.URLDecoder;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.Enumeration;
|
||||||
import java.util.zip.ZipFile;
|
import java.util.zip.ZipFile;
|
||||||
|
|
||||||
import org.eclipse.jetty.osgi.boot.utils.BundleFileLocatorHelper;
|
import org.eclipse.jetty.osgi.boot.utils.BundleFileLocatorHelper;
|
||||||
|
@ -141,13 +142,19 @@ public class DefaultFileLocatorHelper implements BundleFileLocatorHelper
|
||||||
{
|
{
|
||||||
//location defined in the BundleArchive m_bundleArchive
|
//location defined in the BundleArchive m_bundleArchive
|
||||||
//it is relative to relative to the BundleArchive's m_archiveRootDir
|
//it is relative to relative to the BundleArchive's m_archiveRootDir
|
||||||
Object bundleArchive = getFelixBundleArchive(bundle);
|
File res = new File(location.substring("file:".length()));
|
||||||
File archiveRoot = getFelixBundleArchiveRootDir(bundleArchive);
|
if (!res.exists())
|
||||||
String currentLocation = getFelixBundleArchiveCurrentLocation(bundleArchive);
|
{
|
||||||
// System.err.println("Got the archive root " + archiveRoot.getAbsolutePath()
|
return null;
|
||||||
// + " current location " + currentLocation);
|
// Object bundleArchive = getFelixBundleArchive(bundle);
|
||||||
return new File(archiveRoot, currentLocation != null
|
// File archiveRoot = getFelixBundleArchiveRootDir(bundleArchive);
|
||||||
? currentLocation : location.substring("file:".length()));
|
// String currentLocation = getFelixBundleArchiveCurrentLocation(bundleArchive);
|
||||||
|
// System.err.println("Got the archive root " + archiveRoot.getAbsolutePath()
|
||||||
|
// + " current location " + currentLocation + " is directory ?");
|
||||||
|
// res = new File(archiveRoot, currentLocation != null
|
||||||
|
// ? currentLocation : location.substring("file:".length()));
|
||||||
|
}
|
||||||
|
return res;
|
||||||
}
|
}
|
||||||
else if (location.startsWith("reference:file:"))
|
else if (location.startsWith("reference:file:"))
|
||||||
{
|
{
|
||||||
|
@ -182,6 +189,29 @@ public class DefaultFileLocatorHelper implements BundleFileLocatorHelper
|
||||||
}
|
}
|
||||||
return webapp;
|
return webapp;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Helper method equivalent to Bundle#getEntry(String entryPath) except that
|
||||||
|
* it searches for entries in the fragments by using the Bundle#findEntries method.
|
||||||
|
*
|
||||||
|
* @param bundle
|
||||||
|
* @param entryPath
|
||||||
|
* @return null or all the entries found for that path.
|
||||||
|
*/
|
||||||
|
public Enumeration<URL> findEntries(Bundle bundle, String entryPath)
|
||||||
|
{
|
||||||
|
int last = entryPath.lastIndexOf('/');
|
||||||
|
String path = last != -1 && last < entryPath.length() -2
|
||||||
|
? entryPath.substring(0, last) : "/";
|
||||||
|
if (!path.startsWith("/"))
|
||||||
|
{
|
||||||
|
path = "/" + path;
|
||||||
|
}
|
||||||
|
String pattern = last != -1 && last < entryPath.length() -2
|
||||||
|
? entryPath.substring(last+1) : entryPath;
|
||||||
|
Enumeration<URL> enUrls = bundle.findEntries(path, pattern, false);
|
||||||
|
return enUrls;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* If the bundle is a jar, returns the jar. If the bundle is a folder, look
|
* If the bundle is a jar, returns the jar. If the bundle is a folder, look
|
||||||
|
@ -231,6 +261,7 @@ public class DefaultFileLocatorHelper implements BundleFileLocatorHelper
|
||||||
|
|
||||||
|
|
||||||
//introspection on equinox to invoke the getLocalURL method on BundleURLConnection
|
//introspection on equinox to invoke the getLocalURL method on BundleURLConnection
|
||||||
|
//equivalent to using the FileLocator without depending on an equinox class.
|
||||||
private static Method BUNDLE_URL_CONNECTION_getLocalURL = null;
|
private static Method BUNDLE_URL_CONNECTION_getLocalURL = null;
|
||||||
private static Method BUNDLE_URL_CONNECTION_getFileURL = null;
|
private static Method BUNDLE_URL_CONNECTION_getFileURL = null;
|
||||||
/**
|
/**
|
||||||
|
@ -297,62 +328,5 @@ public class DefaultFileLocatorHelper implements BundleFileLocatorHelper
|
||||||
}
|
}
|
||||||
return url;
|
return url;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
//introspection on felix
|
|
||||||
private static Field m_bundleArchive_FIELD = null;
|
|
||||||
private static Field m_archiveRootDir_FIELD = null;
|
|
||||||
private static Field m_currentLocation_FIELD = null;
|
|
||||||
private static Object getFelixBundleArchive(Bundle bundle)
|
|
||||||
{
|
|
||||||
try
|
|
||||||
{
|
|
||||||
if (m_bundleArchive_FIELD == null)
|
|
||||||
{
|
|
||||||
m_bundleArchive_FIELD = bundle.getClass().getDeclaredField("m_archive");
|
|
||||||
m_bundleArchive_FIELD.setAccessible(true);
|
|
||||||
}
|
|
||||||
return m_bundleArchive_FIELD.get(bundle);
|
|
||||||
}
|
|
||||||
catch (Throwable t)
|
|
||||||
{
|
|
||||||
t.printStackTrace();
|
|
||||||
}
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
private static File getFelixBundleArchiveRootDir(Object bundleArchive)
|
|
||||||
{
|
|
||||||
try
|
|
||||||
{
|
|
||||||
if (m_archiveRootDir_FIELD == null)
|
|
||||||
{
|
|
||||||
m_archiveRootDir_FIELD = bundleArchive.getClass().getDeclaredField("m_archiveRootDir");
|
|
||||||
m_archiveRootDir_FIELD.setAccessible(true);
|
|
||||||
}
|
|
||||||
return (File)m_archiveRootDir_FIELD.get(bundleArchive);
|
|
||||||
}
|
|
||||||
catch (Throwable t)
|
|
||||||
{
|
|
||||||
t.printStackTrace();
|
|
||||||
}
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
private static String getFelixBundleArchiveCurrentLocation(Object bundleArchive)
|
|
||||||
{
|
|
||||||
try
|
|
||||||
{
|
|
||||||
if (m_currentLocation_FIELD == null)
|
|
||||||
{
|
|
||||||
m_currentLocation_FIELD = bundleArchive.getClass().getDeclaredField("m_currentLocation");
|
|
||||||
m_currentLocation_FIELD.setAccessible(true);
|
|
||||||
}
|
|
||||||
return (String)m_currentLocation_FIELD.get(bundleArchive);
|
|
||||||
}
|
|
||||||
catch (Throwable t)
|
|
||||||
{
|
|
||||||
t.printStackTrace();
|
|
||||||
}
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue