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%2FDeleteWorkspace.java;h=d4a7783a48857c937cc74ab52c1b75a1dea029a3;hb=706b98df2c68382d7bd501fa05cb128f329087ee;hp=dd016268923267a5768c235f8c8ea4d12c300b0f;hpb=de4970e4ea18056ef32137834bb0ac59b23117ce;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/DeleteWorkspace.java b/plugins/org.argeo.slc.client.ui.dist/src/main/java/org/argeo/slc/client/ui/dist/commands/DeleteWorkspace.java index dd0162689..d4a7783a4 100644 --- a/plugins/org.argeo.slc.client.ui.dist/src/main/java/org/argeo/slc/client/ui/dist/commands/DeleteWorkspace.java +++ b/plugins/org.argeo.slc.client.ui.dist/src/main/java/org/argeo/slc/client/ui/dist/commands/DeleteWorkspace.java @@ -20,6 +20,7 @@ import javax.jcr.Node; import javax.jcr.NodeIterator; import javax.jcr.Repository; import javax.jcr.RepositoryException; +import javax.jcr.RepositoryFactory; import javax.jcr.Session; import javax.jcr.nodetype.NodeType; @@ -27,76 +28,76 @@ 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.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.MessageDialog; -import org.eclipse.ui.IWorkbenchPart; -import org.eclipse.ui.IWorkbenchWindow; +import org.eclipse.jface.resource.ImageDescriptor; /** * Delete chosen workspace in the current repository. + * + * Due to current version of JackRabbit, it only cleans it for the time being, + * removing all nodes of type {@code NodeType.NT_FOLDER} and + * {@code NodeType.NT_UNSTRUCTURED} */ - public class DeleteWorkspace extends AbstractHandler { // private static final Log log = LogFactory.getLog(DeleteWorkspace.class); public final static String ID = DistPlugin.ID + ".deleteWorkspace"; public final static String DEFAULT_LABEL = "Clear"; - public final static String DEFAULT_ICON_PATH = "icons/removeItem.gif"; - - private Repository repository; - private Credentials credentials; + public final static ImageDescriptor DEFAULT_ICON = DistPlugin + .getImageDescriptor("icons/removeItem.gif"); - public Object execute(ExecutionEvent event) throws ExecutionException { + public final static String PARAM_WORKSPACE_NAME = "workspaceName"; + public final static String PARAM_TARGET_REPO_PATH = "targetRepoPath"; - String workspaceName = ""; + // DEPENDENCY INJECTION + private RepositoryFactory repositoryFactory; + private Keyring keyring; + private Repository nodeRepository; - 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; - workspaceName = dvse.wkspName; - } - } + public Object execute(ExecutionEvent event) throws ExecutionException { - if (repository == null) - return null; + String targetRepoPath = event.getParameter(PARAM_TARGET_REPO_PATH); + String workspaceName = event.getParameter(PARAM_WORKSPACE_NAME); - String msg = "Your are about to completely delete workspace [" - + workspaceName + "].\n Do you really want to proceed ?"; - boolean result = MessageDialog.openConfirm(DistPlugin.getDefault() - .getWorkbench().getDisplay().getActiveShell(), - "Confirm workspace deletion", msg); + Session nodeSession = null; + Session session = null; + try { + nodeSession = nodeRepository.login(); + Node repoNode = nodeSession.getNode(targetRepoPath); + Repository repository = RepoUtils.getRepository(repositoryFactory, + keyring, repoNode); + Credentials credentials = RepoUtils.getRepositoryCredentials( + keyring, repoNode); - if (result) { - // msg = - // "There is no possible turning back, are your REALLY sure you want to proceed ?"; - msg = "WARNING: \nCurrent Jackrabbit version used does " - + "not support workspace management.\n" - + "Thus, the workspace will only be cleaned so " - + "that you can launch fetch process again.\n\n" - + "Do you still want to proceed ?"; - result = MessageDialog.openConfirm(DistPlugin.getDefault() + String msg = "Your are about to completely delete workspace [" + + workspaceName + "].\n Do you really want to proceed?"; + boolean result = MessageDialog.openConfirm(DistPlugin.getDefault() .getWorkbench().getDisplay().getActiveShell(), "Confirm workspace deletion", msg); - } - if (result) { - Session session = null; - try { + if (result) { + // msg = + // "There is no possible turning back, are your REALLY sure you want to proceed ?"; + msg = "WARNING: \nCurrent Jackrabbit version used does " + + "not support workspace deletion.\n" + + "Thus, the workspace will only be cleaned so " + + "that you can launch fetch process again.\n\n" + + "Do you still want to proceed?"; + result = MessageDialog.openConfirm(DistPlugin.getDefault() + .getWorkbench().getDisplay().getActiveShell(), + "Confirm workspace deletion", msg); + } + + if (result) { session = repository.login(credentials, workspaceName); // TODO use this with a newer version of Jackrabbit // Workspace wsp = session.getWorkspace(); // wsp.deleteWorkspace(workspaceName); - NodeIterator nit = session.getRootNode().getNodes(); while (nit.hasNext()) { Node node = nit.nextNode(); @@ -108,14 +109,28 @@ public class DeleteWorkspace extends AbstractHandler { } } CommandHelpers.callCommand(RefreshDistributionsView.ID); - } catch (RepositoryException re) { - throw new SlcException( - "Unexpected error while deleting workspace [" - + workspaceName + "].", re); - } finally { - JcrUtils.logoutQuietly(session); } + } catch (RepositoryException re) { + throw new SlcException( + "Unexpected error while deleting workspace [" + + workspaceName + "].", re); + } finally { + JcrUtils.logoutQuietly(session); + JcrUtils.logoutQuietly(nodeSession); } return null; } + + /* DEPENDENCY INJECTION */ + 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