/* 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; using XenAdmin.Controls; using XenAPI; using XenAdmin.Actions; using XenAdmin.Help; using System.Linq; using System.Globalization; using XenAdmin.Core; namespace XenAdmin.Wizards.NewSRWizard_Pages.Frontends { public partial class StorageProvisioning : XenTabPage { private string previousUnitsValueInitAlloc; private string previousUnitsValueIncrAlloc; private const int DecimalPlacesMB = 0; private const int DecimalPlacesGB = 3; private const int IncrementMB = 256; private const int IncrementGB = 1; public StorageProvisioning() { InitializeComponent(); incremental_allocation_units.SelectedItem = previousUnitsValueIncrAlloc = Messages.VAL_MEGB; initial_allocation_units.SelectedItem = previousUnitsValueInitAlloc = Messages.VAL_MEGB; } #region Accessors public Dictionary<string, string> SMConfig { get { var smconfig = new Dictionary<string, string>(); if (radioButtonThinProvisioning.Checked) { smconfig["allocation"] = "xlvhd"; smconfig["allocation_quantum"] = (incremental_allocation_units.SelectedItem.ToString() == Messages.VAL_MEGB ? (long)(allocationQuantumNumericUpDown.Value * Util.BINARY_MEGA) : (long)(allocationQuantumNumericUpDown.Value * Util.BINARY_GIGA)) .ToString(CultureInfo.InvariantCulture); smconfig["initial_allocation"] = (initial_allocation_units.SelectedItem.ToString() == Messages.VAL_MEGB ? (long)(initialAllocationNumericUpDown.Value * Util.BINARY_MEGA) : (long)(initialAllocationNumericUpDown.Value * Util.BINARY_GIGA)) .ToString(CultureInfo.InvariantCulture); } return smconfig; } } public long SRSize { get; set; } #endregion #region XenTabPage overrides public override void PopulatePage() { InitializeNumericUpDowns(); UpdateControls(); OnPageUpdated(); } private void InitializeNumericUpDowns() { // Because we do not initialize the NumericUpDown with values from an existing sm_config // the value passed to the setup functions is -1. SetUpInitAllocationNumericUpDown(-1); SetUpIncrAllocationNumericUpDown(-1); } private void SetNumUpDownIncrementAndDecimals(NumericUpDown upDown, string units) { if (units == Messages.VAL_GIGB) { upDown.DecimalPlaces = DecimalPlacesGB; upDown.Increment = IncrementGB; } else { upDown.DecimalPlaces = DecimalPlacesMB; upDown.Increment = IncrementMB; } } // The value parameter is -1 if we do not use an existing SM Config. Otherwise // it is the value of the initial_allocation in the SM config. The value received is in bytes. private void SetUpInitAllocationNumericUpDown(decimal value) { Helpers.AllocationBounds allocBounds = Helpers.SRInitialAllocationBounds(SRSize); if(value != -1) { allocBounds = new Helpers.AllocationBounds(allocBounds.Min, allocBounds.Max, value); } initialAllocationNumericUpDown.Minimum = allocBounds.MinInUnits; initialAllocationNumericUpDown.Maximum = allocBounds.MaxInUnits; initialAllocationNumericUpDown.Value = allocBounds.DefaultValueInUnits; initial_allocation_units.SelectedItem = previousUnitsValueInitAlloc = allocBounds.Unit; SetNumUpDownIncrementAndDecimals(initialAllocationNumericUpDown, allocBounds.Unit); } // The value parameter is -1 if we do not use an existing SM Config. Otherwise // it is the value of the allocation_quantum in the SM config. private void SetUpIncrAllocationNumericUpDown(decimal value) { Helpers.AllocationBounds allocBounds = Helpers.SRIncrementalAllocationBounds(SRSize); if (value != -1) { allocBounds = new Helpers.AllocationBounds(allocBounds.Min, allocBounds.Max, value); } allocationQuantumNumericUpDown.Minimum = allocBounds.MinInUnits; allocationQuantumNumericUpDown.Maximum = allocBounds.MaxInUnits; allocationQuantumNumericUpDown.Value = allocBounds.DefaultValueInUnits; incremental_allocation_units.SelectedItem = previousUnitsValueInitAlloc = allocBounds.Unit; SetNumUpDownIncrementAndDecimals(allocationQuantumNumericUpDown, allocBounds.Unit); } public override string PageTitle { get { return Messages.STORAGE_PROVISIONING_METHOD_TITLE; } } public override string Text { get { return Messages.STORAGE_PROVISIONING_SETTINGS; } } public override string HelpID { get { return "helpid "; } } public override bool EnableNext() { return true; } #endregion private void radioButton_CheckedChanged(object sender, EventArgs e) { UpdateControls(); } public void DisableControls() { foreach (Control c in Controls) c.Enabled = false; } public void ResetControls() { foreach (Control c in Controls) c.Enabled = true; UpdateControls(); } public void SetControlsUsingExistingSMConfig(Dictionary<string, string> smConfig) { long temp = 0; if (smConfig.ContainsKey("allocation") && smConfig["allocation"] == "xlvhd") { radioButtonThickProvisioning.Checked = false; radioButtonThinProvisioning.Checked = true; if (smConfig.ContainsKey("initial_allocation") && long.TryParse(smConfig["initial_allocation"], out temp)) { SetUpInitAllocationNumericUpDown(temp); } if (smConfig.ContainsKey("allocation_quantum") && long.TryParse(smConfig["allocation_quantum"], out temp)) { SetUpIncrAllocationNumericUpDown(temp); } } else { radioButtonThickProvisioning.Checked = true; radioButtonThinProvisioning.Checked = false; } } private void UpdateControls() { labelAllocationQuantum.Enabled = labelInitialAllocation.Enabled = allocationQuantumNumericUpDown.Enabled = initial_allocation_units.Enabled = incremental_allocation_units.Enabled = initialAllocationNumericUpDown.Enabled = radioButtonThinProvisioning.Checked; } private void initial_allocation_units_SelectedIndexChanged(object sender, EventArgs e) { UpdateValuesWhenUnitsChanged(initialAllocationNumericUpDown, previousUnitsValueInitAlloc, initial_allocation_units.SelectedItem.ToString()); previousUnitsValueInitAlloc = initial_allocation_units.SelectedItem.ToString(); } private void incremental_allocation_units_SelectedIndexChanged(object sender, EventArgs e) { UpdateValuesWhenUnitsChanged(allocationQuantumNumericUpDown, previousUnitsValueIncrAlloc, incremental_allocation_units.SelectedItem.ToString()); previousUnitsValueIncrAlloc = incremental_allocation_units.SelectedItem.ToString(); } public static void UpdateValuesWhenUnitsChanged(NumericUpDown upDown, string previousUnits, string newUnits) { if (previousUnits == newUnits) return; if (newUnits == Messages.VAL_MEGB) { upDown.Maximum *= Util.BINARY_KILO; upDown.Value *= Util.BINARY_KILO; upDown.Minimum *= Util.BINARY_KILO; upDown.DecimalPlaces = DecimalPlacesMB; upDown.Increment = IncrementMB; } else { upDown.Minimum /= Util.BINARY_KILO; upDown.Value /= Util.BINARY_KILO; upDown.Maximum /= Util.BINARY_KILO; upDown.DecimalPlaces = DecimalPlacesGB; upDown.Increment = IncrementGB; } } } }