option explicit
dim objWMIService
dim managementService
dim fileSystem
const JobStarting = 3
const JobRunning = 4
const JobCompleted = 7
const wmiStarted = 4096
const wmiSuccessful = 0
Main()
'-----------------------------------------------------------------
' Main
'-----------------------------------------------------------------
Sub Main()
dim objArgs, vmName, nicName, MACAddress, computer, vm
set objArgs = WScript.Arguments
set objArgs = WScript.Arguments
if WScript.Arguments.Count = 3 then
vmName = objArgs.Unnamed.Item(0)
nicName = objArgs.Unnamed.Item(1)
MACAddress = objArgs.Unnamed.Item(2)
elseif WScript.Arguments.Count = 2 then
vmName = objArgs.Unnamed.Item(0)
nicName = objArgs.Unnamed.Item(1)
MACAddress = NULL
else
WScript.Echo "usage: cscript ModifyVirtualSystemResource vmName syntheticNicName [MACAddress]"
WScript.Echo "Example: MyFirstVM myStaticNic 00155D02B302"
WScript.Quit(1)
end if
set fileSystem = Wscript.CreateObject("Scripting.FileSystemObject")
computer = "."
set objWMIService = GetObject("winmgmts:\\" & computer & "\root\virtualization")
set managementService = objWMIService.ExecQuery("select * from Msvm_VirtualSystemManagementService").ItemIndex(0)
set vm = GetComputerSystem(vmName)
if ModifyVirtualSystemResources(vm, nicName, MACAddress) then
WriteLog "Done"
WScript.Quit(0)
else
WriteLog "ModifyVirtualSystemResources failed."
WScript.Quit(1)
end if
End Sub
'-----------------------------------------------------------------
' Retrieve Msvm_VirtualComputerSystem from base on its ElementName
'-----------------------------------------------------------------
Function GetComputerSystem(vmElementName)
On Error Resume Next
dim query
query = Format1("select * from Msvm_ComputerSystem where ElementName = '{0}'", vmElementName)
set GetComputerSystem = objWMIService.ExecQuery(query).ItemIndex(0)
if (Err.Number <> 0) then
WriteLog Format1("Err.Number: {0}", Err.Number)
WriteLog Format1("Err.Description:{0}",Err.Description)
WScript.Quit(1)
end if
End Function
'-----------------------------------------------------------------
' GetSyntheticEthernetPortSetting
'-----------------------------------------------------------------
Function GetSyntheticEthernetPortSetting(vmSetting, nicName)
dim query, ethernetsettingsData, instance
set GetSyntheticEthernetPortSetting = Nothing
query = Format1("ASSOCIATORS OF {{0}} WHERE " &_
"resultClass = Msvm_SyntheticEthernetPortsettingData " &_
"AssocClass = Msvm_VirtualSystemSettingDataComponent " &_
"ResultRole = PartComponent " &_
"Role = GroupComponent", vmSetting.Path_.Path)
set ethernetsettingsData = objWMIService.ExecQuery(query)
for each instance in ethernetsettingsData
if lcase(instance.ElementName) = lcase(nicName) then
set GetSyntheticEthernetPortSetting = instance
exit function
end if
next
End Function
'-----------------------------------------------------------------
' ModifyVirtualSystemResources
'-----------------------------------------------------------------
Function ModifyVirtualSystemResources(computerSystem, nicName, MACAddress)
dim query, virtualSystemSetting, ethernetsettingData
dim resourcesettings, objInParam, objOutParams
ModifyVirtualSystemResources = false
query = Format1("ASSOCIATORS OF {{0}} WHERE resultClass = Msvm_VirtualSystemsettingData", computerSystem.Path_.Path)
set virtualSystemSetting = objWMIService.ExecQuery(query).ItemIndex(0)
set ethernetsettingData = GetSyntheticEthernetPortSetting(virtualSystemSetting, nicName)
if (ethernetsettingData Is Nothing) then
WriteLog Format1("'{0}' doesn't exist.", nicName)
exit function
end if
if IsNull(MACAddress) then
ethernetsettingData.StaticMacAddress = false
else
ethernetsettingData.StaticMacAddress = true
ethernetsettingData.Address = MACAddress
end if
resourcesettings = Array(1)
resourcesettings(0) = ethernetsettingData.GetText_(1)
set objInParam = managementService.Methods_("ModifyVirtualSystemResources").InParameters.SpawnInstance_()
objInParam.ComputerSystem = computerSystem.Path_.Path
objInParam.ResourcesettingData = resourcesettings
set objOutParams = managementService.ExecMethod_("ModifyVirtualSystemResources", objInParam)
if objOutParams.ReturnValue = wmiStarted then
if (WMIJobCompleted(objOutParams)) then
WriteLog ("Nic Controller was Modify successfully.")
ModifyVirtualSystemResources = true
end if
elseif objOutParams.ReturnValue = wmiSuccessful then
ModifyVirtualSystemResources = true
else
WriteLog Format1("Modify synthetic Ethernet failed with error:{0}", outParams.ReturnValue)
end if
End Function
'-----------------------------------------------------------------
' Handle wmi Job object
'-----------------------------------------------------------------
Function WMIJobCompleted(outParam)
dim WMIJob, jobState
WMIJobCompleted = true
set WMIJob = objWMIService.Get(outParam.Job)
jobState = WMIJob.JobState
while jobState = JobRunning or jobState = JobStarting
WriteLog Format1("In progress... {0}% completed.",WMIJob.PercentComplete)
WScript.Sleep(1000)
set WMIJob = objWMIService.Get(outParam.Job)
jobState = WMIJob.JobState
wend
if (WMIJob.JobState <> JobCompleted) then
WriteLog Format1("ErrorDescription:{0}", WMIJob.ErrorDescription)
WriteLog Format1("ErrorCode:{0}", WMIJob.ErrorCode)
WMIJobCompleted = false
end if
End Function
'-----------------------------------------------------------------
' Create the console log files.
'-----------------------------------------------------------------
Sub WriteLog(line)
dim fileStream
set fileStream = fileSystem.OpenTextFile(".\ADDSCSIContoller.log", 8, true)
WScript.Echo line
fileStream.WriteLine line
fileStream.Close
End Sub
'------------------------------------------------------------------------------
' The string formating functions to avoid string concatenation.
'------------------------------------------------------------------------------
Function Format1(myString, arg0)
Format1 = Replace(myString, "{0}", arg0)
End Function