mirror of
https://github.com/xcp-ng/xenadmin.git
synced 2025-01-21 07:49:32 +01:00
Merge pull request #12 from kc284/vm-copy-credentials_CA-359712
Merge from master
This commit is contained in:
commit
76b20f4874
@ -182,6 +182,9 @@
|
||||
<data name="PRODUCT_VERSION_8_2" xml:space="preserve">
|
||||
<value>8.2</value>
|
||||
</data>
|
||||
<data name="PRODUCT_VERSION_8_2_1" xml:space="preserve">
|
||||
<value>8.2.1</value>
|
||||
</data>
|
||||
<data name="PRODUCT_VERSION_POST_8_2" xml:space="preserve">
|
||||
<value>[BRANDING_PRODUCT_VERSION_TEXT]</value>
|
||||
</data>
|
||||
|
@ -246,11 +246,11 @@ namespace XenAdmin.Actions
|
||||
}
|
||||
|
||||
// Returns a set of params which relate to the object you have selected in the treeview
|
||||
private List<string> RetrieveParams(IXenObject obj)
|
||||
private IEnumerable<string> RetrieveParams(IXenObject obj)
|
||||
{
|
||||
IXenConnection connection = obj.Connection;
|
||||
Host coordinator = connection != null ? Helpers.GetCoordinator(connection) : null; // get coordinator asserts connection is not null
|
||||
string coordinatorAddress = EmptyParameter;
|
||||
var connection = obj?.Connection;
|
||||
var coordinator = connection != null ? Helpers.GetCoordinator(connection) : null; // get coordinator asserts connection is not null
|
||||
var coordinatorAddress = EmptyParameter;
|
||||
|
||||
if (coordinator != null)
|
||||
{
|
||||
@ -258,9 +258,9 @@ namespace XenAdmin.Actions
|
||||
WriteTrustedCertificates(coordinator.Connection);
|
||||
}
|
||||
|
||||
string sessionRef = connection.Session != null ? connection.Session.opaque_ref : EmptyParameter;
|
||||
string objCls = obj != null ? obj.GetType().Name : EmptyParameter;
|
||||
string objUuid = obj != null && connection.Session != null ? Helpers.GetUuid(obj) : EmptyParameter;
|
||||
var sessionRef = connection?.Session != null ? connection.Session.opaque_ref : EmptyParameter;
|
||||
var objCls = obj != null ? obj.GetType().Name : EmptyParameter;
|
||||
var objUuid = connection?.Session != null ? Helpers.GetUuid(obj) : EmptyParameter;
|
||||
return new List<string>(new string[] { coordinatorAddress, sessionRef, objCls, objUuid });
|
||||
}
|
||||
|
||||
|
@ -55,13 +55,8 @@ namespace XenAdmin.Actions.Wlb
|
||||
public WlbOptimizePoolAction(Pool pool, Dictionary<VM, WlbOptimizationRecommendation> vmOptLst, string optId)
|
||||
: base(pool.Connection, string.Format(Messages.WLB_OPTIMIZING_POOL, Helpers.GetName(pool).Ellipsise(50)))
|
||||
{
|
||||
if (pool == null)
|
||||
throw new ArgumentNullException("pool");
|
||||
if (vmOptLst == null)
|
||||
throw new ArgumentNullException("vmOptLst");
|
||||
|
||||
this.Pool = pool;
|
||||
this.vmOptList = vmOptLst;
|
||||
Pool = pool;
|
||||
vmOptList = vmOptLst ?? throw new ArgumentNullException("vmOptLst");
|
||||
this.optId = optId;
|
||||
|
||||
#region RBAC Dependencies
|
||||
|
@ -58,7 +58,10 @@ namespace XenAdmin.Commands
|
||||
|
||||
protected override void RunCore(SelectedItemCollection selection)
|
||||
{
|
||||
Host host = selection[0].HostAncestor;
|
||||
var host = selection[0].HostAncestor;
|
||||
if (host == null)
|
||||
return;
|
||||
|
||||
using (var dlg = new ControlDomainMemoryDialog(host))
|
||||
dlg.ShowDialog(Program.MainWindow);
|
||||
}
|
||||
|
@ -92,23 +92,20 @@ namespace XenAdmin.Commands
|
||||
|
||||
protected override bool CanRunCore(SelectedItemCollection selection)
|
||||
{
|
||||
if (!selection.AllItemsAre<VM>())
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
IXenConnection connection = null;
|
||||
|
||||
bool atLeastOneCanRun = false;
|
||||
foreach (SelectedItem item in selection)
|
||||
var atLeastOneCanRun = false;
|
||||
foreach (var item in selection)
|
||||
{
|
||||
VM vm = (VM)item.XenObject;
|
||||
|
||||
if (!(item.XenObject is VM vm))
|
||||
return false;
|
||||
|
||||
// all VMs must be on the same connection
|
||||
if (connection != null && vm.Connection != connection)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
connection = vm.Connection;
|
||||
|
||||
if (CanRun(item))
|
||||
{
|
||||
|
@ -33,12 +33,11 @@ using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using System.Windows.Forms;
|
||||
using XenAdmin.Controls;
|
||||
using XenAPI;
|
||||
using XenAdmin.Core;
|
||||
using XenAdmin.Actions;
|
||||
using XenAdmin.Actions.Wlb;
|
||||
using XenAdmin.Controls;
|
||||
using XenAdmin.Core;
|
||||
using XenAdmin.Network;
|
||||
using XenAPI;
|
||||
|
||||
|
||||
namespace XenAdmin.Commands
|
||||
@ -112,7 +111,7 @@ namespace XenAdmin.Commands
|
||||
|
||||
// Adds the migrate wizard button, do this before the enable checks on the other items
|
||||
AddAdditionalMenuItems(selection);
|
||||
|
||||
|
||||
UpdateHostList();
|
||||
}
|
||||
|
||||
@ -163,11 +162,13 @@ namespace XenAdmin.Commands
|
||||
if (Helpers.WlbEnabled(connection))
|
||||
{
|
||||
var vms = selection.AsXenObjects<VM>();
|
||||
if (vms == null || vms.Count == 0)
|
||||
return;
|
||||
|
||||
var retrieveVmRecommendationsAction = new WlbRetrieveVmRecommendationsAction(connection, vms);
|
||||
retrieveVmRecommendationsAction.Completed += delegate
|
||||
{
|
||||
if (Stopped || retrieveVmRecommendationsAction.Cancelled ||
|
||||
!retrieveVmRecommendationsAction.Succeeded)
|
||||
if (Stopped || retrieveVmRecommendationsAction.Cancelled || !retrieveVmRecommendationsAction.Succeeded)
|
||||
return;
|
||||
|
||||
var recommendations = new WlbRecommendations(vms, retrieveVmRecommendationsAction.Recommendations);
|
||||
@ -244,7 +245,7 @@ namespace XenAdmin.Commands
|
||||
var firstItem = DropDownItems[0] as VMOperationToolStripMenuSubItem;
|
||||
if (firstItem == null)
|
||||
return;
|
||||
|
||||
|
||||
// API calls could happen in CanRun(), which take time to wait. So a Producer-Consumer-Queue with size 25 is used here to :
|
||||
// 1. Make API calls for different menu items happen in parallel;
|
||||
// 2. Limit the count of concurrent threads (now it's 25).
|
||||
@ -254,7 +255,7 @@ namespace XenAdmin.Commands
|
||||
var connection = selection[0].Connection;
|
||||
var session = connection.DuplicateSession();
|
||||
|
||||
var affinityHost = connection.Resolve(((VM) selection[0].XenObject).affinity);
|
||||
var affinityHost = connection.Resolve(((VM)selection[0].XenObject).affinity);
|
||||
|
||||
EnqueueHostMenuItem(this, session, affinityHost, firstItem, true);
|
||||
|
||||
@ -279,7 +280,7 @@ namespace XenAdmin.Commands
|
||||
workerQueueWithoutWlb.EnqueueItem(() =>
|
||||
{
|
||||
var selection = menu.Command.GetSelection();
|
||||
var cmd = isHomeServer
|
||||
var cmd = isHomeServer
|
||||
? new VMOperationHomeServerCommand(menu.Command.MainWindowCommandInterface, selection, menu._operation, session)
|
||||
: new VMOperationHostCommand(menu.Command.MainWindowCommandInterface, selection, delegate { return host; }, host.Name().EscapeAmpersands(), menu._operation, session);
|
||||
|
||||
@ -321,7 +322,7 @@ namespace XenAdmin.Commands
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
|
||||
#endregion
|
||||
|
||||
/// <summary>
|
||||
|
@ -54,8 +54,6 @@ namespace XenAdmin.Commands
|
||||
/// <param name="recommendations"></param>
|
||||
public WlbRecommendations(List<VM> vms, Dictionary<VM, Dictionary<XenRef<Host>, string[]>> recommendations)
|
||||
{
|
||||
Util.ThrowIfEnumerableParameterNullOrEmpty(vms, "vms");
|
||||
|
||||
_vms = new ReadOnlyCollection<VM>(vms);
|
||||
_recommendations = recommendations;
|
||||
_isError = recommendations == null;
|
||||
|
@ -140,7 +140,7 @@ namespace XenAdmin.Commands
|
||||
|
||||
if(!LiveMigrateAllowedInVersion(targetHost, draggedVM))
|
||||
{
|
||||
Pool targetPool = targetHost == null ? null : Helpers.GetPool(targetHost.Connection);
|
||||
Pool targetPool = Helpers.GetPool(targetHost.Connection);
|
||||
|
||||
if(targetPool == null)
|
||||
return false;
|
||||
|
@ -111,7 +111,8 @@ namespace XenAdmin.Commands
|
||||
!pool.current_operations.Values.Contains(pool_allowed_operations.ha_enable) &&
|
||||
!pool.current_operations.Values.Contains(pool_allowed_operations.ha_disable) &&
|
||||
!pool.current_operations.Values.Contains(pool_allowed_operations.cluster_create) &&
|
||||
!pool.current_operations.Values.Contains(pool_allowed_operations.designate_new_master);
|
||||
!pool.current_operations.Values.Contains(pool_allowed_operations.designate_new_master) &&
|
||||
!pool.RollingUpgrade();
|
||||
}
|
||||
|
||||
protected override string GetCantRunReasonCore(IXenObject item)
|
||||
@ -134,6 +135,9 @@ namespace XenAdmin.Commands
|
||||
|
||||
if (pool.current_operations.Values.Contains(pool_allowed_operations.designate_new_master))
|
||||
return Messages.ENABLE_TLS_VERIFICATION_NEW_COORDINATOR;
|
||||
|
||||
if (pool.RollingUpgrade())
|
||||
return Messages.ENABLE_TLS_VERIFICATION_RPU;
|
||||
}
|
||||
|
||||
return base.GetCantRunReasonCore(item);
|
||||
|
@ -49,14 +49,14 @@ namespace XenAdmin.Commands
|
||||
: base(mainWindow, pool)
|
||||
{ }
|
||||
|
||||
public override string MenuText { get { return Messages.HOST_MENU_IMPORT_VM_TEXT; } }
|
||||
|
||||
public override string ContextMenuText{get{return Messages.HOST_MENU_IMPORT_VM_TEXT;}}
|
||||
public override string MenuText => Messages.HOST_MENU_IMPORT_VM_TEXT;
|
||||
|
||||
public override string ContextMenuText => Messages.HOST_MENU_IMPORT_VM_TEXT;
|
||||
|
||||
protected override void RunCore(SelectedItemCollection selection)
|
||||
{
|
||||
var con = selection.GetConnectionOfFirstItem();
|
||||
MainWindowCommandInterface.ShowPerConnectionWizard(con, new ImportWizard(con, selection.FirstAsXenObject, null, false));
|
||||
MainWindowCommandInterface.ShowPerConnectionWizard(con, new ImportWizard(con, selection.FirstAsXenObject, null));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -78,7 +78,10 @@ namespace XenAdmin.Commands
|
||||
dlg.ShowDialog(Parent);
|
||||
}
|
||||
|
||||
new RepairSRDialog(srList).Show(Parent);
|
||||
if (srList.Count != 0)
|
||||
{
|
||||
new RepairSRDialog(srList).Show(Parent);
|
||||
}
|
||||
}
|
||||
|
||||
protected override bool CanRunCore(SelectedItemCollection selection)
|
||||
|
@ -1497,7 +1497,7 @@ namespace XenAdmin.ConsoleView
|
||||
|
||||
if (this.Size.Height >= (displayBorder ? this.DesktopSize.Height + BORDER_PADDING + BORDER_PADDING : DesktopSize.Height))
|
||||
{
|
||||
this.dy = (this.Size.Height - this.DesktopSize.Height) / 2;
|
||||
this.dy = ((float) this.Size.Height - this.DesktopSize.Height) / 2;
|
||||
}
|
||||
else
|
||||
{
|
||||
@ -1515,7 +1515,7 @@ namespace XenAdmin.ConsoleView
|
||||
|
||||
if (this.Size.Width >= (displayBorder ? this.DesktopSize.Width + BORDER_PADDING + BORDER_PADDING : DesktopSize.Width))
|
||||
{
|
||||
this.dx = (this.Size.Width - this.DesktopSize.Width) / 2;
|
||||
this.dx = ((float) this.Size.Width - this.DesktopSize.Width) / 2;
|
||||
}
|
||||
else
|
||||
{
|
||||
|
@ -711,18 +711,10 @@ namespace XenAdmin.ConsoleView
|
||||
}
|
||||
else if (source.power_state == vm_power_state.Paused)
|
||||
{
|
||||
if (source.allowed_operations.Contains(vm_operations.unpause))
|
||||
{
|
||||
//EnablePowerStateLabel(Messages.CONSOLE_POWER_STATE_PAUSED_UNPAUSE);
|
||||
// CA-12637: Pause/UnPause is not supported in the GUI. Comment out
|
||||
// the EnablePowerStateLabel because it gives the appearance that we
|
||||
// support unpause via the GUI.
|
||||
DisablePowerStateLabel(Messages.CONSOLE_POWER_STATE_PAUSED);
|
||||
}
|
||||
else
|
||||
{
|
||||
DisablePowerStateLabel(Messages.CONSOLE_POWER_STATE_PAUSED);
|
||||
}
|
||||
// CA-12637: Pause/UnPause is not supported in the GUI. Comment out
|
||||
// the EnablePowerStateLabel because it gives the impression that we
|
||||
// support unpause via the GUI.
|
||||
DisablePowerStateLabel(Messages.CONSOLE_POWER_STATE_PAUSED);
|
||||
}
|
||||
else if (source.power_state == vm_power_state.Suspended)
|
||||
{
|
||||
|
@ -127,6 +127,9 @@ namespace XenAdmin.Controls.Ballooning
|
||||
|
||||
private void valueControlDomain_LinkClicked(object sender, LinkLabelLinkClickedEventArgs e)
|
||||
{
|
||||
if (host == null)
|
||||
return;
|
||||
|
||||
using (var dlg = new ControlDomainMemoryDialog(host))
|
||||
dlg.ShowDialog(Program.MainWindow);
|
||||
}
|
||||
|
@ -310,10 +310,9 @@ namespace XenAdmin.Controls
|
||||
|
||||
// find the <VM, VNCView> pair in vncViews and start timer on the vm
|
||||
var views = vncViews.Where(kvp => kvp.Value == vncView).ToList();
|
||||
foreach (var kvp in views)
|
||||
if (views.Count > 0)
|
||||
{
|
||||
StartCloseVNCTimer(kvp.Key);
|
||||
break;
|
||||
StartCloseVNCTimer(views.First().Key);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -300,11 +300,7 @@ namespace XenAdmin.Controls.CustomDataGraph
|
||||
{
|
||||
get
|
||||
{
|
||||
foreach (DataSet s in Sets.Values)
|
||||
{
|
||||
return s.CustomYRange;
|
||||
}
|
||||
return null;
|
||||
return Sets.Values.Select(s => s.CustomYRange).FirstOrDefault();
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -482,19 +482,15 @@ namespace XenAdmin.Controls.CustomDataGraph
|
||||
|
||||
public override bool Equals(object obj)
|
||||
{
|
||||
if(!(obj is DataSet))
|
||||
return base.Equals(obj);
|
||||
|
||||
DataSet other = (DataSet)obj;
|
||||
if (!(obj is DataSet other))
|
||||
return false;
|
||||
|
||||
return Id == other.Id;
|
||||
}
|
||||
|
||||
public override int GetHashCode()
|
||||
{
|
||||
if (string.IsNullOrEmpty(Id))
|
||||
return base.GetHashCode();
|
||||
return Id.GetHashCode();
|
||||
return string.IsNullOrEmpty(Id) ? 0 : Id.GetHashCode();
|
||||
}
|
||||
|
||||
internal void InsertPointCollection(List<DataPoint> list)
|
||||
|
@ -38,8 +38,8 @@ namespace XenAdmin.Controls.CustomGridView
|
||||
{
|
||||
public class GridRow : IComparable<GridRow>
|
||||
{
|
||||
public readonly Dictionary<String, GridItemBase> Items = new Dictionary<string, GridItemBase>();
|
||||
public readonly List<GridRow> Rows = new List<GridRow>();
|
||||
public Dictionary<string, GridItemBase> Items = new Dictionary<string, GridItemBase>();
|
||||
public List<GridRow> Rows = new List<GridRow>();
|
||||
|
||||
public static Image ExpandedImage = Images.StaticImages.expanded_triangle;
|
||||
public static Image ShrunkenImage = Images.StaticImages.contracted_triangle;
|
||||
@ -678,14 +678,14 @@ namespace XenAdmin.Controls.CustomGridView
|
||||
|
||||
public override bool Equals(object obj)
|
||||
{
|
||||
if(!(obj is GridRow))
|
||||
return base.Equals(obj);
|
||||
return OpaqueRef == ((GridRow)obj).OpaqueRef;
|
||||
if (!(obj is GridRow row))
|
||||
return false;
|
||||
return OpaqueRef == row.OpaqueRef;
|
||||
}
|
||||
|
||||
public override int GetHashCode()
|
||||
{
|
||||
return base.GetHashCode();
|
||||
return (OpaqueRef != null ? OpaqueRef.GetHashCode() : 0);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -90,7 +90,9 @@ namespace XenAdmin.Controls.DataGridViewEx
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
private readonly IXenObject _xenObject;
|
||||
|
||||
/// <summary>
|
||||
/// If the row is either a pool row or else a stanadlone host row
|
||||
/// </summary>
|
||||
@ -128,7 +130,7 @@ namespace XenAdmin.Controls.DataGridViewEx
|
||||
|
||||
public override int GetHashCode()
|
||||
{
|
||||
return base.GetHashCode();
|
||||
return _xenObject?.GetHashCode() ?? 0;
|
||||
}
|
||||
|
||||
public CheckState Checked
|
||||
@ -143,11 +145,10 @@ namespace XenAdmin.Controls.DataGridViewEx
|
||||
}
|
||||
}
|
||||
|
||||
protected PoolHostDataGridViewOneCheckboxRow(){}
|
||||
|
||||
protected PoolHostDataGridViewOneCheckboxRow(Pool pool)
|
||||
: base(pool)
|
||||
{
|
||||
_xenObject = pool;
|
||||
SetupCells();
|
||||
}
|
||||
|
||||
@ -159,6 +160,7 @@ namespace XenAdmin.Controls.DataGridViewEx
|
||||
protected PoolHostDataGridViewOneCheckboxRow(Host host, bool hasPool)
|
||||
: base(host, hasPool)
|
||||
{
|
||||
_xenObject = host;
|
||||
SetupCells();
|
||||
}
|
||||
|
||||
|
@ -32,6 +32,7 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.ComponentModel;
|
||||
using System.Linq;
|
||||
using System.Windows.Forms;
|
||||
using XenAdmin.Core;
|
||||
using XenAdmin.Network;
|
||||
@ -119,18 +120,18 @@ namespace XenAdmin.Controls
|
||||
DeregisterEvents();
|
||||
RegisterEvents();
|
||||
|
||||
foreach (IXenConnection c in ConnectionsManager.XenConnectionsCopy)
|
||||
foreach (var c in ConnectionsManager.XenConnectionsCopy)
|
||||
{
|
||||
Pool p = Helpers.GetPool(c);
|
||||
var p = Helpers.GetPool(c);
|
||||
|
||||
if (p == null)// Stand alone host
|
||||
{
|
||||
foreach (Host h in c.Cache.Hosts)
|
||||
if (c.Cache.Hosts.Length > 0)
|
||||
{
|
||||
var item = GenerateFilterItem(h, h.uuid);
|
||||
item.Checked = HostCheckStates.ContainsKey(h.uuid);
|
||||
var host = c.Cache.Hosts.First();
|
||||
var item = GenerateFilterItem(host, host.uuid);
|
||||
item.Checked = HostCheckStates.ContainsKey(host.uuid);
|
||||
DropDownItems.Add(item);
|
||||
break;
|
||||
}
|
||||
}
|
||||
else
|
||||
|
@ -33,7 +33,6 @@ using System;
|
||||
using System.Windows.Forms;
|
||||
using System.Drawing;
|
||||
using System.Runtime.InteropServices;
|
||||
using XenAdmin.Core;
|
||||
using XenCenterLib;
|
||||
|
||||
namespace XenAdmin.Controls
|
||||
@ -62,8 +61,8 @@ namespace XenAdmin.Controls
|
||||
/// The handle of the horizontal scrollbar of this ListBox
|
||||
/// </summary>
|
||||
private IntPtr _hScrollbarHandle = IntPtr.Zero;
|
||||
public WndProcCancelDelegate CancelWndProc = new WndProcCancelDelegate(delegate(Message msg) { return false; });
|
||||
|
||||
public Func<Message, bool> CancelWndProc = msg => false;
|
||||
|
||||
protected override void WndProc(ref Message msg)
|
||||
{
|
||||
@ -92,7 +91,7 @@ namespace XenAdmin.Controls
|
||||
base.Invalidate();
|
||||
}
|
||||
|
||||
if(!CancelWndProc(msg))
|
||||
if (!CancelWndProc(msg))
|
||||
base.WndProc(ref msg);
|
||||
}
|
||||
|
||||
@ -118,18 +117,12 @@ namespace XenAdmin.Controls
|
||||
base.OnMouseWheel(e);
|
||||
}
|
||||
|
||||
private ContextMenuStrip _contextMenuStrip = null;
|
||||
private ContextMenuStrip _contextMenuStrip;
|
||||
|
||||
public override ContextMenuStrip ContextMenuStrip
|
||||
{
|
||||
get
|
||||
{
|
||||
return _contextMenuStrip;
|
||||
}
|
||||
set
|
||||
{
|
||||
_contextMenuStrip = value;
|
||||
}
|
||||
get => _contextMenuStrip;
|
||||
set => _contextMenuStrip = value;
|
||||
}
|
||||
|
||||
protected override void OnKeyUp(KeyEventArgs e)
|
||||
@ -233,115 +226,6 @@ namespace XenAdmin.Controls
|
||||
Refresh();
|
||||
}
|
||||
|
||||
public const int RIGHT_PADDING = 5;
|
||||
|
||||
public void WilkieSpecial(Image icon, string text, string extraText, Color extraTextColor, Font extraTextFont, DrawItemEventArgs e)
|
||||
{
|
||||
Graphics g = e.Graphics;
|
||||
|
||||
WSPaintBG(e, this);
|
||||
|
||||
// This is the rect where we want to put the text pair
|
||||
Rectangle bounds = new Rectangle(e.Bounds.Height, e.Bounds.Y, e.Bounds.Width - e.Bounds.Height - RIGHT_PADDING, e.Bounds.Height);
|
||||
|
||||
String display;
|
||||
Size s = WSDrawTextPair(this, text, extraText, extraTextColor, extraTextFont, e, bounds, true, out display);
|
||||
|
||||
WSDrawSelectRect(e, bounds.Height + s.Width);
|
||||
|
||||
WSDrawLeftImage(icon, e);
|
||||
|
||||
// And the text
|
||||
Drawing.DrawText(g, display, e.Font,
|
||||
bounds, e.ForeColor, e.BackColor, TextFormatFlags.Left | TextFormatFlags.VerticalCenter);
|
||||
}
|
||||
|
||||
private static void WSDrawSelectRect(DrawItemEventArgs e, int width)
|
||||
{
|
||||
Graphics g = e.Graphics;
|
||||
|
||||
Rectangle selectionRectangle = new Rectangle(e.Bounds.Location, e.Bounds.Size);
|
||||
selectionRectangle.Width = width;
|
||||
|
||||
using (SolidBrush backBrush = new SolidBrush(e.BackColor))
|
||||
{
|
||||
g.FillRectangle(backBrush, selectionRectangle);
|
||||
}
|
||||
}
|
||||
|
||||
private static Color GetBackColorFor(Control control)
|
||||
{
|
||||
return !control.Enabled ? SystemColors.Control : control.BackColor;
|
||||
}
|
||||
|
||||
private static void WSDrawLeftImage(Image icon, DrawItemEventArgs e)
|
||||
{
|
||||
Graphics g = e.Graphics;
|
||||
|
||||
g.DrawImage(icon, e.Bounds.Left + 1, e.Bounds.Top + 1, e.Bounds.Height - 2, e.Bounds.Height - 2);
|
||||
}
|
||||
|
||||
private static Size WSDrawTextPair(Control control, String text, String extraText, Color extraTextColor, Font extraTextFont, DrawItemEventArgs e, Rectangle bounds, bool ShowSelectOnExtraText, out String display)
|
||||
{
|
||||
Graphics g = e.Graphics;
|
||||
g.TextRenderingHint = Drawing.TextRenderingHint;
|
||||
|
||||
display = text;
|
||||
Size s = Drawing.MeasureText(g, display, e.Font,
|
||||
bounds.Size, TextFormatFlags.Right | TextFormatFlags.VerticalCenter);
|
||||
|
||||
if (extraText == null)
|
||||
return s;
|
||||
|
||||
// We're going to have the extra text take precedent over the text,
|
||||
// so shrink the text and put ellipses on until it measures up
|
||||
|
||||
Size t = Drawing.MeasureText(g, extraText, extraTextFont,
|
||||
bounds.Size, TextFormatFlags.Right | TextFormatFlags.VerticalCenter);
|
||||
|
||||
int trim = text.Length;
|
||||
|
||||
while (s.Width + t.Width + 10 > bounds.Width && trim > 0)
|
||||
{
|
||||
trim--;
|
||||
|
||||
display = text.Ellipsise(trim);
|
||||
|
||||
s = Drawing.MeasureText(g, display, e.Font,
|
||||
bounds.Size, TextFormatFlags.Right | TextFormatFlags.VerticalCenter);
|
||||
}
|
||||
|
||||
Color backColor = ShowSelectOnExtraText && control.Focused && e.State == DrawItemState.Selected
|
||||
? Color.LightGray
|
||||
: GetBackColorFor(control);
|
||||
|
||||
if (ShowSelectOnExtraText)
|
||||
{
|
||||
Rectangle greySelectionRectangle = new Rectangle(bounds.Width - t.Width + bounds.X, bounds.Y + 2, t.Width, t.Height);
|
||||
|
||||
using (SolidBrush brush = new SolidBrush(backColor))
|
||||
{
|
||||
g.FillRectangle(brush, greySelectionRectangle);
|
||||
}
|
||||
}
|
||||
|
||||
Drawing.DrawText(g, extraText, extraTextFont,
|
||||
bounds, extraTextColor, backColor, TextFormatFlags.Right | TextFormatFlags.VerticalCenter);
|
||||
|
||||
return s;
|
||||
}
|
||||
|
||||
private static void WSPaintBG(DrawItemEventArgs e, Control control)
|
||||
{
|
||||
Graphics g = e.Graphics;
|
||||
Color color = GetBackColorFor(control);
|
||||
|
||||
using (SolidBrush backBrush = new SolidBrush(color))
|
||||
{
|
||||
g.FillRectangle(backBrush, e.Bounds);
|
||||
}
|
||||
}
|
||||
|
||||
protected override void OnGotFocus(EventArgs e)
|
||||
{
|
||||
base.OnGotFocus(e);
|
||||
@ -354,6 +238,4 @@ namespace XenAdmin.Controls
|
||||
this.Refresh();
|
||||
}
|
||||
}
|
||||
|
||||
public delegate bool WndProcCancelDelegate(Message msg);
|
||||
}
|
||||
|
@ -271,7 +271,6 @@ namespace XenAdmin.Controls
|
||||
cbLUN.Items.Add(new LunComboBoxItem(vdi) { AdditionalConstraints = LunConstraints });
|
||||
}
|
||||
|
||||
cbLUN.Items.OfType<LunComboBoxItem>().OrderBy(i=>i.Enabled);
|
||||
Cells.AddRange(tbVDI, cbLUN, tbSR);
|
||||
Debug.Assert(cbLUN.Items.Count == Sr.VDIs.Count, "Not all combobox items were converted");
|
||||
}
|
||||
|
@ -305,8 +305,6 @@ namespace XenAdmin.Controls.NetworkingTab
|
||||
}
|
||||
NetworksGridView.Rows.AddRange(vifRowsToAdd.ToArray());
|
||||
|
||||
bool selected = true;
|
||||
|
||||
if (selectedVIF != null)
|
||||
{
|
||||
foreach (VifRow row in NetworksGridView.Rows)
|
||||
@ -319,11 +317,6 @@ namespace XenAdmin.Controls.NetworkingTab
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (!selected && NetworksGridView.Rows.Count > 0)
|
||||
{
|
||||
NetworksGridView.Rows[0].Selected = true;
|
||||
}
|
||||
}
|
||||
else if (XenObject is Host || XenObject is Pool)
|
||||
{
|
||||
|
@ -300,7 +300,7 @@ namespace XenAdmin.Controls
|
||||
}
|
||||
case VerticalAlignment.Middle:
|
||||
{
|
||||
Y = (this.Height - this.Padding.Vertical) / 2;
|
||||
Y = ((float) this.Height - this.Padding.Vertical) / 2;
|
||||
break;
|
||||
}
|
||||
case VerticalAlignment.Bottom:
|
||||
|
@ -336,17 +336,6 @@ namespace XenAdmin.Controls
|
||||
[DllImport("user32.dll")]
|
||||
internal static extern IntPtr SendMessage(IntPtr hWnd, int msg, IntPtr wParam, ref Win32.POINT pt);
|
||||
|
||||
|
||||
|
||||
public override Size GetPreferredSize(Size proposedSize)
|
||||
{
|
||||
if (root == null && Parent != null)
|
||||
{
|
||||
return DefaultSize;
|
||||
}
|
||||
return new Size(root.SubtreeWidth, root.SubtreeHeight);
|
||||
}
|
||||
|
||||
#endregion
|
||||
|
||||
#region Drawing
|
||||
|
@ -137,12 +137,8 @@ namespace XenAdmin.Controls
|
||||
|
||||
if (_scanCount > 0)
|
||||
return;
|
||||
|
||||
Program.Invoke(this, () =>
|
||||
{
|
||||
Invalidate();
|
||||
Rebuild(items, preselectedSR);
|
||||
});
|
||||
|
||||
Program.Invoke(this, () => Rebuild(items, preselectedSR));
|
||||
};
|
||||
action.RunAsync();
|
||||
}
|
||||
@ -177,6 +173,7 @@ namespace XenAdmin.Controls
|
||||
private void Rebuild(List<SrPickerItem> items = null, SR preselectedSr = null)
|
||||
{
|
||||
Program.AssertOnEventThread();
|
||||
Invalidate();
|
||||
|
||||
SR selectedSr = preselectedSr ?? SR;
|
||||
var theItems = items ?? GetSrPickerItems();
|
||||
@ -213,12 +210,18 @@ namespace XenAdmin.Controls
|
||||
|
||||
private void Server_PropertyChanged(object sender, PropertyChangedEventArgs e)
|
||||
{
|
||||
if (_scanCount > 0)
|
||||
return;
|
||||
|
||||
if (e.PropertyName == "name_label" || e.PropertyName == "PBDs" || e.PropertyName == "physical_utilisation" || e.PropertyName == "currently_attached" || e.PropertyName == "default_SR")
|
||||
Program.Invoke(this, () => Rebuild());
|
||||
}
|
||||
|
||||
private void SR_CollectionChanged(object sender, CollectionChangeEventArgs e)
|
||||
{
|
||||
if (_scanCount > 0)
|
||||
return;
|
||||
|
||||
Program.Invoke(this, () => Rebuild());
|
||||
}
|
||||
|
||||
|
@ -33,6 +33,7 @@ using System;
|
||||
using System.Windows.Forms;
|
||||
using XenAdmin.Core;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using XenAdmin.Network;
|
||||
using XenAdmin.XenSearch;
|
||||
using XenCenterLib;
|
||||
@ -157,7 +158,7 @@ namespace XenAdmin.Controls
|
||||
{
|
||||
VirtualTreeNode.PersistenceInfo info = new VirtualTreeNode.PersistenceInfo(node);
|
||||
|
||||
if (!_persistedSelectionInfo.Contains(info))
|
||||
if (_persistedSelectionInfo != null && !_persistedSelectionInfo.Contains(info))
|
||||
{
|
||||
// selection is different to old one. So fire an event.
|
||||
|
||||
@ -203,11 +204,9 @@ namespace XenAdmin.Controls
|
||||
|
||||
if (newSelectedNodes.Count == 0)
|
||||
{
|
||||
foreach (VirtualTreeNode.PersistenceInfo info in _persistedSelectionInfo)
|
||||
if (_persistedSelectionInfo.Count > 0)
|
||||
{
|
||||
// Finally, just select one of the parents
|
||||
TryToSelectNode(newSelectedNodes, ClosestMatch(info.Path));
|
||||
break;
|
||||
TryToSelectNode(newSelectedNodes, ClosestMatch(_persistedSelectionInfo.First().Path));
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -422,7 +422,7 @@ namespace XenAdmin.Controls.Wlb
|
||||
/// <param name="e">EventArgs</param>
|
||||
private void ButtonApply_Click(object sender, EventArgs e)
|
||||
{
|
||||
if (this._pool == null)
|
||||
if (_pool == null || _vmOptList == null)
|
||||
return;
|
||||
|
||||
applyButton.Enabled = false;
|
||||
|
@ -1080,7 +1080,7 @@ namespace XenAdmin.Controls.XenSearch
|
||||
|
||||
public class ExtraComboEntry
|
||||
{
|
||||
public StringPropertyQuery.PropertyQueryType type;
|
||||
public readonly StringPropertyQuery.PropertyQueryType type;
|
||||
public ExtraComboEntry(StringPropertyQuery.PropertyQueryType type)
|
||||
{
|
||||
this.type = type;
|
||||
@ -1121,7 +1121,7 @@ namespace XenAdmin.Controls.XenSearch
|
||||
|
||||
public override int GetHashCode()
|
||||
{
|
||||
return base.GetHashCode();
|
||||
return (int) type;
|
||||
}
|
||||
}
|
||||
|
||||
@ -1327,7 +1327,7 @@ namespace XenAdmin.Controls.XenSearch
|
||||
|
||||
public override int GetHashCode()
|
||||
{
|
||||
return base.GetHashCode();
|
||||
return (int) type;
|
||||
}
|
||||
}
|
||||
|
||||
@ -2498,7 +2498,7 @@ namespace XenAdmin.Controls.XenSearch
|
||||
if (intQuery == null)
|
||||
return;
|
||||
|
||||
queryElement.numericUpDown.Value = intQuery.query / multiplier;
|
||||
queryElement.numericUpDown.Value = (decimal) intQuery.query / multiplier;
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -139,11 +139,8 @@ namespace XenAdmin.Controls.XenSearch
|
||||
public void Populate(Search search)
|
||||
{
|
||||
ClearItems();
|
||||
if (search != null && search.Query != null)
|
||||
scope = search.Query.QueryScope;
|
||||
else
|
||||
scope = null;
|
||||
search.PopulateAdapters(this);
|
||||
scope = search?.Query?.QueryScope;
|
||||
search?.PopulateAdapters(this);
|
||||
}
|
||||
}
|
||||
}
|
@ -59,7 +59,10 @@ namespace XenAdmin.Core
|
||||
internal static string GetDetails(this ActionBase action)
|
||||
{
|
||||
var sb = new StringBuilder(GetTitle(action));
|
||||
sb.Append("\n").Append(GetDescription(action));
|
||||
|
||||
var description = GetDescription(action);
|
||||
if (!string.IsNullOrEmpty(description))
|
||||
sb.Append("\n").Append(description);
|
||||
|
||||
string timeString = GetTimeElapsed(action);
|
||||
if (!string.IsNullOrEmpty(timeString))
|
||||
|
@ -43,41 +43,30 @@ namespace XenAdmin.Diagnostics.Checks
|
||||
class PVGuestsCheck : HostPostLivenessCheck
|
||||
{
|
||||
private readonly Pool _pool;
|
||||
private readonly bool _upgrade;
|
||||
private readonly bool _manualUpgrade;
|
||||
private readonly Dictionary<string, string> _installMethodConfig;
|
||||
|
||||
public PVGuestsCheck(Host coordinator, bool upgrade, bool manualUpgrade = false, Dictionary<string, string> installMethodConfig = null)
|
||||
public PVGuestsCheck(Host coordinator, bool manualUpgrade = false, Dictionary<string, string> installMethodConfig = null)
|
||||
: base(coordinator)
|
||||
{
|
||||
_pool = Helpers.GetPoolOfOne(Host?.Connection);
|
||||
_upgrade = upgrade;
|
||||
_manualUpgrade = manualUpgrade;
|
||||
_installMethodConfig = installMethodConfig;
|
||||
}
|
||||
|
||||
public override bool CanRun()
|
||||
{
|
||||
if (Helpers.QuebecOrGreater(Host))
|
||||
if (Helpers.YangtzeOrGreater(Host))
|
||||
return false;
|
||||
|
||||
if (_pool == null || !_pool.Connection.Cache.VMs.Any(vm => vm.IsPvVm()))
|
||||
return false;
|
||||
|
||||
if (!_upgrade && !Helpers.NaplesOrGreater(Host))
|
||||
return false;
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
protected override Problem RunHostCheck()
|
||||
{
|
||||
//update case
|
||||
if (!_upgrade)
|
||||
return new PoolHasPVGuestWarningUrl(this, _pool);
|
||||
|
||||
//upgrade case
|
||||
|
||||
if (!_manualUpgrade)
|
||||
{
|
||||
var hotfix = HotfixFactory.Hotfix(Host);
|
||||
@ -95,6 +84,9 @@ namespace XenAdmin.Diagnostics.Checks
|
||||
if (string.IsNullOrEmpty(upgradePlatformVersion))
|
||||
return new PoolHasPVGuestWarningUrl(this, _pool);
|
||||
|
||||
if (Helpers.YangtzeOrGreater(upgradePlatformVersion))
|
||||
return new PoolHasPVGuestProblem(this, _pool);
|
||||
|
||||
if (Helpers.QuebecOrGreater(upgradePlatformVersion))
|
||||
return new PoolHasPVGuestWarningUrl(this, _pool);
|
||||
|
||||
|
@ -57,4 +57,27 @@ namespace XenAdmin.Diagnostics.Problems.PoolProblem
|
||||
public override string HelpMessage => LinkText;
|
||||
public override string LinkText => Messages.LEARN_MORE;
|
||||
}
|
||||
|
||||
|
||||
class PoolHasPVGuestProblem : ProblemWithInformationUrl
|
||||
{
|
||||
private readonly Pool _pool;
|
||||
|
||||
public PoolHasPVGuestProblem(Check check, Pool pool)
|
||||
: base(check)
|
||||
{
|
||||
_pool = pool;
|
||||
}
|
||||
|
||||
private string PVGuestCheckUrl => string.Format(InvisibleMessages.PV_GUESTS_CHECK_URL);
|
||||
public override Uri UriToLaunch => new Uri(PVGuestCheckUrl);
|
||||
public override string Title => Description;
|
||||
|
||||
public override string Description =>
|
||||
string.Format(Messages.POOL_HAS_PV_GUEST_WARNING, _pool.Name(),
|
||||
string.Format(Messages.STRING_SPACE_STRING, BrandManager.ProductBrand, BrandManager.ProductVersion81));
|
||||
|
||||
public override string HelpMessage => LinkText;
|
||||
public override string LinkText => Messages.LEARN_MORE;
|
||||
}
|
||||
}
|
||||
|
@ -124,7 +124,9 @@ namespace XenAdmin.Dialogs
|
||||
var multipleAction = action as MultipleAction;
|
||||
labelSubActionStatus.Visible = multipleAction != null && multipleAction.ShowSubActionsDetails;
|
||||
if (labelSubActionStatus.Visible)
|
||||
UpdateLabel(labelSubActionStatus, multipleAction.SubActionDescription, multipleAction.SubActionTitle);
|
||||
{
|
||||
UpdateLabel(labelSubActionStatus, multipleAction?.SubActionDescription, multipleAction?.SubActionTitle);
|
||||
}
|
||||
}
|
||||
|
||||
private void action_Completed(ActionBase sender)
|
||||
|
@ -137,7 +137,9 @@ namespace XenAdmin.Dialogs
|
||||
ServerNameComboBox.Enabled = true;
|
||||
AddButton.Text = Messages.ADD;
|
||||
}
|
||||
if (_changedPass && connection.Password == null)
|
||||
else if (!_changedPass)
|
||||
return;
|
||||
else if (connection.Password == null)
|
||||
{
|
||||
Text = Messages.CONNECT_TO_SERVER;
|
||||
labelInstructions.Text = Messages.CONNECT_TO_SERVER_BLURB;
|
||||
@ -145,7 +147,7 @@ namespace XenAdmin.Dialogs
|
||||
ServerNameComboBox.Enabled = false;
|
||||
AddButton.Text = Messages.CONNECT;
|
||||
}
|
||||
else if (_changedPass && connection.ExpectPasswordIsCorrect)
|
||||
else if (connection.ExpectPasswordIsCorrect)
|
||||
{
|
||||
// This situation should be rare, it normally comes from logging in a new session after an existing one has been made
|
||||
// We now use duplicate sessions instead most of the time which don't log in again.
|
||||
@ -155,7 +157,7 @@ namespace XenAdmin.Dialogs
|
||||
ServerNameComboBox.Enabled = false;
|
||||
AddButton.Text = Messages.OK;
|
||||
}
|
||||
else if (_changedPass) // the password probably hasnt actually changed but we do know the user has typed it in wrong
|
||||
else // the password probably hasn't actually changed but we do know the user has typed it in wrong
|
||||
{
|
||||
Text = Messages.CONNECT_TO_SERVER;
|
||||
labelInstructions.Text = string.Format(Messages.ERROR_CONNECTING_BLURB, BrandManager.BrandConsole);
|
||||
@ -163,6 +165,7 @@ namespace XenAdmin.Dialogs
|
||||
ServerNameComboBox.Enabled = false;
|
||||
AddButton.Text = Messages.CONNECT;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
private void AddButton_Click(object sender, EventArgs e)
|
||||
@ -200,7 +203,7 @@ namespace XenAdmin.Dialogs
|
||||
{
|
||||
if (conn == null)
|
||||
{
|
||||
conn = new XenConnection {fromDialog = true};
|
||||
conn = new XenConnection { fromDialog = true };
|
||||
conn.CachePopulated += conn_CachePopulated;
|
||||
}
|
||||
else if (!_changedPass)
|
||||
|
@ -50,8 +50,6 @@ namespace XenAdmin.Dialogs
|
||||
public ControlDomainMemoryDialog(Host host)
|
||||
: base(host.Connection)
|
||||
{
|
||||
if (host == null) throw new ArgumentNullException("host");
|
||||
|
||||
InitializeComponent();
|
||||
this.host = host;
|
||||
this.host.PropertyChanged += Server_PropertyChanged;
|
||||
|
@ -207,15 +207,15 @@ namespace XenAdmin.Dialogs
|
||||
if (freeCount == 0 || freeCount < xenObject.Connection.Cache.Hosts.Length)
|
||||
return false;
|
||||
|
||||
var expiryGroups = from Host h in xenObject.Connection.Cache.Hosts
|
||||
var expiryGroups = (from Host h in xenObject.Connection.Cache.Hosts
|
||||
let exp = h.LicenseExpiryUTC()
|
||||
group h by exp
|
||||
into g
|
||||
select new { ExpiryDate = g.Key, Hosts = g };
|
||||
select new { ExpiryDate = g.Key, Hosts = g }).ToList();
|
||||
|
||||
if(expiryGroups.Count() > 1)
|
||||
if (expiryGroups.Count > 1)
|
||||
{
|
||||
expiryGroups.OrderBy(g => g.ExpiryDate);
|
||||
expiryGroups = expiryGroups.OrderBy(g => g.ExpiryDate).ToList();
|
||||
if ((expiryGroups.ElementAt(1).ExpiryDate - expiryGroups.ElementAt(0).ExpiryDate).TotalDays > 30)
|
||||
return true;
|
||||
}
|
||||
|
@ -120,7 +120,7 @@ namespace XenAdmin.Dialogs.OptionsPages
|
||||
log.Warn("Could not unprotect internet proxy password.", e);
|
||||
}
|
||||
|
||||
ConnectionTimeoutNud.Value = Properties.Settings.Default.ConnectionTimeout / 1000;
|
||||
ConnectionTimeoutNud.Value = (decimal) Properties.Settings.Default.ConnectionTimeout / 1000;
|
||||
|
||||
eventsDisabled = false;
|
||||
}
|
||||
|
@ -75,7 +75,6 @@ namespace XenAdmin.Dialogs
|
||||
/// <param name="runAction"></param>
|
||||
public RepairSRDialog(IEnumerable<SR> srs, bool runAction = true)
|
||||
{
|
||||
Util.ThrowIfEnumerableParameterNullOrEmpty(srs, "srs");
|
||||
this.runAction = runAction;
|
||||
BoldFont = new Font(Font, FontStyle.Bold);
|
||||
List<SR> srList = new List<SR>(srs);
|
||||
|
@ -78,7 +78,7 @@ namespace XenAdmin.Dialogs.VMDialogs
|
||||
|
||||
private void buttonMove_Click(object sender, EventArgs e)
|
||||
{
|
||||
var action = new VMMoveAction(vm, srPicker1.SR, vm.GetStorageHost(false), vm.Name());
|
||||
var action = new VMMoveAction(vm, srPicker1.SR, vm.GetStorageHost(false));
|
||||
action.RunAsync();
|
||||
Close();
|
||||
}
|
||||
|
@ -378,8 +378,8 @@ namespace XenAdmin.Dialogs.Wlb
|
||||
Dictionary<string, string> rps = new Dictionary<string, string>();
|
||||
foreach(string key in this._rpParams.Keys)
|
||||
{
|
||||
if (String.Compare(key, WlbReportSubscription.REPORT_NAME, true) == 0)
|
||||
_subscription.ReportName = this._rpParams[WlbReportSubscription.REPORT_NAME];
|
||||
if (String.Compare(key, WlbReportSubscription.REPORT_NAME_KEY, true) == 0)
|
||||
_subscription.ReportName = this._rpParams[WlbReportSubscription.REPORT_NAME_KEY];
|
||||
else
|
||||
{
|
||||
//Get start date range
|
||||
|
@ -37,7 +37,7 @@ namespace XenAdmin
|
||||
{
|
||||
internal Grouping Grouping;
|
||||
internal object Parent;
|
||||
internal object Group;
|
||||
internal readonly object Group;
|
||||
|
||||
/// <summary></summary>
|
||||
/// <param name="grouping"></param>
|
||||
@ -55,8 +55,7 @@ namespace XenAdmin
|
||||
|
||||
public override bool Equals(object obj)
|
||||
{
|
||||
GroupingTag other = obj as GroupingTag;
|
||||
return other != null && Grouping.Equals(other.Grouping) && Group.Equals(other.Group);
|
||||
return obj is GroupingTag other && Grouping.Equals(other.Grouping) && Group.Equals(other.Group);
|
||||
}
|
||||
|
||||
public override int GetHashCode()
|
||||
|
@ -2706,7 +2706,7 @@ namespace XenAdmin
|
||||
{
|
||||
HelpersGUI.BringFormToFront(this);
|
||||
Host hostAncestor = SelectionManager.Selection.Count == 1 ? SelectionManager.Selection[0].HostAncestor : null;
|
||||
new ImportWizard(SelectionManager.Selection.GetConnectionOfFirstItem(), hostAncestor, param, false).Show();
|
||||
new ImportWizard(SelectionManager.Selection.GetConnectionOfFirstItem(), hostAncestor, param).Show();
|
||||
}
|
||||
|
||||
#region XenSearch
|
||||
|
@ -85,8 +85,9 @@ namespace XenAdmin.Plugins
|
||||
ContextMenu = Helpers.GetEnumXmlAttribute(node, ATT_CONTEXT_MENU, GetContextMenuFromMenu(Menu));
|
||||
Serialized = Helpers.GetEnumXmlAttribute(node, ATT_SERIALIZED, PluginSerializationLevel.none);
|
||||
|
||||
foreach (XmlNode child in node.ChildNodes)
|
||||
{
|
||||
if (node.ChildNodes.Count > 0)
|
||||
{
|
||||
var child = node.ChildNodes[0];
|
||||
switch (child.Name)
|
||||
{
|
||||
case TYPE_SHELL:
|
||||
@ -99,7 +100,6 @@ namespace XenAdmin.Plugins
|
||||
ShellCmd = new XenServerPowershellCmd(child, paramsFromXML(child));
|
||||
break;
|
||||
}
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -230,7 +230,7 @@ namespace XenAdmin.SettingsPanels
|
||||
Host host = (Host)_XenObject;
|
||||
Host_metrics metrics = host.Connection.Resolve(host.metrics);
|
||||
if (metrics != null)
|
||||
nudMemoryUsage.Maximum = metrics.memory_total / (1024 * 1024);
|
||||
nudMemoryUsage.Maximum = (decimal) metrics.memory_total / (1024 * 1024);
|
||||
}
|
||||
|
||||
Repopulate();
|
||||
|
@ -231,17 +231,17 @@ namespace XenAdmin.TabPages
|
||||
{
|
||||
vm.PropertyChanged -= VmPropertyChanged;
|
||||
vm.PropertyChanged += VmPropertyChanged;
|
||||
if (pvsProxy != null)
|
||||
{
|
||||
pvsProxy.PropertyChanged -= PvsProxyPropertyChanged;
|
||||
pvsProxy.PropertyChanged += PvsProxyPropertyChanged;
|
||||
PVS_site pvsSite = pvsProxy == null ? null : Connection.Resolve(pvsProxy.site);
|
||||
if (pvsSite != null)
|
||||
{
|
||||
pvsSite.PropertyChanged -= PvsSitePropertyChanged;
|
||||
pvsSite.PropertyChanged += PvsSitePropertyChanged;
|
||||
}
|
||||
}
|
||||
|
||||
if (pvsProxy == null)
|
||||
return;
|
||||
pvsProxy.PropertyChanged -= PvsProxyPropertyChanged;
|
||||
pvsProxy.PropertyChanged += PvsProxyPropertyChanged;
|
||||
|
||||
var pvsSite = Connection.Resolve(pvsProxy.site);
|
||||
if (pvsSite == null)
|
||||
return;
|
||||
pvsSite.PropertyChanged -= PvsSitePropertyChanged;
|
||||
pvsSite.PropertyChanged += PvsSitePropertyChanged;
|
||||
}
|
||||
|
||||
private void UnregisterVmEventHandlers()
|
||||
|
@ -1,161 +0,0 @@
|
||||
/* 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.Windows.Forms;
|
||||
|
||||
namespace DotNetVnc
|
||||
{
|
||||
public class KeySet : IEquatable<KeySet>
|
||||
{
|
||||
List<Keys> keys;
|
||||
|
||||
public IList<Keys> Keys
|
||||
{
|
||||
get
|
||||
{
|
||||
return keys.AsReadOnly();
|
||||
}
|
||||
}
|
||||
|
||||
public KeySet()
|
||||
{
|
||||
this.keys = new List<Keys>();
|
||||
}
|
||||
|
||||
public KeySet(List<Keys> keys)
|
||||
{
|
||||
this.keys = new List<Keys>();
|
||||
|
||||
foreach (Keys key in keys)
|
||||
{
|
||||
if (!this.keys.Contains(key))
|
||||
{
|
||||
this.keys.Add(key);
|
||||
}
|
||||
}
|
||||
|
||||
this.keys.Sort();
|
||||
}
|
||||
|
||||
public KeySet(params Keys[] keys)
|
||||
{
|
||||
this.keys = new List<Keys>();
|
||||
|
||||
foreach (Keys key in keys)
|
||||
{
|
||||
if (!this.keys.Contains(key))
|
||||
{
|
||||
this.keys.Add(key);
|
||||
}
|
||||
}
|
||||
|
||||
this.keys.Sort();
|
||||
}
|
||||
|
||||
public KeySet Add(Keys _key)
|
||||
{
|
||||
List<Keys> newKeys = new List<Keys>();
|
||||
|
||||
foreach(Keys key in this.keys)
|
||||
{
|
||||
newKeys.Add(key);
|
||||
}
|
||||
|
||||
if (!newKeys.Contains(_key))
|
||||
newKeys.Add(_key);
|
||||
|
||||
return new KeySet(newKeys);
|
||||
}
|
||||
|
||||
public KeySet Remove(Keys _key)
|
||||
{
|
||||
List<Keys> newKeys = new List<Keys>();
|
||||
|
||||
foreach (Keys key in this.keys)
|
||||
{
|
||||
if (key != _key)
|
||||
{
|
||||
newKeys.Add(key);
|
||||
}
|
||||
}
|
||||
|
||||
return new KeySet(newKeys);
|
||||
}
|
||||
|
||||
public bool Equals(KeySet keySet)
|
||||
{
|
||||
foreach (Keys key in keySet.Keys)
|
||||
{
|
||||
if (!keys.Contains(key))
|
||||
{
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
foreach (Keys key in this.keys)
|
||||
{
|
||||
if (!keySet.Keys.Contains(key))
|
||||
{
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
public override int GetHashCode()
|
||||
{
|
||||
if (this.keys.Count > 0)
|
||||
{
|
||||
return (int)this.keys[0];
|
||||
}
|
||||
else
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
|
||||
public override String ToString()
|
||||
{
|
||||
String result = "";
|
||||
|
||||
foreach (Keys key in this.keys)
|
||||
{
|
||||
result += key;
|
||||
result += " ";
|
||||
}
|
||||
|
||||
return result;
|
||||
}
|
||||
}
|
||||
}
|
@ -38,6 +38,7 @@ using XenAdmin.Controls.Common;
|
||||
using XenAdmin.Core;
|
||||
using XenAdmin.Dialogs;
|
||||
using XenCenterLib;
|
||||
using XenModel;
|
||||
using Registry = XenAdmin.Core.Registry;
|
||||
|
||||
|
||||
@ -206,9 +207,9 @@ namespace XenAdmin.Wizards.BugToolWizardFiles
|
||||
if (String.IsNullOrEmpty(name))
|
||||
return false;
|
||||
|
||||
if (!PathValidator.IsFileNameValid(name))
|
||||
if (!PathValidator.IsFileNameValid(name, out string invalidNameMsg))
|
||||
{
|
||||
error = Messages.BUGTOOL_PAGE_DESTINATION_INVALID_NAME;
|
||||
error = $"{Messages.BUGTOOL_PAGE_DESTINATION_INVALID_NAME} {invalidNameMsg}";
|
||||
return false;
|
||||
}
|
||||
|
||||
@ -217,9 +218,9 @@ namespace XenAdmin.Wizards.BugToolWizardFiles
|
||||
|
||||
string path = String.Format("{0}\\{1}", folder, name);
|
||||
|
||||
if (!PathValidator.IsPathValid(path))
|
||||
if (!PathValidator.IsPathValid(path, out string invalidPathMsg))
|
||||
{
|
||||
error = Messages.BUGTOOL_PAGE_DESTINATION_INVALID_FOLDER;
|
||||
error = $"{Messages.BUGTOOL_PAGE_DESTINATION_INVALID_FOLDER} {invalidPathMsg}";
|
||||
return false;
|
||||
}
|
||||
|
||||
|
@ -32,6 +32,7 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.ComponentModel;
|
||||
using System.Linq;
|
||||
using System.Windows.Forms;
|
||||
using XenAdmin.Controls;
|
||||
using XenAdmin.Core;
|
||||
@ -121,11 +122,11 @@ namespace XenAdmin.Wizards.BugToolWizardFiles
|
||||
node.State = CheckState.Checked;
|
||||
}
|
||||
|
||||
var checkedItems = HostListTreeView.CheckedItems();
|
||||
//focus on first checked item so the user can find it in a long list
|
||||
foreach (var node in HostListTreeView.CheckedItems())
|
||||
if (checkedItems.Count > 0)
|
||||
{
|
||||
HostListTreeView.SelectedItems.Add(node);
|
||||
break;
|
||||
HostListTreeView.SelectedItems.Add(checkedItems.First());
|
||||
}
|
||||
|
||||
HostListTreeView.EndUpdate();
|
||||
|
@ -599,8 +599,8 @@ namespace XenAdmin.Wizards.DRWizards
|
||||
|
||||
private class PreCheckItemRow : PreCheckGridRow
|
||||
{
|
||||
private Problem _problem = null;
|
||||
private Check _check = null;
|
||||
private readonly Problem _problem;
|
||||
private readonly Check _check;
|
||||
public PreCheckItemRow(Problem problem)
|
||||
{
|
||||
_problem = problem;
|
||||
|
@ -179,8 +179,8 @@ namespace XenAdmin.Wizards.DRWizards
|
||||
var vdis = sr.Connection.ResolveAll(sr.VDIs);
|
||||
bool poolMetadataDetected = vdis.Any(vdi => vdi.type == vdi_type.metadata);
|
||||
|
||||
SrRow row;
|
||||
if (!FindRowByUuid(sr.uuid, out row))
|
||||
var row = dataGridViewSRs.Rows.Cast<SrRow>().FirstOrDefault(r => r.SrUuid == sr.uuid);
|
||||
if (row != null)
|
||||
{
|
||||
row = new SrRow(sr, poolMetadataDetected, SelectedSRsUuids.Contains(sr.uuid));
|
||||
dataGridViewSRs.Rows.Add(row);
|
||||
@ -192,8 +192,8 @@ namespace XenAdmin.Wizards.DRWizards
|
||||
{
|
||||
foreach (var srInfo in scannedDevice.SRList)
|
||||
{
|
||||
SrRow row;
|
||||
if (!FindRowByUuid(srInfo.UUID, out row))
|
||||
var row = dataGridViewSRs.Rows.Cast<SrRow>().FirstOrDefault(r => r.SrUuid == srInfo.UUID);
|
||||
if (row != null)
|
||||
{
|
||||
row = new SrRow(srInfo, scannedDevice.Type, srInfo.PoolMetadataDetected,
|
||||
SelectedSRsUuids.Contains(srInfo.UUID));
|
||||
@ -356,8 +356,9 @@ namespace XenAdmin.Wizards.DRWizards
|
||||
|
||||
foreach (SR.SRInfo srInfo in metadataSrs)
|
||||
{
|
||||
SrRow row;
|
||||
if (!FindRowByUuid(srInfo.UUID, out row))
|
||||
var row = dataGridViewSRs.Rows.Cast<SrRow>().FirstOrDefault(r => r.SrUuid == srInfo.UUID);
|
||||
|
||||
if (row != null)
|
||||
{
|
||||
row = new SrRow(srInfo, type, srInfo.PoolMetadataDetected, srInfo.PoolMetadataDetected);
|
||||
dataGridViewSRs.Rows.Add(row);
|
||||
@ -618,17 +619,6 @@ namespace XenAdmin.Wizards.DRWizards
|
||||
OnPageUpdated();
|
||||
}
|
||||
|
||||
private bool FindRowByUuid(string uuid, out SrRow row)
|
||||
{
|
||||
row = null;
|
||||
foreach (var srRow in dataGridViewSRs.Rows.Cast<SrRow>().Where(srRow => srRow.SrUuid == uuid))
|
||||
{
|
||||
row = srRow;
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
private void buttonSelectAll_Click(object sender, EventArgs e)
|
||||
{
|
||||
SelectAllRows(true);
|
||||
|
@ -36,6 +36,7 @@ using XenAdmin.Controls;
|
||||
using XenAdmin.Controls.Common;
|
||||
using XenAdmin.Wizards.ExportWizard.ApplianceChecks;
|
||||
using XenCenterLib;
|
||||
using XenModel;
|
||||
|
||||
namespace XenAdmin.Wizards.ExportWizard
|
||||
{
|
||||
@ -166,9 +167,9 @@ namespace XenAdmin.Wizards.ExportWizard
|
||||
if (String.IsNullOrEmpty(ApplianceFileName))
|
||||
return false;
|
||||
|
||||
if (!PathValidator.IsFileNameValid(ApplianceFileName))
|
||||
if (!PathValidator.IsFileNameValid(ApplianceFileName, out string invalidNameMsg))
|
||||
{
|
||||
error = Messages.EXPORT_APPLIANCE_PAGE_ERROR_INALID_APP;
|
||||
error = string.Join(" ", new []{ Messages.EXPORT_APPLIANCE_PAGE_ERROR_INALID_APP , invalidNameMsg});
|
||||
return false;
|
||||
}
|
||||
|
||||
@ -177,9 +178,9 @@ namespace XenAdmin.Wizards.ExportWizard
|
||||
|
||||
string path = String.Format("{0}\\{1}", ApplianceDirectory, ApplianceFileName);
|
||||
|
||||
if (!PathValidator.IsPathValid(path))
|
||||
if (!PathValidator.IsPathValid(path, out string invalidPathMsg))
|
||||
{
|
||||
error = Messages.EXPORT_APPLIANCE_PAGE_ERROR_INVALID_DIR;
|
||||
error = string.Join(" ", new[] { Messages.EXPORT_APPLIANCE_PAGE_ERROR_INVALID_DIR, invalidPathMsg });
|
||||
return false;
|
||||
}
|
||||
|
||||
|
@ -35,18 +35,18 @@ using System.IO;
|
||||
using System.Security.Cryptography;
|
||||
using System.Security.Cryptography.X509Certificates;
|
||||
using System.Windows.Forms;
|
||||
using XenCenterLib;
|
||||
using XenOvf;
|
||||
using XenAdmin.Controls;
|
||||
using XenModel;
|
||||
|
||||
namespace XenAdmin.Wizards.ExportWizard
|
||||
{
|
||||
/// <summary>
|
||||
/// Class representing the page of the ExportAppliance wizard where the user specifies
|
||||
/// whether to create a manifest, sign the appliance or encrypt files and whether to
|
||||
/// create an OVA package or compress the OVF files
|
||||
/// </summary>
|
||||
internal partial class ExportOptionsPage : XenTabPage
|
||||
/// <summary>
|
||||
/// Class representing the page of the ExportAppliance wizard where the user specifies
|
||||
/// whether to create a manifest, sign the appliance or encrypt files and whether to
|
||||
/// create an OVA package or compress the OVF files
|
||||
/// </summary>
|
||||
internal partial class ExportOptionsPage : XenTabPage
|
||||
{
|
||||
private const int MIN_PASSWORD_STRENGTH = 1;
|
||||
private int m_passwordStrength;
|
||||
@ -285,9 +285,9 @@ namespace XenAdmin.Wizards.ExportWizard
|
||||
{
|
||||
error = string.Empty;
|
||||
|
||||
if (!PathValidator.IsPathValid(m_textBoxCertificate.Text))//includes null check
|
||||
if (!PathValidator.IsPathValid(m_textBoxCertificate.Text, out string invalidPathMsg))//includes null check
|
||||
{
|
||||
error = Messages.EXPORT_SECURITY_PAGE_ERROR_INVALID_CERT;
|
||||
error = string.Join(" ", new[] { Messages.EXPORT_SECURITY_PAGE_ERROR_INVALID_CERT, invalidPathMsg });
|
||||
return false;
|
||||
}
|
||||
|
||||
|
@ -413,16 +413,17 @@ namespace XenAdmin.Wizards.GenericPages
|
||||
{
|
||||
if (hasPoolSharedStorage)
|
||||
{
|
||||
foreach (var pool in target.Item.Connection.Cache.Pools)
|
||||
//there exists one pool per connection
|
||||
var pools = target.Item.Connection.Cache.Pools;
|
||||
if (pools.Length > 0)
|
||||
{
|
||||
var pool = pools.First();
|
||||
var item = new NoTargetServerPoolItem(pool);
|
||||
cb.Items.Add(item);
|
||||
|
||||
if ((m_selectedObject != null && m_selectedObject.opaque_ref == pool.opaque_ref) ||
|
||||
(target.Item.opaque_ref == pool.opaque_ref))
|
||||
cb.Value = item;
|
||||
|
||||
break; //there exists one pool per connection
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -32,7 +32,7 @@
|
||||
using System;
|
||||
using XenAdmin.Controls;
|
||||
using XenCenterLib;
|
||||
|
||||
using XenModel;
|
||||
|
||||
namespace XenAdmin.Wizards.ImportWizard
|
||||
{
|
||||
@ -55,17 +55,17 @@ namespace XenAdmin.Wizards.ImportWizard
|
||||
/// <summary>
|
||||
/// Gets the page's title (headline)
|
||||
/// </summary>
|
||||
public override string PageTitle { get { return Messages.IMAGE_DEFINITION_PAGE_TITLE; } }
|
||||
public override string PageTitle => Messages.IMAGE_DEFINITION_PAGE_TITLE;
|
||||
|
||||
/// <summary>
|
||||
/// Gets the page's label in the (left hand side) wizard progress panel
|
||||
/// </summary>
|
||||
public override string Text { get { return Messages.IMAGE_DEFINITION_PAGE_TEXT; } }
|
||||
public override string Text => Messages.IMAGE_DEFINITION_PAGE_TEXT;
|
||||
|
||||
/// <summary>
|
||||
/// Gets the value by which the help files section for this page is identified
|
||||
/// </summary>
|
||||
public override string HelpID { get { return "VMConfig"; } }
|
||||
public override string HelpID => "VMConfig";
|
||||
|
||||
protected override bool ImplementsIsDirty()
|
||||
{
|
||||
@ -97,16 +97,16 @@ namespace XenAdmin.Wizards.ImportWizard
|
||||
|
||||
#region Accessors
|
||||
|
||||
public bool IsWim { private get; set; }
|
||||
public bool IsWim { internal get; set; }
|
||||
|
||||
public string VmName { get { return m_textBoxVMName.Text; } }
|
||||
public string VmName => m_textBoxVMName.Text;
|
||||
|
||||
public ulong CpuCount { get { return (ulong)m_upDownCpuCount.Value; } }
|
||||
public ulong CpuCount => (ulong)m_upDownCpuCount.Value;
|
||||
|
||||
public ulong Memory { get { return (ulong)m_upDownMemory.Value; } }
|
||||
public ulong Memory => (ulong)m_upDownMemory.Value;
|
||||
|
||||
public ulong AdditionalSpace => m_groupBoxAddSpace.Visible && m_groupBoxAddSpace.Enabled ? (ulong)m_upDownAddSpace.Value * GB : 0;
|
||||
|
||||
public ulong AdditionalSpace { get { return m_groupBoxAddSpace.Enabled ? (ulong)m_upDownAddSpace.Value * GB : 0; } }
|
||||
|
||||
#endregion
|
||||
|
||||
#region Private Methods
|
||||
@ -118,9 +118,10 @@ namespace XenAdmin.Wizards.ImportWizard
|
||||
if (String.IsNullOrEmpty(name))
|
||||
return false;
|
||||
|
||||
if (!PathValidator.IsFileNameValid(name))
|
||||
|
||||
if (!PathValidator.IsFileNameValid(name, out string invalidNameMsg))
|
||||
{
|
||||
error = Messages.IMPORT_SELECT_APPLIANCE_PAGE_ERROR_INVALID_PATH;
|
||||
error = invalidNameMsg;
|
||||
return false;
|
||||
}
|
||||
return true;
|
||||
|
@ -50,7 +50,7 @@ using XenCenterLib.Archive;
|
||||
using XenOvf;
|
||||
using XenOvf.Definitions.VMC;
|
||||
using XenOvf.Utilities;
|
||||
|
||||
using XenModel;
|
||||
|
||||
namespace XenAdmin.Wizards.ImportWizard
|
||||
{
|
||||
@ -370,21 +370,20 @@ namespace XenAdmin.Wizards.ImportWizard
|
||||
/// </summary>
|
||||
private bool CheckPathValid(out string error)
|
||||
{
|
||||
error = string.Empty;
|
||||
|
||||
error = string.Empty;
|
||||
if (String.IsNullOrEmpty(FilePath))
|
||||
return false;
|
||||
|
||||
if (IsUri())
|
||||
return CheckDownloadFromUri(out error);
|
||||
|
||||
if (!PathValidator.IsPathValid(FilePath))
|
||||
if (!PathValidator.IsPathValid(FilePath, out string invalidNameMsg))
|
||||
{
|
||||
error = Messages.IMPORT_SELECT_APPLIANCE_PAGE_ERROR_INVALID_PATH;
|
||||
return false;
|
||||
error = invalidNameMsg;
|
||||
return false;
|
||||
}
|
||||
|
||||
return true;
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
|
File diff suppressed because it is too large
Load Diff
@ -49,9 +49,6 @@ namespace XenAdmin.Wizards.ImportWizard
|
||||
#region Private fields
|
||||
private static readonly log4net.ILog log = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
|
||||
|
||||
private IXenConnection m_selectedConnection;
|
||||
private Host m_selectedAffinity;
|
||||
private VM m_vm;
|
||||
private bool m_buttonNextEnabled;
|
||||
#endregion
|
||||
|
||||
@ -108,6 +105,15 @@ namespace XenAdmin.Wizards.ImportWizard
|
||||
|
||||
#region Accessors
|
||||
|
||||
/// <summary>
|
||||
/// Should be set before the Affinity is set.
|
||||
/// </summary>
|
||||
internal IXenConnection SelectedConnection { get; set; }
|
||||
|
||||
internal Host SelectedAffinity { get; set; }
|
||||
|
||||
internal VM VM { get; set; }
|
||||
|
||||
public List<VIF> VIFs
|
||||
{
|
||||
get
|
||||
@ -136,24 +142,6 @@ namespace XenAdmin.Wizards.ImportWizard
|
||||
|
||||
#endregion
|
||||
|
||||
public void SetAffinity(Host host)
|
||||
{
|
||||
m_selectedAffinity = host;
|
||||
}
|
||||
|
||||
public void SetVm(VM vm)
|
||||
{
|
||||
m_vm = vm;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Should be called before the Affinity is set.
|
||||
/// </summary>
|
||||
public void SetConnection(IXenConnection con)
|
||||
{
|
||||
m_selectedConnection = con;
|
||||
}
|
||||
|
||||
#region Private methods
|
||||
|
||||
private void UpdateControlsEnabledState(bool enabled)
|
||||
@ -167,7 +155,7 @@ namespace XenAdmin.Wizards.ImportWizard
|
||||
{
|
||||
NetworkNetworkColumn.Items.Clear();
|
||||
|
||||
var networks = m_selectedConnection.Cache.Networks.Where(ShowNetwork);
|
||||
var networks = SelectedConnection.Cache.Networks.Where(ShowNetwork);
|
||||
|
||||
foreach (XenAPI.Network network in networks)
|
||||
{
|
||||
@ -186,18 +174,18 @@ namespace XenAdmin.Wizards.ImportWizard
|
||||
m_networkGridView.SuspendLayout();
|
||||
m_networkGridView.Rows.Clear();
|
||||
|
||||
if (m_vm.is_a_template && m_vm.VIFs.Count < 1)
|
||||
if (VM.is_a_template && VM.VIFs.Count < 1)
|
||||
{
|
||||
// We need to automatically generate VIFs for Networks marked AutoPlug=true
|
||||
|
||||
var networks = m_selectedConnection.Cache.Networks;
|
||||
var networks = SelectedConnection.Cache.Networks;
|
||||
foreach (XenAPI.Network network in networks)
|
||||
{
|
||||
if (m_networkGridView.Rows.Count < m_vm.MaxVIFsAllowed() && ShowNetwork(network) && network.GetAutoPlug())
|
||||
if (m_networkGridView.Rows.Count < VM.MaxVIFsAllowed() && ShowNetwork(network) && network.GetAutoPlug())
|
||||
{
|
||||
AddVIFRow(new VIF
|
||||
{
|
||||
Connection = m_selectedConnection,
|
||||
Connection = SelectedConnection,
|
||||
device = m_networkGridView.Rows.Count.ToString(),
|
||||
network = new XenRef<XenAPI.Network>(network.opaque_ref),
|
||||
MAC = Messages.MAC_AUTOGENERATE
|
||||
@ -205,16 +193,16 @@ namespace XenAdmin.Wizards.ImportWizard
|
||||
}
|
||||
}
|
||||
}
|
||||
else if (m_vm.is_a_template)
|
||||
else if (VM.is_a_template)
|
||||
{
|
||||
// We need to create off the _vmTemplate
|
||||
|
||||
var vifs = m_selectedConnection.ResolveAll(m_vm.VIFs);
|
||||
var vifs = SelectedConnection.ResolveAll(VM.VIFs);
|
||||
foreach (VIF vif in vifs)
|
||||
{
|
||||
AddVIFRow(new VIF
|
||||
{
|
||||
Connection = m_selectedConnection,
|
||||
Connection = SelectedConnection,
|
||||
device = vif.device,
|
||||
network = vif.network,
|
||||
MAC = Messages.MAC_AUTOGENERATE
|
||||
@ -224,7 +212,7 @@ namespace XenAdmin.Wizards.ImportWizard
|
||||
else
|
||||
{
|
||||
//We need to recreate off vm
|
||||
var vifs = m_selectedConnection.ResolveAll(m_vm.VIFs);
|
||||
var vifs = SelectedConnection.ResolveAll(VM.VIFs);
|
||||
foreach (VIF vif in vifs)
|
||||
AddVIFRow(vif);
|
||||
}
|
||||
@ -240,7 +228,7 @@ namespace XenAdmin.Wizards.ImportWizard
|
||||
|
||||
private XenAPI.Network GetDefaultNetwork()
|
||||
{
|
||||
foreach (XenAPI.Network network in m_selectedConnection.Cache.Networks)
|
||||
foreach (XenAPI.Network network in SelectedConnection.Cache.Networks)
|
||||
if (ShowNetwork(network))
|
||||
return network;
|
||||
|
||||
@ -261,13 +249,13 @@ namespace XenAdmin.Wizards.ImportWizard
|
||||
if (network.IsMember())
|
||||
return false;
|
||||
|
||||
if (m_selectedAffinity != null && !m_selectedAffinity.CanSeeNetwork(network))
|
||||
if (SelectedAffinity != null && !SelectedAffinity.CanSeeNetwork(network))
|
||||
return false;
|
||||
|
||||
if (m_selectedAffinity == null && !network.AllHostsCanSeeNetwork())
|
||||
if (SelectedAffinity == null && !network.AllHostsCanSeeNetwork())
|
||||
return false;
|
||||
|
||||
if (network.IsSriov() && !m_vm.HasSriovRecommendation())
|
||||
if (network.IsSriov() && !VM.HasSriovRecommendation())
|
||||
return false;
|
||||
|
||||
return true;
|
||||
@ -276,7 +264,7 @@ namespace XenAdmin.Wizards.ImportWizard
|
||||
private void AddVIFRow(VIF vif)
|
||||
{
|
||||
var row = new VifRow(vif);
|
||||
XenAPI.Network network = m_selectedConnection.Resolve(vif.network);
|
||||
XenAPI.Network network = SelectedConnection.Resolve(vif.network);
|
||||
bool isGuestInstallerNetwork = network != null && network.IsGuestInstallerNetwork();
|
||||
|
||||
ToStringWrapper<XenAPI.Network> comboBoxEntry = FindComboBoxEntryForNetwork(network);
|
||||
@ -344,7 +332,7 @@ namespace XenAdmin.Wizards.ImportWizard
|
||||
|
||||
private void m_buttonAddNetwork_Click(object sender, EventArgs e)
|
||||
{
|
||||
if (m_networkGridView.Rows.Count >= m_vm.MaxVIFsAllowed())
|
||||
if (m_networkGridView.Rows.Count >= VM.MaxVIFsAllowed())
|
||||
{
|
||||
using (var dlg = new ErrorDialog(FriendlyErrorNames.VIFS_MAX_ALLOWED)
|
||||
{WindowTitle = FriendlyErrorNames.VIFS_MAX_ALLOWED_TITLE})
|
||||
@ -354,7 +342,7 @@ namespace XenAdmin.Wizards.ImportWizard
|
||||
return;
|
||||
}
|
||||
|
||||
VIF vif = new VIF {Connection = m_selectedConnection};
|
||||
VIF vif = new VIF {Connection = SelectedConnection};
|
||||
|
||||
int i = 0;
|
||||
while (true)
|
||||
|
@ -45,8 +45,6 @@ namespace XenAdmin.Wizards.ImportWizard
|
||||
public partial class StoragePickerPage : XenTabPage
|
||||
{
|
||||
#region Private fields
|
||||
private Host m_targetHost;
|
||||
private IXenConnection m_targetConnection;
|
||||
private volatile Task m_importTask;
|
||||
private bool m_alreadyFoundVM;
|
||||
private ActionProgressDialog m_actionDialog;
|
||||
@ -98,8 +96,8 @@ namespace XenAdmin.Wizards.ImportWizard
|
||||
SetButtonNextEnabled(false);
|
||||
m_buttonPreviousEnabled = false;
|
||||
OnPageUpdated();
|
||||
ImportXvaAction = new ImportVmAction(m_targetHost == null ? m_targetConnection : m_targetHost.Connection,
|
||||
m_targetHost, FilePath, SR,
|
||||
ImportXvaAction = new ImportVmAction(TargetHost == null ? TargetConnection : TargetHost.Connection,
|
||||
TargetHost, FilePath, SR,
|
||||
VMOperationCommand.WarningDialogHAInvalidConfig, VMOperationCommand.StartDiagnosisForm);
|
||||
ImportXvaAction.Completed += m_importXvaAction_Completed;
|
||||
|
||||
@ -119,7 +117,7 @@ namespace XenAdmin.Wizards.ImportWizard
|
||||
public override void PopulatePage()
|
||||
{
|
||||
SetButtonNextEnabled(false);
|
||||
m_srPicker.PopulateAsync(SrPicker.SRPickerType.VM, m_targetConnection, m_targetHost, null, null);
|
||||
m_srPicker.PopulateAsync(SrPicker.SRPickerType.VM, TargetConnection, TargetHost, null, null);
|
||||
IsDirty = true;
|
||||
}
|
||||
|
||||
@ -137,6 +135,10 @@ namespace XenAdmin.Wizards.ImportWizard
|
||||
|
||||
#region Accessors
|
||||
|
||||
internal IXenConnection TargetConnection { get; set; }
|
||||
|
||||
internal Host TargetHost { get; set; }
|
||||
|
||||
public ImportVmAction ImportXvaAction { get; private set; }
|
||||
|
||||
public string FilePath { private get; set; }
|
||||
@ -147,19 +149,6 @@ namespace XenAdmin.Wizards.ImportWizard
|
||||
|
||||
#endregion
|
||||
|
||||
/// <summary>
|
||||
/// Should be called before the Affinity is set.
|
||||
/// </summary>
|
||||
public void SetConnection(IXenConnection con)
|
||||
{
|
||||
m_targetConnection = con;
|
||||
}
|
||||
|
||||
public void SetTargetHost(Host host)
|
||||
{
|
||||
m_targetHost = host;
|
||||
}
|
||||
|
||||
#region Private methods
|
||||
|
||||
private void SetButtonNextEnabled(bool enabled)
|
||||
@ -196,12 +185,12 @@ namespace XenAdmin.Wizards.ImportWizard
|
||||
while (ImportXvaAction.RelatedTask == null)
|
||||
Thread.Sleep(100);
|
||||
|
||||
while ((m_importTask = m_targetConnection.Resolve(ImportXvaAction.RelatedTask)) == null)
|
||||
while ((m_importTask = TargetConnection.Resolve(ImportXvaAction.RelatedTask)) == null)
|
||||
Thread.Sleep(100);
|
||||
|
||||
// We register a XenObjectsUpdated event handler where we check that the import task has the object creation phase marked as "complete";
|
||||
// Once the object creation is complete, we look for the vm; When we found the vm we unregister this event handler;
|
||||
m_targetConnection.XenObjectsUpdated += targetConnection_XenObjectsUpdated;
|
||||
TargetConnection.XenObjectsUpdated += targetConnection_XenObjectsUpdated;
|
||||
|
||||
Program.Invoke(this, CheckTask);
|
||||
}
|
||||
@ -233,11 +222,11 @@ namespace XenAdmin.Wizards.ImportWizard
|
||||
{
|
||||
// Should never get here (as we unregister XenObjectsUpdated event handler after we find the vm) but just in case,
|
||||
// unregister XenObjectsUpdated event handler
|
||||
m_targetConnection.XenObjectsUpdated -= targetConnection_XenObjectsUpdated;
|
||||
TargetConnection.XenObjectsUpdated -= targetConnection_XenObjectsUpdated;
|
||||
return;
|
||||
}
|
||||
|
||||
foreach (VM vm in m_targetConnection.Cache.VMs)
|
||||
foreach (VM vm in TargetConnection.Cache.VMs)
|
||||
{
|
||||
if (!vm.other_config.ContainsKey(ImportVmAction.IMPORT_TASK))
|
||||
continue;
|
||||
@ -250,7 +239,7 @@ namespace XenAdmin.Wizards.ImportWizard
|
||||
ImportedVm = vm;
|
||||
|
||||
// We found the VM, unregister XenObjectsUpdated event handler
|
||||
m_targetConnection.XenObjectsUpdated -= targetConnection_XenObjectsUpdated;
|
||||
TargetConnection.XenObjectsUpdated -= targetConnection_XenObjectsUpdated;
|
||||
|
||||
// And close the dialog, flick to next page.
|
||||
m_actionDialog.Close();
|
||||
@ -279,7 +268,7 @@ namespace XenAdmin.Wizards.ImportWizard
|
||||
if (!(ImportXvaAction.Succeeded) || ImportXvaAction.Cancelled)
|
||||
{
|
||||
// task failed or has been cancelled, unregister XenObjectsUpdated event handler
|
||||
m_targetConnection.XenObjectsUpdated -= targetConnection_XenObjectsUpdated;
|
||||
TargetConnection.XenObjectsUpdated -= targetConnection_XenObjectsUpdated;
|
||||
|
||||
// Give the user a chance to correct any errors
|
||||
m_actionDialog = null;
|
||||
|
@ -614,8 +614,8 @@ namespace XenAdmin.Wizards.PatchingWizard
|
||||
|
||||
private class PreCheckHostRow : PreCheckGridRow
|
||||
{
|
||||
private Problem _problem = null;
|
||||
private Check _check = null;
|
||||
private readonly Problem _problem = null;
|
||||
private readonly Check _check = null;
|
||||
public PreCheckHostRow(Problem problem)
|
||||
: base(new DataGridViewTextBoxCell())
|
||||
{
|
||||
|
@ -49,7 +49,7 @@ namespace XenAdmin.Wizards.PatchingWizard
|
||||
}
|
||||
|
||||
#region Accessors
|
||||
public readonly List<HostUpdateMapping> PatchMappings = new List<HostUpdateMapping>();
|
||||
public List<HostUpdateMapping> PatchMappings { get; } = new List<HostUpdateMapping>();
|
||||
|
||||
public UpdateType SelectedUpdateType { private get; set; }
|
||||
public string SelectedPatchFilePath { get; set; }
|
||||
|
@ -39,7 +39,8 @@ namespace XenAdmin.Wizards.PatchingWizard.PlanActions
|
||||
public abstract class RebootPlanAction : HostPlanAction
|
||||
{
|
||||
private bool _cancelled;
|
||||
private bool lostConnection;
|
||||
private bool _lostConnection;
|
||||
private readonly object _lockObj = new object();
|
||||
|
||||
protected RebootPlanAction(Host host)
|
||||
: base(host)
|
||||
@ -50,9 +51,9 @@ namespace XenAdmin.Wizards.PatchingWizard.PlanActions
|
||||
{
|
||||
_cancelled = true;
|
||||
|
||||
lock (this)
|
||||
lock (_lockObj)
|
||||
{
|
||||
Monitor.PulseAll(this);
|
||||
Monitor.PulseAll(_lockObj);
|
||||
}
|
||||
}
|
||||
|
||||
@ -98,7 +99,7 @@ namespace XenAdmin.Wizards.PatchingWizard.PlanActions
|
||||
{
|
||||
bool isCoordinator = GetResolvedHost().IsCoordinator();
|
||||
|
||||
lostConnection = false;
|
||||
_lostConnection = false;
|
||||
_cancelled = false;
|
||||
double metric = metricDelegate(session, HostXenRef.opaque_ref);
|
||||
|
||||
@ -134,7 +135,7 @@ namespace XenAdmin.Wizards.PatchingWizard.PlanActions
|
||||
Connection.SuppressErrors = true;
|
||||
|
||||
//
|
||||
// Wait for a dissconnection
|
||||
// Wait for a disconnection
|
||||
//
|
||||
|
||||
WaitForDisconnection();
|
||||
@ -165,11 +166,11 @@ namespace XenAdmin.Wizards.PatchingWizard.PlanActions
|
||||
{
|
||||
log.DebugFormat("{0}._WaitForReboot waiting for connection to go away...", GetType().Name);
|
||||
|
||||
lock (this)
|
||||
lock (_lockObj)
|
||||
{
|
||||
while (!lostConnection && !_cancelled)
|
||||
while (!_lostConnection && !_cancelled)
|
||||
{
|
||||
Monitor.Wait(this);
|
||||
Monitor.Wait(_lockObj);
|
||||
}
|
||||
}
|
||||
|
||||
@ -274,10 +275,10 @@ namespace XenAdmin.Wizards.PatchingWizard.PlanActions
|
||||
|
||||
private void connection_ConnectionLost(IXenConnection conn)
|
||||
{
|
||||
lock (this)
|
||||
lock (_lockObj)
|
||||
{
|
||||
lostConnection = true;
|
||||
Monitor.PulseAll(this);
|
||||
_lostConnection = true;
|
||||
Monitor.PulseAll(_lockObj);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -42,8 +42,8 @@ namespace XenAdmin.Wizards.PatchingWizard
|
||||
public List<HostPlan> HostPlans { get; private set; }
|
||||
public List<PlanAction> FinalActions { get; private set; }
|
||||
public List<PlanAction> CleanupActions { get; private set; }
|
||||
public readonly List<PlanAction> DoneActions = new List<PlanAction>();
|
||||
public readonly List<PlanAction> InProgressActions = new List<PlanAction>();
|
||||
public List<PlanAction> DoneActions { get; } = new List<PlanAction>();
|
||||
public List<PlanAction> InProgressActions { get; } = new List<PlanAction>();
|
||||
public Pool Pool { get; private set; }
|
||||
public string Name { get; private set; }
|
||||
|
||||
|
@ -240,7 +240,7 @@ namespace XenAdmin.Wizards.RollingUpgradeWizard
|
||||
|
||||
//Checking PV guests - for hosts that have any PV guests and warn the user before the upgrade.
|
||||
var pvChecks = (from Host server in SelectedCoordinators
|
||||
let check = new PVGuestsCheck(server, true, ManualUpgrade, InstallMethodConfig)
|
||||
let check = new PVGuestsCheck(server, ManualUpgrade, InstallMethodConfig)
|
||||
where check.CanRun()
|
||||
select check as Check).ToList();
|
||||
|
||||
|
@ -744,7 +744,6 @@
|
||||
<Compile Include="VNC\KeyMap.Designer.cs">
|
||||
<DependentUpon>KeyMap.cs</DependentUpon>
|
||||
</Compile>
|
||||
<Compile Include="VNC\KeySet.cs" />
|
||||
<Compile Include="VNC\MyStream.cs" />
|
||||
<Compile Include="VNC\VNCException.cs" />
|
||||
<Compile Include="VNC\VNCStream.cs" />
|
||||
|
@ -1,100 +0,0 @@
|
||||
/* 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.IO;
|
||||
|
||||
namespace XenCenterLib
|
||||
{
|
||||
public class PathValidator
|
||||
{
|
||||
private static readonly char[] m_invalidFileCharList = Path.GetInvalidFileNameChars();
|
||||
private static readonly string[] m_deviceNames = {
|
||||
"CON", "PRN", "AUX", "NUL",
|
||||
"COM1", "COM2", "COM3", "COM4", "COM5", "COM6", "COM7", "COM8", "COM9",
|
||||
"LPT1", "LPT2", "LPT3", "LPT4", "LPT5", "LPT6", "LPT7", "LPT8", "LPT9"
|
||||
};
|
||||
|
||||
public static bool IsFileNameValid(string filename)
|
||||
{
|
||||
if (filename.IndexOfAny(m_invalidFileCharList) > -1)
|
||||
return false;
|
||||
|
||||
foreach (var name in m_deviceNames)
|
||||
{
|
||||
if (name == filename.ToUpper())
|
||||
return false;
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
public static bool IsPathValid(string path)
|
||||
{
|
||||
if (string.IsNullOrEmpty(path))
|
||||
return false;
|
||||
|
||||
try
|
||||
{
|
||||
if (Path.IsPathRooted(path))
|
||||
{
|
||||
path = path[0] == '\\' && path.Length == 1
|
||||
? path.Substring(1)
|
||||
: path.Substring(2);
|
||||
}
|
||||
}
|
||||
catch(ArgumentException)
|
||||
{
|
||||
//path contains a character from Path.GetInvalidPathChars()
|
||||
return false;
|
||||
}
|
||||
|
||||
string[] parts = path.Split(new[] {'\\'});
|
||||
|
||||
if (parts.Length > 0)
|
||||
{
|
||||
foreach (var part in parts)
|
||||
{
|
||||
if (part.IndexOfAny(m_invalidFileCharList) > -1)
|
||||
return false;
|
||||
|
||||
foreach (var name in m_deviceNames)
|
||||
{
|
||||
if (name == part.ToUpper())
|
||||
return false;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
}
|
||||
}
|
@ -79,7 +79,6 @@
|
||||
<Compile Include="LockFreeQueue.cs" />
|
||||
<Compile Include="NamedPipes.cs" />
|
||||
<Compile Include="PartialIP.cs" />
|
||||
<Compile Include="PathValidator.cs" />
|
||||
<Compile Include="Processes.cs" />
|
||||
<Compile Include="Properties\AssemblyInfo.cs" />
|
||||
<Compile Include="Set.cs" />
|
||||
|
@ -378,10 +378,9 @@ namespace XenAdmin.Actions
|
||||
doc.LoadXml(task.result);
|
||||
var nodes = doc.GetElementsByTagName("value");
|
||||
|
||||
foreach (XmlNode node in nodes)
|
||||
if (nodes.Count > 0)
|
||||
{
|
||||
Result = node.InnerText;
|
||||
break;
|
||||
Result = nodes[0].InnerText;
|
||||
}
|
||||
}
|
||||
catch //CA-352946
|
||||
|
@ -84,7 +84,6 @@ namespace XenAdmin.Actions.DR
|
||||
|
||||
internal static void DestroyVM(Session session, VM vm)
|
||||
{
|
||||
Exception caught = null;
|
||||
log.DebugFormat("Destroying VM '{0}'", vm.Name());
|
||||
|
||||
if (vm.snapshots.Count > 0)
|
||||
@ -143,9 +142,6 @@ namespace XenAdmin.Actions.DR
|
||||
}
|
||||
|
||||
log.DebugFormat("VM '{0}' destroyed", vm.Name());
|
||||
|
||||
if (caught != null)
|
||||
throw caught;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -31,6 +31,7 @@
|
||||
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using XenAdmin.Core;
|
||||
using XenAdmin.Network;
|
||||
using XenAPI;
|
||||
@ -91,25 +92,21 @@ namespace XenAdmin.Actions.DR
|
||||
MetadataSession = Session.get_record(Session, MetadataSessionRef);
|
||||
|
||||
#region FIND POOL
|
||||
Dictionary<XenRef<XenAPI.Pool>, XenAPI.Pool> pools = XenAPI.Pool.get_all_records(MetadataSession);
|
||||
foreach (var pool in pools.Values)
|
||||
var pools = Pool.get_all_records(MetadataSession);
|
||||
var poolValues = pools.Values;
|
||||
if (poolValues.Count > 0)
|
||||
{
|
||||
_poolMetadata.Pool = pool;
|
||||
string poolName = String.IsNullOrEmpty(pool.name_label) && pool.master != null
|
||||
? XenAPI.Host.get_name_label(MetadataSession, pool.master.opaque_ref)
|
||||
: pool.name_label;
|
||||
var pool = poolValues.First();
|
||||
var poolName = string.IsNullOrEmpty(pool.name_label) && pool.master != null
|
||||
? Host.get_name_label(MetadataSession, pool.master.opaque_ref)
|
||||
: pool.name_label;
|
||||
_poolMetadata.Pool.name_label = poolName;
|
||||
log.DebugFormat("Found metadata of pool '{0}' (UUID={1})", _poolMetadata.Pool.Name(),
|
||||
_poolMetadata.Pool.uuid);
|
||||
break;
|
||||
_poolMetadata.Pool.uuid);
|
||||
}
|
||||
|
||||
#endregion
|
||||
|
||||
/*if (_poolMetadata.Pool.uuid == Pool.uuid) // metadata of current pool
|
||||
{
|
||||
return;
|
||||
}*/
|
||||
|
||||
_poolMetadata.VmAppliances = VM_appliance.get_all_records(MetadataSession);
|
||||
foreach (var vmAppRef in _poolMetadata.VmAppliances.Keys)
|
||||
{
|
||||
|
@ -64,9 +64,11 @@ namespace XenAdmin.Actions
|
||||
public ApplyLicenseEditionAction(IEnumerable<IXenObject> xos, Host.Edition edition, string licenseServerAddress, string licenseServerPort, Action<List<LicenseFailure>, string> doOnLicensingFailure = null)
|
||||
: base(null, Messages.LICENSE_UPDATING_LICENSES)
|
||||
{
|
||||
LicenseFailures = new List<LicenseFailure>();
|
||||
Util.ThrowIfEnumerableParameterNullOrEmpty(xos, "xenobjects");
|
||||
if (xos == null || !xos.Any())
|
||||
throw new ArgumentException(@"Parameter cannot be null or empty", nameof(xos));
|
||||
|
||||
LicenseFailures = new List<LicenseFailure>();
|
||||
|
||||
_edition = edition;
|
||||
this.xos = xos;
|
||||
_licenseServerAddress = licenseServerAddress;
|
||||
|
@ -42,12 +42,10 @@ namespace XenAdmin.Actions
|
||||
private readonly bool _resumeVMs;
|
||||
|
||||
public EnableHostAction(Host host, bool resumeVMs,Func<Pool, Host, long, long, bool> acceptNTolChangesOnEnable)
|
||||
: base(host.Connection, Messages.HOST_ENABLE, Messages.WAITING, null, acceptNTolChangesOnEnable)
|
||||
: base(host?.Connection, Messages.HOST_ENABLE, Messages.WAITING, null, acceptNTolChangesOnEnable)
|
||||
{
|
||||
if (host == null)
|
||||
throw new ArgumentNullException("host");
|
||||
Host = host ?? throw new ArgumentNullException("host");
|
||||
_resumeVMs = resumeVMs;
|
||||
this.Host = host;
|
||||
AddCommonAPIMethodsToRoleCheck();
|
||||
ApiMethodsToRoleCheck.Add("pool.ha_compute_hypothetical_max_host_failures_to_tolerate");
|
||||
ApiMethodsToRoleCheck.Add("pool.set_ha_host_failures_to_tolerate");
|
||||
|
@ -60,8 +60,6 @@ namespace XenAdmin.Actions
|
||||
public EvacuateHostAction(Host host, Host newCoordinator, Dictionary<XenRef<VM>, String[]> hostRecommendations, Func<HostAbstractAction, Pool, long, long, bool> acceptNTolChanges, Func<Pool, Host, long, long, bool> acceptNTolChangesOnEnable)
|
||||
: base(host.Connection, null, Messages.HOST_EVACUATE, acceptNTolChanges, acceptNTolChangesOnEnable)
|
||||
{
|
||||
if (host == null)
|
||||
throw new ArgumentNullException("host");
|
||||
Host = host;
|
||||
_newCoordinator = newCoordinator;
|
||||
_hostRecommendations = hostRecommendations;
|
||||
|
@ -50,9 +50,7 @@ namespace XenAdmin.Actions
|
||||
public RebootHostAction(Host host, Func<HostAbstractAction, Pool, long, long, bool> acceptNTolChanges)
|
||||
: base(host.Connection, Messages.HOST_REBOOTING, Messages.WAITING, acceptNTolChanges, null)
|
||||
{
|
||||
if (host == null)
|
||||
throw new ArgumentNullException("host");
|
||||
this.Host = host;
|
||||
Host = host;
|
||||
AddCommonAPIMethodsToRoleCheck();
|
||||
ApiMethodsToRoleCheck.Add("pool.ha_compute_hypothetical_max_host_failures_to_tolerate");
|
||||
ApiMethodsToRoleCheck.Add("pool.set_ha_host_failures_to_tolerate");
|
||||
|
@ -44,8 +44,6 @@ namespace XenAdmin.Actions
|
||||
public ShutdownHostAction(Host host, Func<HostAbstractAction, Pool, long, long, bool> acceptNTolChanges)
|
||||
: base(host.Connection, Messages.HOST_SHUTDOWN, Messages.WAITING, acceptNTolChanges, null)
|
||||
{
|
||||
if (host == null)
|
||||
throw new ArgumentNullException("host");
|
||||
Host = host;
|
||||
ApiMethodsToRoleCheck.Add("pool.ha_compute_hypothetical_max_host_failures_to_tolerate");
|
||||
ApiMethodsToRoleCheck.Add("pool.set_ha_host_failures_to_tolerate");
|
||||
|
@ -49,12 +49,10 @@ namespace XenAdmin.Actions
|
||||
public EnableHAAction(Pool pool, Dictionary<VM, VMStartupOptions> startupOptions, List<SR> heartbeatSRs, long failuresToTolerate)
|
||||
: base(pool.Connection, string.Format(Messages.ENABLING_HA_ON, Helpers.GetName(pool).Ellipsise(50)), Messages.ENABLING_HA, false)
|
||||
{
|
||||
if (pool == null)
|
||||
throw new ArgumentNullException("pool");
|
||||
if (heartbeatSRs.Count == 0)
|
||||
throw new ArgumentException("You must specify at least 1 heartbeat SR");
|
||||
|
||||
this.Pool = pool;
|
||||
Pool = pool;
|
||||
this.startupOptions = startupOptions;
|
||||
this.heartbeatSRs = heartbeatSRs.ToArray();
|
||||
this.failuresToTolerate = failuresToTolerate;
|
||||
@ -69,7 +67,7 @@ namespace XenAdmin.Actions
|
||||
{
|
||||
if (startupOptions != null)
|
||||
{
|
||||
double increment = 10 / Math.Max(startupOptions.Count, 1);
|
||||
double increment = 10.0 / Math.Max(startupOptions.Count, 1);
|
||||
int i = 0;
|
||||
// First set any VM restart priorities supplied
|
||||
foreach (VM vm in startupOptions.Keys)
|
||||
|
@ -57,8 +57,6 @@ namespace XenAdmin.Actions
|
||||
public CheckDiskSpaceForPatchUploadAction(Host host, string fileName, long size, bool suppressHistory)
|
||||
: base(host.Connection, Messages.ACTION_CHECK_DISK_SPACE_TITLE, "", suppressHistory)
|
||||
{
|
||||
if (host == null)
|
||||
throw new ArgumentNullException("host");
|
||||
Host = host;
|
||||
this.fileName = fileName;
|
||||
fileSize = size;
|
||||
|
@ -45,8 +45,6 @@ namespace XenAdmin.Actions
|
||||
public CleanupDiskSpaceAction(Host host, Pool_patch excludedPatch, bool suppressHistory)
|
||||
: base(host.Connection, Messages.ACTION_CLEANUP_DISK_SPACE_TITLE, "", suppressHistory)
|
||||
{
|
||||
if (host == null)
|
||||
throw new ArgumentNullException("host");
|
||||
Host = host;
|
||||
this.excludedPatch = excludedPatch;
|
||||
}
|
||||
|
@ -81,8 +81,6 @@ namespace XenAdmin.Actions
|
||||
public GetDiskSpaceRequirementsAction(Host host, string updateName, long size, bool suppressHistory)
|
||||
: base(host.Connection, Messages.ACTION_GET_DISK_SPACE_REQUIREMENTS_TITLE, suppressHistory)
|
||||
{
|
||||
if (host == null)
|
||||
throw new ArgumentNullException("host");
|
||||
Host = host;
|
||||
this.updateName = updateName;
|
||||
updateSize = size;
|
||||
|
@ -43,8 +43,6 @@ namespace XenAdmin.Actions
|
||||
: base(pool.Connection, string.Format(Messages.UPDATES_WIZARD_REMOVING_UPDATE, patch.Name(), pool.Name()), suppressHistory)
|
||||
{
|
||||
this.patch = patch;
|
||||
if (patch == null)
|
||||
throw new ArgumentNullException("patch");
|
||||
|
||||
#region RBAC Dependencies
|
||||
ApiMethodsToRoleCheck.Add("pool_patch.pool_clean");
|
||||
|
@ -55,10 +55,8 @@ namespace XenAdmin.Actions
|
||||
public SrRepairAction(IXenConnection connection, SR sr,bool isSharedAction)
|
||||
: base(connection, isSharedAction ? string.Format(Messages.ACTION_SR_SHARING, sr.NameWithoutHost()) : string.Format(Messages.ACTION_SR_REPAIRING, sr.NameWithoutHost()))
|
||||
{
|
||||
if (sr == null)
|
||||
throw new ArgumentNullException("sr");
|
||||
this.isSharedAction = isSharedAction;
|
||||
this.SR = sr;
|
||||
SR = sr;
|
||||
|
||||
#region RBAC Dependencies
|
||||
ApiMethodsToRoleCheck.Add("pbd.plug");
|
||||
|
@ -44,16 +44,14 @@ namespace XenAdmin.Actions
|
||||
private readonly VDI vdi;
|
||||
|
||||
public MigrateVirtualDiskAction(IXenConnection connection, VDI vdi, SR sr)
|
||||
: base(connection, string.Format(Messages.ACTION_MOVING_VDI_TO_SR, Helpers.GetName(vdi), Helpers.GetName(sr)))
|
||||
: base(connection, string.Format(Messages.ACTION_MOVING_VDI_TO_SR, Helpers.GetName(vdi), Helpers.GetName(connection.Resolve(vdi.SR)), Helpers.GetName(sr)))
|
||||
{
|
||||
Description = Messages.ACTION_PREPARING;
|
||||
this.vdi = vdi;
|
||||
SR = sr;
|
||||
}
|
||||
|
||||
protected override void Run()
|
||||
{
|
||||
Description = string.Format(Messages.ACTION_MOVING_VDI, Helpers.GetName(vdi));
|
||||
RelatedTask = VDI.async_pool_migrate(Session, vdi.opaque_ref, SR.opaque_ref, new Dictionary<string, string>());
|
||||
PollToCompletion();
|
||||
Description = Messages.MOVED;
|
||||
|
@ -44,8 +44,8 @@ namespace XenAdmin.Actions
|
||||
|
||||
private VDI vdi;
|
||||
|
||||
public MoveVirtualDiskAction(IXenConnection connection, XenAPI.VDI vdi, SR sr)
|
||||
: base(connection, string.Format(Messages.ACTION_MOVING_VDI_TO_SR, Helpers.GetName(vdi), Helpers.GetName(sr)))
|
||||
public MoveVirtualDiskAction(IXenConnection connection, VDI vdi, SR sr)
|
||||
: base(connection, string.Format(Messages.ACTION_MOVING_VDI_TO_SR, Helpers.GetName(vdi), Helpers.GetName(connection.Resolve(vdi.SR)), Helpers.GetName(sr)))
|
||||
{
|
||||
this.vdi = vdi;
|
||||
SR = sr;
|
||||
@ -61,7 +61,6 @@ namespace XenAdmin.Actions
|
||||
|
||||
protected override void Run()
|
||||
{
|
||||
Description = string.Format(Messages.ACTION_MOVING_VDI, Helpers.GetName(vdi));
|
||||
PercentComplete = 10;
|
||||
log.DebugFormat("Moving VDI '{0}'", Helpers.GetName(vdi));
|
||||
RelatedTask = VDI.async_copy(Session, vdi.opaque_ref, SR.opaque_ref);
|
||||
|
@ -72,9 +72,10 @@ namespace XenAdmin.Actions
|
||||
|
||||
public ImportVmAction(IXenConnection connection, Host affinity, string filename, SR sr,
|
||||
Action<VM, bool> warningDelegate, Action<VMStartAbstractAction, Failure> failureDiagnosisDelegate)
|
||||
: base(connection, string.Format(Messages.IMPORTVM_TITLE, filename, Helpers.GetName(connection)), Messages.IMPORTVM_PREP)
|
||||
{
|
||||
Pool = Helpers.GetPoolOfOne(connection);
|
||||
: base(connection, "")
|
||||
{
|
||||
Description = Messages.IMPORTVM_PREP;
|
||||
Pool = Helpers.GetPoolOfOne(connection);
|
||||
m_affinity = affinity;
|
||||
Host = affinity ?? connection.Resolve(Pool.master);
|
||||
SR = sr;
|
||||
@ -94,7 +95,9 @@ namespace XenAdmin.Actions
|
||||
ApiMethodsToRoleCheck.AddRange(Role.CommonSessionApiList);
|
||||
|
||||
#endregion
|
||||
}
|
||||
|
||||
Title = string.Format(Messages.IMPORTVM_TITLE, filename, Host.NameWithLocation());
|
||||
}
|
||||
|
||||
protected override void Run()
|
||||
{
|
||||
|
@ -37,18 +37,17 @@ namespace XenAdmin.Actions.VMActions
|
||||
{
|
||||
public class VMCloneAction : AsyncAction
|
||||
{
|
||||
private readonly string _cloneName;
|
||||
private readonly string _cloneDescription;
|
||||
|
||||
protected string _cloneName;
|
||||
protected string _cloneDescription;
|
||||
public VMCloneAction(VM vm, string name, string description)
|
||||
: base(vm.Connection, string.Format(Messages.CREATEVM_CLONE, name, vm.Name()))
|
||||
: base(vm.Connection, string.Format(Messages.CREATEVM_CLONE, name, vm.NameWithLocation()))
|
||||
{
|
||||
this.Description = Messages.ACTION_PREPARING;
|
||||
this.VM = vm;
|
||||
this.Host = vm.Home();
|
||||
this.Pool = Core.Helpers.GetPool(vm.Connection);
|
||||
VM = vm;
|
||||
Host = vm.Home();
|
||||
Pool = Helpers.GetPool(vm.Connection);
|
||||
if (vm.is_a_template)
|
||||
this.Template = vm;
|
||||
Template = vm;
|
||||
_cloneName = name;
|
||||
_cloneDescription = description;
|
||||
|
||||
@ -68,17 +67,14 @@ namespace XenAdmin.Actions.VMActions
|
||||
|
||||
protected override void Run()
|
||||
{
|
||||
this.Description = Messages.ACTION_TEMPLATE_CLONING;
|
||||
RelatedTask = XenAPI.VM.async_clone(Session, VM.opaque_ref, _cloneName);
|
||||
RelatedTask = VM.async_clone(Session, VM.opaque_ref, _cloneName);
|
||||
PollToCompletion();
|
||||
{
|
||||
VM created = Connection.WaitForCache(new XenRef<VM>(Result));
|
||||
XenAPI.VM.set_name_description(Session, created.opaque_ref, _cloneDescription);
|
||||
Result = created.opaque_ref;
|
||||
}
|
||||
this.Description = Messages.ACTION_TEMPLATE_CLONED;
|
||||
|
||||
VM created = Connection.WaitForCache(new XenRef<VM>(Result));
|
||||
VM.set_name_description(Session, created.opaque_ref, _cloneDescription);
|
||||
Result = created.opaque_ref;
|
||||
|
||||
Description = Messages.ACTION_TEMPLATE_CLONED;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
@ -41,16 +41,15 @@ namespace XenAdmin.Actions.VMActions
|
||||
private string _namedescription;
|
||||
|
||||
public VMCopyAction(VM vm, Host host, SR sr, string nameLabel, string description)
|
||||
: base(vm.Connection, string.Format(Messages.ACTION_VM_COPYING_TITLE, vm.Name(), nameLabel, sr.NameWithoutHost()))
|
||||
: base(vm.Connection, string.Format(Messages.ACTION_VM_COPYING_TITLE, vm.NameWithLocation(), nameLabel, sr.NameWithLocation()))
|
||||
{
|
||||
this.Description = Messages.ACTION_PREPARING;
|
||||
this.VM = vm;
|
||||
this.Host = host;
|
||||
this.Pool = Core.Helpers.GetPool(vm.Connection);
|
||||
this.SR = sr;
|
||||
VM = vm;
|
||||
Host = host;
|
||||
Pool = Core.Helpers.GetPool(vm.Connection);
|
||||
SR = sr;
|
||||
_nameLabel = nameLabel;
|
||||
if (vm.is_a_template)
|
||||
this.Template = vm;
|
||||
Template = vm;
|
||||
_namedescription = description;
|
||||
|
||||
ApiMethodsToRoleCheck.AddRange(StaticRBACDependencies);
|
||||
@ -69,25 +68,21 @@ namespace XenAdmin.Actions.VMActions
|
||||
|
||||
protected override void Run()
|
||||
{
|
||||
|
||||
this.Description = Messages.ACTION_VM_COPYING;
|
||||
RelatedTask = XenAPI.VM.async_copy(Session, VM.opaque_ref, _nameLabel, this.SR.opaque_ref);
|
||||
RelatedTask = VM.async_copy(Session, VM.opaque_ref, _nameLabel, SR.opaque_ref);
|
||||
try
|
||||
{
|
||||
PollToCompletion();
|
||||
}
|
||||
catch (CancelledException)
|
||||
{
|
||||
this.Description = string.Format(Messages.COPY_TO_SHARED_CANCELLED, VM.Name());
|
||||
Description = string.Format(Messages.COPY_TO_SHARED_CANCELLED, VM.NameWithLocation());
|
||||
throw;
|
||||
}
|
||||
{
|
||||
VM created = Connection.WaitForCache(new XenRef<VM>(Result));
|
||||
XenAPI.VM.set_name_description(Session, created.opaque_ref, _namedescription);
|
||||
VM.set_name_description(Session, created.opaque_ref, _namedescription);
|
||||
}
|
||||
this.Description = Messages.ACTION_VM_COPIED;
|
||||
|
||||
|
||||
Description = Messages.ACTION_VM_COPIED;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -55,7 +55,6 @@ namespace XenAdmin.Actions.VMActions
|
||||
: base(vm.Connection, GetTitle(vm, destinationHost, copy))
|
||||
{
|
||||
Session = vm.Connection.Session;
|
||||
Description = Messages.ACTION_PREPARING;
|
||||
VM = vm;
|
||||
Host = destinationHost;
|
||||
Pool = Helpers.GetPool(vm.Connection);
|
||||
@ -80,18 +79,20 @@ namespace XenAdmin.Actions.VMActions
|
||||
public static string GetTitle(VM vm, Host toHost, bool copy)
|
||||
{
|
||||
if (copy)
|
||||
return string.Format(Messages.ACTION_VM_CROSS_POOL_COPY_TITLE, vm.Name(), toHost.Name());
|
||||
return string.Format(Messages.ACTION_VM_CROSS_POOL_COPY_TITLE,
|
||||
vm.NameWithLocation(),
|
||||
Helpers.GetPool(vm.Connection)?.Name() ?? vm.Connection.Name,
|
||||
toHost.NameWithLocation());
|
||||
|
||||
Host residentOn = vm.Connection.Resolve(vm.resident_on);
|
||||
|
||||
|
||||
return residentOn == null
|
||||
? string.Format(Messages.ACTION_VM_MIGRATING_NON_RESIDENT, vm.Name(), toHost.Name())
|
||||
: string.Format(Messages.ACTION_VM_MIGRATING_RESIDENT, vm.Name(), Helpers.GetName(residentOn), toHost.Name());
|
||||
? string.Format(Messages.ACTION_VM_MIGRATING_NON_RESIDENT, vm.NameWithLocation(), toHost.NameWithLocation())
|
||||
: string.Format(Messages.ACTION_VM_MIGRATING_RESIDENT, vm.Name(), residentOn.NameWithLocation(), toHost.NameWithLocation());
|
||||
}
|
||||
|
||||
protected override void Run()
|
||||
{
|
||||
Description = copy ? Messages.ACTION_VM_COPYING: Messages.ACTION_VM_MIGRATING;
|
||||
try
|
||||
{
|
||||
PercentComplete = 0;
|
||||
@ -114,7 +115,7 @@ namespace XenAdmin.Actions.VMActions
|
||||
Description = string.Format(copy
|
||||
? Messages.ACTION_VM_CROSS_POOL_COPY_CANCELLED
|
||||
: Messages.ACTION_VM_MIGRATE_CANCELLED,
|
||||
VM.Name());
|
||||
VM.NameWithLocation());
|
||||
throw;
|
||||
}
|
||||
catch (Failure ex)
|
||||
|
@ -40,27 +40,22 @@ namespace XenAdmin.Actions.VMActions
|
||||
{
|
||||
|
||||
public VMMigrateAction(VM vm, Host destinationHost)
|
||||
: base(vm.Connection, GetTitle(vm, destinationHost))
|
||||
: base(vm.Connection, "")
|
||||
{
|
||||
this.Description = Messages.ACTION_PREPARING;
|
||||
this.VM = vm;
|
||||
this.Host = destinationHost;
|
||||
this.Pool = Core.Helpers.GetPool(vm.Connection);
|
||||
}
|
||||
VM = vm;
|
||||
Host = destinationHost;
|
||||
Pool = Helpers.GetPool(vm.Connection);
|
||||
|
||||
private static string GetTitle(VM vm, Host toHost)
|
||||
{
|
||||
Host residentOn = vm.Connection.Resolve(vm.resident_on);
|
||||
|
||||
return residentOn == null
|
||||
? string.Format(Messages.ACTION_VM_MIGRATING_NON_RESIDENT, vm.Name(), toHost.Name())
|
||||
: string.Format(Messages.ACTION_VM_MIGRATING_RESIDENT, vm.Name(), Helpers.GetName(residentOn), toHost.Name());
|
||||
var residentOn = vm.Connection.Resolve(vm.resident_on);
|
||||
|
||||
Title = residentOn == null
|
||||
? string.Format(Messages.ACTION_VM_MIGRATING_NON_RESIDENT, vm.NameWithLocation(), Host.NameWithLocation())
|
||||
: string.Format(Messages.ACTION_VM_MIGRATING_RESIDENT, vm.Name(), residentOn.NameWithLocation(), Host.NameWithLocation());
|
||||
}
|
||||
|
||||
protected override void Run()
|
||||
{
|
||||
this.Description = Messages.ACTION_VM_MIGRATING;
|
||||
RelatedTask = XenAPI.VM.async_live_migrate(Session, VM.opaque_ref, Host.opaque_ref);
|
||||
RelatedTask = VM.async_live_migrate(Session, VM.opaque_ref, Host.opaque_ref);
|
||||
try
|
||||
{
|
||||
PollToCompletion();
|
||||
@ -68,17 +63,15 @@ namespace XenAdmin.Actions.VMActions
|
||||
catch (Failure f)
|
||||
{
|
||||
if (f.ErrorDescription.Count >= 5 && f.ErrorDescription[0] == "VM_MIGRATE_FAILED"
|
||||
&& f.ErrorDescription[4].Contains("VDI_MISSING"))
|
||||
&& f.ErrorDescription[4].Contains("VDI_MISSING"))
|
||||
{
|
||||
throw new Exception(Messages.MIGRATE_EJECT_TOOLS_ON_UPGRADE);
|
||||
}
|
||||
else
|
||||
{
|
||||
throw;
|
||||
}
|
||||
|
||||
throw;
|
||||
}
|
||||
|
||||
this.Description = Messages.ACTION_VM_MIGRATED;
|
||||
Description = Messages.ACTION_VM_MIGRATED;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -45,40 +45,44 @@ namespace XenAdmin.Actions.VMActions
|
||||
private Dictionary<string, SR> _storageMapping;
|
||||
|
||||
public VMMoveAction(VM vm, Dictionary<string, SR> storageMapping, Host host)
|
||||
: base(vm.Connection, string.Format(Messages.ACTION_VM_MOVING, vm.Name()))
|
||||
: base(vm.Connection, "")
|
||||
{
|
||||
this.VM = vm;
|
||||
this.Host = host;
|
||||
this.Pool = Helpers.GetPool(vm.Connection);
|
||||
VM = vm;
|
||||
Host = host;
|
||||
Pool = Helpers.GetPool(vm.Connection);
|
||||
if (vm.is_a_template)
|
||||
this.Template = vm;
|
||||
Template = vm;
|
||||
|
||||
_storageMapping = storageMapping;
|
||||
SR = _storageMapping.Values.FirstOrDefault();
|
||||
|
||||
PopulateApiMethodsToRoleCheck();
|
||||
|
||||
var sourceHost = vm.Home();
|
||||
if (sourceHost != null && !sourceHost.Equals(host))
|
||||
Title = string.Format(Messages.ACTION_VM_MOVING_HOST, vm.Name(), sourceHost, host.Name());
|
||||
else if (storageMapping.Count == 1)
|
||||
Title = string.Format(Messages.ACTION_VM_MOVING_SR, vm.Name(), storageMapping.Values.ElementAt(0).Name());
|
||||
else
|
||||
Title = string.Format(Messages.ACTION_VM_MOVING, vm.Name());
|
||||
}
|
||||
|
||||
public VMMoveAction(VM vm, SR sr, Host host, string namelabel)
|
||||
: base(vm.Connection, string.Format(Messages.ACTION_VM_MOVING_TITLE, vm.Name(), namelabel, sr.NameWithoutHost()))
|
||||
public VMMoveAction(VM vm, SR sr, Host host)
|
||||
: this(vm, GetStorageMapping(vm, sr), host)
|
||||
{
|
||||
this.VM = vm;
|
||||
this.Host = host;
|
||||
this.Pool = Helpers.GetPool(vm.Connection);
|
||||
this.SR = sr;
|
||||
if (vm.is_a_template)
|
||||
this.Template = vm;
|
||||
}
|
||||
|
||||
// create a storage map where all VDIs are mapped to the same SR
|
||||
_storageMapping = new Dictionary<string, SR>();
|
||||
private static Dictionary<string, SR> GetStorageMapping(VM vm, SR sr)
|
||||
{
|
||||
var storageMapping = new Dictionary<string, SR>();
|
||||
foreach (var vbdRef in vm.VBDs)
|
||||
{
|
||||
var vbd = vm.Connection.Resolve(vbdRef);
|
||||
if (vbd != null)
|
||||
_storageMapping.Add(vbd.VDI.opaque_ref, sr);
|
||||
storageMapping.Add(vbd.VDI.opaque_ref, sr);
|
||||
}
|
||||
return storageMapping;
|
||||
|
||||
PopulateApiMethodsToRoleCheck();
|
||||
}
|
||||
|
||||
#region RBAC Dependencies
|
||||
@ -96,8 +100,6 @@ namespace XenAdmin.Actions.VMActions
|
||||
|
||||
protected override void Run()
|
||||
{
|
||||
Description = Messages.ACTION_PREPARING;
|
||||
|
||||
// move the progress bar above 0, it's more reassuring to see than a blank bar as we copy the first disk
|
||||
PercentComplete += 10;
|
||||
int halfstep = 90 / (VM.VBDs.Count * 2);
|
||||
@ -126,7 +128,7 @@ namespace XenAdmin.Actions.VMActions
|
||||
continue;
|
||||
|
||||
Description = string.Format(Messages.ACTION_MOVING_VDI_TO_SR,
|
||||
Helpers.GetName(curVdi), Helpers.GetName(sr));
|
||||
Helpers.GetName(curVdi), Helpers.GetName(Connection.Resolve(curVdi.SR)), Helpers.GetName(sr));
|
||||
|
||||
RelatedTask = VDI.async_copy(Session, oldVBD.VDI.opaque_ref, sr.opaque_ref);
|
||||
PollToCompletion(PercentComplete, PercentComplete + halfstep);
|
||||
@ -160,11 +162,13 @@ namespace XenAdmin.Actions.VMActions
|
||||
PercentComplete += halfstep;
|
||||
}
|
||||
|
||||
Description = string.Empty;
|
||||
|
||||
if (SR != null)
|
||||
VM.set_suspend_SR(Session, VM.opaque_ref, SR.opaque_ref);
|
||||
|
||||
if (exceptions.Count > 0)
|
||||
throw new Exception(Messages.ACTION_VM_MOVING_VDI_DESTROY_FAILURE);
|
||||
throw new Exception(string.Format(Messages.ACTION_VM_MOVING_VDI_DESTROY_FAILURE, VM.NameWithLocation()));
|
||||
|
||||
Description = Messages.MOVED;
|
||||
}
|
||||
|
@ -287,24 +287,20 @@ namespace XenAdmin.Alerts
|
||||
public static PerfmonDefinition[] GetPerfmonDefinitions(IXenObject xo)
|
||||
{
|
||||
if (!(xo is VM) && !(xo is Host) && !(xo is SR))
|
||||
return new PerfmonDefinition[0];
|
||||
return Array.Empty<PerfmonDefinition>();
|
||||
|
||||
Dictionary<string, string> other_config = Helpers.GetOtherConfig(xo);
|
||||
var other_config = Helpers.GetOtherConfig(xo);
|
||||
if (other_config == null)
|
||||
return new PerfmonDefinition[0];
|
||||
return Array.Empty<PerfmonDefinition>();
|
||||
|
||||
if (!other_config.ContainsKey(PERFMON_KEY_NAME))
|
||||
return new PerfmonDefinition[0];
|
||||
return Array.Empty<PerfmonDefinition>();
|
||||
|
||||
string perfmonConfigXML = other_config[PERFMON_KEY_NAME];
|
||||
var perfmonConfigXML = other_config[PERFMON_KEY_NAME];
|
||||
if (perfmonConfigXML == null)
|
||||
return new PerfmonDefinition[0];
|
||||
return Array.Empty<PerfmonDefinition>();
|
||||
|
||||
perfmonConfigXML.Trim();
|
||||
if (String.IsNullOrEmpty(perfmonConfigXML))
|
||||
return new PerfmonDefinition[0];
|
||||
|
||||
return GetPerfmonDefinitions(perfmonConfigXML);
|
||||
return string.IsNullOrWhiteSpace(perfmonConfigXML) ? Array.Empty<PerfmonDefinition>() : GetPerfmonDefinitions(perfmonConfigXML);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
|
@ -213,74 +213,53 @@ namespace XenAdmin.Alerts
|
||||
|
||||
public static string GetMailDestination(IXenConnection connection)
|
||||
{
|
||||
Pool pool = Helpers.GetPoolOfOne(connection);
|
||||
var pool = Helpers.GetPoolOfOne(connection);
|
||||
if (pool == null)
|
||||
return null;
|
||||
|
||||
Dictionary<String, String> other_config = Helpers.GetOtherConfig(pool);
|
||||
if (other_config == null)
|
||||
var otherConfig = Helpers.GetOtherConfig(pool);
|
||||
if (otherConfig == null)
|
||||
return null;
|
||||
|
||||
if (!other_config.ContainsKey(MAIL_DESTINATION_KEY_NAME))
|
||||
if (!otherConfig.ContainsKey(MAIL_DESTINATION_KEY_NAME))
|
||||
return null;
|
||||
|
||||
String mailAddress = other_config[MAIL_DESTINATION_KEY_NAME];
|
||||
if (mailAddress == null)
|
||||
return null;
|
||||
|
||||
mailAddress.Trim();
|
||||
if (String.IsNullOrEmpty(mailAddress))
|
||||
return null;
|
||||
|
||||
return mailAddress;
|
||||
var mailAddress = otherConfig[MAIL_DESTINATION_KEY_NAME]?.Trim();
|
||||
return string.IsNullOrEmpty(mailAddress) ? null : mailAddress;
|
||||
}
|
||||
|
||||
public static string GetSmtpMailHub(IXenConnection connection)
|
||||
{
|
||||
Pool pool = Helpers.GetPoolOfOne(connection);
|
||||
var pool = Helpers.GetPoolOfOne(connection);
|
||||
if (pool == null)
|
||||
return null;
|
||||
|
||||
Dictionary<String, String> other_config = Helpers.GetOtherConfig(pool);
|
||||
if (other_config == null)
|
||||
var otherConfig = Helpers.GetOtherConfig(pool);
|
||||
if (otherConfig == null)
|
||||
return null;
|
||||
|
||||
if (!other_config.ContainsKey(SMTP_MAILHUB_KEY_NAME))
|
||||
if (!otherConfig.ContainsKey(SMTP_MAILHUB_KEY_NAME))
|
||||
return null;
|
||||
|
||||
String mailHub = other_config[SMTP_MAILHUB_KEY_NAME];
|
||||
if (mailHub == null)
|
||||
return null;
|
||||
|
||||
mailHub.Trim();
|
||||
if (String.IsNullOrEmpty(mailHub))
|
||||
return null;
|
||||
|
||||
return mailHub;
|
||||
var mailHub = otherConfig[SMTP_MAILHUB_KEY_NAME]?.Trim();
|
||||
return string.IsNullOrEmpty(mailHub) ? null : mailHub;
|
||||
}
|
||||
|
||||
public static string GetMailLanguageCode(IXenConnection connection)
|
||||
{
|
||||
Pool pool = Helpers.GetPoolOfOne(connection);
|
||||
var pool = Helpers.GetPoolOfOne(connection);
|
||||
if (pool == null)
|
||||
return null;
|
||||
|
||||
Dictionary<String, String> other_config = Helpers.GetOtherConfig(pool);
|
||||
if (other_config == null)
|
||||
var otherConfig = Helpers.GetOtherConfig(pool);
|
||||
if (otherConfig == null)
|
||||
return null;
|
||||
|
||||
if (!other_config.ContainsKey(MAIL_LANGUAGE_KEY_NAME))
|
||||
if (!otherConfig.ContainsKey(MAIL_LANGUAGE_KEY_NAME))
|
||||
return null;
|
||||
|
||||
String mailLanguageCode = other_config[MAIL_LANGUAGE_KEY_NAME];
|
||||
if (mailLanguageCode == null)
|
||||
return null;
|
||||
|
||||
mailLanguageCode.Trim();
|
||||
if (String.IsNullOrEmpty(mailLanguageCode))
|
||||
return null;
|
||||
|
||||
return mailLanguageCode;
|
||||
var mailLanguageCode = otherConfig[MAIL_LANGUAGE_KEY_NAME]?.Trim();
|
||||
return string.IsNullOrEmpty(mailLanguageCode) ? null : mailLanguageCode;
|
||||
}
|
||||
|
||||
public static String MailLanguageNameFromCode(String code)
|
||||
|
@ -82,6 +82,8 @@ namespace XenAdmin.Core
|
||||
|
||||
public static readonly string ProductVersion82 = Get("PRODUCT_VERSION_8_2");
|
||||
|
||||
public static readonly string ProductVersion821 = Get("PRODUCT_VERSION_8_2_1");
|
||||
|
||||
public static readonly string ProductVersionPost82 = Get("PRODUCT_VERSION_POST_8_2");
|
||||
|
||||
public static readonly string ProductVersionText = Get("PRODUCT_VERSION_TEXT");
|
||||
|
@ -68,36 +68,25 @@ namespace XenAdmin.CustomFields
|
||||
|
||||
private static List<CustomFieldDefinition> GetCustomFieldsFromGuiConfig(IXenConnection connection)
|
||||
{
|
||||
Pool pool = Helpers.GetPoolOfOne(connection);
|
||||
var pool = Helpers.GetPoolOfOne(connection);
|
||||
if (pool == null)
|
||||
{
|
||||
return new List<CustomFieldDefinition>();
|
||||
}
|
||||
|
||||
Dictionary<String, String> other_config = Helpers.GetGuiConfig(pool);
|
||||
if (other_config == null)
|
||||
var otherConfig = Helpers.GetGuiConfig(pool);
|
||||
if (otherConfig == null)
|
||||
{
|
||||
return new List<CustomFieldDefinition>();
|
||||
}
|
||||
|
||||
if (!other_config.ContainsKey(CustomFieldsManager.CUSTOM_FIELD_BASE_KEY))
|
||||
if (!otherConfig.ContainsKey(CustomFieldsManager.CUSTOM_FIELD_BASE_KEY))
|
||||
{
|
||||
return new List<CustomFieldDefinition>();
|
||||
}
|
||||
|
||||
String customFields = other_config[CustomFieldsManager.CUSTOM_FIELD_BASE_KEY];
|
||||
if (customFields == null)
|
||||
{
|
||||
return new List<CustomFieldDefinition>();
|
||||
}
|
||||
|
||||
customFields.Trim();
|
||||
if (String.IsNullOrEmpty(customFields))
|
||||
{
|
||||
return new List<CustomFieldDefinition>();
|
||||
}
|
||||
|
||||
return GetCustomFieldDefinitions(customFields);
|
||||
var customFields = otherConfig[CustomFieldsManager.CUSTOM_FIELD_BASE_KEY]?.Trim();
|
||||
return string.IsNullOrEmpty(customFields) ? new List<CustomFieldDefinition>() : GetCustomFieldDefinitions(customFields);
|
||||
}
|
||||
|
||||
public List<CustomFieldDefinition> GetCustomFields()
|
||||
|
@ -44,6 +44,11 @@ namespace XenAdmin.Mappings
|
||||
}
|
||||
|
||||
public string VmNameLabel { get; set; }
|
||||
public ulong Capacity { get; set; }
|
||||
public ulong CpuCount { get; set; }
|
||||
public ulong Memory { get; set; }
|
||||
public string BootParams { get; set; }
|
||||
public string PlatformSettings { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// OpaqueRef of the target pool or host
|
||||
@ -66,5 +71,26 @@ namespace XenAdmin.Mappings
|
||||
/// Keyed on the id in the ovf file
|
||||
/// </summary>
|
||||
public Dictionary<string, XenAPI.Network> Networks { get; set; }
|
||||
}
|
||||
|
||||
public override bool Equals(object obj)
|
||||
{
|
||||
return obj is VmMapping other &&
|
||||
VmNameLabel == other.VmNameLabel &&
|
||||
Capacity == other.Capacity &&
|
||||
CpuCount == other.CpuCount &&
|
||||
Memory == other.Memory &&
|
||||
BootParams == other.BootParams &&
|
||||
PlatformSettings == other.PlatformSettings &&
|
||||
XenRef == other.XenRef &&
|
||||
TargetName == other.TargetName &&
|
||||
Storage == other.Storage &&
|
||||
StorageToAttach == other.StorageToAttach &&
|
||||
Networks == other.Networks;
|
||||
}
|
||||
|
||||
public override int GetHashCode()
|
||||
{
|
||||
return base.GetHashCode();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
82
XenModel/Messages.Designer.cs
generated
82
XenModel/Messages.Designer.cs
generated
@ -1593,16 +1593,7 @@ namespace XenAdmin {
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Looks up a localized string similar to Moving virtual disk '{0}'....
|
||||
/// </summary>
|
||||
public static string ACTION_MOVING_VDI {
|
||||
get {
|
||||
return ResourceManager.GetString("ACTION_MOVING_VDI", resourceCulture);
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Looks up a localized string similar to Moving Virtual Disk '{0}' to SR '{1}'.
|
||||
/// Looks up a localized string similar to Moving Virtual Disk '{0}' from SR '{1}' to SR '{2}'.
|
||||
/// </summary>
|
||||
public static string ACTION_MOVING_VDI_TO_SR {
|
||||
get {
|
||||
@ -2663,15 +2654,6 @@ namespace XenAdmin {
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Looks up a localized string similar to Duplicating.
|
||||
/// </summary>
|
||||
public static string ACTION_TEMPLATE_CLONING {
|
||||
get {
|
||||
return ResourceManager.GetString("ACTION_TEMPLATE_CLONING", resourceCulture);
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Looks up a localized string similar to Restart toolstack on '{0}'.
|
||||
/// </summary>
|
||||
@ -3114,7 +3096,7 @@ namespace XenAdmin {
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Looks up a localized string similar to Copying VM '{0}' to '{1}'.
|
||||
/// Looks up a localized string similar to Copying VM '{0}' from '{1}' to '{2}'.
|
||||
/// </summary>
|
||||
public static string ACTION_VM_CROSS_POOL_COPY_TITLE {
|
||||
get {
|
||||
@ -3231,11 +3213,20 @@ namespace XenAdmin {
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Looks up a localized string similar to Moving VM '{0}' to '{1}' on SR '{2}'.
|
||||
/// Looks up a localized string similar to Moving VM '{0}' from server '{1}' to server '{2}'.
|
||||
/// </summary>
|
||||
public static string ACTION_VM_MOVING_TITLE {
|
||||
public static string ACTION_VM_MOVING_HOST {
|
||||
get {
|
||||
return ResourceManager.GetString("ACTION_VM_MOVING_TITLE", resourceCulture);
|
||||
return ResourceManager.GetString("ACTION_VM_MOVING_HOST", resourceCulture);
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Looks up a localized string similar to Moving VM '{0}' to SR '{1}'.
|
||||
/// </summary>
|
||||
public static string ACTION_VM_MOVING_SR {
|
||||
get {
|
||||
return ResourceManager.GetString("ACTION_VM_MOVING_SR", resourceCulture);
|
||||
}
|
||||
}
|
||||
|
||||
@ -15294,6 +15285,15 @@ namespace XenAdmin {
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Looks up a localized string similar to You cannot enable certificate verification while a rolling pool upgrade is in progress..
|
||||
/// </summary>
|
||||
public static string ENABLE_TLS_VERIFICATION_RPU {
|
||||
get {
|
||||
return ResourceManager.GetString("ENABLE_TLS_VERIFICATION_RPU", resourceCulture);
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Looks up a localized string similar to Res&ume.
|
||||
/// </summary>
|
||||
@ -16978,6 +16978,24 @@ namespace XenAdmin {
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Looks up a localized string similar to A file name cannot be a device name..
|
||||
/// </summary>
|
||||
public static string FILE_NAME_IS_DEVICE_NAME_ERROR_MESSAGE {
|
||||
get {
|
||||
return ResourceManager.GetString("FILE_NAME_IS_DEVICE_NAME_ERROR_MESSAGE", resourceCulture);
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Looks up a localized string similar to Path section {0} matches a device name..
|
||||
/// </summary>
|
||||
public static string FILE_PATH_DEVICE_NAME_ERROR_MESSAGE {
|
||||
get {
|
||||
return ResourceManager.GetString("FILE_PATH_DEVICE_NAME_ERROR_MESSAGE", resourceCulture);
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Looks up a localized string similar to Acrobat (PDF) file.
|
||||
/// </summary>
|
||||
@ -20224,6 +20242,15 @@ namespace XenAdmin {
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Looks up a localized string similar to The following characters are invalid: {0}.
|
||||
/// </summary>
|
||||
public static string ILLEGAL_CHARACTER_ERROR_MESSAGE {
|
||||
get {
|
||||
return ResourceManager.GetString("ILLEGAL_CHARACTER_ERROR_MESSAGE", resourceCulture);
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Looks up a localized string similar to It is not possible to connect to the iLO service. Please review your configuration..
|
||||
/// </summary>
|
||||
@ -30178,6 +30205,15 @@ namespace XenAdmin {
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Looks up a localized string similar to Path cannot be null or empty..
|
||||
/// </summary>
|
||||
public static string PATH_CAN_NOT_BE_NULL_ERROR_MESSAGE {
|
||||
get {
|
||||
return ResourceManager.GetString("PATH_CAN_NOT_BE_NULL_ERROR_MESSAGE", resourceCulture);
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Looks up a localized string similar to Path does not exist..
|
||||
/// </summary>
|
||||
|
@ -629,11 +629,8 @@ This could be because the data source is not generating any data. Ensure the pre
|
||||
<data name="ACTION_MIGRATING_X_VDIS_STARTED" xml:space="preserve">
|
||||
<value>Started migrating virtual disks</value>
|
||||
</data>
|
||||
<data name="ACTION_MOVING_VDI" xml:space="preserve">
|
||||
<value>Moving virtual disk '{0}'...</value>
|
||||
</data>
|
||||
<data name="ACTION_MOVING_VDI_TO_SR" xml:space="preserve">
|
||||
<value>Moving Virtual Disk '{0}' to SR '{1}'</value>
|
||||
<value>Moving Virtual Disk '{0}' from SR '{1}' to SR '{2}'</value>
|
||||
</data>
|
||||
<data name="ACTION_MOVING_X_VDIS" xml:space="preserve">
|
||||
<value>Moving {0} virtual disks to {1}</value>
|
||||
@ -986,9 +983,6 @@ This could be because the data source is not generating any data. Ensure the pre
|
||||
<data name="ACTION_TEMPLATE_CLONE_NEW_NAME" xml:space="preserve">
|
||||
<value>Copy of {0}</value>
|
||||
</data>
|
||||
<data name="ACTION_TEMPLATE_CLONING" xml:space="preserve">
|
||||
<value>Duplicating</value>
|
||||
</data>
|
||||
<data name="ACTION_TOOLSTACK_RESTARTED" xml:space="preserve">
|
||||
<value>Toolstack restarted.</value>
|
||||
</data>
|
||||
@ -1158,7 +1152,7 @@ This could be because the data source is not generating any data. Ensure the pre
|
||||
<value>Copying {0} canceled</value>
|
||||
</data>
|
||||
<data name="ACTION_VM_CROSS_POOL_COPY_TITLE" xml:space="preserve">
|
||||
<value>Copying VM '{0}' to '{1}'</value>
|
||||
<value>Copying VM '{0}' from '{1}' to '{2}'</value>
|
||||
</data>
|
||||
<data name="ACTION_VM_DELETE_SNAPSHOTS_TITLE" xml:space="preserve">
|
||||
<value>Deleting snapshots</value>
|
||||
@ -1196,8 +1190,11 @@ This could be because the data source is not generating any data. Ensure the pre
|
||||
<data name="ACTION_VM_MOVING" xml:space="preserve">
|
||||
<value>Moving VM '{0}' to new storage</value>
|
||||
</data>
|
||||
<data name="ACTION_VM_MOVING_TITLE" xml:space="preserve">
|
||||
<value>Moving VM '{0}' to '{1}' on SR '{2}'</value>
|
||||
<data name="ACTION_VM_MOVING_HOST" xml:space="preserve">
|
||||
<value>Moving VM '{0}' from server '{1}' to server '{2}'</value>
|
||||
</data>
|
||||
<data name="ACTION_VM_MOVING_SR" xml:space="preserve">
|
||||
<value>Moving VM '{0}' to SR '{1}'</value>
|
||||
</data>
|
||||
<data name="ACTION_VM_MOVING_VDI_DESTROY_FAILURE" xml:space="preserve">
|
||||
<value>Failed to finalize moving VM '{0}' to new storage. Please see logs for details.</value>
|
||||
@ -5382,6 +5379,9 @@ Would you like to eject these ISOs before continuing?</value>
|
||||
|
||||
{1}</value>
|
||||
</data>
|
||||
<data name="ENABLE_TLS_VERIFICATION_RPU" xml:space="preserve">
|
||||
<value>You cannot enable certificate verification while a rolling pool upgrade is in progress.</value>
|
||||
</data>
|
||||
<data name="ENABLE_WLB_ELLIPSIS" xml:space="preserve">
|
||||
<value>Res&ume</value>
|
||||
</data>
|
||||
@ -5938,6 +5938,12 @@ Would you like to eject these ISOs before continuing?</value>
|
||||
<data name="FILE_ALL" xml:space="preserve">
|
||||
<value>All files</value>
|
||||
</data>
|
||||
<data name="FILE_NAME_IS_DEVICE_NAME_ERROR_MESSAGE" xml:space="preserve">
|
||||
<value>A file name cannot be a device name.</value>
|
||||
</data>
|
||||
<data name="FILE_PATH_DEVICE_NAME_ERROR_MESSAGE" xml:space="preserve">
|
||||
<value>Path section {0} matches a device name.</value>
|
||||
</data>
|
||||
<data name="FILE_PDF" xml:space="preserve">
|
||||
<value>Acrobat (PDF) file</value>
|
||||
</data>
|
||||
@ -7046,6 +7052,9 @@ This might result in failure to migrate VMs to this server during the RPU or to
|
||||
<data name="IGNORE_BUTTON_LABEL" xml:space="preserve">
|
||||
<value>&Ignore</value>
|
||||
</data>
|
||||
<data name="ILLEGAL_CHARACTER_ERROR_MESSAGE" xml:space="preserve">
|
||||
<value>The following characters are invalid: {0}</value>
|
||||
</data>
|
||||
<data name="ILO_CONNECTION_ERROR" xml:space="preserve">
|
||||
<value>It is not possible to connect to the iLO service. Please review your configuration.</value>
|
||||
</data>
|
||||
@ -10465,6 +10474,9 @@ File not found</value>
|
||||
<data name="PATCH_UPLOADED" xml:space="preserve">
|
||||
<value>Update uploaded to server '{0}' </value>
|
||||
</data>
|
||||
<data name="PATH_CAN_NOT_BE_NULL_ERROR_MESSAGE" xml:space="preserve">
|
||||
<value>Path cannot be null or empty.</value>
|
||||
</data>
|
||||
<data name="PATH_DOES_NOT_EXIST" xml:space="preserve">
|
||||
<value>Path does not exist.</value>
|
||||
</data>
|
||||
|
@ -41,6 +41,7 @@ using XenAdmin.Core;
|
||||
using XenAPI;
|
||||
using XenCenterLib;
|
||||
using System.Diagnostics;
|
||||
using System.Linq;
|
||||
using System.Xml.Serialization;
|
||||
using XenAdmin.ServerDBs;
|
||||
|
||||
@ -1757,12 +1758,14 @@ namespace XenAdmin.Network
|
||||
|
||||
private Pool getAPool(ICache objects, out string opaqueref)
|
||||
{
|
||||
foreach (Pool pool in objects.Pools)
|
||||
var pools = objects.Pools;
|
||||
if (pools.Length > 0)
|
||||
{
|
||||
var pool = pools.First();
|
||||
opaqueref = pool.opaque_ref;
|
||||
return pool;
|
||||
}
|
||||
System.Diagnostics.Trace.Assert(false);
|
||||
Trace.Assert(false);
|
||||
opaqueref = null;
|
||||
return null;
|
||||
}
|
||||
|
135
XenModel/PathValidator.cs
Normal file
135
XenModel/PathValidator.cs
Normal file
@ -0,0 +1,135 @@
|
||||
/* 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.IO;
|
||||
using System.Linq;
|
||||
using XenAdmin;
|
||||
|
||||
namespace XenModel
|
||||
{
|
||||
public class PathValidator
|
||||
{
|
||||
private static readonly char[] m_invalidFileCharList = Path.GetInvalidFileNameChars();
|
||||
private static readonly string[] m_deviceNames = {
|
||||
"CON", "PRN", "AUX", "NUL",
|
||||
"COM1", "COM2", "COM3", "COM4", "COM5", "COM6", "COM7", "COM8", "COM9",
|
||||
"LPT1", "LPT2", "LPT3", "LPT4", "LPT5", "LPT6", "LPT7", "LPT8", "LPT9"
|
||||
};
|
||||
|
||||
private static string IllegalFileCharMsg {
|
||||
get {
|
||||
return string.Format(Messages.ILLEGAL_CHARACTER_ERROR_MESSAGE, string.Join(" ", m_invalidFileCharList.Where(c => !char.IsControl(c))));
|
||||
}
|
||||
}
|
||||
|
||||
private static string IllegalPathCharMsg
|
||||
{
|
||||
get
|
||||
{
|
||||
return string.Format(Messages.ILLEGAL_CHARACTER_ERROR_MESSAGE, string.Join(" ", m_invalidFileCharList.Where(c => !char.IsControl(c) && c != '\\')));
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
public static bool IsFileNameValid(string filename, out string invalidNameMsg)
|
||||
{
|
||||
invalidNameMsg = string.Empty;
|
||||
if (filename.IndexOfAny(m_invalidFileCharList) > -1)
|
||||
{
|
||||
invalidNameMsg = IllegalFileCharMsg;
|
||||
return false;
|
||||
}
|
||||
|
||||
foreach (var name in m_deviceNames)
|
||||
{
|
||||
if (name == filename.ToUpper())
|
||||
{
|
||||
invalidNameMsg = Messages.FILE_NAME_IS_DEVICE_NAME_ERROR_MESSAGE;
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
public static bool IsPathValid(string path, out string invalidPathMsg)
|
||||
{
|
||||
invalidPathMsg = string.Empty;
|
||||
if (string.IsNullOrEmpty(path))
|
||||
{
|
||||
invalidPathMsg = Messages.PATH_CAN_NOT_BE_NULL_ERROR_MESSAGE;
|
||||
return false;
|
||||
}
|
||||
|
||||
try
|
||||
{
|
||||
if (Path.IsPathRooted(path))
|
||||
{
|
||||
path = path[0] == '\\' && path.Length == 1
|
||||
? path.Substring(1)
|
||||
: path.Substring(2);
|
||||
}
|
||||
}
|
||||
catch (ArgumentException)
|
||||
{
|
||||
//path contains some of the characters from Path.GetInvalidPathChars()
|
||||
invalidPathMsg = IllegalPathCharMsg;
|
||||
return false;
|
||||
}
|
||||
|
||||
var parts = path.Split('\\');
|
||||
|
||||
if (parts.Length > 0)
|
||||
{
|
||||
foreach (var part in parts)
|
||||
{
|
||||
if (part.IndexOfAny(m_invalidFileCharList) > -1)
|
||||
{
|
||||
invalidPathMsg = IllegalPathCharMsg;
|
||||
return false;
|
||||
}
|
||||
|
||||
foreach (var name in m_deviceNames)
|
||||
{
|
||||
if (name == part.ToUpper())
|
||||
{
|
||||
invalidPathMsg = string.Format(Messages.FILE_PATH_DEVICE_NAME_ERROR_MESSAGE, name);
|
||||
return false;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
}
|
||||
}
|
@ -34,6 +34,7 @@ using System.Collections.Generic;
|
||||
using XenAPI;
|
||||
using System.Collections;
|
||||
using System.Globalization;
|
||||
using System.Linq;
|
||||
using System.Threading;
|
||||
|
||||
namespace XenAdmin.ServerDBs.FakeAPI
|
||||
@ -107,14 +108,14 @@ namespace XenAdmin.ServerDBs.FakeAPI
|
||||
|
||||
public Response<string> reboot(string session, string opaque_ref)
|
||||
{
|
||||
string metrics_ref = (string)proxy.db.GetValue("host", opaque_ref, "metrics");
|
||||
var metrics_ref = (string)proxy.db.GetValue("host", opaque_ref, "metrics");
|
||||
proxy.EditObject_(DbProxy.EditTypes.Replace, "host_metrics", metrics_ref, "live", false);
|
||||
|
||||
string coordinator_ref = "";
|
||||
foreach (string pool in proxy.db.Tables["pool"].Rows.Keys)
|
||||
var coordinator_ref = string.Empty;
|
||||
var pools = proxy.db.Tables["pool"].Rows.Keys;
|
||||
if (pools.Count > 0)
|
||||
{
|
||||
coordinator_ref = (string)proxy.db.GetValue("pool", pool, "master");
|
||||
break;
|
||||
coordinator_ref = (string)proxy.db.GetValue("pool", pools.First(), "master");
|
||||
}
|
||||
|
||||
if (opaque_ref == coordinator_ref)
|
||||
|
@ -212,13 +212,7 @@ namespace XenAdmin.Core
|
||||
/// </summary>
|
||||
public static Pool GetPoolOfOne(IXenConnection connection)
|
||||
{
|
||||
if (connection == null)
|
||||
return null;
|
||||
|
||||
foreach (Pool pool in connection.Cache.Pools)
|
||||
return pool;
|
||||
|
||||
return null;
|
||||
return connection?.Cache.Pools.FirstOrDefault();
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
@ -497,6 +491,12 @@ namespace XenAdmin.Core
|
||||
return platformVersion != null && productVersionCompare(platformVersion, "3.2.50") >= 0;
|
||||
}
|
||||
|
||||
/// <param name="conn">May be null, in which case true is returned.</param>
|
||||
public static bool YangtzeOrGreater(IXenConnection conn)
|
||||
{
|
||||
return conn == null || YangtzeOrGreater(Helpers.GetCoordinator(conn));
|
||||
}
|
||||
|
||||
/// <param name="host">May be null, in which case true is returned.</param>
|
||||
public static bool YangtzeOrGreater(Host host)
|
||||
{
|
||||
@ -1545,11 +1545,9 @@ namespace XenAdmin.Core
|
||||
|
||||
public static string HostnameFromLocation(string p)
|
||||
{
|
||||
foreach (Match m in HostnameOrIpRegex.Matches(p))
|
||||
{
|
||||
return m.Value; // we only want the hostname or ip which should be the first match
|
||||
}
|
||||
return "";
|
||||
var matches = HostnameOrIpRegex.Matches(p);
|
||||
// we only want the hostname or ip which should be the first match
|
||||
return matches.Count > 0 ? matches[0].Value : string.Empty;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user