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
.Credentials
;
9 import javax
.jcr
.LoginException
;
10 import javax
.jcr
.Repository
;
11 import javax
.jcr
.RepositoryException
;
12 import javax
.jcr
.Session
;
13 import javax
.servlet
.ServletException
;
14 import javax
.servlet
.http
.HttpServletRequest
;
16 import org
.apache
.commons
.logging
.Log
;
17 import org
.apache
.commons
.logging
.LogFactory
;
18 import org
.apache
.jackrabbit
.server
.SessionProvider
;
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
= Collections
28 .synchronizedMap(new HashMap
<String
, Session
>());
30 private Credentials credentials
= null;
32 public Session
getSession(HttpServletRequest request
, Repository rep
,
33 String workspace
) throws LoginException
, ServletException
,
36 if (!sessions
.containsKey(workspace
)) {
37 Session session
= rep
.login(credentials
, workspace
);
38 sessions
.put(workspace
, session
);
41 Session session
= sessions
.get(workspace
);
42 if (!session
.isLive()) {
43 sessions
.remove(workspace
);
44 session
= rep
.login(credentials
, workspace
);
45 sessions
.put(workspace
, session
);
51 public void releaseSession(Session session
) {
52 if (log
.isDebugEnabled())
53 log
.debug("Releasing JCR session " + session
);
55 // FIXME: find a way to log out when the HTTP session is expired
58 public void dispose() {
59 for (String workspace
: sessions
.keySet()) {
60 Session session
= sessions
.get(workspace
);