mirror of
https://github.com/xcp-ng/xenadmin.git
synced 2024-11-25 06:16:37 +01:00
afb419af04
* Tidy up `VM` extension: use `var` * Tidy up `VM` extension: remove redundant initialisers * Tidy up `VM` extension: use type keywords when possible * Tidy up `VM` extension: merge conditional expressions * Tidy up `VM` extension: remove redundant qualifiers * Tidy up `VM` extension: remove redundant type arguments * Tidy up `VM` extension: remove redundant `else`s and parentheses * Tidy up `VM` extension: fix naming * Tidy up `VM` extension: misc changes * Tidy up `VM` extension: use `null` propagation * Tidy up `VM` extension: fix whitespace * Tidy up `VM` extension: apply ReSharper Code Cleanup utility * Tidy up `VM` extension: Fix naming of private string array * CP-44767: Ignore VM restriction when fetching `MaxVCPUsAllowed` Instead, fetch the highest available value in all templates for the host. This means that VMs imported from vhd won't automatically default to `DEFAULT_NUM_VCPUS_ALLOWED`, and that VMs that have been kept across XenServer upgrades won't be limited to the number of vCPUs in their own (possibly outdated) restrictions * CP-44766: Use value in template with a matching `reference_label` when checking VM restrictions * Move restriction getters to own region * CP-44766: Use matching templates to fetch VM restrictions - Rewrite `GetRestrictions...` methods to perform simpler operations - Add `GetIntRestrictionValue` and `GetBoolRestrictionValue` wrappers to `GetRestrictionValueFromMatchingTemplate` - Now all calls to a restrictions first check the template value, with a fall-back to defaults * CP-44765: Export `reference-label` when generating OVFs --------- Signed-off-by: Danilo Del Busso <danilo.delbusso@cloud.com>
155 lines
5.8 KiB
C#
155 lines
5.8 KiB
C#
/* Copyright (c) Cloud Software Group, Inc.
|
|
*
|
|
* 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.ComponentModel;
|
|
using System.Linq;
|
|
using System.Windows.Forms;
|
|
using XenAdmin.Dialogs;
|
|
using XenAdmin.Wizards;
|
|
using XenAPI;
|
|
|
|
|
|
namespace XenAdmin.Controls.Ballooning
|
|
{
|
|
public partial class VMMemoryControlsNoEdit : UserControl
|
|
{
|
|
private List<VM> vms;
|
|
private VM vm0;
|
|
private List<VM_metrics> vm_metrics;
|
|
|
|
public VMMemoryControlsNoEdit()
|
|
{
|
|
InitializeComponent();
|
|
}
|
|
|
|
public List<VM> VMs
|
|
{
|
|
set
|
|
{
|
|
UnregisterHandlers();
|
|
vms = value;
|
|
if (vms == null)
|
|
{
|
|
vm_metrics = null;
|
|
return;
|
|
}
|
|
|
|
if (vms.Count > 0)
|
|
vm0 = vms[0];
|
|
|
|
vm_metrics = new List<VM_metrics>();
|
|
|
|
foreach (VM vm in vms)
|
|
{
|
|
vm.PropertyChanged += vm_PropertyChanged;
|
|
|
|
var metrics = vm.Connection.Resolve(vm.metrics);
|
|
if (metrics != null)
|
|
{
|
|
vm_metrics.Add(metrics);
|
|
metrics.PropertyChanged += vm_metrics_PropertyChanged;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
protected override void OnPaint(PaintEventArgs e)
|
|
{
|
|
if (vms == null || vms.Count == 0)
|
|
return;
|
|
|
|
// Edit button: don't show if one of the VMs has just been rebooted, because we don't accurately
|
|
// know what its capabilities are in that case (cf CA-31051). Also suspended VMs can't be edited.
|
|
// So "good" VMs are ones which are halted, or running with known virtualisation status.
|
|
|
|
editButton.Visible = vms.All(vm =>
|
|
vm.power_state == vm_power_state.Halted ||
|
|
vm.power_state == vm_power_state.Running && !vm.GetVirtualizationStatus(out _).HasFlag(VM.VirtualizationStatus.Unknown));
|
|
|
|
vmShinyBar.Populate(vms, false);
|
|
|
|
if (vm0.SupportsBallooning())
|
|
{
|
|
valueDynMin.Text = Util.MemorySizeStringSuitableUnits(vm0.memory_dynamic_min, true);
|
|
valueDynMax.Text = Util.MemorySizeStringSuitableUnits(vm0.memory_dynamic_max, true);
|
|
if (vm0.memory_dynamic_max == vm0.memory_static_max)
|
|
labelStatMax.Visible = valueStatMax.Visible = false;
|
|
else
|
|
valueStatMax.Text = Util.MemorySizeStringSuitableUnits(vm0.memory_static_max, true);
|
|
}
|
|
else
|
|
{
|
|
valueDynMin.Text = Util.MemorySizeStringSuitableUnits(vm0.memory_static_max, true);
|
|
iconBoxDynMin.Visible = false;
|
|
labelDynMin.Text = Messages.MEMORY;
|
|
|
|
iconBoxDynMax.Visible = labelDynMax.Visible = valueDynMax.Visible = false;
|
|
labelStatMax.Visible = valueStatMax.Visible = false;
|
|
}
|
|
}
|
|
|
|
private void vm_PropertyChanged(object sender, PropertyChangedEventArgs e)
|
|
{
|
|
if (e.PropertyName == "power_state" || e.PropertyName == "virtualisation_status" || e.PropertyName == "name_label")
|
|
Program.Invoke(this, Refresh);
|
|
}
|
|
|
|
private void vm_metrics_PropertyChanged(object sender, PropertyChangedEventArgs e)
|
|
{
|
|
if (e.PropertyName == "memory_actual")
|
|
Program.Invoke(this, Refresh);
|
|
}
|
|
|
|
private void editButton_Click(object sender, EventArgs e)
|
|
{
|
|
if (vms.Count == 1)
|
|
using (var dlg = new BallooningDialog(vm0))
|
|
dlg.ShowDialog(Program.MainWindow);
|
|
else
|
|
Program.MainWindow.ShowPerConnectionWizard(vm0.Connection, new BallooningWizard(vms));
|
|
}
|
|
|
|
internal void UnregisterHandlers()
|
|
{
|
|
if (vms != null)
|
|
foreach (var vm in vms)
|
|
if (vm != null)
|
|
vm.PropertyChanged -= vm_PropertyChanged;
|
|
|
|
if (vm_metrics != null)
|
|
foreach (var metrics in vm_metrics)
|
|
if (metrics != null)
|
|
metrics.PropertyChanged -= vm_metrics_PropertyChanged;
|
|
}
|
|
}
|
|
}
|