Updated Branches:
  refs/heads/master f420b7489 -> d26b9ac00

http://git-wip-us.apache.org/repos/asf/cloudstack/blob/5a96307f/plugins/hypervisors/hyperv/DotNet/ServerResource/WmiWrappers/ROOT.virtualization.v2.Msvm_VirtualSystemMigrationSettingData.cs
----------------------------------------------------------------------
diff --git 
a/plugins/hypervisors/hyperv/DotNet/ServerResource/WmiWrappers/ROOT.virtualization.v2.Msvm_VirtualSystemMigrationSettingData.cs
 
b/plugins/hypervisors/hyperv/DotNet/ServerResource/WmiWrappers/ROOT.virtualization.v2.Msvm_VirtualSystemMigrationSettingData.cs
new file mode 100644
index 0000000..de5bea5
--- /dev/null
+++ 
b/plugins/hypervisors/hyperv/DotNet/ServerResource/WmiWrappers/ROOT.virtualization.v2.Msvm_VirtualSystemMigrationSettingData.cs
@@ -0,0 +1,915 @@
+// Licensed to the Apache Software Foundation (ASF) under one
+// or more contributor license agreements.  See the NOTICE file
+// distributed with this work for additional information
+// regarding copyright ownership.  The ASF licenses this file
+// to you under the Apache License, Version 2.0 (the
+// "License"); you may not use this file except in compliance
+// with the License.  You may obtain a copy of the License at
+//
+//   http://www.apache.org/licenses/LICENSE-2.0
+//
+// Unless required by applicable law or agreed to in writing,
+// software distributed under the License is distributed on an
+// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+// KIND, either express or implied.  See the License for the
+// specific language governing permissions and limitations
+// under the License.
+
+namespace CloudStack.Plugin.WmiWrappers.ROOT.VIRTUALIZATION.V2 {
+    using System;
+    using System.ComponentModel;
+    using System.Management;
+    using System.Collections;
+    using System.Globalization;
+    using System.ComponentModel.Design.Serialization;
+    using System.Reflection;
+    
+    
+    // Functions ShouldSerialize<PropertyName> are functions used by VS 
property browser to check if a particular property has to be serialized. These 
functions are added for all ValueType properties ( properties of type Int32, 
BOOL etc.. which cannot be set to null). These functions use 
Is<PropertyName>Null function. These functions are also used in the 
TypeConverter implementation for the properties to check for NULL value of 
property so that an empty value can be shown in Property browser in case of 
Drag and Drop in Visual studio.
+    // Functions Is<PropertyName>Null() are used to check if a property is 
NULL.
+    // Functions Reset<PropertyName> are added for Nullable Read/Write 
properties. These functions are used by VS designer in property browser to set 
a property to NULL.
+    // Every property added to the class for WMI property has attributes set 
to define its behavior in Visual Studio designer and also to define a 
TypeConverter to be used.
+    // An Early Bound class generated for the WMI 
class.Msvm_VirtualSystemMigrationSettingData
+    public class VirtualSystemMigrationSettingData : 
System.ComponentModel.Component {
+        
+        // Private property to hold the WMI namespace in which the class 
resides.
+        private static string CreatedWmiNamespace = "ROOT\\virtualization\\v2";
+        
+        // Private property to hold the name of WMI class which created this 
class.
+        public static string CreatedClassName = 
"Msvm_VirtualSystemMigrationSettingData";
+        
+        // Private member variable to hold the ManagementScope which is used 
by the various methods.
+        private static System.Management.ManagementScope statMgmtScope = null;
+        
+        private ManagementSystemProperties PrivateSystemProperties;
+        
+        // Underlying lateBound WMI object.
+        private System.Management.ManagementObject PrivateLateBoundObject;
+        
+        // Member variable to store the 'automatic commit' behavior for the 
class.
+        private bool AutoCommitProp;
+        
+        // Private variable to hold the embedded property representing the 
instance.
+        private System.Management.ManagementBaseObject embeddedObj;
+        
+        // The current WMI object used
+        private System.Management.ManagementBaseObject curObj;
+        
+        // Flag to indicate if the instance is an embedded object.
+        private bool isEmbedded;
+        
+        // Below are different overloads of constructors to initialize an 
instance of the class with a WMI object.
+        public VirtualSystemMigrationSettingData() {
+            this.InitializeObject(null, null, null);
+        }
+        
+        public VirtualSystemMigrationSettingData(string keyInstanceID) {
+            this.InitializeObject(null, new 
System.Management.ManagementPath(VirtualSystemMigrationSettingData.ConstructPath(keyInstanceID)),
 null);
+        }
+        
+        public 
VirtualSystemMigrationSettingData(System.Management.ManagementScope mgmtScope, 
string keyInstanceID) {
+            
this.InitializeObject(((System.Management.ManagementScope)(mgmtScope)), new 
System.Management.ManagementPath(VirtualSystemMigrationSettingData.ConstructPath(keyInstanceID)),
 null);
+        }
+        
+        public 
VirtualSystemMigrationSettingData(System.Management.ManagementPath path, 
System.Management.ObjectGetOptions getOptions) {
+            this.InitializeObject(null, path, getOptions);
+        }
+        
+        public 
VirtualSystemMigrationSettingData(System.Management.ManagementScope mgmtScope, 
System.Management.ManagementPath path) {
+            this.InitializeObject(mgmtScope, path, null);
+        }
+        
+        public 
VirtualSystemMigrationSettingData(System.Management.ManagementPath path) {
+            this.InitializeObject(null, path, null);
+        }
+        
+        public 
VirtualSystemMigrationSettingData(System.Management.ManagementScope mgmtScope, 
System.Management.ManagementPath path, System.Management.ObjectGetOptions 
getOptions) {
+            this.InitializeObject(mgmtScope, path, getOptions);
+        }
+        
+        public 
VirtualSystemMigrationSettingData(System.Management.ManagementObject theObject) 
{
+            Initialize();
+            if ((CheckIfProperClass(theObject) == true)) {
+                PrivateLateBoundObject = theObject;
+                PrivateSystemProperties = new 
ManagementSystemProperties(PrivateLateBoundObject);
+                curObj = PrivateLateBoundObject;
+            }
+            else {
+                throw new System.ArgumentException("Class name does not 
match.");
+            }
+        }
+        
+        public 
VirtualSystemMigrationSettingData(System.Management.ManagementBaseObject 
theObject) {
+            Initialize();
+            if ((CheckIfProperClass(theObject) == true)) {
+                embeddedObj = theObject;
+                PrivateSystemProperties = new 
ManagementSystemProperties(theObject);
+                curObj = embeddedObj;
+                isEmbedded = true;
+            }
+            else {
+                throw new System.ArgumentException("Class name does not 
match.");
+            }
+        }
+        
+        // Property returns the namespace of the WMI class.
+        [Browsable(true)]
+        
[DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)]
+        public string OriginatingNamespace {
+            get {
+                return "ROOT\\virtualization\\v2";
+            }
+        }
+        
+        [Browsable(true)]
+        
[DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)]
+        public string ManagementClassName {
+            get {
+                string strRet = CreatedClassName;
+                if ((curObj != null)) {
+                    if ((curObj.ClassPath != null)) {
+                        strRet = ((string)(curObj["__CLASS"]));
+                        if (((strRet == null) 
+                                    || (strRet == string.Empty))) {
+                            strRet = CreatedClassName;
+                        }
+                    }
+                }
+                return strRet;
+            }
+        }
+        
+        // Property pointing to an embedded object to get System properties of 
the WMI object.
+        [Browsable(true)]
+        
[DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)]
+        public ManagementSystemProperties SystemProperties {
+            get {
+                return PrivateSystemProperties;
+            }
+        }
+        
+        // Property returning the underlying lateBound object.
+        [Browsable(false)]
+        
[DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)]
+        public System.Management.ManagementBaseObject LateBoundObject {
+            get {
+                return curObj;
+            }
+        }
+        
+        // ManagementScope of the object.
+        [Browsable(true)]
+        
[DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)]
+        public System.Management.ManagementScope Scope {
+            get {
+                if ((isEmbedded == false)) {
+                    return PrivateLateBoundObject.Scope;
+                }
+                else {
+                    return null;
+                }
+            }
+            set {
+                if ((isEmbedded == false)) {
+                    PrivateLateBoundObject.Scope = value;
+                }
+            }
+        }
+        
+        // Property to show the commit behavior for the WMI object. If true, 
WMI object will be automatically saved after each property modification.(ie. 
Put() is called after modification of a property).
+        [Browsable(false)]
+        
[DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)]
+        public bool AutoCommit {
+            get {
+                return AutoCommitProp;
+            }
+            set {
+                AutoCommitProp = value;
+            }
+        }
+        
+        // The ManagementPath of the underlying WMI object.
+        [Browsable(true)]
+        public System.Management.ManagementPath Path {
+            get {
+                if ((isEmbedded == false)) {
+                    return PrivateLateBoundObject.Path;
+                }
+                else {
+                    return null;
+                }
+            }
+            set {
+                if ((isEmbedded == false)) {
+                    if ((CheckIfProperClass(null, value, null) != true)) {
+                        throw new System.ArgumentException("Class name does 
not match.");
+                    }
+                    PrivateLateBoundObject.Path = value;
+                }
+            }
+        }
+        
+        // Public static scope property which is used by the various methods.
+        [Browsable(true)]
+        
[DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)]
+        public static System.Management.ManagementScope StaticScope {
+            get {
+                return statMgmtScope;
+            }
+            set {
+                statMgmtScope = value;
+            }
+        }
+        
+        [Browsable(false)]
+        
[DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)]
+        public bool IsBandwidthNull {
+            get {
+                if ((curObj["Bandwidth"] == null)) {
+                    return true;
+                }
+                else {
+                    return false;
+                }
+            }
+        }
+        
+        [Browsable(true)]
+        
[DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)]
+        [TypeConverter(typeof(WMIValueTypeConverter))]
+        public ushort Bandwidth {
+            get {
+                if ((curObj["Bandwidth"] == null)) {
+                    return System.Convert.ToUInt16(0);
+                }
+                return ((ushort)(curObj["Bandwidth"]));
+            }
+        }
+        
+        [Browsable(true)]
+        
[DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)]
+        public string BandwidthUnit {
+            get {
+                return ((string)(curObj["BandwidthUnit"]));
+            }
+        }
+        
+        [Browsable(true)]
+        
[DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)]
+        public string Caption {
+            get {
+                return ((string)(curObj["Caption"]));
+            }
+        }
+        
+        [Browsable(true)]
+        
[DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)]
+        public string Description {
+            get {
+                return ((string)(curObj["Description"]));
+            }
+        }
+        
+        [Browsable(true)]
+        
[DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)]
+        [Description("For storage migration it will be NULL. For virtual 
system \nmigration, client can " +
+            "provide a list of IP addresses of the \ndestination host.")]
+        public string[] DestinationIPAddressList {
+            get {
+                return ((string[])(curObj["DestinationIPAddressList"]));
+            }
+            set {
+                curObj["DestinationIPAddressList"] = value;
+                if (((isEmbedded == false) 
+                            && (AutoCommitProp == true))) {
+                    PrivateLateBoundObject.Put();
+                }
+            }
+        }
+        
+        [Browsable(true)]
+        
[DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)]
+        [Description(@"If we have a planned computer system at migration 
destination then DestinationPlannedVirtualSystemId could be set to 
+the GUID of the destination Planned VM where the VM needs to 
+migrate. This is useful for cases where user has created a 
+planned VM at the destination along with resource fixup, and 
+wants a VM from source to migrate into this planned VM.")]
+        public string DestinationPlannedVirtualSystemId {
+            get {
+                return ((string)(curObj["DestinationPlannedVirtualSystemId"]));
+            }
+            set {
+                curObj["DestinationPlannedVirtualSystemId"] = value;
+                if (((isEmbedded == false) 
+                            && (AutoCommitProp == true))) {
+                    PrivateLateBoundObject.Put();
+                }
+            }
+        }
+        
+        [Browsable(true)]
+        
[DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)]
+        public string ElementName {
+            get {
+                return ((string)(curObj["ElementName"]));
+            }
+        }
+        
+        [Browsable(true)]
+        
[DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)]
+        public string InstanceID {
+            get {
+                return ((string)(curObj["InstanceID"]));
+            }
+        }
+        
+        [Browsable(false)]
+        
[DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)]
+        public bool IsMigrationTypeNull {
+            get {
+                if ((curObj["MigrationType"] == null)) {
+                    return true;
+                }
+                else {
+                    return false;
+                }
+            }
+        }
+        
+        [Browsable(true)]
+        
[DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)]
+        [Description("MigrationType describes the type of migration operation 
to \nbe performed.\n")]
+        [TypeConverter(typeof(WMIValueTypeConverter))]
+        public MigrationTypeValues MigrationType {
+            get {
+                if ((curObj["MigrationType"] == null)) {
+                    return 
((MigrationTypeValues)(System.Convert.ToInt32(32773)));
+                }
+                return 
((MigrationTypeValues)(System.Convert.ToInt32(curObj["MigrationType"])));
+            }
+            set {
+                if ((MigrationTypeValues.NULL_ENUM_VALUE == value)) {
+                    curObj["MigrationType"] = null;
+                }
+                else {
+                    curObj["MigrationType"] = value;
+                }
+                if (((isEmbedded == false) 
+                            && (AutoCommitProp == true))) {
+                    PrivateLateBoundObject.Put();
+                }
+            }
+        }
+        
+        [Browsable(true)]
+        
[DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)]
+        public string OtherTransportType {
+            get {
+                return ((string)(curObj["OtherTransportType"]));
+            }
+        }
+        
+        [Browsable(false)]
+        
[DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)]
+        public bool IsPriorityNull {
+            get {
+                if ((curObj["Priority"] == null)) {
+                    return true;
+                }
+                else {
+                    return false;
+                }
+            }
+        }
+        
+        [Browsable(true)]
+        
[DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)]
+        [TypeConverter(typeof(WMIValueTypeConverter))]
+        public ushort Priority {
+            get {
+                if ((curObj["Priority"] == null)) {
+                    return System.Convert.ToUInt16(0);
+                }
+                return ((ushort)(curObj["Priority"]));
+            }
+        }
+        
+        [Browsable(false)]
+        
[DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)]
+        public bool IsRetainVhdCopiesOnSourceNull {
+            get {
+                if ((curObj["RetainVhdCopiesOnSource"] == null)) {
+                    return true;
+                }
+                else {
+                    return false;
+                }
+            }
+        }
+        
+        [Browsable(true)]
+        
[DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)]
+        [Description("For storage migration, this could be set to TRUE or 
FALSE\nto determine wheither, " +
+            "at the end of a storage migration, when the\nsource host is 
beeing clean up, the " +
+            "read only VHDs should be removedor not.")]
+        [TypeConverter(typeof(WMIValueTypeConverter))]
+        public bool RetainVhdCopiesOnSource {
+            get {
+                if ((curObj["RetainVhdCopiesOnSource"] == null)) {
+                    return System.Convert.ToBoolean(0);
+                }
+                return ((bool)(curObj["RetainVhdCopiesOnSource"]));
+            }
+            set {
+                curObj["RetainVhdCopiesOnSource"] = value;
+                if (((isEmbedded == false) 
+                            && (AutoCommitProp == true))) {
+                    PrivateLateBoundObject.Put();
+                }
+            }
+        }
+        
+        [Browsable(false)]
+        
[DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)]
+        public bool IsTransportTypeNull {
+            get {
+                if ((curObj["TransportType"] == null)) {
+                    return true;
+                }
+                else {
+                    return false;
+                }
+            }
+        }
+        
+        [Browsable(true)]
+        
[DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)]
+        [TypeConverter(typeof(WMIValueTypeConverter))]
+        public ushort TransportType {
+            get {
+                if ((curObj["TransportType"] == null)) {
+                    return System.Convert.ToUInt16(0);
+                }
+                return ((ushort)(curObj["TransportType"]));
+            }
+        }
+        
+        private bool CheckIfProperClass(System.Management.ManagementScope 
mgmtScope, System.Management.ManagementPath path, 
System.Management.ObjectGetOptions OptionsParam) {
+            if (((path != null) 
+                        && (string.Compare(path.ClassName, 
this.ManagementClassName, true, 
System.Globalization.CultureInfo.InvariantCulture) == 0))) {
+                return true;
+            }
+            else {
+                return CheckIfProperClass(new 
System.Management.ManagementObject(mgmtScope, path, OptionsParam));
+            }
+        }
+        
+        private bool CheckIfProperClass(System.Management.ManagementBaseObject 
theObj) {
+            if (((theObj != null) 
+                        && (string.Compare(((string)(theObj["__CLASS"])), 
this.ManagementClassName, true, 
System.Globalization.CultureInfo.InvariantCulture) == 0))) {
+                return true;
+            }
+            else {
+                System.Array parentClasses = 
((System.Array)(theObj["__DERIVATION"]));
+                if ((parentClasses != null)) {
+                    int count = 0;
+                    for (count = 0; (count < parentClasses.Length); count = 
(count + 1)) {
+                        if 
((string.Compare(((string)(parentClasses.GetValue(count))), 
this.ManagementClassName, true, 
System.Globalization.CultureInfo.InvariantCulture) == 0)) {
+                            return true;
+                        }
+                    }
+                }
+            }
+            return false;
+        }
+        
+        private bool ShouldSerializeBandwidth() {
+            if ((this.IsBandwidthNull == false)) {
+                return true;
+            }
+            return false;
+        }
+        
+        private void ResetDestinationIPAddressList() {
+            curObj["DestinationIPAddressList"] = null;
+            if (((isEmbedded == false) 
+                        && (AutoCommitProp == true))) {
+                PrivateLateBoundObject.Put();
+            }
+        }
+        
+        private void ResetDestinationPlannedVirtualSystemId() {
+            curObj["DestinationPlannedVirtualSystemId"] = null;
+            if (((isEmbedded == false) 
+                        && (AutoCommitProp == true))) {
+                PrivateLateBoundObject.Put();
+            }
+        }
+        
+        private bool ShouldSerializeMigrationType() {
+            if ((this.IsMigrationTypeNull == false)) {
+                return true;
+            }
+            return false;
+        }
+        
+        private void ResetMigrationType() {
+            curObj["MigrationType"] = null;
+            if (((isEmbedded == false) 
+                        && (AutoCommitProp == true))) {
+                PrivateLateBoundObject.Put();
+            }
+        }
+        
+        private bool ShouldSerializePriority() {
+            if ((this.IsPriorityNull == false)) {
+                return true;
+            }
+            return false;
+        }
+        
+        private bool ShouldSerializeRetainVhdCopiesOnSource() {
+            if ((this.IsRetainVhdCopiesOnSourceNull == false)) {
+                return true;
+            }
+            return false;
+        }
+        
+        private void ResetRetainVhdCopiesOnSource() {
+            curObj["RetainVhdCopiesOnSource"] = null;
+            if (((isEmbedded == false) 
+                        && (AutoCommitProp == true))) {
+                PrivateLateBoundObject.Put();
+            }
+        }
+        
+        private bool ShouldSerializeTransportType() {
+            if ((this.IsTransportTypeNull == false)) {
+                return true;
+            }
+            return false;
+        }
+        
+        [Browsable(true)]
+        public void CommitObject() {
+            if ((isEmbedded == false)) {
+                PrivateLateBoundObject.Put();
+            }
+        }
+        
+        [Browsable(true)]
+        public void CommitObject(System.Management.PutOptions putOptions) {
+            if ((isEmbedded == false)) {
+                PrivateLateBoundObject.Put(putOptions);
+            }
+        }
+        
+        private void Initialize() {
+            AutoCommitProp = true;
+            isEmbedded = false;
+        }
+        
+        private static string ConstructPath(string keyInstanceID) {
+            string strPath = 
"ROOT\\virtualization\\v2:Msvm_VirtualSystemMigrationSettingData";
+            strPath = string.Concat(strPath, string.Concat(".InstanceID=", 
string.Concat("\"", string.Concat(keyInstanceID, "\""))));
+            return strPath;
+        }
+        
+        private void InitializeObject(System.Management.ManagementScope 
mgmtScope, System.Management.ManagementPath path, 
System.Management.ObjectGetOptions getOptions) {
+            Initialize();
+            if ((path != null)) {
+                if ((CheckIfProperClass(mgmtScope, path, getOptions) != true)) 
{
+                    throw new System.ArgumentException("Class name does not 
match.");
+                }
+            }
+            PrivateLateBoundObject = new 
System.Management.ManagementObject(mgmtScope, path, getOptions);
+            PrivateSystemProperties = new 
ManagementSystemProperties(PrivateLateBoundObject);
+            curObj = PrivateLateBoundObject;
+        }
+        
+        // Different overloads of GetInstances() help in enumerating instances 
of the WMI class.
+        public static VirtualSystemMigrationSettingDataCollection 
GetInstances() {
+            return GetInstances(null, null, null);
+        }
+        
+        public static VirtualSystemMigrationSettingDataCollection 
GetInstances(string condition) {
+            return GetInstances(null, condition, null);
+        }
+        
+        public static VirtualSystemMigrationSettingDataCollection 
GetInstances(string[] selectedProperties) {
+            return GetInstances(null, null, selectedProperties);
+        }
+        
+        public static VirtualSystemMigrationSettingDataCollection 
GetInstances(string condition, string[] selectedProperties) {
+            return GetInstances(null, condition, selectedProperties);
+        }
+        
+        public static VirtualSystemMigrationSettingDataCollection 
GetInstances(System.Management.ManagementScope mgmtScope, 
System.Management.EnumerationOptions enumOptions) {
+            if ((mgmtScope == null)) {
+                if ((statMgmtScope == null)) {
+                    mgmtScope = new System.Management.ManagementScope();
+                    mgmtScope.Path.NamespacePath = "root\\virtualization\\v2";
+                }
+                else {
+                    mgmtScope = statMgmtScope;
+                }
+            }
+            System.Management.ManagementPath pathObj = new 
System.Management.ManagementPath();
+            pathObj.ClassName = "Msvm_VirtualSystemMigrationSettingData";
+            pathObj.NamespacePath = "root\\virtualization\\v2";
+            System.Management.ManagementClass clsObject = new 
System.Management.ManagementClass(mgmtScope, pathObj, null);
+            if ((enumOptions == null)) {
+                enumOptions = new System.Management.EnumerationOptions();
+                enumOptions.EnsureLocatable = true;
+            }
+            return new 
VirtualSystemMigrationSettingDataCollection(clsObject.GetInstances(enumOptions));
+        }
+        
+        public static VirtualSystemMigrationSettingDataCollection 
GetInstances(System.Management.ManagementScope mgmtScope, string condition) {
+            return GetInstances(mgmtScope, condition, null);
+        }
+        
+        public static VirtualSystemMigrationSettingDataCollection 
GetInstances(System.Management.ManagementScope mgmtScope, string[] 
selectedProperties) {
+            return GetInstances(mgmtScope, null, selectedProperties);
+        }
+        
+        public static VirtualSystemMigrationSettingDataCollection 
GetInstances(System.Management.ManagementScope mgmtScope, string condition, 
string[] selectedProperties) {
+            if ((mgmtScope == null)) {
+                if ((statMgmtScope == null)) {
+                    mgmtScope = new System.Management.ManagementScope();
+                    mgmtScope.Path.NamespacePath = "root\\virtualization\\v2";
+                }
+                else {
+                    mgmtScope = statMgmtScope;
+                }
+            }
+            System.Management.ManagementObjectSearcher ObjectSearcher = new 
System.Management.ManagementObjectSearcher(mgmtScope, new 
SelectQuery("Msvm_VirtualSystemMigrationSettingData", condition, 
selectedProperties));
+            System.Management.EnumerationOptions enumOptions = new 
System.Management.EnumerationOptions();
+            enumOptions.EnsureLocatable = true;
+            ObjectSearcher.Options = enumOptions;
+            return new 
VirtualSystemMigrationSettingDataCollection(ObjectSearcher.Get());
+        }
+        
+        [Browsable(true)]
+        public static VirtualSystemMigrationSettingData CreateInstance() {
+            System.Management.ManagementScope mgmtScope = null;
+            if ((statMgmtScope == null)) {
+                mgmtScope = new System.Management.ManagementScope();
+                mgmtScope.Path.NamespacePath = CreatedWmiNamespace;
+            }
+            else {
+                mgmtScope = statMgmtScope;
+            }
+            System.Management.ManagementPath mgmtPath = new 
System.Management.ManagementPath(CreatedClassName);
+            System.Management.ManagementClass tmpMgmtClass = new 
System.Management.ManagementClass(mgmtScope, mgmtPath, null);
+            return new 
VirtualSystemMigrationSettingData(tmpMgmtClass.CreateInstance());
+        }
+        
+        [Browsable(true)]
+        public void Delete() {
+            PrivateLateBoundObject.Delete();
+        }
+        
+        public enum MigrationTypeValues {
+            
+            Unknown0 = 0,
+            
+            VirtualSystem = 32768,
+            
+            Storage = 32769,
+            
+            Staged = 32770,
+            
+            VirtualSystemAndStorage = 32771,
+            
+            StorageDeepCheck = 32772,
+            
+            NULL_ENUM_VALUE = 32773,
+        }
+        
+        // Enumerator implementation for enumerating instances of the class.
+        public class VirtualSystemMigrationSettingDataCollection : object, 
ICollection {
+            
+            private ManagementObjectCollection privColObj;
+            
+            public 
VirtualSystemMigrationSettingDataCollection(ManagementObjectCollection 
objCollection) {
+                privColObj = objCollection;
+            }
+            
+            public virtual int Count {
+                get {
+                    return privColObj.Count;
+                }
+            }
+            
+            public virtual bool IsSynchronized {
+                get {
+                    return privColObj.IsSynchronized;
+                }
+            }
+            
+            public virtual object SyncRoot {
+                get {
+                    return this;
+                }
+            }
+            
+            public virtual void CopyTo(System.Array array, int index) {
+                privColObj.CopyTo(array, index);
+                int nCtr;
+                for (nCtr = 0; (nCtr < array.Length); nCtr = (nCtr + 1)) {
+                    array.SetValue(new 
VirtualSystemMigrationSettingData(((System.Management.ManagementObject)(array.GetValue(nCtr)))),
 nCtr);
+                }
+            }
+            
+            public virtual System.Collections.IEnumerator GetEnumerator() {
+                return new 
VirtualSystemMigrationSettingDataEnumerator(privColObj.GetEnumerator());
+            }
+            
+            public class VirtualSystemMigrationSettingDataEnumerator : object, 
System.Collections.IEnumerator {
+                
+                private ManagementObjectCollection.ManagementObjectEnumerator 
privObjEnum;
+                
+                public 
VirtualSystemMigrationSettingDataEnumerator(ManagementObjectCollection.ManagementObjectEnumerator
 objEnum) {
+                    privObjEnum = objEnum;
+                }
+                
+                public virtual object Current {
+                    get {
+                        return new 
VirtualSystemMigrationSettingData(((System.Management.ManagementObject)(privObjEnum.Current)));
+                    }
+                }
+                
+                public virtual bool MoveNext() {
+                    return privObjEnum.MoveNext();
+                }
+                
+                public virtual void Reset() {
+                    privObjEnum.Reset();
+                }
+            }
+        }
+        
+        // TypeConverter to handle null values for ValueType properties
+        public class WMIValueTypeConverter : TypeConverter {
+            
+            private TypeConverter baseConverter;
+            
+            private System.Type baseType;
+            
+            public WMIValueTypeConverter(System.Type inBaseType) {
+                baseConverter = TypeDescriptor.GetConverter(inBaseType);
+                baseType = inBaseType;
+            }
+            
+            public override bool 
CanConvertFrom(System.ComponentModel.ITypeDescriptorContext context, 
System.Type srcType) {
+                return baseConverter.CanConvertFrom(context, srcType);
+            }
+            
+            public override bool 
CanConvertTo(System.ComponentModel.ITypeDescriptorContext context, System.Type 
destinationType) {
+                return baseConverter.CanConvertTo(context, destinationType);
+            }
+            
+            public override object 
ConvertFrom(System.ComponentModel.ITypeDescriptorContext context, 
System.Globalization.CultureInfo culture, object value) {
+                return baseConverter.ConvertFrom(context, culture, value);
+            }
+            
+            public override object 
CreateInstance(System.ComponentModel.ITypeDescriptorContext context, 
System.Collections.IDictionary dictionary) {
+                return baseConverter.CreateInstance(context, dictionary);
+            }
+            
+            public override bool 
GetCreateInstanceSupported(System.ComponentModel.ITypeDescriptorContext 
context) {
+                return baseConverter.GetCreateInstanceSupported(context);
+            }
+            
+            public override PropertyDescriptorCollection 
GetProperties(System.ComponentModel.ITypeDescriptorContext context, object 
value, System.Attribute[] attributeVar) {
+                return baseConverter.GetProperties(context, value, 
attributeVar);
+            }
+            
+            public override bool 
GetPropertiesSupported(System.ComponentModel.ITypeDescriptorContext context) {
+                return baseConverter.GetPropertiesSupported(context);
+            }
+            
+            public override 
System.ComponentModel.TypeConverter.StandardValuesCollection 
GetStandardValues(System.ComponentModel.ITypeDescriptorContext context) {
+                return baseConverter.GetStandardValues(context);
+            }
+            
+            public override bool 
GetStandardValuesExclusive(System.ComponentModel.ITypeDescriptorContext 
context) {
+                return baseConverter.GetStandardValuesExclusive(context);
+            }
+            
+            public override bool 
GetStandardValuesSupported(System.ComponentModel.ITypeDescriptorContext 
context) {
+                return baseConverter.GetStandardValuesSupported(context);
+            }
+            
+            public override object 
ConvertTo(System.ComponentModel.ITypeDescriptorContext context, 
System.Globalization.CultureInfo culture, object value, System.Type 
destinationType) {
+                if ((baseType.BaseType == typeof(System.Enum))) {
+                    if ((value.GetType() == destinationType)) {
+                        return value;
+                    }
+                    if ((((value == null) 
+                                && (context != null)) 
+                                && 
(context.PropertyDescriptor.ShouldSerializeValue(context.Instance) == false))) {
+                        return  "NULL_ENUM_VALUE" ;
+                    }
+                    return baseConverter.ConvertTo(context, culture, value, 
destinationType);
+                }
+                if (((baseType == typeof(bool)) 
+                            && (baseType.BaseType == 
typeof(System.ValueType)))) {
+                    if ((((value == null) 
+                                && (context != null)) 
+                                && 
(context.PropertyDescriptor.ShouldSerializeValue(context.Instance) == false))) {
+                        return "";
+                    }
+                    return baseConverter.ConvertTo(context, culture, value, 
destinationType);
+                }
+                if (((context != null) 
+                            && 
(context.PropertyDescriptor.ShouldSerializeValue(context.Instance) == false))) {
+                    return "";
+                }
+                return baseConverter.ConvertTo(context, culture, value, 
destinationType);
+            }
+        }
+        
+        // Embedded class to represent WMI system Properties.
+        
[TypeConverter(typeof(System.ComponentModel.ExpandableObjectConverter))]
+        public class ManagementSystemProperties {
+            
+            private System.Management.ManagementBaseObject 
PrivateLateBoundObject;
+            
+            public 
ManagementSystemProperties(System.Management.ManagementBaseObject 
ManagedObject) {
+                PrivateLateBoundObject = ManagedObject;
+            }
+            
+            [Browsable(true)]
+            public int GENUS {
+                get {
+                    return ((int)(PrivateLateBoundObject["__GENUS"]));
+                }
+            }
+            
+            [Browsable(true)]
+            public string CLASS {
+                get {
+                    return ((string)(PrivateLateBoundObject["__CLASS"]));
+                }
+            }
+            
+            [Browsable(true)]
+            public string SUPERCLASS {
+                get {
+                    return ((string)(PrivateLateBoundObject["__SUPERCLASS"]));
+                }
+            }
+            
+            [Browsable(true)]
+            public string DYNASTY {
+                get {
+                    return ((string)(PrivateLateBoundObject["__DYNASTY"]));
+                }
+            }
+            
+            [Browsable(true)]
+            public string RELPATH {
+                get {
+                    return ((string)(PrivateLateBoundObject["__RELPATH"]));
+                }
+            }
+            
+            [Browsable(true)]
+            public int PROPERTY_COUNT {
+                get {
+                    return ((int)(PrivateLateBoundObject["__PROPERTY_COUNT"]));
+                }
+            }
+            
+            [Browsable(true)]
+            public string[] DERIVATION {
+                get {
+                    return 
((string[])(PrivateLateBoundObject["__DERIVATION"]));
+                }
+            }
+            
+            [Browsable(true)]
+            public string SERVER {
+                get {
+                    return ((string)(PrivateLateBoundObject["__SERVER"]));
+                }
+            }
+            
+            [Browsable(true)]
+            public string NAMESPACE {
+                get {
+                    return ((string)(PrivateLateBoundObject["__NAMESPACE"]));
+                }
+            }
+            
+            [Browsable(true)]
+            public string PATH {
+                get {
+                    return ((string)(PrivateLateBoundObject["__PATH"]));
+                }
+            }
+        }
+    }
+}

http://git-wip-us.apache.org/repos/asf/cloudstack/blob/5a96307f/plugins/hypervisors/hyperv/DotNet/ServerResource/WmiWrappers/WmiWrappers.csproj
----------------------------------------------------------------------
diff --git 
a/plugins/hypervisors/hyperv/DotNet/ServerResource/WmiWrappers/WmiWrappers.csproj
 
b/plugins/hypervisors/hyperv/DotNet/ServerResource/WmiWrappers/WmiWrappers.csproj
index da0c0d6..1a70340 100644
--- 
a/plugins/hypervisors/hyperv/DotNet/ServerResource/WmiWrappers/WmiWrappers.csproj
+++ 
b/plugins/hypervisors/hyperv/DotNet/ServerResource/WmiWrappers/WmiWrappers.csproj
@@ -123,6 +123,9 @@
     <Compile Include="ROOT.virtualization.v2.Msvm_MemorySettingData.cs">
       <SubType>Component</SubType>
     </Compile>
+    <Compile Include="ROOT.virtualization.v2.Msvm_MigrationJob.cs">
+      <SubType>Component</SubType>
+    </Compile>
     <Compile Include="ROOT.virtualization.v2.Msvm_ProcessorSettingData.cs">
       <SubType>Component</SubType>
     </Compile>
@@ -153,6 +156,12 @@
     <Compile 
Include="ROOT.virtualization.v2.Msvm_VirtualSystemManagementServiceSettingData.cs">
       <SubType>Component</SubType>
     </Compile>
+    <Compile 
Include="ROOT.virtualization.v2.Msvm_VirtualSystemMigrationService.cs">
+      <SubType>Component</SubType>
+    </Compile>
+    <Compile 
Include="ROOT.virtualization.v2.Msvm_VirtualSystemMigrationSettingData.cs">
+      <SubType>Component</SubType>
+    </Compile>
     <Compile Include="ROOT.virtualization.v2.Msvm_VirtualSystemSettingData.cs">
       <SubType>Component</SubType>
     </Compile>
@@ -172,4 +181,4 @@
   <Target Name="AfterBuild">
   </Target>
   -->
-</Project>
+</Project>
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/cloudstack/blob/5a96307f/server/src/com/cloud/server/ManagementServerImpl.java
----------------------------------------------------------------------
diff --git a/server/src/com/cloud/server/ManagementServerImpl.java 
b/server/src/com/cloud/server/ManagementServerImpl.java
index 860f165..ee9c04a 100755
--- a/server/src/com/cloud/server/ManagementServerImpl.java
+++ b/server/src/com/cloud/server/ManagementServerImpl.java
@@ -1067,12 +1067,14 @@ public class ManagementServerImpl extends ManagerBase 
implements ManagementServe
             throw ex;
         }
 
-        if (!vm.getHypervisorType().equals(HypervisorType.XenServer) && 
!vm.getHypervisorType().equals(HypervisorType.VMware) &&
-            !vm.getHypervisorType().equals(HypervisorType.KVM) && 
!vm.getHypervisorType().equals(HypervisorType.Ovm)) {
+        if (!vm.getHypervisorType().equals(HypervisorType.XenServer) && 
!vm.getHypervisorType().equals(HypervisorType.VMware)
+                && !vm.getHypervisorType().equals(HypervisorType.KVM) && 
!vm.getHypervisorType().equals(HypervisorType.Ovm)
+                && !vm.getHypervisorType().equals(HypervisorType.Hyperv)) {
             if (s_logger.isDebugEnabled()) {
-                s_logger.debug(vm + " is not XenServer/VMware/KVM/OVM, cannot 
migrate this VM.");
+                s_logger.debug(vm + " is not XenServer/VMware/KVM/OVM/Hyperv, 
cannot migrate this VM.");
             }
-            throw new InvalidParameterValueException("Unsupported Hypervisor 
Type for VM migration, we support " + "XenServer/VMware/KVM/Ovm only");
+            throw new InvalidParameterValueException("Unsupported Hypervisor 
Type for VM migration, we support " +
+                    "XenServer/VMware/KVM/Ovm/Hyperv only");
         }
 
         long srcHostId = vm.getHostId();

http://git-wip-us.apache.org/repos/asf/cloudstack/blob/5a96307f/server/src/com/cloud/vm/UserVmManagerImpl.java
----------------------------------------------------------------------
diff --git a/server/src/com/cloud/vm/UserVmManagerImpl.java 
b/server/src/com/cloud/vm/UserVmManagerImpl.java
index d3dd356..49f4e2e 100755
--- a/server/src/com/cloud/vm/UserVmManagerImpl.java
+++ b/server/src/com/cloud/vm/UserVmManagerImpl.java
@@ -3873,13 +3873,18 @@ public class UserVmManagerImpl extends ManagerBase 
implements UserVmManager, Vir
             ex.addProxyObject(vm.getUuid(), "vmId");
             throw ex;
         }
-        if (!vm.getHypervisorType().equals(HypervisorType.XenServer) && 
!vm.getHypervisorType().equals(HypervisorType.VMware) &&
-            !vm.getHypervisorType().equals(HypervisorType.KVM) && 
!vm.getHypervisorType().equals(HypervisorType.Ovm) &&
-            !vm.getHypervisorType().equals(HypervisorType.Simulator)) {
+        if (!vm.getHypervisorType().equals(HypervisorType.XenServer)
+                && !vm.getHypervisorType().equals(HypervisorType.VMware)
+                && !vm.getHypervisorType().equals(HypervisorType.KVM)
+                && !vm.getHypervisorType().equals(HypervisorType.Ovm)
+                && !vm.getHypervisorType().equals(HypervisorType.Hyperv)
+                && !vm.getHypervisorType().equals(HypervisorType.Simulator)) {
             if (s_logger.isDebugEnabled()) {
-                s_logger.debug(vm + " is not XenServer/VMware/KVM/Ovm, cannot 
migrate this VM.");
+                s_logger.debug(vm
+                        + " is not XenServer/VMware/KVM/Ovm/Hyperv, cannot 
migrate this VM.");
             }
-            throw new InvalidParameterValueException("Unsupported Hypervisor 
Type for VM migration, we support XenServer/VMware/KVM only");
+            throw new InvalidParameterValueException(
+                    "Unsupported Hypervisor Type for VM migration, we support 
XenServer/VMware/KVM/Ovm/Hyperv only");
         }
 
         if (isVMUsingLocalStorage(vm)) {

Reply via email to