mirror of
https://github.com/xcp-ng/xenadmin.git
synced 2025-01-22 16:20:42 +01:00
4b0b83245f
* CA-34231: Replace negative language with `block list` in code and references Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CA-34231: Replace negative language with `stop` in code and references Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CA-34231: Replace negative language with `freezing` in code Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CA-34231: Replace negative language with `run/ran` in code comments Some paramater mentions have been renamed, as they will be renamed in future commits. Excluded mentions in XenAPI/Host.cs and XenAPI/VM.cs since code is autogenerated. Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> # Conflicts: # CFUValidator/CommandLineOptions/CFUCommandLineOptionManager.cs # XenAdmin/Controls/Wlb/WlbOptModeScheduler.cs # XenAdmin/Dialogs/Wlb/WorkloadReports.cs * CA-34231: Replace negative language with `run` in Command.cs Run method Used Resharper renaming utility Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> # Conflicts: # XenAdmin/TabPages/GeneralTabPage.cs * CA-34231: Replace negative language with `run` in Command.cs CanRun method Used Resharper rename utility. Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CA-34231: Replace negative language with `run` in Command.cs CanRunCore method Used ReSharper rename utility Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> # Conflicts: # XenAdmin/Commands/DRConfigureCommand.cs # XenAdmin/Commands/DRDryrunCommand.cs # XenAdmin/Commands/DRFailbackCommand.cs # XenAdmin/Commands/DRFailoverCommand.cs # XenAdmin/Commands/DisasterRecoveryCommand.cs # XenAdmin/Commands/VMGroupCommand.cs * CA-34231: Replace negative language with `run` in Command.cs RunCore method Used ReSharper rename utility Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CA-34231: Replace negative language with `run` in Command.cs GetCantExecuteReasonCore method Used ReSharper rename utility Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CA-34231: Replace negative language with `run` in Command.cs GetCantRunReasons method Used ReSharper renaming utility Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CA-34231: Replace remaining negative language with `run` in Command.cs Also applied to related symbols. Used ReSharper renaming utility. Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CA-34231: Replace negative language with `run` in methods named CanRun Used ReSharper renaming utility Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CA-34231: Replace negative language with `run` in methods in CrossPoolMigrateCommand.cs Used ReSharper renaming utility Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> # Conflicts: # XenAdmin/Commands/CrossPoolMigrateCommand.cs * CA-34231: Replace negative language with `run` in remaining Run methods Also updated negative language in `DeleteVMCommand` Also updated in comment in `CrossPoolMigrateCommand` Also renamed missed instances of `CanRun` Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CA-34231: Replace negative language with `run` in `CanRunCore` and `RunCore` Used ReSharper renaming utility. Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CA-34231: Replace remaining negative language with `run` in Commands folder Used ReSharper renaming utility Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CA-34231: Replace remaining negative language with `run` in XenAdmin/Controls folder Used ReSharper renaming utility. Had to rename `WlbReportView.xs:RunReport()` to `WlbReportView.xs:StartRunReport()` to resolve conflict with change from `WlbReportView:ExecuteReport()` to `WlbReportView:RunReport()` Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> # Conflicts: # XenAdmin/Controls/Wlb/WlbOptModeScheduler.cs # XenAdmin/Dialogs/Wlb/WorkloadReports.cs # XenAdminTests/UnitTests/WlbTests/WlbScheduledTaskTests.cs * CA-34231: Replace all remaining negative language with `run` in code Used ReSharper renaming utility Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> # Conflicts: # XenAdmin/Commands/Controls/WlbRecommendations.cs # XenAdminTests/UnitTests/WlbTests/WlbScheduledTaskTests.cs # XenModel/WLB/WlbScheduledTask.cs * CA-34231: Replace negative language with `supporter` or `bond member` in code strings Used ReSharper renaming utility Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CA-34231: Replace negative language with `supporter` or `bond member` in Messages string Used ReSharper renaming utility Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> # Conflicts: # XenAdmin/MainWindow.cs # XenAdmin/Wizards/PatchingWizard/PatchingWizard_SelectServers.cs # XenModel/Messages.Designer.cs # XenModel/Messages.resx * CA-34231: Replace remaining negative language with `supporter` in .resx files Used ReSharper renaming utility. FriendlyErrorNames.resx has been excluded. Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CA-34231: Replace negative language with `supporter` or `bond member` in XenAdmin code Used ReSharper renaming utility Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> # Conflicts: # XenAdmin/Dialogs/NewPoolDialog.cs * CA-34231: Replace negative language with `supporter` or `bond member` in XenModel code Used ReSharper renaming utility. Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CA-34231: Replace negative language with `coordinator` in CFUValidator code Used ReSharper renaming utility Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> # Conflicts: # CFUValidator/CFUValidator.cs * CA-34231: Replace negative language with `coordinator` in solution's comments and hardcoded strings Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CA-34231: Replace negative language with `coordinator` in `Helpers:GetCoordinator` method Used ReSharper renaming utility. also renamed similarly named method in `ObjectChange.cs` Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> # Conflicts: # XenAdmin/Alerts/Types/HotfixEligibilityAlert.cs # XenAdmin/Controls/CustomDataGraph/ArchiveMaintainer.cs * CA-34231: Replace negative language with `coordinator` in `EvacuateHostDialog.resx` Used ReSharper renaming utility. Excluded jp and zh resources Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> # Conflicts: # XenAdmin/Dialogs/EvacuateHostDialog.resx * CA-34231: Replace negative language with `coordinator` in `EvacuateHostDialog.resx` Used ReSharper renaming utility. Excluded jp and zh resource files. Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> # Conflicts: # XenAdmin/Dialogs/NewPoolDialog.resx * CA-34231: Rename missing language references for change to `coordinator` Misc files were not saved before last commits. Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CA-34231: Replace negative language with `coordinator` in `Messages.resx`'s code Used ReSharper renaming utility. Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> # Conflicts: # XenAdmin/Commands/HACommand.cs # XenAdmin/TabPages/AdPage.cs # XenModel/Actions/Network/CreateBondAction.cs # XenModel/Actions/Network/NetworkAction.cs # XenModel/Messages.Designer.cs # XenModel/Messages.resx * CA-34231: Replace negative language with `coordinator` in `ExternalPluginAction.cs` Used ReSharper renaming utility Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CA-34231: Replace negative language with `coordinator` in `XenAdmin/Commands` Used ReSharper renaming utility. Also replace negative language in missed comment in `ExternalPluginAction.cs` Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> # Conflicts: # XenAdmin/Commands/AddHostToPoolCommand.cs # XenAdmin/Commands/HACommand.cs * CA-34231: Replace negative language with `coordinator` in `Helpers.cs` Used ReSharper renaming utility. Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CA-34231: Replace negative language with `coordinator` in `NetworkingHelper.cs` Used ReSharper renaming utility. Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CA-34231: Replace negative language with `coordinator` in `PoolJoinRules.cs` Used ReSharper renaming utility. Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> # Conflicts: # XenAdmin/Dialogs/NewPoolDialog.cs * CA-34231: Replace negative language with `coordinator` in `XenAdmin/Commands`, `Controls`, and `Core` Used ReSharper renaming utility Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> # Conflicts: # XenAdmin/Commands/AddHostToPoolCommand.cs * CA-34231: Replace negative language with `coordinator` in `XenAdmin/Diagnostics` Used ReSharper renaming utility Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CA-34231: Replace negative language with `coordinator` in `XenAdmin/Dialogs` Used ReSharper renaming utility Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> # Conflicts: # XenAdmin/Dialogs/NewPoolDialog.cs * CA-34231: Replace remaining negative language with `coordinator` in `XenAdmin` Used ReSharper renaming utility Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> # Conflicts: # XenAdmin/MainWindow.cs # XenAdmin/TabPages/GeneralTabPage.cs # XenAdmin/Wizards/PatchingWizard/PatchingWizard_SelectServers.cs # XenAdmin/Wizards/RollingUpgradeWizard/RollingUpgradeExtrasPage.cs # XenAdmin/Wizards/RollingUpgradeWizard/RollingUpgradeWizard.cs # XenAdmin/Wizards/RollingUpgradeWizard/RollingUpgradeWizardPrecheckPage.cs # XenAdmin/XenSearch/Columns.cs * CA-34231: Replace remaining negative language with `coordinator` in `XenModel\Actions` Used ReSharper renaming utility. Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> # Conflicts: # XenModel/Actions/Network/CreateBondAction.cs * CA-34231: Replace remaining negative language with `coordinator` in `XenModel` Used ReSharper renaming utility Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CA-34231: Replace remaining negative strings with `main` in `Messages.resx` Used ReSharper renaming utility. Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> # Conflicts: # XenModel/Messages.Designer.cs # XenModel/Messages.resx * CA-34231: Replace remaining negative string names with `main` in `Messages.resx` Used ReSharper renaming utility Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> # Conflicts: # XenAdmin/Dialogs/OptionsPages/SaveAndRestoreOptionsPage.cs # XenModel/Messages.resx * CA-34231: Rename dialogs to replace negative connotations with `main` Used ReSharper renaming utility Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CA-34231: Replace negative language with `main` in `SaveAndResoreOptionsPage.cs` Also updated its resx file. Used ReSharper renaming utility. Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> # Conflicts: # XenAdmin/Dialogs/OptionsPages/SaveAndRestoreOptionsPage.cs * CA-34231: Fix invalid reference in `SaveAndRestoreOptionsPage.Designer.cs` after renaming Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CA-34231: Replace negative language with `main` in `EnterMainPasswordDialog.cs` Used ReSharper renaming utility. Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CA-34231: Replace negative language with `main` in `ChangeMainPasswordDialog.cs` Used ReSharper renaming utility. Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CA-34231: Fix invalid reference not changed after renaming `EnterMainPasswordDialog.cs` Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CA-34231: Replace remaining negative language with `main` in `XenAdmin/Dialogs` Used ReSharper renaming utility. Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CA-34231: Update class names in HelpManager.resx Following renaming of main password dialog. Used ReSharper renaming utility. Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CA-34231: Replace negative language with `main` in `Metadata.cs` Used ReSharper renaming utility. Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CA-34231: Remove remaning negative language with `coordinator` from `Messages.resx` Used ReSharper renaming Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CA-34231: Remove remaning negative language with `other pool member` from `Messages.resx` Used ReSharper Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CA-34231: Replace remaining negative language in solution Used ReSharper renaming utility. Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CP-34231: Remove commented out code in VNCGraphicsClient.cs Code has only been improved partially as it's not strictly relevant to the PR Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CP-34231: Amend negative word replacement in XSVNCScreen.cs Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CP-34231: Simplify debug call formatting in NewPoolDialog.cs Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CP-34231: Add code mistakenly removed in MainWindow.cs Removed as part of `f155f9c8` Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CP-34231: Revert renaming of constant related to Windows' API Considered external to CH Center Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CP-34231: Amend hotkey for Coordinator field in `NewPoolDialog` Previous ALT+<key> hotkey was conflicting with CreatePool Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CP-34231: Remove unecessary whitespace in EvacuateHostDialog.cs Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CP-34231: Update if block to exclude unecessary else in DRFailoverWizard.cs Not relevant to the PR, but the change is small enought to no need extra testing Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CP-34231: Amend typo in PoolJoinRules.cs supporer -> supporter Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CP-34231: Replace missing negative language with `coordinator` in `XenAPI-Extensions/Pool.cs` Variables and methods XenAPI-Extensions were mistakenly skipped Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CP-34231: Replace negative language in `XenApi-Extensions` with `coordinator/interface` Used ReSharper renaming utility. Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CP-34231: Replace negative language in `XenApi-Extensions` with `supporter/member` Used ReSharper renaming utility. Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CP-34231: Replace remaining negative language in `XenServerHealthCheckBugTool.cs` This is only used to format the string Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CP-34231: Change line-endings to CRLF in `Page_CloudConfigParamters.cs` Done in order to fix merge conflict into master Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com> * CP-34231: Amend misc negative language renaming typos `XenServerHealthCheckBugTool` and `XenServerHealthCheckService` Signed-off-by: Danilo Del Busso <Danilo.Del.Busso@citrix.com>
581 lines
24 KiB
C#
581 lines
24 KiB
C#
/* Copyright (c) Citrix Systems, Inc.
|
|
* All rights reserved.
|
|
*
|
|
* Redistribution and use in source and binary forms,
|
|
* with or without modification, are permitted provided
|
|
* that the following conditions are met:
|
|
*
|
|
* * Redistributions of source code must retain the above
|
|
* copyright notice, this list of conditions and the
|
|
* following disclaimer.
|
|
* * Redistributions in binary form must reproduce the above
|
|
* copyright notice, this list of conditions and the
|
|
* following disclaimer in the documentation and/or other
|
|
* materials provided with the distribution.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND
|
|
* CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
|
|
* INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
|
|
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
|
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
|
|
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
|
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
|
|
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
|
|
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
|
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
* SUCH DAMAGE.
|
|
*/
|
|
|
|
using System;
|
|
using System.Collections.Generic;
|
|
using System.Linq;
|
|
using System.Windows.Forms;
|
|
using XenAdmin.Actions;
|
|
using XenAdmin.Controls;
|
|
using XenAdmin.Core;
|
|
using XenAdmin.Dialogs;
|
|
using XenAdmin.Dialogs.WarningDialogs;
|
|
using XenAdmin.Network;
|
|
using XenAPI;
|
|
using System.Drawing;
|
|
|
|
|
|
namespace XenAdmin.Wizards.NewSRWizard_Pages.Frontends
|
|
{
|
|
public partial class LVMoHBA : XenTabPage
|
|
{
|
|
private List<FibreChannelDevice> _selectedDevices = new List<FibreChannelDevice>();
|
|
|
|
public LVMoHBA()
|
|
{
|
|
InitializeComponent();
|
|
SrType = SR.SRTypes.lvmohba;
|
|
}
|
|
|
|
public SR.SRTypes SrType { get; set; }
|
|
|
|
protected virtual bool ShowNicColumn => false;
|
|
|
|
private FibreChannelDescriptor CreateSrDescriptor(FibreChannelDevice device)
|
|
{
|
|
return SrType == SR.SRTypes.gfs2 ? CreateGfs2Descriptor(device) : CreateLvmSrDescriptor(device);
|
|
}
|
|
|
|
protected virtual FibreChannelDescriptor CreateLvmSrDescriptor(FibreChannelDevice device)
|
|
{
|
|
return new LvmOhbaSrDescriptor(device);
|
|
}
|
|
|
|
protected virtual FibreChannelDescriptor CreateGfs2Descriptor(FibreChannelDevice device)
|
|
{
|
|
return new Gfs2HbaSrDescriptor(device);
|
|
}
|
|
|
|
#region XenTabPage overrides
|
|
|
|
public override string PageTitle => Messages.NEWSR_SELECT_LUN;
|
|
|
|
public override string Text => Messages.NEWSR_LOCATION;
|
|
|
|
public override string HelpID => "Location_HBA";
|
|
|
|
protected override void PageLeaveCore(PageLoadedDirection direction, ref bool cancel)
|
|
{
|
|
if (direction == PageLoadedDirection.Back)
|
|
return;
|
|
|
|
Host coordinator = Helpers.GetCoordinator(Connection);
|
|
if (coordinator == null)
|
|
{
|
|
cancel = true;
|
|
return;
|
|
}
|
|
|
|
SrDescriptors = new List<FibreChannelDescriptor>();
|
|
var formatDiskDescriptors = new Dictionary<FibreChannelDescriptor, FibreChannelDescriptor>(); // key = requested SR, value = existing SR
|
|
|
|
var performSecondProbe = Helpers.KolkataOrGreater(Connection) && !Helpers.FeatureForbidden(Connection, Host.CorosyncDisabled)
|
|
&& SrType != SR.SRTypes.lvmofcoe; // gfs2 over fcoe is not supported yet
|
|
|
|
foreach (var device in _selectedDevices)
|
|
{
|
|
// Start probe
|
|
var formatDiskDescriptor = CreateSrDescriptor(device);
|
|
var currentSrDescriptor = formatDiskDescriptor;
|
|
|
|
if (!RunProbe(coordinator, currentSrDescriptor, out List<SR.SRInfo> srs))
|
|
{
|
|
cancel = true;
|
|
return;
|
|
}
|
|
|
|
if (performSecondProbe && srs.Count == 0)
|
|
{
|
|
// Start second probe
|
|
currentSrDescriptor = SrType == SR.SRTypes.gfs2 ? CreateLvmSrDescriptor(device) : CreateGfs2Descriptor(device);
|
|
|
|
if (!RunProbe(coordinator, currentSrDescriptor, out srs))
|
|
{
|
|
cancel = true;
|
|
return;
|
|
}
|
|
}
|
|
|
|
currentSrDescriptor.UUID = srs.Select(sr => sr.UUID).FirstOrDefault();
|
|
if (srs.Count > 0)
|
|
currentSrDescriptor.UpdateDeviceConfig(srs[0].Configuration);
|
|
|
|
if (!string.IsNullOrEmpty(SrWizardType.UUID))
|
|
{
|
|
// Check LUN contains correct SR
|
|
if (currentSrDescriptor.UUID == SrWizardType.UUID)
|
|
{
|
|
SrDescriptors.Add(currentSrDescriptor);
|
|
continue;
|
|
}
|
|
|
|
using (var dlog = new ErrorDialog(String.Format(Messages.INCORRECT_LUN_FOR_SR, SrWizardType.SrName)))
|
|
dlog.ShowDialog(this);
|
|
|
|
cancel = true;
|
|
return;
|
|
}
|
|
|
|
if (string.IsNullOrEmpty(currentSrDescriptor.UUID))
|
|
{
|
|
// No existing SRs were found on this LUN. If allowed to create
|
|
// a new SR, ask the user if they want to proceed and format.
|
|
if (!SrWizardType.AllowToCreateNewSr)
|
|
{
|
|
using (var dlog = new ErrorDialog(Messages.NEWSR_LUN_HAS_NO_SRS))
|
|
dlog.ShowDialog(this);
|
|
|
|
cancel = true;
|
|
return;
|
|
}
|
|
|
|
if (!Program.RunInAutomatedTestMode)
|
|
formatDiskDescriptors.Add(formatDiskDescriptor, null);
|
|
}
|
|
else
|
|
{
|
|
// Check this isn't an existing SR on the current pool
|
|
var existingSr = Connection.Cache.SRs.FirstOrDefault(sr => sr.uuid == currentSrDescriptor.UUID);
|
|
if (existingSr != null)
|
|
{
|
|
var pool = Helpers.GetPool(existingSr.Connection);
|
|
var errorText = pool != null
|
|
? string.Format(Messages.NEWSR_LUN_IN_USE_ON_SELECTED_POOL, device.SCSIid, existingSr.Name())
|
|
: string.Format(Messages.NEWSR_LUN_IN_USE_ON_SELECTED_SERVER, device.SCSIid, existingSr.Name());
|
|
|
|
using (var dlog = new ErrorDialog(errorText))
|
|
dlog.ShowDialog(this);
|
|
|
|
cancel = true;
|
|
return;
|
|
}
|
|
|
|
// CA-17230: Check this isn't an existing SR on any of the known pools.
|
|
// If it is then just continue (i.e. do not ask the user if they want to format or reattach it, we will just reattach it)
|
|
existingSr = SrWizardHelpers.SrInUse(currentSrDescriptor.UUID);
|
|
if (existingSr != null)
|
|
{
|
|
SrDescriptors.Add(currentSrDescriptor);
|
|
continue;
|
|
}
|
|
|
|
// We found a SR on this LUN. Will ask user for choice later.
|
|
formatDiskDescriptors.Add(formatDiskDescriptor, currentSrDescriptor);
|
|
}
|
|
}
|
|
|
|
if (!cancel && formatDiskDescriptors.Count > 0)
|
|
{
|
|
var launcher = new LVMoHBAWarningDialogLauncher(Connection, this, formatDiskDescriptors, SrType);
|
|
launcher.ShowWarnings();
|
|
cancel = launcher.Cancelled;
|
|
if (!cancel && launcher.SrDescriptors.Count > 0)
|
|
SrDescriptors.AddRange(launcher.SrDescriptors);
|
|
}
|
|
}
|
|
|
|
private bool RunProbe(Host coordinator, FibreChannelDescriptor srDescriptor, out List<SR.SRInfo> srs)
|
|
{
|
|
var action = new SrProbeAction(Connection, coordinator, srDescriptor.SrType, srDescriptor.DeviceConfig);
|
|
|
|
using (var dlg = new ActionProgressDialog(action, ProgressBarStyle.Marquee))
|
|
dlg.ShowDialog(this);
|
|
|
|
srs = action.SRs ?? new List<SR.SRInfo>();
|
|
return action.Succeeded;
|
|
}
|
|
|
|
public override bool EnableNext()
|
|
{
|
|
UpdateSelectionButtons();
|
|
return _selectedDevices.Count > 0;
|
|
}
|
|
|
|
public override bool EnablePrevious()
|
|
{
|
|
if (SrWizardType.DisasterRecoveryTask && SrWizardType.SrToReattach == null)
|
|
return false;
|
|
|
|
return true;
|
|
}
|
|
|
|
protected override void PageLoadedCore(PageLoadedDirection direction)
|
|
{
|
|
if (direction == PageLoadedDirection.Back)
|
|
return;
|
|
|
|
colNic.Visible = ShowNicColumn;
|
|
dataGridView.Rows.Clear();
|
|
|
|
var vendorGroups = from device in FCDevices
|
|
group device by device.Vendor into g
|
|
orderby g.Key
|
|
select new { VendorName = g.Key, Devices = g.OrderBy(x => x.Serial) };
|
|
|
|
foreach (var vGroup in vendorGroups)
|
|
{
|
|
var vendorRow = new VendorRow(vGroup.VendorName);
|
|
dataGridView.Rows.Add(vendorRow);
|
|
|
|
using (var font = new Font(dataGridView.DefaultCellStyle.Font, FontStyle.Bold))
|
|
vendorRow.DefaultCellStyle = new DataGridViewCellStyle(dataGridView.DefaultCellStyle)
|
|
{
|
|
Font = font,
|
|
SelectionBackColor = dataGridView.DefaultCellStyle.BackColor,
|
|
SelectionForeColor = dataGridView.DefaultCellStyle.ForeColor
|
|
};
|
|
|
|
var deviceRows = from device in vGroup.Devices select new FCDeviceRow(device, ShowNicColumn);
|
|
dataGridView.Rows.AddRange(deviceRows.ToArray());
|
|
}
|
|
}
|
|
|
|
public override string NextText(bool isLastPage)
|
|
{
|
|
// for Dundee or greater connections, we have "Storage provisioning settings" page after this page, so the Next button should say "Next", not "Create"
|
|
return Helpers.DundeeOrGreater(Connection) ? Messages.WIZARD_BUTTON_NEXT : Messages.NEWSR_LVMOHBA_NEXT_TEXT;
|
|
}
|
|
|
|
public override void SelectDefaultControl()
|
|
{
|
|
dataGridView.Select();
|
|
}
|
|
|
|
#endregion
|
|
|
|
#region Event handlers
|
|
|
|
private void dataGridView_CellClick(object sender, DataGridViewCellEventArgs e)
|
|
{
|
|
if (_srWizardType.SrToReattach != null)
|
|
return;
|
|
|
|
if (e.ColumnIndex != colCheck.Index || e.RowIndex < 0 || e.RowIndex > dataGridView.RowCount - 1)
|
|
return;
|
|
|
|
var deviceRow = dataGridView.Rows[e.RowIndex] as FCDeviceRow;
|
|
if (deviceRow == null)
|
|
return;
|
|
|
|
deviceRow.Cells[colCheck.Index].Value = !(bool)deviceRow.Cells[colCheck.Index].Value;
|
|
|
|
UpdateSelectedDevices();
|
|
OnPageUpdated();
|
|
}
|
|
|
|
private void dataGridView_SelectionChanged(object sender, EventArgs e)
|
|
{
|
|
if (_srWizardType.SrToReattach == null)
|
|
return;
|
|
|
|
UpdateSelectedDevices();
|
|
OnPageUpdated();
|
|
}
|
|
|
|
private void buttonSelectAll_Click(object sender, EventArgs e)
|
|
{
|
|
foreach (var row in dataGridView.Rows)
|
|
{
|
|
var deviceRow = row as FCDeviceRow;
|
|
if (deviceRow != null && deviceRow.Cells.Count > 0)
|
|
deviceRow.Cells[colCheck.Index].Value = true;
|
|
}
|
|
|
|
UpdateSelectedDevices();
|
|
OnPageUpdated();
|
|
}
|
|
|
|
private void buttonClearAll_Click(object sender, EventArgs e)
|
|
{
|
|
foreach (var row in dataGridView.Rows)
|
|
{
|
|
var deviceRow = row as FCDeviceRow;
|
|
if (deviceRow != null && deviceRow.Cells.Count > 0)
|
|
deviceRow.Cells[colCheck.Index].Value = false;
|
|
}
|
|
|
|
UpdateSelectedDevices();
|
|
OnPageUpdated();
|
|
}
|
|
|
|
#endregion
|
|
|
|
private void UpdateSelectedDevices()
|
|
{
|
|
if (SrWizardType.SrToReattach == null)
|
|
{
|
|
//when creating a new SR the checkbox column is visible
|
|
_selectedDevices = (from DataGridViewRow row in dataGridView.Rows
|
|
let deviceRow = row as FCDeviceRow
|
|
where deviceRow != null
|
|
&& deviceRow.Cells.Count > 0
|
|
&& (bool)(deviceRow.Cells[colCheck.Index].Value)
|
|
select deviceRow.Device).ToList();
|
|
}
|
|
else
|
|
{
|
|
//when reattaching SR the checkbox column is hidden
|
|
_selectedDevices = (from DataGridViewRow row in dataGridView.Rows
|
|
let deviceRow = row as FCDeviceRow
|
|
where deviceRow != null && deviceRow.Selected
|
|
select deviceRow.Device).ToList();
|
|
}
|
|
}
|
|
|
|
private void UpdateSelectionButtons()
|
|
{
|
|
if (buttonSelectAll.Visible)
|
|
buttonSelectAll.Enabled = _selectedDevices.Count < FCDevices.Count;
|
|
|
|
if (buttonClearAll.Visible)
|
|
buttonClearAll.Enabled = _selectedDevices.Count > 0;
|
|
}
|
|
|
|
public bool FiberChannelScan(IWin32Window owner, IXenConnection connection, out List<FibreChannelDevice> devices)
|
|
{
|
|
devices = new List<FibreChannelDevice>();
|
|
|
|
Host coordinator = Helpers.GetCoordinator(connection);
|
|
if (coordinator == null)
|
|
return false;
|
|
|
|
var action = new FibreChannelProbeAction(coordinator, SrType);
|
|
using (var dialog = new ActionProgressDialog(action, ProgressBarStyle.Marquee))
|
|
dialog.ShowDialog(owner); //Will block until dialog closes, action completed
|
|
|
|
if (!action.Succeeded)
|
|
return false;
|
|
|
|
devices = action.FibreChannelDevices;
|
|
if (devices != null && devices.Count > 0)
|
|
return true;
|
|
|
|
using (var dlg = new WarningDialog(Messages.FIBRECHANNEL_NO_RESULTS))
|
|
dlg.ShowDialog();
|
|
|
|
return false;
|
|
}
|
|
|
|
#region Accessors
|
|
|
|
public List<FibreChannelDevice> FCDevices { private get; set; }
|
|
|
|
private SrWizardType _srWizardType;
|
|
public SrWizardType SrWizardType
|
|
{
|
|
private get
|
|
{
|
|
return _srWizardType;
|
|
}
|
|
set
|
|
{
|
|
_srWizardType = value;
|
|
|
|
bool creatingNew = _srWizardType.SrToReattach == null;
|
|
|
|
colCheck.Visible = creatingNew;
|
|
dataGridView.MultiSelect = creatingNew;
|
|
buttonSelectAll.Visible = creatingNew;
|
|
buttonClearAll.Visible = creatingNew;
|
|
labelCreate.Visible = creatingNew;
|
|
labelReattach.Visible = !creatingNew;
|
|
}
|
|
}
|
|
|
|
public List<FibreChannelDescriptor> SrDescriptors { get; private set; }
|
|
|
|
/// <summary>
|
|
/// min size
|
|
/// </summary>
|
|
public long SRSize
|
|
{
|
|
get
|
|
{
|
|
long size = long.MaxValue;
|
|
foreach (var srDescriptor in SrDescriptors)
|
|
{
|
|
if (srDescriptor.Device.Size < size)
|
|
size = srDescriptor.Device.Size;
|
|
}
|
|
return size;
|
|
}
|
|
}
|
|
|
|
#endregion
|
|
|
|
#region Nested classes
|
|
|
|
private class FCDeviceRow : DataGridViewRow
|
|
{
|
|
public FibreChannelDevice Device { get; private set; }
|
|
|
|
public FCDeviceRow(FibreChannelDevice device, bool showNicColumn)
|
|
{
|
|
Device = device;
|
|
|
|
string id = string.IsNullOrEmpty(device.SCSIid) ? device.Path : device.SCSIid;
|
|
string details = String.Format("{0}:{1}:{2}:{3}", device.adapter, device.channel, device.id, device.lun);
|
|
|
|
Cells.AddRange(new DataGridViewCheckBoxCell{ThreeState = false, Value = false},
|
|
new DataGridViewTextBoxCell { Value = Util.DiskSizeString(device.Size) },
|
|
new DataGridViewTextBoxCell { Value = device.Serial },
|
|
new DataGridViewTextBoxCell { Value = id },
|
|
new DataGridViewTextBoxCell { Value = details });
|
|
|
|
if (showNicColumn)
|
|
Cells.Add(new DataGridViewTextBoxCell {Value = device.eth});
|
|
}
|
|
}
|
|
|
|
private class VendorRow : DataGridViewRow
|
|
{
|
|
public VendorRow(string vendor)
|
|
{
|
|
Cells.AddRange(new DataGridViewCheckBoxCellVendor(),
|
|
new DataGridViewTextBoxCell { Value = vendor },
|
|
new DataGridViewTextBoxCell(),
|
|
new DataGridViewTextBoxCell(),
|
|
new DataGridViewTextBoxCell());
|
|
}
|
|
|
|
private class DataGridViewCheckBoxCellVendor : DataGridViewCheckBoxCell
|
|
{
|
|
protected override void Paint(Graphics graphics, Rectangle clipBounds, Rectangle cellBounds, int rowIndex, DataGridViewElementStates elementState, object value, object formattedValue, string errorText, DataGridViewCellStyle cellStyle, DataGridViewAdvancedBorderStyle advancedBorderStyle, DataGridViewPaintParts paintParts)
|
|
{
|
|
using (var normalBrush = new SolidBrush(OwningRow.DefaultCellStyle.BackColor))
|
|
using (var selectedBrush = new SolidBrush(OwningRow.DefaultCellStyle.SelectionBackColor))
|
|
{
|
|
graphics.FillRectangle(
|
|
(elementState & DataGridViewElementStates.Selected) != 0 ? selectedBrush : normalBrush,
|
|
cellBounds.X, cellBounds.Y, cellBounds.Width, cellBounds.Height);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
private class LVMoHBAWarningDialogLauncher
|
|
{
|
|
private readonly Dictionary<FibreChannelDescriptor, FibreChannelDescriptor> inputSrDescriptors;
|
|
private readonly IWin32Window owner;
|
|
private readonly SR.SRTypes requestedSrType;
|
|
private readonly IXenConnection _connection;
|
|
|
|
public List<FibreChannelDescriptor> SrDescriptors { get; }
|
|
public bool Cancelled { get; private set; }
|
|
|
|
public LVMoHBAWarningDialogLauncher(IXenConnection conn, IWin32Window owner, Dictionary<FibreChannelDescriptor, FibreChannelDescriptor> srDescriptors, SR.SRTypes requestedSrType)
|
|
{
|
|
_connection = conn;
|
|
this.owner = owner;
|
|
inputSrDescriptors = srDescriptors;
|
|
this.requestedSrType = requestedSrType;
|
|
SrDescriptors = new List<FibreChannelDescriptor>();
|
|
}
|
|
|
|
private LVMoHBAWarningDialog.UserSelectedOption GetSelectedOption(FibreChannelDescriptor descriptor, int remainingCount, bool foundExistingSr,
|
|
SR.SRTypes existingSrType, out bool repeatForRemainingLUNs)
|
|
{
|
|
var deviceDetails = string.Format(Messages.LVMOHBA_WARNING_DIALOG_LUN_DETAILS,
|
|
descriptor.Device.Vendor,
|
|
descriptor.Device.Serial,
|
|
string.IsNullOrEmpty(descriptor.Device.SCSIid) ? descriptor.Device.Path : descriptor.Device.SCSIid,
|
|
Util.DiskSizeString(descriptor.Device.Size));
|
|
|
|
using (var dialog = new LVMoHBAWarningDialog(_connection, deviceDetails, remainingCount, foundExistingSr, existingSrType, requestedSrType))
|
|
{
|
|
dialog.ShowDialog(owner);
|
|
repeatForRemainingLUNs = dialog.RepeatForRemainingLUNs;
|
|
return dialog.SelectedOption;
|
|
}
|
|
}
|
|
|
|
public void ShowWarnings()
|
|
{
|
|
// process LUNs where existing SRs have been found
|
|
bool repeatForRemainingLUNs = false;
|
|
var selectedOption = LVMoHBAWarningDialog.UserSelectedOption.Cancel;
|
|
var descriptors = inputSrDescriptors.Keys.Where(d => inputSrDescriptors[d] != null).ToList();
|
|
|
|
foreach (var descriptor in descriptors)
|
|
{
|
|
if (!repeatForRemainingLUNs)
|
|
{
|
|
var remainingCount = descriptors.Count - 1 - descriptors.IndexOf(descriptor);
|
|
var existingSrType = inputSrDescriptors[descriptor].SrType;
|
|
|
|
selectedOption = GetSelectedOption(descriptor, remainingCount, true, existingSrType, out repeatForRemainingLUNs);
|
|
}
|
|
ProcessSelectedOption(selectedOption, descriptor);
|
|
}
|
|
|
|
if (Cancelled)
|
|
return;
|
|
|
|
// process LUNs where no existing have been found
|
|
repeatForRemainingLUNs = false;
|
|
selectedOption = LVMoHBAWarningDialog.UserSelectedOption.Cancel;
|
|
descriptors = inputSrDescriptors.Keys.Where(d => inputSrDescriptors[d] == null).ToList();
|
|
|
|
foreach (var descriptor in descriptors)
|
|
{
|
|
if (!repeatForRemainingLUNs)
|
|
{
|
|
var remainingCount = descriptors.Count - 1 - descriptors.IndexOf(descriptor);
|
|
var existingSrType = descriptor.SrType;
|
|
selectedOption = GetSelectedOption(descriptor, remainingCount, false, existingSrType, out repeatForRemainingLUNs);
|
|
}
|
|
ProcessSelectedOption(selectedOption, descriptor);
|
|
}
|
|
}
|
|
|
|
private void ProcessSelectedOption(LVMoHBAWarningDialog.UserSelectedOption selectedOption, FibreChannelDescriptor descriptor)
|
|
{
|
|
switch (selectedOption)
|
|
{
|
|
case LVMoHBAWarningDialog.UserSelectedOption.Format:
|
|
descriptor.UUID = null;
|
|
SrDescriptors.Add(descriptor); // descriptor of requested SR
|
|
break;
|
|
case LVMoHBAWarningDialog.UserSelectedOption.Reattach:
|
|
SrDescriptors.Add(inputSrDescriptors[descriptor]); // value = descriptor of existing SR
|
|
break;
|
|
case LVMoHBAWarningDialog.UserSelectedOption.Cancel:
|
|
SrDescriptors.Clear();
|
|
Cancelled = true;
|
|
return;
|
|
}
|
|
}
|
|
}
|
|
|
|
#endregion
|
|
}
|
|
}
|