You are viewing a plain text version of this content. The canonical link for it is here.
Posted to cvs@cocoon.apache.org by da...@apache.org on 2006/04/17 19:59:29 UTC

svn commit: r394738 - /cocoon/trunk/core/cocoon-blocks-fw/cocoon-blocks-fw-impl/src/main/java/org/apache/cocoon/blocks/Activator.java

Author: danielf
Date: Mon Apr 17 10:59:27 2006
New Revision: 394738

URL: http://svn.apache.org/viewcvs?rev=394738&view=rev
Log:
The ServletContext.getResource should be resolved in the bundle of the servlet instead of the bundle of the cocoon-blocks-fw. 

Modified:
    cocoon/trunk/core/cocoon-blocks-fw/cocoon-blocks-fw-impl/src/main/java/org/apache/cocoon/blocks/Activator.java

Modified: cocoon/trunk/core/cocoon-blocks-fw/cocoon-blocks-fw-impl/src/main/java/org/apache/cocoon/blocks/Activator.java
URL: http://svn.apache.org/viewcvs/cocoon/trunk/core/cocoon-blocks-fw/cocoon-blocks-fw-impl/src/main/java/org/apache/cocoon/blocks/Activator.java?rev=394738&r1=394737&r2=394738&view=diff
==============================================================================
--- cocoon/trunk/core/cocoon-blocks-fw/cocoon-blocks-fw-impl/src/main/java/org/apache/cocoon/blocks/Activator.java (original)
+++ cocoon/trunk/core/cocoon-blocks-fw/cocoon-blocks-fw-impl/src/main/java/org/apache/cocoon/blocks/Activator.java Mon Apr 17 10:59:27 2006
@@ -15,15 +15,21 @@
  */
 package org.apache.cocoon.blocks;
 
+import java.io.IOException;
+import java.net.URL;
 import java.util.HashMap;
 import java.util.Iterator;
 import java.util.Map.Entry;
 
 import javax.servlet.Servlet;
 import javax.servlet.ServletException;
+import javax.servlet.http.HttpServletRequest;
+import javax.servlet.http.HttpServletResponse;
 
+import org.osgi.framework.Bundle;
 import org.osgi.framework.ServiceReference;
 import org.osgi.service.component.ComponentContext;
+import org.osgi.service.http.HttpContext;
 import org.osgi.service.http.HttpService;
 import org.osgi.service.http.NamespaceException;
 import org.osgi.service.log.LogService;
@@ -80,10 +86,27 @@
     protected void deactivate(ComponentContext context) {
     }
     
-    private void registerServlet(String path, ServiceReference reference)
+    private void registerServlet(String path, final ServiceReference reference)
         throws ServletException, NamespaceException {
         Servlet servlet = (Servlet) this.context.locateService("Servlet", reference);
-        this.httpService.registerServlet(path, servlet, null, null);
+        
+        // Create a context that resolves resources in the bundle context where
+        // the servlet origins from
+        HttpContext httpContext = new HttpContext() {
+            private Bundle bundle = reference.getBundle();
+            public boolean handleSecurity(HttpServletRequest request, HttpServletResponse response) throws IOException {
+                return true;
+            }
+
+            public URL getResource(String name) {
+                return this.bundle.getEntry(name);
+            }
+
+            public String getMimeType(String name) {
+                return null;
+            }
+        };
+        this.httpService.registerServlet(path, servlet, null, httpContext);
         this.log.log(LogService.LOG_DEBUG, "Register Servlet at " + path);    
     }