From: Mathieu Baudier Date: Wed, 16 Feb 2022 08:49:08 +0000 (+0100) Subject: Make open admin session more robust. X-Git-Tag: argeo-commons-2.3.5~17 X-Git-Url: https://git.argeo.org/?p=lgpl%2Fargeo-commons.git;a=commitdiff_plain;h=bc26c1e21422319813b910e74270fa923607b24b Make open admin session more robust. --- diff --git a/jcr/org.argeo.cms.jcr/src/org/argeo/cms/jcr/CmsJcrUtils.java b/jcr/org.argeo.cms.jcr/src/org/argeo/cms/jcr/CmsJcrUtils.java index b5d9adfca..4a28dca77 100644 --- a/jcr/org.argeo.cms.jcr/src/org/argeo/cms/jcr/CmsJcrUtils.java +++ b/jcr/org.argeo.cms.jcr/src/org/argeo/cms/jcr/CmsJcrUtils.java @@ -239,11 +239,10 @@ public class CmsJcrUtils { /** * Open a JCR session with full read/write rights on the data, as * {@link CmsConstants#ROLE_USER_ADMIN}, using the - * {@link CmsAuth#LOGIN_CONTEXT_DATA_ADMIN} login context. For security - * hardened deployement, use {@link AuthPermission} on this login context. + * {@link CmsAuth#LOGIN_CONTEXT_DATA_ADMIN} login context. For security hardened + * deployement, use {@link AuthPermission} on this login context. */ public static Session openDataAdminSession(Repository repository, String workspaceName) { - ClassLoader currentCl = Thread.currentThread().getContextClassLoader(); LoginContext loginContext; try { loginContext = new LoginContext(CmsAuth.LOGIN_CONTEXT_DATA_ADMIN); @@ -251,22 +250,28 @@ public class CmsJcrUtils { } catch (LoginException e1) { throw new RuntimeException("Could not login as data admin", e1); } finally { - Thread.currentThread().setContextClassLoader(currentCl); } - return Subject.doAs(loginContext.getSubject(), new PrivilegedAction() { - @Override - public Session run() { - try { - return repository.login(workspaceName); - } catch (NoSuchWorkspaceException e) { - throw new IllegalArgumentException("No workspace " + workspaceName + " available", e); - } catch (RepositoryException e) { - throw new RuntimeException("Cannot open data admin session", e); + ClassLoader currentCl = Thread.currentThread().getContextClassLoader(); + try { + Thread.currentThread().setContextClassLoader(CmsJcrUtils.class.getClassLoader()); + return Subject.doAs(loginContext.getSubject(), new PrivilegedAction() { + + @Override + public Session run() { + try { + return repository.login(workspaceName); + } catch (NoSuchWorkspaceException e) { + throw new IllegalArgumentException("No workspace " + workspaceName + " available", e); + } catch (RepositoryException e) { + throw new RuntimeException("Cannot open data admin session", e); + } } - } - }); + }); + } finally { + Thread.currentThread().setContextClassLoader(currentCl); + } } /** Singleton. */