// THIS CODE AND INFORMATION IS PROVIDED "AS IS" WITHOUT WARRANTY OF
// ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO
// THE IMPLIED WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR A
// PARTICULAR PURPOSE.
//
// Copyright (c) Microsoft. All rights reserved.
namespace Microsoft.Samples.HyperV.Storage
{
using System;
using System.Globalization;
using System.Management;
using Microsoft.Samples.HyperV.Common;
static class StorageSetParentSample
{
///
/// Updates the parent for a VHD/VHDX.
///
/// The name of the server on which to perform the action.
/// The path to the child VHD/VHDX.
/// The path to the new parent VHD/VHDX.
/// The path to the leaf VHD/VHDX.
/// Indicates whether the parent should be forcibly set when
/// the virtual disk IDs do not match.
internal static void
SetParentVirtualHardDisk(
string ServerName,
string ChildPath,
string ParentPath,
string LeafPath,
string IgnoreIDMismatch)
{
ManagementScope scope =
new ManagementScope("\\\\" + ServerName + "\\root\\virtualization\\v2");
using (ManagementObject imageManagementService =
StorageUtilities.GetImageManagementService(scope))
{
using (ManagementBaseObject inParams =
imageManagementService.GetMethodParameters("SetParentVirtualHardDisk"))
{
inParams["ChildPath"] = ChildPath;
inParams["ParentPath"] = ParentPath;
inParams["LeafPath"] = LeafPath;
inParams["IgnoreIDMismatch"] = IgnoreIDMismatch;
using (ManagementBaseObject outParams = imageManagementService.InvokeMethod(
"SetParentVirtualHardDisk", inParams, null))
{
WmiUtilities.ValidateOutput(outParams, scope);
}
}
}
}
}
}