Der WMI Filter-Wettbewerb - sind Sie der Ritter in glänzender Rüstung?
Willkommen zu „Die Suche nach dem heiligen Filter des Schreibtisch-WMI“, dieses ist eine globale Suche nach, was Sie benennen konnten „Der vollkommene Filter des Schreibtisch-WMI". Ein WMI Filter, der, indem es WMI Abfragesprache (WQL), sollte verwendet, beschmutzt nur Tischrechner. Es sollte eine allgemeine Frage sein - Bedeutung, die es möglich sein sollte, den Filter in den meisten aktiven Verzeichnisklimas um die Kugel für die Gruppe Politikentstörung zu benutzen.
So ist was ein Schreibtisch wirklich? Gut wirklich in diesem Fall sagen wir, daß es das Entgegengesetzte eines Laptops ist. Hmm, dann was ist ein Laptop? Einfach genug: ein Computer mit einer Batterie! Wir haben den WMI Filter für Laptope bereits finden:
Wählen Sie * von Win32_Battery vor - nicht lieben Sie gerecht die Einfachheit in dieser Frage?
Dieser Filter läßt einen Computer mit einer Batterie mit „ZUTREFFENDEM“ zurück reagieren (weil der WMI Kategorie Fall anwesend ist) und bedeutet, daß ein GPO mit diesem Filter auf Computer mit Batterien zutrifft. Einfaches Recht? Und Sie konnten denken, daß es einfach ist, „es um“ zu den Entdeckungschreibtischen, wie gerade zu drehen:
* von Win32_Battery in dem Verwendbarkeit vorwählen Sie! = 2
oder
Wählen Sie * von Win32_Battery vor, in dem Verwendbarkeit NICHT UNGÜLTIG IST
oder
„Wo nicht X Y“ mögen oder, was auch immer
Möglicherweise ist es, möglicherweise es ist nicht… Ich denke, daß es recht verfluchtes hartes ist! Auf das Beschmutzen der Laptope könnten wir die Kategorien Win32_PortableBattery, Win32_PCMCIAController, Win32_POTSModem außerdem geprüft haben - aber irgendwie denke ich, daß die meisten Leute zustimmen, die das „wesentliche Ting“, das einen Laptop einen Laptop bildet, tatsächlich die Batterieanwesenheit ist!
Aber, unsere Tests für das Beschmutzen nur der SCHREIBTISCHE (Maschinen ohne eine Batterie - ja weiß ich, daß diese Bediener als sie ein „stationäres“ auch miteinschließt), sind nicht ein Erfolg noch gewesen! Wir benötigen vermutlich gerade die korrekte Syntax? Und dieses ist, wohin Sie in die Abbildung erhalten!
Sind Sie in der Lage, geöffnet diese Nuß zu knacken? Es gibt einen kühlen Preis!
Dieses ganz begonnen auf einer Adressenkartei für Gruppe Politikkerle und die Mädchen - benanntes GPTalk - hergestellt und durch Group Policy Guru und MVP Darren beibehalten Beschädigen-Elia - den Kerl nach GPOguy.com und SDM Software. Sie können die Liste verbinden RECHT HIER und nehmen Sie an diesem Wettbewerb zu teil GEWINNEN Sie ein Freiexemplar von:
GPExpert™, das Pak überprüft
ABER Sie müssen die erste Person sein, zum dieser Sache zu knacken, dort sind nur EIN SIEGER - der Sie sein könnte!
Ich werde ankommende Antworten auswerten - Fifo: " Zuerst innen zuerst heraus" method is used. Hopefully we'll see the most simple solution first - simplicity works, right? Actually I wouldn't know in this case would I...
One important thing! We will ask you kindly to TEST any WMI query submissions before sending them to everybody on the list. During your testing, you should use a tool to verify the WMI filter against a minimum of 2 desktops and 2 laptops. You can use the free WMI Filter Validation Tool to test you WMI filters in your environment. Personally I’m also using Scriptomatic version 2 and WBEMTEST for finding the available classes, items, queries etc.
Please have a look at the "rules" further down!
Why do this? Well, because it's fun - and useful at the same time... When looking at it generally, the purpose of this filter is to say: "I want these user settings to apply, but only when the user logs on to stationary machines". This can be used for a lot of security related setting, eg. in the case where Automatically cached Offline Files/Folders are unwanted on stationary machines for certain users etc. The job of most WMI filters placed on User policies is to limit which machines the policy setting(s) should apply to (even though WMI filters could check for user specific things too). Besides from that it's a nice challenge, we can pretty easily "spot" laptops, as they have batteries – and desktops don’t, but that’s not good enough for Mr. WQL, is it?!
Stuff we have tried - and the rules
We’ve been around solutions looking for Win32_SystemEnclosure > ChassisType before - which basically doesn’t work in a WMI filter because that’s an Array (and yes, I've also seen lots of posts on forums out there claiming that particular class is the solution – but for WMI/WQL queries it’s not). If would work in a script (because you can add additional logic to scripts), but we are searching for a WMI Filter - not workarounds of any kind!
As mentioned we tried with the Win32_Battery WMI class. However, as desktops don’t know this class at all, they'll return FALSE no matter what. Basically a desktop computer is gonna say “Heck, I don’t know anything about that class *Panic* I’m out!” – or just “False”... Bummer!
We have also tried PowerSupplyState, Win32_DesktopMonitor, Win32_DisplayConfiguration, Win32_SystemSlot, Win32_Fan and other classes – just haven’t found the perfect “this is definitely a desktop WMI item value or class”…
We're basically looking for something like:
A) Select * from Win32_SomeClassOnlyDesktopsHave
Or
B )Select * from Win32_SomeClass.SomeItem = “SomeValueOnlyDesktopsHave”
Or
C) Some way of saying “if you don’t know the class (eg. Win32_Battery), then apply the GPO anyway”
Again, the “quest” is to find the perfect, *universal*, way of spotting “Non-laptops” or Desktops – it can of course be done by looking for some special computer Manufacturer/Model, BIOS version, specific hardware driver or whatever – but that stuff it most likely gonna be different from environment to environment. Also, if we all just used computer names like “DESKxxx” for desktops and “LAPTxxx” for laptops, we could have used WMI filters for computer name – but unfortunately that’s not the case - or at least I won't consider that a valid solution :)
The thing is, that normally it’s the LAPTOPS that have special hardware – like Batteries and built-in Modems, PCMCIA slots etc. – so they are pretty easy to find. With desktop computers it’s another story – hope you can help us out here!
Please, again, we know lot’s of “workarounds”, but what we need is a *WMI filter* and it has to return *TRUE* for *DESKTOPS* (or let’s call the NON-LAPTOPS or NON-PORTABLES, it doesn’t really matter).
Remember, simplicity works - maybe the answer/solution is pretty straight forward? Feel free to post any additional questions to the mailing list!
Another example of what has been tried
We could maybe try to go for presence of PCI (and not Mini-PCI) or AGP slots, as we expect most desktops to have PCI slots (and laptops to have Mini-PCI, but that would depend on the form factor) – or maybe AGP (but does onboard VGA count as AGP? Any PCI VGA cards left out there? Yeah, probably...). If not we could maybe go for something like this:
A) Select * From Win32_SystemSlot Where SlotDesignation = “PCI%”
Or
B) Select * From Win32_SystemSlot Where SlotDesignation = “AGP”
However, this is not accepted as a solution as we cannot say that all desktop computers have AGP slots. But - maybe you can convince us otherwise?
Other cool Group Policy information:
You'll find additional Group Policy information at these sites:
www.gpanswers.com - The home of Group Policy guru and MVP Jeremy Moskowitz, check out the community there too!
TechNet Group Policy Forum - A brand new Group Policy forum on Microsoft TechNet
The Group Policy Team - The home of the Microsoft Group Policy Team
Jakob H. Heidelberg blog - My own blog, mostly about Group Policy and Security
www.heidelbergit.dk - My website with blog RSS, certifications, LinkedIn info etc.
Hope to hear from you soon - O' Yee Knight of the Microsoft Group Policy Table!
Popularity: 17%
Written by Jakob H. Heidelberg. Read more great feeds at is source WEBSITE
no comments.
Read more articles on Jeremy Moskowitz and otherSoftware and MVP and technet and Group Policy and Microsoft.
- [+] Digg: Feature this article
- [+] Del.icio.us: Bookmark this article
- [+] Furl: Bookmark this article














