You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@sling.apache.org by ju...@apache.org on 2010/06/01 17:12:32 UTC

svn commit: r950103 - /sling/trunk/bundles/jcr/resource/src/main/java/org/apache/sling/jcr/resource/internal/JcrResourceResolver.java

Author: justin
Date: Tue Jun  1 15:12:31 2010
New Revision: 950103

URL: http://svn.apache.org/viewvc?rev=950103&view=rev
Log:
SLING-1447 - if resolve is called with a request which specifies a workspace, future requests to adaptTo(Session.class) will return a session to the request-specified workspace. also modifying queryResources to query the request-specified workspace under those conditions

Modified:
    sling/trunk/bundles/jcr/resource/src/main/java/org/apache/sling/jcr/resource/internal/JcrResourceResolver.java

Modified: sling/trunk/bundles/jcr/resource/src/main/java/org/apache/sling/jcr/resource/internal/JcrResourceResolver.java
URL: http://svn.apache.org/viewvc/sling/trunk/bundles/jcr/resource/src/main/java/org/apache/sling/jcr/resource/internal/JcrResourceResolver.java?rev=950103&r1=950102&r2=950103&view=diff
==============================================================================
--- sling/trunk/bundles/jcr/resource/src/main/java/org/apache/sling/jcr/resource/internal/JcrResourceResolver.java (original)
+++ sling/trunk/bundles/jcr/resource/src/main/java/org/apache/sling/jcr/resource/internal/JcrResourceResolver.java Tue Jun  1 15:12:31 2010
@@ -104,6 +104,9 @@ public class JcrResourceResolver
     /** Closed marker. */
     private volatile boolean closed = false;
 
+    /** a resolver with the workspace which was specifically requested via a request attribute. */
+    private ResourceResolver requestBoundResolver;
+
     public JcrResourceResolver(final JcrResourceProviderEntry rootProvider,
                                final JcrResourceResolverFactoryImpl factory,
                                final boolean isAdmin,
@@ -179,6 +182,7 @@ public class JcrResourceResolver
             LOGGER.debug("Delegating resolving to resolver for workspace {}", workspaceName);
             try {
                 final ResourceResolver wsResolver = getResolverForWorkspace(workspaceName);
+                requestBoundResolver = wsResolver;
                 return wsResolver.resolve(request, absPath);
             } catch (LoginException e) {
                 // requested a resource in a workspace I don't have access to.
@@ -644,7 +648,7 @@ public class JcrResourceResolver
     throws SlingException {
         checkClosed();
         try {
-            QueryResult result = JcrResourceUtil.query(getSession(), query,
+            QueryResult result = JcrResourceUtil.query(adaptTo(Session.class), query,
                 language);
             final String[] colNames = result.getColumnNames();
             final RowIterator rows = result.getRows();
@@ -693,7 +697,11 @@ public class JcrResourceResolver
     public <AdapterType> AdapterType adaptTo(Class<AdapterType> type) {
         checkClosed();
         if (type == Session.class) {
-            return (AdapterType) getSession();
+            if (requestBoundResolver != null) {
+                return (AdapterType) requestBoundResolver.adaptTo(Session.class);
+            } else {
+                return (AdapterType) getSession();
+            }
         }
 
         // fall back to default behaviour