X-Git-Url: http://git.argeo.org/?a=blobdiff_plain;f=plugins%2Forg.argeo.slc.client.ui.dist%2Fsrc%2Fmain%2Fjava%2Forg%2Fargeo%2Fslc%2Fclient%2Fui%2Fdist%2Fcommands%2FOpenModuleEditor.java;h=9250b25e69d92606e0b3d097d460099ef396f785;hb=1e6cf7254fb9f150251594cf0383b3b1c5210517;hp=85d047a95d5d18dd394042af1afaedf2606daf71;hpb=524221f25edad4b09aac22555450164e587b304a;p=gpl%2Fargeo-slc.git diff --git a/plugins/org.argeo.slc.client.ui.dist/src/main/java/org/argeo/slc/client/ui/dist/commands/OpenModuleEditor.java b/plugins/org.argeo.slc.client.ui.dist/src/main/java/org/argeo/slc/client/ui/dist/commands/OpenModuleEditor.java index 85d047a95..9250b25e6 100644 --- a/plugins/org.argeo.slc.client.ui.dist/src/main/java/org/argeo/slc/client/ui/dist/commands/OpenModuleEditor.java +++ b/plugins/org.argeo.slc.client.ui.dist/src/main/java/org/argeo/slc/client/ui/dist/commands/OpenModuleEditor.java @@ -16,21 +16,17 @@ package org.argeo.slc.client.ui.dist.commands; import javax.jcr.Node; -import javax.jcr.Repository; import javax.jcr.RepositoryException; -import javax.jcr.RepositoryFactory; import javax.jcr.Session; -import org.argeo.jcr.ArgeoNames; import org.argeo.jcr.JcrUtils; import org.argeo.slc.SlcException; import org.argeo.slc.client.ui.dist.DistPlugin; +import org.argeo.slc.client.ui.dist.RepoService; import org.argeo.slc.client.ui.dist.editors.ArtifactVersionEditor; import org.argeo.slc.client.ui.dist.editors.ModularDistVersionEditor; import org.argeo.slc.client.ui.dist.editors.ModuleEditorInput; import org.argeo.slc.jcr.SlcTypes; -import org.argeo.slc.repo.RepoUtils; -import org.argeo.util.security.Keyring; import org.eclipse.core.commands.AbstractHandler; import org.eclipse.core.commands.ExecutionEvent; import org.eclipse.core.commands.ExecutionException; @@ -56,11 +52,7 @@ public class OpenModuleEditor extends AbstractHandler { public final static String PARAM_MODULE_PATH = "param.modulePath"; /* DEPENDENCY INJECTION */ - private Repository localRepository; - // We must log in the corresponding repository to get the node and be able - // to decide which editor to open depending on its mixin - private RepositoryFactory repositoryFactory; - private Keyring keyring; + private RepoService repoService; public Object execute(ExecutionEvent event) throws ExecutionException { String repoNodePath = event.getParameter(PARAM_REPO_NODE_PATH); @@ -68,43 +60,22 @@ public class OpenModuleEditor extends AbstractHandler { String workspaceName = event.getParameter(PARAM_WORKSPACE_NAME); String modulePath = event.getParameter(PARAM_MODULE_PATH); - Session localSession = null; Session businessSession = null; - Node repoNode = null; - try { - try { - localSession = localRepository.login(); - if (repoNodePath != null - && localSession.nodeExists(repoNodePath)) - repoNode = localSession.getNode(repoNodePath); - - businessSession = RepoUtils.getCorrespondingSession( - repositoryFactory, keyring, repoNode, repoUri, - workspaceName); - if (repoUri == null && repoNode != null) - repoUri = repoNode.getProperty(ArgeoNames.ARGEO_URI) - .getString(); + businessSession = repoService.getRemoteSession(repoNodePath, + repoUri, workspaceName); - } catch (RepositoryException e) { - throw new SlcException("Cannot log to workspace " - + workspaceName + " for repo defined in " - + repoNodePath, e); - } finally { - JcrUtils.logoutQuietly(localSession); - } - - ModuleEditorInput wei = new ModuleEditorInput(repoNodePath, + Node module = businessSession.getNode(modulePath); + ModuleEditorInput mei = new ModuleEditorInput(repoNodePath, repoUri, workspaceName, modulePath); - Node artifact = businessSession.getNode(modulePath); - // Choose correct editor based on the artifact mixin - if (artifact.isNodeType(SlcTypes.SLC_MODULAR_DISTRIBUTION)) + // Choose correct editor based on its mixin + if (module.isNodeType(SlcTypes.SLC_MODULAR_DISTRIBUTION)) HandlerUtil.getActiveWorkbenchWindow(event).getActivePage() - .openEditor(wei, ModularDistVersionEditor.ID); + .openEditor(mei, ModularDistVersionEditor.ID); else HandlerUtil.getActiveWorkbenchWindow(event).getActivePage() - .openEditor(wei, ArtifactVersionEditor.ID); + .openEditor(mei, ArtifactVersionEditor.ID); } catch (RepositoryException e) { throw new SlcException("Unexpected error while " + "getting repoNode info for repoNode at path " @@ -121,16 +92,7 @@ public class OpenModuleEditor extends AbstractHandler { } /* DEPENDENCY INJECTION */ - public void setLocalRepository(Repository localRepository) { - this.localRepository = localRepository; - } - - public void setRepositoryFactory(RepositoryFactory repositoryFactory) { - this.repositoryFactory = repositoryFactory; - } - - public void setKeyring(Keyring keyring) { - this.keyring = keyring; + public void setRepoService(RepoService repoService) { + this.repoService = repoService; } - } \ No newline at end of file