Remove node data model, home areas based on workspaces instead.
[lgpl/argeo-commons.git] / org.argeo.cms / src / org / argeo / cms / internal / http / CmsSessionProvider.java
index c0284f4c72967b7630cff88622d64d9cf57a3fff..14f311f3796903721987b8c197f8cd4d3f0ca690 100644 (file)
@@ -1,36 +1,31 @@
 package org.argeo.cms.internal.http;
 
 import java.io.Serializable;
-import java.security.PrivilegedExceptionAction;
-import java.util.LinkedHashMap;
 
 import javax.jcr.Repository;
 import javax.jcr.RepositoryException;
 import javax.jcr.Session;
-import javax.security.auth.Subject;
-import javax.security.auth.login.LoginContext;
 import javax.servlet.ServletException;
 import javax.servlet.http.HttpServletRequest;
 
+import org.apache.commons.logging.Log;
+import org.apache.commons.logging.LogFactory;
 import org.apache.jackrabbit.server.SessionProvider;
-import org.argeo.cms.CmsException;
-import org.argeo.cms.auth.CmsSession;
+import org.argeo.cms.internal.auth.CmsSessionImpl;
 import org.argeo.jcr.JcrUtils;
-import org.argeo.node.NodeConstants;
 
 /**
  * Implements an open session in view patter: a new JCR session is created for
  * each request
  */
-class CmsSessionProvider implements SessionProvider, Serializable {
+public class CmsSessionProvider implements SessionProvider, Serializable {
        private static final long serialVersionUID = -1358136599534938466L;
 
-       // private final static Log log =
-       // LogFactory.getLog(CmsSessionProvider.class);
+       private final static Log log = LogFactory.getLog(CmsSessionProvider.class);
 
        private final String alias;
 
-       private LinkedHashMap<Session, CmsSession> cmsSessions = new LinkedHashMap<>();
+//     private LinkedHashMap<Session, CmsSessionImpl> cmsSessions = new LinkedHashMap<>();
 
        public CmsSessionProvider(String alias) {
                this.alias = alias;
@@ -39,41 +34,27 @@ class CmsSessionProvider implements SessionProvider, Serializable {
        public Session getSession(HttpServletRequest request, Repository rep, String workspace)
                        throws javax.jcr.LoginException, ServletException, RepositoryException {
 
-               CmsSession cmsSession = WebCmsSessionImpl.getCmsSession(request);
-               if (cmsSession == null)
-                       return anonymousSession(request, rep, workspace);
-               Session session = cmsSession.getDataSession(alias, workspace, rep);
-               cmsSessions.put(session, cmsSession);
-               return session;
-       }
+               // a client is scanning parent URLs.
+               if (workspace == null)
+                       return null;
 
-       private synchronized Session anonymousSession(HttpServletRequest request, Repository repository, String workspace) {
-               // TODO rather log in here as anonymous?
-               LoginContext lc = (LoginContext) request.getAttribute(NodeConstants.LOGIN_CONTEXT_USER);
-               if (lc == null)
-                       throw new CmsException("No login context available");
-               // optimize
-               Session session;
-               try {
-                       session = Subject.doAs(lc.getSubject(), new PrivilegedExceptionAction<Session>() {
-                               @Override
-                               public Session run() throws Exception {
-                                       return repository.login(workspace);
-                               }
-                       });
-               } catch (Exception e) {
-                       throw new CmsException("Cannot log in to JCR", e);
+               CmsSessionImpl cmsSession = WebCmsSessionImpl.getCmsSession(request);
+               if (log.isTraceEnabled()) {
+                       log.trace("Get JCR session from " + cmsSession);
                }
+               Session session = cmsSession.newDataSession(alias, workspace, rep);
+//             cmsSessions.put(session, cmsSession);
                return session;
        }
 
-       public synchronized void releaseSession(Session session) {
-               if (cmsSessions.containsKey(session)) {
-                       CmsSession cmsSession = cmsSessions.get(session);
-                       cmsSession.releaseDataSession(alias, session);
-               } else {
-                       // anonymous
-                       JcrUtils.logoutQuietly(session);
-               }
+       public void releaseSession(Session session) {
+               JcrUtils.logoutQuietly(session);
+//             if (cmsSessions.containsKey(session)) {
+//                     CmsSessionImpl cmsSession = cmsSessions.get(session);
+//                     cmsSession.releaseDataSession(alias, session);
+//             } else {
+//                     log.warn("JCR session " + session + " not found in CMS session list. Logging it out...");
+//                     JcrUtils.logoutQuietly(session);
+//             }
        }
 }