Hi Steve,
As I noted inside the email that the WMI does work as long as I am
outside of the WE scripting environment. The WScript at the bottom works for
both XP and Windows 7 but, the one inside my app only works for XP.
So in saying that the only conclusion is the format or limitations of
the connectevent. I had mentioned as a comment that maybe the passed in
parms are not being passed in. It would seem that at least one should be but
I am only guessing.
I did try the connecteventwithparameters but which one and how. For I
thought that any WMI event would automatically be passed in, but maybe that
is the issue.
But, it works as is on an XP machine and not the Windows 7 and the
WScript outside of the WE Object Model both work all the time.
I am at a loss and it seems to hinge on how the connectevent is taking
and passing events here.
So I am asking the experts on this, for it would seem they someone has
come across this.
Bruce
Sent: Friday, April 06, 2012 3:47 PM
Subject: Re: ConnectEvent and ConnectObject Issue?
Bruce,
I'm not a WMI expert by any stretch, but I am thinking that the added
security settings in Windows Vista and above may be preventing your
script from working as it did in XP. Do you notice any difference if you
disable the UAC?
Regards,
Steve
On 4/6/2012 3:37 PM, BT wrote:
> Hi Steve,
>
> All you scriptors below is an issue I have asked several on. The one
> that resides inside my Unintall app works on an XP but not on a Windows 7.
> In fact both work on the XP machine, only the one inside my app does
> not
> work on Windows 7.
> The .vbs file at the bottom works on the Windows 7 and alerts each
> time
> there is a change no matter the folder inside the LocalMachine hive of the
> registry.
>
> So the qeustion to ask is your connect object and event routines
> suppose to be the substitute for the standard script CreateObject ?
> Sincerely
> Bruce
>
>
> The first one is inside my Uninstall app around line 323 and does not
> work in Windows 7, below that is the script and does work in Windows 7
> when
> run outside of any WE app, using WScript.
>
> In Uninstall app around line 323:
> Dim strComputer: strComputer = "."
> Dim strWMIKeyPath: strWMIKeyPath =
> "KeyPath='SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Uninstall'"
> ' Universal way for all OS systems for local machine:
> 'Set wmiServices = GetObject("winmgmts:" _
> '& "{impersonationLevel=impersonate}!\\"& strComputer& "\root\default")
>
> Set wmiServices = GetObject("winmgmts:root/default")
> ' Below is one script create but inside we apps you have to split it into
> 2
> parts and is not working on windows 7, but does on XP:
> Set wmiSink = CreateObject( "WbemScripting.SWbemSink")
> wmiSinkConnection = ConnectEvent( wmiSink, "OnObjectReady",
> "Sink_OnObjectReady")
> wmiServices.ExecNotificationQueryAsync wmiSink, _
> "SELECT * FROM RegistryKeyChangeEvent " _
> & "WHERE Hive='HKEY_LOCAL_MACHINE' AND " _
> & strWMIKeyPath
>
> Sub Sink_OnObjectReady( wmiObject, wmiAsyncContext)
> ' It could be failing because of the 2 parms needed.
> msgBox " A registry change has happened! "
> End Sub
>
>
> Below is a standard script that works and reports the registry change:
> 'RegistryChange.vbs
> Set wmiServices = GetObject("winmgmts:root/default")
> Set wmiSink = WScript.CreateObject( _
> "WbemScripting.SWbemSink", "SINK_")
> Dim strWMIKeyPath: strWMIKeyPath =
> "KeyPath='SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Uninstall'"
> wmiServices.ExecNotificationQueryAsync wmiSink, _
> "SELECT * FROM RegistryKeyChangeEvent " _
> & "WHERE Hive='HKEY_LOCAL_MACHINE' AND " _
> & strWMIKeyPath
> WScript.Echo "Listening for Registry Key" _
> & " Change Events..."& vbCrLf
> While(True)
> WScript.Sleep 1000
> Wend
> Sub SINK_OnObjectReady(wmiObject, wmiAsyncContext)
> WScript.Echo "Received Registry Change Event" _
> & vbCrLf& wmiObject.GetObjectText_()
> End Sub
--
Stephen Clower
Product support specialist & App Development
GW Micro, Inc. * 725 Airport North Office Park, Fort Wayne, IN 46825
260-489-3671 * gwmicro.com