' A script that enumerates Software Updates for MOM Agent (not MOM 2005 but higher versions)
' For use with Windows Scripting Host, CScript.exe or WScript.exe
' Copyright (c) Microsoft Corporation. All rights reserved.
' does NOT work agentlessly
'
Dim oAPI, oAgentPatchDiscoveryData
Set oAPI = CreateObject("MOM.ScriptAPI")
set oAgentPatchDiscoveryData = oAPI.CreateDiscoveryData(0, SourceId, ManagedEntityId)
' Connect to Windows Installer object
Function DoPatchDiscovery(ByVal oDisc)
On Error Resume Next
Dim installer : Set installer = Nothing
Set installer = Wscript.CreateObject("WindowsInstaller.Installer") : CheckError
Dim product, productList, count, path, patch, patchList, patchListString, oHealthServiceinstance
On Error Resume Next
Set productList = installer.ProductsEx("","",4) : CheckError
patchListString = ""
For count = 0 to (productList.Count-1)
set product = productList.Item(count)
path = installer.ComponentPath(product.ProductCode, momAgentComponentID)
If path <> "" Then
Set patchList = installer.PatchesEx(product.productCode, "", 7, 1)
For Each patch In patchList
patchListString = patchListString & patch.PatchProperty("DisplayName") & "; "
Next
End If
Next
Set productList = Nothing
Set oHealthServiceinstance = oDisc.CreateClassInstance("$MPElement[Name='SCLibrary!Microsoft.SystemCenter.HealthService']$")
With oHealthServiceinstance
.AddProperty "$MPElement[Name='Windows!Microsoft.Windows.Computer']/PrincipalName$", TargetComputerID
.AddProperty "$MPElement[Name='SCLibrary!Microsoft.SystemCenter.HealthService']/PatchList$", patchListString
End With
call oDisc.AddInstance(oHealthServiceinstance)
End Function
Sub CheckError
Dim message, errRec
If Err = 0 Then Exit Sub
message = Err.Source & " : " & Hex(Err) & ": " & Err.Description
If Not installer Is Nothing Then
Set errRec = installer.LastErrorRecord
If Not errRec Is Nothing Then message = message & vbNewLine & errRec.FormatText
End If
Wscript.Echo message
Wscript.Quit 2
End Sub