xenadmin/XenModel/WLB/WlbConfigurationBase.cs
Gabor Apati-Nagy 7c0bc50b4a CA-176169: Changed copyright statements to include the comma in Citrix Systems,
Inc.

Signed-off-by: Gabor Apati-Nagy<gabor.apati-nagy@citrix.com>
2017-01-16 19:59:50 +00:00

395 lines
13 KiB
C#

/* Copyright (c) Citrix Systems, Inc.
* All rights reserved.
*
* Redistribution and use in source and binary forms,
* with or without modification, are permitted provided
* that the following conditions are met:
*
* * Redistributions of source code must retain the above
* copyright notice, this list of conditions and the
* following disclaimer.
* * Redistributions in binary form must reproduce the above
* copyright notice, this list of conditions and the
* following disclaimer in the documentation and/or other
* materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND
* CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
* INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
*/
using System;
using System.Collections.Generic;
using System.Text;
using System.Globalization;
namespace XenAdmin.Wlb
{
public class WlbConfigurationBase
{
protected const double KILOBYTE = 1024;
private List<string> _wlbConfigurationKeys;
private WlbConfigurationKeyBase _keyBase;
private string _itemId;
private Dictionary<string, string> _configuration;
private NumberFormatInfo _nfi = new CultureInfo("en-US", false).NumberFormat;
private DateTimeFormatInfo _dtfi = new CultureInfo("en-US", false).DateTimeFormat;
public enum WlbConfigurationKeyBase
{
pool,
host,
schedTask,
rpSub
}
#region Constructor
public WlbConfigurationBase()
{
_configuration = new Dictionary<string, string>();
_nfi = new CultureInfo("en-US", false).NumberFormat;
_keyBase = WlbConfigurationKeyBase.pool;
}
#endregion
#region Static Conversion Functions
public static decimal ConvertToMB(double byteValue)
{
return Convert.ToDecimal(byteValue / 1024 / 1024);
}
public static double ConvertFromMB(decimal mbyteValue)
{
return (double)(mbyteValue * 1024 * 1024);
}
public static double ConvertToMbps(double rawValue)
{
return (int)(rawValue / KILOBYTE / KILOBYTE);
}
public static double ConvertFromMbps(double mbpsValue)
{
return (double)(mbpsValue * KILOBYTE * KILOBYTE);
}
#endregion
#region Public Methods
public Dictionary<string, string> ToDictionary()
{
return _configuration;
}
#endregion
#region protected Methods
protected string GetConfigValueString(string key)
{
string stringValue = String.Empty;
if (_configuration.ContainsKey(key))
{
stringValue = _configuration[key];
}
return stringValue;
}
protected void SetConfigValueString(string key, string value)
{
SetConfigValueString(key, value, false);
}
protected void SetConfigValueString(string key, string value, bool createKey)
{
if (!_configuration.ContainsKey(key) && createKey)
{
_configuration.Add(key, value);
}
else if (_configuration.ContainsKey(key))
{
_configuration[key] = value;
}
}
protected int GetConfigValuePercent(string key)
{
return GetConfigValuePercent(key, 0);
}
protected int GetConfigValuePercent(string key, int defaultValue)
{
double floatValue;
if (!_configuration.ContainsKey(key) || !double.TryParse(_configuration[key], System.Globalization.NumberStyles.Any, _nfi, out floatValue))
{
floatValue = ((double)defaultValue) / 100;
}
return (int)(floatValue * 100);
}
protected void SetConfigValuePercent(string key, int value)
{
SetConfigValuePercent(key, value, false);
}
protected void SetConfigValuePercent(string key, int value, bool createKey)
{
double percentageValue = ((double)value) / 100;
if (!_configuration.ContainsKey(key) && createKey)
{
_configuration.Add(key, percentageValue.ToString(_nfi));
}
else if (_configuration.ContainsKey(key))
{
_configuration[key] = percentageValue.ToString(_nfi);
}
}
protected double GetConfigValueDouble(string key)
{
return GetConfigValueDouble(key, 0);
}
protected double GetConfigValueDouble(string key, double defaultValue)
{
double doubleValue;
if (!_configuration.ContainsKey(key) || !double.TryParse(_configuration[key], System.Globalization.NumberStyles.Any, _nfi, out doubleValue))
{
doubleValue = defaultValue;
}
return doubleValue;
}
protected void SetConfigValueDouble(string key, double value)
{
SetConfigValueDouble(key, value, false);
}
protected void SetConfigValueDouble(string key, double value, bool createKey)
{
if (!_configuration.ContainsKey(key) && createKey)
{
_configuration.Add(key, Math.Round(value, 0).ToString(_nfi));
}
else if (_configuration.ContainsKey(key))
{
_configuration[key] = Math.Round(value, 0).ToString(_nfi);
}
}
protected int GetConfigValueInt(string key)
{
return GetConfigValueInt(key, 0);
}
protected int GetConfigValueInt(string key, int defaultValue)
{
int result = defaultValue;
if (_configuration.ContainsKey(key))
{
int.TryParse(_configuration[key], System.Globalization.NumberStyles.Any, _nfi, out result);
}
return result;
}
protected void SetConfigValueInt(string key, int value)
{
SetConfigValueInt(key, value, false);
}
protected void SetConfigValueInt(string key, int value, bool createKey)
{
if (!_configuration.ContainsKey(key) && createKey)
{
_configuration.Add(key, value.ToString(_nfi));
}
else if(_configuration.ContainsKey(key))
{
_configuration[key] = value.ToString(_nfi);
}
}
protected DateTime GetConfigValueUTCDateTime(string key)
{
return GetConfigValueUTCDateTime(key, DateTime.MinValue);
}
protected DateTime GetConfigValueUTCDateTime(string key, DateTime defaultValue)
{
DateTime result = defaultValue;
if (_configuration.ContainsKey(key))
{
// Converts the specified string representation of a date and time to its System.DateTime
// equivalent using the specified culture-specific format information and formatting style.
DateTime.TryParse(_configuration[key], CultureInfo.InvariantCulture, DateTimeStyles.None, out result);
}
return result;
}
protected void SetConfigValueUTCDateTime(string key, DateTime value)
{
SetConfigValueUTCDateTime(key, value, false);
}
/// <summary>
/// Expect value is UTC time
/// </summary>
/// <param name="key"></param>
/// <param name="value"></param>
/// <param name="createKey"></param>
protected void SetConfigValueUTCDateTime(string key, DateTime value, bool createKey)
{
if (!_configuration.ContainsKey(key) && createKey)
{
_configuration.Add(key, value.ToString(_dtfi));
}
else if (_configuration.ContainsKey(key))
{
_configuration[key] = value.ToString(_dtfi);
}
}
protected bool GetConfigValueBool(string key)
{
return GetConfigValueBool(key, false);
}
protected bool GetConfigValueBool(string key, bool defaultValue)
{
bool boolValue;
if (!_configuration.ContainsKey(key) || !bool.TryParse(_configuration[key], out boolValue))
{
boolValue = defaultValue;
}
return boolValue;
}
protected void SetConfigValueBool(string key, bool value)
{
SetConfigValueBool(key, value, false);
}
protected void SetConfigValueBool(string key, bool value, bool createKey)
{
if (!_configuration.ContainsKey(key) && createKey)
{
_configuration.Add(key, value.ToString(_nfi));
}
else if (_configuration.ContainsKey(key))
{
_configuration[key] = value.ToString(_nfi).ToLower();
}
}
/// <summary>
/// Set the value of a non-defined key, considered a parameter
/// </summary>
/// <param name="Uuid">uuid of the host</param>
/// <param name="Key">name of the parameter</param>
/// <param name="Value">value of the parameter</param>
protected void SetOtherParameter(string key, string value)
{
SetConfigValueString(BuildComplexKey(key), value, true);
}
/// <summary>
/// Set an entire set of parameters (Dictionary) at once
/// </summary>
/// <param name="Parameters">Dictionary of parameters</param>
protected void SetOtherParameters(Dictionary<string, string> Parameters)
{
foreach (string key in Parameters.Keys)
{
SetOtherParameter(key, Parameters[key]);
}
}
/// <summary>
/// Get all Other, unknown key's parameters
/// </summary>
/// <param name="keyBase">partial key used to form keys of the dicitionary </param>
/// <returns>Dictionary of parameters (unknown keys and their values)</returns>
protected Dictionary<string, string> GetOtherParameters()
{
Dictionary<string, string> parameters = new Dictionary<string, string>();
string currentKeyBase = string.Format("{0}_{1}_", this._keyBase, this._itemId);
foreach (string key in this._configuration.Keys)
{
if (key.StartsWith(currentKeyBase))
{
string paramName = key.Remove(0, currentKeyBase.Length);
if (!this._wlbConfigurationKeys.Contains(paramName))
{
parameters.Add(paramName, this._configuration[key]);
}
}
}
return parameters;
}
/// <summary>
/// Assemble a dictionary key for a specific host and known key type
/// </summary>
/// <param name="Key">key type enumeration</param>
/// <returns>assembled key string</returns>
protected string BuildComplexKey(string Key)
{
return string.Format("{0}_{1}_{2}", this._keyBase, this._itemId, Key);
}
protected Dictionary<string, string> Configuration
{
get { return _configuration; }
set { _configuration = value; }
}
/// <summary>
/// Used by collections to directly insert entries into the Dictionary
/// </summary>
/// <param name="key">name of the key</param>
/// <param name="value">value of the key</param>
public void AddParameter(string key, string value)
{
_configuration.Add(key, value);
}
protected List<string> WlbConfigurationKeys
{
get { return _wlbConfigurationKeys; }
set { _wlbConfigurationKeys = value; }
}
public WlbConfigurationKeyBase KeyBase
{
get { return _keyBase; }
set { _keyBase = value; }
}
protected string ItemId
{
get { return _itemId; }
set { _itemId = value; }
}
#endregion
}
}