</property>
</bean>
-<!-- <bean id="repositoryRegister" class="org.argeo.jcr.DefaultRepositoryRegister" /> -->
+ <!-- <bean id="repositoryRegister" class="org.argeo.jcr.DefaultRepositoryRegister"
+ /> -->
- <bean id="sessionProvider" scope="session" init-method="init"
- destroy-method="dispose" class="org.argeo.jackrabbit.remote.SimpleSessionProvider">
- <aop:scoped-proxy proxy-target-class="false" />
- </bean>
+ <bean id="sessionProvider" init-method="init" destroy-method="destroy"
+ class="org.argeo.jackrabbit.remote.SimpleSessionProvider" />
-<!-- <bean id="osivInterceptor" class="org.argeo.jcr.mvc.OpenSessionInViewJcrInterceptor"> -->
-<!-- <property name="session" ref="jcrSession" /> -->
-<!-- </bean> -->
+ <!-- <bean id="osivInterceptor" class="org.argeo.jcr.mvc.OpenSessionInViewJcrInterceptor"> -->
+ <!-- <property name="session" ref="jcrSession" /> -->
+ <!-- </bean> -->
</beans>
\ No newline at end of file
import org.argeo.jcr.JcrUtils;
/**
- * To be injected, typically of scope="session". Implements an open session in
- * view patter: a new JCR session is created for each request
+ * Implements an open session in view patter: a new JCR session is created for
+ * each request
*/
public class SimpleSessionProvider implements SessionProvider, Serializable {
private static final long serialVersionUID = 2270957712453841368L;
if (openSessionInView) {
JackrabbitSession session = (JackrabbitSession) rep
.login(workspace);
- writeRemoteRoles(session);
+ if (!workspace.equals(securityWorkspace))
+ writeRemoteRoles(session);
return session;
} else {
// since sessions is transient it can't be restored from the session
try {
JackrabbitSession session = (JackrabbitSession) rep.login(
null, workspace);
- writeRemoteRoles(session);
+ if (!workspace.equals(securityWorkspace))
+ writeRemoteRoles(session);
if (log.isTraceEnabled())
log.trace("User " + session.getUserID()
+ " logged into " + request.getServletPath());
protected void writeRemoteRoles(JackrabbitSession session)
throws RepositoryException {
- if (!session.getWorkspace().getName().equals(securityWorkspace))
- return;
-
// retrieve roles
String userId = session.getUserID();
UserManager userManager = session.getUserManager();
public void init() {
}
- public void dispose() {
+ public void destroy() {
if (sessions != null)
for (String workspace : sessions.keySet()) {
Session session = sessions.get(workspace);
}
}
}
+
+ /**
+ * If set to true a new session will be created each time (the default),
+ * otherwise a single session is cached by workspace and the object should
+ * be of scope session (not supported)
+ */
+ public void setOpenSessionInView(Boolean openSessionInView) {
+ this.openSessionInView = openSessionInView;
+ }
+
+ public void setSecurityWorkspace(String securityWorkspace) {
+ this.securityWorkspace = securityWorkspace;
+ }
+
}