1 package org
.argeo
.jackrabbit
.remote
;
3 import java
.io
.Serializable
;
4 import java
.util
.Collections
;
5 import java
.util
.HashMap
;
8 import javax
.jcr
.LoginException
;
9 import javax
.jcr
.Repository
;
10 import javax
.jcr
.RepositoryException
;
11 import javax
.jcr
.Session
;
12 import javax
.servlet
.ServletException
;
13 import javax
.servlet
.http
.HttpServletRequest
;
15 import org
.apache
.commons
.logging
.Log
;
16 import org
.apache
.commons
.logging
.LogFactory
;
17 import org
.apache
.jackrabbit
.server
.SessionProvider
;
18 import org
.argeo
.ArgeoException
;
20 /** To be injected, typically of scope="session" */
21 public class SimpleSessionProvider
implements SessionProvider
, Serializable
{
22 private static final long serialVersionUID
= 2270957712453841368L;
24 private final static Log log
= LogFactory
25 .getLog(SimpleSessionProvider
.class);
27 private transient Map
<String
, Session
> sessions
;
29 public Session
getSession(HttpServletRequest request
, Repository rep
,
30 String workspace
) throws LoginException
, ServletException
,
32 // since sessions is transient it can't be restored from the session
34 sessions
= Collections
35 .synchronizedMap(new HashMap
<String
, Session
>());
37 if (!sessions
.containsKey(workspace
)) {
39 Session session
= rep
.login(null, workspace
);
40 if (log
.isTraceEnabled())
41 log
.trace("User " + session
.getUserID() + " logged into "
42 + request
.getServletPath());
43 sessions
.put(workspace
, session
);
45 } catch (Exception e
) {
46 throw new ArgeoException("Cannot open session", e
);
49 Session session
= sessions
.get(workspace
);
50 if (!session
.isLive()) {
51 sessions
.remove(workspace
);
52 session
= rep
.login(null, workspace
);
53 sessions
.put(workspace
, session
);
59 public void releaseSession(Session session
) {
60 if (log
.isTraceEnabled())
61 log
.trace("Releasing JCR session " + session
);
67 public void dispose() {
69 for (String workspace
: sessions
.keySet()) {
70 Session session
= sessions
.get(workspace
);