X-Git-Url: http://git.argeo.org/?a=blobdiff_plain;ds=inline;f=plugins%2Forg.argeo.slc.client.ui.dist%2Fsrc%2Fmain%2Fjava%2Forg%2Fargeo%2Fslc%2Fclient%2Fui%2Fdist%2Fcommands%2FCopyWorkspace.java;h=72b5a75035045945845ae62190976de00954ef65;hb=0d236262a853a1286b317c30d64d4692bc21c7a4;hp=2711694621c7d14c16b3a3d18889f50ca34ba688;hpb=dc95cc0fdc36c88e778cdfd52d443d0a0b8d926c;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/CopyWorkspace.java b/plugins/org.argeo.slc.client.ui.dist/src/main/java/org/argeo/slc/client/ui/dist/commands/CopyWorkspace.java index 271169462..72b5a7503 100644 --- a/plugins/org.argeo.slc.client.ui.dist/src/main/java/org/argeo/slc/client/ui/dist/commands/CopyWorkspace.java +++ b/plugins/org.argeo.slc.client.ui.dist/src/main/java/org/argeo/slc/client/ui/dist/commands/CopyWorkspace.java @@ -19,6 +19,7 @@ import javax.jcr.Credentials; import javax.jcr.Node; import javax.jcr.Repository; import javax.jcr.RepositoryException; +import javax.jcr.RepositoryFactory; import javax.jcr.Session; import javax.jcr.security.Privilege; @@ -26,15 +27,13 @@ import org.argeo.ArgeoException; import org.argeo.jcr.JcrUtils; import org.argeo.slc.client.ui.dist.DistPlugin; import org.argeo.slc.client.ui.dist.utils.CommandHelpers; -import org.argeo.slc.client.ui.dist.views.DistributionsView; -import org.argeo.slc.client.ui.dist.views.DistributionsView.DistributionViewSelectedElement; 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; import org.eclipse.jface.dialogs.InputDialog; -import org.eclipse.ui.IWorkbenchPart; -import org.eclipse.ui.IWorkbenchWindow; +import org.eclipse.ui.handlers.HandlerUtil; /** * Create a copy of the chosen workspace in the current repository. @@ -44,37 +43,39 @@ public class CopyWorkspace extends AbstractHandler { // private static final Log log = LogFactory.getLog(CopyWorkspace.class); public final static String ID = DistPlugin.ID + ".copyWorkspace"; public final static String DEFAULT_LABEL = "Duplicate"; + public final static String PARAM_SOURCE_WORKSPACE_NAME = "srcWkspName"; + public final static String PARAM_TARGET_REPO_PATH = "targetRepoPath"; public final static String DEFAULT_ICON_PATH = "icons/addItem.gif"; - private Repository repository; - private Credentials credentials; - private String wkspName; + // DEPENDENCY INJECTION + private RepositoryFactory repositoryFactory; + private Keyring keyring; + private Repository nodeRepository; + private String slcRole = "ROLE_SLC"; public Object execute(ExecutionEvent event) throws ExecutionException { - IWorkbenchWindow iww = DistPlugin.getDefault().getWorkbench() - .getActiveWorkbenchWindow(); - IWorkbenchPart view = iww.getActivePage().getActivePart(); - if (view instanceof DistributionsView) { - DistributionViewSelectedElement dvse = ((DistributionsView) view) - .getSelectedElement(); - if (dvse != null && (dvse.isWorkspace)) { - repository = dvse.repository; - credentials = dvse.credentials; - wkspName = dvse.wkspName; - } - } - if (repository == null || wkspName == null) - return null; - InputDialog inputDialog = new InputDialog(iww.getShell(), - "New copy of workspace " + wkspName, - "Choose a name for the workspace to create", "", null); - inputDialog.open(); - String newWorkspaceName = inputDialog.getValue(); + String targetRepoPath = event.getParameter(PARAM_TARGET_REPO_PATH); + String wkspName = event.getParameter(PARAM_SOURCE_WORKSPACE_NAME); + + Session nodeSession = null; Session srcSession = null; Session newSession = null; try { + nodeSession = nodeRepository.login(); + Node repoNode = nodeSession.getNode(targetRepoPath); + Repository repository = RepoUtils.getRepository(repositoryFactory, + keyring, repoNode); + Credentials credentials = RepoUtils.getRepositoryCredentials( + keyring, repoNode); + + InputDialog inputDialog = new InputDialog(HandlerUtil + .getActiveWorkbenchWindow(event).getShell(), + "New copy of workspace " + wkspName, + "Choose a name for the workspace to create", "", null); + inputDialog.open(); + String newWorkspaceName = inputDialog.getValue(); srcSession = repository.login(credentials, wkspName); // Create the workspace @@ -91,16 +92,23 @@ public class CopyWorkspace extends AbstractHandler { throw new ArgeoException( "Unexpected error while creating the new workspace.", re); } finally { - if (srcSession != null) - srcSession.logout(); - if (newSession != null) - newSession.logout(); + JcrUtils.logoutQuietly(newSession); + JcrUtils.logoutQuietly(srcSession); + JcrUtils.logoutQuietly(nodeSession); } return null; } /* DEPENDENCY INJECTION */ - public void setRepository(Repository repository) { - this.repository = repository; + public void setNodeRepository(Repository nodeRepository) { + this.nodeRepository = nodeRepository; + } + + public void setRepositoryFactory(RepositoryFactory repositoryFactory) { + this.repositoryFactory = repositoryFactory; + } + + public void setKeyring(Keyring keyring) { + this.keyring = keyring; } -} +} \ No newline at end of file