summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorSelvam <selvam@gluster.com>2011-04-29 15:19:50 +0530
committerSelvam <selvam@gluster.com>2011-04-29 15:19:50 +0530
commit1a2533deb10ed4dc0c4d910ce830a7065b845e68 (patch)
treee9c83f01d03f0c959cfb65cb0d7a15935b53b543 /src
parent3149b18d24539f5680848c25064f447c15bbbcc4 (diff)
parent3cc0768e0baf35ea140262e4f646cbdb9a3b8b84 (diff)
Merge branch 'expand-volume'
Conflicts: src/com.gluster.storage.management.client/src/com/gluster/storage/management/client/VolumesClient.java src/com.gluster.storage.management.core/src/com/gluster/storage/management/core/model/Volume.java src/com.gluster.storage.management.core/src/com/gluster/storage/management/core/utils/StringUtil.java src/com.gluster.storage.management.gui/plugin.xml src/com.gluster.storage.management.gui/src/com/gluster/storage/management/gui/actions/AddDiskAction.java src/com.gluster.storage.management.gui/src/com/gluster/storage/management/gui/dialogs/AddDiskPage.java src/com.gluster.storage.management.gui/src/com/gluster/storage/management/gui/dialogs/AddDiskWizard.java src/com.gluster.storage.management.server/src/com/gluster/storage/management/server/resources/VolumesResource.java src/com.gluster.storage.management.server/src/com/gluster/storage/management/server/utils/GlusterUtil.java
Diffstat (limited to 'src')
-rw-r--r--src/com.gluster.storage.management.client/src/com/gluster/storage/management/client/DiscoveredServersClient.java1
-rw-r--r--src/com.gluster.storage.management.client/src/com/gluster/storage/management/client/VolumesClient.java62
-rw-r--r--src/com.gluster.storage.management.core/src/com/gluster/storage/management/core/model/Volume.java4
-rw-r--r--src/com.gluster.storage.management.core/src/com/gluster/storage/management/core/utils/GlusterCoreUtil.java38
-rw-r--r--src/com.gluster.storage.management.core/src/com/gluster/storage/management/core/utils/StringUtil.java10
-rw-r--r--src/com.gluster.storage.management.gui/plugin.xml5
-rw-r--r--src/com.gluster.storage.management.gui/src/com/gluster/storage/management/gui/actions/AddDiskAction.java25
-rw-r--r--src/com.gluster.storage.management.gui/src/com/gluster/storage/management/gui/dialogs/AddDiskPage.java94
-rw-r--r--src/com.gluster.storage.management.gui/src/com/gluster/storage/management/gui/dialogs/AddDiskWizard.java81
-rw-r--r--src/com.gluster.storage.management.gui/src/com/gluster/storage/management/gui/dialogs/DisksSelectionPage.java (renamed from src/com.gluster.storage.management.gui/src/com/gluster/storage/management/gui/dialogs/CreateVolumeDisksPage.java)9
-rw-r--r--src/com.gluster.storage.management.gui/src/com/gluster/storage/management/gui/dialogs/SelectDisksDialog.java24
-rw-r--r--src/com.gluster.storage.management.server/src/com/gluster/storage/management/server/resources/VolumesResource.java5
-rw-r--r--src/com.gluster.storage.management.server/src/com/gluster/storage/management/server/utils/GlusterUtil.java28
13 files changed, 249 insertions, 137 deletions
diff --git a/src/com.gluster.storage.management.client/src/com/gluster/storage/management/client/DiscoveredServersClient.java b/src/com.gluster.storage.management.client/src/com/gluster/storage/management/client/DiscoveredServersClient.java
index eb6ef3a0..c7ea7507 100644
--- a/src/com.gluster.storage.management.client/src/com/gluster/storage/management/client/DiscoveredServersClient.java
+++ b/src/com.gluster.storage.management.client/src/com/gluster/storage/management/client/DiscoveredServersClient.java
@@ -46,6 +46,7 @@ public class DiscoveredServersClient extends AbstractClient {
MultivaluedMap<String, String> queryParams = new MultivaluedMapImpl();
queryParams.putSingle("details", getDetails.toString());
+ //System.out.println((String) fetchResource(queryParams, String.class));
return ((Response) fetchResource(queryParams, responseClass)).getData();
}
diff --git a/src/com.gluster.storage.management.client/src/com/gluster/storage/management/client/VolumesClient.java b/src/com.gluster.storage.management.client/src/com/gluster/storage/management/client/VolumesClient.java
index b37c880c..87e02e28 100644
--- a/src/com.gluster.storage.management.client/src/com/gluster/storage/management/client/VolumesClient.java
+++ b/src/com.gluster.storage.management.client/src/com/gluster/storage/management/client/VolumesClient.java
@@ -20,14 +20,22 @@
*/
package com.gluster.storage.management.client;
+
+import java.util.ArrayList;
+import java.util.List;
+
import javax.ws.rs.core.MultivaluedMap;
import com.gluster.storage.management.core.constants.RESTConstants;
+import com.gluster.storage.management.core.model.Disk;
+import com.gluster.storage.management.core.model.Disk.DISK_STATUS;
import com.gluster.storage.management.core.model.Status;
import com.gluster.storage.management.core.model.Volume;
import com.gluster.storage.management.core.response.LogMessageListResponse;
import com.gluster.storage.management.core.response.VolumeListResponse;
import com.gluster.storage.management.core.response.VolumeOptionInfoListResponse;
+import com.gluster.storage.management.core.utils.GlusterCoreUtil;
+import com.gluster.storage.management.core.utils.StringUtil;
import com.sun.jersey.api.representation.Form;
import com.sun.jersey.core.util.MultivaluedMapImpl;
@@ -88,6 +96,13 @@ public class VolumesClient extends AbstractClient {
return ((VolumeOptionInfoListResponse) fetchSubResource(RESTConstants.SUBRESOURCE_DEFAULT_OPTIONS,
VolumeOptionInfoListResponse.class));
}
+
+ public Status addDisks(String volumeName, List<Disk> diskList) {
+ String disks = StringUtil.ListToString( GlusterCoreUtil.getQualifiedDiskNames(diskList), ",");
+ Form form = new Form();
+ form.add(RESTConstants.QUERY_PARAM_DISKS, disks);
+ return (Status) postRequest(volumeName + "/" + RESTConstants.SUBRESOURCE_DISKS, Status.class, form);
+ }
public Status addDisks(String volumeName, String disks) {
Form form = new Form();
@@ -108,27 +123,32 @@ public class VolumesClient extends AbstractClient {
UsersClient usersClient = new UsersClient();
if (usersClient.authenticate("gluster", "gluster").isSuccess()) {
VolumesClient client = new VolumesClient(usersClient.getSecurityToken());
- // List<Disk> disks = new ArrayList<Disk>();
- // Disk diskElement = new Disk();
- // diskElement.setName("sda1");
- // diskElement.setStatus(DISK_STATUS.READY);
- // disks.add(diskElement);
- // diskElement.setName("sda2");
- // diskElement.setStatus(DISK_STATUS.READY);
- // disks.add(diskElement);
- //
- // Volume vol = new Volume("vol1", null, Volume.VOLUME_TYPE.PLAIN_DISTRIBUTE,
- // Volume.TRANSPORT_TYPE.ETHERNET,
- // Volume.VOLUME_STATUS.ONLINE);
- // // vol.setDisks(disks);
- // System.out.println(client.createVolume(vol));
- // for (VolumeOptionInfo option : client.getVolumeOptionsDefaults()) {
- // System.out.println(option.getName() + "-" + option.getDescription() + "-" + option.getDefaultValue());
- // }
- // System.out.println(client.getVolume("Volume3").getOptions());
- // System.out.println(client.setVolumeOption("Volume3", "network.frame-timeout", "600").getMessage());
-
- Status status = client.addDisks("Volume3", "server1:sda, server1:sdb, server1:sdc");
+// List<Disk> disks = new ArrayList<Disk>();
+// Disk diskElement = new Disk();
+// diskElement.setName("sda1");
+// diskElement.setStatus(DISK_STATUS.READY);
+// disks.add(diskElement);
+// diskElement.setName("sda2");
+// diskElement.setStatus(DISK_STATUS.READY);
+// disks.add(diskElement);
+//
+// Volume vol = new Volume("vol1", null, Volume.VOLUME_TYPE.PLAIN_DISTRIBUTE, Volume.TRANSPORT_TYPE.ETHERNET,
+// Volume.VOLUME_STATUS.ONLINE);
+// // vol.setDisks(disks);
+// System.out.println(client.createVolume(vol));
+// for (VolumeOptionInfo option : client.getVolumeOptionsDefaults()) {
+// System.out.println(option.getName() + "-" + option.getDescription() + "-" + option.getDefaultValue());
+// }
+// System.out.println(client.getVolume("Volume3").getOptions());
+// System.out.println(client.setVolumeOption("Volume3", "network.frame-timeout", "600").getMessage());
+ List<Disk> disks = new ArrayList<Disk>();
+ Disk disk = new Disk();
+ disk.setServerName("server1");
+ disk.setName("sda");
+ disk.setStatus(DISK_STATUS.READY);
+ disks.add(disk);
+
+ Status status = client.addDisks("Volume3", disks);
System.out.println(status.getMessage());
}
}
diff --git a/src/com.gluster.storage.management.core/src/com/gluster/storage/management/core/model/Volume.java b/src/com.gluster.storage.management.core/src/com/gluster/storage/management/core/model/Volume.java
index 99b76ed7..41ed5a25 100644
--- a/src/com.gluster.storage.management.core/src/com/gluster/storage/management/core/model/Volume.java
+++ b/src/com.gluster.storage.management.core/src/com/gluster/storage/management/core/model/Volume.java
@@ -51,8 +51,8 @@ public class Volume extends Entity {
public static final int DEFAULT_REPLICA_COUNT = 2;
- public static final int DEFAULT_STRIPE_COUNT = 2;
-
+ public static final int DEFAULT_STRIPE_COUNT = 4;
+
public static final String OPTION_AUTH_ALLOW = "auth.allow";
private static final String[] VOLUME_TYPE_STR = new String[] { "Plain Distribute", "Distributed Mirror",
diff --git a/src/com.gluster.storage.management.core/src/com/gluster/storage/management/core/utils/GlusterCoreUtil.java b/src/com.gluster.storage.management.core/src/com/gluster/storage/management/core/utils/GlusterCoreUtil.java
new file mode 100644
index 00000000..9e3084fb
--- /dev/null
+++ b/src/com.gluster.storage.management.core/src/com/gluster/storage/management/core/utils/GlusterCoreUtil.java
@@ -0,0 +1,38 @@
+/**
+ * GlusterCoreUtil.java
+ *
+ * Copyright (c) 2011 Gluster, Inc. <http://www.gluster.com>
+ * This file is part of Gluster Management Console.
+ *
+ * Gluster Management Console is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Affero General Public License as published
+ * by the Free Software Foundation; either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * Gluster Management Console is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
+ * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License
+ * for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program. If not, see
+ * <http://www.gnu.org/licenses/>.
+ */
+package com.gluster.storage.management.core.utils;
+
+import java.util.ArrayList;
+import java.util.List;
+
+import com.gluster.storage.management.core.model.Disk;
+
+
+public class GlusterCoreUtil {
+ // Convert from Disk list to Qualified disk name list
+ public static final List<String> getQualifiedDiskNames(List<Disk> diskList) {
+ List<String> qualifiedDiskNames = new ArrayList<String>();
+ for (Disk disk : diskList) {
+ qualifiedDiskNames.add(disk.getQualifiedName());
+ }
+ return qualifiedDiskNames;
+ }
+}
diff --git a/src/com.gluster.storage.management.core/src/com/gluster/storage/management/core/utils/StringUtil.java b/src/com.gluster.storage.management.core/src/com/gluster/storage/management/core/utils/StringUtil.java
index aed9c80c..8dc5837d 100644
--- a/src/com.gluster.storage.management.core/src/com/gluster/storage/management/core/utils/StringUtil.java
+++ b/src/com.gluster.storage.management.core/src/com/gluster/storage/management/core/utils/StringUtil.java
@@ -32,12 +32,10 @@ public class StringUtil {
public static String ListToString(List<String> list, String delimiter) {
StringBuilder output = new StringBuilder();
- for (int i = 0; i < list.size(); i++) {
- output.append(list.get(i));
- if (i < (list.size()-1) ) {
- output.append(delimiter);
- }
+ for(String element : list) {
+ output.append(element).append(delimiter);
}
- return output.toString();
+ String outputStr = output.toString();
+ return outputStr.substring(0, outputStr.length() - (delimiter.length()+1));
}
}
diff --git a/src/com.gluster.storage.management.gui/plugin.xml b/src/com.gluster.storage.management.gui/plugin.xml
index 8004b47e..21dbbf50 100644
--- a/src/com.gluster.storage.management.gui/plugin.xml
+++ b/src/com.gluster.storage.management.gui/plugin.xml
@@ -497,6 +497,11 @@
style="push"
toolbarPath="Normal"
tooltip="Migrate Disk">
+ <enablement>
+ <objectClass
+ name="com.gluster.storage.management.core.model.Disk">
+ </objectClass>
+ </enablement>
</action>
<action
allowLabelUpdate="false"
diff --git a/src/com.gluster.storage.management.gui/src/com/gluster/storage/management/gui/actions/AddDiskAction.java b/src/com.gluster.storage.management.gui/src/com/gluster/storage/management/gui/actions/AddDiskAction.java
index befa3e37..cc57c541 100644
--- a/src/com.gluster.storage.management.gui/src/com/gluster/storage/management/gui/actions/AddDiskAction.java
+++ b/src/com.gluster.storage.management.gui/src/com/gluster/storage/management/gui/actions/AddDiskAction.java
@@ -1,3 +1,24 @@
+/**
+ * AddDiskAction.java
+ *
+ * Copyright (c) 2011 Gluster, Inc. <http://www.gluster.com>
+ * This file is part of Gluster Management Console.
+ *
+ * Gluster Management Console is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Affero General Public License as published
+ * by the Free Software Foundation; either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * Gluster Management Console is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
+ * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License
+ * for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program. If not, see
+ * <http://www.gnu.org/licenses/>.
+ */
+
package com.gluster.storage.management.gui.actions;
import org.eclipse.jface.action.IAction;
@@ -32,8 +53,7 @@ public class AddDiskAction extends AbstractActionDelegate {
@Override
public void run() {
- AddDiskWizard wizard = new AddDiskWizard();
- wizard.addPages(volume);
+ AddDiskWizard wizard = new AddDiskWizard(volume); // Also add single page
WizardDialog dialog = new WizardDialog(getShell(), wizard);
dialog.create();
@@ -41,7 +61,6 @@ public class AddDiskAction extends AbstractActionDelegate {
dialog.open();
}
});
-
}
diff --git a/src/com.gluster.storage.management.gui/src/com/gluster/storage/management/gui/dialogs/AddDiskPage.java b/src/com.gluster.storage.management.gui/src/com/gluster/storage/management/gui/dialogs/AddDiskPage.java
index f8046a13..7eb107c0 100644
--- a/src/com.gluster.storage.management.gui/src/com/gluster/storage/management/gui/dialogs/AddDiskPage.java
+++ b/src/com.gluster.storage.management.gui/src/com/gluster/storage/management/gui/dialogs/AddDiskPage.java
@@ -31,6 +31,8 @@ import com.gluster.storage.management.client.GlusterDataModelManager;
import com.gluster.storage.management.core.model.Disk;
import com.gluster.storage.management.core.model.Volume;
import com.gluster.storage.management.core.model.Volume.VOLUME_TYPE;
+import com.richclientgui.toolbox.duallists.DualListComposite.ListContentChangedListener;
+import com.richclientgui.toolbox.duallists.IRemovableContentProvider;
/**
* @author root
@@ -40,7 +42,8 @@ public class AddDiskPage extends WizardPage {
private List<Disk> availableDisks = new ArrayList<Disk>();
private List<Disk> selectedDisks = new ArrayList<Disk>();
private Volume volume = null;
- private CreateVolumeDisksPage page = null;
+ private DisksSelectionPage page = null;
+
public static final String PAGE_NAME = "add.disk.volume.page";
@@ -59,29 +62,52 @@ public class AddDiskPage extends WizardPage {
description += "(Disk selection should be multiples of " + volume.getStripeCount() + ")";
}
setDescription(description);
-
+
availableDisks = getAvailableDisks(volume);
+
+ setPageComplete(false);
+ setErrorMessage("Please select disks to be added to the volume.");
}
+
+ private boolean isDiskUsed(Volume volume, Disk disk){
+ for (String volumeDisk : volume.getDisks()) { // expected form of volumeDisk is "server:diskName"
+ if ( disk.getQualifiedName().equals(volumeDisk)) {
+ return true;
+ }
+ }
+ return false;
+ }
+
protected List<Disk> getAvailableDisks(Volume volume) {
List<Disk> availableDisks = new ArrayList<Disk>();
- boolean isDiskAlreadyUsedInTheVolume = false;
for (Disk disk : GlusterDataModelManager.getInstance().getReadyDisksOfAllServers()) {
- isDiskAlreadyUsedInTheVolume = false;
- for (String volumeDisk : volume.getDisks()) { // volumeDisk of the form "server:diskName"
- if (disk.getServerName().equals(volumeDisk.split(":")[0])
- && disk.getName().equals(volumeDisk.split(":")[1])) {
- isDiskAlreadyUsedInTheVolume = true;
- break;
- }
- }
- if (!isDiskAlreadyUsedInTheVolume) {
+ if ( ! isDiskUsed(volume, disk) ) {
availableDisks.add(disk);
}
}
return availableDisks;
}
+
+ public List<Disk> getChosenDisks( ) {
+ return page.getChosenDisks();
+ }
+
+ private boolean isValidDiskSelection(int diskCount) {
+ if ( diskCount == 0) {
+ return false;
+ }
+ switch (volume.getVolumeType()) {
+ case DISTRIBUTED_MIRROR:
+ return (diskCount % volume.getReplicaCount() == 0);
+ case DISTRIBUTED_STRIPE:
+ return (diskCount % volume.getStripeCount() == 0);
+ }
+ return true;
+ }
+
+
/*
* (non-Javadoc)
*
@@ -90,12 +116,50 @@ public class AddDiskPage extends WizardPage {
@Override
public void createControl(Composite parent) {
getShell().setText("Add Disk");
- List<Disk> configuredDisks = new ArrayList<Disk>(); // or volume.getDisks();
- page = new CreateVolumeDisksPage(parent, SWT.NONE, availableDisks, configuredDisks);
+ List<Disk> chosenDisks = new ArrayList<Disk>(); // or volume.getDisks();
+
+ page = new DisksSelectionPage(parent, SWT.NONE, availableDisks, chosenDisks);
+ page.addDiskSelectionListener(new ListContentChangedListener<Disk>() {
+ @Override
+ public void listContentChanged(IRemovableContentProvider<Disk> contentProvider) {
+ List<Disk> newChosenDisks = page.getChosenDisks();
+
+ // validate chosen disks
+ if(isValidDiskSelection(newChosenDisks.size())) {
+ clearError();
+ } else {
+ setError();
+ }
+ }
+ });
setControl(page);
}
- public CreateVolumeDisksPage getDialogPage() {
+ private void setError() {
+ String errorMessage = null;
+ if ( volume.getVolumeType() == VOLUME_TYPE.PLAIN_DISTRIBUTE) {
+ errorMessage = "Please select at least one disk!";
+ } else if( volume.getVolumeType() == VOLUME_TYPE.DISTRIBUTED_MIRROR) {
+ errorMessage = "Please select disks in multiples of " + volume.getReplicaCount();
+ } else {
+ errorMessage = "Please select disks in multiples of " + volume.getStripeCount();
+ }
+
+ setPageComplete(false);
+ setErrorMessage(errorMessage);
+ }
+
+ private void clearError() {
+ setErrorMessage(null);
+ setPageComplete(true);
+ }
+
+ public DisksSelectionPage getDialogPage() {
return this.page;
}
+
+ public void setPageComplete() {
+
+ }
+
}
diff --git a/src/com.gluster.storage.management.gui/src/com/gluster/storage/management/gui/dialogs/AddDiskWizard.java b/src/com.gluster.storage.management.gui/src/com/gluster/storage/management/gui/dialogs/AddDiskWizard.java
index 5d096764..e9608e38 100644
--- a/src/com.gluster.storage.management.gui/src/com/gluster/storage/management/gui/dialogs/AddDiskWizard.java
+++ b/src/com.gluster.storage.management.gui/src/com/gluster/storage/management/gui/dialogs/AddDiskWizard.java
@@ -20,20 +20,19 @@
*/
package com.gluster.storage.management.gui.dialogs;
-import java.util.ArrayList;
-import java.util.Arrays;
+
import java.util.List;
import org.eclipse.jface.dialogs.MessageDialog;
import org.eclipse.jface.wizard.Wizard;
-import org.eclipse.swt.widgets.Display;
+
import com.gluster.storage.management.client.GlusterDataModelManager;
import com.gluster.storage.management.client.VolumesClient;
import com.gluster.storage.management.core.model.Disk;
import com.gluster.storage.management.core.model.Status;
import com.gluster.storage.management.core.model.Volume;
-import com.gluster.storage.management.core.model.Volume.VOLUME_TYPE;
-import com.gluster.storage.management.core.utils.StringUtil;
+import com.gluster.storage.management.core.utils.GlusterCoreUtil;
+
/**
*
@@ -42,37 +41,18 @@ public class AddDiskWizard extends Wizard {
private AddDiskPage page;
private Volume volume;
- public AddDiskWizard() {
+
+ public AddDiskWizard(Volume volume) {
setWindowTitle("Gluster Management Console - Add disk");
setHelpAvailable(false); // TODO: Introduce wizard help
+ this.volume = volume;
}
- public void addPages(Volume volume) {
- this.volume = volume;
+ public void addPages() {
page = new AddDiskPage(volume);
addPage(page);
}
- private String getDiskNames(List<Disk> disks) {
- List<String> diskNames = new ArrayList<String>();
- for (Disk disk : disks) {
- diskNames.add(disk.getServerName() + ":" + disk.getName());
- }
- return StringUtil.ListToString(diskNames, ",");
- }
-
- private boolean isValidDiskSelection(int diskCount) {
- switch (volume.getVolumeType()) {
- case PLAIN_DISTRIBUTE:
- return (diskCount > 0);
- case DISTRIBUTED_MIRROR:
- return (diskCount % volume.getReplicaCount() == 0 && diskCount > 0);
- case DISTRIBUTED_STRIPE:
- return (diskCount % volume.getStripeCount() == 0 && diskCount > 0);
- }
- return false;
- }
-
/*
* (non-Javadoc)
@@ -81,37 +61,23 @@ public class AddDiskWizard extends Wizard {
*/
@Override
public boolean performFinish() {
- List<Disk> disks = page.getDialogPage().getChosenDisks();
- String selectedDisks = getDiskNames(disks);
- List<String> diskList = Arrays.asList(selectedDisks.split(":"));
- if (isValidDiskSelection(disks.size())) {
- VolumesClient volumeClient = new VolumesClient(GlusterDataModelManager.getInstance().getSecurityToken());
- try {
- Status status = volumeClient.addDisks(volume.getName(), getDiskNames(disks));
- if (!status.isSuccess()) {
- MessageDialog.openError(getShell(), "Add disk failure", status.getMessage());
- return status.isSuccess();
- } else {
- volume.addDisks(diskList);
- MessageDialog.openInformation(getShell(), "Add Disk", status.getMessage());
- return status.isSuccess();
- }
- } catch (Exception e) {
- MessageDialog.openError(getShell(), "Add disk failure", e.getMessage());
- return false;
- }
- } else {
- String errorMessage = "";
- if ( volume.getVolumeType() == VOLUME_TYPE.PLAIN_DISTRIBUTE) {
- errorMessage = "Atleast one disk required to add";
- } else if( volume.getVolumeType() == VOLUME_TYPE.DISTRIBUTED_MIRROR) {
- errorMessage = "Multiples of " + volume.getReplicaCount() + " disks are required to add";
+ List<Disk> disks = page.getChosenDisks();
+ VolumesClient volumeClient = new VolumesClient(GlusterDataModelManager.getInstance().getSecurityToken());
+ try {
+ Status status = volumeClient.addDisks(volume.getName(), disks);
+ if (!status.isSuccess()) {
+ MessageDialog.openError(getShell(), "Add disk(s) to Volume", status.getMessage());
+ return status.isSuccess();
} else {
- errorMessage = "Multiples of " + volume.getStripeCount() + " disks are required to add";
+ volume.addDisks(GlusterCoreUtil.getQualifiedDiskNames(disks));
+ MessageDialog.openInformation(getShell(), "Add disk(s) to Volume", "Disk(s) are successfully added to "
+ + volume.getName());
+ return status.isSuccess();
}
- MessageDialog.openError(getShell(), "Add disk failure", errorMessage);
+ } catch (Exception e) {
+ MessageDialog.openError(getShell(), "Add disk(s) to Volume", e.getMessage());
+ return false;
}
- return false;
}
/*
@@ -121,7 +87,6 @@ public class AddDiskWizard extends Wizard {
*/
@Override
public boolean canFinish() {
- // TODO: Add logic to return true only when all validations are successful
- return super.canFinish();
+ return super.canFinish() && page.isPageComplete();
}
}
diff --git a/src/com.gluster.storage.management.gui/src/com/gluster/storage/management/gui/dialogs/CreateVolumeDisksPage.java b/src/com.gluster.storage.management.gui/src/com/gluster/storage/management/gui/dialogs/DisksSelectionPage.java
index c78601d9..e50e81a7 100644
--- a/src/com.gluster.storage.management.gui/src/com/gluster/storage/management/gui/dialogs/CreateVolumeDisksPage.java
+++ b/src/com.gluster.storage.management.gui/src/com/gluster/storage/management/gui/dialogs/DisksSelectionPage.java
@@ -19,7 +19,6 @@
package com.gluster.storage.management.gui.dialogs;
import java.util.ArrayList;
-import java.util.Arrays;
import java.util.List;
import org.eclipse.jface.viewers.ITableLabelProvider;
@@ -48,7 +47,7 @@ import com.richclientgui.toolbox.duallists.IRemovableContentProvider;
import com.richclientgui.toolbox.duallists.RemovableContentProvider;
import com.richclientgui.toolbox.duallists.TableColumnData;
-public class CreateVolumeDisksPage extends Composite {
+public class DisksSelectionPage extends Composite {
private enum DISK_TABLE_COLUMN_INDICES {
SERVER, DISK, SPACE, SPACE_USED
}
@@ -67,13 +66,17 @@ public class CreateVolumeDisksPage extends Composite {
private Button btnDown;
- public CreateVolumeDisksPage(final Composite parent, int style, List<Disk> allDisks, List<Disk> selectedDisks) {
+ public DisksSelectionPage(final Composite parent, int style, List<Disk> allDisks, List<Disk> selectedDisks) {
super(parent, style);
createPage(allDisks, selectedDisks);
parent.layout();
}
+
+ public void addDiskSelectionListener(ListContentChangedListener<Disk> listener) {
+ dualTableViewer.addChosenListChangedSelectionListener(listener);
+ }
private TableLabelProviderAdapter getDiskLabelProvider() {
return new TableLabelProviderAdapter() {
diff --git a/src/com.gluster.storage.management.gui/src/com/gluster/storage/management/gui/dialogs/SelectDisksDialog.java b/src/com.gluster.storage.management.gui/src/com/gluster/storage/management/gui/dialogs/SelectDisksDialog.java
index 134323b3..08a35357 100644
--- a/src/com.gluster.storage.management.gui/src/com/gluster/storage/management/gui/dialogs/SelectDisksDialog.java
+++ b/src/com.gluster.storage.management.gui/src/com/gluster/storage/management/gui/dialogs/SelectDisksDialog.java
@@ -24,7 +24,6 @@ import java.util.List;
import org.eclipse.jface.dialogs.Dialog;
import org.eclipse.jface.dialogs.IDialogConstants;
import org.eclipse.jface.dialogs.MessageDialog;
-import org.eclipse.osgi.framework.internal.core.Msg;
import org.eclipse.swt.SWT;
import org.eclipse.swt.graphics.Point;
import org.eclipse.swt.layout.GridData;
@@ -33,13 +32,11 @@ import org.eclipse.swt.widgets.Composite;
import org.eclipse.swt.widgets.Control;
import org.eclipse.swt.widgets.Shell;
-import com.gluster.storage.management.client.GlusterDataModelManager;
import com.gluster.storage.management.core.model.Disk;
-import com.gluster.storage.management.core.model.Volume;
public class SelectDisksDialog extends Dialog {
- private CreateVolumeDisksPage disksPage;
+ private DisksSelectionPage disksPage;
private List<Disk> allDisks;
private List<Disk> selectedDisks;
@@ -78,14 +75,12 @@ public class SelectDisksDialog extends Dialog {
Composite container = new Composite(parent, SWT.NONE);
GridLayout containerLayout = new GridLayout(2, false);
container.setLayout(containerLayout);
- GridData containerLayoutData = new GridData(SWT.FILL, SWT.FILL, true,
- true);
+ GridData containerLayoutData = new GridData(SWT.FILL, SWT.FILL, true, true);
container.setLayoutData(containerLayoutData);
getShell().setText("Create Volume - Select Disks");
- disksPage = new CreateVolumeDisksPage(container, SWT.NONE, allDisks,
- selectedDisks);
+ disksPage = new DisksSelectionPage(container, SWT.NONE, allDisks, selectedDisks);
return container;
}
@@ -97,10 +92,8 @@ public class SelectDisksDialog extends Dialog {
*/
@Override
protected void createButtonsForButtonBar(Composite parent) {
- createButton(parent, IDialogConstants.OK_ID, IDialogConstants.OK_LABEL,
- true);
- createButton(parent, IDialogConstants.CANCEL_ID,
- IDialogConstants.CANCEL_LABEL, false);
+ createButton(parent, IDialogConstants.OK_ID, IDialogConstants.OK_LABEL, true);
+ createButton(parent, IDialogConstants.CANCEL_ID, IDialogConstants.CANCEL_LABEL, false);
}
/**
@@ -112,15 +105,14 @@ public class SelectDisksDialog extends Dialog {
}
@Override
- protected void cancelPressed() {
+ protected void cancelPressed() { System.out.println("Test");
super.cancelPressed();
}
@Override
protected void okPressed() {
if (this.getSelectedDisks().size() == 0) {
- MessageDialog.openError(getShell(), "Select Disk(s)",
- "Please select atlease one disk");
+ MessageDialog.openError(getShell(), "Select Disk(s)", "Please select atlease one disk");
} else {
super.okPressed();
}
@@ -129,7 +121,7 @@ public class SelectDisksDialog extends Dialog {
public List<Disk> getSelectedDisks() {
return disksPage.getChosenDisks();
}
-
+
public List<String> getSelectedBricks() {
return disksPage.getChosenBricks();
}
diff --git a/src/com.gluster.storage.management.server/src/com/gluster/storage/management/server/resources/VolumesResource.java b/src/com.gluster.storage.management.server/src/com/gluster/storage/management/server/resources/VolumesResource.java
index d3bdec8b..457776cc 100644
--- a/src/com.gluster.storage.management.server/src/com/gluster/storage/management/server/resources/VolumesResource.java
+++ b/src/com.gluster.storage.management.server/src/com/gluster/storage/management/server/resources/VolumesResource.java
@@ -226,7 +226,7 @@ public class VolumesResource {
status = new Status(e);
}
if (status.isSuccess()) {
- String brickDir = status.getMessage().trim().replace(CoreConstants.NEWLINE, "");
+ String brickDir = status.getMessage().trim();
bricks.add(serverName + ":" + brickDir);
} else {
// Brick preparation failed. Cleanup directories already created and return failure status
@@ -330,7 +330,8 @@ public class VolumesResource {
Status status = createDirectories(diskList, volumeName);
if (status.isSuccess()) {
List<String> bricks = Arrays.asList(status.getMessage().split(" "));
- status = glusterUtil.addDisks(volumeName, bricks);
+ status = glusterUtil.addBricks(volumeName, bricks);
+
if (!status.isSuccess()) {
Status cleanupStatus = cleanupDirectories(diskList, volumeName, diskList.size());
if (!cleanupStatus.isSuccess()) {
diff --git a/src/com.gluster.storage.management.server/src/com/gluster/storage/management/server/utils/GlusterUtil.java b/src/com.gluster.storage.management.server/src/com/gluster/storage/management/server/utils/GlusterUtil.java
index aaedb3d4..30f73595 100644
--- a/src/com.gluster.storage.management.server/src/com/gluster/storage/management/server/utils/GlusterUtil.java
+++ b/src/com.gluster.storage.management.server/src/com/gluster/storage/management/server/utils/GlusterUtil.java
@@ -54,7 +54,8 @@ public class GlusterUtil {
private static final String VOLUME_OPTIONS_RECONFIG_PFX = "Options Reconfigured";
private static final String VOLUME_OPTION_AUTH_ALLOW = "auth.allow:";
private static final String VOLUME_LOG_LOCATION_PFX = "log file location:";
-
+ private static final String VOLUME_TYPE_DISTRIBUTE = "Distribute";
+ private static final String VOLUME_TYPE_REPLICATE = "Replicate";
private static final ProcessUtil processUtil = new ProcessUtil();
/**
@@ -258,9 +259,9 @@ public class GlusterUtil {
private boolean readVolumeType(Volume volume, String line) {
String volumeType = extractToken(line, VOLUME_TYPE_PFX);
if (volumeType != null) {
- if (volumeType.equals("Distribute")) {
+ if (volumeType.equals(VOLUME_TYPE_DISTRIBUTE)) {
volume.setVolumeType(VOLUME_TYPE.PLAIN_DISTRIBUTE);
- } else if (volumeType.equals("Replicate")) {
+ } else if (volumeType.equals(VOLUME_TYPE_REPLICATE)) {
volume.setVolumeType(VOLUME_TYPE.DISTRIBUTED_MIRROR);
volume.setReplicaCount(Volume.DEFAULT_REPLICA_COUNT);
} else {
@@ -272,18 +273,18 @@ public class GlusterUtil {
return false;
}
- private void readBrickPair(Volume volume, String line) {
+
+ private void readReplicaOrStripeCount(Volume volume, String line) {
if (extractToken(line, "x") != null) {
+ // expected formated of line is "Number of Bricks: 3 x 2 = 6"
int count = Integer.parseInt(line.split("x")[1].split("=")[0].trim());
if (volume.getVolumeType() == VOLUME_TYPE.DISTRIBUTED_STRIPE) {
volume.setStripeCount(count);
} else if (volume.getVolumeType() == VOLUME_TYPE.DISTRIBUTED_MIRROR) {
volume.setReplicaCount(count);
volume.setStripeCount(0);
- } else {
- volume.setStripeCount(0);
- volume.setReplicaCount(0);
- }
+ }
+
}
return;
}
@@ -320,6 +321,7 @@ public class GlusterUtil {
return false;
}
+
private void detectAndAddDiskToVolume(Volume volume, String serverName, String brickDir) {
// brick directory should be of the form /export/<diskname>/volume-name
try {
@@ -338,6 +340,7 @@ public class GlusterUtil {
}
}
+
private boolean readBrickGroup(String line) {
return extractToken(line, VOLUME_BRICKS_GROUP_PFX) != null;
}
@@ -390,7 +393,7 @@ public class GlusterUtil {
if (readVolumeType(volume, line))
continue;
if (extractToken(line, VOLUME_NUMBER_OF_BRICKS) != null) {
- readBrickPair(volume, line);
+ readReplicaOrStripeCount(volume, line);
}
if (readVolumeStatus(volume, line))
continue;
@@ -429,7 +432,8 @@ public class GlusterUtil {
return volumes;
}
- public Status addDisks(String volumeName, List<String> bricks) {
+
+ public Status addBricks(String volumeName, List<String> bricks) {
List<String> command = new ArrayList<String>();
command.add("gluster");
command.add("volume");
@@ -439,6 +443,7 @@ public class GlusterUtil {
return new Status(processUtil.executeCommand(command));
}
+
public String getLogLocation(String volumeName, String brickName) {
ProcessResult result = new ProcessUtil().executeCommand("gluster", "volume", "log", "locate", volumeName,
brickName);
@@ -464,13 +469,14 @@ public class GlusterUtil {
return logFileName;
}
+
public static void main(String args[]) {
// List<String> names = new GlusterUtil().getGlusterServerNames();
// System.out.println(names);
List<String> disks = new ArrayList<String>();
disks.add("server1:sda");
disks.add("server1:sdb");
- Status status = new GlusterUtil().addDisks("Volume3", disks);
+ Status status = new GlusterUtil().addBricks("Volume3", disks);
System.out.println(status);
}
}